vue_crud 0.1.9.5 → 0.1.9.6

Sign up to get free protection for your applications and to get access to all the features.
Files changed (90) hide show
  1. checksums.yaml +4 -4
  2. data/lib/generators/vue_crud/example_generator.rb +12 -0
  3. data/lib/generators/vue_crud/install_generator.rb +1 -1
  4. data/lib/generators/vue_crud/pace_generator.rb +11 -0
  5. data/lib/generators/vue_crud/semantic_generator.rb +12 -0
  6. data/lib/generators/vue_crud/templates/assets/images/semantic-ui/flags.png +0 -0
  7. data/lib/generators/vue_crud/templates/assets/javascripts/pace.min.js +1 -0
  8. data/lib/generators/vue_crud/templates/assets/javascripts/semantic-ui/checkbox.js +831 -0
  9. data/lib/generators/vue_crud/templates/assets/javascripts/semantic-ui/dimmer.js +708 -0
  10. data/lib/generators/vue_crud/templates/assets/javascripts/semantic-ui/dropdown.js +3741 -0
  11. data/lib/generators/vue_crud/templates/assets/javascripts/semantic-ui/modal.js +913 -0
  12. data/lib/generators/vue_crud/templates/assets/javascripts/semantic-ui/site.js +487 -0
  13. data/lib/generators/vue_crud/templates/assets/javascripts/semantic-ui/transition.js +1089 -0
  14. data/lib/generators/vue_crud/templates/assets/javascripts/vue.js +7402 -0
  15. data/lib/generators/vue_crud/templates/assets/stylesheets/pace.min.css +1 -0
  16. data/lib/generators/vue_crud/templates/assets/stylesheets/semantic-ui/.DS_Store +0 -0
  17. data/lib/generators/vue_crud/templates/assets/stylesheets/semantic-ui/collections/.DS_Store +0 -0
  18. data/lib/generators/vue_crud/templates/assets/stylesheets/semantic-ui/collections/_all.scss +7 -0
  19. data/lib/generators/vue_crud/templates/assets/stylesheets/semantic-ui/collections/_breadcrumb.scss +124 -0
  20. data/lib/generators/vue_crud/templates/assets/stylesheets/semantic-ui/collections/_form.scss +1706 -0
  21. data/lib/generators/vue_crud/templates/assets/stylesheets/semantic-ui/collections/_grid.scss +84 -0
  22. data/lib/generators/vue_crud/templates/assets/stylesheets/semantic-ui/collections/_grid_bk.scss +2032 -0
  23. data/lib/generators/vue_crud/templates/assets/stylesheets/semantic-ui/collections/_menu.scss +2021 -0
  24. data/lib/generators/vue_crud/templates/assets/stylesheets/semantic-ui/collections/_message.scss +482 -0
  25. data/lib/generators/vue_crud/templates/assets/stylesheets/semantic-ui/collections/_mixins.scss +3 -0
  26. data/lib/generators/vue_crud/templates/assets/stylesheets/semantic-ui/collections/_table.scss +1108 -0
  27. data/lib/generators/vue_crud/templates/assets/stylesheets/semantic-ui/collections/mixins/.DS_Store +0 -0
  28. data/lib/generators/vue_crud/templates/assets/stylesheets/semantic-ui/collections/mixins/_clearfix.scss +1 -0
  29. data/lib/generators/vue_crud/templates/assets/stylesheets/semantic-ui/collections/mixins/_grid-framework.scss +1 -0
  30. data/lib/generators/vue_crud/templates/assets/stylesheets/semantic-ui/collections/mixins/_grid.scss +1 -0
  31. data/lib/generators/vue_crud/templates/assets/stylesheets/semantic-ui/elements/_all.scss +15 -0
  32. data/lib/generators/vue_crud/templates/assets/stylesheets/semantic-ui/elements/_button.scss +3470 -0
  33. data/lib/generators/vue_crud/templates/assets/stylesheets/semantic-ui/elements/_container.scss +148 -0
  34. data/lib/generators/vue_crud/templates/assets/stylesheets/semantic-ui/elements/_divider.scss +262 -0
  35. data/lib/generators/vue_crud/templates/assets/stylesheets/semantic-ui/elements/_flag.scss +1031 -0
  36. data/lib/generators/vue_crud/templates/assets/stylesheets/semantic-ui/elements/_header.scss +721 -0
  37. data/lib/generators/vue_crud/templates/assets/stylesheets/semantic-ui/elements/_icon.scss +3148 -0
  38. data/lib/generators/vue_crud/templates/assets/stylesheets/semantic-ui/elements/_image.scss +306 -0
  39. data/lib/generators/vue_crud/templates/assets/stylesheets/semantic-ui/elements/_input.scss +517 -0
  40. data/lib/generators/vue_crud/templates/assets/stylesheets/semantic-ui/elements/_label.scss +1314 -0
  41. data/lib/generators/vue_crud/templates/assets/stylesheets/semantic-ui/elements/_list.scss +951 -0
  42. data/lib/generators/vue_crud/templates/assets/stylesheets/semantic-ui/elements/_loader.scss +349 -0
  43. data/lib/generators/vue_crud/templates/assets/stylesheets/semantic-ui/elements/_rail.scss +152 -0
  44. data/lib/generators/vue_crud/templates/assets/stylesheets/semantic-ui/elements/_reveal.scss +307 -0
  45. data/lib/generators/vue_crud/templates/assets/stylesheets/semantic-ui/elements/_segment.scss +799 -0
  46. data/lib/generators/vue_crud/templates/assets/stylesheets/semantic-ui/elements/_step.scss +646 -0
  47. data/lib/generators/vue_crud/templates/assets/stylesheets/semantic-ui/globals/_all.scss +3 -0
  48. data/lib/generators/vue_crud/templates/assets/stylesheets/semantic-ui/globals/_reset.scss +424 -0
  49. data/lib/generators/vue_crud/templates/assets/stylesheets/semantic-ui/globals/_site.scss +163 -0
  50. data/lib/generators/vue_crud/templates/assets/stylesheets/semantic-ui/globals/_variables.scss +32 -0
  51. data/lib/generators/vue_crud/templates/assets/stylesheets/semantic-ui/modules/_accordion.scss +256 -0
  52. data/lib/generators/vue_crud/templates/assets/stylesheets/semantic-ui/modules/_all.scss +17 -0
  53. data/lib/generators/vue_crud/templates/assets/stylesheets/semantic-ui/modules/_checkbox.scss +627 -0
  54. data/lib/generators/vue_crud/templates/assets/stylesheets/semantic-ui/modules/_dimmer.scss +199 -0
  55. data/lib/generators/vue_crud/templates/assets/stylesheets/semantic-ui/modules/_dropdown.scss +1425 -0
  56. data/lib/generators/vue_crud/templates/assets/stylesheets/semantic-ui/modules/_embed.scss +167 -0
  57. data/lib/generators/vue_crud/templates/assets/stylesheets/semantic-ui/modules/_modal.scss +509 -0
  58. data/lib/generators/vue_crud/templates/assets/stylesheets/semantic-ui/modules/_nag.scss +147 -0
  59. data/lib/generators/vue_crud/templates/assets/stylesheets/semantic-ui/modules/_popup.scss +764 -0
  60. data/lib/generators/vue_crud/templates/assets/stylesheets/semantic-ui/modules/_progress.scss +516 -0
  61. data/lib/generators/vue_crud/templates/assets/stylesheets/semantic-ui/modules/_rating.scss +265 -0
  62. data/lib/generators/vue_crud/templates/assets/stylesheets/semantic-ui/modules/_search.scss +409 -0
  63. data/lib/generators/vue_crud/templates/assets/stylesheets/semantic-ui/modules/_shape.scss +157 -0
  64. data/lib/generators/vue_crud/templates/assets/stylesheets/semantic-ui/modules/_sidebar.scss +644 -0
  65. data/lib/generators/vue_crud/templates/assets/stylesheets/semantic-ui/modules/_sticky.scss +78 -0
  66. data/lib/generators/vue_crud/templates/assets/stylesheets/semantic-ui/modules/_tab.scss +91 -0
  67. data/lib/generators/vue_crud/templates/assets/stylesheets/semantic-ui/modules/_transition.scss +1981 -0
  68. data/lib/generators/vue_crud/templates/assets/stylesheets/semantic-ui/modules/_video.scss +125 -0
  69. data/lib/generators/vue_crud/templates/assets/stylesheets/semantic-ui/views/_ad.scss +276 -0
  70. data/lib/generators/vue_crud/templates/assets/stylesheets/semantic-ui/views/_all.scss +6 -0
  71. data/lib/generators/vue_crud/templates/assets/stylesheets/semantic-ui/views/_card.scss +685 -0
  72. data/lib/generators/vue_crud/templates/assets/stylesheets/semantic-ui/views/_comment.scss +270 -0
  73. data/lib/generators/vue_crud/templates/assets/stylesheets/semantic-ui/views/_feed.scss +300 -0
  74. data/lib/generators/vue_crud/templates/assets/stylesheets/semantic-ui/views/_item.scss +481 -0
  75. data/lib/generators/vue_crud/templates/assets/stylesheets/semantic-ui/views/_statistic.scss +583 -0
  76. data/lib/generators/vue_crud/templates/example/user.rb +10 -0
  77. data/lib/generators/vue_crud/templates/example/users/index.html.erb +154 -0
  78. data/lib/generators/vue_crud/templates/example/users/index.json.jbuilder +15 -0
  79. data/lib/generators/vue_crud/templates/example/users/show.json.jbuilder +11 -0
  80. data/lib/generators/vue_crud/templates/example/users_controller.rb +85 -0
  81. data/lib/generators/vue_crud/vuejs_generator.rb +10 -0
  82. data/lib/vue_crud/version.rb +1 -1
  83. data/vendor/assets/javascripts/vue_crud.js +24 -3
  84. data/vendor/assets/stylesheets/vue_crud.css +0 -2
  85. metadata +80 -6
  86. data/vue_crud-0.1.5.gem +0 -0
  87. data/vue_crud-0.1.6.gem +0 -0
  88. data/vue_crud-0.1.7.gem +0 -0
  89. data/vue_crud-0.1.8.gem +0 -0
  90. data/vue_crud-0.1.9.gem +0 -0
@@ -0,0 +1,913 @@
1
+ /*!
2
+ * # Semantic UI - Modal
3
+ * http://github.com/semantic-org/semantic-ui/
4
+ *
5
+ *
6
+ * Released under the MIT license
7
+ * http://opensource.org/licenses/MIT
8
+ *
9
+ */
10
+
11
+ ;(function ($, window, document, undefined) {
12
+
13
+ "use strict";
14
+
15
+ window = (typeof window != 'undefined' && window.Math == Math)
16
+ ? window
17
+ : (typeof self != 'undefined' && self.Math == Math)
18
+ ? self
19
+ : Function('return this')()
20
+ ;
21
+
22
+ $.fn.modal = function(parameters) {
23
+ var
24
+ $allModules = $(this),
25
+ $window = $(window),
26
+ $document = $(document),
27
+ $body = $('body'),
28
+
29
+ moduleSelector = $allModules.selector || '',
30
+
31
+ time = new Date().getTime(),
32
+ performance = [],
33
+
34
+ query = arguments[0],
35
+ methodInvoked = (typeof query == 'string'),
36
+ queryArguments = [].slice.call(arguments, 1),
37
+
38
+ requestAnimationFrame = window.requestAnimationFrame
39
+ || window.mozRequestAnimationFrame
40
+ || window.webkitRequestAnimationFrame
41
+ || window.msRequestAnimationFrame
42
+ || function(callback) { setTimeout(callback, 0); },
43
+
44
+ returnedValue
45
+ ;
46
+
47
+ $allModules
48
+ .each(function() {
49
+ var
50
+ settings = ( $.isPlainObject(parameters) )
51
+ ? $.extend(true, {}, $.fn.modal.settings, parameters)
52
+ : $.extend({}, $.fn.modal.settings),
53
+
54
+ selector = settings.selector,
55
+ className = settings.className,
56
+ namespace = settings.namespace,
57
+ error = settings.error,
58
+
59
+ eventNamespace = '.' + namespace,
60
+ moduleNamespace = 'module-' + namespace,
61
+
62
+ $module = $(this),
63
+ $context = $(settings.context),
64
+ $close = $module.find(selector.close),
65
+
66
+ $allModals,
67
+ $otherModals,
68
+ $focusedElement,
69
+ $dimmable,
70
+ $dimmer,
71
+
72
+ element = this,
73
+ instance = $module.data(moduleNamespace),
74
+
75
+ elementEventNamespace,
76
+ id,
77
+ observer,
78
+ module
79
+ ;
80
+ module = {
81
+
82
+ initialize: function() {
83
+ module.verbose('Initializing dimmer', $context);
84
+
85
+ module.create.id();
86
+ module.create.dimmer();
87
+ module.refreshModals();
88
+
89
+ module.bind.events();
90
+ if(settings.observeChanges) {
91
+ module.observeChanges();
92
+ }
93
+ module.instantiate();
94
+ },
95
+
96
+ instantiate: function() {
97
+ module.verbose('Storing instance of modal');
98
+ instance = module;
99
+ $module
100
+ .data(moduleNamespace, instance)
101
+ ;
102
+ },
103
+
104
+ create: {
105
+ dimmer: function() {
106
+ var
107
+ defaultSettings = {
108
+ debug : settings.debug,
109
+ dimmerName : 'modals',
110
+ duration : {
111
+ show : settings.duration,
112
+ hide : settings.duration
113
+ }
114
+ },
115
+ dimmerSettings = $.extend(true, defaultSettings, settings.dimmerSettings)
116
+ ;
117
+ if(settings.inverted) {
118
+ dimmerSettings.variation = (dimmerSettings.variation !== undefined)
119
+ ? dimmerSettings.variation + ' inverted'
120
+ : 'inverted'
121
+ ;
122
+ }
123
+ if($.fn.dimmer === undefined) {
124
+ module.error(error.dimmer);
125
+ return;
126
+ }
127
+ module.debug('Creating dimmer with settings', dimmerSettings);
128
+ $dimmable = $context.dimmer(dimmerSettings);
129
+ if(settings.detachable) {
130
+ module.verbose('Modal is detachable, moving content into dimmer');
131
+ $dimmable.dimmer('add content', $module);
132
+ }
133
+ else {
134
+ module.set.undetached();
135
+ }
136
+ if(settings.blurring) {
137
+ $dimmable.addClass(className.blurring);
138
+ }
139
+ $dimmer = $dimmable.dimmer('get dimmer');
140
+ },
141
+ id: function() {
142
+ id = (Math.random().toString(16) + '000000000').substr(2,8);
143
+ elementEventNamespace = '.' + id;
144
+ module.verbose('Creating unique id for element', id);
145
+ }
146
+ },
147
+
148
+ destroy: function() {
149
+ module.verbose('Destroying previous modal');
150
+ $module
151
+ .removeData(moduleNamespace)
152
+ .off(eventNamespace)
153
+ ;
154
+ $window.off(elementEventNamespace);
155
+ $dimmer.off(elementEventNamespace);
156
+ $close.off(eventNamespace);
157
+ $context.dimmer('destroy');
158
+ },
159
+
160
+ observeChanges: function() {
161
+ if('MutationObserver' in window) {
162
+ observer = new MutationObserver(function(mutations) {
163
+ module.debug('DOM tree modified, refreshing');
164
+ module.refresh();
165
+ });
166
+ observer.observe(element, {
167
+ childList : true,
168
+ subtree : true
169
+ });
170
+ module.debug('Setting up mutation observer', observer);
171
+ }
172
+ },
173
+
174
+ refresh: function() {
175
+ module.remove.scrolling();
176
+ module.cacheSizes();
177
+ module.set.screenHeight();
178
+ module.set.type();
179
+ module.set.position();
180
+ },
181
+
182
+ refreshModals: function() {
183
+ $otherModals = $module.siblings(selector.modal);
184
+ $allModals = $otherModals.add($module);
185
+ },
186
+
187
+ attachEvents: function(selector, event) {
188
+ var
189
+ $toggle = $(selector)
190
+ ;
191
+ event = $.isFunction(module[event])
192
+ ? module[event]
193
+ : module.toggle
194
+ ;
195
+ if($toggle.length > 0) {
196
+ module.debug('Attaching modal events to element', selector, event);
197
+ $toggle
198
+ .off(eventNamespace)
199
+ .on('click' + eventNamespace, event)
200
+ ;
201
+ }
202
+ else {
203
+ module.error(error.notFound, selector);
204
+ }
205
+ },
206
+
207
+ bind: {
208
+ events: function() {
209
+ module.verbose('Attaching events');
210
+ $module
211
+ .on('click' + eventNamespace, selector.close, module.event.close)
212
+ .on('click' + eventNamespace, selector.approve, module.event.approve)
213
+ .on('click' + eventNamespace, selector.deny, module.event.deny)
214
+ ;
215
+ $window
216
+ .on('resize' + elementEventNamespace, module.event.resize)
217
+ ;
218
+ }
219
+ },
220
+
221
+ get: {
222
+ id: function() {
223
+ return (Math.random().toString(16) + '000000000').substr(2,8);
224
+ }
225
+ },
226
+
227
+ event: {
228
+ approve: function() {
229
+ if(settings.onApprove.call(element, $(this)) === false) {
230
+ module.verbose('Approve callback returned false cancelling hide');
231
+ return;
232
+ }
233
+ module.hide();
234
+ },
235
+ deny: function() {
236
+ if(settings.onDeny.call(element, $(this)) === false) {
237
+ module.verbose('Deny callback returned false cancelling hide');
238
+ return;
239
+ }
240
+ module.hide();
241
+ },
242
+ close: function() {
243
+ module.hide();
244
+ },
245
+ click: function(event) {
246
+ var
247
+ $target = $(event.target),
248
+ isInModal = ($target.closest(selector.modal).length > 0),
249
+ isInDOM = $.contains(document.documentElement, event.target)
250
+ ;
251
+ if(!isInModal && isInDOM) {
252
+ module.debug('Dimmer clicked, hiding all modals');
253
+ if( module.is.active() ) {
254
+ module.remove.clickaway();
255
+ if(settings.allowMultiple) {
256
+ module.hide();
257
+ }
258
+ else {
259
+ module.hideAll();
260
+ }
261
+ }
262
+ }
263
+ },
264
+ debounce: function(method, delay) {
265
+ clearTimeout(module.timer);
266
+ module.timer = setTimeout(method, delay);
267
+ },
268
+ keyboard: function(event) {
269
+ var
270
+ keyCode = event.which,
271
+ escapeKey = 27
272
+ ;
273
+ if(keyCode == escapeKey) {
274
+ if(settings.closable) {
275
+ module.debug('Escape key pressed hiding modal');
276
+ module.hide();
277
+ }
278
+ else {
279
+ module.debug('Escape key pressed, but closable is set to false');
280
+ }
281
+ event.preventDefault();
282
+ }
283
+ },
284
+ resize: function() {
285
+ if( $dimmable.dimmer('is active') ) {
286
+ requestAnimationFrame(module.refresh);
287
+ }
288
+ }
289
+ },
290
+
291
+ toggle: function() {
292
+ if( module.is.active() || module.is.animating() ) {
293
+ module.hide();
294
+ }
295
+ else {
296
+ module.show();
297
+ }
298
+ },
299
+
300
+ show: function(callback) {
301
+ callback = $.isFunction(callback)
302
+ ? callback
303
+ : function(){}
304
+ ;
305
+ module.refreshModals();
306
+ module.showModal(callback);
307
+ },
308
+
309
+ hide: function(callback) {
310
+ callback = $.isFunction(callback)
311
+ ? callback
312
+ : function(){}
313
+ ;
314
+ module.refreshModals();
315
+ module.hideModal(callback);
316
+ },
317
+
318
+ showModal: function(callback) {
319
+ callback = $.isFunction(callback)
320
+ ? callback
321
+ : function(){}
322
+ ;
323
+ if( module.is.animating() || !module.is.active() ) {
324
+
325
+ module.showDimmer();
326
+ module.cacheSizes();
327
+ module.set.position();
328
+ module.set.screenHeight();
329
+ module.set.type();
330
+ module.set.clickaway();
331
+
332
+ if( !settings.allowMultiple && module.others.active() ) {
333
+ module.hideOthers(module.showModal);
334
+ }
335
+ else {
336
+ settings.onShow.call(element);
337
+ if(settings.transition && $.fn.transition !== undefined && $module.transition('is supported')) {
338
+ module.debug('Showing modal with css animations');
339
+ $module
340
+ .transition({
341
+ debug : settings.debug,
342
+ animation : settings.transition + ' in',
343
+ queue : settings.queue,
344
+ duration : settings.duration,
345
+ useFailSafe : true,
346
+ onComplete : function() {
347
+ settings.onVisible.apply(element);
348
+ if(settings.keyboardShortcuts) {
349
+ module.add.keyboardShortcuts();
350
+ }
351
+ module.save.focus();
352
+ module.set.active();
353
+ if(settings.autofocus) {
354
+ module.set.autofocus();
355
+ }
356
+ callback();
357
+ }
358
+ })
359
+ ;
360
+ }
361
+ else {
362
+ module.error(error.noTransition);
363
+ }
364
+ }
365
+ }
366
+ else {
367
+ module.debug('Modal is already visible');
368
+ }
369
+ },
370
+
371
+ hideModal: function(callback, keepDimmed) {
372
+ callback = $.isFunction(callback)
373
+ ? callback
374
+ : function(){}
375
+ ;
376
+ module.debug('Hiding modal');
377
+ if(settings.onHide.call(element, $(this)) === false) {
378
+ module.verbose('Hide callback returned false cancelling hide');
379
+ return;
380
+ }
381
+
382
+ if( module.is.animating() || module.is.active() ) {
383
+ if(settings.transition && $.fn.transition !== undefined && $module.transition('is supported')) {
384
+ module.remove.active();
385
+ $module
386
+ .transition({
387
+ debug : settings.debug,
388
+ animation : settings.transition + ' out',
389
+ queue : settings.queue,
390
+ duration : settings.duration,
391
+ useFailSafe : true,
392
+ onStart : function() {
393
+ if(!module.others.active() && !keepDimmed) {
394
+ module.hideDimmer();
395
+ }
396
+ if(settings.keyboardShortcuts) {
397
+ module.remove.keyboardShortcuts();
398
+ }
399
+ },
400
+ onComplete : function() {
401
+ settings.onHidden.call(element);
402
+ module.restore.focus();
403
+ callback();
404
+ }
405
+ })
406
+ ;
407
+ }
408
+ else {
409
+ module.error(error.noTransition);
410
+ }
411
+ }
412
+ },
413
+
414
+ showDimmer: function() {
415
+ if($dimmable.dimmer('is animating') || !$dimmable.dimmer('is active') ) {
416
+ module.debug('Showing dimmer');
417
+ $dimmable.dimmer('show');
418
+ }
419
+ else {
420
+ module.debug('Dimmer already visible');
421
+ }
422
+ },
423
+
424
+ hideDimmer: function() {
425
+ if( $dimmable.dimmer('is animating') || ($dimmable.dimmer('is active')) ) {
426
+ $dimmable.dimmer('hide', function() {
427
+ module.remove.clickaway();
428
+ module.remove.screenHeight();
429
+ });
430
+ }
431
+ else {
432
+ module.debug('Dimmer is not visible cannot hide');
433
+ return;
434
+ }
435
+ },
436
+
437
+ hideAll: function(callback) {
438
+ var
439
+ $visibleModals = $allModals.filter('.' + className.active + ', .' + className.animating)
440
+ ;
441
+ callback = $.isFunction(callback)
442
+ ? callback
443
+ : function(){}
444
+ ;
445
+ if( $visibleModals.length > 0 ) {
446
+ module.debug('Hiding all visible modals');
447
+ module.hideDimmer();
448
+ $visibleModals
449
+ .modal('hide modal', callback)
450
+ ;
451
+ }
452
+ },
453
+
454
+ hideOthers: function(callback) {
455
+ var
456
+ $visibleModals = $otherModals.filter('.' + className.active + ', .' + className.animating)
457
+ ;
458
+ callback = $.isFunction(callback)
459
+ ? callback
460
+ : function(){}
461
+ ;
462
+ if( $visibleModals.length > 0 ) {
463
+ module.debug('Hiding other modals', $otherModals);
464
+ $visibleModals
465
+ .modal('hide modal', callback, true)
466
+ ;
467
+ }
468
+ },
469
+
470
+ others: {
471
+ active: function() {
472
+ return ($otherModals.filter('.' + className.active).length > 0);
473
+ },
474
+ animating: function() {
475
+ return ($otherModals.filter('.' + className.animating).length > 0);
476
+ }
477
+ },
478
+
479
+
480
+ add: {
481
+ keyboardShortcuts: function() {
482
+ module.verbose('Adding keyboard shortcuts');
483
+ $document
484
+ .on('keyup' + eventNamespace, module.event.keyboard)
485
+ ;
486
+ }
487
+ },
488
+
489
+ save: {
490
+ focus: function() {
491
+ $focusedElement = $(document.activeElement).blur();
492
+ }
493
+ },
494
+
495
+ restore: {
496
+ focus: function() {
497
+ if($focusedElement && $focusedElement.length > 0) {
498
+ $focusedElement.focus();
499
+ }
500
+ }
501
+ },
502
+
503
+ remove: {
504
+ active: function() {
505
+ $module.removeClass(className.active);
506
+ },
507
+ clickaway: function() {
508
+ if(settings.closable) {
509
+ $dimmer
510
+ .off('click' + elementEventNamespace)
511
+ ;
512
+ }
513
+ },
514
+ bodyStyle: function() {
515
+ if($body.attr('style') === '') {
516
+ module.verbose('Removing style attribute');
517
+ $body.removeAttr('style');
518
+ }
519
+ },
520
+ screenHeight: function() {
521
+ module.debug('Removing page height');
522
+ $body
523
+ .css('height', '')
524
+ ;
525
+ },
526
+ keyboardShortcuts: function() {
527
+ module.verbose('Removing keyboard shortcuts');
528
+ $document
529
+ .off('keyup' + eventNamespace)
530
+ ;
531
+ },
532
+ scrolling: function() {
533
+ $dimmable.removeClass(className.scrolling);
534
+ $module.removeClass(className.scrolling);
535
+ }
536
+ },
537
+
538
+ cacheSizes: function() {
539
+ var
540
+ modalHeight = $module.outerHeight()
541
+ ;
542
+ if(module.cache === undefined || modalHeight !== 0) {
543
+ module.cache = {
544
+ pageHeight : $(document).outerHeight(),
545
+ height : modalHeight + settings.offset,
546
+ contextHeight : (settings.context == 'body')
547
+ ? $(window).height()
548
+ : $dimmable.height()
549
+ };
550
+ }
551
+ module.debug('Caching modal and container sizes', module.cache);
552
+ },
553
+
554
+ can: {
555
+ fit: function() {
556
+ return ( ( module.cache.height + (settings.padding * 2) ) < module.cache.contextHeight);
557
+ }
558
+ },
559
+
560
+ is: {
561
+ active: function() {
562
+ return $module.hasClass(className.active);
563
+ },
564
+ animating: function() {
565
+ return $module.transition('is supported')
566
+ ? $module.transition('is animating')
567
+ : $module.is(':visible')
568
+ ;
569
+ },
570
+ scrolling: function() {
571
+ return $dimmable.hasClass(className.scrolling);
572
+ },
573
+ modernBrowser: function() {
574
+ // appName for IE11 reports 'Netscape' can no longer use
575
+ return !(window.ActiveXObject || "ActiveXObject" in window);
576
+ }
577
+ },
578
+
579
+ set: {
580
+ autofocus: function() {
581
+ var
582
+ $inputs = $module.find('[tabindex], :input').filter(':visible'),
583
+ $autofocus = $inputs.filter('[autofocus]'),
584
+ $input = ($autofocus.length > 0)
585
+ ? $autofocus.first()
586
+ : $inputs.first()
587
+ ;
588
+ if($input.length > 0) {
589
+ $input.focus();
590
+ }
591
+ },
592
+ clickaway: function() {
593
+ if(settings.closable) {
594
+ $dimmer
595
+ .on('click' + elementEventNamespace, module.event.click)
596
+ ;
597
+ }
598
+ },
599
+ screenHeight: function() {
600
+ if( module.can.fit() ) {
601
+ $body.css('height', '');
602
+ }
603
+ else {
604
+ module.debug('Modal is taller than page content, resizing page height');
605
+ $body
606
+ .css('height', module.cache.height + (settings.padding * 2) )
607
+ ;
608
+ }
609
+ },
610
+ active: function() {
611
+ $module.addClass(className.active);
612
+ },
613
+ scrolling: function() {
614
+ $dimmable.addClass(className.scrolling);
615
+ $module.addClass(className.scrolling);
616
+ },
617
+ type: function() {
618
+ if(module.can.fit()) {
619
+ module.verbose('Modal fits on screen');
620
+ if(!module.others.active() && !module.others.animating()) {
621
+ module.remove.scrolling();
622
+ }
623
+ }
624
+ else {
625
+ module.verbose('Modal cannot fit on screen setting to scrolling');
626
+ module.set.scrolling();
627
+ }
628
+ },
629
+ position: function() {
630
+ module.verbose('Centering modal on page', module.cache);
631
+ if(module.can.fit()) {
632
+ $module
633
+ .css({
634
+ top: '',
635
+ marginTop: -(module.cache.height / 2)
636
+ })
637
+ ;
638
+ }
639
+ else {
640
+ $module
641
+ .css({
642
+ marginTop : '',
643
+ top : $document.scrollTop()
644
+ })
645
+ ;
646
+ }
647
+ },
648
+ undetached: function() {
649
+ $dimmable.addClass(className.undetached);
650
+ }
651
+ },
652
+
653
+ setting: function(name, value) {
654
+ module.debug('Changing setting', name, value);
655
+ if( $.isPlainObject(name) ) {
656
+ $.extend(true, settings, name);
657
+ }
658
+ else if(value !== undefined) {
659
+ if($.isPlainObject(settings[name])) {
660
+ $.extend(true, settings[name], value);
661
+ }
662
+ else {
663
+ settings[name] = value;
664
+ }
665
+ }
666
+ else {
667
+ return settings[name];
668
+ }
669
+ },
670
+ internal: function(name, value) {
671
+ if( $.isPlainObject(name) ) {
672
+ $.extend(true, module, name);
673
+ }
674
+ else if(value !== undefined) {
675
+ module[name] = value;
676
+ }
677
+ else {
678
+ return module[name];
679
+ }
680
+ },
681
+ debug: function() {
682
+ if(!settings.silent && settings.debug) {
683
+ if(settings.performance) {
684
+ module.performance.log(arguments);
685
+ }
686
+ else {
687
+ module.debug = Function.prototype.bind.call(console.info, console, settings.name + ':');
688
+ module.debug.apply(console, arguments);
689
+ }
690
+ }
691
+ },
692
+ verbose: function() {
693
+ if(!settings.silent && settings.verbose && settings.debug) {
694
+ if(settings.performance) {
695
+ module.performance.log(arguments);
696
+ }
697
+ else {
698
+ module.verbose = Function.prototype.bind.call(console.info, console, settings.name + ':');
699
+ module.verbose.apply(console, arguments);
700
+ }
701
+ }
702
+ },
703
+ error: function() {
704
+ if(!settings.silent) {
705
+ module.error = Function.prototype.bind.call(console.error, console, settings.name + ':');
706
+ module.error.apply(console, arguments);
707
+ }
708
+ },
709
+ performance: {
710
+ log: function(message) {
711
+ var
712
+ currentTime,
713
+ executionTime,
714
+ previousTime
715
+ ;
716
+ if(settings.performance) {
717
+ currentTime = new Date().getTime();
718
+ previousTime = time || currentTime;
719
+ executionTime = currentTime - previousTime;
720
+ time = currentTime;
721
+ performance.push({
722
+ 'Name' : message[0],
723
+ 'Arguments' : [].slice.call(message, 1) || '',
724
+ 'Element' : element,
725
+ 'Execution Time' : executionTime
726
+ });
727
+ }
728
+ clearTimeout(module.performance.timer);
729
+ module.performance.timer = setTimeout(module.performance.display, 500);
730
+ },
731
+ display: function() {
732
+ var
733
+ title = settings.name + ':',
734
+ totalTime = 0
735
+ ;
736
+ time = false;
737
+ clearTimeout(module.performance.timer);
738
+ $.each(performance, function(index, data) {
739
+ totalTime += data['Execution Time'];
740
+ });
741
+ title += ' ' + totalTime + 'ms';
742
+ if(moduleSelector) {
743
+ title += ' \'' + moduleSelector + '\'';
744
+ }
745
+ if( (console.group !== undefined || console.table !== undefined) && performance.length > 0) {
746
+ console.groupCollapsed(title);
747
+ if(console.table) {
748
+ console.table(performance);
749
+ }
750
+ else {
751
+ $.each(performance, function(index, data) {
752
+ console.log(data['Name'] + ': ' + data['Execution Time']+'ms');
753
+ });
754
+ }
755
+ console.groupEnd();
756
+ }
757
+ performance = [];
758
+ }
759
+ },
760
+ invoke: function(query, passedArguments, context) {
761
+ var
762
+ object = instance,
763
+ maxDepth,
764
+ found,
765
+ response
766
+ ;
767
+ passedArguments = passedArguments || queryArguments;
768
+ context = element || context;
769
+ if(typeof query == 'string' && object !== undefined) {
770
+ query = query.split(/[\. ]/);
771
+ maxDepth = query.length - 1;
772
+ $.each(query, function(depth, value) {
773
+ var camelCaseValue = (depth != maxDepth)
774
+ ? value + query[depth + 1].charAt(0).toUpperCase() + query[depth + 1].slice(1)
775
+ : query
776
+ ;
777
+ if( $.isPlainObject( object[camelCaseValue] ) && (depth != maxDepth) ) {
778
+ object = object[camelCaseValue];
779
+ }
780
+ else if( object[camelCaseValue] !== undefined ) {
781
+ found = object[camelCaseValue];
782
+ return false;
783
+ }
784
+ else if( $.isPlainObject( object[value] ) && (depth != maxDepth) ) {
785
+ object = object[value];
786
+ }
787
+ else if( object[value] !== undefined ) {
788
+ found = object[value];
789
+ return false;
790
+ }
791
+ else {
792
+ return false;
793
+ }
794
+ });
795
+ }
796
+ if ( $.isFunction( found ) ) {
797
+ response = found.apply(context, passedArguments);
798
+ }
799
+ else if(found !== undefined) {
800
+ response = found;
801
+ }
802
+ if($.isArray(returnedValue)) {
803
+ returnedValue.push(response);
804
+ }
805
+ else if(returnedValue !== undefined) {
806
+ returnedValue = [returnedValue, response];
807
+ }
808
+ else if(response !== undefined) {
809
+ returnedValue = response;
810
+ }
811
+ return found;
812
+ }
813
+ };
814
+
815
+ if(methodInvoked) {
816
+ if(instance === undefined) {
817
+ module.initialize();
818
+ }
819
+ module.invoke(query);
820
+ }
821
+ else {
822
+ if(instance !== undefined) {
823
+ instance.invoke('destroy');
824
+ }
825
+ module.initialize();
826
+ }
827
+ })
828
+ ;
829
+
830
+ return (returnedValue !== undefined)
831
+ ? returnedValue
832
+ : this
833
+ ;
834
+ };
835
+
836
+ $.fn.modal.settings = {
837
+
838
+ name : 'Modal',
839
+ namespace : 'modal',
840
+
841
+ silent : false,
842
+ debug : false,
843
+ verbose : false,
844
+ performance : true,
845
+
846
+ observeChanges : false,
847
+
848
+ allowMultiple : false,
849
+ detachable : true,
850
+ closable : true,
851
+ autofocus : true,
852
+
853
+ inverted : false,
854
+ blurring : false,
855
+
856
+ dimmerSettings : {
857
+ closable : false,
858
+ useCSS : true
859
+ },
860
+
861
+ // whether to use keyboard shortcuts
862
+ keyboardShortcuts: true,
863
+
864
+ context : 'body',
865
+
866
+ queue : false,
867
+ duration : 500,
868
+ offset : 0,
869
+ transition : 'scale',
870
+
871
+ // padding with edge of page
872
+ padding : 50,
873
+
874
+ // called before show animation
875
+ onShow : function(){},
876
+
877
+ // called after show animation
878
+ onVisible : function(){},
879
+
880
+ // called before hide animation
881
+ onHide : function(){ return true; },
882
+
883
+ // called after hide animation
884
+ onHidden : function(){},
885
+
886
+ // called after approve selector match
887
+ onApprove : function(){ return true; },
888
+
889
+ // called after deny selector match
890
+ onDeny : function(){ return true; },
891
+
892
+ selector : {
893
+ close : '> .close',
894
+ approve : '.actions .positive, .actions .approve, .actions .ok',
895
+ deny : '.actions .negative, .actions .deny, .actions .cancel',
896
+ modal : '.ui.modal'
897
+ },
898
+ error : {
899
+ dimmer : 'UI Dimmer, a required component is not included in this page',
900
+ method : 'The method you called is not defined.',
901
+ notFound : 'The element you specified could not be found'
902
+ },
903
+ className : {
904
+ active : 'active',
905
+ animating : 'animating',
906
+ blurring : 'blurring',
907
+ scrolling : 'scrolling',
908
+ undetached : 'undetached'
909
+ }
910
+ };
911
+
912
+
913
+ })( jQuery, window, document );