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.
- data/LICENSE +1 -1
- data/app/assets/javascripts/admin/shipping_methods.js +14 -0
- data/app/assets/stylesheets/store/reset.css +1 -1
- data/app/controllers/spree/admin/orders/customer_details_controller.rb +1 -1
- data/app/controllers/spree/admin/resource_controller.rb +1 -1
- data/app/controllers/spree/admin/shipping_methods_controller.rb +9 -0
- data/app/controllers/spree/admin/users_controller.rb +7 -0
- data/app/helpers/spree/admin/base_helper.rb +4 -3
- data/app/helpers/spree/admin/navigation_helper.rb +3 -1
- data/app/models/spree/order.rb +3 -3
- data/app/models/spree/preferences/preferable.rb +9 -0
- data/app/models/spree/product.rb +2 -2
- data/app/models/spree/shipment.rb +1 -1
- data/app/models/spree/shipping_category.rb +2 -0
- data/app/models/spree/shipping_method.rb +17 -1
- data/app/models/spree/tax_rate.rb +3 -1
- data/app/models/spree/variant.rb +1 -1
- data/app/models/spree/zone.rb +9 -9
- data/app/views/spree/admin/adjustments/edit.html.erb +1 -1
- data/app/views/spree/admin/orders/_form.html.erb +1 -1
- data/app/views/spree/admin/orders/customer_details/_form.html.erb +1 -1
- data/app/views/spree/admin/payment_methods/edit.html.erb +1 -1
- data/app/views/spree/admin/product_properties/index.html.erb +1 -1
- data/app/views/spree/admin/products/edit.html.erb +1 -1
- data/app/views/spree/admin/shared/_destroy.js.erb +1 -1
- data/app/views/spree/admin/shipments/edit.html.erb +1 -1
- data/app/views/spree/admin/shipping_methods/_form.html.erb +15 -0
- data/app/views/spree/admin/taxons/edit.html.erb +1 -1
- data/app/views/spree/admin/zones/_form.html.erb +4 -5
- data/app/views/spree/checkout/edit.html.erb +1 -1
- data/app/views/spree/checkout/registration.html.erb +1 -1
- data/app/views/spree/orders/new.html.erb +1 -1
- data/app/views/spree/shared/_filters.html.erb +1 -1
- data/config/locales/en.yml +9 -2
- data/config/routes.rb +1 -0
- data/db/migrate/20120105193911_associate_shipping_methods_and_shipping_categories.rb +7 -0
- data/db/migrate/20120105195817_add_match_rules_to_shipping_methods.rb +7 -0
- data/lib/generators/spree/dummy/dummy_generator.rb +1 -0
- data/lib/generators/spree/dummy/templates/rails/script/rails +6 -0
- data/lib/generators/spree/install/install_generator.rb +167 -0
- data/lib/generators/spree/install/templates/app/assets/javascripts/admin/all.js +15 -0
- data/lib/generators/spree/install/templates/app/assets/javascripts/store/all.js +15 -0
- data/lib/generators/spree/install/templates/app/assets/stylesheets/admin/all.css +16 -0
- data/lib/generators/spree/install/templates/app/assets/stylesheets/store/all.css +16 -0
- data/lib/generators/spree/install/templates/config/initializers/spree.rb +9 -0
- data/lib/spree/core.rb +2 -2
- data/lib/spree/core/controller_helpers.rb +6 -0
- data/lib/spree/core/engine.rb +1 -1
- data/lib/spree/core/middleware/seo_assist.rb +2 -1
- data/lib/spree/core/ssl_requirement.rb +2 -2
- data/lib/spree/core/testing_support/common_rake.rb +1 -1
- data/lib/spree/core/testing_support/factories/shipping_method_factory.rb +10 -0
- data/lib/spree/core/version.rb +1 -1
- data/lib/spree/product_filters.rb +9 -7
- metadata +125 -242
- data/lib/generators/spree/extension/extension_generator.rb +0 -25
- data/lib/generators/spree/extension/templates/Gemfile +0 -13
- data/lib/generators/spree/extension/templates/LICENSE +0 -26
- data/lib/generators/spree/extension/templates/README.md +0 -21
- data/lib/generators/spree/extension/templates/Rakefile +0 -29
- data/lib/generators/spree/extension/templates/Versionfile +0 -9
- data/lib/generators/spree/extension/templates/app/assets/javascripts/admin/%file_name%.js +0 -1
- data/lib/generators/spree/extension/templates/app/assets/javascripts/store/%file_name%.js +0 -1
- data/lib/generators/spree/extension/templates/app/assets/stylesheets/admin/%file_name%.css +0 -3
- data/lib/generators/spree/extension/templates/app/assets/stylesheets/store/%file_name%.css +0 -3
- data/lib/generators/spree/extension/templates/config/locales/en.yml +0 -5
- data/lib/generators/spree/extension/templates/config/routes.rb +0 -3
- data/lib/generators/spree/extension/templates/extension.gemspec +0 -26
- data/lib/generators/spree/extension/templates/gitignore +0 -10
- data/lib/generators/spree/extension/templates/lib/%file_name%.rb.tt +0 -2
- data/lib/generators/spree/extension/templates/lib/%file_name%/engine.rb.tt +0 -20
- data/lib/generators/spree/extension/templates/lib/generators/%file_name%/install/install_generator.rb.tt +0 -29
- data/lib/generators/spree/extension/templates/rspec +0 -1
- data/lib/generators/spree/extension/templates/script/rails.tt +0 -5
- data/lib/generators/spree/extension/templates/spec/spec_helper.rb.tt +0 -32
data/LICENSE
CHANGED
@@ -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
|
+
});
|
@@ -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
|
33
|
+
redirect_to admin_order_customer_path(@order)
|
34
34
|
end
|
35
35
|
else
|
36
36
|
render :action => :edit
|
@@ -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
|
-
|
183
|
-
|
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
|
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
|
data/app/models/spree/order.rb
CHANGED
@@ -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 =>
|
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
|
-
|
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
|
-
|
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
|
data/app/models/spree/product.rb
CHANGED
@@ -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
|
@@ -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
|
-
|
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
|
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
|
data/app/models/spree/variant.rb
CHANGED
@@ -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 :
|
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.
|
data/app/models/spree/zone.rb
CHANGED
@@ -111,18 +111,18 @@ module Spree
|
|
111
111
|
end
|
112
112
|
|
113
113
|
private
|
114
|
-
|
115
|
-
|
116
|
-
|
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
|
-
|
121
|
-
|
120
|
+
def remove_previous_default
|
121
|
+
return unless self.default_tax
|
122
122
|
|
123
|
-
|
124
|
-
|
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), :
|
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), :
|
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">
|
@@ -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), :
|
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), :
|
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], :
|
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 %>
|
@@ -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), :
|
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>
|
30
|
+
<%= f.check_box :match_none %> <%= f.label :match_none, t('match_choices.none') %>
|
31
|
+
<%= f.check_box :match_one %> <%= f.label :match_one, t('match_choices.one') %>
|
32
|
+
<%= f.check_box :match_all %> <%= 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], :
|
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>
|
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>
|
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 } %>
|
@@ -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, :
|
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 =>'#', :
|
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
|
|