spree_backend 4.2.0.rc2 → 4.2.1

Sign up to get free protection for your applications and to get access to all the features.
Files changed (168) hide show
  1. checksums.yaml +4 -4
  2. data/app/assets/javascripts/spree/backend.js +1 -2
  3. data/app/assets/javascripts/spree/backend/address_states.js +20 -9
  4. data/app/assets/javascripts/spree/backend/admin.js +9 -15
  5. data/app/assets/javascripts/spree/backend/calculator.js +2 -0
  6. data/app/assets/javascripts/spree/backend/checkouts/edit.js +99 -71
  7. data/app/assets/javascripts/spree/backend/line_items_on_order_edit.js +1 -1
  8. data/app/assets/javascripts/spree/backend/option_type_autocomplete.js +31 -37
  9. data/app/assets/javascripts/spree/backend/option_value_picker.js +50 -23
  10. data/app/assets/javascripts/spree/backend/product_picker.js +35 -19
  11. data/app/assets/javascripts/spree/backend/promotions.js +32 -27
  12. data/app/assets/javascripts/spree/backend/shipments.js +28 -37
  13. data/app/assets/javascripts/spree/backend/spree-select2.js +33 -14
  14. data/app/assets/javascripts/spree/backend/stock_transfer.js +32 -13
  15. data/app/assets/javascripts/spree/backend/taxon_autocomplete.js +30 -43
  16. data/app/assets/javascripts/spree/backend/taxons.js +60 -47
  17. data/app/assets/javascripts/spree/backend/user_picker.js +16 -18
  18. data/app/assets/javascripts/spree/backend/variant_autocomplete.js +23 -22
  19. data/app/assets/stylesheets/spree/backend/components/_badges.scss +1 -1
  20. data/app/assets/stylesheets/spree/backend/components/_tables.scss +2 -2
  21. data/app/assets/stylesheets/spree/backend/global/_mixins.scss +19 -0
  22. data/app/assets/stylesheets/spree/backend/global/_variables.scss +1 -1
  23. data/app/assets/stylesheets/spree/backend/plugins/_flatpickr.scss +94 -76
  24. data/app/assets/stylesheets/spree/backend/plugins/_select2_custom.scss +11 -0
  25. data/app/assets/stylesheets/spree/backend/plugins/select2_bootstrap4.scss +622 -0
  26. data/app/assets/stylesheets/spree/backend/shared/_base.scss +4 -0
  27. data/app/assets/stylesheets/spree/backend/spree_admin.css.scss +3 -1
  28. data/app/controllers/spree/admin/base_controller.rb +2 -0
  29. data/app/controllers/spree/admin/general_settings_controller.rb +1 -1
  30. data/app/controllers/spree/admin/images_controller.rb +3 -3
  31. data/app/controllers/spree/admin/orders/customer_details_controller.rb +1 -1
  32. data/app/controllers/spree/admin/orders_controller.rb +15 -2
  33. data/app/controllers/spree/admin/prices_controller.rb +0 -13
  34. data/app/controllers/spree/admin/products_controller.rb +2 -2
  35. data/app/controllers/spree/admin/states_controller.rb +1 -1
  36. data/app/controllers/spree/admin/stores_controller.rb +7 -14
  37. data/app/controllers/spree/admin/taxons_controller.rb +15 -5
  38. data/app/helpers/spree/admin/base_helper.rb +68 -6
  39. data/app/helpers/spree/admin/navigation_helper.rb +11 -1
  40. data/app/helpers/spree/admin/payments_helper.rb +3 -3
  41. data/app/helpers/spree/admin/stock_movements_helper.rb +2 -0
  42. data/app/views/kaminari/admin-twitter-bootstrap-4/_first_page.html.erb +2 -2
  43. data/app/views/kaminari/admin-twitter-bootstrap-4/_gap.html.erb +2 -2
  44. data/app/views/kaminari/admin-twitter-bootstrap-4/_last_page.html.erb +2 -2
  45. data/app/views/kaminari/admin-twitter-bootstrap-4/_next_page.html.erb +2 -2
  46. data/app/views/kaminari/admin-twitter-bootstrap-4/_page.html.erb +2 -2
  47. data/app/views/kaminari/admin-twitter-bootstrap-4/_paginator.html.erb +2 -2
  48. data/app/views/kaminari/admin-twitter-bootstrap-4/_prev_page.html.erb +2 -2
  49. data/app/views/spree/admin/adjustments/index.html.erb +2 -2
  50. data/app/views/spree/admin/countries/index.html.erb +6 -6
  51. data/app/views/spree/admin/customer_returns/_return_item_decision.html.erb +48 -46
  52. data/app/views/spree/admin/customer_returns/_return_item_selection.html.erb +3 -1
  53. data/app/views/spree/admin/customer_returns/edit.html.erb +1 -1
  54. data/app/views/spree/admin/customer_returns/index.html.erb +2 -2
  55. data/app/views/spree/admin/customer_returns/new.html.erb +1 -1
  56. data/app/views/spree/admin/general_settings/edit.html.erb +27 -4
  57. data/app/views/spree/admin/images/edit.html.erb +1 -1
  58. data/app/views/spree/admin/log_entries/index.html.erb +1 -1
  59. data/app/views/spree/admin/option_types/index.html.erb +2 -2
  60. data/app/views/spree/admin/orders/_add_line_item.html.erb +1 -1
  61. data/app/views/spree/admin/orders/_add_product.html.erb +1 -1
  62. data/app/views/spree/admin/orders/_adjustments.html.erb +2 -2
  63. data/app/views/spree/admin/orders/_channel_form.html.erb +18 -0
  64. data/app/views/spree/admin/orders/_form.html.erb +6 -10
  65. data/app/views/spree/admin/orders/_line_items.html.erb +1 -1
  66. data/app/views/spree/admin/orders/_line_items_edit_form.html.erb +5 -8
  67. data/app/views/spree/admin/orders/_order_actions.html.erb +1 -2
  68. data/app/views/spree/admin/orders/_risk_analysis.html.erb +3 -3
  69. data/app/views/spree/admin/orders/_shipment.html.erb +3 -2
  70. data/app/views/spree/admin/orders/_shipment_manifest.html.erb +1 -1
  71. data/app/views/spree/admin/orders/cart.html.erb +1 -1
  72. data/app/views/spree/admin/orders/channel.html.erb +7 -0
  73. data/app/views/spree/admin/orders/customer_details/_autocomplete.js.erb +35 -12
  74. data/app/views/spree/admin/orders/customer_details/_form.html.erb +3 -3
  75. data/app/views/spree/admin/orders/customer_details/edit.html.erb +1 -1
  76. data/app/views/spree/admin/orders/edit.html.erb +1 -1
  77. data/app/views/spree/admin/orders/index.html.erb +12 -11
  78. data/app/views/spree/admin/payment_methods/_form.html.erb +65 -46
  79. data/app/views/spree/admin/payment_methods/index.html.erb +2 -2
  80. data/app/views/spree/admin/payments/_form.html.erb +2 -3
  81. data/app/views/spree/admin/payments/show.html.erb +1 -2
  82. data/app/views/spree/admin/payments/source_forms/_gateway.html.erb +3 -4
  83. data/app/views/spree/admin/payments/source_views/_gateway.html.erb +1 -1
  84. data/app/views/spree/admin/prices/_variant_prices.html.erb +5 -5
  85. data/app/views/spree/admin/prices/index.html.erb +2 -2
  86. data/app/views/spree/admin/product_properties/index.html.erb +3 -4
  87. data/app/views/spree/admin/products/_form.html.erb +8 -9
  88. data/app/views/spree/admin/products/index.html.erb +2 -1
  89. data/app/views/spree/admin/products/new.html.erb +5 -3
  90. data/app/views/spree/admin/products/stock.html.erb +2 -2
  91. data/app/views/spree/admin/promotion_rules/create.js.erb +1 -1
  92. data/app/views/spree/admin/promotions/_actions.html.erb +2 -3
  93. data/app/views/spree/admin/promotions/_form.html.erb +10 -11
  94. data/app/views/spree/admin/promotions/_rules.html.erb +1 -1
  95. data/app/views/spree/admin/promotions/actions/_create_adjustment.html.erb +1 -1
  96. data/app/views/spree/admin/promotions/actions/_create_item_adjustments.html.erb +1 -1
  97. data/app/views/spree/admin/promotions/actions/_create_line_items.html.erb +1 -1
  98. data/app/views/spree/admin/promotions/index.html.erb +7 -5
  99. data/app/views/spree/admin/promotions/rules/_option_value.html.erb +8 -7
  100. data/app/views/spree/admin/promotions/rules/_product.html.erb +1 -1
  101. data/app/views/spree/admin/promotions/rules/_taxon.html.erb +2 -2
  102. data/app/views/spree/admin/promotions/rules/_user.html.erb +1 -1
  103. data/app/views/spree/admin/prototypes/_form.html.erb +1 -1
  104. data/app/views/spree/admin/prototypes/show.html.erb +1 -1
  105. data/app/views/spree/admin/refunds/edit.html.erb +2 -2
  106. data/app/views/spree/admin/refunds/new.html.erb +3 -3
  107. data/app/views/spree/admin/reimbursements/edit.html.erb +5 -4
  108. data/app/views/spree/admin/reimbursements/show.html.erb +3 -1
  109. data/app/views/spree/admin/return_authorizations/_form.html.erb +7 -5
  110. data/app/views/spree/admin/return_authorizations/index.html.erb +2 -2
  111. data/app/views/spree/admin/return_index/customer_returns.html.erb +2 -2
  112. data/app/views/spree/admin/return_index/return_authorizations.html.erb +2 -2
  113. data/app/views/spree/admin/roles/index.html.erb +1 -1
  114. data/app/views/spree/admin/shared/_account_nav.html.erb +3 -3
  115. data/app/views/spree/admin/shared/_address_form.html.erb +9 -9
  116. data/app/views/spree/admin/shared/_error_messages.html.erb +1 -1
  117. data/app/views/spree/admin/shared/_head.html.erb +6 -2
  118. data/app/views/spree/admin/shared/_header.html.erb +0 -2
  119. data/app/views/spree/admin/shared/_main_menu.html.erb +1 -1
  120. data/app/views/spree/admin/shared/_order_summary.html.erb +25 -21
  121. data/app/views/spree/admin/shared/_order_tabs.html.erb +9 -0
  122. data/app/views/spree/admin/shared/_refunds.html.erb +2 -2
  123. data/app/views/spree/admin/shared/_report_order_criteria.html.erb +4 -2
  124. data/app/views/spree/admin/shared/_translations.html.erb +9 -38
  125. data/app/views/spree/admin/shared/_update_order_state.js.erb +6 -2
  126. data/app/views/spree/admin/shared/named_types/_index.html.erb +1 -1
  127. data/app/views/spree/admin/shipping_categories/index.html.erb +2 -2
  128. data/app/views/spree/admin/shipping_methods/_form.html.erb +2 -2
  129. data/app/views/spree/admin/shipping_methods/index.html.erb +7 -3
  130. data/app/views/spree/admin/states/index.html.erb +2 -2
  131. data/app/views/spree/admin/stock_locations/_form.html.erb +2 -2
  132. data/app/views/spree/admin/stock_locations/_transfer_stock_form.html.erb +1 -1
  133. data/app/views/spree/admin/stock_locations/index.html.erb +6 -6
  134. data/app/views/spree/admin/stock_movements/_form.html.erb +1 -1
  135. data/app/views/spree/admin/stock_movements/index.html.erb +2 -2
  136. data/app/views/spree/admin/stock_transfers/_stock_movements.html.erb +1 -1
  137. data/app/views/spree/admin/stock_transfers/index.html.erb +42 -37
  138. data/app/views/spree/admin/stock_transfers/new.html.erb +1 -1
  139. data/app/views/spree/admin/stock_transfers/show.html.erb +0 -1
  140. data/app/views/spree/admin/stores/_form.html.erb +83 -25
  141. data/app/views/spree/admin/stores/index.html.erb +15 -8
  142. data/app/views/spree/admin/tax_categories/index.html.erb +3 -3
  143. data/app/views/spree/admin/tax_rates/index.html.erb +8 -8
  144. data/app/views/spree/admin/taxonomies/_js_head.html.erb +1 -2
  145. data/app/views/spree/admin/taxonomies/_list.html.erb +1 -1
  146. data/app/views/spree/admin/taxons/_form.html.erb +38 -35
  147. data/app/views/spree/admin/taxons/_taxon_table.html.erb +2 -2
  148. data/app/views/spree/admin/taxons/index.html.erb +1 -1
  149. data/app/views/spree/admin/users/_addresses_form.html.erb +4 -6
  150. data/app/views/spree/admin/users/_form.html.erb +0 -1
  151. data/app/views/spree/admin/users/edit.html.erb +1 -1
  152. data/app/views/spree/admin/users/index.html.erb +2 -2
  153. data/app/views/spree/admin/users/items.html.erb +1 -1
  154. data/app/views/spree/admin/variants/_form.html.erb +5 -3
  155. data/app/views/spree/admin/zones/_country_members.html.erb +1 -1
  156. data/app/views/spree/admin/zones/_form.html.erb +2 -2
  157. data/app/views/spree/admin/zones/index.html.erb +1 -1
  158. data/app/views/spree/admin/zones/new.html.erb +1 -1
  159. data/app/views/spree/layouts/admin.html.erb +2 -3
  160. data/config/initializers/assets.rb +1 -1
  161. data/config/routes.rb +7 -1
  162. data/spree_backend.gemspec +2 -2
  163. metadata +20 -20
  164. data/app/assets/javascripts/spree/backend/flatpickr_locals.js +0 -37
  165. data/app/assets/javascripts/spree/backend/tag_picker.js +0 -52
  166. data/app/assets/stylesheets/spree/backend/plugins/_select2.scss +0 -190
  167. data/app/helpers/spree/admin/currency_helper.rb +0 -14
  168. data/app/views/spree/admin/general_settings/_form.html.erb +0 -17
@@ -2,6 +2,10 @@ $('#order_tab_summary h5#order_status').html('<%= j Spree.t(:status) %>: <%= j S
2
2
  $('#order_tab_summary h5#order_total').html('<%= j Spree.t(:total) %>: <%= j @order.display_total.to_html %>');
3
3
 
4
4
  <% if @order.completed? %>
5
- $('#order_tab_summary h5#payment_status').html('<%= j Spree.t(:payment) %>: <%= j Spree.t(@order.payment_state, scope: :payment_states, default: [:missing, "none"]) %>');
6
- $('#order_tab_summary h5#shipment_status').html('<%= j Spree.t(:shipment) %>: <%= j Spree.t(@order.shipment_state, scope: :shipment_state, default: [:missing, "none"]) %>');
5
+ <% if @order.payment_state.present? %>
6
+ $('#order_tab_summary h5#payment_status').html('<%= j Spree.t(:payment) %>: <%= j Spree.t(@order.payment_state, scope: :payment_states, default: [:missing, "none"]) %>');
7
+ <% end %>
8
+ <% if @order.shipment_state.present? %>
9
+ $('#order_tab_summary h5#shipment_status').html('<%= j Spree.t(:shipment) %>: <%= j Spree.t(@order.shipment_state, scope: :shipment_state, default: [:missing, "none"]) %>');
10
+ <% end %>
7
11
  <% end %>
@@ -23,7 +23,7 @@
23
23
  <%= named_type.name %>
24
24
  </td>
25
25
  <td class="align-center">
26
- <%= Spree.t(named_type.active? ? :active : :inactive) %>
26
+ <%= active_badge(named_type.active, label: Spree.t(named_type.active? ? :active : :inactive)) %>
27
27
  </td>
28
28
  <td class="actions actions-1 text-right">
29
29
  <% if named_type.mutable? %>
@@ -16,7 +16,7 @@
16
16
  </tr>
17
17
  </thead>
18
18
  <tbody>
19
- <% @shipping_categories.each do |shipping_category|%>
19
+ <% @shipping_categories.each do |shipping_category| %>
20
20
  <tr id="<%= spree_dom_id shipping_category %>" data-hook="category_row">
21
21
  <td><%= shipping_category.name %></td>
22
22
  <td class="actions actions-2 text-right">
@@ -27,7 +27,7 @@
27
27
  <% end %>
28
28
  </tbody>
29
29
  </table>
30
- </div>
30
+ </div>
31
31
  <% else %>
32
32
  <div class="alert alert-info no-objects-found">
33
33
  <%= Spree.t(:no_resource_found, resource: plural_resource_name(Spree::ShippingCategory)) %>,
@@ -11,7 +11,7 @@
11
11
  <div data-hook="admin_shipping_method_form_display_field" class="col-12 col-lg-6">
12
12
  <%= f.field_container :display_on, class: ['form-group'] do %>
13
13
  <%= f.label :display_on, Spree.t(:display) %>
14
- <%= select(:shipping_method, :display_on, Spree::ShippingMethod::DISPLAY.collect { |display| [Spree.t(display), display.to_s] }, { include_blank: true }, { class: 'select2' }) %>
14
+ <%= select(:shipping_method, :display_on, Spree::ShippingMethod::DISPLAY.collect { |display| [Spree.t(display), display.to_s] }, { include_blank: true }, { class: 'select2-clear' }) %>
15
15
  <%= f.error_message_on :display_on %>
16
16
  <% end %>
17
17
  </div>
@@ -110,7 +110,7 @@
110
110
 
111
111
  <div class="card-body">
112
112
  <%= f.field_container :categories, class: ['form-group'] do %>
113
- <%= f.select :tax_category_id, @tax_categories.map { |tc| [tc.name, tc.id] }, { include_blank: true }, class: "select2" %>
113
+ <%= f.select :tax_category_id, @tax_categories.map { |tc| [tc.name, tc.id] }, { include_blank: true }, class: "select2-clear" %>
114
114
  <%= f.error_message_on :tax_category_id %>
115
115
  <% end %>
116
116
  </div>
@@ -19,10 +19,14 @@
19
19
  </tr>
20
20
  </thead>
21
21
  <tbody>
22
- <% @shipping_methods.includes(:zones, :calculator).each do |shipping_method|%>
22
+ <% @shipping_methods.includes(:zones, :calculator).each do |shipping_method| %>
23
23
  <tr id="<%= spree_dom_id shipping_method %>" data-hook="admin_shipping_methods_index_rows">
24
24
  <td><%= shipping_method.admin_name + ' / ' if shipping_method.admin_name.present? %><%= shipping_method.name %></td>
25
- <td><%= shipping_method.zones.collect(&:name).join(", ") if shipping_method.zones %></td>
25
+ <td>
26
+ <% shipping_method.zones.each do |zone| %>
27
+ <%= link_to zone.name, spree.edit_admin_zone_path(zone) %>
28
+ <% end %>
29
+ </td>
26
30
  <td><%= shipping_method.calculator.description %></td>
27
31
  <td class="text-center"><%= shipping_method.display_on.blank? ? Spree.t(:none) : Spree.t(shipping_method.display_on) %></td>
28
32
  <td data-hook="admin_shipping_methods_index_row_actions" class="actions actions-2 text-right">
@@ -33,7 +37,7 @@
33
37
  <% end %>
34
38
  </tbody>
35
39
  </table>
36
- </div>
40
+ </div>
37
41
  <% else %>
38
42
  <div class="alert alert-info no-objects-found">
39
43
  <%= Spree.t(:no_resource_found, resource: plural_resource_name(Spree::ShippingMethod)) %>,
@@ -8,11 +8,11 @@
8
8
 
9
9
  <div data-hook="country" class="form-group">
10
10
  <%= label_tag :country, Spree.t(:country) %>
11
- <select id="country" class='observe_field select2' data-base-url="<%=admin_states_path(format: :js) %>?country_id=" data-update="#state-list">
11
+ <select id="country" class='observe_field select2' data-base-url="<%= admin_states_path(format: :js) %>?country_id=" data-update="#state-list">
12
12
  <%= options_from_collection_for_select(@countries, :id, :name, @country.id) %>
13
13
  </select>
14
14
  </div>
15
15
 
16
16
  <div id="state-list" data-hook>
17
- <%= render partial: 'state_list'%>
17
+ <%= render partial: 'state_list' %>
18
18
  </div>
@@ -3,7 +3,7 @@
3
3
  <div class="col-12 col-md-9" data-hook="stock_location_names">
4
4
  <div data-hook="stock_location_name">
5
5
  <%= f.field_container :name, class: ['form-group'] do %>
6
- <%= f.label :name, Spree.t(:name) %> <span class="required">*</span><br />
6
+ <%= f.label :name, Spree.t(:name) %> <span class="required">*</span><br>
7
7
  <%= f.text_field :name, class: 'form-control', required: true %>
8
8
  <%= f.error_message_on :name %>
9
9
  <% end %>
@@ -80,7 +80,7 @@
80
80
  <%= f.label :state_id, Spree.t(:state) %>
81
81
  <span id="state" class="region">
82
82
  <%= f.text_field :state_name, style: "#{f.object.country.states.empty? ? '' : 'display: none;'}", disabled: !f.object.country.states.empty?, class: 'state_name form-control' %>
83
- <%= f.collection_select :state_id, f.object.country.states.sort, :id, :name, { include_blank: true }, {class: 'select2', style: "#{f.object.country.states.empty? ? 'display: none;' : '' };", disabled: f.object.country.states.empty?} %>
83
+ <%= f.collection_select :state_id, f.object.country.states.sort, :id, :name, { include_blank: true }, {class: 'select2-clear', style: "#{f.object.country.states.empty? ? 'display: none;' : '' };", disabled: f.object.country.states.empty?} %>
84
84
  </span>
85
85
  <% end %>
86
86
  </div>
@@ -1,6 +1,6 @@
1
1
  <%= form_tag transfer_stock_admin_stock_locations_path do %>
2
2
  <fieldset>
3
- <legend><%= Spree.t(:move_stock_between_locations)%></legend>
3
+ <legend><%= Spree.t(:move_stock_between_locations) %></legend>
4
4
  <div data-hook="admin_stock_movements_form_fields" class="row">
5
5
  <div class="col-12 col-md-5">
6
6
  <div class="form-group" id="stock_movement_transfer_from_field">
@@ -12,20 +12,20 @@
12
12
  <thead>
13
13
  <tr data-hook="stock_locations_header">
14
14
  <th><%= Spree.t(:name) %></th>
15
- <th><%= Spree.t(:status) %></th>
16
15
  <th><%= Spree.t(:stock_movements) %></th>
16
+ <th><%= Spree.t(:status) %></th>
17
17
  <th class="actions"></th>
18
18
  </tr>
19
19
  </thead>
20
20
  <tbody>
21
21
  <% @stock_locations.each do |stock_location|
22
- @edit_url = edit_admin_stock_location_path(stock_location)
23
- @delete_url = admin_stock_location_path(stock_location)
24
- %>
22
+ @edit_url = spree.edit_admin_stock_location_path(stock_location)
23
+ @delete_url = spree.admin_stock_location_path(stock_location) %>
24
+
25
25
  <tr id="<%= spree_dom_id stock_location %>" data-hook="stock_location_row">
26
26
  <td><%= display_name(stock_location) %></td>
27
- <td><span class="state <%= state(stock_location) %>"><%= Spree.t(state(stock_location)) %></span></td>
28
- <td><%= link_to Spree.t(:stock_movements), admin_stock_location_stock_movements_path(stock_location.id) %> </td>
27
+ <td><%= link_to Spree.t(:stock_movements), spree.admin_stock_location_stock_movements_path(stock_location.id) %> </td>
28
+ <td><%= active_badge(stock_location.active, label: Spree.t(state(stock_location))) %></td>
29
29
  <td class="actions actions-2 text-center">
30
30
  <%= link_to_edit(stock_location, no_text: true) if can? :create, stock_location %>
31
31
  <%= link_to_delete(stock_location, no_text: true) if can? :create, stock_location %>
@@ -5,7 +5,7 @@
5
5
  <% end %>
6
6
  <%= f.field_container :stock_item_id, class: ['form-group'] do %>
7
7
  <%= f.label :stock_item_id, Spree.t(:stock_item_id) %>
8
- <%= f.text_field 'stock_item_id', :'data-stock-location-id' => params[:stock_location_id] %>
8
+ <%= select_tag 'stock_movement[stock_item_id]', nil , class: 'variant_autocomplete d-block w-100', :'data-stock-location-id' => params[:stock_location_id] %>
9
9
  <% end %>
10
10
  </div>
11
11
 
@@ -17,13 +17,13 @@
17
17
  </colgroup>
18
18
  <thead>
19
19
  <tr data-hook="admin_stock_movements_index_headers">
20
- <th><%= Spree.t(:stock_item) %>
20
+ <th><%= Spree.t(:variant) %>
21
21
  <th><%= Spree.t(:quantity) %></th>
22
22
  <th><%= Spree.t(:action) %></th>
23
23
  </tr>
24
24
  </thead>
25
25
  <tbody>
26
- <% @stock_movements.each do |stock_movement|%>
26
+ <% @stock_movements.each do |stock_movement| %>
27
27
  <tr id="<%= spree_dom_id stock_movement %>" data-hook="admin_stock_movements_index_rows">
28
28
  <td>
29
29
  <%= display_variant(stock_movement) %>
@@ -12,7 +12,7 @@
12
12
  <tbody id="bulk_variants_tbody">
13
13
  <% stock_movements.each do |movement| %>
14
14
  <tr>
15
- <td><%= movement.stock_item.variant.name %></td>
15
+ <td><%= link_to movement.stock_item.variant.name, spree.edit_admin_product_path(movement.stock_item.variant.product) %></td>
16
16
  <td><%= movement.stock_item.variant.sku %></td>
17
17
  <td><%= movement.quantity %></td>
18
18
  <td><%= movement.stock_item.count_on_hand %></td>
@@ -6,68 +6,73 @@
6
6
  <%= button_link_to Spree.t(:new_stock_transfer), new_admin_stock_transfer_path, { icon: 'add.svg', class: 'btn-success' } %>
7
7
  <% end if can? :create, Spree::StockTransfer %>
8
8
 
9
- <div data-hook="admin_orders_index_search" class="card bg-light mb-3">
10
- <div class="card-body">
11
- <fieldset>
12
- <legend class="border-bottom"><%= Spree.t(:search) %></legend>
13
- <%= search_form_for @q, url: admin_stock_transfers_path do |f| %>
9
+ <% content_for :table_filter do %>
10
+ <div data-hook="admin_orders_index_search">
11
+ <%= search_form_for @q, url: admin_stock_transfers_path do |f| %>
14
12
 
15
- <div class="row mb-0">
16
- <div class="col-12 col-lg-4">
17
- <div class="form-group">
18
- <%= f.label :reference_cont, Spree.t(:reference_contains) %>
19
- <%= f.text_field :reference_cont, class: 'form-control' %>
20
- </div>
21
- </div>
22
-
23
- <div class="col-12 col-lg-4">
24
- <div class="form-group">
25
- <%= f.label :source_location, Spree.t(:source) %>
26
- <%= f.select :source_location_id_eq,
27
- options_from_collection_for_select(@stock_locations, :id, :name, @q.source_location_id_eq),
28
- { include_blank: true }, class: 'select2' %>
29
- </div>
13
+ <div class="row mb-0">
14
+ <div class="col-12 col-lg-4">
15
+ <div class="form-group">
16
+ <%= f.label :reference_cont, Spree.t(:reference_contains) %>
17
+ <%= f.text_field :reference_cont, class: 'form-control' %>
30
18
  </div>
19
+ </div>
31
20
 
32
- <div class="col-12 col-lg-4">
33
- <div class="form-group">
34
- <%= f.label :destination_location, Spree.t(:destination) %>
35
- <%= f.select :destination_location_id_eq,
36
- options_from_collection_for_select(@stock_locations, :id, :name, @q.destination_location_id_eq),
37
- { include_blank: true }, class: 'select2' %>
38
- </div>
21
+ <div class="col-12 col-lg-4">
22
+ <div class="form-group">
23
+ <%= f.label :source_location, Spree.t(:source) %>
24
+ <%= f.select :source_location_id_eq,
25
+ options_from_collection_for_select(@stock_locations, :id, :name, @q.source_location_id_eq),
26
+ { include_blank: true }, class: 'select2-clear js-filterable' %>
39
27
  </div>
40
28
  </div>
41
29
 
42
- <div class="form-actions">
43
- <div data-hook="admin_stock_transfers_index_search_buttons">
44
- <%= button Spree.t(:filter_results), 'search.svg' %>
30
+ <div class="col-12 col-lg-4">
31
+ <div class="form-group">
32
+ <%= f.label :destination_location, Spree.t(:destination) %>
33
+ <%= f.select :destination_location_id_eq,
34
+ options_from_collection_for_select(@stock_locations, :id, :name, @q.destination_location_id_eq),
35
+ { include_blank: true }, class: 'select2-clear js-filterable' %>
45
36
  </div>
46
37
  </div>
47
- <% end %>
48
- </fieldset>
38
+ </div>
39
+
40
+ <div class="form-actions" data-hook="admin_stock_transfers_index_search_buttons">
41
+ <%= button Spree.t(:filter_results), 'search.svg' %>
42
+ </div>
43
+ <% end %>
49
44
  </div>
50
- </div>
45
+ <% end %>
51
46
 
52
47
  <% if @stock_transfers.any? %>
53
48
  <div class="table-responsive">
54
49
  <table class="table" id='listing_stock_transfers' data-hook>
55
50
  <thead>
56
51
  <tr data-hook='stock_transfers_header'>
57
- <th><%= Spree.t(:created_at) %></th>
52
+ <th><%= Spree.t(:number) %></th>
58
53
  <th><%= Spree.t(:reference) %></th>
59
54
  <th><%= Spree.t(:source) %></th>
60
55
  <th><%= Spree.t(:destination) %></th>
56
+ <th><%= Spree.t(:created_at) %></th>
61
57
  <th class='actions'></th>
62
58
  </tr>
63
59
  </thead>
64
60
  <tbody>
65
61
  <% @stock_transfers.each do |stock_transfer| %>
66
62
  <tr id="<%= spree_dom_id stock_transfer %>" data-hook="stock_transfer_row">
67
- <td><%= link_to stock_transfer.created_at.strftime('%F %T %Z'), admin_stock_transfer_path(stock_transfer) %></td>
63
+ <td><%= link_to stock_transfer.number, admin_stock_transfer_path(stock_transfer) %></td>
68
64
  <td><%= stock_transfer.reference %></td>
69
- <td><%= stock_transfer.source_location.try(:name) %></td>
70
- <td><%= stock_transfer.destination_location.try(:name) %></td>
65
+ <td>
66
+ <% if stock_transfer.source_location.present? %>
67
+ <%= stock_transfer.source_location.name %>
68
+ <% end %>
69
+ </td>
70
+ <td>
71
+ <% if stock_transfer.destination_location.present? %>
72
+ <%= stock_transfer.destination_location.name %>
73
+ <% end %>
74
+ </td>
75
+ <td><%= stock_transfer.created_at.strftime('%F %T %Z') %></td>
71
76
  <td class="actions actions-1">
72
77
  <%= link_to_with_icon 'show', Spree.t(:show), admin_stock_transfer_path(stock_transfer), class: 'btn btn-outline-secondary btn-sm', no_text: true, data: {action: 'view'} %>
73
78
  </td>
@@ -66,7 +66,7 @@
66
66
  <div class="form-group" id="stock_movement_variant_id_field">
67
67
  <%= label_tag 'variant_id', Spree.t(:variant) %>
68
68
  <div class="input-group">
69
- <%= hidden_field_tag 'transfer_variant', {}, { class: 'w-100'} %>
69
+ <%= select_tag 'transfer_variant', nil, class: 'd-block w-100', id: 'transfer_variant' %>
70
70
  </div>
71
71
  </div>
72
72
  </div>
@@ -40,5 +40,4 @@
40
40
  <%= render partial: 'stock_movements', object: @stock_transfer.destination_movements %>
41
41
  </fieldset>
42
42
  <% end %>
43
-
44
43
  </fieldset>
@@ -14,7 +14,7 @@
14
14
  <%= image_tag main_app.url_for(@store.logo) %>
15
15
  <% end %>
16
16
  <%= f.field_container :logo, class: ['form-group'] do %>
17
- <%= f.label :logo, Spree.t(:logo) %><br />
17
+ <%= f.label :logo, Spree.t(:logo) %><br>
18
18
  <%= f.file_field :logo %>
19
19
  <%= f.error_message_on :logo %>
20
20
  <% end %>
@@ -24,7 +24,7 @@
24
24
  <%= image_tag main_app.url_for(@store.mailer_logo.variant(resize: '244x104>')) %>
25
25
  <% end %>
26
26
  <%= f.field_container :mailer_logo, class: ['form-group'] do %>
27
- <%= f.label :mailer_logo, Spree.t(:mailer_logo) %><br />
27
+ <%= f.label :mailer_logo, Spree.t(:mailer_logo) %><br>
28
28
  <%= f.file_field :mailer_logo, accept: 'image/png, image/jpeg' %>
29
29
  <%= f.error_message_on :mailer_logo %>
30
30
  <% end %>
@@ -37,11 +37,19 @@
37
37
  <%= f.field_container :code, class: ['form-group'] do %>
38
38
  <%= f.label :code, raw(Spree.t(:code) + required_span_tag) %>
39
39
  <%= f.text_field :code, class: 'form-control', required: true %>
40
+ <small class="form-text text-muted">
41
+ <%= Spree.t('store_form.code_help') %>
42
+ </small>
40
43
  <%= f.error_message_on :code %>
41
44
  <% end %>
42
45
  <%= f.field_container :url, class: ['form-group'] do %>
43
- <%= f.label :url, raw(Spree.t(:url) + required_span_tag) %>
44
- <%= f.text_field :url, class: 'form-control', required: true %>
46
+ <%= f.label :url, raw(Spree.t(:url) + required_span_tag) %>
47
+ <div class="input-group mb-3">
48
+ <div class="input-group-prepend">
49
+ <span class="input-group-text" id="basic-addon3">https://</span>
50
+ </div>
51
+ <%= f.text_field :url, class: 'form-control', required: true %>
52
+ </div>
45
53
  <%= f.error_message_on :url %>
46
54
  <% end %>
47
55
  </div>
@@ -60,15 +68,23 @@
60
68
  <%= f.error_message_on :seo_title %>
61
69
  <% end %>
62
70
  <%= f.field_container :meta_description, class: ['form-group'] do %>
63
- <%= f.label :meta_description, Spree.t(:meta_description) %>
71
+ <%= f.label :meta_description, Spree.t(:meta_description) %>
64
72
  <%= f.text_area :meta_description, class: 'form-control' %>
65
73
  <%= f.error_message_on :meta_description %>
66
74
  <% end %>
67
75
  <%= f.field_container :meta_keywords, class: ['form-group'] do %>
68
- <%= f.label :meta_keywords, Spree.t(:meta_keywords) %>
76
+ <%= f.label :meta_keywords, Spree.t(:meta_keywords) %>
69
77
  <%= f.text_field :meta_keywords, class: 'form-control' %>
70
78
  <%= f.error_message_on :meta_keywords %>
71
79
  <% end %>
80
+ <%= f.field_container :seo_robots, class:['form-group'] do %>
81
+ <%= f.label :seo_robots, Spree.t(:seo_robots) %>
82
+ <%= f.text_field :seo_robots, class: 'form-control' %>
83
+ <%= f.error_message_on :seo_robots %>
84
+ <small class="form-text text-muted">
85
+ <%= raw(Spree.t('store_form.seo_robots')) %>
86
+ </small>
87
+ <% end %>
72
88
  </div>
73
89
  </div>
74
90
 
@@ -83,18 +99,27 @@
83
99
  <%= f.label :mail_from_address, raw(Spree.t(:mail_from_address) + required_span_tag) %>
84
100
  <%= f.text_field :mail_from_address, class: 'form-control', required: true %>
85
101
  <%= f.error_message_on :mail_from_address %>
102
+ <small class="form-text text-muted">
103
+ <%= Spree.t('store_form.mail_from_address_help') %>
104
+ </small>
86
105
  <% end %>
87
106
 
88
107
  <%= f.field_container :customer_support_email, class: ['form-group'] do %>
89
108
  <%= f.label :customer_support_email, Spree.t(:customer_support_email) %>
90
109
  <%= f.text_field :customer_support_email, class: 'form-control' %>
91
110
  <%= f.error_message_on :customer_support_email %>
111
+ <small class="form-text text-muted">
112
+ <%= Spree.t('store_form.customer_support_email_help') %>
113
+ </small>
92
114
  <% end %>
93
115
 
94
116
  <%= f.field_container :new_order_notifications_email, class: ['form-group'] do %>
95
117
  <%= f.label :new_order_notifications_email, Spree.t(:new_order_notifications_email) %>
96
118
  <%= f.text_field :new_order_notifications_email, class: 'form-control' %>
97
119
  <%= f.error_message_on :new_order_notifications_email %>
120
+ <small class="form-text text-muted">
121
+ <%= Spree.t('store_form.new_order_notifications_email_help') %>
122
+ </small>
98
123
  <% end %>
99
124
  </div>
100
125
  </div>
@@ -107,7 +132,7 @@
107
132
  </div>
108
133
  <div class="card-body">
109
134
  <%= f.field_container :default_currency, class: ['form-group'] do %>
110
- <%= f.label :default_currency, Spree.t(:currency) %>
135
+ <%= f.label :default_currency %>
111
136
  <%= f.select :default_currency, currency_options(@store.default_currency), {}, { class: 'select2' } %>
112
137
  <%= f.error_message_on :default_currency %>
113
138
  <% end %>
@@ -119,18 +144,33 @@
119
144
  <%= f.field_container :checkout_zone_id, class: ['form-group'] do %>
120
145
  <%= f.label :checkout_zone_id, Spree.t(:zone) %>
121
146
  <%= f.select :checkout_zone_id, options_for_select(@zones, selected_checkout_zone(@store)&.id), { include_blank: Spree.t(:no_limits_zone) }, { class: 'select2' } %>
122
- <%= f.label :checkout_zone_id, Spree.t('i18n.checkout_zone_warning_html'), class: 'alert alert-warning col-12' %>
147
+ <small class="form-text text-muted">
148
+ <%= raw(Spree.t('store_form.checkout_zone_help')) %>
149
+ </small>
123
150
  <%= f.error_message_on :checkout_zone_id %>
124
151
  <% end %>
125
152
  <%= f.field_container :default_locale, class: ['form-group'] do %>
126
- <%= f.label :default_locale, Spree.t('i18n.language') %>
127
- <%= f.select :default_locale, options_from_collection_for_select(all_locales_options, :last, :first, @store.default_locale), {}, { class: 'select2' } %>
153
+ <%= f.label :default_locale %>
154
+ <%= f.select :default_locale, options_from_collection_for_select(all_locales_options, :last, :first, @store.default_locale || I18n.locale), {}, { class: 'select2' } %>
128
155
  <%= f.error_message_on :default_locale %>
156
+ <% unless defined?(SpreeI18n) %>
157
+ <small class="form-text text-muted">
158
+ <%= raw(Spree.t('store_form.locales_help')) %>
159
+ </small>
160
+ <% end %>
161
+ <% end %>
162
+ <%= f.field_container :supported_locales, class: ['form-group'] do %>
163
+ <%= f.label :supported_locales, Spree.t(:supported_locales) %>
164
+ <%= f.select :supported_locales, options_from_collection_for_select(all_locales_options, :last, :first, @store.supported_locales&.split(',')), {}, { multiple: true, class: 'select2' } %>
165
+ <%= f.error_message_on :supported_locales %>
129
166
  <% end %>
130
167
  <%= f.field_container :default_country_id, class: ['form-group'] do %>
131
168
  <%= f.label :default_country_id, Spree.t('i18n.default_country') %>
132
169
  <%= f.select :default_country_id, options_from_collection_for_select(@countries, :id, :name, @store.default_country_id || Spree::Config[:default_country_id]), {}, { class: 'select2' } %>
133
170
  <%= f.error_message_on :default_country_id %>
171
+ <small class="form-text text-muted">
172
+ <%= Spree.t('store_form.default_country_help') %>
173
+ </small>
134
174
  <% end %>
135
175
  </div>
136
176
  </div>
@@ -142,19 +182,38 @@
142
182
  </h1>
143
183
  </div>
144
184
  <div class="card-body">
185
+ <div class="alert alert-warning col-12">
186
+ <%= Spree.t('store_form.social_help') %>
187
+ </div>
188
+
145
189
  <%= f.field_container :facebook, class: ['form-group'] do %>
146
- <%= f.label :facebook, Spree.t(:facebook) %>
147
- <%= f.text_field :facebook, class: 'form-control' %>
190
+ <%= f.label :facebook, Spree.t(:facebook) %>
191
+ <div class="input-group mb-3">
192
+ <div class="input-group-prepend">
193
+ <span class="input-group-text" id="basic-addon3">https://facebook.com</span>
194
+ </div>
195
+ <%= f.text_field :facebook, class: 'form-control' %>
196
+ </div>
148
197
  <%= f.error_message_on :facebook %>
149
198
  <% end %>
150
199
  <%= f.field_container :twitter, class: ['form-group'] do %>
151
- <%= f.label :twitter, Spree.t(:twitter) %>
152
- <%= f.text_field :twitter, class: 'form-control' %>
200
+ <%= f.label :twitter, Spree.t(:twitter) %>
201
+ <div class="input-group mb-3">
202
+ <div class="input-group-prepend">
203
+ <span class="input-group-text" id="basic-addon3">https://twitter.com</span>
204
+ </div>
205
+ <%= f.text_field :twitter, class: 'form-control' %>
206
+ </div>
153
207
  <%= f.error_message_on :twitter %>
154
208
  <% end %>
155
209
  <%= f.field_container :instagram, class: ['form-group'] do %>
156
- <%= f.label :instagram, Spree.t(:instagram) %>
157
- <%= f.text_field :instagram, class: 'form-control' %>
210
+ <%= f.label :instagram, Spree.t(:instagram) %>
211
+ <div class="input-group mb-3">
212
+ <div class="input-group-prepend">
213
+ <span class="input-group-text" id="basic-addon3">https://instagram.com</span>
214
+ </div>
215
+ <%= f.text_field :instagram, class: 'form-control' %>
216
+ </div>
158
217
  <%= f.error_message_on :instagram %>
159
218
  <% end %>
160
219
  </div>
@@ -163,27 +222,26 @@
163
222
  <div class="card mb-4">
164
223
  <div class="card-header">
165
224
  <h1 class="card-title mb-0 h5">
166
- <%= Spree.t(:footer_info) %>
225
+ <%= Spree.t(:footer) %>
167
226
  </h1>
168
227
  </div>
169
228
  <div class="card-body">
229
+ <div class="alert alert-warning col-12">
230
+ <%= Spree.t('store_form.footer_help') %>
231
+ </div>
232
+
170
233
  <%= f.field_container :description, class: ['form-group'] do %>
171
- <%= f.label :description, Spree.t(:description) %>
234
+ <%= f.label :description, Spree.t(:description) %>
172
235
  <%= f.text_area :description, class: 'form-control' %>
173
236
  <%= f.error_message_on :description %>
174
237
  <% end %>
175
238
  <%= f.field_container :address, class: ['form-group'] do %>
176
- <%= f.label :address, Spree.t(:address) %>
239
+ <%= f.label :address, Spree.t(:address) %>
177
240
  <%= f.text_area :address, class: 'form-control' %>
178
241
  <%= f.error_message_on :address %>
179
242
  <% end %>
180
- <%= f.field_container :contact_email, class: ['form-group'] do %>
181
- <%= f.label :contact_email, Spree.t(:contact_email) %>
182
- <%= f.text_field :contact_email, class: 'form-control' %>
183
- <%= f.error_message_on :contact_email %>
184
- <% end %>
185
243
  <%= f.field_container :contact_phone, class: ['form-group'] do %>
186
- <%= f.label :contact_phone, Spree.t(:contact_phone) %>
244
+ <%= f.label :contact_phone, Spree.t(:contact_phone) %>
187
245
  <%= f.text_field :contact_phone, class: 'form-control' %>
188
246
  <%= f.error_message_on :contact_phone %>
189
247
  <% end %>