mirror of
https://github.com/optim-enterprises-bv/control-pane.git
synced 2025-11-01 18:38:03 +00:00
make network, authkey menu; begining to work in bhyve, sources and bases
This commit is contained in:
1328
public/js/clonos.js
Normal file
1328
public/js/clonos.js
Normal file
File diff suppressed because it is too large
Load Diff
3
public/js/lang-delete/en.js
Normal file
3
public/js/lang-delete/en.js
Normal file
@@ -0,0 +1,3 @@
|
||||
clonos.lang={
|
||||
|
||||
}
|
||||
26
public/js/lang-delete/ru.js
Normal file
26
public/js/lang-delete/ru.js
Normal file
@@ -0,0 +1,26 @@
|
||||
clonos.lang={
|
||||
"Error": "Ошибка",
|
||||
"No data, add something": "Нет данных, добавьте что-нибудь",
|
||||
"available on the jail is not running": "доступно при остановленной клетке",
|
||||
"Log is empty": "Лог пуст",
|
||||
"Exported jails": "Экспортированные клетки",
|
||||
"Download": "Скачать",
|
||||
"Jail is created": "Клетка создана",
|
||||
"Jail already launched": "Клетка уже запущена",
|
||||
"Jail already stopped": "Клетка уже остановлена",
|
||||
"Export not available on launched jail": "Экспорт невозможен на запущенной клетке",
|
||||
"This field cannot be left blank": "Это поле должно быть заполнено",
|
||||
"You need to select one or more jails for clone": "Вам необходимо выбрать одну или несколько клеток для клонирования",
|
||||
"Not running":"Не запущено",
|
||||
"Launched":"Запущено",
|
||||
"Stopped":"Остановлено",
|
||||
"Removed":"Удалено",
|
||||
"Creating…":"Создаётся…",
|
||||
"Starting":"Запускается",
|
||||
"Stopping":"Останавливается",
|
||||
"Removing":"Удаляется",
|
||||
"Exporting":"Экспортируется",
|
||||
"Cloning":"Клонируется",
|
||||
|
||||
"end":"конец"
|
||||
}
|
||||
623
public/js/noty/jquery.noty.js
Normal file
623
public/js/noty/jquery.noty.js
Normal file
@@ -0,0 +1,623 @@
|
||||
/*!
|
||||
@package noty - jQuery Notification Plugin
|
||||
@version version: 2.3.11
|
||||
@contributors https://github.com/needim/noty/graphs/contributors
|
||||
|
||||
@documentation Examples and Documentation - http://needim.github.com/noty/
|
||||
|
||||
@license 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();
|
||||
};
|
||||
}
|
||||
|
||||
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];
|
||||
|
||||
if ($.noty.themes[this.options.theme]) {
|
||||
this.options.theme = $.noty.themes[this.options.theme];
|
||||
if (this.options.theme.template)
|
||||
this.options.template = this.options.theme.template;
|
||||
|
||||
if (this.options.theme.animation)
|
||||
this.options.animation = this.options.theme.animation;
|
||||
}
|
||||
else {
|
||||
this.options.themeClassName = this.options.theme;
|
||||
}
|
||||
|
||||
this.options = $.extend({}, this.options, this.options.layout.options);
|
||||
|
||||
if (this.options.id) {
|
||||
if ($.noty.store[this.options.id]) {
|
||||
return $.noty.store[this.options.id];
|
||||
}
|
||||
} else {
|
||||
this.options.id = 'noty_' + (new Date().getTime() * Math.floor(Math.random() * 1000000));
|
||||
}
|
||||
|
||||
// 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 noty_type_' + this.options.type + '"></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;
|
||||
|
||||
if (this.options.themeClassName)
|
||||
this.$bar.addClass(this.options.themeClassName).addClass('noty_container_type_' + this.options.type);
|
||||
|
||||
// Set buttons if available
|
||||
if (this.options.buttons) {
|
||||
|
||||
var $buttons;
|
||||
// Try find container for buttons in presented template, and create it if not found
|
||||
if (this.$bar.find('.noty_buttons').length > 0) {
|
||||
$buttons = this.$bar.find('.noty_buttons');
|
||||
} else {
|
||||
$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).attr('id', button.id ? button.id : 'button-' + i)
|
||||
.attr('title', button.title)
|
||||
.appendTo($buttons)
|
||||
.on('click', function (event) {
|
||||
if ($.isFunction(button.onClick)) {
|
||||
button.onClick.call($button, self, event);
|
||||
}
|
||||
});
|
||||
});
|
||||
} else {
|
||||
// If buttons is not available, then remove containers if exist
|
||||
this.$bar.find('.noty_buttons').remove();
|
||||
}
|
||||
|
||||
// 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.custom) ? self.options.custom.find(self.options.layout.container.selector).append(self.$bar) : $(self.options.layout.container.selector).append(self.$bar);
|
||||
|
||||
if (self.options.theme && self.options.theme.style)
|
||||
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.within]);
|
||||
|
||||
self.showing = true;
|
||||
|
||||
if (self.options.theme && self.options.theme.style)
|
||||
self.options.theme.callback.onShow.apply(this);
|
||||
|
||||
if ($.inArray('click', self.options.closeWith) > -1)
|
||||
self.$bar.css('cursor', 'pointer').on('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.beforeShow)
|
||||
self.options.callback.beforeShow.apply(self);
|
||||
|
||||
if (typeof self.options.animation.open == 'string') {
|
||||
self.animationTypeOpen = 'css';
|
||||
self.$bar.css('min-height', self.$bar.innerHeight());
|
||||
self.$bar.on('click', function (e) {
|
||||
self.wasClicked = true;
|
||||
});
|
||||
self.$bar.show();
|
||||
|
||||
if (self.options.callback.onShow)
|
||||
self.options.callback.onShow.apply(self);
|
||||
|
||||
self.$bar.addClass(self.options.animation.open).one('webkitAnimationEnd mozAnimationEnd MSAnimationEnd oanimationend animationend', function () {
|
||||
if (self.options.callback.afterShow) self.options.callback.afterShow.apply(self);
|
||||
self.showing = false;
|
||||
self.shown = true;
|
||||
if (self.hasOwnProperty('wasClicked')) {
|
||||
self.$bar.off('click', function (e) {
|
||||
self.wasClicked = true;
|
||||
});
|
||||
self.close();
|
||||
}
|
||||
});
|
||||
|
||||
} else if (typeof self.options.animation.open == 'object' && self.options.animation.open == null) {
|
||||
self.animationTypeOpen = 'none';
|
||||
self.showing = false;
|
||||
self.shown = true;
|
||||
self.$bar.show();
|
||||
|
||||
if (self.options.callback.onShow)
|
||||
self.options.callback.onShow.apply(self);
|
||||
|
||||
self.$bar.queue(function () {
|
||||
if (self.options.callback.afterShow)
|
||||
self.options.callback.afterShow.apply(self);
|
||||
});
|
||||
|
||||
} else {
|
||||
self.animationTypeOpen = 'anim';
|
||||
|
||||
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.showing = false;
|
||||
self.shown = true;
|
||||
});
|
||||
}
|
||||
|
||||
// If noty is have a timeout option
|
||||
if (self.options.timeout) {
|
||||
self.queueClose(self.options.timeout);
|
||||
self.$bar.on('mouseenter', self.dequeueClose.bind(self));
|
||||
self.$bar.on('mouseleave', self.queueClose.bind(self, self.options.timeout));
|
||||
}
|
||||
|
||||
return this;
|
||||
|
||||
}, // end show
|
||||
|
||||
dequeueClose: function () {
|
||||
if (!this.closeTimer) return;
|
||||
clearTimeout(this.closeTimer);
|
||||
this.closeTimer = null;
|
||||
},
|
||||
|
||||
queueClose: function (timeout) {
|
||||
if (this.closeTimer) return;
|
||||
var self = this;
|
||||
self.closeTimer = window.setTimeout(function () {
|
||||
self.close();
|
||||
}, timeout);
|
||||
return self.closeTimer
|
||||
},
|
||||
|
||||
close: function () {
|
||||
if (this.closeTimer) this.dequeueClose();
|
||||
|
||||
if (this.closed) return;
|
||||
if (this.$bar && this.$bar.hasClass('i-am-closing-now')) return;
|
||||
|
||||
var self = this;
|
||||
|
||||
if (this.showing && (this.animationTypeOpen == 'anim' || this.animationTypeOpen == 'none')) {
|
||||
self.$bar.queue(
|
||||
function () {
|
||||
self.close.apply(self);
|
||||
}
|
||||
);
|
||||
return;
|
||||
} else if (this.showing && this.animationTypeOpen == 'css') {
|
||||
self.$bar.on('webkitAnimationEnd mozAnimationEnd MSAnimationEnd oanimationend animationend', function () {
|
||||
self.close();
|
||||
});
|
||||
}
|
||||
|
||||
if (!this.shown && !this.showing) { // 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);
|
||||
}
|
||||
|
||||
if (typeof self.options.animation.close == 'string') {
|
||||
self.$bar.removeClass(self.options.animation.open).addClass(self.options.animation.close).one('webkitAnimationEnd mozAnimationEnd MSAnimationEnd oanimationend animationend', function () {
|
||||
if (self.options.callback.afterClose) self.options.callback.afterClose.apply(self);
|
||||
self.closeCleanUp();
|
||||
});
|
||||
|
||||
} else if (typeof self.options.animation.close == 'object' && self.options.animation.close == null) {
|
||||
self.$bar.dequeue().hide(0, function() {
|
||||
if (self.options.callback.afterClose) self.options.callback.afterClose.apply(self);
|
||||
self.closeCleanUp();
|
||||
});
|
||||
|
||||
} else {
|
||||
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 () {
|
||||
self.closeCleanUp();
|
||||
});
|
||||
}
|
||||
|
||||
}, // end close
|
||||
|
||||
closeCleanUp: function () {
|
||||
|
||||
var self = this;
|
||||
|
||||
// Modal Cleaning
|
||||
if (self.options.modal) {
|
||||
$.notyRenderer.setModalCount(-1);
|
||||
if ($.notyRenderer.getModalCount() == 0 && !$.noty.queue.length) $('.noty_modal').fadeOut(self.options.animation.fadeSpeed, 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) {
|
||||
|
||||
if (typeof self.options.animation.close == 'string') {
|
||||
self.$bar.css('transition', 'all 10ms ease').css('border', 0).css('margin', 0).height(0);
|
||||
self.$bar.one('transitionend webkitTransitionEnd oTransitionEnd MSTransitionEnd', function () {
|
||||
self.$bar.remove();
|
||||
self.$bar = null;
|
||||
self.closed = true;
|
||||
|
||||
if (self.options.theme.callback && self.options.theme.callback.onClose) {
|
||||
self.options.theme.callback.onClose.apply(self);
|
||||
}
|
||||
|
||||
self.handleNext();
|
||||
});
|
||||
} else {
|
||||
self.$bar.remove();
|
||||
self.$bar = null;
|
||||
self.closed = true;
|
||||
|
||||
self.handleNext();
|
||||
}
|
||||
} else {
|
||||
self.handleNext();
|
||||
}
|
||||
|
||||
}, // end close clean up
|
||||
|
||||
handleNext: function () {
|
||||
var self = this;
|
||||
|
||||
delete $.noty.store[self.options.id]; // deleting noty from store
|
||||
|
||||
if (self.options.theme.callback && self.options.theme.callback.onClose) {
|
||||
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();
|
||||
}
|
||||
},
|
||||
|
||||
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,
|
||||
showing: false,
|
||||
shown : false
|
||||
|
||||
}; // end NotyObject
|
||||
|
||||
$.notyRenderer = {};
|
||||
|
||||
$.notyRenderer.init = function (options) {
|
||||
|
||||
// Renderer creates a new noty
|
||||
var notification = Object.create(NotyObject).init(options);
|
||||
|
||||
if (notification.options.killer)
|
||||
$.noty.closeAll();
|
||||
|
||||
(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.custom) {
|
||||
if (notification.options.custom.find(notification.options.layout.container.selector).length == 0) {
|
||||
notification.options.custom.append($(notification.options.layout.container.object).addClass('i-am-new'));
|
||||
}
|
||||
else {
|
||||
notification.options.custom.find(notification.options.layout.container.selector).removeClass('i-am-new');
|
||||
}
|
||||
}
|
||||
else {
|
||||
if ($(notification.options.layout.container.selector).length == 0) {
|
||||
$('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) {
|
||||
var modal = $('<div/>').addClass('noty_modal').addClass(notification.options.theme).data('noty_modal_count', 0);
|
||||
|
||||
if (notification.options.theme.modal && notification.options.theme.modal.css)
|
||||
modal.css(notification.options.theme.modal.css);
|
||||
|
||||
modal.prependTo($('body')).fadeIn(notification.options.animation.fadeSpeed);
|
||||
|
||||
if ($.inArray('backdrop', notification.options.closeWith) > -1)
|
||||
modal.on('click', function () {
|
||||
$.noty.closeAll();
|
||||
});
|
||||
}
|
||||
};
|
||||
|
||||
$.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 : 'topRight',
|
||||
theme : 'relax',
|
||||
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,
|
||||
fadeSpeed: 'fast'
|
||||
},
|
||||
timeout : false,
|
||||
force : false,
|
||||
modal : false,
|
||||
maxVisible : 5,
|
||||
killer : false,
|
||||
closeWith : ['click'],
|
||||
callback : {
|
||||
beforeShow : function () {
|
||||
},
|
||||
onShow : function () {
|
||||
},
|
||||
afterShow : function () {
|
||||
},
|
||||
onClose : function () {
|
||||
},
|
||||
afterClose : function () {
|
||||
},
|
||||
onCloseClick: function () {
|
||||
}
|
||||
},
|
||||
buttons : false
|
||||
};
|
||||
|
||||
$(window).on('resize', function () {
|
||||
$.each($.noty.layouts, function (index, layout) {
|
||||
layout.container.style.apply($(layout.container.selector));
|
||||
});
|
||||
});
|
||||
|
||||
// Helpers
|
||||
window.noty = function noty(options) {
|
||||
return $.notyRenderer.init(options);
|
||||
};
|
||||
30
public/js/noty/layouts/bottom.js
Normal file
30
public/js/noty/layouts/bottom.js
Normal file
@@ -0,0 +1,30 @@
|
||||
$.noty.layouts.bottom = {
|
||||
name : 'bottom',
|
||||
options : {},
|
||||
container: {
|
||||
object : '<ul id="noty_bottom_layout_container" />',
|
||||
selector: 'ul#noty_bottom_layout_container',
|
||||
style : function() {
|
||||
$(this).css({
|
||||
bottom : 0,
|
||||
left : '5%',
|
||||
position : 'fixed',
|
||||
width : '90%',
|
||||
height : 'auto',
|
||||
margin : 0,
|
||||
padding : 0,
|
||||
listStyleType: 'none',
|
||||
zIndex : 9999999
|
||||
});
|
||||
}
|
||||
},
|
||||
parent : {
|
||||
object : '<li />',
|
||||
selector: 'li',
|
||||
css : {}
|
||||
},
|
||||
css : {
|
||||
display: 'none'
|
||||
},
|
||||
addClass : ''
|
||||
};
|
||||
38
public/js/noty/layouts/bottomCenter.js
Normal file
38
public/js/noty/layouts/bottomCenter.js
Normal file
@@ -0,0 +1,38 @@
|
||||
$.noty.layouts.bottomCenter = {
|
||||
name : 'bottomCenter',
|
||||
options : { // overrides options
|
||||
|
||||
},
|
||||
container: {
|
||||
object : '<ul id="noty_bottomCenter_layout_container" />',
|
||||
selector: 'ul#noty_bottomCenter_layout_container',
|
||||
style : function() {
|
||||
$(this).css({
|
||||
bottom : 20,
|
||||
left : 0,
|
||||
position : 'fixed',
|
||||
width : '310px',
|
||||
height : 'auto',
|
||||
margin : 0,
|
||||
padding : 0,
|
||||
listStyleType: 'none',
|
||||
zIndex : 10000000
|
||||
});
|
||||
|
||||
$(this).css({
|
||||
left: ($(window).width() - $(this).outerWidth(false)) / 2 + 'px'
|
||||
});
|
||||
}
|
||||
},
|
||||
parent : {
|
||||
object : '<li />',
|
||||
selector: 'li',
|
||||
css : {}
|
||||
},
|
||||
css : {
|
||||
display: 'none',
|
||||
width : '310px'
|
||||
},
|
||||
addClass : ''
|
||||
};
|
||||
|
||||
39
public/js/noty/layouts/bottomLeft.js
Normal file
39
public/js/noty/layouts/bottomLeft.js
Normal file
@@ -0,0 +1,39 @@
|
||||
$.noty.layouts.bottomLeft = {
|
||||
name : 'bottomLeft',
|
||||
options : { // overrides options
|
||||
|
||||
},
|
||||
container: {
|
||||
object : '<ul id="noty_bottomLeft_layout_container" />',
|
||||
selector: 'ul#noty_bottomLeft_layout_container',
|
||||
style : function() {
|
||||
$(this).css({
|
||||
bottom : 20,
|
||||
left : 20,
|
||||
position : 'fixed',
|
||||
width : '310px',
|
||||
height : 'auto',
|
||||
margin : 0,
|
||||
padding : 0,
|
||||
listStyleType: 'none',
|
||||
zIndex : 10000000
|
||||
});
|
||||
|
||||
if(window.innerWidth < 600) {
|
||||
$(this).css({
|
||||
left: 5
|
||||
});
|
||||
}
|
||||
}
|
||||
},
|
||||
parent : {
|
||||
object : '<li />',
|
||||
selector: 'li',
|
||||
css : {}
|
||||
},
|
||||
css : {
|
||||
display: 'none',
|
||||
width : '310px'
|
||||
},
|
||||
addClass : ''
|
||||
};
|
||||
39
public/js/noty/layouts/bottomRight.js
Normal file
39
public/js/noty/layouts/bottomRight.js
Normal file
@@ -0,0 +1,39 @@
|
||||
$.noty.layouts.bottomRight = {
|
||||
name : 'bottomRight',
|
||||
options : { // overrides options
|
||||
|
||||
},
|
||||
container: {
|
||||
object : '<ul id="noty_bottomRight_layout_container" />',
|
||||
selector: 'ul#noty_bottomRight_layout_container',
|
||||
style : function() {
|
||||
$(this).css({
|
||||
bottom : 20,
|
||||
right : 20,
|
||||
position : 'fixed',
|
||||
width : '310px',
|
||||
height : 'auto',
|
||||
margin : 0,
|
||||
padding : 0,
|
||||
listStyleType: 'none',
|
||||
zIndex : 10000000
|
||||
});
|
||||
|
||||
if(window.innerWidth < 600) {
|
||||
$(this).css({
|
||||
right: 5
|
||||
});
|
||||
}
|
||||
}
|
||||
},
|
||||
parent : {
|
||||
object : '<li />',
|
||||
selector: 'li',
|
||||
css : {}
|
||||
},
|
||||
css : {
|
||||
display: 'none',
|
||||
width : '310px'
|
||||
},
|
||||
addClass : ''
|
||||
};
|
||||
53
public/js/noty/layouts/center.js
Normal file
53
public/js/noty/layouts/center.js
Normal file
@@ -0,0 +1,53 @@
|
||||
$.noty.layouts.center = {
|
||||
name : 'center',
|
||||
options : { // overrides options
|
||||
|
||||
},
|
||||
container: {
|
||||
object : '<ul id="noty_center_layout_container" />',
|
||||
selector: 'ul#noty_center_layout_container',
|
||||
style : function() {
|
||||
$(this).css({
|
||||
position : 'fixed',
|
||||
width : '310px',
|
||||
height : 'auto',
|
||||
margin : 0,
|
||||
padding : 0,
|
||||
listStyleType: 'none',
|
||||
zIndex : 10000000
|
||||
});
|
||||
|
||||
// getting hidden height
|
||||
var dupe = $(this).clone().css({visibility: "hidden", display: "block", position: "absolute", top: 0, left: 0}).attr('id', 'dupe');
|
||||
$("body").append(dupe);
|
||||
dupe.find('.i-am-closing-now').remove();
|
||||
dupe.find('li').css('display', 'block');
|
||||
var actual_height = dupe.height();
|
||||
dupe.remove();
|
||||
|
||||
if($(this).hasClass('i-am-new')) {
|
||||
$(this).css({
|
||||
left: ($(window).width() - $(this).outerWidth(false)) / 2 + 'px',
|
||||
top : ($(window).height() - actual_height) / 2 + 'px'
|
||||
});
|
||||
}
|
||||
else {
|
||||
$(this).animate({
|
||||
left: ($(window).width() - $(this).outerWidth(false)) / 2 + 'px',
|
||||
top : ($(window).height() - actual_height) / 2 + 'px'
|
||||
}, 500);
|
||||
}
|
||||
|
||||
}
|
||||
},
|
||||
parent : {
|
||||
object : '<li />',
|
||||
selector: 'li',
|
||||
css : {}
|
||||
},
|
||||
css : {
|
||||
display: 'none',
|
||||
width : '310px'
|
||||
},
|
||||
addClass : ''
|
||||
};
|
||||
58
public/js/noty/layouts/centerLeft.js
Normal file
58
public/js/noty/layouts/centerLeft.js
Normal file
@@ -0,0 +1,58 @@
|
||||
$.noty.layouts.centerLeft = {
|
||||
name : 'centerLeft',
|
||||
options : { // overrides options
|
||||
|
||||
},
|
||||
container: {
|
||||
object : '<ul id="noty_centerLeft_layout_container" />',
|
||||
selector: 'ul#noty_centerLeft_layout_container',
|
||||
style : function() {
|
||||
$(this).css({
|
||||
left : 20,
|
||||
position : 'fixed',
|
||||
width : '310px',
|
||||
height : 'auto',
|
||||
margin : 0,
|
||||
padding : 0,
|
||||
listStyleType: 'none',
|
||||
zIndex : 10000000
|
||||
});
|
||||
|
||||
// getting hidden height
|
||||
var dupe = $(this).clone().css({visibility: "hidden", display: "block", position: "absolute", top: 0, left: 0}).attr('id', 'dupe');
|
||||
$("body").append(dupe);
|
||||
dupe.find('.i-am-closing-now').remove();
|
||||
dupe.find('li').css('display', 'block');
|
||||
var actual_height = dupe.height();
|
||||
dupe.remove();
|
||||
|
||||
if($(this).hasClass('i-am-new')) {
|
||||
$(this).css({
|
||||
top: ($(window).height() - actual_height) / 2 + 'px'
|
||||
});
|
||||
}
|
||||
else {
|
||||
$(this).animate({
|
||||
top: ($(window).height() - actual_height) / 2 + 'px'
|
||||
}, 500);
|
||||
}
|
||||
|
||||
if(window.innerWidth < 600) {
|
||||
$(this).css({
|
||||
left: 5
|
||||
});
|
||||
}
|
||||
|
||||
}
|
||||
},
|
||||
parent : {
|
||||
object : '<li />',
|
||||
selector: 'li',
|
||||
css : {}
|
||||
},
|
||||
css : {
|
||||
display: 'none',
|
||||
width : '310px'
|
||||
},
|
||||
addClass : ''
|
||||
};
|
||||
58
public/js/noty/layouts/centerRight.js
Normal file
58
public/js/noty/layouts/centerRight.js
Normal file
@@ -0,0 +1,58 @@
|
||||
$.noty.layouts.centerRight = {
|
||||
name : 'centerRight',
|
||||
options : { // overrides options
|
||||
|
||||
},
|
||||
container: {
|
||||
object : '<ul id="noty_centerRight_layout_container" />',
|
||||
selector: 'ul#noty_centerRight_layout_container',
|
||||
style : function() {
|
||||
$(this).css({
|
||||
right : 20,
|
||||
position : 'fixed',
|
||||
width : '310px',
|
||||
height : 'auto',
|
||||
margin : 0,
|
||||
padding : 0,
|
||||
listStyleType: 'none',
|
||||
zIndex : 10000000
|
||||
});
|
||||
|
||||
// getting hidden height
|
||||
var dupe = $(this).clone().css({visibility: "hidden", display: "block", position: "absolute", top: 0, left: 0}).attr('id', 'dupe');
|
||||
$("body").append(dupe);
|
||||
dupe.find('.i-am-closing-now').remove();
|
||||
dupe.find('li').css('display', 'block');
|
||||
var actual_height = dupe.height();
|
||||
dupe.remove();
|
||||
|
||||
if($(this).hasClass('i-am-new')) {
|
||||
$(this).css({
|
||||
top: ($(window).height() - actual_height) / 2 + 'px'
|
||||
});
|
||||
}
|
||||
else {
|
||||
$(this).animate({
|
||||
top: ($(window).height() - actual_height) / 2 + 'px'
|
||||
}, 500);
|
||||
}
|
||||
|
||||
if(window.innerWidth < 600) {
|
||||
$(this).css({
|
||||
right: 5
|
||||
});
|
||||
}
|
||||
|
||||
}
|
||||
},
|
||||
parent : {
|
||||
object : '<li />',
|
||||
selector: 'li',
|
||||
css : {}
|
||||
},
|
||||
css : {
|
||||
display: 'none',
|
||||
width : '310px'
|
||||
},
|
||||
addClass : ''
|
||||
};
|
||||
27
public/js/noty/layouts/inline.js
Normal file
27
public/js/noty/layouts/inline.js
Normal file
@@ -0,0 +1,27 @@
|
||||
$.noty.layouts.inline = {
|
||||
name : 'inline',
|
||||
options : {},
|
||||
container: {
|
||||
object : '<ul class="noty_inline_layout_container" />',
|
||||
selector: 'ul.noty_inline_layout_container',
|
||||
style : function() {
|
||||
$(this).css({
|
||||
width : '100%',
|
||||
height : 'auto',
|
||||
margin : 0,
|
||||
padding : 0,
|
||||
listStyleType: 'none',
|
||||
zIndex : 9999999
|
||||
});
|
||||
}
|
||||
},
|
||||
parent : {
|
||||
object : '<li />',
|
||||
selector: 'li',
|
||||
css : {}
|
||||
},
|
||||
css : {
|
||||
display: 'none'
|
||||
},
|
||||
addClass : ''
|
||||
};
|
||||
30
public/js/noty/layouts/top.js
Normal file
30
public/js/noty/layouts/top.js
Normal file
@@ -0,0 +1,30 @@
|
||||
$.noty.layouts.top = {
|
||||
name : 'top',
|
||||
options : {},
|
||||
container: {
|
||||
object : '<ul id="noty_top_layout_container" />',
|
||||
selector: 'ul#noty_top_layout_container',
|
||||
style : function() {
|
||||
$(this).css({
|
||||
top : 0,
|
||||
left : '5%',
|
||||
position : 'fixed',
|
||||
width : '90%',
|
||||
height : 'auto',
|
||||
margin : 0,
|
||||
padding : 0,
|
||||
listStyleType: 'none',
|
||||
zIndex : 9999999
|
||||
});
|
||||
}
|
||||
},
|
||||
parent : {
|
||||
object : '<li />',
|
||||
selector: 'li',
|
||||
css : {}
|
||||
},
|
||||
css : {
|
||||
display: 'none'
|
||||
},
|
||||
addClass : ''
|
||||
};
|
||||
37
public/js/noty/layouts/topCenter.js
Normal file
37
public/js/noty/layouts/topCenter.js
Normal file
@@ -0,0 +1,37 @@
|
||||
$.noty.layouts.topCenter = {
|
||||
name : 'topCenter',
|
||||
options : { // overrides options
|
||||
|
||||
},
|
||||
container: {
|
||||
object : '<ul id="noty_topCenter_layout_container" />',
|
||||
selector: 'ul#noty_topCenter_layout_container',
|
||||
style : function() {
|
||||
$(this).css({
|
||||
top : 20,
|
||||
left : 0,
|
||||
position : 'fixed',
|
||||
width : '310px',
|
||||
height : 'auto',
|
||||
margin : 0,
|
||||
padding : 0,
|
||||
listStyleType: 'none',
|
||||
zIndex : 10000000
|
||||
});
|
||||
|
||||
$(this).css({
|
||||
left: ($(window).width() - $(this).outerWidth(false)) / 2 + 'px'
|
||||
});
|
||||
}
|
||||
},
|
||||
parent : {
|
||||
object : '<li />',
|
||||
selector: 'li',
|
||||
css : {}
|
||||
},
|
||||
css : {
|
||||
display: 'none',
|
||||
width : '310px'
|
||||
},
|
||||
addClass : ''
|
||||
};
|
||||
39
public/js/noty/layouts/topLeft.js
Normal file
39
public/js/noty/layouts/topLeft.js
Normal file
@@ -0,0 +1,39 @@
|
||||
$.noty.layouts.topLeft = {
|
||||
name : 'topLeft',
|
||||
options : { // overrides options
|
||||
|
||||
},
|
||||
container: {
|
||||
object : '<ul id="noty_topLeft_layout_container" />',
|
||||
selector: 'ul#noty_topLeft_layout_container',
|
||||
style : function() {
|
||||
$(this).css({
|
||||
top : 20,
|
||||
left : 20,
|
||||
position : 'fixed',
|
||||
width : '310px',
|
||||
height : 'auto',
|
||||
margin : 0,
|
||||
padding : 0,
|
||||
listStyleType: 'none',
|
||||
zIndex : 10000000
|
||||
});
|
||||
|
||||
if(window.innerWidth < 600) {
|
||||
$(this).css({
|
||||
left: 5
|
||||
});
|
||||
}
|
||||
}
|
||||
},
|
||||
parent : {
|
||||
object : '<li />',
|
||||
selector: 'li',
|
||||
css : {}
|
||||
},
|
||||
css : {
|
||||
display: 'none',
|
||||
width : '310px'
|
||||
},
|
||||
addClass : ''
|
||||
};
|
||||
39
public/js/noty/layouts/topRight.js
Normal file
39
public/js/noty/layouts/topRight.js
Normal file
@@ -0,0 +1,39 @@
|
||||
$.noty.layouts.topRight = {
|
||||
name : 'topRight',
|
||||
options : { // overrides options
|
||||
|
||||
},
|
||||
container: {
|
||||
object : '<ul id="noty_topRight_layout_container" />',
|
||||
selector: 'ul#noty_topRight_layout_container',
|
||||
style : function() {
|
||||
$(this).css({
|
||||
top : 20,
|
||||
right : 20,
|
||||
position : 'fixed',
|
||||
width : '310px',
|
||||
height : 'auto',
|
||||
margin : 0,
|
||||
padding : 0,
|
||||
listStyleType: 'none',
|
||||
zIndex : 10000000
|
||||
});
|
||||
|
||||
if(window.innerWidth < 600) {
|
||||
$(this).css({
|
||||
right: 5
|
||||
});
|
||||
}
|
||||
}
|
||||
},
|
||||
parent : {
|
||||
object : '<li />',
|
||||
selector: 'li',
|
||||
css : {}
|
||||
},
|
||||
css : {
|
||||
display: 'none',
|
||||
width : '310px'
|
||||
},
|
||||
addClass : ''
|
||||
};
|
||||
1768
public/js/noty/packaged/jquery.noty.packaged.js
Normal file
1768
public/js/noty/packaged/jquery.noty.packaged.js
Normal file
File diff suppressed because it is too large
Load Diff
1
public/js/noty/packaged/jquery.noty.packaged.min.js
vendored
Normal file
1
public/js/noty/packaged/jquery.noty.packaged.min.js
vendored
Normal file
File diff suppressed because one or more lines are too long
432
public/js/noty/promise.js
Normal file
432
public/js/noty/promise.js
Normal file
@@ -0,0 +1,432 @@
|
||||
/*!
|
||||
* Noty Helpers Javascript From JQuery Javascript Library
|
||||
*
|
||||
* Ported by Maksim Pecherskiy. Original Licensing:
|
||||
*
|
||||
* http://jquery.com/
|
||||
*
|
||||
* Copyright 2011, John Resig
|
||||
* Dual licensed under the MIT or GPL Version 2 licenses.
|
||||
* http://jquery.org/license
|
||||
*
|
||||
* Includes Sizzle.js
|
||||
* http://sizzlejs.com/
|
||||
* Copyright 2011, The Dojo Foundation
|
||||
* Released under the MIT, BSD, and GPL Licenses.
|
||||
*
|
||||
* Date: Mon Nov 21 21:11:03 2011 -0500
|
||||
*/
|
||||
|
||||
|
||||
(function(){
|
||||
|
||||
// String to Object flags format cache
|
||||
var flagsCache = {};
|
||||
|
||||
// Convert String-formatted flags into Object-formatted ones and store in cache
|
||||
function createFlags( flags ) {
|
||||
var object = flagsCache[ flags ] = {},
|
||||
i, length;
|
||||
flags = flags.split( /\s+/ );
|
||||
for ( i = 0, length = flags.length; i < length; i++ ) {
|
||||
object[ flags[i] ] = true;
|
||||
}
|
||||
return object;
|
||||
}
|
||||
|
||||
jQuery.extend({
|
||||
|
||||
_mark: function( elem, type ) {
|
||||
if ( elem ) {
|
||||
type = (type || "fx") + "mark";
|
||||
jQuery.data( elem, type, (jQuery.data(elem,type,undefined,true) || 0) + 1, true );
|
||||
}
|
||||
},
|
||||
|
||||
_unmark: function( force, elem, type ) {
|
||||
if ( force !== true ) {
|
||||
type = elem;
|
||||
elem = force;
|
||||
force = false;
|
||||
}
|
||||
if ( elem ) {
|
||||
type = type || "fx";
|
||||
var key = type + "mark",
|
||||
count = force ? 0 : ( (jQuery.data( elem, key, undefined, true) || 1 ) - 1 );
|
||||
if ( count ) {
|
||||
jQuery.data( elem, key, count, true );
|
||||
} else {
|
||||
jQuery.removeData( elem, key, true );
|
||||
handleQueueMarkDefer( elem, type, "mark" );
|
||||
}
|
||||
}
|
||||
},
|
||||
|
||||
queue: function( elem, type, data ) {
|
||||
if ( elem ) {
|
||||
type = (type || "fx") + "queue";
|
||||
var q = jQuery.data( elem, type, undefined, true );
|
||||
// Speed up dequeue by getting out quickly if this is just a lookup
|
||||
if ( data ) {
|
||||
if ( !q || jQuery.isArray(data) ) {
|
||||
q = jQuery.data( elem, type, jQuery.makeArray(data), true );
|
||||
} else {
|
||||
q.push( data );
|
||||
}
|
||||
}
|
||||
return q || [];
|
||||
}
|
||||
},
|
||||
|
||||
dequeue: function( elem, type ) {
|
||||
type = type || "fx";
|
||||
|
||||
var queue = jQuery.queue( elem, type ),
|
||||
fn = queue.shift(),
|
||||
defer;
|
||||
|
||||
// If the fx queue is dequeued, always remove the progress sentinel
|
||||
if ( fn === "inprogress" ) {
|
||||
fn = queue.shift();
|
||||
}
|
||||
|
||||
if ( fn ) {
|
||||
// Add a progress sentinel to prevent the fx queue from being
|
||||
// automatically dequeued
|
||||
if ( type === "fx" ) {
|
||||
queue.unshift("inprogress");
|
||||
}
|
||||
|
||||
fn.call(elem, function() {
|
||||
jQuery.dequeue(elem, type);
|
||||
});
|
||||
}
|
||||
|
||||
if ( !queue.length ) {
|
||||
jQuery.removeData( elem, type + "queue", true );
|
||||
handleQueueMarkDefer( elem, type, "queue" );
|
||||
}
|
||||
}
|
||||
});
|
||||
|
||||
jQuery.fn.extend({
|
||||
queue: function( type, data ) {
|
||||
if ( typeof type !== "string" ) {
|
||||
data = type;
|
||||
type = "fx";
|
||||
}
|
||||
|
||||
if ( data === undefined ) {
|
||||
return jQuery.queue( this[0], type );
|
||||
}
|
||||
return this.each(function() {
|
||||
var queue = jQuery.queue( this, type, data );
|
||||
|
||||
if ( type === "fx" && queue[0] !== "inprogress" ) {
|
||||
jQuery.dequeue( this, type );
|
||||
}
|
||||
});
|
||||
},
|
||||
dequeue: function( type ) {
|
||||
return this.each(function() {
|
||||
jQuery.dequeue( this, type );
|
||||
});
|
||||
},
|
||||
// Based off of the plugin by Clint Helfers, with permission.
|
||||
// http://blindsignals.com/index.php/2009/07/jquery-delay/
|
||||
delay: function( time, type ) {
|
||||
time = jQuery.fx ? jQuery.fx.speeds[time] || time : time;
|
||||
type = type || "fx";
|
||||
|
||||
return this.queue( type, function() {
|
||||
var elem = this;
|
||||
setTimeout(function() {
|
||||
jQuery.dequeue( elem, type );
|
||||
}, time );
|
||||
});
|
||||
},
|
||||
clearQueue: function( type ) {
|
||||
return this.queue( type || "fx", [] );
|
||||
},
|
||||
// Get a promise resolved when queues of a certain type
|
||||
// are emptied (fx is the type by default)
|
||||
promise: function( type, object ) {
|
||||
if ( typeof type !== "string" ) {
|
||||
object = type;
|
||||
type = undefined;
|
||||
}
|
||||
type = type || "fx";
|
||||
var defer = jQuery.Deferred(),
|
||||
elements = this,
|
||||
i = elements.length,
|
||||
count = 1,
|
||||
deferDataKey = type + "defer",
|
||||
queueDataKey = type + "queue",
|
||||
markDataKey = type + "mark",
|
||||
tmp;
|
||||
function resolve() {
|
||||
if ( !( --count ) ) {
|
||||
defer.resolveWith( elements, [ elements ] );
|
||||
}
|
||||
}
|
||||
while( i-- ) {
|
||||
if (( tmp = jQuery.data( elements[ i ], deferDataKey, undefined, true ) ||
|
||||
( jQuery.data( elements[ i ], queueDataKey, undefined, true ) ||
|
||||
jQuery.data( elements[ i ], markDataKey, undefined, true ) ) &&
|
||||
jQuery.data( elements[ i ], deferDataKey, jQuery._Deferred(), true ) )) {
|
||||
count++;
|
||||
tmp.done( resolve );
|
||||
}
|
||||
}
|
||||
resolve();
|
||||
return defer.promise();
|
||||
}
|
||||
});
|
||||
|
||||
function handleQueueMarkDefer( elem, type, src ) {
|
||||
var deferDataKey = type + "defer",
|
||||
queueDataKey = type + "queue",
|
||||
markDataKey = type + "mark",
|
||||
defer = jQuery._data( elem, deferDataKey );
|
||||
if ( defer &&
|
||||
( src === "queue" || !jQuery._data(elem, queueDataKey) ) &&
|
||||
( src === "mark" || !jQuery._data(elem, markDataKey) ) ) {
|
||||
// Give room for hard-coded callbacks to fire first
|
||||
// and eventually mark/queue something else on the element
|
||||
setTimeout( function() {
|
||||
if ( !jQuery._data( elem, queueDataKey ) &&
|
||||
!jQuery._data( elem, markDataKey ) ) {
|
||||
jQuery.removeData( elem, deferDataKey, true );
|
||||
defer.fire();
|
||||
}
|
||||
}, 0 );
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
|
||||
jQuery.Callbacks = function( flags ) {
|
||||
|
||||
// Convert flags from String-formatted to Object-formatted
|
||||
// (we check in cache first)
|
||||
flags = flags ? ( /*flagsCache[ flags ] || */createFlags( flags ) ) : {};
|
||||
|
||||
var // Actual callback list
|
||||
list = [],
|
||||
// Stack of fire calls for repeatable lists
|
||||
stack = [],
|
||||
// Last fire value (for non-forgettable lists)
|
||||
memory,
|
||||
// Flag to know if list is currently firing
|
||||
firing,
|
||||
// First callback to fire (used internally by add and fireWith)
|
||||
firingStart,
|
||||
// End of the loop when firing
|
||||
firingLength,
|
||||
// Index of currently firing callback (modified by remove if needed)
|
||||
firingIndex,
|
||||
// Add one or several callbacks to the list
|
||||
add = function( args ) {
|
||||
var i,
|
||||
length,
|
||||
elem,
|
||||
type,
|
||||
actual;
|
||||
for ( i = 0, length = args.length; i < length; i++ ) {
|
||||
elem = args[ i ];
|
||||
type = jQuery.type( elem );
|
||||
if ( type === "array" ) {
|
||||
// Inspect recursively
|
||||
add( elem );
|
||||
} else if ( type === "function" ) {
|
||||
// Add if not in unique mode and callback is not in
|
||||
if ( !flags.unique || !self.has( elem ) ) {
|
||||
list.push( elem );
|
||||
}
|
||||
}
|
||||
}
|
||||
},
|
||||
// Fire callbacks
|
||||
fire = function( context, args ) {
|
||||
args = args || [];
|
||||
memory = !flags.memory || [ context, args ];
|
||||
firing = true;
|
||||
firingIndex = firingStart || 0;
|
||||
firingStart = 0;
|
||||
firingLength = list.length;
|
||||
for ( ; list && firingIndex < firingLength; firingIndex++ ) {
|
||||
if ( list[ firingIndex ].apply( context, args ) === false && flags.stopOnFalse ) {
|
||||
memory = true; // Mark as halted
|
||||
break;
|
||||
}
|
||||
}
|
||||
firing = false;
|
||||
if ( list ) {
|
||||
if ( !flags.once ) {
|
||||
if ( stack && stack.length ) {
|
||||
memory = stack.shift();
|
||||
self.fireWith( memory[ 0 ], memory[ 1 ] );
|
||||
}
|
||||
} else if ( memory === true ) {
|
||||
self.disable();
|
||||
} else {
|
||||
list = [];
|
||||
}
|
||||
}
|
||||
},
|
||||
// Actual Callbacks object
|
||||
self = {
|
||||
// Add a callback or a collection of callbacks to the list
|
||||
add: function() {
|
||||
if ( list ) {
|
||||
var length = list.length;
|
||||
add( arguments );
|
||||
// Do we need to add the callbacks to the
|
||||
// current firing batch?
|
||||
if ( firing ) {
|
||||
firingLength = list.length;
|
||||
// With memory, if we're not firing then
|
||||
// we should call right away, unless previous
|
||||
// firing was halted (stopOnFalse)
|
||||
} else if ( memory && memory !== true ) {
|
||||
firingStart = length;
|
||||
fire( memory[ 0 ], memory[ 1 ] );
|
||||
}
|
||||
}
|
||||
return this;
|
||||
},
|
||||
// Remove a callback from the list
|
||||
remove: function() {
|
||||
if ( list ) {
|
||||
var args = arguments,
|
||||
argIndex = 0,
|
||||
argLength = args.length;
|
||||
for ( ; argIndex < argLength ; argIndex++ ) {
|
||||
for ( var i = 0; i < list.length; i++ ) {
|
||||
if ( args[ argIndex ] === list[ i ] ) {
|
||||
// Handle firingIndex and firingLength
|
||||
if ( firing ) {
|
||||
if ( i <= firingLength ) {
|
||||
firingLength--;
|
||||
if ( i <= firingIndex ) {
|
||||
firingIndex--;
|
||||
}
|
||||
}
|
||||
}
|
||||
// Remove the element
|
||||
list.splice( i--, 1 );
|
||||
// If we have some unicity property then
|
||||
// we only need to do this once
|
||||
if ( flags.unique ) {
|
||||
break;
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
return this;
|
||||
},
|
||||
// Control if a given callback is in the list
|
||||
has: function( fn ) {
|
||||
if ( list ) {
|
||||
var i = 0,
|
||||
length = list.length;
|
||||
for ( ; i < length; i++ ) {
|
||||
if ( fn === list[ i ] ) {
|
||||
return true;
|
||||
}
|
||||
}
|
||||
}
|
||||
return false;
|
||||
},
|
||||
// Remove all callbacks from the list
|
||||
empty: function() {
|
||||
list = [];
|
||||
return this;
|
||||
},
|
||||
// Have the list do nothing anymore
|
||||
disable: function() {
|
||||
list = stack = memory = undefined;
|
||||
return this;
|
||||
},
|
||||
// Is it disabled?
|
||||
disabled: function() {
|
||||
return !list;
|
||||
},
|
||||
// Lock the list in its current state
|
||||
lock: function() {
|
||||
stack = undefined;
|
||||
if ( !memory || memory === true ) {
|
||||
self.disable();
|
||||
}
|
||||
return this;
|
||||
},
|
||||
// Is it locked?
|
||||
locked: function() {
|
||||
return !stack;
|
||||
},
|
||||
// Call all callbacks with the given context and arguments
|
||||
fireWith: function( context, args ) {
|
||||
if ( stack ) {
|
||||
if ( firing ) {
|
||||
if ( !flags.once ) {
|
||||
stack.push( [ context, args ] );
|
||||
}
|
||||
} else if ( !( flags.once && memory ) ) {
|
||||
fire( context, args );
|
||||
}
|
||||
}
|
||||
return this;
|
||||
},
|
||||
// Call all the callbacks with the given arguments
|
||||
fire: function() {
|
||||
self.fireWith( this, arguments );
|
||||
return this;
|
||||
},
|
||||
// To know if the callbacks have already been called at least once
|
||||
fired: function() {
|
||||
return !!memory;
|
||||
}
|
||||
};
|
||||
|
||||
return self;
|
||||
};
|
||||
|
||||
|
||||
|
||||
jQuery.fn.extend({
|
||||
// Get a promise resolved when queues of a certain type
|
||||
// are emptied (fx is the type by default)
|
||||
promise: function( type, object ) {
|
||||
if ( typeof type !== "string" ) {
|
||||
object = type;
|
||||
type = undefined;
|
||||
}
|
||||
type = type || "fx";
|
||||
var defer = jQuery.Deferred(),
|
||||
elements = this,
|
||||
i = elements.length,
|
||||
count = 1,
|
||||
deferDataKey = type + "defer",
|
||||
queueDataKey = type + "queue",
|
||||
markDataKey = type + "mark",
|
||||
tmp;
|
||||
function resolve() {
|
||||
if ( !( --count ) ) {
|
||||
defer.resolveWith( elements, [ elements ] );
|
||||
}
|
||||
}
|
||||
while( i-- ) {
|
||||
if (( tmp = jQuery.data( elements[ i ], deferDataKey, undefined, true ) ||
|
||||
( jQuery.data( elements[ i ], queueDataKey, undefined, true ) ||
|
||||
jQuery.data( elements[ i ], markDataKey, undefined, true ) ) &&
|
||||
jQuery.data( elements[ i ], deferDataKey, jQuery.Callbacks( "once memory" ), true ) )) {
|
||||
count++;
|
||||
tmp.add( resolve );
|
||||
}
|
||||
}
|
||||
resolve();
|
||||
return defer.promise();
|
||||
}
|
||||
});
|
||||
})();
|
||||
58
public/js/noty/themes/bootstrap.js
vendored
Normal file
58
public/js/noty/themes/bootstrap.js
vendored
Normal file
@@ -0,0 +1,58 @@
|
||||
$.noty.themes.bootstrapTheme = {
|
||||
name : 'bootstrapTheme',
|
||||
modal : {
|
||||
css: {
|
||||
position : 'fixed',
|
||||
width : '100%',
|
||||
height : '100%',
|
||||
backgroundColor: '#000',
|
||||
zIndex : 10000,
|
||||
opacity : 0.6,
|
||||
display : 'none',
|
||||
left : 0,
|
||||
top : 0,
|
||||
wordBreak : 'break-all'
|
||||
}
|
||||
},
|
||||
style : function () {
|
||||
|
||||
var containerSelector = this.options.layout.container.selector;
|
||||
$(containerSelector).addClass('list-group');
|
||||
|
||||
this.$closeButton.append('<span aria-hidden="true">×</span><span class="sr-only">Close</span>');
|
||||
this.$closeButton.addClass('close');
|
||||
|
||||
this.$bar.addClass("list-group-item").css('padding', '0px');
|
||||
|
||||
switch (this.options.type) {
|
||||
case 'alert':
|
||||
case 'notification':
|
||||
this.$bar.addClass("list-group-item-info");
|
||||
break;
|
||||
case 'warning':
|
||||
this.$bar.addClass("list-group-item-warning");
|
||||
break;
|
||||
case 'error':
|
||||
this.$bar.addClass("list-group-item-danger");
|
||||
break;
|
||||
case 'information':
|
||||
this.$bar.addClass("list-group-item-info");
|
||||
break;
|
||||
case 'success':
|
||||
this.$bar.addClass("list-group-item-success");
|
||||
break;
|
||||
}
|
||||
|
||||
this.$message.css({
|
||||
textAlign: 'center',
|
||||
padding : '8px 10px 9px',
|
||||
width : 'auto',
|
||||
position : 'relative'
|
||||
});
|
||||
},
|
||||
callback: {
|
||||
onShow : function () { },
|
||||
onClose: function () { }
|
||||
}
|
||||
};
|
||||
|
||||
182
public/js/noty/themes/default.js
Normal file
182
public/js/noty/themes/default.js
Normal file
@@ -0,0 +1,182 @@
|
||||
$.noty.themes.defaultTheme = {
|
||||
name : 'defaultTheme',
|
||||
helpers : {
|
||||
borderFix: function () {
|
||||
if (this.options.dismissQueue) {
|
||||
var selector = this.options.layout.container.selector + ' ' + this.options.layout.parent.selector;
|
||||
switch (this.options.layout.name) {
|
||||
case 'top':
|
||||
$(selector).css({borderRadius: '0px 0px 0px 0px'});
|
||||
$(selector).last().css({borderRadius: '0px 0px 5px 5px'});
|
||||
break;
|
||||
case 'topCenter':
|
||||
case 'topLeft':
|
||||
case 'topRight':
|
||||
case 'bottomCenter':
|
||||
case 'bottomLeft':
|
||||
case 'bottomRight':
|
||||
case 'center':
|
||||
case 'centerLeft':
|
||||
case 'centerRight':
|
||||
case 'inline':
|
||||
$(selector).css({borderRadius: '0px 0px 0px 0px'});
|
||||
$(selector).first().css({'border-top-left-radius': '5px', 'border-top-right-radius': '5px'});
|
||||
$(selector).last().css({'border-bottom-left-radius': '5px', 'border-bottom-right-radius': '5px'});
|
||||
break;
|
||||
case 'bottom':
|
||||
$(selector).css({borderRadius: '0px 0px 0px 0px'});
|
||||
$(selector).first().css({borderRadius: '5px 5px 0px 0px'});
|
||||
break;
|
||||
default:
|
||||
break;
|
||||
}
|
||||
}
|
||||
}
|
||||
},
|
||||
modal : {
|
||||
css: {
|
||||
position : 'fixed',
|
||||
width : '100%',
|
||||
height : '100%',
|
||||
backgroundColor: '#000',
|
||||
zIndex : 10000,
|
||||
opacity : 0.6,
|
||||
display : 'none',
|
||||
left : 0,
|
||||
top : 0
|
||||
}
|
||||
},
|
||||
style : function () {
|
||||
|
||||
this.$bar.css({
|
||||
overflow : 'hidden',
|
||||
background: "url('') repeat-x scroll left top #fff"
|
||||
});
|
||||
|
||||
this.$message.css({
|
||||
textAlign : 'center',
|
||||
padding : '8px 10px 9px',
|
||||
width : 'auto',
|
||||
position : 'relative'
|
||||
});
|
||||
|
||||
this.$closeButton.css({
|
||||
position : 'absolute',
|
||||
top : 4, right: 4,
|
||||
width : 10, height: 10,
|
||||
background: "url()",
|
||||
display : 'none',
|
||||
cursor : 'pointer'
|
||||
});
|
||||
|
||||
this.$buttons.css({
|
||||
padding : 5,
|
||||
textAlign : 'right',
|
||||
borderTop : '1px solid #ccc',
|
||||
backgroundColor: '#fff'
|
||||
});
|
||||
|
||||
this.$buttons.find('button').css({
|
||||
marginLeft: 5
|
||||
});
|
||||
|
||||
this.$buttons.find('button:first').css({
|
||||
marginLeft: 0
|
||||
});
|
||||
|
||||
this.$bar.on({
|
||||
mouseenter: function () {
|
||||
$(this).find('.noty_close').stop().fadeTo('normal', 1);
|
||||
},
|
||||
mouseleave: function () {
|
||||
$(this).find('.noty_close').stop().fadeTo('normal', 0);
|
||||
}
|
||||
});
|
||||
|
||||
switch (this.options.layout.name) {
|
||||
case 'top':
|
||||
this.$bar.css({
|
||||
borderRadius: '0px 0px 5px 5px',
|
||||
borderBottom: '2px solid #eee',
|
||||
borderLeft : '2px solid #eee',
|
||||
borderRight : '2px solid #eee',
|
||||
boxShadow : "0 2px 4px rgba(0, 0, 0, 0.1)"
|
||||
});
|
||||
break;
|
||||
case 'topCenter':
|
||||
case 'center':
|
||||
case 'bottomCenter':
|
||||
case 'inline':
|
||||
this.$bar.css({
|
||||
borderRadius: '5px',
|
||||
border : '1px solid #eee',
|
||||
boxShadow : "0 2px 4px rgba(0, 0, 0, 0.1)"
|
||||
});
|
||||
this.$message.css({textAlign: 'center'});
|
||||
break;
|
||||
case 'topLeft':
|
||||
case 'topRight':
|
||||
case 'bottomLeft':
|
||||
case 'bottomRight':
|
||||
case 'centerLeft':
|
||||
case 'centerRight':
|
||||
this.$bar.css({
|
||||
borderRadius: '5px',
|
||||
border : '1px solid #eee',
|
||||
boxShadow : "0 2px 4px rgba(0, 0, 0, 0.1)"
|
||||
});
|
||||
this.$message.css({textAlign: 'left'});
|
||||
break;
|
||||
case 'bottom':
|
||||
this.$bar.css({
|
||||
borderRadius: '5px 5px 0px 0px',
|
||||
borderTop : '2px solid #eee',
|
||||
borderLeft : '2px solid #eee',
|
||||
borderRight : '2px solid #eee',
|
||||
boxShadow : "0 -2px 4px rgba(0, 0, 0, 0.1)"
|
||||
});
|
||||
break;
|
||||
default:
|
||||
this.$bar.css({
|
||||
border : '2px solid #eee',
|
||||
boxShadow: "0 2px 4px rgba(0, 0, 0, 0.1)"
|
||||
});
|
||||
break;
|
||||
}
|
||||
|
||||
switch (this.options.type) {
|
||||
case 'alert':
|
||||
case 'notification':
|
||||
this.$bar.css({backgroundColor: '#FFF', borderColor: '#CCC', color: '#444'});
|
||||
break;
|
||||
case 'warning':
|
||||
this.$bar.css({backgroundColor: '#FFEAA8', borderColor: '#FFC237', color: '#826200'});
|
||||
this.$buttons.css({borderTop: '1px solid #FFC237'});
|
||||
break;
|
||||
case 'error':
|
||||
this.$bar.css({backgroundColor: 'red', borderColor: 'darkred', color: '#FFF'});
|
||||
this.$message.css({fontWeight: 'bold'});
|
||||
this.$buttons.css({borderTop: '1px solid darkred'});
|
||||
break;
|
||||
case 'information':
|
||||
this.$bar.css({backgroundColor: '#57B7E2', borderColor: '#0B90C4', color: '#FFF'});
|
||||
this.$buttons.css({borderTop: '1px solid #0B90C4'});
|
||||
break;
|
||||
case 'success':
|
||||
this.$bar.css({backgroundColor: 'lightgreen', borderColor: '#50C24E', color: 'darkgreen'});
|
||||
this.$buttons.css({borderTop: '1px solid #50C24E'});
|
||||
break;
|
||||
default:
|
||||
this.$bar.css({backgroundColor: '#FFF', borderColor: '#CCC', color: '#444'});
|
||||
break;
|
||||
}
|
||||
},
|
||||
callback: {
|
||||
onShow : function () {
|
||||
$.noty.themes.defaultTheme.helpers.borderFix.apply(this);
|
||||
},
|
||||
onClose: function () {
|
||||
$.noty.themes.defaultTheme.helpers.borderFix.apply(this);
|
||||
}
|
||||
}
|
||||
};
|
||||
143
public/js/noty/themes/metroui.js
Normal file
143
public/js/noty/themes/metroui.js
Normal file
@@ -0,0 +1,143 @@
|
||||
$.noty.themes.metroui = {
|
||||
name : 'metroui',
|
||||
helpers : {},
|
||||
modal : {
|
||||
css: {
|
||||
position : 'fixed',
|
||||
width : '100%',
|
||||
height : '100%',
|
||||
backgroundColor: '#000',
|
||||
zIndex : 10000,
|
||||
opacity : 0.6,
|
||||
display : 'none',
|
||||
left : 0,
|
||||
top : 0
|
||||
}
|
||||
},
|
||||
style : function () {
|
||||
|
||||
this.$bar.css({
|
||||
overflow : 'hidden',
|
||||
margin : '4px 0',
|
||||
borderRadius: '0'
|
||||
});
|
||||
|
||||
this.$message.css({
|
||||
textAlign: 'center',
|
||||
padding : '1.25rem',
|
||||
width : 'auto',
|
||||
position : 'relative'
|
||||
});
|
||||
|
||||
this.$closeButton.css({
|
||||
position : 'absolute',
|
||||
top : '.25rem', right: '.25rem',
|
||||
width : 10, height: 10,
|
||||
background: "url()",
|
||||
display : 'none',
|
||||
cursor : 'pointer'
|
||||
});
|
||||
|
||||
this.$buttons.css({
|
||||
padding : 5,
|
||||
textAlign : 'right',
|
||||
borderTop : '1px solid #ccc',
|
||||
backgroundColor: '#fff'
|
||||
});
|
||||
|
||||
this.$buttons.find('button').css({
|
||||
marginLeft: 5
|
||||
});
|
||||
|
||||
this.$buttons.find('button:first').css({
|
||||
marginLeft: 0
|
||||
});
|
||||
|
||||
this.$bar.on({
|
||||
mouseenter: function () {
|
||||
$(this).find('.noty_close').stop().fadeTo('normal', 1);
|
||||
},
|
||||
mouseleave: function () {
|
||||
$(this).find('.noty_close').stop().fadeTo('normal', 0);
|
||||
}
|
||||
});
|
||||
|
||||
switch (this.options.layout.name) {
|
||||
case 'top':
|
||||
this.$bar.css({
|
||||
border : 'none',
|
||||
boxShadow: "0 0 5px 0 rgba(0, 0, 0, 0.3)"
|
||||
});
|
||||
break;
|
||||
case 'topCenter':
|
||||
case 'center':
|
||||
case 'bottomCenter':
|
||||
case 'inline':
|
||||
this.$bar.css({
|
||||
border : 'none',
|
||||
boxShadow: "0 0 5px 0 rgba(0, 0, 0, 0.3)"
|
||||
});
|
||||
this.$message.css({textAlign: 'center'});
|
||||
break;
|
||||
case 'topLeft':
|
||||
case 'topRight':
|
||||
case 'bottomLeft':
|
||||
case 'bottomRight':
|
||||
case 'centerLeft':
|
||||
case 'centerRight':
|
||||
this.$bar.css({
|
||||
border : 'none',
|
||||
boxShadow: "0 0 5px 0 rgba(0, 0, 0, 0.3)"
|
||||
});
|
||||
this.$message.css({textAlign: 'left'});
|
||||
break;
|
||||
case 'bottom':
|
||||
this.$bar.css({
|
||||
border : 'none',
|
||||
boxShadow: "0 0 5px 0 rgba(0, 0, 0, 0.3)"
|
||||
});
|
||||
break;
|
||||
default:
|
||||
this.$bar.css({
|
||||
border : 'none',
|
||||
boxShadow: "0 0 5px 0 rgba(0, 0, 0, 0.3)"
|
||||
});
|
||||
break;
|
||||
}
|
||||
|
||||
switch (this.options.type) {
|
||||
case 'alert':
|
||||
case 'notification':
|
||||
this.$bar.css({backgroundColor: '#fff', border: 'none', color: '#1d1d1d'});
|
||||
break;
|
||||
case 'warning':
|
||||
this.$bar.css({backgroundColor: '#FA6800', border: 'none', color: '#fff'});
|
||||
this.$buttons.css({borderTop: '1px solid #FA6800'});
|
||||
break;
|
||||
case 'error':
|
||||
this.$bar.css({backgroundColor: '#CE352C', border: 'none', color: '#fff'});
|
||||
this.$message.css({fontWeight: 'bold'});
|
||||
this.$buttons.css({borderTop: '1px solid #CE352C'});
|
||||
break;
|
||||
case 'information':
|
||||
this.$bar.css({backgroundColor: '#1BA1E2', border: 'none', color: '#fff'});
|
||||
this.$buttons.css({borderTop: '1px solid #1BA1E2'});
|
||||
break;
|
||||
case 'success':
|
||||
this.$bar.css({backgroundColor: '#60A917', border: 'none', color: '#fff'});
|
||||
this.$buttons.css({borderTop: '1px solid #50C24E'});
|
||||
break;
|
||||
default:
|
||||
this.$bar.css({backgroundColor: '#fff', border: 'none', color: '#1d1d1d'});
|
||||
break;
|
||||
}
|
||||
},
|
||||
callback: {
|
||||
onShow : function () {
|
||||
|
||||
},
|
||||
onClose: function () {
|
||||
|
||||
}
|
||||
}
|
||||
};
|
||||
149
public/js/noty/themes/relax.js
Normal file
149
public/js/noty/themes/relax.js
Normal file
@@ -0,0 +1,149 @@
|
||||
$.noty.themes.relax = {
|
||||
name : 'relax',
|
||||
helpers : {},
|
||||
modal : {
|
||||
css: {
|
||||
position : 'fixed',
|
||||
width : '100%',
|
||||
height : '100%',
|
||||
backgroundColor: '#000',
|
||||
zIndex : 10000,
|
||||
opacity : 0.6,
|
||||
display : 'none',
|
||||
left : 0,
|
||||
top : 0
|
||||
}
|
||||
},
|
||||
style : function() {
|
||||
|
||||
this.$bar.css({
|
||||
overflow : 'hidden',
|
||||
margin : '4px 0',
|
||||
borderRadius: '2px'
|
||||
});
|
||||
|
||||
this.$message.css({
|
||||
textAlign : 'center',
|
||||
padding : '10px',
|
||||
width : 'auto',
|
||||
position : 'relative'
|
||||
});
|
||||
|
||||
this.$closeButton.css({
|
||||
position : 'absolute',
|
||||
top : 4, right: 4,
|
||||
width : 10, height: 10,
|
||||
background: "url()",
|
||||
display : 'none',
|
||||
cursor : 'pointer'
|
||||
});
|
||||
|
||||
this.$buttons.css({
|
||||
padding : 5,
|
||||
textAlign : 'right',
|
||||
borderTop : '1px solid #ccc',
|
||||
backgroundColor: '#fff'
|
||||
});
|
||||
|
||||
this.$buttons.find('button').css({
|
||||
marginLeft: 5
|
||||
});
|
||||
|
||||
this.$buttons.find('button:first').css({
|
||||
marginLeft: 0
|
||||
});
|
||||
|
||||
this.$bar.on({
|
||||
mouseenter: function() {
|
||||
$(this).find('.noty_close').stop().fadeTo('normal', 1);
|
||||
},
|
||||
mouseleave: function() {
|
||||
$(this).find('.noty_close').stop().fadeTo('normal', 0);
|
||||
}
|
||||
});
|
||||
|
||||
switch(this.options.layout.name) {
|
||||
case 'top':
|
||||
this.$bar.css({
|
||||
borderBottom: '2px solid #eee',
|
||||
borderLeft : '2px solid #eee',
|
||||
borderRight : '2px solid #eee',
|
||||
borderTop : '2px solid #eee',
|
||||
boxShadow : "0 2px 4px rgba(0, 0, 0, 0.1)"
|
||||
});
|
||||
break;
|
||||
case 'topCenter':
|
||||
case 'center':
|
||||
case 'bottomCenter':
|
||||
case 'inline':
|
||||
this.$bar.css({
|
||||
border : '1px solid #eee',
|
||||
boxShadow: "0 2px 4px rgba(0, 0, 0, 0.1)"
|
||||
});
|
||||
this.$message.css({textAlign: 'center'});
|
||||
break;
|
||||
case 'topLeft':
|
||||
case 'topRight':
|
||||
case 'bottomLeft':
|
||||
case 'bottomRight':
|
||||
case 'centerLeft':
|
||||
case 'centerRight':
|
||||
this.$bar.css({
|
||||
border : '1px solid #eee',
|
||||
boxShadow: "0 2px 4px rgba(0, 0, 0, 0.1)"
|
||||
});
|
||||
this.$message.css({textAlign: 'left'});
|
||||
break;
|
||||
case 'bottom':
|
||||
this.$bar.css({
|
||||
borderTop : '2px solid #eee',
|
||||
borderLeft : '2px solid #eee',
|
||||
borderRight : '2px solid #eee',
|
||||
borderBottom: '2px solid #eee',
|
||||
boxShadow : "0 -2px 4px rgba(0, 0, 0, 0.1)"
|
||||
});
|
||||
break;
|
||||
default:
|
||||
this.$bar.css({
|
||||
border : '2px solid #eee',
|
||||
boxShadow: "0 2px 4px rgba(0, 0, 0, 0.1)"
|
||||
});
|
||||
break;
|
||||
}
|
||||
|
||||
switch(this.options.type) {
|
||||
case 'alert':
|
||||
case 'notification':
|
||||
this.$bar.css({backgroundColor: '#FFF', borderColor: '#dedede', color: '#444'});
|
||||
break;
|
||||
case 'warning':
|
||||
this.$bar.css({backgroundColor: '#FFEAA8', borderColor: '#FFC237', color: '#826200'});
|
||||
this.$buttons.css({borderTop: '1px solid #FFC237'});
|
||||
break;
|
||||
case 'error':
|
||||
this.$bar.css({backgroundColor: '#FF8181', borderColor: '#e25353', color: '#FFF'});
|
||||
this.$message.css({fontWeight: 'bold'});
|
||||
this.$buttons.css({borderTop: '1px solid darkred'});
|
||||
break;
|
||||
case 'information':
|
||||
this.$bar.css({backgroundColor: '#78C5E7', borderColor: '#3badd6', color: '#FFF'});
|
||||
this.$buttons.css({borderTop: '1px solid #0B90C4'});
|
||||
break;
|
||||
case 'success':
|
||||
this.$bar.css({backgroundColor: '#BCF5BC', borderColor: '#7cdd77', color: 'darkgreen'});
|
||||
this.$buttons.css({borderTop: '1px solid #50C24E'});
|
||||
break;
|
||||
default:
|
||||
this.$bar.css({backgroundColor: '#FFF', borderColor: '#CCC', color: '#444'});
|
||||
break;
|
||||
}
|
||||
},
|
||||
callback: {
|
||||
onShow : function() {
|
||||
|
||||
},
|
||||
onClose: function() {
|
||||
|
||||
}
|
||||
}
|
||||
};
|
||||
103
public/js/noty/themes/semanticUI.js
Normal file
103
public/js/noty/themes/semanticUI.js
Normal file
@@ -0,0 +1,103 @@
|
||||
$.noty.themes.semanticUI = {
|
||||
name : 'semanticUI',
|
||||
|
||||
template : '<div class="ui message"><div class="content"><div class="header"></div></div></div>',
|
||||
|
||||
animation: {
|
||||
open : {
|
||||
animation: 'fade',
|
||||
duration : '800ms'
|
||||
},
|
||||
close: {
|
||||
animation: 'fade left',
|
||||
duration : '800ms'
|
||||
}
|
||||
},
|
||||
|
||||
modal : {
|
||||
css: {
|
||||
position : 'fixed',
|
||||
width : '100%',
|
||||
height : '100%',
|
||||
backgroundColor: '#000',
|
||||
zIndex : 10000,
|
||||
opacity : 0.6,
|
||||
display : 'none',
|
||||
left : 0,
|
||||
top : 0
|
||||
}
|
||||
},
|
||||
style : function () {
|
||||
this.$message = this.$bar.find('.ui.message');
|
||||
|
||||
this.$message.find('.header').html(this.options.header);
|
||||
this.$message.find('.content').append(this.options.text);
|
||||
|
||||
this.$bar.css({
|
||||
margin: '0.5em'
|
||||
});
|
||||
|
||||
if (this.options.icon) {
|
||||
this.$message.addClass('icon').prepend($('<i/>').addClass(this.options.icon));
|
||||
}
|
||||
|
||||
switch (this.options.size) {
|
||||
case 'mini':
|
||||
this.$message.addClass('mini');
|
||||
break;
|
||||
case 'tiny':
|
||||
this.$message.addClass('tiny');
|
||||
break;
|
||||
case 'small':
|
||||
this.$message.addClass('small');
|
||||
break;
|
||||
case 'large':
|
||||
this.$message.addClass('large');
|
||||
break;
|
||||
case 'big':
|
||||
this.$message.addClass('big');
|
||||
break;
|
||||
case 'huge':
|
||||
this.$message.addClass('huge');
|
||||
break;
|
||||
case 'massive':
|
||||
this.$message.addClass('massive');
|
||||
break;
|
||||
}
|
||||
|
||||
switch (this.options.type) {
|
||||
case 'info':
|
||||
this.$message.addClass('info');
|
||||
break;
|
||||
case 'warning':
|
||||
this.$message.addClass('warning');
|
||||
break;
|
||||
case 'error':
|
||||
this.$message.addClass('error');
|
||||
break;
|
||||
case 'negative':
|
||||
this.$message.addClass('negative');
|
||||
break;
|
||||
case 'success':
|
||||
this.$message.addClass('success');
|
||||
break;
|
||||
case 'positive':
|
||||
this.$message.addClass('positive');
|
||||
break;
|
||||
case 'floating':
|
||||
this.$message.addClass('floating');
|
||||
break;
|
||||
}
|
||||
},
|
||||
callback: {
|
||||
onShow : function () {
|
||||
// Enable transition
|
||||
this.$bar.addClass('transition');
|
||||
// Actual transition
|
||||
this.$bar.transition(this.options.animation.open);
|
||||
},
|
||||
onClose: function () {
|
||||
this.$bar.transition(this.options.animation.close);
|
||||
}
|
||||
}
|
||||
};
|
||||
@@ -1,413 +0,0 @@
|
||||
var clonos={
|
||||
jsonLoad:false,
|
||||
|
||||
start:function()
|
||||
{
|
||||
this.addEvents();
|
||||
|
||||
var r, res, args=[];
|
||||
var hash=window.location.hash;
|
||||
hash=hash.replace(new RegExp(/^#/),'');
|
||||
var rx=new RegExp(/([^\/]+)/g);
|
||||
if(res=hash.match(rx))
|
||||
{
|
||||
for(r in res)
|
||||
{
|
||||
var r1=res[r].split('-');
|
||||
if(r1.length==2) args[args.length]={'var':r1[0],'val':r1[1]};
|
||||
}
|
||||
this.route(args);
|
||||
}
|
||||
},
|
||||
|
||||
addEvents:function()
|
||||
{
|
||||
$('#lng-sel').bind('change',function(){document.cookie="lang="+$(this).val()+";path=/;";location.reload();});
|
||||
$('#content').bind('click',$.proxy(this.tableClick,this));
|
||||
},
|
||||
|
||||
translate:function(phrase)
|
||||
{
|
||||
if(typeof this.lang!='undefined')
|
||||
{
|
||||
if(typeof this.lang[phrase]!='undefined')
|
||||
return this.lang[phrase];
|
||||
}
|
||||
return phrase;
|
||||
},
|
||||
|
||||
route:function(args)
|
||||
{
|
||||
if(typeof args=='undefined') return;
|
||||
//alert(args.length);
|
||||
},
|
||||
|
||||
loadData:function()
|
||||
{
|
||||
if(!this.jsonLoad) return;
|
||||
var path=location.pathname;
|
||||
var file='/json.php'; //'/pages'+path+'a.json.php';
|
||||
this.loadDataJson(file,$.proxy(this.onLoadData,this),{'path':path});
|
||||
},
|
||||
loadDataJson:function(file,return_func,arr) //mode,
|
||||
{
|
||||
var posts=arr;
|
||||
/*
|
||||
var posts={'mode':mode,'project':this.project,'jail':this.jail,'module':this.module};
|
||||
if(typeof arr=='object')
|
||||
{
|
||||
posts['form_data']={};
|
||||
for(n=0,nl=arr.length;n<nl;n++)
|
||||
posts['form_data'][arr[n]['name']]=arr[n]['value'];
|
||||
}
|
||||
*/
|
||||
$.post(file,posts,
|
||||
$.proxy(function(data){return_func(data);},this));
|
||||
},
|
||||
onLoadData:function(data)
|
||||
{
|
||||
try{
|
||||
var data=$.parseJSON(data);
|
||||
}catch(e){alert(e.message);return;}
|
||||
|
||||
if(data.error)
|
||||
{
|
||||
var t=$('tbody.error td.error_message');
|
||||
if(typeof(data.error_message)!='undefined' && data.error_message!='') t.html(data.error_message);
|
||||
$(t).parents('table').addClass('error');
|
||||
}else{
|
||||
if(typeof data.func!='undefined')
|
||||
{
|
||||
this[data.func](data);
|
||||
return;
|
||||
}
|
||||
for(id in data) $('#'+id).html(data[id]);
|
||||
}
|
||||
},
|
||||
|
||||
fillTable:function(data)
|
||||
{
|
||||
if(typeof data.id!='undefined')
|
||||
{
|
||||
$('#'+data.id+' tbody').html(data.html);
|
||||
}
|
||||
},
|
||||
|
||||
enableWait:function(id)
|
||||
{
|
||||
var icon_cnt=$('tr.id-'+id).find('span.icon-cnt');
|
||||
var icon=$(icon_cnt).find('span');
|
||||
$(icon).removeClass('icon-play');
|
||||
$(icon).removeClass('icon-stop');
|
||||
$(icon).addClass('icon-spin6 animate-spin');
|
||||
},
|
||||
enablePlay:function(id)
|
||||
{
|
||||
var icon_cnt=$('tr.id-'+id).find('span.icon-cnt');
|
||||
var icon=$(icon_cnt).find('span');
|
||||
if(icon[0]) icon[0].className='icon-play';
|
||||
},
|
||||
enableStop:function(id)
|
||||
{
|
||||
var icon_cnt=$('tr.id-'+id).find('span.icon-cnt');
|
||||
var icon=$(icon_cnt).find('span');
|
||||
if(icon[0]) icon[0].className='icon-stop';
|
||||
},
|
||||
enableRip:function(id)
|
||||
{
|
||||
var icon_cnt=$('tr.id-'+id).find('span.icon-cnt');
|
||||
if(typeof icon_cnt!='undefined')
|
||||
{
|
||||
var icon=$(icon_cnt).find('span');
|
||||
if(typeof icon!='undefined')
|
||||
icon[0].className='icon-emo-cry';
|
||||
}
|
||||
},
|
||||
|
||||
jailStart:function(obj)
|
||||
{
|
||||
if(!obj) return;
|
||||
// if(this.currentPage=='services') return this.serviceStart(obj);
|
||||
// var id=this.getJailId(obj);
|
||||
// if(id<0) return;
|
||||
var icon_cnt=$(obj).find('span.icon-cnt');
|
||||
var icon=$(icon_cnt).find('span');
|
||||
op='';
|
||||
if($(icon).hasClass('icon-play')) op='jstart';
|
||||
if($(icon).hasClass('icon-stop')) op='jstop';
|
||||
this.enableWait(id);
|
||||
|
||||
var op_status=(op=='jstart'?1:0);
|
||||
|
||||
if(op!='')
|
||||
{
|
||||
this.tasks.add({'operation':op,'jail_id':id});
|
||||
this.tasks.start();
|
||||
}
|
||||
},
|
||||
|
||||
|
||||
tasks:
|
||||
{
|
||||
context:null,
|
||||
tasks:{},
|
||||
interval:null,
|
||||
checkTasks:false,
|
||||
|
||||
init:function(context)
|
||||
{
|
||||
this.context=context;
|
||||
},
|
||||
|
||||
add:function(vars)
|
||||
{
|
||||
if(typeof vars['status']=='undefined') vars['status']=-1;
|
||||
if(typeof vars['jail_id']!='undefined')
|
||||
this.tasks[vars['jail_id']]=vars;
|
||||
if(typeof vars['modules_id']!='undefined')
|
||||
this.tasks['mod_ops']=vars;
|
||||
if(typeof vars['service_id']!='undefined')
|
||||
this.tasks[vars['service_id']]=vars;
|
||||
if(typeof vars['projects_id']!='undefined')
|
||||
{
|
||||
this.tasks['proj_ops']='projDelete';
|
||||
this.tasks[vars['projects_id']]=vars;
|
||||
}
|
||||
},
|
||||
|
||||
start:function()
|
||||
{
|
||||
if(this.checkTasks) return;
|
||||
this.checkTasks=true;
|
||||
|
||||
if($.isEmptyObject(this.tasks))
|
||||
{
|
||||
clearInterval(this.interval);
|
||||
this.interval=null;
|
||||
this.checkTasks=false;
|
||||
return;
|
||||
}
|
||||
|
||||
var vars=JSON.stringify(this.tasks);
|
||||
this.context.loadData('getTasksStatus',$.proxy(this.update,this),[{'name':'jsonObj','value':vars}]);
|
||||
},
|
||||
|
||||
update:function(data)
|
||||
{
|
||||
try{
|
||||
var data=$.parseJSON(data);
|
||||
}catch(e){alert(e.message);return;}
|
||||
|
||||
if(typeof data['mod_ops']!='undefined')
|
||||
{
|
||||
var key='mod_ops';
|
||||
this.tasks[key]=data[key];
|
||||
var d=data[key];
|
||||
|
||||
if(d.status==2)
|
||||
{
|
||||
//this.context.onTaskEnd(this.tasks[key],key);
|
||||
this.context.modulesUpdate(data);
|
||||
delete this.tasks[key];
|
||||
this.context.waitScreenHide();
|
||||
}
|
||||
if(d.status<2) this.context.waitScreenShow();
|
||||
|
||||
this.checkTasks=false;
|
||||
if(this.interval===null)
|
||||
{
|
||||
this.interval=setInterval($.proxy(this.start,this),1000);
|
||||
}
|
||||
return;
|
||||
|
||||
}
|
||||
|
||||
if(typeof data['proj_ops']!='undefined')
|
||||
{
|
||||
if(data['proj_ops']=='projDelete')
|
||||
{
|
||||
if(typeof data.projects!='undefined')
|
||||
this.context.projectsList=data.projects;
|
||||
this.context.showProjectsList();
|
||||
return;
|
||||
}
|
||||
}
|
||||
|
||||
for(key in data)
|
||||
{
|
||||
if(key>0)
|
||||
{
|
||||
$('tr.id-'+key+' .jstatus').html(data[key].txt_status);
|
||||
var errmsg=$('tr.id-'+key+' .errmsg');
|
||||
if(typeof data[key].errmsg!='undefined')
|
||||
{
|
||||
$(errmsg).html('<span class="label">Error:</span>'+data[key].errmsg); //'+this.translate('Error')+'
|
||||
this.tasks[key].errmsg=data[key].errmsg;
|
||||
}
|
||||
this.tasks[key].operation=data[key].operation;
|
||||
this.tasks[key].task_id=data[key].task_id;
|
||||
this.tasks[key].status=data[key].status;
|
||||
|
||||
if(data[key].status==2)
|
||||
{
|
||||
this.context.onTaskEnd(this.tasks[key],key);
|
||||
delete this.tasks[key];
|
||||
}
|
||||
}else{
|
||||
if(typeof data[-1].jails!='undefined')
|
||||
{
|
||||
this.context.jailsList=data[-1].jails;
|
||||
this.context.showJailsList();
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
this.checkTasks=false;
|
||||
|
||||
if(this.interval===null)
|
||||
{
|
||||
this.interval=setInterval($.proxy(this.start,this),1000);
|
||||
}
|
||||
|
||||
},
|
||||
},
|
||||
|
||||
tableClick:function(event)
|
||||
{
|
||||
debugger;
|
||||
var target=event.target;
|
||||
/* if(target.id=='main_chkbox')
|
||||
{
|
||||
this.mainChkBoxClick(event);
|
||||
return;
|
||||
} */
|
||||
var td=$(target).closest('td');
|
||||
td=td[0];
|
||||
var tr=$(target).closest('tr');
|
||||
/* if(target.tagName=='SPAN')
|
||||
{
|
||||
var cl=target.className;
|
||||
if(cl && cl.indexOf('install')>=0)
|
||||
{
|
||||
var res=cl.match(new RegExp(/helper-(\w+)/));
|
||||
if(res)
|
||||
{
|
||||
this.installHelper(res[1]);
|
||||
return;
|
||||
}
|
||||
}
|
||||
|
||||
if(cl && cl.indexOf('default')>=0)
|
||||
{
|
||||
var res=cl.match(new RegExp(/val-(.*)/));
|
||||
if(res)
|
||||
{
|
||||
this.fillHelperDefault(target,res[1]);
|
||||
return;
|
||||
}
|
||||
}
|
||||
}
|
||||
*/
|
||||
/* if(target.tagName=='INPUT')
|
||||
{
|
||||
var cl=target.className;
|
||||
if(cl=='') return;
|
||||
if(cl=='save-helper-values') this.saveHelperValues();
|
||||
if(cl=='clear-helper') this.clearHelperForm(target);
|
||||
|
||||
return;
|
||||
}
|
||||
|
||||
if(typeof td!='undefined') this.selItem(tr);
|
||||
|
||||
if(typeof tr[0]=='undefined') return;
|
||||
var cl=tr[0].className;
|
||||
if(!$(tr).hasClass('link')) return;
|
||||
var rx=new RegExp(/id-(\d+)/);
|
||||
if(res=cl.match(rx))
|
||||
{
|
||||
var id=res[1];
|
||||
} */
|
||||
//debugger;
|
||||
if(!td || typeof td.className=='undefined') return false;
|
||||
var tdc=td.className;
|
||||
tdc=tdc.replace(' ','-');
|
||||
|
||||
switch(tdc)
|
||||
{
|
||||
case 'ops':
|
||||
this.jailStart(tr);
|
||||
return;break;
|
||||
/* case 'sett-proj':
|
||||
this.lastProjectId=id;
|
||||
this.editMode='edit-proj';
|
||||
this.projSettings(id);
|
||||
return;break;
|
||||
case 'sett':
|
||||
this.lastJailId=id;
|
||||
this.editMode='edit';
|
||||
this.getJailSettings(tr);
|
||||
return;break;
|
||||
case 'jstatus':
|
||||
return;break;
|
||||
case 'info':
|
||||
this.loadData('getForm',$.proxy(this.loadForm,this));
|
||||
return;break;
|
||||
case 'mod-info':
|
||||
alert('show info about module!');
|
||||
return;break;
|
||||
case 'user-info':
|
||||
this.editMode='user-edit';
|
||||
var n;
|
||||
data=null;
|
||||
for(n=0,nl=this.usersList.length;n<nl;n++)
|
||||
if(this.usersList[n].id==id) {data=this.usersList[n];break;}
|
||||
if(data==null) return;
|
||||
var obj_cnt=this.settWinOpen('users');
|
||||
var form=$('form',obj_cnt);
|
||||
$('#window-content h1').html(this.translate('User edit'));
|
||||
$('input[name="login"]',form).val(data.login).attr('disabled','disabled');
|
||||
$('input[name="fullname"]',form).val(data.gecos);
|
||||
return;break;
|
||||
*/ }
|
||||
|
||||
/* if($(td).hasClass('chbx'))
|
||||
{
|
||||
// tr.link.hover.id-1
|
||||
if(this.currentPage=='project')
|
||||
if(id>0) this.selectedProjects[id]=$(td).children('input[type="checkbox"]').prop('checked');
|
||||
if(this.currentPage=='jails')
|
||||
if(id>0) this.selectedJails[id]=$(td).children('input[type="checkbox"]').prop('checked');
|
||||
if(this.currentPage=='modules')
|
||||
if(id>0) this.selectedModules[id]=$(td).children('input[type="checkbox"]').prop('checked');
|
||||
return;
|
||||
}
|
||||
|
||||
switch(this.currentPage)
|
||||
{
|
||||
case 'project':
|
||||
location.hash='#prj-'+id;
|
||||
break;
|
||||
case 'jails':
|
||||
location.hash='#prj-'+this.project+'/jail-'+id;
|
||||
break;
|
||||
case 'modules':
|
||||
location.hash='#prj-'+this.project+'/jail-'+this.jail+'/module-'+id;
|
||||
break;
|
||||
case 'log':
|
||||
var hid=$('td.sp-id',tr).html();
|
||||
location.hash='#prj-'+this.project+'/jail-'+this.jail+'/log-'+hid;
|
||||
break;
|
||||
case 'helpers':
|
||||
var hid=$('td .sp-id',tr).html();
|
||||
location.hash='#prj-'+this.project+'/jail-'+this.jail+'/helpers-'+hid;
|
||||
break;
|
||||
}
|
||||
*/
|
||||
},
|
||||
}
|
||||
|
||||
$(window).load(function(){clonos.start();});
|
||||
$(window).unload(function(){}); /* эта функция заставляет FireFox запускать JS-функции при нажатии кнопки «Назад»
|
||||
http://stackoverflow.com/questions/2638292/after-travelling-back-in-firefox-history-javascript-wont-run */
|
||||
$(document).ready(function(){clonos.loadData();});
|
||||
Reference in New Issue
Block a user