spree_admin 5.0.4 → 5.1.0.beta2
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/images/login_sidebar_background.png +0 -0
- data/app/assets/stylesheets/spree/admin/components/_bulk_panel.scss +8 -1
- data/app/assets/stylesheets/spree/admin/components/_buttons.scss +12 -20
- data/app/assets/stylesheets/spree/admin/components/_cards.scss +9 -3
- data/app/assets/stylesheets/spree/admin/components/_dropdowns.scss +13 -40
- data/app/assets/stylesheets/spree/admin/components/_filters.scss +32 -3
- data/app/assets/stylesheets/spree/admin/components/_main.scss +107 -31
- data/app/assets/stylesheets/spree/admin/components/_media_form.scss +21 -9
- data/app/assets/stylesheets/spree/admin/components/_modals.scss +4 -3
- data/app/assets/stylesheets/spree/admin/components/_navbar.scss +5 -9
- data/app/assets/stylesheets/spree/admin/components/_navigation.scss +0 -1
- data/app/assets/stylesheets/spree/admin/components/_sortable_tree.scss +6 -2
- data/app/assets/stylesheets/spree/admin/components/_tables.scss +35 -5
- data/app/assets/stylesheets/spree/admin/global/_variables.scss +37 -17
- data/app/assets/stylesheets/spree/admin/plugins/tom-select.bootstrap4.scss +5 -4
- data/app/assets/stylesheets/spree/admin/shared/_base.scss +50 -17
- data/app/assets/stylesheets/spree/admin/shared/_forms.scss +6 -2
- data/app/assets/stylesheets/spree/admin/views/_page_builder.scss +30 -21
- data/app/controllers/concerns/spree/admin/breadcrumb_concern.rb +22 -0
- data/app/controllers/concerns/spree/admin/preferences_concern.rb +22 -0
- data/app/controllers/concerns/spree/admin/products_breadcrumb_concern.rb +22 -0
- data/app/controllers/concerns/spree/admin/promotions_breadcrumb_concern.rb +23 -0
- data/app/controllers/concerns/spree/admin/storefront_breadcrumb_concern.rb +12 -0
- data/app/controllers/spree/admin/addresses_controller.rb +4 -0
- data/app/controllers/spree/admin/admin_users_controller.rb +112 -0
- data/app/controllers/spree/admin/assets_controller.rb +7 -9
- data/app/controllers/spree/admin/base_controller.rb +21 -10
- data/app/controllers/spree/admin/checkouts_controller.rb +4 -0
- data/app/controllers/spree/admin/classifications_controller.rb +4 -0
- data/app/controllers/spree/admin/coupon_codes_controller.rb +2 -0
- data/app/controllers/spree/admin/custom_domains_controller.rb +6 -0
- data/app/controllers/spree/admin/customer_returns_controller.rb +4 -0
- data/app/controllers/spree/admin/dashboard_controller.rb +8 -2
- data/app/controllers/spree/admin/digital_assets_controller.rb +8 -0
- data/app/controllers/spree/admin/exports_controller.rb +6 -2
- data/app/controllers/spree/admin/integrations_controller.rb +61 -0
- data/app/controllers/spree/admin/invitations_controller.rb +128 -0
- data/app/controllers/spree/admin/line_items_controller.rb +4 -0
- data/app/controllers/spree/admin/oauth_applications_controller.rb +6 -0
- data/app/controllers/spree/admin/option_types_controller.rb +15 -0
- data/app/controllers/spree/admin/option_values_controller.rb +4 -0
- data/app/controllers/spree/admin/orders/return_authorizations_controller.rb +4 -0
- data/app/controllers/spree/admin/orders_controller.rb +11 -0
- data/app/controllers/spree/admin/page_blocks_controller.rb +9 -2
- data/app/controllers/spree/admin/page_links_controller.rb +9 -0
- data/app/controllers/spree/admin/page_sections_controller.rb +13 -4
- data/app/controllers/spree/admin/pages_controller.rb +7 -0
- data/app/controllers/spree/admin/payment_methods_controller.rb +23 -12
- data/app/controllers/spree/admin/post_categories_controller.rb +3 -0
- data/app/controllers/spree/admin/posts_controller.rb +11 -0
- data/app/controllers/spree/admin/products_controller.rb +11 -8
- data/app/controllers/spree/admin/promotion_actions_controller.rb +10 -2
- data/app/controllers/spree/admin/promotion_rules_controller.rb +10 -2
- data/app/controllers/spree/admin/promotions_controller.rb +6 -0
- data/app/controllers/spree/admin/properties_controller.rb +15 -0
- data/app/controllers/spree/admin/refund_reasons_controller.rb +7 -0
- data/app/controllers/spree/admin/refunds_controller.rb +4 -0
- data/app/controllers/spree/admin/reimbursement_types_controller.rb +7 -0
- data/app/controllers/spree/admin/reimbursements_controller.rb +4 -0
- data/app/controllers/spree/admin/reports_controller.rb +12 -2
- data/app/controllers/spree/admin/resource_controller.rb +1 -1
- data/app/controllers/spree/admin/return_authorization_reasons_controller.rb +7 -0
- data/app/controllers/spree/admin/return_authorizations_controller.rb +4 -0
- data/app/controllers/spree/admin/return_items_controller.rb +6 -0
- data/app/controllers/spree/admin/role_users_controller.rb +36 -0
- data/app/controllers/spree/admin/roles_controller.rb +8 -0
- data/app/controllers/spree/admin/shipments_controller.rb +2 -2
- data/app/controllers/spree/admin/shipping_categories_controller.rb +7 -0
- data/app/controllers/spree/admin/shipping_methods_controller.rb +6 -0
- data/app/controllers/spree/admin/stock_items_controller.rb +13 -0
- data/app/controllers/spree/admin/stock_locations_controller.rb +7 -0
- data/app/controllers/spree/admin/stock_transfers_controller.rb +14 -2
- data/app/controllers/spree/admin/store_credit_categories_controller.rb +5 -0
- data/app/controllers/spree/admin/store_credits_controller.rb +4 -0
- data/app/controllers/spree/admin/storefront_controller.rb +3 -0
- data/app/controllers/spree/admin/stores_controller.rb +17 -2
- data/app/controllers/spree/admin/tax_categories_controller.rb +7 -0
- data/app/controllers/spree/admin/tax_rates_controller.rb +6 -0
- data/app/controllers/spree/admin/taxonomies_controller.rb +15 -0
- data/app/controllers/spree/admin/taxons_controller.rb +24 -1
- data/app/controllers/spree/admin/themes_controller.rb +7 -0
- data/app/controllers/spree/admin/translations_controller.rb +9 -1
- data/app/controllers/spree/admin/user_passwords_controller.rb +22 -0
- data/app/controllers/spree/admin/user_sessions_controller.rb +23 -0
- data/app/controllers/spree/admin/users_controller.rb +11 -2
- data/app/controllers/spree/admin/variants_controller.rb +13 -0
- data/app/controllers/spree/admin/webhooks_subscribers_controller.rb +3 -0
- data/app/controllers/spree/admin/zones_controller.rb +5 -0
- data/app/helpers/spree/admin/base_helper.rb +32 -31
- data/app/helpers/spree/admin/bulk_operations_helper.rb +8 -2
- data/app/helpers/spree/admin/modal_helper.rb +1 -1
- data/app/helpers/spree/admin/navigation_helper.rb +11 -5
- data/app/helpers/spree/admin/posts_helper.rb +1 -1
- data/app/helpers/spree/admin/session_assets_helper.rb +1 -1
- data/app/helpers/spree/admin/stores_helper.rb +1 -18
- data/app/helpers/spree/admin/tags_helper.rb +2 -2
- data/app/javascript/spree/admin/application.js +2 -0
- data/app/javascript/spree/admin/helpers/bootstrap.js +3 -3
- data/app/views/active_storage/_upload_form.html.erb +1 -1
- data/app/views/layouts/spree/minimal.html.erb +22 -0
- data/app/views/spree/admin/admin_users/_admin_user.html.erb +19 -0
- data/app/views/spree/admin/admin_users/_audit_log.html.erb +5 -0
- data/app/views/spree/admin/admin_users/_form.html.erb +12 -0
- data/app/views/spree/admin/admin_users/edit.html.erb +35 -0
- data/app/views/spree/admin/admin_users/index.html.erb +18 -0
- data/app/views/spree/admin/admin_users/new.html.erb +21 -0
- data/app/views/spree/admin/admin_users/show.html.erb +113 -0
- data/app/views/spree/admin/coupon_codes/index.html.erb +6 -6
- data/app/views/spree/admin/custom_domains/_custom_domains.html.erb +1 -1
- data/app/views/spree/admin/customer_returns/index.html.erb +1 -1
- data/app/views/spree/admin/dashboard/_store_preview.html.erb +1 -1
- data/app/views/spree/admin/dashboard/_top_products.html.erb +4 -2
- data/app/views/spree/admin/digital_assets/_table.html.erb +1 -1
- data/app/views/spree/admin/digital_assets/index.html.erb +0 -1
- data/app/views/spree/admin/exports/index.html.erb +1 -1
- data/app/views/spree/admin/integrations/_integration.html.erb +36 -0
- data/app/views/spree/admin/integrations/edit.html.erb +11 -0
- data/app/views/spree/admin/integrations/index.html.erb +23 -0
- data/app/views/spree/admin/integrations/new.html.erb +14 -0
- data/app/views/spree/admin/invitations/_invitation.html.erb +52 -0
- data/app/views/spree/admin/invitations/create.turbo_stream.erb +4 -0
- data/app/views/spree/admin/invitations/index.html.erb +21 -0
- data/app/views/spree/admin/invitations/new.html.erb +32 -0
- data/app/views/spree/admin/invitations/show.html.erb +9 -0
- data/app/views/spree/admin/line_items/new.html.erb +2 -2
- data/app/views/spree/admin/oauth_applications/index.html.erb +1 -1
- data/app/views/spree/admin/option_types/edit.html.erb +1 -1
- data/app/views/spree/admin/option_types/index.html.erb +1 -1
- data/app/views/spree/admin/orders/_customer.html.erb +1 -2
- data/app/views/spree/admin/orders/_filters.html.erb +17 -21
- data/app/views/spree/admin/orders/_list.html.erb +1 -1
- data/app/views/spree/admin/orders/_refunds.html.erb +1 -1
- data/app/views/spree/admin/orders/_shipment.html.erb +1 -1
- data/app/views/spree/admin/orders/_table_filter_dropdown.html.erb +2 -2
- data/app/views/spree/admin/orders/customer_returns/_customer_return.html.erb +1 -1
- data/app/views/spree/admin/orders/customer_returns/_return_item_decision.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 +2 -2
- data/app/views/spree/admin/page_blocks/_form_tab_buttons.html.erb +5 -7
- data/app/views/spree/admin/page_blocks/edit.html.erb +3 -5
- data/app/views/spree/admin/page_builder/_add_block.html.erb +1 -1
- data/app/views/spree/admin/page_builder/_header.html.erb +35 -28
- data/app/views/spree/admin/page_builder/_pages_dropdown.html.erb +15 -21
- data/app/views/spree/admin/page_builder/_sidebar.html.erb +1 -1
- data/app/views/spree/admin/page_builder/_sidebar_block.html.erb +1 -1
- data/app/views/spree/admin/page_links/_list.html.erb +2 -2
- data/app/views/spree/admin/page_links/edit.html.erb +2 -4
- data/app/views/spree/admin/page_sections/_form_tab_buttons.html.erb +6 -10
- data/app/views/spree/admin/page_sections/new.html.erb +1 -1
- data/app/views/spree/admin/pages/edit.html.erb +2 -2
- data/app/views/spree/admin/payment_methods/index.html.erb +16 -15
- data/app/views/spree/admin/payments/_payment.html.erb +1 -1
- data/app/views/spree/admin/post_categories/index.html.erb +1 -1
- data/app/views/spree/admin/posts/index.html.erb +1 -1
- data/app/views/spree/admin/products/_bulk_operations.html.erb +1 -1
- data/app/views/spree/admin/products/_filters.html.erb +2 -5
- data/app/views/spree/admin/products/_list.html.erb +1 -1
- data/app/views/spree/admin/products/_table_filter_dropdown.html.erb +2 -2
- data/app/views/spree/admin/products/form/_categorization.html.erb +34 -30
- data/app/views/spree/admin/promotion_actions/_promotion_action.html.erb +1 -1
- data/app/views/spree/admin/promotion_rules/_promotion_rule.html.erb +1 -1
- data/app/views/spree/admin/promotions/_filters.html.erb +2 -6
- data/app/views/spree/admin/promotions/_header.html.erb +1 -3
- data/app/views/spree/admin/promotions/_sidebar.html.erb +18 -0
- data/app/views/spree/admin/promotions/_table_filter_dropdown.html.erb +2 -2
- data/app/views/spree/admin/promotions/index.html.erb +1 -1
- data/app/views/spree/admin/properties/edit.html.erb +1 -1
- data/app/views/spree/admin/properties/index.html.erb +1 -1
- data/app/views/spree/admin/refund_reasons/index.html.erb +1 -1
- data/app/views/spree/admin/reimbursement_types/_form.html.erb +22 -14
- data/app/views/spree/admin/reimbursement_types/index.html.erb +1 -1
- data/app/views/spree/admin/reimbursements/edit.html.erb +2 -2
- data/app/views/spree/admin/reimbursements/show.html.erb +1 -1
- data/app/views/spree/admin/reports/_report.html.erb +1 -1
- data/app/views/spree/admin/return_authorization_reasons/index.html.erb +1 -1
- data/app/views/spree/admin/return_authorizations/_filters.html.erb +2 -2
- data/app/views/spree/admin/return_authorizations/_list.html.erb +1 -1
- data/app/views/spree/admin/roles/edit.html.erb +6 -4
- data/app/views/spree/admin/roles/index.html.erb +11 -7
- data/app/views/spree/admin/shared/_alerts.html.erb +1 -1
- data/app/views/spree/admin/shared/_breadcrumbs.html.erb +13 -0
- data/app/views/spree/admin/shared/_calendar_range_picker.html.erb +1 -1
- data/app/views/spree/admin/shared/_content_header.html.erb +3 -3
- data/app/views/spree/admin/shared/_filters_button.html.erb +1 -1
- data/app/views/spree/admin/shared/_filters_search_bar.html.erb +1 -1
- data/app/views/spree/admin/shared/_header.html.erb +26 -17
- data/app/views/spree/admin/shared/_index_table_options.html.erb +1 -1
- data/app/views/spree/admin/shared/_multi_product_picker.html.erb +1 -1
- data/app/views/spree/admin/shared/_new_item_dropdown.html.erb +32 -0
- data/app/views/spree/admin/shared/_no_resource_found.html.erb +6 -3
- data/app/views/spree/admin/shared/_offcanvas_nav.html.erb +1 -14
- data/app/views/spree/admin/shared/_refunds.html.erb +1 -1
- data/app/views/spree/admin/shared/_sidebar.html.erb +0 -8
- data/app/views/spree/admin/shared/_team_nav.html.erb +13 -0
- data/app/views/spree/admin/shared/_user_dropdown.html.erb +25 -20
- data/app/views/spree/admin/shared/devise/_links.html.erb +18 -0
- data/app/views/spree/admin/shared/sidebar/_enterprise_edition_notice.html.erb +7 -5
- data/app/views/spree/admin/shared/sidebar/_integrations_nav.html.erb +5 -7
- data/app/views/spree/admin/shared/sidebar/_orders_nav.html.erb +2 -2
- data/app/views/spree/admin/shared/sidebar/_products_nav.html.erb +2 -2
- data/app/views/spree/admin/shared/sidebar/_promotions_nav.html.erb +17 -0
- data/app/views/spree/admin/shared/sidebar/_returns_nav.html.erb +1 -1
- data/app/views/spree/admin/shared/sidebar/_store_dropdown.html.erb +33 -75
- data/app/views/spree/admin/shared/sidebar/_store_nav.html.erb +14 -34
- data/app/views/spree/admin/shared/sidebar/_storefront_nav.html.erb +4 -2
- data/app/views/spree/admin/shared/sidebar/_vendors_nav.html.erb +9 -7
- data/app/views/spree/admin/shared/sortable_tree/_taxonomy.html.erb +1 -1
- data/app/views/spree/admin/shipping_categories/index.html.erb +1 -1
- data/app/views/spree/admin/shipping_methods/_form.html.erb +7 -134
- data/app/views/spree/admin/shipping_methods/form/_display.html.erb +25 -0
- data/app/views/spree/admin/shipping_methods/form/_estimated_transit_business_days.html.erb +23 -0
- data/app/views/spree/admin/shipping_methods/form/_shipping_categories.html.erb +21 -0
- data/app/views/spree/admin/shipping_methods/form/_tax_category.html.erb +16 -0
- data/app/views/spree/admin/shipping_methods/form/_tracking_url.html.erb +18 -0
- data/app/views/spree/admin/shipping_methods/form/_zones.html.erb +26 -0
- data/app/views/spree/admin/shipping_methods/index.html.erb +1 -1
- data/app/views/spree/admin/stock_items/index.html.erb +1 -1
- data/app/views/spree/admin/stock_locations/_stock_location.html.erb +5 -3
- data/app/views/spree/admin/stock_locations/index.html.erb +4 -2
- data/app/views/spree/admin/stock_transfers/index.html.erb +1 -1
- data/app/views/spree/admin/store_credit_categories/index.html.erb +1 -1
- data/app/views/spree/admin/store_credits/_list.html.erb +1 -1
- data/app/views/spree/admin/stores/edit_emails.html.erb +1 -1
- data/app/views/spree/admin/stores/form/_emails.html.erb +1 -1
- data/app/views/spree/admin/tax_categories/index.html.erb +1 -1
- data/app/views/spree/admin/tax_rates/index.html.erb +1 -1
- data/app/views/spree/admin/taxonomies/index.html.erb +1 -1
- data/app/views/spree/admin/themes/_theme.html.erb +6 -4
- data/app/views/spree/admin/themes/_theme_preview_image.html.erb +6 -4
- data/app/views/spree/admin/themes/index.html.erb +1 -1
- data/app/views/spree/admin/translations/edit.html.erb +1 -1
- data/app/views/spree/admin/user_passwords/edit.html.erb +21 -0
- data/app/views/spree/admin/user_passwords/new.html.erb +12 -0
- data/app/views/spree/admin/user_sessions/new.html.erb +16 -0
- data/app/views/spree/admin/users/_form.html.erb +9 -7
- data/app/views/spree/admin/users/_user.html.erb +4 -4
- data/app/views/spree/admin/users/index.html.erb +1 -1
- data/app/views/spree/admin/users/new.html.erb +1 -1
- data/app/views/spree/admin/variants/_search_result.html.erb +1 -1
- data/app/views/spree/admin/variants/form/_media_asset.html.erb +1 -1
- data/app/views/spree/admin/webhooks_subscribers/index.html.erb +1 -1
- data/app/views/spree/admin/zones/_form.html.erb +11 -15
- data/app/views/spree/admin/zones/index.html.erb +1 -1
- data/config/locales/en.yml +3 -0
- data/config/routes.rb +16 -4
- data/lib/spree/admin/engine.rb +4 -0
- data/lib/spree/admin.rb +3 -1
- metadata +64 -7
@@ -1,7 +1,7 @@
|
|
1
1
|
<%= turbo_frame_tag :set_customer_support_email, class: 'w-100' do %>
|
2
2
|
<%= form_for current_store, url: spree.admin_store_path, as: :store do |f| %>
|
3
3
|
<div class="form-group">
|
4
|
-
<%= f.label :customer_support_email,
|
4
|
+
<%= f.label :customer_support_email, Spree.t(:customer_support_email) %>
|
5
5
|
<%= f.email_field :customer_support_email, class: 'form-control', required: true %>
|
6
6
|
</div>
|
7
7
|
<div class="d-flex justify-content-between">
|
@@ -17,7 +17,7 @@
|
|
17
17
|
<% if @taxonomies.present? %>
|
18
18
|
<div class="table-responsive">
|
19
19
|
<table class="table" id='listing_taxonomies'>
|
20
|
-
<thead
|
20
|
+
<thead>
|
21
21
|
<tr data-hook="listing_taxonomies_header">
|
22
22
|
<th class="no-border handel-head"></th>
|
23
23
|
<th><%= Spree.t(:name) %></th>
|
@@ -1,13 +1,15 @@
|
|
1
1
|
<tr id="<%= spree_dom_id theme %>">
|
2
2
|
<td class="w-70 p-0">
|
3
3
|
<%= link_to theme.ready? ? spree.edit_admin_theme_path(theme) : '#', class: 'd-flex align-items-top p-3' do %>
|
4
|
-
|
4
|
+
<div class="w-20">
|
5
|
+
<%= render 'spree/admin/themes/theme_preview_image', theme: theme, css_class: 'img-thumbnail w-100' %>
|
6
|
+
</div>
|
5
7
|
|
6
|
-
<div class="d-flex flex-column ml-3">
|
8
|
+
<div class="d-flex flex-column ml-3 w-80">
|
7
9
|
<strong><%= theme.name %></strong>
|
8
10
|
<p class="mb-0 mt-1">
|
9
11
|
<span class="text-muted">
|
10
|
-
<%= Spree.t(:
|
12
|
+
<%= Spree.t(:updated_at) %>:
|
11
13
|
<%= local_time_ago(theme.updated_at, class: 'with-tip') %>
|
12
14
|
</span>
|
13
15
|
</p>
|
@@ -38,7 +40,7 @@
|
|
38
40
|
<%= link_to Spree.t('actions.publish'), publish_admin_theme_path(theme), class: 'btn btn-sm btn-light mr-2', data: { turbo_method: :put } unless theme.default? %>
|
39
41
|
<div class="dropdown">
|
40
42
|
<button class="btn btn-sm btn-light h-100" type="button" id="dropdownMenuButton" data-toggle="dropdown" aria-haspopup="true" aria-expanded="false">
|
41
|
-
<%= icon('dots', class: 'mr-0') %>
|
43
|
+
<%= icon('dots-vertical', class: 'mr-0') %>
|
42
44
|
</button>
|
43
45
|
<div class="dropdown-menu dropdown-menu-right" aria-labelledby="dropdownMenuButton">
|
44
46
|
<%= link_to_edit theme, class: 'dropdown-item' %>
|
@@ -1,15 +1,17 @@
|
|
1
1
|
<% width ||= 120 %>
|
2
2
|
<% height ||= 72 %>
|
3
|
+
<% css_class ||= 'img-thumbnail border-0' %>
|
3
4
|
|
4
5
|
<% if theme.screenshot.attached? && theme.screenshot.variable? %>
|
5
|
-
<%=
|
6
|
+
<%= image_tag(spree_image_url(theme.screenshot, width: width, height: height), class: css_class, loading: :lazy) %>
|
6
7
|
<% elsif theme.class.preview_image_url.present? %>
|
7
8
|
<%= image_tag(
|
8
9
|
theme.class.preview_image_url,
|
9
|
-
class:
|
10
|
-
style: "width: #{width}px; height: #{height}px",
|
10
|
+
class: css_class,
|
11
11
|
loading: :lazy
|
12
12
|
) %>
|
13
13
|
<% else %>
|
14
|
-
|
14
|
+
<div class="rounded bg-light text-muted d-flex align-items-center justify-content-center img-fluid" style="height: <%= height %>px">
|
15
|
+
<%= icon('camera-off', class: 'text-muted opacity-50') %>
|
16
|
+
</div>
|
15
17
|
<% end %>
|
@@ -29,7 +29,7 @@
|
|
29
29
|
<div class="card-lg">
|
30
30
|
<div class="table-responsive rounded-lg">
|
31
31
|
<table class="table">
|
32
|
-
<thead
|
32
|
+
<thead>
|
33
33
|
<tr>
|
34
34
|
<th class="bg-transparent"><%= Spree.t(:theme) %></th>
|
35
35
|
<th class="bg-transparent"><%= Spree.t(:status) %></th>
|
@@ -15,7 +15,7 @@
|
|
15
15
|
<%= turbo_frame_tag :translations_table, class: "table-responsive border rounded bg-white my-3", refresh: "morph" do %>
|
16
16
|
<%= hidden_field_tag :translation_locale, @selected_translation_locale %>
|
17
17
|
<table class="table">
|
18
|
-
<thead
|
18
|
+
<thead>
|
19
19
|
<tr>
|
20
20
|
<th scope="col" class="text-center"><%= Spree.t(:field) %></th>
|
21
21
|
<th scope="col" class="text-center" style="width: 40%;"><%= Spree.t('i18n.this_file_language', locale: :en) %> (<%= Spree.t(:default) %>)</th>
|
@@ -0,0 +1,21 @@
|
|
1
|
+
<% content_for(:title, Spree.t(:forgot_password)) %>
|
2
|
+
|
3
|
+
<h1 class="mb-3 font-weight-light"><%= Spree.t(:change_password) %></h1>
|
4
|
+
<%= form_for(resource, as: resource_name, url: password_path(:admin_user), html: { method: :put }, data: { turbo_frame: :_top, turbo: false }) do |f| %>
|
5
|
+
<%= render partial: 'spree/admin/shared/error_messages', locals: { target: resource } %>
|
6
|
+
<%= f.hidden_field :reset_password_token %>
|
7
|
+
<div class="form-group mb-3">
|
8
|
+
<%= f.label :password, Spree.t(:password), required: true, class: 'form-label' %>
|
9
|
+
<% if @minimum_password_length %>
|
10
|
+
<em>(<%= @minimum_password_length %> characters minimum)</em>
|
11
|
+
<% end %>
|
12
|
+
<%= f.password_field :password, autofocus: true, autocomplete: "new-password", class: 'form-control form-control-lg rounded-sm', min: @minimum_password_length %>
|
13
|
+
</div>
|
14
|
+
<div class="form-group mb-3">
|
15
|
+
<%= f.label :password_confirmation, Spree.t(:confirm_password), required: true, class: 'form-label' %>
|
16
|
+
<%= f.password_field :password_confirmation, autocomplete: "new-password", class: 'form-control form-control-lg rounded-sm', min: @minimum_password_length %>
|
17
|
+
</div>
|
18
|
+
<%= render 'spree/admin/shared/devise/links', f: f %>
|
19
|
+
<%= turbo_save_button_tag Spree.t(:reset_password), class: 'btn btn-primary btn-lg w-100' %>
|
20
|
+
<% end %>
|
21
|
+
|
@@ -0,0 +1,12 @@
|
|
1
|
+
<% content_for(:title, Spree.t(:forgot_password)) %>
|
2
|
+
|
3
|
+
<h1 class="mb-3 font-weight-light"><%= Spree.t(:forgot_password) %></h1>
|
4
|
+
<%= form_for(resource, as: resource_name, url: password_path(:admin_user), data: { turbo_frame: :_top }) do |f| %>
|
5
|
+
<div class="form-group mb-3">
|
6
|
+
<%= f.label :email, Spree.t(:email), required: true, class: 'form-label' %>
|
7
|
+
<%= f.email_field :email, required: true, class: 'form-control form-control-lg rounded-sm', placeholder: 'steve@apple.com', data: { enable_button_target: :input }, autocomplete: :email, autofocus: true %>
|
8
|
+
</div>
|
9
|
+
<%= render 'spree/admin/shared/devise/links', f: f %>
|
10
|
+
<%= turbo_save_button_tag Spree.t(:reset_password), class: 'btn btn-primary btn-lg w-100' %>
|
11
|
+
<% end %>
|
12
|
+
|
@@ -0,0 +1,16 @@
|
|
1
|
+
<% content_for(:title, Spree.t(:login)) %>
|
2
|
+
|
3
|
+
<h1 class="mb-3 font-weight-light">Welcome back</h1>
|
4
|
+
<%= form_for resource, as: resource_name, url: session_path(resource_name), data: { controller: 'enable-button', turbo: false } do |f| %>
|
5
|
+
<div class="form-group mb-3">
|
6
|
+
<%= f.label :email, Spree.t(:email), required: true, class: 'form-label' %>
|
7
|
+
<%= f.email_field :email, required: true, class: 'form-control form-control-lg rounded-sm', placeholder: 'steve@getvendo.com', data: { enable_button_target: :input }, autocomplete: :email, autofocus: true %>
|
8
|
+
</div>
|
9
|
+
<div class="form-group mb-3">
|
10
|
+
<%= f.label :password, Spree.t(:password), required: true, class: 'form-label' %>
|
11
|
+
<%= f.password_field :password, required: true, class: 'form-control form-control-lg rounded-sm', placeholder: '********', autocomplete: 'current-password' %>
|
12
|
+
</div>
|
13
|
+
<%= render 'spree/admin/shared/devise/links', f: f %>
|
14
|
+
<%= turbo_save_button_tag Spree.t(:login), class: 'btn btn-primary btn-lg w-100' %>
|
15
|
+
<% end %>
|
16
|
+
|
@@ -22,13 +22,15 @@
|
|
22
22
|
<%= f.label :tag_list, Spree.t(:tags) %>
|
23
23
|
<%= tom_select_tag 'user[tag_list]', multiple: true, class: 'w-100', options: user_tags_json_array, active_option: @user.tag_list, value_field: :name, create: true %>
|
24
24
|
</div>
|
25
|
-
|
26
|
-
|
27
|
-
|
28
|
-
|
29
|
-
|
30
|
-
|
31
|
-
|
25
|
+
<% if @user.class == Spree.admin_user_class && can?(:manage, Spree::Role) %>
|
26
|
+
<div class="form-group">
|
27
|
+
<%= f.label :spree_role_ids, Spree.t(:roles) %>
|
28
|
+
<%= f.select :spree_role_ids,
|
29
|
+
options_from_collection_for_select(Spree::Role.all, 'id', 'name', @user.spree_roles.pluck(:id)),
|
30
|
+
{ prompt: false },
|
31
|
+
{ multiple: true, data: { controller: 'autocomplete-select' } } %>
|
32
|
+
</div>
|
33
|
+
<% end %>
|
32
34
|
<div class="custom-control custom-checkbox mb-3">
|
33
35
|
<%= f.check_box :accepts_email_marketing, class: 'custom-control-input' %>
|
34
36
|
<%= f.label :accepts_email_marketing, Spree.t(:accepts_email_marketing), class: 'custom-control-label' %>
|
@@ -2,7 +2,7 @@
|
|
2
2
|
<td class="pr-0 w-5">
|
3
3
|
<%= bulk_operations_checkbox(user) %>
|
4
4
|
</td>
|
5
|
-
<td class='w-50
|
5
|
+
<td class='w-50 text-nowrap py-0 pl-1 pr-0'>
|
6
6
|
<%= render 'spree/admin/shared/user', user: user %>
|
7
7
|
</td>
|
8
8
|
<td class="cursor-pointer" data-action="click->row-link#openLink">
|
@@ -12,7 +12,7 @@
|
|
12
12
|
<%= customer_location_flag(user) %>
|
13
13
|
<%= customer_location(user) %>
|
14
14
|
</td>
|
15
|
-
<td class='w-10
|
16
|
-
<td class='w-10
|
17
|
-
<td class='w-10
|
15
|
+
<td class='w-10 text-nowrap cursor-pointer' data-action="click->row-link#openLink"><%= user.completed_orders_for_store(current_store).count %></td>
|
16
|
+
<td class='w-10 text-nowrap cursor-pointer' data-action="click->row-link#openLink"><%= user.display_amount_spent_in(current_currency) %></td>
|
17
|
+
<td class='w-10 text-nowrap cursor-pointer' data-action="click->row-link#openLink"><%= local_time(user.created_at) %></td>
|
18
18
|
</tr>
|
@@ -1,6 +1,6 @@
|
|
1
1
|
<div class="search-picker__option <% if variant.purchasable? || params[:all] %>cursor-pointer<% else %>opacity-50 disabled<% end %>" data-action="click->search-picker#toggle">
|
2
2
|
<%= radio_button_tag "#{params[:param_name]}[variant_id]", variant.id, false, class: "custom-control-input", id: "ids_#{variant.id}", data: { action: 'search-picker#toggle', search_picker_target: "checkbox" }, disabled: !params[:all] && !variant.purchasable? %>
|
3
|
-
<label for="ids_<%= variant.id %>" class="pr-2">
|
3
|
+
<label for="ids_<%= variant.id %>" class="pr-2 <% unless variant.purchasable? %>cursor-not-allowed<% end %>">
|
4
4
|
<div class="w-70 d-flex align-items-center">
|
5
5
|
<div class="variant-image">
|
6
6
|
<%= render 'spree/admin/shared/product_image', object: variant %>
|
@@ -1,4 +1,4 @@
|
|
1
|
-
<div id="<%= spree_dom_id(asset) %>" class="media-form__image
|
1
|
+
<div id="<%= spree_dom_id(asset) %>" class="media-form__image" data-sortable-update-url="<%= spree.admin_asset_path(asset) %>">
|
2
2
|
<div class="custom-control custom-checkbox d-none">
|
3
3
|
<%= check_box_tag "ids[]", asset.id, false, class: "custom-control-input", id: "#{asset.id}-checkbox", data: { media_form_target: "checkbox", action: 'media-form#showDeleteButton' } %>
|
4
4
|
<label class="custom-control-label" for="<%= asset.id %>-checkbox"><span></span></label>
|
@@ -17,26 +17,22 @@
|
|
17
17
|
<%= zone_form.text_field :description, class: 'form-control' %>
|
18
18
|
</div>
|
19
19
|
|
20
|
-
<div class="form-group
|
21
|
-
|
22
|
-
<%= zone_form.check_box :default_tax %>
|
23
|
-
<%= Spree.t(:default_tax_zone) %>
|
24
|
-
|
20
|
+
<div class="form-group">
|
21
|
+
<div class="custom-control custom-checkbox">
|
22
|
+
<%= zone_form.check_box :default_tax, class: 'custom-control-input' %>
|
23
|
+
<%= zone_form.label :default_tax, Spree.t(:default_tax_zone), class: 'custom-control-label' %>
|
24
|
+
</div>
|
25
25
|
</div>
|
26
26
|
|
27
27
|
<div class="form-group">
|
28
28
|
<strong><%= Spree.t(:type) %></strong>
|
29
|
-
<div class="radio my-2">
|
30
|
-
<%=
|
31
|
-
|
32
|
-
<%= Spree.t(:country_based) %>
|
33
|
-
<% end %>
|
29
|
+
<div class="custom-control custom-radio my-2">
|
30
|
+
<%= zone_form.radio_button :kind, :country, id: 'country_based', class: 'custom-control-input', data: { action: 'auto-submit#submit' } %>
|
31
|
+
<%= label_tag :country_based, Spree.t(:country_based), class: 'custom-control-label' %>
|
34
32
|
</div>
|
35
|
-
<div class="radio my-2">
|
36
|
-
<%=
|
37
|
-
|
38
|
-
<%= Spree.t(:state_based) %>
|
39
|
-
<% end %>
|
33
|
+
<div class="custom-control custom-radio my-2">
|
34
|
+
<%= zone_form.radio_button :kind, :state, id: 'state_based', class: 'custom-control-input', data: { action: 'auto-submit#submit' } %>
|
35
|
+
<%= label_tag :state_based, Spree.t(:state_based), class: 'custom-control-label' %>
|
40
36
|
</div>
|
41
37
|
</div>
|
42
38
|
</div>
|
data/config/locales/en.yml
CHANGED
@@ -74,6 +74,9 @@ en:
|
|
74
74
|
export_only_filtered_records: Export only filtered records, matching the search criteria
|
75
75
|
filters: Filters
|
76
76
|
getting_started: Getting started
|
77
|
+
integrations:
|
78
|
+
invalid_integration_type: This integration is not allowed
|
79
|
+
page_subtitle: Connect your store to third-party services to enhance customer experience.
|
77
80
|
manage_currencies: Manage Currencies
|
78
81
|
manage_properties: Manage Properties
|
79
82
|
manage_stock_locations: Manage Stock Locations
|
data/config/routes.rb
CHANGED
@@ -59,10 +59,10 @@ Spree::Core::Engine.add_routes do
|
|
59
59
|
post :resend
|
60
60
|
put :cancel
|
61
61
|
end
|
62
|
-
resource :shipping_address, except: [:
|
63
|
-
resource :billing_address, except: [:
|
62
|
+
resource :shipping_address, except: [:show], controller: 'orders/shipping_address'
|
63
|
+
resource :billing_address, except: [:show], controller: 'orders/billing_address'
|
64
64
|
resource :contact_information, only: [:edit, :update], controller: 'orders/contact_information'
|
65
|
-
resource :user, except: [:edit, :show
|
65
|
+
resource :user, except: [:edit, :show], controller: 'orders/user'
|
66
66
|
resources :shipments, only: [:edit, :update, :create], controller: 'shipments' do
|
67
67
|
member do
|
68
68
|
post :ship
|
@@ -147,7 +147,9 @@ Spree::Core::Engine.add_routes do
|
|
147
147
|
end
|
148
148
|
end
|
149
149
|
# setting up a new store
|
150
|
-
resources :stores, only: [:new, :create]
|
150
|
+
resources :stores, only: [:new, :create] do
|
151
|
+
resources :role_users, only: [:destroy]
|
152
|
+
end
|
151
153
|
resources :payment_methods, except: :show
|
152
154
|
resources :shipping_methods, except: :show
|
153
155
|
resources :shipping_categories, except: :show
|
@@ -165,6 +167,9 @@ Spree::Core::Engine.add_routes do
|
|
165
167
|
end
|
166
168
|
resources :custom_domains, except: :show
|
167
169
|
|
170
|
+
# integrations
|
171
|
+
resources :integrations
|
172
|
+
|
168
173
|
# storefront / page builder
|
169
174
|
resource :storefront, only: [:edit, :update], controller: :storefront
|
170
175
|
resources :themes, except: [:new, :show] do
|
@@ -214,6 +219,13 @@ Spree::Core::Engine.add_routes do
|
|
214
219
|
|
215
220
|
# account management
|
216
221
|
resources :roles, except: :show
|
222
|
+
resources :invitations, except: [:edit, :update] do
|
223
|
+
member do
|
224
|
+
put :accept
|
225
|
+
put :resend
|
226
|
+
end
|
227
|
+
end
|
228
|
+
resources :admin_users, except: [:destroy]
|
217
229
|
|
218
230
|
# Action Text
|
219
231
|
namespace :action_text do
|
data/lib/spree/admin/engine.rb
CHANGED
@@ -22,6 +22,7 @@ module Spree
|
|
22
22
|
:store_form_partials,
|
23
23
|
:store_nav_partials,
|
24
24
|
:settings_nav_partials,
|
25
|
+
:shipping_method_form_partials,
|
25
26
|
:store_settings_nav_partials,
|
26
27
|
:store_orders_nav_partials,
|
27
28
|
:store_products_nav_partials,
|
@@ -56,6 +57,8 @@ module Spree
|
|
56
57
|
app.config.assets.paths << root.join('app/javascript')
|
57
58
|
app.config.assets.paths << root.join('vendor/javascript')
|
58
59
|
app.config.assets.precompile += %w[ spree_admin_manifest bootstrap.bundle.min.js jquery3.min.js ]
|
60
|
+
# fix for TinyMCE-rails gem to work with both propshaft and sprockets
|
61
|
+
app.config.assets.excluded_paths ||= []
|
59
62
|
end
|
60
63
|
|
61
64
|
initializer 'spree.admin.importmap', after: 'importmap' do |app|
|
@@ -97,6 +100,7 @@ module Spree
|
|
97
100
|
Rails.application.config.spree_admin.store_form_partials = []
|
98
101
|
Rails.application.config.spree_admin.store_nav_partials = []
|
99
102
|
Rails.application.config.spree_admin.settings_nav_partials = []
|
103
|
+
Rails.application.config.spree_admin.shipping_method_form_partials = []
|
100
104
|
Rails.application.config.spree_admin.store_settings_nav_partials = []
|
101
105
|
Rails.application.config.spree_admin.store_orders_nav_partials = []
|
102
106
|
Rails.application.config.spree_admin.store_products_nav_partials = []
|
data/lib/spree/admin.rb
CHANGED
@@ -4,6 +4,7 @@ require 'spree_api'
|
|
4
4
|
require 'sprockets/railtie'
|
5
5
|
|
6
6
|
require 'active_link_to'
|
7
|
+
require 'breadcrumbs_on_rails'
|
7
8
|
require 'chartkick'
|
8
9
|
require 'currency_select'
|
9
10
|
require 'groupdate'
|
@@ -16,8 +17,9 @@ require 'stimulus-rails'
|
|
16
17
|
require 'local_time'
|
17
18
|
require 'payment_icons'
|
18
19
|
require 'dartsass-rails'
|
19
|
-
require 'tinymce-rails'
|
20
20
|
|
21
21
|
require 'spree/admin/action_callbacks'
|
22
22
|
require 'spree/admin/callbacks'
|
23
23
|
require 'spree/admin/engine'
|
24
|
+
|
25
|
+
require 'tinymce-rails'
|