spree_core 1.3.1 → 1.3.2

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 (87) hide show
  1. data/LICENSE +1 -1
  2. data/app/assets/javascripts/admin/admin.js.erb +1 -1
  3. data/app/assets/javascripts/admin/shipping_methods.js.coffee +1 -1
  4. data/app/assets/javascripts/admin/spree_core.js +1 -0
  5. data/app/assets/javascripts/admin/variant_autocomplete.js.erb +1 -1
  6. data/app/assets/stylesheets/admin/globals/_variables.scss +7 -7
  7. data/app/assets/stylesheets/admin/plugins/font-awesome.scss +2 -2
  8. data/app/assets/stylesheets/admin/shared/_forms.scss +19 -16
  9. data/app/assets/stylesheets/admin/shared/_layout.scss +1 -1
  10. data/app/assets/stylesheets/admin/shared/_typography.scss +10 -10
  11. data/app/assets/stylesheets/store/screen.css.scss +50 -50
  12. data/app/controllers/spree/admin/base_controller.rb +0 -1
  13. data/app/controllers/spree/admin/images_controller.rb +1 -1
  14. data/app/controllers/spree/admin/line_items_controller.rb +1 -0
  15. data/app/controllers/spree/admin/orders_controller.rb +5 -1
  16. data/app/controllers/spree/admin/payments_controller.rb +2 -1
  17. data/app/controllers/spree/admin/products_controller.rb +3 -1
  18. data/app/controllers/spree/admin/resource_controller.rb +15 -4
  19. data/app/controllers/spree/admin/shipments_controller.rb +6 -1
  20. data/app/controllers/spree/admin/taxons_controller.rb +0 -6
  21. data/app/controllers/spree/checkout_controller.rb +0 -4
  22. data/app/controllers/spree/locale_controller.rb +2 -2
  23. data/app/controllers/spree/orders_controller.rb +1 -1
  24. data/app/helpers/spree/admin/base_helper.rb +9 -1
  25. data/app/helpers/spree/admin/images_helper.rb +14 -0
  26. data/app/helpers/spree/admin/products_helper.rb +1 -1
  27. data/app/helpers/spree/base_helper.rb +3 -3
  28. data/app/models/spree/ability.rb +2 -6
  29. data/app/models/spree/address.rb +6 -1
  30. data/app/models/spree/legacy_user.rb +11 -0
  31. data/app/models/spree/log_entry.rb +11 -0
  32. data/app/models/spree/order.rb +11 -5
  33. data/app/models/spree/order_populator.rb +2 -2
  34. data/app/models/spree/order_updater.rb +11 -11
  35. data/app/models/spree/payment/processing.rb +2 -2
  36. data/app/models/spree/payment.rb +20 -1
  37. data/app/models/spree/payment_method.rb +10 -3
  38. data/app/models/spree/preference.rb +0 -29
  39. data/app/models/spree/preferences/store.rb +4 -10
  40. data/app/models/spree/product/scopes.rb +2 -2
  41. data/app/models/spree/product.rb +2 -5
  42. data/app/models/spree/product_property.rb +3 -1
  43. data/app/models/spree/property.rb +0 -2
  44. data/app/models/spree/return_authorization.rb +1 -1
  45. data/app/models/spree/shipment.rb +1 -1
  46. data/app/models/spree/variant.rb +1 -1
  47. data/app/views/spree/admin/general_settings/edit.html.erb +2 -2
  48. data/app/views/spree/admin/images/index.html.erb +6 -33
  49. data/app/views/spree/admin/orders/_form.html.erb +1 -1
  50. data/app/views/spree/admin/payment_methods/_form.html.erb +4 -0
  51. data/app/views/spree/admin/payment_methods/index.html.erb +3 -1
  52. data/app/views/spree/admin/product_properties/_product_property_fields.html.erb +5 -1
  53. data/app/views/spree/admin/product_properties/index.html.erb +2 -2
  54. data/app/views/spree/admin/products/_form.html.erb +1 -6
  55. data/app/views/spree/admin/products/edit.html.erb +4 -1
  56. data/app/views/spree/admin/prototypes/_form.html.erb +1 -1
  57. data/app/views/spree/admin/prototypes/select.js.erb +2 -2
  58. data/app/views/spree/admin/return_authorizations/index.html.erb +1 -1
  59. data/app/views/spree/admin/shared/_tabs.html.erb +1 -1
  60. data/app/views/spree/admin/shared/_translations.html.erb +1 -1
  61. data/app/views/spree/admin/shipments/_form.html.erb +1 -1
  62. data/app/views/spree/admin/shipping_methods/_form.html.erb +3 -3
  63. data/app/views/spree/admin/taxonomies/get_children.json.erb +1 -1
  64. data/app/views/spree/admin/variants/_autocomplete.js.erb +1 -1
  65. data/app/views/spree/shared/_order_details.html.erb +1 -1
  66. data/config/routes.rb +5 -1
  67. data/db/migrate/20121031162139_split_prices_from_variants.rb +1 -1
  68. data/db/migrate/20130114053446_add_display_on_to_spree_payment_methods.rb +9 -0
  69. data/db/migrate/20130120201805_add_position_to_product_properties.spree.rb +6 -0
  70. data/db/migrate/20130203232234_add_identifier_to_spree_payments.rb +5 -0
  71. data/lib/generators/spree/install/install_generator.rb +4 -1
  72. data/lib/spree/core/controller_helpers/common.rb +3 -3
  73. data/lib/spree/core/controller_helpers.rb +13 -0
  74. data/lib/spree/core/engine.rb +7 -4
  75. data/lib/spree/core/permalinks.rb +1 -1
  76. data/lib/spree/core/ssl_requirement.rb +1 -1
  77. data/lib/spree/core/testing_support/authorization_helpers.rb +5 -2
  78. data/lib/spree/core/testing_support/bar_ability.rb +17 -0
  79. data/lib/spree/core/testing_support/factories/product_factory.rb +4 -2
  80. data/lib/spree/core/testing_support/factories/variant_factory.rb +9 -3
  81. data/lib/spree/core/testing_support/preferences.rb +12 -6
  82. data/lib/spree/core/version.rb +1 -1
  83. data/lib/spree/core.rb +1 -1
  84. data/lib/spree/scopes/dynamic.rb +1 -1
  85. data/lib/tasks/core.rake +3 -3
  86. data/vendor/assets/javascripts/jquery-migrate-1.0.0.js +498 -0
  87. metadata +14 -7
@@ -0,0 +1,498 @@
1
+ /*!
2
+ * jQuery Migrate - v1.0.0 - 2013-01-14
3
+ * https://github.com/jquery/jquery-migrate
4
+ * Copyright 2005, 2013 jQuery Foundation, Inc. and other contributors; Licensed MIT
5
+ */
6
+ (function( jQuery, window, undefined ) {
7
+ "use strict";
8
+
9
+
10
+ var warnedAbout = {};
11
+
12
+ // List of warnings already given; public read only
13
+ jQuery.migrateWarnings = [];
14
+
15
+ // Set to true to prevent console output; migrateWarnings still maintained
16
+ // jQuery.migrateMute = false;
17
+
18
+ // Forget any warnings we've already given; public
19
+ jQuery.migrateReset = function() {
20
+ warnedAbout = {};
21
+ jQuery.migrateWarnings.length = 0;
22
+ };
23
+
24
+ function migrateWarn( msg) {
25
+ if ( !warnedAbout[ msg ] ) {
26
+ warnedAbout[ msg ] = true;
27
+ jQuery.migrateWarnings.push( msg );
28
+ if ( window.console && console.warn && !jQuery.migrateMute ) {
29
+ console.warn( "JQMIGRATE: " + msg );
30
+ }
31
+ }
32
+ }
33
+
34
+ function migrateWarnProp( obj, prop, value, msg ) {
35
+ if ( Object.defineProperty ) {
36
+ // On ES5 browsers (non-oldIE), warn if the code tries to get prop;
37
+ // allow property to be overwritten in case some other plugin wants it
38
+ try {
39
+ Object.defineProperty( obj, prop, {
40
+ configurable: true,
41
+ enumerable: true,
42
+ get: function() {
43
+ migrateWarn( msg );
44
+ return value;
45
+ },
46
+ set: function( newValue ) {
47
+ migrateWarn( msg );
48
+ value = newValue;
49
+ }
50
+ });
51
+ return;
52
+ } catch( err ) {
53
+ // IE8 is a dope about Object.defineProperty, can't warn there
54
+ }
55
+ }
56
+
57
+ // Non-ES5 (or broken) browser; just set the property
58
+ jQuery._definePropertyBroken = true;
59
+ obj[ prop ] = value;
60
+ }
61
+
62
+ if ( document.compatMode === "BackCompat" ) {
63
+ // jQuery has never supported or tested Quirks Mode
64
+ migrateWarn( "jQuery is not compatible with Quirks Mode" );
65
+ }
66
+
67
+
68
+ var attrFn = {},
69
+ attr = jQuery.attr,
70
+ valueAttrGet = jQuery.attrHooks.value && jQuery.attrHooks.value.get ||
71
+ function() { return null; },
72
+ valueAttrSet = jQuery.attrHooks.value && jQuery.attrHooks.value.set ||
73
+ function() { return undefined; },
74
+ rnoType = /^(?:input|button)$/i,
75
+ rnoAttrNodeType = /^[238]$/,
76
+ rboolean = /^(?:autofocus|autoplay|async|checked|controls|defer|disabled|hidden|loop|multiple|open|readonly|required|scoped|selected)$/i,
77
+ ruseDefault = /^(?:checked|selected)$/i;
78
+
79
+ // jQuery.attrFn
80
+ migrateWarnProp( jQuery, "attrFn", attrFn, "jQuery.attrFn is deprecated" );
81
+
82
+ jQuery.attr = function( elem, name, value, pass ) {
83
+ var lowerName = name.toLowerCase(),
84
+ nType = elem && elem.nodeType;
85
+
86
+ if ( pass ) {
87
+ migrateWarn("jQuery.fn.attr( props, pass ) is deprecated");
88
+ if ( elem && !rnoAttrNodeType.test( nType ) && jQuery.isFunction( jQuery.fn[ name ] ) ) {
89
+ return jQuery( elem )[ name ]( value );
90
+ }
91
+ }
92
+
93
+ // Warn if user tries to set `type` since it breaks on IE 6/7/8
94
+ if ( name === "type" && value !== undefined && rnoType.test( elem.nodeName ) ) {
95
+ migrateWarn("Can't change the 'type' of an input or button in IE 6/7/8");
96
+ }
97
+
98
+ // Restore boolHook for boolean property/attribute synchronization
99
+ if ( !jQuery.attrHooks[ lowerName ] && rboolean.test( lowerName ) ) {
100
+ jQuery.attrHooks[ lowerName ] = {
101
+ get: function( elem, name ) {
102
+ // Align boolean attributes with corresponding properties
103
+ // Fall back to attribute presence where some booleans are not supported
104
+ var attrNode,
105
+ property = jQuery.prop( elem, name );
106
+ return property === true || typeof property !== "boolean" &&
107
+ ( attrNode = elem.getAttributeNode(name) ) && attrNode.nodeValue !== false ?
108
+
109
+ name.toLowerCase() :
110
+ undefined;
111
+ },
112
+ set: function( elem, value, name ) {
113
+ var propName;
114
+ if ( value === false ) {
115
+ // Remove boolean attributes when set to false
116
+ jQuery.removeAttr( elem, name );
117
+ } else {
118
+ // value is true since we know at this point it's type boolean and not false
119
+ // Set boolean attributes to the same name and set the DOM property
120
+ propName = jQuery.propFix[ name ] || name;
121
+ if ( propName in elem ) {
122
+ // Only set the IDL specifically if it already exists on the element
123
+ elem[ propName ] = true;
124
+ }
125
+
126
+ elem.setAttribute( name, name.toLowerCase() );
127
+ }
128
+ return name;
129
+ }
130
+ };
131
+
132
+ // Warn only for attributes that can remain distinct from their properties post-1.9
133
+ if ( ruseDefault.test( lowerName ) ) {
134
+ migrateWarn( "jQuery.fn.attr(" + lowerName + ") may use property instead of attribute" );
135
+ }
136
+ }
137
+
138
+ return attr.call( jQuery, elem, name, value );
139
+ };
140
+
141
+ // attrHooks: value
142
+ jQuery.attrHooks.value = {
143
+ get: function( elem, name ) {
144
+ var nodeName = ( elem.nodeName || "" ).toLowerCase();
145
+ if ( nodeName === "button" ) {
146
+ return valueAttrGet.apply( this, arguments );
147
+ }
148
+ if ( nodeName !== "input" && nodeName !== "option" ) {
149
+ migrateWarn("property-based jQuery.fn.attr('value') is deprecated");
150
+ }
151
+ return name in elem ?
152
+ elem.value :
153
+ null;
154
+ },
155
+ set: function( elem, value ) {
156
+ var nodeName = ( elem.nodeName || "" ).toLowerCase();
157
+ if ( nodeName === "button" ) {
158
+ return valueAttrSet.apply( this, arguments );
159
+ }
160
+ if ( nodeName !== "input" && nodeName !== "option" ) {
161
+ migrateWarn("property-based jQuery.fn.attr('value', val) is deprecated");
162
+ }
163
+ // Does not return so that setAttribute is also used
164
+ elem.value = value;
165
+ }
166
+ };
167
+
168
+
169
+ var matched, browser,
170
+ oldInit = jQuery.fn.init,
171
+ // Note this does NOT include the # XSS fix from 1.7!
172
+ rquickExpr = /^(?:.*(<[\w\W]+>)[^>]*|#([\w\-]*))$/;
173
+
174
+ // $(html) "looks like html" rule change
175
+ jQuery.fn.init = function( selector, context, rootjQuery ) {
176
+ var match;
177
+
178
+ if ( selector && typeof selector === "string" && !jQuery.isPlainObject( context ) &&
179
+ (match = rquickExpr.exec( selector )) && match[1] ) {
180
+ // This is an HTML string according to the "old" rules; is it still?
181
+ if ( selector.charAt( 0 ) !== "<" ) {
182
+ migrateWarn("$(html) HTML strings must start with '<' character");
183
+ }
184
+ // Now process using loose rules; let pre-1.8 play too
185
+ if ( context && context.context ) {
186
+ // jQuery object as context; parseHTML expects a DOM object
187
+ context = context.context;
188
+ }
189
+ if ( jQuery.parseHTML ) {
190
+ return oldInit.call( this, jQuery.parseHTML( jQuery.trim(selector), context, true ),
191
+ context, rootjQuery );
192
+ }
193
+ }
194
+ return oldInit.apply( this, arguments );
195
+ };
196
+ jQuery.fn.init.prototype = jQuery.fn;
197
+
198
+ jQuery.uaMatch = function( ua ) {
199
+ ua = ua.toLowerCase();
200
+
201
+ var match = /(chrome)[ \/]([\w.]+)/.exec( ua ) ||
202
+ /(webkit)[ \/]([\w.]+)/.exec( ua ) ||
203
+ /(opera)(?:.*version|)[ \/]([\w.]+)/.exec( ua ) ||
204
+ /(msie) ([\w.]+)/.exec( ua ) ||
205
+ ua.indexOf("compatible") < 0 && /(mozilla)(?:.*? rv:([\w.]+)|)/.exec( ua ) ||
206
+ [];
207
+
208
+ return {
209
+ browser: match[ 1 ] || "",
210
+ version: match[ 2 ] || "0"
211
+ };
212
+ };
213
+
214
+ matched = jQuery.uaMatch( navigator.userAgent );
215
+ browser = {};
216
+
217
+ if ( matched.browser ) {
218
+ browser[ matched.browser ] = true;
219
+ browser.version = matched.version;
220
+ }
221
+
222
+ // Chrome is Webkit, but Webkit is also Safari.
223
+ if ( browser.chrome ) {
224
+ browser.webkit = true;
225
+ } else if ( browser.webkit ) {
226
+ browser.safari = true;
227
+ }
228
+
229
+ jQuery.browser = browser;
230
+
231
+ // Warn if the code tries to get jQuery.browser
232
+ migrateWarnProp( jQuery, "browser", browser, "jQuery.browser is deprecated" );
233
+
234
+ jQuery.sub = function() {
235
+ function jQuerySub( selector, context ) {
236
+ return new jQuerySub.fn.init( selector, context );
237
+ }
238
+ jQuery.extend( true, jQuerySub, this );
239
+ jQuerySub.superclass = this;
240
+ jQuerySub.fn = jQuerySub.prototype = this();
241
+ jQuerySub.fn.constructor = jQuerySub;
242
+ jQuerySub.sub = this.sub;
243
+ jQuerySub.fn.init = function init( selector, context ) {
244
+ if ( context && context instanceof jQuery && !(context instanceof jQuerySub) ) {
245
+ context = jQuerySub( context );
246
+ }
247
+
248
+ return jQuery.fn.init.call( this, selector, context, rootjQuerySub );
249
+ };
250
+ jQuerySub.fn.init.prototype = jQuerySub.fn;
251
+ var rootjQuerySub = jQuerySub(document);
252
+ migrateWarn( "jQuery.sub() is deprecated" );
253
+ return jQuerySub;
254
+ };
255
+
256
+
257
+ var oldFnData = jQuery.fn.data;
258
+
259
+ jQuery.fn.data = function( name ) {
260
+ var ret, evt,
261
+ elem = this[0];
262
+
263
+ // Handles 1.7 which has this behavior and 1.8 which doesn't
264
+ if ( elem && name === "events" && arguments.length === 1 ) {
265
+ ret = jQuery.data( elem, name );
266
+ evt = jQuery._data( elem, name );
267
+ if ( ( ret === undefined || ret === evt ) && evt !== undefined ) {
268
+ migrateWarn("Use of jQuery.fn.data('events') is deprecated");
269
+ return evt;
270
+ }
271
+ }
272
+ return oldFnData.apply( this, arguments );
273
+ };
274
+
275
+
276
+ var rscriptType = /\/(java|ecma)script/i,
277
+ oldSelf = jQuery.fn.andSelf || jQuery.fn.addBack,
278
+ oldFragment = jQuery.buildFragment;
279
+
280
+ jQuery.fn.andSelf = function() {
281
+ migrateWarn("jQuery.fn.andSelf() replaced by jQuery.fn.addBack()");
282
+ return oldSelf.apply( this, arguments );
283
+ };
284
+
285
+ // Since jQuery.clean is used internally on older versions, we only shim if it's missing
286
+ if ( !jQuery.clean ) {
287
+ jQuery.clean = function( elems, context, fragment, scripts ) {
288
+ // Set context per 1.8 logic
289
+ context = context || document;
290
+ context = !context.nodeType && context[0] || context;
291
+ context = context.ownerDocument || context;
292
+
293
+ migrateWarn("jQuery.clean() is deprecated");
294
+
295
+ var i, elem, handleScript, jsTags,
296
+ ret = [];
297
+
298
+ jQuery.merge( ret, jQuery.buildFragment( elems, context ).childNodes );
299
+
300
+ // Complex logic lifted directly from jQuery 1.8
301
+ if ( fragment ) {
302
+ // Special handling of each script element
303
+ handleScript = function( elem ) {
304
+ // Check if we consider it executable
305
+ if ( !elem.type || rscriptType.test( elem.type ) ) {
306
+ // Detach the script and store it in the scripts array (if provided) or the fragment
307
+ // Return truthy to indicate that it has been handled
308
+ return scripts ?
309
+ scripts.push( elem.parentNode ? elem.parentNode.removeChild( elem ) : elem ) :
310
+ fragment.appendChild( elem );
311
+ }
312
+ };
313
+
314
+ for ( i = 0; (elem = ret[i]) != null; i++ ) {
315
+ // Check if we're done after handling an executable script
316
+ if ( !( jQuery.nodeName( elem, "script" ) && handleScript( elem ) ) ) {
317
+ // Append to fragment and handle embedded scripts
318
+ fragment.appendChild( elem );
319
+ if ( typeof elem.getElementsByTagName !== "undefined" ) {
320
+ // handleScript alters the DOM, so use jQuery.merge to ensure snapshot iteration
321
+ jsTags = jQuery.grep( jQuery.merge( [], elem.getElementsByTagName("script") ), handleScript );
322
+
323
+ // Splice the scripts into ret after their former ancestor and advance our index beyond them
324
+ ret.splice.apply( ret, [i + 1, 0].concat( jsTags ) );
325
+ i += jsTags.length;
326
+ }
327
+ }
328
+ }
329
+ }
330
+
331
+ return ret;
332
+ };
333
+ }
334
+
335
+ jQuery.buildFragment = function( elems, context, scripts, selection ) {
336
+ var ret,
337
+ warning = "jQuery.buildFragment() is deprecated";
338
+
339
+ // Set context per 1.8 logic
340
+ context = context || document;
341
+ context = !context.nodeType && context[0] || context;
342
+ context = context.ownerDocument || context;
343
+
344
+ try {
345
+ ret = oldFragment.call( jQuery, elems, context, scripts, selection );
346
+
347
+ // jQuery < 1.8 required arrayish context; jQuery 1.9 fails on it
348
+ } catch( x ) {
349
+ ret = oldFragment.call( jQuery, elems, context.nodeType ? [ context ] : context[ 0 ], scripts, selection );
350
+
351
+ // Success from tweaking context means buildFragment was called by the user
352
+ migrateWarn( warning );
353
+ }
354
+
355
+ // jQuery < 1.9 returned an object instead of the fragment itself
356
+ if ( !ret.fragment ) {
357
+ migrateWarnProp( ret, "fragment", ret, warning );
358
+ migrateWarnProp( ret, "cacheable", false, warning );
359
+ }
360
+
361
+ return ret;
362
+ };
363
+
364
+ var eventAdd = jQuery.event.add,
365
+ eventRemove = jQuery.event.remove,
366
+ eventTrigger = jQuery.event.trigger,
367
+ oldToggle = jQuery.fn.toggle,
368
+ oldLive = jQuery.fn.live,
369
+ oldDie = jQuery.fn.die,
370
+ ajaxEvents = "ajaxStart|ajaxStop|ajaxSend|ajaxComplete|ajaxError|ajaxSuccess",
371
+ rajaxEvent = new RegExp( "\\b(?:" + ajaxEvents + ")\\b" ),
372
+ rhoverHack = /(?:^|\s)hover(\.\S+|)\b/,
373
+ hoverHack = function( events ) {
374
+ if ( typeof( events ) != "string" || jQuery.event.special.hover ) {
375
+ return events;
376
+ }
377
+ if ( rhoverHack.test( events ) ) {
378
+ migrateWarn("'hover' pseudo-event is deprecated, use 'mouseenter mouseleave'");
379
+ }
380
+ return events && events.replace( rhoverHack, "mouseenter$1 mouseleave$1" );
381
+ };
382
+
383
+ // Event props removed in 1.9, put them back if needed; no practical way to warn them
384
+ if ( jQuery.event.props && jQuery.event.props[ 0 ] !== "attrChange" ) {
385
+ jQuery.event.props.unshift( "attrChange", "attrName", "relatedNode", "srcElement" );
386
+ }
387
+
388
+ // Undocumented jQuery.event.handle was "deprecated" in jQuery 1.7
389
+ migrateWarnProp( jQuery.event, "handle", jQuery.event.dispatch, "jQuery.event.handle is undocumented and deprecated" );
390
+
391
+ // Support for 'hover' pseudo-event and ajax event warnings
392
+ jQuery.event.add = function( elem, types, handler, data, selector ){
393
+ if ( elem !== document && rajaxEvent.test( types ) ) {
394
+ migrateWarn( "AJAX events should be attached to document: " + types );
395
+ }
396
+ eventAdd.call( this, elem, hoverHack( types || "" ), handler, data, selector );
397
+ };
398
+ jQuery.event.remove = function( elem, types, handler, selector, mappedTypes ){
399
+ eventRemove.call( this, elem, hoverHack( types ) || "", handler, selector, mappedTypes );
400
+ };
401
+
402
+ jQuery.fn.error = function() {
403
+ var args = Array.prototype.slice.call( arguments, 0);
404
+ migrateWarn("jQuery.fn.error() is deprecated");
405
+ args.splice( 0, 0, "error" );
406
+ if ( arguments.length ) {
407
+ return this.bind.apply( this, args );
408
+ }
409
+ // error event should not bubble to window, although it does pre-1.7
410
+ this.triggerHandler.apply( this, args );
411
+ return this;
412
+ };
413
+
414
+ jQuery.fn.toggle = function( fn, fn2 ) {
415
+
416
+ // Don't mess with animation or css toggles
417
+ if ( !jQuery.isFunction( fn ) || !jQuery.isFunction( fn2 ) ) {
418
+ return oldToggle.apply( this, arguments );
419
+ }
420
+ migrateWarn("jQuery.fn.toggle(handler, handler...) is deprecated");
421
+
422
+ // Save reference to arguments for access in closure
423
+ var args = arguments,
424
+ guid = fn.guid || jQuery.guid++,
425
+ i = 0,
426
+ toggler = function( event ) {
427
+ // Figure out which function to execute
428
+ var lastToggle = ( jQuery._data( this, "lastToggle" + fn.guid ) || 0 ) % i;
429
+ jQuery._data( this, "lastToggle" + fn.guid, lastToggle + 1 );
430
+
431
+ // Make sure that clicks stop
432
+ event.preventDefault();
433
+
434
+ // and execute the function
435
+ return args[ lastToggle ].apply( this, arguments ) || false;
436
+ };
437
+
438
+ // link all the functions, so any of them can unbind this click handler
439
+ toggler.guid = guid;
440
+ while ( i < args.length ) {
441
+ args[ i++ ].guid = guid;
442
+ }
443
+
444
+ return this.click( toggler );
445
+ };
446
+
447
+ jQuery.fn.live = function( types, data, fn ) {
448
+ migrateWarn("jQuery.fn.live() is deprecated");
449
+ if ( oldLive ) {
450
+ return oldLive.apply( this, arguments );
451
+ }
452
+ jQuery( this.context ).on( types, this.selector, data, fn );
453
+ return this;
454
+ };
455
+
456
+ jQuery.fn.die = function( types, fn ) {
457
+ migrateWarn("jQuery.fn.die() is deprecated");
458
+ if ( oldDie ) {
459
+ return oldDie.apply( this, arguments );
460
+ }
461
+ jQuery( this.context ).off( types, this.selector || "**", fn );
462
+ return this;
463
+ };
464
+
465
+ // Turn global events into document-triggered events
466
+ jQuery.event.trigger = function( event, data, elem, onlyHandlers ){
467
+ if ( !elem & !rajaxEvent.test( event ) ) {
468
+ migrateWarn( "Global events are undocumented and deprecated" );
469
+ }
470
+ return eventTrigger.call( this, event, data, elem || document, onlyHandlers );
471
+ };
472
+ jQuery.each( ajaxEvents.split("|"),
473
+ function( _, name ) {
474
+ jQuery.event.special[ name ] = {
475
+ setup: function() {
476
+ var elem = this;
477
+
478
+ // The document needs no shimming; must be !== for oldIE
479
+ if ( elem !== document ) {
480
+ jQuery.event.add( document, name + "." + jQuery.guid, function() {
481
+ jQuery.event.trigger( name, null, elem, true );
482
+ });
483
+ jQuery._data( this, name, jQuery.guid++ );
484
+ }
485
+ return false;
486
+ },
487
+ teardown: function() {
488
+ if ( this !== document ) {
489
+ jQuery.event.remove( document, name + "." + jQuery._data( this, name ) );
490
+ }
491
+ return false;
492
+ }
493
+ };
494
+ }
495
+ );
496
+
497
+
498
+ })( jQuery, window );
metadata CHANGED
@@ -1,7 +1,7 @@
1
1
  --- !ruby/object:Gem::Specification
2
2
  name: spree_core
3
3
  version: !ruby/object:Gem::Version
4
- version: 1.3.1
4
+ version: 1.3.2
5
5
  prerelease:
6
6
  platform: ruby
7
7
  authors:
@@ -9,7 +9,7 @@ authors:
9
9
  autorequire:
10
10
  bindir: bin
11
11
  cert_chain: []
12
- date: 2013-01-06 00:00:00.000000000 Z
12
+ date: 2013-02-04 00:00:00.000000000 Z
13
13
  dependencies:
14
14
  - !ruby/object:Gem::Dependency
15
15
  name: acts_as_list
@@ -50,7 +50,7 @@ dependencies:
50
50
  requirements:
51
51
  - - ~>
52
52
  - !ruby/object:Gem::Version
53
- version: '2.0'
53
+ version: 2.2.0
54
54
  type: :runtime
55
55
  prerelease: false
56
56
  version_requirements: !ruby/object:Gem::Requirement
@@ -58,7 +58,7 @@ dependencies:
58
58
  requirements:
59
59
  - - ~>
60
60
  - !ruby/object:Gem::Version
61
- version: '2.0'
61
+ version: 2.2.0
62
62
  - !ruby/object:Gem::Dependency
63
63
  name: select2-rails
64
64
  requirement: !ruby/object:Gem::Requirement
@@ -194,7 +194,7 @@ dependencies:
194
194
  requirements:
195
195
  - - ~>
196
196
  - !ruby/object:Gem::Version
197
- version: 3.2.10
197
+ version: 3.2.11
198
198
  type: :runtime
199
199
  prerelease: false
200
200
  version_requirements: !ruby/object:Gem::Requirement
@@ -202,7 +202,7 @@ dependencies:
202
202
  requirements:
203
203
  - - ~>
204
204
  - !ruby/object:Gem::Version
205
- version: 3.2.10
205
+ version: 3.2.11
206
206
  - !ruby/object:Gem::Dependency
207
207
  name: kaminari
208
208
  requirement: !ruby/object:Gem::Requirement
@@ -460,6 +460,7 @@ files:
460
460
  - app/controllers/spree/taxons_controller.rb
461
461
  - app/helpers/spree/admin/base_helper.rb
462
462
  - app/helpers/spree/admin/general_settings_helper.rb
463
+ - app/helpers/spree/admin/images_helper.rb
463
464
  - app/helpers/spree/admin/inventory_settings_helper.rb
464
465
  - app/helpers/spree/admin/navigation_helper.rb
465
466
  - app/helpers/spree/admin/orders_helper.rb
@@ -786,6 +787,7 @@ files:
786
787
  - lib/spree/core/controller_helpers/common.rb
787
788
  - lib/spree/core/controller_helpers/order.rb
788
789
  - lib/spree/core/controller_helpers/respond_with.rb
790
+ - lib/spree/core/controller_helpers.rb
789
791
  - lib/spree/core/custom_fixtures.rb
790
792
  - lib/spree/core/delegate_belongs_to.rb
791
793
  - lib/spree/core/engine.rb
@@ -807,6 +809,7 @@ files:
807
809
  - lib/spree/core/ssl_requirement.rb
808
810
  - lib/spree/core/store_helpers.rb
809
811
  - lib/spree/core/testing_support/authorization_helpers.rb
812
+ - lib/spree/core/testing_support/bar_ability.rb
810
813
  - lib/spree/core/testing_support/capybara_ext.rb
811
814
  - lib/spree/core/testing_support/common_rake.rb
812
815
  - lib/spree/core/testing_support/controller_requests.rb
@@ -882,6 +885,9 @@ files:
882
885
  - db/migrate/20121111231553_remove_display_on_from_payment_methods.rb
883
886
  - db/migrate/20121124203911_add_position_to_taxonomies.rb
884
887
  - db/migrate/20121126040517_add_last_ip_to_spree_orders.rb
888
+ - db/migrate/20130114053446_add_display_on_to_spree_payment_methods.rb
889
+ - db/migrate/20130120201805_add_position_to_product_properties.spree.rb
890
+ - db/migrate/20130203232234_add_identifier_to_spree_payments.rb
885
891
  - db/seeds.rb
886
892
  - vendor/assets/fonts/fontawesome-webfont.eot
887
893
  - vendor/assets/fonts/fontawesome-webfont.svg
@@ -1153,6 +1159,7 @@ files:
1153
1159
  - vendor/assets/javascripts/css_browser_selector_dev.js
1154
1160
  - vendor/assets/javascripts/equalize.js
1155
1161
  - vendor/assets/javascripts/handlebars.js
1162
+ - vendor/assets/javascripts/jquery-migrate-1.0.0.js
1156
1163
  - vendor/assets/javascripts/jquery.adaptivemenu.js
1157
1164
  - vendor/assets/javascripts/jquery.alerts/images/help.gif
1158
1165
  - vendor/assets/javascripts/jquery.alerts/images/important.gif
@@ -1246,7 +1253,7 @@ required_rubygems_version: !ruby/object:Gem::Requirement
1246
1253
  version: '0'
1247
1254
  segments:
1248
1255
  - 0
1249
- hash: -4519868674944601549
1256
+ hash: -3105092707259309965
1250
1257
  requirements:
1251
1258
  - none
1252
1259
  rubyforge_project: spree_core