spree_admin 5.1.2 → 5.1.4

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 (93) hide show
  1. checksums.yaml +4 -4
  2. data/app/assets/stylesheets/spree/admin/components/_bulk_panel.scss +58 -10
  3. data/app/assets/stylesheets/spree/admin/components/_buttons.scss +0 -15
  4. data/app/assets/stylesheets/spree/admin/components/_filters.scss +1 -1
  5. data/app/assets/stylesheets/spree/admin/components/_tables.scss +24 -1
  6. data/app/assets/stylesheets/spree/admin/shared/_base.scss +7 -0
  7. data/app/controllers/spree/admin/base_controller.rb +6 -0
  8. data/app/controllers/spree/admin/option_values_controller.rb +9 -0
  9. data/app/controllers/spree/admin/reports_controller.rb +0 -6
  10. data/app/helpers/spree/admin/bulk_operations_helper.rb +5 -3
  11. data/app/helpers/spree/admin/navigation_helper.rb +10 -4
  12. data/app/javascript/spree/admin/application.js +2 -0
  13. data/app/javascript/spree/admin/controllers/admin_controller.js +18 -0
  14. data/app/views/kaminari/admin-twitter-bootstrap-4/_first_page.html.erb +3 -5
  15. data/app/views/kaminari/admin-twitter-bootstrap-4/_last_page.html.erb +3 -5
  16. data/app/views/kaminari/admin-twitter-bootstrap-4/_next_page.html.erb +4 -5
  17. data/app/views/kaminari/admin-twitter-bootstrap-4/_paginator.html.erb +1 -1
  18. data/app/views/kaminari/admin-twitter-bootstrap-4/_prev_page.html.erb +4 -5
  19. data/app/views/layouts/spree/admin.html.erb +4 -1
  20. data/app/views/spree/admin/admin_users/index.html.erb +6 -0
  21. data/app/views/spree/admin/admin_users/show.html.erb +2 -1
  22. data/app/views/spree/admin/coupon_codes/index.html.erb +6 -0
  23. data/app/views/spree/admin/custom_domains/index.html.erb +4 -3
  24. data/app/views/spree/admin/customer_returns/index.html.erb +6 -0
  25. data/app/views/spree/admin/digital_assets/index.html.erb +3 -0
  26. data/app/views/spree/admin/exports/index.html.erb +6 -0
  27. data/app/views/spree/admin/gift_cards/_filters.html.erb +2 -0
  28. data/app/views/spree/admin/gift_cards/index.html.erb +3 -0
  29. data/app/views/spree/admin/integrations/index.html.erb +6 -0
  30. data/app/views/spree/admin/invitations/index.html.erb +6 -0
  31. data/app/views/spree/admin/oauth_applications/index.html.erb +3 -0
  32. data/app/views/spree/admin/option_types/index.html.erb +3 -0
  33. data/app/views/spree/admin/orders/index.html.erb +3 -0
  34. data/app/views/spree/admin/pages/index.html.erb +3 -0
  35. data/app/views/spree/admin/payment_methods/edit.html.erb +1 -1
  36. data/app/views/spree/admin/payment_methods/index.html.erb +6 -0
  37. data/app/views/spree/admin/post_categories/index.html.erb +4 -1
  38. data/app/views/spree/admin/posts/_filters.html.erb +1 -0
  39. data/app/views/spree/admin/posts/index.html.erb +4 -3
  40. data/app/views/spree/admin/products/_bulk_operations.html.erb +3 -2
  41. data/app/views/spree/admin/products/form/_variants.html.erb +1 -1
  42. data/app/views/spree/admin/products/index.html.erb +10 -1
  43. data/app/views/spree/admin/profile/edit.html.erb +1 -1
  44. data/app/views/spree/admin/promotions/_filters.html.erb +1 -1
  45. data/app/views/spree/admin/promotions/_header.html.erb +2 -6
  46. data/app/views/spree/admin/promotions/index.html.erb +3 -0
  47. data/app/views/spree/admin/properties/index.html.erb +3 -0
  48. data/app/views/spree/admin/refund_reasons/index.html.erb +6 -3
  49. data/app/views/spree/admin/reimbursement_types/index.html.erb +6 -3
  50. data/app/views/spree/admin/reports/index.html.erb +6 -0
  51. data/app/views/spree/admin/return_authorization_reasons/index.html.erb +6 -3
  52. data/app/views/spree/admin/return_authorizations/index.html.erb +6 -0
  53. data/app/views/spree/admin/roles/_form.html.erb +1 -1
  54. data/app/views/spree/admin/roles/index.html.erb +5 -2
  55. data/app/views/spree/admin/roles/new.html.erb +12 -9
  56. data/app/views/spree/admin/shared/_content_header.html.erb +3 -2
  57. data/app/views/spree/admin/shared/_edit_resource_links.html.erb +1 -1
  58. data/app/views/spree/admin/shared/_header.html.erb +4 -3
  59. data/app/views/spree/admin/shared/_new_resource_links.html.erb +1 -1
  60. data/app/views/spree/admin/shared/_returns_and_refunds_nav.html.erb +1 -0
  61. data/app/views/spree/admin/shared/_shipping_nav.html.erb +1 -0
  62. data/app/views/spree/admin/shared/_stock_nav.html.erb +1 -0
  63. data/app/views/spree/admin/shared/_team_nav.html.erb +1 -0
  64. data/app/views/spree/admin/shared/sidebar/_integrations_nav.html.erb +1 -3
  65. data/app/views/spree/admin/shared/sidebar/_products_nav.html.erb +15 -16
  66. data/app/views/spree/admin/shared/sidebar/_promotions_nav.html.erb +4 -14
  67. data/app/views/spree/admin/shared/sidebar/_returns_nav.html.erb +1 -0
  68. data/app/views/spree/admin/shared/sidebar/_store_nav.html.erb +10 -30
  69. data/app/views/spree/admin/shared/sidebar/_storefront_nav.html.erb +18 -20
  70. data/app/views/spree/admin/shared/sidebar/_vendors_nav.html.erb +11 -7
  71. data/app/views/spree/admin/shipping_categories/index.html.erb +3 -0
  72. data/app/views/spree/admin/shipping_methods/index.html.erb +8 -1
  73. data/app/views/spree/admin/stock_items/_filters.html.erb +1 -1
  74. data/app/views/spree/admin/stock_items/index.html.erb +6 -0
  75. data/app/views/spree/admin/stock_locations/index.html.erb +3 -0
  76. data/app/views/spree/admin/stock_transfers/_filters.html.erb +1 -0
  77. data/app/views/spree/admin/stock_transfers/index.html.erb +3 -0
  78. data/app/views/spree/admin/store_credit_categories/index.html.erb +3 -0
  79. data/app/views/spree/admin/store_credits/index.html.erb +3 -0
  80. data/app/views/spree/admin/stores/edit.html.erb +1 -1
  81. data/app/views/spree/admin/tax_categories/index.html.erb +3 -0
  82. data/app/views/spree/admin/tax_rates/index.html.erb +3 -0
  83. data/app/views/spree/admin/taxonomies/index.html.erb +3 -0
  84. data/app/views/spree/admin/themes/index.html.erb +3 -0
  85. data/app/views/spree/admin/users/_filters.html.erb +1 -0
  86. data/app/views/spree/admin/users/index.html.erb +5 -2
  87. data/app/views/spree/admin/webhooks_subscribers/index.html.erb +5 -2
  88. data/app/views/spree/admin/zones/index.html.erb +3 -0
  89. data/lib/spree/admin/engine.rb +111 -37
  90. metadata +9 -11
  91. data/app/views/spree/admin/products/_index_header.html.erb +0 -7
  92. data/app/views/spree/admin/shared/sidebar/_custom_nav.html.erb +0 -0
  93. data/app/views/spree/admin/shipping_methods/_actions.html.erb +0 -5
@@ -1,10 +1,11 @@
1
- <% content_for :page_actions do %>
2
- <%= render 'extra_actions' %>
1
+ <%= render 'spree/admin/shared/posts_tabs' %>
3
2
 
3
+ <% content_for :page_actions do %>
4
+ <%= render_admin_partials(:posts_actions_partials) %>
4
5
  <%= link_to_with_icon 'plus', Spree.t(:new_post), new_object_url, class: 'btn btn-primary' if can?(:create, Spree::Post) %>
5
6
  <% end %>
6
7
 
7
- <%= render 'spree/admin/shared/posts_tabs' %>
8
+ <%= render_admin_partials(:posts_header_partials) %>
8
9
 
9
10
  <div class="card-lg">
10
11
  <%= render "spree/admin/posts/filters" %>
@@ -1,5 +1,7 @@
1
1
  <div id="bulk-panel" class="d-none" data-bulk-operation-target="panel">
2
2
  <div class="bulk-panel-container">
3
+ <%= bulk_operations_counter %>
4
+
3
5
  <% if can?(:activate, Spree::Product) %>
4
6
  <%= bulk_action_link(
5
7
  Spree.t("admin.bulk_ops.products.title.set_status", status: :active),
@@ -20,7 +22,7 @@
20
22
  <button
21
23
  type="button"
22
24
  data-display="static"
23
- class="btn btn-light px-2 h-100"
25
+ class="btn btn-light"
24
26
  data-placement="bottom"
25
27
  data-toggle="dropdown"
26
28
  aria-expanded="false"
@@ -81,7 +83,6 @@
81
83
  </div>
82
84
  </div>
83
85
 
84
- <%= bulk_operations_counter %>
85
86
  <%= bulk_operations_close_button %>
86
87
  </div>
87
88
  </div>
@@ -56,7 +56,7 @@
56
56
  <label class="label" for="new_option_name"><%= Spree.t(:option_name) %></label>
57
57
  <%= tom_select_tag :new_option_name,
58
58
  multiple: false,
59
- create: true,
59
+ create: can?(:create, Spree::OptionType),
60
60
  preloaded_options: option_types_for_select,
61
61
  include_blank: true,
62
62
  select_data: {
@@ -1,4 +1,13 @@
1
- <%= render 'index_header' %>
1
+ <% content_for :page_title do %>
2
+ <%= Spree.t(:products) %>
3
+ <% end %>
4
+
5
+ <% content_for :page_actions do %>
6
+ <%= render_admin_partials(:products_actions_partials) %>
7
+ <%= link_to_with_icon 'plus', Spree.t(:new_product), new_object_url, class: 'btn btn-primary' if can?(:create, Spree::Product) %>
8
+ <% end %>
9
+
10
+ <%= render_admin_partials(:products_header_partials) %>
2
11
 
3
12
  <div class="card-lg">
4
13
  <% if params[:frame_name].present? %>
@@ -3,7 +3,7 @@
3
3
  <% end %>
4
4
 
5
5
  <%= content_for :page_actions do %>
6
- <%= turbo_save_button_tag Spree.t('actions.update'), form: 'edit_user' %>
6
+ <%= turbo_save_button_tag Spree.t('actions.update'), form: 'edit_user', data: { admin_target: 'save' } %>
7
7
  <% end %>
8
8
 
9
9
  <%= form_for @user, url: spree.admin_profile_path, method: :put, as: :user do |f| %>
@@ -13,7 +13,7 @@
13
13
  </div>
14
14
  </div>
15
15
  </div>
16
-
16
+ <%= render_admin_partials(:promotions_filters_partials, f: f) %>
17
17
  <%= render 'spree/admin/shared/filter_submit' %>
18
18
  </div>
19
19
 
@@ -5,10 +5,6 @@
5
5
  <% end %>
6
6
 
7
7
  <% content_for :page_tabs do %>
8
- <li class="nav-item">
9
- <%= active_link_to Spree.t(:settings), spree.admin_promotion_path(@promotion), class: "nav-link", active: controller_name == 'promotions' %>
10
- </li>
11
- <li class="nav-item">
12
- <%= active_link_to Spree.t(:coupon_codes), spree.admin_promotion_coupon_codes_path(@promotion), class: "nav-link" %>
13
- </li>
8
+ <%= nav_item(Spree.t(:settings), spree.admin_promotion_path(@promotion), active: controller_name == 'promotions') %>
9
+ <%= nav_item(Spree.t(:coupon_codes), spree.admin_promotion_coupon_codes_path(@promotion)) %>
14
10
  <% end if @promotion.multi_codes? %>
@@ -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>
@@ -1,4 +1,4 @@
1
- <% record = @object || @customer_return || @order || @product || @vendor || @user || @taxon || @store_credit %>
1
+ <% record = @object || @customer_return || @order || @product || @vendor || @user || @admin_user || @taxon || @store_credit %>
2
2
  <% record = nil if @user&.is_a?(Spree.admin_user_class) %>
3
3
 
4
4
  <% show_record_subtitle = record && record.persisted? && record.has_attribute?(:updated_at) %>
@@ -24,7 +24,8 @@
24
24
  <%= yield :page_actions if content_for?(:page_actions) %>
25
25
 
26
26
  <% if action_name == 'edit' && @object %>
27
- <%= turbo_save_button_tag Spree.t('actions.update'), class: 'btn btn-primary', form: "edit_#{@object.class.name.demodulize.underscore}_#{@object.id}" %>
27
+ <% class_name = defined?(model_class) ? model_class.to_s : @object.class.name %>
28
+ <%= turbo_save_button_tag Spree.t('actions.update'), class: 'btn btn-primary', form: "edit_#{class_name.demodulize.underscore}_#{@object.id}", data: { admin_target: 'save' } %>
28
29
  <% end %>
29
30
 
30
31
  <% if show_record_subtitle || content_for(:page_actions_dropdown) %>
@@ -1,7 +1,7 @@
1
1
  <% destroy_url = defined?(destroy_url) && destroy_url ? destroy_url : object_url(f.object) %>
2
2
 
3
3
  <div class="form-actions">
4
- <%= turbo_save_button_tag Spree.t('actions.update') %>
4
+ <%= turbo_save_button_tag Spree.t('actions.update'), data: { admin_target: 'save' } %>
5
5
  <% if f.object.can_be_deleted? && can?(:delete, f.object) %>
6
6
  <%= link_to Spree.t('actions.destroy'), destroy_url, data: { turbo_method: :delete, turbo_confirm: Spree.t(:are_you_sure_delete), turbo_frame: defined?(turbo_frame) ? turbo_frame : '_top' }, class: 'btn btn-danger ml-auto' %>
7
7
  <% end %>
@@ -11,9 +11,10 @@
11
11
  </div>
12
12
 
13
13
  <% if settings_active? %>
14
- <div class="store-dropdown px-2">
15
- <%= active_link_to_with_icon('arrow-left', Spree.t('admin.back_to_dashboard'), spree.admin_dashboard_path, class: 'btn store-dropdown-button w-100 justify-content-start mx-1 py-2') %>
16
- </div>
14
+ <%= link_to spree.admin_path, class: 'store-dropdown text-decoration-none px-2 justify-content-start with-tip', title: Spree.t('admin.back_to_dashboard'), data: { admin_target: 'close' } do %>
15
+ <%= icon 'x', class: 'mx-2' %>
16
+ <kbd>ESC</kbd>
17
+ <% end %>
17
18
  <% else %>
18
19
  <% if defined?(current_vendor) && current_vendor.present? %>
19
20
  <%= render 'spree/admin/shared/sidebar/vendor_dropdown' %>
@@ -1,3 +1,3 @@
1
1
  <div class="form-actions">
2
- <%= turbo_save_button_tag Spree.t('actions.create') %>
2
+ <%= turbo_save_button_tag Spree.t('actions.create'), data: { admin_target: 'save' } %>
3
3
  </div>
@@ -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">