mirror of
https://github.com/WhatCD/Gazelle.git
synced 2024-12-15 03:46:25 +00:00
551 lines
17 KiB
JavaScript
551 lines
17 KiB
JavaScript
|
/**
|
||
|
* noty - jQuery Notification Plugin v2.1.0
|
||
|
* 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;
|
||
|
var buttonElement = this.options.buttonElement ? this.options.buttonElement : 'button';
|
||
|
$.each(this.options.buttons, function (i, button) {
|
||
|
var $button = $('<' + buttonElement +'/>').addClass((button.addClass) ? button.addClass : 'gray').css("cursor", "pointer").html(button.text)
|
||
|
.appendTo(self.$bar.find('.noty_buttons'))
|
||
|
.bind('click', function () {
|
||
|
if ($.isFunction(button.onClick)) {
|
||
|
button.onClick.call($button, self);
|
||
|
}
|
||
|
});
|
||
|
if (buttonElement == 'a' && button.href) {
|
||
|
$button.attr('href', button.href);
|
||
|
}
|
||
|
});
|
||
|
}
|
||
|
|
||
|
// 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 (evt) {
|
||
|
self.stopPropagation(evt);
|
||
|
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 (evt) {
|
||
|
self.stopPropagation(evt);
|
||
|
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();
|
||
|
}
|
||
|
|
||
|
if (self.options.maxVisible > 0 && self.options.dismissQueue) {
|
||
|
$.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;
|
||
|
},
|
||
|
|
||
|
stopPropagation:function (evt) {
|
||
|
evt = evt || window.event;
|
||
|
if (typeof evt.stopPropagation !== "undefined") {
|
||
|
evt.stopPropagation();
|
||
|
} else {
|
||
|
evt.cancelBubble = true;
|
||
|
}
|
||
|
},
|
||
|
|
||
|
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) {
|
||
|
if (instance.options.maxVisible > 0) {
|
||
|
if ($(instance.options.layout.container.selector + ' li').length < instance.options.maxVisible) {
|
||
|
$.notyRenderer.show($.noty.queue.shift());
|
||
|
} else {
|
||
|
|
||
|
}
|
||
|
} else {
|
||
|
$.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,
|
||
|
maxVisible:5,
|
||
|
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
|
||
|
window.noty = 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.hasOwnProperty('maxVisible')) {
|
||
|
options.maxVisible = jQuery.noty.defaults.maxVisible;
|
||
|
}
|
||
|
|
||
|
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);
|
||
|
}
|