
It seems that directly setting location.hash directly doesn't play nice
with Ember.js URL handling - using it to handle line numbers results in
weird bugs (URL stops being updated after setting hash manually).
This commit gets back to using window.history.pushState() which was
changed to direct hash manipulation in ff1aad3
112 lines
3.1 KiB
CoffeeScript
112 lines
3.1 KiB
CoffeeScript
require 'log'
|
|
require 'travis/lines_selector'
|
|
|
|
Log.DEBUG = false
|
|
Log.LIMIT = 10000
|
|
|
|
Travis.reopen
|
|
LogView: Travis.View.extend
|
|
templateName: 'jobs/log'
|
|
logBinding: 'job.log'
|
|
contextBinding: 'job'
|
|
|
|
didInsertElement: ->
|
|
job = @get('job')
|
|
if job
|
|
job.get('log').fetch()
|
|
job.subscribe()
|
|
|
|
willDestroyElement: ->
|
|
job = @get('job')
|
|
job.unsubscribe() if job
|
|
|
|
PreView: Em.View.extend
|
|
templateName: 'jobs/pre'
|
|
|
|
didInsertElement: ->
|
|
console.log 'log view: did insert' if Log.DEBUG
|
|
@_super.apply this, arguments
|
|
@createEngine()
|
|
|
|
willDestroyElement: ->
|
|
console.log 'log view: will destroy' if Log.DEBUG
|
|
parts = @get('log.parts')
|
|
parts.removeArrayObserver(@, didChange: 'partsDidChange', willChange: 'noop')
|
|
@lineSelector?.willDestroy()
|
|
|
|
versionDidChange: (->
|
|
@rerender() if @get('state') == 'inDOM'
|
|
).observes('log.version')
|
|
|
|
logDidChange: (->
|
|
console.log 'log view: log did change: rerender' if Log.DEBUG
|
|
@rerender() if @get('state') == 'inDOM'
|
|
).observes('log')
|
|
|
|
createEngine: ->
|
|
console.log 'log view: create engine' if Log.DEBUG
|
|
@scroll = new Log.Scroll
|
|
@engine = Log.create(limit: Log.LIMIT, listeners: [@scroll])
|
|
@lineSelector = new Travis.LinesSelector(@$().find('#log'), @scroll)
|
|
@observeParts()
|
|
|
|
observeParts: ->
|
|
parts = @get('log.parts')
|
|
parts.addArrayObserver(@, didChange: 'partsDidChange', willChange: 'noop')
|
|
parts = parts.slice(0)
|
|
@partsDidChange(parts, 0, null, parts.length)
|
|
|
|
partsDidChange: (parts, start, _, added) ->
|
|
console.log 'log view: parts did change' if Log.DEBUG
|
|
for part, i in parts.slice(start, start + added)
|
|
# console.log "limit in log view: #{@get('limited')}"
|
|
break if @get('limited')
|
|
@engine.set(part.number, part.content)
|
|
@propertyDidChange('limited')
|
|
|
|
limited: (->
|
|
@engine?.limit?.limited
|
|
).property()
|
|
|
|
plainTextLogUrl: (->
|
|
Travis.Urls.plainTextLog(id) if id = @get('log.job.id')
|
|
).property('job.log.id')
|
|
|
|
toggleTailing: ->
|
|
Travis.tailing.toggle()
|
|
event.preventDefault()
|
|
|
|
click: (event) ->
|
|
target = $(event.target)
|
|
if target.prop('tagName') == 'P'
|
|
target.closest('.fold').toggleClass('open')
|
|
|
|
actions:
|
|
toTop: () ->
|
|
$(window).scrollTop(0)
|
|
|
|
noop: -> # TODO required?
|
|
|
|
Log.Scroll = ->
|
|
Log.Scroll.prototype = $.extend new Log.Listener,
|
|
insert: (log, data, pos) ->
|
|
@tryScroll() if @numbers
|
|
true
|
|
|
|
tryScroll: ->
|
|
if element = $("#log p:visible.highlight:first")
|
|
$('#main').scrollTop(0)
|
|
$('html, body').scrollTop(element.offset()?.top) # weird, html works in chrome, body in firefox
|
|
|
|
# Log.Logger = ->
|
|
# Log.Logger.prototype = $.extend new Log.Listener,
|
|
# receive: (log, num, string) ->
|
|
# @log("rcv #{num} #{JSON.stringify(string)}")
|
|
# true
|
|
# insert: (log, element, pos) ->
|
|
# @log("ins #{element.id}, #{if pos.before then 'before' else 'after'}: #{pos.before || pos.after || '?'}, #{JSON.stringify(element)}")
|
|
# remove: (log, element) ->
|
|
# @log("rem #{element.id}")
|
|
# log: (line) ->
|
|
# console.log(line)
|