noty-rails 2.0.3.1 → 2.1.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
checksums.yaml CHANGED
@@ -1,7 +1,7 @@
1
1
  ---
2
2
  SHA1:
3
- metadata.gz: da7126a6aa2104d1f9eef088c391b916f9362013
4
- data.tar.gz: 9734bd14d19a8800b4671df9b48aa3c79927e41e
3
+ metadata.gz: df308d43dfcfdc3f9d472b0d12ae5b3aeb54d5e2
4
+ data.tar.gz: 89a867a5ca5cb043ca13c95802d45f0308ee07d7
5
5
  SHA512:
6
- metadata.gz: 88c76143bd44a966537a663c1934f28bd6f3acb7afa1139d508c33267e0739a96c7baaa0446ae8d67d26166b5e0ef975f3b7fa3eed31ca3e8bf7b2f35ccefe3c
7
- data.tar.gz: 4cc10b81033bb487a62893f1e1f81f7eb33a724619f4bd944063e090fb6a4aba955d0aab7d9b8245c2f382651a6bdbda0200efa2523e28310f024ecdb6176916
6
+ metadata.gz: 01c148b56d2c478ab91ef08507ef3eb1eb3c0911f52ffb6c0f893e9fc9c6468f06f6cb3161522ab472c2b2e10800063347278055b9a8421b8d8d0f6c511785c1
7
+ data.tar.gz: 5c1c3ef1db0fb612eb6a5592413c1461d688d66b4973cdc124fa180e773913080ed76e10d692909737d5e3ee7db65578d5cd2fb0d63634f9352a5141f1e2a635
data/README.md CHANGED
@@ -27,6 +27,10 @@ $.noty.defaults.layout = 'bottom'
27
27
 
28
28
  # Changelog
29
29
 
30
+ ### 2.1.0
31
+
32
+ - Update Noty to `2.1.0`
33
+
30
34
  ### 2.0.3.1
31
35
 
32
36
  - Make it compatible with Rails 4 version (Now is an instance of `Gem::Version`)
@@ -1,5 +1,5 @@
1
1
  module Noty
2
2
  module Rails
3
- VERSION = "2.0.3.1"
3
+ VERSION = "2.1.0"
4
4
  end
5
5
  end
@@ -1,471 +1,547 @@
1
1
  /**
2
- * noty - jQuery Notification Plugin v2.0.3
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
- Object.create = function (o) {
14
- function F() {};
15
- F.prototype = o;
16
- return new F();
17
- };
18
- };
13
+ Object.create = function (o) {
14
+ function F() {
15
+ }
19
16
 
20
- ;(function($) {
17
+ F.prototype = o;
18
+ return new F();
19
+ };
20
+ }
21
21
 
22
- var NotyObject = {
22
+ (function ($) {
23
23
 
24
- init: function(options) {
24
+ var NotyObject = {
25
25
 
26
- // Mix in the passed in options with the default options
27
- this.options = $.extend({}, $.noty.defaults, options);
26
+ init:function (options) {
28
27
 
29
- this.options.layout = (this.options.custom) ? $.noty.layouts['inline'] : $.noty.layouts[this.options.layout];
30
- this.options.theme = $.noty.themes[this.options.theme];
28
+ // Mix in the passed in options with the default options
29
+ this.options = $.extend({}, $.noty.defaults, options);
31
30
 
32
- delete options.layout, delete options.theme;
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
- this.options = $.extend({}, this.options, this.options.layout.options);
35
- this.options.id = 'noty_' + (new Date().getTime() * Math.floor(Math.random()* 1000000));
34
+ delete options.layout;
35
+ delete options.theme;
36
36
 
37
- this.options = $.extend({}, this.options, options);
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
- // Build the noty dom initial structure
40
- this._build();
40
+ this.options = $.extend({}, this.options, options);
41
41
 
42
- // return this so we can chain/use the bridge with less code.
43
- return this;
44
- }, // end init
42
+ // Build the noty dom initial structure
43
+ this._build();
45
44
 
46
- _build: function() {
45
+ // return this so we can chain/use the bridge with less code.
46
+ return this;
47
+ }, // end init
47
48
 
48
- // Generating noty bar
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
- this.$bar = (this.options.layout.parent.object !== null) ? $(this.options.layout.parent.object).css(this.options.layout.parent.css).append($bar) : $bar;
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
- // Set buttons if available
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
- // If we have button disable closeWith & timeout options
58
- this.options.closeWith = [], this.options.timeout = false;
57
+ // Set buttons if available
58
+ if (this.options.buttons) {
59
59
 
60
- var $buttons = $('<div/>').addClass('noty_buttons');
60
+ // If we have button disable closeWith & timeout options
61
+ this.options.closeWith = [];
62
+ this.options.timeout = false;
61
63
 
62
- (this.options.layout.parent.object !== null) ? this.$bar.find('.noty_bar').append($buttons) : this.$bar.append($buttons);
64
+ var $buttons = $('<div/>').addClass('noty_buttons');
63
65
 
64
- var self = this;
66
+ (this.options.layout.parent.object !== null) ? this.$bar.find('.noty_bar').append($buttons) : this.$bar.append($buttons);
65
67
 
66
- $.each(this.options.buttons, function(i, button) {
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
- // For easy access
74
- this.$message = this.$bar.find('.noty_message');
75
- this.$closeButton = this.$bar.find('.noty_close');
76
- this.$buttons = this.$bar.find('.noty_buttons');
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
- $.noty.store[this.options.id] = this; // store noty for api
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
- }, // end _build
86
+ $.noty.store[this.options.id] = this; // store noty for api
81
87
 
82
- show: function() {
88
+ }, // end _build
83
89
 
84
- var self = this;
90
+ show:function () {
85
91
 
86
- $(self.options.layout.container.selector).append(self.$bar);
92
+ var self = this;
87
93
 
88
- self.options.theme.style.apply(self);
94
+ $(self.options.layout.container.selector).append(self.$bar);
89
95
 
90
- ($.type(self.options.layout.css) === 'function') ? this.options.layout.css.apply(self.$bar) : self.$bar.css(this.options.layout.css || {});
96
+ self.options.theme.style.apply(self);
91
97
 
92
- self.$bar.addClass(self.options.layout.addClass);
98
+ ($.type(self.options.layout.css) === 'function') ? this.options.layout.css.apply(self.$bar) : self.$bar.css(this.options.layout.css || {});
93
99
 
94
- self.options.layout.container.style.apply($(self.options.layout.container.selector));
100
+ self.$bar.addClass(self.options.layout.addClass);
95
101
 
96
- self.options.theme.callback.onShow.apply(this);
102
+ self.options.layout.container.style.apply($(self.options.layout.container.selector));
97
103
 
98
- if ($.inArray('click', self.options.closeWith) > -1)
99
- self.$bar.css('cursor', 'pointer').one('click', function() { self.close(); });
104
+ self.options.theme.callback.onShow.apply(this);
100
105
 
101
- if ($.inArray('hover', self.options.closeWith) > -1)
102
- self.$bar.one('mouseenter', function() { self.close(); });
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
- if ($.inArray('button', self.options.closeWith) > -1)
105
- self.$closeButton.one('click', function() { self.close(); });
115
+ if ($.inArray('hover', self.options.closeWith) > -1)
116
+ self.$bar.one('mouseenter', function () {
117
+ self.close();
118
+ });
106
119
 
107
- if ($.inArray('button', self.options.closeWith) == -1)
108
- self.$closeButton.remove();
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
- if (self.options.callback.onShow)
111
- self.options.callback.onShow.apply(self);
126
+ if ($.inArray('button', self.options.closeWith) == -1)
127
+ self.$closeButton.remove();
112
128
 
113
- self.$bar.animate(
114
- self.options.animation.open,
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
- // If noty is have a timeout option
123
- if (self.options.timeout)
124
- self.$bar.delay(self.options.timeout).promise().done(function() { self.close(); });
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
- return this;
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
- }, // end show
147
+ return this;
129
148
 
130
- close: function() {
149
+ }, // end show
131
150
 
132
- if (this.closed) return;
151
+ close:function () {
133
152
 
134
- var self = this;
153
+ if (this.closed) return;
154
+ if (this.$bar && this.$bar.hasClass('i-am-closing-now')) return;
135
155
 
136
- if (!this.shown) { // If we are still waiting in the queue just delete from queue
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
- self.$bar.clearQueue().stop().animate(
150
- self.options.animation.close,
151
- self.options.animation.speed,
152
- self.options.animation.easing,
153
- function() { if (self.options.callback.afterClose) self.options.callback.afterClose.apply(self); })
154
- .promise().done(function() {
155
-
156
- // Modal Cleaning
157
- if (self.options.modal) {
158
- $.notyRenderer.setModalCount(-1);
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
- // Layout Cleaning
163
- $.notyRenderer.setLayoutCountFor(self, -1);
164
- if ($.notyRenderer.getLayoutCountFor(self) == 0) $(self.options.layout.container.selector).remove();
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
- self.$bar.remove();
167
- self.$bar = null;
168
- self.closed = true;
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
- delete $.noty.store[self.options.id]; // deleting noty from store
171
-
172
- if (!self.options.dismissQueue) {
173
- // Queue render
174
- $.noty.ontap = true;
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
- }, // end close
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
- setText: function(text) {
184
- if (!this.closed) {
185
- this.options.text = text;
186
- this.$bar.find('.noty_text').html(text);
187
- }
188
- return this;
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
- setType: function(type) {
192
- if (!this.closed) {
193
- this.options.type = type;
194
- this.options.theme.style.apply(this);
195
- this.options.theme.callback.onShow.apply(this);
196
- }
197
- return this;
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
- closed: false,
201
- shown: false
258
+ closed:false,
259
+ shown:false
202
260
 
203
- }; // end NotyObject
261
+ }; // end NotyObject
204
262
 
205
- $.notyRenderer = {};
263
+ $.notyRenderer = {};
206
264
 
207
- $.notyRenderer.init = function(options) {
265
+ $.notyRenderer.init = function (options) {
208
266
 
209
- // Renderer creates a new noty
210
- var notification = Object.create(NotyObject).init(options);
267
+ // Renderer creates a new noty
268
+ var notification = Object.create(NotyObject).init(options);
211
269
 
212
- (notification.options.force) ? $.noty.queue.unshift(notification) : $.noty.queue.push(notification);
270
+ (notification.options.force) ? $.noty.queue.unshift(notification) : $.noty.queue.push(notification);
213
271
 
214
- $.notyRenderer.render();
272
+ $.notyRenderer.render();
215
273
 
216
- return ($.noty.returns == 'object') ? notification : notification.options.id;
217
- };
274
+ return ($.noty.returns == 'object') ? notification : notification.options.id;
275
+ };
218
276
 
219
- $.notyRenderer.render = function() {
277
+ $.notyRenderer.render = function () {
220
278
 
221
- var instance = $.noty.queue[0];
279
+ var instance = $.noty.queue[0];
222
280
 
223
- if ($.type(instance) === 'object') {
224
- if (instance.options.dismissQueue) {
225
- $.notyRenderer.show($.noty.queue.shift());
226
- } else {
227
- if ($.noty.ontap) {
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
- } else {
233
- $.noty.ontap = true; // Queue is over
234
- }
235
-
236
- };
237
-
238
- $.notyRenderer.show = function(notification) {
239
-
240
- if (notification.options.modal) {
241
- $.notyRenderer.createModalFor(notification);
242
- $.notyRenderer.setModalCount(+1);
243
- }
244
-
245
- // Where is the container?
246
- if ($(notification.options.layout.container.selector).length == 0) {
247
- if (notification.options.custom) {
248
- notification.options.custom.append($(notification.options.layout.container.object).addClass('i-am-new'));
249
- } else {
250
- $('body').append($(notification.options.layout.container.object).addClass('i-am-new'));
251
- }
252
- } else {
253
- $(notification.options.layout.container.selector).removeClass('i-am-new');
254
- }
255
-
256
- $.notyRenderer.setLayoutCountFor(notification, +1);
257
-
258
- notification.show();
259
- };
260
-
261
- $.notyRenderer.createModalFor = function(notification) {
262
- if ($('.noty_modal').length == 0)
263
- $('<div/>').addClass('noty_modal').data('noty_modal_count', 0).css(notification.options.theme.modal.css).prependTo($('body')).fadeIn('fast');
264
- };
265
-
266
- $.notyRenderer.getLayoutCountFor = function(notification) {
267
- return $(notification.options.layout.container.selector).data('noty_layout_count') || 0;
268
- };
269
-
270
- $.notyRenderer.setLayoutCountFor = function(notification, arg) {
271
- return $(notification.options.layout.container.selector).data('noty_layout_count', $.notyRenderer.getLayoutCountFor(notification) + arg);
272
- };
273
-
274
- $.notyRenderer.getModalCount = function() {
275
- return $('.noty_modal').data('noty_modal_count') || 0;
276
- };
277
-
278
- $.notyRenderer.setModalCount = function(arg) {
279
- return $('.noty_modal').data('noty_modal_count', $.notyRenderer.getModalCount() + arg);
280
- };
281
-
282
- // This is for custom container
283
- $.fn.noty = function(options) {
284
- options.custom = $(this);
285
- return $.notyRenderer.init(options);
286
- };
287
-
288
- $.noty = {};
289
- $.noty.queue = [];
290
- $.noty.ontap = true;
291
- $.noty.layouts = {};
292
- $.noty.themes = {};
293
- $.noty.returns = 'object';
294
- $.noty.store = {};
295
-
296
- $.noty.get = function(id) {
297
- return $.noty.store.hasOwnProperty(id) ? $.noty.store[id] : false;
298
- };
299
-
300
- $.noty.close = function(id) {
301
- return $.noty.get(id) ? $.noty.get(id).close() : false;
302
- };
303
-
304
- $.noty.setText = function(id, text) {
305
- return $.noty.get(id) ? $.noty.get(id).setText(text) : false;
306
- };
307
-
308
- $.noty.setType = function(id, type) {
309
- return $.noty.get(id) ? $.noty.get(id).setType(type) : false;
310
- };
311
-
312
- $.noty.clearQueue = function() {
313
- $.noty.queue = [];
314
- };
315
-
316
- $.noty.closeAll = function() {
317
- $.noty.clearQueue();
318
- $.each($.noty.store, function(id, noty) {
319
- noty.close();
320
- });
321
- };
322
-
323
- var windowAlert = window.alert;
324
-
325
- $.noty.consumeAlert = function(options) {
326
- window.alert = function(text) {
327
- if (options)
328
- options.text = text;
329
- else
330
- options = {text:text};
331
-
332
- $.notyRenderer.init(options);
333
- };
334
- };
335
-
336
- $.noty.stopConsumeAlert = function(){
337
- window.alert = windowAlert;
338
- };
339
-
340
- $.noty.defaults = {
341
- layout: 'top',
342
- theme: 'default',
343
- type: 'alert',
344
- text: '',
345
- dismissQueue: true,
346
- template: '<div class="noty_message"><span class="noty_text"></span><div class="noty_close"></div></div>',
347
- animation: {
348
- open: {height: 'toggle'},
349
- close: {height: 'toggle'},
350
- easing: 'swing',
351
- speed: 500
352
- },
353
- timeout: false,
354
- force: false,
355
- modal: false,
356
- closeWith: ['click'],
357
- callback: {
358
- onShow: function() {},
359
- afterShow: function() {},
360
- onClose: function() {},
361
- afterClose: function() {}
362
- },
363
- buttons: false
364
- };
365
-
366
- $(window).resize(function() {
367
- $.each($.noty.layouts, function(index, layout) {
368
- layout.container.style.apply($(layout.container.selector));
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
- // This is for BC - Will be deleted on v2.2.0
378
- var using_old = 0
379
- , old_to_new = {
380
- 'animateOpen': 'animation.open',
381
- 'animateClose': 'animation.close',
382
- 'easing': 'animation.easing',
383
- 'speed': 'animation.speed',
384
- 'onShow': 'callback.onShow',
385
- 'onShown': 'callback.afterShow',
386
- 'onClose': 'callback.onClose',
387
- 'onClosed': 'callback.afterClose'
388
- }
389
-
390
- jQuery.each(options, function(key, value) {
391
- if (old_to_new[key]) {
392
- using_old++;
393
- var _new = old_to_new[key].split('.');
394
-
395
- if (!options[_new[0]]) options[_new[0]] = {};
396
-
397
- options[_new[0]][_new[1]] = (value) ? value : function() {};
398
- delete options[key];
399
- }
400
- });
401
-
402
- if (!options.closeWith) {
403
- options.closeWith = jQuery.noty.defaults.closeWith;
404
- }
405
-
406
- if (options.hasOwnProperty('closeButton')) {
407
- using_old++;
408
- if (options.closeButton) options.closeWith.push('button');
409
- delete options.closeButton;
410
- }
411
-
412
- if (options.hasOwnProperty('closeOnSelfClick')) {
413
- using_old++;
414
- if (options.closeOnSelfClick) options.closeWith.push('click');
415
- delete options.closeOnSelfClick;
416
- }
417
-
418
- if (options.hasOwnProperty('closeOnSelfOver')) {
419
- using_old++;
420
- if (options.closeOnSelfOver) options.closeWith.push('hover');
421
- delete options.closeOnSelfOver;
422
- }
423
-
424
- if (options.hasOwnProperty('custom')) {
425
- using_old++;
426
- if (options.custom.container != 'null') options.custom = options.custom.container;
427
- }
428
-
429
- if (options.hasOwnProperty('cssPrefix')) {
430
- using_old++;
431
- delete options.cssPrefix;
432
- }
433
-
434
- if (options.theme == 'noty_theme_default') {
435
- using_old++;
436
- options.theme = 'default';
437
- }
438
-
439
- if (!options.hasOwnProperty('dismissQueue')) {
440
- if (options.layout == 'topLeft'
441
- || options.layout == 'topRight'
442
- || options.layout == 'bottomLeft'
443
- || options.layout == 'bottomRight') {
444
- options.dismissQueue = true;
445
- } else {
446
- options.dismissQueue = false;
447
- }
448
- }
449
-
450
- if (options.buttons) {
451
- jQuery.each(options.buttons, function(i, button) {
452
- if (button.click) {
453
- using_old++;
454
- button.onClick = button.click;
455
- delete button.click;
456
- }
457
- if (button.type) {
458
- using_old++;
459
- button.addClass = button.type;
460
- delete button.type;
461
- }
462
- });
463
- }
464
-
465
- if (using_old) console.warn('You are using noty v2 with v1.x.x options. @deprecated until v2.2.0 - Please update your options.');
466
-
467
- // console.log(options);
468
- // End of the BC
469
-
470
- return jQuery.notyRenderer.init(options);
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.default = {
4
- name: 'default',
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').fadeIn(); },
82
- mouseleave: function() { $(this).find('.noty_close').fadeOut(); }
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.default.helpers.borderFix.apply(this); },
152
- onClose: function() { $.noty.themes.default.helpers.borderFix.apply(this); }
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.3.1
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-25 00:00:00.000000000 Z
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.3
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: