h2ocube_rails_assets 0.0.4 → 0.0.5

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.
Files changed (39) hide show
  1. data/h2ocube_rails_assets.gemspec +1 -1
  2. data/vendor/assets/javascripts/jquery.fileupload.js +1 -1
  3. data/vendor/assets/javascripts/jquery.ui.js +2 -14914
  4. data/vendor/assets/javascripts/jquery.ui/jquery-ui.custom.js +14879 -0
  5. data/vendor/assets/javascripts/jquery.ui/jquery.ui.accordion.js +731 -0
  6. data/vendor/assets/javascripts/jquery.ui/jquery.ui.autocomplete.js +602 -0
  7. data/vendor/assets/javascripts/jquery.ui/jquery.ui.button.js +418 -0
  8. data/vendor/assets/javascripts/jquery.ui/jquery.ui.core.js +356 -0
  9. data/vendor/assets/javascripts/jquery.ui/jquery.ui.datepicker.js +1846 -0
  10. data/vendor/assets/javascripts/jquery.ui/jquery.ui.dialog.js +858 -0
  11. data/vendor/assets/javascripts/jquery.ui/jquery.ui.draggable.js +836 -0
  12. data/vendor/assets/javascripts/jquery.ui/jquery.ui.droppable.js +294 -0
  13. data/vendor/assets/javascripts/jquery.ui/jquery.ui.effect-blind.js +82 -0
  14. data/vendor/assets/javascripts/jquery.ui/jquery.ui.effect-bounce.js +113 -0
  15. data/vendor/assets/javascripts/jquery.ui/jquery.ui.effect-clip.js +67 -0
  16. data/vendor/assets/javascripts/jquery.ui/jquery.ui.effect-drop.js +65 -0
  17. data/vendor/assets/javascripts/jquery.ui/jquery.ui.effect-explode.js +97 -0
  18. data/vendor/assets/javascripts/jquery.ui/jquery.ui.effect-fade.js +30 -0
  19. data/vendor/assets/javascripts/jquery.ui/jquery.ui.effect-fold.js +76 -0
  20. data/vendor/assets/javascripts/jquery.ui/jquery.ui.effect-highlight.js +50 -0
  21. data/vendor/assets/javascripts/jquery.ui/jquery.ui.effect-pulsate.js +63 -0
  22. data/vendor/assets/javascripts/jquery.ui/jquery.ui.effect-scale.js +318 -0
  23. data/vendor/assets/javascripts/jquery.ui/jquery.ui.effect-shake.js +74 -0
  24. data/vendor/assets/javascripts/jquery.ui/jquery.ui.effect-slide.js +64 -0
  25. data/vendor/assets/javascripts/jquery.ui/jquery.ui.effect-transfer.js +47 -0
  26. data/vendor/assets/javascripts/jquery.ui/jquery.ui.effect.js +1276 -0
  27. data/vendor/assets/javascripts/jquery.ui/jquery.ui.menu.js +610 -0
  28. data/vendor/assets/javascripts/jquery.ui/jquery.ui.mouse.js +169 -0
  29. data/vendor/assets/javascripts/jquery.ui/jquery.ui.position.js +517 -0
  30. data/vendor/assets/javascripts/jquery.ui/jquery.ui.progressbar.js +105 -0
  31. data/vendor/assets/javascripts/jquery.ui/jquery.ui.resizable.js +801 -0
  32. data/vendor/assets/javascripts/jquery.ui/jquery.ui.selectable.js +261 -0
  33. data/vendor/assets/javascripts/jquery.ui/jquery.ui.slider.js +644 -0
  34. data/vendor/assets/javascripts/jquery.ui/jquery.ui.sortable.js +1096 -0
  35. data/vendor/assets/javascripts/jquery.ui/jquery.ui.spinner.js +478 -0
  36. data/vendor/assets/javascripts/jquery.ui/jquery.ui.tabs.js +1366 -0
  37. data/vendor/assets/javascripts/jquery.ui/jquery.ui.tooltip.js +398 -0
  38. data/vendor/assets/javascripts/{jquery.ui.widget.js → jquery.ui/jquery.ui.widget.js} +39 -34
  39. metadata +37 -9
@@ -0,0 +1,602 @@
1
+ /*!
2
+ * jQuery UI Autocomplete 1.9.2
3
+ * http://jqueryui.com
4
+ *
5
+ * Copyright 2012 jQuery Foundation and other contributors
6
+ * Released under the MIT license.
7
+ * http://jquery.org/license
8
+ *
9
+ * http://api.jqueryui.com/autocomplete/
10
+ *
11
+ * Depends:
12
+ * jquery.ui.core.js
13
+ * jquery.ui.widget.js
14
+ * jquery.ui.position.js
15
+ * jquery.ui.menu.js
16
+ */
17
+ (function( $, undefined ) {
18
+
19
+ // used to prevent race conditions with remote data sources
20
+ var requestIndex = 0;
21
+
22
+ $.widget( "ui.autocomplete", {
23
+ version: "1.9.2",
24
+ defaultElement: "<input>",
25
+ options: {
26
+ appendTo: "body",
27
+ autoFocus: false,
28
+ delay: 300,
29
+ minLength: 1,
30
+ position: {
31
+ my: "left top",
32
+ at: "left bottom",
33
+ collision: "none"
34
+ },
35
+ source: null,
36
+
37
+ // callbacks
38
+ change: null,
39
+ close: null,
40
+ focus: null,
41
+ open: null,
42
+ response: null,
43
+ search: null,
44
+ select: null
45
+ },
46
+
47
+ pending: 0,
48
+
49
+ _create: function() {
50
+ // Some browsers only repeat keydown events, not keypress events,
51
+ // so we use the suppressKeyPress flag to determine if we've already
52
+ // handled the keydown event. #7269
53
+ // Unfortunately the code for & in keypress is the same as the up arrow,
54
+ // so we use the suppressKeyPressRepeat flag to avoid handling keypress
55
+ // events when we know the keydown event was used to modify the
56
+ // search term. #7799
57
+ var suppressKeyPress, suppressKeyPressRepeat, suppressInput;
58
+
59
+ this.isMultiLine = this._isMultiLine();
60
+ this.valueMethod = this.element[ this.element.is( "input,textarea" ) ? "val" : "text" ];
61
+ this.isNewMenu = true;
62
+
63
+ this.element
64
+ .addClass( "ui-autocomplete-input" )
65
+ .attr( "autocomplete", "off" );
66
+
67
+ this._on( this.element, {
68
+ keydown: function( event ) {
69
+ if ( this.element.prop( "readOnly" ) ) {
70
+ suppressKeyPress = true;
71
+ suppressInput = true;
72
+ suppressKeyPressRepeat = true;
73
+ return;
74
+ }
75
+
76
+ suppressKeyPress = false;
77
+ suppressInput = false;
78
+ suppressKeyPressRepeat = false;
79
+ var keyCode = $.ui.keyCode;
80
+ switch( event.keyCode ) {
81
+ case keyCode.PAGE_UP:
82
+ suppressKeyPress = true;
83
+ this._move( "previousPage", event );
84
+ break;
85
+ case keyCode.PAGE_DOWN:
86
+ suppressKeyPress = true;
87
+ this._move( "nextPage", event );
88
+ break;
89
+ case keyCode.UP:
90
+ suppressKeyPress = true;
91
+ this._keyEvent( "previous", event );
92
+ break;
93
+ case keyCode.DOWN:
94
+ suppressKeyPress = true;
95
+ this._keyEvent( "next", event );
96
+ break;
97
+ case keyCode.ENTER:
98
+ case keyCode.NUMPAD_ENTER:
99
+ // when menu is open and has focus
100
+ if ( this.menu.active ) {
101
+ // #6055 - Opera still allows the keypress to occur
102
+ // which causes forms to submit
103
+ suppressKeyPress = true;
104
+ event.preventDefault();
105
+ this.menu.select( event );
106
+ }
107
+ break;
108
+ case keyCode.TAB:
109
+ if ( this.menu.active ) {
110
+ this.menu.select( event );
111
+ }
112
+ break;
113
+ case keyCode.ESCAPE:
114
+ if ( this.menu.element.is( ":visible" ) ) {
115
+ this._value( this.term );
116
+ this.close( event );
117
+ // Different browsers have different default behavior for escape
118
+ // Single press can mean undo or clear
119
+ // Double press in IE means clear the whole form
120
+ event.preventDefault();
121
+ }
122
+ break;
123
+ default:
124
+ suppressKeyPressRepeat = true;
125
+ // search timeout should be triggered before the input value is changed
126
+ this._searchTimeout( event );
127
+ break;
128
+ }
129
+ },
130
+ keypress: function( event ) {
131
+ if ( suppressKeyPress ) {
132
+ suppressKeyPress = false;
133
+ event.preventDefault();
134
+ return;
135
+ }
136
+ if ( suppressKeyPressRepeat ) {
137
+ return;
138
+ }
139
+
140
+ // replicate some key handlers to allow them to repeat in Firefox and Opera
141
+ var keyCode = $.ui.keyCode;
142
+ switch( event.keyCode ) {
143
+ case keyCode.PAGE_UP:
144
+ this._move( "previousPage", event );
145
+ break;
146
+ case keyCode.PAGE_DOWN:
147
+ this._move( "nextPage", event );
148
+ break;
149
+ case keyCode.UP:
150
+ this._keyEvent( "previous", event );
151
+ break;
152
+ case keyCode.DOWN:
153
+ this._keyEvent( "next", event );
154
+ break;
155
+ }
156
+ },
157
+ input: function( event ) {
158
+ if ( suppressInput ) {
159
+ suppressInput = false;
160
+ event.preventDefault();
161
+ return;
162
+ }
163
+ this._searchTimeout( event );
164
+ },
165
+ focus: function() {
166
+ this.selectedItem = null;
167
+ this.previous = this._value();
168
+ },
169
+ blur: function( event ) {
170
+ if ( this.cancelBlur ) {
171
+ delete this.cancelBlur;
172
+ return;
173
+ }
174
+
175
+ clearTimeout( this.searching );
176
+ this.close( event );
177
+ this._change( event );
178
+ }
179
+ });
180
+
181
+ this._initSource();
182
+ this.menu = $( "<ul>" )
183
+ .addClass( "ui-autocomplete" )
184
+ .appendTo( this.document.find( this.options.appendTo || "body" )[ 0 ] )
185
+ .menu({
186
+ // custom key handling for now
187
+ input: $(),
188
+ // disable ARIA support, the live region takes care of that
189
+ role: null
190
+ })
191
+ .zIndex( this.element.zIndex() + 1 )
192
+ .hide()
193
+ .data( "menu" );
194
+
195
+ this._on( this.menu.element, {
196
+ mousedown: function( event ) {
197
+ // prevent moving focus out of the text field
198
+ event.preventDefault();
199
+
200
+ // IE doesn't prevent moving focus even with event.preventDefault()
201
+ // so we set a flag to know when we should ignore the blur event
202
+ this.cancelBlur = true;
203
+ this._delay(function() {
204
+ delete this.cancelBlur;
205
+ });
206
+
207
+ // clicking on the scrollbar causes focus to shift to the body
208
+ // but we can't detect a mouseup or a click immediately afterward
209
+ // so we have to track the next mousedown and close the menu if
210
+ // the user clicks somewhere outside of the autocomplete
211
+ var menuElement = this.menu.element[ 0 ];
212
+ if ( !$( event.target ).closest( ".ui-menu-item" ).length ) {
213
+ this._delay(function() {
214
+ var that = this;
215
+ this.document.one( "mousedown", function( event ) {
216
+ if ( event.target !== that.element[ 0 ] &&
217
+ event.target !== menuElement &&
218
+ !$.contains( menuElement, event.target ) ) {
219
+ that.close();
220
+ }
221
+ });
222
+ });
223
+ }
224
+ },
225
+ menufocus: function( event, ui ) {
226
+ // #7024 - Prevent accidental activation of menu items in Firefox
227
+ if ( this.isNewMenu ) {
228
+ this.isNewMenu = false;
229
+ if ( event.originalEvent && /^mouse/.test( event.originalEvent.type ) ) {
230
+ this.menu.blur();
231
+
232
+ this.document.one( "mousemove", function() {
233
+ $( event.target ).trigger( event.originalEvent );
234
+ });
235
+
236
+ return;
237
+ }
238
+ }
239
+
240
+ // back compat for _renderItem using item.autocomplete, via #7810
241
+ // TODO remove the fallback, see #8156
242
+ var item = ui.item.data( "ui-autocomplete-item" ) || ui.item.data( "item.autocomplete" );
243
+ if ( false !== this._trigger( "focus", event, { item: item } ) ) {
244
+ // use value to match what will end up in the input, if it was a key event
245
+ if ( event.originalEvent && /^key/.test( event.originalEvent.type ) ) {
246
+ this._value( item.value );
247
+ }
248
+ } else {
249
+ // Normally the input is populated with the item's value as the
250
+ // menu is navigated, causing screen readers to notice a change and
251
+ // announce the item. Since the focus event was canceled, this doesn't
252
+ // happen, so we update the live region so that screen readers can
253
+ // still notice the change and announce it.
254
+ this.liveRegion.text( item.value );
255
+ }
256
+ },
257
+ menuselect: function( event, ui ) {
258
+ // back compat for _renderItem using item.autocomplete, via #7810
259
+ // TODO remove the fallback, see #8156
260
+ var item = ui.item.data( "ui-autocomplete-item" ) || ui.item.data( "item.autocomplete" ),
261
+ previous = this.previous;
262
+
263
+ // only trigger when focus was lost (click on menu)
264
+ if ( this.element[0] !== this.document[0].activeElement ) {
265
+ this.element.focus();
266
+ this.previous = previous;
267
+ // #6109 - IE triggers two focus events and the second
268
+ // is asynchronous, so we need to reset the previous
269
+ // term synchronously and asynchronously :-(
270
+ this._delay(function() {
271
+ this.previous = previous;
272
+ this.selectedItem = item;
273
+ });
274
+ }
275
+
276
+ if ( false !== this._trigger( "select", event, { item: item } ) ) {
277
+ this._value( item.value );
278
+ }
279
+ // reset the term after the select event
280
+ // this allows custom select handling to work properly
281
+ this.term = this._value();
282
+
283
+ this.close( event );
284
+ this.selectedItem = item;
285
+ }
286
+ });
287
+
288
+ this.liveRegion = $( "<span>", {
289
+ role: "status",
290
+ "aria-live": "polite"
291
+ })
292
+ .addClass( "ui-helper-hidden-accessible" )
293
+ .insertAfter( this.element );
294
+
295
+ if ( $.fn.bgiframe ) {
296
+ this.menu.element.bgiframe();
297
+ }
298
+
299
+ // turning off autocomplete prevents the browser from remembering the
300
+ // value when navigating through history, so we re-enable autocomplete
301
+ // if the page is unloaded before the widget is destroyed. #7790
302
+ this._on( this.window, {
303
+ beforeunload: function() {
304
+ this.element.removeAttr( "autocomplete" );
305
+ }
306
+ });
307
+ },
308
+
309
+ _destroy: function() {
310
+ clearTimeout( this.searching );
311
+ this.element
312
+ .removeClass( "ui-autocomplete-input" )
313
+ .removeAttr( "autocomplete" );
314
+ this.menu.element.remove();
315
+ this.liveRegion.remove();
316
+ },
317
+
318
+ _setOption: function( key, value ) {
319
+ this._super( key, value );
320
+ if ( key === "source" ) {
321
+ this._initSource();
322
+ }
323
+ if ( key === "appendTo" ) {
324
+ this.menu.element.appendTo( this.document.find( value || "body" )[0] );
325
+ }
326
+ if ( key === "disabled" && value && this.xhr ) {
327
+ this.xhr.abort();
328
+ }
329
+ },
330
+
331
+ _isMultiLine: function() {
332
+ // Textareas are always multi-line
333
+ if ( this.element.is( "textarea" ) ) {
334
+ return true;
335
+ }
336
+ // Inputs are always single-line, even if inside a contentEditable element
337
+ // IE also treats inputs as contentEditable
338
+ if ( this.element.is( "input" ) ) {
339
+ return false;
340
+ }
341
+ // All other element types are determined by whether or not they're contentEditable
342
+ return this.element.prop( "isContentEditable" );
343
+ },
344
+
345
+ _initSource: function() {
346
+ var array, url,
347
+ that = this;
348
+ if ( $.isArray(this.options.source) ) {
349
+ array = this.options.source;
350
+ this.source = function( request, response ) {
351
+ response( $.ui.autocomplete.filter( array, request.term ) );
352
+ };
353
+ } else if ( typeof this.options.source === "string" ) {
354
+ url = this.options.source;
355
+ this.source = function( request, response ) {
356
+ if ( that.xhr ) {
357
+ that.xhr.abort();
358
+ }
359
+ that.xhr = $.ajax({
360
+ url: url,
361
+ data: request,
362
+ dataType: "json",
363
+ success: function( data ) {
364
+ response( data );
365
+ },
366
+ error: function() {
367
+ response( [] );
368
+ }
369
+ });
370
+ };
371
+ } else {
372
+ this.source = this.options.source;
373
+ }
374
+ },
375
+
376
+ _searchTimeout: function( event ) {
377
+ clearTimeout( this.searching );
378
+ this.searching = this._delay(function() {
379
+ // only search if the value has changed
380
+ if ( this.term !== this._value() ) {
381
+ this.selectedItem = null;
382
+ this.search( null, event );
383
+ }
384
+ }, this.options.delay );
385
+ },
386
+
387
+ search: function( value, event ) {
388
+ value = value != null ? value : this._value();
389
+
390
+ // always save the actual value, not the one passed as an argument
391
+ this.term = this._value();
392
+
393
+ if ( value.length < this.options.minLength ) {
394
+ return this.close( event );
395
+ }
396
+
397
+ if ( this._trigger( "search", event ) === false ) {
398
+ return;
399
+ }
400
+
401
+ return this._search( value );
402
+ },
403
+
404
+ _search: function( value ) {
405
+ this.pending++;
406
+ this.element.addClass( "ui-autocomplete-loading" );
407
+ this.cancelSearch = false;
408
+
409
+ this.source( { term: value }, this._response() );
410
+ },
411
+
412
+ _response: function() {
413
+ var that = this,
414
+ index = ++requestIndex;
415
+
416
+ return function( content ) {
417
+ if ( index === requestIndex ) {
418
+ that.__response( content );
419
+ }
420
+
421
+ that.pending--;
422
+ if ( !that.pending ) {
423
+ that.element.removeClass( "ui-autocomplete-loading" );
424
+ }
425
+ };
426
+ },
427
+
428
+ __response: function( content ) {
429
+ if ( content ) {
430
+ content = this._normalize( content );
431
+ }
432
+ this._trigger( "response", null, { content: content } );
433
+ if ( !this.options.disabled && content && content.length && !this.cancelSearch ) {
434
+ this._suggest( content );
435
+ this._trigger( "open" );
436
+ } else {
437
+ // use ._close() instead of .close() so we don't cancel future searches
438
+ this._close();
439
+ }
440
+ },
441
+
442
+ close: function( event ) {
443
+ this.cancelSearch = true;
444
+ this._close( event );
445
+ },
446
+
447
+ _close: function( event ) {
448
+ if ( this.menu.element.is( ":visible" ) ) {
449
+ this.menu.element.hide();
450
+ this.menu.blur();
451
+ this.isNewMenu = true;
452
+ this._trigger( "close", event );
453
+ }
454
+ },
455
+
456
+ _change: function( event ) {
457
+ if ( this.previous !== this._value() ) {
458
+ this._trigger( "change", event, { item: this.selectedItem } );
459
+ }
460
+ },
461
+
462
+ _normalize: function( items ) {
463
+ // assume all items have the right format when the first item is complete
464
+ if ( items.length && items[0].label && items[0].value ) {
465
+ return items;
466
+ }
467
+ return $.map( items, function( item ) {
468
+ if ( typeof item === "string" ) {
469
+ return {
470
+ label: item,
471
+ value: item
472
+ };
473
+ }
474
+ return $.extend({
475
+ label: item.label || item.value,
476
+ value: item.value || item.label
477
+ }, item );
478
+ });
479
+ },
480
+
481
+ _suggest: function( items ) {
482
+ var ul = this.menu.element
483
+ .empty()
484
+ .zIndex( this.element.zIndex() + 1 );
485
+ this._renderMenu( ul, items );
486
+ this.menu.refresh();
487
+
488
+ // size and position menu
489
+ ul.show();
490
+ this._resizeMenu();
491
+ ul.position( $.extend({
492
+ of: this.element
493
+ }, this.options.position ));
494
+
495
+ if ( this.options.autoFocus ) {
496
+ this.menu.next();
497
+ }
498
+ },
499
+
500
+ _resizeMenu: function() {
501
+ var ul = this.menu.element;
502
+ ul.outerWidth( Math.max(
503
+ // Firefox wraps long text (possibly a rounding bug)
504
+ // so we add 1px to avoid the wrapping (#7513)
505
+ ul.width( "" ).outerWidth() + 1,
506
+ this.element.outerWidth()
507
+ ) );
508
+ },
509
+
510
+ _renderMenu: function( ul, items ) {
511
+ var that = this;
512
+ $.each( items, function( index, item ) {
513
+ that._renderItemData( ul, item );
514
+ });
515
+ },
516
+
517
+ _renderItemData: function( ul, item ) {
518
+ return this._renderItem( ul, item ).data( "ui-autocomplete-item", item );
519
+ },
520
+
521
+ _renderItem: function( ul, item ) {
522
+ return $( "<li>" )
523
+ .append( $( "<a>" ).text( item.label ) )
524
+ .appendTo( ul );
525
+ },
526
+
527
+ _move: function( direction, event ) {
528
+ if ( !this.menu.element.is( ":visible" ) ) {
529
+ this.search( null, event );
530
+ return;
531
+ }
532
+ if ( this.menu.isFirstItem() && /^previous/.test( direction ) ||
533
+ this.menu.isLastItem() && /^next/.test( direction ) ) {
534
+ this._value( this.term );
535
+ this.menu.blur();
536
+ return;
537
+ }
538
+ this.menu[ direction ]( event );
539
+ },
540
+
541
+ widget: function() {
542
+ return this.menu.element;
543
+ },
544
+
545
+ _value: function() {
546
+ return this.valueMethod.apply( this.element, arguments );
547
+ },
548
+
549
+ _keyEvent: function( keyEvent, event ) {
550
+ if ( !this.isMultiLine || this.menu.element.is( ":visible" ) ) {
551
+ this._move( keyEvent, event );
552
+
553
+ // prevents moving cursor to beginning/end of the text field in some browsers
554
+ event.preventDefault();
555
+ }
556
+ }
557
+ });
558
+
559
+ $.extend( $.ui.autocomplete, {
560
+ escapeRegex: function( value ) {
561
+ return value.replace(/[\-\[\]{}()*+?.,\\\^$|#\s]/g, "\\$&");
562
+ },
563
+ filter: function(array, term) {
564
+ var matcher = new RegExp( $.ui.autocomplete.escapeRegex(term), "i" );
565
+ return $.grep( array, function(value) {
566
+ return matcher.test( value.label || value.value || value );
567
+ });
568
+ }
569
+ });
570
+
571
+
572
+ // live region extension, adding a `messages` option
573
+ // NOTE: This is an experimental API. We are still investigating
574
+ // a full solution for string manipulation and internationalization.
575
+ $.widget( "ui.autocomplete", $.ui.autocomplete, {
576
+ options: {
577
+ messages: {
578
+ noResults: "No search results.",
579
+ results: function( amount ) {
580
+ return amount + ( amount > 1 ? " results are" : " result is" ) +
581
+ " available, use up and down arrow keys to navigate.";
582
+ }
583
+ }
584
+ },
585
+
586
+ __response: function( content ) {
587
+ var message;
588
+ this._superApply( arguments );
589
+ if ( this.options.disabled || this.cancelSearch ) {
590
+ return;
591
+ }
592
+ if ( content && content.length ) {
593
+ message = this.options.messages.results( content.length );
594
+ } else {
595
+ message = this.options.messages.noResults;
596
+ }
597
+ this.liveRegion.text( message );
598
+ }
599
+ });
600
+
601
+
602
+ }( jQuery ));