import { inputView, cssModulesUtils, ConfigurationEditorTabView, SelectInputView, SliderInputView, SortableCollectionView, CollectionView as CollectionView$1, CheckBoxInputView, TextInputView, Object as Object$1, TextAreaInputView, SeparatorView, ConfigurationEditorView } from 'pageflow/ui'; import React, { useCallback } from 'react'; import classNames from 'classnames'; import Backbone$1 from 'backbone'; import ReactDOM from 'react-dom'; import { Listbox } from '@headlessui/react'; import Marionette from 'backbone.marionette'; import I18n, { t } from 'i18n-js'; import { createContext } from 'use-context-selector'; import { createSelectorCreator, defaultMemoize } from 'reselect'; import 'slugify'; import { StandaloneSectionThumbnail, getAvailableTransitionNames, utils } from 'pageflow-scrolled/frontend'; import * as globalInterop from 'pageflow/editor'; import { editor as editor$1, Configuration, configurationContainer, delayedDestroying, entryTypeEditorControllerUrls, failureTracking, ForeignKeySubsetCollection, orderedCollection, Entry, modelLifecycleTrackingView, DropDownButtonView, CollectionView, app, EditConfigurationView, cssModulesUtils as cssModulesUtils$1, FileInputView, ColorInputView } from 'pageflow/editor'; import { features, browser } from 'pageflow/frontend'; import $ from 'jquery'; import { editor as editor$2 } from 'pageflow-scrolled/editor'; import 'jquery-ui'; function _arrayWithHoles(arr) { if (Array.isArray(arr)) return arr; } function _iterableToArrayLimit(arr, i) { if (typeof Symbol === "undefined" || !(Symbol.iterator in Object(arr))) return; var _arr = []; var _n = true; var _d = false; var _e = undefined; try { for (var _i = arr[Symbol.iterator](), _s; !(_n = (_s = _i.next()).done); _n = true) { _arr.push(_s.value); if (i && _arr.length === i) break; } } catch (err) { _d = true; _e = err; } finally { try { if (!_n && _i["return"] != null) _i["return"](); } finally { if (_d) throw _e; } } return _arr; } function _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) { arr2[i] = arr[i]; } return arr2; } function _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === "string") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === "Object" && o.constructor) n = o.constructor.name; if (n === "Map" || n === "Set") return Array.from(n); if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); } function _nonIterableRest() { throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); } function _slicedToArray(arr, i) { return _arrayWithHoles(arr) || _iterableToArrayLimit(arr, i) || _unsupportedIterableToArray(arr, i) || _nonIterableRest(); } function _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; } function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); keys.push.apply(keys, symbols); } return keys; } function _objectSpread2(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(Object(source), true).forEach(function (key) { _defineProperty(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; } function styleInject(css, ref) { if ( ref === void 0 ) ref = {}; var insertAt = ref.insertAt; if (!css || typeof document === 'undefined') { return; } var head = document.head || document.getElementsByTagName('head')[0]; var style = document.createElement('style'); style.type = 'text/css'; if (insertAt === 'top') { if (head.firstChild) { head.insertBefore(style, head.firstChild); } else { head.appendChild(style); } } else { head.appendChild(style); } if (style.styleSheet) { style.styleSheet.cssText = css; } else { style.appendChild(document.createTextNode(css)); } } var css = ".TypographyVariantSelectInputView-module_preview__12fCl {\n overflow: hidden;\n position: relative;\n padding: 0.25rem 0.5rem 0.5rem;\n background-color: var(--ui-primary-color);\n color: var(--ui-on-primary-color);\n border: solid 1px var(--ui-on-surface-color-lightest-solid);\n border-radius: 0.125rem;\n margin-bottom: 0.25rem;\n height: 6rem;\n pointer-events: none;\n}\n\n.TypographyVariantSelectInputView-module_preview__12fCl > div {\n width: 200%;\n}\n\n.TypographyVariantSelectInputView-module_cardsAppearance__1bjfD > div {\n margin-top: -3rem;\n margin-left: -3rem;\n padding-bottom: 3rem;\n}\n"; var styles = {"preview":"TypographyVariantSelectInputView-module_preview__12fCl","cardsAppearance":"TypographyVariantSelectInputView-module_cardsAppearance__1bjfD"}; styleInject(css); function _arrayWithoutHoles(arr) { if (Array.isArray(arr)) return _arrayLikeToArray(arr); } function _iterableToArray(iter) { if (typeof Symbol !== "undefined" && Symbol.iterator in Object(iter)) return Array.from(iter); } function _nonIterableSpread() { throw new TypeError("Invalid attempt to spread non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); } function _toConsumableArray(arr) { return _arrayWithoutHoles(arr) || _iterableToArray(arr) || _unsupportedIterableToArray(arr) || _nonIterableSpread(); } var css$1 = ".ListboxInputView-module_container__vNkJh {\n position: relative;\n}\n\n.ListboxInputView-module_button__3ZTnw {\n background-color: var(--ui-surface-color);\n text-align: left;\n background-image: url(\"data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 20 20'%3e%3cpath stroke='%236b7280' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' d='M6 8l4 4 4-4'/%3e%3c/svg%3e\");\n background-position: right 0.5rem center;\n background-repeat: no-repeat;\n background-size: 1.5em 1.5em;\n padding-right: 2.5rem;\n}\n\n.ListboxInputView-module_options__Yp2CJ {\n position: absolute;\n width: 100%;\n box-sizing: border-box;\n left: 0;\n top: 100%;\n z-index: 3;\n padding: 1px;\n margin-bottom: 1rem;\n border: solid 1px var(--ui-on-surface-color-lighter);\n border-radius: 0.125rem;\n box-shadow: var(--ui-box-shadow);\n background-color: var(--ui-surface-color);\n cursor: default;\n -webkit-user-select: none;\n -moz-user-select: none;\n -ms-user-select: none;\n user-select: none;\n}\n\n.ListboxInputView-module_options__Yp2CJ::before{\n content: '';\n position: absolute;\n left: 0;\n top: 0;\n width: 100%;\n height: 100%;\n padding-bottom: 1rem;\n pointer-events: none;\n}\n\n.ListboxInputView-module_options__Yp2CJ:focus {\n outline: 0;\n}\n\n.ListboxInputView-module_option__2Umwh {\n padding: 0.25rem;\n overflow: hidden;\n}\n\n.ListboxInputView-module_activeOption__Mo1YN {\n background-color: var(--ui-selection-color-light);\n}\n"; var styles$1 = {"container":"ListboxInputView-module_container__vNkJh","button":"ListboxInputView-module_button__3ZTnw","options":"ListboxInputView-module_options__Yp2CJ","option":"ListboxInputView-module_option__2Umwh","activeOption":"ListboxInputView-module_activeOption__Mo1YN"}; styleInject(css$1); var ListboxInputView = Marionette.ItemView.extend({ mixins: [inputView], className: styles$1.view, template: function template() { return "\n \n
\n "); }, ui: cssModulesUtils.ui(styles$1, 'container'), modelEvents: function modelEvents() { return _defineProperty({}, "change:".concat(this.options.propertyName), 'renderDropdown'); }, initialize: function initialize() { var _this = this; if (!this.options.texts) { this.options.texts = this.options.translationKeys.map(function (key) { return I18n.t(key); }); } this.items = [{ name: '', text: I18n.t(this.options.blankTranslationKey) }].concat(_toConsumableArray(this.options.values.map(function (value, i) { return { value: value, text: _this.options.texts[i] }; }))); }, renderSelectedItem: function renderSelectedItem(item) { return item.text; }, renderItem: function renderItem(item) { return item.text; }, onRender: function onRender() { this.renderDropdown(); }, updateDisabled: function updateDisabled() { this.renderDropdown(); }, renderDropdown: function renderDropdown(value, text) { var _this2 = this; ReactDOM.render(React.createElement(Dropdown, { items: this.items, disabled: this.isDisabled(), renderSelectedItem: function renderSelectedItem(item) { return _this2.renderSelectedItem(item); }, renderItem: function renderItem(item) { return _this2.renderItem(item); }, selectedItem: this.items.find(function (item) { return item.value === _this2.model.get(_this2.options.propertyName); }) || this.items[0], onChange: function onChange(value) { _this2.model.set(_this2.options.propertyName, value); } }), this.ui.container[0]); } }); function Dropdown(_ref2) { var items = _ref2.items, disabled = _ref2.disabled, renderItem = _ref2.renderItem, renderSelectedItem = _ref2.renderSelectedItem, selectedItem = _ref2.selectedItem, onChange = _ref2.onChange; return /*#__PURE__*/React.createElement(Listbox, { value: selectedItem.value, disabled: disabled, onChange: onChange }, /*#__PURE__*/React.createElement(Listbox.Button, { className: styles$1.button }, renderSelectedItem(selectedItem)), /*#__PURE__*/React.createElement(Listbox.Options, { className: styles$1.options }, items.map(function (item) { return /*#__PURE__*/React.createElement(Listbox.Option, { key: item.value || 'blank', value: item.value }, function (_ref3) { var active = _ref3.active; return /*#__PURE__*/React.createElement("div", { className: classNames(styles$1.option, _defineProperty({}, styles$1.activeOption, active)) }, renderItem(item)); }); }))); } var PREFIX = 'PAGEFLOW_SCROLLED_COLLECTION'; var RESET = "".concat(PREFIX, "_RESET"); var ADD = "".concat(PREFIX, "_ADD"); var CHANGE = "".concat(PREFIX, "_CHANGE"); var REMOVE = "".concat(PREFIX, "_REMOVE"); var SORT = "".concat(PREFIX, "_SORT"); function watchCollection(collection, _ref3) { var name = _ref3.name, dispatch = _ref3.dispatch, attributes = _ref3.attributes, includeConfiguration = _ref3.includeConfiguration, _ref3$keyAttribute = _ref3.keyAttribute, keyAttribute = _ref3$keyAttribute === void 0 ? 'id' : _ref3$keyAttribute; var handle = {}; var options = { attributeNames: attributes, includeConfiguration: includeConfiguration }; var tearingDown = false; var watchedAttributeNames = getWatchedAttributeNames(attributes); var sourceKeyAttribute = findSourceAttributeName(attributes, keyAttribute); dispatch({ type: RESET, payload: { collectionName: name, keyAttribute: keyAttribute, items: collection.map(function (model) { return getAttributes(model, options); }) } }); collection.on('add change:id', function (model) { if (!model.isNew()) { dispatch({ type: ADD, payload: { collectionName: name, keyAttribute: keyAttribute, order: collection.pluck(sourceKeyAttribute).filter(Boolean), attributes: getAttributes(model, options) } }); } }, handle); collection.on('change', function (model) { if (hasChangedAttributes(model, watchedAttributeNames) && !model.isNew()) { dispatch({ type: CHANGE, payload: { collectionName: name, keyAttribute: keyAttribute, attributes: getAttributes(model, options) } }); } }, handle); if (includeConfiguration) { collection.on('change:configuration', function (model, value) { var _ref4 = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : {}, ignoreInWatchCollection = _ref4.ignoreInWatchCollection; if (!model.isNew() && !ignoreInWatchCollection) { dispatch({ type: CHANGE, payload: { collectionName: name, keyAttribute: keyAttribute, attributes: getAttributes(model, options) } }); } }, handle); } collection.on('remove', function (model) { if (!tearingDown && !model.isNew()) { dispatch({ type: REMOVE, payload: { collectionName: name, order: collection.pluck(sourceKeyAttribute).filter(Boolean), key: model.attributes[sourceKeyAttribute] } }); } }, handle); collection.on('sort', function (model) { return dispatch({ type: SORT, payload: { collectionName: name, order: collection.pluck(sourceKeyAttribute).filter(Boolean) } }); }, handle); return function () { tearingDown = true; collection.off(null, null, handle); }; } function findSourceAttributeName(attributeNames, targetAttributeName) { var mapping = attributeNames.find(function (attributeName) { return typeof attributeName === 'object' && mappedAttributeTarget(attributeName) === targetAttributeName; }); return mapping ? mappedAttributeSource(mapping) : targetAttributeName; } function hasChangedAttributes(model, attributeNames) { return attributeNames.some(function (attributeName) { return model.hasChanged(attributeName); }); } function getWatchedAttributeNames(attributeNames) { return attributeNames.map(function (attributeName) { return typeof attributeName == 'object' ? mappedAttributeSource(attributeName) : attributeName; }); } function mappedAttributeSource(attributeName) { return attributeName[Object.keys(attributeName)[0]]; } function mappedAttributeTarget(attributeName) { return Object.keys(attributeName)[0]; } function getAttributes(model, _ref5) { var attributeNames = _ref5.attributeNames, includeConfiguration = _ref5.includeConfiguration; var result = attributeNames.reduce(function (result, attributeName) { if (typeof attributeName == 'object') { var key = Object.keys(attributeName)[0]; var value = attributeName[key]; if (typeof value == 'function') { result[key] = value(model.get(key)); } else { result[key] = model.get(value); } } else { result[attributeName] = model.get(attributeName); } return result; }, {}); if (includeConfiguration) { result.configuration = _objectSpread2({}, model.configuration.attributes); } return result; } var createShallowEqualArraysSelector = createSelectorCreator(defaultMemoize, shallowEqualArrays); function shallowEqualArrays(a, b) { return a.length === b.length && a.every(function (item, index) { return item === b[index]; }); } var Context = createContext(); function watchCollections(entry, _ref) { var dispatch = _ref.dispatch; var chapters = entry.chapters, sections = entry.sections, contentElements = entry.contentElements, widgets = entry.widgets, files = entry.files; var teardownFns = []; teardownFns.push(watchCollection(new Backbone.Collection([entry.metadata]), { name: 'entries', attributes: ['locale', { permaId: function permaId() { return entry.id; } }, // Make sure key attribute is present { shareProviders: 'share_providers' }, { shareUrl: 'share_url' }, 'credits'], keyAttribute: 'permaId', dispatch: dispatch })); teardownFns.push(watchCollection(chapters, { name: 'chapters', attributes: ['id', 'permaId'], keyAttribute: 'permaId', includeConfiguration: true, dispatch: dispatch })); teardownFns.push(watchCollection(sections, { name: 'sections', attributes: ['id', 'permaId', 'chapterId'], keyAttribute: 'permaId', includeConfiguration: true, dispatch: dispatch })); teardownFns.push(watchCollection(contentElements, { name: 'contentElements', attributes: ['id', 'permaId', 'typeName', 'sectionId'], keyAttribute: 'permaId', includeConfiguration: true, dispatch: dispatch })); teardownFns.push(watchCollection(widgets, { name: 'widgets', attributes: [{ typeName: 'type_name' }, 'role', { permaId: 'role' }], keyAttribute: 'permaId', includeConfiguration: true, dispatch: dispatch })); Object.keys(files).forEach(function (collectionName) { teardownFns.push(watchCollection(files[collectionName], { name: camelize(collectionName), attributes: ['id', { permaId: 'perma_id' }, 'width', 'height', 'basename', 'extension', 'rights', { isReady: 'is_ready' }, { variants: function variants(_variants) { return _variants && _variants.map(function (variant) { return camelize(variant); }); } }, { durationInMs: 'duration_in_ms' }, { parentFileId: 'parent_file_id' }, { parentFileModelType: 'parent_file_model_type' }], keyAttribute: 'permaId', includeConfiguration: true, dispatch: dispatch })); }); return function () { teardownFns.forEach(function (fn) { return fn(); }); }; } function camelize(snakeCase) { return snakeCase.replace(/_[a-z]/g, function (match) { return match[1].toUpperCase(); }); } var TypographyVariantSelectInputView = ListboxInputView.extend({ renderItem: function renderItem(item) { return /*#__PURE__*/React.createElement(Preview, { entry: this.options.entry, contentElement: this.options.contentElement, item: item, getPreviewConfiguration: this.options.getPreviewConfiguration }); } }); function Preview(_ref) { var entry = _ref.entry, contentElement = _ref.contentElement, item = _ref.item, getPreviewConfiguration = _ref.getPreviewConfiguration; var subscribe = useCallback(function (dispatch) { watchCollections(buildEntry(entry, contentElement, item, getPreviewConfiguration), { dispatch: dispatch }); }, [entry, contentElement, item, getPreviewConfiguration]); var appearance = contentElement.section.configuration.get('appearance'); return /*#__PURE__*/React.createElement(React.Fragment, null, /*#__PURE__*/React.createElement("div", { className: classNames(styles.preview, styles["".concat(appearance, "Appearance")]), "aria-hidden": "true" }, /*#__PURE__*/React.createElement(StandaloneSectionThumbnail, { scale: false, seed: entry.scrolledSeed, sectionPermaId: 1, subscribe: subscribe })), item.text); } function buildEntry(entry, contentElement, item, getPreviewConfiguration) { var section = contentElement.section; var fakeContentElement = new Backbone$1.Model(contentElement.attributes); fakeContentElement.configuration = new Backbone$1.Model(getPreviewConfiguration(contentElement.configuration.attributes, item.value)); var fakeSection = new Backbone$1.Model(_objectSpread2(_objectSpread2({}, section.attributes), {}, { permaId: 1 })); fakeSection.configuration = new Backbone$1.Model(_objectSpread2(_objectSpread2({}, section.configuration.attributes), {}, { transition: 'preview', fullHeight: false, layout: 'left', exposeMotifArea: false, backdrop: _objectSpread2(_objectSpread2({}, section.configuration.attributes.backdrop), {}, { imageMotifArea: null, imageMobileMotifArea: null, videoMotifArea: null }) })); return { id: entry.id, metadata: entry.metadata, widgets: entry.widgets, files: entry.files, chapters: new Backbone$1.Collection([section.chapter]), sections: new Backbone$1.Collection([fakeSection]), contentElements: new Backbone$1.Collection([fakeContentElement]) }; } var css$2 = ".ColorSelectInputView-module_item__1qpQU {\n display: flex;\n align-items: center;\n}\n\n.ColorSelectInputView-module_swatch__36Kqr {\n background-color: var(--color);\n width: 1rem;\n height: 1rem;\n border: solid 1px var(--ui-on-surface-color-lighter);\n border-radius: 0.125rem;\n margin-right: 0.5rem;\n}\n\n.ColorSelectInputView-module_blank__16xMd .ColorSelectInputView-module_swatch__36Kqr {\n display: none;\n}\n"; var styles$2 = {"item":"ColorSelectInputView-module_item__1qpQU","swatch":"ColorSelectInputView-module_swatch__36Kqr","blank":"ColorSelectInputView-module_blank__16xMd"}; styleInject(css$2); var ColorSelectInputView = ListboxInputView.extend({ renderItem: renderItem, renderSelectedItem: renderItem }); function renderItem(item) { return /*#__PURE__*/React.createElement("div", { className: classNames(styles$2.item, _defineProperty({}, styles$2.blank, !item.value)) }, /*#__PURE__*/React.createElement("div", { className: styles$2.swatch, style: { '--color': "var(--theme-palette-color-".concat(item.value, ")") } }), item.text); } ConfigurationEditorTabView.groups.define('ContentElementPosition', function () { var contentElement = this.model.parent; if (contentElement.getAvailablePositions().length > 1) { this.input('position', SelectInputView, { attributeTranslationKeyPrefixes: ['pageflow_scrolled.editor.common_content_element_attributes'], values: contentElement.getAvailablePositions() }); } this.input('width', SliderInputView, { attributeTranslationKeyPrefixes: ['pageflow_scrolled.editor.common_content_element_attributes'], displayText: function displayText(value) { return ['XXS', 'XS', 'S', 'M', 'L', 'XL', 'XXL'][value + 3]; }, saveOnSlide: true, minValueBinding: 'position', maxValueBinding: 'position', minValue: function minValue() { return contentElement.getAvailableMinWidth(); }, maxValue: function maxValue() { return contentElement.getAvailableMaxWidth(); }, visible: function visible() { return contentElement.getAvailableMinWidth() !== contentElement.getAvailableMaxWidth(); }, defaultValue: this.model.get('position') === 'wide' ? 2 : this.model.get('position') === 'full' ? 3 : 0 }); }); ConfigurationEditorTabView.groups.define('ContentElementTypographyVariant', function (_ref) { var entry = _ref.entry, model = _ref.model, prefix = _ref.prefix, getPreviewConfiguration = _ref.getPreviewConfiguration; var contentElement = this.model.parent; if (entry.getTypographyVariants({ contentElement: contentElement })[0].length) { var _entry$getTypographyV = entry.getTypographyVariants({ contentElement: contentElement, prefix: prefix }), _entry$getTypographyV2 = _slicedToArray(_entry$getTypographyV, 2), variants = _entry$getTypographyV2[0], texts = _entry$getTypographyV2[1]; this.input('typographyVariant', TypographyVariantSelectInputView, { entry: entry, model: model || this.model, contentElement: contentElement, prefix: prefix, getPreviewConfiguration: getPreviewConfiguration, blankTranslationKey: 'pageflow_scrolled.editor.' + 'common_content_element_attributes.' + 'typographyVariant.blank', attributeTranslationKeyPrefixes: ['pageflow_scrolled.editor.common_content_element_attributes'], disabled: !variants.length, values: variants, texts: texts }); } }); ConfigurationEditorTabView.groups.define('ContentElementVariant', function (_ref2) { var entry = _ref2.entry; var _entry$getContentElem = entry.getContentElementVariants({ contentElement: this.model.parent }), _entry$getContentElem2 = _slicedToArray(_entry$getContentElem, 2), variants = _entry$getContentElem2[0], texts = _entry$getContentElem2[1]; if (variants.length) { this.input('variant', SelectInputView, { attributeTranslationKeyPrefixes: ['pageflow_scrolled.editor.common_content_element_attributes'], includeBlank: true, blankTranslationKey: 'pageflow_scrolled.editor.' + 'common_content_element_attributes.' + 'variant.blank', values: variants, texts: texts }); } }); ConfigurationEditorTabView.groups.define('PaletteColor', function (_ref3) { var propertyName = _ref3.propertyName, entry = _ref3.entry, model = _ref3.model; var _entry$getPaletteColo = entry.getPaletteColors(), _entry$getPaletteColo2 = _slicedToArray(_entry$getPaletteColo, 2), values = _entry$getPaletteColo2[0], texts = _entry$getPaletteColo2[1]; if (values.length) { this.input(propertyName, ColorSelectInputView, { model: model || this.model, blankTranslationKey: 'pageflow_scrolled.editor.' + 'common_content_element_attributes.' + 'palette_color.blank', values: values, texts: texts }); } }); editor$1.widgetTypes.registerRole('header', { isOptional: false }); editor$1.widgetTypes.registerRole('footer', { isOptional: true }); function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } } function _defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } function _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); return Constructor; } /** * Integrate new content types into the editor. * @name editor_contentElementTypes */ var ContentElementTypeRegistry = /*#__PURE__*/function () { function ContentElementTypeRegistry(_ref) { var features = _ref.features; _classCallCheck(this, ContentElementTypeRegistry); this.features = features; this.contentElementTypes = {}; } /** * Register a new type of content element in the editor. * * @param {string} typeName - Name of the content element type. * @param {Object} options * @param {Function} options.configurationEditor - * Function that is evaluated in the context of a * `ConfigurationEditorView` (see `pageflow/ui`) which will * be used to edit the configuration of content elements of * this type. Receives an options object with an `entry` * property containing the entry model. * @param {Object} options.defaultConfig - * Object that is set as initial config for the content element. * @param {Function} [options.split] - * Function that receives configuration attributes and a split point * and needs to return a two element array of configuration attributes * objects representing the content elements that arise from splitting * a content element with the given configuration at the specified * split point. Called when inserting content elements at custom split * points. * @param {Function} [options.merge] - * Function that receives two configuration attributes objects and * needs to return a single merged configuration. If provided, this * will function will be called whenever two content elements of this * type become adjacent because a common neighbor has been deleted. * @param {string[]} [options.supportedPositions] - * Pass array containing a subset of the positions `left`, `right`, * `sticky` and `inline`. By default all positions are supported. * @param {string[]} [options.supportedWidthRange] - * Pass array consisting of two widths of the form `xxs`, `xs`, `sm`, * `md`, `lg`, `xl` or `full` representing the smallest andlargest * supported width. By default only width `md` is supported. * @memberof editor_contentElementTypes * * @example * * // editor.js * editor.contentElementTypes.register('inlineImage', { * supportedWidthRange: ['xss', 'full'], * * configurationEditor() { * this.tab('general', function() { * this.input('caption', TextInputView); * }); * } * }); */ _createClass(ContentElementTypeRegistry, [{ key: "register", value: function register(typeName, options) { this.contentElementTypes[typeName] = options; } }, { key: "setupConfigurationEditor", value: function setupConfigurationEditor(typeName, configurationEditorView, options) { return this.findByTypeName(typeName).configurationEditor.call(configurationEditorView, options); } }, { key: "findByTypeName", value: function findByTypeName(typeName) { if (!this.contentElementTypes[typeName]) { throw new Error("Unknown content element type ".concat(typeName)); } return this.contentElementTypes[typeName]; } }, { key: "groupedByCategory", value: function groupedByCategory() { var result = []; var categoriesByName = {}; this.toArray().forEach(function (contentElementType) { var categoryName = contentElementType.category || 'basic'; if (!categoriesByName[categoryName]) { categoriesByName[categoryName] = { name: categoryName, displayName: I18n.t("pageflow_scrolled.editor.content_element_categories.".concat(categoryName, ".name")), contentElementTypes: [] }; result.push(categoriesByName[categoryName]); } categoriesByName[categoryName].contentElementTypes.push(contentElementType); }); return result; } }, { key: "toArray", value: function toArray() { var _this = this; return Object.keys(this.contentElementTypes).map(function (typeName) { return _objectSpread2(_objectSpread2({}, _this.contentElementTypes[typeName]), {}, { typeName: typeName, displayName: I18n.t("pageflow_scrolled.editor.content_elements.".concat(typeName, ".name")), description: I18n.t("pageflow_scrolled.editor.content_elements.".concat(typeName, ".description")) }); }).filter(function (contentElement) { return !contentElement.featureName || _this.features.isEnabled(contentElement.featureName); }); } }]); return ContentElementTypeRegistry; }(); function extend(api) { return Object.assign(api, { contentElementTypes: new ContentElementTypeRegistry({ features: features }) }); } var editor = extend(editor$1); function ConsentVendors(_ref) { var hostMatchers = _ref.hostMatchers; return { fromUrl: function fromUrl(url) { var _Object$entries$find; url = new URL(url); return (_Object$entries$find = Object.entries(hostMatchers).find(function (_ref2) { var _ref3 = _slicedToArray(_ref2, 1), matcher = _ref3[0]; return new RegExp(matcher).test(url.host); })) === null || _Object$entries$find === void 0 ? void 0 : _Object$entries$find[1]; } }; } function _objectWithoutPropertiesLoose(source, excluded) { if (source == null) return {}; var target = {}; var sourceKeys = Object.keys(source); var key, i; for (i = 0; i < sourceKeys.length; i++) { key = sourceKeys[i]; if (excluded.indexOf(key) >= 0) continue; target[key] = source[key]; } return target; } function _objectWithoutProperties(source, excluded) { if (source == null) return {}; var target = _objectWithoutPropertiesLoose(source, excluded); var key, i; if (Object.getOwnPropertySymbols) { var sourceSymbolKeys = Object.getOwnPropertySymbols(source); for (i = 0; i < sourceSymbolKeys.length; i++) { key = sourceSymbolKeys[i]; if (excluded.indexOf(key) >= 0) continue; if (!Object.prototype.propertyIsEnumerable.call(source, key)) continue; target[key] = source[key]; } } return target; } var SectionConfiguration = Configuration.extend({ defaults: { transition: 'fadeBg', fullHeight: true, exposeMotifArea: true, backdrop: {} }, initialize: function initialize() { Configuration.prototype.initialize.apply(this, arguments); this.attributes = _objectSpread2(_objectSpread2({}, this.getAttributesFromBackdropAttribute()), this.attributes); }, getAttributesFromBackdropAttribute: function getAttributesFromBackdropAttribute() { var backdrop = this.attributes.backdrop || {}; if (backdrop.image && backdrop.image.toString().startsWith('#')) { return { backdropType: 'color', backdropColor: backdrop.image }; } else if (backdrop.color) { return { backdropType: 'color', backdropColor: backdrop.color }; } else if (backdrop.video) { return { backdropType: 'video', backdropVideo: backdrop.video }; } else { return { backdropType: 'image', backdropImage: backdrop.image, backdropImageMobile: backdrop.imageMobile }; } }, set: function set(name, value) { if (name !== 'backdrop' && name.startsWith && name.startsWith('backdrop')) { Configuration.prototype.set.call(this, _defineProperty({ backdrop: this.getBackdropAttribute(_objectSpread2(_objectSpread2({}, this.attributes), {}, _defineProperty({}, name, value))) }, name, value)); } else { Configuration.prototype.set.apply(this, arguments); } }, getBackdropAttribute: function getBackdropAttribute(nextAttributes) { switch (nextAttributes.backdropType) { case 'color': return { color: nextAttributes.backdropColor }; case 'video': return { video: nextAttributes.backdropVideo, videoMotifArea: nextAttributes.backdropVideoMotifArea, videoMobile: nextAttributes.backdropVideoMobile, videoMobileMotifArea: nextAttributes.backdropVideoMobileMotifArea }; default: return { image: nextAttributes.backdropImage, imageMotifArea: nextAttributes.backdropImageMotifArea, imageMobile: nextAttributes.backdropImageMobile, imageMobileMotifArea: nextAttributes.backdropImageMobileMotifArea }; } } }); var FileSelectionHandler = function FileSelectionHandler(options) { var section = options.entry.sections.get(options.id); this.call = function (file) { section.configuration.setReference(options.attributeName, file); section.configuration.set("".concat(options.attributeName, "MotifArea"), file.configuration.get('motifArea')); }; this.getReferer = function () { return '/scrolled/sections/' + section.id; }; }; editor$1.registerFileSelectionHandler('sectionConfiguration', FileSelectionHandler); var Section = Backbone$1.Model.extend({ mixins: [configurationContainer({ autoSave: true, includeAttributesInJSON: ['position'], configurationModel: SectionConfiguration }), delayedDestroying, entryTypeEditorControllerUrls.forModel({ resources: 'sections' }), failureTracking], initialize: function initialize(attributes, options) { this.contentElements = new ForeignKeySubsetCollection({ parent: options.contentElements, parentModel: this, foreignKeyAttribute: 'sectionId', parentReferenceAttribute: 'section', autoConsolidatePositions: false }); }, chapterPosition: function chapterPosition() { return this.chapter && this.chapter.has('position') ? this.chapter.get('position') : -1; }, getTransition: function getTransition() { var _this$chapter; var entry = (_this$chapter = this.chapter) === null || _this$chapter === void 0 ? void 0 : _this$chapter.entry; if (!entry) { return 'scroll'; } var sectionIndex = entry.sections.indexOf(this); var previousSection = entry.sections.at(sectionIndex - 1); var availableTransitions = previousSection ? getAvailableTransitionNames(this.configuration.attributes, previousSection.configuration.attributes) : []; var transition = this.configuration.get('transition'); if (availableTransitions.includes(transition)) { return transition; } else { return 'scroll'; } } }); var Chapter = Backbone$1.Model.extend({ mixins: [configurationContainer({ autoSave: true, includeAttributesInJSON: ['position'] }), delayedDestroying, entryTypeEditorControllerUrls.forModel({ resources: 'chapters' }), failureTracking], initialize: function initialize(attributes, options) { this.sections = new ForeignKeySubsetCollection({ parent: options.sections, parentModel: this, foreignKeyAttribute: 'chapterId', parentReferenceAttribute: 'chapter', autoConsolidatePositions: false }); this.entry = options.entry; }, addSection: function addSection(attributes) { var _this = this; var _ref = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {}, select = _ref.select, options = _objectWithoutProperties(_ref, ["select"]); var section = this.sections.create(new Section(_objectSpread2({ position: this.sections.length ? Math.max.apply(Math, _toConsumableArray(this.sections.pluck('position'))) + 1 : 0, chapterId: this.id, configuration: { transition: this.entry.metadata.configuration.get('defaultTransition') } }, attributes), { contentElements: this.entry.contentElements }), options); section.once('sync', function (model, response) { if (select) { _this.entry.trigger('selectSectionSettings', section); } _this.entry.trigger('scrollToSection', section); section.configuration.set(response.configuration, { autoSave: false }); section.contentElements.add(response.contentElements); }); return section; }, insertSection: function insertSection(_ref2, options) { var before = _ref2.before, after = _ref2.after; var position = before ? before.get('position') : after.get('position') + 1; this.sections.each(function (section) { if (section.get('position') >= position) { section.set('position', section.get('position') + 1); } }); var newSection = this.addSection({ position: position }, options); this.sections.sort(); return newSection; }, duplicateSection: function duplicateSection(section) { var newSection = this.insertSection({ after: section }, { url: "".concat(section.url(), "/duplicate") }); return newSection; } }); var ChaptersCollection = Backbone$1.Collection.extend({ model: Chapter, mixins: [entryTypeEditorControllerUrls.forCollection({ resources: 'chapters' }), orderedCollection], comparator: function comparator(chapter) { return chapter.get('position'); } }); var SectionsCollection = Backbone$1.Collection.extend({ model: Section, mixins: [entryTypeEditorControllerUrls.forCollection({ resources: 'sections' })], comparator: function comparator(sectionA, sectionB) { if (sectionA.chapterPosition() > sectionB.chapterPosition()) { return 1; } else if (sectionA.chapterPosition() < sectionB.chapterPosition()) { return -1; } else if (sectionA.get('position') > sectionB.get('position')) { return 1; } else if (sectionA.get('position') < sectionB.get('position')) { return -1; } else { return 0; } } }); var widths = { xxs: -3, xs: -2, s: -1, md: 0, l: 1, xl: 2, full: 3 }; var ContentElement = Backbone$1.Model.extend({ paramRoot: 'content_element', mixins: [configurationContainer({ autoSave: true, includeAttributesInJSON: ['position', 'typeName'] }), delayedDestroying, entryTypeEditorControllerUrls.forModel({ resources: 'content_elements' }), failureTracking], initialize: function initialize() { var _this = this; this.transientState = new Backbone$1.Model(this.get('transientState')); this.listenTo(this, 'change:transientState', function () { return _this.transientState.set(_this.get('transientState'), { skipCommand: true }); }); this.listenTo(this.transientState, 'change', function (model, _ref) { var skipCommand = _ref.skipCommand; if (!skipCommand) { _this.postCommand({ type: 'TRANSIENT_STATE_UPDATE', payload: model.changed }); } }); }, getType: function getType(contentElement) { return editor.contentElementTypes.findByTypeName(this.get('typeName')); }, postCommand: function postCommand(command) { this.trigger('postCommand', this.id, command); }, getAdjacentContentElements: function getAdjacentContentElements() { var section = this.section; var index = section.contentElements.indexOf(this); return [section.contentElements.at(index - 1), section.contentElements.at(index + 1)]; }, applyDefaultConfiguration: function applyDefaultConfiguration(sibling) { var defaultConfig = _objectSpread2({}, this.getType().defaultConfig); var defaultPosition = sibling === null || sibling === void 0 ? void 0 : sibling.getPosition(); var supportedPositions = this.getType().supportedPositions || []; if (defaultPosition && defaultPosition !== 'inline' && supportedPositions.includes(defaultPosition)) { defaultConfig.position = defaultPosition; } this.configuration.set(defaultConfig); }, getPosition: function getPosition() { return this.configuration.get('position'); }, getResolvedPosition: function getResolvedPosition() { var position = this.getPosition(); return this.getAvailablePositions().includes(position) ? position : 'inline'; }, getAvailablePositions: function getAvailablePositions() { var layout = this.section.configuration.get('layout'); var supportedByLayout = layout === 'center' || layout === 'centerRagged' ? ['inline', 'left', 'right'] : ['inline', 'sticky']; var supportedByType = this.getType().supportedPositions; if (supportedByType) { return supportedByLayout.filter(function (position) { return supportedByType.includes(position); }); } else { return supportedByLayout; } }, getWidth: function getWidth() { return this.clampWidthByPosition(this.configuration.get('width') || 0); }, getAvailableMinWidth: function getAvailableMinWidth() { var _this$getType$support; return this.clampWidthByPosition(widths[((_this$getType$support = this.getType().supportedWidthRange) === null || _this$getType$support === void 0 ? void 0 : _this$getType$support[0]) || 'md']); }, getAvailableMaxWidth: function getAvailableMaxWidth() { var _this$getType$support2; return this.clampWidthByPosition(widths[((_this$getType$support2 = this.getType().supportedWidthRange) === null || _this$getType$support2 === void 0 ? void 0 : _this$getType$support2[1]) || 'md']); }, clampWidthByPosition: function clampWidthByPosition(width) { if (['sticky', 'left', 'right'].includes(this.getResolvedPosition())) { return Math.min(Math.max(width, -2), 2); } else { return width; } } }); var ContentElementsCollection = Backbone$1.Collection.extend({ model: ContentElement, mixins: [entryTypeEditorControllerUrls.forCollection({ resources: 'content_elements' })], comparator: 'position' }); // persisting the changes to the server in a single request and // applying them to the section once the requests succeeds. function Batch(entry, section) { // Shallow copy of the section's list of content elements to store // ordering changes and newly inserted content elements. var contentElements = section.contentElements.toArray(); // Since contentElements is only a shallow copy, we cannot write // configuration changes to the actual content elements. var changedConfigurations = {}; // Content elements that have been removed from contentElements // and shall be deleted on the server. var markedForDeletion = []; // Track whether changes have been recorded which need to be // persisted to the server. var isDirty = false; return { getAdjacent: getAdjacent, getLength: getLength, split: split, maybeMerge: maybeMerge, insertBefore: insertBefore, insertAfter: insertAfter, markForUpdate: markForUpdate, markForDeletion: markForDeletion, remove: remove, save: save, saveIfDirty: saveIfDirty }; function getAdjacent(contentElement) { var index = contentElements.indexOf(contentElement); return [contentElements[index - 1], contentElements[index + 1]]; } function getLength(contentElement) { return contentElement.getType().getLength ? contentElement.getType().getLength(getCurrentConfiguration(contentElement)) : 0; } // Higher level transformations based on the more low level // transformations below: function split(contentElement, splitPoint) { var _ref = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : {}, insertAt = _ref.insertAt; var _contentElement$getTy = contentElement.getType().split(getCurrentConfiguration(contentElement), splitPoint), _contentElement$getTy2 = _slicedToArray(_contentElement$getTy, 2), c1 = _contentElement$getTy2[0], c2 = _contentElement$getTy2[1]; var splitOffContentElement; if (insertAt === 'before') { splitOffContentElement = new ContentElement({ typeName: contentElement.get('typeName'), configuration: c1 }); insertBefore(contentElement, splitOffContentElement); markForUpdate(contentElement, c2); } else { splitOffContentElement = new ContentElement({ typeName: contentElement.get('typeName'), configuration: c2 }); markForUpdate(contentElement, c1); insertAfter(contentElement, splitOffContentElement); } return splitOffContentElement; } function maybeMerge(before, after) { if (!before || !after || before.get('typeName') !== after.get('typeName') || !before.getType().merge) { return; } var mergedConfiguration = before.getType().merge(getCurrentConfiguration(before), getCurrentConfiguration(after)); // Update the aleady persisted content element, if one has not yet // been persisted. For example, let X be a content element in // between two text blocks T1 and T2: // // T1 // paragraph A // paragraph B // X // T2 // paragraph C // // When X shall be moved between the two paragraphs of T1, the // second paragraph of T1 will first be split off into a new // content element T3: // // T1 // paragraph A // T3 // paragraph B // X // T2 // paragraph C // // Then X will be moved: // // T1 // paragraph A // X // T3 // paragraph B // T2 // paragraph C // // T3 and T2 become adjacent and need to be merged. We now want to // update T2 instead of creating T3 and deleting T2. Final state: // // T1 // paragraph A // X // T2 // paragraph B // paragraph C // if (before.isNew() && !after.isNew()) { remove(before); markForUpdate(after, mergedConfiguration); return after; } else { markForUpdate(before, mergedConfiguration); remove(after); if (!after.isNew()) { markForDeletion(after); } return before; } } function insertBefore(sibling, contentElement) { isDirty = true; contentElements.splice(contentElements.indexOf(sibling), 0, contentElement); } function insertAfter(sibling, contentElement) { isDirty = true; contentElements.splice(contentElements.indexOf(sibling) + 1, 0, contentElement); } function markForUpdate(contentElement, configuration) { isDirty = true; if (contentElement.isNew()) { contentElement.configuration.set(configuration); } else { changedConfigurations[contentElement.id] = configuration; } } function markForDeletion(contentElement) { isDirty = true; markedForDeletion.push(contentElement); } function remove(contentElement) { // We do not mark the batch as dirty here to allow removing an // element and adding it to another section. We are fine with // the resulting gap in the position attributes of the section's // content elements. contentElements.splice(contentElements.indexOf(contentElement), 1); } function getCurrentConfiguration(contentElement) { return changedConfigurations[contentElement.id] || contentElement.configuration.attributes; } // Functionality to assemble and perform the batch request to // persist the recorded changes: function saveIfDirty(options) { if (isDirty) { save(options); } } function save() { var _ref2 = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {}, _success = _ref2.success; isDirty = false; Backbone$1.sync('update', section, { url: "".concat(section.url(), "/content_elements/batch"), attrs: { content_elements: createBatchItems() }, success: function success(response) { applyConfigurationChanges(); applyPositions(); applyAdditions(response); applyDeletions(); section.contentElements.sort(); if (_success) { _success(); } } }); } function createBatchItems() { return [].concat(_toConsumableArray(contentElements.map(function (contentElement) { if (contentElement.isNew()) { return { typeName: contentElement.get('typeName'), configuration: contentElement.configuration.attributes }; } else if (changedConfigurations[contentElement.id]) { return { id: contentElement.id, configuration: changedConfigurations[contentElement.id] }; } else { return contentElement.pick('id'); } })), _toConsumableArray(markedForDeletion.map(function (contentElement) { return { id: contentElement.id, _delete: true }; }))); } // Functionality to apply the recorded changes to the underlying // section once the request succeeded: function applyAdditions(response) { contentElements.forEach(function (contentElement, index) { if (contentElement.isNew()) { section.contentElements.add(contentElement); contentElement.set({ id: response[index].id, permaId: response[index].permaId }); } else if (contentElement.section !== section) { contentElement.section.contentElements.remove(contentElement); section.contentElements.add(contentElement); } }); } function applyDeletions() { markedForDeletion.forEach(function (contentElement) { return entry.contentElements.remove(contentElement); }); } function applyPositions() { contentElements.forEach(function (contentElement, index) { return contentElement.set('position', index, { autoSave: false }); }); } function applyConfigurationChanges() { contentElements.forEach(function (contentElement) { if (changedConfigurations[contentElement.id]) { contentElement.configuration.set(changedConfigurations[contentElement.id], { autoSave: false }); } }); } } function maybeMergeWithAdjacent(batch, contentElement) { var _batch$getAdjacent = batch.getAdjacent(contentElement), _batch$getAdjacent2 = _slicedToArray(_batch$getAdjacent, 2), before = _batch$getAdjacent2[0], after = _batch$getAdjacent2[1]; var range = createRange(batch, contentElement); var beforeLength = before ? batch.getLength(before) : 0; contentElement = batch.maybeMerge(contentElement, after) || contentElement; var mergedContentElement = batch.maybeMerge(before, contentElement); if (mergedContentElement) { return [mergedContentElement, translateRange(range, beforeLength)]; } return [contentElement, range]; } function createRange(batch, contentElement) { return batch.getLength(contentElement) ? [0, batch.getLength(contentElement)] : undefined; } function translateRange(range, delta) { return range && [range[0] + delta, range[1] + delta]; } // element (e.g. between two paragraphs of a text block). function insertContentElement(entry, sibling, attributes, _ref) { var at = _ref.at, splitPoint = _ref.splitPoint; var batch = new Batch(entry, sibling.section); if (at === 'split') { batch.split(sibling, splitPoint, { insertAt: 'after' }); } var contentElement = new ContentElement(attributes); contentElement.applyDefaultConfiguration(sibling); if (at === 'before') { batch.insertBefore(sibling, contentElement); } else { batch.insertAfter(sibling, contentElement); } var targetRange; var _maybeMergeWithAdjace = maybeMergeWithAdjacent(batch, contentElement); var _maybeMergeWithAdjace2 = _slicedToArray(_maybeMergeWithAdjace, 2); contentElement = _maybeMergeWithAdjace2[0]; targetRange = _maybeMergeWithAdjace2[1]; batch.save({ success: function success() { entry.trigger('selectContentElement', contentElement, { range: targetRange }); } }); } // moving content elements to "split points" inside content elements // with custom split functions (e.g. between two paragraphs of a text // block). Merge content elements of the same type that become // adjacent by moving a content element away (e.g. two text blocks // surrounding an image that is moved away). function moveContentElement(entry, contentElement, _ref) { var range = _ref.range, sibling = _ref.sibling, at = _ref.at, splitPoint = _ref.splitPoint; var sourceBatch = new Batch(entry, contentElement.section); // If we move content elements between sections, merges will need to // be performed in the section where the content element came from. var targetBatch = sibling.section === contentElement.section ? sourceBatch : new Batch(entry, sibling.section); if (range && !rangeCoversWholeElement(sourceBatch, contentElement, range)) { if (contentElement === sibling && at === 'split') { // If we are moving part of a content element inside the content // element itself, we need to adjust the split point if the // moved range lies above the split point since moving a range // means first extracting/removing it from the source element. var delta = splitPoint > range[0] ? range[1] - range[0] : 0; splitPoint -= delta; } contentElement = extractRange(sourceBatch, contentElement, range); } if (at === 'split') { // When moving a content element to a split point in the adjacent // element below, insert split off element before sibling so that // is can directly be merged again. For example, let X be a // content element in between two text blocks T1 and T2: // // T1 // paragraph A // X // T2 // paragraph B // paragraph C // // When X shall be moved between the two paragraphs of T2, we want // to split off the first paragraph of T2 into a new content // element T3 and move X: // // T1 // T1 paragraph A // X // T3 // T1 paragraph B // T2 // T2 paragraph C // // T3 becomes the new sibling that we want to move X after: // // T1 // T1 paragraph A // T3 // T1 paragraph B // X // T2 // T2 paragraph C // // When we later merge T1 and T3, T1 will be updated making T3 // disappear again without ever persisting it to the server: // // T1 // T1 paragraph A // T1 paragraph B // X // T2 // T2 paragraph C // if (sourceBatch.getAdjacent(contentElement)[1] === sibling) { sibling = targetBatch.split(sibling, splitPoint, { insertAt: 'before' }); } else { targetBatch.split(sibling, splitPoint); } } var _sourceBatch$getAdjac = sourceBatch.getAdjacent(contentElement), _sourceBatch$getAdjac2 = _slicedToArray(_sourceBatch$getAdjac, 2), before = _sourceBatch$getAdjac2[0], after = _sourceBatch$getAdjac2[1]; var targetRange; // Check if element was dragged to same position where it came from. if (!(at === 'before' && !range && sibling === after) && !(at === 'after' && !range && sibling === before)) { sourceBatch.remove(contentElement); if (at === 'before') { targetBatch.insertBefore(sibling, contentElement); } else { targetBatch.insertAfter(sibling, contentElement); } var _maybeMergeWithAdjace = maybeMergeWithAdjacent(targetBatch, contentElement); var _maybeMergeWithAdjace2 = _slicedToArray(_maybeMergeWithAdjace, 2); contentElement = _maybeMergeWithAdjace2[0]; targetRange = _maybeMergeWithAdjace2[1]; sourceBatch.maybeMerge(before, after); } // Dragging an element next to a sticky element, shall make the // moved element sticky as well. copyPositionIfAvailable(targetBatch, contentElement, sibling); targetBatch.saveIfDirty({ success: function success() { entry.trigger('selectContentElement', contentElement, { range: targetRange }); } }); sourceBatch.saveIfDirty(); } function rangeCoversWholeElement(batch, contentElement, range) { return range[0] === 0 && range[1] === batch.getLength(contentElement); } function extractRange(batch, contentElement, range) { var extracted = batch.split(contentElement, range[0]); var suffix = batch.split(extracted, range[1] - range[0]); batch.maybeMerge(contentElement, suffix); return extracted; } function copyPositionIfAvailable(batch, contentElement, sibling) { if (contentElement.getPosition() !== sibling.getPosition() && contentElement.getAvailablePositions().includes(sibling.getPosition())) { batch.markForUpdate(contentElement, _objectSpread2(_objectSpread2({}, contentElement.configuration.toJSON), {}, { position: sibling.getPosition() })); } } // (e.g. two text blocks surrounding a deleted image). function deleteContentElement(entry, contentElement) { var batch = new Batch(entry, contentElement.section); var _batch$getAdjacent = batch.getAdjacent(contentElement), _batch$getAdjacent2 = _slicedToArray(_batch$getAdjacent, 2), before = _batch$getAdjacent2[0], after = _batch$getAdjacent2[1]; batch.remove(contentElement); batch.markForDeletion(contentElement); batch.maybeMerge(before, after); batch.save(); } var ScrolledEntry = Entry.extend({ setupFromEntryTypeSeed: function setupFromEntryTypeSeed(seed) { this.consentVendors = new ConsentVendors({ hostMatchers: seed.consentVendorHostMatchers }); this.contentElements = new ContentElementsCollection(seed.collections.contentElements); this.sections = new SectionsCollection(seed.collections.sections, { contentElements: this.contentElements }); this.chapters = new ChaptersCollection(seed.collections.chapters, { sections: this.sections, entry: this }); this.chapters.parentModel = this; this.sections.sort(); editor$1.failures.watch(this.contentElements); editor$1.failures.watch(this.sections); editor$1.failures.watch(this.chapters); editor$1.savingRecords.watch(this.contentElements); editor$1.savingRecords.watch(this.sections); editor$1.savingRecords.watch(this.chapters); this.scrolledSeed = seed; }, addChapter: function addChapter(attributes) { this.chapters.create(_objectSpread2({ position: this.chapters.length }, attributes), { entry: this, sections: this.sections }); }, insertContentElement: function insertContentElement$1(attributes, _ref) { var _this = this; var id = _ref.id, at = _ref.at, splitPoint = _ref.splitPoint; if (at === 'endOfSection') { var contentElement = new ContentElement(_objectSpread2({ position: this.contentElements.length }, attributes)); contentElement.applyDefaultConfiguration(); this.sections.get(id).contentElements.add(contentElement); contentElement.save(); contentElement.once('sync', function () { _this.trigger('selectContentElement', contentElement); }); } else { insertContentElement(this, this.contentElements.get(id), attributes, { at: at, splitPoint: splitPoint }); } }, moveContentElement: function moveContentElement$1(_ref2, _ref3) { var movedId = _ref2.id, movedRange = _ref2.range; var id = _ref3.id, at = _ref3.at, splitPoint = _ref3.splitPoint; moveContentElement(this, this.contentElements.get(movedId), { range: movedRange, sibling: this.contentElements.get(id), at: at, splitPoint: splitPoint }); }, deleteContentElement: function deleteContentElement$1(id) { deleteContentElement(this, this.contentElements.get(id)); }, getTypographyVariants: function getTypographyVariants(_ref4) { var _this2 = this; var contentElement = _ref4.contentElement, prefix = _ref4.prefix; var typographyRuleNames = Object.keys(this.scrolledSeed.config.theme.options.typography || {}); var legacyTypographyVariants = this.scrolledSeed.legacyTypographyVariants || {}; var rulePrefix = [].concat(_toConsumableArray([contentElement.get('typeName'), prefix].filter(Boolean)), ['']).join('-'); var ruleNames = typographyRuleNames.filter(function (name) { return name.indexOf(rulePrefix) === 0; }).filter(function (name) { return !legacyTypographyVariants[name.split('-').pop()]; }); var values = ruleNames.map(function (name) { return name.split('-').pop(); }); var texts = ruleNames.map(function (name) { return I18n.t("pageflow_scrolled.editor.themes.".concat(_this2.metadata.get('theme_name')) + ".typography_variants.".concat(name), { defaultValue: I18n.t("pageflow_scrolled.editor.typography_variants.".concat(name)) }); }); return [values, texts]; }, createLegacyTypographyVariantDelegator: function createLegacyTypographyVariantDelegator(_ref5) { var model = _ref5.model, paletteColorPropertyName = _ref5.paletteColorPropertyName; var delegator = Object.create(model); var mapping = this.scrolledSeed.legacyTypographyVariants; delegator.get = function (name) { var result = model.get(name); if (name === 'typographyVariant') { return mapping[result] ? mapping[result].variant : result; } else if (name === paletteColorPropertyName) { var _mapping$model$get; return ((_mapping$model$get = mapping[model.get('typographyVariant')]) === null || _mapping$model$get === void 0 ? void 0 : _mapping$model$get.paletteColor) || result; } return result; }; delegator.set = function (name, value) { if (name === paletteColorPropertyName && mapping[model.get('typographyVariant')]) { var _model$set; model.set((_model$set = {}, _defineProperty(_model$set, paletteColorPropertyName, value), _defineProperty(_model$set, "typographyVariant", mapping[model.get('typographyVariant')].variant), _model$set)); } else { model.set.apply(this, arguments); } }; return delegator; }, getContentElementVariants: function getContentElementVariants(_ref6) { var _this3 = this; var contentElement = _ref6.contentElement; var scopeNames = Object.keys(this.scrolledSeed.config.theme.options.properties || {}); var scopeNamePrefix = "".concat(contentElement.get('typeName'), "-"); var matchingScopeNames = scopeNames.filter(function (name) { return name.indexOf(scopeNamePrefix) === 0; }); var values = matchingScopeNames.map(function (name) { return name.replace(scopeNamePrefix, ''); }); var texts = matchingScopeNames.map(function (name) { return I18n.t("pageflow_scrolled.editor.themes.".concat(_this3.metadata.get('theme_name')) + ".content_element_variants.".concat(name), { defaultValue: I18n.t("pageflow_scrolled.editor.content_element_variants.".concat(name)) }); }); return [values, texts]; }, getPaletteColors: function getPaletteColors() { var _this$scrolledSeed$co, _this4 = this; var values = Object.keys(((_this$scrolledSeed$co = this.scrolledSeed.config.theme.options.properties) === null || _this$scrolledSeed$co === void 0 ? void 0 : _this$scrolledSeed$co.root) || {}).filter(function (key) { return key.indexOf('paletteColor') === 0; }).map(function (key) { return dasherize(key.replace('paletteColor', '')); }); var texts = values.map(underscore).map(function (name) { return I18n.t("pageflow_scrolled.editor.themes.".concat(_this4.metadata.get('theme_name')) + ".palette_colors.".concat(name), { defaultValue: I18n.t("pageflow_scrolled.editor.palette_colors.".concat(name)) }); }); return [values, texts]; }, supportsSectionWidths: function supportsSectionWidths() { var _theme$options$proper; var theme = this.scrolledSeed.config.theme; return Object.keys(((_theme$options$proper = theme.options.properties) === null || _theme$options$proper === void 0 ? void 0 : _theme$options$proper.root) || {}).some(function (key) { return key.startsWith('narrowSection'); }); } }); function dasherize(text) { return (text[0] + text.slice(1).replace(/[A-Z]/g, function (match) { return "-".concat(match); })).toLowerCase(); } function underscore(dasherizedWord) { return dasherizedWord.replace(/-/g, '_'); } var ContentElementFileSelectionHandler = function ContentElementFileSelectionHandler(options) { var contentElement = options.entry.contentElements.get(options.id); this.call = function (file) { contentElement.configuration.setReference(options.attributeName, file); }; this.getReferer = function () { return '/scrolled/content_elements/' + contentElement.id; }; }; var css$3 = ".SectionThumbnailView-module_thumbnail__RcXov {\n padding-top: 50%;\n position: relative;\n text-align: initial;\n border: solid 1px var(--ui-on-surface-color-lightest);\n}\n"; var styles$3 = {"thumbnail":"SectionThumbnailView-module_thumbnail__RcXov"}; styleInject(css$3); var SectionThumbnailView = Marionette.ItemView.extend({ template: function template() { return "\n
\n "); }, ui: cssModulesUtils.ui(styles$3, 'thumbnail'), modelEvents: { 'change:id': 'renderThumbnail' }, onRender: function onRender() { var _this = this; this.timeout = setTimeout(function () { _this.renderThumbnail(); }, 100); }, onClose: function onClose() { clearTimeout(this.timeout); ReactDOM.unmountComponentAtNode(this.ui.thumbnail[0]); }, renderThumbnail: function renderThumbnail() { var _this2 = this; if (!this.model.isNew()) { ReactDOM.render(React.createElement(StandaloneSectionThumbnail, { sectionPermaId: this.model.get('permaId'), seed: this.options.entry.scrolledSeed, subscribe: function subscribe(dispatch) { return watchCollections(_this2.options.entry, { dispatch: dispatch }); } }), this.ui.thumbnail[0]); } } }); var img = "data:image/svg+xml,%3csvg aria-hidden='true' focusable='false' data-prefix='fas' data-icon='random' role='img' xmlns='http://www.w3.org/2000/svg' viewBox='0 0 512 512'%3e%3cpath fill='hsla(197%2c 26%25%2c 23%25%2c 0.8)' d='M504.971 359.029c9.373 9.373 9.373 24.569 0 33.941l-80 79.984c-15.01 15.01-40.971 4.49-40.971-16.971V416h-58.785a12.004 12.004 0 0 1-8.773-3.812l-70.556-75.596 53.333-57.143L352 336h32v-39.981c0-21.438 25.943-31.998 40.971-16.971l80 79.981zM12 176h84l52.781 56.551 53.333-57.143-70.556-75.596A11.999 11.999 0 0 0 122.785 96H12c-6.627 0-12 5.373-12 12v56c0 6.627 5.373 12 12 12zm372 0v39.984c0 21.46 25.961 31.98 40.971 16.971l80-79.984c9.373-9.373 9.373-24.569 0-33.941l-80-79.981C409.943 24.021 384 34.582 384 56.019V96h-58.785a12.004 12.004 0 0 0-8.773 3.812L96 336H12c-6.627 0-12 5.373-12 12v56c0 6.627 5.373 12 12 12h110.785c3.326 0 6.503-1.381 8.773-3.812L352 176h32z'%3e%3c/path%3e%3c/svg%3e"; var css$4 = ".icons-module_icon__16IVx::before,\n.icons-module_icon__16IVx::after {\n font-family: \"entypo\";\n}.icons-module_arrowsCcw__3_nrJ,\n.icons-module_attention__1sssG,\n.icons-module_cancel__1PjiX,\n.icons-module_check__3Lkw9,\n.icons-module_drag__p7HUE,\n.icons-module_helpCircled__D_oKU,\n.icons-module_plusCircled__20FlJ,\n.icons-module_rightBold__21WdT,\n.icons-module_rightOpen__9vsOG,\n.icons-module_star__1AEW6,\n.icons-module_starOutlined__1TAng,\n.icons-module_trash__DH1EH {\n}.icons-module_arrowsCcw__3_nrJ::before {\n content: \"\\1F504\";\n}.icons-module_attention__1sssG::before {\n content: \"\\26A0\";\n}.icons-module_cancel__1PjiX::before {\n content: \"\\2715\";\n}.icons-module_check__3Lkw9::before {\n content: \"\\2713\";\n}.icons-module_drag__p7HUE {\n display: flex;\n flex-direction: column;\n align-items: center;\n justify-content: center;\n line-height: 10px;\n}.icons-module_drag__p7HUE::before {\n content: \"\\E75F\";\n}.icons-module_drag__p7HUE::after {\n content: \"\\E75C\";\n}.icons-module_helpCircled__D_oKU::before {\n content: \"\\E704\";\n}.icons-module_plusCircled__20FlJ::before {\n content: \"\\2795\";\n}.icons-module_rightBold__21WdT::before {\n content: \"\\E4AE\";\n}.icons-module_rightOpen__9vsOG::before {\n content: \"\\E75E\"\n}.icons-module_star__1AEW6::before {\n content: \"\\2605\";\n}.icons-module_starOutlined__1TAng::before {\n content: \"\\2606\";\n}.icons-module_trash__DH1EH::before {\n content: \"\\E729\";\n}.icons-module_chrome__1XHpi {\n background: url();\n}.icons-module_edge__2KQ9q {\n background: url();\n}.icons-module_firefox__22UR1 {\n background: url();\n}.icons-module_safari__3nzsc {\n background: url();\n}@-webkit-keyframes animations-module_blink__32C5j {\n 0% {\n opacity: 1;\n }\n 50% {\n opacity: 0.3;\n }\n 100% {\n opacity: 1;\n }\n}@keyframes animations-module_blink__32C5j {\n 0% {\n opacity: 1;\n }\n 50% {\n opacity: 0.3;\n }\n 100% {\n opacity: 1;\n }\n}.animations-module_blink__32C5j {\n -webkit-animation: animations-module_blink__32C5j 1.5s ease infinite;\n animation: animations-module_blink__32C5j 1.5s ease infinite;\n}.outline-module_sectionWithTransition__21DW- {\n margin-top: 20px;\n}.outline-module_chapter__2J-r6:first-child .outline-module_sectionWithTransition__21DW-:first-child {\n margin-top: 0;\n}.outline-module_chapter__2J-r6:first-child .outline-module_sectionWithTransition__21DW-:first-child .outline-module_transition__2Re1s {\n display: none;\n}.outline-module_indicator__2dw_X {\n display: none;\n position: absolute;\n right: 14px;\n top: 7px;\n width: 30px;\n height: 30px;\n font-size: 19px;\n color: var(--ui-primary-color-light);\n}.outline-module_creatingIndicator__3O7Rw {\n}.outline-module_destroyingIndicator__2-mKh {\n}.outline-module_failedIndicator__2QK1F {\n color: var(--ui-error-color);\n}.outline-module_dragHandle__3ATeR {\n opacity: 0.3;\n cursor: move;\n position: absolute;\n top: 0;\n left: 0;\n height: 100%;\n width: 30px;\n transition: opacity 0.1s ease;\n transition-delay: 0.2s;\n}\n\n.SectionItemView-module_root__1Pp0d {\n position: relative;\n border: solid 3px transparent;\n border-radius: 0.25rem;\n padding: 1px;\n margin-left: -6px;\n margin-right: -6px;\n text-align: right;\n}\n\n.SectionItemView-module_withTransition__wCxlq {\n}\n\n.SectionItemView-module_selectable__ACpQE:hover,\n.SectionItemView-module_active__1tLN5 {\n border: solid 3px var(--ui-selection-color);\n}\n\n.SectionItemView-module_thumbnailContainer__1Xe7C {\n position: relative;\n}\n\n.SectionItemView-module_thumbnail__1ecBT {}\n\n.SectionItemView-module_clickMask__2JYEH {\n position: absolute;\n top: 0;\n left: 0;\n bottom: 0;\n right: 0;\n cursor: pointer;\n}\n\n.SectionItemView-module_dragHandle__nY7mf {\n color: var(--ui-on-primary-color);\n text-shadow: 0 0 2px #000;\n}\n\n.SectionItemView-module_invert__XRpuB .SectionItemView-module_dragHandle__nY7mf {\n color: var(--ui-primary-color);\n text-shadow: 0 0 2px #fff;\n}\n\n.SectionItemView-module_inner__MwFda:hover .SectionItemView-module_dragHandle__nY7mf {\n opacity: 1;\n}\n\n.SectionItemView-module_dropDownButton__34CFJ {\n position: absolute;\n top: 4px;\n right: 0;\n z-index: 1;\n}\n\n.SectionItemView-module_dropDownButton__34CFJ button {\n border: 0 !important;\n color: var(--ui-on-primary-color) !important;\n text-shadow: 0 0 2px #000;\n box-shadow: none !important;\n opacity: 0.3;\n transition: opacity 0.1s ease;\n transition-delay: 0.2s;\n}\n\n.SectionItemView-module_invert__XRpuB .SectionItemView-module_dropDownButton__34CFJ button {\n color: var(--ui-primary-color) !important;\n text-shadow: 0 0 2px #fff;\n}\n\n.SectionItemView-module_inner__MwFda:hover .SectionItemView-module_dropDownButton__34CFJ button,\n.SectionItemView-module_dropDownButton__34CFJ button.hover {\n opacity: 1;\n}\n\n.SectionItemView-module_creating__3Pjx9 .SectionItemView-module_dropDownButton__34CFJ,\n.SectionItemView-module_destroying__1m53s .SectionItemView-module_dropDownButton__34CFJ,\n.SectionItemView-module_failed__1CR2R .SectionItemView-module_dropDownButton__34CFJ {\n display: none;\n}\n\n.SectionItemView-module_editTransition__2L7ZU {\n position: absolute;\n bottom: 100%;\n left: 1px;\n width: 100%;\n border: 0;\n background: transparent;\n padding: 5px 5px 5px 2px;\n cursor: pointer;\n color: var(--ui-on-surface-color-light);\n opacity: 0.8;\n text-align: left;\n display: flex;\n gap: 9px;\n}\n\n.SectionItemView-module_editTransition__2L7ZU:hover,\n.SectionItemView-module_editTransition__2L7ZU:focus {\n opacity: 1;\n}\n\n.SectionItemView-module_editTransition__2L7ZU img {\n vertical-align: top;\n}\n\n.SectionItemView-module_transition__8a57E {}\n\n.SectionItemView-module_creating__3Pjx9 .SectionItemView-module_creatingIndicator__1GnKq { display: block; }\n.SectionItemView-module_destroying__1m53s .SectionItemView-module_destroyingIndicator__HtKWF { display: block; }\n.SectionItemView-module_failed__1CR2R .SectionItemView-module_failedIndicator__1HVHn { display: block; }\n\n.SectionItemView-module_creatingIndicator__1GnKq { }\n.SectionItemView-module_destroyingIndicator__HtKWF { }\n.SectionItemView-module_failedIndicator__1HVHn { }\n"; var styles$4 = {"selectionColor":"var(--ui-selection-color)","selectionWidth":"3px","root":"SectionItemView-module_root__1Pp0d","withTransition":"SectionItemView-module_withTransition__wCxlq outline-module_sectionWithTransition__21DW-","selectable":"SectionItemView-module_selectable__ACpQE","active":"SectionItemView-module_active__1tLN5","thumbnailContainer":"SectionItemView-module_thumbnailContainer__1Xe7C","thumbnail":"SectionItemView-module_thumbnail__1ecBT","clickMask":"SectionItemView-module_clickMask__2JYEH","dragHandle":"SectionItemView-module_dragHandle__nY7mf outline-module_dragHandle__3ATeR icons-module_drag__p7HUE icons-module_icon__16IVx","invert":"SectionItemView-module_invert__XRpuB","inner":"SectionItemView-module_inner__MwFda","dropDownButton":"SectionItemView-module_dropDownButton__34CFJ","creating":"SectionItemView-module_creating__3Pjx9","destroying":"SectionItemView-module_destroying__1m53s","failed":"SectionItemView-module_failed__1CR2R","editTransition":"SectionItemView-module_editTransition__2L7ZU outline-module_transition__2Re1s","transition":"SectionItemView-module_transition__8a57E","creatingIndicator":"SectionItemView-module_creatingIndicator__1GnKq outline-module_creatingIndicator__3O7Rw outline-module_indicator__2dw_X icons-module_arrowsCcw__3_nrJ icons-module_icon__16IVx animations-module_blink__32C5j","destroyingIndicator":"SectionItemView-module_destroyingIndicator__HtKWF outline-module_destroyingIndicator__2-mKh outline-module_indicator__2dw_X icons-module_trash__DH1EH icons-module_icon__16IVx animations-module_blink__32C5j","failedIndicator":"SectionItemView-module_failedIndicator__1HVHn outline-module_failedIndicator__2QK1F outline-module_indicator__2dw_X icons-module_attention__1sssG icons-module_icon__16IVx"}; styleInject(css$4); var SectionItemView = Marionette.ItemView.extend({ tagName: 'li', className: "".concat(styles$4.root, " ").concat(styles$4.withTransition), mixins: [modelLifecycleTrackingView({ classNames: styles$4 })], template: function template(data) { return "\n \n
\n
\n
\n
\n
\n
\n
\n
\n \n \n \n
\n "); }, ui: cssModulesUtils.ui(styles$4, 'thumbnail', 'dropDownButton', 'editTransition', 'transition'), events: cssModulesUtils.events(styles$4, { 'click clickMask': function clickClickMask() { this.options.entry.trigger('selectSection', this.model); this.options.entry.trigger('scrollToSection', this.model); }, 'dblclick clickMask': function dblclickClickMask() { this.options.entry.trigger('selectSectionSettings', this.model); this.options.entry.trigger('scrollToSection', this.model); }, 'click editTransition': function clickEditTransition() { this.options.entry.trigger('selectSectionTransition', this.model); this.options.entry.trigger('scrollToSection', this.model); } }), initialize: function initialize() { var _this = this; this.listenTo(this.options.entry, 'change:currentSectionIndex', function () { var active = _this.updateActive(); if (active) { _this.$el[0].scrollIntoView({ block: 'nearest', behavior: 'smooth' }); } }); this.listenTo(this.options.entry.sections, 'add', function () { _this.updateActive(); _this.updateTransition(); }); }, onRender: function onRender() { var _this2 = this; this.updateTransition(); if (this.updateActive()) { setTimeout(function () { return _this2.$el[0].scrollIntoView({ block: 'nearest' }); }, 10); } this.$el.toggleClass(styles$4.invert, !!this.model.configuration.get('invert')); this.subview(new SectionThumbnailView({ el: this.ui.thumbnail, model: this.model, entry: this.options.entry })); var dropDownMenuItems = new Backbone$1.Collection(); dropDownMenuItems.add(new MenuItem({ label: I18n.t('pageflow_scrolled.editor.section_item.duplicate') }, { selected: function selected() { return _this2.model.chapter.duplicateSection(_this2.model); } })); dropDownMenuItems.add(new MenuItem({ label: I18n.t('pageflow_scrolled.editor.section_item.insert_section_above') }, { selected: function selected() { return _this2.model.chapter.insertSection({ before: _this2.model }); } })); dropDownMenuItems.add(new MenuItem({ label: I18n.t('pageflow_scrolled.editor.section_item.insert_section_below') }, { selected: function selected() { return _this2.model.chapter.insertSection({ after: _this2.model }); } })); this.appendSubview(new DropDownButtonView({ items: dropDownMenuItems, alignMenu: 'right', ellipsisIcon: true, openOnClick: true }), { to: this.ui.dropDownButton }); }, updateTransition: function updateTransition() { this.ui.transition.text(I18n.t(this.model.getTransition(), { scope: 'pageflow_scrolled.editor.section_item.transitions' })); }, updateActive: function updateActive() { var active = this.options.entry.sections.indexOf(this.model) === this.options.entry.get('currentSectionIndex'); this.$el.toggleClass(styles$4.active, active); return active; } }); var MenuItem = Backbone$1.Model.extend({ initialize: function initialize(attributes, options) { this.options = options; }, selected: function selected() { this.options.selected(); } }); var css$5 = ".icons-module_icon__16IVx::before,\n.icons-module_icon__16IVx::after {\n font-family: \"entypo\";\n}.icons-module_arrowsCcw__3_nrJ,\n.icons-module_attention__1sssG,\n.icons-module_cancel__1PjiX,\n.icons-module_check__3Lkw9,\n.icons-module_drag__p7HUE,\n.icons-module_helpCircled__D_oKU,\n.icons-module_plusCircled__20FlJ,\n.icons-module_rightBold__21WdT,\n.icons-module_rightOpen__9vsOG,\n.icons-module_star__1AEW6,\n.icons-module_starOutlined__1TAng,\n.icons-module_trash__DH1EH {\n}.icons-module_arrowsCcw__3_nrJ::before {\n content: \"\\1F504\";\n}.icons-module_attention__1sssG::before {\n content: \"\\26A0\";\n}.icons-module_cancel__1PjiX::before {\n content: \"\\2715\";\n}.icons-module_check__3Lkw9::before {\n content: \"\\2713\";\n}.icons-module_drag__p7HUE {\n display: flex;\n flex-direction: column;\n align-items: center;\n justify-content: center;\n line-height: 10px;\n}.icons-module_drag__p7HUE::before {\n content: \"\\E75F\";\n}.icons-module_drag__p7HUE::after {\n content: \"\\E75C\";\n}.icons-module_helpCircled__D_oKU::before {\n content: \"\\E704\";\n}.icons-module_plusCircled__20FlJ::before {\n content: \"\\2795\";\n}.icons-module_rightBold__21WdT::before {\n content: \"\\E4AE\";\n}.icons-module_rightOpen__9vsOG::before {\n content: \"\\E75E\"\n}.icons-module_star__1AEW6::before {\n content: \"\\2605\";\n}.icons-module_starOutlined__1TAng::before {\n content: \"\\2606\";\n}.icons-module_trash__DH1EH::before {\n content: \"\\E729\";\n}.icons-module_chrome__1XHpi {\n background: url();\n}.icons-module_edge__2KQ9q {\n background: url();\n}.icons-module_firefox__22UR1 {\n background: url();\n}.icons-module_safari__3nzsc {\n background: url();\n}@-webkit-keyframes animations-module_blink__32C5j {\n 0% {\n opacity: 1;\n }\n 50% {\n opacity: 0.3;\n }\n 100% {\n opacity: 1;\n }\n}@keyframes animations-module_blink__32C5j {\n 0% {\n opacity: 1;\n }\n 50% {\n opacity: 0.3;\n }\n 100% {\n opacity: 1;\n }\n}.animations-module_blink__32C5j {\n -webkit-animation: animations-module_blink__32C5j 1.5s ease infinite;\n animation: animations-module_blink__32C5j 1.5s ease infinite;\n}.outline-module_sectionWithTransition__21DW- {\n margin-top: 20px;\n}.outline-module_chapter__2J-r6:first-child .outline-module_sectionWithTransition__21DW-:first-child {\n margin-top: 0;\n}.outline-module_chapter__2J-r6:first-child .outline-module_sectionWithTransition__21DW-:first-child .outline-module_transition__2Re1s {\n display: none;\n}.outline-module_indicator__2dw_X {\n display: none;\n position: absolute;\n right: 14px;\n top: 7px;\n width: 30px;\n height: 30px;\n font-size: 19px;\n color: var(--ui-primary-color-light);\n}.outline-module_creatingIndicator__3O7Rw {\n}.outline-module_destroyingIndicator__2-mKh {\n}.outline-module_failedIndicator__2QK1F {\n color: var(--ui-error-color);\n}.outline-module_dragHandle__3ATeR {\n opacity: 0.3;\n cursor: move;\n position: absolute;\n top: 0;\n left: 0;\n height: 100%;\n width: 30px;\n transition: opacity 0.1s ease;\n transition-delay: 0.2s;\n}.buttons-module_primaryIconButton__KHPA9 {\n /* see app/assets/stylesheets/pageflow/editor/composable.scss */\n}.buttons-module_secondaryIconButton__4LT0V {\n /* see app/assets/stylesheets/pageflow/editor/composable.scss */\n}.buttons-module_unstyledButton__3m76W {\n border: 0;\n text-align: initial;\n}.buttons-module_addButton__2pN-g {\n}.buttons-module_cancelButton__1xJCN {\n}.buttons-module_saveButton__1M-qM {\n}.buttons-module_selectFileButton__khOoU {\n}\n\n.ChapterItemView-module_root__19GIF {\n margin-bottom: 10px;\n padding: 0 10px 10px 10px;\n background-color: var(--ui-surface-color);\n border: solid 1px var(--ui-on-surface-color-lighter);\n border-radius: 0.5rem;\n}\n\n.ChapterItemView-module_root__19GIF.ui-sortable-helper {\n box-shadow: var(--ui-box-shadow-xl);\n}\n\n.ChapterItemView-module_selectableHover__222px {\n background-color: var(--ui-selection-color-lighter);\n}\n\n.ChapterItemView-module_link__2dj_z {\n display: block;\n margin: 0 -10px 0 -10px;\n padding: 10px;\n}\n\n.ChapterItemView-module_outlineLink__1rY1x {\n position: relative;\n padding-left: 30px;\n}\n\n.ChapterItemView-module_link__2dj_z::before {\n position: absolute;\n right: 10px;\n top: 7px;\n font-size: 19px;\n color: var(--ui-primary-color-light);\n}\n\n.ChapterItemView-module_dragHandle__GZ6T8 {\n color: var(--ui-on-surface-color-light);\n}\n\n.ChapterItemView-module_link__2dj_z:hover .ChapterItemView-module_dragHandle__GZ6T8 {\n opacity: 1;\n}\n\n.ChapterItemView-module_number__1GjyC {\n font-weight: bold;\n}\n\n.ChapterItemView-module_title__3jVXE {}\n\n.ChapterItemView-module_sections__3zg2a {\n margin: 10px 0 10px 0;\n min-height: 20px;\n}\n\n.ChapterItemView-module_withTransitions__1t9Gv .ChapterItemView-module_sections__3zg2a {\n margin-top: 20px;\n}\n\n.ChapterItemView-module_root__19GIF:first-child .ChapterItemView-module_sections__3zg2a {\n margin-top: 10px;\n}\n\n.ChapterItemView-module_sections__3zg2a > .sortable-placeholder {\n margin-top: 25px;\n margin-bottom: 22px;\n}\n\n.ChapterItemView-module_root__19GIF:first-child .ChapterItemView-module_sections__3zg2a > li:first-child + .sortable-placeholder {\n margin-top: 16px;\n}\n\n.ChapterItemView-module_creating__c1q2b .ChapterItemView-module_creatingIndicator__2zOEN { display: block; }\n.ChapterItemView-module_destroying__2PP1l .ChapterItemView-module_destroyingIndicator__2YZaB { display: block; }\n.ChapterItemView-module_failed__2MtQW .ChapterItemView-module_failedIndicator__2s6Xk { display: block; }\n\n\n.ChapterItemView-module_creatingIndicator__2zOEN { }\n.ChapterItemView-module_destroyingIndicator__2YZaB { }\n.ChapterItemView-module_failedIndicator__2s6Xk { }\n\n.ChapterItemView-module_addSection__3XQvI {\n}\n"; var styles$5 = {"indicatorIconColor":"var(--ui-primary-color-light)","root":"ChapterItemView-module_root__19GIF outline-module_chapter__2J-r6","selectableHover":"ChapterItemView-module_selectableHover__222px","link":"ChapterItemView-module_link__2dj_z","outlineLink":"ChapterItemView-module_outlineLink__1rY1x icons-module_rightOpen__9vsOG icons-module_icon__16IVx ChapterItemView-module_link__2dj_z","dragHandle":"ChapterItemView-module_dragHandle__GZ6T8 outline-module_dragHandle__3ATeR icons-module_drag__p7HUE icons-module_icon__16IVx","number":"ChapterItemView-module_number__1GjyC","title":"ChapterItemView-module_title__3jVXE","sections":"ChapterItemView-module_sections__3zg2a","withTransitions":"ChapterItemView-module_withTransitions__1t9Gv","creating":"ChapterItemView-module_creating__c1q2b","creatingIndicator":"ChapterItemView-module_creatingIndicator__2zOEN outline-module_creatingIndicator__3O7Rw outline-module_indicator__2dw_X icons-module_arrowsCcw__3_nrJ icons-module_icon__16IVx animations-module_blink__32C5j","destroying":"ChapterItemView-module_destroying__2PP1l","destroyingIndicator":"ChapterItemView-module_destroyingIndicator__2YZaB outline-module_destroyingIndicator__2-mKh outline-module_indicator__2dw_X icons-module_trash__DH1EH icons-module_icon__16IVx animations-module_blink__32C5j","failed":"ChapterItemView-module_failed__2MtQW","failedIndicator":"ChapterItemView-module_failedIndicator__2s6Xk outline-module_failedIndicator__2QK1F outline-module_indicator__2dw_X icons-module_attention__1sssG icons-module_icon__16IVx","addSection":"ChapterItemView-module_addSection__3XQvI buttons-module_addButton__2pN-g buttons-module_primaryIconButton__KHPA9 primary_icon_button icons-module_plusCircled__20FlJ icons-module_icon__16IVx"}; styleInject(css$5); var ChapterItemView = Marionette.Layout.extend({ tagName: 'li', className: "".concat(styles$5.root, " ").concat(styles$5.withTransitions), mixins: [modelLifecycleTrackingView({ classNames: styles$5 })], template: function template() { return "\n \n \n \n \n \n \n \n \n\n \n\n ").concat(I18n.t('pageflow_scrolled.editor.chapter_item.add_section'), "\n "); }, ui: cssModulesUtils.ui(styles$5, 'title', 'number', 'sections'), events: cssModulesUtils.events(styles$5, { 'click addSection': function clickAddSection() { this.model.addSection({}, { select: true }); }, 'click link': function clickLink() { if (!this.model.isNew() && !this.model.isDestroying()) { editor$1.navigate('/scrolled/chapters/' + this.model.get('id'), { trigger: true }); } return false; } }), modelEvents: { change: 'update' }, onRender: function onRender() { this.subview(new SortableCollectionView({ el: this.ui.sections, collection: this.model.sections, itemViewConstructor: SectionItemView, itemViewOptions: { entry: this.options.entry }, connectWith: cssModulesUtils.selector(styles$5, 'sections') })); this.update(); }, update: function update() { this.ui.title.text(this.model.configuration.get('title') || I18n.t('pageflow.editor.views.chapter_item_view.unnamed')); this.ui.number.text(I18n.t('pageflow.editor.views.chapter_item_view.chapter') + ' ' + (this.model.get('position') + 1)); } }); var css$6 = ".icons-module_icon__16IVx::before,\n.icons-module_icon__16IVx::after {\n font-family: \"entypo\";\n}.icons-module_arrowsCcw__3_nrJ,\n.icons-module_attention__1sssG,\n.icons-module_cancel__1PjiX,\n.icons-module_check__3Lkw9,\n.icons-module_drag__p7HUE,\n.icons-module_helpCircled__D_oKU,\n.icons-module_plusCircled__20FlJ,\n.icons-module_rightBold__21WdT,\n.icons-module_rightOpen__9vsOG,\n.icons-module_star__1AEW6,\n.icons-module_starOutlined__1TAng,\n.icons-module_trash__DH1EH {\n}.icons-module_arrowsCcw__3_nrJ::before {\n content: \"\\1F504\";\n}.icons-module_attention__1sssG::before {\n content: \"\\26A0\";\n}.icons-module_cancel__1PjiX::before {\n content: \"\\2715\";\n}.icons-module_check__3Lkw9::before {\n content: \"\\2713\";\n}.icons-module_drag__p7HUE {\n display: flex;\n flex-direction: column;\n align-items: center;\n justify-content: center;\n line-height: 10px;\n}.icons-module_drag__p7HUE::before {\n content: \"\\E75F\";\n}.icons-module_drag__p7HUE::after {\n content: \"\\E75C\";\n}.icons-module_helpCircled__D_oKU::before {\n content: \"\\E704\";\n}.icons-module_plusCircled__20FlJ::before {\n content: \"\\2795\";\n}.icons-module_rightBold__21WdT::before {\n content: \"\\E4AE\";\n}.icons-module_rightOpen__9vsOG::before {\n content: \"\\E75E\"\n}.icons-module_star__1AEW6::before {\n content: \"\\2605\";\n}.icons-module_starOutlined__1TAng::before {\n content: \"\\2606\";\n}.icons-module_trash__DH1EH::before {\n content: \"\\E729\";\n}.icons-module_chrome__1XHpi {\n background: url();\n}.icons-module_edge__2KQ9q {\n background: url();\n}.icons-module_firefox__22UR1 {\n background: url();\n}.icons-module_safari__3nzsc {\n background: url();\n}.buttons-module_primaryIconButton__KHPA9 {\n /* see app/assets/stylesheets/pageflow/editor/composable.scss */\n}.buttons-module_secondaryIconButton__4LT0V {\n /* see app/assets/stylesheets/pageflow/editor/composable.scss */\n}.buttons-module_unstyledButton__3m76W {\n border: 0;\n text-align: initial;\n}.buttons-module_addButton__2pN-g {\n}.buttons-module_cancelButton__1xJCN {\n}.buttons-module_saveButton__1M-qM {\n}.buttons-module_selectFileButton__khOoU {\n}\n\n.EntryOutlineView-module_root__3NBUB {}\n\n.EntryOutlineView-module_chapters__3Gr1l {}\n\n.EntryOutlineView-module_chapters__3Gr1l > .sortable-placeholder {\n margin-bottom: 12px;\n padding: 0 10px 10px 10px;\n border-radius: 0.5rem;\n}\n\n.EntryOutlineView-module_addChapter__3_M-b {\n}\n"; var styles$6 = {"root":"EntryOutlineView-module_root__3NBUB","chapters":"EntryOutlineView-module_chapters__3Gr1l","addChapter":"EntryOutlineView-module_addChapter__3_M-b buttons-module_addButton__2pN-g buttons-module_primaryIconButton__KHPA9 primary_icon_button icons-module_plusCircled__20FlJ icons-module_icon__16IVx"}; styleInject(css$6); var EntryOutlineView = Marionette.Layout.extend({ tagName: 'nav', className: styles$6.root, template: function template() { return "\n

".concat(I18n.t('pageflow_scrolled.editor.entry_outline.header'), "

\n \n\n \n ").concat(I18n.t('pageflow_scrolled.editor.entry_outline.add_chapter'), "\n \n "); }, ui: cssModulesUtils.ui(styles$6, 'chapters'), events: cssModulesUtils.events(styles$6, { 'click addChapter': function clickAddChapter() { this.options.entry.addChapter(); } }), onRender: function onRender() { this.subview(new SortableCollectionView({ el: this.ui.chapters, collection: this.options.entry.chapters, itemViewConstructor: ChapterItemView, itemViewOptions: { entry: this.options.entry } })); } }); var css$7 = ".icons-module_icon__16IVx::before,\n.icons-module_icon__16IVx::after {\n font-family: \"entypo\";\n}.icons-module_arrowsCcw__3_nrJ,\n.icons-module_attention__1sssG,\n.icons-module_cancel__1PjiX,\n.icons-module_check__3Lkw9,\n.icons-module_drag__p7HUE,\n.icons-module_helpCircled__D_oKU,\n.icons-module_plusCircled__20FlJ,\n.icons-module_rightBold__21WdT,\n.icons-module_rightOpen__9vsOG,\n.icons-module_star__1AEW6,\n.icons-module_starOutlined__1TAng,\n.icons-module_trash__DH1EH {\n}.icons-module_arrowsCcw__3_nrJ::before {\n content: \"\\1F504\";\n}.icons-module_attention__1sssG::before {\n content: \"\\26A0\";\n}.icons-module_cancel__1PjiX::before {\n content: \"\\2715\";\n}.icons-module_check__3Lkw9::before {\n content: \"\\2713\";\n}.icons-module_drag__p7HUE {\n display: flex;\n flex-direction: column;\n align-items: center;\n justify-content: center;\n line-height: 10px;\n}.icons-module_drag__p7HUE::before {\n content: \"\\E75F\";\n}.icons-module_drag__p7HUE::after {\n content: \"\\E75C\";\n}.icons-module_helpCircled__D_oKU::before {\n content: \"\\E704\";\n}.icons-module_plusCircled__20FlJ::before {\n content: \"\\2795\";\n}.icons-module_rightBold__21WdT::before {\n content: \"\\E4AE\";\n}.icons-module_rightOpen__9vsOG::before {\n content: \"\\E75E\"\n}.icons-module_star__1AEW6::before {\n content: \"\\2605\";\n}.icons-module_starOutlined__1TAng::before {\n content: \"\\2606\";\n}.icons-module_trash__DH1EH::before {\n content: \"\\E729\";\n}.icons-module_chrome__1XHpi {\n background: url();\n}.icons-module_edge__2KQ9q {\n background: url();\n}.icons-module_firefox__22UR1 {\n background: url();\n}.icons-module_safari__3nzsc {\n background: url();\n}.buttons-module_primaryIconButton__KHPA9 {\n /* see app/assets/stylesheets/pageflow/editor/composable.scss */\n}.buttons-module_secondaryIconButton__4LT0V {\n /* see app/assets/stylesheets/pageflow/editor/composable.scss */\n}.buttons-module_unstyledButton__3m76W {\n border: 0;\n text-align: initial;\n}.buttons-module_addButton__2pN-g {\n}.buttons-module_cancelButton__1xJCN {\n}.buttons-module_saveButton__1M-qM {\n}.buttons-module_selectFileButton__khOoU {\n}\n\n.dialogView-module_backdrop__2Goe6 {\n position: absolute;\n top: 0;\n left: 0;\n width: 100%;\n height: 100%;\n z-index: 5;\n background-color: var(--ui-backdrop-color);\n display: flex;\n flex-direction: column;\n align-items: center;\n}\n\n.dialogView-module_box__1Tgag {\n padding: 20px;\n margin: 20px 0;\n background-color: var(--ui-surface-color);\n border-radius: 0.25rem;\n box-shadow: var(--ui-box-shadow-md);\n}\n\n.dialogView-module_header__35Taz {\n font-size: 17px;\n font-weight: bold;\n margin: 0 0 10px 0;\n}\n\n.dialogView-module_hint__2_hs9 {\n margin-bottom: 10px;\n}\n\n.dialogView-module_footer__347pC {\n margin-top: 10px;\n clear: left;\n text-align: right;\n}\n\n.dialogView-module_close__EwMQp {\n}\n"; var dialogViewStyles = {"backdrop":"dialogView-module_backdrop__2Goe6","box":"dialogView-module_box__1Tgag","header":"dialogView-module_header__35Taz","hint":"dialogView-module_hint__2_hs9","footer":"dialogView-module_footer__347pC","close":"dialogView-module_close__EwMQp buttons-module_cancelButton__1xJCN buttons-module_secondaryIconButton__4LT0V secondary_icon_button icons-module_cancel__1PjiX icons-module_icon__16IVx"}; styleInject(css$7); var dialogView = { events: cssModulesUtils.events(dialogViewStyles, { 'mousedown backdrop': function mousedownBackdrop() { this.close(); }, 'mousedown box': function mousedownBox(event) { event.stopPropagation(); }, 'click close': function clickClose() { this.close(); } }) }; var css$8 = ".icons-module_icon__16IVx::before,\n.icons-module_icon__16IVx::after {\n font-family: \"entypo\";\n}.icons-module_arrowsCcw__3_nrJ,\n.icons-module_attention__1sssG,\n.icons-module_cancel__1PjiX,\n.icons-module_check__3Lkw9,\n.icons-module_drag__p7HUE,\n.icons-module_helpCircled__D_oKU,\n.icons-module_plusCircled__20FlJ,\n.icons-module_rightBold__21WdT,\n.icons-module_rightOpen__9vsOG,\n.icons-module_star__1AEW6,\n.icons-module_starOutlined__1TAng,\n.icons-module_trash__DH1EH {\n}.icons-module_arrowsCcw__3_nrJ::before {\n content: \"\\1F504\";\n}.icons-module_attention__1sssG::before {\n content: \"\\26A0\";\n}.icons-module_cancel__1PjiX::before {\n content: \"\\2715\";\n}.icons-module_check__3Lkw9::before {\n content: \"\\2713\";\n}.icons-module_drag__p7HUE {\n display: flex;\n flex-direction: column;\n align-items: center;\n justify-content: center;\n line-height: 10px;\n}.icons-module_drag__p7HUE::before {\n content: \"\\E75F\";\n}.icons-module_drag__p7HUE::after {\n content: \"\\E75C\";\n}.icons-module_helpCircled__D_oKU::before {\n content: \"\\E704\";\n}.icons-module_plusCircled__20FlJ::before {\n content: \"\\2795\";\n}.icons-module_rightBold__21WdT::before {\n content: \"\\E4AE\";\n}.icons-module_rightOpen__9vsOG::before {\n content: \"\\E75E\"\n}.icons-module_star__1AEW6::before {\n content: \"\\2605\";\n}.icons-module_starOutlined__1TAng::before {\n content: \"\\2606\";\n}.icons-module_trash__DH1EH::before {\n content: \"\\E729\";\n}.icons-module_chrome__1XHpi {\n background: url();\n}.icons-module_edge__2KQ9q {\n background: url();\n}.icons-module_firefox__22UR1 {\n background: url();\n}.icons-module_safari__3nzsc {\n background: url();\n}.buttons-module_primaryIconButton__KHPA9 {\n /* see app/assets/stylesheets/pageflow/editor/composable.scss */\n}.buttons-module_secondaryIconButton__4LT0V {\n /* see app/assets/stylesheets/pageflow/editor/composable.scss */\n}.buttons-module_unstyledButton__3m76W {\n border: 0;\n text-align: initial;\n}.buttons-module_addButton__2pN-g {\n}.buttons-module_cancelButton__1xJCN {\n}.buttons-module_saveButton__1M-qM {\n}.buttons-module_selectFileButton__khOoU {\n}\n\n.InsertContentElementDialogView-module_box__3sdFf {\n max-width: 580px;\n min-width: 200px;\n width: 70%;\n display: flex;\n flex-direction: column;\n background-color: var(--ui-primary-color);\n color: var(--ui-on-primary-color);\n}\n\n.InsertContentElementDialogView-module_categories__1MuZN {\n padding: 0.25rem 0 0.25rem 0.25rem;\n margin: -0.25rem 0 0.5rem -0.25rem;\n overflow-y: auto;\n}\n\n.InsertContentElementDialogView-module_box__3sdFf .InsertContentElementDialogView-module_categoryName__m5BMX {\n font-weight: 700;\n border-bottom: solid 1px var(--ui-on-primary-color-lighter);\n margin: 0.25rem 0;\n padding-bottom: 0.25rem;\n}\n\n.InsertContentElementDialogView-module_types__1bK1J {\n display: flex;\n flex-wrap: wrap;\n}\n\n.InsertContentElementDialogView-module_item__2kSvL {\n width: 33.3333%;\n}\n\n.InsertContentElementDialogView-module_type__27bal {\n position: relative;\n display: flex;\n flex-direction: column;\n box-sizing: border-box;\n width: 100%;\n height: 100%;\n padding: 0.5rem 0.5rem 0.5rem 2.5rem;\n margin-bottom: 0.25rem;\n color: inherit;\n background-color: transparent;\n}\n\n.InsertContentElementDialogView-module_type__27bal:hover,\n.InsertContentElementDialogView-module_type__27bal:focus {\n background-color: var(--ui-on-primary-color-lightest);\n}\n\n.InsertContentElementDialogView-module_typePictogram__1d_ak {\n position: absolute;\n top: 0.5rem;\n left: 0.5rem;\n opacity: 0.8;\n}\n\n.InsertContentElementDialogView-module_type__27bal:hover .InsertContentElementDialogView-module_typePictogram__1d_ak,\n.InsertContentElementDialogView-module_type__27bal:focus .InsertContentElementDialogView-module_typePictogram__1d_ak {\n opacity: 1;\n}\n\n.InsertContentElementDialogView-module_typeName__1j6nc {\n font-weight: 500;\n}\n\n.InsertContentElementDialogView-module_typeDescription__3yhqS {\n display: block;\n font-size: 11px;\n color: var(--ui-on-primary-color-light);\n margin-top: 0.25rem;\n}\n\n.InsertContentElementDialogView-module_box__3sdFf .InsertContentElementDialogView-module_close__18_6F {\n color: inherit;\n border-color: var(--ui-on-primary-color-lightest);\n}\n\n.InsertContentElementDialogView-module_box__3sdFf .InsertContentElementDialogView-module_close__18_6F:hover {\n border-color: var(--ui-on-primary-color) !important;\n}\n"; var styles$7 = {"box":"InsertContentElementDialogView-module_box__3sdFf","categories":"InsertContentElementDialogView-module_categories__1MuZN","categoryName":"InsertContentElementDialogView-module_categoryName__m5BMX","types":"InsertContentElementDialogView-module_types__1bK1J","item":"InsertContentElementDialogView-module_item__2kSvL","type":"InsertContentElementDialogView-module_type__27bal buttons-module_unstyledButton__3m76W","typePictogram":"InsertContentElementDialogView-module_typePictogram__1d_ak","typeName":"InsertContentElementDialogView-module_typeName__1j6nc","typeDescription":"InsertContentElementDialogView-module_typeDescription__3yhqS","close":"InsertContentElementDialogView-module_close__18_6F"}; styleInject(css$8); var img$1 = "data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 512 512'%3e%3c!--! Font Awesome Pro 6.1.1 by %40fontawesome - https://fontawesome.com License - https://fontawesome.com/license (Commercial License) Copyright 2022 Fonticons%2c Inc. --%3e%3cpath fill='white' d='M411.4 175.5C417.4 185.4 417.5 197.7 411.8 207.8C406.2 217.8 395.5 223.1 384 223.1H192C180.5 223.1 169.8 217.8 164.2 207.8C158.5 197.7 158.6 185.4 164.6 175.5L260.6 15.54C266.3 5.897 276.8 0 288 0C299.2 0 309.7 5.898 315.4 15.54L411.4 175.5zM288 312C288 289.9 305.9 272 328 272H472C494.1 272 512 289.9 512 312V456C512 478.1 494.1 496 472 496H328C305.9 496 288 478.1 288 456V312zM0 384C0 313.3 57.31 256 128 256C198.7 256 256 313.3 256 384C256 454.7 198.7 512 128 512C57.31 512 0 454.7 0 384z'/%3e%3c/svg%3e"; var InsertContentElementDialogView = Marionette.ItemView.extend({ template: function template() { return "\n
\n
\n

").concat(I18n.t('pageflow_scrolled.editor.insert_content_element.header'), "

\n \n\n
\n \n
\n
\n
\n "); }, ui: cssModulesUtils.ui(styles$7, 'categories'), mixins: [dialogView], events: { 'click li button': function clickLiButton() { this.close(); } }, onRender: function onRender() { this.subview(new CollectionView({ el: this.ui.categories, collection: new Backbone$1.Collection(this.options.editor.contentElementTypes.groupedByCategory()), itemViewConstructor: CategoryView, itemViewOptions: { entry: this.options.entry, insertOptions: this.options.insertOptions } })); } }); var CategoryView = Marionette.ItemView.extend({ tagName: 'li', className: styles$7.category, template: function template(_ref) { var displayName = _ref.displayName; return "\n

").concat(displayName, "

\n \n "); }, ui: cssModulesUtils.ui(styles$7, 'types'), onRender: function onRender() { this.subview(new CollectionView({ el: this.ui.types, collection: new Backbone$1.Collection(this.model.get('contentElementTypes')), itemViewConstructor: ItemView, itemViewOptions: { entry: this.options.entry, insertOptions: this.options.insertOptions } })); } }); var ItemView = Marionette.ItemView.extend({ tagName: 'li', className: styles$7.item, template: function template(_ref2) { var displayName = _ref2.displayName, description = _ref2.description, pictogram = _ref2.pictogram; return "\n \n "); }, events: { 'click button': function clickButton() { this.options.entry.insertContentElement({ typeName: this.model.get('typeName') }, this.options.insertOptions); } } }); InsertContentElementDialogView.show = function (options) { var view = new InsertContentElementDialogView(options); app.dialogRegion.show(view.render()); }; var SelectableSectionItemView = Marionette.ItemView.extend({ tagName: 'li', className: "".concat(styles$4.root, " ").concat(styles$4.selectable), template: function template(data) { return "\n
\n
\n \n \n
\n "); }, ui: cssModulesUtils.ui(styles$4, 'thumbnail'), events: _defineProperty({}, "click .".concat(styles$4.clickMask), function click(event) { event.preventDefault(); this.options.onSelect(this.model); }), onRender: function onRender() { this.subview(new SectionThumbnailView({ el: this.ui.thumbnail, model: this.model, entry: this.options.entry })); } }); var SelectableChapterItemView = Marionette.ItemView.extend({ tagName: 'li', className: styles$5.root, template: function template() { return "\n \n \n \n \n\n \n "); }, ui: cssModulesUtils.ui(styles$5, 'title', 'number', 'sections'), events: cssModulesUtils.events(styles$5, { 'click link': function clickLink(event) { event.preventDefault(); return this.options.onSelectChapter(this.model); }, 'mouseenter link': function mouseenterLink() { this.$el.addClass(styles$5.selectableHover); }, 'mouseleave link': function mouseleaveLink() { this.$el.removeClass(styles$5.selectableHover); } }), modelEvents: { change: 'update' }, onRender: function onRender() { this.subview(new CollectionView$1({ el: this.ui.sections, collection: this.model.sections, itemViewConstructor: SelectableSectionItemView, itemViewOptions: { entry: this.options.entry, onSelect: this.options.onSelectSection } })); this.update(); }, update: function update() { this.ui.title.text(this.model.configuration.get('title') || I18n.t('pageflow.editor.views.chapter_item_view.unnamed')); this.ui.number.text(I18n.t('pageflow.editor.views.chapter_item_view.chapter') + ' ' + (this.model.get('position') + 1)); } }); var css$9 = ".SelectableEntryOutlineView-module_chapters__2v35W {\n max-width: 300px;\n margin: 0 auto;\n}\n"; var styles$8 = {"chapters":"SelectableEntryOutlineView-module_chapters__2v35W"}; styleInject(css$9); var SelectableEntryOutlineView = Marionette.ItemView.extend({ template: function template() { return "\n \n "); }, ui: cssModulesUtils.ui(styles$8, 'chapters'), onRender: function onRender() { this.subview(new CollectionView$1({ el: this.ui.chapters, collection: this.options.entry.chapters, itemViewConstructor: SelectableChapterItemView, itemViewOptions: { entry: this.options.entry, onSelectChapter: this.options.onSelectChapter, onSelectSection: this.options.onSelectSection } })); } }); var css$a = ".icons-module_icon__16IVx::before,\n.icons-module_icon__16IVx::after {\n font-family: \"entypo\";\n}.icons-module_arrowsCcw__3_nrJ,\n.icons-module_attention__1sssG,\n.icons-module_cancel__1PjiX,\n.icons-module_check__3Lkw9,\n.icons-module_drag__p7HUE,\n.icons-module_helpCircled__D_oKU,\n.icons-module_plusCircled__20FlJ,\n.icons-module_rightBold__21WdT,\n.icons-module_rightOpen__9vsOG,\n.icons-module_star__1AEW6,\n.icons-module_starOutlined__1TAng,\n.icons-module_trash__DH1EH {\n}.icons-module_arrowsCcw__3_nrJ::before {\n content: \"\\1F504\";\n}.icons-module_attention__1sssG::before {\n content: \"\\26A0\";\n}.icons-module_cancel__1PjiX::before {\n content: \"\\2715\";\n}.icons-module_check__3Lkw9::before {\n content: \"\\2713\";\n}.icons-module_drag__p7HUE {\n display: flex;\n flex-direction: column;\n align-items: center;\n justify-content: center;\n line-height: 10px;\n}.icons-module_drag__p7HUE::before {\n content: \"\\E75F\";\n}.icons-module_drag__p7HUE::after {\n content: \"\\E75C\";\n}.icons-module_helpCircled__D_oKU::before {\n content: \"\\E704\";\n}.icons-module_plusCircled__20FlJ::before {\n content: \"\\2795\";\n}.icons-module_rightBold__21WdT::before {\n content: \"\\E4AE\";\n}.icons-module_rightOpen__9vsOG::before {\n content: \"\\E75E\"\n}.icons-module_star__1AEW6::before {\n content: \"\\2605\";\n}.icons-module_starOutlined__1TAng::before {\n content: \"\\2606\";\n}.icons-module_trash__DH1EH::before {\n content: \"\\E729\";\n}.icons-module_chrome__1XHpi {\n background: url();\n}.icons-module_edge__2KQ9q {\n background: url();\n}.icons-module_firefox__22UR1 {\n background: url();\n}.icons-module_safari__3nzsc {\n background: url();\n}.buttons-module_primaryIconButton__KHPA9 {\n /* see app/assets/stylesheets/pageflow/editor/composable.scss */\n}.buttons-module_secondaryIconButton__4LT0V {\n /* see app/assets/stylesheets/pageflow/editor/composable.scss */\n}.buttons-module_unstyledButton__3m76W {\n border: 0;\n text-align: initial;\n}.buttons-module_addButton__2pN-g {\n}.buttons-module_cancelButton__1xJCN {\n}.buttons-module_saveButton__1M-qM {\n}.buttons-module_selectFileButton__khOoU {\n}\n\n.SelectLinkDestinationDialogView-module_box__1mIW3 {\n display: flex;\n flex-direction: column;\n width: 40%;\n min-width: 400px;\n max-width: 700px;\n}\n\n.SelectLinkDestinationDialogView-module_urlContainer__2bty0 {\n display: flex;\n flex-wrap: wrap;\n justify-content: space-between;\n white-space: nowrap;\n}\n\n.SelectLinkDestinationDialogView-module_urlContainer__2bty0 > :first-child {\n width: 100%;\n}\n\n.SelectLinkDestinationDialogView-module_or__3U4Ky {\n position: relative;\n margin: 0 auto 1rem;\n padding: 0 0.5rem;\n color: var(--ui-on-surface-color-light);\n}\n\n.SelectLinkDestinationDialogView-module_or__3U4Ky::before,\n.SelectLinkDestinationDialogView-module_or__3U4Ky::after {\n content: \"\";\n display: block;\n position: absolute;\n top: 50%;\n width: 2rem;\n border-top: solid 1px var(--ui-on-surface-color-lighter);\n}\n\n.SelectLinkDestinationDialogView-module_or__3U4Ky::before {\n right: 100%;\n}\n\n.SelectLinkDestinationDialogView-module_or__3U4Ky::after {\n left: 100%;\n}\n\n.SelectLinkDestinationDialogView-module_urlContainer__2bty0,\n.SelectLinkDestinationDialogView-module_openInNewTabContainer__2R6Ev {\n width: 100%;\n}\n\n.SelectLinkDestinationDialogView-module_createButton__KxILH {\n}\n\n.SelectLinkDestinationDialogView-module_outlineContainer__1niKf {\n width: 100%;\n box-sizing: border-box;\n padding: 0.5rem;\n overflow: auto;\n}\n\n.SelectLinkDestinationDialogView-module_fileContainer__29VBM {\n display: flex;\n flex-wrap: wrap;\n justify-content: space-between;\n margin-bottom: 1rem;\n}\n\n.SelectLinkDestinationDialogView-module_fileContainer__29VBM > :first-child {\n flex: 1\n}\n\n.SelectLinkDestinationDialogView-module_fileTypeButtonContainer__2RVtt {}\n\n.SelectLinkDestinationDialogView-module_fileTypeButton__BWBxM {\n}\n"; var styles$9 = {"box":"SelectLinkDestinationDialogView-module_box__1mIW3","urlContainer":"SelectLinkDestinationDialogView-module_urlContainer__2bty0","or":"SelectLinkDestinationDialogView-module_or__3U4Ky","openInNewTabContainer":"SelectLinkDestinationDialogView-module_openInNewTabContainer__2R6Ev","createButton":"SelectLinkDestinationDialogView-module_createButton__KxILH buttons-module_saveButton__1M-qM buttons-module_primaryIconButton__KHPA9 primary_icon_button icons-module_check__3Lkw9 icons-module_icon__16IVx","outlineContainer":"SelectLinkDestinationDialogView-module_outlineContainer__1niKf","fileContainer":"SelectLinkDestinationDialogView-module_fileContainer__29VBM","fileTypeButtonContainer":"SelectLinkDestinationDialogView-module_fileTypeButtonContainer__2RVtt","fileTypeButton":"SelectLinkDestinationDialogView-module_fileTypeButton__BWBxM buttons-module_selectFileButton__khOoU buttons-module_primaryIconButton__KHPA9 primary_icon_button icons-module_rightOpen__9vsOG icons-module_icon__16IVx"}; styleInject(css$a); var SelectLinkDestinationDialogView = Marionette.ItemView.extend({ template: function template() { return "\n
\n
\n

").concat(I18n.t('pageflow_scrolled.editor.select_link_destination.header'), "

\n\n
\n
\n
\n\n
\n ").concat(I18n.t('pageflow_scrolled.editor.select_link_destination.or'), "\n
\n\n
\n
\n \n
\n ").concat(I18n.t('pageflow_scrolled.editor.select_link_destination.select_file_description'), "\n
\n
\n
\n
\n
\n\n
\n ").concat(I18n.t('pageflow_scrolled.editor.select_link_destination.or'), "\n
\n\n \n
\n\n
\n \n
\n
\n
\n "); }, ui: cssModulesUtils.ui(styles$9, 'urlContainer', 'outlineContainer', 'fileTypeButtonContainer'), mixins: [dialogView], events: cssModulesUtils.events(styles$9, { 'submit urlContainer': function submitUrlContainer(event) { event.preventDefault(); this.createExternalLink(); } }), createExternalLink: function createExternalLink() { if (!this.externalLink.get('url')) { this.$el.find('input[type=text]').focus(); return; } var link = { href: this.externalLink.get('url') }; if (this.externalLink.get('openInNewTab')) { link.openInNewTab = true; } this.options.onSelect(link); this.close(); }, onRender: function onRender() { var _this = this; this.externalLink = new Backbone$1.Model(); this.externalLink.modelName = 'externalLink'; this.ui.urlContainer.prepend(this.subview(new CheckBoxInputView({ model: this.externalLink, propertyName: 'openInNewTab', label: I18n.t('pageflow_scrolled.editor.select_link_destination.open_in_new_tab') })).el); this.ui.urlContainer.prepend(this.subview(new TextInputView({ model: this.externalLink, propertyName: 'url', label: I18n.t('pageflow_scrolled.editor.select_link_destination.enter_url') })).el); this.ui.fileTypeButtonContainer.append(this.subview(new DropDownButtonView({ label: I18n.t('pageflow_scrolled.editor.select_link_destination.select_in_sidebar'), buttonClassName: styles$9.fileTypeButton, alignMenu: 'right', items: new FileTypeItemCollection(this.options.fileTypes.filter(function (fileType) { return fileType.topLevelType; }).map(function (fileType) { return { label: I18n.t("pageflow.editor.file_types.".concat(fileType.collectionName, ".name.one")), collectionName: fileType.collectionName }; }), { onSelect: function onSelect(collectionName) { currentFileSelectionCallback = function currentFileSelectionCallback(file) { _this.options.onSelect({ href: { file: { permaId: file.get('perma_id'), collectionName: utils.camelize(file.fileType().collectionName) } } }); }; editor$1.selectFile({ defaultTab: collectionName }, 'linkDestination', {}); _this.close(); } }) })).el); this.ui.outlineContainer.append(this.subview(new SelectableEntryOutlineView({ entry: this.options.entry, onSelectChapter: function onSelectChapter(chapter) { _this.options.onSelect({ href: { chapter: chapter.get("permaId") } }); _this.close(); }, onSelectSection: function onSelectSection(section) { _this.options.onSelect({ href: { section: section.get("permaId") } }); _this.close(); } })).el); } }); SelectLinkDestinationDialogView.show = function (options) { var view = new SelectLinkDestinationDialogView(_objectSpread2({ fileTypes: editor$1.fileTypes }, options)); app.dialogRegion.show(view.render()); }; var currentFileSelectionCallback; var FileSelectionHandler$1 = function FileSelectionHandler(options) { this.call = function (file) { currentFileSelectionCallback(file); }; this.getReferer = function () { return '/'; }; }; editor$1.registerFileSelectionHandler('linkDestination', FileSelectionHandler$1); var FileTypeItemModel = Backbone$1.Model.extend({ initialize: function initialize(attributes, options) { this.onSelect = options.onSelect; }, selected: function selected() { this.onSelect(this.get('collectionName')); } }); var FileTypeItemCollection = Backbone$1.Collection.extend({ model: FileTypeItemModel }); var PreviewMessageController = Object$1.extend({ initialize: function initialize(_ref) { var entry = _ref.entry, iframeWindow = _ref.iframeWindow, editor = _ref.editor; this.entry = entry; this.iframeWindow = iframeWindow; this.editor = editor; this.listener = this.handleMessage.bind(this); window.addEventListener('message', this.listener); }, dispose: function dispose() { window.removeEventListener('message', this.listener); }, handleMessage: function handleMessage(message) { var _this = this; var postMessage = function postMessage(message) { _this.iframeWindow.postMessage(message, window.location.origin); }; if (window.location.href.indexOf(message.origin) === 0) { if (message.data.type === 'READY') { watchCollections(this.entry, { dispatch: function dispatch(action) { postMessage({ type: 'ACTION', payload: action }); } }); this.listenTo(this.entry, 'scrollToSection', function (section) { return postMessage({ type: 'SCROLL_TO_SECTION', payload: { index: _this.entry.sections.indexOf(section) } }); }); this.listenTo(this.entry.contentElements, 'postCommand', function (contentElementId, command) { return postMessage({ type: 'CONTENT_ELEMENT_EDITOR_COMMAND', payload: { contentElementId: contentElementId, command: command } }); }); this.listenTo(this.entry, 'selectSection', function (section) { return postMessage({ type: 'SELECT', payload: { id: section.id, type: 'section' } }); }); this.listenTo(this.entry, 'selectSectionSettings', function (section) { return postMessage({ type: 'SELECT', payload: { id: section.id, type: 'sectionSettings' } }); }); this.listenTo(this.entry, 'selectSectionTransition', function (section) { return postMessage({ type: 'SELECT', payload: { id: section.id, type: 'sectionTransition' } }); }); this.listenTo(this.entry, 'selectContentElement', function (contentElement, options) { postMessage({ type: 'SELECT', payload: { id: contentElement.id, range: options === null || options === void 0 ? void 0 : options.range, type: 'contentElement' } }); }); this.listenTo(this.entry, 'resetSelection', function (contentElement) { return postMessage({ type: 'SELECT', payload: null }); }); this.listenTo(this.entry, 'change:emulation_mode', function (entry) { return postMessage({ type: 'CHANGE_EMULATION_MODE', payload: _this.entry.get('emulation_mode') }); }); postMessage({ type: 'ACK' }); } else if (message.data.type === 'CHANGE_SECTION') { this.entry.set('currentSectionIndex', message.data.payload.index); } else if (message.data.type === 'SELECTED') { var _message$data$payload = message.data.payload, type = _message$data$payload.type, id = _message$data$payload.id; if (type === 'contentElement') { this.editor.navigate("/scrolled/content_elements/".concat(id), { trigger: true }); } else if (type === 'sectionSettings') { this.editor.navigate("/scrolled/sections/".concat(id), { trigger: true }); } else if (type === 'sectionTransition') { this.editor.navigate("/scrolled/sections/".concat(id, "/transition"), { trigger: true }); } else { this.editor.navigate('/', { trigger: true }); } } else if (message.data.type === 'SELECT_LINK_DESTINATION') { SelectLinkDestinationDialogView.show({ entry: this.entry, onSelect: function onSelect(result) { postMessage({ type: 'LINK_DESTINATION_SELECTED', payload: result }); } }); } else if (message.data.type === 'INSERT_CONTENT_ELEMENT') { var _message$data$payload2 = message.data.payload, _id = _message$data$payload2.id, at = _message$data$payload2.at, splitPoint = _message$data$payload2.splitPoint; InsertContentElementDialogView.show({ entry: this.entry, insertOptions: { at: at, id: _id, splitPoint: splitPoint }, editor: this.editor }); } else if (message.data.type === 'MOVE_CONTENT_ELEMENT') { var _message$data$payload3 = message.data.payload, _id2 = _message$data$payload3.id, range = _message$data$payload3.range, to = _message$data$payload3.to; this.entry.moveContentElement({ id: _id2, range: range }, to); } else if (message.data.type === 'UPDATE_CONTENT_ELEMENT') { var _message$data$payload4 = message.data.payload, _id3 = _message$data$payload4.id, configuration = _message$data$payload4.configuration; this.entry.contentElements.get(_id3).configuration.set(configuration, { ignoreInWatchCollection: true }); } else if (message.data.type === 'UPDATE_TRANSIENT_CONTENT_ELEMENT_STATE') { var _message$data$payload5 = message.data.payload, _id4 = _message$data$payload5.id, state = _message$data$payload5.state; this.entry.contentElements.get(_id4).set('transientState', state); } else if (message.data.type === 'SAVED_SCROLL_POINT' && this.currentScrollPointCallback) { this.currentScrollPointCallback(); this.currentScrollPointCallback = null; setTimeout(function () { return postMessage({ type: 'RESTORE_SCROLL_POINT' }); }, 100); } } }, preserveScrollPoint: function preserveScrollPoint(callback) { this.currentScrollPointCallback = callback; this.iframeWindow.postMessage({ type: 'SAVE_SCROLL_POINT' }, window.location.origin); } }); var css$b = ".BlankEntryView-module_blankEntry__2FcvR {\n position: absolute;\n top: 0;\n left: 0;\n bottom: 0;\n right: 0;\n background-color: #ffff;\n color: #000;\n}\n"; var styles$a = {"blankEntry":"BlankEntryView-module_blankEntry__2FcvR"}; styleInject(css$b); var BlankEntryView = Marionette.ItemView.extend({ template: function template() { return "\n
\n

".concat(t('pageflow_scrolled.editor.blank_entry.header'), "

\n

").concat(t('pageflow_scrolled.editor.blank_entry.intro'), "

\n
    \n
  1. ").concat(t('pageflow_scrolled.editor.blank_entry.create_chapter'), "
  2. \n
  3. ").concat(t('pageflow_scrolled.editor.blank_entry.create_section'), "
  4. \n
  5. ").concat(t('pageflow_scrolled.editor.blank_entry.create_content_element'), "
  6. \n
\n

").concat(t('pageflow_scrolled.editor.blank_entry.outro'), "

\n
\n "); }, className: styles$a.blankEntry, onRender: function onRender() { this.listenTo(this.model.sections, 'add remove', this.update); this.update(); }, update: function update() { this.$el.toggle(!this.model.sections.length); } }); var css$c = ".EntryPreviewView-module_root__1Nb6e {\n height: 100%;\n width: 100%;\n background-color: #222;\n}\n\n.EntryPreviewView-module_iframe__1leJC {\n border: none;\n width: 100%;\n height: 100%;\n}\n\n.EntryPreviewView-module_phoneEmulationMode__3YXy_ {\n display: flex;\n justify-content: center;\n align-items: center;\n}\n\n.EntryPreviewView-module_phoneEmulationMode__3YXy_ .EntryPreviewView-module_iframe__1leJC {\n width: 400px;\n height: 700px;\n box-shadow: rgba(0, 0, 0, 0.5) 0px 1px 4px 0px;\n}\n"; var styles$b = {"root":"EntryPreviewView-module_root__1Nb6e","iframe":"EntryPreviewView-module_iframe__1leJC","phoneEmulationMode":"EntryPreviewView-module_phoneEmulationMode__3YXy_"}; styleInject(css$c); var EntryPreviewView = Marionette.ItemView.extend({ template: function template() { return "\n