spree_page_builder 5.3.0.rc1

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 (219) hide show
  1. checksums.yaml +7 -0
  2. data/README.md +43 -0
  3. data/Rakefile +18 -0
  4. data/app/controllers/concerns/spree/admin/page_builder_concern.rb +45 -0
  5. data/app/controllers/concerns/spree/admin/storefront_breadcrumb_concern.rb +12 -0
  6. data/app/controllers/spree/admin/page_blocks_controller.rb +58 -0
  7. data/app/controllers/spree/admin/page_links_controller.rb +60 -0
  8. data/app/controllers/spree/admin/page_sections_controller.rb +82 -0
  9. data/app/controllers/spree/admin/pages_controller.rb +39 -0
  10. data/app/controllers/spree/admin/storefront_controller.rb +41 -0
  11. data/app/controllers/spree/admin/themes_controller.rb +87 -0
  12. data/app/helpers/spree/admin/page_builder_helper.rb +125 -0
  13. data/app/helpers/spree/admin/themes_helper.rb +9 -0
  14. data/app/jobs/spree/page_builder/products/touch_taxons_job_decorator.rb +15 -0
  15. data/app/jobs/spree/themes/duplicate_components_job.rb +59 -0
  16. data/app/jobs/spree/themes/screenshot_job.rb +81 -0
  17. data/app/models/concerns/spree/has_page_links.rb +53 -0
  18. data/app/models/spree/page.rb +188 -0
  19. data/app/models/spree/page_block.rb +73 -0
  20. data/app/models/spree/page_blocks/buttons.rb +29 -0
  21. data/app/models/spree/page_blocks/heading.rb +18 -0
  22. data/app/models/spree/page_blocks/image.rb +20 -0
  23. data/app/models/spree/page_blocks/link.rb +21 -0
  24. data/app/models/spree/page_blocks/mega_nav.rb +33 -0
  25. data/app/models/spree/page_blocks/mega_nav_with_subcategories.rb +32 -0
  26. data/app/models/spree/page_blocks/metafields.rb +18 -0
  27. data/app/models/spree/page_blocks/nav.rb +15 -0
  28. data/app/models/spree/page_blocks/newsletter_form.rb +18 -0
  29. data/app/models/spree/page_blocks/products/brand.rb +15 -0
  30. data/app/models/spree/page_blocks/products/buy_buttons.rb +24 -0
  31. data/app/models/spree/page_blocks/products/description.rb +18 -0
  32. data/app/models/spree/page_blocks/products/price.rb +18 -0
  33. data/app/models/spree/page_blocks/products/quantity_selector.rb +20 -0
  34. data/app/models/spree/page_blocks/products/share.rb +8 -0
  35. data/app/models/spree/page_blocks/products/title.rb +19 -0
  36. data/app/models/spree/page_blocks/products/variant_picker.rb +13 -0
  37. data/app/models/spree/page_blocks/subheading.rb +17 -0
  38. data/app/models/spree/page_blocks/text.rb +16 -0
  39. data/app/models/spree/page_builder/policy_decorator.rb +17 -0
  40. data/app/models/spree/page_builder/post_decorator.rb +17 -0
  41. data/app/models/spree/page_builder/product_decorator.rb +17 -0
  42. data/app/models/spree/page_builder/store_decorator.rb +46 -0
  43. data/app/models/spree/page_builder/taxon_decorator.rb +45 -0
  44. data/app/models/spree/page_link.rb +60 -0
  45. data/app/models/spree/page_section.rb +222 -0
  46. data/app/models/spree/page_sections/announcement_bar.rb +28 -0
  47. data/app/models/spree/page_sections/breadcrumbs.rb +12 -0
  48. data/app/models/spree/page_sections/collection_banner.rb +18 -0
  49. data/app/models/spree/page_sections/custom_code.rb +11 -0
  50. data/app/models/spree/page_sections/featured_posts.rb +45 -0
  51. data/app/models/spree/page_sections/featured_product.rb +50 -0
  52. data/app/models/spree/page_sections/featured_taxon.rb +90 -0
  53. data/app/models/spree/page_sections/featured_taxons.rb +45 -0
  54. data/app/models/spree/page_sections/footer.rb +101 -0
  55. data/app/models/spree/page_sections/header.rb +62 -0
  56. data/app/models/spree/page_sections/image_banner.rb +55 -0
  57. data/app/models/spree/page_sections/image_with_text.rb +65 -0
  58. data/app/models/spree/page_sections/main_password_footer.rb +18 -0
  59. data/app/models/spree/page_sections/main_password_header.rb +20 -0
  60. data/app/models/spree/page_sections/newsletter.rb +54 -0
  61. data/app/models/spree/page_sections/page_title.rb +19 -0
  62. data/app/models/spree/page_sections/post_details.rb +19 -0
  63. data/app/models/spree/page_sections/post_grid.rb +19 -0
  64. data/app/models/spree/page_sections/product_details.rb +53 -0
  65. data/app/models/spree/page_sections/product_grid.rb +13 -0
  66. data/app/models/spree/page_sections/related_products.rb +58 -0
  67. data/app/models/spree/page_sections/rich_text.rb +31 -0
  68. data/app/models/spree/page_sections/taxon_banner.rb +18 -0
  69. data/app/models/spree/page_sections/taxon_grid.rb +17 -0
  70. data/app/models/spree/page_sections/video.rb +107 -0
  71. data/app/models/spree/pages/account.rb +19 -0
  72. data/app/models/spree/pages/cart.rb +19 -0
  73. data/app/models/spree/pages/checkout.rb +15 -0
  74. data/app/models/spree/pages/custom.rb +38 -0
  75. data/app/models/spree/pages/homepage.rb +72 -0
  76. data/app/models/spree/pages/login.rb +19 -0
  77. data/app/models/spree/pages/password.rb +59 -0
  78. data/app/models/spree/pages/post.rb +27 -0
  79. data/app/models/spree/pages/post_list.rb +36 -0
  80. data/app/models/spree/pages/product_details.rb +30 -0
  81. data/app/models/spree/pages/search_results.rb +43 -0
  82. data/app/models/spree/pages/shop_all.rb +40 -0
  83. data/app/models/spree/pages/taxon.rb +29 -0
  84. data/app/models/spree/pages/taxon_list.rb +41 -0
  85. data/app/models/spree/pages/wishlist.rb +15 -0
  86. data/app/models/spree/theme.rb +233 -0
  87. data/app/models/spree/themes/default.rb +97 -0
  88. data/app/services/spree/taxons/touch_featured_sections.rb +21 -0
  89. data/app/views/layouts/spree/page_builder.html.erb +46 -0
  90. data/app/views/spree/admin/dashboard/_store_preview.html.erb +38 -0
  91. data/app/views/spree/admin/page_blocks/_form_tab_buttons.html.erb +5 -0
  92. data/app/views/spree/admin/page_blocks/create.turbo_stream.erb +4 -0
  93. data/app/views/spree/admin/page_blocks/destroy.turbo_stream.erb +9 -0
  94. data/app/views/spree/admin/page_blocks/edit.html.erb +43 -0
  95. data/app/views/spree/admin/page_blocks/forms/_brand.html.erb +15 -0
  96. data/app/views/spree/admin/page_blocks/forms/_brand_logo.html.erb +4 -0
  97. data/app/views/spree/admin/page_blocks/forms/_buttons.html.erb +13 -0
  98. data/app/views/spree/admin/page_blocks/forms/_heading.html.erb +28 -0
  99. data/app/views/spree/admin/page_blocks/forms/_image.html.erb +10 -0
  100. data/app/views/spree/admin/page_blocks/forms/_link.html.erb +19 -0
  101. data/app/views/spree/admin/page_blocks/forms/_mega_nav.html.erb +14 -0
  102. data/app/views/spree/admin/page_blocks/forms/_mega_nav_with_subcategories.html.erb +9 -0
  103. data/app/views/spree/admin/page_blocks/forms/_metafields.html.erb +35 -0
  104. data/app/views/spree/admin/page_blocks/forms/_nav.html.erb +6 -0
  105. data/app/views/spree/admin/page_blocks/forms/_newsletter_form.html.erb +20 -0
  106. data/app/views/spree/admin/page_blocks/forms/_price.html.erb +15 -0
  107. data/app/views/spree/admin/page_blocks/forms/_share.html.erb +5 -0
  108. data/app/views/spree/admin/page_blocks/forms/_subheading.html.erb +26 -0
  109. data/app/views/spree/admin/page_blocks/forms/_text.html.erb +21 -0
  110. data/app/views/spree/admin/page_blocks/forms/_title.html.erb +20 -0
  111. data/app/views/spree/admin/page_blocks/forms/_variant_picker.html.erb +10 -0
  112. data/app/views/spree/admin/page_blocks/forms/products/_buy_buttons.html.erb +10 -0
  113. data/app/views/spree/admin/page_blocks/forms/products/_description.html.erb +0 -0
  114. data/app/views/spree/admin/page_blocks/forms/products/_quantity_selector.html.erb +10 -0
  115. data/app/views/spree/admin/page_blocks/move_higher.turbo_stream.erb +4 -0
  116. data/app/views/spree/admin/page_blocks/move_lower.turbo_stream.erb +4 -0
  117. data/app/views/spree/admin/page_blocks/show.html.erb +1 -0
  118. data/app/views/spree/admin/page_blocks/update.turbo_stream.erb +6 -0
  119. data/app/views/spree/admin/page_builder/_add_block.html.erb +22 -0
  120. data/app/views/spree/admin/page_builder/_color_palette.html.erb +17 -0
  121. data/app/views/spree/admin/page_builder/_color_picker.html.erb +26 -0
  122. data/app/views/spree/admin/page_builder/_header.html.erb +113 -0
  123. data/app/views/spree/admin/page_builder/_labeled_range_input.html.erb +10 -0
  124. data/app/views/spree/admin/page_builder/_pages_dropdown.html.erb +17 -0
  125. data/app/views/spree/admin/page_builder/_range_input.html.erb +12 -0
  126. data/app/views/spree/admin/page_builder/_sidebar.html.erb +12 -0
  127. data/app/views/spree/admin/page_builder/_sidebar_block.html.erb +30 -0
  128. data/app/views/spree/admin/page_builder/_sidebar_colors.html.erb +86 -0
  129. data/app/views/spree/admin/page_builder/_sidebar_fonts.html.erb +85 -0
  130. data/app/views/spree/admin/page_builder/_sidebar_section.html.erb +44 -0
  131. data/app/views/spree/admin/page_builder/_sidebar_sections.html.erb +38 -0
  132. data/app/views/spree/admin/page_builder/_sidebar_sections_toolbar.html.erb +180 -0
  133. data/app/views/spree/admin/page_links/_form.html.erb +10 -0
  134. data/app/views/spree/admin/page_links/_linkable_type_dropdown.html.erb +15 -0
  135. data/app/views/spree/admin/page_links/_list.html.erb +36 -0
  136. data/app/views/spree/admin/page_links/_refresh_theme_preview.turbo_stream.erb +5 -0
  137. data/app/views/spree/admin/page_links/create.turbo_stream.erb +10 -0
  138. data/app/views/spree/admin/page_links/destroy.turbo_stream.erb +15 -0
  139. data/app/views/spree/admin/page_links/edit.html.erb +27 -0
  140. data/app/views/spree/admin/page_links/update.turbo_stream.erb +14 -0
  141. data/app/views/spree/admin/page_sections/_form_tab_buttons.html.erb +8 -0
  142. data/app/views/spree/admin/page_sections/create.turbo_stream.erb +11 -0
  143. data/app/views/spree/admin/page_sections/destroy.turbo_stream.erb +16 -0
  144. data/app/views/spree/admin/page_sections/edit.html.erb +39 -0
  145. data/app/views/spree/admin/page_sections/fields/_background_color.html.erb +6 -0
  146. data/app/views/spree/admin/page_sections/fields/_border_bottom_width.html.erb +5 -0
  147. data/app/views/spree/admin/page_sections/fields/_border_color.html.erb +7 -0
  148. data/app/views/spree/admin/page_sections/fields/_border_top_width.html.erb +6 -0
  149. data/app/views/spree/admin/page_sections/fields/_bottom_padding.html.erb +5 -0
  150. data/app/views/spree/admin/page_sections/fields/_button.html.erb +15 -0
  151. data/app/views/spree/admin/page_sections/fields/_header_layout.html.erb +26 -0
  152. data/app/views/spree/admin/page_sections/fields/_height.html.erb +6 -0
  153. data/app/views/spree/admin/page_sections/fields/_text_color.html.erb +7 -0
  154. data/app/views/spree/admin/page_sections/fields/_top_padding.html.erb +6 -0
  155. data/app/views/spree/admin/page_sections/forms/_announcement_bar.html.erb +5 -0
  156. data/app/views/spree/admin/page_sections/forms/_brand_story.html.erb +0 -0
  157. data/app/views/spree/admin/page_sections/forms/_breadcrumbs.html.erb +0 -0
  158. data/app/views/spree/admin/page_sections/forms/_collection_banner.html.erb +0 -0
  159. data/app/views/spree/admin/page_sections/forms/_custom_code.html.erb +4 -0
  160. data/app/views/spree/admin/page_sections/forms/_featured_posts.html.erb +33 -0
  161. data/app/views/spree/admin/page_sections/forms/_featured_product.html.erb +4 -0
  162. data/app/views/spree/admin/page_sections/forms/_featured_taxon.html.erb +59 -0
  163. data/app/views/spree/admin/page_sections/forms/_featured_taxons.html.erb +13 -0
  164. data/app/views/spree/admin/page_sections/forms/_footer.html.erb +20 -0
  165. data/app/views/spree/admin/page_sections/forms/_header.html.erb +12 -0
  166. data/app/views/spree/admin/page_sections/forms/_image_banner.html.erb +13 -0
  167. data/app/views/spree/admin/page_sections/forms/_image_with_text.html.erb +28 -0
  168. data/app/views/spree/admin/page_sections/forms/_main_password_footer.html.erb +9 -0
  169. data/app/views/spree/admin/page_sections/forms/_main_password_header.erb +13 -0
  170. data/app/views/spree/admin/page_sections/forms/_newsletter.html.erb +15 -0
  171. data/app/views/spree/admin/page_sections/forms/_page_title.html.erb +4 -0
  172. data/app/views/spree/admin/page_sections/forms/_post_details.html.erb +0 -0
  173. data/app/views/spree/admin/page_sections/forms/_post_grid.html.erb +0 -0
  174. data/app/views/spree/admin/page_sections/forms/_product_details.html.erb +1 -0
  175. data/app/views/spree/admin/page_sections/forms/_product_grid.html.erb +1 -0
  176. data/app/views/spree/admin/page_sections/forms/_related_products.html.erb +32 -0
  177. data/app/views/spree/admin/page_sections/forms/_rich_text.html.erb +0 -0
  178. data/app/views/spree/admin/page_sections/forms/_taxon_banner.html.erb +0 -0
  179. data/app/views/spree/admin/page_sections/forms/_taxon_grid.html.erb +5 -0
  180. data/app/views/spree/admin/page_sections/forms/_video.html.erb +15 -0
  181. data/app/views/spree/admin/page_sections/move_higher.turbo_stream.erb +7 -0
  182. data/app/views/spree/admin/page_sections/move_lower.turbo_stream.erb +7 -0
  183. data/app/views/spree/admin/page_sections/new.html.erb +26 -0
  184. data/app/views/spree/admin/page_sections/remove_attachment.turbo_stream.erb +4 -0
  185. data/app/views/spree/admin/page_sections/restore_design_settings_to_defaults.turbo_stream.erb +4 -0
  186. data/app/views/spree/admin/page_sections/show.html.erb +1 -0
  187. data/app/views/spree/admin/page_sections/update.turbo_stream.erb +10 -0
  188. data/app/views/spree/admin/pages/_form.html.erb +20 -0
  189. data/app/views/spree/admin/pages/_table_header.html.erb +6 -0
  190. data/app/views/spree/admin/pages/_table_row.html.erb +28 -0
  191. data/app/views/spree/admin/pages/edit.html.erb +13 -0
  192. data/app/views/spree/admin/pages/filters.html.erb +7 -0
  193. data/app/views/spree/admin/pages/index.html.erb +11 -0
  194. data/app/views/spree/admin/pages/new.html.erb +1 -0
  195. data/app/views/spree/admin/storefront/edit.html.erb +89 -0
  196. data/app/views/spree/admin/themes/_theme.html.erb +56 -0
  197. data/app/views/spree/admin/themes/_theme_preview_image.html.erb +17 -0
  198. data/app/views/spree/admin/themes/edit.html.erb +14 -0
  199. data/app/views/spree/admin/themes/index.html.erb +80 -0
  200. data/app/views/spree/admin/themes/update.turbo_stream.erb +1 -0
  201. data/config/initializers/spree_admin_navigation.rb +46 -0
  202. data/config/initializers/spree_admin_partials.rb +3 -0
  203. data/config/locales/en.yml +42 -0
  204. data/config/routes.rb +43 -0
  205. data/db/migrate/20250120094216_create_page_builder_models.rb +78 -0
  206. data/db/migrate/20250305121352_remove_page_builder_indices.rb +11 -0
  207. data/db/migrate/20250825175217_add_missing_page_builder_indexes.rb +7 -0
  208. data/db/migrate/20250913130044_add_page_links_counter_cache_to_spree_stores.rb +10 -0
  209. data/lib/generators/spree/page_builder/install/install_generator.rb +23 -0
  210. data/lib/spree/page_builder/engine.rb +185 -0
  211. data/lib/spree/page_builder/testing_support/factories/page_block_factory.rb +22 -0
  212. data/lib/spree/page_builder/testing_support/factories/page_factory.rb +33 -0
  213. data/lib/spree/page_builder/testing_support/factories/page_link_factory.rb +7 -0
  214. data/lib/spree/page_builder/testing_support/factories/page_section_factory.rb +27 -0
  215. data/lib/spree/page_builder/testing_support/factories/theme_factory.rb +14 -0
  216. data/lib/spree/page_builder/testing_support/factories.rb +3 -0
  217. data/lib/spree/page_builder.rb +4 -0
  218. data/lib/spree_page_builder.rb +1 -0
  219. metadata +288 -0
@@ -0,0 +1,86 @@
1
+ <div id="sidebar-colors">
2
+ <h6 class="sidebar-header">
3
+ <%= Spree.t(:theme) %>
4
+ </h6>
5
+
6
+ <%= form_for @theme_preview, as: :theme, url: spree.admin_theme_path(@theme_preview), method: :put, data: { 'page-builder-target': 'form' } do |f| %>
7
+ <div data-controller="tabs">
8
+ <ul class="nav nav-pills nav-fill m-4" id="pills-tab" role="tablist">
9
+ <li class="nav-item" role="presentation">
10
+ <button class="nav-link w-full active" id="pills-home-tab" data-tabs-target="tab" data-action="click->tabs#select" type="button" role="tab" aria-controls="pills-home" aria-selected="true">Color scheme</button>
11
+ </li>
12
+ <li class="nav-item" role="presentation">
13
+ <button class="nav-link w-full" id="pills-profile-tab" data-tabs-target="tab" data-action="click->tabs#select" type="button" role="tab" aria-controls="pills-profile" aria-selected="false">Elements</button>
14
+ </li>
15
+ </ul>
16
+ <div id="pills-tabContent">
17
+ <div data-tabs-target="panel" id="pills-home" role="tabpanel" aria-labelledby="pills-home-tab" class="animate-fade-in">
18
+ <div class="px-4 py-2" data-controller="color-palette">
19
+ <% color_palettes.each do |color_palette| %>
20
+ <%#= render 'spree/admin/page_builder/color_palette',
21
+ active: color_palette_active?(color_palette),
22
+ primary_color: color_palette[:primary_color],
23
+ text_color: color_palette[:text_color],
24
+ border_color: color_palette[:border_color],
25
+ button_background_color: color_palette[:button_background_color],
26
+ button_text_color: color_palette[:button_text_color],
27
+ background_color: color_palette[:background_color]
28
+ %>
29
+ <% end %>
30
+
31
+ <%# <hr class="my-4 bg-gray-25" /> %>
32
+
33
+ <%= render 'spree/admin/page_builder/color_picker', f: f,
34
+ field: :preferred_primary_color, label: Spree.t("theme_settings.brand_color"),
35
+ value: @theme_preview.preferred_primary_color, action: 'change->page-builder#refreshPreview' %>
36
+ <%= render 'spree/admin/page_builder/color_picker', f: f,
37
+ field: :preferred_text_color, label: Spree.t("theme_settings.text_color"),
38
+ value: @theme_preview.preferred_text_color, action: 'change->page-builder#refreshPreview' %>
39
+ <%= render 'spree/admin/page_builder/color_picker', f: f,
40
+ field: :preferred_button_text_color, label: Spree.t("theme_settings.button_text_color"),
41
+ value: @theme_preview.preferred_button_text_color, action: 'change->page-builder#refreshPreview' %>
42
+ <%= render 'spree/admin/page_builder/color_picker', f: f,
43
+ field: :preferred_input_text_color, label: Spree.t("theme_settings.input_text_color"),
44
+ value: @theme_preview.preferred_input_text_color, action: 'change->page-builder#refreshPreview' %>
45
+ <%= render 'spree/admin/page_builder/color_picker', f: f,
46
+ field: :preferred_border_color, label: Spree.t("theme_settings.border_color"),
47
+ value: @theme_preview.preferred_border_color, action: 'change->page-builder#refreshPreview' %>
48
+ <%= render 'spree/admin/page_builder/color_picker', f: f,
49
+ field: :preferred_button_border_color, label: Spree.t("theme_settings.button_border_color"),
50
+ value: @theme_preview.preferred_button_border_color, action: 'change->page-builder#refreshPreview', clear: true %>
51
+ <%= render 'spree/admin/page_builder/color_picker', f: f,
52
+ field: :preferred_background_color, label: Spree.t("theme_settings.background_color"),
53
+ value: @theme_preview.preferred_background_color, action: 'change->page-builder#refreshPreview' %>
54
+ <%= render 'spree/admin/page_builder/color_picker', f: f,
55
+ field: :preferred_accent_color, label: Spree.t("theme_settings.accent_color"),
56
+ value: @theme_preview.preferred_accent_color, action: 'change->page-builder#refreshPreview' %>
57
+ <%= render 'spree/admin/page_builder/color_picker', f: f,
58
+ field: :preferred_danger_color, label: Spree.t("theme_settings.danger_color"),
59
+ value: @theme_preview.preferred_danger_color, action: 'change->page-builder#refreshPreview' %>
60
+ <%= render 'spree/admin/page_builder/color_picker', f: f,
61
+ field: :preferred_neutral_color, label: Spree.t("theme_settings.neutral_color"),
62
+ value: @theme_preview.preferred_neutral_color, action: 'change->page-builder#refreshPreview' %>
63
+ <%= render 'spree/admin/page_builder/color_picker', f: f,
64
+ field: :preferred_success_color, label: Spree.t("theme_settings.success_color"),
65
+ value: @theme_preview.preferred_success_color, action: 'change->page-builder#refreshPreview' %>
66
+ </div>
67
+ </div>
68
+ <div data-tabs-target="panel" id="pills-profile" role="tabpanel" aria-labelledby="pills-profile-tab" hidden class="animate-fade-in">
69
+ <div class="px-4 py-2">
70
+ <%= render 'spree/admin/page_builder/range_input',
71
+ f: f, field: :preferred_button_border_radius, min: 0, max: 100, unit: 'px', action: 'change->page-builder#refreshPreview'
72
+ %>
73
+ <%= render 'spree/admin/page_builder/range_input',
74
+ f: f, field: :preferred_button_border_thickness, min: 0, max: 10, unit: 'px', action: 'change->page-builder#refreshPreview'
75
+ %>
76
+ <hr>
77
+
78
+ <%= render 'spree/admin/page_builder/range_input',
79
+ f: f, field: :preferred_input_border_radius, min: 0, max: 100, unit: 'px', action: 'change->page-builder#refreshPreview'
80
+ %>
81
+ </div>
82
+ </div>
83
+ </div>
84
+ </div>
85
+ <% end %>
86
+ </div>
@@ -0,0 +1,85 @@
1
+ <h6 class="sidebar-header">
2
+ <%= Spree.t(:fonts) %>
3
+ </h6>
4
+
5
+ <%= form_for @theme_preview, as: :theme, url: spree.admin_theme_path(@theme_preview), method: :put, data: { 'page-builder-target': 'fontForm' } do |f| %>
6
+ <div data-controller="tabs">
7
+ <ul class="nav nav-pills nav-fill m-4" id="pills-tab" role="tablist">
8
+ <li class="nav-item" role="presentation">
9
+ <button class="nav-link w-full active" id="pills-standard" data-tabs-target="tab" data-action="click->tabs#select" type="button" role="tab" aria-controls="pills-standard" aria-selected="true">
10
+ Standard
11
+ </button>
12
+ </li>
13
+ <li class="nav-item" role="presentation">
14
+ <button class="nav-link w-full" id="pills-custom" data-tabs-target="tab" data-action="click->tabs#select" type="button" role="tab" aria-controls="pills-custom" aria-selected="false">
15
+ Custom
16
+ </button>
17
+ </li>
18
+ </ul>
19
+ <div id="pills-tabContent">
20
+ <div data-tabs-target="panel" id="pills-standard-tab" role="tabpanel" aria-labelledby="pills-standard" class="animate-fade-in">
21
+ <div class="px-4 py-2">
22
+ <div class="mb-4 form-group">
23
+ <%= f.label :preferred_font_family, Spree.t(:font_family) %>
24
+ <%= f.select :preferred_font_family, options_for_select(all_fonts_options, f.object.preferred_font_family), { include_blank: true }, class: 'hidden', data: { action: 'change->page-builder#refreshFontPreview', controller: 'font-picker', font_picker_fonts_from_google_value: google_fonts_list.to_json } %>
25
+ </div>
26
+ <div class="mb-3 form-group" data-controller="range-input">
27
+ <%= f.label :preferred_font_size_scale, Spree.t(:font_size_scale) %>
28
+ <%= f.range_field :preferred_font_size_scale, class: 'custom-range', min: 100, max: 150, step: 5, data: {
29
+ 'range-input-target': 'input',
30
+ 'action': 'change->range-input#updatePreview change->page-builder#refreshFontPreview'
31
+ } %>
32
+ <span data-range-input-target="preview">
33
+ <%= f.object.preferred_font_size_scale %>
34
+ </span>%
35
+ </div>
36
+ <hr />
37
+ <div class="mb-4 form-group">
38
+ <%= f.label :preferred_header_font_family, Spree.t(:header_font_family) %>
39
+ <%= f.select :preferred_header_font_family, options_for_select(all_fonts_options, f.object.preferred_header_font_family), { include_blank: true }, class: 'hidden', data: { action: 'change->page-builder#refreshFontPreview', controller: 'font-picker', font_picker_fonts_from_google_value: google_fonts_list.to_json } %>
40
+ </div>
41
+ <div class="mb-3 form-group" data-controller="range-input">
42
+ <%= f.label :preferred_header_font_size_scale, Spree.t(:header_font_size_scale) %>
43
+ <%= f.range_field :preferred_header_font_size_scale, class: 'custom-range', min: 100, max: 150, step: 5, data: {
44
+ 'range-input-target': 'input',
45
+ 'action': 'change->range-input#updatePreview change->page-builder#refreshFontPreview'
46
+ } %>
47
+ <span data-range-input-target="preview">
48
+ <%= f.object.preferred_header_font_size_scale %>
49
+ </span>%
50
+ </div>
51
+ <div class="mb-4 custom-control form-checkbox">
52
+ <%= f.check_box :preferred_headings_uppercase, class: "custom-control-input", data: { action: 'change->page-builder#refreshFontPreview' } %>
53
+ <%= f.label :preferred_headings_uppercase, "Make all headings uppercase", class: "custom-control-label" %>
54
+ </div>
55
+ </div>
56
+ </div>
57
+ <div data-tabs-target="panel" id="pills-custom-tab" role="tabpanel" aria-labelledby="pills-custom" hidden class="animate-fade-in">
58
+ <div class="px-4 py-2">
59
+ <div class="mb-4">
60
+ <div class="alert alert-warning">
61
+ Using custom fonts can slow down your store.
62
+ </div>
63
+ <%= f.spree_text_area :preferred_custom_font_code, style: 'min-height: 6em', label: Spree.t(:custom_font_code) %>
64
+ </div>
65
+ <%= f.submit Spree.t('actions.update'), class: 'btn btn-primary' %>
66
+
67
+ <hr class="my-6" />
68
+
69
+ <h6 class="mb-3">Example how to add custom fonts</h6>
70
+ <textarea class="form-input h-[250px]" ><link rel="stylesheet" href="https://url.to.your.font.com/font.js" />
71
+ <style>
72
+ /* set font for body */
73
+ body {
74
+ font-family: "your font name", sans-serif;
75
+ }
76
+ /* set font for headings */
77
+ h1, h2, h3, h4, h5, h6 {
78
+ font-family: "your font name", sans-serif;
79
+ }
80
+ </style></textarea>
81
+ </div>
82
+ </div>
83
+ </div>
84
+ </div>
85
+ <% end %>
@@ -0,0 +1,44 @@
1
+ <% if section.persisted? %>
2
+ <%= turbo_frame_tag dom_id(section), class: 'list-group-item py-0 border-0 sidebar-page-section draggable rounded-sm',
3
+ data: { sortable_update_url: spree.admin_page_section_path(section, format: :turbo_stream) } do %>
4
+ <div class="flex items-center justify-between sidebar-section-title py-1 rounded-xl"
5
+ data-action="mouseover->page-builder#toggleHighlightElement mouseout->page-builder#toggleHighlightElement"
6
+ data-page-builder-editor-id-param="section-<%= section.id %>">
7
+ <div class="flex items-center flex-1 py-1 px-2">
8
+ <%= icon("#{section.icon_name}", height: 18, class: 'mr-2') if section.icon_name.present? %>
9
+ <%= link_to section.display_name, spree.edit_admin_page_section_path(section),
10
+ class: 'section-edit-link flex-1 font-bold text-gray-900',
11
+ data: {
12
+ turbo_frame: :page_sidebar,
13
+ action: 'click->page-builder#makeOverlayActive',
14
+ page_builder_editor_id_param: "section-#{section.id}"
15
+ }
16
+ %>
17
+ </div>
18
+ <div class="flex items-center hidden">
19
+ <button class="btn btn-sm pr-0 handle hover:bg-gray-100 h-full mr-1 px-1 handle-section shadow-none">
20
+ <%= icon('grip-vertical', class: 'mr-0') %>
21
+ </button>
22
+ </div>
23
+ </div>
24
+ <% if section.blocks_available? %>
25
+ <div class="flex flex-col ml-1 mb-2">
26
+ <%= turbo_frame_tag [:blocks, section.id].join('_'), class: 'list-group-flush' do %>
27
+ <% if section.can_sort_blocks? %>
28
+ <div data-controller="sortable"
29
+ data-sortable-handle-value=".handle-block"
30
+ data-sortable-resource-name-value="page_block"
31
+ data-sortable-response-kind-value="turbo-stream">
32
+ <% else %>
33
+ <div>
34
+ <% end %>
35
+ <%= render partial: 'spree/admin/page_builder/sidebar_block', collection: section.blocks.includes(:rich_text_text), as: :block %>
36
+ </div>
37
+ <% end %>
38
+ <% if section.available_blocks_to_add.any? %>
39
+ <%= render 'spree/admin/page_builder/add_block', section: section %>
40
+ <% end %>
41
+ </div>
42
+ <% end %>
43
+ <% end %>
44
+ <% end %>
@@ -0,0 +1,38 @@
1
+ <%= turbo_frame_tag :page_sidebar do %>
2
+ <div class="hidden md:block">
3
+ <h6 class="sidebar-header">Page sections</h6>
4
+ <% if @page_preview.layout_sections? %>
5
+ <div class="list-group-flush border-b mb-1 pb-2">
6
+ <div data-controller="sortable"
7
+ data-sortable-handle-value=".handle-section"
8
+ data-sortable-resource-name-value="page_section"
9
+ data-sortable-response-kind-value="turbo-stream">
10
+ <%= render collection: @theme_preview.sections.find_all { |s| s.role == 'header' }, partial: 'spree/admin/page_builder/sidebar_section', as: :section %>
11
+ </div>
12
+ </div>
13
+ <% end %>
14
+ <div id="page-sections-list" class="list-group-flush py-2">
15
+ <div data-controller="sortable"
16
+ data-sortable-handle-value=".handle-section"
17
+ data-sortable-resource-name-value="page_section"
18
+ data-sortable-response-kind-value="turbo-stream">
19
+ <%= render partial: 'spree/admin/page_builder/sidebar_section',
20
+ collection: @page_preview.sections.includes(:blocks),
21
+ as: :section %>
22
+ </div>
23
+ </div>
24
+ <div class="px-4">
25
+ <%= link_to_with_icon 'new-section', Spree.t(:add_section), spree.new_admin_page_section_path(@page_preview), class: 'btn btn-primary rounded-full uppercase w-full my-2 py-2' %>
26
+ </div>
27
+ <% if @page_preview.layout_sections? %>
28
+ <div class="list-group-flush border-t py-2">
29
+ <div data-controller="sortable"
30
+ data-sortable-handle-value=".handle-section"
31
+ data-sortable-resource-name-value="page_section"
32
+ data-sortable-response-kind-value="turbo-stream">
33
+ <%= render collection: @theme_preview.sections.find_all { |s| s.role == 'footer' }, partial: 'spree/admin/page_builder/sidebar_section', as: :section %>
34
+ </div>
35
+ </div>
36
+ <% end %>
37
+ </div>
38
+ <% end if @page_preview.present? %>
@@ -0,0 +1,180 @@
1
+ <%= turbo_frame_tag :page_sidebar_toolbar do %>
2
+ <div class="hidden">
3
+ <% sections =
4
+ @page_preview.sections.includes(:blocks).map { |s| [@page_preview, s] } %>
5
+
6
+ <% sections +=
7
+ @theme_preview.sections.includes(:blocks).map { |s| [@theme_preview, s] } %>
8
+
9
+ <% sections.each do |parent, section| %>
10
+ <% next if section.new_record? %>
11
+
12
+ <div id="editor-toolbar-section-<%= section.id %>">
13
+ <button class="editor-toolbar-lower">
14
+ <svg
15
+ xmlns="http://www.w3.org/2000/svg"
16
+ width="16"
17
+ height="16"
18
+ fill="currentColor"
19
+ class="bi bi-arrow-down"
20
+ viewBox="0 0 16 16"
21
+ >
22
+ <path
23
+ fill-rule="evenodd"
24
+ d="M8 1a.5.5 0 0 1 .5.5v11.793l3.146-3.147a.5.5 0 0 1 .708.708l-4 4a.5.5 0 0 1-.708 0l-4-4a.5.5 0 0 1 .708-.708L7.5 13.293V1.5A.5.5 0 0 1 8 1z"
25
+ />
26
+ </svg>
27
+ </button>
28
+ <button class="editor-toolbar-higher">
29
+ <svg
30
+ xmlns="http://www.w3.org/2000/svg"
31
+ width="16"
32
+ height="16"
33
+ fill="currentColor"
34
+ class="bi bi-arrow-up"
35
+ viewBox="0 0 16 16"
36
+ >
37
+ <path
38
+ fill-rule="evenodd"
39
+ d="M8 15a.5.5 0 0 0 .5-.5V2.707l3.146 3.147a.5.5 0 0 0 .708-.708l-4-4a.5.5 0 0 0-.708 0l-4 4a.5.5 0 1 0 .708.708L7.5 2.707V14.5a.5.5 0 0 0 .5.5z"
40
+ />
41
+ </svg>
42
+ </button>
43
+ <button class="editor-toolbar-edit">
44
+ <svg
45
+ xmlns="http://www.w3.org/2000/svg"
46
+ width="16"
47
+ height="16"
48
+ fill="currentColor"
49
+ class="bi bi-pencil"
50
+ viewBox="0 0 16 16"
51
+ >
52
+ <path
53
+ d="M12.146.146a.5.5 0 0 1 .708 0l3 3a.5.5 0 0 1 0 .708l-10 10a.5.5 0 0 1-.168.11l-5 2a.5.5 0 0 1-.65-.65l2-5a.5.5 0 0 1 .11-.168l10-10zM11.207 2.5 13.5 4.793 14.793 3.5 12.5 1.207 11.207 2.5zm1.586 3L10.5 3.207 4 9.707V10h.5a.5.5 0 0 1 .5.5v.5h.5a.5.5 0 0 1 .5.5v.5h.293l6.5-6.5zm-9.761 5.175-.106.106-1.528 3.821 3.821-1.528.106-.106A.5.5 0 0 1 5 12.5V12h-.5a.5.5 0 0 1-.5-.5V11h-.5a.5.5 0 0 1-.468-.325z"
54
+ />
55
+ </svg>
56
+ </button>
57
+ <% if section.can_be_deleted? && can?(:destroy, section) %>
58
+ <button class="editor-toolbar-delete">
59
+ <svg
60
+ xmlns="http://www.w3.org/2000/svg"
61
+ width="16"
62
+ height="16"
63
+ fill="currentColor"
64
+ class="bi bi-trash"
65
+ viewBox="0 0 16 16"
66
+ >
67
+ <path
68
+ d="M5.5 5.5A.5.5 0 0 1 6 6v6a.5.5 0 0 1-1 0V6a.5.5 0 0 1 .5-.5Zm2.5 0a.5.5 0 0 1 .5.5v6a.5.5 0 0 1-1 0V6a.5.5 0 0 1 .5-.5Zm3 .5a.5.5 0 0 0-1 0v6a.5.5 0 0 0 1 0V6Z"
69
+ />
70
+ <path
71
+ d="M14.5 3a1 1 0 0 1-1 1H13v9a2 2 0 0 1-2 2H5a2 2 0 0 1-2-2V4h-.5a1 1 0 0 1-1-1V2a1 1 0 0 1 1-1H6a1 1 0 0 1 1-1h2a1 1 0 0 1 1 1h3.5a1 1 0 0 1 1 1v1ZM4.118 4 4 4.059V13a1 1 0 0 0 1 1h6a1 1 0 0 0 1-1V4.059L11.882 4H4.118ZM2.5 3h11V2h-11v1Z"
72
+ />
73
+ </svg>
74
+ </button>
75
+ <% end %>
76
+ </div>
77
+
78
+ <%= button_to Spree.t(:move_up),
79
+ spree.move_higher_admin_page_section_path(parent, section),
80
+ method: :patch,
81
+ id: "editor-toolbar-higher-section-#{section.id}" if can?(:update, section) %>
82
+ <%= button_to Spree.t(:move_down),
83
+ spree.move_lower_admin_page_section_path(parent, section),
84
+ method: :patch,
85
+ id: "editor-toolbar-lower-section-#{section.id}" if can?(:update, section) %>
86
+ <% if section.can_be_deleted? && can?(:destroy, section) %>
87
+ <%= link_to Spree.t(:destroy),
88
+ spree.admin_page_section_path(section),
89
+ data: {
90
+ turbo_confirm: Spree.t(:are_you_sure),
91
+ turbo_method: :delete,
92
+ },
93
+ id: "editor-toolbar-delete-section-#{section.id}" %>
94
+ <% end %>
95
+
96
+
97
+ <% section.blocks.each do |block| %>
98
+ <div id="editor-toolbar-block-<%= block.id %>">
99
+ <button class="editor-toolbar-lower">
100
+ <svg
101
+ xmlns="http://www.w3.org/2000/svg"
102
+ width="16"
103
+ height="16"
104
+ fill="currentColor"
105
+ class="bi bi-arrow-down"
106
+ viewBox="0 0 16 16"
107
+ >
108
+ <path
109
+ fill-rule="evenodd"
110
+ d="M8 1a.5.5 0 0 1 .5.5v11.793l3.146-3.147a.5.5 0 0 1 .708.708l-4 4a.5.5 0 0 1-.708 0l-4-4a.5.5 0 0 1 .708-.708L7.5 13.293V1.5A.5.5 0 0 1 8 1z"
111
+ />
112
+ </svg>
113
+ </button>
114
+ <button class="editor-toolbar-higher">
115
+ <svg
116
+ xmlns="http://www.w3.org/2000/svg"
117
+ width="16"
118
+ height="16"
119
+ fill="currentColor"
120
+ class="bi bi-arrow-up"
121
+ viewBox="0 0 16 16"
122
+ >
123
+ <path
124
+ fill-rule="evenodd"
125
+ d="M8 15a.5.5 0 0 0 .5-.5V2.707l3.146 3.147a.5.5 0 0 0 .708-.708l-4-4a.5.5 0 0 0-.708 0l-4 4a.5.5 0 1 0 .708.708L7.5 2.707V14.5a.5.5 0 0 0 .5.5z"
126
+ />
127
+ </svg>
128
+ </button>
129
+ <button class="editor-toolbar-edit">
130
+ <svg
131
+ xmlns="http://www.w3.org/2000/svg"
132
+ width="16"
133
+ height="16"
134
+ fill="currentColor"
135
+ class="bi bi-pencil"
136
+ viewBox="0 0 16 16"
137
+ >
138
+ <path
139
+ d="M12.146.146a.5.5 0 0 1 .708 0l3 3a.5.5 0 0 1 0 .708l-10 10a.5.5 0 0 1-.168.11l-5 2a.5.5 0 0 1-.65-.65l2-5a.5.5 0 0 1 .11-.168l10-10zM11.207 2.5 13.5 4.793 14.793 3.5 12.5 1.207 11.207 2.5zm1.586 3L10.5 3.207 4 9.707V10h.5a.5.5 0 0 1 .5.5v.5h.5a.5.5 0 0 1 .5.5v.5h.293l6.5-6.5zm-9.761 5.175-.106.106-1.528 3.821 3.821-1.528.106-.106A.5.5 0 0 1 5 12.5V12h-.5a.5.5 0 0 1-.5-.5V11h-.5a.5.5 0 0 1-.468-.325z"
140
+ />
141
+ </svg>
142
+ </button>
143
+ <button class="editor-toolbar-delete">
144
+ <svg
145
+ xmlns="http://www.w3.org/2000/svg"
146
+ width="16"
147
+ height="16"
148
+ fill="currentColor"
149
+ class="bi bi-trash"
150
+ viewBox="0 0 16 16"
151
+ >
152
+ <path
153
+ d="M5.5 5.5A.5.5 0 0 1 6 6v6a.5.5 0 0 1-1 0V6a.5.5 0 0 1 .5-.5Zm2.5 0a.5.5 0 0 1 .5.5v6a.5.5 0 0 1-1 0V6a.5.5 0 0 1 .5-.5Zm3 .5a.5.5 0 0 0-1 0v6a.5.5 0 0 0 1 0V6Z"
154
+ />
155
+ <path
156
+ d="M14.5 3a1 1 0 0 1-1 1H13v9a2 2 0 0 1-2 2H5a2 2 0 0 1-2-2V4h-.5a1 1 0 0 1-1-1V2a1 1 0 0 1 1-1H6a1 1 0 0 1 1-1h2a1 1 0 0 1 1 1h3.5a1 1 0 0 1 1 1v1ZM4.118 4 4 4.059V13a1 1 0 0 0 1 1h6a1 1 0 0 0 1-1V4.059L11.882 4H4.118ZM2.5 3h11V2h-11v1Z"
157
+ />
158
+ </svg>
159
+ </button>
160
+ </div>
161
+
162
+ <%= button_to Spree.t(:move_up),
163
+ spree.move_higher_admin_page_section_block_path(section, block),
164
+ method: :patch,
165
+ id: "editor-toolbar-higher-block-#{block.id}" %>
166
+ <%= button_to Spree.t(:move_down),
167
+ spree.move_lower_admin_page_section_block_path(section, block),
168
+ method: :patch,
169
+ id: "editor-toolbar-lower-block-#{block.id}" %>
170
+ <%= link_to Spree.t(:destroy),
171
+ spree.admin_page_section_block_path(section, block),
172
+ data: {
173
+ turbo_confirm: Spree.t(:are_you_sure),
174
+ turbo_method: :delete,
175
+ },
176
+ id: "editor-toolbar-delete-block-#{block.id}" %>
177
+ <% end %>
178
+ <% end %>
179
+ </div>
180
+ <% end %>
@@ -0,0 +1,10 @@
1
+ <% data_action = (@page_link.persisted? && !@page_link.parent.is_a?(Spree::Store) ? { action: 'blur->auto-submit#submit' } : {}) %>
2
+
3
+ <%= f.spree_select :linkable_type, @page_link.parent.allowed_linkable_types, { label: 'Link', include_blank: false }, { class: 'form-select mb-6', data: { action: 'auto-submit#submit' } } %>
4
+ <%= render 'spree/admin/page_links/linkable_type_dropdown', page_link: @page_link, form_name: 'page_link' %>
5
+
6
+ <hr class="my-6" />
7
+
8
+ <%= f.spree_text_field :label, label: Spree.t(:name), data: data_action, required: true %>
9
+
10
+ <%= f.spree_check_box :open_in_new_tab, data: data_action %>
@@ -0,0 +1,15 @@
1
+ <% if page_link.linkable_type == 'Spree::Product' %>
2
+ <%= tom_select_tag "#{form_name}[linkable_id]", class: 'w-full', url: spree.select_options_admin_products_path(format: :json), active_option: page_link.linkable_id, select_data: { action: 'auto-submit#submit' } %>
3
+ <% elsif page_link.linkable_type == 'Spree::Taxon' %>
4
+ <%= tom_select_tag "#{form_name}[linkable_id]", class: 'w-full', url: spree.admin_taxons_select_options_path(format: :json, with_automatic: true), active_option: page_link.linkable_id, select_data: { action: 'auto-submit#submit' } %>
5
+ <% elsif page_link.linkable_type == 'Spree::Post' %>
6
+ <%= tom_select_tag "#{form_name}[linkable_id]", class: 'w-full', url: spree.select_options_admin_posts_path(format: :json), active_option: page_link.linkable_id, select_data: { action: 'auto-submit#submit' } %>
7
+ <% elsif page_link.linkable_type == 'Spree::Page' %>
8
+ <%= select_tag "#{form_name}[linkable_id]", options_for_select(all_linkable_pages, page_link.linkable_id), { data: { controller: 'autocomplete-select', action: 'auto-submit#submit' } } %>
9
+ <% elsif page_link.linkable_type == 'Spree::Policy' %>
10
+ <%= select_tag "#{form_name}[linkable_id]", options_for_select(all_linkable_policies, page_link.linkable_id), { data: { controller: 'autocomplete-select', action: 'auto-submit#submit' } } %>
11
+ <% elsif page_link.linkable_type == 'Spree::Vendor' %>
12
+ <%= tom_select_tag "#{form_name}[linkable_id]", class: 'w-full', url: spree.select_options_admin_vendors_path(format: :json), active_option: page_link.linkable_id, select_data: { action: 'auto-submit#submit' } %>
13
+ <% else %>
14
+ <%= text_field_tag "#{form_name}[url]", page_link.url, class: "form-input", required: true, placeholder: 'eg. google.com', data: { action: 'blur->auto-submit#submit' } %>
15
+ <% end %>
@@ -0,0 +1,36 @@
1
+ <div class="mb-6">
2
+ <h5 class="font-bold">Links</h5>
3
+
4
+ <% if parent.links.any? %>
5
+ <ul class="list-group mb-6"
6
+ data-controller="sortable"
7
+ data-sortable-handle-value=".handle"
8
+ data-sortable-resource-name-value="page_link"
9
+ data-sortable-response-kind-value="turbo-stream">
10
+ <% parent.links.each do |link| %>
11
+ <li class="list-group-item p-0 flex items-center hover:bg-gray-100"
12
+ data-sortable-update-url="<%= spree.admin_page_link_path(link, sorting_only: true, format: :turbo_stream) %>"
13
+ >
14
+ <%= link_to link.label, spree.edit_admin_page_link_path(link), class: 'block py-4 px-6 text-gray-900 flex-1' %>
15
+ <button class="btn btn-sm pr-0 handle hover:bg-gray-100 h-full mr-1 px-1 shadow-none">
16
+ <%= icon 'grip-vertical', class: 'mr-0' %>
17
+ </button>
18
+ </li>
19
+ <% end %>
20
+ </ul>
21
+ <% else %>
22
+ <p class="text-gray-600 text-center p-12">
23
+ <%= Spree.t(:no_resource_found, resource: Spree::PageLink.model_name.human) %>
24
+ </p>
25
+ <% end %>
26
+
27
+ <% if show_add_link_button %>
28
+ <% if parent.is_a?(Spree::PageSection) %>
29
+ <% add_url = spree.admin_page_section_links_path(parent) %>
30
+ <% elsif parent.is_a?(Spree::PageBlock) %>
31
+ <% add_url = spree.admin_page_section_block_links_path(parent.section, parent) %>
32
+ <% end %>
33
+
34
+ <%= link_to_with_icon 'plus', Spree.t(:add_link), add_url, class: 'btn btn-primary w-full', data: { turbo_method: :post } if add_url && can?(:create, Spree::PageLink.new(parent: parent)) %>
35
+ <% end %>
36
+ </div>
@@ -0,0 +1,5 @@
1
+ <% if @page_link.parent.is_a?(Spree::PageBlock) %>
2
+ <%= refresh_theme_preview(@page_link.parent.section, @page_link.parent) %>
3
+ <% else %>
4
+ <%= refresh_theme_preview(@page_link.parent) %>
5
+ <% end %>
@@ -0,0 +1,10 @@
1
+ <% if @page_link.parent.is_a?(Spree::Store) %>
2
+ <%= turbo_stream.replace :checkout_links do %>
3
+ <%= render 'spree/admin/stores/form/checkout_links' %>
4
+ <% end %>
5
+ <% else %>
6
+ <%= turbo_stream.replace :page_sidebar do %>
7
+ <%= render template: 'spree/admin/page_links/edit' %>
8
+ <% end %>
9
+ <%= render 'spree/admin/page_links/refresh_theme_preview' %>
10
+ <% end %>
@@ -0,0 +1,15 @@
1
+ <% if @page_link.parent.is_a?(Spree::Store) %>
2
+ <%= turbo_stream.remove spree_dom_id(@page_link) %>
3
+ <% else %>
4
+ <%= turbo_stream.replace :page_sidebar do %>
5
+ <% if @page_link.parent.is_a?(Spree::PageSection) %>
6
+ <% @page_section = @page_link.parent %>
7
+ <%= render template: 'spree/admin/page_sections/edit' %>
8
+ <% elsif @page_link.parent.is_a?(Spree::PageBlock) %>
9
+ <% @page_block = @page_link.parent %>
10
+ <%= render template: 'spree/admin/page_blocks/edit' %>
11
+ <% end %>
12
+ <% end %>
13
+
14
+ <%= render 'spree/admin/page_links/refresh_theme_preview' %>
15
+ <% end %>
@@ -0,0 +1,27 @@
1
+ <% if @page_link.parent.is_a?(Spree::Store) %>
2
+ <%= turbo_frame_tag spree_dom_id(@page_link), class: 'flex items-center w-full py-2 pl-6 pr-2' do %>
3
+ <%= link_to '', collection_url, class: 'btn-close absolute top-0 right-0 mt-4 mr-4' %>
4
+ <%= form_for @page_link, url: spree.admin_page_link_path(@page_link), data: { controller: 'auto-submit' }, html: { class: 'w-full mt-4 mr-1 mb-4' } do |f| %>
5
+ <%= render 'spree/admin/page_links/form', f: f %>
6
+ <hr class="my-6">
7
+ <%= render 'spree/admin/shared/edit_resource_links', f: f %>
8
+ <% end %>
9
+ <% end %>
10
+ <% else %>
11
+ <%= turbo_frame_tag :page_sidebar do %>
12
+ <h6 class="sidebar-header">
13
+ <%= link_to collection_url, data: { action: 'click->page-builder#clearActiveOverlays' }, class: 'btn hover:bg-gray-100 shadow-none px-3' do %>
14
+ <%= icon 'chevron-left', class: 'mr-0' %>
15
+ <% end %>
16
+ <%= @page_link.label %>
17
+ </h6>
18
+ <div class="px-6 pb-12 mb-12 edit-block">
19
+ <%= form_for @page_link, url: spree.admin_page_link_path(@page_link), data: { controller: 'auto-submit' } do |f| %>
20
+ <%= render 'spree/admin/page_links/form', f: f %>
21
+ <% end %>
22
+ </div>
23
+ <div class="sidebar-footer">
24
+ <%= link_to_delete(@page_link, url: spree.admin_page_link_path(@page_link)) %>
25
+ </div>
26
+ <% end %>
27
+ <% end %>
@@ -0,0 +1,14 @@
1
+ <% if @page_link.parent.is_a?(Spree::Store) %>
2
+ <% unless params[:sorting_only] %>
3
+ <%= turbo_stream.replace spree_dom_id(@page_link) do %>
4
+ <%= render template: 'spree/admin/page_links/edit' %>
5
+ <% end %>
6
+ <% end %>
7
+ <% else %>
8
+ <% unless params[:sorting_only] %>
9
+ <%= turbo_stream.replace :page_sidebar do %>
10
+ <%= render template: 'spree/admin/page_links/edit' %>
11
+ <% end %>
12
+ <% end %>
13
+ <%= render 'spree/admin/page_links/refresh_theme_preview' %>
14
+ <% end %>
@@ -0,0 +1,8 @@
1
+ <div class="sidebar-footer">
2
+ <% if @page_section.can_be_deleted? %>
3
+ <%= link_to_delete(@page_section, url: spree.admin_page_section_path(@page_section)) %>
4
+ <% end %>
5
+ <% if tab == :design %>
6
+ <%= link_to_with_icon "restore", Spree.t(:restore_defaults), spree.restore_design_settings_to_defaults_admin_page_section_path(@page_section), {data: {turbo_confirm: Spree.t(:are_you_sure), turbo_method: :patch }, class: 'btn btn-light btn-sm ml-auto'} %>
7
+ <% end %>
8
+ </div>
@@ -0,0 +1,11 @@
1
+ <% if @page_section&.persisted? %>
2
+ <%= turbo_stream.replace :page_sidebar do %>
3
+ <%= render template: 'spree/admin/page_sections/edit' %>
4
+ <% end %>
5
+ <% end %>
6
+
7
+ <%= turbo_stream.replace 'page_sidebar_toolbar' do %>
8
+ <%= render 'spree/admin/page_builder/sidebar_sections_toolbar' %>
9
+ <% end %>
10
+
11
+ <%= refresh_theme_preview(@page_section) %>
@@ -0,0 +1,16 @@
1
+ <%= turbo_stream.replace :page_sidebar do %>
2
+ <%= render 'spree/admin/page_builder/sidebar_sections' %>
3
+ <% end %>
4
+
5
+ <%= turbo_stream.replace 'page_sidebar_toolbar' do %>
6
+ <%= render 'spree/admin/page_builder/sidebar_sections_toolbar' %>
7
+ <% end %>
8
+
9
+ <%= turbo_stream.replace :iframe_preview_scripts do %>%
10
+ <%= turbo_frame_tag :iframe_preview_scripts do %>
11
+ <script>
12
+ document.getElementById('page-builder-preview').contentDocument.body.querySelector('turbo-frame[id="section-<%= @page_section.id %>"]').remove()
13
+ document.getElementById('delete-callback').click()
14
+ </script>
15
+ <% end %>
16
+ <% end %>