2016-08-24 12:49:21 +05:30
|
|
|
class @Build
|
2015-09-25 12:07:36 +05:30
|
|
|
@interval: null
|
2016-06-02 11:05:42 +05:30
|
|
|
@state: null
|
2015-09-25 12:07:36 +05:30
|
|
|
|
2016-08-24 12:49:21 +05:30
|
|
|
constructor: (@page_url, @build_url, @build_status, @state) ->
|
|
|
|
clearInterval(Build.interval)
|
2015-09-25 12:07:36 +05:30
|
|
|
|
2016-06-16 23:09:34 +05:30
|
|
|
# Init breakpoint checker
|
|
|
|
@bp = Breakpoints.get()
|
|
|
|
@hideSidebar()
|
|
|
|
$('.js-build-sidebar').niceScroll()
|
|
|
|
$(document)
|
|
|
|
.off 'click', '.js-sidebar-build-toggle'
|
|
|
|
.on 'click', '.js-sidebar-build-toggle', @toggleSidebar
|
2016-06-02 11:05:42 +05:30
|
|
|
|
2016-06-16 23:09:34 +05:30
|
|
|
$(window)
|
|
|
|
.off 'resize.build'
|
|
|
|
.on 'resize.build', @hideSidebar
|
2016-06-02 11:05:42 +05:30
|
|
|
|
2016-06-16 23:09:34 +05:30
|
|
|
@updateArtifactRemoveDate()
|
|
|
|
|
|
|
|
if $('#build-trace').length
|
|
|
|
@getInitialBuildTrace()
|
|
|
|
@initScrollButtonAffix()
|
|
|
|
|
|
|
|
if @build_status is "running" or @build_status is "pending"
|
2015-09-25 12:07:36 +05:30
|
|
|
#
|
|
|
|
# Bind autoscroll button to follow build output
|
|
|
|
#
|
2016-06-16 23:09:34 +05:30
|
|
|
$('#autoscroll-button').on 'click', ->
|
2015-09-25 12:07:36 +05:30
|
|
|
state = $(this).data("state")
|
|
|
|
if "enabled" is state
|
|
|
|
$(this).data "state", "disabled"
|
|
|
|
$(this).text "enable autoscroll"
|
|
|
|
else
|
|
|
|
$(this).data "state", "enabled"
|
|
|
|
$(this).text "disable autoscroll"
|
|
|
|
|
|
|
|
#
|
|
|
|
# Check for new build output if user still watching build page
|
|
|
|
# Only valid for runnig build when output changes during time
|
|
|
|
#
|
2016-08-24 12:49:21 +05:30
|
|
|
Build.interval = setInterval =>
|
|
|
|
if window.location.href.split("#").first() is @page_url
|
2016-06-16 23:09:34 +05:30
|
|
|
@getBuildTrace()
|
2015-09-25 12:07:36 +05:30
|
|
|
, 4000
|
|
|
|
|
2016-06-16 23:09:34 +05:30
|
|
|
getInitialBuildTrace: ->
|
|
|
|
$.ajax
|
|
|
|
url: @build_url
|
|
|
|
dataType: 'json'
|
|
|
|
success: (build_data) ->
|
|
|
|
$('.js-build-output').html build_data.trace_html
|
|
|
|
|
|
|
|
if build_data.status is 'success' or build_data.status is 'failed'
|
|
|
|
$('.js-build-refresh').remove()
|
|
|
|
|
|
|
|
getBuildTrace: ->
|
|
|
|
$.ajax
|
2016-08-24 12:49:21 +05:30
|
|
|
url: "#{@page_url}/trace.json?state=#{encodeURIComponent(@state)}"
|
2016-06-16 23:09:34 +05:30
|
|
|
dataType: "json"
|
|
|
|
success: (log) =>
|
|
|
|
if log.state
|
|
|
|
@state = log.state
|
|
|
|
|
|
|
|
if log.status is "running"
|
|
|
|
if log.append
|
|
|
|
$('.js-build-output').append log.html
|
|
|
|
else
|
|
|
|
$('.js-build-output').html log.html
|
|
|
|
@checkAutoscroll()
|
|
|
|
else if log.status isnt @build_status
|
2016-08-24 12:49:21 +05:30
|
|
|
Turbolinks.visit @page_url
|
2016-06-16 23:09:34 +05:30
|
|
|
|
2015-09-25 12:07:36 +05:30
|
|
|
checkAutoscroll: ->
|
|
|
|
$("html,body").scrollTop $("#build-trace").height() if "enabled" is $("#autoscroll-button").data("state")
|
|
|
|
|
2016-06-02 11:05:42 +05:30
|
|
|
initScrollButtonAffix: ->
|
|
|
|
$buildScroll = $('#js-build-scroll')
|
|
|
|
$body = $('body')
|
|
|
|
$buildTrace = $('#build-trace')
|
|
|
|
|
|
|
|
$buildScroll.affix(
|
|
|
|
offset:
|
|
|
|
bottom: ->
|
|
|
|
$body.outerHeight() - ($buildTrace.outerHeight() + $buildTrace.offset().top)
|
|
|
|
)
|
|
|
|
|
2016-06-16 23:09:34 +05:30
|
|
|
shouldHideSidebar: ->
|
|
|
|
bootstrapBreakpoint = @bp.getBreakpointSize()
|
|
|
|
|
|
|
|
bootstrapBreakpoint is 'xs' or bootstrapBreakpoint is 'sm'
|
|
|
|
|
|
|
|
toggleSidebar: =>
|
|
|
|
if @shouldHideSidebar()
|
|
|
|
$('.js-build-sidebar')
|
|
|
|
.toggleClass 'right-sidebar-expanded right-sidebar-collapsed'
|
|
|
|
|
|
|
|
hideSidebar: =>
|
|
|
|
if @shouldHideSidebar()
|
|
|
|
$('.js-build-sidebar')
|
|
|
|
.removeClass 'right-sidebar-expanded'
|
|
|
|
.addClass 'right-sidebar-collapsed'
|
|
|
|
else
|
|
|
|
$('.js-build-sidebar')
|
|
|
|
.removeClass 'right-sidebar-collapsed'
|
|
|
|
.addClass 'right-sidebar-expanded'
|
|
|
|
|
|
|
|
updateArtifactRemoveDate: ->
|
|
|
|
$date = $('.js-artifacts-remove')
|
|
|
|
|
|
|
|
if $date.length
|
|
|
|
date = $date.text()
|
|
|
|
$date.text $.timefor(new Date(date), ' ')
|