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
@@ -6,7 +6,6 @@
6
6
  <%= button_link_to Spree.t(:resend, scope: 'admin.order.events', default: Spree.t(:resend)),
7
7
  resend_admin_order_url(order),
8
8
  method: :post,
9
- icon: 'envelope.svg'
10
- %>
9
+ icon: 'envelope.svg' %>
11
10
  <% end %>
12
11
  <% end %>
@@ -3,10 +3,10 @@
3
3
  <div class="table-responsive">
4
4
  <table class="table table-condensed table-bordered">
5
5
  <thead>
6
- <th><%= Spree.t('risk')%></th>
7
- <th><%= Spree.t('status')%></th>
6
+ <th><%= Spree.t('risk') %></th>
7
+ <th><%= Spree.t('status') %></th>
8
8
  </thead>
9
- <tbody id="risk-analysis" data-hook="order_details_adjustments" class="with-border">
9
+ <tbody id="risk-analysis" data-hook="order_details_adjustments" class="with-border">
10
10
  <tr class="">
11
11
  <td>
12
12
  <strong><%= Spree.t(:failed_payment_attempts) %>:</strong>
@@ -8,7 +8,9 @@
8
8
  -
9
9
  <span class="shipment-state"><%= Spree.t("shipment_states.#{shipment.state}") %></span>
10
10
  <%= Spree.t(:package_from) %>
11
- <strong class="stock-location-name" data-hook="stock-location-name">'<%= shipment.stock_location.name %>'</strong>
11
+ <strong class="stock-location-name" data-hook="stock-location-name">
12
+ <%= link_to shipment.stock_location.name, spree.edit_admin_stock_location_url(shipment.stock_location) %>
13
+ </strong>
12
14
  <% if shipment.ready? and can? :update, shipment %>
13
15
  <%= link_to Spree.t(:ship), 'javascript:;', class: 'ship ml-auto btn btn-success', data: { 'shipment-number' => shipment.number } %>
14
16
  <div class='clearfix'></div>
@@ -69,7 +71,6 @@
69
71
  </td>
70
72
  </tr>
71
73
 
72
-
73
74
  <tr class="edit-tracking is-hidden total">
74
75
  <td colspan="5">
75
76
  <label><%= Spree.t(:tracking_number) %>:</label>
@@ -6,7 +6,7 @@
6
6
 
7
7
  <td class="item-name">
8
8
  <%= link_to item.variant.product.name, edit_admin_product_path(item.variant.product) %>
9
- <br />
9
+ <br>
10
10
  <%= "(#{item.variant.options_text})" if item.variant.options_text.present? %>
11
11
  <% if item.variant.sku.present? %>
12
12
  <strong><%= Spree.t(:sku) %>:</strong> <%= item.variant.sku %>
@@ -14,7 +14,7 @@
14
14
 
15
15
  <% if @order.line_items.empty? %>
16
16
  <div class="alert alert-warning">
17
- <%= Spree.t(:your_order_is_empty_add_product)%>
17
+ <%= Spree.t(:your_order_is_empty_add_product) %>
18
18
  </div>
19
19
  <% end %>
20
20
 
@@ -0,0 +1,7 @@
1
+ <%= render 'spree/admin/shared/order_tabs', current: :channel %>
2
+
3
+ <div data-hook="admin_order_edit_header">
4
+ <%= render 'spree/admin/shared/error_messages', target: @order %>
5
+ </div>
6
+
7
+ <%= render 'channel_form', order: @order if can?(:update, @order) %>
@@ -1,19 +1,42 @@
1
1
  <script type='text/template' id='customer_autocomplete_template'>
2
- <div class='customer-autocomplete-item'>
3
- <div class='customer-details'>
4
- <h5>{{customer.email}}</h5>
5
- {{#if bill_address.firstname }}
6
- <strong>{{t 'bill_address' }}</strong>
7
- {{bill_address.firstname}} {{bill_address.lastname}}<br>
8
- {{bill_address.address1}}, {{bill_address.address2}}<br>
9
- {{bill_address.city}}<br>
10
- {{#if bill_address.state_id }}
11
- {{bill_address.state.name}}
2
+ <div class='customer-autocomplete-item container'>
3
+ <div class="row">
4
+ <div class="col">
5
+ <h5><strong>Email:</strong> {{customer.email}}</h5>
6
+ </div>
7
+ </div>
8
+
9
+ <div class="row">
10
+ <div class='customer-details col-6'>
11
+ {{#if bill_address.firstname }}
12
+ <strong>{{t 'bill_address' }}</strong><br>
13
+ {{bill_address.firstname}} {{bill_address.lastname}}<br>
14
+ {{bill_address.address1}}, {{bill_address.address2}}<br>
15
+ {{bill_address.city}}<br>
16
+ {{#if bill_address.state_id }}
17
+ {{bill_address.state.name}}
18
+ {{else}}
19
+ {{bill_address.state_name}}
20
+ {{/if}}
21
+ {{bill_address.country.name}}
22
+ {{/if}}
23
+ </div>
24
+
25
+ <div class='customer-details col-6'>
26
+ {{#if ship_address.firstname }}
27
+ <strong>Shipping Address</strong><br>
28
+ {{ship_address.firstname}} {{ship_address.lastname}}<br>
29
+ {{ship_address.address1}}, {{ship_address.address2}}<br>
30
+ {{ship_address.city}}<br>
31
+ {{#if ship_address.state_id }}
32
+ {{ship_address.state.name}}
12
33
  {{else}}
13
- {{bill_address.state_name}}
34
+ {{ship_address.state_name}}
14
35
  {{/if}}
15
- {{bill_address.country.name}}
36
+ {{ship_address.country.name}}
16
37
  {{/if}}
17
38
  </div>
39
+
18
40
  </div>
41
+ </div>
19
42
  </script>
@@ -33,7 +33,7 @@
33
33
  </span>
34
34
  </div>
35
35
  <% else %>
36
- <div class="radio no-margint">
36
+ <div class="radio mt-0">
37
37
  <%= label_tag :guest_checkout_true do %>
38
38
  <%= radio_button_tag :guest_checkout, true, guest %>
39
39
  <%= Spree.t(:say_yes) %>
@@ -83,8 +83,8 @@
83
83
  <%= f.fields_for :ship_address do |sa_form| %>
84
84
  <div class="form-group">
85
85
  <span data-hook="use_billing">
86
- <%= check_box_tag 'order[use_billing]', '1', @order.shipping_eq_billing_address? %>
87
- <%= label_tag 'order[use_billing]', Spree.t(:use_billing_address) %>
86
+ <%= check_box_tag 'order[use_billing]', '1', @order.shipping_eq_billing_address?, class: 'checkbox' %>
87
+ <%= label_tag 'order[use_billing]', Spree.t(:use_billing_address), class: 'form-check-label' %>
88
88
  </span>
89
89
  </div>
90
90
 
@@ -12,7 +12,7 @@
12
12
  </h1>
13
13
  </div>
14
14
  <div class="card-body" id="customer-search-field">
15
- <%= hidden_field_tag :customer_search, nil, class: 'error-message' %>
15
+ <%= select_tag :customer_search, nil, class: 'd-block w-100' %>
16
16
  <%= render partial: "spree/admin/orders/customer_details/autocomplete", formats: :js %>
17
17
  </div>
18
18
  </div>
@@ -18,7 +18,7 @@
18
18
 
19
19
  <% if @order.line_items.empty? %>
20
20
  <div class="alert alert-warning">
21
- <%= Spree.t(:your_order_is_empty_add_product)%>
21
+ <%= Spree.t(:your_order_is_empty_add_product) %>
22
22
  </div>
23
23
  <% end %>
24
24
 
@@ -23,6 +23,7 @@
23
23
  <div class="col-12 col-md-6 mb-3 mb-md-0">
24
24
  <div class="input-group datePickerFrom"
25
25
  data-wrap="true"
26
+ data-alt-format="<%= Spree.t(:fpr_human_friendly_date_format, scope: 'date_picker', default: 'M j, Y') %>"
26
27
  data-max-date="<%= params[:q][:created_at_lt] %>">
27
28
  <%= f.text_field :created_at_gt,
28
29
  class: 'form-control js-filterable shadow-none',
@@ -36,6 +37,7 @@
36
37
  <div class="col-12 col-md-6 mt-3 mt-md-0">
37
38
  <div class="input-group datePickerTo"
38
39
  data-wrap="true"
40
+ data-alt-format="<%= Spree.t(:fpr_human_friendly_date_format, scope: 'date_picker', default: 'M j, Y') %>"
39
41
  data-min-date="<%= params[:q][:created_at_gt] %>">
40
42
 
41
43
  <%= f.text_field :created_at_lt,
@@ -67,21 +69,21 @@
67
69
  <%= f.select :state_eq,
68
70
  Spree::Order.state_machines[:state].states.map {|s| [Spree.t("order_state.#{s.name}"), s.value]},
69
71
  { include_blank: true },
70
- class: 'select2 js-filterable' %>
72
+ class: 'select2-clear js-filterable' %>
71
73
  </div>
72
74
  </div>
73
75
 
74
76
  <div class="col-12 col-lg-4">
75
77
  <div class="form-group">
76
78
  <%= label_tag :q_payment_state_eq, Spree.t(:payment_state) %>
77
- <%= f.select :payment_state_eq, Spree::Order::PAYMENT_STATES.map {|s| [Spree.t("payment_states.#{s}"), s]}, { include_blank: true }, class: 'select2 js-filterable' %>
79
+ <%= f.select :payment_state_eq, Spree::Order::PAYMENT_STATES.map {|s| [Spree.t("payment_states.#{s}"), s]}, { include_blank: true }, class: 'select2-clear js-filterable' %>
78
80
  </div>
79
81
  </div>
80
82
 
81
83
  <div class="col-12 col-lg-4">
82
84
  <div class="form-group">
83
85
  <%= label_tag :q_shipment_state_eq, Spree.t(:shipment_state) %>
84
- <%= f.select :shipment_state_eq, Spree::Order::SHIPMENT_STATES.map {|s| [Spree.t("shipment_states.#{s}"), s]}, { include_blank: true }, class: 'select2 js-filterable' %>
86
+ <%= f.select :shipment_state_eq, Spree::Order::SHIPMENT_STATES.map {|s| [Spree.t("shipment_states.#{s}"), s]}, { include_blank: true }, class: 'select2-clear js-filterable' %>
85
87
  </div>
86
88
  </div>
87
89
 
@@ -124,21 +126,21 @@
124
126
  <div class="col-12 col-lg-4">
125
127
  <div class="form-group">
126
128
  <%= label_tag :q_promotions_id_in, Spree.t(:promotion) %>
127
- <%= f.select :promotions_id_in, Spree::Promotion.applied.pluck(:name, :id), { include_blank: true }, class: 'select2 js-filterable' %>
129
+ <%= f.select :promotions_id_in, Spree::Promotion.applied.pluck(:name, :id), { include_blank: true }, class: 'select2-clear js-filterable' %>
128
130
  </div>
129
131
  </div>
130
132
 
131
133
  <div class="col-12 col-lg-4">
132
134
  <div class="form-group">
133
135
  <%= label_tag :q_store_id_in, Spree.t(:store) %>
134
- <%= f.select :store_id_in, Spree::Store.order(:name).pluck(:name, :id), { include_blank: true }, class: 'select2 js-filterable' %>
136
+ <%= f.select :store_id_in, Spree::Store.order(:name).pluck(:name, :id), { include_blank: true }, class: 'select2-clear js-filterable' %>
135
137
  </div>
136
138
  </div>
137
139
 
138
140
  <div class="col-12 col-lg-4">
139
141
  <div class="form-group">
140
142
  <%= label_tag :q_channel_eq, Spree.t(:channel) %>
141
- <%= f.select :channel_eq, Spree::Order.distinct.pluck(:channel), { include_blank: true }, class: 'select2 js-filterable' %>
143
+ <%= f.select :channel_eq, Spree::Order.distinct.pluck(:channel), { include_blank: true }, class: 'select2-clear js-filterable' %>
142
144
  </div>
143
145
  </div>
144
146
 
@@ -206,22 +208,21 @@
206
208
  <%= order_time(@show_only_completed ? order.completed_at : order.created_at) %>
207
209
  </td>
208
210
  <td>
209
- <span class="badge badge-<%= order.considered_risky ? 'considered_risky' : 'considered_safe' %>">
211
+ <span class="badge badge-<%= order.considered_risky ? 'considered_risky' : 'considered_safe' %> text-uppercase">
210
212
  <%= order.considered_risky ? Spree.t("risky") : Spree.t("safe") %>
211
213
  </span>
212
214
  </td>
213
215
  <td class="no-wrap">
214
- <span class="badge badge-<%= order.state.downcase %>"><%= Spree.t("order_state.#{order.state.downcase}") %></span>
216
+ <span class="badge badge-<%= order.state.downcase %> text-uppercase"><%= Spree.t("order_state.#{order.state}") %></span>
215
217
  <span class="filterable js-add-filter" data-ransack-field="q_state_eq" data-ransack-value="<%= order.state %>">
216
218
  <%= svg_icon name: "filter.svg", width: '14', height: '14' %>
217
219
  </span>
218
220
  </td>
219
221
  <td class="no-wrap">
220
222
  <% if order.payment_state %>
221
-
222
223
  <%= link_to Spree.t("payment_states.#{order.payment_state}"),
223
224
  admin_order_payments_path(order),
224
- class: "badge badge-#{order.payment_state}" %>
225
+ class: "badge badge-#{order.payment_state} text-uppercase" %>
225
226
 
226
227
  <span class="filterable js-add-filter"
227
228
  data-ransack-field="q_payment_state_eq"
@@ -233,7 +234,7 @@
233
234
  <% if Spree::Order.checkout_step_names.include?(:delivery) %>
234
235
  <td class="no-wrap">
235
236
  <% if order.shipment_state %>
236
- <span class="badge badge-<%= order.shipment_state %>"><%= Spree.t("shipment_states.#{order.shipment_state}") %></span>
237
+ <span class="badge badge-<%= order.shipment_state %> text-uppercase"><%= Spree.t("shipment_states.#{order.shipment_state}") %></span>
237
238
  <span class="filterable js-add-filter" data-ransack-field="q_shipment_state_eq" data-ransack-value="<%= order.shipment_state %>">
238
239
  <%= svg_icon name: "filter.svg", width: '14', height: '14' %>
239
240
  </span>
@@ -2,59 +2,78 @@
2
2
 
3
3
  <div data-hook="payment_method" class="row">
4
4
 
5
- <div class="col-12 col-md-4">
6
- <div id="preference-settings" data-hook class="form-group">
7
- <%= f.label :type, Spree.t(:provider) %>
8
- <%= collection_select(:payment_method, :type, @providers, :to_s, :name, {}, {id: 'gtwy-type', class: 'select2'}) %>
9
-
10
- <% unless @object.new_record? %>
11
- <%= preference_fields(@object, f) %>
12
-
13
- <% if @object.respond_to?(:preferences) %>
14
- <div id="gateway-settings-warning" class="info warning"><%= Spree.t(:provider_settings_warning) %></div>
15
- <% end %>
16
- <% end %>
17
- </div>
18
- <div data-hook="store" class="form-group">
19
- <%= label_tag :payment_method_store, Spree.t(:store) %>
20
- <%= collection_select(:payment_method, :store_id, @stores, :id, :unique_name, { include_blank: true }, {id: 'store_id', class: 'select2'}) %>
21
- </div>
22
- <div data-hook="display" class="form-group">
23
- <%= label_tag :payment_method_display_on, Spree.t(:display) %>
24
- <%= select(:payment_method, :display_on, Spree::PaymentMethod::DISPLAY.collect { |display| [Spree.t(display), display.to_s] }, {}, {class: 'select2'}) %>
25
- </div>
26
- <div data-hook="auto_capture" class="form-group">
27
- <%= label_tag :payment_method_auto_capture, Spree.t(:auto_capture) %>
28
- <%= select(:payment_method, :auto_capture, [["#{Spree.t(:use_app_default)} (#{Spree::Config[:auto_capture]})", ''], [Spree.t(:say_yes), true], [Spree.t(:say_no), false]], {}, {class: 'select2'}) %>
29
- </div>
30
- <div data-hook="active" class="form-group">
31
- <strong><%= Spree.t(:active) %></strong>
32
- <div class="radio my-2">
33
- <%= label_tag :payment_method_active_true do %>
34
- <%= radio_button :payment_method, :active, true %>
35
- <%= Spree.t(:say_yes) %>
36
- <% end %>
5
+ <div class="col-12 col-md-6">
6
+ <div class="card mb-3">
7
+ <div class="card-header">
8
+ <h5 class="mb-0"><%= Spree.t(:settings) %></h5>
37
9
  </div>
10
+ <div class="card-body">
11
+ <div class="form-group">
12
+ <%= f.label :type, Spree.t(:provider) %>
13
+ <%= collection_select(:payment_method, :type, @providers, :to_s, :name, {}, {id: 'gtwy-type', class: 'select2'}) %>
14
+ </div>
15
+ <hr class="my-4">
16
+ <%= field_container :payment_method, :name, class: ['form-group'], 'data-hook' => 'name' do %>
17
+ <%= label_tag :payment_method_name, Spree.t(:name) %>
18
+ <%= text_field :payment_method, :name, class: 'form-control' %>
19
+ <%= error_message_on :payment_method, :name %>
20
+ <% end %>
38
21
 
39
- <div class="radio my-2">
40
- <%= label_tag :payment_method_active_false do %>
41
- <%= radio_button :payment_method, :active, false %>
42
- <%= Spree.t(:say_no) %>
22
+ <%= field_container :payment_method, :description, class: ['form-group'], 'data-hook' => 'description' do %>
23
+ <%= label_tag :payment_method_description, Spree.t(:description) %>
24
+ <%= text_area :payment_method, :description, { cols: 60, rows: 6, class: 'form-control' } %>
43
25
  <% end %>
26
+
27
+ <div data-hook="store" class="form-group">
28
+ <%= label_tag :payment_method_stores, Spree.t(:stores) %>
29
+ <%= collection_select(:payment_method, :store_ids, @stores, :id, :unique_name, {}, { multiple: true, class: 'select2' }) %>
30
+ </div>
31
+
32
+ <div data-hook="display" class="form-group">
33
+ <%= label_tag :payment_method_display_on, Spree.t(:display) %>
34
+ <%= select(:payment_method, :display_on, Spree::PaymentMethod::DISPLAY.collect { |display| [Spree.t(display), display.to_s] }, {}, {class: 'select2'}) %>
35
+ </div>
36
+ <div data-hook="auto_capture" class="form-group">
37
+ <%= label_tag :payment_method_auto_capture, Spree.t(:auto_capture) %>
38
+ <%= select(:payment_method, :auto_capture, [["#{Spree.t(:use_app_default)} (#{Spree::Config[:auto_capture]})", ''], [Spree.t(:say_yes), true], [Spree.t(:say_no), false]], {}, {class: 'select2'}) %>
39
+ </div>
40
+
41
+ <div data-hook="active" class="form-group">
42
+ <strong><%= Spree.t(:active) %></strong>
43
+ <div class="radio my-2 form-check">
44
+ <%= radio_button :payment_method, :active, true, class: 'form-check-input' %>
45
+ <%= label_tag :payment_method_active_true, Spree.t(:say_yes), class: 'form-check-label' %>
46
+ </div>
47
+
48
+ <div class="radio my-2 form-check">
49
+ <%= radio_button :payment_method, :active, false, class: 'form-check-input' %>
50
+ <%= label_tag :payment_method_active_false, Spree.t(:say_no), class: 'form-check-label' %>
51
+ </div>
52
+ </div>
44
53
  </div>
45
54
  </div>
46
55
  </div>
47
56
 
48
- <div class="col-12 col-md-8">
49
- <%= field_container :payment_method, :name, class: ['form-group'], 'data-hook' => 'name' do %>
50
- <%= label_tag :payment_method_name, Spree.t(:name) %>
51
- <%= text_field :payment_method, :name, class: 'form-control' %>
52
- <%= error_message_on :payment_method, :name %>
53
- <% end %>
54
- <%= field_container :payment_method, :description, class: ['form-group'], 'data-hook' => 'description' do %>
55
- <%= label_tag :payment_method_description, Spree.t(:description) %>
56
- <%= text_area :payment_method, :description, { cols: 60, rows: 6, class: 'form-control' } %>
57
- <% end %>
57
+ <div class="col-12 col-md-6">
58
+ <div class="card mb-3">
59
+ <div class="card-header">
60
+ <h5 class="mb-0"><%= Spree.t(:payment_provider_settings) %></h5>
61
+ </div>
62
+ <div class="card-body">
63
+ <div id="preference-settings" data-hook class="form-group">
64
+ <% unless @object.new_record? %>
65
+ <% if preference_fields(@object, f).empty? %>
66
+ <%= Spree.t('no_payment_provider_settings_message') %>
67
+ <% end %>
68
+ <%= preference_fields(@object, f) %>
69
+
70
+ <% if @object.respond_to?(:preferences) %>
71
+ <div id="gateway-settings-warning" class="info warning"><%= Spree.t(:provider_settings_warning) %></div>
72
+ <% end %>
73
+ <% end %>
74
+ </div>
75
+ </div>
76
+ </div>
58
77
  </div>
59
78
  </div>
60
79
  </div>
@@ -20,7 +20,7 @@
20
20
  </tr>
21
21
  </thead>
22
22
  <tbody id="sortVert">
23
- <% @payment_methods.each do |method|%>
23
+ <% @payment_methods.each do |method| %>
24
24
  <tr id="<%= spree_dom_id method %>" data-hook="admin_payment_methods_index_rows">
25
25
  <td class="move-handle text-center">
26
26
  <% if can?(:edit, method) %>
@@ -30,7 +30,7 @@
30
30
  <td><%= method.name %></td>
31
31
  <td><%= method.type.split('::', 3).last %></td>
32
32
  <td class="text-center"><%= Spree.t(method.display_on) %></td>
33
- <td class="text-center"><%= method.active ? Spree.t(:say_yes) : Spree.t(:say_no) %></td>
33
+ <td class="text-center"><%= active_badge(method.active) %></td>
34
34
  <td data-hook="admin_payment_methods_index_row_actions" class="actions actions-2 text-right">
35
35
  <%= link_to_edit(method, no_text: true) if can? :edit, method %>
36
36
  <%= link_to_delete(method, no_text: true) if can? :delete, method %>
@@ -19,12 +19,11 @@
19
19
 
20
20
  <div class="payment-methods my-3" id="payment_method_<%= method.id %>">
21
21
  <% if method.source_required? %>
22
- <%=render partial: "spree/admin/payments/source_forms/#{method.method_type}",
22
+ <%= render partial: "spree/admin/payments/source_forms/#{method.method_type}",
23
23
  locals: {
24
24
  payment_method: method,
25
25
  previous_cards: method.reusable_sources(@order)
26
- }
27
- %>
26
+ } %>
28
27
  <% end %>
29
28
  </div>
30
29
  <% end %>
@@ -18,8 +18,7 @@
18
18
  <%= render partial: "spree/admin/payments/source_views/#{@payment.payment_method.method_type}",
19
19
  locals: {
20
20
  payment: @payment.source.is_a?(Spree::Payment) ? @payment.source : @payment
21
- }
22
- %>
21
+ } %>
23
22
 
24
23
  <div class="alert alert-success" data-hook="amount">
25
24
  <%= Spree.t(:amount) %>: <%= @payment.display_amount.to_html %>
@@ -6,11 +6,10 @@
6
6
  </div>
7
7
  <div class="form-group previous_cards card-body mb-0" data-hook="previous_cards">
8
8
  <ul class="m-0 p-0">
9
-
10
9
  <% previous_cards.each do |card| %>
11
10
  <li>
12
11
  <label>
13
- <%= radio_button_tag :card, card.id, card == previous_cards.first %> <%= card.brand.upcase + ' - ' + card.display_number %>
12
+ <%= radio_button_tag :card, card.id, card == previous_cards.first %> <%= card.display_brand + ' - ' + card.display_number %>
14
13
  </label>
15
14
  </li>
16
15
  <% end %>
@@ -24,7 +23,7 @@
24
23
  </div>
25
24
  </div>
26
25
  <% end %>
27
- <div id="card_form<%= payment_method.id %>" class="margint row" data-hook>
26
+ <div id="card_form<%= payment_method.id %>" class="mt-3 row" data-hook>
28
27
  <% param_prefix = "payment_source[#{payment_method.id}]" %>
29
28
 
30
29
  <div data-hook="card_number" class="form-group col-12">
@@ -32,7 +31,7 @@
32
31
  <%= label_tag "card_number#{payment_method.id}", raw(Spree.t(:card_number) + required_span_tag) %>
33
32
  <%= text_field_tag "#{param_prefix}[number]", '', class: 'required form-control cardNumber', id: "card_number#{payment_method.id}", maxlength: 19 %>
34
33
  <span id="card_type" style="display:none;">
35
- ( <span id="looks_like" ><%= Spree.t(:card_type_is) %> <span id="type"></span></span>
34
+ ( <span id="looks_like"><%= Spree.t(:card_type_is) %> <span id="type"></span></span>
36
35
  <span id="unrecognized"><%= Spree.t(:unrecognized_card_type) %></span>
37
36
  )
38
37
  </span>