spree_admin 5.0.0.rc1 → 5.0.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (161) hide show
  1. checksums.yaml +4 -4
  2. data/app/assets/stylesheets/spree/admin/components/_bulk_panel.scss +11 -1
  3. data/app/assets/stylesheets/spree/admin/components/_cards.scss +3 -4
  4. data/app/assets/stylesheets/spree/admin/components/_dropdowns.scss +1 -1
  5. data/app/assets/stylesheets/spree/admin/components/_main.scss +22 -5
  6. data/app/assets/stylesheets/spree/admin/components/_modals.scss +1 -1
  7. data/app/assets/stylesheets/spree/admin/global/_variables.scss +8 -2
  8. data/app/assets/stylesheets/spree/admin/shared/_base.scss +12 -1
  9. data/app/controllers/spree/admin/dashboard_controller.rb +4 -1
  10. data/app/controllers/spree/admin/products_controller.rb +1 -8
  11. data/app/controllers/spree/admin/storefront_controller.rb +1 -1
  12. data/app/controllers/spree/admin/translations_controller.rb +1 -1
  13. data/app/helpers/spree/admin/base_helper.rb +69 -63
  14. data/app/helpers/spree/admin/bulk_operations_helper.rb +86 -0
  15. data/app/helpers/spree/admin/modal_helper.rb +29 -0
  16. data/app/helpers/spree/admin/navigation_helper.rb +89 -11
  17. data/app/helpers/spree/admin/orders_helper.rb +0 -19
  18. data/app/helpers/spree/admin/stores_helper.rb +8 -36
  19. data/app/helpers/spree/admin/webhooks_subscribers_helper.rb +1 -1
  20. data/app/javascript/spree/admin/controllers/variants_form_controller.js +10 -3
  21. data/app/views/active_storage/_upload_form.html.erb +4 -8
  22. data/app/views/layouts/spree/admin.html.erb +4 -0
  23. data/app/views/spree/admin/assets/edit.html.erb +3 -8
  24. data/app/views/spree/admin/coupon_codes/index.html.erb +4 -6
  25. data/app/views/spree/admin/custom_domains/_custom_domains.html.erb +1 -1
  26. data/app/views/spree/admin/custom_domains/index.html.erb +1 -1
  27. data/app/views/spree/admin/customer_returns/index.html.erb +4 -17
  28. data/app/views/spree/admin/dashboard/_setup_progress.html.erb +4 -2
  29. data/app/views/spree/admin/dashboard/_sidebar.html.erb +2 -0
  30. data/app/views/spree/admin/dashboard/_top_products.html.erb +34 -24
  31. data/app/views/spree/admin/dashboard/analytics.html.erb +3 -1
  32. data/app/views/spree/admin/dashboard/show.html.erb +4 -8
  33. data/app/views/spree/admin/digital_assets/_table.html.erb +1 -1
  34. data/app/views/spree/admin/digital_assets/edit.html.erb +3 -11
  35. data/app/views/spree/admin/digital_assets/new.html.erb +3 -11
  36. data/app/views/spree/admin/exports/index.html.erb +22 -24
  37. data/app/views/spree/admin/exports/new.html.erb +3 -9
  38. data/app/views/spree/admin/line_items/new.html.erb +2 -5
  39. data/app/views/spree/admin/oauth_applications/index.html.erb +57 -58
  40. data/app/views/spree/admin/option_types/_filter.html.erb +1 -1
  41. data/app/views/spree/admin/option_types/index.html.erb +7 -11
  42. data/app/views/spree/admin/orders/_customer_summary.html.erb +0 -2
  43. data/app/views/spree/admin/orders/_filters.html.erb +3 -8
  44. data/app/views/spree/admin/orders/_header.html.erb +2 -0
  45. data/app/views/spree/admin/orders/_list.html.erb +2 -4
  46. data/app/views/spree/admin/orders/_summary.html.erb +1 -1
  47. data/app/views/spree/admin/orders/billing_address/create.turbo_stream.erb +3 -6
  48. data/app/views/spree/admin/orders/billing_address/edit.html.erb +3 -6
  49. data/app/views/spree/admin/orders/billing_address/new.html.erb +3 -6
  50. data/app/views/spree/admin/orders/billing_address/update.turbo_stream.erb +3 -6
  51. data/app/views/spree/admin/orders/contact_information/edit.html.erb +3 -6
  52. data/app/views/spree/admin/orders/customer_returns/edit.html.erb +1 -10
  53. data/app/views/spree/admin/orders/edit.html.erb +3 -5
  54. data/app/views/spree/admin/orders/index.html.erb +1 -1
  55. data/app/views/spree/admin/orders/return_authorizations/_form.html.erb +1 -1
  56. data/app/views/spree/admin/orders/return_authorizations/show.html.erb +45 -43
  57. data/app/views/spree/admin/orders/shipping_address/create.turbo_stream.erb +3 -6
  58. data/app/views/spree/admin/orders/shipping_address/edit.html.erb +3 -6
  59. data/app/views/spree/admin/orders/shipping_address/new.html.erb +3 -6
  60. data/app/views/spree/admin/orders/shipping_address/update.turbo_stream.erb +3 -6
  61. data/app/views/spree/admin/pages/_filters.html.erb +1 -1
  62. data/app/views/spree/admin/pages/edit.html.erb +2 -5
  63. data/app/views/spree/admin/pages/index.html.erb +4 -4
  64. data/app/views/spree/admin/payment_methods/index.html.erb +10 -8
  65. data/app/views/spree/admin/post_categories/index.html.erb +4 -6
  66. data/app/views/spree/admin/posts/_filters.html.erb +2 -7
  67. data/app/views/spree/admin/posts/_post.html.erb +1 -11
  68. data/app/views/spree/admin/posts/index.html.erb +5 -9
  69. data/app/views/spree/admin/products/_bulk_operations.html.erb +59 -94
  70. data/app/views/spree/admin/products/_filters.html.erb +13 -8
  71. data/app/views/spree/admin/products/_form.html.erb +3 -3
  72. data/app/views/spree/admin/products/_list.html.erb +2 -10
  73. data/app/views/spree/admin/products/_product.html.erb +1 -4
  74. data/app/views/spree/admin/products/bulk_modal.html.erb +3 -8
  75. data/app/views/spree/admin/products/edit.html.erb +3 -0
  76. data/app/views/spree/admin/products/form/_variants.html.erb +1 -0
  77. data/app/views/spree/admin/products/index.html.erb +5 -5
  78. data/app/views/spree/admin/promotion_actions/new.html.erb +7 -12
  79. data/app/views/spree/admin/promotion_rules/new.html.erb +7 -12
  80. data/app/views/spree/admin/promotions/_filters.html.erb +27 -0
  81. data/app/views/spree/admin/promotions/index.html.erb +7 -35
  82. data/app/views/spree/admin/properties/index.html.erb +10 -9
  83. data/app/views/spree/admin/refund_reasons/index.html.erb +37 -35
  84. data/app/views/spree/admin/refunds/edit.html.erb +3 -8
  85. data/app/views/spree/admin/reimbursement_types/index.html.erb +42 -40
  86. data/app/views/spree/admin/reports/_report.html.erb +1 -1
  87. data/app/views/spree/admin/return_authorization_reasons/index.html.erb +41 -41
  88. data/app/views/spree/admin/return_authorizations/_filters.html.erb +1 -1
  89. data/app/views/spree/admin/return_authorizations/_list.html.erb +1 -10
  90. data/app/views/spree/admin/return_authorizations/index.html.erb +1 -1
  91. data/app/views/spree/admin/roles/_form.html.erb +1 -1
  92. data/app/views/spree/admin/roles/index.html.erb +26 -24
  93. data/app/views/spree/admin/shared/_bulk_modal.html.erb +6 -7
  94. data/app/views/spree/admin/shared/_developers_nav.html.erb +2 -2
  95. data/app/views/spree/admin/shared/_filter_submit.html.erb +6 -0
  96. data/app/views/spree/admin/shared/_head.html.erb +3 -1
  97. data/app/views/spree/admin/shared/_modal.html.erb +2 -8
  98. data/app/views/spree/admin/shared/_multi_product_picker.html.erb +2 -4
  99. data/app/views/spree/admin/shared/_no_resource_found.html.erb +1 -1
  100. data/app/views/spree/admin/shared/_posts_tabs.html.erb +2 -2
  101. data/app/views/spree/admin/shared/_product_image.html.erb +1 -10
  102. data/app/views/spree/admin/shared/_refunds.html.erb +1 -1
  103. data/app/views/spree/admin/shared/_returns_and_refunds_nav.html.erb +3 -3
  104. data/app/views/spree/admin/shared/_shipping_nav.html.erb +2 -2
  105. data/app/views/spree/admin/shared/_stock_nav.html.erb +2 -2
  106. data/app/views/spree/admin/shared/_tax_nav.html.erb +2 -2
  107. data/app/views/spree/admin/shared/_user.html.erb +2 -2
  108. data/app/views/spree/admin/shared/_user_dropdown.html.erb +2 -2
  109. data/app/views/spree/admin/shared/sidebar/_orders_nav.html.erb +19 -29
  110. data/app/views/spree/admin/shared/sidebar/_products_nav.html.erb +6 -25
  111. data/app/views/spree/admin/shared/sidebar/_returns_nav.html.erb +8 -15
  112. data/app/views/spree/admin/shared/sidebar/_store_dropdown.html.erb +36 -7
  113. data/app/views/spree/admin/shared/sidebar/_store_nav.html.erb +28 -52
  114. data/app/views/spree/admin/shared/sidebar/_storefront_nav.html.erb +19 -26
  115. data/app/views/spree/admin/shared/sortable_tree/_taxonomy.html.erb +3 -23
  116. data/app/views/spree/admin/shipping_categories/index.html.erb +28 -26
  117. data/app/views/spree/admin/shipping_methods/_actions.html.erb +1 -1
  118. data/app/views/spree/admin/shipping_methods/index.html.erb +23 -21
  119. data/app/views/spree/admin/stock_items/_filters.html.erb +2 -7
  120. data/app/views/spree/admin/stock_items/index.html.erb +5 -8
  121. data/app/views/spree/admin/stock_locations/_stock_location.html.erb +16 -13
  122. data/app/views/spree/admin/stock_locations/index.html.erb +24 -21
  123. data/app/views/spree/admin/stock_transfers/_filters.html.erb +1 -1
  124. data/app/views/spree/admin/stock_transfers/_new_variant_modal.html.erb +3 -5
  125. data/app/views/spree/admin/stock_transfers/index.html.erb +6 -6
  126. data/app/views/spree/admin/store_credit_categories/_form.html.erb +1 -1
  127. data/app/views/spree/admin/store_credit_categories/edit.html.erb +6 -4
  128. data/app/views/spree/admin/store_credit_categories/index.html.erb +28 -24
  129. data/app/views/spree/admin/store_credits/index.html.erb +2 -2
  130. data/app/views/spree/admin/storefront/edit.html.erb +7 -9
  131. data/app/views/spree/admin/stores/form/_basic.html.erb +2 -2
  132. data/app/views/spree/admin/stores/form/_policies.html.erb +1 -1
  133. data/app/views/spree/admin/stores/new.html.erb +8 -6
  134. data/app/views/spree/admin/tax_categories/index.html.erb +24 -22
  135. data/app/views/spree/admin/tax_rates/index.html.erb +26 -24
  136. data/app/views/spree/admin/taxonomies/index.html.erb +4 -4
  137. data/app/views/spree/admin/taxonomies/show.html.erb +2 -2
  138. data/app/views/spree/admin/themes/_theme_preview_image.html.erb +1 -10
  139. data/app/views/spree/admin/themes/index.html.erb +2 -2
  140. data/app/views/spree/admin/translations/_translations_unavailable.html.erb +6 -8
  141. data/app/views/spree/admin/users/_filters.html.erb +2 -7
  142. data/app/views/spree/admin/users/_tabs.html.erb +4 -4
  143. data/app/views/spree/admin/users/_user.html.erb +1 -4
  144. data/app/views/spree/admin/users/bulk_modal.html.erb +3 -8
  145. data/app/views/spree/admin/users/index.html.erb +25 -58
  146. data/app/views/spree/admin/variants/_variant.html.erb +8 -2
  147. data/app/views/spree/admin/variants/form/_media_asset.html.erb +1 -7
  148. data/app/views/spree/admin/variants/form/_pricing.html.erb +5 -4
  149. data/app/views/spree/admin/webhooks_subscribers/_form.html.erb +1 -1
  150. data/app/views/spree/admin/webhooks_subscribers/index.html.erb +25 -22
  151. data/app/views/spree/admin/webhooks_subscribers/show.html.erb +3 -3
  152. data/app/views/spree/admin/zones/index.html.erb +34 -32
  153. data/config/locales/en.yml +1 -46
  154. data/lib/spree/admin/engine.rb +50 -0
  155. metadata +13 -14
  156. data/app/views/spree/admin/orders/_extra_filters.html.erb +0 -0
  157. data/app/views/spree/admin/products/_empty_list.html.erb +0 -1
  158. data/app/views/spree/admin/products/form/_extra_filters.html.erb +0 -0
  159. data/app/views/spree/admin/products/form/_extra_form.html.erb +0 -0
  160. data/app/views/spree/admin/products/form/_extra_form_sidebar.erb +0 -0
  161. data/app/views/spree/admin/stores/form/_custom.html.erb +0 -0
@@ -3,28 +3,30 @@
3
3
  <% end %>
4
4
 
5
5
  <% content_for :page_actions do %>
6
- <%= button_link_to Spree.t(:new_tax_category), new_object_url, class: "btn-primary", icon: 'plus', id: 'admin_new_tax_categories_link' %>
6
+ <%= link_to_with_icon 'plus', Spree.t(:new_tax_category), new_object_url, class: "btn btn-primary" %>
7
7
  <% end if can? :create, Spree::TaxCategory %>
8
8
 
9
- <%= render partial: 'spree/admin/shared/tax_nav' %>
9
+ <%= render 'spree/admin/shared/tax_nav' %>
10
10
 
11
- <% if @tax_categories.any? %>
12
- <div class="table-responsive card-lg p-0">
13
- <table class="table" id='listing_tax_categories'>
14
- <thead class="text-muted">
15
- <tr>
16
- <th><%= Spree.t(:name) %></th>
17
- <th><%= Spree.t(:tax_code) %></th>
18
- <th><%= Spree.t(:description) %></th>
19
- <th><%= Spree.t(:default) %></th>
20
- <th></th>
21
- </tr>
22
- </thead>
23
- <tbody>
24
- <%= render collection: @tax_categories, partial: 'spree/admin/tax_categories/tax_category', cached: spree_base_cache_scope %>
25
- </tbody>
26
- </table>
27
- </div>
28
- <% else %>
29
- <%= render 'spree/admin/shared/no_resource_found' %>
30
- <% end %>
11
+ <div class="card-lg">
12
+ <% if @collection.any? %>
13
+ <div class="table-responsive">
14
+ <table class="table">
15
+ <thead class="text-muted">
16
+ <tr>
17
+ <th><%= Spree.t(:name) %></th>
18
+ <th><%= Spree.t(:tax_code) %></th>
19
+ <th><%= Spree.t(:description) %></th>
20
+ <th><%= Spree.t(:default) %></th>
21
+ <th></th>
22
+ </tr>
23
+ </thead>
24
+ <tbody>
25
+ <%= render collection: @collection, partial: 'spree/admin/tax_categories/tax_category', cached: spree_base_cache_scope %>
26
+ </tbody>
27
+ </table>
28
+ </div>
29
+ <% else %>
30
+ <%= render 'spree/admin/shared/no_resource_found' %>
31
+ <% end %>
32
+ </div>
@@ -3,30 +3,32 @@
3
3
  <% end %>
4
4
 
5
5
  <% content_for :page_actions do %>
6
- <%= button_link_to Spree.t(:new_tax_rate), new_object_url, class: "btn-primary", icon: 'plus' %>
6
+ <%= link_to_with_icon 'plus', Spree.t(:new_tax_rate), new_object_url, class: "btn btn-primary" %>
7
7
  <% end if can? :create, Spree::TaxRate %>
8
8
 
9
- <%= render partial: 'spree/admin/shared/tax_nav' %>
9
+ <%= render 'spree/admin/shared/tax_nav' %>
10
10
 
11
- <% if @tax_rates.any? %>
12
- <div class="table-responsive card-lg p-0">
13
- <table class="table" id='listing_tax_rates'>
14
- <thead class="text-muted">
15
- <tr data-hook="rate_header">
16
- <th><%= Spree.t(:name) %></th>
17
- <th><%= Spree.t(:tax_category) %></th>
18
- <th><%= Spree.t(:zone) %></th>
19
- <th><%= Spree.t(:amount) %></th>
20
- <th><%= Spree.t(:included_in_price) %></th>
21
- <th><%= Spree.t(:show_rate_in_label) %></th>
22
- <th></th>
23
- </tr>
24
- </thead>
25
- <tbody>
26
- <%= render partial: 'spree/admin/tax_rates/tax_rate', collection: @tax_rates, cached: spree_base_cache_scope %>
27
- </tbody>
28
- </table>
29
- </div>
30
- <% else %>
31
- <%= render 'spree/admin/shared/no_resource_found' %>
32
- <% end %>
11
+ <div class="card-lg">
12
+ <% if @collection.any? %>
13
+ <div class="table-responsive">
14
+ <table class="table">
15
+ <thead class="text-muted">
16
+ <tr data-hook="rate_header">
17
+ <th><%= Spree.t(:name) %></th>
18
+ <th><%= Spree.t(:tax_category) %></th>
19
+ <th><%= Spree.t(:zone) %></th>
20
+ <th><%= Spree.t(:amount) %></th>
21
+ <th><%= Spree.t(:included_in_price) %></th>
22
+ <th><%= Spree.t(:show_rate_in_label) %></th>
23
+ <th></th>
24
+ </tr>
25
+ </thead>
26
+ <tbody>
27
+ <%= render partial: 'spree/admin/tax_rates/tax_rate', collection: @collection, cached: spree_base_cache_scope %>
28
+ </tbody>
29
+ </table>
30
+ </div>
31
+ <% else %>
32
+ <%= render 'spree/admin/shared/no_resource_found' %>
33
+ <% end %>
34
+ </div>
@@ -3,11 +3,11 @@
3
3
  <% end %>
4
4
 
5
5
  <% content_for :page_actions do %>
6
- <%= button_link_to Spree.t(:new_taxonomy), new_object_url, { class: "btn-primary", icon: "plus" } %>
6
+ <%= link_to_with_icon 'plus', Spree.t(:new_taxonomy), new_object_url, class: "btn btn-primary" %>
7
7
  <% end if can?(:create, Spree::Taxonomy) %>
8
8
 
9
- <div class="card-lg p-0">
10
- <%= search_form_for [:admin, @search], class: "filter-wrap border-bottom", data: {controller: "filters reveal", reveal_hidden_class: "d-none"} do |f| %>
9
+ <div class="card-lg">
10
+ <%= search_form_for [:admin, @search], class: "filter-wrap", data: {controller: "filters reveal", reveal_hidden_class: "d-none"} do |f| %>
11
11
  <%= render 'spree/admin/shared/filters_search_bar', param: :name_cont, label: Spree.t(:name) %>
12
12
 
13
13
  <%= render "spree/admin/shared/filter_badge_template" %>
@@ -22,7 +22,7 @@
22
22
  <th class="no-border handel-head"></th>
23
23
  <th><%= Spree.t(:name) %></th>
24
24
  <th><%= Spree.t(:taxons) %></th>
25
- <th class="actions"></th>
25
+ <th></th>
26
26
  </tr>
27
27
  </thead>
28
28
  <tbody
@@ -4,8 +4,8 @@
4
4
  <% end %>
5
5
 
6
6
  <% content_for :page_actions do %>
7
- <%= button_link_to Spree.t(:new_taxon), spree.new_admin_taxonomy_taxon_path(@taxonomy), icon: 'plus', class: 'no-wrap btn btn-primary align-self-center' %>
8
- <% end %>
7
+ <%= link_to_with_icon 'plus', Spree.t(:new_taxon), spree.new_admin_taxonomy_taxon_path(@taxonomy), class: 'btn btn-primary' %>
8
+ <% end if can?(:create, Spree::Taxon) %>
9
9
 
10
10
  <% content_for :page_actions_dropdown do %>
11
11
  <%= link_to_edit(@taxonomy.root, url: spree.edit_admin_taxonomy_taxon_path(@taxonomy, @taxonomy.root.id), class: 'text-left dropdown-item') %>
@@ -2,16 +2,7 @@
2
2
  <% height ||= 72 %>
3
3
 
4
4
  <% if theme.screenshot.attached? && theme.screenshot.variable? %>
5
- <%= image_tag(
6
- main_app.cdn_image_url(
7
- theme.screenshot.variant(
8
- spree_image_variant_options(resize_to_fill: [width * 2, height * 2])
9
- )
10
- ),
11
- class: 'img-thumbnail',
12
- style: "width: #{width}px; height: #{height}px",
13
- loading: :lazy
14
- ) %>
5
+ <%= spree_image_tag(theme.screenshot, width: width, height: height, class: 'img-thumbnail', style: "width: #{width}px; height: #{height}px", loading: :lazy) %>
15
6
  <% elsif theme.class.preview_image_url.present? %>
16
7
  <%= image_tag(
17
8
  theme.class.preview_image_url,
@@ -26,7 +26,7 @@
26
26
  <% end %>
27
27
  <% end %>
28
28
 
29
- <div class="card-lg p-0">
29
+ <div class="card-lg">
30
30
  <div class="table-responsive rounded-lg">
31
31
  <table class="table">
32
32
  <thead class="text-muted">
@@ -44,7 +44,7 @@
44
44
  </div>
45
45
 
46
46
  <% if available_themes.any? %>
47
- <div class="card-lg p-0">
47
+ <div class="card-lg">
48
48
  <div class="card-header">
49
49
  <h5 class="card-title">Add a new theme</h5>
50
50
  </div>
@@ -1,10 +1,8 @@
1
- <div class="container">
2
- <div class="card">
3
- <div class="card-body">
4
- <p>To use translations, configure more than one locale for the store.</p>
5
- <% if can?(:edit, current_store) %>
6
- <%= button_link_to('Configure store', spree.edit_admin_store_path(current_store)) %>
7
- <% end %>
8
- </div>
1
+ <div class="card">
2
+ <div class="card-body">
3
+ <p>To use translations, configure more than one locale for the store.</p>
4
+ <% if can?(:edit, current_store) %>
5
+ <%= link_to_with_icon 'settings', 'Configure store', spree.edit_admin_store_path(section: 'general-settings'), class: 'btn btn-light' %>
6
+ <% end %>
9
7
  </div>
10
8
  </div>
@@ -1,4 +1,4 @@
1
- <%= search_form_for [:admin, @search], url: spree.admin_users_url, class: "filter-wrap border-bottom", data: {controller: "filters reveal", reveal_hidden_class: "d-none"} do |f| %>
1
+ <%= search_form_for [:admin, @search], url: spree.admin_users_url, class: "filter-wrap", data: {controller: "filters reveal", reveal_hidden_class: "d-none"} do |f| %>
2
2
  <div class="d-flex flex-column flex-lg-row gap-2">
3
3
  <%= render 'spree/admin/shared/filters_search_bar', param: :multi_search, placeholder: Spree.t('admin.users.filters.search_placeholder') %>
4
4
 
@@ -71,12 +71,7 @@
71
71
  </div>
72
72
  </div>
73
73
  </div>
74
- <div class="form-actions">
75
- <%= turbo_save_button_tag Spree.t(:filter_results) do %>
76
- <%= icon("search") %>
77
- <%= Spree.t(:filter_results) %>
78
- <% end %>
79
- </div>
74
+ <%= render 'spree/admin/shared/filter_submit' %>
80
75
  </div>
81
76
 
82
77
  <%= render "spree/admin/shared/filter_badge_template" %>
@@ -36,7 +36,7 @@
36
36
 
37
37
  <% if can?(:read, Spree::Order) %>
38
38
  <div class="tab-pane fade <%= 'show active' unless spree.respond_to?(:admin_user_visits_path) %>" id="pills-orders2" role="tabpanel" aria-labelledby="pills-orders2">
39
- <div class="card-lg p-0">
39
+ <div class="card-lg">
40
40
  <%= turbo_frame_tag :orders_list, src: spree.admin_user_orders_path(@user, frame_name: :orders_list), loading: :lazy, autoscroll: true, data: { autoscroll_block: :nearest, autoscroll_behavior: :smooth } do %>
41
41
  <%= render 'spree/admin/shared/spinner' %>
42
42
  <% end %>
@@ -44,7 +44,7 @@
44
44
  </div>
45
45
 
46
46
  <div class="tab-pane fade" id="pills-checkouts" role="tabpanel" aria-labelledby="pills-checkouts">
47
- <div class="card-lg p-0">
47
+ <div class="card-lg">
48
48
  <%= turbo_frame_tag :orders_list, src: spree.admin_user_checkouts_path(@user, frame_name: :orders_list), loading: :lazy, autoscroll: true, data: { autoscroll_block: :nearest, autoscroll_behavior: :smooth } do %>
49
49
  <%= render 'spree/admin/shared/spinner' %>
50
50
  <% end %>
@@ -54,7 +54,7 @@
54
54
 
55
55
  <% if spree.respond_to?(:admin_user_gift_cards_path) && can?(:read, Spree::GiftCard) %>
56
56
  <div class="tab-pane fade" id="pills-gift-cards" role="tabpanel" aria-labelledby="pills-gift-cards">
57
- <div class="card-lg p-0">
57
+ <div class="card-lg">
58
58
  <%= turbo_frame_tag :gift_cards_list, src: spree.admin_user_gift_cards_path(@user, frame_name: :gift_cards_list), loading: :lazy, autoscroll: true, data: { autoscroll_block: :nearest, autoscroll_behavior: :smooth } do %>
59
59
  <%= render 'spree/admin/shared/spinner' %>
60
60
  <% end %>
@@ -64,7 +64,7 @@
64
64
 
65
65
  <% if can?(:read, Spree::StoreCredit) %>
66
66
  <div class="tab-pane fade" id="pills-store-credits" role="tabpanel" aria-labelledby="pills-store-credits">
67
- <div class="card-lg p-0">
67
+ <div class="card-lg">
68
68
  <%= turbo_frame_tag :store_credits_list, src: spree.admin_user_store_credits_path(@user, frame_name: :store_credits_list), loading: :lazy, autoscroll: true, data: { autoscroll_block: :nearest, autoscroll_behavior: :smooth } do %>
69
69
  <%= render 'spree/admin/shared/spinner' %>
70
70
  <% end %>
@@ -1,9 +1,6 @@
1
1
  <tr id="<%= spree_dom_id user %>">
2
2
  <td class="pr-0 w-5">
3
- <div class="custom-control custom-checkbox ml-1">
4
- <%= check_box_tag "ids[]", user.id, false, class: "custom-control-input", id: "ids_#{user.id}", data: { bulk_operation_target: "checkbox" } %>
5
- <label class="custom-control-label" for="ids_<%= user.id %>"><span></span></label>
6
- </div>
3
+ <%= bulk_operations_checkbox(user) %>
7
4
  </td>
8
5
  <td class='user_name w-50 no-wrap py-0 pl-1 pr-0'>
9
6
  <%= render 'spree/admin/shared/user', user: user %>
@@ -1,11 +1,6 @@
1
1
  <%= turbo_frame_tag :bulk_modal do %>
2
2
  <div class="modal-content">
3
- <div class="modal-header">
4
- <h5 class="modal-title" id="exampleModalLabel">
5
- <%= @title %>
6
- </h5>
7
- <button type="button" class="btn-close" data-dismiss="modal" aria-label="<%= Spree.t(:close) %>" />
8
- </div>
3
+ <%= modal_header(@title) %>
9
4
  <div class="modal-body">
10
5
  <p><%= @body %></p>
11
6
 
@@ -13,8 +8,8 @@
13
8
  <%= tom_select_tag 'tags', multiple: true, class: 'w-100', options: user_tags_json_array, required: true, value_field: :name, create: params[:kind] == 'add_tags' %>
14
9
  <% end %>
15
10
  </div>
16
- <div class="modal-footer d-flex justify-content-between">
17
- <button type="button" class="btn btn-light" data-dismiss="modal"><%= Spree.t('actions.discard') %></button>
11
+ <div class="modal-footer">
12
+ <%= modal_discard_button %>
18
13
  <%= turbo_save_button_tag %>
19
14
  </div>
20
15
  </div>
@@ -7,61 +7,37 @@
7
7
  <%= icon 'table-export', class: 'mr-2' %>
8
8
  <%= Spree.t(:export) %>
9
9
  <% end if can?(:export, Spree::Export) %>
10
+
10
11
  <%= render 'extra_actions' %>
11
- <%= button_link_to Spree.t(:create_customer), spree.new_admin_user_path, class: "btn-primary", icon: 'plus', id: 'admin_new_user_link' %>
12
- <% end if can? :create, Spree::user_class %>
13
12
 
14
- <% content_for :table_filter_title do %>
15
- <%= Spree.t(:search) %>
16
- <% end %>
13
+ <%= link_to_with_icon 'plus', Spree.t(:create_customer), spree.new_admin_user_path, class: "btn btn-primary" %>
14
+ <% end if can? :create, Spree::user_class %>
17
15
 
18
- <div class="card-lg p-0">
16
+ <div class="card-lg">
19
17
  <%= render "spree/admin/users/filters" %>
20
18
 
21
- <% if @users.any? %>
19
+ <% if @collection.any? %>
22
20
  <div data-controller="bulk-operation" data-action="keydown.esc->bulk-operation#cancel" tabindex="0">
23
21
  <%= form_tag spree.admin_users_path, data: { 'bulk-operation-target': 'form' } do %>
24
22
  <%= render 'spree/admin/shared/bulk_modal' %>
25
23
  <div id="bulk-panel" class="d-none" data-bulk-operation-target="panel">
26
- <div class="bulk-panel-container animate__animated animate__bounceInUp animate__faster">
27
- <div data-toggle="modal" data-target="#bulk-modal">
28
- <% if can?(:manage_tags, Spree.user_class) %>
29
- <a
30
- href="<%= spree.bulk_modal_admin_users_path(kind: :add_tags) %>"
31
- data-turbo-frame="bulk_modal"
32
- class="btn btn-light mr-2"
33
- data-action="click->bulk-operation#setBulkAction"
34
- data-url="<%= spree.bulk_add_tags_admin_users_path %>"
35
- >
36
- <%= icon("tag-plus") %>
37
- <%= Spree.t("admin.bulk_ops.users.title.add_tags") %>
38
- </a>
39
-
40
- <a
41
- href="<%= spree.bulk_modal_admin_users_path(kind: :remove_tags) %>"
42
- data-turbo-frame="bulk_modal"
43
- class="btn btn-light mr-3"
44
- data-action="click->bulk-operation#setBulkAction"
45
- data-url="<%= spree.bulk_remove_tags_admin_users_path %>"
46
- >
47
- <%= icon("tag-minus") %>
48
- <%= Spree.t("admin.bulk_ops.users.title.remove_tags") %>
49
- </a>
50
- <% end %>
51
- </div>
52
-
53
- <span>
54
- <strong data-bulk-operation-target="counter"></strong>
55
- customers selected
56
- </span>
57
-
58
- <button
59
- type="button"
60
- class="btn-close ml-2"
61
- data-dismiss="modal"
62
- aria-label="<%= Spree.t(:close) %>"
63
- data-action="bulk-operation#cancel"
64
- />
24
+ <div class="bulk-panel-container">
25
+ <% if can?(:manage_tags, Spree.user_class) %>
26
+ <%= bulk_action_link(
27
+ Spree.t("admin.bulk_ops.users.title.add_tags"),
28
+ spree.bulk_modal_admin_users_path(kind: :add_tags),
29
+ icon: "tag-plus",
30
+ url: spree.bulk_add_tags_admin_users_path
31
+ ) %>
32
+ <%= bulk_action_link(
33
+ Spree.t("admin.bulk_ops.users.title.remove_tags"),
34
+ spree.bulk_modal_admin_users_path(kind: :remove_tags),
35
+ icon: "tag-minus",
36
+ url: spree.bulk_remove_tags_admin_users_path
37
+ ) %>
38
+ <% end %>
39
+ <%= bulk_operations_counter %>
40
+ <%= bulk_operations_close_button %>
65
41
  </div>
66
42
  </div>
67
43
 
@@ -70,15 +46,7 @@
70
46
  <thead class="text-muted">
71
47
  <tr data-hook="admin_users_index_headers">
72
48
  <th scope="col" class="pr-0 w-5">
73
- <div class="custom-control custom-checkbox ml-1">
74
- <input
75
- type="checkbox"
76
- class="custom-control-input"
77
- id="checkAllMasterCheckbox"
78
- data-bulk-operation-target="checkboxAll"
79
- >
80
- <label class="custom-control-label" for="checkAllMasterCheckbox"><span></span></label>
81
- </div>
49
+ <%= bulk_operations_select_all_checkbox %>
82
50
  </th>
83
51
  <th><%= Spree.t(:name) %></th>
84
52
  <th><%= Spree.t(:email_marketing) %></th>
@@ -88,15 +56,14 @@
88
56
  </tr>
89
57
  </thead>
90
58
  <tbody>
91
- <%= render collection: @users, partial: "spree/admin/users/user", cached: spree_base_cache_scope %>
59
+ <%= render collection: @collection, partial: "spree/admin/users/user", cached: spree_base_cache_scope %>
92
60
  </tbody>
93
61
  </table>
94
62
  </div>
95
63
  <% end %>
96
64
  </div>
65
+ <%= render "spree/admin/shared/index_table_options", collection: @collection if @collection.any? %>
97
66
  <% else %>
98
67
  <%= render "spree/admin/shared/no_resource_found" %>
99
68
  <% end %>
100
-
101
- <%= render "spree/admin/shared/index_table_options", collection: @users, simple: true if @users.any? %>
102
69
  </div>
@@ -1,5 +1,11 @@
1
1
  <% cache variant do %>
2
- <%= link_to spree.edit_admin_product_variant_path(variant.product, variant), id: spree_dom_id(variant), data: { turbo_permanent: true, turbo_frame: :_top }, class: 'd-flex align-items-center justify-content-start text-decoration-none' do %>
2
+ <% if variant.is_master? %>
3
+ <% variant_url = spree.edit_admin_product_path(variant.product) %>
4
+ <% else %>
5
+ <% variant_url = spree.edit_admin_product_variant_path(variant.product, variant) %>
6
+ <% end %>
7
+
8
+ <%= link_to variant_url, id: spree_dom_id(variant), data: { turbo_permanent: true, turbo_frame: :_top }, class: 'd-flex align-items-center justify-content-start text-decoration-none' do %>
3
9
  <%= render 'spree/admin/shared/product_image', object: variant %>
4
10
  <div class="ml-3">
5
11
  <strong><%= variant.name %></strong>
@@ -10,4 +16,4 @@
10
16
  <% end %>
11
17
  </div>
12
18
  <% end %>
13
- <% end %>
19
+ <% end %>
@@ -9,13 +9,7 @@
9
9
 
10
10
  <div data-toggle="modal" data-target="#modal-lg">
11
11
  <%= link_to spree.edit_admin_asset_path(asset), data: { turbo_frame: 'dialog_modal_lg' } do %>
12
- <%= image_tag(
13
- main_app.cdn_image_url(
14
- asset.attachment.variant(spree_image_variant_options(resize_to_fill: [400, 400]))
15
- ),
16
- alt: asset.alt,
17
- class: 'w-100 d-block h-100 position-absolute'
18
- ) %>
12
+ <%= spree_image_tag(asset.attachment, width: 200, height: 200, alt: asset.alt, class: 'w-100 d-block h-100 position-absolute') %>
19
13
  <% end %>
20
14
  </div>
21
15
  </div>
@@ -5,7 +5,7 @@
5
5
  </h5>
6
6
 
7
7
  <% if can?(:manage, Spree::Store) %>
8
- <%= link_to_with_icon 'adjustments', Spree.t('admin.manage_currencies'), spree.edit_admin_store_path, class: 'btn btn-sm btn-light' %>
8
+ <%= link_to_with_icon 'adjustments', Spree.t('admin.manage_currencies'), spree.edit_admin_store_path(section: 'general-settings'), class: 'btn btn-sm btn-light' %>
9
9
  <% end %>
10
10
  </div>
11
11
  <div class="card-body p-0">
@@ -30,13 +30,13 @@
30
30
  <td><%= price_form.object.currency %></td>
31
31
  <td>
32
32
  <div class="form-control align-items-center py-0 focus-shadow focus-border mr-2 price-input-container d-flex">
33
- <%= price_form.text_field :amount, class: 'form-control-plaintext px-0', disabled: !can?(:manage, price_form.object) %>
33
+ <%= price_form.text_field :amount, class: 'form-control-plaintext px-0', disabled: !can?(:manage, price_form.object), value: price_form.object.amount.present? ? Spree::Money.new(price_form.object.amount, currency: price_form.object.currency, symbol: '').to_s : '' %>
34
34
  <span><%= currency_symbol(price_form.object.currency) %></span>
35
35
  </div>
36
36
  </td>
37
37
  <td>
38
38
  <div class="form-control align-items-center py-0 focus-shadow focus-border mr-2 price-input-container d-flex">
39
- <%= price_form.text_field :compare_at_amount, class: 'form-control-plaintext px-0', disabled: !can?(:manage, price_form.object) %>
39
+ <%= price_form.text_field :compare_at_amount, class: 'form-control-plaintext px-0', disabled: !can?(:manage, price_form.object), value: price_form.object.compare_at_amount.present? ? Spree::Money.new(price_form.object.compare_at_amount, currency: price_form.object.currency, symbol: '').to_s : '' %>
40
40
  <span><%= currency_symbol(price_form.object.currency) %></span>
41
41
  </div>
42
42
  </td>
@@ -45,4 +45,5 @@
45
45
  </tbody>
46
46
  </table>
47
47
  </div>
48
- </div>
48
+ </div>
49
+
@@ -9,7 +9,7 @@
9
9
  <div class="card-body">
10
10
  <div class="row">
11
11
  <div class="form-group col-12">
12
- <%= f.label :url, raw(Spree.t('admin.url') + required_span_tag) %>
12
+ <%= f.label :url, raw(Spree.t(:url) + required_span_tag) %>
13
13
  <%= f.text_field :url, class: 'form-control', placeholder: 'https://example.com/endpoint' %>
14
14
  <%= f.error_message_on :url %>
15
15
  </div>
@@ -1,26 +1,29 @@
1
1
  <%= render 'spree/admin/shared/developers_nav' %>
2
2
 
3
3
  <% content_for :page_actions do %>
4
- <%= button_link_to Spree.t('admin.webhooks_subscribers.new_webhooks_subscriber'), new_object_url, class: "btn-primary", icon: 'add.svg', id: 'admin_new_webhooks_subscriber_link' %>
4
+ <%= link_to_with_icon 'plus', Spree.t('admin.webhooks_subscribers.new_webhooks_subscriber'), new_object_url, class: "btn btn-primary" %>
5
5
  <% end if can?(:create, Spree::Webhooks::Subscriber) %>
6
- <% if @webhooks_subscribers.any? %>
7
- <div class="border rounded bg-white">
8
- <table class="table">
9
- <thead class="text-muted">
10
- <tr>
11
- <th><%= Spree.t('admin.url') %></th>
12
- <th><%= Spree.t('admin.active') %></th>
13
- <th><%= Spree.t('admin.webhooks_subscribers.subscriptions') %></th>
14
- <th><%= Spree.t('admin.webhooks_subscribers.time_of_last_event') %></th>
15
- <th></th>
16
- </tr>
17
- </thead>
18
- <tbody>
19
- <%= render partial: 'spree/admin/webhooks_subscribers/webhooks_subscriber', collection: @webhooks_subscribers, cached: spree_base_cache_scope %>
20
- </tbody>
21
- </table>
22
- </div>
23
- <%= render 'spree/admin/shared/index_table_options', collection: @webhooks_subscribers, simple: true %>
24
- <% else %>
25
- <%= render 'spree/admin/shared/no_resource_found' %>
26
- <% end %>
6
+
7
+ <div class="card-lg">
8
+ <% if @collection.any? %>
9
+ <div class="table-responsive">
10
+ <table class="table">
11
+ <thead class="text-muted">
12
+ <tr>
13
+ <th><%= Spree.t(:url) %></th>
14
+ <th><%= Spree.t(:active) %></th>
15
+ <th><%= Spree.t('admin.webhooks_subscribers.subscriptions') %></th>
16
+ <th><%= Spree.t('admin.webhooks_subscribers.time_of_last_event') %></th>
17
+ <th></th>
18
+ </tr>
19
+ </thead>
20
+ <tbody>
21
+ <%= render partial: 'spree/admin/webhooks_subscribers/webhooks_subscriber', collection: @collection, cached: spree_base_cache_scope %>
22
+ </tbody>
23
+ </table>
24
+ </div>
25
+ <%= render 'spree/admin/shared/index_table_options', collection: @collection %>
26
+ <% else %>
27
+ <%= render 'spree/admin/shared/no_resource_found' %>
28
+ <% end %>
29
+ </div>
@@ -5,11 +5,11 @@
5
5
  <fieldset class="card mb-4">
6
6
  <table class="table card-body pb-0">
7
7
  <tr>
8
- <td><strong class="text-uppercase"><%= Spree.t('admin.url') %></strong></td>
8
+ <td><strong class="text-uppercase"><%= Spree.t(:url) %></strong></td>
9
9
  <td><%= external_link_to @webhooks_subscriber.url, @webhooks_subscriber.url %></td>
10
10
  </tr>
11
11
  <tr>
12
- <td><strong><%= Spree.t('admin.active') %></strong></td>
12
+ <td><strong><%= Spree.t(:active) %></strong></td>
13
13
  <td><%= active_badge(@webhooks_subscriber.active) %></td>
14
14
  </tr>
15
15
  <tr>
@@ -45,7 +45,7 @@
45
45
  <%= render partial: 'spree/admin/webhook_events/webhook_event', collection: @events, cached: spree_base_cache_scope %>
46
46
  </tbody>
47
47
  </table>
48
- <%= render 'spree/admin/shared/index_table_options', collection: @events, simple: true %>
48
+ <%= render 'spree/admin/shared/index_table_options', collection: @events %>
49
49
  </div>
50
50
  <% else %>
51
51
  <div class="text-center no-objects-found m-5">