maglevcms 1.0.0.rc1
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +7 -0
- data/MIT-LICENSE +20 -0
- data/README.md +27 -0
- data/Rakefile +34 -0
- data/app/assets/config/maglev_manifest.js +1 -0
- data/app/assets/images/maglev/favicon.png +0 -0
- data/app/assets/images/maglev/logo.png +0 -0
- data/app/assets/stylesheets/maglev/application.css +15 -0
- data/app/components/maglev/base_component.rb +54 -0
- data/app/components/maglev/block_component.rb +46 -0
- data/app/components/maglev/content/base.rb +52 -0
- data/app/components/maglev/content/builder.rb +28 -0
- data/app/components/maglev/content/checkbox.rb +19 -0
- data/app/components/maglev/content/collection_item.rb +29 -0
- data/app/components/maglev/content/color.rb +20 -0
- data/app/components/maglev/content/icon.rb +26 -0
- data/app/components/maglev/content/image.rb +55 -0
- data/app/components/maglev/content/link.rb +61 -0
- data/app/components/maglev/content/select.rb +8 -0
- data/app/components/maglev/content/text.rb +25 -0
- data/app/components/maglev/page_component.rb +44 -0
- data/app/components/maglev/section_component.rb +96 -0
- data/app/components/maglev/tag_helper.rb +43 -0
- data/app/controllers/concerns/maglev/authentication_concern.rb +31 -0
- data/app/controllers/concerns/maglev/back_action_concern.rb +30 -0
- data/app/controllers/concerns/maglev/content_locale_concern.rb +26 -0
- data/app/controllers/concerns/maglev/fetchers_concern.rb +108 -0
- data/app/controllers/concerns/maglev/json_concern.rb +21 -0
- data/app/controllers/concerns/maglev/rendering_concern.rb +40 -0
- data/app/controllers/concerns/maglev/services_concern.rb +39 -0
- data/app/controllers/concerns/maglev/standalone_sections_concern.rb +28 -0
- data/app/controllers/concerns/maglev/ui_locale_concern.rb +32 -0
- data/app/controllers/maglev/admin/base_controller.rb +21 -0
- data/app/controllers/maglev/admin/dashboard_controller.rb +11 -0
- data/app/controllers/maglev/admin/sections/previews_controller.rb +52 -0
- data/app/controllers/maglev/admin/sections/screenshots_controller.rb +17 -0
- data/app/controllers/maglev/admin/themes_controller.rb +19 -0
- data/app/controllers/maglev/api/assets_controller.rb +44 -0
- data/app/controllers/maglev/api/collection_items_controller.rb +14 -0
- data/app/controllers/maglev/api/page_clones_controller.rb +22 -0
- data/app/controllers/maglev/api/pages_controller.rb +65 -0
- data/app/controllers/maglev/api/publications_controller.rb +15 -0
- data/app/controllers/maglev/api/sites_controller.rb +21 -0
- data/app/controllers/maglev/api.rb +15 -0
- data/app/controllers/maglev/api_controller.rb +61 -0
- data/app/controllers/maglev/application_controller.rb +17 -0
- data/app/controllers/maglev/assets_controller.rb +10 -0
- data/app/controllers/maglev/editor_controller.rb +46 -0
- data/app/controllers/maglev/page_preview_controller.rb +53 -0
- data/app/helpers/maglev/admin/sections/previews_helper.rb +21 -0
- data/app/helpers/maglev/admin/themes_helper.rb +27 -0
- data/app/helpers/maglev/application_helper.rb +13 -0
- data/app/helpers/maglev/editor_helper.rb +78 -0
- data/app/helpers/maglev/page_preview_helper.rb +57 -0
- data/app/javascript/controllers/dropdown_controller.js +9 -0
- data/app/javascript/controllers/iframe_controller.js +14 -0
- data/app/javascript/controllers/index.js +11 -0
- data/app/javascript/controllers/screenshot_controller.js +37 -0
- data/app/javascript/editor/App.vue +43 -0
- data/app/javascript/editor/assets/remixicons/add-box-line.svg +1 -0
- data/app/javascript/editor/assets/remixicons/arrow-down-s-line.svg +1 -0
- data/app/javascript/editor/assets/remixicons/arrow-drop-left.svg +1 -0
- data/app/javascript/editor/assets/remixicons/arrow-drop-right.svg +1 -0
- data/app/javascript/editor/assets/remixicons/arrow-up-s-line.svg +1 -0
- data/app/javascript/editor/assets/remixicons/camera-line.svg +1 -0
- data/app/javascript/editor/assets/remixicons/check-line.svg +1 -0
- data/app/javascript/editor/assets/remixicons/close-line.svg +1 -0
- data/app/javascript/editor/assets/remixicons/computer-line.svg +1 -0
- data/app/javascript/editor/assets/remixicons/delete-bin-line.svg +1 -0
- data/app/javascript/editor/assets/remixicons/file-line.svg +1 -0
- data/app/javascript/editor/assets/remixicons/format-blockquote.svg +1 -0
- data/app/javascript/editor/assets/remixicons/format-bold.svg +1 -0
- data/app/javascript/editor/assets/remixicons/format-code.svg +1 -0
- data/app/javascript/editor/assets/remixicons/format-heading-2.svg +1 -0
- data/app/javascript/editor/assets/remixicons/format-heading-3.svg +1 -0
- data/app/javascript/editor/assets/remixicons/format-heading-4.svg +1 -0
- data/app/javascript/editor/assets/remixicons/format-italic.svg +1 -0
- data/app/javascript/editor/assets/remixicons/format-link-unlink.svg +1 -0
- data/app/javascript/editor/assets/remixicons/format-link.svg +1 -0
- data/app/javascript/editor/assets/remixicons/format-list-ordered.svg +1 -0
- data/app/javascript/editor/assets/remixicons/format-list-unordered.svg +1 -0
- data/app/javascript/editor/assets/remixicons/format-paragraph.svg +1 -0
- data/app/javascript/editor/assets/remixicons/format-strikethrough.svg +1 -0
- data/app/javascript/editor/assets/remixicons/format-underline.svg +1 -0
- data/app/javascript/editor/assets/remixicons/home-4-line.svg +1 -0
- data/app/javascript/editor/assets/remixicons/image-line.svg +1 -0
- data/app/javascript/editor/assets/remixicons/logout-box-r-line.svg +1 -0
- data/app/javascript/editor/assets/remixicons/ri-add-line.svg +1 -0
- data/app/javascript/editor/assets/remixicons/ri-alert-line.svg +1 -0
- data/app/javascript/editor/assets/remixicons/ri-book-line.svg +1 -0
- data/app/javascript/editor/assets/remixicons/ri-bug-line.svg +1 -0
- data/app/javascript/editor/assets/remixicons/ri-close-circle-line.svg +1 -0
- data/app/javascript/editor/assets/remixicons/ri-close-line.svg +1 -0
- data/app/javascript/editor/assets/remixicons/ri-delete-column.svg +1 -0
- data/app/javascript/editor/assets/remixicons/ri-delete-row.svg +1 -0
- data/app/javascript/editor/assets/remixicons/ri-drop-line.svg +1 -0
- data/app/javascript/editor/assets/remixicons/ri-external-link-line.svg +1 -0
- data/app/javascript/editor/assets/remixicons/ri-eye-line.svg +1 -0
- data/app/javascript/editor/assets/remixicons/ri-eye-off-line.svg +1 -0
- data/app/javascript/editor/assets/remixicons/ri-file-copy-line.svg +1 -0
- data/app/javascript/editor/assets/remixicons/ri-file-line.svg +1 -0
- data/app/javascript/editor/assets/remixicons/ri-global-line.svg +1 -0
- data/app/javascript/editor/assets/remixicons/ri-insert-column-left.svg +1 -0
- data/app/javascript/editor/assets/remixicons/ri-insert-column-right.svg +1 -0
- data/app/javascript/editor/assets/remixicons/ri-insert-row-bottom.svg +1 -0
- data/app/javascript/editor/assets/remixicons/ri-insert-row-top.svg +1 -0
- data/app/javascript/editor/assets/remixicons/ri-loader-4-line.svg +1 -0
- data/app/javascript/editor/assets/remixicons/ri-mail-line.svg +1 -0
- data/app/javascript/editor/assets/remixicons/ri-more-2-fill.svg +1 -0
- data/app/javascript/editor/assets/remixicons/ri-pencil-line.svg +1 -0
- data/app/javascript/editor/assets/remixicons/ri-play-list-add-line.svg +1 -0
- data/app/javascript/editor/assets/remixicons/ri-settings-5-line.svg +1 -0
- data/app/javascript/editor/assets/remixicons/ri-stack-line.svg +1 -0
- data/app/javascript/editor/assets/remixicons/ri-table-2.svg +1 -0
- data/app/javascript/editor/assets/remixicons/ri-table-line.svg +1 -0
- data/app/javascript/editor/assets/remixicons/search-line.svg +1 -0
- data/app/javascript/editor/assets/remixicons/settings-4-line.svg +1 -0
- data/app/javascript/editor/assets/remixicons/smartphone-line.svg +1 -0
- data/app/javascript/editor/assets/remixicons/tablet-line.svg +1 -0
- data/app/javascript/editor/assets/zondicons/add-outline.svg +1 -0
- data/app/javascript/editor/assets/zondicons/add-solid.svg +1 -0
- data/app/javascript/editor/assets/zondicons/adjust.svg +1 -0
- data/app/javascript/editor/assets/zondicons/airplane.svg +1 -0
- data/app/javascript/editor/assets/zondicons/album.svg +1 -0
- data/app/javascript/editor/assets/zondicons/align-center.svg +1 -0
- data/app/javascript/editor/assets/zondicons/align-justified.svg +1 -0
- data/app/javascript/editor/assets/zondicons/align-left.svg +1 -0
- data/app/javascript/editor/assets/zondicons/align-right.svg +1 -0
- data/app/javascript/editor/assets/zondicons/anchor.svg +1 -0
- data/app/javascript/editor/assets/zondicons/announcement.svg +1 -0
- data/app/javascript/editor/assets/zondicons/apparel.svg +1 -0
- data/app/javascript/editor/assets/zondicons/arrow-down.svg +1 -0
- data/app/javascript/editor/assets/zondicons/arrow-left.svg +1 -0
- data/app/javascript/editor/assets/zondicons/arrow-outline-down.svg +1 -0
- data/app/javascript/editor/assets/zondicons/arrow-outline-left.svg +1 -0
- data/app/javascript/editor/assets/zondicons/arrow-outline-right.svg +1 -0
- data/app/javascript/editor/assets/zondicons/arrow-outline-up.svg +1 -0
- data/app/javascript/editor/assets/zondicons/arrow-right.svg +1 -0
- data/app/javascript/editor/assets/zondicons/arrow-thick-down.svg +1 -0
- data/app/javascript/editor/assets/zondicons/arrow-thick-left.svg +1 -0
- data/app/javascript/editor/assets/zondicons/arrow-thick-right.svg +1 -0
- data/app/javascript/editor/assets/zondicons/arrow-thick-up.svg +1 -0
- data/app/javascript/editor/assets/zondicons/arrow-thin-down.svg +1 -0
- data/app/javascript/editor/assets/zondicons/arrow-thin-left.svg +1 -0
- data/app/javascript/editor/assets/zondicons/arrow-thin-right.svg +1 -0
- data/app/javascript/editor/assets/zondicons/arrow-thin-up.svg +1 -0
- data/app/javascript/editor/assets/zondicons/arrow-up.svg +1 -0
- data/app/javascript/editor/assets/zondicons/artist.svg +1 -0
- data/app/javascript/editor/assets/zondicons/at-symbol.svg +1 -0
- data/app/javascript/editor/assets/zondicons/attachment.svg +1 -0
- data/app/javascript/editor/assets/zondicons/backspace.svg +1 -0
- data/app/javascript/editor/assets/zondicons/backward-step.svg +1 -0
- data/app/javascript/editor/assets/zondicons/backward.svg +1 -0
- data/app/javascript/editor/assets/zondicons/badge.svg +1 -0
- data/app/javascript/editor/assets/zondicons/battery-full.svg +1 -0
- data/app/javascript/editor/assets/zondicons/battery-half.svg +1 -0
- data/app/javascript/editor/assets/zondicons/battery-low.svg +1 -0
- data/app/javascript/editor/assets/zondicons/beverage.svg +1 -0
- data/app/javascript/editor/assets/zondicons/block.svg +1 -0
- data/app/javascript/editor/assets/zondicons/bluetooth.svg +1 -0
- data/app/javascript/editor/assets/zondicons/bolt.svg +1 -0
- data/app/javascript/editor/assets/zondicons/book-reference.svg +1 -0
- data/app/javascript/editor/assets/zondicons/bookmark copy 2.svg +1 -0
- data/app/javascript/editor/assets/zondicons/bookmark copy 3.svg +1 -0
- data/app/javascript/editor/assets/zondicons/bookmark-outline-add.svg +1 -0
- data/app/javascript/editor/assets/zondicons/bookmark-outline.svg +1 -0
- data/app/javascript/editor/assets/zondicons/bookmark.svg +1 -0
- data/app/javascript/editor/assets/zondicons/border-all.svg +1 -0
- data/app/javascript/editor/assets/zondicons/border-bottom.svg +1 -0
- data/app/javascript/editor/assets/zondicons/border-horizontal.svg +1 -0
- data/app/javascript/editor/assets/zondicons/border-inner.svg +1 -0
- data/app/javascript/editor/assets/zondicons/border-left.svg +1 -0
- data/app/javascript/editor/assets/zondicons/border-none.svg +1 -0
- data/app/javascript/editor/assets/zondicons/border-outer.svg +1 -0
- data/app/javascript/editor/assets/zondicons/border-right.svg +1 -0
- data/app/javascript/editor/assets/zondicons/border-top.svg +1 -0
- data/app/javascript/editor/assets/zondicons/border-vertical.svg +1 -0
- data/app/javascript/editor/assets/zondicons/box.svg +1 -0
- data/app/javascript/editor/assets/zondicons/brightness-down.svg +1 -0
- data/app/javascript/editor/assets/zondicons/brightness-up.svg +1 -0
- data/app/javascript/editor/assets/zondicons/browser-window-new.svg +1 -0
- data/app/javascript/editor/assets/zondicons/browser-window-open.svg +1 -0
- data/app/javascript/editor/assets/zondicons/browser-window.svg +1 -0
- data/app/javascript/editor/assets/zondicons/bug.svg +1 -0
- data/app/javascript/editor/assets/zondicons/buoy.svg +1 -0
- data/app/javascript/editor/assets/zondicons/calculator.svg +1 -0
- data/app/javascript/editor/assets/zondicons/calendar.svg +1 -0
- data/app/javascript/editor/assets/zondicons/camera.svg +1 -0
- data/app/javascript/editor/assets/zondicons/chart-bar.svg +1 -0
- data/app/javascript/editor/assets/zondicons/chart-pie.svg +1 -0
- data/app/javascript/editor/assets/zondicons/chart.svg +1 -0
- data/app/javascript/editor/assets/zondicons/chat-bubble-dots.svg +1 -0
- data/app/javascript/editor/assets/zondicons/checkmark-outline.svg +1 -0
- data/app/javascript/editor/assets/zondicons/checkmark.svg +1 -0
- data/app/javascript/editor/assets/zondicons/cheveron-down.svg +1 -0
- data/app/javascript/editor/assets/zondicons/cheveron-left.svg +1 -0
- data/app/javascript/editor/assets/zondicons/cheveron-outline-down.svg +1 -0
- data/app/javascript/editor/assets/zondicons/cheveron-outline-left.svg +1 -0
- data/app/javascript/editor/assets/zondicons/cheveron-outline-right.svg +1 -0
- data/app/javascript/editor/assets/zondicons/cheveron-outline-up.svg +1 -0
- data/app/javascript/editor/assets/zondicons/cheveron-right.svg +1 -0
- data/app/javascript/editor/assets/zondicons/cheveron-up.svg +1 -0
- data/app/javascript/editor/assets/zondicons/clipboard.svg +1 -0
- data/app/javascript/editor/assets/zondicons/close-outline.svg +1 -0
- data/app/javascript/editor/assets/zondicons/close-solid.svg +1 -0
- data/app/javascript/editor/assets/zondicons/close.svg +1 -0
- data/app/javascript/editor/assets/zondicons/cloud-upload.svg +1 -0
- data/app/javascript/editor/assets/zondicons/cloud.svg +1 -0
- data/app/javascript/editor/assets/zondicons/code.svg +1 -0
- data/app/javascript/editor/assets/zondicons/coffee.svg +1 -0
- data/app/javascript/editor/assets/zondicons/cog.svg +1 -0
- data/app/javascript/editor/assets/zondicons/color-palette.svg +1 -0
- data/app/javascript/editor/assets/zondicons/compose.svg +1 -0
- data/app/javascript/editor/assets/zondicons/computer-desktop.svg +1 -0
- data/app/javascript/editor/assets/zondicons/computer-laptop.svg +1 -0
- data/app/javascript/editor/assets/zondicons/conversation.svg +1 -0
- data/app/javascript/editor/assets/zondicons/copy.svg +1 -0
- data/app/javascript/editor/assets/zondicons/credit-card.svg +1 -0
- data/app/javascript/editor/assets/zondicons/currency-dollar.svg +1 -0
- data/app/javascript/editor/assets/zondicons/dashboard.svg +1 -0
- data/app/javascript/editor/assets/zondicons/date-add.svg +1 -0
- data/app/javascript/editor/assets/zondicons/dial-pad.svg +1 -0
- data/app/javascript/editor/assets/zondicons/directions.svg +1 -0
- data/app/javascript/editor/assets/zondicons/document-add.svg +1 -0
- data/app/javascript/editor/assets/zondicons/document.svg +1 -0
- data/app/javascript/editor/assets/zondicons/dots-horizontal-double.svg +1 -0
- data/app/javascript/editor/assets/zondicons/dots-horizontal-triple.svg +1 -0
- data/app/javascript/editor/assets/zondicons/download.svg +1 -0
- data/app/javascript/editor/assets/zondicons/duplicate.svg +1 -0
- data/app/javascript/editor/assets/zondicons/edit-copy.svg +1 -0
- data/app/javascript/editor/assets/zondicons/edit-crop.svg +1 -0
- data/app/javascript/editor/assets/zondicons/edit-cut.svg +1 -0
- data/app/javascript/editor/assets/zondicons/edit-pencil.svg +1 -0
- data/app/javascript/editor/assets/zondicons/education.svg +1 -0
- data/app/javascript/editor/assets/zondicons/envelope.svg +1 -0
- data/app/javascript/editor/assets/zondicons/exclamation-outline.svg +1 -0
- data/app/javascript/editor/assets/zondicons/exclamation-solid.svg +1 -0
- data/app/javascript/editor/assets/zondicons/explore.svg +1 -0
- data/app/javascript/editor/assets/zondicons/factory.svg +1 -0
- data/app/javascript/editor/assets/zondicons/fast-forward.svg +1 -0
- data/app/javascript/editor/assets/zondicons/fast-rewind.svg +1 -0
- data/app/javascript/editor/assets/zondicons/film.svg +1 -0
- data/app/javascript/editor/assets/zondicons/filter.svg +1 -0
- data/app/javascript/editor/assets/zondicons/flag.svg +1 -0
- data/app/javascript/editor/assets/zondicons/flashlight.svg +1 -0
- data/app/javascript/editor/assets/zondicons/folder-outline-add.svg +1 -0
- data/app/javascript/editor/assets/zondicons/folder-outline.svg +1 -0
- data/app/javascript/editor/assets/zondicons/folder.svg +1 -0
- data/app/javascript/editor/assets/zondicons/format-bold.svg +1 -0
- data/app/javascript/editor/assets/zondicons/format-font-size.svg +1 -0
- data/app/javascript/editor/assets/zondicons/format-italic.svg +1 -0
- data/app/javascript/editor/assets/zondicons/format-text-size.svg +1 -0
- data/app/javascript/editor/assets/zondicons/format-underline.svg +1 -0
- data/app/javascript/editor/assets/zondicons/forward-step.svg +1 -0
- data/app/javascript/editor/assets/zondicons/forward.svg +1 -0
- data/app/javascript/editor/assets/zondicons/gift.svg +1 -0
- data/app/javascript/editor/assets/zondicons/globe.svg +1 -0
- data/app/javascript/editor/assets/zondicons/hand-stop.svg +1 -0
- data/app/javascript/editor/assets/zondicons/hard-drive.svg +1 -0
- data/app/javascript/editor/assets/zondicons/headphones.svg +1 -0
- data/app/javascript/editor/assets/zondicons/heart.svg +1 -0
- data/app/javascript/editor/assets/zondicons/home.svg +1 -0
- data/app/javascript/editor/assets/zondicons/hot.svg +1 -0
- data/app/javascript/editor/assets/zondicons/hour-glass.svg +1 -0
- data/app/javascript/editor/assets/zondicons/inbox-check.svg +1 -0
- data/app/javascript/editor/assets/zondicons/inbox-download.svg +1 -0
- data/app/javascript/editor/assets/zondicons/inbox-full.svg +1 -0
- data/app/javascript/editor/assets/zondicons/inbox.svg +1 -0
- data/app/javascript/editor/assets/zondicons/indent-decrease.svg +1 -0
- data/app/javascript/editor/assets/zondicons/indent-increase.svg +1 -0
- data/app/javascript/editor/assets/zondicons/information-outline.svg +1 -0
- data/app/javascript/editor/assets/zondicons/information-solid.svg +1 -0
- data/app/javascript/editor/assets/zondicons/key.svg +1 -0
- data/app/javascript/editor/assets/zondicons/keyboard.svg +1 -0
- data/app/javascript/editor/assets/zondicons/layers.svg +1 -0
- data/app/javascript/editor/assets/zondicons/library.svg +1 -0
- data/app/javascript/editor/assets/zondicons/light-bulb.svg +1 -0
- data/app/javascript/editor/assets/zondicons/link.svg +1 -0
- data/app/javascript/editor/assets/zondicons/list-add.svg +1 -0
- data/app/javascript/editor/assets/zondicons/list-bullet.svg +1 -0
- data/app/javascript/editor/assets/zondicons/list.svg +1 -0
- data/app/javascript/editor/assets/zondicons/load-balancer.svg +1 -0
- data/app/javascript/editor/assets/zondicons/location-current.svg +1 -0
- data/app/javascript/editor/assets/zondicons/location-food.svg +1 -0
- data/app/javascript/editor/assets/zondicons/location-gas-station.svg +1 -0
- data/app/javascript/editor/assets/zondicons/location-hotel.svg +1 -0
- data/app/javascript/editor/assets/zondicons/location-marina.svg +1 -0
- data/app/javascript/editor/assets/zondicons/location-park.svg +1 -0
- data/app/javascript/editor/assets/zondicons/location-restroom.svg +1 -0
- data/app/javascript/editor/assets/zondicons/location-shopping.svg +1 -0
- data/app/javascript/editor/assets/zondicons/location.svg +1 -0
- data/app/javascript/editor/assets/zondicons/lock-closed.svg +1 -0
- data/app/javascript/editor/assets/zondicons/lock-open.svg +1 -0
- data/app/javascript/editor/assets/zondicons/map.svg +1 -0
- data/app/javascript/editor/assets/zondicons/menu.svg +1 -0
- data/app/javascript/editor/assets/zondicons/mic.svg +1 -0
- data/app/javascript/editor/assets/zondicons/minus-outline.svg +1 -0
- data/app/javascript/editor/assets/zondicons/minus-solid.svg +1 -0
- data/app/javascript/editor/assets/zondicons/mobile-devices.svg +1 -0
- data/app/javascript/editor/assets/zondicons/mood-happy-outline.svg +1 -0
- data/app/javascript/editor/assets/zondicons/mood-happy-solid.svg +1 -0
- data/app/javascript/editor/assets/zondicons/mood-neutral-outline.svg +1 -0
- data/app/javascript/editor/assets/zondicons/mood-neutral-solid.svg +1 -0
- data/app/javascript/editor/assets/zondicons/mood-sad-outline.svg +1 -0
- data/app/javascript/editor/assets/zondicons/mood-sad-solid.svg +1 -0
- data/app/javascript/editor/assets/zondicons/mouse.svg +1 -0
- data/app/javascript/editor/assets/zondicons/music-album.svg +1 -0
- data/app/javascript/editor/assets/zondicons/music-artist.svg +1 -0
- data/app/javascript/editor/assets/zondicons/music-notes.svg +1 -0
- data/app/javascript/editor/assets/zondicons/music-playlist.svg +1 -0
- data/app/javascript/editor/assets/zondicons/navigation-more.svg +1 -0
- data/app/javascript/editor/assets/zondicons/network.svg +1 -0
- data/app/javascript/editor/assets/zondicons/news-paper.svg +1 -0
- data/app/javascript/editor/assets/zondicons/notification.svg +1 -0
- data/app/javascript/editor/assets/zondicons/notifications-outline.svg +1 -0
- data/app/javascript/editor/assets/zondicons/notifications.svg +1 -0
- data/app/javascript/editor/assets/zondicons/paste.svg +1 -0
- data/app/javascript/editor/assets/zondicons/pause-outline.svg +1 -0
- data/app/javascript/editor/assets/zondicons/pause-solid.svg +1 -0
- data/app/javascript/editor/assets/zondicons/pause.svg +1 -0
- data/app/javascript/editor/assets/zondicons/pen-tool.svg +1 -0
- data/app/javascript/editor/assets/zondicons/phone.svg +1 -0
- data/app/javascript/editor/assets/zondicons/photo.svg +1 -0
- data/app/javascript/editor/assets/zondicons/php-elephant.svg +1 -0
- data/app/javascript/editor/assets/zondicons/pin.svg +1 -0
- data/app/javascript/editor/assets/zondicons/play-outline.svg +1 -0
- data/app/javascript/editor/assets/zondicons/play.svg +1 -0
- data/app/javascript/editor/assets/zondicons/playlist.svg +1 -0
- data/app/javascript/editor/assets/zondicons/plugin.svg +1 -0
- data/app/javascript/editor/assets/zondicons/portfolio.svg +1 -0
- data/app/javascript/editor/assets/zondicons/printer.svg +1 -0
- data/app/javascript/editor/assets/zondicons/pylon.svg +1 -0
- data/app/javascript/editor/assets/zondicons/question.svg +1 -0
- data/app/javascript/editor/assets/zondicons/queue.svg +1 -0
- data/app/javascript/editor/assets/zondicons/radar copy 2.svg +1 -0
- data/app/javascript/editor/assets/zondicons/radar.svg +1 -0
- data/app/javascript/editor/assets/zondicons/radio.svg +1 -0
- data/app/javascript/editor/assets/zondicons/refresh.svg +1 -0
- data/app/javascript/editor/assets/zondicons/reload.svg +1 -0
- data/app/javascript/editor/assets/zondicons/reply-all.svg +1 -0
- data/app/javascript/editor/assets/zondicons/reply.svg +1 -0
- data/app/javascript/editor/assets/zondicons/repost.svg +1 -0
- data/app/javascript/editor/assets/zondicons/save-disk.svg +1 -0
- data/app/javascript/editor/assets/zondicons/screen-full.svg +1 -0
- data/app/javascript/editor/assets/zondicons/search.svg +1 -0
- data/app/javascript/editor/assets/zondicons/send.svg +1 -0
- data/app/javascript/editor/assets/zondicons/servers.svg +1 -0
- data/app/javascript/editor/assets/zondicons/share-01.svg +1 -0
- data/app/javascript/editor/assets/zondicons/share-alt.svg +1 -0
- data/app/javascript/editor/assets/zondicons/share.svg +1 -0
- data/app/javascript/editor/assets/zondicons/shield.svg +1 -0
- data/app/javascript/editor/assets/zondicons/shopping-cart.svg +1 -0
- data/app/javascript/editor/assets/zondicons/show-sidebar.svg +1 -0
- data/app/javascript/editor/assets/zondicons/shuffle.svg +1 -0
- data/app/javascript/editor/assets/zondicons/stand-by.svg +1 -0
- data/app/javascript/editor/assets/zondicons/star-full.svg +1 -0
- data/app/javascript/editor/assets/zondicons/station.svg +1 -0
- data/app/javascript/editor/assets/zondicons/step-backward.svg +1 -0
- data/app/javascript/editor/assets/zondicons/step-forward.svg +1 -0
- data/app/javascript/editor/assets/zondicons/stethoscope.svg +1 -0
- data/app/javascript/editor/assets/zondicons/store-front.svg +1 -0
- data/app/javascript/editor/assets/zondicons/stroke-width.svg +1 -0
- data/app/javascript/editor/assets/zondicons/subdirectory-left.svg +1 -0
- data/app/javascript/editor/assets/zondicons/subdirectory-right.svg +1 -0
- data/app/javascript/editor/assets/zondicons/swap.svg +1 -0
- data/app/javascript/editor/assets/zondicons/tablet.svg +1 -0
- data/app/javascript/editor/assets/zondicons/tag.svg +1 -0
- data/app/javascript/editor/assets/zondicons/target.svg +1 -0
- data/app/javascript/editor/assets/zondicons/text-box.svg +1 -0
- data/app/javascript/editor/assets/zondicons/text-decoration.svg +1 -0
- data/app/javascript/editor/assets/zondicons/thermometer.svg +1 -0
- data/app/javascript/editor/assets/zondicons/thumbs-down.svg +1 -0
- data/app/javascript/editor/assets/zondicons/thumbs-up.svg +1 -0
- data/app/javascript/editor/assets/zondicons/ticket.svg +1 -0
- data/app/javascript/editor/assets/zondicons/time.svg +1 -0
- data/app/javascript/editor/assets/zondicons/timer.svg +1 -0
- data/app/javascript/editor/assets/zondicons/tools copy.svg +1 -0
- data/app/javascript/editor/assets/zondicons/translate.svg +1 -0
- data/app/javascript/editor/assets/zondicons/trash.svg +1 -0
- data/app/javascript/editor/assets/zondicons/travel-bus.svg +1 -0
- data/app/javascript/editor/assets/zondicons/travel-car.svg +1 -0
- data/app/javascript/editor/assets/zondicons/travel-case.svg +1 -0
- data/app/javascript/editor/assets/zondicons/travel-taxi-cab.svg +1 -0
- data/app/javascript/editor/assets/zondicons/travel-train.svg +1 -0
- data/app/javascript/editor/assets/zondicons/travel-walk.svg +1 -0
- data/app/javascript/editor/assets/zondicons/travel.svg +1 -0
- data/app/javascript/editor/assets/zondicons/trophy.svg +1 -0
- data/app/javascript/editor/assets/zondicons/tuning.svg +1 -0
- data/app/javascript/editor/assets/zondicons/upload.svg +1 -0
- data/app/javascript/editor/assets/zondicons/usb.svg +1 -0
- data/app/javascript/editor/assets/zondicons/user-add.svg +1 -0
- data/app/javascript/editor/assets/zondicons/user-group.svg +1 -0
- data/app/javascript/editor/assets/zondicons/user-solid-circle.svg +1 -0
- data/app/javascript/editor/assets/zondicons/user-solid-square.svg +1 -0
- data/app/javascript/editor/assets/zondicons/user.svg +1 -0
- data/app/javascript/editor/assets/zondicons/vector.svg +1 -0
- data/app/javascript/editor/assets/zondicons/video-camera.svg +1 -0
- data/app/javascript/editor/assets/zondicons/view-carousel.svg +1 -0
- data/app/javascript/editor/assets/zondicons/view-column.svg +1 -0
- data/app/javascript/editor/assets/zondicons/view-hide.svg +1 -0
- data/app/javascript/editor/assets/zondicons/view-list.svg +1 -0
- data/app/javascript/editor/assets/zondicons/view-show.svg +1 -0
- data/app/javascript/editor/assets/zondicons/view-tile.svg +1 -0
- data/app/javascript/editor/assets/zondicons/volume-down.svg +1 -0
- data/app/javascript/editor/assets/zondicons/volume-mute.svg +1 -0
- data/app/javascript/editor/assets/zondicons/volume-off.svg +1 -0
- data/app/javascript/editor/assets/zondicons/volume-up.svg +1 -0
- data/app/javascript/editor/assets/zondicons/wallet.svg +1 -0
- data/app/javascript/editor/assets/zondicons/watch.svg +1 -0
- data/app/javascript/editor/assets/zondicons/window-new.svg +1 -0
- data/app/javascript/editor/assets/zondicons/window-open.svg +1 -0
- data/app/javascript/editor/assets/zondicons/window.svg +1 -0
- data/app/javascript/editor/assets/zondicons/wrench.svg +1 -0
- data/app/javascript/editor/assets/zondicons/yin-yang.svg +1 -0
- data/app/javascript/editor/assets/zondicons/zoom-in.svg +1 -0
- data/app/javascript/editor/assets/zondicons/zoom-out.svg +1 -0
- data/app/javascript/editor/components/dynamic-form/dynamic-input.vue +121 -0
- data/app/javascript/editor/components/dynamic-form/index.vue +34 -0
- data/app/javascript/editor/components/errors/stale-record.vue +24 -0
- data/app/javascript/editor/components/header-nav/device-toggler.vue +37 -0
- data/app/javascript/editor/components/header-nav/index.vue +103 -0
- data/app/javascript/editor/components/header-nav/locale-toggler/index.vue +51 -0
- data/app/javascript/editor/components/header-nav/locale-toggler/locale-link.vue +32 -0
- data/app/javascript/editor/components/header-nav/preview-button.vue +15 -0
- data/app/javascript/editor/components/header-nav/preview-toggler.vue +40 -0
- data/app/javascript/editor/components/header-nav/publish-button.vue +87 -0
- data/app/javascript/editor/components/header-nav/save-button.vue +42 -0
- data/app/javascript/editor/components/header-nav/separator.vue +11 -0
- data/app/javascript/editor/components/icon-library/index.vue +39 -0
- data/app/javascript/editor/components/image-library/index.vue +110 -0
- data/app/javascript/editor/components/image-library/list-item.vue +93 -0
- data/app/javascript/editor/components/image-library/list.vue +26 -0
- data/app/javascript/editor/components/image-library/uploader.vue +78 -0
- data/app/javascript/editor/components/kit/accordion.vue +63 -0
- data/app/javascript/editor/components/kit/checkbox-input.vue +59 -0
- data/app/javascript/editor/components/kit/collection-item-input.vue +64 -0
- data/app/javascript/editor/components/kit/color-picker.vue +81 -0
- data/app/javascript/editor/components/kit/confirmation-button.vue +65 -0
- data/app/javascript/editor/components/kit/dropdown.vue +60 -0
- data/app/javascript/editor/components/kit/icon-input.vue +96 -0
- data/app/javascript/editor/components/kit/icon.vue +35 -0
- data/app/javascript/editor/components/kit/image-input.vue +124 -0
- data/app/javascript/editor/components/kit/index.js +50 -0
- data/app/javascript/editor/components/kit/link-input.vue +117 -0
- data/app/javascript/editor/components/kit/list-item-button.vue +16 -0
- data/app/javascript/editor/components/kit/modal-root.vue +81 -0
- data/app/javascript/editor/components/kit/modal.vue +39 -0
- data/app/javascript/editor/components/kit/page-icon.vue +21 -0
- data/app/javascript/editor/components/kit/pagination/button.vue +35 -0
- data/app/javascript/editor/components/kit/pagination/index.vue +116 -0
- data/app/javascript/editor/components/kit/rich-text-input/block-button.vue +75 -0
- data/app/javascript/editor/components/kit/rich-text-input/extensions/Doc.js +12 -0
- data/app/javascript/editor/components/kit/rich-text-input/extensions/LineBreak.js +38 -0
- data/app/javascript/editor/components/kit/rich-text-input/extensions/marks/Link.js +57 -0
- data/app/javascript/editor/components/kit/rich-text-input/format-buttons.vue +39 -0
- data/app/javascript/editor/components/kit/rich-text-input/link-buttons.vue +91 -0
- data/app/javascript/editor/components/kit/rich-text-input/list-buttons.vue +29 -0
- data/app/javascript/editor/components/kit/rich-text-input/menu-button.vue +22 -0
- data/app/javascript/editor/components/kit/rich-text-input/table-button.vue +106 -0
- data/app/javascript/editor/components/kit/rich-text-input.vue +181 -0
- data/app/javascript/editor/components/kit/search-input.vue +53 -0
- data/app/javascript/editor/components/kit/select-input.vue +188 -0
- data/app/javascript/editor/components/kit/simple-select.vue +44 -0
- data/app/javascript/editor/components/kit/submit-button.vue +117 -0
- data/app/javascript/editor/components/kit/tabs.vue +88 -0
- data/app/javascript/editor/components/kit/text-input.vue +62 -0
- data/app/javascript/editor/components/kit/textarea-input.vue +59 -0
- data/app/javascript/editor/components/link-picker/actions.vue +32 -0
- data/app/javascript/editor/components/link-picker/email.vue +32 -0
- data/app/javascript/editor/components/link-picker/index.vue +97 -0
- data/app/javascript/editor/components/link-picker/page.vue +124 -0
- data/app/javascript/editor/components/link-picker/url.vue +43 -0
- data/app/javascript/editor/components/page/edit.vue +98 -0
- data/app/javascript/editor/components/page/form/main.vue +64 -0
- data/app/javascript/editor/components/page/form/seo.vue +94 -0
- data/app/javascript/editor/components/page/list/index.vue +67 -0
- data/app/javascript/editor/components/page/list/list-item.vue +147 -0
- data/app/javascript/editor/components/page/new.vue +78 -0
- data/app/javascript/editor/components/section-block-pane/index.vue +69 -0
- data/app/javascript/editor/components/section-block-pane/setting-list.vue +49 -0
- data/app/javascript/editor/components/section-highlighter/bottom-actions.vue +60 -0
- data/app/javascript/editor/components/section-highlighter/index.vue +133 -0
- data/app/javascript/editor/components/section-highlighter/top-left-actions.vue +68 -0
- data/app/javascript/editor/components/section-highlighter/top-right-actions.vue +127 -0
- data/app/javascript/editor/components/section-list/index.vue +64 -0
- data/app/javascript/editor/components/section-list/list-item.vue +33 -0
- data/app/javascript/editor/components/section-pane/block-list/index.vue +67 -0
- data/app/javascript/editor/components/section-pane/block-list/list-item.vue +71 -0
- data/app/javascript/editor/components/section-pane/block-list/new-block-button.vue +74 -0
- data/app/javascript/editor/components/section-pane/block-tree/index.vue +63 -0
- data/app/javascript/editor/components/section-pane/block-tree/new-nested-block-button.vue +67 -0
- data/app/javascript/editor/components/section-pane/block-tree/tree-node.vue +109 -0
- data/app/javascript/editor/components/section-pane/index.vue +92 -0
- data/app/javascript/editor/components/section-pane/setting-list.vue +46 -0
- data/app/javascript/editor/components/sidebar-nav.vue +125 -0
- data/app/javascript/editor/components/style-pane/index.vue +44 -0
- data/app/javascript/editor/components/theme-section-list/index.vue +51 -0
- data/app/javascript/editor/components/theme-section-list/list-item.vue +88 -0
- data/app/javascript/editor/design/application.scss +17 -0
- data/app/javascript/editor/design/components/buttons.scss +25 -0
- data/app/javascript/editor/design/components/modal.scss +49 -0
- data/app/javascript/editor/design/components/rich-text-editor.scss +180 -0
- data/app/javascript/editor/design/components/tooltip.scss +117 -0
- data/app/javascript/editor/design/components/tree.scss +6 -0
- data/app/javascript/editor/design/helpers.scss +30 -0
- data/app/javascript/editor/design/transitions.scss +121 -0
- data/app/javascript/editor/layouts/app.vue +30 -0
- data/app/javascript/editor/layouts/default.vue +42 -0
- data/app/javascript/editor/layouts/slide-pane.vue +87 -0
- data/app/javascript/editor/locales/editor.en.json +257 -0
- data/app/javascript/editor/locales/editor.fr.json +244 -0
- data/app/javascript/editor/locales/index.js +11 -0
- data/app/javascript/editor/main.js +19 -0
- data/app/javascript/editor/mixins/error-modal.js +23 -0
- data/app/javascript/editor/mixins/focused-input.js +20 -0
- data/app/javascript/editor/mixins/global.js +125 -0
- data/app/javascript/editor/mixins/grouped-dropdowns.js +17 -0
- data/app/javascript/editor/mixins/index.js +1 -0
- data/app/javascript/editor/mixins/preview-transformation.js +60 -0
- data/app/javascript/editor/plugins/event-bus.js +3 -0
- data/app/javascript/editor/plugins/filters.js +7 -0
- data/app/javascript/editor/plugins/i18n.js +28 -0
- data/app/javascript/editor/plugins/index.js +3 -0
- data/app/javascript/editor/plugins/tooltip.js +4 -0
- data/app/javascript/editor/router/index.js +20 -0
- data/app/javascript/editor/router/routes/base.js +53 -0
- data/app/javascript/editor/router/routes/index.js +3 -0
- data/app/javascript/editor/router/routes/page.js +30 -0
- data/app/javascript/editor/router/routes/section-block.js +29 -0
- data/app/javascript/editor/router/routes/section.js +67 -0
- data/app/javascript/editor/router/routes/style.js +17 -0
- data/app/javascript/editor/services/__tests__/page.spec.js +38 -0
- data/app/javascript/editor/services/__tests__/section.spec.js +32 -0
- data/app/javascript/editor/services/api.js +40 -0
- data/app/javascript/editor/services/block.js +26 -0
- data/app/javascript/editor/services/collection-item.js +12 -0
- data/app/javascript/editor/services/image.js +23 -0
- data/app/javascript/editor/services/index.js +21 -0
- data/app/javascript/editor/services/inline-editing.js +403 -0
- data/app/javascript/editor/services/page.js +107 -0
- data/app/javascript/editor/services/section.js +180 -0
- data/app/javascript/editor/services/site.js +21 -0
- data/app/javascript/editor/services/theme.js +8 -0
- data/app/javascript/editor/spec/__mocks__/page.js +432 -0
- data/app/javascript/editor/spec/__mocks__/section.js +232 -0
- data/app/javascript/editor/spec/__mocks__/services.js +77 -0
- data/app/javascript/editor/spec/__mocks__/site.js +95 -0
- data/app/javascript/editor/spec/__mocks__/theme.js +518 -0
- data/app/javascript/editor/store/__tests__/getters.spec.js +102 -0
- data/app/javascript/editor/store/actions/__tests__/page.spec.js +93 -0
- data/app/javascript/editor/store/actions/__tests__/section-block.spec.js +104 -0
- data/app/javascript/editor/store/actions/__tests__/section.spec.js +61 -0
- data/app/javascript/editor/store/actions/index.js +37 -0
- data/app/javascript/editor/store/actions/page.js +52 -0
- data/app/javascript/editor/store/actions/section-block.js +74 -0
- data/app/javascript/editor/store/actions/section.js +86 -0
- data/app/javascript/editor/store/actions/site.js +32 -0
- data/app/javascript/editor/store/default-state.js +28 -0
- data/app/javascript/editor/store/getters.js +91 -0
- data/app/javascript/editor/store/index.js +28 -0
- data/app/javascript/editor/store/mutations.js +183 -0
- data/app/javascript/editor/utils.js +127 -0
- data/app/javascript/editor/views/content-pane.vue +105 -0
- data/app/javascript/editor/views/page-preview.vue +183 -0
- data/app/javascript/editor/views/pages/edit.vue +26 -0
- data/app/javascript/editor/views/pages/index.vue +65 -0
- data/app/javascript/editor/views/sections/add-pane.vue +23 -0
- data/app/javascript/editor/views/sections/list-pane.vue +20 -0
- data/app/javascript/editor/views/slide-pane.vue +14 -0
- data/app/javascript/editor/views/slide-pane2.vue +14 -0
- data/app/javascript/editor/views/style/edit-pane.vue +22 -0
- data/app/javascript/packs/application.js +8 -0
- data/app/javascript/packs/editor.js +2 -0
- data/app/javascript/style/application/_changes.scss +1 -0
- data/app/javascript/style/application/_variables.scss +0 -0
- data/app/javascript/style/application.scss +5 -0
- data/app/javascript/utils/axios.js +16 -0
- data/app/jobs/maglev/application_job.rb +6 -0
- data/app/mailers/maglev/application_mailer.rb +8 -0
- data/app/models/concerns/maglev/sections_concern.rb +45 -0
- data/app/models/concerns/maglev/translatable.rb +44 -0
- data/app/models/maglev/application_record.rb +7 -0
- data/app/models/maglev/asset.rb +28 -0
- data/app/models/maglev/page/path_concern.rb +70 -0
- data/app/models/maglev/page/search_concern.rb +40 -0
- data/app/models/maglev/page.rb +38 -0
- data/app/models/maglev/page_path.rb +46 -0
- data/app/models/maglev/section/block.rb +41 -0
- data/app/models/maglev/section/content_concern.rb +83 -0
- data/app/models/maglev/section/setting.rb +53 -0
- data/app/models/maglev/section.rb +85 -0
- data/app/models/maglev/site/locale.rb +19 -0
- data/app/models/maglev/site/locales_concern.rb +37 -0
- data/app/models/maglev/site/style_value.rb +43 -0
- data/app/models/maglev/site.rb +25 -0
- data/app/models/maglev/static_page.rb +40 -0
- data/app/models/maglev/theme/section_category.rb +23 -0
- data/app/models/maglev/theme/style_setting.rb +43 -0
- data/app/models/maglev/theme.rb +16 -0
- data/app/services/concerns/maglev/get_page_sections/transform_collection_item_concern.rb +18 -0
- data/app/services/concerns/maglev/get_page_sections/transform_link_concern.rb +35 -0
- data/app/services/concerns/maglev/get_page_sections/transform_text_concern.rb +38 -0
- data/app/services/maglev/app_container.rb +48 -0
- data/app/services/maglev/change_site_locales.rb +37 -0
- data/app/services/maglev/clone_page.rb +62 -0
- data/app/services/maglev/extract_locale.rb +36 -0
- data/app/services/maglev/fetch_collection_items.rb +97 -0
- data/app/services/maglev/fetch_page.rb +26 -0
- data/app/services/maglev/fetch_section_screenshot_path.rb +17 -0
- data/app/services/maglev/fetch_section_screenshot_url.rb +14 -0
- data/app/services/maglev/fetch_sections_path.rb +13 -0
- data/app/services/maglev/fetch_site.rb +20 -0
- data/app/services/maglev/fetch_static_pages.rb +56 -0
- data/app/services/maglev/fetch_style.rb +38 -0
- data/app/services/maglev/fetch_theme.rb +12 -0
- data/app/services/maglev/fetch_theme_layout.rb +14 -0
- data/app/services/maglev/generate_site.rb +26 -0
- data/app/services/maglev/get_base_url.rb +32 -0
- data/app/services/maglev/get_page_fullpath.rb +65 -0
- data/app/services/maglev/get_page_section_names.rb +25 -0
- data/app/services/maglev/get_page_sections.rb +103 -0
- data/app/services/maglev/persist_page.rb +74 -0
- data/app/services/maglev/persist_section_screenshot.rb +58 -0
- data/app/services/maglev/search_pages.rb +60 -0
- data/app/services/maglev/setup_pages.rb +45 -0
- data/app/validators/maglev/collection_validator.rb +24 -0
- data/app/validators/maglev/presence_validator.rb +16 -0
- data/app/views/layouts/maglev/admin/_header_actions.html.erb +5 -0
- data/app/views/layouts/maglev/admin/application.html.erb +25 -0
- data/app/views/maglev/admin/sections/previews/show.html.erb +32 -0
- data/app/views/maglev/admin/themes/_empty.html.erb +20 -0
- data/app/views/maglev/admin/themes/_section_categories.html.erb +9 -0
- data/app/views/maglev/admin/themes/_sections.html.erb +54 -0
- data/app/views/maglev/admin/themes/show.html.erb +21 -0
- data/app/views/maglev/api/_pagination.json.jbuilder +6 -0
- data/app/views/maglev/api/assets/_show.json.jbuilder +8 -0
- data/app/views/maglev/api/assets/index.json.jbuilder +9 -0
- data/app/views/maglev/api/assets/show.json.jbuilder +3 -0
- data/app/views/maglev/api/collection_items/_show.json.jbuilder +5 -0
- data/app/views/maglev/api/collection_items/index.json.jbuilder +5 -0
- data/app/views/maglev/api/pages/index.json.jbuilder +18 -0
- data/app/views/maglev/api/pages/show.json.jbuilder +24 -0
- data/app/views/maglev/api/sites/_show.json.jbuilder +15 -0
- data/app/views/maglev/api/sites/show.json.jbuilder +3 -0
- data/app/views/maglev/api/themes/_show.json.jbuilder +17 -0
- data/app/views/maglev/editor/_header.html.erb +1 -0
- data/app/views/maglev/editor/show.html.erb +39 -0
- data/config/initializers/assets.rb +24 -0
- data/config/initializers/filter_parameters_logging.rb +6 -0
- data/config/initializers/kaminari.rb +16 -0
- data/config/locales/activerecord.en.yml +7 -0
- data/config/locales/activerecord.fr.yml +26 -0
- data/config/routes.rb +46 -0
- data/config/webpack/development.js +5 -0
- data/config/webpack/environment.js +38 -0
- data/config/webpack/loaders/optional_chaining.js +10 -0
- data/config/webpack/loaders/vue.js +6 -0
- data/config/webpack/production.js +5 -0
- data/config/webpack/test.js +5 -0
- data/config/webpacker.yml +95 -0
- data/db/migrate/20200824085207_create_maglev_sites.rb +8 -0
- data/db/migrate/20200824104648_create_maglev_pages.rb +17 -0
- data/db/migrate/20200831101942_create_maglev_section_content.rb +11 -0
- data/db/migrate/20201206172020_create_maglev_assets.rb +13 -0
- data/db/migrate/20210819092740_switch_to_localized_page_fields.rb +17 -0
- data/db/migrate/20210830085101_create_maglev_page_paths.rb +13 -0
- data/db/migrate/20210906102712_add_canonical_to_pages.rb +6 -0
- data/db/migrate/20211008064437_add_locales_to_sites.rb +5 -0
- data/db/migrate/20211013210954_translate_section_content.rb +8 -0
- data/db/migrate/20211101205001_add_lock_version_to_maglev_pages.rb +6 -0
- data/db/migrate/20211116161121_better_page_path_canonical_indices.rb +8 -0
- data/db/migrate/20211124101005_fix_page_path_indices.rb +6 -0
- data/db/migrate/20211203224112_add_open_graph_tags_to_pages.rb +9 -0
- data/db/migrate/20220612092235_add_style_to_sites.rb +7 -0
- data/lib/generators/maglev/install_generator.rb +50 -0
- data/lib/generators/maglev/section_generator.rb +128 -0
- data/lib/generators/maglev/templates/install/config/initializers/maglev.rb +77 -0
- data/lib/generators/maglev/templates/install/public/theme/image-placeholder.jpg +0 -0
- data/lib/generators/maglev/templates/section/app/theme/sections/%category%/%file_name%.yml.tt +102 -0
- data/lib/generators/maglev/templates/section/app/views/theme/sections/%category%/%file_name%.html.erb.tt +55 -0
- data/lib/generators/maglev/templates/theme/app/theme/theme.yml.tt +22 -0
- data/lib/generators/maglev/templates/theme/app/views/theme/layout.html.erb.tt +21 -0
- data/lib/generators/maglev/theme_generator.rb +12 -0
- data/lib/maglev/active_storage.rb +36 -0
- data/lib/maglev/config.rb +9 -0
- data/lib/maglev/engine.rb +65 -0
- data/lib/maglev/errors.rb +8 -0
- data/lib/maglev/i18n.rb +46 -0
- data/lib/maglev/preview_constraint.rb +25 -0
- data/lib/maglev/theme_filesystem_loader.rb +55 -0
- data/lib/maglev/version.rb +5 -0
- data/lib/maglev.rb +70 -0
- data/lib/maglevcms.rb +4 -0
- data/lib/tasks/maglev_tasks.rake +108 -0
- metadata +827 -0
@@ -0,0 +1,68 @@
|
|
1
|
+
<template>
|
2
|
+
<div class="absolute top-0 left-0 mt-2 ml-2 flex">
|
3
|
+
<div
|
4
|
+
class="bg-editor-primary text-white py-1 px-3 rounded-l-2xl text-xs flex items-center"
|
5
|
+
:class="{ 'rounded-r-2xl': !displayMoveArrows }"
|
6
|
+
>
|
7
|
+
<span>{{ hoveredSection.name }}</span>
|
8
|
+
</div>
|
9
|
+
<button
|
10
|
+
type="button"
|
11
|
+
class="button"
|
12
|
+
@click="moveHoveredSection('up')"
|
13
|
+
v-if="displayMoveArrows"
|
14
|
+
>
|
15
|
+
<icon name="arrow-up-s-line" />
|
16
|
+
</button>
|
17
|
+
<button
|
18
|
+
type="button"
|
19
|
+
class="button button-last"
|
20
|
+
@click="moveHoveredSection('down')"
|
21
|
+
v-if="displayMoveArrows"
|
22
|
+
>
|
23
|
+
<icon name="arrow-down-s-line" />
|
24
|
+
</button>
|
25
|
+
</div>
|
26
|
+
</template>
|
27
|
+
|
28
|
+
<script>
|
29
|
+
import { mapActions } from 'vuex'
|
30
|
+
|
31
|
+
export default {
|
32
|
+
name: 'SectionHighlighterTopLeftActions',
|
33
|
+
props: {
|
34
|
+
hoveredSection: { type: Object },
|
35
|
+
},
|
36
|
+
computed: {
|
37
|
+
displayMoveArrows() {
|
38
|
+
return !this.currentSection && !this.hoveredSection.definition.insertAt
|
39
|
+
},
|
40
|
+
},
|
41
|
+
methods: {
|
42
|
+
...mapActions(['moveHoveredSection']),
|
43
|
+
},
|
44
|
+
}
|
45
|
+
</script>
|
46
|
+
|
47
|
+
<style scoped>
|
48
|
+
.button {
|
49
|
+
@apply bg-editor-primary
|
50
|
+
py-1
|
51
|
+
px-1
|
52
|
+
pointer-events-auto
|
53
|
+
border-solid
|
54
|
+
border-white
|
55
|
+
border-opacity-25
|
56
|
+
border-0
|
57
|
+
border-l
|
58
|
+
text-white text-opacity-75;
|
59
|
+
}
|
60
|
+
|
61
|
+
.button.button-last {
|
62
|
+
@apply pr-2 rounded-r-2xl;
|
63
|
+
}
|
64
|
+
|
65
|
+
.button:hover {
|
66
|
+
@apply hover:text-opacity-100;
|
67
|
+
}
|
68
|
+
</style>
|
@@ -0,0 +1,127 @@
|
|
1
|
+
<template>
|
2
|
+
<div class="absolute top-0 right-0 mt-2 mr-2 flex">
|
3
|
+
<router-link
|
4
|
+
:to="{
|
5
|
+
name: 'editSection',
|
6
|
+
params: { sectionId: hoveredSection.sectionId },
|
7
|
+
}"
|
8
|
+
custom
|
9
|
+
v-slot="{ navigate }"
|
10
|
+
v-if="hasSettings"
|
11
|
+
>
|
12
|
+
<button
|
13
|
+
type="button"
|
14
|
+
@click="navigate"
|
15
|
+
@keypress.enter="navigate"
|
16
|
+
class="ml-2 button"
|
17
|
+
>
|
18
|
+
<icon name="ri-pencil-line" />
|
19
|
+
</button>
|
20
|
+
</router-link>
|
21
|
+
|
22
|
+
<router-link
|
23
|
+
:to="{
|
24
|
+
name: 'editSection',
|
25
|
+
params: { sectionId: hoveredSection.sectionId },
|
26
|
+
hash: '#blocks',
|
27
|
+
}"
|
28
|
+
custom
|
29
|
+
v-slot="{ navigate }"
|
30
|
+
v-if="hasBlocks"
|
31
|
+
>
|
32
|
+
<button
|
33
|
+
type="button"
|
34
|
+
@click="navigate"
|
35
|
+
@keypress.enter="navigate"
|
36
|
+
class="ml-2 button"
|
37
|
+
>
|
38
|
+
<icon name="ri-play-list-add-line" />
|
39
|
+
</button>
|
40
|
+
</router-link>
|
41
|
+
|
42
|
+
<router-link
|
43
|
+
:to="{
|
44
|
+
name: 'editSection',
|
45
|
+
params: { sectionId: hoveredSection.sectionId },
|
46
|
+
hash: '#advanced',
|
47
|
+
}"
|
48
|
+
custom
|
49
|
+
v-slot="{ navigate }"
|
50
|
+
v-if="hasAdvancedSettings"
|
51
|
+
>
|
52
|
+
<button
|
53
|
+
type="button"
|
54
|
+
@click="navigate"
|
55
|
+
@keypress.enter="navigate"
|
56
|
+
class="ml-2 button"
|
57
|
+
>
|
58
|
+
<icon name="ri-settings-5-line" />
|
59
|
+
</button>
|
60
|
+
</router-link>
|
61
|
+
|
62
|
+
<confirmation-button class="ml-2 pointer-events-auto" @confirm="remove">
|
63
|
+
<div class="button">
|
64
|
+
<icon name="delete-bin-line" />
|
65
|
+
</div>
|
66
|
+
</confirmation-button>
|
67
|
+
</div>
|
68
|
+
</template>
|
69
|
+
|
70
|
+
<script>
|
71
|
+
import { mapActions } from 'vuex'
|
72
|
+
|
73
|
+
export default {
|
74
|
+
name: 'SectionHighlighterTopRightActions',
|
75
|
+
props: {
|
76
|
+
hoveredSection: { type: Object },
|
77
|
+
},
|
78
|
+
computed: {
|
79
|
+
hasSettings() {
|
80
|
+
const { definition } = this.hoveredSection
|
81
|
+
return !this.isBlank(this.services.section.getSettings(definition, false))
|
82
|
+
},
|
83
|
+
hasAdvancedSettings() {
|
84
|
+
const { definition } = this.hoveredSection
|
85
|
+
return !this.isBlank(this.services.section.getSettings(definition, true))
|
86
|
+
},
|
87
|
+
hasBlocks() {
|
88
|
+
const {
|
89
|
+
definition: { blocks },
|
90
|
+
} = this.hoveredSection
|
91
|
+
return !this.isBlank(blocks)
|
92
|
+
},
|
93
|
+
},
|
94
|
+
methods: {
|
95
|
+
...mapActions(['removeSection', 'leaveSection']),
|
96
|
+
remove() {
|
97
|
+
const sectionId = this.hoveredSection.sectionId
|
98
|
+
this.leaveSection()
|
99
|
+
if (
|
100
|
+
this.currentSection &&
|
101
|
+
this.currentSection.id === this.hoveredSection.sectionId
|
102
|
+
)
|
103
|
+
this.$router.push({ name: 'editPage' })
|
104
|
+
// waiting for the animation to finish
|
105
|
+
setTimeout(() => this.removeSection(sectionId), 200)
|
106
|
+
},
|
107
|
+
},
|
108
|
+
}
|
109
|
+
</script>
|
110
|
+
|
111
|
+
<style scoped>
|
112
|
+
.button {
|
113
|
+
@apply bg-white
|
114
|
+
rounded-full
|
115
|
+
shadow-xl
|
116
|
+
h-8
|
117
|
+
w-8
|
118
|
+
flex
|
119
|
+
items-center
|
120
|
+
justify-center
|
121
|
+
text-gray-700
|
122
|
+
pointer-events-auto;
|
123
|
+
}
|
124
|
+
.button:hover {
|
125
|
+
@apply hover:text-black;
|
126
|
+
}
|
127
|
+
</style>
|
@@ -0,0 +1,64 @@
|
|
1
|
+
<template>
|
2
|
+
<div>
|
3
|
+
<div v-if="isListEmpty" class="text-center mt-8">
|
4
|
+
<span class="text-gray-800">{{ $t('sections.listPane.empty') }}</span>
|
5
|
+
</div>
|
6
|
+
<draggable :list="list" @end="onSortEnd" v-bind="dragOptions" v-else>
|
7
|
+
<transition-group type="transition" name="flip-list">
|
8
|
+
<list-item
|
9
|
+
v-for="(section, index) in list"
|
10
|
+
:key="section.id"
|
11
|
+
:section="section"
|
12
|
+
:index="index"
|
13
|
+
@on-dropdown-toggle="onDropdownToggle"
|
14
|
+
class="mb-3"
|
15
|
+
/>
|
16
|
+
</transition-group>
|
17
|
+
</draggable>
|
18
|
+
</div>
|
19
|
+
</template>
|
20
|
+
|
21
|
+
<script>
|
22
|
+
import { mapActions } from 'vuex'
|
23
|
+
import draggable from 'vuedraggable'
|
24
|
+
import GroupedDropdownsMixin from '@/mixins/grouped-dropdowns'
|
25
|
+
import ListItem from './list-item'
|
26
|
+
|
27
|
+
export default {
|
28
|
+
name: 'SectionList',
|
29
|
+
mixins: [GroupedDropdownsMixin],
|
30
|
+
components: { draggable, ListItem },
|
31
|
+
computed: {
|
32
|
+
list() {
|
33
|
+
return this.currentSectionList
|
34
|
+
},
|
35
|
+
isListEmpty() {
|
36
|
+
return this.currentSectionList.length === 0
|
37
|
+
},
|
38
|
+
dragOptions() {
|
39
|
+
return {
|
40
|
+
animation: 0,
|
41
|
+
group: 'description',
|
42
|
+
disabled: false,
|
43
|
+
ghostClass: 'ghost',
|
44
|
+
}
|
45
|
+
},
|
46
|
+
},
|
47
|
+
methods: {
|
48
|
+
...mapActions(['moveSection']),
|
49
|
+
onSortEnd(event) {
|
50
|
+
this.moveSection({
|
51
|
+
from: event.oldIndex,
|
52
|
+
to: event.newIndex,
|
53
|
+
})
|
54
|
+
},
|
55
|
+
},
|
56
|
+
}
|
57
|
+
</script>
|
58
|
+
|
59
|
+
<style scope>
|
60
|
+
.flip-list-move {
|
61
|
+
@apply transition-transform;
|
62
|
+
@apply duration-300;
|
63
|
+
}
|
64
|
+
</style>
|
@@ -0,0 +1,33 @@
|
|
1
|
+
<template>
|
2
|
+
<div
|
3
|
+
class="bg-gray-100 rounded-md px-4 py-3 flex items-center justify-between text-gray-800 cursor-move"
|
4
|
+
>
|
5
|
+
<router-link
|
6
|
+
:to="{ name: 'editSection', params: { sectionId: section.id } }"
|
7
|
+
class="flex items-center"
|
8
|
+
>
|
9
|
+
<span>{{ section.name | truncate(40) }}</span>
|
10
|
+
</router-link>
|
11
|
+
<confirmation-button @confirm="removeSection(section.id)" v-on="$listeners">
|
12
|
+
<button
|
13
|
+
class="px-1 py-1 rounded-full bg-gray-600 bg-opacity-0 hover:text-gray-900 text-gray-600 focus:outline-none hover:bg-opacity-10 transition-colors duration-200"
|
14
|
+
>
|
15
|
+
<icon name="ri-close-line" size="1.25rem" />
|
16
|
+
</button>
|
17
|
+
</confirmation-button>
|
18
|
+
</div>
|
19
|
+
</template>
|
20
|
+
|
21
|
+
<script>
|
22
|
+
import { mapActions } from 'vuex'
|
23
|
+
|
24
|
+
export default {
|
25
|
+
name: 'SectionListItem',
|
26
|
+
props: {
|
27
|
+
section: { type: Object, required: true },
|
28
|
+
},
|
29
|
+
methods: {
|
30
|
+
...mapActions(['removeSection']),
|
31
|
+
},
|
32
|
+
}
|
33
|
+
</script>
|
@@ -0,0 +1,67 @@
|
|
1
|
+
<template>
|
2
|
+
<div class="flex flex-col h-full">
|
3
|
+
<div class="relative flex-auto h-0 overflow-y-auto pt-2">
|
4
|
+
<draggable v-model="list" v-bind="dragOptions">
|
5
|
+
<transition-group type="transition" name="flip-list">
|
6
|
+
<list-item
|
7
|
+
v-for="(sectionBlock, index) in currentSectionBlocks"
|
8
|
+
:key="sectionBlock.id"
|
9
|
+
:sectionBlock="sectionBlock"
|
10
|
+
:index="index"
|
11
|
+
@on-dropdown-toggle="onDropdownToggle"
|
12
|
+
class="mb-4"
|
13
|
+
/>
|
14
|
+
</transition-group>
|
15
|
+
</draggable>
|
16
|
+
</div>
|
17
|
+
|
18
|
+
<div class="mt-auto relative">
|
19
|
+
<new-block-button @on-dropdown-toggle="onDropdownToggle" />
|
20
|
+
</div>
|
21
|
+
</div>
|
22
|
+
</template>
|
23
|
+
|
24
|
+
<script>
|
25
|
+
import { mapActions } from 'vuex'
|
26
|
+
import draggable from 'vuedraggable'
|
27
|
+
import GroupedDropdownsMixin from '@/mixins/grouped-dropdowns'
|
28
|
+
import ListItem from './list-item'
|
29
|
+
import NewBlockButton from './new-block-button'
|
30
|
+
|
31
|
+
export default {
|
32
|
+
name: 'SectionBlockList',
|
33
|
+
mixins: [GroupedDropdownsMixin],
|
34
|
+
components: { draggable, ListItem, NewBlockButton },
|
35
|
+
computed: {
|
36
|
+
list: {
|
37
|
+
get() {
|
38
|
+
return this.currentSectionBlocks
|
39
|
+
},
|
40
|
+
set(value) {
|
41
|
+
this.sortSectionBlocks(value)
|
42
|
+
},
|
43
|
+
},
|
44
|
+
dragOptions() {
|
45
|
+
return {
|
46
|
+
animation: 0,
|
47
|
+
group: 'description',
|
48
|
+
disabled: false,
|
49
|
+
ghostClass: 'ghost',
|
50
|
+
}
|
51
|
+
},
|
52
|
+
},
|
53
|
+
methods: {
|
54
|
+
...mapActions(['sortSectionBlocks']),
|
55
|
+
},
|
56
|
+
}
|
57
|
+
</script>
|
58
|
+
|
59
|
+
<style scoped>
|
60
|
+
.flip-list-move {
|
61
|
+
@apply transition-transform;
|
62
|
+
@apply duration-300;
|
63
|
+
}
|
64
|
+
.ghost {
|
65
|
+
@apply opacity-50;
|
66
|
+
}
|
67
|
+
</style>
|
@@ -0,0 +1,71 @@
|
|
1
|
+
<template>
|
2
|
+
<div
|
3
|
+
class="bg-gray-100 rounded-md px-4 py-3 flex items-center justify-between text-gray-800"
|
4
|
+
:class="{ 'cursor-move': isList }"
|
5
|
+
>
|
6
|
+
<router-link
|
7
|
+
:to="{
|
8
|
+
name: 'editSectionBlock',
|
9
|
+
params: { sectionBlockId: sectionBlock.id },
|
10
|
+
}"
|
11
|
+
class="flex items-center"
|
12
|
+
>
|
13
|
+
<div class="h-8 w-8 bg-gray-400 mr-3" v-if="image">
|
14
|
+
<img
|
15
|
+
:src="image"
|
16
|
+
class="object-cover w-full h-full"
|
17
|
+
:class="{ hidden: !imageLoaded }"
|
18
|
+
@load="() => (imageLoaded = true)"
|
19
|
+
/>
|
20
|
+
</div>
|
21
|
+
<span>{{ label | truncate(40) }}</span>
|
22
|
+
</router-link>
|
23
|
+
<div class="flex items-center">
|
24
|
+
<slot name="actions"></slot>
|
25
|
+
<confirmation-button
|
26
|
+
@confirm="removeSectionBlock(sectionBlock.id)"
|
27
|
+
v-on="$listeners"
|
28
|
+
>
|
29
|
+
<list-item-button iconName="ri-close-line" />
|
30
|
+
</confirmation-button>
|
31
|
+
</div>
|
32
|
+
</div>
|
33
|
+
</template>
|
34
|
+
|
35
|
+
<script>
|
36
|
+
import { mapActions } from 'vuex'
|
37
|
+
|
38
|
+
export default {
|
39
|
+
name: 'SectionBlockListItem',
|
40
|
+
props: {
|
41
|
+
sectionBlock: { type: Object, required: true },
|
42
|
+
index: { type: Number, required: true },
|
43
|
+
},
|
44
|
+
data() {
|
45
|
+
return {
|
46
|
+
imageLoaded: false,
|
47
|
+
}
|
48
|
+
},
|
49
|
+
computed: {
|
50
|
+
isList() {
|
51
|
+
return this.currentSectionDefinition.blocksPresentation !== 'tree'
|
52
|
+
},
|
53
|
+
presentation() {
|
54
|
+
const label = this.$store.getters.sectionBlockLabel(
|
55
|
+
this.sectionBlock,
|
56
|
+
this.index + 1,
|
57
|
+
)
|
58
|
+
return { label: label[0], image: label[1] }
|
59
|
+
},
|
60
|
+
label() {
|
61
|
+
return this.presentation.label
|
62
|
+
},
|
63
|
+
image() {
|
64
|
+
return this.presentation.image
|
65
|
+
},
|
66
|
+
},
|
67
|
+
methods: {
|
68
|
+
...mapActions(['removeSectionBlock']),
|
69
|
+
},
|
70
|
+
}
|
71
|
+
</script>
|
@@ -0,0 +1,74 @@
|
|
1
|
+
<template>
|
2
|
+
<div v-if="hasTypes" class="w-full button-wrapper">
|
3
|
+
<dropdown
|
4
|
+
ref="dropdown"
|
5
|
+
placement="top"
|
6
|
+
v-on="$listeners"
|
7
|
+
v-if="hasMultipleTypes"
|
8
|
+
>
|
9
|
+
<template v-slot:button>
|
10
|
+
<button class="big-submit-button bg-editor-primary">
|
11
|
+
<icon name="ri-add-line" size="1.5rem" />
|
12
|
+
<span class="ml-3">{{ $t('sectionPane.blockList.add') }}</span>
|
13
|
+
</button>
|
14
|
+
</template>
|
15
|
+
<template v-slot:content>
|
16
|
+
<div class="w-full flex flex-col">
|
17
|
+
<button
|
18
|
+
v-for="blockType in blockTypes"
|
19
|
+
:key="blockType.type"
|
20
|
+
class="mb-2 text-base text-gray-900 py-2 px-14 hover:bg-gray-100 transition-colors"
|
21
|
+
@click="addSectionBlockAndClose(blockType.type)"
|
22
|
+
>
|
23
|
+
{{ blockType.name }}
|
24
|
+
</button>
|
25
|
+
</div>
|
26
|
+
</template>
|
27
|
+
</dropdown>
|
28
|
+
<button
|
29
|
+
class="big-submit-button bg-editor-primary"
|
30
|
+
@click="addSectionBlock"
|
31
|
+
v-else
|
32
|
+
>
|
33
|
+
<icon name="ri-add-line" size="1.5rem" />
|
34
|
+
<span class="ml-3">{{ $t('sectionPane.blockList.add') }}</span>
|
35
|
+
</button>
|
36
|
+
</div>
|
37
|
+
</template>
|
38
|
+
|
39
|
+
<script>
|
40
|
+
import { mapActions } from 'vuex'
|
41
|
+
|
42
|
+
export default {
|
43
|
+
name: 'NewSectionBlockButton',
|
44
|
+
computed: {
|
45
|
+
hasTypes() {
|
46
|
+
return this.blockTypes.length > 0
|
47
|
+
},
|
48
|
+
hasMultipleTypes() {
|
49
|
+
return this.blockTypes.length > 1
|
50
|
+
},
|
51
|
+
blockTypes() {
|
52
|
+
if (this.currentSectionDefinition.blocksPresentation === 'tree')
|
53
|
+
return this.services.block.filterRoot(
|
54
|
+
this.currentSectionDefinition.blocks,
|
55
|
+
this.currentSectionBlocks,
|
56
|
+
)
|
57
|
+
else return this.currentSectionDefinition.blocks
|
58
|
+
},
|
59
|
+
},
|
60
|
+
methods: {
|
61
|
+
...mapActions(['addSectionBlock']),
|
62
|
+
addSectionBlockAndClose(blockType) {
|
63
|
+
this.addSectionBlock({ blockType })
|
64
|
+
this.$refs.dropdown.close()
|
65
|
+
},
|
66
|
+
},
|
67
|
+
}
|
68
|
+
</script>
|
69
|
+
|
70
|
+
<style scoped>
|
71
|
+
.button-wrapper >>> .trigger {
|
72
|
+
@apply w-full;
|
73
|
+
}
|
74
|
+
</style>
|
@@ -0,0 +1,63 @@
|
|
1
|
+
<template>
|
2
|
+
<div class="flex flex-col h-full">
|
3
|
+
<div class="relative flex-auto h-0 overflow-y-auto">
|
4
|
+
<transition-group type="transition" name="flip-list">
|
5
|
+
<tree-node
|
6
|
+
v-for="(treeNode, index) in treeData"
|
7
|
+
:key="treeNode.sectionBlock.id"
|
8
|
+
:treeNode="treeNode"
|
9
|
+
:siblings="treeData"
|
10
|
+
:depth="0"
|
11
|
+
:index="index"
|
12
|
+
:last="index === treeData.length - 1"
|
13
|
+
@on-dropdown-toggle="onDropdownToggle"
|
14
|
+
@change="change"
|
15
|
+
class="mb-3"
|
16
|
+
/>
|
17
|
+
</transition-group>
|
18
|
+
</div>
|
19
|
+
<div class="mt-auto relative">
|
20
|
+
<new-block-button @on-dropdown-toggle="onDropdownToggle" />
|
21
|
+
</div>
|
22
|
+
</div>
|
23
|
+
</template>
|
24
|
+
|
25
|
+
<script>
|
26
|
+
import { mapActions } from 'vuex'
|
27
|
+
import GroupedDropdownsMixin from '@/mixins/grouped-dropdowns'
|
28
|
+
import TreeNode from './tree-node'
|
29
|
+
import NewBlockButton from '../block-list/new-block-button'
|
30
|
+
|
31
|
+
export default {
|
32
|
+
name: 'SectionBlockTree',
|
33
|
+
mixins: [GroupedDropdownsMixin],
|
34
|
+
components: { TreeNode, NewBlockButton },
|
35
|
+
data() {
|
36
|
+
return { treeData: null }
|
37
|
+
},
|
38
|
+
methods: {
|
39
|
+
...mapActions(['sortSectionBlocks']),
|
40
|
+
change() {
|
41
|
+
const list = this.services.block.decodeTree(this.treeData)
|
42
|
+
this.sortSectionBlocks(list)
|
43
|
+
},
|
44
|
+
},
|
45
|
+
watch: {
|
46
|
+
currentSectionBlocks: {
|
47
|
+
immediate: true,
|
48
|
+
handler() {
|
49
|
+
this.treeData = this.services.block.encodeToTree(
|
50
|
+
this.currentSectionBlocks,
|
51
|
+
)
|
52
|
+
},
|
53
|
+
},
|
54
|
+
},
|
55
|
+
}
|
56
|
+
</script>
|
57
|
+
|
58
|
+
<style scoped>
|
59
|
+
.flip-list-move {
|
60
|
+
@apply transition-transform;
|
61
|
+
@apply duration-300;
|
62
|
+
}
|
63
|
+
</style>
|
@@ -0,0 +1,67 @@
|
|
1
|
+
<template>
|
2
|
+
<div class="w-full">
|
3
|
+
<dropdown
|
4
|
+
placement="left"
|
5
|
+
ref="dropdown"
|
6
|
+
:fullWidth="true"
|
7
|
+
v-on="$listeners"
|
8
|
+
v-if="hasMultipleTypes"
|
9
|
+
>
|
10
|
+
<template v-slot:button>
|
11
|
+
<list-item-button iconName="ri-add-line" />
|
12
|
+
</template>
|
13
|
+
<template v-slot:content>
|
14
|
+
<div class="w-full flex flex-col">
|
15
|
+
<button
|
16
|
+
v-for="blockType in blockTypes"
|
17
|
+
:key="blockType.type"
|
18
|
+
class="mb-2 text-base text-gray-900 py-2 px-4 hover:bg-gray-100 transition-colors"
|
19
|
+
@click="addNestedSectionBlockAndClose(blockType.type)"
|
20
|
+
>
|
21
|
+
{{ blockType.name }}
|
22
|
+
</button>
|
23
|
+
</div>
|
24
|
+
</template>
|
25
|
+
</dropdown>
|
26
|
+
<list-item-button
|
27
|
+
iconName="ri-add-line"
|
28
|
+
@click.native="addNestedSectionBlock"
|
29
|
+
v-else
|
30
|
+
/>
|
31
|
+
</div>
|
32
|
+
</template>
|
33
|
+
|
34
|
+
<script>
|
35
|
+
import { mapActions } from 'vuex'
|
36
|
+
|
37
|
+
export default {
|
38
|
+
name: 'NewNestedSectionBlockButton',
|
39
|
+
props: {
|
40
|
+
parentId: { type: String, required: true },
|
41
|
+
accept: { type: Array, required: true },
|
42
|
+
},
|
43
|
+
computed: {
|
44
|
+
hasMultipleTypes() {
|
45
|
+
return this.blockTypes.length > 1
|
46
|
+
},
|
47
|
+
blockTypes() {
|
48
|
+
return this.currentSectionDefinition.blocks.filter(
|
49
|
+
(block) => this.accept.indexOf(block.type) !== -1,
|
50
|
+
)
|
51
|
+
},
|
52
|
+
},
|
53
|
+
methods: {
|
54
|
+
...mapActions(['addSectionBlock']),
|
55
|
+
addNestedSectionBlock() {
|
56
|
+
this.addSectionBlock({
|
57
|
+
blockType: this.blockTypes[0].type,
|
58
|
+
parentId: this.parentId,
|
59
|
+
})
|
60
|
+
},
|
61
|
+
addNestedSectionBlockAndClose(blockType) {
|
62
|
+
this.addSectionBlock({ blockType, parentId: this.parentId })
|
63
|
+
this.$refs.dropdown.close()
|
64
|
+
},
|
65
|
+
},
|
66
|
+
}
|
67
|
+
</script>
|