http://git-wip-us.apache.org/repos/asf/incubator-griffin/blob/f629d0f4/griffin-ui/bower_components/AngularJS-Toaster/toaster.js
----------------------------------------------------------------------
diff --git a/griffin-ui/bower_components/AngularJS-Toaster/toaster.js 
b/griffin-ui/bower_components/AngularJS-Toaster/toaster.js
deleted file mode 100644
index 654185d..0000000
--- a/griffin-ui/bower_components/AngularJS-Toaster/toaster.js
+++ /dev/null
@@ -1,504 +0,0 @@
-/* global angular */
-(function (window, document) {
-    'use strict';
-
-    /*
-     * AngularJS Toaster
-     * Version: 1.2.0
-     *
-     * Copyright 2013-2016 Jiri Kavulak.
-     * All Rights Reserved.
-     * Use, reproduction, distribution, and modification of this code is 
subject to the terms and
-     * conditions of the MIT license, available at 
http://www.opensource.org/licenses/mit-license.php
-     *
-     * Author: Jiri Kavulak
-     * Related to project of John Papa, Hans Fjällemark and Nguyễn Thiện 
Hùng (thienhung1989)
-     */
-
-    angular.module('toaster', []).constant(
-        'toasterConfig', {
-            'limit': 0,                   // limits max number of toasts
-            'tap-to-dismiss': true,
-
-            /* Options:
-             - Boolean false/true
-             'close-button': true
-             - object if not a boolean that allows you to
-             override showing the close button for each
-             icon-class value
-             'close-button': { 'toast-error': true, 'toast-info': false }
-             */
-            'close-button': false,
-            'close-html': '<button class="toast-close-button" 
type="button">&times;</button>',
-            'newest-on-top': true, 
-            //'fade-in': 1000,            // done in css
-            //'on-fade-in': undefined,    // not implemented
-            //'fade-out': 1000,           // done in css
-            //'on-fade-out': undefined,   // not implemented
-            //'extended-time-out': 1000,  // not implemented
-            'time-out': 5000, // Set timeOut and extendedTimeout to 0 to make 
it sticky
-            'icon-classes': {
-                error: 'toast-error',
-                info: 'toast-info',
-                wait: 'toast-wait',
-                success: 'toast-success',
-                warning: 'toast-warning'
-            },
-            'body-output-type': '', // Options: '', 'trustedHtml', 'template', 
'templateWithData', 'directive'
-            'body-template': 'toasterBodyTmpl.html',
-            'icon-class': 'toast-info',
-            'position-class': 'toast-top-right', // Options (see CSS):
-            // 'toast-top-full-width', 'toast-bottom-full-width', 
'toast-center',
-            // 'toast-top-left', 'toast-top-center', 'toast-top-right',
-            // 'toast-bottom-left', 'toast-bottom-center', 
'toast-bottom-right',
-            'title-class': 'toast-title',
-            'message-class': 'toast-message',
-            'prevent-duplicates': false,
-            'mouseover-timer-stop': true // stop timeout on mouseover and 
restart timer on mouseout
-        }
-        ).service(
-        'toaster', [
-            '$rootScope', 'toasterConfig', function ($rootScope, 
toasterConfig) {
-                this.pop = function (type, title, body, timeout, 
bodyOutputType, clickHandler, toasterId, showCloseButton, toastId, 
onHideCallback) {
-                    if (angular.isObject(type)) {
-                        var params = type; // Enable named parameters as pop 
argument
-                        this.toast = {
-                            type: params.type,
-                            title: params.title,
-                            body: params.body,
-                            timeout: params.timeout,
-                            bodyOutputType: params.bodyOutputType,
-                            clickHandler: params.clickHandler,
-                            showCloseButton: params.showCloseButton,
-                            closeHtml: params.closeHtml,
-                            uid: params.toastId,
-                            onShowCallback: params.onShowCallback,
-                            onHideCallback: params.onHideCallback,
-                            directiveData: params.directiveData
-                        };
-                        toastId = params.toastId;
-                        toasterId = params.toasterId;
-                    } else {
-                        this.toast = {
-                            type: type,
-                            title: title,
-                            body: body,
-                            timeout: timeout,
-                            bodyOutputType: bodyOutputType,
-                            clickHandler: clickHandler,
-                            showCloseButton: showCloseButton,
-                            uid: toastId,
-                            onHideCallback: onHideCallback
-                        };
-                    }
-                    $rootScope.$emit('toaster-newToast', toasterId, toastId);
-                };
-
-                this.clear = function (toasterId, toastId) {
-                    $rootScope.$emit('toaster-clearToasts', toasterId, 
toastId);
-                };
-
-                // Create one method per icon class, to allow to call 
toaster.info() and similar
-                for (var type in toasterConfig['icon-classes']) {
-                    this[type] = createTypeMethod(type);
-                }
-
-                function createTypeMethod(toasterType) {
-                    return function (title, body, timeout, bodyOutputType, 
clickHandler, toasterId, showCloseButton, toastId, onHideCallback) {
-                        if (angular.isString(title)) {
-                            this.pop(
-                                toasterType,
-                                title,
-                                body,
-                                timeout,
-                                bodyOutputType,
-                                clickHandler,
-                                toasterId,
-                                showCloseButton,
-                                toastId,
-                                onHideCallback);
-                        } else { // 'title' is actually an object with options
-                            this.pop(angular.extend(title, { type: toasterType 
}));
-                        }
-                    };
-                }
-            }]
-        ).factory(
-        'toasterEventRegistry', [
-            '$rootScope', function ($rootScope) {
-                var deregisterNewToast = null, deregisterClearToasts = null, 
newToastEventSubscribers = [], clearToastsEventSubscribers = [], toasterFactory;
-
-                toasterFactory = {
-                    setup: function () {
-                        if (!deregisterNewToast) {
-                            deregisterNewToast = $rootScope.$on(
-                                'toaster-newToast', function (event, 
toasterId, toastId) {
-                                    for (var i = 0, len = 
newToastEventSubscribers.length; i < len; i++) {
-                                        newToastEventSubscribers[i](event, 
toasterId, toastId);
-                                    }
-                                });
-                        }
-
-                        if (!deregisterClearToasts) {
-                            deregisterClearToasts = $rootScope.$on(
-                                'toaster-clearToasts', function (event, 
toasterId, toastId) {
-                                    for (var i = 0, len = 
clearToastsEventSubscribers.length; i < len; i++) {
-                                        clearToastsEventSubscribers[i](event, 
toasterId, toastId);
-                                    }
-                                });
-                        }
-                    },
-
-                    subscribeToNewToastEvent: function (onNewToast) {
-                        newToastEventSubscribers.push(onNewToast);
-                    },
-                    subscribeToClearToastsEvent: function (onClearToasts) {
-                        clearToastsEventSubscribers.push(onClearToasts);
-                    },
-                    unsubscribeToNewToastEvent: function (onNewToast) {
-                        var index = 
newToastEventSubscribers.indexOf(onNewToast);
-                        if (index >= 0) {
-                            newToastEventSubscribers.splice(index, 1);
-                        }
-
-                        if (newToastEventSubscribers.length === 0) {
-                            deregisterNewToast();
-                            deregisterNewToast = null;
-                        }
-                    },
-                    unsubscribeToClearToastsEvent: function (onClearToasts) {
-                        var index = 
clearToastsEventSubscribers.indexOf(onClearToasts);
-                        if (index >= 0) {
-                            clearToastsEventSubscribers.splice(index, 1);
-                        }
-
-                        if (clearToastsEventSubscribers.length === 0) {
-                            deregisterClearToasts();
-                            deregisterClearToasts = null;
-                        }
-                    }
-                };
-                return {
-                    setup: toasterFactory.setup,
-                    subscribeToNewToastEvent: 
toasterFactory.subscribeToNewToastEvent,
-                    subscribeToClearToastsEvent: 
toasterFactory.subscribeToClearToastsEvent,
-                    unsubscribeToNewToastEvent: 
toasterFactory.unsubscribeToNewToastEvent,
-                    unsubscribeToClearToastsEvent: 
toasterFactory.unsubscribeToClearToastsEvent
-                };
-            }]
-        )
-        .directive('directiveTemplate', ['$compile', '$injector', 
function($compile, $injector) {
-            return {
-                restrict: 'A',
-                scope: {
-                    directiveName: '@directiveName',
-                    directiveData: '@directiveData'
-                },
-                replace: true,   
-                link: function (scope, elm, attrs) {
-                    scope.$watch('directiveName', function (directiveName) {
-                        if (angular.isUndefined(directiveName) || 
directiveName.length <= 0)
-                            throw new Error('A valid directive name must be 
provided via the toast body argument when using bodyOutputType: directive');
-                        
-                        var directive;
-                        
-                        try {
-                            directive = 
$injector.get(attrs.$normalize(directiveName) + 'Directive');
-                        } catch(e) {
-                            throw new Error(directiveName + ' could not be 
found. ' +
-                                 'The name should appear as it exists in the 
markup, not camelCased as it would appear in the directive declaration,' +
-                                 ' e.g. directive-name not directiveName.');
-                        }
-                        
-                        
-                        var directiveDetails = directive[0];
-                            
-                        if (directiveDetails.scope !== true && 
directiveDetails.scope) {
-                            throw new Error('Cannot use a directive with an 
isolated scope. ' + 
-                                'The scope must be either true or falsy (e.g. 
false/null/undefined). ' + 
-                                'Occurred for directive ' + directiveName + 
'.');
-                        }
-                        
-                        if (directiveDetails.restrict.indexOf('A') < 0) {
-                            throw new Error('Directives must be usable as 
attributes. ' +
-                              'Add "A" to the restrict option (or remove the 
option entirely). Occurred for directive ' + 
-                              directiveName + '.');
-                        }
-                            
-                        if (scope.directiveData)
-                            scope.directiveData = 
angular.fromJson(scope.directiveData);
-                        
-                        var template = $compile('<div ' + directiveName + 
'></div>')(scope);
-
-                        elm.append(template);
-                    });
-                }
-            };
-        }])
-        .directive(
-        'toasterContainer', [
-            '$parse', '$rootScope', '$interval', '$sce', 'toasterConfig', 
'toaster', 'toasterEventRegistry',
-            function ($parse, $rootScope, $interval, $sce, toasterConfig, 
toaster, toasterEventRegistry) {
-                return {
-                    replace: true,
-                    restrict: 'EA',
-                    scope: true, // creates an internal scope for this 
directive (one per directive instance)
-                    link: function (scope, elm, attrs) {
-                        var id = 0, mergedConfig;
-
-                        // Merges configuration set in directive with default 
one
-                        mergedConfig = angular.extend({}, toasterConfig, 
scope.$eval(attrs.toasterOptions));
-
-                        scope.config = {
-                            toasterId: mergedConfig['toaster-id'],
-                            position: mergedConfig['position-class'],
-                            title: mergedConfig['title-class'],
-                            message: mergedConfig['message-class'],
-                            tap: mergedConfig['tap-to-dismiss'],
-                            closeButton: mergedConfig['close-button'],
-                            closeHtml: mergedConfig['close-html'],
-                            animation: mergedConfig['animation-class'],
-                            mouseoverTimer: 
mergedConfig['mouseover-timer-stop']
-                        };
-
-                        scope.$on(
-                            "$destroy", function () {
-                                
toasterEventRegistry.unsubscribeToNewToastEvent(scope._onNewToast);
-                                
toasterEventRegistry.unsubscribeToClearToastsEvent(scope._onClearToasts);
-                            }
-                            );
-
-                        function setTimeout(toast, time) {
-                            toast.timeoutPromise = $interval(
-                                function () {
-                                    scope.removeToast(toast.id);
-                                }, time, 1
-                                );
-                        }
-
-                        scope.configureTimer = function (toast) {
-                            var timeout = angular.isNumber(toast.timeout) ? 
toast.timeout : mergedConfig['time-out'];
-                            if (typeof timeout === "object") timeout = 
timeout[toast.type];
-                            if (timeout > 0) {
-                                setTimeout(toast, timeout);
-                            }
-                        };
-
-                        function addToast(toast, toastId) {
-                            toast.type = 
mergedConfig['icon-classes'][toast.type];
-                            if (!toast.type) {
-                                toast.type = mergedConfig['icon-class'];
-                            }
-
-                            if (mergedConfig['prevent-duplicates'] === true) {
-                                // Prevent adding duplicate toasts if it's set
-                                if (isUndefinedOrNull(toastId)) {
-                                    if (scope.toasters.length > 0 && 
scope.toasters[scope.toasters.length - 1].body === toast.body) {
-                                        return;
-                                    }
-                                } else {
-                                    var i, len;
-                                    for (i = 0, len = scope.toasters.length; i 
< len; i++) {
-                                        if (scope.toasters[i].uid === toastId) 
{
-                                            removeToast(i);
-                                            // update loop
-                                            i--;
-                                            len = scope.toasters.length;
-                                        }
-                                    }
-                                }
-                            }
-
-                            toast.id = ++id;
-                            // Sure uid defined
-                            if (!isUndefinedOrNull(toastId)) {
-                                toast.uid = toastId;
-                            }
-
-                            // set the showCloseButton property on the toast 
so that
-                            // each template can bind directly to the property 
to show/hide
-                            // the close button
-                            var closeButton = mergedConfig['close-button'];
-
-                            // if toast.showCloseButton is a boolean value,
-                            // it was specifically overriden in the pop 
arguments
-                            if (typeof toast.showCloseButton === "boolean") {
-
-                            } else if (typeof closeButton === "boolean") {
-                                toast.showCloseButton = closeButton;
-                            } else if (typeof closeButton === "object") {
-                                var closeButtonForType = 
closeButton[toast.type];
-
-                                if (typeof closeButtonForType !== "undefined" 
&& closeButtonForType !== null) {
-                                    toast.showCloseButton = closeButtonForType;
-                                }
-                            } else {
-                                // if an option was not set, default to false.
-                                toast.showCloseButton = false;
-                            }
-                            
-                            if (toast.showCloseButton) {
-                                toast.closeHtml = 
$sce.trustAsHtml(toast.closeHtml || scope.config.closeHtml);
-                            }
-                             
-                            // Set the toast.bodyOutputType to the default if 
it isn't set
-                            toast.bodyOutputType = toast.bodyOutputType || 
mergedConfig['body-output-type'];
-                            switch (toast.bodyOutputType) {
-                                case 'trustedHtml':
-                                    toast.html = $sce.trustAsHtml(toast.body);
-                                    break;
-                                case 'template':
-                                    toast.bodyTemplate = toast.body || 
mergedConfig['body-template'];
-                                    break;
-                                case 'templateWithData':
-                                    var fcGet = $parse(toast.body || 
mergedConfig['body-template']);
-                                    var templateWithData = fcGet(scope);
-                                    toast.bodyTemplate = 
templateWithData.template;
-                                    toast.data = templateWithData.data;
-                                    break;
-                                case 'directive':
-                                    toast.html = toast.body;
-                                    break;
-                            }
-
-                            scope.configureTimer(toast);
-                            
-                            if (mergedConfig['newest-on-top'] === true) {
-                                scope.toasters.unshift(toast);
-                                if (mergedConfig['limit'] > 0 && 
scope.toasters.length > mergedConfig['limit']) {
-                                    scope.toasters.pop();
-                                }
-                            } else {
-                                scope.toasters.push(toast);
-                                if (mergedConfig['limit'] > 0 && 
scope.toasters.length > mergedConfig['limit']) {
-                                    scope.toasters.shift();
-                                }
-                            }
-                            
-                            if (angular.isFunction(toast.onShowCallback)) {
-                                toast.onShowCallback();
-                            }
-                        }
-
-                        scope.removeToast = function (id) {
-                            var i, len;
-                            for (i = 0, len = scope.toasters.length; i < len; 
i++) {
-                                if (scope.toasters[i].id === id) {
-                                    removeToast(i);
-                                    break;
-                                }
-                            }
-                        };
-
-                        function removeToast(toastIndex) {
-                            var toast = scope.toasters[toastIndex];
-                            
-                            // toast is always defined since the index always 
has a match
-                            if (toast.timeoutPromise) {
-                                $interval.cancel(toast.timeoutPromise);
-                            }
-                            scope.toasters.splice(toastIndex, 1);
-
-                            if (angular.isFunction(toast.onHideCallback)) {
-                                toast.onHideCallback();
-                            }
-                        }
-
-                        function removeAllToasts(toastId) {
-                            for (var i = scope.toasters.length - 1; i >= 0; 
i--) {
-                                if (isUndefinedOrNull(toastId)) {
-                                    removeToast(i);
-                                } else {
-                                    if (scope.toasters[i].uid == toastId) {
-                                        removeToast(i);
-                                    }
-                                }
-                            }
-                        }
-
-                        scope.toasters = [];
-
-                        function isUndefinedOrNull(val) {
-                            return angular.isUndefined(val) || val === null;
-                        }
-
-                        scope._onNewToast = function (event, toasterId, 
toastId) {
-                            // Compatibility: if toaster has no toasterId 
defined, and if call to display
-                            // hasn't either, then the request is for us
-
-                            if ((isUndefinedOrNull(scope.config.toasterId) && 
isUndefinedOrNull(toasterId)) || (!isUndefinedOrNull(scope.config.toasterId) && 
!isUndefinedOrNull(toasterId) && scope.config.toasterId == toasterId)) {
-                                addToast(toaster.toast, toastId);
-                            }
-                        };
-                        scope._onClearToasts = function (event, toasterId, 
toastId) {
-                            // Compatibility: if toaster has no toasterId 
defined, and if call to display
-                            // hasn't either, then the request is for us
-                            if (toasterId == '*' || 
(isUndefinedOrNull(scope.config.toasterId) && isUndefinedOrNull(toasterId)) || 
(!isUndefinedOrNull(scope.config.toasterId) && !isUndefinedOrNull(toasterId) && 
scope.config.toasterId == toasterId)) {
-                                removeAllToasts(toastId);
-                            }
-                        };
-
-                        toasterEventRegistry.setup();
-
-                        
toasterEventRegistry.subscribeToNewToastEvent(scope._onNewToast);
-                        
toasterEventRegistry.subscribeToClearToastsEvent(scope._onClearToasts);
-                    },
-                    controller: [
-                        '$scope', '$element', '$attrs', function ($scope, 
$element, $attrs) {
-                            // Called on mouseover
-                            $scope.stopTimer = function (toast) {
-                                if ($scope.config.mouseoverTimer === true) {
-                                    if (toast.timeoutPromise) {
-                                        $interval.cancel(toast.timeoutPromise);
-                                        toast.timeoutPromise = null;
-                                    }
-                                }
-                            };
-
-                            // Called on mouseout
-                            $scope.restartTimer = function (toast) {
-                                if ($scope.config.mouseoverTimer === true) {
-                                    if (!toast.timeoutPromise) {
-                                        $scope.configureTimer(toast);
-                                    }
-                                } else if (toast.timeoutPromise === null) {
-                                    $scope.removeToast(toast.id);
-                                }
-                            };
-
-                            $scope.click = function (toast, isCloseButton) {
-                                if ($scope.config.tap === true || 
(toast.showCloseButton === true && isCloseButton === true)) {
-                                    var removeToast = true;
-                                    if (toast.clickHandler) {
-                                        if 
(angular.isFunction(toast.clickHandler)) {
-                                            removeToast = 
toast.clickHandler(toast, isCloseButton);
-                                        } else if 
(angular.isFunction($scope.$parent.$eval(toast.clickHandler))) {
-                                            removeToast = 
$scope.$parent.$eval(toast.clickHandler)(toast, isCloseButton);
-                                        } else {
-                                            console.log("TOAST-NOTE: Your 
click handler is not inside a parent scope of toaster-container.");
-                                        }
-                                    }
-                                    if (removeToast) {
-                                        $scope.removeToast(toast.id);
-                                    }
-                                }
-                            };
-                        }],
-                    template: 
-                        '<div id="toast-container" ng-class="[config.position, 
config.animation]">' + 
-                            '<div ng-repeat="toaster in toasters" 
class="toast" ng-class="toaster.type" ng-click="click(toaster)" 
ng-mouseover="stopTimer(toaster)" ng-mouseout="restartTimer(toaster)">' + 
-                                '<div ng-if="toaster.showCloseButton" 
ng-click="click(toaster, true)" ng-bind-html="toaster.closeHtml"></div>' + 
-                                '<div 
ng-class="config.title">{{toaster.title}}</div>' + 
-                                '<div ng-class="config.message" ng-switch 
on="toaster.bodyOutputType">' + 
-                                    '<div ng-switch-when="trustedHtml" 
ng-bind-html="toaster.html"></div>' + 
-                                    '<div ng-switch-when="template"><div 
ng-include="toaster.bodyTemplate"></div></div>' + 
-                                    '<div 
ng-switch-when="templateWithData"><div 
ng-include="toaster.bodyTemplate"></div></div>' +
-                                    '<div ng-switch-when="directive"><div 
directive-template directive-name="{{toaster.html}}" 
directive-data="{{toaster.directiveData}}"></div></div>' + 
-                                    '<div ng-switch-default 
>{{toaster.body}}</div>' + 
-                                '</div>' + 
-                            '</div>' + 
-                        '</div>'
-                };
-            }]
-        );
-})(window, document);
\ No newline at end of file

http://git-wip-us.apache.org/repos/asf/incubator-griffin/blob/f629d0f4/griffin-ui/bower_components/AngularJS-Toaster/toaster.min.css
----------------------------------------------------------------------
diff --git a/griffin-ui/bower_components/AngularJS-Toaster/toaster.min.css 
b/griffin-ui/bower_components/AngularJS-Toaster/toaster.min.css
deleted file mode 100644
index 3b3c2e3..0000000
--- a/griffin-ui/bower_components/AngularJS-Toaster/toaster.min.css
+++ /dev/null
@@ -1,12 +0,0 @@
-/*!
- * Toastr
- * Version 2.0.1
- * Copyright 2012 John Papa and Hans Fjallemark.
- * All Rights Reserved.
- * Use, reproduction, distribution, and modification of this code is subject 
to the terms and
- * conditions of the MIT license, available at 
http://www.opensource.org/licenses/mit-license.php
- *
- * Author: John Papa and Hans Fjallemark
- * Project: https://github.com/CodeSeven/toastr
- */
-.toast-title{font-weight:700}.toast-message{-ms-word-wrap:break-word;word-wrap:break-word}.toast-message
 a,.toast-message label{color:#fff}.toast-message 
a:hover{color:#ccc;text-decoration:none}.toast-close-button{position:relative;right:-.3em;top:-.3em;float:right;font-size:20px;font-weight:700;color:#fff;-webkit-text-shadow:0
 1px 0 #fff;text-shadow:0 1px 0 
#fff;opacity:.8;-ms-filter:progid:DXImageTransform.Microsoft.Alpha(Opacity=80);filter:alpha(opacity=80)}.toast-close-button:focus,.toast-close-button:hover{color:#000;text-decoration:none;cursor:pointer;opacity:.4;-ms-filter:progid:DXImageTransform.Microsoft.Alpha(Opacity=40);filter:alpha(opacity=40)}button.toast-close-button{padding:0;cursor:pointer;background:0
 
0;border:0;-webkit-appearance:none}.toast-top-full-width{top:0;right:0;width:100%}.toast-bottom-full-width{bottom:0;right:0;width:100%}.toast-top-left{top:12px;left:12px}.toast-top-center{top:12px}.toast-top-right{top:12px;right:12px}.toast-bottom-right{right:12px;botto
 
m:12px}.toast-bottom-center{bottom:12px}.toast-bottom-left{bottom:12px;left:12px}.toast-center{top:45%}#toast-container{position:fixed;z-index:999999;pointer-events:auto;}#toast-container.toast-bottom-center,#toast-container.toast-center,#toast-container.toast-top-center{width:100%;pointer-events:none}#toast-container.toast-bottom-center>div,#toast-container.toast-center>div,#toast-container.toast-top-center>div{margin:auto;pointer-events:auto}#toast-container.toast-bottom-center>button,#toast-container.toast-center>button,#toast-container.toast-top-cente>button{pointer-events:auto}#toast-container
 
*{-moz-box-sizing:border-box;-webkit-box-sizing:border-box;box-sizing:border-box}#toast-container>div{margin:0
 0 6px;padding:15px 15px 15px 
50px;width:300px;-moz-border-radius:3px;-webkit-border-radius:3px;border-radius:3px;background-position:15px
 center;background-repeat:no-repeat;-moz-box-shadow:0 0 12px 
#999;-webkit-box-shadow:0 0 12px #999;box-shadow:0 0 12px 
#999;color:#fff;opacity:
 
.8;-ms-filter:progid:DXImageTransform.Microsoft.Alpha(Opacity=80);filter:alpha(opacity=80)}#toast-container>:hover{-moz-box-shadow:0
 0 12px #000;-webkit-box-shadow:0 0 12px #000;box-shadow:0 0 12px 
#000;opacity:1;-ms-filter:progid:DXImageTransform.Microsoft.Alpha(Opacity=100);filter:alpha(opacity=100);cursor:pointer}#toast-container>.toast-info{background-image:url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABgAAAAYCAYAAADgdz34AAAAAXNSR0IArs4c6QAAAARnQU1BAACxjwv8YQUAAAAJcEhZcwAADsMAAA7DAcdvqGQAAAGwSURBVEhLtZa9SgNBEMc9sUxxRcoUKSzSWIhXpFMhhYWFhaBg4yPYiWCXZxBLERsLRS3EQkEfwCKdjWJAwSKCgoKCcudv4O5YLrt7EzgXhiU3/4+b2ckmwVjJSpKkQ6wAi4gwhT+z3wRBcEz0yjSseUTrcRyfsHsXmD0AmbHOC9Ii8VImnuXBPglHpQ5wwSVM7sNnTG7Za4JwDdCjxyAiH3nyA2mtaTJufiDZ5dCaqlItILh1NHatfN5skvjx9Z38m69CgzuXmZgVrPIGE763Jx9qKsRozWYw6xOHdER+nn2KkO+Bb+UV5CBN6WC6QtBgbRVozrahAbmm6HtUsgtPC19tFdxXZYBOfkbmFJ1VaHA1VAHjd0pp70oTZzvR+EVrx2Ygfdsq6eu55BHYR8hlcki+n+kERUFG8BrA0BwjeAv2M8WLQBtcy+SD6fNsmnB3AlBLrgTtVW1c2QN4bVWLATaIS60J2Du5y1TiJgjSBvF
 
VZgTmwCU+dAZFoPxGEEs8nyHC9Bwe2GvEJv2WXZb0vjdyFT4Cxk3e/kIqlOGoVLwwPevpYHT+00T+hWwXDf4AJAOUqWcDhbwAAAAASUVORK5CYII=)!important}#toast-container>.toast-wait{background-image:url(data:image/gif;base64,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)!important}#toast-container>.toast-error{background-image:url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABgAAAAYCAYAAADgdz34AAAAAXNSR0IArs4c6QAAAARnQU1BAACxjwv8YQUAAAAJcEhZcwAADsMAAA7DAcdvqGQAAAHOSURBVEhLrZa/SgNBEMZzh0WKCClSCKaIYOED+AAKeQQLG8HWztLCImBrYadgIdY+gIKNYkBFSwu7CAoqCgkkoGBI/E28PdbLZmeDLgzZzcx83/zZ2SSXC1j9fr+I1Hq93g2yxH4iwM1vkoBWAdxCmpzTxfkN2RcyZNaHFIkSo10+8kgxkXIURV5HGxTmFuc75B2RfQkpxHG8aAgaAFa0tAHqYFfQ7Iwe2yhODk8+J4C7yAoRTWI3w/4klGRgR4lO7Rpn9+gvMyWp+uxFh8+H+ARlgN1nJuJuQAYvNkEnwGFck18Er4q3egEc/oO+mhLdKgRyhdNFiacC0rlOCbhNVz4H9FnAYgDBvU3QIioZlJFLJtsoHYRDfiZoUyIxqCtRpVlANq0EU4dApjrtgezPFad5S19Wgjkc0hNVnuF4HjVA6C7QrSIbylB+oZe3aHgBsqlNqKYH48jXyJKMuAbiyVJ8KzaB3eRc0pg9VwQ4niFryI68qiOi3AbjwdsfnAtk0bCjTLJKr6mrD9g8iq/S/B81hguOMlQTnVyG40wAcjnmgsCNESDrjme7wfftP4P7SP4N3CJZdvzoNyGq2c/HWOXJGsvVg+RA/k2MC/wN6I2YA2Pt8GkAAAAASUVORK5CYII=)!important}#toast-container>.toast-success{background-image:url(data:image/png;base64,
 
iVBORw0KGgoAAAANSUhEUgAAABgAAAAYCAYAAADgdz34AAAAAXNSR0IArs4c6QAAAARnQU1BAACxjwv8YQUAAAAJcEhZcwAADsMAAA7DAcdvqGQAAADsSURBVEhLY2AYBfQMgf///3P8+/evAIgvA/FsIF+BavYDDWMBGroaSMMBiE8VC7AZDrIFaMFnii3AZTjUgsUUWUDA8OdAH6iQbQEhw4HyGsPEcKBXBIC4ARhex4G4BsjmweU1soIFaGg/WtoFZRIZdEvIMhxkCCjXIVsATV6gFGACs4Rsw0EGgIIH3QJYJgHSARQZDrWAB+jawzgs+Q2UO49D7jnRSRGoEFRILcdmEMWGI0cm0JJ2QpYA1RDvcmzJEWhABhD/pqrL0S0CWuABKgnRki9lLseS7g2AlqwHWQSKH4oKLrILpRGhEQCw2LiRUIa4lwAAAABJRU5ErkJggg==)!important}#toast-container>.toast-warning{background-image:url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABgAAAAYCAYAAADgdz34AAAAAXNSR0IArs4c6QAAAARnQU1BAACxjwv8YQUAAAAJcEhZcwAADsMAAA7DAcdvqGQAAAGYSURBVEhL5ZSvTsNQFMbXZGICMYGYmJhAQIJAICYQPAACiSDB8AiICQQJT4CqQEwgJvYASAQCiZiYmJhAIBATCARJy+9rTsldd8sKu1M0+dLb057v6/lbq/2rK0mS/TRNj9cWNAKPYIJII7gIxCcQ51cvqID+GIEX8ASG4B1bK5gIZFeQfoJdEXOfgX4QAQg7kH2A65yQ87lyxb27sggkAzAuFhbbg1K2kgCkB1bVwyIR9m2L7PRPIhDUIXgGtyKw575yz3lTNs6X4JXnjV+LKM/m3MydnTbtOKIjtz6VhCBq4vSm3ncdrD2lk0VgUXSVKjVDJXJzijW1RQ
 
dsU7F77He8u68koNZTz8Oz5yGa6J3H3lZ0xYgXBK2QymlWWA+RWnYhskLBv2vmE+hBMCtbA7KX5drWyRT/2JsqZ2IvfB9Y4bWDNMFbJRFmC9E74SoS0CqulwjkC0+5bpcV1CZ8NMej4pjy0U+doDQsGyo1hzVJttIjhQ7GnBtRFN1UarUlH8F3xict+HY07rEzoUGPlWcjRFRr4/gChZgc3ZL2d8oAAAAASUVORK5CYII=)!important}#toast-container.toast-bottom-full-width>div,#toast-container.toast-top-full-width>div{width:96%;margin:auto}.toast{background-color:#030303}.toast-success{background-color:#51a351}.toast-error{background-color:#bd362f}.toast-info,.toast-wait{background-color:#2f96b4}.toast-warning{background-color:#f89406}@media
 all and (max-width:240px){#toast-container>div{padding:8px 8px 8px 
50px;width:11em}#toast-container 
.toast-close-button{right:-.2em;top:-.2em}}@media all and (min-width:241px) and 
(max-width:480px){#toast-container>div{padding:8px 8px 8px 
50px;width:18em}#toast-container 
.toast-close-button{right:-.2em;top:-.2em}}@media all and (min-width:481px) and 
(max-width:768px){#toast-container>div{padding:15px 15px 15px 50px;width:25em}}:
 
not(.no-enter)#toast-container>div.ng-enter,:not(.no-leave)#toast-container>div.ng-leave{-webkit-transition:1000ms
 cubic-bezier(.25,.25,.75,.75) all;-moz-transition:1000ms 
cubic-bezier(.25,.25,.75,.75) all;-ms-transition:1000ms 
cubic-bezier(.25,.25,.75,.75) all;-o-transition:1000ms 
cubic-bezier(.25,.25,.75,.75) all;transition:1000ms 
cubic-bezier(.25,.25,.75,.75) 
all}:not(.no-enter)#toast-container>div.ng-enter.ng-enter-active,:not(.no-leave)#toast-container>div.ng-leave{opacity:.8}:not(.no-enter)#toast-container>div.ng-enter,:not(.no-leave)#toast-container>div.ng-leave.ng-leave-active{opacity:0}
\ No newline at end of file

http://git-wip-us.apache.org/repos/asf/incubator-griffin/blob/f629d0f4/griffin-ui/bower_components/AngularJS-Toaster/toaster.min.js
----------------------------------------------------------------------
diff --git a/griffin-ui/bower_components/AngularJS-Toaster/toaster.min.js 
b/griffin-ui/bower_components/AngularJS-Toaster/toaster.min.js
deleted file mode 100644
index 98b7e72..0000000
--- a/griffin-ui/bower_components/AngularJS-Toaster/toaster.min.js
+++ /dev/null
@@ -1,13 +0,0 @@
-/*
- * AngularJS Toaster
- * Version: 1.2.0
- *
- * Copyright 2013-2016 Jiri Kavulak.
- * All Rights Reserved.
- * Use, reproduction, distribution, and modification of this code is subject 
to the terms and
- * conditions of the MIT license, available at 
http://www.opensource.org/licenses/mit-license.php
- *
- * Author: Jiri Kavulak
- * Related to project of John Papa, Hans Fjällemark and Nguyễn Thiện 
Hùng (thienhung1989)
- */
-!function(t,e){"use 
strict";angular.module("toaster",[]).constant("toasterConfig",{limit:0,"tap-to-dismiss":!0,"close-button":!1,"close-html":'<button
 class="toast-close-button" 
type="button">&times;</button>',"newest-on-top":!0,"time-out":5e3,"icon-classes":{error:"toast-error",info:"toast-info",wait:"toast-wait",success:"toast-success",warning:"toast-warning"},"body-output-type":"","body-template":"toasterBodyTmpl.html","icon-class":"toast-info","position-class":"toast-top-right","title-class":"toast-title","message-class":"toast-message","prevent-duplicates":!1,"mouseover-timer-stop":!0}).service("toaster",["$rootScope","toasterConfig",function(t,e){function
 o(t){return 
function(e,o,s,i,a,n,r,c,l){angular.isString(e)?this.pop(t,e,o,s,i,a,n,r,c,l):this.pop(angular.extend(e,{type:t}))}}this.pop=function(e,o,s,i,a,n,r,c,l,u){if(angular.isObject(e)){var
 
d=e;this.toast={type:d.type,title:d.title,body:d.body,timeout:d.timeout,bodyOutputType:d.bodyOutputType,clickHandler:d.clickHandler,
 
showCloseButton:d.showCloseButton,closeHtml:d.closeHtml,uid:d.toastId,onShowCallback:d.onShowCallback,onHideCallback:d.onHideCallback,directiveData:d.directiveData},l=d.toastId,r=d.toasterId}else
 
this.toast={type:e,title:o,body:s,timeout:i,bodyOutputType:a,clickHandler:n,showCloseButton:c,uid:l,onHideCallback:u};t.$emit("toaster-newToast",r,l)},this.clear=function(e,o){t.$emit("toaster-clearToasts",e,o)};for(var
 s in 
e["icon-classes"])this[s]=o(s)}]).factory("toasterEventRegistry",["$rootScope",function(t){var
 e,o=null,s=null,i=[],a=[];return 
e={setup:function(){o||(o=t.$on("toaster-newToast",function(t,e,o){for(var 
s=0,a=i.length;a>s;s++)i[s](t,e,o)})),s||(s=t.$on("toaster-clearToasts",function(t,e,o){for(var
 
s=0,i=a.length;i>s;s++)a[s](t,e,o)}))},subscribeToNewToastEvent:function(t){i.push(t)},subscribeToClearToastsEvent:function(t){a.push(t)},unsubscribeToNewToastEvent:function(t){var
 
e=i.indexOf(t);e>=0&&i.splice(e,1),0===i.length&&(o(),o=null)},unsubscribeToClearToastsEvent:fun
 ction(t){var 
e=a.indexOf(t);e>=0&&a.splice(e,1),0===a.length&&(s(),s=null)}},{setup:e.setup,subscribeToNewToastEvent:e.subscribeToNewToastEvent,subscribeToClearToastsEvent:e.subscribeToClearToastsEvent,unsubscribeToNewToastEvent:e.unsubscribeToNewToastEvent,unsubscribeToClearToastsEvent:e.unsubscribeToClearToastsEvent}}]).directive("directiveTemplate",["$compile","$injector",function(t,e){return{restrict:"A",scope:{directiveName:"@directiveName",directiveData:"@directiveData"},replace:!0,link:function(o,s,i){o.$watch("directiveName",function(a){if(angular.isUndefined(a)||a.length<=0)throw
 new Error("A valid directive name must be provided via the toast body argument 
when using bodyOutputType: directive");var 
n;try{n=e.get(i.$normalize(a)+"Directive")}catch(r){throw new Error(a+" could 
not be found. The name should appear as it exists in the markup, not camelCased 
as it would appear in the directive declaration, e.g. directive-name not 
directiveName.")}var c=n[0];if(c.scope!==!0&&c.s
 cope)throw new Error("Cannot use a directive with an isolated scope. The scope 
must be either true or falsy (e.g. false/null/undefined). Occurred for 
directive "+a+".");if(c.restrict.indexOf("A")<0)throw new Error('Directives 
must be usable as attributes. Add "A" to the restrict option (or remove the 
option entirely). Occurred for directive 
'+a+".");o.directiveData&&(o.directiveData=angular.fromJson(o.directiveData));var
 l=t("<div 
"+a+"></div>")(o);s.append(l)})}}}]).directive("toasterContainer",["$parse","$rootScope","$interval","$sce","toasterConfig","toaster","toasterEventRegistry",function(t,e,o,s,i,a,n){return{replace:!0,restrict:"EA",scope:!0,link:function(e,r,c){function
 l(t,s){t.timeoutPromise=o(function(){e.removeToast(t.id)},s,1)}function 
u(o,i){if(o.type=v["icon-classes"][o.type],o.type||(o.type=v["icon-class"]),v["prevent-duplicates"]===!0)if(p(i)){if(e.toasters.length>0&&e.toasters[e.toasters.length-1].body===o.body)return}else{var
 a,n;for(a=0,n=e.toasters.length;n>a;a+
 
+)e.toasters[a].uid===i&&(d(a),a--,n=e.toasters.length)}o.id=++f,p(i)||(o.uid=i);var
 r=v["close-button"];if("boolean"==typeof o.showCloseButton);else 
if("boolean"==typeof r)o.showCloseButton=r;else if("object"==typeof r){var 
c=r[o.type];"undefined"!=typeof c&&null!==c&&(o.showCloseButton=c)}else 
o.showCloseButton=!1;switch(o.showCloseButton&&(o.closeHtml=s.trustAsHtml(o.closeHtml||e.config.closeHtml)),o.bodyOutputType=o.bodyOutputType||v["body-output-type"],o.bodyOutputType){case"trustedHtml":o.html=s.trustAsHtml(o.body);break;case"template":o.bodyTemplate=o.body||v["body-template"];break;case"templateWithData":var
 
l=t(o.body||v["body-template"]),u=l(e);o.bodyTemplate=u.template,o.data=u.data;break;case"directive":o.html=o.body}e.configureTimer(o),v["newest-on-top"]===!0?(e.toasters.unshift(o),v.limit>0&&e.toasters.length>v.limit&&e.toasters.pop()):(e.toasters.push(o),v.limit>0&&e.toasters.length>v.limit&&e.toasters.shift()),angular.isFunction(o.onShowCallback)&&o.onShowCallback()}f
 unction d(t){var 
s=e.toasters[t];s.timeoutPromise&&o.cancel(s.timeoutPromise),e.toasters.splice(t,1),angular.isFunction(s.onHideCallback)&&s.onHideCallback()}function
 m(t){for(var 
o=e.toasters.length-1;o>=0;o--)p(t)?d(o):e.toasters[o].uid==t&&d(o)}function 
p(t){return angular.isUndefined(t)||null===t}var 
v,f=0;v=angular.extend({},i,e.$eval(c.toasterOptions)),e.config={toasterId:v["toaster-id"],position:v["position-class"],title:v["title-class"],message:v["message-class"],tap:v["tap-to-dismiss"],closeButton:v["close-button"],closeHtml:v["close-html"],animation:v["animation-class"],mouseoverTimer:v["mouseover-timer-stop"]},e.$on("$destroy",function(){n.unsubscribeToNewToastEvent(e._onNewToast),n.unsubscribeToClearToastsEvent(e._onClearToasts)}),e.configureTimer=function(t){var
 e=angular.isNumber(t.timeout)?t.timeout:v["time-out"];"object"==typeof 
e&&(e=e[t.type]),e>0&&l(t,e)},e.removeToast=function(t){var 
o,s;for(o=0,s=e.toasters.length;s>o;o++)if(e.toasters[o].id===t){d(o);break}},e.
 
toasters=[],e._onNewToast=function(t,o,s){(p(e.config.toasterId)&&p(o)||!p(e.config.toasterId)&&!p(o)&&e.config.toasterId==o)&&u(a.toast,s)},e._onClearToasts=function(t,o,s){("*"==o||p(e.config.toasterId)&&p(o)||!p(e.config.toasterId)&&!p(o)&&e.config.toasterId==o)&&m(s)},n.setup(),n.subscribeToNewToastEvent(e._onNewToast),n.subscribeToClearToastsEvent(e._onClearToasts)},controller:["$scope","$element","$attrs",function(t,e,s){t.stopTimer=function(e){t.config.mouseoverTimer===!0&&e.timeoutPromise&&(o.cancel(e.timeoutPromise),e.timeoutPromise=null)},t.restartTimer=function(e){t.config.mouseoverTimer===!0?e.timeoutPromise||t.configureTimer(e):null===e.timeoutPromise&&t.removeToast(e.id)},t.click=function(e,o){if(t.config.tap===!0||e.showCloseButton===!0&&o===!0){var
 
s=!0;e.clickHandler&&(angular.isFunction(e.clickHandler)?s=e.clickHandler(e,o):angular.isFunction(t.$parent.$eval(e.clickHandler))?s=t.$parent.$eval(e.clickHandler)(e,o):console.log("TOAST-NOTE:
 Your click handler is not i
 nside a parent scope of 
toaster-container.")),s&&t.removeToast(e.id)}}}],template:'<div 
id="toast-container" ng-class="[config.position, config.animation]"><div 
ng-repeat="toaster in toasters" class="toast" ng-class="toaster.type" 
ng-click="click(toaster)" ng-mouseover="stopTimer(toaster)" 
ng-mouseout="restartTimer(toaster)"><div ng-if="toaster.showCloseButton" 
ng-click="click(toaster, true)" ng-bind-html="toaster.closeHtml"></div><div 
ng-class="config.title">{{toaster.title}}</div><div ng-class="config.message" 
ng-switch on="toaster.bodyOutputType"><div ng-switch-when="trustedHtml" 
ng-bind-html="toaster.html"></div><div ng-switch-when="template"><div 
ng-include="toaster.bodyTemplate"></div></div><div 
ng-switch-when="templateWithData"><div 
ng-include="toaster.bodyTemplate"></div></div><div 
ng-switch-when="directive"><div directive-template 
directive-name="{{toaster.html}}" 
directive-data="{{toaster.directiveData}}"></div></div><div ng-switch-default 
>{{toaster.body}}</div></div></di
 v></div>'}}])}(window,document);
\ No newline at end of file


Reply via email to