spree_admin 5.0.6 → 5.1.0.beta

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 (266) hide show
  1. checksums.yaml +4 -4
  2. data/app/assets/images/login_sidebar_background.png +0 -0
  3. data/app/assets/stylesheets/spree/admin/components/_bulk_panel.scss +8 -1
  4. data/app/assets/stylesheets/spree/admin/components/_buttons.scss +12 -20
  5. data/app/assets/stylesheets/spree/admin/components/_cards.scss +9 -3
  6. data/app/assets/stylesheets/spree/admin/components/_dropdowns.scss +13 -40
  7. data/app/assets/stylesheets/spree/admin/components/_filters.scss +32 -3
  8. data/app/assets/stylesheets/spree/admin/components/_main.scss +107 -31
  9. data/app/assets/stylesheets/spree/admin/components/_media_form.scss +21 -9
  10. data/app/assets/stylesheets/spree/admin/components/_modals.scss +4 -3
  11. data/app/assets/stylesheets/spree/admin/components/_navbar.scss +5 -9
  12. data/app/assets/stylesheets/spree/admin/components/_navigation.scss +0 -1
  13. data/app/assets/stylesheets/spree/admin/components/_sortable_tree.scss +6 -2
  14. data/app/assets/stylesheets/spree/admin/components/_tables.scss +35 -5
  15. data/app/assets/stylesheets/spree/admin/global/_variables.scss +37 -17
  16. data/app/assets/stylesheets/spree/admin/plugins/tom-select.bootstrap4.scss +5 -4
  17. data/app/assets/stylesheets/spree/admin/shared/_base.scss +50 -17
  18. data/app/assets/stylesheets/spree/admin/shared/_forms.scss +6 -2
  19. data/app/assets/stylesheets/spree/admin/views/_page_builder.scss +30 -21
  20. data/app/controllers/concerns/spree/admin/breadcrumb_concern.rb +22 -0
  21. data/app/controllers/concerns/spree/admin/preferences_concern.rb +22 -0
  22. data/app/controllers/concerns/spree/admin/products_breadcrumb_concern.rb +22 -0
  23. data/app/controllers/concerns/spree/admin/promotions_breadcrumb_concern.rb +23 -0
  24. data/app/controllers/concerns/spree/admin/storefront_breadcrumb_concern.rb +12 -0
  25. data/app/controllers/spree/admin/addresses_controller.rb +4 -0
  26. data/app/controllers/spree/admin/admin_users_controller.rb +112 -0
  27. data/app/controllers/spree/admin/assets_controller.rb +7 -9
  28. data/app/controllers/spree/admin/base_controller.rb +21 -10
  29. data/app/controllers/spree/admin/checkouts_controller.rb +4 -0
  30. data/app/controllers/spree/admin/classifications_controller.rb +4 -0
  31. data/app/controllers/spree/admin/coupon_codes_controller.rb +2 -0
  32. data/app/controllers/spree/admin/custom_domains_controller.rb +6 -0
  33. data/app/controllers/spree/admin/customer_returns_controller.rb +4 -0
  34. data/app/controllers/spree/admin/dashboard_controller.rb +8 -2
  35. data/app/controllers/spree/admin/digital_assets_controller.rb +8 -0
  36. data/app/controllers/spree/admin/exports_controller.rb +6 -2
  37. data/app/controllers/spree/admin/integrations_controller.rb +61 -0
  38. data/app/controllers/spree/admin/invitations_controller.rb +128 -0
  39. data/app/controllers/spree/admin/line_items_controller.rb +4 -0
  40. data/app/controllers/spree/admin/oauth_applications_controller.rb +6 -0
  41. data/app/controllers/spree/admin/option_types_controller.rb +15 -0
  42. data/app/controllers/spree/admin/option_values_controller.rb +4 -0
  43. data/app/controllers/spree/admin/orders/return_authorizations_controller.rb +4 -0
  44. data/app/controllers/spree/admin/orders_controller.rb +12 -1
  45. data/app/controllers/spree/admin/page_blocks_controller.rb +3 -2
  46. data/app/controllers/spree/admin/page_links_controller.rb +9 -0
  47. data/app/controllers/spree/admin/page_sections_controller.rb +13 -4
  48. data/app/controllers/spree/admin/pages_controller.rb +7 -0
  49. data/app/controllers/spree/admin/payment_methods_controller.rb +23 -12
  50. data/app/controllers/spree/admin/post_categories_controller.rb +3 -0
  51. data/app/controllers/spree/admin/posts_controller.rb +11 -0
  52. data/app/controllers/spree/admin/products_controller.rb +15 -12
  53. data/app/controllers/spree/admin/promotion_actions_controller.rb +10 -2
  54. data/app/controllers/spree/admin/promotion_rules_controller.rb +10 -2
  55. data/app/controllers/spree/admin/promotions_controller.rb +6 -0
  56. data/app/controllers/spree/admin/properties_controller.rb +15 -0
  57. data/app/controllers/spree/admin/refund_reasons_controller.rb +7 -0
  58. data/app/controllers/spree/admin/refunds_controller.rb +4 -0
  59. data/app/controllers/spree/admin/reimbursement_types_controller.rb +7 -0
  60. data/app/controllers/spree/admin/reimbursements_controller.rb +4 -0
  61. data/app/controllers/spree/admin/reports_controller.rb +12 -2
  62. data/app/controllers/spree/admin/resource_controller.rb +1 -1
  63. data/app/controllers/spree/admin/return_authorization_reasons_controller.rb +7 -0
  64. data/app/controllers/spree/admin/return_authorizations_controller.rb +4 -0
  65. data/app/controllers/spree/admin/return_items_controller.rb +6 -0
  66. data/app/controllers/spree/admin/role_users_controller.rb +36 -0
  67. data/app/controllers/spree/admin/roles_controller.rb +8 -0
  68. data/app/controllers/spree/admin/shipments_controller.rb +2 -2
  69. data/app/controllers/spree/admin/shipping_categories_controller.rb +7 -0
  70. data/app/controllers/spree/admin/shipping_methods_controller.rb +6 -0
  71. data/app/controllers/spree/admin/stock_items_controller.rb +13 -0
  72. data/app/controllers/spree/admin/stock_locations_controller.rb +7 -0
  73. data/app/controllers/spree/admin/stock_transfers_controller.rb +14 -2
  74. data/app/controllers/spree/admin/store_credit_categories_controller.rb +5 -0
  75. data/app/controllers/spree/admin/store_credits_controller.rb +4 -0
  76. data/app/controllers/spree/admin/storefront_controller.rb +3 -0
  77. data/app/controllers/spree/admin/stores_controller.rb +17 -2
  78. data/app/controllers/spree/admin/tax_categories_controller.rb +7 -0
  79. data/app/controllers/spree/admin/tax_rates_controller.rb +6 -0
  80. data/app/controllers/spree/admin/taxonomies_controller.rb +15 -0
  81. data/app/controllers/spree/admin/taxons_controller.rb +24 -1
  82. data/app/controllers/spree/admin/themes_controller.rb +7 -0
  83. data/app/controllers/spree/admin/translations_controller.rb +9 -1
  84. data/app/controllers/spree/admin/user_passwords_controller.rb +22 -0
  85. data/app/controllers/spree/admin/user_sessions_controller.rb +23 -0
  86. data/app/controllers/spree/admin/users_controller.rb +11 -2
  87. data/app/controllers/spree/admin/variants_controller.rb +13 -0
  88. data/app/controllers/spree/admin/webhooks_subscribers_controller.rb +3 -0
  89. data/app/controllers/spree/admin/zones_controller.rb +5 -0
  90. data/app/helpers/spree/admin/base_helper.rb +32 -31
  91. data/app/helpers/spree/admin/bulk_operations_helper.rb +8 -2
  92. data/app/helpers/spree/admin/modal_helper.rb +1 -1
  93. data/app/helpers/spree/admin/navigation_helper.rb +11 -5
  94. data/app/helpers/spree/admin/orders_filters_helper.rb +1 -1
  95. data/app/helpers/spree/admin/orders_helper.rb +1 -3
  96. data/app/helpers/spree/admin/payments_helper.rb +5 -0
  97. data/app/helpers/spree/admin/posts_helper.rb +1 -1
  98. data/app/helpers/spree/admin/session_assets_helper.rb +1 -1
  99. data/app/helpers/spree/admin/stores_helper.rb +1 -18
  100. data/app/helpers/spree/admin/tags_helper.rb +2 -2
  101. data/app/javascript/spree/admin/application.js +2 -0
  102. data/app/javascript/spree/admin/controllers/active_storage_upload_controller.js +11 -2
  103. data/app/javascript/spree/admin/controllers/multi_tom_select_controller.js +2 -3
  104. data/app/javascript/spree/admin/controllers/select_controller.js +6 -0
  105. data/app/javascript/spree/admin/controllers/variants_form_controller.js +17 -23
  106. data/app/javascript/spree/admin/helpers/bootstrap.js +3 -3
  107. data/app/javascript/spree/admin/helpers/uppy_active_storage.js +3 -15
  108. data/app/views/active_storage/_upload_form.html.erb +3 -3
  109. data/app/views/layouts/spree/minimal.html.erb +22 -0
  110. data/app/views/spree/admin/admin_users/_admin_user.html.erb +19 -0
  111. data/app/views/spree/admin/admin_users/_audit_log.html.erb +5 -0
  112. data/app/views/spree/admin/admin_users/_form.html.erb +12 -0
  113. data/app/views/spree/admin/admin_users/edit.html.erb +35 -0
  114. data/app/views/spree/admin/admin_users/index.html.erb +18 -0
  115. data/app/views/spree/admin/admin_users/new.html.erb +21 -0
  116. data/app/views/spree/admin/admin_users/show.html.erb +113 -0
  117. data/app/views/spree/admin/coupon_codes/index.html.erb +6 -6
  118. data/app/views/spree/admin/custom_domains/_custom_domains.html.erb +1 -1
  119. data/app/views/spree/admin/customer_returns/index.html.erb +1 -1
  120. data/app/views/spree/admin/dashboard/_store_preview.html.erb +1 -1
  121. data/app/views/spree/admin/dashboard/_top_products.html.erb +4 -2
  122. data/app/views/spree/admin/digital_assets/_table.html.erb +1 -1
  123. data/app/views/spree/admin/digital_assets/index.html.erb +0 -1
  124. data/app/views/spree/admin/exports/index.html.erb +1 -1
  125. data/app/views/spree/admin/integrations/_integration.html.erb +36 -0
  126. data/app/views/spree/admin/integrations/edit.html.erb +11 -0
  127. data/app/views/spree/admin/integrations/index.html.erb +23 -0
  128. data/app/views/spree/admin/integrations/new.html.erb +14 -0
  129. data/app/views/spree/admin/invitations/_invitation.html.erb +52 -0
  130. data/app/views/spree/admin/invitations/create.turbo_stream.erb +4 -0
  131. data/app/views/spree/admin/invitations/index.html.erb +21 -0
  132. data/app/views/spree/admin/invitations/new.html.erb +32 -0
  133. data/app/views/spree/admin/invitations/show.html.erb +9 -0
  134. data/app/views/spree/admin/line_items/new.html.erb +2 -2
  135. data/app/views/spree/admin/oauth_applications/index.html.erb +1 -1
  136. data/app/views/spree/admin/option_types/edit.html.erb +1 -1
  137. data/app/views/spree/admin/option_types/index.html.erb +1 -1
  138. data/app/views/spree/admin/orders/_customer.html.erb +1 -2
  139. data/app/views/spree/admin/orders/_filters.html.erb +17 -21
  140. data/app/views/spree/admin/orders/_list.html.erb +1 -1
  141. data/app/views/spree/admin/orders/_refunds.html.erb +1 -1
  142. data/app/views/spree/admin/orders/_return_authorizations.html.erb +1 -3
  143. data/app/views/spree/admin/orders/_shipment.html.erb +1 -1
  144. data/app/views/spree/admin/orders/_table_filter_dropdown.html.erb +2 -2
  145. data/app/views/spree/admin/orders/customer_returns/_customer_return.html.erb +1 -1
  146. data/app/views/spree/admin/orders/customer_returns/_return_item_decision.html.erb +1 -1
  147. data/app/views/spree/admin/orders/return_authorizations/_form.html.erb +1 -1
  148. data/app/views/spree/admin/orders/return_authorizations/show.html.erb +2 -2
  149. data/app/views/spree/admin/page_blocks/_form_tab_buttons.html.erb +5 -7
  150. data/app/views/spree/admin/page_blocks/edit.html.erb +3 -5
  151. data/app/views/spree/admin/page_builder/_add_block.html.erb +1 -1
  152. data/app/views/spree/admin/page_builder/_header.html.erb +35 -28
  153. data/app/views/spree/admin/page_builder/_pages_dropdown.html.erb +15 -21
  154. data/app/views/spree/admin/page_builder/_sidebar.html.erb +1 -1
  155. data/app/views/spree/admin/page_builder/_sidebar_block.html.erb +1 -1
  156. data/app/views/spree/admin/page_links/_list.html.erb +2 -2
  157. data/app/views/spree/admin/page_links/edit.html.erb +2 -4
  158. data/app/views/spree/admin/page_sections/_form_tab_buttons.html.erb +6 -10
  159. data/app/views/spree/admin/page_sections/forms/_featured_posts.html.erb +5 -0
  160. data/app/views/spree/admin/page_sections/new.html.erb +1 -1
  161. data/app/views/spree/admin/pages/edit.html.erb +2 -2
  162. data/app/views/spree/admin/pages/index.html.erb +1 -2
  163. data/app/views/spree/admin/payment_methods/index.html.erb +16 -15
  164. data/app/views/spree/admin/payments/_payment.html.erb +1 -1
  165. data/app/views/spree/admin/payments/source_forms/_gateway.html.erb +1 -1
  166. data/app/views/spree/admin/post_categories/index.html.erb +1 -1
  167. data/app/views/spree/admin/posts/index.html.erb +1 -1
  168. data/app/views/spree/admin/preferences/_password_field.html.erb +2 -2
  169. data/app/views/spree/admin/products/_bulk_operations.html.erb +1 -1
  170. data/app/views/spree/admin/products/_filters.html.erb +2 -5
  171. data/app/views/spree/admin/products/_form.html.erb +1 -2
  172. data/app/views/spree/admin/products/_list.html.erb +1 -1
  173. data/app/views/spree/admin/products/_table_filter_dropdown.html.erb +2 -2
  174. data/app/views/spree/admin/products/form/_categorization.html.erb +34 -30
  175. data/app/views/spree/admin/promotion_actions/_promotion_action.html.erb +1 -1
  176. data/app/views/spree/admin/promotion_rules/_promotion_rule.html.erb +1 -1
  177. data/app/views/spree/admin/promotions/_filters.html.erb +2 -6
  178. data/app/views/spree/admin/promotions/_header.html.erb +1 -3
  179. data/app/views/spree/admin/promotions/_sidebar.html.erb +18 -0
  180. data/app/views/spree/admin/promotions/_table_filter_dropdown.html.erb +2 -2
  181. data/app/views/spree/admin/promotions/index.html.erb +1 -1
  182. data/app/views/spree/admin/properties/edit.html.erb +1 -1
  183. data/app/views/spree/admin/properties/index.html.erb +1 -1
  184. data/app/views/spree/admin/refund_reasons/index.html.erb +1 -1
  185. data/app/views/spree/admin/reimbursement_types/index.html.erb +1 -1
  186. data/app/views/spree/admin/reimbursements/edit.html.erb +2 -2
  187. data/app/views/spree/admin/reimbursements/show.html.erb +1 -1
  188. data/app/views/spree/admin/reports/_report.html.erb +1 -1
  189. data/app/views/spree/admin/return_authorization_reasons/index.html.erb +1 -1
  190. data/app/views/spree/admin/return_authorizations/_filters.html.erb +2 -2
  191. data/app/views/spree/admin/return_authorizations/_list.html.erb +1 -1
  192. data/app/views/spree/admin/roles/edit.html.erb +6 -4
  193. data/app/views/spree/admin/roles/index.html.erb +11 -7
  194. data/app/views/spree/admin/shared/_alerts.html.erb +1 -1
  195. data/app/views/spree/admin/shared/_breadcrumbs.html.erb +13 -0
  196. data/app/views/spree/admin/shared/_calendar_range_picker.html.erb +1 -1
  197. data/app/views/spree/admin/shared/_content_header.html.erb +3 -3
  198. data/app/views/spree/admin/shared/_filters_button.html.erb +1 -1
  199. data/app/views/spree/admin/shared/_filters_search_bar.html.erb +1 -1
  200. data/app/views/spree/admin/shared/_head.html.erb +4 -0
  201. data/app/views/spree/admin/shared/_header.html.erb +26 -17
  202. data/app/views/spree/admin/shared/_index_table_options.html.erb +1 -1
  203. data/app/views/spree/admin/shared/_multi_product_picker.html.erb +1 -1
  204. data/app/views/spree/admin/shared/_new_item_dropdown.html.erb +32 -0
  205. data/app/views/spree/admin/shared/_no_resource_found.html.erb +6 -3
  206. data/app/views/spree/admin/shared/_offcanvas_nav.html.erb +1 -14
  207. data/app/views/spree/admin/shared/_refunds.html.erb +1 -1
  208. data/app/views/spree/admin/shared/_sidebar.html.erb +0 -8
  209. data/app/views/spree/admin/shared/_team_nav.html.erb +13 -0
  210. data/app/views/spree/admin/shared/_user_dropdown.html.erb +25 -20
  211. data/app/views/spree/admin/shared/devise/_links.html.erb +18 -0
  212. data/app/views/spree/admin/shared/sidebar/_enterprise_edition_notice.html.erb +7 -5
  213. data/app/views/spree/admin/shared/sidebar/_integrations_nav.html.erb +5 -7
  214. data/app/views/spree/admin/shared/sidebar/_orders_nav.html.erb +2 -2
  215. data/app/views/spree/admin/shared/sidebar/_products_nav.html.erb +2 -2
  216. data/app/views/spree/admin/shared/sidebar/_promotions_nav.html.erb +17 -0
  217. data/app/views/spree/admin/shared/sidebar/_returns_nav.html.erb +1 -1
  218. data/app/views/spree/admin/shared/sidebar/_store_dropdown.html.erb +33 -75
  219. data/app/views/spree/admin/shared/sidebar/_store_nav.html.erb +14 -34
  220. data/app/views/spree/admin/shared/sidebar/_storefront_nav.html.erb +4 -2
  221. data/app/views/spree/admin/shared/sidebar/_vendors_nav.html.erb +9 -7
  222. data/app/views/spree/admin/shared/sortable_tree/_taxonomy.html.erb +1 -1
  223. data/app/views/spree/admin/shipping_categories/index.html.erb +1 -1
  224. data/app/views/spree/admin/shipping_methods/_form.html.erb +7 -134
  225. data/app/views/spree/admin/shipping_methods/form/_display.html.erb +25 -0
  226. data/app/views/spree/admin/shipping_methods/form/_estimated_transit_business_days.html.erb +23 -0
  227. data/app/views/spree/admin/shipping_methods/form/_shipping_categories.html.erb +21 -0
  228. data/app/views/spree/admin/shipping_methods/form/_tax_category.html.erb +16 -0
  229. data/app/views/spree/admin/shipping_methods/form/_tracking_url.html.erb +18 -0
  230. data/app/views/spree/admin/shipping_methods/form/_zones.html.erb +26 -0
  231. data/app/views/spree/admin/shipping_methods/index.html.erb +1 -1
  232. data/app/views/spree/admin/stock_items/index.html.erb +1 -1
  233. data/app/views/spree/admin/stock_locations/_stock_location.html.erb +5 -3
  234. data/app/views/spree/admin/stock_locations/index.html.erb +4 -2
  235. data/app/views/spree/admin/stock_transfers/index.html.erb +1 -1
  236. data/app/views/spree/admin/store_credit_categories/index.html.erb +1 -1
  237. data/app/views/spree/admin/store_credits/_list.html.erb +1 -1
  238. data/app/views/spree/admin/stores/edit_emails.html.erb +1 -1
  239. data/app/views/spree/admin/stores/form/_emails.html.erb +1 -1
  240. data/app/views/spree/admin/tax_categories/index.html.erb +1 -1
  241. data/app/views/spree/admin/tax_rates/index.html.erb +1 -1
  242. data/app/views/spree/admin/taxonomies/index.html.erb +1 -1
  243. data/app/views/spree/admin/themes/_theme.html.erb +6 -4
  244. data/app/views/spree/admin/themes/_theme_preview_image.html.erb +6 -4
  245. data/app/views/spree/admin/themes/index.html.erb +1 -1
  246. data/app/views/spree/admin/translations/edit.html.erb +2 -2
  247. data/app/views/spree/admin/user_passwords/edit.html.erb +21 -0
  248. data/app/views/spree/admin/user_passwords/new.html.erb +12 -0
  249. data/app/views/spree/admin/user_sessions/new.html.erb +16 -0
  250. data/app/views/spree/admin/users/_form.html.erb +9 -7
  251. data/app/views/spree/admin/users/_user.html.erb +4 -4
  252. data/app/views/spree/admin/users/index.html.erb +1 -1
  253. data/app/views/spree/admin/users/new.html.erb +1 -1
  254. data/app/views/spree/admin/variants/_search_result.html.erb +1 -1
  255. data/app/views/spree/admin/variants/_variant.html.erb +2 -2
  256. data/app/views/spree/admin/variants/form/_basic.html.erb +4 -4
  257. data/app/views/spree/admin/variants/form/_media_asset.html.erb +1 -1
  258. data/app/views/spree/admin/webhooks_subscribers/index.html.erb +1 -1
  259. data/app/views/spree/admin/zones/_form.html.erb +11 -15
  260. data/app/views/spree/admin/zones/index.html.erb +1 -1
  261. data/config/locales/en.yml +4 -0
  262. data/config/routes.rb +13 -1
  263. data/lib/spree/admin/engine.rb +2 -0
  264. data/lib/spree/admin.rb +1 -0
  265. metadata +65 -9
  266. data/app/views/spree/admin/products/form/_tax.html.erb +0 -12
@@ -0,0 +1,32 @@
1
+ <div class="dropdown">
2
+ <button type="button" class="btn btn-sm btn-light shadow-xs px-1" data-toggle="dropdown" aria-expanded="false">
3
+ <%= icon 'plus', class: 'mr-0' %>
4
+ </button>
5
+ <div class="dropdown-menu">
6
+ <%= link_to_with_icon 'shopping-bag-plus', Spree.t(:new_order), spree.admin_orders_path, class: "dropdown-item", data: { turbo_method: :post } if can?(:manage, Spree::Order) %>
7
+
8
+ <%= link_to spree.new_admin_product_path, class: 'dropdown-item' do %>
9
+ <%= icon 'cube-plus' %>
10
+ <%= Spree.t(:new_product) %>
11
+ <% end if can?(:create, Spree::Product) %>
12
+ <%= link_to spree.new_admin_user_path, class: 'dropdown-item' do %>
13
+ <%= icon 'user-plus' %>
14
+ <%= Spree.t(:new_customer) %>
15
+ <% end if can?(:manage, Spree.user_class) %>
16
+
17
+ <%= link_to spree.new_admin_promotion_path, class: 'dropdown-item' do %>
18
+ <%= icon 'discount' %>
19
+ <%= Spree.t(:new_promotion) %>
20
+ <% end if can?(:create, Spree::Promotion) %>
21
+
22
+ <%= invite_vendor_button(class: 'dropdown-item') if defined?(invite_vendor_button) %>
23
+
24
+ <% if can?(:create, Spree::Store) %>
25
+ <div class="dropdown-divider"></div>
26
+
27
+ <span data-toggle="modal" data-target="#modal-lg">
28
+ <%= link_to_with_icon 'building-store', Spree.t(:new_store), spree.new_admin_store_path, class: 'dropdown-item', data: { turbo_frame: 'dialog_modal_lg' } %>
29
+ </span>
30
+ <% end %>
31
+ </div>
32
+ </div>
@@ -1,6 +1,9 @@
1
1
  <% resource_name ||= model_class.name.demodulize.underscore.humanize %>
2
2
 
3
- <div class="text-muted p-5 d-flex align-items-center w-100 justify-content-center">
4
- <%= Spree.t(:no_resource_found, resource: resource_name) %>
5
- <%= link_to_with_icon 'plus', Spree.t(:add_one), new_object_url, class: 'btn btn-light ml-3', data: { 'turbo-frame': '_top' } if can?(:create, model_class) && defined?(new_object_url) && new_object_url.present? %>
3
+ <div class="text-muted p-5 d-flex align-items-center w-100 justify-content-center flex-column">
4
+ <%= icon 'map-search', class: 'mb-3 opacity-50', style: 'font-size: 2rem;' %>
5
+ <p>
6
+ <%= Spree.t(:no_resource_found, resource: resource_name) %>
7
+ </p>
8
+ <%= link_to_with_icon 'plus', Spree.t(:add_one), new_object_url, class: 'btn btn-link btn-sm ml-3', data: { 'turbo-frame': '_top' } if can?(:create, model_class) && defined?(new_object_url) && new_object_url.present? %>
6
9
  </div>
@@ -1,19 +1,6 @@
1
1
  <!-- Left off-canvas sidebar -->
2
- <div class="bs-canvas bs-canvas-left position-fixed bg-black h-100">
2
+ <div class="bs-canvas bs-canvas-left position-fixed h-100 bg-light border-right">
3
3
  <div class="bs-canvas-content px-2">
4
- <div class="d-flex align-items-center font-weight-bold py-3 bg-black text-white border-bottom border-black sticky-top justify-content-between">
5
- <div class="d-flex align-items-center">
6
- <% if defined?(current_store) && current_store&.present? %>
7
- <%= store_admin_icon(current_store, width: 36, height: 36) %>
8
- <span class="ml-3 font-size-lg">
9
- <%= truncate(current_store.name, length: 15) %>
10
- </span>
11
- <% end %>
12
- </div>
13
- <button class="btn py-0 bs-canvas-close text-white">
14
- <%= icon('x', height: 18, class: 'mr-0') %>
15
- </button>
16
- </div>
17
4
  <% if try_spree_current_user.present? %>
18
5
  <% if defined?(current_vendor) && current_vendor.present? %>
19
6
  <%= render 'spree/admin/shared/sidebar/vendor_nav' %>
@@ -1,6 +1,6 @@
1
1
  <div class="table-responsive card-lg">
2
2
  <table class="table table-condensed" id='refunds' data-order-id='<%= @order.number %>'>
3
- <thead class="text-muted">
3
+ <thead>
4
4
  <tr data-hook="refunds_header" class="border-bottom">
5
5
  <th><%= "#{Spree.t('date')}/#{Spree.t('time')}" %></th>
6
6
  <th><%= Spree.t(:amount) %></th>
@@ -1,15 +1,7 @@
1
1
  <aside id="main-sidebar">
2
2
  <% if defined?(current_vendor) && current_vendor.present? %>
3
- <%= render 'spree/admin/shared/sidebar/vendor_dropdown' %>
4
3
  <%= render 'spree/admin/shared/sidebar/vendor_nav' %>
5
4
  <% else %>
6
5
  <%= render 'spree/admin/shared/sidebar/store_nav' %>
7
6
  <% end %>
8
-
9
- <% unless settings_active? %>
10
- <section class="position-sticky d-none d-lg-block w-100 z-index-1000 mt-auto bottom-0">
11
- <%= render 'spree/admin/shared/sidebar/enterprise_edition_notice' %>
12
- <%= render 'spree/admin/shared/user_dropdown' %>
13
- </section>
14
- <% end %>
15
7
  </aside>
@@ -0,0 +1,13 @@
1
+ <% content_for :page_title, Spree.t(:users) %>
2
+
3
+ <%= content_for(:page_tabs) do %>
4
+ <%= nav_item(Spree.t(:users), spree.admin_admin_users_path) if can?(:manage, Spree.admin_user_class) %>
5
+ <%= nav_item(Spree.t(:invitations), spree.admin_invitations_path) if can?(:manage, Spree::Invitation) %>
6
+ <%= nav_item(Spree.t(:roles), spree.admin_roles_path) if can?(:manage, Spree::Role) %>
7
+ <% end %>
8
+
9
+ <% content_for :page_actions do %>
10
+ <span data-toggle="modal" data-target="#modal">
11
+ <%= link_to_with_icon 'send', Spree.t('actions.send_invitation'), spree.new_admin_invitation_path, class: "btn btn-primary", data: { turbo_frame: 'dialog_modal' } %>
12
+ </span>
13
+ <% end if can? :create, Spree::Invitation %>
@@ -1,38 +1,43 @@
1
1
  <% if try_spree_current_user.present? %>
2
- <div class="dropdown py-2 bg-gray-25 border-top" id="<%= dom_id(try_spree_current_user, 'account-dropdown') %>" data-turbo-permanent>
2
+ <div class="dropdown" id="<%= dom_id(try_spree_current_user, 'account-dropdown') %>" data-turbo-permanent>
3
3
  <button type="button"
4
- class="btn d-flex align-items-center justify-content-between text-left w-100"
4
+ class="btn d-flex align-items-center justify-content-between text-left w-100 pr-0"
5
5
  data-toggle="dropdown" aria-expanded="false" id="accountNav">
6
- <div class="d-flex align-items-center">
6
+ <%= render_avatar(try_spree_current_user, width: 32, height: 32) %>
7
+ </button>
8
+ <div class="dropdown-menu dropdown-menu-right" style="min-width: 250px;">
9
+ <div class="d-flex align-items-center p-2 bg-gray-25 rounded-lg">
7
10
  <%= render_avatar(try_spree_current_user, width: 34, height: 34) %>
8
11
  <span class="d-none d-lg-inline ml-lg-2">
9
- <%= try_spree_current_user.name&.full&.truncate(15)&.presence || try_spree_current_user.email.truncate(15) %><br />
10
- <span class="text-muted small"><%= try_spree_current_user.email.truncate(22) %></span>
12
+ <% if try_spree_current_user.name.present? %>
13
+ <%= try_spree_current_user.name&.full %><br />
14
+ <span class="small text-muted"><%= try_spree_current_user.email %></span>
15
+ <% else %>
16
+ <%= try_spree_current_user.email %><br />
17
+ <% end %>
11
18
  </span>
12
19
  </div>
13
- </button>
14
- <div class="dropdown-menu dropdown-menu-right w-100 mb-1 mt-1 mt-lg-0">
20
+
21
+ <%= render_admin_partials(:user_dropdown_partials) %>
22
+
15
23
  <% if can?(:update, try_spree_current_user) %>
24
+ <h6 class="dropdown-header mt-2">
25
+ <%= Spree.t(:account) %>
26
+ </h6>
16
27
  <%= link_to_with_icon 'user-scan', Spree.t('admin.edit_profile'), spree.edit_admin_profile_path, class: 'dropdown-item' %>
17
28
  <% end %>
18
29
 
19
- <% if enterprise_edition? && try_spree_current_user.respond_to?(:accounts) && try_spree_current_user.accounts.count > 1 %>
20
- <div data-toggle="modal" data-target="#modal">
21
- <%= link_to_with_icon 'switch-3', Spree.t(:switch_team), main_app.accounts_path, class: 'dropdown-item', data: { turbo_frame: 'dialog_modal' } %>
22
- </div>
30
+ <% if can?(:manage, current_store) %>
31
+ <h6 class="dropdown-header mt-2">
32
+ <%= Spree.t(:support) %>
33
+ </h6>
34
+ <%= external_link_to Spree.t(:help_center), 'https://spreecommerce.org/docs/user', class: 'dropdown-item justify-content-between', target: '_blank' %>
35
+ <%= external_link_to Spree.t(:contact_us), 'https://spreecommerce.org/contact/', class: 'dropdown-item justify-content-between', target: '_blank' %>
23
36
  <% end %>
24
37
 
25
- <% if enterprise_edition? && defined?(app_domain) && defined?(Vendo::Account) && can?(:create, Vendo::Account) %>
26
- <%= link_to_with_icon 'plus', Spree.t(:create_new_team), main_app.new_account_url(host: app_domain), class: 'dropdown-item', data: { turbo: false } %>
27
- <% end %>
28
-
29
- <div class="dropdown-divider"></div>
30
-
31
- <%= link_to_with_icon 'book', 'Help center', 'https://spreecommerce.org/docs/user', class: 'dropdown-item', target: '_blank' %>
32
- <%= link_to_with_icon 'message-circle', 'Contact us', 'https://spreecommerce.org/contact/', class: 'dropdown-item', target: '_blank' %>
33
38
  <div class="dropdown-divider"></div>
34
39
 
35
- <%= button_to spree_admin_logout_path, class: 'dropdown-item mb-0', method: :delete do %>
40
+ <%= button_to spree_admin_logout_path, class: 'dropdown-item mb-0 btn-danger', method: :delete do %>
36
41
  <%= icon('logout', class: "icon icon-logout") %>
37
42
  <%= Spree.t(:logout) %>
38
43
  <% end if defined?(spree_admin_logout_path) %>
@@ -0,0 +1,18 @@
1
+ <div class="mb-2 d-flex justify-content-between">
2
+ <div>
3
+ <% if defined?(devise_mapping) && devise_mapping.rememberable? && controller_name == 'user_sessions' %>
4
+ <div class="custom-control custom-checkbox">
5
+ <%= f.check_box :remember_me, class: "custom-control-input" %>
6
+ <%= f.label :remember_me, Spree.t(:remember_me), class: "custom-control-label" %>
7
+ </div>
8
+ <% end %>
9
+ </div>
10
+ <div class="d-flex align-items-center gap-2">
11
+ <% if controller_name != 'user_sessions' %>
12
+ <p><%= link_to Spree.t(:log_in), new_session_path(resource_name) %></p>
13
+ <% end %>
14
+ <% if defined?(devise_mapping) && devise_mapping.recoverable? && controller_name != 'user_passwords' && controller_name != 'user_registrations' %>
15
+ <p><%= link_to Spree.t(:forgot_password), new_password_path(resource_name) %></p>
16
+ <% end %>
17
+ </div>
18
+ </div>
@@ -1,10 +1,12 @@
1
1
  <% if can?(:manage, current_store) && !enterprise_edition? %>
2
2
  <% unless session[:spree_enterprise_edition_notice_dismissed] %>
3
- <div id="enterprise-edition-notice">
4
- <%= link_to '', spree.admin_dismiss_enterprise_edition_notice_path, method: :patch, class: 'btn-close' %>
5
- <p class="mb-1">You're using Spree Community Edition. To get access to all features, please upgrade to Enterprise Edition.</p>
3
+ <section class="d-none d-lg-block">
4
+ <div id="enterprise-edition-notice">
5
+ <%= link_to '', spree.admin_dismiss_enterprise_edition_notice_path, method: :patch, class: 'btn-close' %>
6
+ <p>You're using Spree Community Edition. To get access to all features, please upgrade to Enterprise Edition.</p>
6
7
 
7
- <%= external_link_to 'Upgrade', 'https://spreecommerce.org/pricing', target: '_blank', class: 'btn btn-link btn-sm shadow-xs' %>
8
- </div>
8
+ <%= external_link_to 'Upgrade', 'https://spreecommerce.org/pricing', target: '_blank', class: 'btn btn-link btn-sm shadow-xs' %>
9
+ </div>
10
+ </section>
9
11
  <% end %>
10
12
  <% end %>
@@ -1,7 +1,5 @@
1
- <li class="nav-item">
2
- <span class="nav-link d-flex align-items-center pr-1 cursor-default with-tip" title="Connect your store to third-party services to automate your business processes.">
3
- <%= icon 'plug' %>
4
- <span><%= Spree.t(:integrations) %></span>
5
- <span class="badge ml-auto rounded-pill">Coming soon!</span>
6
- </span>
7
- </li>
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>
5
+ <% end %>
@@ -8,7 +8,7 @@
8
8
  <%= nav_item(orders_label.html_safe, spree.admin_orders_path, icon: 'inbox', active: orders_active) %>
9
9
 
10
10
  <% if orders_active && (ready_to_ship_orders_count&.positive? || can?(:manage, :checkouts)) %>
11
- <ul class="ml-4 pl-1 mb-2 nav-submenu mt-1">
11
+ <ul class="nav-submenu">
12
12
  <% if ready_to_ship_orders_count&.positive? %>
13
13
  <% fulfill_label = Spree.t('admin.orders.orders_to_fulfill') %>
14
14
  <% fulfill_label += content_tag(:span, ready_to_ship_orders_count, class: 'badge ml-auto') %>
@@ -16,7 +16,7 @@
16
16
  <% end %>
17
17
 
18
18
  <% if can?(:manage, :checkouts) %>
19
- <%= nav_item(Spree.t(:draft_orders), spree.admin_checkouts_path) %>
19
+ <%= nav_item(Spree.t(:draft_orders), spree.admin_checkouts_path, active: controller_name == 'checkouts' || (@order.present? && !@order.completed?)) %>
20
20
  <% end %>
21
21
 
22
22
  <%= render_admin_partials(:store_orders_nav_partials) %>
@@ -1,8 +1,8 @@
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
- <%= nav_item(Spree.t(:products), spree.admin_products_path, icon: 'box-seam', active: products_active) %>
3
+ <%= nav_item(Spree.t(:products), spree.admin_products_path, icon: 'package', active: products_active) %>
4
4
  <% if products_active %>
5
- <ul class="ml-4 pl-1 mb-2 nav-submenu mt-1">
5
+ <ul class="nav-submenu">
6
6
  <% if can?(:manage, Spree::StockItem) || can?(:manage, Spree::StockTransfer) %>
7
7
  <%= nav_item(Spree.t(:stock), spree.admin_stock_items_path, active: %w[stock_items stock_transfers].include?(controller_name)) %>
8
8
  <% end %>
@@ -0,0 +1,17 @@
1
+ <% if can?(:manage, Spree::Promotion) %>
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>
17
+ <% end %>
@@ -4,7 +4,7 @@
4
4
  <%= nav_item(Spree.t(:returns), spree.admin_customer_returns_path, icon: 'receipt-refund', active: returns_active) %>
5
5
 
6
6
  <% if returns_active %>
7
- <ul class="ml-4 pl-1 mb-2 nav-submenu mt-1">
7
+ <ul class="nav-submenu">
8
8
  <% if can?(:manage, Spree::ReturnAuthorization) %>
9
9
  <%= nav_item(Spree.t(:return_authorizations), spree.admin_return_authorizations_path) %>
10
10
  <% end %>
@@ -1,46 +1,11 @@
1
- <% if available_stores.count > 1 %>
2
- <div class="modal fade" id="switch-store-modal" tabindex="-1" role="dialog" aria-labelledby="switchStoreModalLabel" aria-hidden="true">
3
- <div class="modal-dialog" role="document">
4
- <div class="modal-content">
5
- <%= modal_header(icon('switch-horizontal', class: 'mr-2') + Spree.t(:switch_store)) %>
6
- <div class="modal-body">
7
- <div class="list-group">
8
- <% available_stores.each do |store| %>
9
- <% if store.id != current_store.id %>
10
- <%= link_to spree.admin_dashboard_url(host: store.url), class: 'list-group-item hover-light d-flex text-dark w-100 align-items-center text-primary' do %>
11
- <%= store_admin_icon(current_store, height: 32, width: 32) %>
12
- <span class="ml-3">
13
- <%= store.name %>
14
- </span>
15
- <% end %>
16
- <% else %>
17
- <div class="list-group-item d-flex text-dark w-100 align-items-center cursor-disabled active">
18
- <%= store_admin_icon(current_store, height: 32, width: 32) %>
19
- <span class="ml-3">
20
- <%= store.name %>
21
- </span>
22
-
23
- <%= icon('check', class: 'ml-auto') %>
24
- </div>
25
- <% end %>
26
- <% end %>
27
- </div>
28
- </div>
29
- </div>
30
- </div>
31
- </div>
32
- <% end %>
33
-
34
- <div class="border-bottom border-bottom-dashed pb-2 d-flex align-items-center justify-content-between pr-1" id="store-menu" data-turbo-permanent>
1
+ <div class="store-dropdown" id="store-menu" data-turbo-permanent>
35
2
  <div class="dropdown">
36
- <button type="button" class="btn d-flex align-items-center justify-content-between text-left dropdown-toggle d-flex align-items-center gap-2"
3
+ <button type="button" class="btn store-dropdown-button dropdown-toggle"
37
4
  data-toggle="dropdown" aria-expanded="false">
38
5
  <%= store_admin_icon(current_store, height: 32, width: 32) %>
39
- <span class="d-none d-lg-block">
40
- <%= truncate(current_store.name, length: 10) %>
41
- </span>
6
+ <%= truncate(current_store.name, length: 10) %>
42
7
  </button>
43
- <div class="dropdown-menu">
8
+ <div class="dropdown-menu ml-2">
44
9
  <%= link_to current_store.formatted_url_or_custom_domain, class: 'dropdown-item', target: '_blank' do %>
45
10
  <%= icon 'eye' %>
46
11
  <%= Spree.t(:view_store) %>
@@ -52,45 +17,38 @@
52
17
 
53
18
  <% if available_stores.count > 1 %>
54
19
  <div class="dropdown-divider"></div>
55
- <%= link_to "#", class: 'dropdown-item mb-0', data: { toggle: 'modal', target: '#switch-store-modal' } do %>
56
- <%= icon 'switch-horizontal' %>
20
+ <h6 class="dropdown-header">
57
21
  <%= Spree.t(:switch_store) %>
58
- <% end %>
22
+ </h6>
23
+ <div class="store-chooser">
24
+ <% available_stores.each do |store| %>
25
+ <% if store.id == current_store.id %>
26
+ <div class="store-chooser-item active">
27
+ <%= store_admin_icon(store, height: 32, width: 32) %>
28
+ <span class="d-flex flex-column mr-2">
29
+ <%= store.name %>
30
+ <small class="text-muted">
31
+ <%= store.url_or_custom_domain %>
32
+ </small>
33
+ </span>
34
+ <%= icon('check', class: 'ml-auto') %>
35
+ </div>
36
+ <% else %>
37
+ <%= link_to spree.admin_dashboard_url(host: store.url), class: 'store-chooser-item' do %>
38
+ <%= store_admin_icon(store, height: 32, width: 32) %>
39
+ <span class="d-flex flex-column">
40
+ <%= store.name %>
41
+ <small class="text-muted">
42
+ <%= store.url_or_custom_domain %>
43
+ </small>
44
+ </span>
45
+ <% end %>
46
+ <% end %>
47
+ <% end %>
48
+ </div>
59
49
  <% end %>
60
50
  </div>
61
51
  </div>
62
52
 
63
- <div class="dropdown">
64
- <button type="button" class="btn btn-sm btn-light shadow-xs" data-toggle="dropdown" aria-expanded="false">
65
- <%= icon 'plus', class: 'mr-0' %>
66
- </button>
67
- <div class="dropdown-menu">
68
- <%= link_to_with_icon 'shopping-cart', Spree.t(:new_order), spree.admin_orders_path, class: "dropdown-item", data: { turbo_method: :post } if can?(:create, Spree::Order) %>
69
-
70
- <%= link_to spree.new_admin_product_path, class: 'dropdown-item' do %>
71
- <%= icon 'box' %>
72
- <%= Spree.t(:new_product) %>
73
- <% end if can?(:create, Spree::Product) %>
74
- <%= link_to spree.new_admin_user_path, class: 'dropdown-item' do %>
75
- <%= icon 'user' %>
76
- <%= Spree.t(:new_user) %>
77
- <% end if can?(:create, Spree.user_class) %>
78
-
79
- <%= link_to spree.new_admin_promotion_path, class: 'dropdown-item' do %>
80
- <%= icon 'discount' %>
81
- <%= Spree.t(:new_promotion) %>
82
- <% end if can?(:create, Spree::Promotion) %>
83
-
84
- <%= invite_vendor_button(class: 'dropdown-item') if defined?(invite_vendor_button) %>
85
-
86
- <% if can?(:create, Spree::Store) %>
87
- <div class="dropdown-divider"></div>
88
-
89
- <span data-toggle="modal" data-target="#modal-lg">
90
- <%= link_to_with_icon 'building-store', Spree.t(:new_store), spree.new_admin_store_path, class: 'dropdown-item', data: { turbo_frame: 'dialog_modal_lg' } %>
91
- </span>
92
- <% end %>
93
- </div>
94
- </div>
53
+ <%= render 'spree/admin/shared/new_item_dropdown' %>
95
54
  </div>
96
-
@@ -1,16 +1,11 @@
1
1
  <% if settings_active? %>
2
2
  <ul class="nav flex-column">
3
- <li class="nav-item mb-1 py-2 border-bottom border-bottom-dashed">
4
- <%= active_link_to_with_icon('chevron-left', Spree.t('admin.back_to_dashboard'), spree.admin_dashboard_path, class: 'nav-link') %>
5
- </li>
6
-
7
3
  <% if can?(:manage, current_store) %>
8
4
  <%= nav_item(Spree.t(:store_details), spree.edit_admin_store_path(section: 'general-settings'), icon: 'building-store', active: params[:section] == 'general-settings') %>
9
5
  <% end %>
10
6
 
11
- <% if defined?(current_account) && current_account.present? && can?(:manage, current_account) %>
12
- <%= nav_item(Spree.t(:account), main_app.edit_account_path(current_account), icon: 'receipt') %>
13
- <%= nav_item(Spree.t(:account_members), main_app.account_members_path(current_account), icon: 'users') %>
7
+ <% if can?(:manage, Spree.admin_user_class) %>
8
+ <%= nav_item(Spree.t(:users), spree.admin_admin_users_path, icon: 'users', active: %w[admin_users invitations roles].include?(controller_name)) %>
14
9
  <% end %>
15
10
 
16
11
  <% if can?(:manage, current_store) %>
@@ -70,8 +65,6 @@
70
65
  <%= render_admin_partials(:settings_nav_partials) %>
71
66
  </ul>
72
67
  <% else %>
73
- <%= render 'spree/admin/shared/sidebar/store_dropdown' %>
74
-
75
68
  <ul class="nav flex-column">
76
69
  <% unless current_store.setup_completed? %>
77
70
  <li class="nav-item">
@@ -107,23 +100,7 @@
107
100
  </li>
108
101
  <% end %>
109
102
 
110
- <% if can?(:manage, Spree::Promotion) %>
111
- <% discounts_active = %w[promotions gift_cards gift_card_batches coupon_codes].include?(controller_name) %>
112
- <li class="nav-item">
113
- <%= active_link_to spree.admin_promotions_path, class: 'nav-link', active: discounts_active do %>
114
- <%= icon 'discount' %>
115
- <%= Spree.t(:promotions) %>
116
- <% end %>
117
-
118
- <% if discounts_active && defined?(Spree::GiftCard) && spree.respond_to?(:admin_gift_cards_path) && can?(:manage, Spree::GiftCard) %>
119
- <ul class="ml-4 pl-1 mb-2 nav-submenu mt-1">
120
- <li class="nav-item">
121
- <%= 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) %>
122
- </li>
123
- </ul>
124
- <% end %>
125
- </li>
126
- <% end %>
103
+ <%= render 'spree/admin/shared/sidebar/promotions_nav' %>
127
104
 
128
105
  <% if can?(:manage, Spree::Report) %>
129
106
  <li class="nav-item">
@@ -141,13 +118,16 @@
141
118
  <li class="nav-item border-top border-top-dashed my-1"></li>
142
119
  <%= render 'spree/admin/shared/sidebar/storefront_nav' %>
143
120
  <%= render 'spree/admin/shared/sidebar/integrations_nav' %>
144
-
145
- <% if can?(:manage, current_store) %>
146
- <li class="nav-item border-top border-top-dashed my-1"></li>
147
- <%= nav_item(Spree.t(:settings), spree.edit_admin_store_path(section: 'general-settings'), icon: 'settings', active: params[:section] == 'general-settings') %>
148
- <% end %>
149
- <% if defined?(current_account) && current_account.present? && can?(:manage, current_account) %>
150
- <%= nav_item(Spree.t(:account_members), main_app.account_members_path(current_account), icon: 'users') %>
151
- <% end %>
152
121
  </ul>
122
+
123
+ <div class="mt-auto d-flex flex-column">
124
+ <%= render 'spree/admin/shared/sidebar/enterprise_edition_notice' %>
125
+
126
+ <ul class="nav flex-column mb-2">
127
+ <% if can?(:manage, current_store) %>
128
+ <%= nav_item(Spree.t(:settings), spree.edit_admin_store_path(section: 'general-settings'), icon: 'settings', active: params[:section] == 'general-settings') %>
129
+ <%= nav_item(Spree.t(:users), spree.admin_admin_users_path, icon: 'users') %>
130
+ <% end %>
131
+ </ul>
132
+ </div>
153
133
  <% end %>
@@ -3,8 +3,10 @@
3
3
  <%= nav_item(Spree.t('admin.storefront'), spree.admin_themes_path, icon: 'building-store', active: storefront_active) %>
4
4
 
5
5
  <% if storefront_active %>
6
- <ul class="ml-4 pl-1 mb-2 nav-submenu mt-1">
7
- <%= nav_item(Spree.t(:themes), spree.admin_themes_path) %>
6
+ <ul class="nav-submenu">
7
+ <% if can?(:manage, Spree::Theme) %>
8
+ <%= nav_item(Spree.t(:themes), spree.admin_themes_path) %>
9
+ <% end %>
8
10
 
9
11
  <% if can?(:manage, Spree::Page) %>
10
12
  <%= nav_item(Spree.t(:pages), spree.admin_pages_path) %>
@@ -1,8 +1,10 @@
1
- <li class="nav-item">
2
- <%= external_link_to nil, 'https://spreecommerce.org/pricing', class: 'nav-link d-flex align-items-center w-100' do %>
3
- <%= icon 'heart-handshake' %>
4
- <%= Spree.t(:vendors) %>
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) %>
5
6
 
6
- <span class="badge ml-auto with-tip rounded-pill" title="This feature is part of the Enterprise Edition.">Enterprise</span>
7
- <% end %>
8
- </li>
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
+ <% end%>
@@ -31,7 +31,7 @@
31
31
 
32
32
  <div class="dropdown ml-2 h-100">
33
33
  <button class="btn btn-light btn-sm px-1 h-100" type="button" id="dropdownMenuButton-<%= taxon.id %>" data-toggle="dropdown" aria-haspopup="true" aria-expanded="false">
34
- <%= icon('dots', class: 'mr-0') %>
34
+ <%= icon('dots-vertical', class: 'mr-0') %>
35
35
  </button>
36
36
  <div class="dropdown-menu dropdown-menu-right" aria-labelledby="dropdownMenuButton-<%= taxon.id %>">
37
37
  <% if can?(:create, Spree::Taxon) %>
@@ -12,7 +12,7 @@
12
12
  <% if @collection.any? %>
13
13
  <div class="table-responsive">
14
14
  <table class="table">
15
- <thead class="text-muted">
15
+ <thead>
16
16
  <tr>
17
17
  <th><%= Spree.t(:name) %></th>
18
18
  <th></th>