spree_core 0.60.6 → 0.70.0
Sign up to get free protection for your applications and to get access to all the features.
- data/LICENSE +1 -1
- data/README.md +10 -4
- data/{public → app/assets}/images/admin/bg/active-tab.png +0 -0
- data/{public → app/assets}/images/admin/bg/admin_tab_back.png +0 -0
- data/{public → app/assets}/images/admin/bg/admin_tab_selected_back.png +0 -0
- data/{public → app/assets}/images/admin/bg/content-back-blue.png +0 -0
- data/{public → app/assets}/images/admin/bg/content-back-green.png +0 -0
- data/{public → app/assets}/images/admin/bg/content-back.png +0 -0
- data/{public → app/assets}/images/admin/bg/flash-error.png +0 -0
- data/{public → app/assets}/images/admin/bg/flash-notice.png +0 -0
- data/{public → app/assets}/images/admin/bg/green-stripes.gif +0 -0
- data/{public → app/assets}/images/admin/bg/green-stripes.png +0 -0
- data/{public → app/assets}/images/admin/bg/grid_header_back.png +0 -0
- data/{public → app/assets}/images/admin/bg/grid_header_back_green.png +0 -0
- data/{public → app/assets}/images/admin/bg/header-bg.png +0 -0
- data/{public → app/assets}/images/admin/bg/header.png +0 -0
- data/{public → app/assets}/images/admin/bg/header_bg.jpg +0 -0
- data/{public → app/assets}/images/admin/bg/menu-current.png +0 -0
- data/{public → app/assets}/images/admin/bg/red-stripes.gif +0 -0
- data/{public → app/assets}/images/admin/bg/red-stripes.png +0 -0
- data/{public → app/assets}/images/admin/bg/spree_50.png +0 -0
- data/{public → app/assets}/images/admin/bg/subnav-divider.png +0 -0
- data/{public → app/assets}/images/admin/bg/subnav.png +0 -0
- data/{public → app/assets}/images/admin/bg/tab-back.png +0 -0
- data/{public → app/assets}/images/admin/buttons/blue/left_01.png +0 -0
- data/{public → app/assets}/images/admin/buttons/blue/right_01.png +0 -0
- data/{public → app/assets}/images/admin/buttons/drag-handle-green.png +0 -0
- data/{public → app/assets}/images/admin/buttons/green/left_01.png +0 -0
- data/{public → app/assets}/images/admin/buttons/green/right_01.png +0 -0
- data/{public → app/assets}/images/admin/buttons/left_01.png +0 -0
- data/{public → app/assets}/images/admin/buttons/left_01_small.png +0 -0
- data/{public → app/assets}/images/admin/buttons/orange/left_03.png +0 -0
- data/{public → app/assets}/images/admin/buttons/orange/right_03.png +0 -0
- data/{public → app/assets}/images/admin/buttons/right_01.png +0 -0
- data/{public → app/assets}/images/admin/buttons/right_01_small.png +0 -0
- data/{public → app/assets}/images/admin/icons/16x16/1.png +0 -0
- data/{public → app/assets}/images/admin/icons/16x16/10.png +0 -0
- data/{public → app/assets}/images/admin/icons/16x16/2.png +0 -0
- data/{public → app/assets}/images/admin/icons/16x16/3.png +0 -0
- data/{public → app/assets}/images/admin/icons/16x16/4.png +0 -0
- data/{public → app/assets}/images/admin/icons/16x16/5.png +0 -0
- data/{public → app/assets}/images/admin/icons/16x16/6.png +0 -0
- data/{public → app/assets}/images/admin/icons/16x16/7.png +0 -0
- data/{public → app/assets}/images/admin/icons/16x16/8.png +0 -0
- data/{public → app/assets}/images/admin/icons/16x16/9.png +0 -0
- data/{public → app/assets}/images/admin/icons/32x32/1.png +0 -0
- data/{public → app/assets}/images/admin/icons/32x32/10.png +0 -0
- data/{public → app/assets}/images/admin/icons/32x32/11.png +0 -0
- data/{public → app/assets}/images/admin/icons/32x32/2.png +0 -0
- data/{public → app/assets}/images/admin/icons/32x32/3.png +0 -0
- data/{public → app/assets}/images/admin/icons/32x32/4.png +0 -0
- data/{public → app/assets}/images/admin/icons/32x32/5.png +0 -0
- data/{public → app/assets}/images/admin/icons/32x32/6.png +0 -0
- data/{public → app/assets}/images/admin/icons/32x32/7.png +0 -0
- data/{public → app/assets}/images/admin/icons/32x32/8.png +0 -0
- data/{public → app/assets}/images/admin/icons/32x32/9.png +0 -0
- data/{public → app/assets}/images/admin/icons/accept.png +0 -0
- data/{public → app/assets}/images/admin/icons/add.gif +0 -0
- data/{public → app/assets}/images/admin/icons/add.png +0 -0
- data/{public → app/assets}/images/admin/icons/arrow-down.gif +0 -0
- data/{public → app/assets}/images/admin/icons/cross.png +0 -0
- data/{public → app/assets}/images/admin/icons/delete.gif +0 -0
- data/{public → app/assets}/images/admin/icons/delete.png +0 -0
- data/{public → app/assets}/images/admin/icons/drag.gif +0 -0
- data/{public → app/assets}/images/admin/icons/edit.gif +0 -0
- data/{public → app/assets}/images/admin/icons/edit.png +0 -0
- data/{public → app/assets}/images/admin/icons/email.png +0 -0
- data/{public → app/assets}/images/admin/icons/error.png +0 -0
- data/{public → app/assets}/images/admin/icons/exclamation.png +0 -0
- data/{public → app/assets}/images/admin/icons/feed.png +0 -0
- data/{public → app/assets}/images/admin/icons/pdf.png +0 -0
- data/{public → app/assets}/images/admin/icons/reorder.gif +0 -0
- data/{public → app/assets}/images/admin/icons/search.gif +0 -0
- data/{public → app/assets}/images/admin/icons/send-email.png +0 -0
- data/{public → app/assets}/images/admin/icons/stop.png +0 -0
- data/app/assets/images/admin/icons/switch.png +0 -0
- data/{public → app/assets}/images/admin/icons/tick.png +0 -0
- data/{public → app/assets}/images/admin/icons/up.gif +0 -0
- data/{public → app/assets}/images/admin/icons/xls.png +0 -0
- data/{public/images → app/assets/images/admin}/progress.gif +0 -0
- data/{public/images → app/assets/images/creditcards}/amex_cid.gif +0 -0
- data/{public/images → app/assets/images/creditcards}/creditcard.gif +0 -0
- data/{public/images → app/assets/images/creditcards}/discover_cid.gif +0 -0
- data/{public/images → app/assets/images/creditcards}/master_cid.jpg +0 -0
- data/{public/images → app/assets/images/creditcards}/visa_cid.gif +0 -0
- data/{public → app/assets}/images/favicon.ico +0 -0
- data/{public/images → app/assets/images/icons}/add-to-cart.png +0 -0
- data/{public/images → app/assets/images/icons}/checkout.png +0 -0
- data/app/assets/images/icons/delete.png +0 -0
- data/{public/images → app/assets/images/icons}/update.png +0 -0
- data/app/assets/images/noimage/mini.png +0 -0
- data/app/assets/images/noimage/product.png +0 -0
- data/app/assets/images/noimage/small.png +0 -0
- data/{public → app/assets}/images/spinner.gif +0 -0
- data/{public → app/assets}/javascripts/admin/address_states.js +4 -4
- data/{public/javascripts/admin.js → app/assets/javascripts/admin/admin.js.erb} +90 -93
- data/app/assets/javascripts/admin/calculator.js +15 -0
- data/{public → app/assets}/javascripts/admin/checkouts/edit.js +13 -13
- data/app/assets/javascripts/admin/gateway.js +13 -0
- data/app/assets/javascripts/admin/images/index.js +10 -0
- data/app/assets/javascripts/admin/images/new.js +5 -0
- data/app/assets/javascripts/admin/nested-attribute.js +23 -0
- data/app/assets/javascripts/admin/orders/edit.js +15 -0
- data/app/assets/javascripts/admin/orders/edit_form.js +18 -0
- data/{public → app/assets}/javascripts/admin/payments/new.js +0 -0
- data/app/assets/javascripts/admin/products.js +23 -0
- data/app/assets/javascripts/admin/spree_core.js +10 -0
- data/app/assets/javascripts/admin/taxonomy.js +206 -0
- data/app/assets/javascripts/admin/underscore-min.js +26 -0
- data/app/assets/javascripts/admin/zone.js +44 -0
- data/app/assets/javascripts/store/cart.js +11 -0
- data/app/assets/javascripts/store/checkout.js +77 -0
- data/app/assets/javascripts/store/product.js +49 -0
- data/app/assets/javascripts/store/spree_core.js +6 -0
- data/{public/stylesheets/admin/admin-forms.css → app/assets/stylesheets/admin/admin-form.css.erb} +28 -19
- data/{public → app/assets}/stylesheets/admin/admin-reset.css +0 -0
- data/{public/stylesheets/admin/admin-tables.css → app/assets/stylesheets/admin/admin-tables.css.erb} +3 -2
- data/{public → app/assets}/stylesheets/admin/admin-typography.css +2 -2
- data/{public/stylesheets/admin/admin.css → app/assets/stylesheets/admin/admin.css.erb} +22 -46
- data/{public/stylesheets/admin/autocomplete.css → app/assets/stylesheets/admin/edit_checkouts.css} +6 -7
- data/app/assets/stylesheets/admin/spree_core.css +15 -0
- data/{public → app/assets}/stylesheets/admin/token-input.css +0 -0
- data/app/assets/stylesheets/store/reset.css +175 -0
- data/app/assets/stylesheets/store/screen.css +122 -0
- data/app/assets/stylesheets/store/spree_core.css +5 -0
- data/app/controllers/admin/base_controller.rb +3 -32
- data/app/controllers/admin/general_settings_controller.rb +14 -15
- data/app/controllers/admin/line_items_controller.rb +4 -2
- data/app/controllers/admin/mail_methods_controller.rb +13 -0
- data/app/controllers/admin/option_types_controller.rb +1 -2
- data/app/controllers/admin/orders_controller.rb +9 -8
- data/app/controllers/admin/product_groups_controller.rb +1 -2
- data/app/controllers/admin/products_controller.rb +4 -6
- data/app/controllers/admin/prototypes_controller.rb +1 -0
- data/app/controllers/admin/resource_controller.rb +7 -1
- data/app/controllers/admin/shipments_controller.rb +1 -1
- data/app/controllers/admin/states_controller.rb +1 -1
- data/app/controllers/admin/tax_categories_controller.rb +6 -0
- data/app/controllers/admin/tax_rates_controller.rb +2 -2
- data/app/controllers/admin/taxons_controller.rb +0 -9
- data/app/controllers/admin/users_controller.rb +9 -5
- data/app/controllers/admin/variants_controller.rb +22 -0
- data/app/controllers/admin/zones_controller.rb +1 -1
- data/app/controllers/checkout_controller.rb +12 -0
- data/app/controllers/content_controller.rb +1 -1
- data/app/controllers/home_controller.rb +10 -0
- data/app/controllers/orders_controller.rb +11 -7
- data/app/controllers/products_controller.rb +0 -1
- data/app/helpers/admin/base_helper.rb +5 -9
- data/app/helpers/admin/navigation_helper.rb +9 -2
- data/app/helpers/checkout_helper.rb +7 -3
- data/app/helpers/hook_helper.rb +5 -15
- data/app/helpers/products_helper.rb +4 -0
- data/app/helpers/spree/base_helper.rb +70 -16
- data/app/helpers/taxons_helper.rb +0 -16
- data/app/mailers/order_mailer.rb +5 -5
- data/app/mailers/shipment_mailer.rb +3 -3
- data/app/mailers/test_mailer.rb +10 -0
- data/app/models/activator.rb +27 -0
- data/app/models/adjustment.rb +32 -12
- data/app/models/app_configuration.rb +7 -6
- data/app/models/calculator/flat_percent_item_total.rb +0 -5
- data/app/models/calculator/flat_rate.rb +0 -5
- data/app/models/calculator/flexi_rate.rb +0 -5
- data/app/models/calculator/per_item.rb +0 -5
- data/app/models/calculator/price_bucket.rb +0 -6
- data/app/models/calculator/sales_tax.rb +1 -6
- data/app/models/calculator/vat.rb +26 -47
- data/app/models/calculator.rb +7 -9
- data/app/models/creditcard.rb +36 -31
- data/app/models/gateway.rb +1 -0
- data/app/models/image.rb +7 -2
- data/app/models/inventory_unit.rb +6 -10
- data/app/models/line_item.rb +17 -2
- data/app/models/order.rb +35 -20
- data/app/models/payment.rb +6 -12
- data/app/models/payment_method/check.rb +0 -4
- data/app/models/payment_method.rb +1 -11
- data/app/models/product.rb +54 -29
- data/app/models/product_group.rb +4 -8
- data/app/models/product_scope.rb +1 -1
- data/app/models/shipment.rb +1 -6
- data/app/models/tax_category.rb +6 -0
- data/app/models/tax_rate.rb +10 -0
- data/app/models/taxon.rb +3 -3
- data/app/models/taxonomy.rb +1 -1
- data/app/models/zone.rb +4 -4
- data/app/views/admin/adjustments/_adjustments_table.html.erb +6 -6
- data/app/views/admin/adjustments/_form.html.erb +4 -4
- data/app/views/admin/adjustments/edit.html.erb +8 -8
- data/app/views/admin/adjustments/index.html.erb +2 -2
- data/app/views/admin/adjustments/new.html.erb +7 -7
- data/app/views/admin/configurations/index.html.erb +57 -59
- data/app/views/admin/general_settings/edit.html.erb +16 -41
- data/app/views/admin/general_settings/show.html.erb +15 -26
- data/app/views/admin/images/_form.html.erb +6 -6
- data/app/views/admin/images/edit.html.erb +11 -11
- data/app/views/admin/images/index.html.erb +18 -32
- data/app/views/admin/images/new.html.erb +8 -18
- data/app/views/admin/inventory_settings/edit.html.erb +10 -10
- data/app/views/admin/inventory_settings/show.html.erb +4 -4
- data/app/views/admin/inventory_units/adjust.html.erb +13 -13
- data/app/views/admin/line_items/create.js.erb +4 -0
- data/app/views/admin/mail_methods/_form.html.erb +27 -33
- data/app/views/admin/mail_methods/edit.html.erb +5 -5
- data/app/views/admin/mail_methods/index.html.erb +19 -23
- data/app/views/admin/mail_methods/new.html.erb +5 -5
- data/app/views/admin/option_types/_available.html.erb +14 -13
- data/app/views/admin/option_types/_form.html.erb +2 -2
- data/app/views/admin/option_types/_option_value_fields.html.erb +4 -4
- data/app/views/admin/option_types/_selected.html.erb +10 -10
- data/app/views/admin/option_types/available.js.erb +1 -1
- data/app/views/admin/option_types/edit.html.erb +13 -13
- data/app/views/admin/option_types/index.html.erb +11 -11
- data/app/views/admin/option_types/new.html.erb +11 -0
- data/app/views/admin/option_types/new.js.erb +2 -0
- data/app/views/admin/option_types/selected.html.erb +2 -2
- data/app/views/admin/orders/_add_product.html.erb +8 -8
- data/app/views/admin/orders/_form.html.erb +36 -47
- data/app/views/admin/orders/_line_item.html.erb +12 -15
- data/app/views/admin/orders/_user_form.html.erb +22 -17
- data/app/views/admin/orders/edit.html.erb +16 -20
- data/app/views/admin/orders/history.html.erb +11 -11
- data/app/views/admin/orders/index.html.erb +54 -67
- data/app/views/admin/orders/new.html.erb +10 -11
- data/app/views/admin/orders/show.html.erb +11 -13
- data/app/views/admin/orders/user.html.erb +8 -13
- data/app/views/admin/payment_methods/_form.html.erb +23 -23
- data/app/views/admin/payment_methods/edit.html.erb +6 -6
- data/app/views/admin/payment_methods/index.html.erb +22 -32
- data/app/views/admin/payment_methods/new.html.erb +5 -5
- data/app/views/admin/payments/_bill_address_form.html.erb +1 -1
- data/app/views/admin/payments/_form.html.erb +6 -6
- data/app/views/admin/payments/_list.html.erb +7 -7
- data/app/views/admin/payments/_transaction_list.html.erb +9 -9
- data/app/views/admin/payments/credit.html.erb +6 -6
- data/app/views/admin/payments/index.html.erb +9 -9
- data/app/views/admin/payments/new.html.erb +7 -7
- data/app/views/admin/payments/show.html.erb +3 -3
- data/app/views/admin/payments/source_forms/_gateway.html.erb +13 -13
- data/app/views/admin/payments/source_views/_gateway.html.erb +9 -9
- data/app/views/admin/product_groups/_preview.html.erb +8 -8
- data/app/views/admin/product_groups/_product_scope.html.erb +8 -8
- data/app/views/admin/product_groups/edit.html.erb +12 -15
- data/app/views/admin/product_groups/index.html.erb +14 -14
- data/app/views/admin/product_groups/new.html.erb +4 -4
- data/app/views/admin/product_groups/show.html.erb +5 -5
- data/app/views/admin/product_groups/update.js.erb +7 -3
- data/app/views/admin/product_properties/_product_property_fields.html.erb +4 -4
- data/app/views/admin/product_properties/index.html.erb +22 -22
- data/app/views/admin/product_scopes/create.js.erb +3 -3
- data/app/views/admin/product_scopes/destroy.js.erb +3 -3
- data/app/views/admin/products/_form.html.erb +81 -78
- data/app/views/admin/products/_option_types.html.erb +36 -36
- data/app/views/admin/products/_properties_form.erb +3 -3
- data/app/views/admin/products/edit.html.erb +3 -4
- data/app/views/admin/products/index.html.erb +34 -43
- data/app/views/admin/products/new.html.erb +52 -0
- data/app/views/admin/products/new.js.erb +3 -0
- data/app/views/admin/products/show.html.erb +1 -1
- data/app/views/admin/properties/_form.html.erb +13 -10
- data/app/views/admin/properties/edit.html.erb +3 -3
- data/app/views/admin/properties/index.html.erb +11 -11
- data/app/views/admin/properties/{new.erb → new.html.erb} +4 -4
- data/app/views/admin/properties/new.js.erb +2 -0
- data/app/views/admin/prototypes/_form.html.erb +21 -21
- data/app/views/admin/prototypes/_prototypes.html.erb +21 -0
- data/app/views/admin/prototypes/available.js.erb +2 -0
- data/app/views/admin/prototypes/edit.html.erb +4 -4
- data/app/views/admin/prototypes/index.html.erb +11 -11
- data/app/views/admin/prototypes/{new.erb → new.html.erb} +4 -4
- data/app/views/admin/prototypes/new.js.erb +2 -0
- data/app/views/admin/reports/index.html.erb +5 -5
- data/app/views/admin/reports/sales_total.html.erb +8 -8
- data/app/views/admin/return_authorizations/_form.html.erb +15 -16
- data/app/views/admin/return_authorizations/edit.html.erb +13 -13
- data/app/views/admin/return_authorizations/index.html.erb +14 -14
- data/app/views/admin/return_authorizations/new.html.erb +8 -8
- data/app/views/admin/shared/_additional_field.html.erb +1 -1
- data/app/views/admin/shared/_address.html.erb +1 -1
- data/app/views/admin/shared/_address_form.html.erb +26 -27
- data/app/views/admin/shared/_calculator_fields.html.erb +6 -6
- data/app/views/admin/shared/_configuration_menu.html.erb +14 -15
- data/app/views/admin/shared/_destroy.js.erb +2 -2
- data/app/views/admin/shared/_edit_resource_links.html.erb +3 -3
- data/app/views/admin/shared/_group_from_products_form.html.erb +7 -7
- data/app/views/admin/shared/_head.html.erb +26 -0
- data/app/views/admin/shared/_new_adjustment_button.html.erb +5 -5
- data/app/views/admin/shared/_new_resource_links.html.erb +3 -3
- data/app/views/admin/shared/_order_details.html.erb +0 -1
- data/app/views/admin/shared/_order_tabs.html.erb +43 -48
- data/app/views/admin/shared/_product_sub_menu.html.erb +6 -8
- data/app/views/admin/shared/_product_tabs.html.erb +21 -25
- data/app/views/admin/shared/_report_criteria.html.erb +9 -9
- data/app/views/admin/shared/_show_resource_links.html.erb +5 -5
- data/app/views/admin/shared/_tabs.html.erb +1 -1
- data/app/views/admin/shared/_update_order_state.js +4 -4
- data/app/views/admin/shipments/_form.html.erb +42 -46
- data/app/views/admin/shipments/edit.html.erb +23 -25
- data/app/views/admin/shipments/index.html.erb +25 -34
- data/app/views/admin/shipments/new.html.erb +12 -12
- data/app/views/admin/shipping_categories/_form.html.erb +4 -4
- data/app/views/admin/shipping_categories/edit.html.erb +4 -4
- data/app/views/admin/shipping_categories/index.html.erb +12 -12
- data/app/views/admin/shipping_categories/new.html.erb +4 -4
- data/app/views/admin/shipping_methods/_form.html.erb +9 -10
- data/app/views/admin/shipping_methods/edit.html.erb +11 -11
- data/app/views/admin/shipping_methods/index.html.erb +19 -29
- data/app/views/admin/shipping_methods/new.html.erb +10 -10
- data/app/views/admin/states/_form.html.erb +3 -3
- data/app/views/admin/states/_state_list.html.erb +11 -13
- data/app/views/admin/states/edit.html.erb +4 -4
- data/app/views/admin/states/index.html.erb +6 -6
- data/app/views/admin/states/new.html.erb +8 -0
- data/app/views/admin/states/new.js.erb +2 -0
- data/app/views/admin/tax_categories/_form.html.erb +6 -6
- data/app/views/admin/tax_categories/edit.html.erb +4 -4
- data/app/views/admin/tax_categories/index.html.erb +14 -15
- data/app/views/admin/tax_categories/new.html.erb +4 -4
- data/app/views/admin/tax_rates/_form.html.erb +9 -9
- data/app/views/admin/tax_rates/edit.html.erb +5 -5
- data/app/views/admin/tax_rates/index.html.erb +14 -14
- data/app/views/admin/tax_rates/new.html.erb +4 -4
- data/app/views/admin/tax_settings/edit.html.erb +15 -9
- data/app/views/admin/tax_settings/show.html.erb +11 -7
- data/app/views/admin/taxonomies/_form.html.erb +3 -3
- data/app/views/admin/taxonomies/_js_head.html.erb +4 -5
- data/app/views/admin/taxonomies/_list.html.erb +7 -7
- data/app/views/admin/taxonomies/_taxon.html.erb +2 -2
- data/app/views/admin/taxonomies/edit.erb +31 -32
- data/app/views/admin/taxonomies/get_children.json.erb +7 -7
- data/app/views/admin/taxonomies/index.html.erb +7 -7
- data/app/views/admin/taxonomies/new.html.erb +5 -5
- data/app/views/admin/taxons/_form.html.erb +5 -5
- data/app/views/admin/taxons/_taxon_table.html.erb +10 -10
- data/app/views/admin/taxons/available.js.erb +7 -14
- data/app/views/admin/taxons/edit.html.erb +4 -4
- data/app/views/admin/taxons/remove.html.erb +1 -1
- data/app/views/admin/taxons/select.js.erb +1 -1
- data/app/views/admin/taxons/selected.html.erb +14 -14
- data/app/views/admin/trackers/_form.html.erb +16 -15
- data/app/views/admin/trackers/edit.html.erb +5 -5
- data/app/views/admin/trackers/index.html.erb +15 -20
- data/app/views/admin/trackers/new.html.erb +4 -4
- data/app/views/admin/users/_form.html.erb +17 -18
- data/app/views/admin/users/edit.html.erb +10 -10
- data/app/views/admin/users/index.html.erb +24 -38
- data/app/views/admin/users/new.html.erb +10 -10
- data/app/views/admin/users/show.html.erb +7 -7
- data/app/views/admin/variants/_form.html.erb +9 -9
- data/app/views/admin/variants/edit.html.erb +5 -5
- data/app/views/admin/variants/index.html.erb +20 -24
- data/app/views/admin/variants/new.html.erb +8 -0
- data/app/views/admin/variants/new.js.erb +2 -0
- data/app/views/admin/zones/_country_member.html.erb +2 -2
- data/app/views/admin/zones/_form.html.erb +15 -15
- data/app/views/admin/zones/_member_type.html.erb +2 -2
- data/app/views/admin/zones/_state_member.html.erb +3 -3
- data/app/views/admin/zones/_zone_member.html.erb +2 -2
- data/app/views/admin/zones/edit.html.erb +5 -5
- data/app/views/admin/zones/index.html.erb +12 -13
- data/app/views/admin/zones/new.html.erb +5 -5
- data/app/views/checkout/_address.html.erb +125 -134
- data/app/views/checkout/_confirm.html.erb +3 -3
- data/app/views/checkout/_delivery.html.erb +11 -7
- data/app/views/checkout/_payment.html.erb +10 -10
- data/app/views/checkout/_summary.html.erb +8 -7
- data/app/views/checkout/edit.html.erb +9 -11
- data/app/views/checkout/payment/_gateway.html.erb +13 -13
- data/app/views/checkout/registration.html.erb +9 -9
- data/app/views/content/cvv.html.erb +7 -7
- data/app/views/home/index.html.erb +10 -0
- data/app/views/layouts/admin.html.erb +23 -32
- data/app/views/layouts/spree_application.html.erb +29 -43
- data/app/views/order_mailer/cancel_email.text.erb +2 -2
- data/app/views/order_mailer/confirm_email.text.erb +1 -1
- data/app/views/orders/_form.html.erb +9 -11
- data/app/views/orders/_line_item.html.erb +21 -31
- data/app/views/orders/edit.html.erb +25 -23
- data/app/views/orders/new.html.erb +3 -3
- data/app/views/orders/show.html.erb +5 -5
- data/app/views/products/_cart_form.html.erb +42 -47
- data/app/views/products/_properties.html.erb +5 -4
- data/app/views/products/_taxons.html.erb +10 -12
- data/app/views/products/_thumbnails.html.erb +14 -35
- data/app/views/products/index.html.erb +10 -13
- data/app/views/products/show.html.erb +19 -24
- data/app/views/shared/_error_messages.html.erb +1 -1
- data/app/views/shared/_filters.html.erb +3 -4
- data/app/views/shared/_google_analytics.html.erb +6 -6
- data/app/views/shared/_head.html.erb +4 -7
- data/app/views/shared/_nav_bar.html.erb +3 -2
- data/app/views/shared/_order_details.html.erb +31 -41
- data/app/views/shared/_products.html.erb +10 -16
- data/app/views/shared/_store_menu.html.erb +2 -2
- data/app/views/shared/_taxonomies.html.erb +3 -14
- data/app/views/shipment_mailer/shipped_email.text.erb +2 -2
- data/app/views/taxons/_taxon.html.erb +2 -2
- data/app/views/taxons/show.html.erb +10 -10
- data/app/views/test_mailer/test_email.text.erb +4 -0
- data/config/initializers/deprecation_checker.rb +7 -0
- data/config/initializers/form_builder.rb +0 -4
- data/config/initializers/rails_3_1.rb +12 -0
- data/config/initializers/workarounds_for_ruby19.rb +1 -1
- data/config/locales/en.yml +59 -24
- data/config/routes.rb +9 -8
- data/db/default/roles.yml +1 -3
- data/db/migrate/20100419194457_fix_existing_coupon_credits.rb +9 -0
- data/db/migrate/20110329141434_create_activators.rb +21 -0
- data/db/migrate/20110418151136_eligible_for_adjustments.rb +9 -0
- data/db/seeds.rb +4 -2
- data/lib/custom_fixtures.rb +64 -3
- data/lib/environment_extension.rb +26 -0
- data/lib/generators/spree/dummy/dummy_generator.rb +106 -0
- data/lib/generators/spree/dummy/templates/cucumber/cucumber.rb +38 -0
- data/lib/generators/spree/dummy/templates/rails/application.rb +10 -0
- data/lib/generators/spree/dummy/templates/rails/boot.rb +6 -0
- data/lib/generators/spree/dummy/templates/rails/database.yml +30 -0
- data/lib/generators/spree/dummy/templates/rails/routes.rb +3 -0
- data/lib/generators/spree/sandbox/sandbox_generator.rb +27 -0
- data/lib/generators/spree/site/site_generator.rb +87 -0
- data/lib/generators/spree/site/templates/app/assets/javascripts/admin/all.js +16 -0
- data/lib/generators/spree/site/templates/app/assets/javascripts/store/all.js +16 -0
- data/lib/generators/spree/site/templates/app/assets/stylesheets/admin/all.css +17 -0
- data/lib/generators/spree/site/templates/app/assets/stylesheets/store/all.css +17 -0
- data/lib/product_filters.rb +8 -0
- data/lib/scopes/product.rb +6 -6
- data/lib/scopes.rb +1 -1
- data/lib/spree/calculated_adjustments.rb +16 -11
- data/lib/spree/environment/calculators.rb +10 -0
- data/lib/spree/environment.rb +12 -0
- data/lib/spree/search/base.rb +1 -5
- data/lib/spree_base.rb +17 -6
- data/lib/spree_core/ext/active_record.rb +1 -1
- data/lib/spree_core/preferences/model_hooks.rb +7 -3
- data/lib/spree_core/railtie.rb +42 -36
- data/lib/spree_core/ssl_requirement.rb +1 -1
- data/lib/spree_core/testing_support/common_rake.rb +12 -0
- data/lib/spree_core/testing_support/factories/activator_factory.rb +6 -0
- data/lib/spree_core/testing_support/factories/adjustment_factory.rb +1 -0
- data/lib/spree_core/testing_support/factories/calculator_factory.rb +6 -0
- data/lib/spree_core/testing_support/factories/order_factory.rb +7 -6
- data/lib/spree_core/testing_support/factories/product_factory.rb +6 -0
- data/lib/spree_core/testing_support/factories/user_factory.rb +14 -10
- data/lib/spree_core/testing_support/factories/zone_factory.rb +1 -1
- data/lib/spree_core/theme_support/hook_listener.rb +112 -35
- data/lib/spree_core/theme_support.rb +0 -3
- data/lib/spree_core/version.rb +1 -1
- data/lib/spree_core.rb +10 -7
- data/lib/tasks/assets.rake +58 -0
- data/lib/tasks/core.rake +18 -11
- data/lib/tasks/install.rake +4 -12
- data/{public → vendor/assets}/images/datepicker/cal.gif +0 -0
- data/vendor/assets/images/jquery-ui/ui-bg_flat_0_aaaaaa_40x100.png +0 -0
- data/vendor/assets/images/jquery-ui/ui-bg_flat_0_eeeeee_40x100.png +0 -0
- data/vendor/assets/images/jquery-ui/ui-bg_flat_55_ffffff_40x100.png +0 -0
- data/vendor/assets/images/jquery-ui/ui-bg_flat_75_ffffff_40x100.png +0 -0
- data/vendor/assets/images/jquery-ui/ui-bg_glass_65_ffffff_1x400.png +0 -0
- data/vendor/assets/images/jquery-ui/ui-bg_highlight-soft_100_f6f6f6_1x100.png +0 -0
- data/vendor/assets/images/jquery-ui/ui-bg_highlight-soft_25_0073ea_1x100.png +0 -0
- data/vendor/assets/images/jquery-ui/ui-bg_highlight-soft_50_dddddd_1x100.png +0 -0
- data/vendor/assets/images/jquery-ui/ui-icons_0073ea_256x240.png +0 -0
- data/vendor/assets/images/jquery-ui/ui-icons_454545_256x240.png +0 -0
- data/vendor/assets/images/jquery-ui/ui-icons_666666_256x240.png +0 -0
- data/vendor/assets/images/jquery-ui/ui-icons_ff0084_256x240.png +0 -0
- data/vendor/assets/images/jquery-ui/ui-icons_ffffff_256x240.png +0 -0
- data/{public → vendor/assets}/javascripts/jquery.alerts/images/help.gif +0 -0
- data/{public → vendor/assets}/javascripts/jquery.alerts/images/important.gif +0 -0
- data/{public → vendor/assets}/javascripts/jquery.alerts/images/info.gif +0 -0
- data/{public → vendor/assets}/javascripts/jquery.alerts/images/title.gif +0 -0
- data/{public → vendor/assets}/javascripts/jquery.alerts/jquery.alerts.css +0 -0
- data/{public → vendor/assets}/javascripts/jquery.alerts/jquery.alerts.js +0 -0
- data/{public → vendor/assets}/javascripts/jquery.alerts/jquery.alerts.spree.css +0 -0
- data/{public → vendor/assets}/javascripts/jquery.autocomplete.min.js +0 -0
- data/vendor/assets/javascripts/jquery.cookie.js +41 -0
- data/{public → vendor/assets}/javascripts/jquery.delayedobserver.js +0 -0
- data/{public/javascripts/jsTree → vendor/assets/javascripts/jquery.jstree}/jquery.jstree.js +4544 -3510
- data/{public/javascripts/jsTree → vendor/assets/javascripts/jquery.jstree}/themes/apple/bg.jpg +0 -0
- data/{public/javascripts/jsTree → vendor/assets/javascripts/jquery.jstree}/themes/apple/d.png +0 -0
- data/{public/javascripts/jsTree → vendor/assets/javascripts/jquery.jstree}/themes/apple/dot_for_ie.gif +0 -0
- data/{public/javascripts/jsTree → vendor/assets/javascripts/jquery.jstree}/themes/apple/style.css +2 -1
- data/{public/javascripts/jsTree → vendor/assets/javascripts/jquery.jstree}/themes/apple/throbber.gif +0 -0
- data/vendor/assets/javascripts/jquery.tokeninput.js +860 -0
- data/vendor/assets/javascripts/jquery.validate/additional-methods.min.js +28 -0
- data/vendor/assets/javascripts/jquery.validate/jquery.validate.min.js +51 -0
- data/vendor/assets/javascripts/jquery.validate/localization/messages_ar.js +24 -0
- data/vendor/assets/javascripts/jquery.validate/localization/messages_bg.js +23 -0
- data/vendor/assets/javascripts/jquery.validate/localization/messages_ca.js +23 -0
- data/vendor/assets/javascripts/jquery.validate/localization/messages_cn.js +23 -0
- data/vendor/assets/javascripts/jquery.validate/localization/messages_cs.js +23 -0
- data/vendor/assets/javascripts/jquery.validate/localization/messages_da.js +20 -0
- data/vendor/assets/javascripts/jquery.validate/localization/messages_de.js +21 -0
- data/vendor/assets/javascripts/jquery.validate/localization/messages_el.js +24 -0
- data/{public/javascripts → vendor/assets/javascripts/jquery.validate}/localization/messages_es.js +22 -23
- data/vendor/assets/javascripts/jquery.validate/localization/messages_fa.js +23 -0
- data/vendor/assets/javascripts/jquery.validate/localization/messages_fi.js +21 -0
- data/vendor/assets/javascripts/jquery.validate/localization/messages_fr.js +23 -0
- data/vendor/assets/javascripts/jquery.validate/localization/messages_ge.js +23 -0
- data/vendor/assets/javascripts/jquery.validate/localization/messages_he.js +23 -0
- data/vendor/assets/javascripts/jquery.validate/localization/messages_hu.js +21 -0
- data/vendor/assets/javascripts/jquery.validate/localization/messages_it.js +23 -0
- data/vendor/assets/javascripts/jquery.validate/localization/messages_ja.js +23 -0
- data/vendor/assets/javascripts/jquery.validate/localization/messages_kk.js +23 -0
- data/vendor/assets/javascripts/jquery.validate/localization/messages_lt.js +23 -0
- data/vendor/assets/javascripts/jquery.validate/localization/messages_lv.js +23 -0
- data/vendor/assets/javascripts/jquery.validate/localization/messages_nl.js +23 -0
- data/vendor/assets/javascripts/jquery.validate/localization/messages_no.js +23 -0
- data/vendor/assets/javascripts/jquery.validate/localization/messages_pl.js +23 -0
- data/vendor/assets/javascripts/jquery.validate/localization/messages_ptbr.js +30 -0
- data/vendor/assets/javascripts/jquery.validate/localization/messages_ptpt.js +23 -0
- data/{public/javascripts → vendor/assets/javascripts/jquery.validate}/localization/messages_ro.js +22 -23
- data/vendor/assets/javascripts/jquery.validate/localization/messages_ru.js +23 -0
- data/vendor/assets/javascripts/jquery.validate/localization/messages_se.js +23 -0
- data/vendor/assets/javascripts/jquery.validate/localization/messages_si.js +23 -0
- data/vendor/assets/javascripts/jquery.validate/localization/messages_sk.js +21 -0
- data/vendor/assets/javascripts/jquery.validate/localization/messages_sr.js +23 -0
- data/vendor/assets/javascripts/jquery.validate/localization/messages_th.js +23 -0
- data/vendor/assets/javascripts/jquery.validate/localization/messages_tr.js +24 -0
- data/vendor/assets/javascripts/jquery.validate/localization/messages_tw.js +24 -0
- data/vendor/assets/javascripts/jquery.validate/localization/messages_ua.js +24 -0
- data/vendor/assets/javascripts/jquery.validate/localization/messages_vi.js +23 -0
- data/vendor/assets/javascripts/jquery.validate/localization/methods_de.js +12 -0
- data/vendor/assets/javascripts/jquery.validate/localization/methods_nl.js +9 -0
- data/vendor/assets/javascripts/jquery.validate/localization/methods_pt.js +9 -0
- data/vendor/assets/stylesheets/jquery-ui.datepicker.css.erb +357 -0
- metadata +310 -417
- data/app/models/spree/alert.rb +0 -13
- data/app/stylesheets/_buttons.less +0 -80
- data/app/stylesheets/_cart.less +0 -24
- data/app/stylesheets/_checkout.less +0 -76
- data/app/stylesheets/_checkout_progress.less +0 -62
- data/app/stylesheets/_colors.less +0 -16
- data/app/stylesheets/_forms.less +0 -50
- data/app/stylesheets/_layout.less +0 -77
- data/app/stylesheets/_messages.less +0 -32
- data/app/stylesheets/_mixins.less +0 -71
- data/app/stylesheets/_navigation.less +0 -130
- data/app/stylesheets/_prices.less +0 -18
- data/app/stylesheets/_product_details.less +0 -56
- data/app/stylesheets/_product_lists.less +0 -66
- data/app/stylesheets/_registration.less +0 -24
- data/app/stylesheets/_reset.less +0 -69
- data/app/stylesheets/_typography.less +0 -158
- data/app/stylesheets/screen.less +0 -13
- data/app/views/admin/extensions/index.html.erb +0 -23
- data/app/views/admin/option_types/new.erb +0 -11
- data/app/views/admin/product_scopes/_form.html.erb +0 -106
- data/app/views/admin/products/new.erb +0 -53
- data/app/views/admin/prototypes/available.html.erb +0 -22
- data/app/views/admin/shared/_alert.html.erb +0 -6
- data/app/views/admin/states/new.erb +0 -8
- data/app/views/admin/variants/new.erb +0 -11
- data/app/views/shared/_additional_field.html.erb +0 -7
- data/app/views/shared/_admin_head.html.erb +0 -34
- data/app/views/shared/_basic_layout.html.erb +0 -44
- data/app/views/shared/_edit_resource_links.html.erb +0 -1
- data/app/views/shared/_footer.html.erb +0 -13
- data/app/views/shared/_method_error_message.html.erb +0 -4
- data/app/views/shared/_new_resource_links.html.erb +0 -1
- data/app/views/shared/_show_resource_links.html.erb +0 -3
- data/app/views/shared/_test_hook.html.erb +0 -1
- data/config/initializers/load_unobtrusive_date_picker.rb +0 -8
- data/db/migrate/20101026184833_migrate_adjustments.rb +0 -9
- data/lib/generators/spree_core/upgrade_generator.rb +0 -23
- data/lib/generators/templates/config/initializers/%file_name%.rb.tt +0 -1
- data/lib/generators/templates/config/locales/%current_locale%.yml.tt +0 -2
- data/lib/generators/templates/config/routes.rb +0 -3
- data/lib/spree_core/theme_support/hook.rb +0 -51
- data/lib/spree_core/theme_support/hook_modifier.rb +0 -35
- data/lib/spree_core/theme_support/more_patches.rb +0 -118
- data/lib/tasks/common.rb +0 -30
- data/lib/tasks/themes.rake +0 -34
- data/public/images/admin/tabs/off-left.png +0 -0
- data/public/images/admin/tabs/off-right.png +0 -0
- data/public/images/admin/tabs/on-left.png +0 -0
- data/public/images/admin/tabs/on-right.png +0 -0
- data/public/images/ajax_loader.gif +0 -0
- data/public/images/bg-button-hover.png +0 -0
- data/public/images/bg-button-pressed.png +0 -0
- data/public/images/bg-button.gif +0 -0
- data/public/images/bg-button.png +0 -0
- data/public/images/blue/left_01.png +0 -0
- data/public/images/blue/right_01.png +0 -0
- data/public/images/body-back.png +0 -0
- data/public/images/bottom_shine.png +0 -0
- data/public/images/breadcrumb.gif +0 -0
- data/public/images/button-dark-hover.png +0 -0
- data/public/images/button-dark.png +0 -0
- data/public/images/buttons/bg-button-hover.png +0 -0
- data/public/images/buttons/bg-button-pressed.png +0 -0
- data/public/images/buttons/bg-button.gif +0 -0
- data/public/images/buttons/bg-button.png +0 -0
- data/public/images/buttons/blue/left_01.png +0 -0
- data/public/images/buttons/blue/right_01.png +0 -0
- data/public/images/buttons/button-dark-hover.png +0 -0
- data/public/images/buttons/button-dark.png +0 -0
- data/public/images/buttons/drag-handle-green.png +0 -0
- data/public/images/buttons/green/left_01.png +0 -0
- data/public/images/buttons/green/right_01.png +0 -0
- data/public/images/buttons/left_01.png +0 -0
- data/public/images/buttons/left_01_small.png +0 -0
- data/public/images/buttons/orange/left_03.png +0 -0
- data/public/images/buttons/orange/right_03.png +0 -0
- data/public/images/buttons/right_01.png +0 -0
- data/public/images/buttons/right_01_small.png +0 -0
- data/public/images/buttons/sxsw-ribbon-v1.png +0 -0
- data/public/images/buttons/top-shine.png +0 -0
- data/public/images/calendar_date_select/calendar.gif +0 -0
- data/public/images/cart-empty.png +0 -0
- data/public/images/cart-empty_x32.png +0 -0
- data/public/images/cart-full.png +0 -0
- data/public/images/cart-full_x32.png +0 -0
- data/public/images/datepicker/backstripes.gif +0 -0
- data/public/images/datepicker/bg_header.jpg +0 -0
- data/public/images/datepicker/bullet1.gif +0 -0
- data/public/images/datepicker/bullet2.gif +0 -0
- data/public/images/datepicker/gradient-e5e5e5-ffffff.gif +0 -0
- data/public/images/drag-handle-green.png +0 -0
- data/public/images/green/left_01.png +0 -0
- data/public/images/green/right_01.png +0 -0
- data/public/images/grid.png +0 -0
- data/public/images/left_01.png +0 -0
- data/public/images/left_01_small.png +0 -0
- data/public/images/menu-current.png +0 -0
- data/public/images/menu-hover.png +0 -0
- data/public/images/noimage/mini.jpg +0 -0
- data/public/images/noimage/product.jpg +0 -0
- data/public/images/noimage/small.jpg +0 -0
- data/public/images/openid-inputicon.gif +0 -0
- data/public/images/orange/left_03.png +0 -0
- data/public/images/orange/right_03.png +0 -0
- data/public/images/reorder.jpg +0 -0
- data/public/images/right_01.png +0 -0
- data/public/images/right_01_small.png +0 -0
- data/public/images/separator.png +0 -0
- data/public/images/shadow-top.png +0 -0
- data/public/images/shadow_top.png +0 -0
- data/public/images/spree/progress.gif +0 -0
- data/public/images/spree/spinner.gif +0 -0
- data/public/images/spree/spree.jpg +0 -0
- data/public/images/spree.jpg +0 -0
- data/public/images/step-progress/completed-completed.gif +0 -0
- data/public/images/step-progress/completed-current.gif +0 -0
- data/public/images/step-progress/completed-first.gif +0 -0
- data/public/images/step-progress/current-first.gif +0 -0
- data/public/images/step-progress/current-incomplete.gif +0 -0
- data/public/images/step-progress/current-right.gif +0 -0
- data/public/images/step-progress/incomplete-incomplete.gif +0 -0
- data/public/images/step-progress/incomplete-right.gif +0 -0
- data/public/images/steps/1.png +0 -0
- data/public/images/steps/1_small.png +0 -0
- data/public/images/steps/2.png +0 -0
- data/public/images/steps/2_small.png +0 -0
- data/public/images/steps/3.png +0 -0
- data/public/images/steps/3_small.png +0 -0
- data/public/images/steps/4.png +0 -0
- data/public/images/steps/4_small.png +0 -0
- data/public/images/steps/5.png +0 -0
- data/public/images/steps/5_small.png +0 -0
- data/public/images/steps/6.png +0 -0
- data/public/images/steps/6_small.png +0 -0
- data/public/images/sxsw-ribbon-v1.png +0 -0
- data/public/images/tab_bottom.gif +0 -0
- data/public/images/tile-header.png +0 -0
- data/public/images/tile-slider.png +0 -0
- data/public/images/top-shine.png +0 -0
- data/public/images/tree-nav-icons/bullet.gif +0 -0
- data/public/images/tree-nav-icons/minus.gif +0 -0
- data/public/images/tree-nav-icons/plus.gif +0 -0
- data/public/images/tree-nav-icons/treeview-loading.gif +0 -0
- data/public/images/tree-nav-icons/treeview-sprite.gif +0 -0
- data/public/images/wrapper-back-2.png +0 -0
- data/public/images/wrapper-back.png +0 -0
- data/public/images/yui-menubaritem_submenuindicator.png +0 -0
- data/public/images/yui-menubaritem_submenuindicator_disabled.png +0 -0
- data/public/images/yui-menuitem_checkbox.png +0 -0
- data/public/images/yui-menuitem_checkbox_disabled.png +0 -0
- data/public/images/yui-menuitem_submenuindicator.png +0 -0
- data/public/images/yui-menuitem_submenuindicator_disabled.png +0 -0
- data/public/images/yui-sprite.png +0 -0
- data/public/javascripts/additional-methods.js +0 -236
- data/public/javascripts/admin/orders/edit.js +0 -23
- data/public/javascripts/admin/orders/edit_form.js +0 -16
- data/public/javascripts/admin/unobtrusive_handlers.js +0 -43
- data/public/javascripts/application.js +0 -12
- data/public/javascripts/calculator.js +0 -15
- data/public/javascripts/checkout.js +0 -75
- data/public/javascripts/datepicker.js +0 -1445
- data/public/javascripts/gateway.js +0 -13
- data/public/javascripts/jquery-1.4.2.min.js +0 -154
- data/public/javascripts/jquery-ui.js +0 -188
- data/public/javascripts/jquery.cookie.js +0 -96
- data/public/javascripts/jquery.suggest.js +0 -276
- data/public/javascripts/jquery.template.js +0 -255
- data/public/javascripts/jquery.tokeninput.js +0 -618
- data/public/javascripts/jquery.validate.min.js +0 -16
- data/public/javascripts/lang/af.js +0 -40
- data/public/javascripts/lang/ar.js +0 -50
- data/public/javascripts/lang/de.js +0 -40
- data/public/javascripts/lang/du.js +0 -40
- data/public/javascripts/lang/en.js +0 -42
- data/public/javascripts/lang/es.js +0 -41
- data/public/javascripts/lang/fi.js +0 -40
- data/public/javascripts/lang/fr.js +0 -44
- data/public/javascripts/lang/gr.js +0 -40
- data/public/javascripts/lang/he.js +0 -49
- data/public/javascripts/lang/it.js +0 -13
- data/public/javascripts/lang/nl.js +0 -40
- data/public/javascripts/lang/no.js +0 -40
- data/public/javascripts/lang/pt.js +0 -50
- data/public/javascripts/lang/ro.js +0 -40
- data/public/javascripts/lang/ru.js +0 -40
- data/public/javascripts/lang/sp.js +0 -40
- data/public/javascripts/lang/sv.js +0 -41
- data/public/javascripts/lang/ua.js +0 -40
- data/public/javascripts/localization/messages_cn.js +0 -24
- data/public/javascripts/localization/messages_cs.js +0 -23
- data/public/javascripts/localization/messages_da.js +0 -21
- data/public/javascripts/localization/messages_de.js +0 -21
- data/public/javascripts/localization/messages_fr.js +0 -23
- data/public/javascripts/localization/messages_hu.js +0 -21
- data/public/javascripts/localization/messages_it.js +0 -26
- data/public/javascripts/localization/messages_kk.js +0 -23
- data/public/javascripts/localization/messages_nl.js +0 -23
- data/public/javascripts/localization/messages_no.js +0 -23
- data/public/javascripts/localization/messages_pl.js +0 -23
- data/public/javascripts/localization/messages_ptbr.js +0 -30
- data/public/javascripts/localization/messages_ru.js +0 -23
- data/public/javascripts/localization/messages_se.js +0 -23
- data/public/javascripts/localization/messages_sk.js +0 -21
- data/public/javascripts/localization/messages_tr.js +0 -24
- data/public/javascripts/localization/messages_tw.js +0 -24
- data/public/javascripts/localization/messages_ua.js +0 -24
- data/public/javascripts/nested-attribute.js +0 -26
- data/public/javascripts/open_id.js +0 -15
- data/public/javascripts/product.js +0 -49
- data/public/javascripts/rails.js +0 -127
- data/public/javascripts/taxonomy.js +0 -201
- data/public/javascripts/zone.js +0 -39
- data/public/stylesheets/admin/dashboard.css +0 -143
- data/public/stylesheets/admin/edit_checkouts.css +0 -57
- data/public/stylesheets/admin/grids.css +0 -314
- data/public/stylesheets/admin/reset-fonts-grids-2-6-0.css +0 -7
- data/public/stylesheets/admin/yui-includes.css +0 -14
- data/public/stylesheets/datepicker.css +0 -263
- data/public/stylesheets/jquery.autocomplete.css +0 -48
- data/public/stylesheets/screen.css +0 -916
data/app/models/creditcard.rb
CHANGED
@@ -23,7 +23,7 @@ class Creditcard < ActiveRecord::Base
|
|
23
23
|
verification_value.to_s.gsub!(/\s/,'') unless number.nil?
|
24
24
|
self.last_digits ||= number.to_s.length <= 4 ? number : number.to_s.slice(-4..-1)
|
25
25
|
end
|
26
|
-
|
26
|
+
|
27
27
|
# cheap hack to get to the type? method from deep within ActiveMerchant without stomping on
|
28
28
|
# potentially existing methods in CreditCard
|
29
29
|
class CardDetector
|
@@ -31,12 +31,12 @@ class Creditcard < ActiveRecord::Base
|
|
31
31
|
include ActiveMerchant::Billing::CreditCardMethods::ClassMethods
|
32
32
|
end
|
33
33
|
end
|
34
|
-
|
34
|
+
|
35
35
|
# sets self.cc_type while we still have the card number
|
36
36
|
def set_card_type
|
37
37
|
self.cc_type ||= CardDetector.type?(self.number)
|
38
38
|
end
|
39
|
-
|
39
|
+
|
40
40
|
def name?
|
41
41
|
first_name? && last_name?
|
42
42
|
end
|
@@ -86,11 +86,11 @@ class Creditcard < ActiveRecord::Base
|
|
86
86
|
payment.avs_response = response.avs_result['code']
|
87
87
|
payment.pend
|
88
88
|
else
|
89
|
-
payment.
|
89
|
+
payment.failure
|
90
90
|
gateway_error(response)
|
91
91
|
end
|
92
|
-
rescue ActiveMerchant::ConnectionError
|
93
|
-
gateway_error
|
92
|
+
rescue ActiveMerchant::ConnectionError => e
|
93
|
+
gateway_error e
|
94
94
|
end
|
95
95
|
|
96
96
|
def purchase(amount, payment)
|
@@ -106,11 +106,11 @@ class Creditcard < ActiveRecord::Base
|
|
106
106
|
payment.avs_response = response.avs_result['code']
|
107
107
|
payment.complete
|
108
108
|
else
|
109
|
-
payment.
|
109
|
+
payment.failure
|
110
110
|
gateway_error(response) unless response.success?
|
111
111
|
end
|
112
|
-
rescue ActiveMerchant::ConnectionError
|
113
|
-
gateway_error
|
112
|
+
rescue ActiveMerchant::ConnectionError => e
|
113
|
+
gateway_error e
|
114
114
|
end
|
115
115
|
|
116
116
|
def capture(payment)
|
@@ -121,10 +121,10 @@ class Creditcard < ActiveRecord::Base
|
|
121
121
|
if payment_gateway.payment_profiles_supported?
|
122
122
|
# Gateways supporting payment profiles will need access to creditcard object because this stores the payment profile information
|
123
123
|
# so supply the authorization itself as well as the creditcard, rather than just the authorization code
|
124
|
-
response = payment_gateway.capture(payment, self, minimal_gateway_options(payment))
|
124
|
+
response = payment_gateway.capture(payment, self, minimal_gateway_options(payment, false))
|
125
125
|
else
|
126
126
|
# Standard ActiveMerchant capture usage
|
127
|
-
response = payment_gateway.capture((payment.amount * 100).round, payment.response_code, minimal_gateway_options(payment))
|
127
|
+
response = payment_gateway.capture((payment.amount * 100).round, payment.response_code, minimal_gateway_options(payment, false))
|
128
128
|
end
|
129
129
|
|
130
130
|
record_log payment, response
|
@@ -133,18 +133,18 @@ class Creditcard < ActiveRecord::Base
|
|
133
133
|
payment.response_code = response.authorization
|
134
134
|
payment.complete
|
135
135
|
else
|
136
|
-
payment.
|
136
|
+
payment.failure
|
137
137
|
gateway_error(response)
|
138
138
|
end
|
139
|
-
rescue ActiveMerchant::ConnectionError
|
140
|
-
gateway_error
|
139
|
+
rescue ActiveMerchant::ConnectionError => e
|
140
|
+
gateway_error e
|
141
141
|
end
|
142
142
|
|
143
143
|
def void(payment)
|
144
144
|
payment_gateway = payment.payment_method
|
145
145
|
check_environment(payment_gateway)
|
146
146
|
|
147
|
-
response = payment_gateway.void(payment.response_code, minimal_gateway_options(payment))
|
147
|
+
response = payment_gateway.void(payment.response_code, minimal_gateway_options(payment, false))
|
148
148
|
record_log payment, response
|
149
149
|
|
150
150
|
if response.success?
|
@@ -153,8 +153,8 @@ class Creditcard < ActiveRecord::Base
|
|
153
153
|
else
|
154
154
|
gateway_error(response)
|
155
155
|
end
|
156
|
-
rescue ActiveMerchant::ConnectionError
|
157
|
-
gateway_error
|
156
|
+
rescue ActiveMerchant::ConnectionError => e
|
157
|
+
gateway_error e
|
158
158
|
end
|
159
159
|
|
160
160
|
def credit(payment)
|
@@ -162,11 +162,10 @@ class Creditcard < ActiveRecord::Base
|
|
162
162
|
check_environment(payment_gateway)
|
163
163
|
|
164
164
|
amount = payment.credit_allowed >= payment.order.outstanding_balance.abs ? payment.order.outstanding_balance.abs : payment.credit_allowed.abs
|
165
|
-
|
166
165
|
if payment_gateway.payment_profiles_supported?
|
167
|
-
response = payment_gateway.credit((amount * 100).round, self, payment.response_code, minimal_gateway_options(payment))
|
166
|
+
response = payment_gateway.credit((amount * 100).round, self, payment.response_code, minimal_gateway_options(payment, false))
|
168
167
|
else
|
169
|
-
response = payment_gateway.credit((amount * 100).round, payment.response_code, minimal_gateway_options(payment))
|
168
|
+
response = payment_gateway.credit((amount * 100).round, payment.response_code, minimal_gateway_options(payment, false))
|
170
169
|
end
|
171
170
|
|
172
171
|
record_log payment, response
|
@@ -181,8 +180,8 @@ class Creditcard < ActiveRecord::Base
|
|
181
180
|
else
|
182
181
|
gateway_error(response)
|
183
182
|
end
|
184
|
-
rescue ActiveMerchant::ConnectionError
|
185
|
-
gateway_error
|
183
|
+
rescue ActiveMerchant::ConnectionError => e
|
184
|
+
gateway_error e
|
186
185
|
end
|
187
186
|
|
188
187
|
def actions
|
@@ -218,6 +217,8 @@ class Creditcard < ActiveRecord::Base
|
|
218
217
|
def gateway_error(error)
|
219
218
|
if error.is_a? ActiveMerchant::Billing::Response
|
220
219
|
text = error.params['message'] || error.params['response_reason_text'] || error.message
|
220
|
+
elsif error.is_a? ActiveMerchant::ConnectionError
|
221
|
+
text = I18n.t(:unable_to_connect_to_gateway)
|
221
222
|
else
|
222
223
|
text = error.to_s
|
223
224
|
end
|
@@ -242,18 +243,22 @@ class Creditcard < ActiveRecord::Base
|
|
242
243
|
# Generates a minimal set of gateway options. There appears to be some issues with passing in
|
243
244
|
# a billing address when authorizing/voiding a previously captured transaction. So omits these
|
244
245
|
# options in this case since they aren't necessary.
|
245
|
-
def minimal_gateway_options(payment)
|
246
|
-
|
247
|
-
|
248
|
-
|
249
|
-
|
250
|
-
|
251
|
-
|
252
|
-
|
246
|
+
def minimal_gateway_options(payment, totals=true)
|
247
|
+
|
248
|
+
options = {:email => payment.order.email,
|
249
|
+
:customer => payment.order.email,
|
250
|
+
:ip => payment.order.ip_address,
|
251
|
+
:order_id => payment.order.number}
|
252
|
+
if totals
|
253
|
+
options.merge!({ :shipping => payment.order.ship_total * 100,
|
254
|
+
:tax => payment.order.tax_total * 100,
|
255
|
+
:subtotal => payment.order.item_total * 100 })
|
256
|
+
end
|
257
|
+
options
|
253
258
|
end
|
254
259
|
|
255
260
|
def spree_cc_type
|
256
|
-
return "visa" if
|
261
|
+
return "visa" if ENV['RAILS_ENV'] == "development"
|
257
262
|
self.cc_type
|
258
263
|
end
|
259
264
|
|
data/app/models/gateway.rb
CHANGED
@@ -17,6 +17,7 @@ class Gateway < PaymentMethod
|
|
17
17
|
|
18
18
|
def provider
|
19
19
|
gateway_options = options
|
20
|
+
gateway_options.delete :login if gateway_options.has_key?(:login) and gateway_options[:login].nil?
|
20
21
|
ActiveMerchant::Billing::Base.gateway_mode = gateway_options[:server].to_sym
|
21
22
|
@provider ||= provider_class.new(gateway_options)
|
22
23
|
end
|
data/app/models/image.rb
CHANGED
@@ -3,13 +3,18 @@ class Image < Asset
|
|
3
3
|
has_attached_file :attachment,
|
4
4
|
:styles => { :mini => '48x48>', :small => '100x100>', :product => '240x240>', :large => '600x600>' },
|
5
5
|
:default_style => :product,
|
6
|
-
:url => "/
|
7
|
-
:path => ":rails_root/public/
|
6
|
+
:url => "/spree/products/:id/:style/:basename.:extension",
|
7
|
+
:path => ":rails_root/public/spree/products/:id/:style/:basename.:extension"
|
8
8
|
|
9
9
|
# save the w,h of the original image (from which others can be calculated)
|
10
10
|
# we need to look at the write-queue for images which have not been saved yet
|
11
11
|
after_post_process :find_dimensions
|
12
12
|
|
13
|
+
#used by admin products autocomplete
|
14
|
+
def mini_url
|
15
|
+
attachment.url(:mini, false)
|
16
|
+
end
|
17
|
+
|
13
18
|
def find_dimensions
|
14
19
|
temporary = attachment.queued_for_write[:original]
|
15
20
|
filename = temporary.path unless temporary.nil?
|
@@ -22,12 +22,6 @@ class InventoryUnit < ActiveRecord::Base
|
|
22
22
|
after_transition :to => 'returned', :do => :restock_variant
|
23
23
|
end
|
24
24
|
|
25
|
-
# method deprecated in favour of adjust_units (which creates & destroys units as needed).
|
26
|
-
def self.sell_units(order)
|
27
|
-
warn "[DEPRECATION] `InventoryUnits#sell_units` is deprecated. Please use `InventoryUnits#assign_opening_inventory` instead. (called from #{caller[0]})"
|
28
|
-
self.adjust_units(order)
|
29
|
-
end
|
30
|
-
|
31
25
|
# Assigns inventory to a newly completed order.
|
32
26
|
# Should only be called once during the life-cycle of an order, on transition to completed.
|
33
27
|
#
|
@@ -88,7 +82,10 @@ class InventoryUnit < ActiveRecord::Base
|
|
88
82
|
end
|
89
83
|
|
90
84
|
def self.destroy_units(order, variant, quantity)
|
91
|
-
variant_units = order.inventory_units.group_by(&:variant_id)
|
85
|
+
variant_units = order.inventory_units.group_by(&:variant_id)
|
86
|
+
return unless variant_units.include? variant.id
|
87
|
+
|
88
|
+
variant_units = variant_units[variant.id].sort_by(&:state)
|
92
89
|
|
93
90
|
quantity.times do
|
94
91
|
inventory_unit = variant_units.shift
|
@@ -97,9 +94,8 @@ class InventoryUnit < ActiveRecord::Base
|
|
97
94
|
end
|
98
95
|
|
99
96
|
def self.create_units(order, variant, sold, back_order)
|
100
|
-
if back_order > 0 && !Spree::Config[:allow_backorders]
|
101
|
-
|
102
|
-
end
|
97
|
+
return if back_order > 0 && !Spree::Config[:allow_backorders]
|
98
|
+
|
103
99
|
|
104
100
|
shipment = order.shipments.detect {|shipment| !shipment.shipped? }
|
105
101
|
|
data/app/models/line_item.rb
CHANGED
@@ -10,6 +10,8 @@ class LineItem < ActiveRecord::Base
|
|
10
10
|
validates :variant, :presence => true
|
11
11
|
validates :quantity, :numericality => { :only_integer => true, :message => I18n.t("validation.must_be_int") }
|
12
12
|
validates :price, :numericality => true
|
13
|
+
validate :stock_availability
|
14
|
+
|
13
15
|
# validate :meta_validation_of_quantities
|
14
16
|
|
15
17
|
attr_accessible :quantity
|
@@ -58,6 +60,14 @@ class LineItem < ActiveRecord::Base
|
|
58
60
|
self.quantity = 0 if self.quantity.nil? || self.quantity < 0
|
59
61
|
end
|
60
62
|
|
63
|
+
def sufficient_stock?
|
64
|
+
Spree::Config[:allow_backorders] ? true : (self.variant.on_hand >= self.quantity)
|
65
|
+
end
|
66
|
+
|
67
|
+
def insufficient_stock?
|
68
|
+
!sufficient_stock?
|
69
|
+
end
|
70
|
+
|
61
71
|
private
|
62
72
|
def update_inventory
|
63
73
|
return true unless self.order.completed?
|
@@ -89,7 +99,12 @@ class LineItem < ActiveRecord::Base
|
|
89
99
|
if order.try(:inventory_units).to_a.any?{|unit| unit.variant_id == variant_id && unit.shipped?}
|
90
100
|
errors.add :base, I18n.t("cannot_destory_line_item_as_inventory_units_have_shipped")
|
91
101
|
return false
|
92
|
-
|
93
|
-
|
102
|
+
end
|
103
|
+
end
|
104
|
+
|
105
|
+
def stock_availability
|
106
|
+
return if sufficient_stock?
|
107
|
+
errors.add(:quantiy, "can't be greater than avaiable stock.")
|
108
|
+
end
|
94
109
|
end
|
95
110
|
|
data/app/models/order.rb
CHANGED
@@ -25,6 +25,7 @@ class Order < ActiveRecord::Base
|
|
25
25
|
|
26
26
|
before_create :create_user
|
27
27
|
before_create :generate_order_number
|
28
|
+
after_create :create_tax_charge!
|
28
29
|
|
29
30
|
# TODO: validate the format of the email as well (but we can't rely on authlogic anymore to help with validation)
|
30
31
|
validates :email, :presence => true, :format => /^([\w\.%\+\-]+)@([\w\-]+\.)+([\w]{2,})$/i, :if => :require_email
|
@@ -44,8 +45,6 @@ class Order < ActiveRecord::Base
|
|
44
45
|
|
45
46
|
make_permalink :field => :number
|
46
47
|
|
47
|
-
attr_accessor :out_of_stock_items
|
48
|
-
|
49
48
|
class_attribute :update_hooks
|
50
49
|
self.update_hooks = Set.new
|
51
50
|
|
@@ -69,18 +68,24 @@ class Order < ActiveRecord::Base
|
|
69
68
|
line_items.count > 0
|
70
69
|
end
|
71
70
|
|
71
|
+
# Is this a free order in which case the payment step should be skipped
|
72
|
+
def payment_required?
|
73
|
+
total.to_f > 0.0
|
74
|
+
end
|
75
|
+
|
72
76
|
# Indicates the number of items in the order
|
73
77
|
def item_count
|
74
78
|
line_items.map(&:quantity).sum
|
75
79
|
end
|
76
80
|
|
77
81
|
# order state machine (see http://github.com/pluginaweek/state_machine/tree/master for details)
|
78
|
-
state_machine :initial =>
|
82
|
+
state_machine :initial => :cart, :use_transactions => false do
|
79
83
|
|
80
84
|
event :next do
|
81
85
|
transition :from => 'cart', :to => 'address'
|
82
86
|
transition :from => 'address', :to => 'delivery'
|
83
|
-
transition :from => 'delivery', :to => 'payment'
|
87
|
+
transition :from => 'delivery', :to => 'payment', :if => :payment_required?
|
88
|
+
transition :from => 'delivery', :to => 'complete'
|
84
89
|
transition :from => 'confirm', :to => 'complete'
|
85
90
|
|
86
91
|
# note: some payment methods will not support a confirm step
|
@@ -257,9 +262,18 @@ class Order < ActiveRecord::Base
|
|
257
262
|
|
258
263
|
# Creates a new tax charge if applicable. Uses the highest possible matching rate and destroys any previous
|
259
264
|
# tax charges if they were created by rates that no longer apply.
|
265
|
+
# for the vat case adjutments according to default country are created
|
260
266
|
def create_tax_charge!
|
261
267
|
adjustments.tax.each {|e| e.destroy }
|
262
|
-
TaxRate.match(ship_address)
|
268
|
+
matching_rates = TaxRate.match(ship_address)
|
269
|
+
if matching_rates.empty? and Spree::Config[:show_price_inc_vat]
|
270
|
+
# somebody may be able to make the search shorter here , some unremember bug caused this
|
271
|
+
matching_rates = TaxRate.all.select{|rate| # get all rates that apply to default country
|
272
|
+
rate.zone.country_list.collect{|c| c.id}.include?(Spree::Config[:default_country_id]) }
|
273
|
+
end
|
274
|
+
matching_rates.each do |rate|
|
275
|
+
rate.create_adjustment( "#{rate.calculator.description} #{rate.amount*100}%" , self, self, true)
|
276
|
+
end
|
263
277
|
end
|
264
278
|
|
265
279
|
# Creates a new shipment (adjustment is created by shipment model)
|
@@ -283,11 +297,6 @@ class Order < ActiveRecord::Base
|
|
283
297
|
self.outstanding_balance != 0
|
284
298
|
end
|
285
299
|
|
286
|
-
def destroy_inapplicable_adjustments
|
287
|
-
destroyed = adjustments.reject(&:applicable?).map(&:destroy)
|
288
|
-
adjustments.reload if destroyed.any?
|
289
|
-
end
|
290
|
-
|
291
300
|
def name
|
292
301
|
if (address = bill_address || ship_address)
|
293
302
|
"#{address.firstname} #{address.lastname}"
|
@@ -307,7 +316,7 @@ class Order < ActiveRecord::Base
|
|
307
316
|
# Called after transition to complete state when payments will have been processed
|
308
317
|
def finalize!
|
309
318
|
update_attribute(:completed_at, Time.now)
|
310
|
-
|
319
|
+
InventoryUnit.assign_opening_inventory(self)
|
311
320
|
# lock any optional adjustments (coupon promotions, etc.)
|
312
321
|
adjustments.optional.each { |adjustment| adjustment.update_attribute("locked", true) }
|
313
322
|
OrderMailer.confirm_email(self).deliver
|
@@ -367,6 +376,10 @@ class Order < ActiveRecord::Base
|
|
367
376
|
line_items.map{|li| li.variant.product}
|
368
377
|
end
|
369
378
|
|
379
|
+
def insufficient_stock_lines
|
380
|
+
line_items.select &:insufficient_stock?
|
381
|
+
end
|
382
|
+
|
370
383
|
private
|
371
384
|
def create_user
|
372
385
|
self.email = user.email if self.user and not user.anonymous?
|
@@ -419,10 +432,10 @@ class Order < ActiveRecord::Base
|
|
419
432
|
#
|
420
433
|
# The +payment_state+ value helps with reporting, etc. since it provides a quick and easy way to locate Orders needing attention.
|
421
434
|
def update_payment_state
|
422
|
-
if payment_total < total
|
435
|
+
if round_money(payment_total) < round_money(total)
|
423
436
|
self.payment_state = "balance_due"
|
424
437
|
self.payment_state = "failed" if payments.present? and payments.last.state == "failed"
|
425
|
-
elsif payment_total > total
|
438
|
+
elsif round_money(payment_total) > round_money(total)
|
426
439
|
self.payment_state = "credit_owed"
|
427
440
|
else
|
428
441
|
self.payment_state = "paid"
|
@@ -432,12 +445,16 @@ class Order < ActiveRecord::Base
|
|
432
445
|
self.state_events.create({
|
433
446
|
:previous_state => old_payment_state,
|
434
447
|
:next_state => self.payment_state,
|
435
|
-
:name => "payment"
|
448
|
+
:name => "payment",
|
436
449
|
:user_id => (User.respond_to?(:current) && User.current && User.current.id) || self.user_id
|
437
450
|
})
|
438
451
|
end
|
439
452
|
end
|
440
453
|
|
454
|
+
def round_money(n)
|
455
|
+
(n*100).round / 100.0
|
456
|
+
end
|
457
|
+
|
441
458
|
# Updates the following Order total values:
|
442
459
|
#
|
443
460
|
# +payment_total+ The total value of all finalized Payments (NOTE: non-finalized Payments are excluded)
|
@@ -448,17 +465,15 @@ class Order < ActiveRecord::Base
|
|
448
465
|
# update_adjustments
|
449
466
|
self.payment_total = payments.completed.map(&:amount).sum
|
450
467
|
self.item_total = line_items.map(&:amount).sum
|
451
|
-
self.adjustment_total = adjustments.map(&:amount).sum
|
468
|
+
self.adjustment_total = adjustments.eligible.map(&:amount).sum
|
452
469
|
self.total = item_total + adjustment_total
|
453
470
|
end
|
454
471
|
|
455
472
|
# Updates each of the Order adjustments. This is intended to be called from an Observer so that the Order can
|
456
|
-
# respond to external changes to LineItem, Shipment, other Adjustments, etc.
|
457
|
-
#
|
473
|
+
# respond to external changes to LineItem, Shipment, other Adjustments, etc.
|
474
|
+
# Adjustments will check if they are still eligible. Ineligible adjustments are preserved but not counted
|
475
|
+
# towards adjustment_total.
|
458
476
|
def update_adjustments
|
459
|
-
# separate into adjustments to keep and adjustements to toss
|
460
|
-
obsolete_adjustments = adjustments.select{|adjustment| !adjustment.applicable?}
|
461
|
-
obsolete_adjustments.each(&:destroy)
|
462
477
|
self.adjustments.reload.each(&:update!)
|
463
478
|
end
|
464
479
|
|
data/app/models/payment.rb
CHANGED
@@ -26,7 +26,7 @@ class Payment < ActiveRecord::Base
|
|
26
26
|
transition :from => ['checkout', 'pending', 'completed'], :to => 'processing'
|
27
27
|
end
|
28
28
|
# When processing during checkout fails
|
29
|
-
event :
|
29
|
+
event :failure do
|
30
30
|
transition :from => 'processing', :to => 'failed'
|
31
31
|
end
|
32
32
|
# With card payments this represents authorizing the payment
|
@@ -62,22 +62,16 @@ class Payment < ActiveRecord::Base
|
|
62
62
|
end
|
63
63
|
|
64
64
|
# With nested attributes, Rails calls build_[association_name] for the nested model which won't work for a polymorphic association
|
65
|
-
def build_source(params)
|
65
|
+
def build_source(params, opts)
|
66
66
|
if payment_method and payment_method.payment_source_class
|
67
67
|
self.source = payment_method.payment_source_class.new(params)
|
68
68
|
end
|
69
69
|
end
|
70
70
|
|
71
71
|
def process!
|
72
|
-
if
|
73
|
-
|
74
|
-
|
75
|
-
started_processing!
|
76
|
-
source.process!(self) # source is responsible for updating the payment state when it's done processing
|
77
|
-
end
|
78
|
-
else
|
79
|
-
raise Spree::GatewayError.new(I18n.t(:payment_processing_failed))
|
80
|
-
end
|
72
|
+
if !processing? and source and source.respond_to?(:process!)
|
73
|
+
started_processing!
|
74
|
+
source.process!(self) # source is responsible for updating the payment state when it's done processing
|
81
75
|
end
|
82
76
|
end
|
83
77
|
|
@@ -108,7 +102,7 @@ class Payment < ActiveRecord::Base
|
|
108
102
|
return unless source.is_a?(Creditcard) && source.number && !source.has_payment_profile?
|
109
103
|
payment_method.create_profile(self)
|
110
104
|
rescue ActiveMerchant::ConnectionError => e
|
111
|
-
gateway_error
|
105
|
+
gateway_error e
|
112
106
|
end
|
113
107
|
|
114
108
|
def update_order
|
@@ -2,14 +2,8 @@ class PaymentMethod < ActiveRecord::Base
|
|
2
2
|
DISPLAY = [:both, :front_end, :back_end]
|
3
3
|
default_scope where(:deleted_at => nil)
|
4
4
|
|
5
|
-
@provider = nil
|
6
|
-
@@providers = Set.new
|
7
|
-
def self.register
|
8
|
-
@@providers.add(self)
|
9
|
-
end
|
10
|
-
|
11
5
|
def self.providers
|
12
|
-
|
6
|
+
Rails.application.config.spree.payment_methods
|
13
7
|
end
|
14
8
|
|
15
9
|
def provider_class
|
@@ -51,8 +45,4 @@ class PaymentMethod < ActiveRecord::Base
|
|
51
45
|
false
|
52
46
|
end
|
53
47
|
|
54
|
-
def source_required?
|
55
|
-
true
|
56
|
-
end
|
57
|
-
|
58
48
|
end
|
data/app/models/product.rb
CHANGED
@@ -44,21 +44,25 @@ class Product < ActiveRecord::Base
|
|
44
44
|
after_save :save_master
|
45
45
|
|
46
46
|
has_many :variants,
|
47
|
-
:conditions => ["
|
48
|
-
:order =>
|
49
|
-
|
47
|
+
:conditions => ["#{Variant.table_name}.is_master = ? AND #{Variant.table_name}.deleted_at IS NULL", false],
|
48
|
+
:order => "#{Variant.table_name}.position ASC"
|
50
49
|
|
51
50
|
has_many :variants_including_master,
|
52
51
|
:class_name => 'Variant',
|
53
|
-
:conditions => ["
|
52
|
+
:conditions => ["#{Variant.table_name}.deleted_at IS NULL"],
|
54
53
|
:dependent => :destroy
|
55
54
|
|
56
55
|
has_many :variants_with_only_master,
|
57
56
|
:class_name => 'Variant',
|
58
|
-
:conditions => ["
|
57
|
+
:conditions => ["#{Variant.table_name}.deleted_at IS NULL AND #{Variant.table_name}.is_master = ?", true],
|
59
58
|
:dependent => :destroy
|
60
59
|
|
61
60
|
|
61
|
+
def variant_images
|
62
|
+
Image.find_by_sql("SELECT assets.* FROM assets LEFT JOIN variants ON (variants.id = assets.viewable_id) WHERE (variants.product_id = #{self.id})")
|
63
|
+
end
|
64
|
+
|
65
|
+
|
62
66
|
validates :name, :price, :permalink, :presence => true
|
63
67
|
|
64
68
|
accepts_nested_attributes_for :product_properties, :allow_destroy => true, :reject_if => lambda { |pp| pp[:property_name].blank? }
|
@@ -69,30 +73,43 @@ class Product < ActiveRecord::Base
|
|
69
73
|
|
70
74
|
include ::Scopes::Product
|
71
75
|
|
72
|
-
#RAILS3 TODO - scopes are duplicated here and in
|
76
|
+
#RAILS3 TODO - scopes are duplicated here and in scopes/product.rb - can we DRY it up?
|
73
77
|
# default product scope only lists available and non-deleted products
|
74
|
-
|
78
|
+
class << self
|
79
|
+
def not_deleted
|
80
|
+
where(Product.arel_table[:deleted_at].eq(nil))
|
81
|
+
end
|
75
82
|
|
76
|
-
|
83
|
+
def available(available_on = nil)
|
84
|
+
where(Product.arel_table[:available_on].lteq(available_on || Time.zone.now ))
|
85
|
+
end
|
77
86
|
|
78
|
-
|
79
|
-
|
87
|
+
#RAILS 3 TODO - this scope doesn't match the original 2.3.x version, needs attention (but it works)
|
88
|
+
def active
|
89
|
+
not_deleted.available
|
90
|
+
end
|
80
91
|
|
81
|
-
|
92
|
+
def on_hand
|
93
|
+
where(Product.arel_table[:count_on_hand].gteq(0))
|
94
|
+
end
|
95
|
+
|
96
|
+
def id_equals(input_id)
|
97
|
+
where(Product.arel_table[:id].eq(input_id))
|
98
|
+
end
|
82
99
|
|
100
|
+
def taxons_name_eq(name)
|
101
|
+
joins(:taxons).where(Taxon.arel_table[:name].eq(name))
|
102
|
+
end
|
103
|
+
end
|
83
104
|
if (ActiveRecord::Base.connection.adapter_name == 'PostgreSQL')
|
84
|
-
if
|
85
|
-
scope :group_by_products_id, { :group =>
|
105
|
+
if Product.table_exists?
|
106
|
+
scope :group_by_products_id, { :group => Product.column_names.map{|col_name| "#{Product.table_name}.#{col_name}"} }
|
86
107
|
end
|
87
108
|
else
|
88
|
-
scope :group_by_products_id, { :group => "
|
109
|
+
scope :group_by_products_id, { :group => "#{Product.table_name}.id" }
|
89
110
|
end
|
90
111
|
search_methods :group_by_products_id
|
91
112
|
|
92
|
-
scope :id_equals, lambda { |input_id| where("products.id = ?", input_id) }
|
93
|
-
|
94
|
-
scope :taxons_name_eq, lambda { |name| joins(:taxons).where("taxons.name = ?", name) }
|
95
|
-
|
96
113
|
# ----------------------------------------------------------------------------------------------------------
|
97
114
|
#
|
98
115
|
# The following methods are deprecated and will be removed in a future version of Spree
|
@@ -130,7 +147,7 @@ class Product < ActiveRecord::Base
|
|
130
147
|
|
131
148
|
# returns true if the product has any variants (the master variant is not a member of the variants array)
|
132
149
|
def has_variants?
|
133
|
-
|
150
|
+
variants.any?
|
134
151
|
end
|
135
152
|
|
136
153
|
# returns the number of inventory units "on_hand" for this product
|
@@ -146,7 +163,7 @@ class Product < ActiveRecord::Base
|
|
146
163
|
|
147
164
|
# Returns true if there are inventory units (any variant) with "on_hand" state for this product
|
148
165
|
def has_stock?
|
149
|
-
master.in_stock? ||
|
166
|
+
master.in_stock? || variants.any?(&:in_stock?)
|
150
167
|
end
|
151
168
|
|
152
169
|
def tax_category
|
@@ -175,30 +192,30 @@ class Product < ActiveRecord::Base
|
|
175
192
|
# for adding products which are closely related to existing ones
|
176
193
|
# define "duplicate_extra" for site-specific actions, eg for additional fields
|
177
194
|
def duplicate
|
178
|
-
p = self.
|
195
|
+
p = self.dup
|
179
196
|
p.name = 'COPY OF ' + self.name
|
180
197
|
p.deleted_at = nil
|
181
198
|
p.created_at = p.updated_at = nil
|
182
199
|
p.taxons = self.taxons
|
183
200
|
|
184
|
-
p.product_properties = self.product_properties.map {|q| r = q.
|
201
|
+
p.product_properties = self.product_properties.map {|q| r = q.dup; r.created_at = r.updated_at = nil; r}
|
185
202
|
|
186
|
-
|
187
|
-
p.images = self.images.map {|i|
|
203
|
+
image_dup = lambda {|i| j = i.dup; j.attachment = i.attachment.clone; j}
|
204
|
+
p.images = self.images.map {|i| image_dup.call i}
|
188
205
|
|
189
|
-
variant = self.master.
|
206
|
+
variant = self.master.dup
|
190
207
|
variant.sku = 'COPY OF ' + self.master.sku
|
191
208
|
variant.deleted_at = nil
|
192
|
-
variant.images = self.master.images.map {|i|
|
209
|
+
variant.images = self.master.images.map {|i| image_dup.call i}
|
193
210
|
p.master = variant
|
194
211
|
|
195
212
|
if self.has_variants?
|
196
|
-
# don't
|
213
|
+
# don't dup the actual variants, just the characterising types
|
197
214
|
p.option_types = self.option_types
|
198
215
|
else
|
199
216
|
end
|
200
217
|
# allow site to do some customization
|
201
|
-
p.send(:duplicate_extra) if p.respond_to?(:duplicate_extra)
|
218
|
+
p.send(:duplicate_extra, self) if p.respond_to?(:duplicate_extra)
|
202
219
|
p.save!
|
203
220
|
p
|
204
221
|
end
|
@@ -217,13 +234,21 @@ class Product < ActiveRecord::Base
|
|
217
234
|
variants.active.group_by {|v| v.option_values.detect {|o| o.option_type == opt_type} }
|
218
235
|
end
|
219
236
|
|
237
|
+
def effective_tax_rate
|
238
|
+
if self.tax_category
|
239
|
+
tax_category.effective_amount
|
240
|
+
else
|
241
|
+
TaxRate.default
|
242
|
+
end
|
243
|
+
end
|
244
|
+
|
220
245
|
def self.like_any(fields, values)
|
221
246
|
where_str = fields.map{|field| Array.new(values.size, "products.#{field} #{LIKE} ?").join(' OR ') }.join(' OR ')
|
222
247
|
self.where([where_str, values.map{|value| "%#{value}%"} * fields.size].flatten)
|
223
248
|
end
|
224
249
|
|
225
250
|
private
|
226
|
-
|
251
|
+
|
227
252
|
def sanitize_permalink
|
228
253
|
self.permalink = self.permalink.to_url
|
229
254
|
end
|