solidus_core 2.10.5 → 2.11.0
Sign up to get free protection for your applications and to get access to all the features.
Potentially problematic release.
This version of solidus_core might be problematic. Click here for more details.
- checksums.yaml +4 -4
- data/app/assets/javascripts/spree.js.erb +31 -2
- data/app/controllers/spree/base_controller.rb +1 -0
- data/app/mailers/spree/base_mailer.rb +4 -0
- data/app/mailers/spree/order_mailer.rb +1 -1
- data/app/models/concerns/spree/active_storage_adapter.rb +116 -0
- data/app/models/concerns/spree/active_storage_adapter/attachment.rb +69 -0
- data/app/models/concerns/spree/active_storage_adapter/normalization.rb +39 -0
- data/app/models/concerns/spree/default_price.rb +1 -1
- data/app/models/concerns/spree/soft_deletable.rb +18 -0
- data/app/models/concerns/spree/user_address_book.rb +86 -32
- data/app/models/concerns/spree/user_methods.rb +3 -2
- data/app/models/spree/ability.rb +34 -10
- data/app/models/spree/address.rb +94 -17
- data/app/models/spree/address/name.rb +49 -0
- data/app/models/spree/address/state_validator.rb +71 -0
- data/app/models/spree/adjustment.rb +1 -1
- data/app/models/spree/base.rb +1 -0
- data/app/models/spree/calculator/default_tax.rb +1 -1
- data/app/models/spree/calculator/percent_per_item.rb +4 -4
- data/app/models/spree/calculator/price_sack.rb +1 -1
- data/app/models/spree/credit_card.rb +2 -2
- data/app/models/spree/customer_return.rb +4 -2
- data/app/models/spree/exchange.rb +1 -1
- data/app/models/spree/image/active_storage_attachment.rb +21 -0
- data/app/models/spree/inventory_unit.rb +1 -1
- data/app/models/spree/line_item.rb +13 -4
- data/app/models/spree/option_type.rb +1 -1
- data/app/models/spree/option_value.rb +2 -2
- data/app/models/spree/order.rb +91 -20
- data/app/models/spree/order/checkout.rb +1 -0
- data/app/models/spree/order_inventory.rb +16 -4
- data/app/models/spree/order_merger.rb +6 -4
- data/app/models/spree/order_promotion.rb +1 -1
- data/app/models/spree/order_updater.rb +11 -10
- data/app/models/spree/payment.rb +3 -3
- data/app/models/spree/payment/cancellation.rb +3 -3
- data/app/models/spree/payment/processing.rb +54 -30
- data/app/models/spree/payment_method.rb +8 -9
- data/app/models/spree/preference.rb +1 -1
- data/app/models/spree/price.rb +2 -8
- data/app/models/spree/product.rb +19 -14
- data/app/models/spree/product/scopes.rb +9 -4
- data/app/models/spree/promotion.rb +18 -7
- data/app/models/spree/promotion/actions/free_shipping.rb +6 -5
- data/app/models/spree/promotion_action.rb +1 -7
- data/app/models/spree/promotion_code.rb +6 -1
- data/app/models/spree/promotion_code_batch.rb +1 -1
- data/app/models/spree/promotion_handler/coupon.rb +2 -2
- data/app/models/spree/promotion_rule.rb +1 -1
- data/app/models/spree/promotion_rule_role.rb +1 -1
- data/app/models/spree/refund.rb +54 -12
- data/app/models/spree/reimbursement.rb +27 -0
- data/app/models/spree/reimbursement_type/reimbursement_helpers.rb +10 -3
- data/app/models/spree/return_authorization.rb +1 -1
- data/app/models/spree/return_item.rb +21 -10
- data/app/models/spree/return_item/exchange_variant_eligibility/same_option_value.rb +1 -1
- data/app/models/spree/role.rb +1 -1
- data/app/models/spree/shipment.rb +2 -2
- data/app/models/spree/shipping_calculator.rb +1 -1
- data/app/models/spree/shipping_manifest.rb +2 -2
- data/app/models/spree/shipping_method.rb +2 -9
- data/app/models/spree/shipping_rate.rb +1 -1
- data/app/models/spree/shipping_rate_tax.rb +1 -1
- data/app/models/spree/stock/inventory_unit_builder.rb +18 -7
- data/app/models/spree/stock/inventory_units_finalizer.rb +3 -5
- data/app/models/spree/stock/package.rb +1 -1
- data/app/models/spree/stock/simple_coordinator.rb +1 -3
- data/app/models/spree/stock_item.rb +2 -8
- data/app/models/spree/stock_movement.rb +2 -0
- data/app/models/spree/store.rb +1 -1
- data/app/models/spree/store_credit.rb +1 -7
- data/app/models/spree/store_credit_category.rb +30 -3
- data/app/models/spree/store_credit_event.rb +1 -7
- data/app/models/spree/store_credit_reason.rb +0 -4
- data/app/models/spree/tax/tax_helpers.rb +1 -1
- data/app/models/spree/tax_category.rb +2 -8
- data/app/models/spree/tax_rate.rb +7 -7
- data/app/models/spree/taxon.rb +1 -1
- data/app/models/spree/taxon/active_storage_attachment.rb +19 -0
- data/app/models/spree/user_address.rb +8 -2
- data/app/models/spree/variant.rb +7 -13
- data/app/models/spree/variant_property_rule.rb +5 -1
- data/app/models/spree/wallet/add_payment_sources_to_wallet.rb +8 -3
- data/app/models/spree/zone.rb +1 -1
- data/config/locales/en.yml +44 -5
- data/db/default/spree/countries.rb +1 -1
- data/db/default/spree/states.rb +12 -4
- data/db/default/spree/store_credit.rb +2 -2
- data/db/migrate/20180416083007_add_apply_to_all_to_variant_property_rule.rb +12 -0
- data/db/migrate/20200320144521_add_default_billng_flag_to_user_addresses.rb +6 -0
- data/db/migrate/20200530111458_add_bcc_email_to_spree_stores.rb +7 -0
- data/db/migrate/20201008213609_add_discontinue_on_to_spree_products.rb +7 -0
- data/lib/generators/solidus/install/install_generator.rb +253 -0
- data/lib/generators/{spree → solidus}/install/templates/config/initializers/spree.rb.tt +36 -5
- data/lib/generators/{spree → solidus}/install/templates/vendor/assets/javascripts/spree/backend/all.js +0 -0
- data/lib/generators/{spree → solidus}/install/templates/vendor/assets/javascripts/spree/frontend/all.js +0 -0
- data/lib/generators/{spree → solidus}/install/templates/vendor/assets/stylesheets/spree/backend/all.css +0 -0
- data/lib/generators/{spree → solidus}/install/templates/vendor/assets/stylesheets/spree/frontend/all.css +0 -0
- data/lib/generators/spree/install/install_generator.rb +7 -189
- data/lib/solidus/migrations/promotions_with_code_handlers.rb +1 -1
- data/lib/spree/app_configuration.rb +117 -51
- data/lib/spree/awesome_nested_set_override.rb +44 -0
- data/lib/spree/core.rb +5 -11
- data/lib/spree/core/controller_helpers/auth.rb +17 -4
- data/lib/spree/core/controller_helpers/current_host.rb +17 -0
- data/lib/spree/core/controller_helpers/order.rb +8 -7
- data/lib/spree/core/engine.rb +39 -2
- data/lib/spree/core/importer/order.rb +24 -10
- data/lib/spree/core/permalinks.rb +1 -3
- data/lib/spree/core/product_filters.rb +6 -5
- data/lib/spree/core/state_machines.rb +20 -1
- data/lib/spree/core/state_machines/order.rb +249 -0
- data/lib/spree/core/state_machines/return_item/reception_status.rb +2 -2
- data/lib/spree/core/version.rb +1 -1
- data/lib/spree/encryptor.rb +25 -0
- data/lib/spree/event.rb +40 -7
- data/lib/spree/event/adapters/active_support_notifications.rb +32 -0
- data/lib/spree/event/configuration.rb +11 -6
- data/lib/spree/event/subscriber.rb +38 -18
- data/lib/spree/event/subscriber_registry.rb +92 -0
- data/lib/spree/i18n.rb +1 -1
- data/lib/spree/mailer_previews/carton_preview.rb +2 -1
- data/lib/spree/paranoia_deprecations.rb +32 -12
- data/lib/spree/permission_sets/configuration_display.rb +14 -14
- data/lib/spree/permission_sets/default_customer.rb +16 -16
- data/lib/spree/permission_sets/order_display.rb +11 -11
- data/lib/spree/permission_sets/order_management.rb +1 -1
- data/lib/spree/permission_sets/product_display.rb +9 -9
- data/lib/spree/permission_sets/promotion_display.rb +5 -5
- data/lib/spree/permission_sets/restricted_stock_display.rb +2 -2
- data/lib/spree/permission_sets/restricted_stock_management.rb +1 -1
- data/lib/spree/permission_sets/stock_display.rb +2 -2
- data/lib/spree/permission_sets/stock_management.rb +1 -1
- data/lib/spree/permission_sets/user_display.rb +3 -3
- data/lib/spree/permission_sets/user_management.rb +4 -3
- data/lib/spree/permitted_attributes.rb +4 -3
- data/lib/spree/preferences/preferable.rb +4 -3
- data/lib/spree/preferences/preferable_class_methods.rb +22 -3
- data/lib/spree/testing_support/ability_helpers.rb +9 -9
- data/lib/spree/testing_support/authorization_helpers.rb +1 -0
- data/lib/spree/testing_support/blacklist_urls.rb +23 -0
- data/lib/spree/testing_support/capybara_ext.rb +3 -0
- data/lib/spree/testing_support/common_rake.rb +3 -3
- data/lib/spree/testing_support/dummy_app.rb +44 -23
- data/lib/spree/testing_support/dummy_app/migrations.rb +5 -6
- data/lib/spree/testing_support/dummy_app/rake_tasks.rb +1 -3
- data/lib/spree/testing_support/factories/address_factory.rb +1 -2
- data/lib/spree/testing_support/factories/image_factory.rb +1 -1
- data/lib/spree/testing_support/factories/promotion_factory.rb +6 -0
- data/lib/spree/testing_support/factories/refund_factory.rb +1 -0
- data/lib/spree/testing_support/factories/reimbursement_factory.rb +1 -1
- data/lib/spree/testing_support/factories/return_item_factory.rb +0 -1
- data/lib/spree/testing_support/factories/store_credit_category_factory.rb +8 -0
- data/lib/spree/testing_support/factories/store_credit_event_factory.rb +1 -0
- data/lib/spree/testing_support/factories/store_credit_reason_factory.rb +3 -1
- data/lib/spree/testing_support/factories/taxon_factory.rb +4 -0
- data/lib/spree/testing_support/factories/zone_factory.rb +1 -1
- data/lib/spree/testing_support/job_helpers.rb +24 -0
- data/lib/spree/testing_support/precompiled_assets.rb +15 -0
- data/lib/spree/testing_support/preferences.rb +3 -1
- data/lib/spree/testing_support/shared_examples/gallery.rb +1 -1
- data/lib/spree/testing_support/translations.rb +25 -0
- data/solidus_core.gemspec +7 -4
- metadata +91 -370
- data/script/rails +0 -10
- data/spec/fixtures/thinking-cat.jpg +0 -0
- data/spec/helpers/base_helper_spec.rb +0 -168
- data/spec/helpers/products_helper_spec.rb +0 -202
- data/spec/helpers/taxons_helper_spec.rb +0 -43
- data/spec/jobs/promotion_code_batch_job_spec.rb +0 -96
- data/spec/lib/calculated_adjustments_spec.rb +0 -133
- data/spec/lib/i18n_spec.rb +0 -97
- data/spec/lib/search/base_spec.rb +0 -91
- data/spec/lib/search/variant_spec.rb +0 -115
- data/spec/lib/spree/app_configuration_spec.rb +0 -140
- data/spec/lib/spree/core/class_constantizer_spec.rb +0 -91
- data/spec/lib/spree/core/controller_helpers/auth_spec.rb +0 -73
- data/spec/lib/spree/core/controller_helpers/order_spec.rb +0 -126
- data/spec/lib/spree/core/controller_helpers/payment_parameters_spec.rb +0 -195
- data/spec/lib/spree/core/controller_helpers/pricing_spec.rb +0 -94
- data/spec/lib/spree/core/controller_helpers/search_spec.rb +0 -21
- data/spec/lib/spree/core/controller_helpers/store_spec.rb +0 -18
- data/spec/lib/spree/core/controller_helpers/strong_parameters_spec.rb +0 -48
- data/spec/lib/spree/core/current_store_spec.rb +0 -33
- data/spec/lib/spree/core/environment_extension_spec.rb +0 -46
- data/spec/lib/spree/core/importer/order_spec.rb +0 -484
- data/spec/lib/spree/core/role_configuration_spec.rb +0 -155
- data/spec/lib/spree/core/stock_configuration_spec.rb +0 -95
- data/spec/lib/spree/core/testing_support/factories/address_factory_spec.rb +0 -61
- data/spec/lib/spree/core/testing_support/factories/adjustment_factory_spec.rb +0 -20
- data/spec/lib/spree/core/testing_support/factories/adjustment_reason_factory_spec.rb +0 -14
- data/spec/lib/spree/core/testing_support/factories/calculator_factory_spec.rb +0 -44
- data/spec/lib/spree/core/testing_support/factories/carton_factory_spec.rb +0 -14
- data/spec/lib/spree/core/testing_support/factories/country_factory_spec.rb +0 -14
- data/spec/lib/spree/core/testing_support/factories/credit_card_factory_spec.rb +0 -14
- data/spec/lib/spree/core/testing_support/factories/customer_return_factory_spec.rb +0 -39
- data/spec/lib/spree/core/testing_support/factories/image_factory_spec.rb +0 -14
- data/spec/lib/spree/core/testing_support/factories/inventory_unit_factory_spec.rb +0 -14
- data/spec/lib/spree/core/testing_support/factories/line_item_factory_spec.rb +0 -14
- data/spec/lib/spree/core/testing_support/factories/option_type_factory_spec.rb +0 -14
- data/spec/lib/spree/core/testing_support/factories/option_value_factory_spec.rb +0 -14
- data/spec/lib/spree/core/testing_support/factories/order_factory_spec.rb +0 -376
- data/spec/lib/spree/core/testing_support/factories/order_promotion_factory_spec.rb +0 -14
- data/spec/lib/spree/core/testing_support/factories/payment_factory_spec.rb +0 -40
- data/spec/lib/spree/core/testing_support/factories/payment_method_factory_spec.rb +0 -32
- data/spec/lib/spree/core/testing_support/factories/price_factory_spec.rb +0 -14
- data/spec/lib/spree/core/testing_support/factories/product_factory_spec.rb +0 -32
- data/spec/lib/spree/core/testing_support/factories/product_option_type_factory_spec.rb +0 -14
- data/spec/lib/spree/core/testing_support/factories/product_property_factory_spec.rb +0 -14
- data/spec/lib/spree/core/testing_support/factories/promotion_category_factory_spec.rb +0 -14
- data/spec/lib/spree/core/testing_support/factories/promotion_code_factory_spec.rb +0 -14
- data/spec/lib/spree/core/testing_support/factories/promotion_factory_spec.rb +0 -32
- data/spec/lib/spree/core/testing_support/factories/property_factory_spec.rb +0 -14
- data/spec/lib/spree/core/testing_support/factories/refund_factory_spec.rb +0 -14
- data/spec/lib/spree/core/testing_support/factories/refund_reason_factory_spec.rb +0 -14
- data/spec/lib/spree/core/testing_support/factories/reimbursement_factory_spec.rb +0 -20
- data/spec/lib/spree/core/testing_support/factories/reimbursement_type_factory_spec.rb +0 -14
- data/spec/lib/spree/core/testing_support/factories/return_authorization_factory_spec.rb +0 -14
- data/spec/lib/spree/core/testing_support/factories/return_item_factory_spec.rb +0 -20
- data/spec/lib/spree/core/testing_support/factories/return_reason_factory_spec.rb +0 -14
- data/spec/lib/spree/core/testing_support/factories/role_factory_spec.rb +0 -20
- data/spec/lib/spree/core/testing_support/factories/shipment_factory_spec.rb +0 -14
- data/spec/lib/spree/core/testing_support/factories/shipping_category_factory_spec.rb +0 -14
- data/spec/lib/spree/core/testing_support/factories/shipping_method_factory_spec.rb +0 -44
- data/spec/lib/spree/core/testing_support/factories/shipping_rate_factory_spec.rb +0 -14
- data/spec/lib/spree/core/testing_support/factories/state_factory_spec.rb +0 -59
- data/spec/lib/spree/core/testing_support/factories/stock_item_factory_spec.rb +0 -14
- data/spec/lib/spree/core/testing_support/factories/stock_location_factory_spec.rb +0 -35
- data/spec/lib/spree/core/testing_support/factories/stock_movement_factory_spec.rb +0 -14
- data/spec/lib/spree/core/testing_support/factories/stock_package_factory_spec.rb +0 -28
- data/spec/lib/spree/core/testing_support/factories/store_credit_category_factory_spec.rb +0 -14
- data/spec/lib/spree/core/testing_support/factories/store_credit_event_factory_spec.rb +0 -43
- data/spec/lib/spree/core/testing_support/factories/store_credit_factory_spec.rb +0 -14
- data/spec/lib/spree/core/testing_support/factories/store_credit_reason_factory_spec.rb +0 -14
- data/spec/lib/spree/core/testing_support/factories/store_credit_type_factory_spec.rb +0 -20
- data/spec/lib/spree/core/testing_support/factories/store_factory_spec.rb +0 -14
- data/spec/lib/spree/core/testing_support/factories/tax_category_factory_spec.rb +0 -14
- data/spec/lib/spree/core/testing_support/factories/tax_rate_factory_spec.rb +0 -14
- data/spec/lib/spree/core/testing_support/factories/taxon_factory_spec.rb +0 -14
- data/spec/lib/spree/core/testing_support/factories/taxonomy_factory_spec.rb +0 -14
- data/spec/lib/spree/core/testing_support/factories/user_factory_spec.rb +0 -24
- data/spec/lib/spree/core/testing_support/factories/variant_factory_spec.rb +0 -56
- data/spec/lib/spree/core/testing_support/factories/variant_property_rule_condition_factory_spec.rb +0 -14
- data/spec/lib/spree/core/testing_support/factories/variant_property_rule_factory_spec.rb +0 -14
- data/spec/lib/spree/core/testing_support/factories/variant_property_rule_value_factory_spec.rb +0 -14
- data/spec/lib/spree/core/testing_support/factories/zone_factory_spec.rb +0 -20
- data/spec/lib/spree/core/testing_support/preferences_spec.rb +0 -61
- data/spec/lib/spree/core/validators/email_spec.rb +0 -53
- data/spec/lib/spree/core/version_spec.rb +0 -19
- data/spec/lib/spree/event/subscriber_spec.rb +0 -85
- data/spec/lib/spree/event_spec.rb +0 -130
- data/spec/lib/spree/localized_number_spec.rb +0 -45
- data/spec/lib/spree/migrations_spec.rb +0 -32
- data/spec/lib/spree/money_spec.rb +0 -298
- data/spec/lib/spree/permission_sets/default_customer_spec.rb +0 -22
- data/spec/lib/spree/permitted_attributes_spec.rb +0 -41
- data/spec/lib/spree/promo/environment_spec.rb +0 -53
- data/spec/lib/tasks/dummy_task.rake +0 -12
- data/spec/lib/tasks/dummy_task_spec.rb +0 -30
- data/spec/lib/tasks/migrations/migrate_shipping_rate_taxes_spec.rb +0 -21
- data/spec/mailers/carton_mailer_spec.rb +0 -44
- data/spec/mailers/order_mailer_spec.rb +0 -117
- data/spec/mailers/promotion_code_batch_mailer_spec.rb +0 -47
- data/spec/mailers/reimbursement_mailer_spec.rb +0 -36
- data/spec/mailers/test_mailer_spec.rb +0 -13
- data/spec/models/spree/ability_spec.rb +0 -279
- data/spec/models/spree/address_spec.rb +0 -399
- data/spec/models/spree/adjustment_reason_spec.rb +0 -11
- data/spec/models/spree/adjustment_spec.rb +0 -339
- data/spec/models/spree/asset_spec.rb +0 -25
- data/spec/models/spree/calculator/default_tax_spec.rb +0 -260
- data/spec/models/spree/calculator/distributed_amount_spec.rb +0 -82
- data/spec/models/spree/calculator/flat_percent_item_total_spec.rb +0 -39
- data/spec/models/spree/calculator/flat_rate_spec.rb +0 -52
- data/spec/models/spree/calculator/flexi_rate_spec.rb +0 -158
- data/spec/models/spree/calculator/free_shipping_spec.rb +0 -8
- data/spec/models/spree/calculator/percent_on_line_item_spec.rb +0 -20
- data/spec/models/spree/calculator/percent_per_item_spec.rb +0 -12
- data/spec/models/spree/calculator/price_sack_spec.rb +0 -35
- data/spec/models/spree/calculator/refunds/default_refund_amount_spec.rb +0 -70
- data/spec/models/spree/calculator/shipping/flat_percent_item_total_spec.rb +0 -44
- data/spec/models/spree/calculator/shipping/flat_rate_spec.rb +0 -18
- data/spec/models/spree/calculator/shipping/flexi_rate_spec.rb +0 -56
- data/spec/models/spree/calculator/shipping/per_item_spec.rb +0 -25
- data/spec/models/spree/calculator/shipping/price_sack_spec.rb +0 -44
- data/spec/models/spree/calculator/tiered_flat_rate_spec.rb +0 -99
- data/spec/models/spree/calculator/tiered_percent_spec.rb +0 -197
- data/spec/models/spree/calculator_spec.rb +0 -43
- data/spec/models/spree/carton_spec.rb +0 -145
- data/spec/models/spree/classification_spec.rb +0 -126
- data/spec/models/spree/concerns/display_money_spec.rb +0 -44
- data/spec/models/spree/concerns/ordered_property_value_list_spec.rb +0 -52
- data/spec/models/spree/concerns/user_address_book_spec.rb +0 -358
- data/spec/models/spree/concerns/user_methods_spec.rb +0 -122
- data/spec/models/spree/country_spec.rb +0 -154
- data/spec/models/spree/credit_card_spec.rb +0 -373
- data/spec/models/spree/customer_return_spec.rb +0 -294
- data/spec/models/spree/distributed_amounts_handler_spec.rb +0 -83
- data/spec/models/spree/exchange_spec.rb +0 -76
- data/spec/models/spree/fulfilment_changer_spec.rb +0 -340
- data/spec/models/spree/gallery/product_gallery_spec.rb +0 -21
- data/spec/models/spree/gallery/variant_gallery_spec.rb +0 -21
- data/spec/models/spree/gateway/bogus_simple.rb +0 -14
- data/spec/models/spree/gateway/bogus_spec.rb +0 -14
- data/spec/models/spree/gateway_spec.rb +0 -14
- data/spec/models/spree/image_spec.rb +0 -25
- data/spec/models/spree/inventory_unit_spec.rb +0 -309
- data/spec/models/spree/line_item_spec.rb +0 -240
- data/spec/models/spree/option_type_spec.rb +0 -16
- data/spec/models/spree/option_value_spec.rb +0 -52
- data/spec/models/spree/order/address_spec.rb +0 -52
- data/spec/models/spree/order/adjustments_spec.rb +0 -29
- data/spec/models/spree/order/callbacks_spec.rb +0 -44
- data/spec/models/spree/order/checkout_spec.rb +0 -740
- data/spec/models/spree/order/finalizing_spec.rb +0 -92
- data/spec/models/spree/order/number_generator_spec.rb +0 -47
- data/spec/models/spree/order/outstanding_balance_integration_spec.rb +0 -138
- data/spec/models/spree/order/payment_spec.rb +0 -280
- data/spec/models/spree/order/risk_assessment_spec.rb +0 -70
- data/spec/models/spree/order/state_machine_spec.rb +0 -122
- data/spec/models/spree/order/totals_spec.rb +0 -26
- data/spec/models/spree/order/validations_spec.rb +0 -17
- data/spec/models/spree/order_cancellations_spec.rb +0 -233
- data/spec/models/spree/order_capturing_spec.rb +0 -16
- data/spec/models/spree/order_contents_spec.rb +0 -362
- data/spec/models/spree/order_inventory_spec.rb +0 -285
- data/spec/models/spree/order_merger_spec.rb +0 -162
- data/spec/models/spree/order_mutex_spec.rb +0 -89
- data/spec/models/spree/order_promotion_spec.rb +0 -33
- data/spec/models/spree/order_shipping_spec.rb +0 -247
- data/spec/models/spree/order_spec.rb +0 -1687
- data/spec/models/spree/order_taxation_spec.rb +0 -128
- data/spec/models/spree/order_update_attributes_spec.rb +0 -49
- data/spec/models/spree/order_updater_spec.rb +0 -556
- data/spec/models/spree/payment/cancellation_spec.rb +0 -84
- data/spec/models/spree/payment_create_spec.rb +0 -195
- data/spec/models/spree/payment_method/bogus_credit_card_spec.rb +0 -10
- data/spec/models/spree/payment_method/check_spec.rb +0 -80
- data/spec/models/spree/payment_method/credit_card_spec.rb +0 -68
- data/spec/models/spree/payment_method/simple_bogus_credit_card_spec.rb +0 -20
- data/spec/models/spree/payment_method/store_credit_spec.rb +0 -325
- data/spec/models/spree/payment_method_spec.rb +0 -408
- data/spec/models/spree/payment_spec.rb +0 -1270
- data/spec/models/spree/permission_sets/base_spec.rb +0 -14
- data/spec/models/spree/permission_sets/configuration_display.rb +0 -79
- data/spec/models/spree/permission_sets/configuration_management_spec.rb +0 -49
- data/spec/models/spree/permission_sets/dashboard_display_spec.rb +0 -23
- data/spec/models/spree/permission_sets/order_display_spec.rb +0 -56
- data/spec/models/spree/permission_sets/order_management_spec.rb +0 -43
- data/spec/models/spree/permission_sets/product_display_spec.rb +0 -57
- data/spec/models/spree/permission_sets/product_management_spec.rb +0 -39
- data/spec/models/spree/permission_sets/promotion_display_spec.rb +0 -41
- data/spec/models/spree/permission_sets/promotion_management_spec.rb +0 -29
- data/spec/models/spree/permission_sets/restricted_stock_display_spec.rb +0 -42
- data/spec/models/spree/permission_sets/restricted_stock_management_spec.rb +0 -42
- data/spec/models/spree/permission_sets/stock_display_spec.rb +0 -25
- data/spec/models/spree/permission_sets/stock_management_spec.rb +0 -23
- data/spec/models/spree/permission_sets/user_display_spec.rb +0 -39
- data/spec/models/spree/permission_sets/user_management_spec.rb +0 -58
- data/spec/models/spree/preference_spec.rb +0 -79
- data/spec/models/spree/preferences/configuration_spec.rb +0 -27
- data/spec/models/spree/preferences/preferable_spec.rb +0 -334
- data/spec/models/spree/preferences/scoped_store_spec.rb +0 -62
- data/spec/models/spree/preferences/static_model_preferences_spec.rb +0 -79
- data/spec/models/spree/preferences/statically_configurable_spec.rb +0 -67
- data/spec/models/spree/preferences/store_spec.rb +0 -40
- data/spec/models/spree/price_spec.rb +0 -150
- data/spec/models/spree/product/scopes_spec.rb +0 -164
- data/spec/models/spree/product_duplicator_spec.rb +0 -92
- data/spec/models/spree/product_filter_spec.rb +0 -28
- data/spec/models/spree/product_property_spec.rb +0 -20
- data/spec/models/spree/product_spec.rb +0 -584
- data/spec/models/spree/promotion/actions/create_adjustment_spec.rb +0 -126
- data/spec/models/spree/promotion/actions/create_item_adjustments_spec.rb +0 -198
- data/spec/models/spree/promotion/actions/create_quantity_adjustments_spec.rb +0 -298
- data/spec/models/spree/promotion/actions/free_shipping_spec.rb +0 -61
- data/spec/models/spree/promotion/rules/first_order_spec.rb +0 -87
- data/spec/models/spree/promotion/rules/first_repeat_purchase_since_spec.rb +0 -71
- data/spec/models/spree/promotion/rules/item_total_spec.rb +0 -128
- data/spec/models/spree/promotion/rules/nth_order_spec.rb +0 -72
- data/spec/models/spree/promotion/rules/one_use_per_user_spec.rb +0 -54
- data/spec/models/spree/promotion/rules/option_value_spec.rb +0 -96
- data/spec/models/spree/promotion/rules/product_spec.rb +0 -193
- data/spec/models/spree/promotion/rules/store_spec.rb +0 -35
- data/spec/models/spree/promotion/rules/taxon_spec.rb +0 -227
- data/spec/models/spree/promotion/rules/user_logged_in_spec.rb +0 -33
- data/spec/models/spree/promotion/rules/user_role_spec.rb +0 -88
- data/spec/models/spree/promotion/rules/user_spec.rb +0 -39
- data/spec/models/spree/promotion_action_spec.rb +0 -44
- data/spec/models/spree/promotion_category_spec.rb +0 -19
- data/spec/models/spree/promotion_code/batch_builder_spec.rb +0 -107
- data/spec/models/spree/promotion_code_batch_spec.rb +0 -54
- data/spec/models/spree/promotion_code_spec.rb +0 -206
- data/spec/models/spree/promotion_handler/cart_spec.rb +0 -132
- data/spec/models/spree/promotion_handler/coupon_spec.rb +0 -419
- data/spec/models/spree/promotion_handler/page_spec.rb +0 -45
- data/spec/models/spree/promotion_handler/shipping_spec.rb +0 -96
- data/spec/models/spree/promotion_rule_spec.rb +0 -34
- data/spec/models/spree/promotion_spec.rb +0 -945
- data/spec/models/spree/refund_spec.rb +0 -200
- data/spec/models/spree/reimbursement/credit_spec.rb +0 -38
- data/spec/models/spree/reimbursement/reimbursement_type_engine_spec.rb +0 -144
- data/spec/models/spree/reimbursement/reimbursement_type_validator_spec.rb +0 -85
- data/spec/models/spree/reimbursement_performer_spec.rb +0 -33
- data/spec/models/spree/reimbursement_spec.rb +0 -278
- data/spec/models/spree/reimbursement_tax_calculator_spec.rb +0 -52
- data/spec/models/spree/reimbursement_type/credit_spec.rb +0 -56
- data/spec/models/spree/reimbursement_type/exchange_spec.rb +0 -48
- data/spec/models/spree/reimbursement_type/original_payment_spec.rb +0 -110
- data/spec/models/spree/reimbursement_type/store_credit_spec.rb +0 -111
- data/spec/models/spree/return_authorization_spec.rb +0 -226
- data/spec/models/spree/return_item/eligibility_validator/default_spec.rb +0 -79
- data/spec/models/spree/return_item/eligibility_validator/inventory_shipped_spec.rb +0 -59
- data/spec/models/spree/return_item/eligibility_validator/no_reimbursements_spec.rb +0 -86
- data/spec/models/spree/return_item/eligibility_validator/order_completed_spec.rb +0 -35
- data/spec/models/spree/return_item/eligibility_validator/rma_required_spec.rb +0 -31
- data/spec/models/spree/return_item/eligibility_validator/time_since_purchase_spec.rb +0 -42
- data/spec/models/spree/return_item/exchange_variant_eligibility/same_option_value_spec.rb +0 -66
- data/spec/models/spree/return_item/exchange_variant_eligibility/same_product_spec.rb +0 -43
- data/spec/models/spree/return_item_spec.rb +0 -785
- data/spec/models/spree/returns_calculator_spec.rb +0 -16
- data/spec/models/spree/shipment_spec.rb +0 -914
- data/spec/models/spree/shipping_calculator_spec.rb +0 -45
- data/spec/models/spree/shipping_manifest_spec.rb +0 -110
- data/spec/models/spree/shipping_method_spec.rb +0 -292
- data/spec/models/spree/shipping_rate_spec.rb +0 -154
- data/spec/models/spree/shipping_rate_tax_spec.rb +0 -79
- data/spec/models/spree/state_spec.rb +0 -43
- data/spec/models/spree/stock/allocator/on_hand_first_spec.rb +0 -146
- data/spec/models/spree/stock/availability_spec.rb +0 -143
- data/spec/models/spree/stock/availability_validator_spec.rb +0 -140
- data/spec/models/spree/stock/content_item_spec.rb +0 -70
- data/spec/models/spree/stock/differentiator_spec.rb +0 -41
- data/spec/models/spree/stock/estimator_spec.rb +0 -241
- data/spec/models/spree/stock/inventory_unit_builder_spec.rb +0 -34
- data/spec/models/spree/stock/inventory_units_finalizer_spec.rb +0 -58
- data/spec/models/spree/stock/location_filter/active_spec.rb +0 -22
- data/spec/models/spree/stock/location_sorter/default_first_spec.rb +0 -22
- data/spec/models/spree/stock/location_sorter/unsorted_spec.rb +0 -21
- data/spec/models/spree/stock/package_spec.rb +0 -182
- data/spec/models/spree/stock/quantifier_spec.rb +0 -113
- data/spec/models/spree/stock/shipping_rate_selector_spec.rb +0 -18
- data/spec/models/spree/stock/shipping_rate_sorter_spec.rb +0 -18
- data/spec/models/spree/stock/simple_coordinator_spec.rb +0 -264
- data/spec/models/spree/stock/splitter/backordered_spec.rb +0 -31
- data/spec/models/spree/stock/splitter/base_spec.rb +0 -22
- data/spec/models/spree/stock/splitter/shipping_category_spec.rb +0 -48
- data/spec/models/spree/stock/splitter/weight_spec.rb +0 -31
- data/spec/models/spree/stock/splitter_chain_spec.rb +0 -66
- data/spec/models/spree/stock_item_spec.rb +0 -348
- data/spec/models/spree/stock_location_spec.rb +0 -288
- data/spec/models/spree/stock_movement_spec.rb +0 -58
- data/spec/models/spree/stock_quantities_spec.rb +0 -249
- data/spec/models/spree/store_credit_category_spec.rb +0 -19
- data/spec/models/spree/store_credit_event_spec.rb +0 -328
- data/spec/models/spree/store_credit_spec.rb +0 -900
- data/spec/models/spree/store_selector/by_server_name_spec.rb +0 -28
- data/spec/models/spree/store_selector/legacy_spec.rb +0 -46
- data/spec/models/spree/store_spec.rb +0 -156
- data/spec/models/spree/tax/order_adjuster_spec.rb +0 -35
- data/spec/models/spree/tax/shipping_rate_taxer_spec.rb +0 -59
- data/spec/models/spree/tax/tax_location_spec.rb +0 -79
- data/spec/models/spree/tax/taxation_integration_spec.rb +0 -815
- data/spec/models/spree/tax_calculator/default_spec.rb +0 -56
- data/spec/models/spree/tax_category_spec.rb +0 -50
- data/spec/models/spree/tax_rate_spec.rb +0 -317
- data/spec/models/spree/taxon_spec.rb +0 -197
- data/spec/models/spree/taxonomy_spec.rb +0 -15
- data/spec/models/spree/taxons/paperclip_attachment_spec.rb +0 -29
- data/spec/models/spree/unit_cancel_spec.rb +0 -126
- data/spec/models/spree/user_last_url_storer/rules/authentication_rule_spec.rb +0 -31
- data/spec/models/spree/user_last_url_storer_spec.rb +0 -60
- data/spec/models/spree/user_spec.rb +0 -247
- data/spec/models/spree/validations/db_maximum_length_validator_spec.rb +0 -33
- data/spec/models/spree/variant/price_selector_spec.rb +0 -90
- data/spec/models/spree/variant/pricing_options_spec.rb +0 -204
- data/spec/models/spree/variant/scopes_spec.rb +0 -94
- data/spec/models/spree/variant/vat_price_generator_spec.rb +0 -77
- data/spec/models/spree/variant_property_rule_condition_spec.rb +0 -17
- data/spec/models/spree/variant_property_rule_spec.rb +0 -85
- data/spec/models/spree/variant_property_rule_value_spec.rb +0 -20
- data/spec/models/spree/variant_spec.rb +0 -862
- data/spec/models/spree/wallet_payment_source_spec.rb +0 -77
- data/spec/models/spree/wallet_spec.rb +0 -155
- data/spec/models/spree/zone_spec.rb +0 -248
- data/spec/rails_helper.rb +0 -46
- data/spec/shared_examples/calculator_shared_examples.rb +0 -10
- data/spec/spec_helper.rb +0 -36
- data/spec/support/big_decimal.rb +0 -7
- data/spec/support/concerns/default_price.rb +0 -44
- data/spec/support/concerns/payment_source.rb +0 -66
- data/spec/support/concerns/working_factories.rb +0 -15
- data/spec/support/dummy_ability.rb +0 -7
@@ -34,12 +34,13 @@ module Spree
|
|
34
34
|
|
35
35
|
include Spree::RansackableAttributes unless included_modules.include?(Spree::RansackableAttributes)
|
36
36
|
|
37
|
+
ransack_alias :firstname_or_lastname, :addresses_firstname_or_addresses_lastname
|
37
38
|
self.whitelisted_ransackable_associations = %w[addresses spree_roles]
|
38
|
-
self.whitelisted_ransackable_attributes = %w[id email created_at]
|
39
|
+
self.whitelisted_ransackable_attributes = %w[firstname_or_lastname id email created_at]
|
39
40
|
end
|
40
41
|
|
41
42
|
def wallet
|
42
|
-
Spree::Wallet.new(self)
|
43
|
+
@wallet ||= Spree::Wallet.new(self)
|
43
44
|
end
|
44
45
|
|
45
46
|
# has_spree_role? simply needs to return true or false whether a user has a role or not.
|
data/app/models/spree/ability.rb
CHANGED
@@ -14,6 +14,13 @@ module Spree
|
|
14
14
|
|
15
15
|
attr_reader :user
|
16
16
|
|
17
|
+
CUSTOM_ALIASES_MAP = {
|
18
|
+
delete: :destroy,
|
19
|
+
display: :read,
|
20
|
+
new_action: :create,
|
21
|
+
read: :show
|
22
|
+
}.freeze
|
23
|
+
|
17
24
|
# Allows us to go beyond the standard cancan initialize method which makes it difficult for engines to
|
18
25
|
# modify the default +Ability+ of an application. The +ability+ argument must be a class that includes
|
19
26
|
# the +CanCan::Ability+ module. The registered ability should behave properly as a stand-alone class
|
@@ -29,23 +36,40 @@ module Spree
|
|
29
36
|
def initialize(current_user)
|
30
37
|
@user = current_user || Spree.user_class.new
|
31
38
|
|
32
|
-
alias_actions
|
33
39
|
activate_permission_sets
|
34
40
|
register_extension_abilities
|
35
41
|
end
|
36
42
|
|
43
|
+
def can?(action, *args)
|
44
|
+
super(normalize_action(action), *args)
|
45
|
+
end
|
46
|
+
|
47
|
+
def model_adapter(model_class, action)
|
48
|
+
super(model_class, normalize_action(action))
|
49
|
+
end
|
50
|
+
|
37
51
|
private
|
38
52
|
|
39
|
-
def
|
40
|
-
|
53
|
+
def normalize_action(action)
|
54
|
+
return action unless Spree::Config.use_custom_cancancan_actions
|
55
|
+
|
56
|
+
normalized_action = CUSTOM_ALIASES_MAP.fetch(action, action)
|
57
|
+
|
58
|
+
if action == :read
|
59
|
+
Spree::Deprecation.warn <<~WARN, caller(3)
|
60
|
+
The behavior of CanCanCan `:read` action alias will be changing in Solidus 3.0.
|
61
|
+
The current alias is: `:show, :to => :read`,
|
62
|
+
the new alias will be compliant with CanCanCan's default: `index, :show, :to => :read`
|
63
|
+
WARN
|
64
|
+
elsif CUSTOM_ALIASES_MAP.key? action
|
65
|
+
Spree::Deprecation.warn <<~WARN, caller(3)
|
66
|
+
Calling CanCanCan alias action #{action.inspect} is deprecated.
|
67
|
+
In Solidus 3.0 non-standard CanCanCan action aliases will be replaced with default ones,
|
68
|
+
please replace with #{normalized_action.inspect}.
|
69
|
+
WARN
|
70
|
+
end
|
41
71
|
|
42
|
-
|
43
|
-
alias_action :delete, to: :destroy
|
44
|
-
alias_action :edit, to: :update
|
45
|
-
alias_action :new, to: :create
|
46
|
-
alias_action :new_action, to: :create
|
47
|
-
alias_action :show, to: :read
|
48
|
-
alias_action :index, :read, to: :display
|
72
|
+
normalized_action
|
49
73
|
end
|
50
74
|
|
51
75
|
# Before, this was the only way to extend this ability. Permission sets have been added since.
|
data/app/models/spree/address.rb
CHANGED
@@ -8,21 +8,39 @@ module Spree
|
|
8
8
|
class Address < Spree::Base
|
9
9
|
extend ActiveModel::ForbiddenAttributesProtection
|
10
10
|
|
11
|
+
mattr_accessor :state_validator_class
|
12
|
+
self.state_validator_class = Spree::Address::StateValidator
|
13
|
+
|
11
14
|
belongs_to :country, class_name: "Spree::Country", optional: true
|
12
15
|
belongs_to :state, class_name: "Spree::State", optional: true
|
13
16
|
|
14
|
-
validates :
|
17
|
+
validates :address1, :city, :country_id, presence: true
|
15
18
|
validates :zipcode, presence: true, if: :require_zipcode?
|
16
19
|
validates :phone, presence: true, if: :require_phone?
|
17
20
|
|
18
|
-
validate :
|
19
|
-
|
21
|
+
validate :validate_name
|
22
|
+
|
23
|
+
validate do
|
24
|
+
if Spree::Config.use_legacy_address_state_validator
|
25
|
+
begin
|
26
|
+
@silence_state_deprecations = true
|
27
|
+
state_validate
|
28
|
+
validate_state_matches_country
|
29
|
+
ensure
|
30
|
+
@silence_state_deprecations = false
|
31
|
+
end
|
32
|
+
else
|
33
|
+
self.class.state_validator_class.new(self).perform
|
34
|
+
end
|
35
|
+
end
|
20
36
|
|
21
37
|
alias_attribute :first_name, :firstname
|
22
38
|
alias_attribute :last_name, :lastname
|
39
|
+
alias_attribute :full_name, :name
|
23
40
|
|
24
41
|
DB_ONLY_ATTRS = %w(id updated_at created_at)
|
25
42
|
TAXATION_ATTRS = %w(state_id country_id zipcode)
|
43
|
+
LEGACY_NAME_ATTRS = %w(firstname lastname full_name)
|
26
44
|
|
27
45
|
self.whitelisted_ransackable_attributes = %w[firstname lastname]
|
28
46
|
|
@@ -30,6 +48,11 @@ module Spree
|
|
30
48
|
where(value_attributes(attributes))
|
31
49
|
end
|
32
50
|
|
51
|
+
Spree::Deprecation.deprecate_methods(
|
52
|
+
Spree::Address,
|
53
|
+
LEGACY_NAME_ATTRS.product([:name]).to_h
|
54
|
+
)
|
55
|
+
|
33
56
|
# @return [Address] an address with default attributes
|
34
57
|
def self.build_default(*args, &block)
|
35
58
|
where(country: Spree::Country.default).build(*args, &block)
|
@@ -62,10 +85,13 @@ module Spree
|
|
62
85
|
def self.value_attributes(base_attributes, merge_attributes = {})
|
63
86
|
base = base_attributes.stringify_keys.merge(merge_attributes.stringify_keys)
|
64
87
|
|
65
|
-
|
66
|
-
base['firstname']
|
67
|
-
|
68
|
-
|
88
|
+
name_from_attributes = Spree::Address::Name.from_attributes(base)
|
89
|
+
if base['firstname'].presence || base['first_name'].presence
|
90
|
+
base['firstname'] = name_from_attributes.first_name
|
91
|
+
end
|
92
|
+
if base['lastname'].presence || base['last_name'].presence
|
93
|
+
base['lastname'] = name_from_attributes.last_name
|
94
|
+
end
|
69
95
|
excluded_attributes = DB_ONLY_ATTRS + %w(first_name last_name)
|
70
96
|
|
71
97
|
base.except(*excluded_attributes)
|
@@ -80,18 +106,13 @@ module Spree
|
|
80
106
|
self.class.value_attributes(attributes.slice(*TAXATION_ATTRS))
|
81
107
|
end
|
82
108
|
|
83
|
-
# @return [String] the full name on this address
|
84
|
-
def full_name
|
85
|
-
"#{firstname} #{lastname}".strip
|
86
|
-
end
|
87
|
-
|
88
109
|
# @return [String] a string representation of this state
|
89
110
|
def state_text
|
90
111
|
state.try(:abbr) || state.try(:name) || state_name
|
91
112
|
end
|
92
113
|
|
93
114
|
def to_s
|
94
|
-
"#{
|
115
|
+
"#{name}: #{address1}"
|
95
116
|
end
|
96
117
|
|
97
118
|
# @note This compares the addresses based on only the fields that make up
|
@@ -130,7 +151,7 @@ module Spree
|
|
130
151
|
# @return [Hash] an ActiveMerchant compatible address hash
|
131
152
|
def active_merchant_hash
|
132
153
|
{
|
133
|
-
name:
|
154
|
+
name: name,
|
134
155
|
address1: address1,
|
135
156
|
address2: address2,
|
136
157
|
city: city,
|
@@ -143,13 +164,13 @@ module Spree
|
|
143
164
|
|
144
165
|
# @todo Remove this from the public API if possible.
|
145
166
|
# @return [true] whether or not the address requires a phone number to be
|
146
|
-
#
|
167
|
+
# present
|
147
168
|
def require_phone?
|
148
|
-
|
169
|
+
Spree::Config[:address_requires_phone]
|
149
170
|
end
|
150
171
|
|
151
172
|
# @todo Remove this from the public API if possible.
|
152
|
-
# @return [true] whether or not the address requires a zipcode to be
|
173
|
+
# @return [true] whether or not the address requires a zipcode to be present
|
153
174
|
def require_zipcode?
|
154
175
|
true
|
155
176
|
end
|
@@ -172,9 +193,54 @@ module Spree
|
|
172
193
|
country && country.iso
|
173
194
|
end
|
174
195
|
|
196
|
+
# @return [String] the full name on this address
|
197
|
+
def name
|
198
|
+
Spree::Address::Name.new(
|
199
|
+
read_attribute(:firstname),
|
200
|
+
read_attribute(:lastname)
|
201
|
+
).value
|
202
|
+
end
|
203
|
+
|
204
|
+
def name=(value)
|
205
|
+
return if value.nil?
|
206
|
+
|
207
|
+
name_from_value = Spree::Address::Name.new(value)
|
208
|
+
write_attribute(:firstname, name_from_value.first_name)
|
209
|
+
write_attribute(:lastname, name_from_value.last_name)
|
210
|
+
end
|
211
|
+
|
212
|
+
def as_json(options = {})
|
213
|
+
if Spree::Config.use_combined_first_and_last_name_in_address
|
214
|
+
super(options.merge(except: LEGACY_NAME_ATTRS)).tap do |hash|
|
215
|
+
hash['name'] = name
|
216
|
+
end
|
217
|
+
else
|
218
|
+
super
|
219
|
+
end
|
220
|
+
end
|
221
|
+
|
175
222
|
private
|
176
223
|
|
224
|
+
def validate_name
|
225
|
+
return if name.present?
|
226
|
+
|
227
|
+
name_attribute = if Spree::Config.use_combined_first_and_last_name_in_address
|
228
|
+
:name
|
229
|
+
else
|
230
|
+
:firstname
|
231
|
+
end
|
232
|
+
errors.add(name_attribute, :blank)
|
233
|
+
end
|
234
|
+
|
177
235
|
def state_validate
|
236
|
+
unless @silence_state_deprecations
|
237
|
+
Spree::Deprecation.warn \
|
238
|
+
"#{self.class}#state_validate private method has been deprecated" \
|
239
|
+
" and will be removed in Solidus v3." \
|
240
|
+
" Check https://github.com/solidusio/solidus/pull/3129 for more details.",
|
241
|
+
caller
|
242
|
+
end
|
243
|
+
|
178
244
|
# Skip state validation without country (also required)
|
179
245
|
# or when disabled by preference
|
180
246
|
return if country.blank? || !Spree::Config[:address_requires_state]
|
@@ -210,6 +276,17 @@ module Spree
|
|
210
276
|
end
|
211
277
|
|
212
278
|
def validate_state_matches_country
|
279
|
+
unless @silence_state_deprecations
|
280
|
+
Spree::Deprecation.warn \
|
281
|
+
"#{self.class}#validate_state_matches_country private method has been deprecated" \
|
282
|
+
" and will be removed in Solidus v3." \
|
283
|
+
" Check https://github.com/solidusio/solidus/pull/3129 for more details.",
|
284
|
+
caller
|
285
|
+
end
|
286
|
+
|
287
|
+
return unless country
|
288
|
+
|
289
|
+
self.state = nil if country.states.empty?
|
213
290
|
if state && state.country != country
|
214
291
|
errors.add(:state, :does_not_match_country)
|
215
292
|
end
|
@@ -0,0 +1,49 @@
|
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
3
|
+
module Spree
|
4
|
+
class Address
|
5
|
+
# Provides a value object to help transitioning from legacy
|
6
|
+
# firstname and lastname fields to a unified name field.
|
7
|
+
class Name
|
8
|
+
attr_reader :first_name, :last_name, :value
|
9
|
+
|
10
|
+
# Creates an instance of Spree::Address::Name parsing input attributes.
|
11
|
+
# @param attributes [Hash] an hash possibly containing name-related
|
12
|
+
# attributes (name, firstname, lastname, first_name, last_name)
|
13
|
+
# @return [Spree::Address::Name] the object created
|
14
|
+
def self.from_attributes(attributes)
|
15
|
+
params = attributes.with_indifferent_access
|
16
|
+
|
17
|
+
if params[:name].present?
|
18
|
+
Spree::Address::Name.new(params[:name])
|
19
|
+
elsif params[:firstname].present?
|
20
|
+
Spree::Address::Name.new(params[:firstname], params[:lastname])
|
21
|
+
elsif params[:first_name].present?
|
22
|
+
Spree::Address::Name.new(params[:first_name], params[:last_name])
|
23
|
+
else
|
24
|
+
Spree::Address::Name.new
|
25
|
+
end
|
26
|
+
end
|
27
|
+
|
28
|
+
def initialize(*components)
|
29
|
+
@value = components.join(' ').strip
|
30
|
+
initialize_name_components(components)
|
31
|
+
end
|
32
|
+
|
33
|
+
def to_s
|
34
|
+
@value
|
35
|
+
end
|
36
|
+
|
37
|
+
private
|
38
|
+
|
39
|
+
def initialize_name_components(components)
|
40
|
+
if components.size == 2
|
41
|
+
@first_name = components[0].to_s
|
42
|
+
@last_name = components[1].to_s
|
43
|
+
else
|
44
|
+
@first_name, @last_name = @value.split(/[[:space:]]/, 2)
|
45
|
+
end
|
46
|
+
end
|
47
|
+
end
|
48
|
+
end
|
49
|
+
end
|
@@ -0,0 +1,71 @@
|
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
3
|
+
module Spree
|
4
|
+
class Address::StateValidator
|
5
|
+
attr_reader :address
|
6
|
+
delegate :state, :state_name, :country, to: :address
|
7
|
+
|
8
|
+
def initialize(address)
|
9
|
+
@address = address
|
10
|
+
end
|
11
|
+
|
12
|
+
def perform
|
13
|
+
return unless state_required?
|
14
|
+
|
15
|
+
if country.present?
|
16
|
+
normalize_state if state.present?
|
17
|
+
normalize_state_name if state_name.present?
|
18
|
+
end
|
19
|
+
|
20
|
+
validate_not_blank
|
21
|
+
validate_matches_country
|
22
|
+
end
|
23
|
+
|
24
|
+
private
|
25
|
+
|
26
|
+
def normalize_state
|
27
|
+
# discard the 'state' attribute when having a country with no states
|
28
|
+
address.state = nil if country.states.blank?
|
29
|
+
end
|
30
|
+
|
31
|
+
def normalize_state_name
|
32
|
+
# discard the 'state_name' when having a valid 'state' and country combo
|
33
|
+
if state.present? && state.country == country
|
34
|
+
address.state_name = nil
|
35
|
+
return
|
36
|
+
end
|
37
|
+
|
38
|
+
# set the state from the state name if the country contains one with that name
|
39
|
+
states_from_name = country.states.with_name_or_abbr(state_name)
|
40
|
+
if states_from_name.size == 1
|
41
|
+
address.state = states_from_name.first
|
42
|
+
address.state_name = nil
|
43
|
+
end
|
44
|
+
end
|
45
|
+
|
46
|
+
def validate_not_blank
|
47
|
+
if state.blank? && state_name.blank?
|
48
|
+
address.errors.add(:state, :blank)
|
49
|
+
end
|
50
|
+
end
|
51
|
+
|
52
|
+
def validate_matches_country
|
53
|
+
if state.present? && state.country != country
|
54
|
+
address.errors.add(:state, :does_not_match_country)
|
55
|
+
end
|
56
|
+
end
|
57
|
+
|
58
|
+
# Don't require a state if disabled at config level or
|
59
|
+
# the associated country doesn't require states
|
60
|
+
def state_required?
|
61
|
+
Spree::Config.address_requires_state && country_requires_states?
|
62
|
+
end
|
63
|
+
|
64
|
+
def country_requires_states?
|
65
|
+
# default to `true` if country not present
|
66
|
+
return true if country.blank?
|
67
|
+
|
68
|
+
country.states_required
|
69
|
+
end
|
70
|
+
end
|
71
|
+
end
|
@@ -159,7 +159,7 @@ module Spree
|
|
159
159
|
private
|
160
160
|
|
161
161
|
def require_promotion_code?
|
162
|
-
promotion? && source.promotion.codes.any?
|
162
|
+
promotion? && !source.promotion.apply_automatically && source.promotion.codes.any?
|
163
163
|
end
|
164
164
|
|
165
165
|
def repair_adjustments_associations_on_create
|
data/app/models/spree/base.rb
CHANGED
@@ -16,9 +16,9 @@ module Spree
|
|
16
16
|
|
17
17
|
def compute(object = nil)
|
18
18
|
return 0 if object.nil?
|
19
|
-
object.line_items.
|
19
|
+
object.line_items.sum { |line_item|
|
20
20
|
value_for_line_item(line_item)
|
21
|
-
}
|
21
|
+
}
|
22
22
|
end
|
23
23
|
|
24
24
|
private
|
@@ -28,9 +28,9 @@ module Spree
|
|
28
28
|
# Copied from per_item.rb
|
29
29
|
def matching_products
|
30
30
|
if compute_on_promotion?
|
31
|
-
calculable.promotion.rules.
|
31
|
+
calculable.promotion.rules.flat_map do |rule|
|
32
32
|
rule.respond_to?(:products) ? rule.products : []
|
33
|
-
end
|
33
|
+
end
|
34
34
|
end
|
35
35
|
end
|
36
36
|
|
@@ -12,7 +12,7 @@ module Spree
|
|
12
12
|
# as object we always get line items, as calculable we have Coupon, ShippingMethod
|
13
13
|
def compute(object)
|
14
14
|
if object.is_a?(Array)
|
15
|
-
base = object.
|
15
|
+
base = object.sum { |element| element.respond_to?(:amount) ? element.amount : BigDecimal(element.to_s) }
|
16
16
|
else
|
17
17
|
base = object.respond_to?(:amount) ? object.amount : BigDecimal(object.to_s)
|
18
18
|
end
|