Calculate actual avatar URL in model

repeated logic for Gravatar fallback
This commit is contained in:
Jonas Weber 2016-01-01 17:09:54 +01:00 committed by Piotr Sarnacki
parent 573ebfd406
commit 8abc24f04b
5 changed files with 20 additions and 29 deletions

View File

@ -1,5 +1,4 @@
`import Ember from 'ember'`
`import { gravatarImage } from 'travis/utils/urls'`
`import GithubUrlPropertievs from 'travis/mixins/github-url-properties'`
`import { durationFrom, safe } from 'travis/utils/helpers'`
`import { githubCommit } from 'travis/utils/urls'`
@ -10,22 +9,6 @@ BuildHeaderComponent = Ember.Component.extend
classNames: ['build-header']
classNameBindings: ['item.state']
committerAvatarUrl: (->
if url = @get('commit.committerAvatarUrl')
url
else
email = @get('commit.committerEmail')
gravatarImage(email, 40)
).property('commit.committerEmail', 'commit.committerAvatarUrl')
authorAvatarUrl: (->
if url = @get('commit.authorAvatarUrl')
url
else
email = @get('commit.authorEmail')
gravatarImage(email, 40)
).property('commit.authorEmail', 'commit.authorAvatarUrl')
isJob: (->
if @get('item.build') then true else false
).property('item')

View File

@ -1,5 +1,4 @@
`import Ember from 'ember'`
`import { gravatarImage } from 'travis/utils/urls'`
`import { githubCommit as githubCommitUrl } from 'travis/utils/urls'`
BuildsItemComponent = Ember.Component.extend
@ -7,14 +6,6 @@ BuildsItemComponent = Ember.Component.extend
classNameBindings: ['build.state']
classNames: ['row-li', 'pr-row']
authorAvatarUrl: (->
if url = @get('build.commit.authorAvatarUrl')
url
else
email = @get('build.commit.authorEmail')
gravatarImage(email, 40)
).property('build.commit.authorEmail', 'build.commit.authorAvatarUrl')
urlGithubCommit: (->
githubCommitUrl(@get('build.repo.slug'), @get('build.commit.sha'))
).property('build.commit.sha')

View File

@ -1,6 +1,7 @@
`import Ember from 'ember'`
`import Model from 'travis/models/model'`
`import Build from 'travis/models/build'`
`import { gravatarImage } from 'travis/utils/urls'`
Commit = Model.extend
sha: DS.attr()
@ -34,4 +35,20 @@ Commit = Model.extend
@get('authorEmail') == @get('committerEmail')
).property('authorName', 'authorEmail', 'committerName', 'committerEmail')
authorAvatarUrl: (->
if url = @get('authorAvatarUrl')
url
else
email = @get('authorEmail')
gravatarImage(email, 40)
).property('authorEmail', 'authorAvatarUrl')
committerAvatarUrl: (->
if url = @get('committerAvatarUrl')
url
else
email = @get('committerEmail')
gravatarImage(email, 40)
).property('committerEmail', 'committerAvatarUrl')
`export default Commit`

View File

@ -38,11 +38,11 @@
</ul>
<p class="commit-author">
{{#if commit.authorName}}
<img src={{authorAvatarUrl}} alt="comitter avatar" aria-hidden="true"><span class="label-align">{{commit.authorName}} authored{{#if commit.authorIsCommitter}} and committed{{/if}}</span>
<img src={{commit.authorAvatarUrl}} alt="author avatar" aria-hidden="true"><span class="label-align">{{commit.authorName}} authored{{#if commit.authorIsCommitter}} and committed{{/if}}</span>
{{/if}}
{{#unless commit.authorIsCommitter}}
{{#if commit.committerName}}
<img src={{committerAvatarUrl}} alt="comitter avatar" aria-hidden="true"><span class="label-align">{{commit.committerName}} committed</span>
<img src={{commit.committerAvatarUrl}} alt="comitter avatar" aria-hidden="true"><span class="label-align">{{commit.committerName}} committed</span>
{{/if}}
{{/unless}}
</p>

View File

@ -20,7 +20,7 @@
{{/unless}}
</div>
<div class="row-item row-committer">
<img class="avatar" src={{authorAvatarUrl}} alt="{{build.commit.committerName}} avatar">
<img class="avatar" src={{build.commit.authorAvatarUrl}} alt="{{build.commit.authorName}} avatar">
<span class="label-align">{{build.commit.committerName}}</span>
</div>
</div>