spree_core 1.0.0.rc1 → 1.0.0.rc2

Sign up to get free protection for your applications and to get access to all the features.
Files changed (75) hide show
  1. data/LICENSE +1 -1
  2. data/app/assets/javascripts/admin/shipping_methods.js +14 -0
  3. data/app/assets/stylesheets/store/reset.css +1 -1
  4. data/app/controllers/spree/admin/orders/customer_details_controller.rb +1 -1
  5. data/app/controllers/spree/admin/resource_controller.rb +1 -1
  6. data/app/controllers/spree/admin/shipping_methods_controller.rb +9 -0
  7. data/app/controllers/spree/admin/users_controller.rb +7 -0
  8. data/app/helpers/spree/admin/base_helper.rb +4 -3
  9. data/app/helpers/spree/admin/navigation_helper.rb +3 -1
  10. data/app/models/spree/order.rb +3 -3
  11. data/app/models/spree/preferences/preferable.rb +9 -0
  12. data/app/models/spree/product.rb +2 -2
  13. data/app/models/spree/shipment.rb +1 -1
  14. data/app/models/spree/shipping_category.rb +2 -0
  15. data/app/models/spree/shipping_method.rb +17 -1
  16. data/app/models/spree/tax_rate.rb +3 -1
  17. data/app/models/spree/variant.rb +1 -1
  18. data/app/models/spree/zone.rb +9 -9
  19. data/app/views/spree/admin/adjustments/edit.html.erb +1 -1
  20. data/app/views/spree/admin/orders/_form.html.erb +1 -1
  21. data/app/views/spree/admin/orders/customer_details/_form.html.erb +1 -1
  22. data/app/views/spree/admin/payment_methods/edit.html.erb +1 -1
  23. data/app/views/spree/admin/product_properties/index.html.erb +1 -1
  24. data/app/views/spree/admin/products/edit.html.erb +1 -1
  25. data/app/views/spree/admin/shared/_destroy.js.erb +1 -1
  26. data/app/views/spree/admin/shipments/edit.html.erb +1 -1
  27. data/app/views/spree/admin/shipping_methods/_form.html.erb +15 -0
  28. data/app/views/spree/admin/taxons/edit.html.erb +1 -1
  29. data/app/views/spree/admin/zones/_form.html.erb +4 -5
  30. data/app/views/spree/checkout/edit.html.erb +1 -1
  31. data/app/views/spree/checkout/registration.html.erb +1 -1
  32. data/app/views/spree/orders/new.html.erb +1 -1
  33. data/app/views/spree/shared/_filters.html.erb +1 -1
  34. data/config/locales/en.yml +9 -2
  35. data/config/routes.rb +1 -0
  36. data/db/migrate/20120105193911_associate_shipping_methods_and_shipping_categories.rb +7 -0
  37. data/db/migrate/20120105195817_add_match_rules_to_shipping_methods.rb +7 -0
  38. data/lib/generators/spree/dummy/dummy_generator.rb +1 -0
  39. data/lib/generators/spree/dummy/templates/rails/script/rails +6 -0
  40. data/lib/generators/spree/install/install_generator.rb +167 -0
  41. data/lib/generators/spree/install/templates/app/assets/javascripts/admin/all.js +15 -0
  42. data/lib/generators/spree/install/templates/app/assets/javascripts/store/all.js +15 -0
  43. data/lib/generators/spree/install/templates/app/assets/stylesheets/admin/all.css +16 -0
  44. data/lib/generators/spree/install/templates/app/assets/stylesheets/store/all.css +16 -0
  45. data/lib/generators/spree/install/templates/config/initializers/spree.rb +9 -0
  46. data/lib/spree/core.rb +2 -2
  47. data/lib/spree/core/controller_helpers.rb +6 -0
  48. data/lib/spree/core/engine.rb +1 -1
  49. data/lib/spree/core/middleware/seo_assist.rb +2 -1
  50. data/lib/spree/core/ssl_requirement.rb +2 -2
  51. data/lib/spree/core/testing_support/common_rake.rb +1 -1
  52. data/lib/spree/core/testing_support/factories/shipping_method_factory.rb +10 -0
  53. data/lib/spree/core/version.rb +1 -1
  54. data/lib/spree/product_filters.rb +9 -7
  55. metadata +125 -242
  56. data/lib/generators/spree/extension/extension_generator.rb +0 -25
  57. data/lib/generators/spree/extension/templates/Gemfile +0 -13
  58. data/lib/generators/spree/extension/templates/LICENSE +0 -26
  59. data/lib/generators/spree/extension/templates/README.md +0 -21
  60. data/lib/generators/spree/extension/templates/Rakefile +0 -29
  61. data/lib/generators/spree/extension/templates/Versionfile +0 -9
  62. data/lib/generators/spree/extension/templates/app/assets/javascripts/admin/%file_name%.js +0 -1
  63. data/lib/generators/spree/extension/templates/app/assets/javascripts/store/%file_name%.js +0 -1
  64. data/lib/generators/spree/extension/templates/app/assets/stylesheets/admin/%file_name%.css +0 -3
  65. data/lib/generators/spree/extension/templates/app/assets/stylesheets/store/%file_name%.css +0 -3
  66. data/lib/generators/spree/extension/templates/config/locales/en.yml +0 -5
  67. data/lib/generators/spree/extension/templates/config/routes.rb +0 -3
  68. data/lib/generators/spree/extension/templates/extension.gemspec +0 -26
  69. data/lib/generators/spree/extension/templates/gitignore +0 -10
  70. data/lib/generators/spree/extension/templates/lib/%file_name%.rb.tt +0 -2
  71. data/lib/generators/spree/extension/templates/lib/%file_name%/engine.rb.tt +0 -20
  72. data/lib/generators/spree/extension/templates/lib/generators/%file_name%/install/install_generator.rb.tt +0 -29
  73. data/lib/generators/spree/extension/templates/rspec +0 -1
  74. data/lib/generators/spree/extension/templates/script/rails.tt +0 -5
  75. data/lib/generators/spree/extension/templates/spec/spec_helper.rb.tt +0 -32
data/LICENSE CHANGED
@@ -1,4 +1,4 @@
1
- Copyright (c) 2007-2011, Spree Commerce, Inc. and other contributors
1
+ Copyright (c) 2007-2012, Spree Commerce, Inc. and other contributors
2
2
  All rights reserved.
3
3
 
4
4
  Redistribution and use in source and binary forms, with or without modification,
@@ -0,0 +1,14 @@
1
+ $(document).ready(function() {
2
+ if ($(".categories input:checked").length > 0) {
3
+ $('input[type=checkbox]:not(:checked)').attr('disabled', true);
4
+ }
5
+
6
+ $('.categories input[type=checkbox]').change(function(){
7
+ if($(this).is(':checked')) {
8
+ $('input[type=checkbox]').attr('disabled', true);
9
+ $(this).removeAttr('disabled');
10
+ } else {
11
+ $('input[type=checkbox]').removeAttr('disabled');
12
+ }
13
+ });
14
+ });
@@ -172,4 +172,4 @@ th, td, caption { padding: 4px 10px 4px 5px; }
172
172
  tr.even td { background: #e5ecf9; }
173
173
  tfoot { font-style: italic; }
174
174
  caption { background: #eeeeee; }
175
-
175
+ input[type="number"] { width: 42px; }
@@ -30,7 +30,7 @@ module Spree
30
30
  redirect_to edit_admin_order_shipment_path(@order, @order.shipment)
31
31
  else
32
32
  flash[:error] = t('errors.messages.no_shipping_methods_available')
33
- redirect_to user_admin_order_path(@order)
33
+ redirect_to admin_order_customer_path(@order)
34
34
  end
35
35
  else
36
36
  render :action => :edit
@@ -34,7 +34,7 @@ class Spree::Admin::ResourceController < Spree::Admin::BaseController
34
34
  end
35
35
  else
36
36
  invoke_callbacks(:update, :fails)
37
- respond_with(@object)
37
+ respond_with(@object, :location => [:admin, @object])
38
38
  end
39
39
  end
40
40
 
@@ -2,8 +2,17 @@ module Spree
2
2
  module Admin
3
3
  class ShippingMethodsController < ResourceController
4
4
  before_filter :load_data, :except => [:index]
5
+ before_filter :set_shipping_category, :only => [:create, :update]
5
6
 
6
7
  private
8
+
9
+ def set_shipping_category
10
+ return true if params[:shipping_method][:shipping_category_id] == ""
11
+ @shipping_method.shipping_category = Spree::ShippingCategory.find(params[:shipping_method][:shipping_category_id])
12
+ @shipping_method.save
13
+ params[:shipping_method].delete(:shipping_category_id)
14
+ end
15
+
7
16
  def location_after_save
8
17
  edit_admin_shipping_method_path(@shipping_method)
9
18
  end
@@ -7,6 +7,7 @@ module Spree
7
7
 
8
8
  create.after :save_user_roles
9
9
  update.before :save_user_roles
10
+ update.after :sign_in_if_change_own_password
10
11
 
11
12
  def index
12
13
  respond_with(@collection) do |format|
@@ -65,6 +66,12 @@ module Spree
65
66
  def load_roles
66
67
  @roles = Role.all
67
68
  end
69
+
70
+ def sign_in_if_change_own_password
71
+ if current_user == @user && @user.password.present?
72
+ sign_in(@user, :event => :authentication, :bypass => true)
73
+ end
74
+ end
68
75
  end
69
76
  end
70
77
  end
@@ -178,9 +178,10 @@ module Spree
178
178
  end
179
179
 
180
180
  def product_picker_field(name, value)
181
- products = Product.with_ids(value)
182
- product_names_hash = products.inject({}){|memo,item| memo[item.id] = item.name; memo}
183
- %(<input type="text" name="#{name}" value="#{value}" class="tokeninput products" data-names='#{product_names_hash.to_json}' />).html_safe
181
+ products = Product.with_ids(value.split(','))
182
+ product_names = products.inject({}){|memo,item| memo[item.id] = item.name; memo}
183
+ product_rules = products.collect{ |p| { :id => p.id, :name => p.name } }
184
+ %(<input type="text" name="#{name}" value="#{value}" class="tokeninput products" data-names='#{product_names.to_json}' data-pre='#{product_rules.to_json}'/>).html_safe
184
185
  end
185
186
 
186
187
  # renders set of hidden fields and button to add new record using nested_attributes
@@ -22,7 +22,9 @@ module Spree
22
22
  css_classes = []
23
23
 
24
24
  selected = if options[:match_path]
25
- request.fullpath.starts_with?("/admin#{options[:match_path]}")
25
+ # TODO: `request.fullpath` for engines mounted at '/' returns '//'
26
+ # which seems an issue with Rails routing.- revisit issue #910
27
+ request.fullpath.gsub('//', '/').starts_with?("#{root_path}admin#{options[:match_path]}")
26
28
  else
27
29
  args.include?(controller.controller_name.to_sym)
28
30
  end
@@ -87,7 +87,7 @@ module Spree
87
87
  end
88
88
 
89
89
  # order state machine (see http://github.com/pluginaweek/state_machine/tree/master for details)
90
- state_machine :initial => :cart, :use_transactions => false do
90
+ state_machine :initial => 'cart', :use_transactions => false do
91
91
 
92
92
  event :next do
93
93
  transition :from => 'cart', :to => 'address'
@@ -547,7 +547,7 @@ module Spree
547
547
  shipments.each do |shipment|
548
548
  shipment.inventory_units.each do |inventory_unit|
549
549
  line_item = line_items.find_by_variant_id(inventory_unit.variant_id)
550
- Spree::InventoryUnit.decrease(self, inventory_unit.variant, line_item.quantity)
550
+ InventoryUnit.decrease(self, inventory_unit.variant, line_item.quantity)
551
551
  end
552
552
  end
553
553
  end
@@ -560,7 +560,7 @@ module Spree
560
560
  shipments.each do |shipment|
561
561
  shipment.inventory_units.each do |inventory_unit|
562
562
  line_item = line_items.find_by_variant_id(inventory_unit.variant_id)
563
- Spree::InventoryUnit.increase(self, inventory_unit.variant, line_item.quantity)
563
+ InventoryUnit.increase(self, inventory_unit.variant, line_item.quantity)
564
564
  end
565
565
  end
566
566
  end
@@ -8,6 +8,11 @@ module Spree::Preferences::Preferable
8
8
  def self.included(base)
9
9
  base.class_eval do
10
10
  extend Spree::Preferences::PreferableClassMethods
11
+ if respond_to?(:after_destroy)
12
+ after_destroy do |obj|
13
+ obj.clear_preferences
14
+ end
15
+ end
11
16
  end
12
17
  end
13
18
 
@@ -62,6 +67,10 @@ module Spree::Preferences::Preferable
62
67
  [self.class.name, name, (try(:id) || :new)].join('::').underscore
63
68
  end
64
69
 
70
+ def clear_preferences
71
+ preferences.keys.each {|pref| preference_store.delete preference_cache_key(pref)}
72
+ end
73
+
65
74
  private
66
75
 
67
76
  def preference_store
@@ -40,9 +40,9 @@ module Spree
40
40
  after_create :add_properties_and_option_types_from_prototype
41
41
  before_save :recalculate_count_on_hand
42
42
  after_save :update_memberships if ProductGroup.table_exists?
43
- after_save :set_master_on_hand_to_zero_when_product_has_variants
44
43
  after_save :save_master
45
-
44
+ after_save :set_master_on_hand_to_zero_when_product_has_variants
45
+
46
46
  has_many :variants,
47
47
  :class_name => 'Spree::Variant',
48
48
  :conditions => ["#{::Spree::Variant.quoted_table_name}.is_master = ? AND #{::Spree::Variant.quoted_table_name}.deleted_at IS NULL", false],
@@ -7,7 +7,7 @@ module Spree
7
7
  belongs_to :address
8
8
  has_many :state_events, :as => :stateful
9
9
  has_many :inventory_units, :dependent => :nullify
10
- has_one :adjustment, :as => :source
10
+ has_one :adjustment, :as => :source, :dependent => :destroy
11
11
 
12
12
  before_create :generate_shipment_number
13
13
  after_save :ensure_correct_adjustment, :update_order
@@ -1,5 +1,7 @@
1
1
  module Spree
2
2
  class ShippingCategory < ActiveRecord::Base
3
3
  validates :name, :presence => true
4
+ has_many :products
5
+ has_many :shipping_methods
4
6
  end
5
7
  end
@@ -4,6 +4,7 @@ module Spree
4
4
  belongs_to :zone
5
5
  has_many :shipments
6
6
  validates :name, :calculator, :zone, :presence => true
7
+ belongs_to :shipping_category
7
8
 
8
9
  calculated_adjustments
9
10
 
@@ -16,7 +17,22 @@ module Spree
16
17
  def available_to_order?(order, display_on=nil)
17
18
  availability_check = available?(order,display_on)
18
19
  zone_check = zone && zone.include?(order.ship_address)
19
- availability_check && zone_check
20
+ category_check = category_match?(order)
21
+ availability_check && zone_check && category_check
22
+ end
23
+
24
+ # Indicates whether or not the category rules for this shipping method
25
+ # are satisfied (if applicable)
26
+ def category_match?(order)
27
+ return true if shipping_category.nil?
28
+
29
+ if match_all
30
+ order.products.all? { |p| p.shipping_category == shipping_category }
31
+ elsif match_one
32
+ order.products.any? { |p| p.shipping_category == shipping_category }
33
+ elsif match_none
34
+ order.products.all? { |p| p.shipping_category != shipping_category }
35
+ end
20
36
  end
21
37
 
22
38
  def self.all_available(order, display_on=nil)
@@ -23,7 +23,9 @@ module Spree
23
23
  # Gets the array of TaxRates appropriate for the specified order
24
24
  def self.match(order)
25
25
  return [] unless order.tax_zone
26
- all.select { |rate| rate.zone == order.tax_zone || rate.zone.contains?(order.tax_zone) }
26
+ all.select do |rate|
27
+ rate.zone == order.tax_zone || rate.zone.contains?(order.tax_zone) || rate.zone.default_tax
28
+ end
27
29
  end
28
30
 
29
31
  # For Vat the default rate is the rate that is configured for the default category
@@ -27,7 +27,7 @@ module Spree
27
27
 
28
28
  # Returns number of inventory units for this variant (new records haven't been saved to database, yet)
29
29
  def on_hand
30
- Spree::Config[:track_inventory_levels] ? self.count_on_hand : nil
30
+ Spree::Config[:track_inventory_levels] ? self.count_on_hand : (1.0/0) # Infinity
31
31
  end
32
32
 
33
33
  # Adjusts the inventory units to match the given new level.
@@ -111,18 +111,18 @@ module Spree
111
111
  end
112
112
 
113
113
  private
114
- def remove_defunct_members
115
- zone_members.each do |zone_member|
116
- zone_member.destroy if zone_member.zoneable_id.nil?
114
+ def remove_defunct_members
115
+ zone_members.each do |zone_member|
116
+ zone_member.destroy if zone_member.zoneable_id.nil? || zone_member.zoneable_type != "Spree::#{self.kind.capitalize}"
117
+ end
117
118
  end
118
- end
119
119
 
120
- def remove_previous_default
121
- return unless self.default_tax
120
+ def remove_previous_default
121
+ return unless self.default_tax
122
122
 
123
- Zone.all.each do |zone|
124
- zone.update_attribute "default_tax", false unless zone == self
123
+ Zone.all.each do |zone|
124
+ zone.update_attribute "default_tax", false unless zone == self
125
+ end
125
126
  end
126
- end
127
127
  end
128
128
  end
@@ -3,7 +3,7 @@
3
3
  <h2><%= t(:adjustment) %></h2>
4
4
 
5
5
  <%= render :partial => 'spree/shared/error_messages', :locals => { :target => @adjustment } %>
6
- <%= form_for @adjustment, :url => admin_order_adjustment_path(@order, @adjustment), :html => { :method => :put} do |f| %>
6
+ <%= form_for @adjustment, :url => admin_order_adjustment_path(@order, @adjustment), :method => :put do |f| %>
7
7
  <%= render :partial => 'form', :locals => { :f => f } %>
8
8
 
9
9
  <p class="form-buttons" data-hook="buttons">
@@ -2,7 +2,7 @@
2
2
  <%= render :partial => 'spree/shared/error_messages', :locals => { :target => @line_item } %>
3
3
  <% end %>
4
4
 
5
- <%= form_for @order, :url => admin_order_url(@order), :html => { :method => :put} do |f| %>
5
+ <%= form_for @order, :url => admin_order_url(@order), :method => :put do |f| %>
6
6
  <%= f.hidden_field :number %>
7
7
  <table class="index">
8
8
  <tbody id="line-items">
@@ -43,6 +43,6 @@
43
43
  </p>
44
44
 
45
45
  <% content_for :head do %>
46
- <%= javascript_include_tag '/states.js', 'admin/address_states.js' %>
46
+ <%= javascript_include_tag states_path, 'admin/address_states.js' %>
47
47
  <% end %>
48
48
 
@@ -2,7 +2,7 @@
2
2
 
3
3
  <h1><%= t(:editing_payment_method) %></h1>
4
4
  <%= render :partial => 'spree/shared/error_messages', :locals => { :target => @payment_method } %>
5
- <%= form_for @payment_method, :url => admin_payment_method_path(@payment_method), :html => { :method => :put } do |f| %>
5
+ <%= form_for @payment_method, :url => admin_payment_method_path(@payment_method), :method => :put do |f| %>
6
6
  <%= render :partial => 'form', :locals => { :f => f } %>
7
7
  <p data-hook="buttons">
8
8
  <%= submit_tag t(:update) %>
@@ -4,7 +4,7 @@
4
4
 
5
5
  <%= render :partial => 'spree/shared/error_messages', :locals => { :target => @product } %>
6
6
 
7
- <%= form_for @product, :url => admin_product_url(@product), :html => { :method => :put } do |f| %>
7
+ <%= form_for @product, :url => admin_product_url(@product), :method => :put do |f| %>
8
8
  <table class="index">
9
9
  <thead>
10
10
  <tr data-hook="product_properties_header">
@@ -3,7 +3,7 @@
3
3
  <%= render :partial => 'spree/admin/shared/product_tabs', :locals => { :current => 'Product Details' } %>
4
4
  <%= render :partial => 'spree/shared/error_messages', :locals => { :target => @product } %>
5
5
 
6
- <%= form_for [:admin, @product], :html => { :method => :put, :multipart => true } do |f| %>
6
+ <%= form_for [:admin, @product], :method => :put, :html => { :multipart => true } do |f| %>
7
7
  <%= render :partial => 'form', :locals => { :f => f } %>
8
8
  <%= render :partial => 'spree/admin/shared/edit_resource_links' %>
9
9
  <% end %>
@@ -13,4 +13,4 @@ if notice %>
13
13
  } <%
14
14
  end %>
15
15
 
16
- <%= render :partial => '/admin/shared/update_order_state' if @order %>
16
+ <%= render :partial => '/spree/admin/shared/update_order_state' if @order %>
@@ -21,7 +21,7 @@
21
21
  </div>
22
22
 
23
23
  <div data-hook="admin_shipment_edit_form">
24
- <%= form_for @shipment, :url => admin_order_shipment_path(@order, @shipment), :html => { :method => :put } do |shipment_form| %>
24
+ <%= form_for @shipment, :url => admin_order_shipment_path(@order, @shipment), :method => :put do |shipment_form| %>
25
25
  <%= render :partial => 'form', :locals => { :shipment_form => shipment_form } %>
26
26
 
27
27
  <div data-hook="admin_shipment_edit_form_buttons">
@@ -18,6 +18,21 @@
18
18
  <% end %>
19
19
  </div>
20
20
 
21
+ <div data-hook"admin_shipping_method_form_availability_fields">
22
+ <fieldset class="categories">
23
+ <legend><%= t(:availability) %></legend>
24
+ <%= f.field_container :shipping_category do %>
25
+ <%= f.label :shipping_category, t(:shipping_category_choose) %>
26
+ <%= select(:shipping_method, :shipping_category_id, Spree::ShippingCategory.all.collect { |s| [s.name, s.id] }, { :include_blank => true }) %>
27
+ <% end %>
28
+
29
+ <b><%= t(:match_rule) %></b>&nbsp;&nbsp;
30
+ <%= f.check_box :match_none %>&nbsp;<%= f.label :match_none, t('match_choices.none') %>
31
+ <%= f.check_box :match_one %>&nbsp;<%= f.label :match_one, t('match_choices.one') %>
32
+ <%= f.check_box :match_all %>&nbsp;<%= f.label :match_all, t('match_choices.all') %>
33
+ </fieldset>
34
+ </div>
35
+
21
36
  <div data-hook="admin_shipping_method_form_calculator_fields">
22
37
  <%= render :partial => 'spree/admin/shared/calculator_fields', :locals => { :f => f } %>
23
38
  </div>
@@ -2,7 +2,7 @@
2
2
 
3
3
  <h1><%= t(:taxon_edit) %></h1>
4
4
 
5
- <%= form_for [:admin, @taxonomy, @taxon], :html => { :method => :put, :multipart => true} do |f| %>
5
+ <%= form_for [:admin, @taxonomy, @taxon], :method => :put, :html => { :multipart => true } do |f| %>
6
6
  <%= render :partial => 'form', :locals => { :f => f } %>
7
7
 
8
8
  <p class="form-buttons" data-hook="buttons">
@@ -13,18 +13,17 @@
13
13
  <td><%= zone_form.check_box :default_tax %></td>
14
14
  </p>
15
15
 
16
-
17
16
  <p data-hook="type">
18
17
  <%= label_tag nil, t(:type) %><br />
19
18
  <label class="sub">
20
- <%= zone_form.radio_button('kind', 'country', {:id => 'country_based'}) %>
19
+ <%= zone_form.radio_button('kind', 'country', { :id => 'country_based' }) %>
21
20
  <%= t(:country_based) %>
22
21
  </label> &nbsp;
23
22
  <label class="sub">
24
- <%= zone_form.radio_button('kind', 'state', {:id => 'state_based'}) %>
23
+ <%= zone_form.radio_button('kind', 'state', { :id => 'state_based' }) %>
25
24
  <%= t(:state_based) %>
26
25
  </label> &nbsp;
27
26
  </p>
28
27
 
29
- <%= render :partial =>'member_type', :locals => { :type => 'country', :zone_form => zone_form }%>
30
- <%= render :partial =>'member_type', :locals => { :type => 'state', :zone_form => zone_form } %>
28
+ <%= render :partial => 'member_type', :locals => { :type => 'country', :zone_form => zone_form }%>
29
+ <%= render :partial => 'member_type', :locals => { :type => 'state', :zone_form => zone_form } %>
@@ -1,5 +1,5 @@
1
1
  <% content_for :head do %>
2
- <%= javascript_include_tag '/states' %>
2
+ <%= javascript_include_tag states_path %>
3
3
  <% end %>
4
4
  <div id="checkout" data-hook>
5
5
  <h1><%= t(:checkout) %></h1>
@@ -8,7 +8,7 @@
8
8
  <div id="guest_checkout" data-hook>
9
9
  <%= render :partial => 'spree/shared/error_messages', :locals => { :target => @order } %>
10
10
  <h2><%= t(:guest_user_account) %></h2>
11
- <%= form_for @order, :url => update_checkout_registration_path, :html => { :method => :put, :id => 'checkout_form_registration'} do |f| %>
11
+ <%= form_for @order, :url => update_checkout_registration_path, :method => :put, :html => { :id => 'checkout_form_registration' } do |f| %>
12
12
  <p>
13
13
  <%= f.label :email, t(:email) %><br />
14
14
  <%= f.email_field :email, :class => 'title' %>
@@ -2,7 +2,7 @@
2
2
 
3
3
  <h1><%= t(:shopping_cart) %></h1>
4
4
 
5
- <%= form_for @order, :url =>'#', :html => {:method => :put} do |order_form| %>
5
+ <%= form_for @order, :url =>'#', :method => :put do |order_form| %>
6
6
  <%= render :partial => 'form', :locals => { :order_form => order_form } %>
7
7
  <% end %>
8
8