203 lines
6.9 KiB
JavaScript
203 lines
6.9 KiB
JavaScript
(function() {
|
|
var bind = function(fn, me){ return function(){ return fn.apply(me, arguments); }; };
|
|
|
|
this.Build = (function() {
|
|
Build.interval = null;
|
|
|
|
Build.state = null;
|
|
|
|
function Build(options) {
|
|
this.page_url = options.page_url;
|
|
this.build_url = options.build_url;
|
|
this.build_status = options.build_status;
|
|
this.state = options.state1;
|
|
this.build_stage = options.build_stage;
|
|
this.hideSidebar = bind(this.hideSidebar, this);
|
|
this.toggleSidebar = bind(this.toggleSidebar, this);
|
|
this.updateDropdown = bind(this.updateDropdown, this);
|
|
this.$document = $(document);
|
|
clearInterval(Build.interval);
|
|
// Init breakpoint checker
|
|
this.bp = Breakpoints.get();
|
|
this.initSidebar();
|
|
|
|
this.populateJobs(this.build_stage);
|
|
this.updateStageDropdownText(this.build_stage);
|
|
|
|
$(window).off('resize.build').on('resize.build', this.hideSidebar);
|
|
this.$document.off('click', '.stage-item').on('click', '.stage-item', this.updateDropdown);
|
|
$('#js-build-scroll > a').off('click').on('click', this.stepTrace);
|
|
this.updateArtifactRemoveDate();
|
|
if ($('#build-trace').length) {
|
|
this.getInitialBuildTrace();
|
|
this.initScrollButtons();
|
|
}
|
|
if (this.build_status === "running" || this.build_status === "pending") {
|
|
$('#autoscroll-button').on('click', function() {
|
|
var state;
|
|
state = $(this).data("state");
|
|
if ("enabled" === state) {
|
|
$(this).data("state", "disabled");
|
|
return $(this).text("enable autoscroll");
|
|
} else {
|
|
$(this).data("state", "enabled");
|
|
return $(this).text("disable autoscroll");
|
|
}
|
|
//
|
|
// Bind autoscroll button to follow build output
|
|
//
|
|
});
|
|
Build.interval = setInterval((function(_this) {
|
|
return function() {
|
|
if (window.location.href.split("#").first() === _this.page_url) {
|
|
return _this.getBuildTrace();
|
|
}
|
|
};
|
|
//
|
|
// Check for new build output if user still watching build page
|
|
// Only valid for runnig build when output changes during time
|
|
//
|
|
})(this), 4000);
|
|
}
|
|
}
|
|
|
|
Build.prototype.initSidebar = function() {
|
|
this.$sidebar = $('.js-build-sidebar');
|
|
this.sidebarTranslationLimits = {
|
|
min: $('.navbar-gitlab').outerHeight() + $('.layout-nav').outerHeight()
|
|
}
|
|
this.sidebarTranslationLimits.max = this.sidebarTranslationLimits.min + $('.scrolling-tabs-container').outerHeight();
|
|
this.$sidebar.css({
|
|
top: this.sidebarTranslationLimits.max
|
|
});
|
|
this.$sidebar.niceScroll();
|
|
this.hideSidebar();
|
|
this.$document.off('click', '.js-sidebar-build-toggle').on('click', '.js-sidebar-build-toggle', this.toggleSidebar);
|
|
this.$document.off('scroll.translateSidebar').on('scroll.translateSidebar', this.translateSidebar.bind(this));
|
|
};
|
|
|
|
Build.prototype.getInitialBuildTrace = function() {
|
|
var removeRefreshStatuses = ['success', 'failed', 'canceled', 'skipped']
|
|
|
|
return $.ajax({
|
|
url: this.build_url,
|
|
dataType: 'json',
|
|
success: function(build_data) {
|
|
$('.js-build-output').html(build_data.trace_html);
|
|
if (removeRefreshStatuses.indexOf(build_data.status) >= 0) {
|
|
return $('.js-build-refresh').remove();
|
|
}
|
|
}
|
|
});
|
|
};
|
|
|
|
Build.prototype.getBuildTrace = function() {
|
|
return $.ajax({
|
|
url: this.page_url + "/trace.json?state=" + (encodeURIComponent(this.state)),
|
|
dataType: "json",
|
|
success: (function(_this) {
|
|
return function(log) {
|
|
if (log.state) {
|
|
_this.state = log.state;
|
|
}
|
|
if (log.status === "running") {
|
|
if (log.append) {
|
|
$('.js-build-output').append(log.html);
|
|
} else {
|
|
$('.js-build-output').html(log.html);
|
|
}
|
|
return _this.checkAutoscroll();
|
|
} else if (log.status !== _this.build_status) {
|
|
return Turbolinks.visit(_this.page_url);
|
|
}
|
|
};
|
|
})(this)
|
|
});
|
|
};
|
|
|
|
Build.prototype.checkAutoscroll = function() {
|
|
if ("enabled" === $("#autoscroll-button").data("state")) {
|
|
return $("html,body").scrollTop($("#build-trace").height());
|
|
}
|
|
};
|
|
|
|
Build.prototype.initScrollButtons = function() {
|
|
var $body, $buildScroll, $buildTrace;
|
|
$buildScroll = $('#js-build-scroll');
|
|
$body = $('body');
|
|
$buildTrace = $('#build-trace');
|
|
return $buildScroll.affix({
|
|
offset: {
|
|
bottom: function() {
|
|
return $body.outerHeight() - ($buildTrace.outerHeight() + $buildTrace.offset().top);
|
|
}
|
|
}
|
|
});
|
|
};
|
|
|
|
Build.prototype.shouldHideSidebar = function() {
|
|
var bootstrapBreakpoint;
|
|
bootstrapBreakpoint = this.bp.getBreakpointSize();
|
|
return bootstrapBreakpoint === 'xs' || bootstrapBreakpoint === 'sm';
|
|
};
|
|
|
|
Build.prototype.toggleSidebar = function() {
|
|
if (this.shouldHideSidebar()) {
|
|
return this.$sidebar.toggleClass('right-sidebar-expanded right-sidebar-collapsed');
|
|
}
|
|
};
|
|
|
|
Build.prototype.translateSidebar = function(e) {
|
|
var newPosition = this.sidebarTranslationLimits.max - document.body.scrollTop;
|
|
if (newPosition < this.sidebarTranslationLimits.min) newPosition = this.sidebarTranslationLimits.min;
|
|
this.$sidebar.css({
|
|
top: newPosition
|
|
});
|
|
};
|
|
|
|
Build.prototype.hideSidebar = function() {
|
|
if (this.shouldHideSidebar()) {
|
|
return this.$sidebar.removeClass('right-sidebar-expanded').addClass('right-sidebar-collapsed');
|
|
} else {
|
|
return this.$sidebar.removeClass('right-sidebar-collapsed').addClass('right-sidebar-expanded');
|
|
}
|
|
};
|
|
|
|
Build.prototype.updateArtifactRemoveDate = function() {
|
|
var $date, date;
|
|
$date = $('.js-artifacts-remove');
|
|
if ($date.length) {
|
|
date = $date.text();
|
|
return $date.text($.timefor(new Date(date.replace(/([0-9]+)-([0-9]+)-([0-9]+)/g, '$1/$2/$3')), ' '));
|
|
}
|
|
};
|
|
|
|
Build.prototype.populateJobs = function(stage) {
|
|
$('.build-job').hide();
|
|
$('.build-job[data-stage="' + stage + '"]').show();
|
|
};
|
|
|
|
Build.prototype.updateStageDropdownText = function(stage) {
|
|
$('.stage-selection').text(stage);
|
|
};
|
|
|
|
Build.prototype.updateDropdown = function(e) {
|
|
e.preventDefault();
|
|
var stage = e.currentTarget.text;
|
|
this.updateStageDropdownText(stage);
|
|
this.populateJobs(stage);
|
|
};
|
|
|
|
Build.prototype.stepTrace = function(e) {
|
|
e.preventDefault();
|
|
$currentTarget = $(e.currentTarget);
|
|
$.scrollTo($currentTarget.attr('href'), {
|
|
offset: -($('.navbar-gitlab').outerHeight() + $('.layout-nav').outerHeight())
|
|
});
|
|
};
|
|
|
|
return Build;
|
|
|
|
})();
|
|
|
|
}).call(this);
|