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.
- checksums.yaml +7 -0
- data/README.md +43 -0
- data/Rakefile +18 -0
- data/app/controllers/concerns/spree/admin/page_builder_concern.rb +45 -0
- data/app/controllers/concerns/spree/admin/storefront_breadcrumb_concern.rb +12 -0
- data/app/controllers/spree/admin/page_blocks_controller.rb +58 -0
- data/app/controllers/spree/admin/page_links_controller.rb +60 -0
- data/app/controllers/spree/admin/page_sections_controller.rb +82 -0
- data/app/controllers/spree/admin/pages_controller.rb +39 -0
- data/app/controllers/spree/admin/storefront_controller.rb +41 -0
- data/app/controllers/spree/admin/themes_controller.rb +87 -0
- data/app/helpers/spree/admin/page_builder_helper.rb +125 -0
- data/app/helpers/spree/admin/themes_helper.rb +9 -0
- data/app/jobs/spree/page_builder/products/touch_taxons_job_decorator.rb +15 -0
- data/app/jobs/spree/themes/duplicate_components_job.rb +59 -0
- data/app/jobs/spree/themes/screenshot_job.rb +81 -0
- data/app/models/concerns/spree/has_page_links.rb +53 -0
- data/app/models/spree/page.rb +188 -0
- data/app/models/spree/page_block.rb +73 -0
- data/app/models/spree/page_blocks/buttons.rb +29 -0
- data/app/models/spree/page_blocks/heading.rb +18 -0
- data/app/models/spree/page_blocks/image.rb +20 -0
- data/app/models/spree/page_blocks/link.rb +21 -0
- data/app/models/spree/page_blocks/mega_nav.rb +33 -0
- data/app/models/spree/page_blocks/mega_nav_with_subcategories.rb +32 -0
- data/app/models/spree/page_blocks/metafields.rb +18 -0
- data/app/models/spree/page_blocks/nav.rb +15 -0
- data/app/models/spree/page_blocks/newsletter_form.rb +18 -0
- data/app/models/spree/page_blocks/products/brand.rb +15 -0
- data/app/models/spree/page_blocks/products/buy_buttons.rb +24 -0
- data/app/models/spree/page_blocks/products/description.rb +18 -0
- data/app/models/spree/page_blocks/products/price.rb +18 -0
- data/app/models/spree/page_blocks/products/quantity_selector.rb +20 -0
- data/app/models/spree/page_blocks/products/share.rb +8 -0
- data/app/models/spree/page_blocks/products/title.rb +19 -0
- data/app/models/spree/page_blocks/products/variant_picker.rb +13 -0
- data/app/models/spree/page_blocks/subheading.rb +17 -0
- data/app/models/spree/page_blocks/text.rb +16 -0
- data/app/models/spree/page_builder/policy_decorator.rb +17 -0
- data/app/models/spree/page_builder/post_decorator.rb +17 -0
- data/app/models/spree/page_builder/product_decorator.rb +17 -0
- data/app/models/spree/page_builder/store_decorator.rb +46 -0
- data/app/models/spree/page_builder/taxon_decorator.rb +45 -0
- data/app/models/spree/page_link.rb +60 -0
- data/app/models/spree/page_section.rb +222 -0
- data/app/models/spree/page_sections/announcement_bar.rb +28 -0
- data/app/models/spree/page_sections/breadcrumbs.rb +12 -0
- data/app/models/spree/page_sections/collection_banner.rb +18 -0
- data/app/models/spree/page_sections/custom_code.rb +11 -0
- data/app/models/spree/page_sections/featured_posts.rb +45 -0
- data/app/models/spree/page_sections/featured_product.rb +50 -0
- data/app/models/spree/page_sections/featured_taxon.rb +90 -0
- data/app/models/spree/page_sections/featured_taxons.rb +45 -0
- data/app/models/spree/page_sections/footer.rb +101 -0
- data/app/models/spree/page_sections/header.rb +62 -0
- data/app/models/spree/page_sections/image_banner.rb +55 -0
- data/app/models/spree/page_sections/image_with_text.rb +65 -0
- data/app/models/spree/page_sections/main_password_footer.rb +18 -0
- data/app/models/spree/page_sections/main_password_header.rb +20 -0
- data/app/models/spree/page_sections/newsletter.rb +54 -0
- data/app/models/spree/page_sections/page_title.rb +19 -0
- data/app/models/spree/page_sections/post_details.rb +19 -0
- data/app/models/spree/page_sections/post_grid.rb +19 -0
- data/app/models/spree/page_sections/product_details.rb +53 -0
- data/app/models/spree/page_sections/product_grid.rb +13 -0
- data/app/models/spree/page_sections/related_products.rb +58 -0
- data/app/models/spree/page_sections/rich_text.rb +31 -0
- data/app/models/spree/page_sections/taxon_banner.rb +18 -0
- data/app/models/spree/page_sections/taxon_grid.rb +17 -0
- data/app/models/spree/page_sections/video.rb +107 -0
- data/app/models/spree/pages/account.rb +19 -0
- data/app/models/spree/pages/cart.rb +19 -0
- data/app/models/spree/pages/checkout.rb +15 -0
- data/app/models/spree/pages/custom.rb +38 -0
- data/app/models/spree/pages/homepage.rb +72 -0
- data/app/models/spree/pages/login.rb +19 -0
- data/app/models/spree/pages/password.rb +59 -0
- data/app/models/spree/pages/post.rb +27 -0
- data/app/models/spree/pages/post_list.rb +36 -0
- data/app/models/spree/pages/product_details.rb +30 -0
- data/app/models/spree/pages/search_results.rb +43 -0
- data/app/models/spree/pages/shop_all.rb +40 -0
- data/app/models/spree/pages/taxon.rb +29 -0
- data/app/models/spree/pages/taxon_list.rb +41 -0
- data/app/models/spree/pages/wishlist.rb +15 -0
- data/app/models/spree/theme.rb +233 -0
- data/app/models/spree/themes/default.rb +97 -0
- data/app/services/spree/taxons/touch_featured_sections.rb +21 -0
- data/app/views/layouts/spree/page_builder.html.erb +46 -0
- data/app/views/spree/admin/dashboard/_store_preview.html.erb +38 -0
- data/app/views/spree/admin/page_blocks/_form_tab_buttons.html.erb +5 -0
- data/app/views/spree/admin/page_blocks/create.turbo_stream.erb +4 -0
- data/app/views/spree/admin/page_blocks/destroy.turbo_stream.erb +9 -0
- data/app/views/spree/admin/page_blocks/edit.html.erb +43 -0
- data/app/views/spree/admin/page_blocks/forms/_brand.html.erb +15 -0
- data/app/views/spree/admin/page_blocks/forms/_brand_logo.html.erb +4 -0
- data/app/views/spree/admin/page_blocks/forms/_buttons.html.erb +13 -0
- data/app/views/spree/admin/page_blocks/forms/_heading.html.erb +28 -0
- data/app/views/spree/admin/page_blocks/forms/_image.html.erb +10 -0
- data/app/views/spree/admin/page_blocks/forms/_link.html.erb +19 -0
- data/app/views/spree/admin/page_blocks/forms/_mega_nav.html.erb +14 -0
- data/app/views/spree/admin/page_blocks/forms/_mega_nav_with_subcategories.html.erb +9 -0
- data/app/views/spree/admin/page_blocks/forms/_metafields.html.erb +35 -0
- data/app/views/spree/admin/page_blocks/forms/_nav.html.erb +6 -0
- data/app/views/spree/admin/page_blocks/forms/_newsletter_form.html.erb +20 -0
- data/app/views/spree/admin/page_blocks/forms/_price.html.erb +15 -0
- data/app/views/spree/admin/page_blocks/forms/_share.html.erb +5 -0
- data/app/views/spree/admin/page_blocks/forms/_subheading.html.erb +26 -0
- data/app/views/spree/admin/page_blocks/forms/_text.html.erb +21 -0
- data/app/views/spree/admin/page_blocks/forms/_title.html.erb +20 -0
- data/app/views/spree/admin/page_blocks/forms/_variant_picker.html.erb +10 -0
- data/app/views/spree/admin/page_blocks/forms/products/_buy_buttons.html.erb +10 -0
- data/app/views/spree/admin/page_blocks/forms/products/_description.html.erb +0 -0
- data/app/views/spree/admin/page_blocks/forms/products/_quantity_selector.html.erb +10 -0
- data/app/views/spree/admin/page_blocks/move_higher.turbo_stream.erb +4 -0
- data/app/views/spree/admin/page_blocks/move_lower.turbo_stream.erb +4 -0
- data/app/views/spree/admin/page_blocks/show.html.erb +1 -0
- data/app/views/spree/admin/page_blocks/update.turbo_stream.erb +6 -0
- data/app/views/spree/admin/page_builder/_add_block.html.erb +22 -0
- data/app/views/spree/admin/page_builder/_color_palette.html.erb +17 -0
- data/app/views/spree/admin/page_builder/_color_picker.html.erb +26 -0
- data/app/views/spree/admin/page_builder/_header.html.erb +113 -0
- data/app/views/spree/admin/page_builder/_labeled_range_input.html.erb +10 -0
- data/app/views/spree/admin/page_builder/_pages_dropdown.html.erb +17 -0
- data/app/views/spree/admin/page_builder/_range_input.html.erb +12 -0
- data/app/views/spree/admin/page_builder/_sidebar.html.erb +12 -0
- data/app/views/spree/admin/page_builder/_sidebar_block.html.erb +30 -0
- data/app/views/spree/admin/page_builder/_sidebar_colors.html.erb +86 -0
- data/app/views/spree/admin/page_builder/_sidebar_fonts.html.erb +85 -0
- data/app/views/spree/admin/page_builder/_sidebar_section.html.erb +44 -0
- data/app/views/spree/admin/page_builder/_sidebar_sections.html.erb +38 -0
- data/app/views/spree/admin/page_builder/_sidebar_sections_toolbar.html.erb +180 -0
- data/app/views/spree/admin/page_links/_form.html.erb +10 -0
- data/app/views/spree/admin/page_links/_linkable_type_dropdown.html.erb +15 -0
- data/app/views/spree/admin/page_links/_list.html.erb +36 -0
- data/app/views/spree/admin/page_links/_refresh_theme_preview.turbo_stream.erb +5 -0
- data/app/views/spree/admin/page_links/create.turbo_stream.erb +10 -0
- data/app/views/spree/admin/page_links/destroy.turbo_stream.erb +15 -0
- data/app/views/spree/admin/page_links/edit.html.erb +27 -0
- data/app/views/spree/admin/page_links/update.turbo_stream.erb +14 -0
- data/app/views/spree/admin/page_sections/_form_tab_buttons.html.erb +8 -0
- data/app/views/spree/admin/page_sections/create.turbo_stream.erb +11 -0
- data/app/views/spree/admin/page_sections/destroy.turbo_stream.erb +16 -0
- data/app/views/spree/admin/page_sections/edit.html.erb +39 -0
- data/app/views/spree/admin/page_sections/fields/_background_color.html.erb +6 -0
- data/app/views/spree/admin/page_sections/fields/_border_bottom_width.html.erb +5 -0
- data/app/views/spree/admin/page_sections/fields/_border_color.html.erb +7 -0
- data/app/views/spree/admin/page_sections/fields/_border_top_width.html.erb +6 -0
- data/app/views/spree/admin/page_sections/fields/_bottom_padding.html.erb +5 -0
- data/app/views/spree/admin/page_sections/fields/_button.html.erb +15 -0
- data/app/views/spree/admin/page_sections/fields/_header_layout.html.erb +26 -0
- data/app/views/spree/admin/page_sections/fields/_height.html.erb +6 -0
- data/app/views/spree/admin/page_sections/fields/_text_color.html.erb +7 -0
- data/app/views/spree/admin/page_sections/fields/_top_padding.html.erb +6 -0
- data/app/views/spree/admin/page_sections/forms/_announcement_bar.html.erb +5 -0
- data/app/views/spree/admin/page_sections/forms/_brand_story.html.erb +0 -0
- data/app/views/spree/admin/page_sections/forms/_breadcrumbs.html.erb +0 -0
- data/app/views/spree/admin/page_sections/forms/_collection_banner.html.erb +0 -0
- data/app/views/spree/admin/page_sections/forms/_custom_code.html.erb +4 -0
- data/app/views/spree/admin/page_sections/forms/_featured_posts.html.erb +33 -0
- data/app/views/spree/admin/page_sections/forms/_featured_product.html.erb +4 -0
- data/app/views/spree/admin/page_sections/forms/_featured_taxon.html.erb +59 -0
- data/app/views/spree/admin/page_sections/forms/_featured_taxons.html.erb +13 -0
- data/app/views/spree/admin/page_sections/forms/_footer.html.erb +20 -0
- data/app/views/spree/admin/page_sections/forms/_header.html.erb +12 -0
- data/app/views/spree/admin/page_sections/forms/_image_banner.html.erb +13 -0
- data/app/views/spree/admin/page_sections/forms/_image_with_text.html.erb +28 -0
- data/app/views/spree/admin/page_sections/forms/_main_password_footer.html.erb +9 -0
- data/app/views/spree/admin/page_sections/forms/_main_password_header.erb +13 -0
- data/app/views/spree/admin/page_sections/forms/_newsletter.html.erb +15 -0
- data/app/views/spree/admin/page_sections/forms/_page_title.html.erb +4 -0
- data/app/views/spree/admin/page_sections/forms/_post_details.html.erb +0 -0
- data/app/views/spree/admin/page_sections/forms/_post_grid.html.erb +0 -0
- data/app/views/spree/admin/page_sections/forms/_product_details.html.erb +1 -0
- data/app/views/spree/admin/page_sections/forms/_product_grid.html.erb +1 -0
- data/app/views/spree/admin/page_sections/forms/_related_products.html.erb +32 -0
- data/app/views/spree/admin/page_sections/forms/_rich_text.html.erb +0 -0
- data/app/views/spree/admin/page_sections/forms/_taxon_banner.html.erb +0 -0
- data/app/views/spree/admin/page_sections/forms/_taxon_grid.html.erb +5 -0
- data/app/views/spree/admin/page_sections/forms/_video.html.erb +15 -0
- data/app/views/spree/admin/page_sections/move_higher.turbo_stream.erb +7 -0
- data/app/views/spree/admin/page_sections/move_lower.turbo_stream.erb +7 -0
- data/app/views/spree/admin/page_sections/new.html.erb +26 -0
- data/app/views/spree/admin/page_sections/remove_attachment.turbo_stream.erb +4 -0
- data/app/views/spree/admin/page_sections/restore_design_settings_to_defaults.turbo_stream.erb +4 -0
- data/app/views/spree/admin/page_sections/show.html.erb +1 -0
- data/app/views/spree/admin/page_sections/update.turbo_stream.erb +10 -0
- data/app/views/spree/admin/pages/_form.html.erb +20 -0
- data/app/views/spree/admin/pages/_table_header.html.erb +6 -0
- data/app/views/spree/admin/pages/_table_row.html.erb +28 -0
- data/app/views/spree/admin/pages/edit.html.erb +13 -0
- data/app/views/spree/admin/pages/filters.html.erb +7 -0
- data/app/views/spree/admin/pages/index.html.erb +11 -0
- data/app/views/spree/admin/pages/new.html.erb +1 -0
- data/app/views/spree/admin/storefront/edit.html.erb +89 -0
- data/app/views/spree/admin/themes/_theme.html.erb +56 -0
- data/app/views/spree/admin/themes/_theme_preview_image.html.erb +17 -0
- data/app/views/spree/admin/themes/edit.html.erb +14 -0
- data/app/views/spree/admin/themes/index.html.erb +80 -0
- data/app/views/spree/admin/themes/update.turbo_stream.erb +1 -0
- data/config/initializers/spree_admin_navigation.rb +46 -0
- data/config/initializers/spree_admin_partials.rb +3 -0
- data/config/locales/en.yml +42 -0
- data/config/routes.rb +43 -0
- data/db/migrate/20250120094216_create_page_builder_models.rb +78 -0
- data/db/migrate/20250305121352_remove_page_builder_indices.rb +11 -0
- data/db/migrate/20250825175217_add_missing_page_builder_indexes.rb +7 -0
- data/db/migrate/20250913130044_add_page_links_counter_cache_to_spree_stores.rb +10 -0
- data/lib/generators/spree/page_builder/install/install_generator.rb +23 -0
- data/lib/spree/page_builder/engine.rb +185 -0
- data/lib/spree/page_builder/testing_support/factories/page_block_factory.rb +22 -0
- data/lib/spree/page_builder/testing_support/factories/page_factory.rb +33 -0
- data/lib/spree/page_builder/testing_support/factories/page_link_factory.rb +7 -0
- data/lib/spree/page_builder/testing_support/factories/page_section_factory.rb +27 -0
- data/lib/spree/page_builder/testing_support/factories/theme_factory.rb +14 -0
- data/lib/spree/page_builder/testing_support/factories.rb +3 -0
- data/lib/spree/page_builder.rb +4 -0
- data/lib/spree_page_builder.rb +1 -0
- 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,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 %>
|