spree_admin 5.1.3 → 5.1.5

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 (91) hide show
  1. checksums.yaml +4 -4
  2. data/app/assets/stylesheets/spree/admin/components/_variants_form.scss +5 -1
  3. data/app/assets/stylesheets/spree/admin/shared/_forms.scss +4 -0
  4. data/app/controllers/spree/admin/base_controller.rb +6 -0
  5. data/app/controllers/spree/admin/custom_domains_controller.rb +0 -4
  6. data/app/controllers/spree/admin/reports_controller.rb +0 -6
  7. data/app/controllers/spree/admin/taxonomies_controller.rb +4 -0
  8. data/app/helpers/spree/admin/navigation_helper.rb +9 -3
  9. data/app/javascript/spree/admin/controllers/admin_controller.js +8 -2
  10. data/app/javascript/spree/admin/controllers/select_controller.js +0 -6
  11. data/app/views/spree/admin/admin_users/index.html.erb +6 -0
  12. data/app/views/spree/admin/coupon_codes/index.html.erb +6 -0
  13. data/app/views/spree/admin/custom_domains/_custom_domain.html.erb +4 -6
  14. data/app/views/spree/admin/custom_domains/_custom_domains.html.erb +4 -9
  15. data/app/views/spree/admin/custom_domains/index.html.erb +35 -20
  16. data/app/views/spree/admin/customer_returns/index.html.erb +6 -0
  17. data/app/views/spree/admin/digital_assets/index.html.erb +3 -0
  18. data/app/views/spree/admin/exports/index.html.erb +6 -0
  19. data/app/views/spree/admin/gift_cards/_filters.html.erb +2 -0
  20. data/app/views/spree/admin/gift_cards/index.html.erb +3 -0
  21. data/app/views/spree/admin/integrations/index.html.erb +6 -0
  22. data/app/views/spree/admin/invitations/index.html.erb +6 -0
  23. data/app/views/spree/admin/invitations/show.html.erb +2 -2
  24. data/app/views/spree/admin/oauth_applications/index.html.erb +3 -0
  25. data/app/views/spree/admin/option_types/index.html.erb +3 -0
  26. data/app/views/spree/admin/orders/index.html.erb +3 -0
  27. data/app/views/spree/admin/pages/index.html.erb +3 -0
  28. data/app/views/spree/admin/payment_methods/index.html.erb +6 -0
  29. data/app/views/spree/admin/post_categories/index.html.erb +4 -1
  30. data/app/views/spree/admin/posts/_filters.html.erb +1 -0
  31. data/app/views/spree/admin/posts/index.html.erb +4 -3
  32. data/app/views/spree/admin/products/_list.html.erb +6 -4
  33. data/app/views/spree/admin/products/_product.html.erb +2 -0
  34. data/app/views/spree/admin/products/edit.html.erb +1 -0
  35. data/app/views/spree/admin/products/form/_variants.html.erb +1 -1
  36. data/app/views/spree/admin/products/index.html.erb +10 -1
  37. data/app/views/spree/admin/profile/edit.html.erb +1 -1
  38. data/app/views/spree/admin/promotions/_filters.html.erb +1 -1
  39. data/app/views/spree/admin/promotions/_header.html.erb +2 -6
  40. data/app/views/spree/admin/promotions/index.html.erb +3 -0
  41. data/app/views/spree/admin/properties/index.html.erb +3 -0
  42. data/app/views/spree/admin/refund_reasons/index.html.erb +6 -3
  43. data/app/views/spree/admin/reimbursement_types/index.html.erb +6 -3
  44. data/app/views/spree/admin/reports/index.html.erb +6 -0
  45. data/app/views/spree/admin/return_authorization_reasons/index.html.erb +6 -3
  46. data/app/views/spree/admin/return_authorizations/index.html.erb +6 -0
  47. data/app/views/spree/admin/roles/_form.html.erb +1 -1
  48. data/app/views/spree/admin/roles/index.html.erb +5 -2
  49. data/app/views/spree/admin/roles/new.html.erb +12 -9
  50. data/app/views/spree/admin/shared/_new_item_dropdown.html.erb +1 -1
  51. data/app/views/spree/admin/shared/_returns_and_refunds_nav.html.erb +1 -0
  52. data/app/views/spree/admin/shared/_shipping_nav.html.erb +1 -0
  53. data/app/views/spree/admin/shared/_stock_nav.html.erb +1 -0
  54. data/app/views/spree/admin/shared/_team_nav.html.erb +1 -0
  55. data/app/views/spree/admin/shared/sidebar/_integrations_nav.html.erb +1 -3
  56. data/app/views/spree/admin/shared/sidebar/_products_nav.html.erb +15 -16
  57. data/app/views/spree/admin/shared/sidebar/_promotions_nav.html.erb +4 -14
  58. data/app/views/spree/admin/shared/sidebar/_returns_nav.html.erb +1 -0
  59. data/app/views/spree/admin/shared/sidebar/_store_nav.html.erb +10 -30
  60. data/app/views/spree/admin/shared/sidebar/_storefront_nav.html.erb +18 -20
  61. data/app/views/spree/admin/shared/sidebar/_vendors_nav.html.erb +11 -7
  62. data/app/views/spree/admin/shipping_categories/index.html.erb +3 -0
  63. data/app/views/spree/admin/shipping_methods/index.html.erb +8 -1
  64. data/app/views/spree/admin/stock_items/_filters.html.erb +1 -1
  65. data/app/views/spree/admin/stock_items/index.html.erb +6 -0
  66. data/app/views/spree/admin/stock_locations/index.html.erb +3 -0
  67. data/app/views/spree/admin/stock_transfers/_filters.html.erb +1 -0
  68. data/app/views/spree/admin/stock_transfers/index.html.erb +3 -0
  69. data/app/views/spree/admin/store_credit_categories/index.html.erb +3 -0
  70. data/app/views/spree/admin/store_credits/index.html.erb +3 -0
  71. data/app/views/spree/admin/stores/edit.html.erb +1 -1
  72. data/app/views/spree/admin/stores/form/_emails.html.erb +17 -0
  73. data/app/views/spree/admin/tax_categories/index.html.erb +3 -0
  74. data/app/views/spree/admin/tax_rates/_form.html.erb +7 -5
  75. data/app/views/spree/admin/tax_rates/index.html.erb +3 -0
  76. data/app/views/spree/admin/taxonomies/_taxonomy.html.erb +2 -2
  77. data/app/views/spree/admin/taxonomies/index.html.erb +3 -0
  78. data/app/views/spree/admin/taxonomies/update.turbo_stream.erb +1 -0
  79. data/app/views/spree/admin/themes/index.html.erb +3 -0
  80. data/app/views/spree/admin/users/_filters.html.erb +1 -0
  81. data/app/views/spree/admin/users/index.html.erb +3 -1
  82. data/app/views/spree/admin/webhooks_subscribers/index.html.erb +5 -2
  83. data/app/views/spree/admin/zones/index.html.erb +3 -0
  84. data/config/locales/en.yml +1 -0
  85. data/lib/spree/admin/engine.rb +114 -37
  86. metadata +9 -13
  87. data/app/helpers/spree/admin/custom_domains_helper.rb +0 -9
  88. data/app/views/spree/admin/custom_domains/create.turbo_stream.erb +0 -3
  89. data/app/views/spree/admin/products/_index_header.html.erb +0 -7
  90. data/app/views/spree/admin/shared/sidebar/_custom_nav.html.erb +0 -0
  91. data/app/views/spree/admin/shipping_methods/_actions.html.erb +0 -5
@@ -3,9 +3,12 @@
3
3
  <% end %>
4
4
 
5
5
  <% content_for :page_actions do %>
6
+ <%= render_admin_partials(:promotions_actions_partials) %>
6
7
  <%= link_to_with_icon 'plus', Spree.t(:new_promotion), new_object_url, class: "btn btn-primary" %>
7
8
  <% end if can?(:create, Spree::Promotion) %>
8
9
 
10
+ <%= render_admin_partials(:promotions_header_partials) %>
11
+
9
12
  <div class="card-lg">
10
13
  <%= render 'filters' %>
11
14
 
@@ -9,9 +9,12 @@
9
9
  <% end %>
10
10
 
11
11
  <% content_for :page_actions do %>
12
+ <%= render_admin_partials(:properties_actions_partials) %>
12
13
  <%= link_to_with_icon 'plus', Spree.t(:new_property), new_object_url, class: "btn btn-primary" %>
13
14
  <% end if can?(:create, Spree::Property) %>
14
15
 
16
+ <%= render_admin_partials(:properties_header_partials) %>
17
+
15
18
  <div class="card-lg">
16
19
  <%= search_form_for [:admin, @search], class: "filter-wrap", data: {controller: "filters reveal", reveal_hidden_class: "d-none"} do |f| %>
17
20
  <%= render 'spree/admin/shared/filters_search_bar', param: :name_cont, label: Spree.t(:name) %>
@@ -1,8 +1,11 @@
1
+ <%= render 'spree/admin/shared/returns_and_refunds_nav' %>
2
+
1
3
  <% content_for :page_actions do %>
2
- <%= link_to_with_icon 'plus', Spree.t(:new_refund_reason), new_object_url, class: "btn btn-primary" %>
3
- <% end if can? :create, Spree::RefundReason %>
4
+ <%= render_admin_partials(:refund_reasons_actions_partials) %>
5
+ <%= link_to_with_icon 'plus', Spree.t(:new_refund_reason), new_object_url, class: "btn btn-primary" if can? :create, Spree::RefundReason %>
6
+ <% end %>
4
7
 
5
- <%= render 'spree/admin/shared/returns_and_refunds_nav' %>
8
+ <%= render_admin_partials(:refund_reasons_header_partials) %>
6
9
 
7
10
  <div class="card-lg">
8
11
  <% if @collection.any? %>
@@ -1,8 +1,11 @@
1
+ <%= render 'spree/admin/shared/returns_and_refunds_nav' %>
2
+
1
3
  <% content_for :page_actions do %>
2
- <%= link_to_with_icon 'plus', Spree.t(:new_reimbursement_type), new_object_url, class: "btn btn-primary" %>
3
- <% end if can?(:create, Spree::ReimbursementType) %>
4
+ <%= render_admin_partials(:reimbursement_types_actions_partials) %>
5
+ <%= link_to_with_icon 'plus', Spree.t(:new_reimbursement_type), new_object_url, class: "btn btn-primary" if can?(:create, Spree::ReimbursementType) %>
6
+ <% end %>
4
7
 
5
- <%= render 'spree/admin/shared/returns_and_refunds_nav' %>
8
+ <%= render_admin_partials(:reimbursement_types_header_partials) %>
6
9
 
7
10
  <div class="card-lg">
8
11
  <% if @collection.any? %>
@@ -2,6 +2,12 @@
2
2
  <%= Spree.t(:reports) %>
3
3
  <% end %>
4
4
 
5
+ <% content_for :page_actions do %>
6
+ <%= render_admin_partials(:reports_actions_partials) %>
7
+ <% end %>
8
+
9
+ <%= render_admin_partials(:reports_header_partials) %>
10
+
5
11
  <div class="card">
6
12
  <div class="table-responsive">
7
13
  <table class="table">
@@ -1,8 +1,11 @@
1
+ <%= render"spree/admin/shared/returns_and_refunds_nav" %>
2
+
1
3
  <% content_for :page_actions do %>
2
- <%= link_to_with_icon 'plus', Spree.t(:new_rma_reason), new_object_url, class: "btn btn-primary" %>
3
- <% end if can? :create, Spree::ReturnAuthorizationReason %>
4
+ <%= render_admin_partials(:return_authorization_reasons_actions_partials) %>
5
+ <%= link_to_with_icon 'plus', Spree.t(:new_rma_reason), new_object_url, class: "btn btn-primary" if can? :create, Spree::ReturnAuthorizationReason %>
6
+ <% end %>
4
7
 
5
- <%= render"spree/admin/shared/returns_and_refunds_nav" %>
8
+ <%= render_admin_partials(:return_authorization_reasons_header_partials) %>
6
9
 
7
10
  <div class="card-lg">
8
11
  <% if @collection.any? %>
@@ -2,6 +2,12 @@
2
2
  <%= Spree.t(:return_authorizations) %>
3
3
  <% end %>
4
4
 
5
+ <% content_for :page_actions do %>
6
+ <%= render_admin_partials(:return_authorizations_actions_partials) %>
7
+ <% end %>
8
+
9
+ <%= render_admin_partials(:return_authorizations_header_partials) %>
10
+
5
11
  <div class="card-lg">
6
12
  <%= render "spree/admin/return_authorizations/filters" %>
7
13
  <%= render "spree/admin/return_authorizations/list" %>
@@ -1,6 +1,6 @@
1
1
  <div class="form-group">
2
2
  <%= f.label :name, raw(Spree.t(:name) + required_span_tag) %>
3
- <%= f.text_field :name, class: 'form-control' %>
3
+ <%= f.text_field :name, class: 'form-control', required: true %>
4
4
  <%= f.error_message_on :name %>
5
5
  </div>
6
6
 
@@ -1,8 +1,11 @@
1
1
  <%= render 'spree/admin/shared/team_nav' %>
2
2
 
3
3
  <% content_for :page_actions do %>
4
- <%= link_to_with_icon 'plus', Spree.t(:new_role), new_object_url, class: "btn btn-primary" %>
5
- <% end if can? :create, Spree::Role %>
4
+ <%= render_admin_partials(:roles_actions_partials) %>
5
+ <%= link_to_with_icon 'plus', Spree.t(:new_role), new_object_url, class: "btn btn-primary" if can? :create, Spree::Role %>
6
+ <% end %>
7
+
8
+ <%= render_admin_partials(:roles_header_partials) %>
6
9
 
7
10
  <div class="card-lg">
8
11
  <% if @collection.any? %>
@@ -3,13 +3,16 @@
3
3
  <%= Spree.t(:new_role) %>
4
4
  <% end %>
5
5
 
6
- <%= render partial: 'spree/admin/shared/error_messages', locals: { target: @role } %>
7
-
8
- <%= form_for [:admin, @role] do |f| %>
9
- <div class="card mb-4">
10
- <div class="card-body">
11
- <%= render 'form', f: f %>
12
- </div>
6
+ <div class="row">
7
+ <div class="col-lg-6 offset-lg-3">
8
+ <%= form_for [:admin, @role] do |f| %>
9
+ <div class="card mb-4">
10
+ <div class="card-body">
11
+ <%= render partial: 'spree/admin/shared/error_messages', locals: { target: @role } %>
12
+ <%= render 'form', f: f %>
13
+ </div>
14
+ </div>
15
+ <%= render 'spree/admin/shared/new_resource_links' %>
16
+ <% end %>
13
17
  </div>
14
- <%= render 'spree/admin/shared/new_resource_links' %>
15
- <% end %>
18
+ </div>
@@ -21,7 +21,7 @@
21
21
 
22
22
  <%= invite_vendor_button(class: 'dropdown-item') if defined?(invite_vendor_button) %>
23
23
 
24
- <% if can?(:create, Spree::Store) %>
24
+ <% if can?(:create, Spree::Store) && Spree.root_domain.present? %>
25
25
  <div class="dropdown-divider"></div>
26
26
 
27
27
  <span data-toggle="modal" data-target="#modal-lg">
@@ -6,4 +6,5 @@
6
6
  <%= nav_item(Spree.t(:return_authorization_reasons), spree.admin_return_authorization_reasons_path) if can?(:manage, Spree::ReturnAuthorizationReason) %>
7
7
  <%= nav_item(Spree.t(:refund_reasons), spree.admin_refund_reasons_path) if can?(:manage, Spree::RefundReason) %>
8
8
  <%= nav_item(Spree.t(:reimbursement_types), spree.admin_reimbursement_types_path) if can?(:manage, Spree::ReimbursementType) %>
9
+ <%= render_admin_partials(:returns_and_refunds_nav_partials) %>
9
10
  <% end %>
@@ -1,4 +1,5 @@
1
1
  <%= content_for(:page_tabs) do %>
2
2
  <%= nav_item(Spree.t(:shipping_methods), spree.admin_shipping_methods_path, active: controller_name == 'shipping_methods' && action_name == 'index') if can?(:manage, Spree::ShippingMethod) %>
3
3
  <%= nav_item(Spree.t(:shipping_categories), spree.admin_shipping_categories_path) if can?(:manage, Spree::ShippingCategory) %>
4
+ <%= render_admin_partials(:shipping_nav_partials) %>
4
5
  <% end %>
@@ -1,2 +1,3 @@
1
1
  <%= nav_item(Spree.t(:stock_items), spree.admin_stock_items_path) if can?(:manage, Spree::StockItem) %>
2
2
  <%= nav_item(Spree.t(:stock_transfers), spree.admin_stock_transfers_path) if can?(:manage, Spree::StockTransfer) %>
3
+ <%= render_admin_partials(:stock_nav_partials) %>
@@ -4,6 +4,7 @@
4
4
  <%= nav_item(Spree.t(:users), spree.admin_admin_users_path) if can?(:manage, Spree.admin_user_class) %>
5
5
  <%= nav_item(Spree.t(:invitations), spree.admin_invitations_path) if can?(:manage, Spree::Invitation) %>
6
6
  <%= nav_item(Spree.t(:roles), spree.admin_roles_path) if can?(:manage, Spree::Role) %>
7
+ <%= render_admin_partials(:team_nav_partials) %>
7
8
  <% end %>
8
9
 
9
10
  <% content_for :page_actions do %>
@@ -1,5 +1,3 @@
1
1
  <% if can?(:manage, Spree::Integration) %>
2
- <li class="nav-item">
3
- <%= nav_item(Spree.t(:integrations), spree.admin_integrations_path, icon: 'plug-connected') %>
4
- </li>
2
+ <%= nav_item(Spree.t(:integrations), spree.admin_integrations_path, icon: 'plug-connected') %>
5
3
  <% end %>
@@ -1,22 +1,21 @@
1
1
  <% products_active = %w[products external_categories taxons taxonomies option_types option_values properties stock_items stock_transfers].include?(controller_name) || request.path.include?('products') %>
2
2
  <% if can?(:manage, Spree::Product) %>
3
3
  <%= nav_item(Spree.t(:products), spree.admin_products_path, icon: 'package', active: products_active) %>
4
- <% if products_active %>
5
- <ul class="nav-submenu">
6
- <% if can?(:manage, Spree::StockItem) || can?(:manage, Spree::StockTransfer) %>
7
- <%= nav_item(Spree.t(:stock), spree.admin_stock_items_path, active: %w[stock_items stock_transfers].include?(controller_name)) %>
8
- <% end %>
9
- <% if can?(:manage, Spree::Taxonomy) && can?(:manage, Spree::Taxon) %>
10
- <%= nav_item(Spree.t(:taxonomies), spree.admin_taxonomies_path) %>
11
- <% end %>
12
- <% if can?(:manage, Spree::OptionType) %>
13
- <%= nav_item(Spree.t(:options), spree.admin_option_types_path, active: %w[option_types option_values].include?(controller_name)) %>
14
- <% end %>
15
- <% if can?(:manage, Spree::Property) %>
16
- <%= nav_item(Spree.t(:properties), spree.admin_properties_path) %>
17
- <% end %>
18
4
 
19
- <%= render_admin_partials(:store_products_nav_partials) %>
20
- </ul>
5
+ <ul class="nav-submenu <% unless products_active %>d-none<% end %>">
6
+ <% if can?(:manage, Spree::StockItem) || can?(:manage, Spree::StockTransfer) %>
7
+ <%= nav_item(Spree.t(:stock), spree.admin_stock_items_path, active: %w[stock_items stock_transfers].include?(controller_name)) %>
21
8
  <% end %>
9
+ <% if can?(:manage, Spree::Taxonomy) && can?(:manage, Spree::Taxon) %>
10
+ <%= nav_item(Spree.t(:taxonomies), spree.admin_taxonomies_path) %>
11
+ <% end %>
12
+ <% if can?(:manage, Spree::OptionType) %>
13
+ <%= nav_item(Spree.t(:options), spree.admin_option_types_path, active: %w[option_types option_values].include?(controller_name)) %>
14
+ <% end %>
15
+ <% if can?(:manage, Spree::Property) %>
16
+ <%= nav_item(Spree.t(:properties), spree.admin_properties_path) %>
17
+ <% end %>
18
+
19
+ <%= render_admin_partials(:store_products_nav_partials) %>
20
+ </ul>
22
21
  <% end %>
@@ -1,17 +1,7 @@
1
1
  <% if can?(:manage, Spree::Promotion) %>
2
2
  <% discounts_active = %w[promotions gift_cards gift_card_batches coupon_codes].include?(controller_name) && @user.nil? %>
3
- <li class="nav-item">
4
- <%= active_link_to spree.admin_promotions_path, class: 'nav-link', active: discounts_active do %>
5
- <%= icon 'discount' %>
6
- <%= Spree.t(:promotions) %>
7
- <% end %>
8
-
9
- <% if discounts_active && defined?(Spree::GiftCard) && spree.respond_to?(:admin_gift_cards_path) && can?(:manage, Spree::GiftCard) %>
10
- <ul class="nav-submenu">
11
- <li class="nav-item">
12
- <%= active_link_to Spree.t(:gift_cards), spree.admin_gift_cards_path, class: 'nav-link', active: %w[gift_cards gift_card_batches].include?(controller_name) %>
13
- </li>
14
- </ul>
15
- <% end %>
16
- </li>
3
+ <%= nav_item(Spree.t(:promotions), spree.admin_promotions_path, icon: 'discount', active: discounts_active) %>
4
+ <ul class="nav-submenu <% unless discounts_active %>d-none<% end %>">
5
+ <%= nav_item(Spree.t(:gift_cards), spree.admin_gift_cards_path, active: %w[gift_cards gift_card_batches].include?(controller_name)) %>
6
+ </ul>
17
7
  <% end %>
@@ -8,6 +8,7 @@
8
8
  <% if can?(:manage, Spree::ReturnAuthorization) %>
9
9
  <%= nav_item(Spree.t(:return_authorizations), spree.admin_return_authorizations_path) %>
10
10
  <% end %>
11
+ <%= render_admin_partials(:returns_nav_partials) %>
11
12
  </ul>
12
13
  <% end %>
13
14
  <% end %>
@@ -67,24 +67,16 @@
67
67
  <% else %>
68
68
  <ul class="nav flex-column">
69
69
  <% unless current_store.setup_completed? %>
70
- <li class="nav-item">
71
- <%= active_link_to spree.admin_getting_started_path, class: 'nav-link' do %>
72
- <%= icon 'map' %>
73
- <%= Spree.t('admin.getting_started') %>
74
-
75
- <span class="badge ml-auto badge-info">
76
- <%= current_store.setup_tasks_done %><span class="opacity-50">/<%= current_store.setup_tasks_total %></span>
77
- </span>
78
- <% end %>
79
- </li>
70
+ <%= nav_item(nil, spree.admin_getting_started_path, icon: 'map') do %>
71
+ <%= icon 'map' %>
72
+ <%= Spree.t('admin.getting_started') %>
73
+ <span class="badge ml-auto badge-info">
74
+ <%= current_store.setup_tasks_done %><span class="opacity-50">/<%= current_store.setup_tasks_total %></span>
75
+ </span>
76
+ <% end %>
80
77
  <% end %>
81
78
 
82
- <li class="nav-item">
83
- <%= active_link_to spree.admin_path, class: 'nav-link', active: controller_name == 'dashboard' && action_name == 'show' do %>
84
- <%= icon 'home' %>
85
- <%= Spree.t(:home) %>
86
- <% end %>
87
- </li>
79
+ <%= nav_item(Spree.t(:home), spree.admin_path, icon: 'home', active: controller_name == 'dashboard' && action_name == 'show') %>
88
80
 
89
81
  <%= render 'spree/admin/shared/sidebar/orders_nav' %>
90
82
  <%= render 'spree/admin/shared/sidebar/returns_nav' %>
@@ -92,27 +84,15 @@
92
84
  <%= render 'spree/admin/shared/sidebar/vendors_nav' %>
93
85
 
94
86
  <% if can?(:manage, Spree.user_class) %>
95
- <li class="nav-item">
96
- <%= active_link_to spree.admin_users_path, class: 'nav-link' do %>
97
- <%= icon 'users' %>
98
- <%= Spree.t(:customers) %>
99
- <% end %>
100
- </li>
87
+ <%= nav_item(Spree.t(:customers), spree.admin_users_path, icon: 'users') %>
101
88
  <% end %>
102
89
 
103
90
  <%= render 'spree/admin/shared/sidebar/promotions_nav' %>
104
91
 
105
92
  <% if can?(:manage, Spree::Report) %>
106
- <li class="nav-item">
107
- <%= active_link_to spree.admin_reports_path, class: 'nav-link' do %>
108
- <%= icon 'chart-bar' %>
109
- <%= Spree.t(:reports) %>
110
- <% end %>
111
- </li>
93
+ <%= nav_item(Spree.t(:reports), spree.admin_reports_path, icon: 'chart-bar') %>
112
94
  <% end %>
113
95
 
114
- <%= render 'spree/admin/shared/sidebar/custom_nav' %>
115
-
116
96
  <%= render_admin_partials(:store_nav_partials) %>
117
97
 
118
98
  <li class="nav-item border-top border-top-dashed my-1"></li>
@@ -2,25 +2,23 @@
2
2
  <% storefront_active = %w[themes posts post_categories pages storefront].include?(controller_name) %>
3
3
  <%= nav_item(Spree.t('admin.storefront'), spree.admin_themes_path, icon: 'building-store', active: storefront_active) %>
4
4
 
5
- <% if storefront_active %>
6
- <ul class="nav-submenu">
7
- <% if can?(:manage, Spree::Theme) %>
8
- <%= nav_item(Spree.t(:themes), spree.admin_themes_path) %>
9
- <% end %>
10
-
11
- <% if can?(:manage, Spree::Page) %>
12
- <%= nav_item(Spree.t(:pages), spree.admin_pages_path) %>
13
- <% end %>
14
-
15
- <% if can?(:manage, Spree::Post) %>
16
- <%= nav_item(Spree.t(:posts), spree.admin_posts_path, active: %w[posts post_categories].include?(controller_name)) %>
17
- <% end %>
18
-
19
- <% if can?(:manage, current_store) %>
20
- <%= nav_item(Spree.t(:settings), spree.edit_admin_storefront_path) %>
21
- <% end %>
5
+ <ul class="nav-submenu <% unless storefront_active %>d-none<% end %>">
6
+ <% if can?(:manage, Spree::Theme) %>
7
+ <%= nav_item(Spree.t(:themes), spree.admin_themes_path) %>
8
+ <% end %>
9
+
10
+ <% if can?(:manage, Spree::Page) %>
11
+ <%= nav_item(Spree.t(:pages), spree.admin_pages_path) %>
12
+ <% end %>
13
+
14
+ <% if can?(:manage, Spree::Post) %>
15
+ <%= nav_item(Spree.t(:posts), spree.admin_posts_path, active: %w[posts post_categories].include?(controller_name)) %>
16
+ <% end %>
17
+
18
+ <% if can?(:manage, current_store) %>
19
+ <%= nav_item(Spree.t(:settings), spree.edit_admin_storefront_path) %>
20
+ <% end %>
22
21
 
23
- <%= render_admin_partials(:storefront_nav_partials) %>
24
- </ul>
25
- <% end %>
22
+ <%= render_admin_partials(:storefront_nav_partials) %>
23
+ </ul>
26
24
  <% end %>
@@ -1,10 +1,14 @@
1
1
  <% if can?(:manage, current_store) %>
2
- <li class="nav-item">
3
- <%= external_link_to nil, 'https://spreecommerce.org/pricing', class: 'nav-link d-flex align-items-center w-100' do %>
4
- <%= icon 'heart-handshake' %>
5
- <%= Spree.t(:vendors) %>
2
+ <% if enterprise_edition? %>
3
+ <%= render_admin_partials(:vendors_nav_partials) %>
4
+ <% else %>
5
+ <li class="nav-item">
6
+ <%= external_link_to nil, 'https://spreecommerce.org/pricing', class: 'nav-link d-flex align-items-center w-100' do %>
7
+ <%= icon 'heart-handshake' %>
8
+ <%= Spree.t(:vendors) %>
6
9
 
7
- <span class="badge ml-auto with-tip rounded-pill" title="This feature is part of the Enterprise Edition.">Enterprise</span>
8
- <% end %>
9
- </li>
10
+ <span class="badge ml-auto with-tip rounded-pill" title="This feature is part of the Enterprise Edition.">Enterprise</span>
11
+ <% end %>
12
+ </li>
13
+ <% end %>
10
14
  <% end%>
@@ -3,9 +3,12 @@
3
3
  <% end %>
4
4
 
5
5
  <% content_for :page_actions do %>
6
+ <%= render_admin_partials(:shipping_categories_actions_partials) %>
6
7
  <%= link_to_with_icon 'plus', Spree.t(:new_shipping_category), new_object_url, class: "btn btn-primary" %>
7
8
  <% end if can? :create, Spree::ShippingCategory %>
8
9
 
10
+ <%= render_admin_partials(:shipping_categories_header_partials) %>
11
+
9
12
  <%= render partial: 'spree/admin/shared/shipping_nav' %>
10
13
 
11
14
  <div class="card-lg">
@@ -2,7 +2,12 @@
2
2
  <%= Spree.t(:shipping) %>
3
3
  <% end %>
4
4
 
5
- <%= render partial: 'spree/admin/shipping_methods/actions' %>
5
+ <% content_for :page_actions do %>
6
+ <%= render_admin_partials(:shipping_methods_actions_partials) %>
7
+ <% if can?(:create, Spree::ShippingMethod) %>
8
+ <%= link_to_with_icon 'plus', Spree.t(:new_shipping_method), new_object_url, class: "btn btn-primary" %>
9
+ <% end %>
10
+ <% end %>
6
11
  <%= render partial: 'spree/admin/shared/shipping_nav' %>
7
12
 
8
13
  <% content_for :page_alerts do %>
@@ -11,6 +16,8 @@
11
16
  </div>
12
17
  <% end %>
13
18
 
19
+ <%= render_admin_partials(:shipping_methods_header_partials) %>
20
+
14
21
  <div class="card-lg">
15
22
  <% if @collection.any? %>
16
23
  <div class="table-responsive">
@@ -24,7 +24,7 @@
24
24
  </div>
25
25
 
26
26
  </div>
27
-
27
+ <%= render_admin_partials(:stock_items_filters_partials, f: f) %>
28
28
  <%= render 'spree/admin/shared/filter_submit' %>
29
29
  </div>
30
30
 
@@ -2,10 +2,16 @@
2
2
  <%= Spree.t(:stock) %>
3
3
  <% end %>
4
4
 
5
+ <% content_for :page_actions do %>
6
+ <%= render_admin_partials(:stock_items_actions_partials) %>
7
+ <% end %>
8
+
5
9
  <% content_for :page_tabs do %>
6
10
  <%= render "spree/admin/shared/stock_nav" %>
7
11
  <% end %>
8
12
 
13
+ <%= render_admin_partials(:stock_items_header_partials) %>
14
+
9
15
  <div class="card-lg">
10
16
  <%= render "filters" %>
11
17
 
@@ -2,9 +2,12 @@
2
2
  <%= Spree.t(:stock_locations) %>
3
3
  <% end %>
4
4
  <% content_for :page_actions do %>
5
+ <%= render_admin_partials(:stock_locations_actions_partials) %>
5
6
  <%= link_to_with_icon 'plus', Spree.t(:new_stock_location), new_object_url, class: "btn btn-primary" %>
6
7
  <% end if can? :create, Spree::StockLocation %>
7
8
 
9
+ <%= render_admin_partials(:stock_locations_header_partials) %>
10
+
8
11
  <div class="card-lg">
9
12
  <% if @collection.any? %>
10
13
  <div class="table-responsive">
@@ -36,6 +36,7 @@
36
36
  </div>
37
37
  </div>
38
38
  </div>
39
+ <%= render_admin_partials(:stock_transfers_filters_partials, f: f) %>
39
40
  <div class="form-actions">
40
41
  <%= button Spree.t(:search), "search" %>
41
42
  </div>
@@ -5,11 +5,14 @@
5
5
  <%= render "spree/admin/shared/stock_nav" %>
6
6
  <% end %>
7
7
  <% content_for :page_actions do %>
8
+ <%= render_admin_partials(:stock_transfers_actions_partials) %>
8
9
  <%= if can?(:create, Spree::StockTransfer)
9
10
  link_to_with_icon 'plus', Spree.t(:new_stock_transfer), new_object_url, class: "btn btn-primary"
10
11
  end %>
11
12
  <% end %>
12
13
 
14
+ <%= render_admin_partials(:stock_transfers_header_partials) %>
15
+
13
16
  <div class="card-lg">
14
17
  <%= render "filters" %>
15
18
  <% if @collection.any? %>
@@ -3,9 +3,12 @@
3
3
  <% end %>
4
4
 
5
5
  <% content_for :page_actions do %>
6
+ <%= render_admin_partials(:store_credit_categories_actions_partials) %>
6
7
  <%= link_to_with_icon 'plus', Spree.t(:new_store_credit_category), new_object_url, class: "btn btn-primary" %>
7
8
  <% end if can? :create, Spree::StoreCreditCategory %>
8
9
 
10
+ <%= render_admin_partials(:store_credit_categories_header_partials) %>
11
+
9
12
  <div class="card-lg">
10
13
  <% if @collection.any? %>
11
14
  <div class="table-responsive">
@@ -5,10 +5,13 @@
5
5
  <% end %>
6
6
 
7
7
  <% content_for :page_actions do %>
8
+ <%= render_admin_partials(:store_credits_actions_partials) %>
8
9
  <%= link_to_with_icon 'plus', Spree.t(:add_store_credit), spree.new_admin_user_store_credit_path(@user), class: "btn btn-primary" if can?(:create, Spree::StoreCredit) %>
9
10
  <% end %>
10
11
  <% end %>
11
12
 
13
+ <%= render_admin_partials(:store_credits_header_partials) %>
14
+
12
15
  <div class="card-lg">
13
16
  <% if params[:frame_name].present? %>
14
17
  <%= turbo_frame_tag params[:frame_name], autoscroll: true, data: { autoscroll_block: :nearest, autoscroll_behavior: :smooth } do %>
@@ -1,5 +1,5 @@
1
1
  <%= content_for :page_actions do %>
2
- <%= turbo_save_button_tag Spree.t('actions.update'), class: 'btn btn-primary', form: "edit_store_#{current_store.id}" %>
2
+ <%= turbo_save_button_tag Spree.t('actions.update'), class: 'btn btn-primary', form: "edit_store_#{current_store.id}", data: { admin_target: 'save' } %>
3
3
  <% end %>
4
4
 
5
5
  <%= render partial: 'spree/admin/shared/error_messages', locals: { target: @store }, class: 'mb-5 pb-5' %>
@@ -4,6 +4,23 @@
4
4
 
5
5
  <div class="row">
6
6
  <div class="col-lg-6 offset-lg-3">
7
+ <div class="card mb-4">
8
+ <div class="card-header">
9
+ <h5 class="card-title"><%= Spree.t(:settings) %></h5>
10
+ </div>
11
+ <div class="card-body">
12
+ <div class="form-group">
13
+ <div class="custom-control custom-checkbox">
14
+ <%= f.check_box :preferred_send_consumer_transactional_emails, class: 'custom-control-input' %>
15
+ <%= f.label :preferred_send_consumer_transactional_emails, Spree.t(:send_consumer_transactional_emails), class: 'custom-control-label' %>
16
+ <small class="form-text text-muted mt-2">
17
+ <%= Spree.t('admin.store_form.send_consumer_transactional_emails_help') %>
18
+ </small>
19
+ </div>
20
+ </div>
21
+ </div>
22
+ </div>
23
+
7
24
  <div class="card mb-4">
8
25
  <div class="card-header">
9
26
  <h5 class="card-title">Email addresses</h5>
@@ -3,9 +3,12 @@
3
3
  <% end %>
4
4
 
5
5
  <% content_for :page_actions do %>
6
+ <%= render_admin_partials(:tax_categories_actions_partials) %>
6
7
  <%= link_to_with_icon 'plus', Spree.t(:new_tax_category), new_object_url, class: "btn btn-primary" %>
7
8
  <% end if can? :create, Spree::TaxCategory %>
8
9
 
10
+ <%= render_admin_partials(:tax_categories_header_partials) %>
11
+
9
12
  <%= render 'spree/admin/shared/tax_nav' %>
10
13
 
11
14
  <div class="card-lg">
@@ -12,12 +12,14 @@
12
12
  <%= f.error_message_on :name %>
13
13
  </div>
14
14
  <div class="form-group">
15
- <%= f.label :amount, Spree.t(:rate) %>
16
- <%= f.number_field :amount, class: 'form-control', min: 0, step: 0.0001, required: true %>
15
+ <%= f.label :amount_percentage, Spree.t(:rate) %>
16
+ <div class="input-group">
17
+ <%= f.number_field :amount_percentage, class: 'form-control', min: 0, step: 0.1, required: true %>
18
+ <div class="input-group-append">
19
+ <span class="input-group-text">%</span>
20
+ </div>
21
+ </div>
17
22
  <%= f.error_message_on :amount %>
18
- <small class="form-text text-muted">
19
- <%= Spree.t(:tax_rate_amount_explanation) %>
20
- </small>
21
23
  </div>
22
24
 
23
25
  <div class="form-group">
@@ -3,9 +3,12 @@
3
3
  <% end %>
4
4
 
5
5
  <% content_for :page_actions do %>
6
+ <%= render_admin_partials(:tax_rates_actions_partials) %>
6
7
  <%= link_to_with_icon 'plus', Spree.t(:new_tax_rate), new_object_url, class: "btn btn-primary" %>
7
8
  <% end if can? :create, Spree::TaxRate %>
8
9
 
10
+ <%= render_admin_partials(:tax_rates_header_partials) %>
11
+
9
12
  <%= render 'spree/admin/shared/tax_nav' %>
10
13
 
11
14
  <div class="card-lg">