Fix avatar in the user view
This commit is contained in:
parent
f67eeee8c8
commit
2d8237bd83
3 changed files with 17 additions and 12 deletions
|
@ -4,7 +4,7 @@
|
||||||
<img ng-src="//www.gravatar.com/avatar/{{ data.hash }}?d=404&size={{ size }}"
|
<img ng-src="//www.gravatar.com/avatar/{{ data.hash }}?d=404&size={{ size }}"
|
||||||
ng-if="loadGravatar"
|
ng-if="loadGravatar"
|
||||||
ng-show="hasGravatar"
|
ng-show="hasGravatar"
|
||||||
ng-image-watch="imageCallback">
|
ng-image-watch="imageCallback(result)">
|
||||||
<span class="default-avatar" ng-if="!isLoading && !hasGravatar">
|
<span class="default-avatar" ng-if="!isLoading && !hasGravatar">
|
||||||
<span class="letter" ng-if="data.kind != 'team' || data.name != 'owners'">{{ data.name.charAt(0).toUpperCase() }}</span>
|
<span class="letter" ng-if="data.kind != 'team' || data.name != 'owners'">{{ data.name.charAt(0).toUpperCase() }}</span>
|
||||||
<span class="letter" ng-if="data.kind == 'team' && data.name == 'owners'">Ω</span>
|
<span class="letter" ng-if="data.kind == 'team' && data.name == 'owners'">Ω</span>
|
||||||
|
|
|
@ -1,17 +1,20 @@
|
||||||
/**
|
/**
|
||||||
* Adds a ng-image-watch attribute, which is a callback invoked when the image is loaded or fails.
|
* Adds a ng-image-watch attribute, which is a callback invoked when the image is loaded or fails.
|
||||||
*/
|
*/
|
||||||
angular.module('quay').directive('ngImageWatch', function () {
|
angular.module('quay').directive('ngImageWatch', function ($parse) {
|
||||||
return {
|
return {
|
||||||
restrict: 'A',
|
restrict: 'A',
|
||||||
link: function postLink($scope, $element, $attr) {
|
compile: function($element, attr) {
|
||||||
$element.bind('error', function() {
|
var fn = $parse(attr['ngImageWatch']);
|
||||||
$scope.$eval($attr.ngImageWatch)(false);
|
return function(scope, element) {
|
||||||
|
element.bind('error', function() {
|
||||||
|
fn(scope, {result: false});
|
||||||
});
|
});
|
||||||
|
|
||||||
$element.bind('load', function() {
|
element.bind('load', function() {
|
||||||
$scope.$eval($attr.ngImageWatch)(true);
|
fn(scope, {result: true});
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
}
|
||||||
};
|
};
|
||||||
});
|
});
|
|
@ -12,7 +12,7 @@ angular.module('quay').directive('avatar', function () {
|
||||||
'data': '=data',
|
'data': '=data',
|
||||||
'size': '=size'
|
'size': '=size'
|
||||||
},
|
},
|
||||||
controller: function($scope, $element, AvatarService, Config, UIService) {
|
controller: function($scope, $element, AvatarService, Config, UIService, $timeout) {
|
||||||
$scope.AvatarService = AvatarService;
|
$scope.AvatarService = AvatarService;
|
||||||
$scope.Config = Config;
|
$scope.Config = Config;
|
||||||
$scope.isLoading = true;
|
$scope.isLoading = true;
|
||||||
|
@ -20,8 +20,10 @@ angular.module('quay').directive('avatar', function () {
|
||||||
$scope.loadGravatar = false;
|
$scope.loadGravatar = false;
|
||||||
|
|
||||||
$scope.imageCallback = function(r) {
|
$scope.imageCallback = function(r) {
|
||||||
|
$timeout(function() {
|
||||||
$scope.isLoading = false;
|
$scope.isLoading = false;
|
||||||
$scope.hasGravatar = r;
|
$scope.hasGravatar = r;
|
||||||
|
}, 1);
|
||||||
};
|
};
|
||||||
|
|
||||||
$scope.$watch('size', function(size) {
|
$scope.$watch('size', function(size) {
|
||||||
|
|
Reference in a new issue