spree_core 4.1.8 → 4.2.0.rc1

Sign up to get free protection for your applications and to get access to all the features.
Files changed (99) hide show
  1. checksums.yaml +4 -4
  2. data/app/controllers/spree/base_controller.rb +1 -0
  3. data/app/finders/spree/addresses/find.rb +17 -0
  4. data/app/helpers/spree/base_helper.rb +60 -13
  5. data/app/helpers/spree/mail_helper.rb +29 -0
  6. data/app/helpers/spree/products_helper.rb +2 -1
  7. data/app/mailers/spree/base_mailer.rb +17 -3
  8. data/app/mailers/spree/order_mailer.rb +11 -2
  9. data/app/mailers/spree/reimbursement_mailer.rb +4 -2
  10. data/app/mailers/spree/shipment_mailer.rb +4 -2
  11. data/app/models/concerns/spree/default_price.rb +2 -1
  12. data/app/models/concerns/spree/user_methods.rb +11 -5
  13. data/app/models/concerns/spree/user_payment_source.rb +1 -1
  14. data/app/models/spree/address.rb +13 -1
  15. data/app/models/spree/app_configuration.rb +5 -0
  16. data/app/models/spree/app_dependencies.rb +7 -1
  17. data/app/models/spree/credit_card.rb +5 -0
  18. data/app/models/spree/line_item.rb +12 -2
  19. data/app/models/spree/option_type.rb +5 -1
  20. data/app/models/spree/order.rb +33 -7
  21. data/app/models/spree/order/payments.rb +10 -2
  22. data/app/models/spree/preferences/store.rb +1 -1
  23. data/app/models/spree/price.rb +26 -2
  24. data/app/models/spree/product.rb +17 -7
  25. data/app/models/spree/promotion.rb +6 -0
  26. data/app/models/spree/promotion_handler/coupon.rb +1 -1
  27. data/app/models/spree/promotion_handler/promotion_duplicator.rb +9 -3
  28. data/app/models/spree/reimbursement.rb +2 -0
  29. data/app/models/spree/shipment.rb +2 -5
  30. data/app/models/spree/stock_location.rb +13 -2
  31. data/app/models/spree/store.rb +22 -2
  32. data/app/models/spree/variant.rb +20 -3
  33. data/app/presenters/spree/variant_presenter.rb +9 -1
  34. data/app/presenters/spree/variants/option_types_presenter.rb +1 -0
  35. data/app/services/spree/account/addresses/base.rb +39 -0
  36. data/app/services/spree/account/addresses/create.rb +18 -0
  37. data/app/services/spree/account/addresses/update.rb +18 -0
  38. data/app/services/spree/checkout/update.rb +13 -2
  39. data/app/views/layouts/spree/base_mailer.html.erb +45 -40
  40. data/app/views/spree/order_mailer/cancel_email.html.erb +19 -25
  41. data/app/views/spree/order_mailer/cancel_email.text.erb +24 -2
  42. data/app/views/spree/order_mailer/confirm_email.html.erb +18 -65
  43. data/app/views/spree/order_mailer/confirm_email.text.erb +2 -1
  44. data/app/views/spree/order_mailer/store_owner_notification_email.html.erb +23 -0
  45. data/app/views/spree/order_mailer/store_owner_notification_email.text.erb +38 -0
  46. data/app/views/spree/reimbursement_mailer/reimbursement_email.html.erb +53 -58
  47. data/app/views/spree/reimbursement_mailer/reimbursement_email.text.erb +3 -1
  48. data/app/views/spree/shared/_base_mailer_footer.html.erb +6 -14
  49. data/app/views/spree/shared/_base_mailer_header.html.erb +12 -32
  50. data/app/views/spree/shared/_base_mailer_stylesheets.html.erb +293 -625
  51. data/app/views/spree/shared/_purchased_items_table.html.erb +60 -0
  52. data/app/views/spree/shared/purchased_items_table/_adjustment.html.erb +13 -0
  53. data/app/views/spree/shared/purchased_items_table/_line_item.html.erb +27 -0
  54. data/app/views/spree/shared/purchased_items_table/_subtotal.html.erb +13 -0
  55. data/app/views/spree/shared/purchased_items_table/_total.html.erb +13 -0
  56. data/app/views/spree/shipment_mailer/shipped_email.html.erb +31 -36
  57. data/app/views/spree/shipment_mailer/shipped_email.text.erb +2 -1
  58. data/config/initializers/assets.rb +1 -0
  59. data/config/locales/en.yml +123 -16
  60. data/db/default/spree/countries.rb +10 -4
  61. data/db/default/spree/states.rb +42 -5
  62. data/db/default/spree/stores.rb +17 -12
  63. data/db/default/spree/zones.rb +1 -1
  64. data/db/migrate/20140309033438_create_store_from_preferences.rb +1 -1
  65. data/db/migrate/20191017121054_add_supported_currencies_to_store.rb +10 -0
  66. data/db/migrate/20200102141311_add_social_to_spree_stores.rb +3 -0
  67. data/db/migrate/20200308210757_add_default_locale_to_spree_store.rb +7 -0
  68. data/db/migrate/20200310145140_add_customer_support_email_to_spree_store.rb +7 -0
  69. data/db/migrate/20200421095017_add_compare_at_amount_to_spree_prices.rb +7 -0
  70. data/db/migrate/20200423123001_add_default_country_id_to_spree_store.rb +9 -0
  71. data/db/migrate/20200430072209_add_footer_fields_to_spree_stores.rb +8 -0
  72. data/db/migrate/20200513154939_add_show_property_to_spree_product_properties.rb +5 -0
  73. data/db/migrate/20200607161221_add_store_owner_order_notification_delivered_to_spree_orders.rb +7 -0
  74. data/db/migrate/20200607161222_add_new_order_notifications_email_to_spree_stores.rb +7 -0
  75. data/db/migrate/20200610113542_add_label_to_spree_addresses.rb +5 -0
  76. data/db/migrate/20200826075557_add_unique_index_on_taxon_id_and_product_id_to_spree_products_taxons.rb +5 -0
  77. data/db/migrate/20201013084504_add_seo_robots_to_spree_stores.rb +5 -0
  78. data/lib/generators/spree/install/templates/vendor/assets/javascripts/spree/backend/all.js +0 -2
  79. data/lib/generators/spree/install/templates/vendor/assets/javascripts/spree/frontend/all.js +0 -2
  80. data/lib/generators/spree/mailers_preview/mailers_preview_generator.rb +23 -0
  81. data/lib/generators/spree/mailers_preview/templates/mailers/previews/order_preview.rb +13 -0
  82. data/lib/generators/spree/mailers_preview/templates/mailers/previews/reimbursement_preview.rb +5 -0
  83. data/lib/generators/spree/mailers_preview/templates/mailers/previews/shipment_preview.rb +5 -0
  84. data/lib/generators/spree/mailers_preview/templates/mailers/previews/user_preview.rb +11 -0
  85. data/lib/spree/core.rb +2 -0
  86. data/lib/spree/core/controller_helpers/common.rb +1 -0
  87. data/lib/spree/core/controller_helpers/currency_helpers.rb +15 -0
  88. data/lib/spree/core/controller_helpers/order.rb +9 -4
  89. data/lib/spree/core/controller_helpers/store.rb +12 -1
  90. data/lib/spree/core/version.rb +1 -1
  91. data/lib/spree/permitted_attributes.rb +8 -5
  92. data/lib/spree/testing_support/authorization_helpers.rb +7 -4
  93. data/lib/spree/testing_support/factories/store_factory.rb +11 -8
  94. data/spree_core.gemspec +5 -4
  95. data/vendor/assets/javascripts/cleave.js +1669 -0
  96. metadata +55 -12
  97. data/app/views/spree/order_mailer/_adjustment.html.erb +0 -8
  98. data/app/views/spree/order_mailer/_subtotal.html.erb +0 -8
  99. data/app/views/spree/order_mailer/_total.html.erb +0 -8
@@ -3,19 +3,23 @@ module Spree
3
3
  include Rails.application.routes.url_helpers
4
4
  include Spree::BaseHelper
5
5
 
6
- attr_reader :current_currency, :current_price_options
6
+ attr_reader :current_currency, :current_price_options, :current_store
7
7
 
8
8
  def initialize(opts = {})
9
9
  @variants = opts[:variants]
10
10
  @is_product_available_in_currency = opts[:is_product_available_in_currency]
11
11
  @current_currency = opts[:current_currency]
12
12
  @current_price_options = opts[:current_price_options]
13
+ @current_store = opts[:current_store]
13
14
  end
14
15
 
15
16
  def call
16
17
  @variants.map do |variant|
17
18
  {
18
19
  display_price: display_price(variant),
20
+ price: variant.price_in(current_currency),
21
+ display_compare_at_price: display_compare_at_price(variant),
22
+ should_display_compare_at_price: should_display_compare_at_price(variant),
19
23
  is_product_available_in_currency: @is_product_available_in_currency,
20
24
  backorderable: backorderable?(variant),
21
25
  in_stock: in_stock?(variant),
@@ -71,5 +75,9 @@ module Spree
71
75
  purchasable: variant.purchasable?
72
76
  }
73
77
  end
78
+
79
+ def should_display_compare_at_price(variant)
80
+ variant.compare_at_price.present? && variant.compare_at_price > variant.price
81
+ end
74
82
  end
75
83
  end
@@ -76,6 +76,7 @@ module Spree
76
76
  id: option_value.id,
77
77
  position: option_value.position,
78
78
  presentation: option_value.presentation,
79
+ name: option_value.name,
79
80
  variant_id: option_value.variants.where(id: @variant_ids).order(:position).first.id,
80
81
  is_default: option_value == default_variant_data[:option_value]
81
82
  }
@@ -0,0 +1,39 @@
1
+ module Spree
2
+ module Account
3
+ module Addresses
4
+ class Base
5
+ prepend Spree::ServiceModule::Base
6
+
7
+ private
8
+
9
+ attr_accessor :country
10
+
11
+ def fill_country_and_state_ids(params)
12
+ replace_country_iso_with_id(params)
13
+ fill_state_id(params)
14
+ end
15
+
16
+ def replace_country_iso_with_id(params)
17
+ iso = params[:country_iso]
18
+ return params unless iso.present?
19
+
20
+ country = Spree::Country.by_iso(iso)
21
+ params[:country_id] = country&.id
22
+ params.delete(:country_iso)
23
+ params
24
+ end
25
+
26
+ def fill_state_id(params)
27
+ state_name = params[:state_name]
28
+ return params unless state_name.present?
29
+
30
+ country ||= Spree::Country.find(params[:country_id]) if params[:country_id].present?
31
+ return params unless country
32
+
33
+ params[:state_id] = country.states.find_by(name: state_name)&.id
34
+ params
35
+ end
36
+ end
37
+ end
38
+ end
39
+ end
@@ -0,0 +1,18 @@
1
+ module Spree
2
+ module Account
3
+ module Addresses
4
+ class Create < ::Spree::Account::Addresses::Base
5
+ def call(user:, address_params:)
6
+ fill_country_and_state_ids(address_params)
7
+
8
+ address = user.addresses.new(address_params)
9
+ if address.save
10
+ success(address)
11
+ else
12
+ failure(address)
13
+ end
14
+ end
15
+ end
16
+ end
17
+ end
18
+ end
@@ -0,0 +1,18 @@
1
+ module Spree
2
+ module Account
3
+ module Addresses
4
+ class Update < ::Spree::Account::Addresses::Base
5
+ def call(address:, address_params:)
6
+ address_params[:country_id] ||= address.country_id
7
+ fill_country_and_state_ids(address_params)
8
+
9
+ if address.update(address_params)
10
+ success(address)
11
+ else
12
+ failure(address)
13
+ end
14
+ end
15
+ end
16
+ end
17
+ end
18
+ end
@@ -4,8 +4,12 @@ module Spree
4
4
  prepend Spree::ServiceModule::Base
5
5
 
6
6
  def call(order:, params:, permitted_attributes:, request_env:)
7
- params = replace_country_iso_with_id(params, 'ship') if address_with_country_iso_present?(params, 'ship')
8
- params = replace_country_iso_with_id(params, 'bill') if address_with_country_iso_present?(params, 'bill')
7
+ ship_changed = address_with_country_iso_present?(params, 'ship')
8
+ bill_changed = address_with_country_iso_present?(params, 'bill')
9
+ params = replace_country_iso_with_id(params, 'ship') if ship_changed
10
+ params = replace_country_iso_with_id(params, 'bill') if bill_changed
11
+ order.state = 'address' if (ship_changed || bill_changed) && order.has_checkout_step?('address')
12
+ order.state = 'delivery' if selected_shipping_rate_present?(params) && order.has_checkout_step?('delivery')
9
13
  return success(order) if order.update_from_params(params, permitted_attributes, request_env)
10
14
 
11
15
  failure(order)
@@ -20,6 +24,13 @@ module Spree
20
24
  true
21
25
  end
22
26
 
27
+ def selected_shipping_rate_present?(params)
28
+ shipments_attributes = params.dig(:order, :shipments_attributes)
29
+ return false unless shipments_attributes
30
+
31
+ shipments_attributes.any? { |s| s.dig(:selected_shipping_rate_id) }
32
+ end
33
+
23
34
  def replace_country_iso_with_id(params, address_kind = 'ship')
24
35
  country_id = Spree::Country.by_iso(params[:order]["#{address_kind}_address_attributes"].fetch(:country_iso))&.id
25
36
 
@@ -1,41 +1,46 @@
1
- <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
2
- <html xmlns="http://www.w3.org/1999/xhtml">
3
- <head>
4
- <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
5
- <meta name="viewport" content="width=device-width"/>
6
- <%= render partial: 'spree/shared/base_mailer_stylesheets' %>
7
- </head>
8
- <body>
9
- <table class="body">
10
- <tr>
11
- <td class="center" align="center" valign="top">
12
- <center>
13
- <%= render partial: 'spree/shared/base_mailer_header' %>
14
- <table class="container">
15
- <tr>
16
- <td>
17
- <table class="row">
18
- <tr>
19
- <td class="wrapper last">
20
- <table class="twelve columns">
21
- <tr>
22
- <td>
23
- <%= yield %>
24
- </td>
25
- <td class="expander"></td>
26
- </tr>
27
- </table>
28
- </td>
29
- </tr>
30
- </table>
31
- <%= render partial: 'spree/shared/base_mailer_footer' %>
32
- <!-- container end below -->
33
- </td>
34
- </tr>
35
- </table>
36
- </center>
37
- </td>
38
- </tr>
39
- </table>
40
- </body>
1
+ <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
2
+ <html>
3
+ <head>
4
+ <meta name="viewport" content="width=device-width, initial-scale=1.0"/>
5
+ <meta name="x-apple-disable-message-reformatting"/>
6
+ <meta http-equiv="Content-Type" content="text/html; charset=UTF-8"/>
7
+
8
+ <%= render partial: 'spree/shared/base_mailer_stylesheets' %>
9
+ </head>
10
+ <body>
11
+ <table class="email-wrapper" width="100%" cellpadding="0" cellspacing="0" role="presentation">
12
+ <tr>
13
+ <td align="center">
14
+ <table class="email-content" width="100%" cellpadding="0" cellspacing="0" role="presentation">
15
+ <%= render partial: 'spree/shared/base_mailer_header' %>
16
+ <!-- Email Body -->
17
+ <tr>
18
+ <td class="email-body" width="570" cellpadding="0" cellspacing="0">
19
+ <table class="email-body_inner" align="center" width="570" cellpadding="0" cellspacing="0" role="presentation">
20
+ <!-- Body content -->
21
+ <tbody>
22
+ <tr>
23
+ <td class="content-cell">
24
+ <div class="f-fallback">
25
+ <%= yield %>
26
+ </div>
27
+ </td>
28
+ </tr>
29
+ </tbody>
30
+ </table>
31
+ </td>
32
+ </tr>
33
+ <tr>
34
+ <td>
35
+ <%= render partial: 'spree/shared/base_mailer_footer' %>
36
+ </td>
37
+ </tr>
38
+ </table>
39
+ </td>
40
+ </tr>
41
+ <tr>
42
+ <td height="60px">&nbsp;</td>
43
+ </tr>
44
+ </table>
45
+ </body>
41
46
  </html>
@@ -1,30 +1,24 @@
1
- <table class="row header">
1
+ <h1>
2
+ <%= Spree.t('order_mailer.cancel_email.dear_customer', name: name_for(@order)) %>
3
+ </h1>
4
+ <p>
5
+ <%= Spree.t('order_mailer.cancel_email.instructions') %>
6
+ </p>
7
+
8
+ <table class="purchase" role="presentation">
2
9
  <tr>
3
10
  <td>
4
- <p class="lede">
5
- <%= Spree.t('order_mailer.cancel_email.dear_customer') %>
6
- </p>
7
- <p>
8
- <%= Spree.t('order_mailer.cancel_email.instructions') %>
9
- </p>
10
- <p>
11
- <%= Spree.t('order_mailer.cancel_email.order_summary_canceled', number: @order.number) %>
12
- </p>
13
- <table class="container">
14
- <tr>
15
- <td class="wrapper last">
16
- <table class="twelve columns">
17
- <%= render collection: @order.line_items, partial: 'spree/shared/mailer_line_item', as: :line_item %>
18
- <%= render 'spree/order_mailer/subtotal', order: @order %>
19
- <% @order.adjustments.eligible.each do |adjustment| %>
20
- <%= render 'spree/order_mailer/adjustment', adjustment: adjustment %>
21
- <% end %>
22
- <%= render 'spree/order_mailer/total', order: @order %>
23
- </table>
24
- </td>
25
- </tr>
26
- </table>
11
+ <h3> <%= Spree.t('order_mailer.cancel_email.order_summary_canceled', number: @order.number) %></h3>
12
+ </td>
13
+ </tr>
14
+ <tr>
15
+ <td colspan="2">
16
+ <%= render 'spree/shared/purchased_items_table', line_items: @order.line_items, order: @order %>
27
17
  </td>
28
- <td class="expander"></td>
29
18
  </tr>
30
19
  </table>
20
+ <p>
21
+ <%= Spree.t('order_mailer.cancel_email.thanks') %>
22
+ <br />
23
+ <%= Spree.t('order_mailer.store_team', store_name: current_store.name) %>
24
+ </p>
@@ -1,4 +1,4 @@
1
- <%= Spree.t('order_mailer.cancel_email.dear_customer') %>
1
+ <%= Spree.t('order_mailer.cancel_email.dear_customer', name: name_for(@order)) %>
2
2
 
3
3
  <%= Spree.t('order_mailer.cancel_email.instructions') %>
4
4
 
@@ -10,7 +10,29 @@
10
10
  <% end %>
11
11
  ============================================================
12
12
  <%= Spree.t('order_mailer.subtotal') %> <%= @order.display_item_total %>
13
+ <% if @order.line_item_adjustments.exists? %>
14
+ <% if @order.all_adjustments.promotion.eligible.exists? %>
15
+ <% @order.all_adjustments.promotion.eligible.group_by(&:label).each do |label, adjustments| %>
16
+ <%= Spree.t(:promotion) %>: <%= label %> <%= Spree::Money.new(adjustments.sum(&:amount), currency: @order.currency) %>
17
+ <% end %>
18
+ <% end %>
19
+ <% end %>
20
+
21
+ <% @order.shipments.group_by { |s| s.selected_shipping_rate.try(:name) }.each do |name, shipments| %>
22
+ <%= Spree.t(:shipping) %>: <%= name %> <%= Spree::Money.new(shipments.sum(&:discounted_cost), currency: @order.currency) %>
23
+ <% end %>
24
+
25
+ <% if @order.all_adjustments.eligible.tax.exists? %>
26
+ <% @order.all_adjustments.eligible.tax.group_by(&:label).each do |label, adjustments| %>
27
+ <%= Spree.t(:tax) %>: <%= label %> <%= Spree::Money.new(adjustments.sum(&:amount), currency: @order.currency) %>
28
+ <% end %>
29
+ <% end %>
30
+
13
31
  <% @order.adjustments.eligible.each do |adjustment| %>
14
- <%= raw(adjustment.label) %> <%= adjustment.display_amount %>
32
+ <% next if (adjustment.source_type == 'Spree::TaxRate') and (adjustment.amount == 0) %>
33
+ <%= adjustment.label %> <%= adjustment.display_amount %>
15
34
  <% end %>
35
+ ============================================================
16
36
  <%= Spree.t('order_mailer.total') %> <%= @order.display_total %>
37
+ <%= Spree.t('order_mailer.cancel_email.thanks') %>
38
+ <%= Spree.t('order_mailer.store_team', store_name: current_store.name) %>
@@ -1,70 +1,23 @@
1
- <table class="row header">
1
+ <h1>
2
+ <%= Spree.t('order_mailer.confirm_email.dear_customer', name: name_for(@order)) %>
3
+ </h1>
4
+ <p>
5
+ <%= Spree.t('order_mailer.confirm_email.instructions') %>
6
+ </p>
7
+ <table class="purchase" role="presentation">
2
8
  <tr>
3
9
  <td>
4
- <p class="lede">
5
- <%= Spree.t('order_mailer.confirm_email.dear_customer') %>
6
- </p>
7
- <p>
8
- <%= Spree.t('order_mailer.confirm_email.instructions') %>
9
- </p>
10
- <p>
11
- <%= Spree.t('order_mailer.confirm_email.order_summary', number: @order.number) %>
12
- </p>
13
- <table class="container">
14
- <tr>
15
- <td class="wrapper last">
16
- <table class="twelve columns">
17
- <%= render collection: @order.line_items, partial: 'spree/shared/mailer_line_item', as: :line_item %>
18
- <%= render 'spree/order_mailer/subtotal', order: @order %>
19
- <% if @order.line_item_adjustments.exists? %>
20
- <% if @order.all_adjustments.promotion.eligible.exists? %>
21
- <% @order.all_adjustments.promotion.eligible.group_by(&:label).each do |label, adjustments| %>
22
- <tr>
23
- <td class="six sub-columns">
24
- <%= Spree.t(:promotion) %> <%= label %>:
25
- </td>
26
- <td class="six sub-columns last right">
27
- <%= Spree::Money.new(adjustments.sum(&:amount), currency: @order.currency) %>
28
- </td>
29
- </tr>
30
- <% end %>
31
- <% end %>
32
- <% end %>
33
- <% @order.shipments.group_by { |s| s.selected_shipping_rate.try(:name) }.each do |name, shipments| %>
34
- <tr>
35
- <td class="six sub-columns">
36
- <%= Spree.t(:shipping) %> <%= name %>:
37
- </td>
38
- <td class="six sub-columns last right">
39
- <%= Spree::Money.new(shipments.sum(&:discounted_cost), currency: @order.currency) %>
40
- </td>
41
- </tr>
42
- <% end %>
43
- <% if @order.all_adjustments.eligible.tax.exists? %>
44
- <% @order.all_adjustments.eligible.tax.group_by(&:label).each do |label, adjustments| %>
45
- <tr>
46
- <td class="six sub-columns">
47
- <%= Spree.t(:tax) %> <%= label %>:
48
- </td>
49
- <td class="six sub-columns last right">
50
- <%= Spree::Money.new(adjustments.sum(&:amount), currency: @order.currency) %>
51
- </td>
52
- </tr>
53
- <% end %>
54
- <% end %>
55
- <% @order.adjustments.eligible.each do |adjustment| %>
56
- <% next if (adjustment.source_type == 'Spree::TaxRate') || (adjustment.amount == 0) %>
57
- <%= render 'spree/order_mailer/adjustment', adjustment: adjustment %>
58
- <% end %>
59
- <%= render 'spree/order_mailer/total', order: @order %>
60
- </table>
61
- </td>
62
- </tr>
63
- </table>
64
- <p>
65
- <%= Spree.t('order_mailer.confirm_email.thanks') %>
66
- </p>
10
+ <h3><%= Spree.t('order_mailer.confirm_email.order_summary', number: @order.number) %></h3>
11
+ </td>
12
+ </tr>
13
+ <tr>
14
+ <td colspan="2">
15
+ <%= render 'spree/shared/purchased_items_table', line_items: @order.line_items, order: @order %>
67
16
  </td>
68
- <td class="expander"></td>
69
17
  </tr>
70
18
  </table>
19
+ <p>
20
+ <%= Spree.t('order_mailer.confirm_email.thanks') %>
21
+ <br />
22
+ <%= Spree.t('order_mailer.store_team', store_name: current_store.name) %>
23
+ </p>
@@ -1,4 +1,4 @@
1
- <%= Spree.t('order_mailer.confirm_email.dear_customer') %>
1
+ <%= Spree.t('order_mailer.confirm_email.dear_customer', name: name_for(@order)) %>
2
2
 
3
3
  <%= Spree.t('order_mailer.confirm_email.instructions') %>
4
4
 
@@ -36,3 +36,4 @@
36
36
  <%= Spree.t('order_mailer.total') %> <%= @order.display_total %>
37
37
 
38
38
  <%= Spree.t('order_mailer.confirm_email.thanks') %>
39
+ <%= Spree.t('order_mailer.store_team', store_name: current_store.name) %>
@@ -0,0 +1,23 @@
1
+ <h1>
2
+ <%= Spree.t('order_mailer.store_owner_notification_email.heading') %>
3
+ </h1>
4
+ <p>
5
+ <%= Spree.t('order_mailer.store_owner_notification_email.instructions') %>
6
+ </p>
7
+ <table class="purchase" role="presentation">
8
+ <tr>
9
+ <td>
10
+ <h3><%= Spree.t('order_mailer.store_owner_notification_email.order_summary', number: @order.number) %></h3>
11
+ </td>
12
+ </tr>
13
+ <tr>
14
+ <td colspan="2">
15
+ <%= render 'spree/shared/purchased_items_table', line_items: @order.line_items, order: @order %>
16
+ </td>
17
+ </tr>
18
+ </table>
19
+ <p>
20
+ <%= Spree.t('order_mailer.store_owner_notification_email.thanks') %>
21
+ <br />
22
+ <%= Spree.t('order_mailer.store_team', store_name: current_store.name) %>
23
+ </p>