mirror of
				https://git.code.sf.net/p/seeddms/code
				synced 2025-10-25 18:21:19 +00:00 
			
		
		
		
	
		
			
				
	
	
		
			521 lines
		
	
	
		
			16 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
			
		
		
	
	
			521 lines
		
	
	
		
			16 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
| /**
 | |
|  * noty - jQuery Notification Plugin v2.0.3
 | |
|  * Contributors: https://github.com/needim/noty/graphs/contributors
 | |
|  *
 | |
|  * Examples and Documentation - http://needim.github.com/noty/
 | |
|  *
 | |
|  * Licensed under the MIT licenses:
 | |
|  * http://www.opensource.org/licenses/mit-license.php
 | |
|  *
 | |
|  **/
 | |
| 
 | |
| if (typeof Object.create !== 'function') {
 | |
|     Object.create = function (o) {
 | |
|         function F() {
 | |
|         }
 | |
| 
 | |
|         F.prototype = o;
 | |
|         return new F();
 | |
|     };
 | |
| }
 | |
| 
 | |
| (function ($) {
 | |
| 
 | |
|     var NotyObject = {
 | |
| 
 | |
|         init:function (options) {
 | |
| 
 | |
|             // Mix in the passed in options with the default options
 | |
|             this.options = $.extend({}, $.noty.defaults, options);
 | |
| 
 | |
|             this.options.layout = (this.options.custom) ? $.noty.layouts['inline'] : $.noty.layouts[this.options.layout];
 | |
|             this.options.theme = $.noty.themes[this.options.theme];
 | |
| 
 | |
|             delete options.layout;
 | |
|             delete options.theme;
 | |
| 
 | |
|             this.options = $.extend({}, this.options, this.options.layout.options);
 | |
|             this.options.id = 'noty_' + (new Date().getTime() * Math.floor(Math.random() * 1000000));
 | |
| 
 | |
|             this.options = $.extend({}, this.options, options);
 | |
| 
 | |
|             // Build the noty dom initial structure
 | |
|             this._build();
 | |
| 
 | |
|             // return this so we can chain/use the bridge with less code.
 | |
|             return this;
 | |
|         }, // end init
 | |
| 
 | |
|         _build:function () {
 | |
| 
 | |
|             // Generating noty bar
 | |
|             var $bar = $('<div class="noty_bar"></div>').attr('id', this.options.id);
 | |
|             $bar.append(this.options.template).find('.noty_text').html(this.options.text);
 | |
| 
 | |
|             this.$bar = (this.options.layout.parent.object !== null) ? $(this.options.layout.parent.object).css(this.options.layout.parent.css).append($bar) : $bar;
 | |
| 
 | |
|             // Set buttons if available
 | |
|             if (this.options.buttons) {
 | |
| 
 | |
|                 // If we have button disable closeWith & timeout options
 | |
|                 this.options.closeWith = [];
 | |
|                 this.options.timeout = false;
 | |
| 
 | |
|                 var $buttons = $('<div/>').addClass('noty_buttons');
 | |
| 
 | |
|                 (this.options.layout.parent.object !== null) ? this.$bar.find('.noty_bar').append($buttons) : this.$bar.append($buttons);
 | |
| 
 | |
|                 var self = this;
 | |
| 
 | |
|                 $.each(this.options.buttons, function (i, button) {
 | |
|                     var $button = $('<button/>').addClass((button.addClass) ? button.addClass : 'gray').html(button.text)
 | |
|                         .appendTo(self.$bar.find('.noty_buttons'))
 | |
|                         .bind('click', function () {
 | |
|                             if ($.isFunction(button.onClick)) {
 | |
|                                 button.onClick.call($button, self);
 | |
|                             }
 | |
|                         });
 | |
|                 });
 | |
|             }
 | |
| 
 | |
|             // For easy access
 | |
|             this.$message = this.$bar.find('.noty_message');
 | |
|             this.$closeButton = this.$bar.find('.noty_close');
 | |
|             this.$buttons = this.$bar.find('.noty_buttons');
 | |
| 
 | |
|             $.noty.store[this.options.id] = this; // store noty for api
 | |
| 
 | |
|         }, // end _build
 | |
| 
 | |
|         show:function () {
 | |
| 
 | |
|             var self = this;
 | |
| 
 | |
|             $(self.options.layout.container.selector).append(self.$bar);
 | |
| 
 | |
|             self.options.theme.style.apply(self);
 | |
| 
 | |
|             ($.type(self.options.layout.css) === 'function') ? this.options.layout.css.apply(self.$bar) : self.$bar.css(this.options.layout.css || {});
 | |
| 
 | |
|             self.$bar.addClass(self.options.layout.addClass);
 | |
| 
 | |
|             self.options.layout.container.style.apply($(self.options.layout.container.selector));
 | |
| 
 | |
|             self.options.theme.callback.onShow.apply(this);
 | |
| 
 | |
|             if ($.inArray('click', self.options.closeWith) > -1)
 | |
|                 self.$bar.css('cursor', 'pointer').one('click', function () {
 | |
|                     if (self.options.callback.onCloseClick) {
 | |
|                         self.options.callback.onCloseClick.apply(self);
 | |
|                     }
 | |
|                     self.close();
 | |
|                 });
 | |
| 
 | |
|             if ($.inArray('hover', self.options.closeWith) > -1)
 | |
|                 self.$bar.one('mouseenter', function () {
 | |
|                     self.close();
 | |
|                 });
 | |
| 
 | |
|             if ($.inArray('button', self.options.closeWith) > -1)
 | |
|                 self.$closeButton.one('click', function () {
 | |
|                     self.close();
 | |
|                 });
 | |
| 
 | |
|             if ($.inArray('button', self.options.closeWith) == -1)
 | |
|                 self.$closeButton.remove();
 | |
| 
 | |
|             if (self.options.callback.onShow)
 | |
|                 self.options.callback.onShow.apply(self);
 | |
| 
 | |
|             self.$bar.animate(
 | |
|                 self.options.animation.open,
 | |
|                 self.options.animation.speed,
 | |
|                 self.options.animation.easing,
 | |
|                 function () {
 | |
|                     if (self.options.callback.afterShow) self.options.callback.afterShow.apply(self);
 | |
|                     self.shown = true;
 | |
|                 });
 | |
| 
 | |
|             // If noty is have a timeout option
 | |
|             if (self.options.timeout)
 | |
|                 self.$bar.delay(self.options.timeout).promise().done(function () {
 | |
|                     self.close();
 | |
|                 });
 | |
| 
 | |
|             return this;
 | |
| 
 | |
|         }, // end show
 | |
| 
 | |
|         close:function () {
 | |
| 
 | |
|             if (this.closed) return;
 | |
|             if (this.$bar && this.$bar.hasClass('i-am-closing-now')) return;
 | |
| 
 | |
|             var self = this;
 | |
| 
 | |
|             if (!this.shown) { // If we are still waiting in the queue just delete from queue
 | |
|                 var queue = [];
 | |
|                 $.each($.noty.queue, function (i, n) {
 | |
|                     if (n.options.id != self.options.id) {
 | |
|                         queue.push(n);
 | |
|                     }
 | |
|                 });
 | |
|                 $.noty.queue = queue;
 | |
|                 return;
 | |
|             }
 | |
| 
 | |
|             self.$bar.addClass('i-am-closing-now');
 | |
| 
 | |
|             if (self.options.callback.onClose) {
 | |
|                 self.options.callback.onClose.apply(self);
 | |
|             }
 | |
| 
 | |
|             self.$bar.clearQueue().stop().animate(
 | |
|                 self.options.animation.close,
 | |
|                 self.options.animation.speed,
 | |
|                 self.options.animation.easing,
 | |
|                 function () {
 | |
|                     if (self.options.callback.afterClose) self.options.callback.afterClose.apply(self);
 | |
|                 })
 | |
|                 .promise().done(function () {
 | |
| 
 | |
|                     // Modal Cleaning
 | |
|                     if (self.options.modal) {
 | |
|                         $.notyRenderer.setModalCount(-1);
 | |
|                         if ($.notyRenderer.getModalCount() == 0) $('.noty_modal').fadeOut('fast', function () {
 | |
|                             $(this).remove();
 | |
|                         });
 | |
|                     }
 | |
| 
 | |
|                     // Layout Cleaning
 | |
|                     $.notyRenderer.setLayoutCountFor(self, -1);
 | |
|                     if ($.notyRenderer.getLayoutCountFor(self) == 0) $(self.options.layout.container.selector).remove();
 | |
| 
 | |
|                     // Make sure self.$bar has not been removed before attempting to remove it
 | |
|                     if (typeof self.$bar !== 'undefined' && self.$bar !== null ) {
 | |
|                         self.$bar.remove();
 | |
|                         self.$bar = null;
 | |
|                         self.closed = true;
 | |
|                     }
 | |
| 
 | |
|                     delete $.noty.store[self.options.id]; // deleting noty from store
 | |
| 
 | |
|                     self.options.theme.callback.onClose.apply(self);
 | |
| 
 | |
|                     if (!self.options.dismissQueue) {
 | |
|                         // Queue render
 | |
|                         $.noty.ontap = true;
 | |
| 
 | |
|                         $.notyRenderer.render();
 | |
|                     }
 | |
| 
 | |
|                 });
 | |
| 
 | |
|         }, // end close
 | |
| 
 | |
|         setText:function (text) {
 | |
|             if (!this.closed) {
 | |
|                 this.options.text = text;
 | |
|                 this.$bar.find('.noty_text').html(text);
 | |
|             }
 | |
|             return this;
 | |
|         },
 | |
| 
 | |
|         setType:function (type) {
 | |
|             if (!this.closed) {
 | |
|                 this.options.type = type;
 | |
|                 this.options.theme.style.apply(this);
 | |
|                 this.options.theme.callback.onShow.apply(this);
 | |
|             }
 | |
|             return this;
 | |
|         },
 | |
| 
 | |
|         setTimeout:function (time) {
 | |
|             if (!this.closed) {
 | |
|                 var self = this;
 | |
|                 this.options.timeout = time;
 | |
|                 self.$bar.delay(self.options.timeout).promise().done(function () {
 | |
|                     self.close();
 | |
|                 });
 | |
|             }
 | |
|             return this;
 | |
|         },
 | |
| 
 | |
|         closed:false,
 | |
|         shown:false
 | |
| 
 | |
|     }; // end NotyObject
 | |
| 
 | |
|     $.notyRenderer = {};
 | |
| 
 | |
|     $.notyRenderer.init = function (options) {
 | |
| 
 | |
|         // Renderer creates a new noty
 | |
|         var notification = Object.create(NotyObject).init(options);
 | |
| 
 | |
|         (notification.options.force) ? $.noty.queue.unshift(notification) : $.noty.queue.push(notification);
 | |
| 
 | |
|         $.notyRenderer.render();
 | |
| 
 | |
|         return ($.noty.returns == 'object') ? notification : notification.options.id;
 | |
|     };
 | |
| 
 | |
|     $.notyRenderer.render = function () {
 | |
| 
 | |
|         var instance = $.noty.queue[0];
 | |
| 
 | |
|         if ($.type(instance) === 'object') {
 | |
|             if (instance.options.dismissQueue) {
 | |
|                 $.notyRenderer.show($.noty.queue.shift());
 | |
|             } else {
 | |
|                 if ($.noty.ontap) {
 | |
|                     $.notyRenderer.show($.noty.queue.shift());
 | |
|                     $.noty.ontap = false;
 | |
|                 }
 | |
|             }
 | |
|         } else {
 | |
|             $.noty.ontap = true; // Queue is over
 | |
|         }
 | |
| 
 | |
|     };
 | |
| 
 | |
|     $.notyRenderer.show = function (notification) {
 | |
| 
 | |
|         if (notification.options.modal) {
 | |
|             $.notyRenderer.createModalFor(notification);
 | |
|             $.notyRenderer.setModalCount(+1);
 | |
|         }
 | |
| 
 | |
|         // Where is the container?
 | |
|         if ($(notification.options.layout.container.selector).length == 0) {
 | |
|             if (notification.options.custom) {
 | |
|                 notification.options.custom.append($(notification.options.layout.container.object).addClass('i-am-new'));
 | |
|             } else {
 | |
|                 $('body').append($(notification.options.layout.container.object).addClass('i-am-new'));
 | |
|             }
 | |
|         } else {
 | |
|             $(notification.options.layout.container.selector).removeClass('i-am-new');
 | |
|         }
 | |
| 
 | |
|         $.notyRenderer.setLayoutCountFor(notification, +1);
 | |
| 
 | |
|         notification.show();
 | |
|     };
 | |
| 
 | |
|     $.notyRenderer.createModalFor = function (notification) {
 | |
|         if ($('.noty_modal').length == 0)
 | |
|             $('<div/>').addClass('noty_modal').data('noty_modal_count', 0).css(notification.options.theme.modal.css).prependTo($('body')).fadeIn('fast');
 | |
|     };
 | |
| 
 | |
|     $.notyRenderer.getLayoutCountFor = function (notification) {
 | |
|         return $(notification.options.layout.container.selector).data('noty_layout_count') || 0;
 | |
|     };
 | |
| 
 | |
|     $.notyRenderer.setLayoutCountFor = function (notification, arg) {
 | |
|         return $(notification.options.layout.container.selector).data('noty_layout_count', $.notyRenderer.getLayoutCountFor(notification) + arg);
 | |
|     };
 | |
| 
 | |
|     $.notyRenderer.getModalCount = function () {
 | |
|         return $('.noty_modal').data('noty_modal_count') || 0;
 | |
|     };
 | |
| 
 | |
|     $.notyRenderer.setModalCount = function (arg) {
 | |
|         return $('.noty_modal').data('noty_modal_count', $.notyRenderer.getModalCount() + arg);
 | |
|     };
 | |
| 
 | |
|     // This is for custom container
 | |
|     $.fn.noty = function (options) {
 | |
|         options.custom = $(this);
 | |
|         return $.notyRenderer.init(options);
 | |
|     };
 | |
| 
 | |
|     $.noty = {};
 | |
|     $.noty.queue = [];
 | |
|     $.noty.ontap = true;
 | |
|     $.noty.layouts = {};
 | |
|     $.noty.themes = {};
 | |
|     $.noty.returns = 'object';
 | |
|     $.noty.store = {};
 | |
| 
 | |
|     $.noty.get = function (id) {
 | |
|         return $.noty.store.hasOwnProperty(id) ? $.noty.store[id] : false;
 | |
|     };
 | |
| 
 | |
|     $.noty.close = function (id) {
 | |
|         return $.noty.get(id) ? $.noty.get(id).close() : false;
 | |
|     };
 | |
| 
 | |
|     $.noty.setText = function (id, text) {
 | |
|         return $.noty.get(id) ? $.noty.get(id).setText(text) : false;
 | |
|     };
 | |
| 
 | |
|     $.noty.setType = function (id, type) {
 | |
|         return $.noty.get(id) ? $.noty.get(id).setType(type) : false;
 | |
|     };
 | |
| 
 | |
|     $.noty.clearQueue = function () {
 | |
|         $.noty.queue = [];
 | |
|     };
 | |
| 
 | |
|     $.noty.closeAll = function () {
 | |
|         $.noty.clearQueue();
 | |
|         $.each($.noty.store, function (id, noty) {
 | |
|             noty.close();
 | |
|         });
 | |
|     };
 | |
| 
 | |
|     var windowAlert = window.alert;
 | |
| 
 | |
|     $.noty.consumeAlert = function (options) {
 | |
|         window.alert = function (text) {
 | |
|             if (options)
 | |
|                 options.text = text;
 | |
|             else
 | |
|                 options = {text:text};
 | |
| 
 | |
|             $.notyRenderer.init(options);
 | |
|         };
 | |
|     };
 | |
| 
 | |
|     $.noty.stopConsumeAlert = function () {
 | |
|         window.alert = windowAlert;
 | |
|     };
 | |
| 
 | |
|     $.noty.defaults = {
 | |
|         layout:'top',
 | |
|         theme:'defaultTheme',
 | |
|         type:'alert',
 | |
|         text:'',
 | |
|         dismissQueue:true,
 | |
|         template:'<div class="noty_message"><span class="noty_text"></span><div class="noty_close"></div></div>',
 | |
|         animation:{
 | |
|             open:{height:'toggle'},
 | |
|             close:{height:'toggle'},
 | |
|             easing:'swing',
 | |
|             speed:500
 | |
|         },
 | |
|         timeout:false,
 | |
|         force:false,
 | |
|         modal:false,
 | |
|         closeWith:['click'],
 | |
|         callback:{
 | |
|             onShow:function () {
 | |
|             },
 | |
|             afterShow:function () {
 | |
|             },
 | |
|             onClose:function () {
 | |
|             },
 | |
|             afterClose:function () {
 | |
|             },
 | |
|             onCloseClick:function () {
 | |
|             }
 | |
|         },
 | |
|         buttons:false
 | |
|     };
 | |
| 
 | |
|     $(window).resize(function () {
 | |
|         $.each($.noty.layouts, function (index, layout) {
 | |
|             layout.container.style.apply($(layout.container.selector));
 | |
|         });
 | |
|     });
 | |
| 
 | |
| })(jQuery);
 | |
| 
 | |
| // Helpers
 | |
| function noty(options) {
 | |
| 
 | |
|     // This is for BC  -  Will be deleted on v2.2.0
 | |
|     var using_old = 0
 | |
|         , old_to_new = {
 | |
|             'animateOpen':'animation.open',
 | |
|             'animateClose':'animation.close',
 | |
|             'easing':'animation.easing',
 | |
|             'speed':'animation.speed',
 | |
|             'onShow':'callback.onShow',
 | |
|             'onShown':'callback.afterShow',
 | |
|             'onClose':'callback.onClose',
 | |
|             'onCloseClick':'callback.onCloseClick',
 | |
|             'onClosed':'callback.afterClose'
 | |
|         };
 | |
| 
 | |
|     jQuery.each(options, function (key, value) {
 | |
|         if (old_to_new[key]) {
 | |
|             using_old++;
 | |
|             var _new = old_to_new[key].split('.');
 | |
| 
 | |
|             if (!options[_new[0]]) options[_new[0]] = {};
 | |
| 
 | |
|             options[_new[0]][_new[1]] = (value) ? value : function () {
 | |
|             };
 | |
|             delete options[key];
 | |
|         }
 | |
|     });
 | |
| 
 | |
|     if (!options.closeWith) {
 | |
|         options.closeWith = jQuery.noty.defaults.closeWith;
 | |
|     }
 | |
| 
 | |
|     if (options.hasOwnProperty('closeButton')) {
 | |
|         using_old++;
 | |
|         if (options.closeButton) options.closeWith.push('button');
 | |
|         delete options.closeButton;
 | |
|     }
 | |
| 
 | |
|     if (options.hasOwnProperty('closeOnSelfClick')) {
 | |
|         using_old++;
 | |
|         if (options.closeOnSelfClick) options.closeWith.push('click');
 | |
|         delete options.closeOnSelfClick;
 | |
|     }
 | |
| 
 | |
|     if (options.hasOwnProperty('closeOnSelfOver')) {
 | |
|         using_old++;
 | |
|         if (options.closeOnSelfOver) options.closeWith.push('hover');
 | |
|         delete options.closeOnSelfOver;
 | |
|     }
 | |
| 
 | |
|     if (options.hasOwnProperty('custom')) {
 | |
|         using_old++;
 | |
|         if (options.custom.container != 'null') options.custom = options.custom.container;
 | |
|     }
 | |
| 
 | |
|     if (options.hasOwnProperty('cssPrefix')) {
 | |
|         using_old++;
 | |
|         delete options.cssPrefix;
 | |
|     }
 | |
| 
 | |
|     if (options.theme == 'noty_theme_default') {
 | |
|         using_old++;
 | |
|         options.theme = 'defaultTheme';
 | |
|     }
 | |
| 
 | |
|     if (!options.hasOwnProperty('dismissQueue')) {
 | |
|         options.dismissQueue = jQuery.noty.defaults.dismissQueue;
 | |
|     }
 | |
| 
 | |
|     if (options.buttons) {
 | |
|         jQuery.each(options.buttons, function (i, button) {
 | |
|             if (button.click) {
 | |
|                 using_old++;
 | |
|                 button.onClick = button.click;
 | |
|                 delete button.click;
 | |
|             }
 | |
|             if (button.type) {
 | |
|                 using_old++;
 | |
|                 button.addClass = button.type;
 | |
|                 delete button.type;
 | |
|             }
 | |
|         });
 | |
|     }
 | |
| 
 | |
|     if (using_old) {
 | |
|         if (typeof console !== "undefined" && console.warn) {
 | |
|             console.warn('You are using noty v2 with v1.x.x options. @deprecated until v2.2.0 - Please update your options.');
 | |
|         }
 | |
|     }
 | |
| 
 | |
|     // console.log(options);
 | |
|     // End of the BC
 | |
| 
 | |
|     return jQuery.notyRenderer.init(options);
 | |
| }
 | 
