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.
- checksums.yaml +4 -4
- data/app/assets/stylesheets/spree/admin/components/_bulk_panel.scss +11 -1
- data/app/assets/stylesheets/spree/admin/components/_cards.scss +3 -4
- data/app/assets/stylesheets/spree/admin/components/_dropdowns.scss +1 -1
- data/app/assets/stylesheets/spree/admin/components/_main.scss +22 -5
- data/app/assets/stylesheets/spree/admin/components/_modals.scss +1 -1
- data/app/assets/stylesheets/spree/admin/global/_variables.scss +8 -2
- data/app/assets/stylesheets/spree/admin/shared/_base.scss +12 -1
- data/app/controllers/spree/admin/dashboard_controller.rb +4 -1
- data/app/controllers/spree/admin/products_controller.rb +1 -8
- data/app/controllers/spree/admin/storefront_controller.rb +1 -1
- data/app/controllers/spree/admin/translations_controller.rb +1 -1
- data/app/helpers/spree/admin/base_helper.rb +69 -63
- data/app/helpers/spree/admin/bulk_operations_helper.rb +86 -0
- data/app/helpers/spree/admin/modal_helper.rb +29 -0
- data/app/helpers/spree/admin/navigation_helper.rb +89 -11
- data/app/helpers/spree/admin/orders_helper.rb +0 -19
- data/app/helpers/spree/admin/stores_helper.rb +8 -36
- data/app/helpers/spree/admin/webhooks_subscribers_helper.rb +1 -1
- data/app/javascript/spree/admin/controllers/variants_form_controller.js +10 -3
- data/app/views/active_storage/_upload_form.html.erb +4 -8
- data/app/views/layouts/spree/admin.html.erb +4 -0
- data/app/views/spree/admin/assets/edit.html.erb +3 -8
- data/app/views/spree/admin/coupon_codes/index.html.erb +4 -6
- data/app/views/spree/admin/custom_domains/_custom_domains.html.erb +1 -1
- data/app/views/spree/admin/custom_domains/index.html.erb +1 -1
- data/app/views/spree/admin/customer_returns/index.html.erb +4 -17
- data/app/views/spree/admin/dashboard/_setup_progress.html.erb +4 -2
- data/app/views/spree/admin/dashboard/_sidebar.html.erb +2 -0
- data/app/views/spree/admin/dashboard/_top_products.html.erb +34 -24
- data/app/views/spree/admin/dashboard/analytics.html.erb +3 -1
- data/app/views/spree/admin/dashboard/show.html.erb +4 -8
- data/app/views/spree/admin/digital_assets/_table.html.erb +1 -1
- data/app/views/spree/admin/digital_assets/edit.html.erb +3 -11
- data/app/views/spree/admin/digital_assets/new.html.erb +3 -11
- data/app/views/spree/admin/exports/index.html.erb +22 -24
- data/app/views/spree/admin/exports/new.html.erb +3 -9
- data/app/views/spree/admin/line_items/new.html.erb +2 -5
- data/app/views/spree/admin/oauth_applications/index.html.erb +57 -58
- data/app/views/spree/admin/option_types/_filter.html.erb +1 -1
- data/app/views/spree/admin/option_types/index.html.erb +7 -11
- data/app/views/spree/admin/orders/_customer_summary.html.erb +0 -2
- data/app/views/spree/admin/orders/_filters.html.erb +3 -8
- data/app/views/spree/admin/orders/_header.html.erb +2 -0
- data/app/views/spree/admin/orders/_list.html.erb +2 -4
- data/app/views/spree/admin/orders/_summary.html.erb +1 -1
- data/app/views/spree/admin/orders/billing_address/create.turbo_stream.erb +3 -6
- data/app/views/spree/admin/orders/billing_address/edit.html.erb +3 -6
- data/app/views/spree/admin/orders/billing_address/new.html.erb +3 -6
- data/app/views/spree/admin/orders/billing_address/update.turbo_stream.erb +3 -6
- data/app/views/spree/admin/orders/contact_information/edit.html.erb +3 -6
- data/app/views/spree/admin/orders/customer_returns/edit.html.erb +1 -10
- data/app/views/spree/admin/orders/edit.html.erb +3 -5
- data/app/views/spree/admin/orders/index.html.erb +1 -1
- data/app/views/spree/admin/orders/return_authorizations/_form.html.erb +1 -1
- data/app/views/spree/admin/orders/return_authorizations/show.html.erb +45 -43
- data/app/views/spree/admin/orders/shipping_address/create.turbo_stream.erb +3 -6
- data/app/views/spree/admin/orders/shipping_address/edit.html.erb +3 -6
- data/app/views/spree/admin/orders/shipping_address/new.html.erb +3 -6
- data/app/views/spree/admin/orders/shipping_address/update.turbo_stream.erb +3 -6
- data/app/views/spree/admin/pages/_filters.html.erb +1 -1
- data/app/views/spree/admin/pages/edit.html.erb +2 -5
- data/app/views/spree/admin/pages/index.html.erb +4 -4
- data/app/views/spree/admin/payment_methods/index.html.erb +10 -8
- data/app/views/spree/admin/post_categories/index.html.erb +4 -6
- data/app/views/spree/admin/posts/_filters.html.erb +2 -7
- data/app/views/spree/admin/posts/_post.html.erb +1 -11
- data/app/views/spree/admin/posts/index.html.erb +5 -9
- data/app/views/spree/admin/products/_bulk_operations.html.erb +59 -94
- data/app/views/spree/admin/products/_filters.html.erb +13 -8
- data/app/views/spree/admin/products/_form.html.erb +3 -3
- data/app/views/spree/admin/products/_list.html.erb +2 -10
- data/app/views/spree/admin/products/_product.html.erb +1 -4
- data/app/views/spree/admin/products/bulk_modal.html.erb +3 -8
- data/app/views/spree/admin/products/edit.html.erb +3 -0
- data/app/views/spree/admin/products/form/_variants.html.erb +1 -0
- data/app/views/spree/admin/products/index.html.erb +5 -5
- data/app/views/spree/admin/promotion_actions/new.html.erb +7 -12
- data/app/views/spree/admin/promotion_rules/new.html.erb +7 -12
- data/app/views/spree/admin/promotions/_filters.html.erb +27 -0
- data/app/views/spree/admin/promotions/index.html.erb +7 -35
- data/app/views/spree/admin/properties/index.html.erb +10 -9
- data/app/views/spree/admin/refund_reasons/index.html.erb +37 -35
- data/app/views/spree/admin/refunds/edit.html.erb +3 -8
- data/app/views/spree/admin/reimbursement_types/index.html.erb +42 -40
- data/app/views/spree/admin/reports/_report.html.erb +1 -1
- data/app/views/spree/admin/return_authorization_reasons/index.html.erb +41 -41
- data/app/views/spree/admin/return_authorizations/_filters.html.erb +1 -1
- data/app/views/spree/admin/return_authorizations/_list.html.erb +1 -10
- data/app/views/spree/admin/return_authorizations/index.html.erb +1 -1
- data/app/views/spree/admin/roles/_form.html.erb +1 -1
- data/app/views/spree/admin/roles/index.html.erb +26 -24
- data/app/views/spree/admin/shared/_bulk_modal.html.erb +6 -7
- data/app/views/spree/admin/shared/_developers_nav.html.erb +2 -2
- data/app/views/spree/admin/shared/_filter_submit.html.erb +6 -0
- data/app/views/spree/admin/shared/_head.html.erb +3 -1
- data/app/views/spree/admin/shared/_modal.html.erb +2 -8
- data/app/views/spree/admin/shared/_multi_product_picker.html.erb +2 -4
- data/app/views/spree/admin/shared/_no_resource_found.html.erb +1 -1
- data/app/views/spree/admin/shared/_posts_tabs.html.erb +2 -2
- data/app/views/spree/admin/shared/_product_image.html.erb +1 -10
- data/app/views/spree/admin/shared/_refunds.html.erb +1 -1
- data/app/views/spree/admin/shared/_returns_and_refunds_nav.html.erb +3 -3
- data/app/views/spree/admin/shared/_shipping_nav.html.erb +2 -2
- data/app/views/spree/admin/shared/_stock_nav.html.erb +2 -2
- data/app/views/spree/admin/shared/_tax_nav.html.erb +2 -2
- data/app/views/spree/admin/shared/_user.html.erb +2 -2
- data/app/views/spree/admin/shared/_user_dropdown.html.erb +2 -2
- data/app/views/spree/admin/shared/sidebar/_orders_nav.html.erb +19 -29
- data/app/views/spree/admin/shared/sidebar/_products_nav.html.erb +6 -25
- data/app/views/spree/admin/shared/sidebar/_returns_nav.html.erb +8 -15
- data/app/views/spree/admin/shared/sidebar/_store_dropdown.html.erb +36 -7
- data/app/views/spree/admin/shared/sidebar/_store_nav.html.erb +28 -52
- data/app/views/spree/admin/shared/sidebar/_storefront_nav.html.erb +19 -26
- data/app/views/spree/admin/shared/sortable_tree/_taxonomy.html.erb +3 -23
- data/app/views/spree/admin/shipping_categories/index.html.erb +28 -26
- data/app/views/spree/admin/shipping_methods/_actions.html.erb +1 -1
- data/app/views/spree/admin/shipping_methods/index.html.erb +23 -21
- data/app/views/spree/admin/stock_items/_filters.html.erb +2 -7
- data/app/views/spree/admin/stock_items/index.html.erb +5 -8
- data/app/views/spree/admin/stock_locations/_stock_location.html.erb +16 -13
- data/app/views/spree/admin/stock_locations/index.html.erb +24 -21
- data/app/views/spree/admin/stock_transfers/_filters.html.erb +1 -1
- data/app/views/spree/admin/stock_transfers/_new_variant_modal.html.erb +3 -5
- data/app/views/spree/admin/stock_transfers/index.html.erb +6 -6
- data/app/views/spree/admin/store_credit_categories/_form.html.erb +1 -1
- data/app/views/spree/admin/store_credit_categories/edit.html.erb +6 -4
- data/app/views/spree/admin/store_credit_categories/index.html.erb +28 -24
- data/app/views/spree/admin/store_credits/index.html.erb +2 -2
- data/app/views/spree/admin/storefront/edit.html.erb +7 -9
- data/app/views/spree/admin/stores/form/_basic.html.erb +2 -2
- data/app/views/spree/admin/stores/form/_policies.html.erb +1 -1
- data/app/views/spree/admin/stores/new.html.erb +8 -6
- data/app/views/spree/admin/tax_categories/index.html.erb +24 -22
- data/app/views/spree/admin/tax_rates/index.html.erb +26 -24
- data/app/views/spree/admin/taxonomies/index.html.erb +4 -4
- data/app/views/spree/admin/taxonomies/show.html.erb +2 -2
- data/app/views/spree/admin/themes/_theme_preview_image.html.erb +1 -10
- data/app/views/spree/admin/themes/index.html.erb +2 -2
- data/app/views/spree/admin/translations/_translations_unavailable.html.erb +6 -8
- data/app/views/spree/admin/users/_filters.html.erb +2 -7
- data/app/views/spree/admin/users/_tabs.html.erb +4 -4
- data/app/views/spree/admin/users/_user.html.erb +1 -4
- data/app/views/spree/admin/users/bulk_modal.html.erb +3 -8
- data/app/views/spree/admin/users/index.html.erb +25 -58
- data/app/views/spree/admin/variants/_variant.html.erb +8 -2
- data/app/views/spree/admin/variants/form/_media_asset.html.erb +1 -7
- data/app/views/spree/admin/variants/form/_pricing.html.erb +5 -4
- data/app/views/spree/admin/webhooks_subscribers/_form.html.erb +1 -1
- data/app/views/spree/admin/webhooks_subscribers/index.html.erb +25 -22
- data/app/views/spree/admin/webhooks_subscribers/show.html.erb +3 -3
- data/app/views/spree/admin/zones/index.html.erb +34 -32
- data/config/locales/en.yml +1 -46
- data/lib/spree/admin/engine.rb +50 -0
- metadata +13 -14
- data/app/views/spree/admin/orders/_extra_filters.html.erb +0 -0
- data/app/views/spree/admin/products/_empty_list.html.erb +0 -1
- data/app/views/spree/admin/products/form/_extra_filters.html.erb +0 -0
- data/app/views/spree/admin/products/form/_extra_form.html.erb +0 -0
- data/app/views/spree/admin/products/form/_extra_form_sidebar.erb +0 -0
- 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
|
-
<%=
|
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
|
9
|
+
<%= render 'spree/admin/shared/tax_nav' %>
|
10
10
|
|
11
|
-
|
12
|
-
|
13
|
-
<
|
14
|
-
<
|
15
|
-
<
|
16
|
-
<
|
17
|
-
|
18
|
-
|
19
|
-
|
20
|
-
|
21
|
-
|
22
|
-
|
23
|
-
|
24
|
-
|
25
|
-
|
26
|
-
|
27
|
-
|
28
|
-
|
29
|
-
|
30
|
-
|
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
|
-
<%=
|
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
|
9
|
+
<%= render 'spree/admin/shared/tax_nav' %>
|
10
10
|
|
11
|
-
|
12
|
-
|
13
|
-
<
|
14
|
-
<
|
15
|
-
<
|
16
|
-
<
|
17
|
-
|
18
|
-
|
19
|
-
|
20
|
-
|
21
|
-
|
22
|
-
|
23
|
-
|
24
|
-
|
25
|
-
|
26
|
-
|
27
|
-
|
28
|
-
|
29
|
-
|
30
|
-
|
31
|
-
|
32
|
-
|
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
|
-
<%=
|
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
|
10
|
-
<%= search_form_for [:admin, @search], class: "filter-wrap
|
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
|
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
|
-
<%=
|
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
|
-
<%=
|
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
|
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
|
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="
|
2
|
-
<div class="card">
|
3
|
-
<
|
4
|
-
|
5
|
-
|
6
|
-
|
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
|
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
|
-
|
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
|
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
|
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
|
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
|
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
|
-
|
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
|
-
|
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
|
17
|
-
|
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
|
-
|
15
|
-
|
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
|
16
|
+
<div class="card-lg">
|
19
17
|
<%= render "spree/admin/users/filters" %>
|
20
18
|
|
21
|
-
<% if @
|
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
|
27
|
-
|
28
|
-
|
29
|
-
|
30
|
-
|
31
|
-
|
32
|
-
|
33
|
-
|
34
|
-
|
35
|
-
|
36
|
-
|
37
|
-
|
38
|
-
|
39
|
-
|
40
|
-
|
41
|
-
|
42
|
-
|
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
|
-
|
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: @
|
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
|
-
|
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
|
-
<%=
|
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(
|
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
|
-
<%=
|
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
|
-
|
7
|
-
|
8
|
-
|
9
|
-
|
10
|
-
|
11
|
-
|
12
|
-
<
|
13
|
-
|
14
|
-
|
15
|
-
|
16
|
-
|
17
|
-
|
18
|
-
|
19
|
-
|
20
|
-
|
21
|
-
|
22
|
-
|
23
|
-
|
24
|
-
|
25
|
-
|
26
|
-
<%
|
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(
|
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(
|
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
|
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">
|