noty-rails 2.0.3.1 → 2.1.0
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/README.md +4 -0
- data/lib/noty-rails/version.rb +1 -1
- data/vendor/assets/javascripts/noty/jquery.noty.js +473 -397
- data/vendor/assets/javascripts/noty/layouts/bottomCenter.js +4 -4
- data/vendor/assets/javascripts/noty/layouts/center.js +2 -2
- data/vendor/assets/javascripts/noty/layouts/centerLeft.js +3 -3
- data/vendor/assets/javascripts/noty/layouts/centerRight.js +4 -4
- data/vendor/assets/javascripts/noty/layouts/topCenter.js +4 -4
- data/vendor/assets/javascripts/noty/themes/default.js +23 -23
- metadata +4 -3
checksums.yaml
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
---
|
2
2
|
SHA1:
|
3
|
-
metadata.gz:
|
4
|
-
data.tar.gz:
|
3
|
+
metadata.gz: df308d43dfcfdc3f9d472b0d12ae5b3aeb54d5e2
|
4
|
+
data.tar.gz: 89a867a5ca5cb043ca13c95802d45f0308ee07d7
|
5
5
|
SHA512:
|
6
|
-
metadata.gz:
|
7
|
-
data.tar.gz:
|
6
|
+
metadata.gz: 01c148b56d2c478ab91ef08507ef3eb1eb3c0911f52ffb6c0f893e9fc9c6468f06f6cb3161522ab472c2b2e10800063347278055b9a8421b8d8d0f6c511785c1
|
7
|
+
data.tar.gz: 5c1c3ef1db0fb612eb6a5592413c1461d688d66b4973cdc124fa180e773913080ed76e10d692909737d5e3ee7db65578d5cd2fb0d63634f9352a5141f1e2a635
|
data/README.md
CHANGED
data/lib/noty-rails/version.rb
CHANGED
@@ -1,471 +1,547 @@
|
|
1
1
|
/**
|
2
|
-
* noty - jQuery Notification Plugin v2.0
|
3
|
-
* Contributors: https://github.com/needim/noty/graphs/contributors
|
4
|
-
*
|
5
|
-
* Examples and Documentation - http://needim.github.com/noty/
|
6
|
-
*
|
7
|
-
* Licensed under the MIT licenses:
|
8
|
-
* http://www.opensource.org/licenses/mit-license.php
|
9
|
-
*
|
10
|
-
**/
|
2
|
+
* noty - jQuery Notification Plugin v2.1.0
|
3
|
+
* Contributors: https://github.com/needim/noty/graphs/contributors
|
4
|
+
*
|
5
|
+
* Examples and Documentation - http://needim.github.com/noty/
|
6
|
+
*
|
7
|
+
* Licensed under the MIT licenses:
|
8
|
+
* http://www.opensource.org/licenses/mit-license.php
|
9
|
+
*
|
10
|
+
**/
|
11
11
|
|
12
12
|
if (typeof Object.create !== 'function') {
|
13
|
-
|
14
|
-
|
15
|
-
|
16
|
-
return new F();
|
17
|
-
};
|
18
|
-
};
|
13
|
+
Object.create = function (o) {
|
14
|
+
function F() {
|
15
|
+
}
|
19
16
|
|
20
|
-
;
|
17
|
+
F.prototype = o;
|
18
|
+
return new F();
|
19
|
+
};
|
20
|
+
}
|
21
21
|
|
22
|
-
|
22
|
+
(function ($) {
|
23
23
|
|
24
|
-
|
24
|
+
var NotyObject = {
|
25
25
|
|
26
|
-
|
27
|
-
this.options = $.extend({}, $.noty.defaults, options);
|
26
|
+
init:function (options) {
|
28
27
|
|
29
|
-
|
30
|
-
|
28
|
+
// Mix in the passed in options with the default options
|
29
|
+
this.options = $.extend({}, $.noty.defaults, options);
|
31
30
|
|
32
|
-
|
31
|
+
this.options.layout = (this.options.custom) ? $.noty.layouts['inline'] : $.noty.layouts[this.options.layout];
|
32
|
+
this.options.theme = $.noty.themes[this.options.theme];
|
33
33
|
|
34
|
-
|
35
|
-
|
34
|
+
delete options.layout;
|
35
|
+
delete options.theme;
|
36
36
|
|
37
|
-
|
37
|
+
this.options = $.extend({}, this.options, this.options.layout.options);
|
38
|
+
this.options.id = 'noty_' + (new Date().getTime() * Math.floor(Math.random() * 1000000));
|
38
39
|
|
39
|
-
|
40
|
-
this._build();
|
40
|
+
this.options = $.extend({}, this.options, options);
|
41
41
|
|
42
|
-
|
43
|
-
|
44
|
-
}, // end init
|
42
|
+
// Build the noty dom initial structure
|
43
|
+
this._build();
|
45
44
|
|
46
|
-
|
45
|
+
// return this so we can chain/use the bridge with less code.
|
46
|
+
return this;
|
47
|
+
}, // end init
|
47
48
|
|
48
|
-
|
49
|
-
var $bar = $('<div class="noty_bar"/>').attr('id', this.options.id);
|
50
|
-
$bar.append(this.options.template).find('.noty_text').html(this.options.text);
|
49
|
+
_build:function () {
|
51
50
|
|
52
|
-
|
51
|
+
// Generating noty bar
|
52
|
+
var $bar = $('<div class="noty_bar"></div>').attr('id', this.options.id);
|
53
|
+
$bar.append(this.options.template).find('.noty_text').html(this.options.text);
|
53
54
|
|
54
|
-
|
55
|
-
if (this.options.buttons) {
|
55
|
+
this.$bar = (this.options.layout.parent.object !== null) ? $(this.options.layout.parent.object).css(this.options.layout.parent.css).append($bar) : $bar;
|
56
56
|
|
57
|
-
|
58
|
-
|
57
|
+
// Set buttons if available
|
58
|
+
if (this.options.buttons) {
|
59
59
|
|
60
|
-
|
60
|
+
// If we have button disable closeWith & timeout options
|
61
|
+
this.options.closeWith = [];
|
62
|
+
this.options.timeout = false;
|
61
63
|
|
62
|
-
|
64
|
+
var $buttons = $('<div/>').addClass('noty_buttons');
|
63
65
|
|
64
|
-
|
66
|
+
(this.options.layout.parent.object !== null) ? this.$bar.find('.noty_bar').append($buttons) : this.$bar.append($buttons);
|
65
67
|
|
66
|
-
|
67
|
-
var $button = $('<button/>').addClass((button.addClass) ? button.addClass : 'gray').html(button.text)
|
68
|
-
.appendTo(self.$bar.find('.noty_buttons'))
|
69
|
-
.bind('click', function(e) { if ($.isFunction(button.onClick)) { button.onClick.call($button, self); } });
|
70
|
-
});
|
71
|
-
}
|
68
|
+
var self = this;
|
72
69
|
|
73
|
-
|
74
|
-
|
75
|
-
|
76
|
-
|
70
|
+
$.each(this.options.buttons, function (i, button) {
|
71
|
+
var $button = $('<button/>').addClass((button.addClass) ? button.addClass : 'gray').html(button.text)
|
72
|
+
.appendTo(self.$bar.find('.noty_buttons'))
|
73
|
+
.bind('click', function () {
|
74
|
+
if ($.isFunction(button.onClick)) {
|
75
|
+
button.onClick.call($button, self);
|
76
|
+
}
|
77
|
+
});
|
78
|
+
});
|
79
|
+
}
|
77
80
|
|
78
|
-
|
81
|
+
// For easy access
|
82
|
+
this.$message = this.$bar.find('.noty_message');
|
83
|
+
this.$closeButton = this.$bar.find('.noty_close');
|
84
|
+
this.$buttons = this.$bar.find('.noty_buttons');
|
79
85
|
|
80
|
-
|
86
|
+
$.noty.store[this.options.id] = this; // store noty for api
|
81
87
|
|
82
|
-
|
88
|
+
}, // end _build
|
83
89
|
|
84
|
-
|
90
|
+
show:function () {
|
85
91
|
|
86
|
-
|
92
|
+
var self = this;
|
87
93
|
|
88
|
-
|
94
|
+
$(self.options.layout.container.selector).append(self.$bar);
|
89
95
|
|
90
|
-
|
96
|
+
self.options.theme.style.apply(self);
|
91
97
|
|
92
|
-
|
98
|
+
($.type(self.options.layout.css) === 'function') ? this.options.layout.css.apply(self.$bar) : self.$bar.css(this.options.layout.css || {});
|
93
99
|
|
94
|
-
|
100
|
+
self.$bar.addClass(self.options.layout.addClass);
|
95
101
|
|
96
|
-
|
102
|
+
self.options.layout.container.style.apply($(self.options.layout.container.selector));
|
97
103
|
|
98
|
-
|
99
|
-
self.$bar.css('cursor', 'pointer').one('click', function() { self.close(); });
|
104
|
+
self.options.theme.callback.onShow.apply(this);
|
100
105
|
|
101
|
-
|
102
|
-
|
106
|
+
if ($.inArray('click', self.options.closeWith) > -1)
|
107
|
+
self.$bar.css('cursor', 'pointer').one('click', function (evt) {
|
108
|
+
self.stopPropagation(evt);
|
109
|
+
if (self.options.callback.onCloseClick) {
|
110
|
+
self.options.callback.onCloseClick.apply(self);
|
111
|
+
}
|
112
|
+
self.close();
|
113
|
+
});
|
103
114
|
|
104
|
-
|
105
|
-
|
115
|
+
if ($.inArray('hover', self.options.closeWith) > -1)
|
116
|
+
self.$bar.one('mouseenter', function () {
|
117
|
+
self.close();
|
118
|
+
});
|
106
119
|
|
107
|
-
|
108
|
-
|
120
|
+
if ($.inArray('button', self.options.closeWith) > -1)
|
121
|
+
self.$closeButton.one('click', function (evt) {
|
122
|
+
self.stopPropagation(evt);
|
123
|
+
self.close();
|
124
|
+
});
|
109
125
|
|
110
|
-
|
111
|
-
|
126
|
+
if ($.inArray('button', self.options.closeWith) == -1)
|
127
|
+
self.$closeButton.remove();
|
112
128
|
|
113
|
-
|
114
|
-
|
115
|
-
self.options.animation.speed,
|
116
|
-
self.options.animation.easing,
|
117
|
-
function() {
|
118
|
-
if (self.options.callback.afterShow) self.options.callback.afterShow.apply(self);
|
119
|
-
self.shown = true;
|
120
|
-
});
|
129
|
+
if (self.options.callback.onShow)
|
130
|
+
self.options.callback.onShow.apply(self);
|
121
131
|
|
122
|
-
|
123
|
-
|
124
|
-
|
132
|
+
self.$bar.animate(
|
133
|
+
self.options.animation.open,
|
134
|
+
self.options.animation.speed,
|
135
|
+
self.options.animation.easing,
|
136
|
+
function () {
|
137
|
+
if (self.options.callback.afterShow) self.options.callback.afterShow.apply(self);
|
138
|
+
self.shown = true;
|
139
|
+
});
|
125
140
|
|
126
|
-
|
141
|
+
// If noty is have a timeout option
|
142
|
+
if (self.options.timeout)
|
143
|
+
self.$bar.delay(self.options.timeout).promise().done(function () {
|
144
|
+
self.close();
|
145
|
+
});
|
127
146
|
|
128
|
-
|
147
|
+
return this;
|
129
148
|
|
130
|
-
|
149
|
+
}, // end show
|
131
150
|
|
132
|
-
|
151
|
+
close:function () {
|
133
152
|
|
134
|
-
|
153
|
+
if (this.closed) return;
|
154
|
+
if (this.$bar && this.$bar.hasClass('i-am-closing-now')) return;
|
135
155
|
|
136
|
-
|
137
|
-
$.each($.noty.queue, function(i, n) {
|
138
|
-
if (n.options.id == self.options.id) {
|
139
|
-
$.noty.queue.splice(i, 1);
|
140
|
-
}
|
141
|
-
});
|
142
|
-
return;
|
143
|
-
}
|
144
|
-
|
145
|
-
self.$bar.addClass('i-am-closing-now');
|
146
|
-
|
147
|
-
if (self.options.callback.onClose) { self.options.callback.onClose.apply(self); }
|
156
|
+
var self = this;
|
148
157
|
|
149
|
-
|
150
|
-
|
151
|
-
|
152
|
-
|
153
|
-
|
154
|
-
|
155
|
-
|
156
|
-
|
157
|
-
|
158
|
-
|
159
|
-
if ($.notyRenderer.getModalCount() == 0) $('.noty_modal').fadeOut('fast', function() { $(this).remove(); });
|
160
|
-
}
|
158
|
+
if (!this.shown) { // If we are still waiting in the queue just delete from queue
|
159
|
+
var queue = [];
|
160
|
+
$.each($.noty.queue, function (i, n) {
|
161
|
+
if (n.options.id != self.options.id) {
|
162
|
+
queue.push(n);
|
163
|
+
}
|
164
|
+
});
|
165
|
+
$.noty.queue = queue;
|
166
|
+
return;
|
167
|
+
}
|
161
168
|
|
162
|
-
|
163
|
-
|
164
|
-
|
169
|
+
self.$bar.addClass('i-am-closing-now');
|
170
|
+
|
171
|
+
if (self.options.callback.onClose) {
|
172
|
+
self.options.callback.onClose.apply(self);
|
173
|
+
}
|
165
174
|
|
166
|
-
|
167
|
-
|
168
|
-
|
175
|
+
self.$bar.clearQueue().stop().animate(
|
176
|
+
self.options.animation.close,
|
177
|
+
self.options.animation.speed,
|
178
|
+
self.options.animation.easing,
|
179
|
+
function () {
|
180
|
+
if (self.options.callback.afterClose) self.options.callback.afterClose.apply(self);
|
181
|
+
})
|
182
|
+
.promise().done(function () {
|
169
183
|
|
170
|
-
|
171
|
-
|
172
|
-
|
173
|
-
|
174
|
-
|
184
|
+
// Modal Cleaning
|
185
|
+
if (self.options.modal) {
|
186
|
+
$.notyRenderer.setModalCount(-1);
|
187
|
+
if ($.notyRenderer.getModalCount() == 0) $('.noty_modal').fadeOut('fast', function () {
|
188
|
+
$(this).remove();
|
189
|
+
});
|
190
|
+
}
|
175
191
|
|
192
|
+
// Layout Cleaning
|
193
|
+
$.notyRenderer.setLayoutCountFor(self, -1);
|
194
|
+
if ($.notyRenderer.getLayoutCountFor(self) == 0) $(self.options.layout.container.selector).remove();
|
195
|
+
|
196
|
+
// Make sure self.$bar has not been removed before attempting to remove it
|
197
|
+
if (typeof self.$bar !== 'undefined' && self.$bar !== null ) {
|
198
|
+
self.$bar.remove();
|
199
|
+
self.$bar = null;
|
200
|
+
self.closed = true;
|
201
|
+
}
|
202
|
+
|
203
|
+
delete $.noty.store[self.options.id]; // deleting noty from store
|
204
|
+
|
205
|
+
self.options.theme.callback.onClose.apply(self);
|
206
|
+
|
207
|
+
if (!self.options.dismissQueue) {
|
208
|
+
// Queue render
|
209
|
+
$.noty.ontap = true;
|
210
|
+
|
211
|
+
$.notyRenderer.render();
|
212
|
+
}
|
213
|
+
|
214
|
+
if (self.options.maxVisible > 0 && self.options.dismissQueue) {
|
176
215
|
$.notyRenderer.render();
|
177
216
|
}
|
217
|
+
})
|
218
|
+
|
219
|
+
}, // end close
|
178
220
|
|
179
|
-
|
221
|
+
setText:function (text) {
|
222
|
+
if (!this.closed) {
|
223
|
+
this.options.text = text;
|
224
|
+
this.$bar.find('.noty_text').html(text);
|
225
|
+
}
|
226
|
+
return this;
|
227
|
+
},
|
180
228
|
|
181
|
-
|
229
|
+
setType:function (type) {
|
230
|
+
if (!this.closed) {
|
231
|
+
this.options.type = type;
|
232
|
+
this.options.theme.style.apply(this);
|
233
|
+
this.options.theme.callback.onShow.apply(this);
|
234
|
+
}
|
235
|
+
return this;
|
236
|
+
},
|
182
237
|
|
183
|
-
|
184
|
-
|
185
|
-
|
186
|
-
|
187
|
-
|
188
|
-
|
189
|
-
|
238
|
+
setTimeout:function (time) {
|
239
|
+
if (!this.closed) {
|
240
|
+
var self = this;
|
241
|
+
this.options.timeout = time;
|
242
|
+
self.$bar.delay(self.options.timeout).promise().done(function () {
|
243
|
+
self.close();
|
244
|
+
});
|
245
|
+
}
|
246
|
+
return this;
|
247
|
+
},
|
190
248
|
|
191
|
-
|
192
|
-
|
193
|
-
|
194
|
-
|
195
|
-
|
196
|
-
|
197
|
-
|
198
|
-
|
249
|
+
stopPropagation:function (evt) {
|
250
|
+
evt = evt || window.event;
|
251
|
+
if (typeof evt.stopPropagation !== "undefined") {
|
252
|
+
evt.stopPropagation();
|
253
|
+
} else {
|
254
|
+
evt.cancelBubble = true;
|
255
|
+
}
|
256
|
+
},
|
199
257
|
|
200
|
-
|
201
|
-
|
258
|
+
closed:false,
|
259
|
+
shown:false
|
202
260
|
|
203
|
-
|
261
|
+
}; // end NotyObject
|
204
262
|
|
205
|
-
|
263
|
+
$.notyRenderer = {};
|
206
264
|
|
207
|
-
|
265
|
+
$.notyRenderer.init = function (options) {
|
208
266
|
|
209
|
-
|
210
|
-
|
267
|
+
// Renderer creates a new noty
|
268
|
+
var notification = Object.create(NotyObject).init(options);
|
211
269
|
|
212
|
-
|
270
|
+
(notification.options.force) ? $.noty.queue.unshift(notification) : $.noty.queue.push(notification);
|
213
271
|
|
214
|
-
|
272
|
+
$.notyRenderer.render();
|
215
273
|
|
216
|
-
|
217
|
-
|
274
|
+
return ($.noty.returns == 'object') ? notification : notification.options.id;
|
275
|
+
};
|
218
276
|
|
219
|
-
|
277
|
+
$.notyRenderer.render = function () {
|
220
278
|
|
221
|
-
|
279
|
+
var instance = $.noty.queue[0];
|
222
280
|
|
223
|
-
|
224
|
-
|
225
|
-
|
226
|
-
|
227
|
-
|
281
|
+
if ($.type(instance) === 'object') {
|
282
|
+
if (instance.options.dismissQueue) {
|
283
|
+
if (instance.options.maxVisible > 0) {
|
284
|
+
if ($(instance.options.layout.container.selector + ' li').length < instance.options.maxVisible) {
|
285
|
+
$.notyRenderer.show($.noty.queue.shift());
|
286
|
+
} else {
|
287
|
+
|
288
|
+
}
|
289
|
+
} else {
|
228
290
|
$.notyRenderer.show($.noty.queue.shift());
|
229
|
-
$.noty.ontap = false;
|
230
291
|
}
|
231
|
-
|
232
|
-
|
233
|
-
|
234
|
-
|
235
|
-
|
236
|
-
|
237
|
-
|
238
|
-
|
239
|
-
|
240
|
-
|
241
|
-
|
242
|
-
|
243
|
-
|
244
|
-
|
245
|
-
|
246
|
-
|
247
|
-
|
248
|
-
|
249
|
-
|
250
|
-
|
251
|
-
|
252
|
-
|
253
|
-
|
254
|
-
|
255
|
-
|
256
|
-
|
257
|
-
|
258
|
-
|
259
|
-
|
260
|
-
|
261
|
-
|
262
|
-
|
263
|
-
|
264
|
-
|
265
|
-
|
266
|
-
|
267
|
-
|
268
|
-
|
269
|
-
|
270
|
-
|
271
|
-
|
272
|
-
|
273
|
-
|
274
|
-
|
275
|
-
|
276
|
-
|
277
|
-
|
278
|
-
|
279
|
-
|
280
|
-
|
281
|
-
|
282
|
-
|
283
|
-
|
284
|
-
|
285
|
-
|
286
|
-
|
287
|
-
|
288
|
-
|
289
|
-
|
290
|
-
|
291
|
-
|
292
|
-
|
293
|
-
|
294
|
-
|
295
|
-
|
296
|
-
|
297
|
-
|
298
|
-
|
299
|
-
|
300
|
-
|
301
|
-
|
302
|
-
|
303
|
-
|
304
|
-
|
305
|
-
|
306
|
-
|
307
|
-
|
308
|
-
|
309
|
-
|
310
|
-
|
311
|
-
|
312
|
-
|
313
|
-
|
314
|
-
|
315
|
-
|
316
|
-
|
317
|
-
|
318
|
-
|
319
|
-
|
320
|
-
|
321
|
-
|
322
|
-
|
323
|
-
|
324
|
-
|
325
|
-
|
326
|
-
|
327
|
-
|
328
|
-
|
329
|
-
|
330
|
-
|
331
|
-
|
332
|
-
|
333
|
-
|
334
|
-
|
335
|
-
|
336
|
-
|
337
|
-
|
338
|
-
|
339
|
-
|
340
|
-
|
341
|
-
|
342
|
-
|
343
|
-
|
344
|
-
|
345
|
-
|
346
|
-
|
347
|
-
|
348
|
-
|
349
|
-
|
350
|
-
|
351
|
-
|
352
|
-
|
353
|
-
|
354
|
-
|
355
|
-
|
356
|
-
|
357
|
-
|
358
|
-
|
359
|
-
|
360
|
-
|
361
|
-
|
362
|
-
|
363
|
-
|
364
|
-
|
365
|
-
|
366
|
-
|
367
|
-
|
368
|
-
|
369
|
-
|
370
|
-
|
292
|
+
} else {
|
293
|
+
if ($.noty.ontap) {
|
294
|
+
$.notyRenderer.show($.noty.queue.shift());
|
295
|
+
$.noty.ontap = false;
|
296
|
+
}
|
297
|
+
}
|
298
|
+
} else {
|
299
|
+
$.noty.ontap = true; // Queue is over
|
300
|
+
}
|
301
|
+
|
302
|
+
};
|
303
|
+
|
304
|
+
$.notyRenderer.show = function (notification) {
|
305
|
+
|
306
|
+
if (notification.options.modal) {
|
307
|
+
$.notyRenderer.createModalFor(notification);
|
308
|
+
$.notyRenderer.setModalCount(+1);
|
309
|
+
}
|
310
|
+
|
311
|
+
// Where is the container?
|
312
|
+
if ($(notification.options.layout.container.selector).length == 0) {
|
313
|
+
if (notification.options.custom) {
|
314
|
+
notification.options.custom.append($(notification.options.layout.container.object).addClass('i-am-new'));
|
315
|
+
} else {
|
316
|
+
$('body').append($(notification.options.layout.container.object).addClass('i-am-new'));
|
317
|
+
}
|
318
|
+
} else {
|
319
|
+
$(notification.options.layout.container.selector).removeClass('i-am-new');
|
320
|
+
}
|
321
|
+
|
322
|
+
$.notyRenderer.setLayoutCountFor(notification, +1);
|
323
|
+
|
324
|
+
notification.show();
|
325
|
+
};
|
326
|
+
|
327
|
+
$.notyRenderer.createModalFor = function (notification) {
|
328
|
+
if ($('.noty_modal').length == 0)
|
329
|
+
$('<div/>').addClass('noty_modal').data('noty_modal_count', 0).css(notification.options.theme.modal.css).prependTo($('body')).fadeIn('fast');
|
330
|
+
};
|
331
|
+
|
332
|
+
$.notyRenderer.getLayoutCountFor = function (notification) {
|
333
|
+
return $(notification.options.layout.container.selector).data('noty_layout_count') || 0;
|
334
|
+
};
|
335
|
+
|
336
|
+
$.notyRenderer.setLayoutCountFor = function (notification, arg) {
|
337
|
+
return $(notification.options.layout.container.selector).data('noty_layout_count', $.notyRenderer.getLayoutCountFor(notification) + arg);
|
338
|
+
};
|
339
|
+
|
340
|
+
$.notyRenderer.getModalCount = function () {
|
341
|
+
return $('.noty_modal').data('noty_modal_count') || 0;
|
342
|
+
};
|
343
|
+
|
344
|
+
$.notyRenderer.setModalCount = function (arg) {
|
345
|
+
return $('.noty_modal').data('noty_modal_count', $.notyRenderer.getModalCount() + arg);
|
346
|
+
};
|
347
|
+
|
348
|
+
// This is for custom container
|
349
|
+
$.fn.noty = function (options) {
|
350
|
+
options.custom = $(this);
|
351
|
+
return $.notyRenderer.init(options);
|
352
|
+
};
|
353
|
+
|
354
|
+
$.noty = {};
|
355
|
+
$.noty.queue = [];
|
356
|
+
$.noty.ontap = true;
|
357
|
+
$.noty.layouts = {};
|
358
|
+
$.noty.themes = {};
|
359
|
+
$.noty.returns = 'object';
|
360
|
+
$.noty.store = {};
|
361
|
+
|
362
|
+
$.noty.get = function (id) {
|
363
|
+
return $.noty.store.hasOwnProperty(id) ? $.noty.store[id] : false;
|
364
|
+
};
|
365
|
+
|
366
|
+
$.noty.close = function (id) {
|
367
|
+
return $.noty.get(id) ? $.noty.get(id).close() : false;
|
368
|
+
};
|
369
|
+
|
370
|
+
$.noty.setText = function (id, text) {
|
371
|
+
return $.noty.get(id) ? $.noty.get(id).setText(text) : false;
|
372
|
+
};
|
373
|
+
|
374
|
+
$.noty.setType = function (id, type) {
|
375
|
+
return $.noty.get(id) ? $.noty.get(id).setType(type) : false;
|
376
|
+
};
|
377
|
+
|
378
|
+
$.noty.clearQueue = function () {
|
379
|
+
$.noty.queue = [];
|
380
|
+
};
|
381
|
+
|
382
|
+
$.noty.closeAll = function () {
|
383
|
+
$.noty.clearQueue();
|
384
|
+
$.each($.noty.store, function (id, noty) {
|
385
|
+
noty.close();
|
386
|
+
});
|
387
|
+
};
|
388
|
+
|
389
|
+
var windowAlert = window.alert;
|
390
|
+
|
391
|
+
$.noty.consumeAlert = function (options) {
|
392
|
+
window.alert = function (text) {
|
393
|
+
if (options)
|
394
|
+
options.text = text;
|
395
|
+
else
|
396
|
+
options = {text:text};
|
397
|
+
|
398
|
+
$.notyRenderer.init(options);
|
399
|
+
};
|
400
|
+
};
|
401
|
+
|
402
|
+
$.noty.stopConsumeAlert = function () {
|
403
|
+
window.alert = windowAlert;
|
404
|
+
};
|
405
|
+
|
406
|
+
$.noty.defaults = {
|
407
|
+
layout:'top',
|
408
|
+
theme:'defaultTheme',
|
409
|
+
type:'alert',
|
410
|
+
text:'',
|
411
|
+
dismissQueue:true,
|
412
|
+
template:'<div class="noty_message"><span class="noty_text"></span><div class="noty_close"></div></div>',
|
413
|
+
animation:{
|
414
|
+
open:{height:'toggle'},
|
415
|
+
close:{height:'toggle'},
|
416
|
+
easing:'swing',
|
417
|
+
speed:500
|
418
|
+
},
|
419
|
+
timeout:false,
|
420
|
+
force:false,
|
421
|
+
modal:false,
|
422
|
+
maxVisible:5,
|
423
|
+
closeWith:['click'],
|
424
|
+
callback:{
|
425
|
+
onShow:function () {
|
426
|
+
},
|
427
|
+
afterShow:function () {
|
428
|
+
},
|
429
|
+
onClose:function () {
|
430
|
+
},
|
431
|
+
afterClose:function () {
|
432
|
+
},
|
433
|
+
onCloseClick:function () {
|
434
|
+
}
|
435
|
+
},
|
436
|
+
buttons:false
|
437
|
+
};
|
438
|
+
|
439
|
+
$(window).resize(function () {
|
440
|
+
$.each($.noty.layouts, function (index, layout) {
|
441
|
+
layout.container.style.apply($(layout.container.selector));
|
442
|
+
});
|
443
|
+
});
|
371
444
|
|
372
445
|
})(jQuery);
|
373
446
|
|
374
447
|
// Helpers
|
375
|
-
function noty(options) {
|
376
|
-
|
377
|
-
|
378
|
-
|
379
|
-
|
380
|
-
|
381
|
-
|
382
|
-
|
383
|
-
|
384
|
-
|
385
|
-
|
386
|
-
|
387
|
-
|
388
|
-
|
389
|
-
|
390
|
-
|
391
|
-
|
392
|
-
|
393
|
-
|
394
|
-
|
395
|
-
|
396
|
-
|
397
|
-
|
398
|
-
|
399
|
-
|
400
|
-
|
401
|
-
|
402
|
-
|
403
|
-
|
404
|
-
|
405
|
-
|
406
|
-
|
407
|
-
|
408
|
-
|
409
|
-
|
410
|
-
|
411
|
-
|
412
|
-
|
413
|
-
|
414
|
-
|
415
|
-
|
416
|
-
|
417
|
-
|
418
|
-
|
419
|
-
|
420
|
-
|
421
|
-
|
422
|
-
|
423
|
-
|
424
|
-
|
425
|
-
|
426
|
-
|
427
|
-
|
428
|
-
|
429
|
-
|
430
|
-
|
431
|
-
|
432
|
-
|
433
|
-
|
434
|
-
|
435
|
-
|
436
|
-
|
437
|
-
|
438
|
-
|
439
|
-
|
440
|
-
|
441
|
-
|
442
|
-
|
443
|
-
|
444
|
-
|
445
|
-
|
446
|
-
|
447
|
-
|
448
|
-
|
449
|
-
|
450
|
-
|
451
|
-
|
452
|
-
|
453
|
-
|
454
|
-
|
455
|
-
|
456
|
-
|
457
|
-
|
458
|
-
|
459
|
-
|
460
|
-
|
461
|
-
|
462
|
-
|
463
|
-
|
464
|
-
|
465
|
-
|
466
|
-
|
467
|
-
|
468
|
-
|
469
|
-
|
470
|
-
|
471
|
-
|
448
|
+
window.noty = function noty(options) {
|
449
|
+
|
450
|
+
// This is for BC - Will be deleted on v2.2.0
|
451
|
+
var using_old = 0
|
452
|
+
, old_to_new = {
|
453
|
+
'animateOpen':'animation.open',
|
454
|
+
'animateClose':'animation.close',
|
455
|
+
'easing':'animation.easing',
|
456
|
+
'speed':'animation.speed',
|
457
|
+
'onShow':'callback.onShow',
|
458
|
+
'onShown':'callback.afterShow',
|
459
|
+
'onClose':'callback.onClose',
|
460
|
+
'onCloseClick':'callback.onCloseClick',
|
461
|
+
'onClosed':'callback.afterClose'
|
462
|
+
};
|
463
|
+
|
464
|
+
jQuery.each(options, function (key, value) {
|
465
|
+
if (old_to_new[key]) {
|
466
|
+
using_old++;
|
467
|
+
var _new = old_to_new[key].split('.');
|
468
|
+
|
469
|
+
if (!options[_new[0]]) options[_new[0]] = {};
|
470
|
+
|
471
|
+
options[_new[0]][_new[1]] = (value) ? value : function () {
|
472
|
+
};
|
473
|
+
delete options[key];
|
474
|
+
}
|
475
|
+
});
|
476
|
+
|
477
|
+
if (!options.closeWith) {
|
478
|
+
options.closeWith = jQuery.noty.defaults.closeWith;
|
479
|
+
}
|
480
|
+
|
481
|
+
if (options.hasOwnProperty('closeButton')) {
|
482
|
+
using_old++;
|
483
|
+
if (options.closeButton) options.closeWith.push('button');
|
484
|
+
delete options.closeButton;
|
485
|
+
}
|
486
|
+
|
487
|
+
if (options.hasOwnProperty('closeOnSelfClick')) {
|
488
|
+
using_old++;
|
489
|
+
if (options.closeOnSelfClick) options.closeWith.push('click');
|
490
|
+
delete options.closeOnSelfClick;
|
491
|
+
}
|
492
|
+
|
493
|
+
if (options.hasOwnProperty('closeOnSelfOver')) {
|
494
|
+
using_old++;
|
495
|
+
if (options.closeOnSelfOver) options.closeWith.push('hover');
|
496
|
+
delete options.closeOnSelfOver;
|
497
|
+
}
|
498
|
+
|
499
|
+
if (options.hasOwnProperty('custom')) {
|
500
|
+
using_old++;
|
501
|
+
if (options.custom.container != 'null') options.custom = options.custom.container;
|
502
|
+
}
|
503
|
+
|
504
|
+
if (options.hasOwnProperty('cssPrefix')) {
|
505
|
+
using_old++;
|
506
|
+
delete options.cssPrefix;
|
507
|
+
}
|
508
|
+
|
509
|
+
if (options.theme == 'noty_theme_default') {
|
510
|
+
using_old++;
|
511
|
+
options.theme = 'defaultTheme';
|
512
|
+
}
|
513
|
+
|
514
|
+
if (!options.hasOwnProperty('dismissQueue')) {
|
515
|
+
options.dismissQueue = jQuery.noty.defaults.dismissQueue;
|
516
|
+
}
|
517
|
+
|
518
|
+
if (!options.hasOwnProperty('maxVisible')) {
|
519
|
+
options.maxVisible = jQuery.noty.defaults.maxVisible;
|
520
|
+
}
|
521
|
+
|
522
|
+
if (options.buttons) {
|
523
|
+
jQuery.each(options.buttons, function (i, button) {
|
524
|
+
if (button.click) {
|
525
|
+
using_old++;
|
526
|
+
button.onClick = button.click;
|
527
|
+
delete button.click;
|
528
|
+
}
|
529
|
+
if (button.type) {
|
530
|
+
using_old++;
|
531
|
+
button.addClass = button.type;
|
532
|
+
delete button.type;
|
533
|
+
}
|
534
|
+
});
|
535
|
+
}
|
536
|
+
|
537
|
+
if (using_old) {
|
538
|
+
if (typeof console !== "undefined" && console.warn) {
|
539
|
+
console.warn('You are using noty v2 with v1.x.x options. @deprecated until v2.2.0 - Please update your options.');
|
540
|
+
}
|
541
|
+
}
|
542
|
+
|
543
|
+
// console.log(options);
|
544
|
+
// End of the BC
|
545
|
+
|
546
|
+
return jQuery.notyRenderer.init(options);
|
547
|
+
}
|
@@ -3,7 +3,7 @@
|
|
3
3
|
$.noty.layouts.bottomCenter = {
|
4
4
|
name: 'bottomCenter',
|
5
5
|
options: { // overrides options
|
6
|
-
|
6
|
+
|
7
7
|
},
|
8
8
|
container: {
|
9
9
|
object: '<ul id="noty_bottomCenter_layout_container" />',
|
@@ -20,9 +20,9 @@
|
|
20
20
|
listStyleType: 'none',
|
21
21
|
zIndex: 10000000
|
22
22
|
});
|
23
|
-
|
23
|
+
|
24
24
|
$(this).css({
|
25
|
-
left: ($(window).width() - $(this).outerWidth()) / 2 + 'px'
|
25
|
+
left: ($(window).width() - $(this).outerWidth(false)) / 2 + 'px'
|
26
26
|
});
|
27
27
|
}
|
28
28
|
},
|
@@ -38,4 +38,4 @@
|
|
38
38
|
addClass: ''
|
39
39
|
};
|
40
40
|
|
41
|
-
})(jQuery);
|
41
|
+
})(jQuery);
|
@@ -29,12 +29,12 @@
|
|
29
29
|
|
30
30
|
if ($(this).hasClass('i-am-new')) {
|
31
31
|
$(this).css({
|
32
|
-
left: ($(window).width() - $(this).outerWidth()) / 2 + 'px',
|
32
|
+
left: ($(window).width() - $(this).outerWidth(false)) / 2 + 'px',
|
33
33
|
top: ($(window).height() - actual_height) / 2 + 'px'
|
34
34
|
});
|
35
35
|
} else {
|
36
36
|
$(this).animate({
|
37
|
-
left: ($(window).width() - $(this).outerWidth()) / 2 + 'px',
|
37
|
+
left: ($(window).width() - $(this).outerWidth(false)) / 2 + 'px',
|
38
38
|
top: ($(window).height() - actual_height) / 2 + 'px'
|
39
39
|
}, 500);
|
40
40
|
}
|
@@ -3,7 +3,7 @@
|
|
3
3
|
$.noty.layouts.centerLeft = {
|
4
4
|
name: 'centerLeft',
|
5
5
|
options: { // overrides options
|
6
|
-
|
6
|
+
|
7
7
|
},
|
8
8
|
container: {
|
9
9
|
object: '<ul id="noty_centerLeft_layout_container" />',
|
@@ -30,7 +30,7 @@
|
|
30
30
|
|
31
31
|
if ($(this).hasClass('i-am-new')) {
|
32
32
|
$(this).css({
|
33
|
-
top: ($(window).height() - actual_height) / 2 + 'px'
|
33
|
+
top: ($(window).height() - actual_height) / 2 + 'px'
|
34
34
|
});
|
35
35
|
} else {
|
36
36
|
$(this).animate({
|
@@ -58,4 +58,4 @@
|
|
58
58
|
addClass: ''
|
59
59
|
};
|
60
60
|
|
61
|
-
})(jQuery);
|
61
|
+
})(jQuery);
|
@@ -3,7 +3,7 @@
|
|
3
3
|
$.noty.layouts.centerRight = {
|
4
4
|
name: 'centerRight',
|
5
5
|
options: { // overrides options
|
6
|
-
|
6
|
+
|
7
7
|
},
|
8
8
|
container: {
|
9
9
|
object: '<ul id="noty_centerRight_layout_container" />',
|
@@ -30,7 +30,7 @@
|
|
30
30
|
|
31
31
|
if ($(this).hasClass('i-am-new')) {
|
32
32
|
$(this).css({
|
33
|
-
top: ($(window).height() - actual_height) / 2 + 'px'
|
33
|
+
top: ($(window).height() - actual_height) / 2 + 'px'
|
34
34
|
});
|
35
35
|
} else {
|
36
36
|
$(this).animate({
|
@@ -43,7 +43,7 @@
|
|
43
43
|
right: 5
|
44
44
|
});
|
45
45
|
}
|
46
|
-
|
46
|
+
|
47
47
|
}
|
48
48
|
},
|
49
49
|
parent: {
|
@@ -58,4 +58,4 @@
|
|
58
58
|
addClass: ''
|
59
59
|
};
|
60
60
|
|
61
|
-
})(jQuery);
|
61
|
+
})(jQuery);
|
@@ -3,7 +3,7 @@
|
|
3
3
|
$.noty.layouts.topCenter = {
|
4
4
|
name: 'topCenter',
|
5
5
|
options: { // overrides options
|
6
|
-
|
6
|
+
|
7
7
|
},
|
8
8
|
container: {
|
9
9
|
object: '<ul id="noty_topCenter_layout_container" />',
|
@@ -20,9 +20,9 @@
|
|
20
20
|
listStyleType: 'none',
|
21
21
|
zIndex: 10000000
|
22
22
|
});
|
23
|
-
|
23
|
+
|
24
24
|
$(this).css({
|
25
|
-
left: ($(window).width() - $(this).outerWidth()) / 2 + 'px'
|
25
|
+
left: ($(window).width() - $(this).outerWidth(false)) / 2 + 'px'
|
26
26
|
});
|
27
27
|
}
|
28
28
|
},
|
@@ -38,4 +38,4 @@
|
|
38
38
|
addClass: ''
|
39
39
|
};
|
40
40
|
|
41
|
-
})(jQuery);
|
41
|
+
})(jQuery);
|
@@ -1,7 +1,7 @@
|
|
1
1
|
;(function($) {
|
2
2
|
|
3
|
-
$.noty.themes.
|
4
|
-
name: '
|
3
|
+
$.noty.themes.defaultTheme = {
|
4
|
+
name: 'defaultTheme',
|
5
5
|
helpers: {
|
6
6
|
borderFix: function() {
|
7
7
|
if (this.options.dismissQueue) {
|
@@ -34,16 +34,16 @@
|
|
34
34
|
opacity: 0.6,
|
35
35
|
display: 'none',
|
36
36
|
left: 0,
|
37
|
-
top: 0
|
37
|
+
top: 0
|
38
38
|
}
|
39
39
|
},
|
40
40
|
style: function() {
|
41
|
-
|
41
|
+
|
42
42
|
this.$bar.css({
|
43
43
|
overflow: 'hidden',
|
44
44
|
background: "url('') repeat-x scroll left top #fff"
|
45
45
|
});
|
46
|
-
|
46
|
+
|
47
47
|
this.$message.css({
|
48
48
|
fontSize: '13px',
|
49
49
|
lineHeight: '16px',
|
@@ -52,36 +52,36 @@
|
|
52
52
|
width: 'auto',
|
53
53
|
position: 'relative'
|
54
54
|
});
|
55
|
-
|
55
|
+
|
56
56
|
this.$closeButton.css({
|
57
57
|
position: 'absolute',
|
58
58
|
top: 4, right: 4,
|
59
59
|
width: 10, height: 10,
|
60
60
|
background: "url()",
|
61
61
|
display: 'none',
|
62
|
-
cursor: 'pointer'
|
62
|
+
cursor: 'pointer'
|
63
63
|
});
|
64
|
-
|
64
|
+
|
65
65
|
this.$buttons.css({
|
66
66
|
padding: 5,
|
67
67
|
textAlign: 'right',
|
68
68
|
borderTop: '1px solid #ccc',
|
69
|
-
backgroundColor: '#fff'
|
69
|
+
backgroundColor: '#fff'
|
70
70
|
});
|
71
|
-
|
71
|
+
|
72
72
|
this.$buttons.find('button').css({
|
73
73
|
marginLeft: 5
|
74
74
|
});
|
75
|
-
|
75
|
+
|
76
76
|
this.$buttons.find('button:first').css({
|
77
77
|
marginLeft: 0
|
78
78
|
});
|
79
|
-
|
79
|
+
|
80
80
|
this.$bar.bind({
|
81
|
-
mouseenter: function() { $(this).find('.noty_close').
|
82
|
-
mouseleave: function() { $(this).find('.noty_close').
|
81
|
+
mouseenter: function() { $(this).find('.noty_close').stop().fadeTo('normal',1); },
|
82
|
+
mouseleave: function() { $(this).find('.noty_close').stop().fadeTo('normal',0); }
|
83
83
|
});
|
84
|
-
|
84
|
+
|
85
85
|
switch (this.options.layout.name) {
|
86
86
|
case 'top':
|
87
87
|
this.$bar.css({
|
@@ -126,31 +126,31 @@
|
|
126
126
|
});
|
127
127
|
break;
|
128
128
|
}
|
129
|
-
|
129
|
+
|
130
130
|
switch (this.options.type) {
|
131
131
|
case 'alert': case 'notification':
|
132
132
|
this.$bar.css({backgroundColor: '#FFF', borderColor: '#CCC', color: '#444'}); break;
|
133
133
|
case 'warning':
|
134
|
-
this.$bar.css({backgroundColor: '#FFEAA8', borderColor: '#FFC237', color: '#826200'});
|
134
|
+
this.$bar.css({backgroundColor: '#FFEAA8', borderColor: '#FFC237', color: '#826200'});
|
135
135
|
this.$buttons.css({borderTop: '1px solid #FFC237'}); break;
|
136
136
|
case 'error':
|
137
137
|
this.$bar.css({backgroundColor: 'red', borderColor: 'darkred', color: '#FFF'});
|
138
|
-
this.$message.css({fontWeight: 'bold'});
|
138
|
+
this.$message.css({fontWeight: 'bold'});
|
139
139
|
this.$buttons.css({borderTop: '1px solid darkred'}); break;
|
140
140
|
case 'information':
|
141
|
-
this.$bar.css({backgroundColor: '#57B7E2', borderColor: '#0B90C4', color: '#FFF'});
|
141
|
+
this.$bar.css({backgroundColor: '#57B7E2', borderColor: '#0B90C4', color: '#FFF'});
|
142
142
|
this.$buttons.css({borderTop: '1px solid #0B90C4'}); break;
|
143
143
|
case 'success':
|
144
|
-
this.$bar.css({backgroundColor: 'lightgreen', borderColor: '#50C24E', color: 'darkgreen'});
|
144
|
+
this.$bar.css({backgroundColor: 'lightgreen', borderColor: '#50C24E', color: 'darkgreen'});
|
145
145
|
this.$buttons.css({borderTop: '1px solid #50C24E'});break;
|
146
146
|
default:
|
147
147
|
this.$bar.css({backgroundColor: '#FFF', borderColor: '#CCC', color: '#444'}); break;
|
148
148
|
}
|
149
149
|
},
|
150
150
|
callback: {
|
151
|
-
onShow: function() { $.noty.themes.
|
152
|
-
onClose: function() { $.noty.themes.
|
151
|
+
onShow: function() { $.noty.themes.defaultTheme.helpers.borderFix.apply(this); },
|
152
|
+
onClose: function() { $.noty.themes.defaultTheme.helpers.borderFix.apply(this); }
|
153
153
|
}
|
154
154
|
};
|
155
155
|
|
156
|
-
})(jQuery);
|
156
|
+
})(jQuery);
|
metadata
CHANGED
@@ -1,14 +1,14 @@
|
|
1
1
|
--- !ruby/object:Gem::Specification
|
2
2
|
name: noty-rails
|
3
3
|
version: !ruby/object:Gem::Version
|
4
|
-
version: 2.0
|
4
|
+
version: 2.1.0
|
5
5
|
platform: ruby
|
6
6
|
authors:
|
7
7
|
- PikachuEXE
|
8
8
|
autorequire:
|
9
9
|
bindir: bin
|
10
10
|
cert_chain: []
|
11
|
-
date: 2013-03
|
11
|
+
date: 2013-09-03 00:00:00.000000000 Z
|
12
12
|
dependencies: []
|
13
13
|
description: This gem provides Noty, a jQuery Notification Plugin, for your Rails
|
14
14
|
application.
|
@@ -59,8 +59,9 @@ required_rubygems_version: !ruby/object:Gem::Requirement
|
|
59
59
|
version: '0'
|
60
60
|
requirements: []
|
61
61
|
rubyforge_project:
|
62
|
-
rubygems_version: 2.0.
|
62
|
+
rubygems_version: 2.0.7
|
63
63
|
signing_key:
|
64
64
|
specification_version: 4
|
65
65
|
summary: Noty asset pipeline provider/wrapper
|
66
66
|
test_files: []
|
67
|
+
has_rdoc:
|