var directives = angular.module('core.directives', []); directives.filter('countBadgeByLevel', function () { return function (badges) { // 5 levels var levels = [0, 0, 0, 0, 0]; angular.forEach(badges, function (value, key) { levels[value.level - 1]++; }); return levels; } }); directives.filter('isodate', function () { return function (date) { return date.toISOString(); } }); directives.filter('gz', function () { return function (num) { if (angular.isArray(num)) { var out = []; angular.forEach(num, function (x) { if (x > 0) { out.push(x); } }); return out; } else if (angular.isNumber(num)) { return num > 0; } console.log("fail"); return undefined; } }); directives.directive('navbar', function () { return { restrict: 'E', templateUrl: '/apps/core/navbar.html?noCache=' + noCache }; }); directives.directive('badge', function () { return { restrict: 'E', scope: { badgeDetail: '=badgeDetail' }, template: '' + ' {{badgeDetail.badge.name}}' + ' ' + '' + ' awarded to ' + '{{badgeDetail.person.name}}. ' + 'More' } }); directives.directive('badgeSpan', function () { var template = '' + ' {{badge.name}}' + ' ' + ''; return { restrict: 'E', scope: { badge: '=badge' }, template: template } }); directives.directive('personLink', function () { return { restrict: 'E', scope: { person: '=person' }, template: '{{person.name}}' } }); directives.directive('avatarXl', function () { // TODO: set height="" and width="" // TODO: do not return a useful url unless person.gravatar is set. return { restrict: 'E', scope: { person: '=person' }, template: '' + '' + '' } }); directives.directive('dogtagXl', function () { return { restrict: 'EACM', scope: { person: '=person' }, templateUrl: '/apps/dogtag-xl.html' } }); directives.directive('spinner', function () { return function($scope, element, attr) { var opts = { lines: 13, // The number of lines to draw length: 7, // The length of each line width: 4, // The line thickness radius: 10, // The radius of the inner circle corners: 1, // Corner roundness (0..1) rotate: 0, // The rotation offset color: '#000', // #rgb or #rrggbb speed: 1, // Rounds per second trail: 60, // Afterglow percentage shadow: false, // Whether to render a shadow hwaccel: false, // Whether to use hardware acceleration className: attr.spinnerClass || 'spinner', // The CSS class to assign to the spinner zIndex: 2e9, // The z-index (defaults to 2000000000) top: attr.spinnerTop || 'auto', // Top position relative to parent in px left: attr.spinnerLeft || 'auto' // Left position relative to parent in px }; console.log("attr.spinnerTop =", attr.spinnerTop, "attr.spinnerLeft =", attr.spinnerLeft); var target = element[0]; new Spinner(opts).spin(target); return target; } });