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,39 @@
1
+ <%= turbo_frame_tag :page_sidebar do %>
2
+ <% tab_selected ||= :content %>
3
+ <h6 class="sidebar-header">
4
+ <%= link_to collection_url, data: { action: 'click->page-builder#clearActiveOverlays' }, class: 'btn hover:bg-gray-100 shadow-none px-3' do %>
5
+ <%= icon 'chevron-left', class: 'mr-0 back' %>
6
+ <% end %>
7
+ <%= @page_section.display_name %>
8
+ </h6>
9
+ <div class="p-3 edit-block">
10
+ <%= form_for @page_section, url: spree.admin_page_section_path(@page_section), data: { controller: 'auto-submit' }, as: :page_section do |f| %>
11
+ <div data-controller="tabs">
12
+ <ul class="nav nav-pills nav-fill mb-6" id="pills-tab" role="tablist">
13
+ <li class="nav-item" role="presentation">
14
+ <button class="nav-link w-full <%= tab_selected == :content ? 'active' : '' %>" id="pills-home-tab" data-tabs-target="tab" data-action="click->tabs#select" type="button" role="tab" aria-controls="pills-home" aria-selected="<%= tab_selected == :content %>">Content</button>
15
+ </li>
16
+ <li class="nav-item" role="presentation">
17
+ <button class="nav-link w-full <%= tab_selected == :design ? 'active' : '' %>" id="pills-profile-tab" data-tabs-target="tab" data-action="click->tabs#select" type="button" role="tab" aria-controls="pills-profile" aria-selected="<%= tab_selected == :design %>">Design</button>
18
+ </li>
19
+ </ul>
20
+ <div data-tabs-target="panel" id="pills-home" role="tabpanel" aria-labelledby="pills-home-tab" class="animate-fade-in" <%= 'hidden' unless tab_selected == :content %>>
21
+ <%= render "spree/admin/page_sections/forms/#{@page_section.type.demodulize.underscore}", f: f %>
22
+ <%= render 'spree/admin/page_sections/form_tab_buttons', tab: :content %>
23
+ </div>
24
+ <div data-tabs-target="panel" id="pills-profile" role="tabpanel" aria-labelledby="pills-profile-tab" class="animate-fade-in" <%= 'hidden' unless tab_selected == :design %>>
25
+ <%= render 'spree/admin/page_sections/fields/top_padding', f: f %>
26
+ <%= render 'spree/admin/page_sections/fields/bottom_padding', f: f %>
27
+ <%= render 'spree/admin/page_sections/fields/background_color', f: f %>
28
+ <%= render 'spree/admin/page_sections/fields/text_color', f: f %>
29
+ <%= render 'spree/admin/page_sections/fields/border_color', f: f %>
30
+ <%= render 'spree/admin/page_sections/fields/border_top_width', f: f %>
31
+ <%= render 'spree/admin/page_sections/fields/border_bottom_width', f: f %>
32
+ <%= render 'spree/admin/page_sections/fields/button', f: f %>
33
+ <%= yield(:design_tab) %>
34
+ <%= render 'spree/admin/page_sections/form_tab_buttons', tab: :design %>
35
+ </div>
36
+ </div>
37
+ <% end %>
38
+ </div>
39
+ <% end %>
@@ -0,0 +1,6 @@
1
+ <%= render 'spree/admin/page_builder/color_picker',
2
+ f: f,
3
+ field: :preferred_background_color,
4
+ value: f.object.preferred_background_color.presence,
5
+ label: Spree.t('admin.page_builder.background_color'),
6
+ action: 'change->auto-submit#submit' %>
@@ -0,0 +1,5 @@
1
+ <%= render 'spree/admin/page_builder/range_input',
2
+ f: f,
3
+ field: :preferred_bottom_border_width, min: 0, max: 100, unit: 'px',
4
+ label: Spree.t('admin.page_builder.border_bottom_width')
5
+ %>
@@ -0,0 +1,7 @@
1
+ <%= render 'spree/admin/page_builder/color_picker',
2
+ f: f,
3
+ field: :preferred_border_color,
4
+ value: f.object.preferred_border_color.presence,
5
+ label: Spree.t('admin.page_builder.border_color'),
6
+ action: 'change->auto-submit#submit' %>
7
+
@@ -0,0 +1,6 @@
1
+ <%= render 'spree/admin/page_builder/range_input',
2
+ f: f,
3
+ field: :preferred_top_border_width,
4
+ min: 0, max: 100, unit: 'px',
5
+ label: Spree.t('admin.page_builder.border_top_width')
6
+ %>
@@ -0,0 +1,5 @@
1
+ <%= render 'spree/admin/page_builder/range_input',
2
+ f: f, field: :preferred_bottom_padding,
3
+ min: 0, max: 100, unit: 'px',
4
+ label: Spree.t('admin.page_builder.bottom_padding')
5
+ %>
@@ -0,0 +1,15 @@
1
+ <% if f.object.respond_to?(:preferred_button_background_color) %>
2
+ <%= render 'spree/admin/page_builder/color_picker',
3
+ f: f, field: :preferred_button_background_color, value: f.object.preferred_button_background_color.presence,
4
+ label: Spree.t('admin.page_builder.button_background_color'),
5
+ clear: true,
6
+ action: 'change->auto-submit#submit' %>
7
+ <% end %>
8
+
9
+ <% if f.object.respond_to?(:preferred_button_text_color) %>
10
+ <%= render 'spree/admin/page_builder/color_picker',
11
+ f: f, field: :preferred_button_text_color, value: f.object.preferred_button_text_color.presence,
12
+ label: Spree.t('admin.page_builder.button_text_color'),
13
+ clear: true,
14
+ action: 'change->auto-submit#submit' %>
15
+ <% end %>
@@ -0,0 +1,26 @@
1
+ <label>Layout (desktop)</label>
2
+
3
+ <div class="flex mt-2 radio-buttons-header">
4
+ <label>
5
+ <%= f.radio_button :preferred_layout, 'nav-centered', class: 'hidden', data: { action: 'change->auto-submit#submit' } %>
6
+ <p class="btn-light"><%= Spree.t('admin.page_builder.nav_centered') %></p>
7
+ </label>
8
+ <label>
9
+ <%= f.radio_button :preferred_layout, 'logo-centered', class: 'hidden', data: { action: 'change->auto-submit#submit' } %>
10
+ <p class="btn-light"><%= Spree.t('admin.page_builder.logo_centered') %></p>
11
+ </label>
12
+ <label>
13
+ <%= f.radio_button :preferred_layout, 'left', class: 'hidden', data: { action: 'change->auto-submit#submit' } %>
14
+ <p class="btn-light"><%= Spree.t('admin.page_builder.left_aligned') %></p>
15
+ </label>
16
+ </div>
17
+
18
+ <div class="mt-2">
19
+ <%= render 'spree/admin/page_builder/range_input',
20
+ f: f,
21
+ field: :preferred_desktop_logo_height,
22
+ min: 0, max: 120, unit: 'px',
23
+ label: Spree.t('admin.page_builder.desktop_logo_height'),
24
+ label_for_min_value: "auto"
25
+ %>
26
+ </div>
@@ -0,0 +1,6 @@
1
+ <%= render 'spree/admin/page_builder/range_input',
2
+ f: f,
3
+ field: :preferred_height,
4
+ min: 192, max: 600, unit: 'px',
5
+ label: Spree.t('admin.page_builder.height')
6
+ %>
@@ -0,0 +1,7 @@
1
+ <%= render 'spree/admin/page_builder/color_picker',
2
+ f: f,
3
+ field: :preferred_text_color,
4
+ value: f.object.preferred_text_color.presence,
5
+ label: Spree.t('admin.page_builder.text_color'),
6
+ action: 'change->auto-submit#submit'
7
+ %>
@@ -0,0 +1,6 @@
1
+ <%= render 'spree/admin/page_builder/range_input',
2
+ f: f,
3
+ field: :preferred_top_padding,
4
+ min: 0, max: 100, unit: 'px',
5
+ label: Spree.t('admin.page_builder.top_padding')
6
+ %>
@@ -0,0 +1,5 @@
1
+ <div class="trix-container">
2
+ <%= f.rich_text_area :text, data: {
3
+ action: 'trix-change->auto-submit#submit'
4
+ }, class: 'mb-4' %>
5
+ </div>
@@ -0,0 +1,4 @@
1
+ <p class="text-gray-600">
2
+ You can use all HTML tags, JavaScript or CSS here
3
+ </p>
4
+ <%= f.text_area :preferred_custom_code, rows: 10, class: 'mb-6 form-input', data: { action: 'auto-submit#submit' } %>
@@ -0,0 +1,33 @@
1
+ <div class="form-group">
2
+ <%= f.label :preferred_heading, Spree.t('admin.page_builder.heading') %>
3
+ <%= f.text_field :preferred_heading, data: { action: 'auto-submit#submit' }, class: "form-input" %>
4
+ </div>
5
+ <div class="form-group">
6
+ <%= f.label :preferred_heading_size, Spree.t('admin.page_builder.heading_size') %>
7
+ <%= f.select :preferred_heading_size, options_for_select([ ["Small", 'small'], ["Medium", 'medium'], ["Large", 'large'] ], @page_section.preferred_heading_size ), {}, data: { action: 'auto-submit#submit' }, class: "form-select" %>
8
+ </div>
9
+ <div class="form-group">
10
+ <%= f.label :preferred_heading_alignment, Spree.t('admin.page_builder.heading_alignment') %>
11
+ <%= f.select :preferred_heading_alignment, options_for_select([ ["Left", "left"], ["Center", "center"], ["Right", "right"] ], @page_section.preferred_heading_alignment ), {}, data: { action: 'auto-submit#submit' }, class: "form-select" %>
12
+ </div>
13
+ <div class="form-group">
14
+ <%= f.label :description %>
15
+ <div class="trix-container">
16
+ <%= f.rich_text_area :description, data: {action: 'trix-change->auto-submit#submit'}, class: 'mb-4 w-full' %>
17
+ </div>
18
+ </div>
19
+ <div class="form-group">
20
+ <%= f.label :preferred_description_alignment, Spree.t('admin.page_builder.description_alignment') %>
21
+ <%= f.select :preferred_description_alignment, options_for_select([ ["Left", "left"], ["Center", "center"], ["Right", "right"] ], @page_section.preferred_description_alignment ), {}, data: { action: 'auto-submit#submit' }, class: "form-select" %>
22
+ </div>
23
+
24
+ <div class="form-group">
25
+ <div data-controller="better-slider">
26
+ <label><%= Spree.t('admin.page_builder.maximum_posts_to_show') %>: <span data-better-slider-target="currentValueLabel"></span></label>
27
+ <div class="flex flex-row w-full">
28
+ <span class="mr-2">2</span>
29
+ <%= f.range_field :preferred_max_posts_to_show, class: "custom-range w-full", min: 2, max: 8, data: {'better-slider-target': 'rangeInput', action: 'auto-submit#submit'} %>
30
+ <span class="ml-2">8</span>
31
+ </div>
32
+ </div>
33
+ </div>
@@ -0,0 +1,4 @@
1
+ <div class="form-group">
2
+ <%= f.label :preferred_product, Spree.t(:product) %>
3
+ <%= tom_select_tag 'page_section[preferred_product_id]', active_option: @page_section.preferred_product_id, class: 'w-full', url: spree.select_options_admin_products_path(format: :json), include_blank: false, select_data: {action: 'auto-submit#submit'} %>
4
+ </div>
@@ -0,0 +1,59 @@
1
+ <div class="form-group">
2
+ <%= f.label :preferred_heading, Spree.t('admin.page_builder.heading') %>
3
+ <%= f.text_field :preferred_heading, data: { action: 'auto-submit#submit' }, class: "form-input" %>
4
+ </div>
5
+ <div class="form-group">
6
+ <%= f.label :preferred_heading_size, Spree.t('admin.page_builder.heading_size') %>
7
+ <%= f.select :preferred_heading_size, options_for_select([ ["Small", 'small'], ["Medium", 'medium'], ["Large", 'large'] ], @page_section.preferred_heading_size ), {}, data: { action: 'auto-submit#submit' }, class: "form-select" %>
8
+ </div>
9
+ <div class="form-group">
10
+ <%= f.label :preferred_heading_alignment, Spree.t('admin.page_builder.heading_alignment') %>
11
+ <%= f.select :preferred_heading_alignment, options_for_select([ ["Left", "left"], ["Center", "center"], ["Right", "right"] ], @page_section.preferred_heading_alignment ), {}, data: { action: 'auto-submit#submit' }, class: "form-select" %>
12
+ </div>
13
+ <div class="form-group">
14
+ <%= f.label :description %>
15
+ <div class="trix-container">
16
+ <%= f.rich_text_area :description, data: {action: 'trix-change->auto-submit#submit'}, class: 'mb-4 w-full' %>
17
+ </div>
18
+ </div>
19
+ <div class="form-group">
20
+ <%= f.label :preferred_description_alignment, Spree.t('admin.page_builder.description_alignment') %>
21
+ <%= f.select :preferred_description_alignment, options_for_select([ ["Left", "left"], ["Center", "center"], ["Right", "right"] ], @page_section.preferred_description_alignment ), {}, data: { action: 'auto-submit#submit' }, class: "form-select" %>
22
+ </div>
23
+ <div class="form-group">
24
+ <%= f.check_box :preferred_use_description_from_admin, class: "checkbox-input", data: { action: 'auto-submit#submit' } %>
25
+ <%= f.label :preferred_use_description_from_admin, Spree.t('admin.page_builder.use_description_from_admin') %>
26
+ <div class="alert alert-info">If the category description is not set, then the above description will be used.</div>
27
+ </div>
28
+ <div class="form-group">
29
+ <%= f.label :preferred_button_text, Spree.t('admin.page_builder.button_text') %>
30
+ <%= f.text_field :preferred_button_text, class: 'form-input', data: { action: 'blur->auto-submit#submit' }, placeholder: 'eg. Explore category', required: true %>
31
+ </div>
32
+ <div class="form-group">
33
+ <%= f.check_box :preferred_show_taxon_image, class: "checkbox-input", data: { action: 'auto-submit#submit' } %>
34
+ <%= f.label :preferred_show_taxon_image, Spree.t('admin.page_builder.show_taxon_image') %>
35
+ </div>
36
+ <div class="form-group">
37
+ <%= f.label :preferred_taxon, Spree.t('admin.page_builder.category') %>
38
+ <%= tom_select_tag 'page_section[preferred_taxon_id]', active_option: @page_section.preferred_taxon_id, class: 'w-full', url: spree.admin_taxons_select_options_path(format: :json, with_automatic: true), select_data: {action: 'auto-submit#submit'} %>
39
+ </div>
40
+ <div class="form-group">
41
+ <%= f.check_box :preferred_show_more_button, class: "checkbox-input", data: { action: 'auto-submit#submit' } %>
42
+ <%= f.label :preferred_show_more_button, Spree.t('admin.page_builder.show_more_button') %>
43
+ </div>
44
+ <div class="form-group">
45
+ <div data-controller="better-slider">
46
+ <label><%= Spree.t('admin.page_builder.maximum_products_to_show') %>: <span data-better-slider-target="currentValueLabel"></span></label>
47
+ <div class="flex flex-row w-full">
48
+ <span class="mr-4">3</span>
49
+ <%= f.range_field :preferred_max_products_to_show, class: "custom-range w-full", min: 3, max: 20, data: {'better-slider-target': 'rangeInput', action: 'auto-submit#submit'} %>
50
+ <span class="ml-4">20</span>
51
+ </div>
52
+ </div>
53
+ </div>
54
+ <% content_for(:design_tab) do %>
55
+ <div class="form-group">
56
+ <%= f.label :preferred_button_style, Spree.t('admin.page_builder.button_style') %>
57
+ <%= f.select :preferred_button_style, options_for_select([['Primary', 'primary'], ['Secondary', 'secondary']], @page_section.preferred_button_style), {}, data: { action: 'auto-submit#submit' }, class: 'form-select' %>
58
+ </div>
59
+ <% end %>
@@ -0,0 +1,13 @@
1
+ <div class="form-group">
2
+ <%= f.label :preferred_heading, Spree.t('admin.page_builder.heading') %>
3
+ <%= f.text_field :preferred_heading, data: { action: 'auto-submit#submit' }, class: "form-input" %>
4
+ </div>
5
+ <div class="form-group">
6
+ <%= f.label :preferred_heading_size, Spree.t('admin.page_builder.heading_size') %>
7
+ <%= f.select :preferred_heading_size, options_for_select([ ["Small", 'small'], ["Medium", 'medium'], ["Large", 'large'] ], @page_section.preferred_heading_size ), {}, data: { action: 'auto-submit#submit' }, class: "form-select" %>
8
+ </div>
9
+ <div class="form-group">
10
+ <%= f.label :preferred_heading_alignment, Spree.t('admin.page_builder.heading_alignment') %>
11
+ <%= f.select :preferred_heading_alignment, options_for_select([ ["Left", "left"], ["Center", "center"], ["Right", "right"] ], @page_section.preferred_heading_alignment ), {}, data: { action: 'auto-submit#submit' }, class: "form-select" %>
12
+ </div>
13
+ <%= render 'spree/admin/page_links/list', parent: @page_section, show_add_link_button: true %>
@@ -0,0 +1,20 @@
1
+ <div class="alert alert-info mb-6">
2
+ If you don't upload a logo we'll use the one from the header.
3
+ </div>
4
+
5
+ <%= render 'spree/admin/shared/page_section_logo', f: f %>
6
+
7
+ <p class="text-gray-600 small mt-4">
8
+ We recommend transparent images with a minimum size of 400x128 pixels.
9
+ </p>
10
+
11
+ <% content_for(:design_tab) do %>
12
+ <%= render 'spree/admin/page_builder/color_picker',
13
+ f: f, field: :preferred_copyright_text_color, value: @page_section.preferred_copyright_text_color,
14
+ label: 'Copyright Text color',
15
+ action: 'change->auto-submit#submit' %>
16
+ <%= render 'spree/admin/page_builder/color_picker',
17
+ f: f, field: :preferred_copyright_background_color, value: @page_section.preferred_copyright_background_color,
18
+ label: 'Copyright Background color',
19
+ action: 'change->auto-submit#submit' %>
20
+ <% end %>
@@ -0,0 +1,12 @@
1
+ <%= render 'spree/admin/shared/page_section_logo', f: f %>
2
+
3
+ <p class="text-gray-600 small mt-2">
4
+ We recommend transparent images with a minimum size of 400x128 pixels.
5
+ </p>
6
+
7
+ <%= render 'spree/admin/page_links/list', parent: @page_section, show_add_link_button: true %>
8
+
9
+ <% content_for(:design_tab) do %>
10
+ <%= render 'spree/admin/page_sections/fields/header_layout', f: f %>
11
+ <hr />
12
+ <% end %>
@@ -0,0 +1,13 @@
1
+ <%= render 'spree/admin/shared/page_section_image', f: f %>
2
+
3
+ <% content_for(:design_tab) do %>
4
+ <div class="form-group">
5
+ <%= f.label :preferred_vertical_alignment, Spree.t('admin.page_builder.vertical_alignment') %>
6
+ <%= f.select :preferred_vertical_alignment, options_for_select([:top, :middle, :bottom], @page_section.preferred_vertical_alignment), { }, { class: 'form-select', data: { action: 'auto-submit#submit' } } %>
7
+ </div>
8
+
9
+ <%= render 'spree/admin/page_builder/range_input',
10
+ f: f, field: :preferred_overlay_transparency, min: 1, max: 100, unit: '%' %>
11
+
12
+ <%= render 'spree/admin/page_sections/fields/height', f: f %>
13
+ <% end %>
@@ -0,0 +1,28 @@
1
+ <%= render 'spree/admin/shared/page_section_image', f: f %>
2
+ <div class="py-2">
3
+ <%= f.fields_for :link do |lf| %>
4
+ <div class="form-group">
5
+ <%= lf.label :linkable_type, 'Link' %>
6
+ <%= lf.select :linkable_type, @page_section.allowed_linkable_types, { include_blank: false }, { class: 'form-select mb-4', data: { action: 'auto-submit#submit' } } %>
7
+ <div id="linkable_type_dropdown">
8
+ <%= render 'spree/admin/page_links/linkable_type_dropdown', page_link: lf.object, form_name: 'page_section[link_attributes]' %>
9
+ </div>
10
+ </div>
11
+ <div class="pb-2 custom-control form-checkbox">
12
+ <%= lf.check_box :open_in_new_tab, class: 'custom-control-input', data: { action: 'auto-submit#submit' } %>
13
+ <%= lf.label :open_in_new_tab, class: 'custom-control-label' %>
14
+ <span class="mt-2 text-gray-600 form-text"><%= Spree.t('admin.page_builder.image_click_hint') %></span>
15
+ </div>
16
+ <% end %>
17
+ </div>
18
+ <% content_for(:design_tab) do %>
19
+ <div class="form-group">
20
+ <%= f.label :preferred_desktop_image_alignment, Spree.t('admin.page_builder.desktop_image_alignment') %>
21
+ <%= f.select :preferred_desktop_image_alignment, options_for_select(['left', 'right'], @page_section.preferred_desktop_image_alignment), { }, { class: 'form-select', data: { action: 'auto-submit#submit' } } %>
22
+ </div>
23
+ <div class="form-group">
24
+ <%= f.label :preferred_vertical_alignment, Spree.t('admin.page_builder.vertical_alignment') %>
25
+ <%= f.select :preferred_vertical_alignment, options_for_select([:top, :middle, :bottom], @page_section.preferred_vertical_alignment), { }, { class: 'form-select', data: { action: 'auto-submit#submit' } } %>
26
+ </div>
27
+ <hr />
28
+ <% end %>
@@ -0,0 +1,9 @@
1
+ <div class="alert alert-info mb-6">
2
+ If you don't upload a logo we'll use the one from the header.
3
+ </div>
4
+
5
+ <%= render 'spree/admin/shared/page_section_logo', f: f %>
6
+
7
+ <p class="text-gray-600 small mt-4">
8
+ We recommend transparent images with a minimum size of 400x128 pixels.
9
+ </p>
@@ -0,0 +1,13 @@
1
+ <label>Logo image</label>
2
+ <%= render 'spree/admin/shared/page_section_logo', f: f %>
3
+
4
+ <p class="text-gray-600 small mt-2">
5
+ We recommend transparent images with a minimum size of 400x128 pixels.
6
+ </p>
7
+
8
+ <% content_for(:design_tab) do %>
9
+ <%= render 'spree/admin/page_builder/range_input',
10
+ f: f, field: :preferred_desktop_logo_height, min: 0, max: 120, unit: 'px', label: "Logo height (desktop)", label_for_min_value: "auto"
11
+ %>
12
+ <hr />
13
+ <% end %>
@@ -0,0 +1,15 @@
1
+ <% content_for(:design_tab) do %>
2
+
3
+ <%= label_tag :background_image %>
4
+ <br />
5
+
6
+ <%= render 'spree/admin/shared/page_section_image', f: f %>
7
+
8
+ <br /><br />
9
+
10
+ <%= render 'spree/admin/page_builder/range_input',
11
+ f: f, field: :preferred_overlay_transparency, min: 1, max: 100, unit: '%'
12
+ %>
13
+
14
+ <hr />
15
+ <% end %>
@@ -0,0 +1,4 @@
1
+ <div class="form-group">
2
+ <%= f.label :preferred_title, Spree.t('admin.page_builder.title') %>
3
+ <%= f.text_field :preferred_title, data: { action: 'auto-submit#submit' }, class: "form-input" %>
4
+ </div>
@@ -0,0 +1,32 @@
1
+ <div class="form-group">
2
+ <%= f.label :preferred_heading, Spree.t('admin.page_builder.heading') %>
3
+ <%= f.text_field :preferred_heading, data: { action: 'auto-submit#submit' }, class: "form-input" %>
4
+ </div>
5
+ <div class="form-group">
6
+ <%= f.label :preferred_heading_size, Spree.t('admin.page_builder.heading_size') %>
7
+ <%= f.select :preferred_heading_size, options_for_select([ ["Small", 'small'], ["Medium", 'medium'], ["Large", 'large'] ], @page_section.preferred_heading_size ), {}, data: { action: 'auto-submit#submit' }, class: "form-select" %>
8
+ </div>
9
+ <div class="form-group">
10
+ <%= f.label :preferred_heading_alignment, Spree.t('admin.page_builder.heading_alignment') %>
11
+ <%= f.select :preferred_heading_alignment, options_for_select([ ["Left", "left"], ["Center", "center"], ["Right", "right"] ], @page_section.preferred_heading_alignment ), {}, data: { action: 'auto-submit#submit' }, class: "form-select" %>
12
+ </div>
13
+ <div class="form-group">
14
+ <%= f.label :description, Spree.t('admin.page_builder.description') %>
15
+ <div class="trix-container">
16
+ <%= f.rich_text_area :description, data: {action: 'trix-change->auto-submit#submit'}, class: 'mb-4 w-full' %>
17
+ </div>
18
+ </div>
19
+ <div class="form-group">
20
+ <%= f.label :preferred_description_alignment, Spree.t('admin.page_builder.description_alignment') %>
21
+ <%= f.select :preferred_description_alignment, options_for_select([ ["Left", "left"], ["Center", "center"], ["Right", "right"] ], @page_section.preferred_description_alignment ), {}, data: { action: 'auto-submit#submit' }, class: "form-select" %>
22
+ </div>
23
+ <div class="form-group">
24
+ <div data-controller="better-slider">
25
+ <label><%= Spree.t('admin.page_builder.maximum_products_to_show') %>: <span data-better-slider-target="currentValueLabel"></span></label>
26
+ <div class="flex flex-row w-full">
27
+ <span class="mr-2">2</span>
28
+ <%= f.range_field :preferred_max_products_to_show, class: "custom-range w-full", min: 2, max: 20, data: {'better-slider-target': 'rangeInput', action: 'auto-submit#submit'} %>
29
+ <span class="ml-2">20</span>
30
+ </div>
31
+ </div>
32
+ </div>
@@ -0,0 +1,5 @@
1
+ <div class="form-group">
2
+ <%= f.label :preferred_heading, Spree.t('admin.page_builder.heading') %>
3
+ <%= f.text_field :preferred_heading, data: { action: 'auto-submit#submit' }, class: "form-input" %>
4
+ </div>
5
+
@@ -0,0 +1,15 @@
1
+ <div class="form-group">
2
+ <%= f.label :preferred_youtube_video_url, Spree.t('admin.page_builder.youtube_video_url') %>
3
+ <%= f.url_field :preferred_youtube_video_url, data: { action: 'change->auto-submit#submit' }, class: 'form-input' %>
4
+ </div>
5
+
6
+ <% content_for(:design_tab) do %>
7
+ <div class="form-group">
8
+ <%= f.label :preferred_separated, Spree.t('admin.page_builder.separated') %>
9
+ <%= f.select :preferred_separated, options_for_select(['horizontally', 'vertically'], @page_section.preferred_separated), { }, { class: 'form-select', data: { action: 'auto-submit#submit' } } %>
10
+ </div>
11
+
12
+ <%= render 'spree/admin/page_builder/labeled_range_input',
13
+ f: f, field: :preferred_width_desktop, min: 1, max: 100, unit: '%', _label: Spree.t('admin.page_builder.max_video_width_on_desktop')
14
+ %>
15
+ <% end %>
@@ -0,0 +1,7 @@
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 %>
@@ -0,0 +1,7 @@
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 %>
@@ -0,0 +1,26 @@
1
+ <%= turbo_frame_tag :page_sidebar do %>
2
+ <h6 class="sidebar-header">
3
+ <%= link_to collection_url, data: { action: 'click->page-builder#clearActiveOverlays' }, class: 'btn hover:bg-gray-100 shadow-none px-2' do %>
4
+ <%= icon 'chevron-left', class: 'mr-0 back' %>
5
+ <% end %>
6
+ <%= Spree.t(:add_section) %>
7
+ </h6>
8
+ <div class="pb-12 mb-12 edit-block">
9
+ <%= form_for @page_preview.sections.new, url: spree.admin_page_sections_path(@page_preview), data: { controller: 'section-form', section_form_target: :form } do |f| %>
10
+ <%= f.hidden_field :type, data: { section_form_target: 'type' } %>
11
+ <%= f.hidden_field :pageable_id %>
12
+ <%= f.hidden_field :pageable_type %>
13
+ <div class="flex flex-col gap-1 p-3">
14
+ <% @theme.available_page_sections.each do |section_class| %>
15
+ <button class="cursor-pointer flex items-center gap-4 hover:bg-gray-100 p-2 rounded-lg focus:outline focus:outline-2 focus:outline-offset-2 focus:outline-blue-500"
16
+ data-action="click->section-form#addSection keydown.enter->section-form#addSection"
17
+ data-section-form-type-param="<%= section_class %>"
18
+ >
19
+ <%= icon section_class.new.icon_name if section_class.new.icon_name.present? %>
20
+ <%= section_class.to_s.demodulize.titleize %>
21
+ </button>
22
+ <% end %>
23
+ </ul>
24
+ <% end %>
25
+ </div>
26
+ <% end %>
@@ -0,0 +1,4 @@
1
+ <%= refresh_theme_preview(@page_section) %>
2
+ <%= turbo_stream.replace :page_sidebar do %>
3
+ <%= render template: 'spree/admin/page_sections/edit' %>
4
+ <% end %>
@@ -0,0 +1,4 @@
1
+ <%= refresh_theme_preview(@page_section) %>
2
+ <%= turbo_stream.replace :page_sidebar do %>
3
+ <%= render template: 'spree/admin/page_sections/edit', locals: {tab_selected: :design} %>
4
+ <% end %>
@@ -0,0 +1 @@
1
+ <%= render 'spree/admin/page_builder/sidebar_section', section: @page_section %>
@@ -0,0 +1,10 @@
1
+ <% if @page_section.previous_changes.key?('position') %>
2
+ <%= refresh_theme_preview %>
3
+ <% else %>
4
+ <%= refresh_theme_preview(@page_section) %>
5
+ <% end %>
6
+ <% if @page_section.respond_to?(:link) %>
7
+ <%= turbo_stream.update :linkable_type_dropdown do %>
8
+ <%= render 'spree/admin/page_links/linkable_type_dropdown', page_link: @page_section.link, form_name: 'page_section[link_attributes]' %>
9
+ <% end %>
10
+ <% end %>
@@ -0,0 +1,20 @@
1
+ <div class="card mb-6">
2
+ <div class="card-header flex items-center justify-between">
3
+ <h5 class="card-title">
4
+ <%= Spree.t(:details) %>
5
+ </h5>
6
+ </div>
7
+ <div class="card-body">
8
+ <%= f.spree_text_field :name, required: true, data: { slug_form_target: :name, action: 'slug-form#updateUrlFromName', seo_form_target: 'sourceTitleInput' }, autofocus: true %>
9
+ </div>
10
+ </div>
11
+ <%= render 'spree/admin/shared/seo',
12
+ f: f,
13
+ title: @page.name,
14
+ meta_title: @page.meta_title,
15
+ description: nil,
16
+ slug_attribute_name: "page[slug]",
17
+ slug: @page.slug,
18
+ slug_path: 'pages',
19
+ placeholder: 'Add a title to see how this page might appear in a search engine listing' %>
20
+
@@ -0,0 +1,6 @@
1
+ <tr>
2
+ <th scope="col"><%= sort_link @search, :name, Spree.t(:name) %></th>
3
+ <th scope="col"><%= sort_link @search, :created_at, Spree.t(:created_at) %></th>
4
+ <th scope="col"><%= sort_link @search, :updated_at, Spree.t(:updated_at) %></th>
5
+ <th scope="col"></th>
6
+ </tr>