First stab at changing favicon based on build or job state
This commit is contained in:
parent
34d4f1624e
commit
acb70dcac7
|
@ -23,4 +23,8 @@ Controller = Ember.Controller.extend GithubUrlPropertievs,
|
|||
gravatarImage(@get('commit.authorEmail'), 40)
|
||||
).property('commit.authorEmail')
|
||||
|
||||
buildStateDidChange: (->
|
||||
@send('faviconStateDidChange', @get('build.state'))
|
||||
).observes('build.state')
|
||||
|
||||
`export default Controller`
|
||||
|
|
|
@ -16,4 +16,8 @@ Controller = Ember.Controller.extend
|
|||
githubCommit(@get('repo.slug'), @get('commit.sha'))
|
||||
).property('repo.slug', 'commit.sha')
|
||||
|
||||
jobStateDidChange: (->
|
||||
@send('faviconStateDidChange', @get('job.state'))
|
||||
).observes('job.state')
|
||||
|
||||
`export default Controller`
|
||||
|
|
36
app/mixins/build-favicon.coffee
Normal file
36
app/mixins/build-favicon.coffee
Normal file
|
@ -0,0 +1,36 @@
|
|||
`import Ember from 'ember'`
|
||||
`import { colorForState } from 'travis/utils/helpers'`
|
||||
`import FaviconManager from 'travis/utils/favicon-manager'`
|
||||
|
||||
Mixin = Ember.Mixin.create
|
||||
actions:
|
||||
faviconStateDidChange: (state) ->
|
||||
if state
|
||||
@setFaviconForState(state)
|
||||
else
|
||||
@setDefault()
|
||||
|
||||
init: ->
|
||||
@faviconManager = new FaviconManager()
|
||||
|
||||
@_super.apply this, arguments
|
||||
|
||||
setFaviconForState: (state) ->
|
||||
color = colorForState(state)
|
||||
|
||||
images = {
|
||||
red: '',
|
||||
yellow: '',
|
||||
green: '',
|
||||
gray: ''
|
||||
}
|
||||
|
||||
@setFavicon(images[color])
|
||||
|
||||
setDefault: ->
|
||||
@setFavicon('')
|
||||
|
||||
setFavicon: (href) ->
|
||||
@faviconManager.setFavicon(href)
|
||||
|
||||
`export default Mixin`
|
|
@ -15,6 +15,8 @@ Route = TravisRoute.extend
|
|||
deactivate: ->
|
||||
@controllerFor('repo').removeObserver(@get('path'), this, 'contentDidChange')
|
||||
|
||||
@_super.apply(this, arguments)
|
||||
|
||||
contentDidChange: ->
|
||||
path = @get('path')
|
||||
@controllerFor('builds').set('model', @controllerFor('repo').get(path))
|
||||
|
|
|
@ -1,7 +1,8 @@
|
|||
`import TravisRoute from 'travis/routes/basic'`
|
||||
`import config from 'travis/config/environment'`
|
||||
`import BuildFaviconMixin from 'travis/mixins/build-favicon'`
|
||||
|
||||
Route = TravisRoute.extend
|
||||
Route = TravisRoute.extend BuildFaviconMixin,
|
||||
needsAuth: false
|
||||
|
||||
renderTemplate: ->
|
||||
|
|
|
@ -22,6 +22,7 @@ Route = TravisRoute.extend
|
|||
@store.find('build', params.build_id)
|
||||
|
||||
deactivate: ->
|
||||
@_super.apply(this, arguments)
|
||||
@controllerFor('job').set('job', null)
|
||||
@controllerFor('build').set('build', null)
|
||||
|
||||
|
|
|
@ -17,6 +17,8 @@ Route = TravisRoute.extend
|
|||
deactivate: ->
|
||||
@controllerFor('repos').removeObserver('firstObject', this, 'currentRepoDidChange')
|
||||
|
||||
@_super.apply(this, arguments)
|
||||
|
||||
currentRepoDidChange: ->
|
||||
if repo = @controllerFor('repos').get('firstObject')
|
||||
@controllerFor('repo').set('repo', repo)
|
||||
|
|
|
@ -10,6 +10,7 @@ Route = AbstractBuildsRoute.extend(
|
|||
this.controllerFor('builds').set('isPullRequestsList', true)
|
||||
|
||||
deactivate: ->
|
||||
@_super.apply(this, arguments)
|
||||
this.controllerFor('builds').set('isPullRequestsList', false)
|
||||
)
|
||||
|
||||
|
|
|
@ -16,4 +16,6 @@ Route = TravisRoute.extend
|
|||
@controllerFor('build').set('build', null)
|
||||
@controllerFor('job').set('job', null)
|
||||
|
||||
@_super.apply(this, arguments)
|
||||
|
||||
`export default Route`
|
||||
|
|
38
app/utils/favicon-manager.coffee
Normal file
38
app/utils/favicon-manager.coffee
Normal file
|
@ -0,0 +1,38 @@
|
|||
`import Ember from 'ember'`
|
||||
|
||||
manager = (headTag) ->
|
||||
@headTag = headTag if headTag
|
||||
|
||||
return this
|
||||
|
||||
manager.prototype.getHeadTag = ->
|
||||
@headTag || document.getElementsByTagName('head')[0]
|
||||
|
||||
manager.prototype.setFavicon = (href) ->
|
||||
link = @getLinkTag()
|
||||
|
||||
if !link
|
||||
oldLink = link
|
||||
link = @createLinkTag()
|
||||
head = @getHeadTag()
|
||||
head.appendChild(link)
|
||||
|
||||
link.setAttribute('href', href)
|
||||
|
||||
if oldLink
|
||||
head.removeChild(oldLink)
|
||||
|
||||
manager.prototype.getLinkTag = ->
|
||||
links = document.getElementsByTagName('head')[0].getElementsByTagName('link')
|
||||
if links.length
|
||||
for link in links
|
||||
if link.getAttribute('rel').trim() == 'icon'
|
||||
return link
|
||||
|
||||
manager.prototype.createLinkTag = ->
|
||||
link = document.createElement('link')
|
||||
link.setAttribute('rel', 'icon')
|
||||
link.setAttribute('type', 'image/png')
|
||||
document.getElementsByTagName('head')[0].appendChild(link)
|
||||
|
||||
`export default manager`
|
Loading…
Reference in New Issue
Block a user