1
0
mirror of https://github.com/LaCasemate/fab-manager.git synced 2025-01-20 09:52:19 +01:00
2016-03-23 18:39:41 +01:00

431 lines
15 KiB
JavaScript

/**
* angular-growl-v2 - v0.7.8 - 2015-10-25
* http://janstevens.github.io/angular-growl-2
* Copyright (c) 2015 Marco Rinck,Jan Stevens,Silvan van Leeuwen; Licensed MIT
*/
angular.module('angular-growl', []);
angular.module('angular-growl').directive('growl', [function () {
'use strict';
return {
restrict: 'A',
templateUrl: 'templates/growl/growl.html',
replace: false,
scope: {
reference: '@',
inline: '=',
limitMessages: '='
},
controller: [
'$scope',
'$interval',
'growl',
'growlMessages',
function ($scope, $interval, growl, growlMessages) {
$scope.referenceId = $scope.reference || 0;
growlMessages.initDirective($scope.referenceId, $scope.limitMessages);
$scope.growlMessages = growlMessages;
$scope.inlineMessage = angular.isDefined($scope.inline) ? $scope.inline : growl.inlineMessages();
$scope.$watch('limitMessages', function (limitMessages) {
var directive = growlMessages.directives[$scope.referenceId];
if (!angular.isUndefined(limitMessages) && !angular.isUndefined(directive)) {
directive.limitMessages = limitMessages;
}
});
$scope.stopTimeoutClose = function (message) {
if (!message.clickToClose) {
angular.forEach(message.promises, function (promise) {
$interval.cancel(promise);
});
if (message.close) {
growlMessages.deleteMessage(message);
} else {
message.close = true;
}
}
};
$scope.alertClasses = function (message) {
return {
'alert-success': message.severity === 'success',
'alert-error': message.severity === 'error',
'alert-danger': message.severity === 'error',
'alert-info': message.severity === 'info',
'alert-warning': message.severity === 'warning',
'icon': message.disableIcons === false,
'alert-dismissable': !message.disableCloseButton
};
};
$scope.showCountDown = function (message) {
return !message.disableCountDown && message.ttl > 0;
};
$scope.wrapperClasses = function () {
var classes = {};
classes['growl-fixed'] = !$scope.inlineMessage;
classes[growl.position()] = true;
return classes;
};
$scope.computeTitle = function (message) {
var ret = {
'success': 'Success',
'error': 'Error',
'info': 'Information',
'warn': 'Warning'
};
return ret[message.severity];
};
}
]
};
}]);
angular.module('angular-growl').run([
'$templateCache',
function ($templateCache) {
'use strict';
if ($templateCache.get('templates/growl/growl.html') === undefined) {
$templateCache.put('templates/growl/growl.html', '<div class="growl-container" ng-class="wrapperClasses()">' + '<div class="growl-item alert" ng-repeat="message in growlMessages.directives[referenceId].messages" ng-class="alertClasses(message)" ng-click="stopTimeoutClose(message)">' + '<button type="button" class="close" data-dismiss="alert" aria-hidden="true" ng-click="growlMessages.deleteMessage(message)" ng-show="!message.disableCloseButton">&times;</button>' + '<button type="button" class="close" aria-hidden="true" ng-show="showCountDown(message)">{{message.countdown}}</button>' + '<h4 class="growl-title" ng-show="message.title" ng-bind="message.title"></h4>' + '<div class="growl-message" ng-bind-html="message.text"></div>' + '</div>' + '</div>');
}
}
]);
angular.module('angular-growl').provider('growl', function () {
'use strict';
var _ttl = {
success: null,
error: null,
warning: null,
info: null
}, _messagesKey = 'messages', _messageTextKey = 'text', _messageTitleKey = 'title', _messageSeverityKey = 'severity', _messageTTLKey = 'ttl', _onlyUniqueMessages = true, _messageVariableKey = 'variables', _referenceId = 0, _inline = false, _position = 'top-right', _disableCloseButton = false, _disableIcons = false, _reverseOrder = false, _disableCountDown = false, _translateMessages = true;
this.globalTimeToLive = function (ttl) {
if (typeof ttl === 'object') {
for (var k in ttl) {
if (ttl.hasOwnProperty(k)) {
_ttl[k] = ttl[k];
}
}
} else {
for (var severity in _ttl) {
if (_ttl.hasOwnProperty(severity)) {
_ttl[severity] = ttl;
}
}
}
return this;
};
this.globalTranslateMessages = function (translateMessages) {
_translateMessages = translateMessages;
return this;
};
this.globalDisableCloseButton = function (disableCloseButton) {
_disableCloseButton = disableCloseButton;
return this;
};
this.globalDisableIcons = function (disableIcons) {
_disableIcons = disableIcons;
return this;
};
this.globalReversedOrder = function (reverseOrder) {
_reverseOrder = reverseOrder;
return this;
};
this.globalDisableCountDown = function (countDown) {
_disableCountDown = countDown;
return this;
};
this.messageVariableKey = function (messageVariableKey) {
_messageVariableKey = messageVariableKey;
return this;
};
this.globalInlineMessages = function (inline) {
_inline = inline;
return this;
};
this.globalPosition = function (position) {
_position = position;
return this;
};
this.messagesKey = function (messagesKey) {
_messagesKey = messagesKey;
return this;
};
this.messageTextKey = function (messageTextKey) {
_messageTextKey = messageTextKey;
return this;
};
this.messageTitleKey = function (messageTitleKey) {
_messageTitleKey = messageTitleKey;
return this;
};
this.messageSeverityKey = function (messageSeverityKey) {
_messageSeverityKey = messageSeverityKey;
return this;
};
this.messageTTLKey = function (messageTTLKey) {
_messageTTLKey = messageTTLKey;
return this;
};
this.onlyUniqueMessages = function (onlyUniqueMessages) {
_onlyUniqueMessages = onlyUniqueMessages;
return this;
};
this.serverMessagesInterceptor = [
'$q',
'growl',
function ($q, growl) {
function checkResponse(response) {
if (response !== undefined && response.data && response.data[_messagesKey] && response.data[_messagesKey].length > 0) {
growl.addServerMessages(response.data[_messagesKey]);
}
}
return {
'response': function (response) {
checkResponse(response);
return response;
},
'responseError': function (rejection) {
checkResponse(rejection);
return $q.reject(rejection);
}
};
}
];
this.$get = [
'$rootScope',
'$interpolate',
'$sce',
'$filter',
'$interval',
'growlMessages',
function ($rootScope, $interpolate, $sce, $filter, $interval, growlMessages) {
var translate;
growlMessages.onlyUnique = _onlyUniqueMessages;
growlMessages.reverseOrder = _reverseOrder;
try {
translate = $filter('translate');
} catch (e) {
}
function broadcastMessage(message) {
if (translate && message.translateMessage) {
message.text = translate(message.text, message.variables) || message.text;
message.title = translate(message.title) || message.title;
} else {
var polation = $interpolate(message.text);
message.text = polation(message.variables);
}
var addedMessage = growlMessages.addMessage(message);
$rootScope.$broadcast('growlMessage', message);
$interval(function () {
}, 0, 1);
return addedMessage;
}
function sendMessage(text, config, severity) {
var _config = config || {}, message;
message = {
text: text,
title: _config.title,
severity: severity,
ttl: _config.ttl || _ttl[severity],
variables: _config.variables || {},
disableCloseButton: _config.disableCloseButton === undefined ? _disableCloseButton : _config.disableCloseButton,
disableIcons: _config.disableIcons === undefined ? _disableIcons : _config.disableIcons,
disableCountDown: _config.disableCountDown === undefined ? _disableCountDown : _config.disableCountDown,
position: _config.position || _position,
referenceId: _config.referenceId || _referenceId,
translateMessage: _config.translateMessage === undefined ? _translateMessages : _config.translateMessage,
destroy: function () {
growlMessages.deleteMessage(message);
},
setText: function (newText) {
message.text = $sce.trustAsHtml(String(newText));
},
onclose: _config.onclose,
onopen: _config.onopen
};
return broadcastMessage(message);
}
function warning(text, config) {
return sendMessage(text, config, 'warning');
}
function error(text, config) {
return sendMessage(text, config, 'error');
}
function info(text, config) {
return sendMessage(text, config, 'info');
}
function success(text, config) {
return sendMessage(text, config, 'success');
}
function general(text, config, severity) {
severity = (severity || 'error').toLowerCase();
return sendMessage(text, config, severity);
}
function addServerMessages(messages) {
if (!messages || !messages.length) {
return;
}
var i, message, severity, length;
length = messages.length;
for (i = 0; i < length; i++) {
message = messages[i];
if (message[_messageTextKey]) {
severity = (message[_messageSeverityKey] || 'error').toLowerCase();
var config = {};
config.variables = message[_messageVariableKey] || {};
config.title = message[_messageTitleKey];
if (message[_messageTTLKey]) {
config.ttl = message[_messageTTLKey];
}
sendMessage(message[_messageTextKey], config, severity);
}
}
}
function onlyUnique() {
return _onlyUniqueMessages;
}
function reverseOrder() {
return _reverseOrder;
}
function inlineMessages() {
return _inline;
}
function position() {
return _position;
}
return {
warning: warning,
error: error,
info: info,
success: success,
general: general,
addServerMessages: addServerMessages,
onlyUnique: onlyUnique,
reverseOrder: reverseOrder,
inlineMessages: inlineMessages,
position: position
};
}
];
});
angular.module('angular-growl').service('growlMessages', [
'$sce',
'$interval',
function ($sce, $interval) {
'use strict';
var self = this;
this.directives = {};
var preloadDirectives = {};
function preLoad(referenceId) {
var directive;
if (preloadDirectives[referenceId]) {
directive = preloadDirectives[referenceId];
} else {
directive = preloadDirectives[referenceId] = { messages: [] };
}
return directive;
}
function directiveForRefId(referenceId) {
var refId = referenceId || 0;
return self.directives[refId] || preloadDirectives[refId];
}
this.initDirective = function (referenceId, limitMessages) {
if (preloadDirectives[referenceId]) {
this.directives[referenceId] = preloadDirectives[referenceId];
this.directives[referenceId].limitMessages = limitMessages;
} else {
this.directives[referenceId] = {
messages: [],
limitMessages: limitMessages
};
}
return this.directives[referenceId];
};
this.getAllMessages = function (referenceId) {
referenceId = referenceId || 0;
var messages;
if (directiveForRefId(referenceId)) {
messages = directiveForRefId(referenceId).messages;
} else {
messages = [];
}
return messages;
};
this.destroyAllMessages = function (referenceId) {
var messages = this.getAllMessages(referenceId);
for (var i = messages.length - 1; i >= 0; i--) {
messages[i].destroy();
}
var directive = directiveForRefId(referenceId);
if (directive) {
directive.messages = [];
}
};
this.addMessage = function (message) {
var directive, messages, found, msgText;
if (this.directives[message.referenceId]) {
directive = this.directives[message.referenceId];
} else {
directive = preLoad(message.referenceId);
}
messages = directive.messages;
if (this.onlyUnique) {
angular.forEach(messages, function (msg) {
msgText = $sce.getTrustedHtml(msg.text);
if (message.text === msgText && message.severity === msg.severity && message.title === msg.title) {
found = true;
}
});
if (found) {
return;
}
}
message.text = $sce.trustAsHtml(String(message.text));
if (message.ttl && message.ttl !== -1) {
message.countdown = message.ttl / 1000;
message.promises = [];
message.close = false;
message.countdownFunction = function () {
if (message.countdown > 1) {
message.countdown--;
message.promises.push($interval(message.countdownFunction, 1000, 1, 1));
} else {
message.countdown--;
}
};
}
if (angular.isDefined(directive.limitMessages)) {
var diff = messages.length - (directive.limitMessages - 1);
if (diff > 0) {
messages.splice(directive.limitMessages - 1, diff);
}
}
if (this.reverseOrder) {
messages.unshift(message);
} else {
messages.push(message);
}
if (typeof message.onopen === 'function') {
message.onopen();
}
if (message.ttl && message.ttl !== -1) {
var self = this;
message.promises.push($interval(angular.bind(this, function () {
self.deleteMessage(message);
}), message.ttl, 1, 1));
message.promises.push($interval(message.countdownFunction, 1000, 1, 1));
}
return message;
};
this.deleteMessage = function (message) {
var messages = this.getAllMessages(message.referenceId), index = -1;
for (var i in messages) {
if (messages.hasOwnProperty(i)) {
index = messages[i] === message ? i : index;
}
}
if (index > -1) {
messages[index].close = true;
messages.splice(index, 1);
}
if (typeof message.onclose === 'function') {
message.onclose();
}
};
}
]);