solidus_backend 2.10.5 → 2.11.0

Sign up to get free protection for your applications and to get access to all the features.

Potentially problematic release.


This version of solidus_backend might be problematic. Click here for more details.

Files changed (233) hide show
  1. checksums.yaml +4 -4
  2. data/app/assets/javascripts/spree/backend.js +4 -1
  3. data/app/assets/javascripts/spree/backend/adjustments.js +1 -1
  4. data/app/assets/javascripts/spree/backend/admin.js +18 -29
  5. data/app/assets/javascripts/spree/backend/collections/states.js +1 -1
  6. data/app/assets/javascripts/spree/backend/components/selectable_table.js +5 -0
  7. data/app/assets/javascripts/spree/backend/components/selectable_table/return_items.js +5 -0
  8. data/app/assets/javascripts/spree/backend/components/selectable_table/summary.js +7 -0
  9. data/app/assets/javascripts/spree/backend/components/sortable_table.js +31 -25
  10. data/app/assets/javascripts/spree/backend/models/order.js +3 -3
  11. data/app/assets/javascripts/spree/backend/models/payment.js +1 -1
  12. data/app/assets/javascripts/spree/backend/models/shipment.js +1 -1
  13. data/app/assets/javascripts/spree/backend/models/stock_item.js +1 -1
  14. data/app/assets/javascripts/spree/backend/option_type_autocomplete.js +2 -2
  15. data/app/assets/javascripts/spree/backend/option_value_picker.js +2 -2
  16. data/app/assets/javascripts/spree/backend/product_picker.js +2 -2
  17. data/app/assets/javascripts/spree/backend/routes.js +40 -21
  18. data/app/assets/javascripts/spree/backend/shipments.js +5 -5
  19. data/app/assets/javascripts/spree/backend/shipping_methods/stock_locations_picker.js +18 -0
  20. data/app/assets/javascripts/spree/backend/stock_management.js +4 -2
  21. data/app/assets/javascripts/spree/backend/taxon_autocomplete.js +2 -2
  22. data/app/assets/javascripts/spree/backend/taxons.js +3 -3
  23. data/app/assets/javascripts/spree/backend/templates/index.js +2 -0
  24. data/app/assets/javascripts/spree/backend/templates/orders/customer_details/autocomplete.hbs +2 -2
  25. data/app/assets/javascripts/spree/backend/templates/stock_items/stock_location_stock_item.hbs +5 -1
  26. data/app/assets/javascripts/spree/backend/templates/tables/return_item_sum_amount.hbs +7 -0
  27. data/app/assets/javascripts/spree/backend/templates/tables/selectable_label.hbs +6 -0
  28. data/app/assets/javascripts/spree/backend/user_picker.js +3 -4
  29. data/app/assets/javascripts/spree/backend/variant_autocomplete.js +2 -2
  30. data/app/assets/javascripts/spree/backend/views/cart/empty_cart_button.js +2 -2
  31. data/app/assets/javascripts/spree/backend/views/index.js +4 -0
  32. data/app/assets/javascripts/spree/backend/views/order/address.js +1 -1
  33. data/app/assets/javascripts/spree/backend/views/order/customer_select.js +2 -3
  34. data/app/assets/javascripts/spree/backend/views/order/details_adjustments.js +4 -1
  35. data/app/assets/javascripts/spree/backend/views/stock/edit_stock_item_row.js +4 -0
  36. data/app/assets/javascripts/spree/backend/views/tables/return_items.js +9 -0
  37. data/app/assets/javascripts/spree/backend/views/tables/selectable_table.js +70 -0
  38. data/app/assets/javascripts/spree/backend/views/tables/selectable_table/sum_return_item_amount.js +32 -0
  39. data/app/assets/javascripts/spree/backend/views/tables/selectable_table/summary.js +45 -0
  40. data/app/assets/stylesheets/spree/backend/components/_navigation.scss +4 -5
  41. data/app/assets/stylesheets/spree/backend/sections/_orders.scss +5 -1
  42. data/app/assets/stylesheets/spree/backend/sections/_style_guide.scss +4 -0
  43. data/app/assets/stylesheets/spree/backend/shared/_forms.scss +1 -0
  44. data/app/controllers/spree/admin/base_controller.rb +6 -0
  45. data/app/controllers/spree/admin/cancellations_controller.rb +2 -0
  46. data/app/controllers/spree/admin/customer_returns_controller.rb +4 -4
  47. data/app/controllers/spree/admin/images_controller.rb +2 -1
  48. data/app/controllers/spree/admin/orders/customer_details_controller.rb +2 -0
  49. data/app/controllers/spree/admin/orders_controller.rb +7 -2
  50. data/app/controllers/spree/admin/payments_controller.rb +3 -1
  51. data/app/controllers/spree/admin/product_properties_controller.rb +1 -1
  52. data/app/controllers/spree/admin/products_controller.rb +18 -24
  53. data/app/controllers/spree/admin/promotion_codes_controller.rb +9 -4
  54. data/app/controllers/spree/admin/refunds_controller.rb +19 -0
  55. data/app/controllers/spree/admin/resource_controller.rb +27 -7
  56. data/app/controllers/spree/admin/return_authorizations_controller.rb +1 -1
  57. data/app/controllers/spree/admin/root_controller.rb +1 -1
  58. data/app/controllers/spree/admin/search_controller.rb +1 -2
  59. data/app/controllers/spree/admin/stock_items_controller.rb +6 -5
  60. data/app/controllers/spree/admin/stock_locations_controller.rb +4 -0
  61. data/app/controllers/spree/admin/stock_movements_controller.rb +7 -0
  62. data/app/controllers/spree/admin/taxons_controller.rb +12 -1
  63. data/app/controllers/spree/admin/users/api_key_controller.rb +29 -0
  64. data/app/controllers/spree/admin/users_controller.rb +37 -20
  65. data/app/controllers/spree/admin/variants_controller.rb +4 -2
  66. data/app/controllers/spree/admin/zones_controller.rb +1 -1
  67. data/app/helpers/spree/admin/base_helper.rb +4 -0
  68. data/app/helpers/spree/admin/customer_returns_helper.rb +1 -1
  69. data/app/helpers/spree/admin/navigation_helper.rb +1 -1
  70. data/app/helpers/spree/admin/orders_helper.rb +8 -4
  71. data/app/helpers/spree/admin/stock_movements_helper.rb +8 -4
  72. data/app/views/spree/admin/customer_returns/_return_item_selection.html.erb +2 -3
  73. data/app/views/spree/admin/images/index.html.erb +25 -21
  74. data/app/views/spree/admin/option_types/_option_value_fields.html.erb +8 -1
  75. data/app/views/spree/admin/option_types/edit.html.erb +3 -1
  76. data/app/views/spree/admin/orders/customer_details/_form.html.erb +13 -13
  77. data/app/views/spree/admin/orders/index.html.erb +23 -13
  78. data/app/views/spree/admin/payment_methods/_form.html.erb +7 -2
  79. data/app/views/spree/admin/payments/index.html.erb +3 -1
  80. data/app/views/spree/admin/prices/_master_variant_table.html.erb +3 -3
  81. data/app/views/spree/admin/prices/_table.html.erb +3 -3
  82. data/app/views/spree/admin/product_properties/_product_property_fields.html.erb +7 -2
  83. data/app/views/spree/admin/product_properties/index.html.erb +14 -2
  84. data/app/views/spree/admin/products/_form.html.erb +13 -2
  85. data/app/views/spree/admin/products/index.html.erb +1 -1
  86. data/app/views/spree/admin/promotion_codes/index.html.erb +1 -1
  87. data/app/views/spree/admin/promotions/_actions.html.erb +1 -1
  88. data/app/views/spree/admin/promotions/_activations_new.html.erb +1 -1
  89. data/app/views/spree/admin/promotions/_rules.html.erb +1 -1
  90. data/app/views/spree/admin/promotions/edit.html.erb +2 -2
  91. data/app/views/spree/admin/promotions/index.html.erb +12 -5
  92. data/app/views/spree/admin/return_authorizations/_form.html.erb +3 -10
  93. data/app/views/spree/admin/return_authorizations/index.html.erb +1 -1
  94. data/app/views/spree/admin/search/users.json.jbuilder +15 -1
  95. data/app/views/spree/admin/shared/_address.html.erb +6 -6
  96. data/app/views/spree/admin/shared/_address_form.html.erb +15 -8
  97. data/app/views/spree/admin/shared/_order_submenu.html.erb +4 -4
  98. data/app/views/spree/admin/shared/_payments_tabs.html.erb +1 -1
  99. data/app/views/spree/admin/shared/_settings_checkout_tabs.html.erb +5 -5
  100. data/app/views/spree/admin/shared/_settings_sub_menu.html.erb +6 -6
  101. data/app/views/spree/admin/shared/_shipping_tabs.html.erb +3 -3
  102. data/app/views/spree/admin/shared/_taxes_tabs.html.erb +2 -2
  103. data/app/views/spree/admin/shared/preference_fields/_encrypted_string.html.erb +12 -0
  104. data/app/views/spree/admin/shipping_methods/_form.html.erb +18 -0
  105. data/app/views/spree/admin/stock_items/_stock_management.html.erb +1 -1
  106. data/app/views/spree/admin/stock_locations/edit.html.erb +1 -1
  107. data/app/views/spree/admin/stock_locations/index.html.erb +3 -1
  108. data/app/views/spree/admin/stock_movements/index.html.erb +30 -1
  109. data/app/views/spree/admin/stores/_form.html.erb +6 -0
  110. data/app/views/spree/admin/style_guide/topics/tables/_building_tables.html.erb +27 -3
  111. data/app/views/spree/admin/tax_categories/_form.html.erb +1 -0
  112. data/app/views/spree/admin/users/_form.html.erb +2 -2
  113. data/app/views/spree/admin/users/_tabs.html.erb +1 -1
  114. data/app/views/spree/admin/users/edit.html.erb +4 -4
  115. data/app/views/spree/admin/users/items.html.erb +5 -3
  116. data/app/views/spree/admin/users/orders.html.erb +5 -3
  117. data/app/views/spree/admin/variants/_table_filter.html.erb +1 -1
  118. data/app/views/spree/admin/variants/index.html.erb +2 -2
  119. data/config/initializers/form_builder.rb +2 -2
  120. data/lib/spree/backend/engine.rb +0 -2
  121. data/lib/spree/backend_configuration.rb +14 -1
  122. data/solidus_backend.gemspec +4 -4
  123. metadata +21 -120
  124. data/app/assets/javascripts/spree/backend/returns/return_item_selection.js +0 -35
  125. data/script/rails +0 -10
  126. data/spec/controllers/spree/admin/base_controller_spec.rb +0 -26
  127. data/spec/controllers/spree/admin/cancellations_controller_spec.rb +0 -83
  128. data/spec/controllers/spree/admin/customer_returns_controller_spec.rb +0 -235
  129. data/spec/controllers/spree/admin/locale_controller_spec.rb +0 -45
  130. data/spec/controllers/spree/admin/missing_products_controller_spec.rb +0 -18
  131. data/spec/controllers/spree/admin/orders/customer_details_controller_spec.rb +0 -128
  132. data/spec/controllers/spree/admin/orders_controller_spec.rb +0 -408
  133. data/spec/controllers/spree/admin/payment_methods_controller_spec.rb +0 -95
  134. data/spec/controllers/spree/admin/payments_controller_spec.rb +0 -194
  135. data/spec/controllers/spree/admin/prices_controller_spec.rb +0 -45
  136. data/spec/controllers/spree/admin/product_properties_controller_spec.rb +0 -71
  137. data/spec/controllers/spree/admin/products_controller_spec.rb +0 -270
  138. data/spec/controllers/spree/admin/promotion_actions_controller_spec.rb +0 -23
  139. data/spec/controllers/spree/admin/promotion_codes_controller_spec.rb +0 -32
  140. data/spec/controllers/spree/admin/promotion_rules_controller_spec.rb +0 -36
  141. data/spec/controllers/spree/admin/promotions_controller_spec.rb +0 -122
  142. data/spec/controllers/spree/admin/refunds_controller_spec.rb +0 -35
  143. data/spec/controllers/spree/admin/reimbursements_controller_spec.rb +0 -137
  144. data/spec/controllers/spree/admin/resource_controller_spec.rb +0 -201
  145. data/spec/controllers/spree/admin/return_authorizations_controller_spec.rb +0 -291
  146. data/spec/controllers/spree/admin/return_items_controller_spec.rb +0 -29
  147. data/spec/controllers/spree/admin/root_controller_spec.rb +0 -43
  148. data/spec/controllers/spree/admin/search_controller_spec.rb +0 -106
  149. data/spec/controllers/spree/admin/shipping_methods_controller_spec.rb +0 -16
  150. data/spec/controllers/spree/admin/stock_items_controller_spec.rb +0 -52
  151. data/spec/controllers/spree/admin/stock_locations_controller_spec.rb +0 -44
  152. data/spec/controllers/spree/admin/store_credits_controller_spec.rb +0 -311
  153. data/spec/controllers/spree/admin/users_controller_spec.rb +0 -287
  154. data/spec/controllers/spree/admin/variants_controller_spec.rb +0 -71
  155. data/spec/features/admin/configuration/payment_methods_spec.rb +0 -176
  156. data/spec/features/admin/configuration/shipping_methods_spec.rb +0 -126
  157. data/spec/features/admin/configuration/stock_locations_spec.rb +0 -54
  158. data/spec/features/admin/configuration/store_spec.rb +0 -62
  159. data/spec/features/admin/configuration/tax_categories_spec.rb +0 -58
  160. data/spec/features/admin/configuration/tax_rates_spec.rb +0 -31
  161. data/spec/features/admin/configuration/taxonomies_spec.rb +0 -61
  162. data/spec/features/admin/configuration/zones_spec.rb +0 -41
  163. data/spec/features/admin/homepage_spec.rb +0 -86
  164. data/spec/features/admin/javascript_format_money_spec.rb +0 -22
  165. data/spec/features/admin/locale_spec.rb +0 -34
  166. data/spec/features/admin/orders/adjustments_promotions_spec.rb +0 -55
  167. data/spec/features/admin/orders/adjustments_spec.rb +0 -130
  168. data/spec/features/admin/orders/cancelling_and_resuming_spec.rb +0 -45
  169. data/spec/features/admin/orders/cancelling_inventory_spec.rb +0 -50
  170. data/spec/features/admin/orders/customer_details_spec.rb +0 -203
  171. data/spec/features/admin/orders/customer_returns_spec.rb +0 -41
  172. data/spec/features/admin/orders/line_items_spec.rb +0 -52
  173. data/spec/features/admin/orders/listing_spec.rb +0 -186
  174. data/spec/features/admin/orders/log_entries_spec.rb +0 -56
  175. data/spec/features/admin/orders/new_order_spec.rb +0 -379
  176. data/spec/features/admin/orders/new_refund_spec.rb +0 -35
  177. data/spec/features/admin/orders/order_details_spec.rb +0 -591
  178. data/spec/features/admin/orders/payments_spec.rb +0 -330
  179. data/spec/features/admin/orders/return_authorizations_spec.rb +0 -56
  180. data/spec/features/admin/orders/return_payment_state_spec.rb +0 -65
  181. data/spec/features/admin/orders/risk_analysis_spec.rb +0 -49
  182. data/spec/features/admin/orders/shipments_spec.rb +0 -145
  183. data/spec/features/admin/payments/store_credits_spec.rb +0 -23
  184. data/spec/features/admin/products/edit/images_spec.rb +0 -76
  185. data/spec/features/admin/products/edit/products_spec.rb +0 -92
  186. data/spec/features/admin/products/edit/taxons_spec.rb +0 -57
  187. data/spec/features/admin/products/edit/variants_spec.rb +0 -63
  188. data/spec/features/admin/products/option_types_spec.rb +0 -116
  189. data/spec/features/admin/products/pricing_spec.rb +0 -127
  190. data/spec/features/admin/products/products_spec.rb +0 -348
  191. data/spec/features/admin/products/properties_spec.rb +0 -141
  192. data/spec/features/admin/products/stock_management_spec.rb +0 -101
  193. data/spec/features/admin/products/variant_spec.rb +0 -89
  194. data/spec/features/admin/promotion_adjustments_spec.rb +0 -286
  195. data/spec/features/admin/promotions/option_value_rule_spec.rb +0 -90
  196. data/spec/features/admin/promotions/product_rule_spec.rb +0 -35
  197. data/spec/features/admin/promotions/promotion_categories_spec.rb +0 -83
  198. data/spec/features/admin/promotions/promotion_code_batches_spec.rb +0 -37
  199. data/spec/features/admin/promotions/promotion_code_spec.rb +0 -31
  200. data/spec/features/admin/promotions/promotion_spec.rb +0 -52
  201. data/spec/features/admin/promotions/tiered_calculator_spec.rb +0 -76
  202. data/spec/features/admin/promotions/user_rule_spec.rb +0 -42
  203. data/spec/features/admin/reimbursements_spec.rb +0 -18
  204. data/spec/features/admin/store_credits_spec.rb +0 -132
  205. data/spec/features/admin/stores_spec.rb +0 -37
  206. data/spec/features/admin/style_guide_spec.rb +0 -14
  207. data/spec/features/admin/taxons_spec.rb +0 -90
  208. data/spec/features/admin/users_spec.rb +0 -412
  209. data/spec/fixtures/files/ror_ringer.jpeg +0 -0
  210. data/spec/helpers/admin/base_helper_spec.rb +0 -49
  211. data/spec/helpers/admin/navigation_helper_spec.rb +0 -139
  212. data/spec/helpers/admin/stock_movements_helper_spec.rb +0 -29
  213. data/spec/helpers/admin/store_credit_events_helper_spec.rb +0 -97
  214. data/spec/helpers/promotion_rules_helper_spec.rb +0 -14
  215. data/spec/javascripts/fixtures/_boot.html.erb +0 -8
  216. data/spec/javascripts/fixtures/number_with_currency/with_currency_select.html.erb +0 -3
  217. data/spec/javascripts/fixtures/number_with_currency/without_select.html.erb +0 -3
  218. data/spec/javascripts/format_money_spec.js +0 -48
  219. data/spec/javascripts/spec_helper.js +0 -13
  220. data/spec/javascripts/support/show_errors.js +0 -8
  221. data/spec/javascripts/support/with_translations.js +0 -11
  222. data/spec/javascripts/translation_spec.js +0 -58
  223. data/spec/javascripts/views/number_with_currency_spec.js +0 -72
  224. data/spec/lib/spree/backend_configuration/menu_item_spec.rb +0 -17
  225. data/spec/lib/spree/backend_configuration_spec.rb +0 -22
  226. data/spec/spec_helper.rb +0 -123
  227. data/spec/support/appear_before_matcher.rb +0 -10
  228. data/spec/support/feature/base_feature_helper.rb +0 -17
  229. data/spec/support/feature/order_feature_helper.rb +0 -27
  230. data/spec/teaspoon_env.rb +0 -51
  231. data/spec/test_views/spree/admin/widgets/edit.html.erb +0 -1
  232. data/spec/test_views/spree/admin/widgets/new.html.erb +0 -1
  233. data/spec/views/spree/admin/shared/navigation_footer_spec.rb +0 -67
@@ -7,7 +7,7 @@
7
7
  <li>
8
8
  <%= link_to t('spree.new_order'), new_admin_order_url, id: 'admin_new_order', class: 'btn btn-primary' %>
9
9
  </li>
10
- <% end if can? :create, Spree::Order %>
10
+ <% end if can? :manage, Spree::Order %>
11
11
 
12
12
  <% content_for :table_filter_title do %>
13
13
  <%= t('spree.filter') %>
@@ -65,14 +65,21 @@
65
65
  </div>
66
66
 
67
67
  <div class="col-12 col-xl-6">
68
- <div class="field">
69
- <%= label_tag :q_bill_address_firstname_start, t('spree.first_name_begins_with') %>
70
- <%= f.text_field :bill_address_firstname_start, size: 25 %>
71
- </div>
72
- <div class="field">
73
- <%= label_tag :q_bill_address_lastname_start, t('spree.last_name_begins_with') %>
74
- <%= f.text_field :bill_address_lastname_start, size: 25%>
75
- </div>
68
+ <% if Spree::Config.use_combined_first_and_last_name_in_address %>
69
+ <div class="field">
70
+ <%= label_tag :q_bill_address_firstname_or_lastname_start, t('spree.name_contains') %>
71
+ <%= f.text_field :bill_address_firstname_or_lastname_start, size: 25 %>
72
+ </div>
73
+ <% else %>
74
+ <div class="field">
75
+ <%= label_tag :q_bill_address_firstname_start, t('spree.first_name_begins_with') %>
76
+ <%= f.text_field :bill_address_firstname_start, size: 25 %>
77
+ </div>
78
+ <div class="field">
79
+ <%= label_tag :q_bill_address_lastname_start, t('spree.last_name_begins_with') %>
80
+ <%= f.text_field :bill_address_lastname_start, size: 25 %>
81
+ </div>
82
+ <% end %>
76
83
  </div>
77
84
 
78
85
  <div class="col-12 col-xl-6">
@@ -177,8 +184,9 @@
177
184
  <% if order.user %>
178
185
  <%= link_to order.email, edit_admin_user_path(order.user) %>
179
186
  <% else %>
180
- <%= mail_to order.email %>
187
+ <%= order.email %>
181
188
  <% end %>
189
+ <%= link_to_with_icon('email', t('spree.actions.send_email'), "mailto:#{order.email}", no_text: true) %>
182
190
  </td>
183
191
  <td class="align-right"><%= order.display_total.to_html %></td>
184
192
  <td class='actions align-center' data-hook="admin_orders_index_row_actions">
@@ -190,9 +198,11 @@
190
198
  </table>
191
199
  <% else %>
192
200
  <div class="no-objects-found">
193
- <%= render 'spree/admin/shared/no_objects_found',
194
- resource: Spree::Order,
195
- new_resource_url: spree.new_admin_order_path %>
201
+ <% if can? :manage, Spree::Order %>
202
+ <%= render 'spree/admin/shared/no_objects_found',
203
+ resource: Spree::Order,
204
+ new_resource_url: spree.new_admin_order_path %>
205
+ <% end %>
196
206
  </div>
197
207
  <% end %>
198
208
 
@@ -31,7 +31,12 @@
31
31
  </div>
32
32
  <div data-hook="auto_capture" class="field">
33
33
  <%= f.label :auto_capture %>
34
- <%= f.select :auto_capture, [["#{t('spree.use_app_default')} (#{Spree::Config[:auto_capture]})", ''], [t('spree.say_yes'), true], [t('spree.say_no'), false]], {}, {class: 'custom-select fullwidth'} %>
34
+ <%= f.select :auto_capture,
35
+ [["#{t('spree.use_app_default')} (#{Spree::Config[:auto_capture] ? t('spree.say_yes') : t('spree.say_no')})", ''],
36
+ [t('spree.say_yes'), true],
37
+ [t('spree.say_no'), false]],
38
+ {},
39
+ {class: 'custom-select fullwidth'} %>
35
40
  </div>
36
41
  <div data-hook="available_to_user" class="field">
37
42
  <label>
@@ -39,7 +44,7 @@
39
44
  <%= Spree::PaymentMethod.human_attribute_name :available_to_users %>
40
45
  </label>
41
46
  </div>
42
- <div data-hook="available_to_user" class="field">
47
+ <div data-hook="available_to_admin" class="field">
43
48
  <label>
44
49
  <%= f.check_box :available_to_admin %>
45
50
  <%= Spree::PaymentMethod.human_attribute_name :available_to_admin %>
@@ -3,7 +3,9 @@
3
3
  <% content_for :page_actions do %>
4
4
  <% if @order.outstanding_balance? %>
5
5
  <li id="new_payment_section">
6
- <%= link_to t('spree.new_payment'), new_admin_order_payment_url(@order), class: 'btn btn-primary' %>
6
+ <% if can? :create, Spree::Payment %>
7
+ <%= link_to t('spree.new_payment'), new_admin_order_payment_url(@order), class: 'btn btn-primary' %>
8
+ <% end %>
7
9
  </li>
8
10
  <% end %>
9
11
  <% end %>
@@ -20,17 +20,17 @@
20
20
  </tr>
21
21
  </thead>
22
22
  <% master_prices.each do |price| %>
23
- <tr id="<%= spree_dom_id price %>" data-hook="prices_row" class="<%= "deleted" if price.deleted? %>">
23
+ <tr id="<%= spree_dom_id price %>" data-hook="prices_row" class="<%= "deleted" if price.discarded? %>">
24
24
  <td><%= price.display_country %></td>
25
25
  <td><%= price.currency %></td>
26
26
  <td><%= price.money.to_html %></td>
27
27
  <td class="actions">
28
28
  <% if can?(:update, price) %>
29
- <%= link_to_edit(price, no_text: true) unless price.deleted? %>
29
+ <%= link_to_edit(price, no_text: true) unless price.discarded? %>
30
30
  <% end %>
31
31
  <% if can?(:destroy, price) %>
32
32
  &nbsp;
33
- <%= link_to_delete(price, no_text: true) unless price.deleted? %>
33
+ <%= link_to_delete(price, no_text: true) unless price.discarded? %>
34
34
  <% end %>
35
35
  </td>
36
36
  </tr>
@@ -14,18 +14,18 @@
14
14
  </thead>
15
15
  <tbody>
16
16
  <% variant_prices.each do |price| %>
17
- <tr id="<%= spree_dom_id price %>" data-hook="prices_row" class="<%= "deleted" if price.deleted? %>">
17
+ <tr id="<%= spree_dom_id price %>" data-hook="prices_row" class="<%= "deleted" if price.discarded? %>">
18
18
  <td><%= price.variant.descriptive_name %></td>
19
19
  <td><%= price.display_country %></td>
20
20
  <td><%= price.currency %></td>
21
21
  <td><%= price.money.to_html %></td>
22
22
  <td class="actions">
23
23
  <% if can?(:update, price) %>
24
- <%= link_to_edit(price, no_text: true) unless price.deleted? %>
24
+ <%= link_to_edit(price, no_text: true) unless price.discarded? %>
25
25
  <% end %>
26
26
  <% if can?(:destroy, price) %>
27
27
  &nbsp;
28
- <%= link_to_delete(price, no_text: true) unless price.deleted? %>
28
+ <%= link_to_delete(price, no_text: true) unless price.discarded? %>
29
29
  <% end %>
30
30
  </td>
31
31
  </tr>
@@ -12,8 +12,13 @@
12
12
  <%= f.text_field :value %>
13
13
  </td>
14
14
  <td class="actions">
15
- <% if f.object.persisted? && can?(:destroy, f.object) %>
16
- <%= link_to_delete f.object, no_text: true %>
15
+ <% if f.object.persisted? %>
16
+ <% if can?(:destroy, f.object) %>
17
+ <%= link_to_delete f.object, no_text: true %>
18
+ <% end %>
19
+ <% else %>
20
+ <%= link_to_with_icon('trash', 'remove', '#', no_text: true, class: "spree_remove_fields",
21
+ data: { action: 'remove' }, title: t('spree.actions.remove')) %>
17
22
  <% end %>
18
23
  </td>
19
24
  </tr>
@@ -7,7 +7,9 @@
7
7
  <% if can?(:create, Spree::ProductProperty) %>
8
8
  <ul class="tollbar inline-menu">
9
9
  <li>
10
- <%= link_to_add_fields t('spree.add_product_properties'), 'tbody#product_properties', class: 'plus btn btn-primary' %>
10
+ <%= button_tag t('spree.add_product_properties'), type: 'button',
11
+ data: { target: 'tbody#product_properties' },
12
+ class: 'btn btn-primary spree_add_fields' %>
11
13
  </li>
12
14
  </ul>
13
15
  <% end %>
@@ -55,7 +57,9 @@
55
57
  <div class="form-buttons filter-actions actions">
56
58
  <%= button_tag t('spree.filter_results'), class: 'btn btn-primary' %>
57
59
  <% if @option_value_ids.present? %>
58
- <%= link_to_add_fields t('spree.add_variant_properties'), 'tbody#variant_property_values', class: 'plus button' %>
60
+ <%= button_tag t('spree.add_variant_properties'), type: 'button',
61
+ data: { target: 'tbody#variant_property_values' },
62
+ class: 'button spree_add_fields' %>
59
63
  <% end %>
60
64
  </div>
61
65
  </fieldset>
@@ -66,6 +70,14 @@
66
70
  <%= f.fields_for :variant_property_rules, @variant_property_rule do |rule_form| %>
67
71
  <%= rule_form.hidden_field 'id', value: @variant_property_rule.id %>
68
72
  <%= rule_form.hidden_field 'option_value_ids', value: @option_value_ids.join(',') %>
73
+ <div class="col-12">
74
+ <div class="field checkbox">
75
+ <label>
76
+ <%= rule_form.check_box 'apply_to_all', value: @variant_property_rule.apply_to_all %>
77
+ <%= t('spree.applies_to_all_variant_properties') %>
78
+ </label>
79
+ </div>
80
+ </div>
69
81
  <% if @option_value_ids.present? %>
70
82
  <fieldset class='no-border-top'>
71
83
  <table class="index sortable" data-hook data-sortable-link="<%= update_positions_admin_product_variant_property_rule_values_url %>">
@@ -83,6 +83,17 @@
83
83
  <% end %>
84
84
  </div>
85
85
 
86
+ <div data-hook="admin_product_form_discontinue_on">
87
+ <%= f.field_container :discontinue_on do %>
88
+ <%= f.label :discontinue_on %>
89
+ <%= f.field_hint :discontinue_on %>
90
+
91
+ <%= render "spree/admin/shared/datepicker", f: f, date_attr: :discontinue_on %>
92
+
93
+ <%= f.error_message_on :discontinue_on %>
94
+ <% end %>
95
+ </div>
96
+
86
97
  <div data-hook="admin_product_form_promotionable">
87
98
  <%= f.field_container :promotionable do %>
88
99
  <label>
@@ -146,8 +157,8 @@
146
157
  <div data-hook="admin_product_form_tax_category">
147
158
  <%= f.field_container :tax_category do %>
148
159
  <%= f.label :tax_category_id, Spree::TaxCategory.model_name.human %>
149
- <%= f.field_hint :tax_category %>
150
- <%= f.collection_select(:tax_category_id, @tax_categories, :id, :name, { include_blank: t('spree.match_choices.none') }, { class: 'custom-select' }) %>
160
+ <%= f.field_hint :tax_category, default_tax_category: @default_tax_category&.name %>
161
+ <%= f.collection_select(:tax_category_id, @tax_categories, :id, :name, { include_blank: t('spree.match_choices.none'), selected: @default_tax_category&.id }, { class: 'custom-select' }) %>
151
162
  <%= f.error_message_on :tax_category %>
152
163
  <% end %>
153
164
  </div>
@@ -34,7 +34,7 @@
34
34
  <div class="col-2">
35
35
  <div class="field checkbox">
36
36
  <label>
37
- <%= f.check_box :with_deleted, { checked: params[:q][:with_deleted] == 'true' }, 'true', 'false' %>
37
+ <%= f.check_box :with_discarded, { checked: params[:q][:with_discarded] == 'true' }, 'true', 'false' %>
38
38
  <%= t('spree.show_deleted') %>
39
39
  </label>
40
40
  </div>
@@ -4,7 +4,7 @@
4
4
 
5
5
  <% content_for :page_actions do %>
6
6
  <li>
7
- <% if can?(:create, Spree::PromotionCode) %>
7
+ <% if can?(:create, Spree::PromotionCode) && !@promotion.apply_automatically? %>
8
8
  <%= link_to t('spree.create_promotion_code'), new_admin_promotion_promotion_code_path(promotion_id: @promotion.id), class: 'btn btn-primary' %>
9
9
  <% end %>
10
10
 
@@ -8,7 +8,7 @@
8
8
  <div class="field">
9
9
  <%= label_tag :action_type, t('spree.adjustment_type')%>
10
10
  <%= admin_hint t('spree.adjustment_type'), t(:promotions, scope: [:spree, :hints, "spree/calculator"]) %>
11
- <%= select_tag 'action_type', options, include_blank: t(:choose_promotion_action, scope: 'spree'), class: 'custom-select fullwidth' %>
11
+ <%= select_tag 'action_type', options, include_blank: t(:choose_promotion_action, scope: 'spree'), class: 'custom-select fullwidth', required: true %>
12
12
  </div>
13
13
  <div class="filter-actions actions">
14
14
  <%= button_tag t('spree.actions.add'), class: 'btn btn-primary' %>
@@ -4,7 +4,7 @@
4
4
  <div class="form-check">
5
5
  <label class="form-check-label">
6
6
  <%= radio_button_tag('activation_type', 'auto', activation_type == 'auto') %>
7
- <%= t('.auto') %>
7
+ <%= t('.auto') %> <%= f.field_hint :promo_code_will_be_disabled %>
8
8
  </label>
9
9
  </div>
10
10
  <div class="form-check">
@@ -7,7 +7,7 @@
7
7
  <% if can?(:update, @promotion) %>
8
8
  <div class="field">
9
9
  <%= label_tag :promotion_rule_type, t('spree.discount_rules') %>
10
- <%= select_tag('promotion_rule[type]', options_for_promotion_rule_types(@promotion), include_blank: t(:choose_promotion_rule, scope: 'spree'), class: 'custom-select fullwidth') %>
10
+ <%= select_tag('promotion_rule[type]', options_for_promotion_rule_types(@promotion), include_blank: t(:choose_promotion_rule, scope: 'spree'), class: 'custom-select fullwidth', required: true) %>
11
11
  </div>
12
12
  <div class="filter-actions actions">
13
13
  <%= button_tag t('spree.actions.add'), class: 'btn btn-primary' %>
@@ -5,13 +5,13 @@
5
5
 
6
6
  <% content_for :page_actions do %>
7
7
  <li>
8
- <% if can?(:display, Spree::PromotionCode) %>
8
+ <% if can?(:show, Spree::PromotionCode) %>
9
9
  <%= link_to t('spree.view_promotion_codes_list'), admin_promotion_promotion_codes_path(promotion_id: @promotion.id), class: 'btn btn-primary' %>
10
10
 
11
11
  <%= link_to t('spree.download_promotion_codes_list'), admin_promotion_promotion_codes_path(promotion_id: @promotion.id, format: :csv), class: 'btn btn-primary' %>
12
12
  <% end %>
13
13
 
14
- <% if can?(:display, Spree::PromotionCodeBatch) %>
14
+ <% if can?(:show, Spree::PromotionCodeBatch) %>
15
15
  <%= link_to plural_resource_name(Spree::PromotionCodeBatch), admin_promotion_promotion_code_batches_path(promotion_id: @promotion.id), class: 'btn btn-primary' %>
16
16
  <% end %>
17
17
  </li>
@@ -16,33 +16,40 @@
16
16
  <div data-hook="admin_promotions_index_search">
17
17
  <%= search_form_for [:admin, @search] do |f| %>
18
18
  <div class="row">
19
- <div class="col-3">
19
+ <div class="col-4">
20
20
  <div class="field">
21
21
  <%= label_tag :q_name_cont, Spree::Promotion.human_attribute_name(:name) %>
22
22
  <%= f.text_field :name_cont, tabindex: 1 %>
23
23
  </div>
24
24
  </div>
25
25
 
26
- <div class="col-3">
26
+ <div class="col-2">
27
27
  <div class="field">
28
28
  <%= label_tag :q_codes_value_cont, Spree::Promotion.human_attribute_name(:code) %>
29
29
  <%= f.text_field :codes_value_cont, tabindex: 1 %>
30
30
  </div>
31
31
  </div>
32
32
 
33
- <div class="col-3">
33
+ <div class="col-2">
34
34
  <div class="field">
35
35
  <%= label_tag :q_path_cont, Spree::Promotion.human_attribute_name(:path) %>
36
36
  <%= f.text_field :path_cont, tabindex: 1 %>
37
37
  </div>
38
38
  </div>
39
39
 
40
- <div class="col-3">
40
+ <div class="col-2">
41
41
  <div class="field">
42
42
  <%= label_tag :q_promotion_category_id_eq, Spree::PromotionCategory.model_name.human %><br>
43
43
  <%= f.collection_select(:promotion_category_id_eq, @promotion_categories, :id, :name, { include_blank: t('spree.match_choices.all') }, { class: 'custom-select fullwidth' }) %>
44
44
  </div>
45
45
  </div>
46
+
47
+ <div class="col-2">
48
+ <div class="field">
49
+ <%= label_tag :active, t('spree.active') %><br>
50
+ <%= f.check_box :active, label: false, as: :boolean, checked_value: true %>
51
+ </div>
52
+ </div>
46
53
  </div>
47
54
 
48
55
  <div class="clearfix"></div>
@@ -59,7 +66,7 @@
59
66
 
60
67
  <%= paginate @promotions, theme: "solidus_admin" %>
61
68
 
62
- <% if @promotions.any? %>
69
+ <% if @promotions.length > 0 %>
63
70
  <table class="index">
64
71
  <thead>
65
72
  <tr>
@@ -1,13 +1,10 @@
1
1
  <% allow_return_item_changes = !@return_authorization.customer_returned_items? %>
2
2
 
3
3
  <div data-hook="admin_return_authorization_form_fields">
4
- <table class="index return-items-table">
4
+ <table class="index return-items-table selectable-table">
5
5
  <thead>
6
6
  <tr data-hook="rma_header">
7
- <th class="return-item-checkbox">
8
- <% if allow_return_item_changes %>
9
- <%= check_box_tag 'select-all' %>
10
- <% end %>
7
+ <th>
11
8
  </th>
12
9
  <th class="return-item-product"><%= Spree::Product.model_name.human %></th>
13
10
  <th class="return-item-state"><%= Spree::ReturnAuthorization.human_attribute_name(:state) %></th>
@@ -27,7 +24,7 @@
27
24
  <td class="return-item-checkbox inventory-unit-checkbox">
28
25
  <% if editable %>
29
26
  <%= item_fields.hidden_field :inventory_unit_id %>
30
- <%= item_fields.check_box :_destroy, {checked: return_item.persisted?, class: 'add-item', "data-price" => return_item.amount}, '0', '1' %>
27
+ <%= item_fields.check_box :_destroy, {checked: return_item.persisted?, class: 'selectable add-item', "data-price" => return_item.amount}, '0', '1' %>
31
28
  <% end %>
32
29
  </td>
33
30
  <td class="return-item-product">
@@ -75,10 +72,6 @@
75
72
  </tbody>
76
73
  </table>
77
74
 
78
- <%= f.field_container :amount do %>
79
- <%= t('spree.total_pre_tax_refund') %>: <span id="total_pre_tax_refund">0.00</span>
80
- <% end %>
81
-
82
75
  <%= f.field_container :stock_location do %>
83
76
  <%= f.label :stock_location_id, Spree::StockLocation.model_name.human %>
84
77
  <%= f.select :stock_location_id, @stock_locations.to_a.collect{|l|[l.name, l.id]}, {include_blank: true}, {class: 'custom-select fullwidth', "data-placeholder" => t('spree.select_a_stock_location')} %>
@@ -3,7 +3,7 @@
3
3
  <% content_for :page_actions do %>
4
4
  <% if @order.shipments.any? &:shipped? %>
5
5
  <li>
6
- <% if can? :create, Spree::ReturnAuthorization %>
6
+ <% if can? :manage, Spree::ReturnAuthorization %>
7
7
  <%= link_to t('spree.new_return_authorization'), new_admin_order_return_authorization_url(@order), class: 'btn btn-primary' %>
8
8
  <% end %>
9
9
  </li>
@@ -4,7 +4,21 @@ json.array!(@users) do |user|
4
4
  json.id user.id
5
5
  json.email user.email
6
6
 
7
- address_fields = [:firstname, :lastname, :address1, :address2, :city, :zipcode, :phone, :state_name, :state_id, :country_id, :company]
7
+ address_fields = [
8
+ :name,
9
+ :address1,
10
+ :address2,
11
+ :city,
12
+ :zipcode,
13
+ :phone,
14
+ :state_name,
15
+ :state_id,
16
+ :country_id,
17
+ :company
18
+ ]
19
+ unless Spree::Config.use_combined_first_and_last_name_in_address
20
+ address_fields.push(:firstname, :lastname)
21
+ end
8
22
  json.ship_address do
9
23
  if user.ship_address
10
24
  json.(user.ship_address, *address_fields)
@@ -1,8 +1,8 @@
1
1
  <div data-hook="address">
2
- <%="#{address.firstname} #{address.lastname} "%><%= address.company unless address.company.blank? %><br />
3
- <%="#{address.phone}" %><%= address.alternative_phone unless address.alternative_phone.blank? %><br />
4
- <%= address.address1 %><br />
5
- <% if address.address2.present? %><%= "#{address.address2}" %><br /><% end %>
6
- <%= "#{address.city}, #{address.state_text}, #{address.zipcode}" %><br />
7
- <%= "#{address.country.name}" %>
2
+ <%= address.name %> <%= address.company unless address.company.blank? %><br>
3
+ <%= address.phone %><%= address.alternative_phone unless address.alternative_phone.blank? %><br>
4
+ <%= address.address1 %><br>
5
+ <% if address.address2.present? %><%= address.address2 %><br><% end %>
6
+ <%= "#{address.city}, #{address.state_text}, #{address.zipcode}" %><br>
7
+ <%= address.country.name %>
8
8
  </div>
@@ -1,15 +1,22 @@
1
1
  <% s_or_b = type.chars.first %>
2
2
 
3
3
  <div id="<%= type %>" data-hook="address_fields">
4
- <div class="field <%= "#{type}-row" %>">
5
- <%= f.label :firstname %>
6
- <%= f.text_field :firstname, class: 'fullwidth' %>
7
- </div>
4
+ <% if Spree::Config.use_combined_first_and_last_name_in_address %>
5
+ <div class="field <%= "#{type}-row" %>">
6
+ <%= f.label :name %>
7
+ <%= f.text_field :name, class: 'fullwidth' %>
8
+ </div>
9
+ <% else %>
10
+ <div class="field <%= "#{type}-row" %>">
11
+ <%= f.label :firstname %>
12
+ <%= f.text_field :firstname, class: 'fullwidth' %>
13
+ </div>
8
14
 
9
- <div class="field <%= "#{type}-row" %>">
10
- <%= f.label :lastname %>
11
- <%= f.text_field :lastname, class: 'fullwidth' %>
12
- </div>
15
+ <div class="field <%= "#{type}-row" %>">
16
+ <%= f.label :lastname %>
17
+ <%= f.text_field :lastname, class: 'fullwidth' %>
18
+ </div>
19
+ <% end %>
13
20
 
14
21
  <% if Spree::Config[:company] %>
15
22
  <div class="field <%= "#{type}-row" %>">