class CiBuild @interval: null @state: null constructor: (build_url, build_status, build_state) -> clearInterval(CiBuild.interval) @state = build_state @initScrollButtonAffix() if build_status == "running" || build_status == "pending" # # Bind autoscroll button to follow build output # $("#autoscroll-button").bind "click", -> 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 # CiBuild.interval = setInterval => if window.location.href.split("#").first() is build_url last_state = @state $.ajax url: build_url + "/trace.json?state=" + encodeURIComponent(@state) dataType: "json" success: (log) => return unless last_state is @state if log.state and log.status is "running" @state = log.state if log.append $('.fa-refresh').before log.html else $('#build-trace code').html log.html $('#build-trace code').append '<i class="fa fa-refresh fa-spin"/>' @checkAutoscroll() else if log.status isnt build_status Turbolinks.visit build_url , 4000 checkAutoscroll: -> $("html,body").scrollTop $("#build-trace").height() if "enabled" is $("#autoscroll-button").data("state") initScrollButtonAffix: -> $buildScroll = $('#js-build-scroll') $body = $('body') $buildTrace = $('#build-trace') $buildScroll.affix( offset: bottom: -> $body.outerHeight() - ($buildTrace.outerHeight() + $buildTrace.offset().top) ) @CiBuild = CiBuild