spree_core 0.30.0.beta1 → 0.30.0
Sign up to get free protection for your applications and to get access to all the features.
- data/README.md +3 -12
- data/app/controllers/admin/adjustments_controller.rb +1 -17
- data/app/controllers/admin/base_controller.rb +12 -6
- data/app/controllers/admin/line_items_controller.rb +6 -29
- data/app/controllers/admin/mail_methods_controller.rb +13 -0
- data/app/controllers/admin/orders_controller.rb +32 -10
- data/app/controllers/admin/payments_controller.rb +15 -31
- data/app/controllers/admin/products_controller.rb +40 -41
- data/app/controllers/admin/reports_controller.rb +15 -14
- data/app/controllers/admin/return_authorizations_controller.rb +3 -16
- data/app/controllers/admin/shipments_controller.rb +8 -18
- data/app/controllers/admin/taxons_controller.rb +3 -3
- data/app/controllers/admin/users_controller.rb +5 -4
- data/app/controllers/checkout_controller.rb +26 -8
- data/app/controllers/orders_controller.rb +22 -10
- data/app/controllers/password_resets_controller.rb +0 -1
- data/app/controllers/products_controller.rb +2 -3
- data/app/controllers/spree/base_controller.rb +8 -0
- data/app/controllers/taxons_controller.rb +4 -4
- data/app/helpers/admin/navigation_helper.rb +4 -3
- data/app/helpers/checkout_helper.rb +1 -6
- data/app/helpers/spree/base_helper.rb +2 -0
- data/app/mailers/order_mailer.rb +19 -0
- data/app/mailers/shipment_mailer.rb +11 -0
- data/app/models/address.rb +3 -9
- data/app/models/adjustment.rb +3 -2
- data/app/models/app_configuration.rb +3 -16
- data/app/models/creditcard.rb +51 -45
- data/app/models/inventory_unit.rb +77 -80
- data/app/models/line_item.rb +33 -4
- data/app/models/log_entry.rb +3 -0
- data/app/models/mail_method.rb +23 -0
- data/app/models/order.rb +79 -177
- data/app/models/payment.rb +21 -18
- data/app/models/payment_method.rb +3 -3
- data/app/models/return_authorization.rb +11 -7
- data/app/models/shipment.rb +64 -40
- data/app/models/user.rb +1 -1
- data/app/models/variant.rb +6 -6
- data/app/views/admin/adjustments/index.html.erb +2 -32
- data/app/views/admin/configurations/index.html.erb +3 -3
- data/app/views/admin/mail_methods/_form.html.erb +96 -0
- data/app/views/admin/mail_methods/edit.html.erb +9 -0
- data/app/views/admin/mail_methods/index.html.erb +41 -0
- data/app/views/admin/mail_methods/new.html.erb +9 -0
- data/app/views/admin/orders/_form.html.erb +3 -4
- data/app/views/admin/{checkouts/_form.html.erb → orders/_user_form.html.erb} +10 -10
- data/app/views/admin/orders/edit.html.erb +1 -0
- data/app/views/admin/orders/index.html.erb +10 -6
- data/app/views/admin/orders/new.html.erb +1 -0
- data/app/views/admin/orders/show.html.erb +3 -2
- data/app/views/admin/{checkouts/edit.html.erb → orders/user.html.erb} +8 -5
- data/app/views/admin/payments/_list.html.erb +5 -7
- data/app/views/admin/payments/index.html.erb +3 -8
- data/app/views/admin/payments/new.html.erb +1 -1
- data/app/views/admin/payments/source_views/_gateway.html.erb +0 -1
- data/app/views/admin/reports/sales_total.html.erb +2 -6
- data/app/views/admin/return_authorizations/_form.html.erb +24 -12
- data/app/views/admin/return_authorizations/edit.html.erb +1 -1
- data/app/views/admin/return_authorizations/index.html.erb +6 -4
- data/app/views/admin/shared/_address_form.html.erb +20 -17
- data/app/views/admin/shared/_adjustments_table.html.erb +21 -0
- data/app/views/admin/shared/_configuration_menu.html.erb +1 -1
- data/app/views/admin/shared/_destroy.js.erb +3 -0
- data/app/views/admin/shared/_new_adjustment_button.html.erb +8 -0
- data/app/views/admin/shared/_order_tabs.html.erb +26 -22
- data/app/views/admin/shared/_report_criteria.html.erb +2 -2
- data/app/views/admin/shared/_update_order_state.js +6 -0
- data/app/views/admin/shipments/_form.html.erb +5 -11
- data/app/views/admin/shipments/edit.html.erb +4 -4
- data/app/views/admin/taxons/_form.html.erb +2 -2
- data/app/views/admin/taxons/_taxon_table.html.erb +3 -8
- data/app/views/admin/taxons/available.js.erb +4 -7
- data/app/views/admin/taxons/select.js.erb +2 -0
- data/app/views/admin/variants/index.html.erb +1 -1
- data/app/views/checkout/_address.html.erb +2 -0
- data/app/views/checkout/_delivery.html.erb +3 -3
- data/app/views/checkout/_payment.html.erb +23 -18
- data/app/views/checkout/_summary.html.erb +0 -10
- data/app/views/checkout/payment/_gateway.html.erb +1 -1
- data/app/views/checkout/registration.html.erb +20 -0
- data/app/views/layouts/admin.html.erb +2 -2
- data/app/views/order_mailer/{cancel.html.erb → cancel_email.text.erb} +4 -4
- data/app/views/order_mailer/{confirm.html.erb → confirm_email.text.erb} +3 -3
- data/app/views/orders/_line_item.html.erb +1 -3
- data/app/views/orders/edit.html.erb +1 -1
- data/app/views/shared/_basic_layout.html.erb +44 -0
- data/app/views/shared/_google_analytics.html.erb +23 -22
- data/app/views/shared/_head.html.erb +1 -1
- data/app/views/shared/_products.html.erb +1 -1
- data/app/views/shipment_mailer/shipped_email.text.erb +15 -0
- data/app/views/taxons/_taxon.html.erb +2 -2
- data/config/initializers/spree.rb +6 -2
- data/config/locales/{en_spree.yml → en.yml} +47 -17
- data/config/routes.rb +15 -8
- data/{lib/generators/templates/db → db}/default/countries.yml +0 -0
- data/{lib/generators/templates/db → db}/default/roles.yml +0 -0
- data/{lib/generators/templates/db → db}/default/states.yml +0 -0
- data/{lib/generators/templates/db → db}/default/zone_members.yml +0 -0
- data/{lib/generators/templates/db → db}/default/zones.yml +0 -0
- data/{lib/generators/templates/db → db}/migrate/20090823005402_spree_zero_nine_zero.rb +0 -0
- data/{lib/generators/templates/db → db}/migrate/20090904192342_create_indexes_for_inventory_units.rb +0 -0
- data/{lib/generators/templates/db → db}/migrate/20090923100315_add_count_on_hand_to_variants_and_products.rb +0 -0
- data/{lib/generators/templates/db → db}/migrate/20091007134354_change_taxons_to_nested_set.rb +0 -0
- data/{lib/generators/templates/db → db}/migrate/20091008091614_move_to_configurable_gateways.rb +0 -0
- data/{lib/generators/templates/db → db}/migrate/20091012120519_product_groups_and_scopes.rb +0 -0
- data/{lib/generators/templates/db → db}/migrate/20091015110842_add_open_id_authentication_tables.rb +0 -0
- data/{lib/generators/templates/db → db}/migrate/20091015153048_add_openid_field_to_users.rb +0 -0
- data/{lib/generators/templates/db → db}/migrate/20091016174634_change_preference_value_type.rb +0 -0
- data/{lib/generators/templates/db → db}/migrate/20091017175558_create_billing_integrations.rb +0 -0
- data/{lib/generators/templates/db → db}/migrate/20091021133257_charge_refactoring.rb +7 -4
- data/{lib/generators/templates/db → db}/migrate/20091104151730_add_some_indexes.rb +0 -0
- data/{lib/generators/templates/db → db}/migrate/20091126190904_checkout_state_machine.rb +0 -0
- data/{lib/generators/templates/db → db}/migrate/20091209153045_state_for_shipments.rb +0 -0
- data/{lib/generators/templates/db → db}/migrate/20091209202200_make_state_events_polymorphic.rb +0 -0
- data/{lib/generators/templates/db → db}/migrate/20091211203813_ship_address_id_for_checkouts.rb +0 -0
- data/{lib/generators/templates/db → db}/migrate/20091212161118_shipping_method_id_for_checkouts.rb +0 -0
- data/{lib/generators/templates/db → db}/migrate/20091213222815_creditcard_last_four_digits.rb +0 -0
- data/{lib/generators/templates/db → db}/migrate/20091214183826_populate_legacy_shipment_state.rb +0 -0
- data/{lib/generators/templates/db → db}/migrate/20100105090147_add_cost_price.rb +0 -0
- data/{lib/generators/templates/db → db}/migrate/20100105132138_shipment_id_for_inventory_units.rb +0 -0
- data/{lib/generators/templates/db → db}/migrate/20100111205525_cim_fields_for_creditcards.rb +0 -0
- data/{lib/generators/templates/db → db}/migrate/20100112151511_create_return_authorizations.rb +0 -0
- data/{lib/generators/templates/db → db}/migrate/20100113090919_add_return_authorization_to_inventory_units.rb +0 -0
- data/{lib/generators/templates/db → db}/migrate/20100113203104_create_trackers.rb +0 -0
- data/{lib/generators/templates/db → db}/migrate/20100121160010_creditcard_id_for_creditcard_txns.rb +0 -0
- data/{lib/generators/templates/db → db}/migrate/20100121183934_original_creditcard_txn_id_for_creditcard_txns.rb +0 -0
- data/{lib/generators/templates/db → db}/migrate/20100125145351_add_test_mode_to_billing_integration.rb +0 -0
- data/{lib/generators/templates/db → db}/migrate/20100126103714_create_products_product_groups.rb +0 -0
- data/{lib/generators/templates/db → db}/migrate/20100209025806_create_payment_methods.rb +0 -0
- data/{lib/generators/templates/db → db}/migrate/20100209144531_polymorphic_payments.rb +0 -0
- data/{lib/generators/templates/db → db}/migrate/20100213103131_change_payments_payment_method_to_belongs_to.rb +0 -0
- data/{lib/generators/templates/db → db}/migrate/20100214212536_assign_creditcard_txns_to_payment.rb +0 -0
- data/{lib/generators/templates/db → db}/migrate/20100223170312_sti_for_transactions.rb +0 -0
- data/{lib/generators/templates/db → db}/migrate/20100223183812_drop_billing_integrations.rb +0 -0
- data/{lib/generators/templates/db → db}/migrate/20100224153127_deleted_at_for_payment_methods.rb +0 -0
- data/{lib/generators/templates/db → db}/migrate/20100301163454_add_adjustments_index.rb +0 -0
- data/{lib/generators/templates/db → db}/migrate/20100306153445_fix_by_popularity.rb +0 -0
- data/{lib/generators/templates/db → db}/migrate/20100317120946_add_alt_text_to_images.rb +0 -0
- data/{lib/generators/templates/db → db}/migrate/20100427121301_add_display_to_payment_methods.rb +0 -0
- data/{lib/generators/templates/db → db}/migrate/20100504142133_add_addresses_checkouts_indexes.rb +0 -0
- data/{lib/generators/templates/db → db}/migrate/20100506180619_add_icon_to_taxons.rb +0 -0
- data/{lib/generators/templates/db → db}/migrate/20100506185838_add_description_to_taxons.rb +0 -0
- data/{lib/generators/templates/db → db}/migrate/20100528155333_index_for_shipments_number.rb +0 -0
- data/{lib/generators/templates/db → db}/migrate/20100528185820_add_index_on_users_persistence_token.rb +0 -0
- data/{lib/generators/templates/db → db}/migrate/20100605152042_add_default_to_tax_categories.rb +0 -0
- data/{lib/generators/templates/db → db}/migrate/20100624110730_add_display_to_shipping_methods.rb +0 -0
- data/{lib/generators/templates/db → db}/migrate/20100624123336_rename_payment_method_display.rb +0 -0
- data/{lib/generators/templates/db → db}/migrate/20100624175547_rename_preferences_field.rb +0 -0
- data/{lib/generators/templates/db → db}/migrate/20100811163637_add_guest_flag.rb +0 -0
- data/{lib/generators/templates/db → db}/migrate/20100811205836_drop_order_token.rb +0 -0
- data/{lib/generators/templates/db → db}/migrate/20100812162326_payments_state_and_assigned_to_order_only.rb +0 -0
- data/{lib/generators/templates/db → db}/migrate/20100813023502_create_address_keys_for_order.rb +0 -0
- data/{lib/generators/templates/db → db}/migrate/20100813185745_payment_total_for_orders.rb +0 -0
- data/{lib/generators/templates/db → db}/migrate/20100816212146_shipping_method_id_for_orders.rb +0 -0
- data/{lib/generators/templates/db → db}/migrate/20100817152723_add_shipment_and_payment_state.rb +0 -0
- data/{lib/generators/templates/db → db}/migrate/20100819170125_refactor_adjustments.rb +0 -0
- data/{lib/generators/templates/db → db}/migrate/20100820135707_response_code_and_avs_response_for_payments.rb +0 -0
- data/{lib/generators/templates/db → db}/migrate/20100901171814_change_guest_flag_to_anonymous.rb +0 -0
- data/db/migrate/20100903203949_email_for_orders.rb +9 -0
- data/db/migrate/20100908170204_remove_unique_index_on_users_email.rb +9 -0
- data/db/migrate/20100923162011_create_mail_methods.rb +12 -0
- data/db/migrate/20100929151905_rename_frozen_to_locked.rb +8 -0
- data/db/migrate/20101008190536_move_special_instructions_to_orders.rb +11 -0
- data/db/migrate/20101026184700_create_log_entries.rb +15 -0
- data/db/migrate/20101026184714_migrate_transactions_to_payment_state.rb +94 -0
- data/db/migrate/20101026184746_delete_in_progress_orders.rb +18 -0
- data/db/migrate/20101026184808_migrate_checkout_to_orders.rb +27 -0
- data/db/migrate/20101026184833_migrate_adjustments.rb +9 -0
- data/db/migrate/20101026184855_remove_shipped_state.rb +14 -0
- data/db/migrate/20101026184916_prevent_nil_payment_total.rb +8 -0
- data/db/migrate/20101026184932_prevent_nil_email.rb +9 -0
- data/db/migrate/20101026184959_generate_anonymous_users.rb +14 -0
- data/db/migrate/20101026185022_update_order_state.rb +8 -0
- data/db/migrate/20101026192225_cleanup_legacy_tables.rb +11 -0
- data/db/migrate/20101028151745_remove_number_and_cvv_from_credicard.rb +9 -0
- data/db/migrate/20101103212716_drop_anonymous_field_for_user.rb +8 -0
- data/{lib/generators/templates/db → db}/sample/users.rb +0 -0
- data/db/seeds.rb +3 -0
- data/lib/generators/spree_core/upgrade_generator.rb +23 -0
- data/lib/scopes/product.rb +0 -5
- data/lib/spree/config.rb +4 -4
- data/lib/spree/current_order.rb +11 -3
- data/lib/spree/i18n_utils.rb +47 -0
- data/lib/spree/mail_interceptor.rb +23 -0
- data/lib/spree/mail_settings.rb +34 -0
- data/lib/spree/search/base.rb +50 -6
- data/lib/spree_core.rb +9 -8
- data/lib/{active_merchant/billing/authorize_net_cim.rb → spree_core/authorize_net_cim_hack.rb} +0 -0
- data/lib/spree_core/ext/active_record.rb +2 -0
- data/lib/spree_core/ssl_requirement.rb +9 -15
- data/lib/tasks/core.rake +1 -8
- data/lib/tasks/install.rake +27 -0
- data/{lib/generators/templates/public → public}/images/add-to-cart.png +0 -0
- data/{lib/generators/templates/public → public}/images/admin/bg/active-tab.png +0 -0
- data/{lib/generators/templates/public → public}/images/admin/bg/admin_tab_back.png +0 -0
- data/{lib/generators/templates/public → public}/images/admin/bg/admin_tab_selected_back.png +0 -0
- data/{lib/generators/templates/public → public}/images/admin/bg/content-back-blue.png +0 -0
- data/{lib/generators/templates/public → public}/images/admin/bg/content-back-green.png +0 -0
- data/{lib/generators/templates/public → public}/images/admin/bg/content-back.png +0 -0
- data/{lib/generators/templates/public → public}/images/admin/bg/flash-error.png +0 -0
- data/{lib/generators/templates/public → public}/images/admin/bg/flash-notice.png +0 -0
- data/{lib/generators/templates/public → public}/images/admin/bg/green-stripes.gif +0 -0
- data/{lib/generators/templates/public → public}/images/admin/bg/green-stripes.png +0 -0
- data/{lib/generators/templates/public → public}/images/admin/bg/grid_header_back.png +0 -0
- data/{lib/generators/templates/public → public}/images/admin/bg/grid_header_back_green.png +0 -0
- data/{lib/generators/templates/public → public}/images/admin/bg/header-bg.png +0 -0
- data/{lib/generators/templates/public → public}/images/admin/bg/header.png +0 -0
- data/{lib/generators/templates/public → public}/images/admin/bg/header_bg.jpg +0 -0
- data/{lib/generators/templates/public → public}/images/admin/bg/menu-current.png +0 -0
- data/{lib/generators/templates/public → public}/images/admin/bg/red-stripes.gif +0 -0
- data/{lib/generators/templates/public → public}/images/admin/bg/red-stripes.png +0 -0
- data/{lib/generators/templates/public → public}/images/admin/bg/spree_50.png +0 -0
- data/{lib/generators/templates/public → public}/images/admin/bg/subnav-divider.png +0 -0
- data/{lib/generators/templates/public → public}/images/admin/bg/subnav.png +0 -0
- data/{lib/generators/templates/public → public}/images/admin/bg/tab-back.png +0 -0
- data/{lib/generators/templates/public → public}/images/admin/buttons/blue/left_01.png +0 -0
- data/{lib/generators/templates/public → public}/images/admin/buttons/blue/right_01.png +0 -0
- data/{lib/generators/templates/public → public}/images/admin/buttons/drag-handle-green.png +0 -0
- data/{lib/generators/templates/public → public}/images/admin/buttons/green/left_01.png +0 -0
- data/{lib/generators/templates/public → public}/images/admin/buttons/green/right_01.png +0 -0
- data/{lib/generators/templates/public → public}/images/admin/buttons/left_01.png +0 -0
- data/{lib/generators/templates/public → public}/images/admin/buttons/left_01_small.png +0 -0
- data/{lib/generators/templates/public → public}/images/admin/buttons/orange/left_03.png +0 -0
- data/{lib/generators/templates/public → public}/images/admin/buttons/orange/right_03.png +0 -0
- data/{lib/generators/templates/public → public}/images/admin/buttons/right_01.png +0 -0
- data/{lib/generators/templates/public → public}/images/admin/buttons/right_01_small.png +0 -0
- data/{lib/generators/templates/public → public}/images/admin/icons/16x16/1.png +0 -0
- data/{lib/generators/templates/public → public}/images/admin/icons/16x16/10.png +0 -0
- data/{lib/generators/templates/public → public}/images/admin/icons/16x16/2.png +0 -0
- data/{lib/generators/templates/public → public}/images/admin/icons/16x16/3.png +0 -0
- data/{lib/generators/templates/public → public}/images/admin/icons/16x16/4.png +0 -0
- data/{lib/generators/templates/public → public}/images/admin/icons/16x16/5.png +0 -0
- data/{lib/generators/templates/public → public}/images/admin/icons/16x16/6.png +0 -0
- data/{lib/generators/templates/public → public}/images/admin/icons/16x16/7.png +0 -0
- data/{lib/generators/templates/public → public}/images/admin/icons/16x16/8.png +0 -0
- data/{lib/generators/templates/public → public}/images/admin/icons/16x16/9.png +0 -0
- data/{lib/generators/templates/public → public}/images/admin/icons/32x32/1.png +0 -0
- data/{lib/generators/templates/public → public}/images/admin/icons/32x32/10.png +0 -0
- data/{lib/generators/templates/public → public}/images/admin/icons/32x32/11.png +0 -0
- data/{lib/generators/templates/public → public}/images/admin/icons/32x32/2.png +0 -0
- data/{lib/generators/templates/public → public}/images/admin/icons/32x32/3.png +0 -0
- data/{lib/generators/templates/public → public}/images/admin/icons/32x32/4.png +0 -0
- data/{lib/generators/templates/public → public}/images/admin/icons/32x32/5.png +0 -0
- data/{lib/generators/templates/public → public}/images/admin/icons/32x32/6.png +0 -0
- data/{lib/generators/templates/public → public}/images/admin/icons/32x32/7.png +0 -0
- data/{lib/generators/templates/public → public}/images/admin/icons/32x32/8.png +0 -0
- data/{lib/generators/templates/public → public}/images/admin/icons/32x32/9.png +0 -0
- data/{lib/generators/templates/public → public}/images/admin/icons/accept.png +0 -0
- data/{lib/generators/templates/public → public}/images/admin/icons/add.gif +0 -0
- data/{lib/generators/templates/public → public}/images/admin/icons/add.png +0 -0
- data/{lib/generators/templates/public → public}/images/admin/icons/arrow-down.gif +0 -0
- data/{lib/generators/templates/public → public}/images/admin/icons/cross.png +0 -0
- data/{lib/generators/templates/public → public}/images/admin/icons/delete.gif +0 -0
- data/{lib/generators/templates/public → public}/images/admin/icons/delete.png +0 -0
- data/{lib/generators/templates/public → public}/images/admin/icons/drag.gif +0 -0
- data/{lib/generators/templates/public → public}/images/admin/icons/edit.gif +0 -0
- data/{lib/generators/templates/public → public}/images/admin/icons/edit.png +0 -0
- data/{lib/generators/templates/public → public}/images/admin/icons/email.png +0 -0
- data/{lib/generators/templates/public → public}/images/admin/icons/error.png +0 -0
- data/{lib/generators/templates/public → public}/images/admin/icons/exclamation.png +0 -0
- data/{lib/generators/templates/public → public}/images/admin/icons/feed.png +0 -0
- data/{lib/generators/templates/public → public}/images/admin/icons/pdf.png +0 -0
- data/{lib/generators/templates/public → public}/images/admin/icons/reorder.gif +0 -0
- data/{lib/generators/templates/public → public}/images/admin/icons/search.gif +0 -0
- data/{lib/generators/templates/public → public}/images/admin/icons/send-email.png +0 -0
- data/{lib/generators/templates/public → public}/images/admin/icons/stop.png +0 -0
- data/{lib/generators/templates/public → public}/images/admin/icons/tick.png +0 -0
- data/{lib/generators/templates/public → public}/images/admin/icons/up.gif +0 -0
- data/{lib/generators/templates/public → public}/images/admin/icons/xls.png +0 -0
- data/{lib/generators/templates/public → public}/images/admin/tabs/off-left.png +0 -0
- data/{lib/generators/templates/public → public}/images/admin/tabs/off-right.png +0 -0
- data/{lib/generators/templates/public → public}/images/admin/tabs/on-left.png +0 -0
- data/{lib/generators/templates/public → public}/images/admin/tabs/on-right.png +0 -0
- data/{lib/generators/templates/public → public}/images/ajax_loader.gif +0 -0
- data/{lib/generators/templates/public → public}/images/amex_cid.gif +0 -0
- data/{lib/generators/templates/public → public}/images/bg-button-hover.png +0 -0
- data/{lib/generators/templates/public → public}/images/bg-button-pressed.png +0 -0
- data/{lib/generators/templates/public → public}/images/bg-button.gif +0 -0
- data/{lib/generators/templates/public → public}/images/bg-button.png +0 -0
- data/{lib/generators/templates/public → public}/images/blue/left_01.png +0 -0
- data/{lib/generators/templates/public → public}/images/blue/right_01.png +0 -0
- data/{lib/generators/templates/public → public}/images/body-back.png +0 -0
- data/{lib/generators/templates/public → public}/images/bottom_shine.png +0 -0
- data/{lib/generators/templates/public → public}/images/breadcrumb.gif +0 -0
- data/{lib/generators/templates/public → public}/images/button-dark-hover.png +0 -0
- data/{lib/generators/templates/public → public}/images/button-dark.png +0 -0
- data/{lib/generators/templates/public → public}/images/buttons/bg-button-hover.png +0 -0
- data/{lib/generators/templates/public → public}/images/buttons/bg-button-pressed.png +0 -0
- data/{lib/generators/templates/public → public}/images/buttons/bg-button.gif +0 -0
- data/{lib/generators/templates/public → public}/images/buttons/bg-button.png +0 -0
- data/{lib/generators/templates/public → public}/images/buttons/blue/left_01.png +0 -0
- data/{lib/generators/templates/public → public}/images/buttons/blue/right_01.png +0 -0
- data/{lib/generators/templates/public → public}/images/buttons/button-dark-hover.png +0 -0
- data/{lib/generators/templates/public → public}/images/buttons/button-dark.png +0 -0
- data/{lib/generators/templates/public → public}/images/buttons/drag-handle-green.png +0 -0
- data/{lib/generators/templates/public → public}/images/buttons/green/left_01.png +0 -0
- data/{lib/generators/templates/public → public}/images/buttons/green/right_01.png +0 -0
- data/{lib/generators/templates/public → public}/images/buttons/left_01.png +0 -0
- data/{lib/generators/templates/public → public}/images/buttons/left_01_small.png +0 -0
- data/{lib/generators/templates/public → public}/images/buttons/orange/left_03.png +0 -0
- data/{lib/generators/templates/public → public}/images/buttons/orange/right_03.png +0 -0
- data/{lib/generators/templates/public → public}/images/buttons/right_01.png +0 -0
- data/{lib/generators/templates/public → public}/images/buttons/right_01_small.png +0 -0
- data/{lib/generators/templates/public → public}/images/buttons/sxsw-ribbon-v1.png +0 -0
- data/{lib/generators/templates/public → public}/images/buttons/top-shine.png +0 -0
- data/{lib/generators/templates/public → public}/images/calendar_date_select/calendar.gif +0 -0
- data/{lib/generators/templates/public → public}/images/cart-empty.png +0 -0
- data/{lib/generators/templates/public → public}/images/cart-empty_x32.png +0 -0
- data/{lib/generators/templates/public → public}/images/cart-full.png +0 -0
- data/{lib/generators/templates/public → public}/images/cart-full_x32.png +0 -0
- data/{lib/generators/templates/public → public}/images/checkout.png +0 -0
- data/{lib/generators/templates/public → public}/images/creditcard.gif +0 -0
- data/{lib/generators/templates/public → public}/images/datepicker/backstripes.gif +0 -0
- data/{lib/generators/templates/public → public}/images/datepicker/bg_header.jpg +0 -0
- data/{lib/generators/templates/public → public}/images/datepicker/bullet1.gif +0 -0
- data/{lib/generators/templates/public → public}/images/datepicker/bullet2.gif +0 -0
- data/{lib/generators/templates/public → public}/images/datepicker/cal.gif +0 -0
- data/{lib/generators/templates/public → public}/images/datepicker/gradient-e5e5e5-ffffff.gif +0 -0
- data/{lib/generators/templates/public → public}/images/discover_cid.gif +0 -0
- data/{lib/generators/templates/public → public}/images/drag-handle-green.png +0 -0
- data/{lib/generators/templates/public → public}/images/favicon.ico +0 -0
- data/{lib/generators/templates/public → public}/images/green/left_01.png +0 -0
- data/{lib/generators/templates/public → public}/images/green/right_01.png +0 -0
- data/{lib/generators/templates/public → public}/images/grid.png +0 -0
- data/{lib/generators/templates/public → public}/images/left_01.png +0 -0
- data/{lib/generators/templates/public → public}/images/left_01_small.png +0 -0
- data/{lib/generators/templates/public → public}/images/master_cid.jpg +0 -0
- data/{lib/generators/templates/public → public}/images/menu-current.png +0 -0
- data/{lib/generators/templates/public → public}/images/menu-hover.png +0 -0
- data/{lib/generators/templates/public → public}/images/noimage/mini.jpg +0 -0
- data/{lib/generators/templates/public → public}/images/noimage/product.jpg +0 -0
- data/{lib/generators/templates/public → public}/images/noimage/small.jpg +0 -0
- data/{lib/generators/templates/public → public}/images/openid-inputicon.gif +0 -0
- data/{lib/generators/templates/public → public}/images/orange/left_03.png +0 -0
- data/{lib/generators/templates/public → public}/images/orange/right_03.png +0 -0
- data/{lib/generators/templates/public → public}/images/progress.gif +0 -0
- data/{lib/generators/templates/public → public}/images/right_01.png +0 -0
- data/{lib/generators/templates/public → public}/images/right_01_small.png +0 -0
- data/{lib/generators/templates/public → public}/images/separator.png +0 -0
- data/{lib/generators/templates/public → public}/images/shadow-top.png +0 -0
- data/{lib/generators/templates/public → public}/images/shadow_top.png +0 -0
- data/{lib/generators/templates/public → public}/images/spinner.gif +0 -0
- data/{lib/generators/templates/public → public}/images/spree.jpg +0 -0
- data/{lib/generators/templates/public → public}/images/spree/progress.gif +0 -0
- data/{lib/generators/templates/public → public}/images/spree/spinner.gif +0 -0
- data/{lib/generators/templates/public → public}/images/spree/spree.jpg +0 -0
- data/{lib/generators/templates/public → public}/images/step-progress/completed-completed.gif +0 -0
- data/{lib/generators/templates/public → public}/images/step-progress/completed-current.gif +0 -0
- data/{lib/generators/templates/public → public}/images/step-progress/completed-first.gif +0 -0
- data/{lib/generators/templates/public → public}/images/step-progress/current-first.gif +0 -0
- data/{lib/generators/templates/public → public}/images/step-progress/current-incomplete.gif +0 -0
- data/{lib/generators/templates/public → public}/images/step-progress/current-right.gif +0 -0
- data/{lib/generators/templates/public → public}/images/step-progress/incomplete-incomplete.gif +0 -0
- data/{lib/generators/templates/public → public}/images/step-progress/incomplete-right.gif +0 -0
- data/{lib/generators/templates/public → public}/images/steps/1.png +0 -0
- data/{lib/generators/templates/public → public}/images/steps/1_small.png +0 -0
- data/{lib/generators/templates/public → public}/images/steps/2.png +0 -0
- data/{lib/generators/templates/public → public}/images/steps/2_small.png +0 -0
- data/{lib/generators/templates/public → public}/images/steps/3.png +0 -0
- data/{lib/generators/templates/public → public}/images/steps/3_small.png +0 -0
- data/{lib/generators/templates/public → public}/images/steps/4.png +0 -0
- data/{lib/generators/templates/public → public}/images/steps/4_small.png +0 -0
- data/{lib/generators/templates/public → public}/images/steps/5.png +0 -0
- data/{lib/generators/templates/public → public}/images/steps/5_small.png +0 -0
- data/{lib/generators/templates/public → public}/images/steps/6.png +0 -0
- data/{lib/generators/templates/public → public}/images/steps/6_small.png +0 -0
- data/{lib/generators/templates/public → public}/images/sxsw-ribbon-v1.png +0 -0
- data/{lib/generators/templates/public → public}/images/tab_bottom.gif +0 -0
- data/{lib/generators/templates/public → public}/images/tile-header.png +0 -0
- data/{lib/generators/templates/public → public}/images/tile-slider.png +0 -0
- data/{lib/generators/templates/public → public}/images/top-shine.png +0 -0
- data/{lib/generators/templates/public → public}/images/tree-nav-icons/bullet.gif +0 -0
- data/{lib/generators/templates/public → public}/images/tree-nav-icons/minus.gif +0 -0
- data/{lib/generators/templates/public → public}/images/tree-nav-icons/plus.gif +0 -0
- data/{lib/generators/templates/public → public}/images/tree-nav-icons/treeview-loading.gif +0 -0
- data/{lib/generators/templates/public → public}/images/tree-nav-icons/treeview-sprite.gif +0 -0
- data/{lib/generators/templates/public → public}/images/update.png +0 -0
- data/{lib/generators/templates/public → public}/images/visa_cid.gif +0 -0
- data/{lib/generators/templates/public → public}/images/wrapper-back-2.png +0 -0
- data/{lib/generators/templates/public → public}/images/wrapper-back.png +0 -0
- data/{lib/generators/templates/public → public}/images/yui-menubaritem_submenuindicator.png +0 -0
- data/{lib/generators/templates/public → public}/images/yui-menubaritem_submenuindicator_disabled.png +0 -0
- data/{lib/generators/templates/public → public}/images/yui-menuitem_checkbox.png +0 -0
- data/{lib/generators/templates/public → public}/images/yui-menuitem_checkbox_disabled.png +0 -0
- data/{lib/generators/templates/public → public}/images/yui-menuitem_submenuindicator.png +0 -0
- data/{lib/generators/templates/public → public}/images/yui-menuitem_submenuindicator_disabled.png +0 -0
- data/{lib/generators/templates/public → public}/images/yui-sprite.png +0 -0
- data/{lib/generators/templates/public → public}/javascripts/additional-methods.js +0 -0
- data/{lib/generators/templates/public → public}/javascripts/admin.js +11 -11
- data/{lib/generators/templates/public → public}/javascripts/admin/address_states.js +0 -0
- data/{lib/generators/templates/public → public}/javascripts/admin/checkouts/edit.js +1 -1
- data/{lib/generators/templates/public → public}/javascripts/admin/orders/edit.js +0 -0
- data/{lib/generators/templates/public → public}/javascripts/admin/orders/edit_form.js +0 -0
- data/{lib/generators/templates/public → public}/javascripts/admin/payments/new.js +0 -0
- data/{lib/generators/templates/public → public}/javascripts/admin/unobtrusive_handlers.js +0 -0
- data/{lib/generators/templates/public → public}/javascripts/application.js +3 -3
- data/{lib/generators/templates/public → public}/javascripts/calculator.js +0 -0
- data/{lib/generators/templates/public → public}/javascripts/checkout.js +26 -15
- data/{lib/generators/templates/public → public}/javascripts/datepicker.js +0 -0
- data/{lib/generators/templates/public → public}/javascripts/gateway.js +0 -0
- data/{lib/generators/templates/public → public}/javascripts/jquery-1.4.2.min.js +0 -0
- data/{lib/generators/templates/public → public}/javascripts/jquery-ui.js +0 -0
- data/{lib/generators/templates/public → public}/javascripts/jquery.alerts/images/help.gif +0 -0
- data/{lib/generators/templates/public → public}/javascripts/jquery.alerts/images/important.gif +0 -0
- data/{lib/generators/templates/public → public}/javascripts/jquery.alerts/images/info.gif +0 -0
- data/{lib/generators/templates/public → public}/javascripts/jquery.alerts/images/title.gif +0 -0
- data/{lib/generators/templates/public → public}/javascripts/jquery.alerts/jquery.alerts.css +0 -0
- data/{lib/generators/templates/public → public}/javascripts/jquery.alerts/jquery.alerts.js +0 -0
- data/{lib/generators/templates/public → public}/javascripts/jquery.alerts/jquery.alerts.spree.css +0 -0
- data/{lib/generators/templates/public → public}/javascripts/jquery.autocomplete.min.js +0 -0
- data/{lib/generators/templates/public → public}/javascripts/jquery.js +0 -0
- data/{lib/generators/templates/public → public}/javascripts/jquery.suggest.js +0 -0
- data/{lib/generators/templates/public → public}/javascripts/jquery.template.js +0 -0
- data/{lib/generators/templates/public → public}/javascripts/jquery.tokeninput.js +0 -0
- data/{lib/generators/templates/public → public}/javascripts/jquery.validate.min.js +0 -0
- data/{lib/generators/templates/public → public}/javascripts/jrails.autocomplete.js +0 -0
- data/{lib/generators/templates/public → public}/javascripts/jrails.js +0 -0
- data/{lib/generators/templates/public → public}/javascripts/jsTree/jquery.tree.js +0 -0
- data/{lib/generators/templates/public → public}/javascripts/jsTree/plugins/jquery.tree.contextmenu.js +0 -0
- data/{lib/generators/templates/public → public}/javascripts/jsTree/themes/apple/bg.jpg +0 -0
- data/{lib/generators/templates/public → public}/javascripts/jsTree/themes/apple/dot_for_ie.gif +0 -0
- data/{lib/generators/templates/public → public}/javascripts/jsTree/themes/apple/icons.png +0 -0
- data/{lib/generators/templates/public → public}/javascripts/jsTree/themes/apple/style.css +0 -0
- data/{lib/generators/templates/public → public}/javascripts/jsTree/themes/apple/throbber.gif +0 -0
- data/{lib/generators/templates/public → public}/javascripts/lang/af.js +0 -0
- data/{lib/generators/templates/public → public}/javascripts/lang/ar.js +0 -0
- data/{lib/generators/templates/public → public}/javascripts/lang/de.js +0 -0
- data/{lib/generators/templates/public → public}/javascripts/lang/du.js +0 -0
- data/{lib/generators/templates/public → public}/javascripts/lang/en.js +0 -0
- data/{lib/generators/templates/public → public}/javascripts/lang/es.js +0 -0
- data/{lib/generators/templates/public → public}/javascripts/lang/fi.js +0 -0
- data/{lib/generators/templates/public → public}/javascripts/lang/fr.js +0 -0
- data/{lib/generators/templates/public → public}/javascripts/lang/gr.js +0 -0
- data/{lib/generators/templates/public → public}/javascripts/lang/he.js +0 -0
- data/{lib/generators/templates/public → public}/javascripts/lang/it.js +0 -0
- data/{lib/generators/templates/public → public}/javascripts/lang/nl.js +0 -0
- data/{lib/generators/templates/public → public}/javascripts/lang/no.js +0 -0
- data/{lib/generators/templates/public → public}/javascripts/lang/pt.js +0 -0
- data/{lib/generators/templates/public → public}/javascripts/lang/ro.js +0 -0
- data/{lib/generators/templates/public → public}/javascripts/lang/ru.js +0 -0
- data/{lib/generators/templates/public → public}/javascripts/lang/sp.js +0 -0
- data/{lib/generators/templates/public → public}/javascripts/lang/sv.js +0 -0
- data/{lib/generators/templates/public → public}/javascripts/lang/ua.js +0 -0
- data/{lib/generators/templates/public → public}/javascripts/localization/messages_cn.js +0 -0
- data/{lib/generators/templates/public → public}/javascripts/localization/messages_cs.js +0 -0
- data/{lib/generators/templates/public → public}/javascripts/localization/messages_da.js +0 -0
- data/{lib/generators/templates/public → public}/javascripts/localization/messages_de.js +0 -0
- data/{lib/generators/templates/public → public}/javascripts/localization/messages_es.js +0 -0
- data/{lib/generators/templates/public → public}/javascripts/localization/messages_fr.js +0 -0
- data/{lib/generators/templates/public → public}/javascripts/localization/messages_hu.js +0 -0
- data/{lib/generators/templates/public → public}/javascripts/localization/messages_it.js +0 -0
- data/{lib/generators/templates/public → public}/javascripts/localization/messages_kk.js +0 -0
- data/{lib/generators/templates/public → public}/javascripts/localization/messages_nl.js +0 -0
- data/{lib/generators/templates/public → public}/javascripts/localization/messages_no.js +0 -0
- data/{lib/generators/templates/public → public}/javascripts/localization/messages_pl.js +0 -0
- data/{lib/generators/templates/public → public}/javascripts/localization/messages_ptbr.js +0 -0
- data/{lib/generators/templates/public → public}/javascripts/localization/messages_ro.js +0 -0
- data/{lib/generators/templates/public → public}/javascripts/localization/messages_ru.js +0 -0
- data/{lib/generators/templates/public → public}/javascripts/localization/messages_se.js +0 -0
- data/{lib/generators/templates/public → public}/javascripts/localization/messages_sk.js +0 -0
- data/{lib/generators/templates/public → public}/javascripts/localization/messages_tr.js +0 -0
- data/{lib/generators/templates/public → public}/javascripts/localization/messages_tw.js +0 -0
- data/{lib/generators/templates/public → public}/javascripts/localization/messages_ua.js +0 -0
- data/{lib/generators/templates/public → public}/javascripts/nested-attribute.js +0 -0
- data/{lib/generators/templates/public → public}/javascripts/open_id.js +0 -0
- data/{lib/generators/templates/public → public}/javascripts/product.js +0 -0
- data/{lib/generators/templates/public → public}/javascripts/rails.js +0 -0
- data/{lib/generators/templates/public → public}/javascripts/taxonomy.js +0 -0
- data/{lib/generators/templates/public → public}/javascripts/zone.js +0 -0
- data/{lib/generators/templates/public → public}/stylesheets/admin/admin-forms.css +0 -0
- data/{lib/generators/templates/public → public}/stylesheets/admin/admin-reset.css +0 -0
- data/{lib/generators/templates/public → public}/stylesheets/admin/admin-tables.css +0 -0
- data/{lib/generators/templates/public → public}/stylesheets/admin/admin-typography.css +0 -0
- data/{lib/generators/templates/public → public}/stylesheets/admin/admin.css +21 -18
- data/{lib/generators/templates/public → public}/stylesheets/admin/autocomplete.css +0 -1
- data/{lib/generators/templates/public → public}/stylesheets/admin/dashboard.css +0 -0
- data/{lib/generators/templates/public → public}/stylesheets/admin/edit_checkouts.css +0 -0
- data/{lib/generators/templates/public → public}/stylesheets/admin/grids.css +0 -0
- data/{lib/generators/templates/public → public}/stylesheets/admin/reset-fonts-grids-2-6-0.css +0 -0
- data/{lib/generators/templates/public → public}/stylesheets/admin/token-input.css +0 -0
- data/{lib/generators/templates/public → public}/stylesheets/admin/yui-includes.css +0 -0
- data/{lib/generators/templates/public → public}/stylesheets/datepicker.css +0 -0
- data/{lib/generators/templates/public → public}/stylesheets/jquery.autocomplete.css +0 -0
- data/{lib/generators/templates/public → public}/stylesheets/scaffold.css +0 -0
- data/{lib/generators/templates/public → public}/stylesheets/screen.css +0 -0
- metadata +475 -402
- data/app/controllers/admin/checkouts_controller.rb +0 -58
- data/app/models/checkout.rb +0 -141
- data/app/models/order_mailer.rb +0 -24
- data/app/views/admin/checkouts/show.html.erb +0 -131
- data/app/views/admin/mail_settings/edit.html.erb +0 -114
- data/app/views/admin/mail_settings/show.html.erb +0 -59
- data/app/views/admin/taxons/select.html.erb +0 -1
- data/app/views/checkout/_complete.html.erb +0 -1
- data/app/views/password_resets/edit.html.erb +0 -12
- data/app/views/password_resets/new.html.erb +0 -12
- data/config/initializers/touch.rb +0 -14
- data/lib/generators/spree_core/extension_generator.rb +0 -57
- data/lib/generators/spree_core/install_generator.rb +0 -59
- data/lib/generators/templates/LICENSE +0 -23
- data/lib/generators/templates/README.md +0 -13
- data/lib/generators/templates/Rakefile +0 -1
- data/lib/generators/templates/application_controller.rb +0 -4
- data/lib/generators/templates/extension.gemspec.tt +0 -21
- data/lib/generators/templates/extension/engine.rb.tt +0 -14
- data/lib/generators/templates/extension/extension.rb.tt +0 -1
- data/lib/generators/templates/lib/tasks/%file_name%.rake.tt +0 -1
- data/lib/generators/templates/public/javascripts/jquery-1.3.2.min.js +0 -19
- data/lib/generators/templates/public/javascripts/jquery-and-plugins.js +0 -36
- data/lib/generators/templates/spree_site.rb +0 -8
- data/lib/spree/search.rb +0 -47
- data/lib/spree_core/preferences/mail_settings.rb +0 -57
@@ -1,10 +1,6 @@
|
|
1
1
|
class Admin::ReturnAuthorizationsController < Admin::BaseController
|
2
2
|
resource_controller
|
3
3
|
belongs_to :order
|
4
|
-
ssl_required
|
5
|
-
|
6
|
-
new_action.before :returnable_units
|
7
|
-
edit.before :returnable_units
|
8
4
|
|
9
5
|
update.wants.html { redirect_to collection_url }
|
10
6
|
create.wants.html { redirect_to collection_url }
|
@@ -21,16 +17,7 @@ class Admin::ReturnAuthorizationsController < Admin::BaseController
|
|
21
17
|
end
|
22
18
|
|
23
19
|
private
|
24
|
-
|
25
|
-
|
26
|
-
|
27
|
-
|
28
|
-
@returned_units = @return_authorization.inventory_units.group_by(&:variant_id)
|
29
|
-
end
|
30
|
-
|
31
|
-
|
32
|
-
|
33
|
-
def associate_inventory_units
|
34
|
-
params[:return_quantity].each { |variant_id, qty| @return_authorization.add_variant(variant_id.to_i, qty.to_i) }
|
35
|
-
end
|
20
|
+
def associate_inventory_units
|
21
|
+
params[:return_quantity].each { |variant_id, qty| @return_authorization.add_variant(variant_id.to_i, qty.to_i) }
|
22
|
+
end
|
36
23
|
end
|
@@ -1,15 +1,14 @@
|
|
1
1
|
class Admin::ShipmentsController < Admin::BaseController
|
2
|
-
before_filter :load_data, :except => :country_changed
|
3
|
-
before_filter :require_object_editable_by_current_user, :only => [:update]
|
2
|
+
before_filter :load_data, :except => [:country_changed, :index]
|
4
3
|
|
5
4
|
resource_controller
|
6
5
|
belongs_to :order
|
7
6
|
|
8
7
|
update.wants.html do
|
9
|
-
if @order.
|
10
|
-
redirect_to admin_order_adjustments_url(@order)
|
11
|
-
else
|
8
|
+
if @order.completed?
|
12
9
|
redirect_to edit_object_url
|
10
|
+
else
|
11
|
+
redirect_to admin_order_adjustments_url(@order)
|
13
12
|
end
|
14
13
|
end
|
15
14
|
|
@@ -23,7 +22,6 @@ class Admin::ShipmentsController < Admin::BaseController
|
|
23
22
|
update.after :update_after
|
24
23
|
|
25
24
|
create.before :assign_inventory_units
|
26
|
-
create.after :recalculate_order
|
27
25
|
|
28
26
|
destroy.success.wants.js { render_js_for_destroy }
|
29
27
|
|
@@ -45,35 +43,27 @@ class Admin::ShipmentsController < Admin::BaseController
|
|
45
43
|
|
46
44
|
def load_data
|
47
45
|
load_object
|
48
|
-
@selected_country_id = params[:shipment_presenter][:address_country_id].to_i if params.has_key?('shipment_presenter')
|
49
46
|
@selected_country_id ||= @order.bill_address.country_id unless @order.nil? || @order.bill_address.nil?
|
50
47
|
@selected_country_id ||= Spree::Config[:default_country_id]
|
51
48
|
@shipping_methods = ShippingMethod.all_available(@order, :back_end)
|
52
49
|
|
53
50
|
@states = State.find_all_by_country_id(@selected_country_id, :order => 'name')
|
54
|
-
@countries =
|
55
|
-
@countries = [Country.find(Spree::Config[:default_country_id])] if @countries.empty?
|
51
|
+
@countries = available_countries
|
56
52
|
end
|
57
53
|
|
58
54
|
def edit_before # copy into instance variable before editing
|
59
|
-
@shipment.special_instructions = @order.
|
55
|
+
@shipment.special_instructions = @order.special_instructions
|
60
56
|
end
|
61
57
|
|
62
58
|
def update_after # copy back to order if instructions are enabled
|
63
|
-
@order.
|
64
|
-
@order.
|
59
|
+
@order.special_instructions = object_params[:special_instructions] if Spree::Config[:shipping_instructions]
|
60
|
+
@order.shipping_method = @order.shipment.shipping_method
|
65
61
|
@order.save
|
66
|
-
recalculate_order
|
67
62
|
end
|
68
63
|
|
69
64
|
def assign_inventory_units
|
70
65
|
return unless params.has_key? :inventory_units
|
71
|
-
#params[:inventory_units].each { |id, value| @shipment.inventory_units << InventoryUnit.find(id) }
|
72
66
|
@shipment.inventory_unit_ids = params[:inventory_units].keys
|
73
67
|
end
|
74
68
|
|
75
|
-
def recalculate_order
|
76
|
-
@shipment.recalculate_order if params[:recalculate]
|
77
|
-
end
|
78
|
-
|
79
69
|
end
|
@@ -38,13 +38,13 @@ class Admin::TaxonsController < Admin::BaseController
|
|
38
38
|
@product.taxons.delete(@taxon)
|
39
39
|
@product.save
|
40
40
|
@taxons = @product.taxons
|
41
|
-
|
41
|
+
render_js_for_destroy
|
42
42
|
end
|
43
43
|
|
44
44
|
def select
|
45
45
|
@product = Product.find_by_param!(params[:product_id])
|
46
|
-
taxon = Taxon.find(params[:id])
|
47
|
-
@product.taxons << taxon
|
46
|
+
@taxon = Taxon.find(params[:id])
|
47
|
+
@product.taxons << @taxon
|
48
48
|
@product.save
|
49
49
|
@taxons = @product.taxons
|
50
50
|
render :layout => false
|
@@ -1,5 +1,6 @@
|
|
1
1
|
class Admin::UsersController < Admin::BaseController
|
2
2
|
resource_controller
|
3
|
+
before_filter :check_json_authenticity, :only => :index
|
3
4
|
before_filter :load_roles, :only => [:edit, :new, :update, :create]
|
4
5
|
|
5
6
|
create.after :save_user_roles
|
@@ -9,7 +10,7 @@ class Admin::UsersController < Admin::BaseController
|
|
9
10
|
wants.html { render :action => :index }
|
10
11
|
wants.json { render :json => json_data }
|
11
12
|
end
|
12
|
-
|
13
|
+
|
13
14
|
destroy.success.wants.js { render_js_for_destroy }
|
14
15
|
|
15
16
|
private
|
@@ -21,12 +22,12 @@ class Admin::UsersController < Admin::BaseController
|
|
21
22
|
when 'basic'
|
22
23
|
collection.map {|u| {'id' => u.id, 'name' => u.email}}.to_json
|
23
24
|
else
|
24
|
-
collection.to_json(:include =>
|
25
|
-
{:bill_address => {:include => [:state, :country]},
|
25
|
+
collection.to_json(:include =>
|
26
|
+
{:bill_address => {:include => [:state, :country]},
|
26
27
|
:ship_address => {:include => [:state, :country]}})
|
27
28
|
end
|
28
29
|
end
|
29
|
-
|
30
|
+
|
30
31
|
def collection
|
31
32
|
return @collection if @collection.present?
|
32
33
|
unless request.xhr?
|
@@ -2,21 +2,40 @@
|
|
2
2
|
# Checkout object. There's enough distinct logic specific to checkout which has nothing to do with updating an
|
3
3
|
# order that this approach is waranted.
|
4
4
|
class CheckoutController < Spree::BaseController
|
5
|
+
ssl_required
|
5
6
|
|
6
7
|
before_filter :load_order
|
7
8
|
|
8
9
|
# Updates the order and advances to the next state (when possible.)
|
9
10
|
def update
|
10
11
|
if @order.update_attributes(object_params)
|
11
|
-
if @order.
|
12
|
+
if @order.next
|
13
|
+
state_callback(:after)
|
14
|
+
else
|
15
|
+
flash[:error] = I18n.t(:payment_processing_failed)
|
12
16
|
redirect_to checkout_state_path(@order.state) and return
|
13
17
|
end
|
18
|
+
|
19
|
+
if @order.state == "complete" or @order.completed?
|
20
|
+
flash[:notice] = I18n.t(:order_processed_successfully)
|
21
|
+
flash[:commerce_tracking] = "nothing special"
|
22
|
+
redirect_to completion_route
|
23
|
+
else
|
24
|
+
redirect_to checkout_state_path(@order.state)
|
25
|
+
end
|
26
|
+
|
27
|
+
else
|
28
|
+
render :edit
|
14
29
|
end
|
15
|
-
render :edit
|
16
30
|
end
|
17
31
|
|
18
32
|
private
|
19
33
|
|
34
|
+
# Provides a route to redirect after order completion
|
35
|
+
def completion_route
|
36
|
+
order_path(@order)
|
37
|
+
end
|
38
|
+
|
20
39
|
def object_params
|
21
40
|
# For payment step, filter order parameters to produce the expected nested attributes for a single payment and its source, discarding attributes for payment methods other than the one selected
|
22
41
|
if @order.payment?
|
@@ -33,12 +52,7 @@ class CheckoutController < Spree::BaseController
|
|
33
52
|
def load_order
|
34
53
|
@order = current_order
|
35
54
|
redirect_to cart_path and return unless @order and @order.checkout_allowed?
|
36
|
-
if @order.
|
37
|
-
session[:order_id] = nil
|
38
|
-
unless params[:state] == 'complete'
|
39
|
-
redirect_to cart_path and return
|
40
|
-
end
|
41
|
-
end
|
55
|
+
redirect_to cart_path and return if @order.completed?
|
42
56
|
@order.state = params[:state] if params[:state]
|
43
57
|
state_callback(:before)
|
44
58
|
end
|
@@ -61,6 +75,10 @@ class CheckoutController < Spree::BaseController
|
|
61
75
|
current_order.payments.destroy_all if request.put?
|
62
76
|
end
|
63
77
|
|
78
|
+
def after_complete
|
79
|
+
session[:order_id] = nil
|
80
|
+
end
|
81
|
+
|
64
82
|
def default_country
|
65
83
|
Country.find Spree::Config[:default_country_id]
|
66
84
|
end
|
@@ -1,11 +1,15 @@
|
|
1
1
|
class OrdersController < Spree::BaseController
|
2
|
-
ssl_required :show
|
3
2
|
|
4
3
|
helper :products
|
5
4
|
|
5
|
+
def show
|
6
|
+
@order = Order.find_by_number(params[:id])
|
7
|
+
end
|
8
|
+
|
6
9
|
def update
|
7
10
|
@order = current_order
|
8
11
|
if @order.update_attributes(params[:order])
|
12
|
+
@order.line_items = @order.line_items.select {|li| li.quantity > 0 }
|
9
13
|
redirect_to cart_path
|
10
14
|
else
|
11
15
|
render :edit
|
@@ -14,7 +18,7 @@ class OrdersController < Spree::BaseController
|
|
14
18
|
|
15
19
|
# Shows the current incomplete order from the session
|
16
20
|
def edit
|
17
|
-
@order = current_order
|
21
|
+
@order = current_order(true)
|
18
22
|
end
|
19
23
|
|
20
24
|
# Adds a new item to the order (creating a new order if none already exists)
|
@@ -24,14 +28,23 @@ class OrdersController < Spree::BaseController
|
|
24
28
|
# * Single variant/quantity pairing
|
25
29
|
# +:variants => {variant_id => quantity}+
|
26
30
|
#
|
27
|
-
# * Multiple products at once
|
28
|
-
# +:products => {product_id =>
|
29
|
-
# +:products => {product_id =>
|
31
|
+
# * Multiple products at once
|
32
|
+
# +:products => {product_id => variant_id, product_id => variant_id}, :quantity => quantity +
|
33
|
+
# +:products => {product_id => variant_id, product_id => variant_id}}, :quantity => {variant_id => quantity, variant_id => quantity}+
|
30
34
|
def populate
|
31
35
|
@order = current_order(true)
|
36
|
+
|
37
|
+
params[:products].each do |product_id,variant_id|
|
38
|
+
quantity = params[:quantity].to_i if !params[:quantity].is_a?(Hash)
|
39
|
+
quantity = params[:quantity][variant_id].to_i if params[:quantity].is_a?(Hash)
|
40
|
+
@order.add_variant(Variant.find(variant_id), quantity) if quantity > 0
|
41
|
+
end if params[:products]
|
42
|
+
|
32
43
|
params[:variants].each do |variant_id, quantity|
|
33
|
-
|
44
|
+
quantity = quantity.to_i
|
45
|
+
@order.add_variant(Variant.find(variant_id), quantity) if quantity > 0
|
34
46
|
end if params[:variants]
|
47
|
+
|
35
48
|
redirect_to cart_path
|
36
49
|
end
|
37
50
|
|
@@ -42,8 +55,7 @@ class OrdersController < Spree::BaseController
|
|
42
55
|
redirect_to cart_path
|
43
56
|
end
|
44
57
|
|
45
|
-
|
46
|
-
|
47
|
-
|
48
|
-
# end
|
58
|
+
def accurate_title
|
59
|
+
I18n.t(:shopping_cart)
|
60
|
+
end
|
49
61
|
end
|
@@ -8,8 +8,6 @@ class ProductsController < Spree::BaseController
|
|
8
8
|
helper :taxons
|
9
9
|
actions :show, :index
|
10
10
|
|
11
|
-
include Spree::Search
|
12
|
-
|
13
11
|
private
|
14
12
|
|
15
13
|
def load_data
|
@@ -29,7 +27,8 @@ class ProductsController < Spree::BaseController
|
|
29
27
|
end
|
30
28
|
|
31
29
|
def collection
|
32
|
-
|
30
|
+
@searcher = Spree::Config.searcher_class.new(params)
|
31
|
+
@products = @searcher.retrieve_products
|
33
32
|
end
|
34
33
|
|
35
34
|
def accurate_title
|
@@ -108,4 +108,12 @@ class Spree::BaseController < ActionController::Base
|
|
108
108
|
locale = I18n.default_locale unless I18n.available_locales.include?(locale.to_sym)
|
109
109
|
I18n.locale = locale.to_sym
|
110
110
|
end
|
111
|
+
|
112
|
+
helper_method :available_countries
|
113
|
+
|
114
|
+
def available_countries
|
115
|
+
return Country.all unless zone = Zone.find_by_name(Spree::Config[:checkout_zone])
|
116
|
+
zone.country_list
|
117
|
+
end
|
118
|
+
|
111
119
|
end
|
@@ -1,16 +1,16 @@
|
|
1
1
|
class TaxonsController < Spree::BaseController
|
2
|
-
prepend_before_filter :reject_unknown_object, :only => [:show]
|
2
|
+
#prepend_before_filter :reject_unknown_object, :only => [:show]
|
3
3
|
before_filter :load_data, :only => :show
|
4
4
|
resource_controller
|
5
5
|
actions :show
|
6
6
|
helper :products
|
7
7
|
|
8
|
-
include Spree::Search
|
9
|
-
|
10
8
|
private
|
11
9
|
def load_data
|
12
10
|
@taxon ||= object
|
13
|
-
|
11
|
+
params[:taxon] = @taxon.id
|
12
|
+
@searcher = Spree::Config.searcher_class.new(params)
|
13
|
+
@products = @searcher.retrieve_products
|
14
14
|
end
|
15
15
|
|
16
16
|
def object
|
@@ -48,16 +48,17 @@ module Admin::NavigationHelper
|
|
48
48
|
end
|
49
49
|
|
50
50
|
def link_to_delete(resource, options = {})
|
51
|
-
options.assert_valid_keys(:url, :caption, :title, :dataType, :success)
|
51
|
+
options.assert_valid_keys(:url, :caption, :title, :dataType, :success, :name)
|
52
52
|
|
53
53
|
options.reverse_merge! :url => object_url(resource) unless options.key? :url
|
54
54
|
options.reverse_merge! :caption => t('are_you_sure')
|
55
55
|
options.reverse_merge! :title => t('confirm_delete')
|
56
56
|
options.reverse_merge! :dataType => 'script'
|
57
57
|
options.reverse_merge! :success => "function(r){ jQuery('##{dom_id resource}').fadeOut('hide'); }"
|
58
|
+
options.reverse_merge! :name => icon("delete") + ' ' + t("delete")
|
58
59
|
|
59
60
|
#link_to_with_icon('delete', t("delete"), object_url(resource), :confirm => t('are_you_sure'), :method => :delete )
|
60
|
-
link_to_function
|
61
|
+
link_to_function options[:name], "jConfirm('#{options[:caption]}', '#{options[:title]}', function(r) {
|
61
62
|
if(r){
|
62
63
|
jQuery.ajax({
|
63
64
|
type: 'POST',
|
@@ -134,7 +135,7 @@ module Admin::NavigationHelper
|
|
134
135
|
<td>#{link_to(link_text, url)}</td>
|
135
136
|
<td>#{description}</td>
|
136
137
|
</tr>
|
137
|
-
)
|
138
|
+
).html_safe
|
138
139
|
end
|
139
140
|
|
140
141
|
end
|
@@ -3,7 +3,7 @@ module CheckoutHelper
|
|
3
3
|
def checkout_progress
|
4
4
|
states = %w(address delivery payment confirm complete)
|
5
5
|
items = states.map do |state|
|
6
|
-
text = t("
|
6
|
+
text = t("order_state.#{state}").titleize
|
7
7
|
|
8
8
|
css_classes = []
|
9
9
|
current_index = states.index(@order.state)
|
@@ -24,9 +24,4 @@ module CheckoutHelper
|
|
24
24
|
content_tag('ol', raw(items.join("\n")), :class => 'progress-steps', :id => "checkout-step-#{@order.state}")
|
25
25
|
end
|
26
26
|
|
27
|
-
def available_countries
|
28
|
-
return Country.all unless zone = Zone.find_by_name(Spree::Config[:checkout_zone])
|
29
|
-
zone.country_list
|
30
|
-
end
|
31
|
-
|
32
27
|
end
|
@@ -8,6 +8,7 @@ module Spree::BaseHelper
|
|
8
8
|
css_class = 'empty'
|
9
9
|
else
|
10
10
|
text = "#{text}: (#{current_order.item_count}) #{order_price(current_order)}"
|
11
|
+
css_class = 'full'
|
11
12
|
end
|
12
13
|
link_to text, cart_path, :class => css_class
|
13
14
|
end
|
@@ -88,4 +89,5 @@ module Spree::BaseHelper
|
|
88
89
|
def logo(image_path=Spree::Config[:logo])
|
89
90
|
link_to image_tag(image_path), root_path
|
90
91
|
end
|
92
|
+
|
91
93
|
end
|
@@ -0,0 +1,19 @@
|
|
1
|
+
class OrderMailer < ActionMailer::Base
|
2
|
+
helper "spree/base"
|
3
|
+
|
4
|
+
def confirm_email(order, resend=false)
|
5
|
+
@order = order
|
6
|
+
subject = (resend ? "[RESEND] " : "")
|
7
|
+
subject += "#{Spree::Config[:site_name]} Order Confirmation ##{order.number}"
|
8
|
+
mail(:to => order.email,
|
9
|
+
:subject => subject)
|
10
|
+
end
|
11
|
+
|
12
|
+
def cancel_email(order, resend=false)
|
13
|
+
@order = order
|
14
|
+
subject = (resend ? "[RESEND] " : "")
|
15
|
+
subject += "#{Spree::Config[:site_name]} Cancellation of Order ##{order.number}"
|
16
|
+
mail(:to => order.email,
|
17
|
+
:subject => subject)
|
18
|
+
end
|
19
|
+
end
|
@@ -0,0 +1,11 @@
|
|
1
|
+
class ShipmentMailer < ActionMailer::Base
|
2
|
+
helper "spree/base"
|
3
|
+
|
4
|
+
def shipped_email(shipment, resend=false)
|
5
|
+
@shipment = shipment
|
6
|
+
subject = (resend ? "[RESEND] " : "")
|
7
|
+
subject += "#{Spree::Config[:site_name]} Shipment Notification ##{shipment.order.number}"
|
8
|
+
mail(:to => shipment.order.email,
|
9
|
+
:subject => subject)
|
10
|
+
end
|
11
|
+
end
|
data/app/models/address.rb
CHANGED
@@ -2,8 +2,6 @@ class Address < ActiveRecord::Base
|
|
2
2
|
belongs_to :country
|
3
3
|
belongs_to :state
|
4
4
|
|
5
|
-
has_many :billing_checkouts, :foreign_key => "bill_address_id", :class_name => "Checkout"
|
6
|
-
has_many :shipping_checkouts, :foreign_key => "ship_address_id", :class_name => "Checkout"
|
7
5
|
has_many :shipments
|
8
6
|
|
9
7
|
validates :firstname, :lastname, :address1, :city, :zipcode, :country, :phone, :presence => true
|
@@ -11,10 +9,6 @@ class Address < ActiveRecord::Base
|
|
11
9
|
validates :state_name, :presence => true, :if => Proc.new { |address| address.state.blank? && Spree::Config[:address_requires_state] }
|
12
10
|
validate :state_name_validate, :if => Proc.new { |address| address.state.blank? && Spree::Config[:address_requires_state] }
|
13
11
|
|
14
|
-
def checkouts
|
15
|
-
(billing_checkouts + shipping_checkouts).uniq
|
16
|
-
end
|
17
|
-
|
18
12
|
# disconnected since there's no code to display error messages yet OR matching client-side validation
|
19
13
|
def phone_validate
|
20
14
|
return if phone.blank?
|
@@ -38,9 +32,9 @@ class Address < ActiveRecord::Base
|
|
38
32
|
end
|
39
33
|
|
40
34
|
# can modify an address if it's not been used in an order (but checkouts controller has finer control)
|
41
|
-
def editable?
|
42
|
-
|
43
|
-
end
|
35
|
+
# def editable?
|
36
|
+
# new_record? || (shipments.empty? && checkouts.empty?)
|
37
|
+
# end
|
44
38
|
|
45
39
|
def full_name
|
46
40
|
self.firstname + " " + self.lastname
|