decap-cms-core 3.5.0 → 3.6.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/decap-cms-core.js +10 -10
- package/dist/decap-cms-core.js.map +1 -1
- package/dist/esm/actions/auth.js +22 -37
- package/dist/esm/actions/collections.js +9 -17
- package/dist/esm/actions/config.js +58 -74
- package/dist/esm/actions/deploys.js +10 -17
- package/dist/esm/actions/editorialWorkflow.js +87 -101
- package/dist/esm/actions/entries.js +161 -211
- package/dist/esm/actions/media.js +31 -46
- package/dist/esm/actions/mediaLibrary.js +94 -126
- package/dist/esm/actions/notifications.js +5 -13
- package/dist/esm/actions/search.js +30 -47
- package/dist/esm/actions/status.js +13 -23
- package/dist/esm/actions/waitUntil.js +4 -11
- package/dist/esm/backend.js +132 -148
- package/dist/esm/bootstrap.js +37 -44
- package/dist/esm/components/App/App.js +82 -89
- package/dist/esm/components/App/Header.js +46 -52
- package/dist/esm/components/App/NotFoundPage.js +11 -18
- package/dist/esm/components/Collection/Collection.js +55 -63
- package/dist/esm/components/Collection/CollectionControls.js +15 -22
- package/dist/esm/components/Collection/CollectionSearch.js +35 -42
- package/dist/esm/components/Collection/CollectionTop.js +23 -30
- package/dist/esm/components/Collection/ControlButton.js +10 -16
- package/dist/esm/components/Collection/Entries/Entries.js +24 -31
- package/dist/esm/components/Collection/Entries/EntriesCollection.js +60 -63
- package/dist/esm/components/Collection/Entries/EntriesSearch.js +26 -33
- package/dist/esm/components/Collection/Entries/EntryCard.js +38 -45
- package/dist/esm/components/Collection/Entries/EntryListing.js +24 -32
- package/dist/esm/components/Collection/FilterControl.js +9 -16
- package/dist/esm/components/Collection/GroupControl.js +9 -16
- package/dist/esm/components/Collection/NestedCollection.js +56 -64
- package/dist/esm/components/Collection/Sidebar.js +36 -43
- package/dist/esm/components/Collection/SortControl.js +19 -26
- package/dist/esm/components/Collection/ViewStyleControl.js +17 -24
- package/dist/esm/components/Editor/Editor.js +100 -108
- package/dist/esm/components/Editor/EditorControlPane/EditorControl.js +105 -112
- package/dist/esm/components/Editor/EditorControlPane/EditorControlPane.js +68 -62
- package/dist/esm/components/Editor/EditorControlPane/Widget.js +87 -73
- package/dist/esm/components/Editor/EditorInterface.js +95 -98
- package/dist/esm/components/Editor/EditorPreviewPane/EditorPreview.js +13 -21
- package/dist/esm/components/Editor/EditorPreviewPane/EditorPreviewContent.js +64 -23
- package/dist/esm/components/Editor/EditorPreviewPane/EditorPreviewPane.js +94 -78
- package/dist/esm/components/Editor/EditorPreviewPane/PreviewHOC.js +9 -16
- package/dist/esm/components/Editor/EditorToolbar.js +133 -140
- package/dist/esm/components/Editor/withWorkflow.js +15 -22
- package/dist/esm/components/EditorWidgets/Unknown/UnknownControl.js +9 -16
- package/dist/esm/components/EditorWidgets/Unknown/UnknownPreview.js +9 -16
- package/dist/esm/components/EditorWidgets/index.js +4 -7
- package/dist/esm/components/MediaLibrary/EmptyMessage.js +12 -19
- package/dist/esm/components/MediaLibrary/MediaLibrary.js +55 -62
- package/dist/esm/components/MediaLibrary/MediaLibraryButtons.js +28 -35
- package/dist/esm/components/MediaLibrary/MediaLibraryCard.js +36 -43
- package/dist/esm/components/MediaLibrary/MediaLibraryCardGrid.js +50 -57
- package/dist/esm/components/MediaLibrary/MediaLibraryHeader.js +16 -23
- package/dist/esm/components/MediaLibrary/MediaLibraryModal.js +59 -64
- package/dist/esm/components/MediaLibrary/MediaLibrarySearch.js +18 -25
- package/dist/esm/components/MediaLibrary/MediaLibraryTop.js +39 -46
- package/dist/esm/components/UI/DragDrop.js +21 -30
- package/dist/esm/components/UI/ErrorBoundary.js +35 -43
- package/dist/esm/components/UI/FileUploadButton.js +11 -18
- package/dist/esm/components/UI/Modal.js +19 -26
- package/dist/esm/components/UI/Notifications.js +21 -28
- package/dist/esm/components/UI/SettingsDropdown.js +28 -34
- package/dist/esm/components/UI/index.js +6 -60
- package/dist/esm/components/Workflow/Workflow.js +52 -61
- package/dist/esm/components/Workflow/WorkflowCard.js +45 -51
- package/dist/esm/components/Workflow/WorkflowList.js +43 -49
- package/dist/esm/constants/collectionTypes.js +2 -8
- package/dist/esm/constants/collectionViews.js +2 -8
- package/dist/esm/constants/commitProps.js +2 -8
- package/dist/esm/constants/configSchema.js +23 -27
- package/dist/esm/constants/fieldInference.js +8 -15
- package/dist/esm/constants/publishModes.js +6 -11
- package/dist/esm/constants/validationErrorTypes.js +1 -7
- package/dist/esm/formats/formats.js +32 -41
- package/dist/esm/formats/frontmatter.js +18 -30
- package/dist/esm/formats/helpers.js +1 -7
- package/dist/esm/formats/json.js +1 -7
- package/dist/esm/formats/toml.js +11 -18
- package/dist/esm/formats/yaml.js +7 -14
- package/dist/esm/index.js +5 -12
- package/dist/esm/integrations/index.js +8 -16
- package/dist/esm/integrations/providers/algolia/implementation.js +14 -22
- package/dist/esm/integrations/providers/assetStore/implementation.js +10 -18
- package/dist/esm/lib/consoleError.js +1 -7
- package/dist/esm/lib/formatters.js +34 -47
- package/dist/esm/lib/i18n.js +37 -66
- package/dist/esm/lib/phrases.js +4 -11
- package/dist/esm/lib/registry.js +40 -75
- package/dist/esm/lib/serializeEntryValues.js +11 -18
- package/dist/esm/lib/textHelper.js +1 -7
- package/dist/esm/lib/urlHelper.js +28 -43
- package/dist/esm/mediaLibrary.js +12 -16
- package/dist/esm/reducers/auth.js +10 -16
- package/dist/esm/reducers/collections.js +70 -102
- package/dist/esm/reducers/combinedReducer.js +4 -11
- package/dist/esm/reducers/config.js +11 -19
- package/dist/esm/reducers/cursors.js +12 -18
- package/dist/esm/reducers/deploys.js +8 -15
- package/dist/esm/reducers/editorialWorkflow.js +37 -47
- package/dist/esm/reducers/entries.js +107 -132
- package/dist/esm/reducers/entryDraft.js +64 -72
- package/dist/esm/reducers/globalUI.js +5 -11
- package/dist/esm/reducers/index.js +43 -64
- package/dist/esm/reducers/integrations.js +8 -16
- package/dist/esm/reducers/mediaLibrary.js +43 -52
- package/dist/esm/reducers/medias.js +11 -18
- package/dist/esm/reducers/notifications.js +9 -15
- package/dist/esm/reducers/search.js +12 -18
- package/dist/esm/reducers/status.js +7 -13
- package/dist/esm/redux/index.js +7 -13
- package/dist/esm/redux/middleware/waitUntilAction.js +3 -10
- package/dist/esm/routing/history.js +7 -15
- package/dist/esm/types/diacritics.d.js +0 -1
- package/dist/esm/types/global.d.js +1 -5
- package/dist/esm/types/immutable.js +1 -5
- package/dist/esm/types/redux.js +7 -8
- package/dist/esm/types/tomlify-j0.4.d.js +0 -1
- package/dist/esm/valueObjects/AssetProxy.js +2 -10
- package/dist/esm/valueObjects/EditorComponent.js +5 -12
- package/dist/esm/valueObjects/Entry.js +3 -10
- package/index.d.ts +1 -0
- package/package.json +3 -2
- package/src/components/Collection/Entries/EntriesCollection.js +21 -10
- package/src/components/Collection/Entries/__tests__/EntriesCollection.spec.js +7 -7
- package/src/components/Collection/Entries/__tests__/__snapshots__/EntriesCollection.spec.js.snap +9 -9
- package/src/components/Collection/NestedCollection.js +11 -2
- package/src/components/Collection/__tests__/NestedCollection.spec.js +3 -0
- package/src/components/Collection/__tests__/__snapshots__/NestedCollection.spec.js.snap +68 -0
- package/src/components/Editor/EditorControlPane/EditorControl.js +0 -3
- package/src/components/Editor/EditorControlPane/EditorControlPane.js +21 -8
- package/src/components/Editor/EditorControlPane/Widget.js +22 -1
- package/src/components/Editor/EditorInterface.js +6 -1
- package/src/components/Editor/EditorPreviewPane/EditorPreviewContent.js +51 -11
- package/src/components/Editor/EditorPreviewPane/EditorPreviewPane.js +33 -1
- package/src/constants/configSchema.js +1 -0
- package/src/types/redux.ts +1 -1
- package/dist/esm/actions/editorControl.js +0 -14
- package/dist/esm/reducers/editorComponent.js +0 -1
- package/dist/esm/reducers/editorControl.js +0 -17
|
@@ -1,48 +1,40 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
Object.defineProperty(exports, "__esModule", {
|
|
4
|
-
value: true
|
|
5
|
-
});
|
|
6
|
-
exports.default = void 0;
|
|
7
|
-
var _base = _interopRequireDefault(require("@emotion/styled/base"));
|
|
8
|
-
var _propTypes = _interopRequireDefault(require("prop-types"));
|
|
9
|
-
var _react = _interopRequireWildcard(require("react"));
|
|
10
|
-
var _reactImmutableProptypes = _interopRequireDefault(require("react-immutable-proptypes"));
|
|
11
|
-
var _react2 = require("@emotion/react");
|
|
12
|
-
var _reactSplitPane = _interopRequireDefault(require("react-split-pane"));
|
|
13
|
-
var _decapCmsUiDefault = require("decap-cms-ui-default");
|
|
14
|
-
var _reactScrollSync = require("react-scroll-sync");
|
|
15
|
-
var _EditorControlPane = _interopRequireDefault(require("./EditorControlPane/EditorControlPane"));
|
|
16
|
-
var _EditorPreviewPane = _interopRequireDefault(require("./EditorPreviewPane/EditorPreviewPane"));
|
|
17
|
-
var _EditorToolbar = _interopRequireDefault(require("./EditorToolbar"));
|
|
18
|
-
var _i18n = require("../../lib/i18n");
|
|
19
|
-
var _collectionTypes = require("../../constants/collectionTypes");
|
|
20
|
-
var _collections = require("../../reducers/collections");
|
|
21
|
-
function _getRequireWildcardCache(e) { if ("function" != typeof WeakMap) return null; var r = new WeakMap(), t = new WeakMap(); return (_getRequireWildcardCache = function (e) { return e ? t : r; })(e); }
|
|
22
|
-
function _interopRequireWildcard(e, r) { if (!r && e && e.__esModule) return e; if (null === e || "object" != typeof e && "function" != typeof e) return { default: e }; var t = _getRequireWildcardCache(r); if (t && t.has(e)) return t.get(e); var n = { __proto__: null }, a = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var u in e) if ("default" !== u && Object.prototype.hasOwnProperty.call(e, u)) { var i = a ? Object.getOwnPropertyDescriptor(e, u) : null; i && (i.get || i.set) ? Object.defineProperty(n, u, i) : n[u] = e[u]; } return n.default = e, t && t.set(e, n), n; }
|
|
23
|
-
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
|
|
1
|
+
import _styled from "@emotion/styled/base";
|
|
24
2
|
function _extends() { _extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }
|
|
25
3
|
function _defineProperty(obj, key, value) { key = _toPropertyKey(key); if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }
|
|
26
4
|
function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol" == typeof i ? i : String(i); }
|
|
27
5
|
function _toPrimitive(t, r) { if ("object" != typeof t || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || "default"); if ("object" != typeof i) return i; throw new TypeError("@@toPrimitive must return a primitive value."); } return ("string" === r ? String : Number)(t); }
|
|
28
6
|
function _EMOTION_STRINGIFIED_CSS_ERROR__() { return "You have tried to stringify object returned from `css` function. It isn't supposed to be used directly (e.g. as value of the `className` prop), but rather handed to emotion so it can handle it (e.g. as value of `css` prop)."; }
|
|
7
|
+
import PropTypes from 'prop-types';
|
|
8
|
+
import React, { Component } from 'react';
|
|
9
|
+
import ImmutablePropTypes from 'react-immutable-proptypes';
|
|
10
|
+
import { css, Global } from '@emotion/react';
|
|
11
|
+
import SplitPane from 'react-split-pane';
|
|
12
|
+
import { colors, colorsRaw, components, transitions, IconButton, zIndex } from 'decap-cms-ui-default';
|
|
13
|
+
import { ScrollSync, ScrollSyncPane } from 'react-scroll-sync';
|
|
14
|
+
import EditorControlPane from './EditorControlPane/EditorControlPane';
|
|
15
|
+
import EditorPreviewPane from './EditorPreviewPane/EditorPreviewPane';
|
|
16
|
+
import EditorToolbar from './EditorToolbar';
|
|
17
|
+
import { hasI18n, getI18nInfo, getPreviewEntry } from '../../lib/i18n';
|
|
18
|
+
import { FILES } from '../../constants/collectionTypes';
|
|
19
|
+
import { getFileFromSlug } from '../../reducers/collections';
|
|
20
|
+
import { jsx as ___EmotionJSX } from "@emotion/react";
|
|
29
21
|
const PREVIEW_VISIBLE = 'cms.preview-visible';
|
|
30
22
|
const SCROLL_SYNC_ENABLED = 'cms.scroll-sync-enabled';
|
|
31
23
|
const SPLIT_PANE_POSITION = 'cms.split-pane-position';
|
|
32
24
|
const I18N_VISIBLE = 'cms.i18n-visible';
|
|
33
25
|
const styles = {
|
|
34
|
-
splitPane: /*#__PURE__*/(0, _react2.css)(_decapCmsUiDefault.components.card, ";border-radius:0;height:100%;;label:splitPane;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/Editor/EditorInterface.js"],"names":[],"mappings":"AA6BgB","file":"../../../../src/components/Editor/EditorInterface.js","sourcesContent":["import PropTypes from 'prop-types';\nimport React, { Component } from 'react';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\nimport { css, Global } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport SplitPane from 'react-split-pane';\nimport {\n  colors,\n  colorsRaw,\n  components,\n  transitions,\n  IconButton,\n  zIndex,\n} from 'decap-cms-ui-default';\nimport { ScrollSync, ScrollSyncPane } from 'react-scroll-sync';\n\nimport EditorControlPane from './EditorControlPane/EditorControlPane';\nimport EditorPreviewPane from './EditorPreviewPane/EditorPreviewPane';\nimport EditorToolbar from './EditorToolbar';\nimport { hasI18n, getI18nInfo, getPreviewEntry } from '../../lib/i18n';\nimport { FILES } from '../../constants/collectionTypes';\nimport { getFileFromSlug } from '../../reducers/collections';\n\nconst PREVIEW_VISIBLE = 'cms.preview-visible';\nconst SCROLL_SYNC_ENABLED = 'cms.scroll-sync-enabled';\nconst SPLIT_PANE_POSITION = 'cms.split-pane-position';\nconst I18N_VISIBLE = 'cms.i18n-visible';\n\nconst styles = {\n  splitPane: css`\n    ${components.card};\n    border-radius: 0;\n    height: 100%;\n  `,\n  pane: css`\n    height: 100%;\n    overflow-y: auto;\n  `,\n};\n\nconst EditorToggle = styled(IconButton)`\n  margin-bottom: 12px;\n`;\n\nfunction ReactSplitPaneGlobalStyles() {\n  return (\n    <Global\n      styles={css`\n        .Resizer.vertical {\n          width: 2px;\n          cursor: col-resize;\n          position: relative;\n          background: none;\n\n          &:before {\n            content: '';\n            width: 2px;\n            height: 100%;\n            position: relative;\n            background-color: ${colors.textFieldBorder};\n            display: block;\n            z-index: 10;\n            transition: background-color ${transitions.main};\n          }\n\n          &:hover,\n          &:active {\n            &:before {\n              width: 4px;\n              left: -1px;\n              background-color: ${colorsRaw.blue};\n            }\n          }\n        }\n      `}\n    />\n  );\n}\n\nconst StyledSplitPane = styled(SplitPane)`\n  ${styles.splitPane};\n\n  /**\n   * Quick fix for preview pane not fully displaying in Safari\n   */\n  .Pane {\n    height: 100%;\n  }\n`;\n\nconst NoPreviewContainer = styled.div`\n  ${styles.splitPane};\n`;\n\nconst EditorContainer = styled.div`\n  width: 100%;\n  min-width: 800px;\n  height: 100%;\n  position: absolute;\n  top: 0;\n  left: 0;\n  overflow: hidden;\n  padding-top: 66px;\n  background-color: ${colors.background};\n`;\n\nconst Editor = styled.div`\n  height: 100%;\n  margin: 0 auto;\n  position: relative;\n`;\n\nconst PreviewPaneContainer = styled.div`\n  height: 100%;\n  pointer-events: ${props => (props.blockEntry ? 'none' : 'auto')};\n  overflow-y: ${props => (props.overFlow ? 'auto' : 'hidden')};\n`;\n\nconst ControlPaneContainer = styled(PreviewPaneContainer)`\n  padding: 0 16px;\n  position: relative;\n  overflow-x: hidden;\n`;\n\nconst ViewControls = styled.div`\n  position: absolute;\n  top: 10px;\n  right: 10px;\n  z-index: ${zIndex.zIndex299};\n`;\n\nfunction EditorContent({\n  i18nVisible,\n  previewVisible,\n  editor,\n  editorWithEditor,\n  editorWithPreview,\n}) {\n  if (i18nVisible) {\n    return editorWithEditor;\n  } else if (previewVisible) {\n    return editorWithPreview;\n  } else {\n    return <NoPreviewContainer>{editor}</NoPreviewContainer>;\n  }\n}\n\nfunction isPreviewEnabled(collection, entry) {\n  if (collection.get('type') === FILES) {\n    const file = getFileFromSlug(collection, entry.get('slug'));\n    const previewEnabled = file?.getIn(['editor', 'preview']);\n    if (previewEnabled != null) return previewEnabled;\n  }\n  return collection.getIn(['editor', 'preview'], true);\n}\n\nclass EditorInterface extends Component {\n  state = {\n    showEventBlocker: false,\n    previewVisible: localStorage.getItem(PREVIEW_VISIBLE) !== 'false',\n    scrollSyncEnabled: localStorage.getItem(SCROLL_SYNC_ENABLED) !== 'false',\n    i18nVisible: localStorage.getItem(I18N_VISIBLE) !== 'false',\n  };\n\n  handleSplitPaneDragStart = () => {\n    this.setState({ showEventBlocker: true });\n  };\n\n  handleSplitPaneDragFinished = () => {\n    this.setState({ showEventBlocker: false });\n  };\n\n  handleOnPersist = async (opts = {}) => {\n    const { createNew = false, duplicate = false } = opts;\n    await this.controlPaneRef.switchToDefaultLocale();\n    this.controlPaneRef.validate();\n    this.props.onPersist({ createNew, duplicate });\n  };\n\n  handleOnPublish = async (opts = {}) => {\n    const { createNew = false, duplicate = false } = opts;\n    await this.controlPaneRef.switchToDefaultLocale();\n    this.controlPaneRef.validate();\n    this.props.onPublish({ createNew, duplicate });\n  };\n\n  handleTogglePreview = () => {\n    const newPreviewVisible = !this.state.previewVisible;\n    this.setState({ previewVisible: newPreviewVisible });\n    localStorage.setItem(PREVIEW_VISIBLE, newPreviewVisible);\n  };\n\n  handleToggleScrollSync = () => {\n    const newScrollSyncEnabled = !this.state.scrollSyncEnabled;\n    this.setState({ scrollSyncEnabled: newScrollSyncEnabled });\n    localStorage.setItem(SCROLL_SYNC_ENABLED, newScrollSyncEnabled);\n  };\n\n  handleToggleI18n = () => {\n    const newI18nVisible = !this.state.i18nVisible;\n    this.setState({ i18nVisible: newI18nVisible });\n    localStorage.setItem(I18N_VISIBLE, newI18nVisible);\n  };\n\n  handleLeftPanelLocaleChange = locale => {\n    this.setState({ leftPanelLocale: locale });\n  };\n\n  render() {\n    const {\n      collection,\n      entry,\n      fields,\n      fieldsMetaData,\n      fieldsErrors,\n      onChange,\n      showDelete,\n      onDelete,\n      onDeleteUnpublishedChanges,\n      onChangeStatus,\n      onPublish,\n      unPublish,\n      onDuplicate,\n      onValidate,\n      user,\n      hasChanged,\n      displayUrl,\n      hasWorkflow,\n      useOpenAuthoring,\n      hasUnpublishedChanges,\n      isNewEntry,\n      isModification,\n      currentStatus,\n      onLogoutClick,\n      loadDeployPreview,\n      deployPreview,\n      draftKey,\n      editorBackLink,\n      t,\n    } = this.props;\n\n    const { scrollSyncEnabled, showEventBlocker } = this.state;\n\n    const previewEnabled = isPreviewEnabled(collection, entry);\n\n    const { locales, defaultLocale } = getI18nInfo(this.props.collection);\n    const collectionI18nEnabled = hasI18n(collection) && locales.length > 1;\n    const editorProps = {\n      collection,\n      entry,\n      fields,\n      fieldsMetaData,\n      fieldsErrors,\n      onChange,\n      onValidate,\n    };\n\n    const leftPanelLocale = this.state.leftPanelLocale || locales?.[0];\n    const editor = (\n      <ControlPaneContainer overFlow blockEntry={showEventBlocker}>\n        <EditorControlPane\n          {...editorProps}\n          ref={c => (this.controlPaneRef = c)}\n          locale={leftPanelLocale}\n          t={t}\n          onLocaleChange={this.handleLeftPanelLocaleChange}\n        />\n      </ControlPaneContainer>\n    );\n\n    const editor2 = (\n      <ControlPaneContainer overFlow={!this.state.scrollSyncEnabled} blockEntry={showEventBlocker}>\n        <EditorControlPane {...editorProps} locale={locales?.[1]} t={t} />\n      </ControlPaneContainer>\n    );\n\n    const previewEntry = collectionI18nEnabled\n      ? getPreviewEntry(entry, leftPanelLocale, defaultLocale)\n      : entry;\n\n    const editorWithPreview = (\n      <ScrollSync enabled={this.state.scrollSyncEnabled}>\n        <div>\n          <ReactSplitPaneGlobalStyles />\n          <StyledSplitPane\n            maxSize={-100}\n            minSize={400}\n            defaultSize={parseInt(localStorage.getItem(SPLIT_PANE_POSITION), 10) || '50%'}\n            onChange={size => localStorage.setItem(SPLIT_PANE_POSITION, size)}\n            onDragStarted={this.handleSplitPaneDragStart}\n            onDragFinished={this.handleSplitPaneDragFinished}\n          >\n            <ScrollSyncPane>{editor}</ScrollSyncPane>\n            <PreviewPaneContainer blockEntry={showEventBlocker}>\n              <EditorPreviewPane\n                collection={collection}\n                entry={previewEntry}\n                fields={fields}\n                fieldsMetaData={fieldsMetaData}\n                locale={leftPanelLocale}\n              />\n            </PreviewPaneContainer>\n          </StyledSplitPane>\n        </div>\n      </ScrollSync>\n    );\n\n    const editorWithEditor = (\n      <ScrollSync enabled={this.state.scrollSyncEnabled}>\n        <div>\n          <StyledSplitPane\n            maxSize={-100}\n            defaultSize={parseInt(localStorage.getItem(SPLIT_PANE_POSITION), 10) || '50%'}\n            onChange={size => localStorage.setItem(SPLIT_PANE_POSITION, size)}\n            onDragStarted={this.handleSplitPaneDragStart}\n            onDragFinished={this.handleSplitPaneDragFinished}\n          >\n            <ScrollSyncPane>{editor}</ScrollSyncPane>\n            <ScrollSyncPane>{editor2}</ScrollSyncPane>\n          </StyledSplitPane>\n        </div>\n      </ScrollSync>\n    );\n\n    const i18nVisible = collectionI18nEnabled && this.state.i18nVisible;\n    const previewVisible = previewEnabled && this.state.previewVisible;\n    const scrollSyncVisible = i18nVisible || previewVisible;\n\n    return (\n      <EditorContainer>\n        <EditorToolbar\n          isPersisting={entry.get('isPersisting')}\n          isPublishing={entry.get('isPublishing')}\n          isUpdatingStatus={entry.get('isUpdatingStatus')}\n          isDeleting={entry.get('isDeleting')}\n          onPersist={this.handleOnPersist}\n          onPersistAndNew={() => this.handleOnPersist({ createNew: true })}\n          onPersistAndDuplicate={() => this.handleOnPersist({ createNew: true, duplicate: true })}\n          onDelete={onDelete}\n          onDeleteUnpublishedChanges={onDeleteUnpublishedChanges}\n          onChangeStatus={onChangeStatus}\n          showDelete={showDelete}\n          onPublish={onPublish}\n          unPublish={unPublish}\n          onDuplicate={onDuplicate}\n          onPublishAndNew={() => this.handleOnPublish({ createNew: true })}\n          onPublishAndDuplicate={() => this.handleOnPublish({ createNew: true, duplicate: true })}\n          user={user}\n          hasChanged={hasChanged}\n          displayUrl={displayUrl}\n          collection={collection}\n          hasWorkflow={hasWorkflow}\n          useOpenAuthoring={useOpenAuthoring}\n          hasUnpublishedChanges={hasUnpublishedChanges}\n          isNewEntry={isNewEntry}\n          isModification={isModification}\n          currentStatus={currentStatus}\n          onLogoutClick={onLogoutClick}\n          loadDeployPreview={loadDeployPreview}\n          deployPreview={deployPreview}\n          editorBackLink={editorBackLink}\n        />\n        <Editor key={draftKey}>\n          <ViewControls>\n            {collectionI18nEnabled && (\n              <EditorToggle\n                isActive={i18nVisible}\n                onClick={this.handleToggleI18n}\n                size=\"large\"\n                type=\"page\"\n                title={t('editor.editorInterface.toggleI18n')}\n                marginTop=\"70px\"\n              />\n            )}\n            {previewEnabled && (\n              <EditorToggle\n                isActive={previewVisible}\n                onClick={this.handleTogglePreview}\n                size=\"large\"\n                type=\"eye\"\n                title={t('editor.editorInterface.togglePreview')}\n              />\n            )}\n            {scrollSyncVisible && (\n              <EditorToggle\n                isActive={scrollSyncEnabled}\n                onClick={this.handleToggleScrollSync}\n                size=\"large\"\n                type=\"scroll\"\n                title={t('editor.editorInterface.toggleScrollSync')}\n              />\n            )}\n          </ViewControls>\n          <EditorContent\n            i18nVisible={i18nVisible}\n            previewVisible={previewVisible}\n            editor={editor}\n            editorWithEditor={editorWithEditor}\n            editorWithPreview={editorWithPreview}\n          />\n        </Editor>\n      </EditorContainer>\n    );\n  }\n}\n\nEditorInterface.propTypes = {\n  collection: ImmutablePropTypes.map.isRequired,\n  entry: ImmutablePropTypes.map.isRequired,\n  fields: ImmutablePropTypes.list.isRequired,\n  fieldsMetaData: ImmutablePropTypes.map.isRequired,\n  fieldsErrors: ImmutablePropTypes.map.isRequired,\n  onChange: PropTypes.func.isRequired,\n  onValidate: PropTypes.func.isRequired,\n  onPersist: PropTypes.func.isRequired,\n  showDelete: PropTypes.bool.isRequired,\n  onDelete: PropTypes.func.isRequired,\n  onDeleteUnpublishedChanges: PropTypes.func.isRequired,\n  onPublish: PropTypes.func.isRequired,\n  unPublish: PropTypes.func.isRequired,\n  onDuplicate: PropTypes.func.isRequired,\n  onChangeStatus: PropTypes.func.isRequired,\n  user: PropTypes.object,\n  hasChanged: PropTypes.bool,\n  displayUrl: PropTypes.string,\n  hasWorkflow: PropTypes.bool,\n  useOpenAuthoring: PropTypes.bool,\n  hasUnpublishedChanges: PropTypes.bool,\n  isNewEntry: PropTypes.bool,\n  isModification: PropTypes.bool,\n  currentStatus: PropTypes.string,\n  onLogoutClick: PropTypes.func.isRequired,\n  deployPreview: PropTypes.object,\n  loadDeployPreview: PropTypes.func.isRequired,\n  draftKey: PropTypes.string.isRequired,\n  t: PropTypes.func.isRequired,\n};\n\nexport default EditorInterface;\n"]} */")),
|
|
26
|
+
splitPane: /*#__PURE__*/css(components.card, ";border-radius:0;height:100%;;label:splitPane;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/Editor/EditorInterface.js"],"names":[],"mappings":"AA6BgB","file":"../../../../src/components/Editor/EditorInterface.js","sourcesContent":["import PropTypes from 'prop-types';\nimport React, { Component } from 'react';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\nimport { css, Global } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport SplitPane from 'react-split-pane';\nimport {\n  colors,\n  colorsRaw,\n  components,\n  transitions,\n  IconButton,\n  zIndex,\n} from 'decap-cms-ui-default';\nimport { ScrollSync, ScrollSyncPane } from 'react-scroll-sync';\n\nimport EditorControlPane from './EditorControlPane/EditorControlPane';\nimport EditorPreviewPane from './EditorPreviewPane/EditorPreviewPane';\nimport EditorToolbar from './EditorToolbar';\nimport { hasI18n, getI18nInfo, getPreviewEntry } from '../../lib/i18n';\nimport { FILES } from '../../constants/collectionTypes';\nimport { getFileFromSlug } from '../../reducers/collections';\n\nconst PREVIEW_VISIBLE = 'cms.preview-visible';\nconst SCROLL_SYNC_ENABLED = 'cms.scroll-sync-enabled';\nconst SPLIT_PANE_POSITION = 'cms.split-pane-position';\nconst I18N_VISIBLE = 'cms.i18n-visible';\n\nconst styles = {\n  splitPane: css`\n    ${components.card};\n    border-radius: 0;\n    height: 100%;\n  `,\n  pane: css`\n    height: 100%;\n    overflow-y: auto;\n  `,\n};\n\nconst EditorToggle = styled(IconButton)`\n  margin-bottom: 12px;\n`;\n\nfunction ReactSplitPaneGlobalStyles() {\n  return (\n    <Global\n      styles={css`\n        .Resizer.vertical {\n          width: 2px;\n          cursor: col-resize;\n          position: relative;\n          background: none;\n\n          &:before {\n            content: '';\n            width: 2px;\n            height: 100%;\n            position: relative;\n            background-color: ${colors.textFieldBorder};\n            display: block;\n            z-index: 10;\n            transition: background-color ${transitions.main};\n          }\n\n          &:hover,\n          &:active {\n            &:before {\n              width: 4px;\n              left: -1px;\n              background-color: ${colorsRaw.blue};\n            }\n          }\n        }\n      `}\n    />\n  );\n}\n\nconst StyledSplitPane = styled(SplitPane)`\n  ${styles.splitPane};\n\n  /**\n   * Quick fix for preview pane not fully displaying in Safari\n   */\n  .Pane {\n    height: 100%;\n  }\n`;\n\nconst NoPreviewContainer = styled.div`\n  ${styles.splitPane};\n`;\n\nconst EditorContainer = styled.div`\n  width: 100%;\n  min-width: 800px;\n  height: 100%;\n  position: absolute;\n  top: 0;\n  left: 0;\n  overflow: hidden;\n  padding-top: 66px;\n  background-color: ${colors.background};\n`;\n\nconst Editor = styled.div`\n  height: 100%;\n  margin: 0 auto;\n  position: relative;\n`;\n\nconst PreviewPaneContainer = styled.div`\n  height: 100%;\n  pointer-events: ${props => (props.blockEntry ? 'none' : 'auto')};\n  overflow-y: ${props => (props.overFlow ? 'auto' : 'hidden')};\n`;\n\nconst ControlPaneContainer = styled(PreviewPaneContainer)`\n  padding: 0 16px;\n  position: relative;\n  overflow-x: hidden;\n`;\n\nconst ViewControls = styled.div`\n  position: absolute;\n  top: 10px;\n  right: 10px;\n  z-index: ${zIndex.zIndex299};\n`;\n\nfunction EditorContent({\n  i18nVisible,\n  previewVisible,\n  editor,\n  editorWithEditor,\n  editorWithPreview,\n}) {\n  if (i18nVisible) {\n    return editorWithEditor;\n  } else if (previewVisible) {\n    return editorWithPreview;\n  } else {\n    return <NoPreviewContainer>{editor}</NoPreviewContainer>;\n  }\n}\n\nfunction isPreviewEnabled(collection, entry) {\n  if (collection.get('type') === FILES) {\n    const file = getFileFromSlug(collection, entry.get('slug'));\n    const previewEnabled = file?.getIn(['editor', 'preview']);\n    if (previewEnabled != null) return previewEnabled;\n  }\n  return collection.getIn(['editor', 'preview'], true);\n}\n\nclass EditorInterface extends Component {\n  state = {\n    showEventBlocker: false,\n    previewVisible: localStorage.getItem(PREVIEW_VISIBLE) !== 'false',\n    scrollSyncEnabled: localStorage.getItem(SCROLL_SYNC_ENABLED) !== 'false',\n    i18nVisible: localStorage.getItem(I18N_VISIBLE) !== 'false',\n  };\n\n  handleFieldClick = path => {\n    this.controlPaneRef?.focus(path);\n  };\n\n  handleSplitPaneDragStart = () => {\n    this.setState({ showEventBlocker: true });\n  };\n\n  handleSplitPaneDragFinished = () => {\n    this.setState({ showEventBlocker: false });\n  };\n\n  handleOnPersist = async (opts = {}) => {\n    const { createNew = false, duplicate = false } = opts;\n    await this.controlPaneRef.switchToDefaultLocale();\n    this.controlPaneRef.validate();\n    this.props.onPersist({ createNew, duplicate });\n  };\n\n  handleOnPublish = async (opts = {}) => {\n    const { createNew = false, duplicate = false } = opts;\n    await this.controlPaneRef.switchToDefaultLocale();\n    this.controlPaneRef.validate();\n    this.props.onPublish({ createNew, duplicate });\n  };\n\n  handleTogglePreview = () => {\n    const newPreviewVisible = !this.state.previewVisible;\n    this.setState({ previewVisible: newPreviewVisible });\n    localStorage.setItem(PREVIEW_VISIBLE, newPreviewVisible);\n  };\n\n  handleToggleScrollSync = () => {\n    const newScrollSyncEnabled = !this.state.scrollSyncEnabled;\n    this.setState({ scrollSyncEnabled: newScrollSyncEnabled });\n    localStorage.setItem(SCROLL_SYNC_ENABLED, newScrollSyncEnabled);\n  };\n\n  handleToggleI18n = () => {\n    const newI18nVisible = !this.state.i18nVisible;\n    this.setState({ i18nVisible: newI18nVisible });\n    localStorage.setItem(I18N_VISIBLE, newI18nVisible);\n  };\n\n  handleLeftPanelLocaleChange = locale => {\n    this.setState({ leftPanelLocale: locale });\n  };\n\n  render() {\n    const {\n      collection,\n      entry,\n      fields,\n      fieldsMetaData,\n      fieldsErrors,\n      onChange,\n      showDelete,\n      onDelete,\n      onDeleteUnpublishedChanges,\n      onChangeStatus,\n      onPublish,\n      unPublish,\n      onDuplicate,\n      onValidate,\n      user,\n      hasChanged,\n      displayUrl,\n      hasWorkflow,\n      useOpenAuthoring,\n      hasUnpublishedChanges,\n      isNewEntry,\n      isModification,\n      currentStatus,\n      onLogoutClick,\n      loadDeployPreview,\n      deployPreview,\n      draftKey,\n      editorBackLink,\n      t,\n    } = this.props;\n\n    const { scrollSyncEnabled, showEventBlocker } = this.state;\n\n    const previewEnabled = isPreviewEnabled(collection, entry);\n\n    const { locales, defaultLocale } = getI18nInfo(this.props.collection);\n    const collectionI18nEnabled = hasI18n(collection) && locales.length > 1;\n    const editorProps = {\n      collection,\n      entry,\n      fields,\n      fieldsMetaData,\n      fieldsErrors,\n      onChange,\n      onValidate,\n    };\n\n    const leftPanelLocale = this.state.leftPanelLocale || locales?.[0];\n    const editor = (\n      <ControlPaneContainer overFlow blockEntry={showEventBlocker}>\n        <EditorControlPane\n          {...editorProps}\n          ref={c => (this.controlPaneRef = c)}\n          locale={leftPanelLocale}\n          t={t}\n          onLocaleChange={this.handleLeftPanelLocaleChange}\n        />\n      </ControlPaneContainer>\n    );\n\n    const editor2 = (\n      <ControlPaneContainer overFlow={!this.state.scrollSyncEnabled} blockEntry={showEventBlocker}>\n        <EditorControlPane {...editorProps} locale={locales?.[1]} t={t} />\n      </ControlPaneContainer>\n    );\n\n    const previewEntry = collectionI18nEnabled\n      ? getPreviewEntry(entry, leftPanelLocale, defaultLocale)\n      : entry;\n\n    const editorWithPreview = (\n      <ScrollSync enabled={this.state.scrollSyncEnabled}>\n        <div>\n          <ReactSplitPaneGlobalStyles />\n          <StyledSplitPane\n            maxSize={-100}\n            minSize={400}\n            defaultSize={parseInt(localStorage.getItem(SPLIT_PANE_POSITION), 10) || '50%'}\n            onChange={size => localStorage.setItem(SPLIT_PANE_POSITION, size)}\n            onDragStarted={this.handleSplitPaneDragStart}\n            onDragFinished={this.handleSplitPaneDragFinished}\n          >\n            <ScrollSyncPane>{editor}</ScrollSyncPane>\n            <PreviewPaneContainer blockEntry={showEventBlocker}>\n              <EditorPreviewPane\n                collection={collection}\n                entry={previewEntry}\n                fields={fields}\n                fieldsMetaData={fieldsMetaData}\n                locale={leftPanelLocale}\n                onFieldClick={this.handleFieldClick}\n              />\n            </PreviewPaneContainer>\n          </StyledSplitPane>\n        </div>\n      </ScrollSync>\n    );\n\n    const editorWithEditor = (\n      <ScrollSync enabled={this.state.scrollSyncEnabled}>\n        <div>\n          <StyledSplitPane\n            maxSize={-100}\n            defaultSize={parseInt(localStorage.getItem(SPLIT_PANE_POSITION), 10) || '50%'}\n            onChange={size => localStorage.setItem(SPLIT_PANE_POSITION, size)}\n            onDragStarted={this.handleSplitPaneDragStart}\n            onDragFinished={this.handleSplitPaneDragFinished}\n          >\n            <ScrollSyncPane>{editor}</ScrollSyncPane>\n            <ScrollSyncPane>{editor2}</ScrollSyncPane>\n          </StyledSplitPane>\n        </div>\n      </ScrollSync>\n    );\n\n    const i18nVisible = collectionI18nEnabled && this.state.i18nVisible;\n    const previewVisible = previewEnabled && this.state.previewVisible;\n    const scrollSyncVisible = i18nVisible || previewVisible;\n\n    return (\n      <EditorContainer>\n        <EditorToolbar\n          isPersisting={entry.get('isPersisting')}\n          isPublishing={entry.get('isPublishing')}\n          isUpdatingStatus={entry.get('isUpdatingStatus')}\n          isDeleting={entry.get('isDeleting')}\n          onPersist={this.handleOnPersist}\n          onPersistAndNew={() => this.handleOnPersist({ createNew: true })}\n          onPersistAndDuplicate={() => this.handleOnPersist({ createNew: true, duplicate: true })}\n          onDelete={onDelete}\n          onDeleteUnpublishedChanges={onDeleteUnpublishedChanges}\n          onChangeStatus={onChangeStatus}\n          showDelete={showDelete}\n          onPublish={onPublish}\n          unPublish={unPublish}\n          onDuplicate={onDuplicate}\n          onPublishAndNew={() => this.handleOnPublish({ createNew: true })}\n          onPublishAndDuplicate={() => this.handleOnPublish({ createNew: true, duplicate: true })}\n          user={user}\n          hasChanged={hasChanged}\n          displayUrl={displayUrl}\n          collection={collection}\n          hasWorkflow={hasWorkflow}\n          useOpenAuthoring={useOpenAuthoring}\n          hasUnpublishedChanges={hasUnpublishedChanges}\n          isNewEntry={isNewEntry}\n          isModification={isModification}\n          currentStatus={currentStatus}\n          onLogoutClick={onLogoutClick}\n          loadDeployPreview={loadDeployPreview}\n          deployPreview={deployPreview}\n          editorBackLink={editorBackLink}\n        />\n        <Editor key={draftKey}>\n          <ViewControls>\n            {collectionI18nEnabled && (\n              <EditorToggle\n                isActive={i18nVisible}\n                onClick={this.handleToggleI18n}\n                size=\"large\"\n                type=\"page\"\n                title={t('editor.editorInterface.toggleI18n')}\n                marginTop=\"70px\"\n              />\n            )}\n            {previewEnabled && (\n              <EditorToggle\n                isActive={previewVisible}\n                onClick={this.handleTogglePreview}\n                size=\"large\"\n                type=\"eye\"\n                title={t('editor.editorInterface.togglePreview')}\n              />\n            )}\n            {scrollSyncVisible && !collection.getIn(['editor', 'visualEditing']) && (\n              <EditorToggle\n                isActive={scrollSyncEnabled}\n                onClick={this.handleToggleScrollSync}\n                size=\"large\"\n                type=\"scroll\"\n                title={t('editor.editorInterface.toggleScrollSync')}\n              />\n            )}\n          </ViewControls>\n          <EditorContent\n            i18nVisible={i18nVisible}\n            previewVisible={previewVisible}\n            editor={editor}\n            editorWithEditor={editorWithEditor}\n            editorWithPreview={editorWithPreview}\n          />\n        </Editor>\n      </EditorContainer>\n    );\n  }\n}\n\nEditorInterface.propTypes = {\n  collection: ImmutablePropTypes.map.isRequired,\n  entry: ImmutablePropTypes.map.isRequired,\n  fields: ImmutablePropTypes.list.isRequired,\n  fieldsMetaData: ImmutablePropTypes.map.isRequired,\n  fieldsErrors: ImmutablePropTypes.map.isRequired,\n  onChange: PropTypes.func.isRequired,\n  onValidate: PropTypes.func.isRequired,\n  onPersist: PropTypes.func.isRequired,\n  showDelete: PropTypes.bool.isRequired,\n  onDelete: PropTypes.func.isRequired,\n  onDeleteUnpublishedChanges: PropTypes.func.isRequired,\n  onPublish: PropTypes.func.isRequired,\n  unPublish: PropTypes.func.isRequired,\n  onDuplicate: PropTypes.func.isRequired,\n  onChangeStatus: PropTypes.func.isRequired,\n  user: PropTypes.object,\n  hasChanged: PropTypes.bool,\n  displayUrl: PropTypes.string,\n  hasWorkflow: PropTypes.bool,\n  useOpenAuthoring: PropTypes.bool,\n  hasUnpublishedChanges: PropTypes.bool,\n  isNewEntry: PropTypes.bool,\n  isModification: PropTypes.bool,\n  currentStatus: PropTypes.string,\n  onLogoutClick: PropTypes.func.isRequired,\n  deployPreview: PropTypes.object,\n  loadDeployPreview: PropTypes.func.isRequired,\n  draftKey: PropTypes.string.isRequired,\n  t: PropTypes.func.isRequired,\n};\n\nexport default EditorInterface;\n"]} */")),
|
|
35
27
|
pane: process.env.NODE_ENV === "production" ? {
|
|
36
28
|
name: "1yvxf4n-pane",
|
|
37
29
|
styles: "height:100%;overflow-y:auto;label:pane;"
|
|
38
30
|
} : {
|
|
39
31
|
name: "1yvxf4n-pane",
|
|
40
32
|
styles: "height:100%;overflow-y:auto;label:pane;",
|
|
41
|
-
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/Editor/EditorInterface.js"],"names":[],"mappings":"AAkCW","file":"../../../../src/components/Editor/EditorInterface.js","sourcesContent":["import PropTypes from 'prop-types';\nimport React, { Component } from 'react';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\nimport { css, Global } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport SplitPane from 'react-split-pane';\nimport {\n  colors,\n  colorsRaw,\n  components,\n  transitions,\n  IconButton,\n  zIndex,\n} from 'decap-cms-ui-default';\nimport { ScrollSync, ScrollSyncPane } from 'react-scroll-sync';\n\nimport EditorControlPane from './EditorControlPane/EditorControlPane';\nimport EditorPreviewPane from './EditorPreviewPane/EditorPreviewPane';\nimport EditorToolbar from './EditorToolbar';\nimport { hasI18n, getI18nInfo, getPreviewEntry } from '../../lib/i18n';\nimport { FILES } from '../../constants/collectionTypes';\nimport { getFileFromSlug } from '../../reducers/collections';\n\nconst PREVIEW_VISIBLE = 'cms.preview-visible';\nconst SCROLL_SYNC_ENABLED = 'cms.scroll-sync-enabled';\nconst SPLIT_PANE_POSITION = 'cms.split-pane-position';\nconst I18N_VISIBLE = 'cms.i18n-visible';\n\nconst styles = {\n  splitPane: css`\n    ${components.card};\n    border-radius: 0;\n    height: 100%;\n  `,\n  pane: css`\n    height: 100%;\n    overflow-y: auto;\n  `,\n};\n\nconst EditorToggle = styled(IconButton)`\n  margin-bottom: 12px;\n`;\n\nfunction ReactSplitPaneGlobalStyles() {\n  return (\n    <Global\n      styles={css`\n        .Resizer.vertical {\n          width: 2px;\n          cursor: col-resize;\n          position: relative;\n          background: none;\n\n          &:before {\n            content: '';\n            width: 2px;\n            height: 100%;\n            position: relative;\n            background-color: ${colors.textFieldBorder};\n            display: block;\n            z-index: 10;\n            transition: background-color ${transitions.main};\n          }\n\n          &:hover,\n          &:active {\n            &:before {\n              width: 4px;\n              left: -1px;\n              background-color: ${colorsRaw.blue};\n            }\n          }\n        }\n      `}\n    />\n  );\n}\n\nconst StyledSplitPane = styled(SplitPane)`\n  ${styles.splitPane};\n\n  /**\n   * Quick fix for preview pane not fully displaying in Safari\n   */\n  .Pane {\n    height: 100%;\n  }\n`;\n\nconst NoPreviewContainer = styled.div`\n  ${styles.splitPane};\n`;\n\nconst EditorContainer = styled.div`\n  width: 100%;\n  min-width: 800px;\n  height: 100%;\n  position: absolute;\n  top: 0;\n  left: 0;\n  overflow: hidden;\n  padding-top: 66px;\n  background-color: ${colors.background};\n`;\n\nconst Editor = styled.div`\n  height: 100%;\n  margin: 0 auto;\n  position: relative;\n`;\n\nconst PreviewPaneContainer = styled.div`\n  height: 100%;\n  pointer-events: ${props => (props.blockEntry ? 'none' : 'auto')};\n  overflow-y: ${props => (props.overFlow ? 'auto' : 'hidden')};\n`;\n\nconst ControlPaneContainer = styled(PreviewPaneContainer)`\n  padding: 0 16px;\n  position: relative;\n  overflow-x: hidden;\n`;\n\nconst ViewControls = styled.div`\n  position: absolute;\n  top: 10px;\n  right: 10px;\n  z-index: ${zIndex.zIndex299};\n`;\n\nfunction EditorContent({\n  i18nVisible,\n  previewVisible,\n  editor,\n  editorWithEditor,\n  editorWithPreview,\n}) {\n  if (i18nVisible) {\n    return editorWithEditor;\n  } else if (previewVisible) {\n    return editorWithPreview;\n  } else {\n    return <NoPreviewContainer>{editor}</NoPreviewContainer>;\n  }\n}\n\nfunction isPreviewEnabled(collection, entry) {\n  if (collection.get('type') === FILES) {\n    const file = getFileFromSlug(collection, entry.get('slug'));\n    const previewEnabled = file?.getIn(['editor', 'preview']);\n    if (previewEnabled != null) return previewEnabled;\n  }\n  return collection.getIn(['editor', 'preview'], true);\n}\n\nclass EditorInterface extends Component {\n  state = {\n    showEventBlocker: false,\n    previewVisible: localStorage.getItem(PREVIEW_VISIBLE) !== 'false',\n    scrollSyncEnabled: localStorage.getItem(SCROLL_SYNC_ENABLED) !== 'false',\n    i18nVisible: localStorage.getItem(I18N_VISIBLE) !== 'false',\n  };\n\n  handleSplitPaneDragStart = () => {\n    this.setState({ showEventBlocker: true });\n  };\n\n  handleSplitPaneDragFinished = () => {\n    this.setState({ showEventBlocker: false });\n  };\n\n  handleOnPersist = async (opts = {}) => {\n    const { createNew = false, duplicate = false } = opts;\n    await this.controlPaneRef.switchToDefaultLocale();\n    this.controlPaneRef.validate();\n    this.props.onPersist({ createNew, duplicate });\n  };\n\n  handleOnPublish = async (opts = {}) => {\n    const { createNew = false, duplicate = false } = opts;\n    await this.controlPaneRef.switchToDefaultLocale();\n    this.controlPaneRef.validate();\n    this.props.onPublish({ createNew, duplicate });\n  };\n\n  handleTogglePreview = () => {\n    const newPreviewVisible = !this.state.previewVisible;\n    this.setState({ previewVisible: newPreviewVisible });\n    localStorage.setItem(PREVIEW_VISIBLE, newPreviewVisible);\n  };\n\n  handleToggleScrollSync = () => {\n    const newScrollSyncEnabled = !this.state.scrollSyncEnabled;\n    this.setState({ scrollSyncEnabled: newScrollSyncEnabled });\n    localStorage.setItem(SCROLL_SYNC_ENABLED, newScrollSyncEnabled);\n  };\n\n  handleToggleI18n = () => {\n    const newI18nVisible = !this.state.i18nVisible;\n    this.setState({ i18nVisible: newI18nVisible });\n    localStorage.setItem(I18N_VISIBLE, newI18nVisible);\n  };\n\n  handleLeftPanelLocaleChange = locale => {\n    this.setState({ leftPanelLocale: locale });\n  };\n\n  render() {\n    const {\n      collection,\n      entry,\n      fields,\n      fieldsMetaData,\n      fieldsErrors,\n      onChange,\n      showDelete,\n      onDelete,\n      onDeleteUnpublishedChanges,\n      onChangeStatus,\n      onPublish,\n      unPublish,\n      onDuplicate,\n      onValidate,\n      user,\n      hasChanged,\n      displayUrl,\n      hasWorkflow,\n      useOpenAuthoring,\n      hasUnpublishedChanges,\n      isNewEntry,\n      isModification,\n      currentStatus,\n      onLogoutClick,\n      loadDeployPreview,\n      deployPreview,\n      draftKey,\n      editorBackLink,\n      t,\n    } = this.props;\n\n    const { scrollSyncEnabled, showEventBlocker } = this.state;\n\n    const previewEnabled = isPreviewEnabled(collection, entry);\n\n    const { locales, defaultLocale } = getI18nInfo(this.props.collection);\n    const collectionI18nEnabled = hasI18n(collection) && locales.length > 1;\n    const editorProps = {\n      collection,\n      entry,\n      fields,\n      fieldsMetaData,\n      fieldsErrors,\n      onChange,\n      onValidate,\n    };\n\n    const leftPanelLocale = this.state.leftPanelLocale || locales?.[0];\n    const editor = (\n      <ControlPaneContainer overFlow blockEntry={showEventBlocker}>\n        <EditorControlPane\n          {...editorProps}\n          ref={c => (this.controlPaneRef = c)}\n          locale={leftPanelLocale}\n          t={t}\n          onLocaleChange={this.handleLeftPanelLocaleChange}\n        />\n      </ControlPaneContainer>\n    );\n\n    const editor2 = (\n      <ControlPaneContainer overFlow={!this.state.scrollSyncEnabled} blockEntry={showEventBlocker}>\n        <EditorControlPane {...editorProps} locale={locales?.[1]} t={t} />\n      </ControlPaneContainer>\n    );\n\n    const previewEntry = collectionI18nEnabled\n      ? getPreviewEntry(entry, leftPanelLocale, defaultLocale)\n      : entry;\n\n    const editorWithPreview = (\n      <ScrollSync enabled={this.state.scrollSyncEnabled}>\n        <div>\n          <ReactSplitPaneGlobalStyles />\n          <StyledSplitPane\n            maxSize={-100}\n            minSize={400}\n            defaultSize={parseInt(localStorage.getItem(SPLIT_PANE_POSITION), 10) || '50%'}\n            onChange={size => localStorage.setItem(SPLIT_PANE_POSITION, size)}\n            onDragStarted={this.handleSplitPaneDragStart}\n            onDragFinished={this.handleSplitPaneDragFinished}\n          >\n            <ScrollSyncPane>{editor}</ScrollSyncPane>\n            <PreviewPaneContainer blockEntry={showEventBlocker}>\n              <EditorPreviewPane\n                collection={collection}\n                entry={previewEntry}\n                fields={fields}\n                fieldsMetaData={fieldsMetaData}\n                locale={leftPanelLocale}\n              />\n            </PreviewPaneContainer>\n          </StyledSplitPane>\n        </div>\n      </ScrollSync>\n    );\n\n    const editorWithEditor = (\n      <ScrollSync enabled={this.state.scrollSyncEnabled}>\n        <div>\n          <StyledSplitPane\n            maxSize={-100}\n            defaultSize={parseInt(localStorage.getItem(SPLIT_PANE_POSITION), 10) || '50%'}\n            onChange={size => localStorage.setItem(SPLIT_PANE_POSITION, size)}\n            onDragStarted={this.handleSplitPaneDragStart}\n            onDragFinished={this.handleSplitPaneDragFinished}\n          >\n            <ScrollSyncPane>{editor}</ScrollSyncPane>\n            <ScrollSyncPane>{editor2}</ScrollSyncPane>\n          </StyledSplitPane>\n        </div>\n      </ScrollSync>\n    );\n\n    const i18nVisible = collectionI18nEnabled && this.state.i18nVisible;\n    const previewVisible = previewEnabled && this.state.previewVisible;\n    const scrollSyncVisible = i18nVisible || previewVisible;\n\n    return (\n      <EditorContainer>\n        <EditorToolbar\n          isPersisting={entry.get('isPersisting')}\n          isPublishing={entry.get('isPublishing')}\n          isUpdatingStatus={entry.get('isUpdatingStatus')}\n          isDeleting={entry.get('isDeleting')}\n          onPersist={this.handleOnPersist}\n          onPersistAndNew={() => this.handleOnPersist({ createNew: true })}\n          onPersistAndDuplicate={() => this.handleOnPersist({ createNew: true, duplicate: true })}\n          onDelete={onDelete}\n          onDeleteUnpublishedChanges={onDeleteUnpublishedChanges}\n          onChangeStatus={onChangeStatus}\n          showDelete={showDelete}\n          onPublish={onPublish}\n          unPublish={unPublish}\n          onDuplicate={onDuplicate}\n          onPublishAndNew={() => this.handleOnPublish({ createNew: true })}\n          onPublishAndDuplicate={() => this.handleOnPublish({ createNew: true, duplicate: true })}\n          user={user}\n          hasChanged={hasChanged}\n          displayUrl={displayUrl}\n          collection={collection}\n          hasWorkflow={hasWorkflow}\n          useOpenAuthoring={useOpenAuthoring}\n          hasUnpublishedChanges={hasUnpublishedChanges}\n          isNewEntry={isNewEntry}\n          isModification={isModification}\n          currentStatus={currentStatus}\n          onLogoutClick={onLogoutClick}\n          loadDeployPreview={loadDeployPreview}\n          deployPreview={deployPreview}\n          editorBackLink={editorBackLink}\n        />\n        <Editor key={draftKey}>\n          <ViewControls>\n            {collectionI18nEnabled && (\n              <EditorToggle\n                isActive={i18nVisible}\n                onClick={this.handleToggleI18n}\n                size=\"large\"\n                type=\"page\"\n                title={t('editor.editorInterface.toggleI18n')}\n                marginTop=\"70px\"\n              />\n            )}\n            {previewEnabled && (\n              <EditorToggle\n                isActive={previewVisible}\n                onClick={this.handleTogglePreview}\n                size=\"large\"\n                type=\"eye\"\n                title={t('editor.editorInterface.togglePreview')}\n              />\n            )}\n            {scrollSyncVisible && (\n              <EditorToggle\n                isActive={scrollSyncEnabled}\n                onClick={this.handleToggleScrollSync}\n                size=\"large\"\n                type=\"scroll\"\n                title={t('editor.editorInterface.toggleScrollSync')}\n              />\n            )}\n          </ViewControls>\n          <EditorContent\n            i18nVisible={i18nVisible}\n            previewVisible={previewVisible}\n            editor={editor}\n            editorWithEditor={editorWithEditor}\n            editorWithPreview={editorWithPreview}\n          />\n        </Editor>\n      </EditorContainer>\n    );\n  }\n}\n\nEditorInterface.propTypes = {\n  collection: ImmutablePropTypes.map.isRequired,\n  entry: ImmutablePropTypes.map.isRequired,\n  fields: ImmutablePropTypes.list.isRequired,\n  fieldsMetaData: ImmutablePropTypes.map.isRequired,\n  fieldsErrors: ImmutablePropTypes.map.isRequired,\n  onChange: PropTypes.func.isRequired,\n  onValidate: PropTypes.func.isRequired,\n  onPersist: PropTypes.func.isRequired,\n  showDelete: PropTypes.bool.isRequired,\n  onDelete: PropTypes.func.isRequired,\n  onDeleteUnpublishedChanges: PropTypes.func.isRequired,\n  onPublish: PropTypes.func.isRequired,\n  unPublish: PropTypes.func.isRequired,\n  onDuplicate: PropTypes.func.isRequired,\n  onChangeStatus: PropTypes.func.isRequired,\n  user: PropTypes.object,\n  hasChanged: PropTypes.bool,\n  displayUrl: PropTypes.string,\n  hasWorkflow: PropTypes.bool,\n  useOpenAuthoring: PropTypes.bool,\n  hasUnpublishedChanges: PropTypes.bool,\n  isNewEntry: PropTypes.bool,\n  isModification: PropTypes.bool,\n  currentStatus: PropTypes.string,\n  onLogoutClick: PropTypes.func.isRequired,\n  deployPreview: PropTypes.object,\n  loadDeployPreview: PropTypes.func.isRequired,\n  draftKey: PropTypes.string.isRequired,\n  t: PropTypes.func.isRequired,\n};\n\nexport default EditorInterface;\n"]} */",
|
|
33
|
+
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/Editor/EditorInterface.js"],"names":[],"mappings":"AAkCW","file":"../../../../src/components/Editor/EditorInterface.js","sourcesContent":["import PropTypes from 'prop-types';\nimport React, { Component } from 'react';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\nimport { css, Global } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport SplitPane from 'react-split-pane';\nimport {\n  colors,\n  colorsRaw,\n  components,\n  transitions,\n  IconButton,\n  zIndex,\n} from 'decap-cms-ui-default';\nimport { ScrollSync, ScrollSyncPane } from 'react-scroll-sync';\n\nimport EditorControlPane from './EditorControlPane/EditorControlPane';\nimport EditorPreviewPane from './EditorPreviewPane/EditorPreviewPane';\nimport EditorToolbar from './EditorToolbar';\nimport { hasI18n, getI18nInfo, getPreviewEntry } from '../../lib/i18n';\nimport { FILES } from '../../constants/collectionTypes';\nimport { getFileFromSlug } from '../../reducers/collections';\n\nconst PREVIEW_VISIBLE = 'cms.preview-visible';\nconst SCROLL_SYNC_ENABLED = 'cms.scroll-sync-enabled';\nconst SPLIT_PANE_POSITION = 'cms.split-pane-position';\nconst I18N_VISIBLE = 'cms.i18n-visible';\n\nconst styles = {\n  splitPane: css`\n    ${components.card};\n    border-radius: 0;\n    height: 100%;\n  `,\n  pane: css`\n    height: 100%;\n    overflow-y: auto;\n  `,\n};\n\nconst EditorToggle = styled(IconButton)`\n  margin-bottom: 12px;\n`;\n\nfunction ReactSplitPaneGlobalStyles() {\n  return (\n    <Global\n      styles={css`\n        .Resizer.vertical {\n          width: 2px;\n          cursor: col-resize;\n          position: relative;\n          background: none;\n\n          &:before {\n            content: '';\n            width: 2px;\n            height: 100%;\n            position: relative;\n            background-color: ${colors.textFieldBorder};\n            display: block;\n            z-index: 10;\n            transition: background-color ${transitions.main};\n          }\n\n          &:hover,\n          &:active {\n            &:before {\n              width: 4px;\n              left: -1px;\n              background-color: ${colorsRaw.blue};\n            }\n          }\n        }\n      `}\n    />\n  );\n}\n\nconst StyledSplitPane = styled(SplitPane)`\n  ${styles.splitPane};\n\n  /**\n   * Quick fix for preview pane not fully displaying in Safari\n   */\n  .Pane {\n    height: 100%;\n  }\n`;\n\nconst NoPreviewContainer = styled.div`\n  ${styles.splitPane};\n`;\n\nconst EditorContainer = styled.div`\n  width: 100%;\n  min-width: 800px;\n  height: 100%;\n  position: absolute;\n  top: 0;\n  left: 0;\n  overflow: hidden;\n  padding-top: 66px;\n  background-color: ${colors.background};\n`;\n\nconst Editor = styled.div`\n  height: 100%;\n  margin: 0 auto;\n  position: relative;\n`;\n\nconst PreviewPaneContainer = styled.div`\n  height: 100%;\n  pointer-events: ${props => (props.blockEntry ? 'none' : 'auto')};\n  overflow-y: ${props => (props.overFlow ? 'auto' : 'hidden')};\n`;\n\nconst ControlPaneContainer = styled(PreviewPaneContainer)`\n  padding: 0 16px;\n  position: relative;\n  overflow-x: hidden;\n`;\n\nconst ViewControls = styled.div`\n  position: absolute;\n  top: 10px;\n  right: 10px;\n  z-index: ${zIndex.zIndex299};\n`;\n\nfunction EditorContent({\n  i18nVisible,\n  previewVisible,\n  editor,\n  editorWithEditor,\n  editorWithPreview,\n}) {\n  if (i18nVisible) {\n    return editorWithEditor;\n  } else if (previewVisible) {\n    return editorWithPreview;\n  } else {\n    return <NoPreviewContainer>{editor}</NoPreviewContainer>;\n  }\n}\n\nfunction isPreviewEnabled(collection, entry) {\n  if (collection.get('type') === FILES) {\n    const file = getFileFromSlug(collection, entry.get('slug'));\n    const previewEnabled = file?.getIn(['editor', 'preview']);\n    if (previewEnabled != null) return previewEnabled;\n  }\n  return collection.getIn(['editor', 'preview'], true);\n}\n\nclass EditorInterface extends Component {\n  state = {\n    showEventBlocker: false,\n    previewVisible: localStorage.getItem(PREVIEW_VISIBLE) !== 'false',\n    scrollSyncEnabled: localStorage.getItem(SCROLL_SYNC_ENABLED) !== 'false',\n    i18nVisible: localStorage.getItem(I18N_VISIBLE) !== 'false',\n  };\n\n  handleFieldClick = path => {\n    this.controlPaneRef?.focus(path);\n  };\n\n  handleSplitPaneDragStart = () => {\n    this.setState({ showEventBlocker: true });\n  };\n\n  handleSplitPaneDragFinished = () => {\n    this.setState({ showEventBlocker: false });\n  };\n\n  handleOnPersist = async (opts = {}) => {\n    const { createNew = false, duplicate = false } = opts;\n    await this.controlPaneRef.switchToDefaultLocale();\n    this.controlPaneRef.validate();\n    this.props.onPersist({ createNew, duplicate });\n  };\n\n  handleOnPublish = async (opts = {}) => {\n    const { createNew = false, duplicate = false } = opts;\n    await this.controlPaneRef.switchToDefaultLocale();\n    this.controlPaneRef.validate();\n    this.props.onPublish({ createNew, duplicate });\n  };\n\n  handleTogglePreview = () => {\n    const newPreviewVisible = !this.state.previewVisible;\n    this.setState({ previewVisible: newPreviewVisible });\n    localStorage.setItem(PREVIEW_VISIBLE, newPreviewVisible);\n  };\n\n  handleToggleScrollSync = () => {\n    const newScrollSyncEnabled = !this.state.scrollSyncEnabled;\n    this.setState({ scrollSyncEnabled: newScrollSyncEnabled });\n    localStorage.setItem(SCROLL_SYNC_ENABLED, newScrollSyncEnabled);\n  };\n\n  handleToggleI18n = () => {\n    const newI18nVisible = !this.state.i18nVisible;\n    this.setState({ i18nVisible: newI18nVisible });\n    localStorage.setItem(I18N_VISIBLE, newI18nVisible);\n  };\n\n  handleLeftPanelLocaleChange = locale => {\n    this.setState({ leftPanelLocale: locale });\n  };\n\n  render() {\n    const {\n      collection,\n      entry,\n      fields,\n      fieldsMetaData,\n      fieldsErrors,\n      onChange,\n      showDelete,\n      onDelete,\n      onDeleteUnpublishedChanges,\n      onChangeStatus,\n      onPublish,\n      unPublish,\n      onDuplicate,\n      onValidate,\n      user,\n      hasChanged,\n      displayUrl,\n      hasWorkflow,\n      useOpenAuthoring,\n      hasUnpublishedChanges,\n      isNewEntry,\n      isModification,\n      currentStatus,\n      onLogoutClick,\n      loadDeployPreview,\n      deployPreview,\n      draftKey,\n      editorBackLink,\n      t,\n    } = this.props;\n\n    const { scrollSyncEnabled, showEventBlocker } = this.state;\n\n    const previewEnabled = isPreviewEnabled(collection, entry);\n\n    const { locales, defaultLocale } = getI18nInfo(this.props.collection);\n    const collectionI18nEnabled = hasI18n(collection) && locales.length > 1;\n    const editorProps = {\n      collection,\n      entry,\n      fields,\n      fieldsMetaData,\n      fieldsErrors,\n      onChange,\n      onValidate,\n    };\n\n    const leftPanelLocale = this.state.leftPanelLocale || locales?.[0];\n    const editor = (\n      <ControlPaneContainer overFlow blockEntry={showEventBlocker}>\n        <EditorControlPane\n          {...editorProps}\n          ref={c => (this.controlPaneRef = c)}\n          locale={leftPanelLocale}\n          t={t}\n          onLocaleChange={this.handleLeftPanelLocaleChange}\n        />\n      </ControlPaneContainer>\n    );\n\n    const editor2 = (\n      <ControlPaneContainer overFlow={!this.state.scrollSyncEnabled} blockEntry={showEventBlocker}>\n        <EditorControlPane {...editorProps} locale={locales?.[1]} t={t} />\n      </ControlPaneContainer>\n    );\n\n    const previewEntry = collectionI18nEnabled\n      ? getPreviewEntry(entry, leftPanelLocale, defaultLocale)\n      : entry;\n\n    const editorWithPreview = (\n      <ScrollSync enabled={this.state.scrollSyncEnabled}>\n        <div>\n          <ReactSplitPaneGlobalStyles />\n          <StyledSplitPane\n            maxSize={-100}\n            minSize={400}\n            defaultSize={parseInt(localStorage.getItem(SPLIT_PANE_POSITION), 10) || '50%'}\n            onChange={size => localStorage.setItem(SPLIT_PANE_POSITION, size)}\n            onDragStarted={this.handleSplitPaneDragStart}\n            onDragFinished={this.handleSplitPaneDragFinished}\n          >\n            <ScrollSyncPane>{editor}</ScrollSyncPane>\n            <PreviewPaneContainer blockEntry={showEventBlocker}>\n              <EditorPreviewPane\n                collection={collection}\n                entry={previewEntry}\n                fields={fields}\n                fieldsMetaData={fieldsMetaData}\n                locale={leftPanelLocale}\n                onFieldClick={this.handleFieldClick}\n              />\n            </PreviewPaneContainer>\n          </StyledSplitPane>\n        </div>\n      </ScrollSync>\n    );\n\n    const editorWithEditor = (\n      <ScrollSync enabled={this.state.scrollSyncEnabled}>\n        <div>\n          <StyledSplitPane\n            maxSize={-100}\n            defaultSize={parseInt(localStorage.getItem(SPLIT_PANE_POSITION), 10) || '50%'}\n            onChange={size => localStorage.setItem(SPLIT_PANE_POSITION, size)}\n            onDragStarted={this.handleSplitPaneDragStart}\n            onDragFinished={this.handleSplitPaneDragFinished}\n          >\n            <ScrollSyncPane>{editor}</ScrollSyncPane>\n            <ScrollSyncPane>{editor2}</ScrollSyncPane>\n          </StyledSplitPane>\n        </div>\n      </ScrollSync>\n    );\n\n    const i18nVisible = collectionI18nEnabled && this.state.i18nVisible;\n    const previewVisible = previewEnabled && this.state.previewVisible;\n    const scrollSyncVisible = i18nVisible || previewVisible;\n\n    return (\n      <EditorContainer>\n        <EditorToolbar\n          isPersisting={entry.get('isPersisting')}\n          isPublishing={entry.get('isPublishing')}\n          isUpdatingStatus={entry.get('isUpdatingStatus')}\n          isDeleting={entry.get('isDeleting')}\n          onPersist={this.handleOnPersist}\n          onPersistAndNew={() => this.handleOnPersist({ createNew: true })}\n          onPersistAndDuplicate={() => this.handleOnPersist({ createNew: true, duplicate: true })}\n          onDelete={onDelete}\n          onDeleteUnpublishedChanges={onDeleteUnpublishedChanges}\n          onChangeStatus={onChangeStatus}\n          showDelete={showDelete}\n          onPublish={onPublish}\n          unPublish={unPublish}\n          onDuplicate={onDuplicate}\n          onPublishAndNew={() => this.handleOnPublish({ createNew: true })}\n          onPublishAndDuplicate={() => this.handleOnPublish({ createNew: true, duplicate: true })}\n          user={user}\n          hasChanged={hasChanged}\n          displayUrl={displayUrl}\n          collection={collection}\n          hasWorkflow={hasWorkflow}\n          useOpenAuthoring={useOpenAuthoring}\n          hasUnpublishedChanges={hasUnpublishedChanges}\n          isNewEntry={isNewEntry}\n          isModification={isModification}\n          currentStatus={currentStatus}\n          onLogoutClick={onLogoutClick}\n          loadDeployPreview={loadDeployPreview}\n          deployPreview={deployPreview}\n          editorBackLink={editorBackLink}\n        />\n        <Editor key={draftKey}>\n          <ViewControls>\n            {collectionI18nEnabled && (\n              <EditorToggle\n                isActive={i18nVisible}\n                onClick={this.handleToggleI18n}\n                size=\"large\"\n                type=\"page\"\n                title={t('editor.editorInterface.toggleI18n')}\n                marginTop=\"70px\"\n              />\n            )}\n            {previewEnabled && (\n              <EditorToggle\n                isActive={previewVisible}\n                onClick={this.handleTogglePreview}\n                size=\"large\"\n                type=\"eye\"\n                title={t('editor.editorInterface.togglePreview')}\n              />\n            )}\n            {scrollSyncVisible && !collection.getIn(['editor', 'visualEditing']) && (\n              <EditorToggle\n                isActive={scrollSyncEnabled}\n                onClick={this.handleToggleScrollSync}\n                size=\"large\"\n                type=\"scroll\"\n                title={t('editor.editorInterface.toggleScrollSync')}\n              />\n            )}\n          </ViewControls>\n          <EditorContent\n            i18nVisible={i18nVisible}\n            previewVisible={previewVisible}\n            editor={editor}\n            editorWithEditor={editorWithEditor}\n            editorWithPreview={editorWithPreview}\n          />\n        </Editor>\n      </EditorContainer>\n    );\n  }\n}\n\nEditorInterface.propTypes = {\n  collection: ImmutablePropTypes.map.isRequired,\n  entry: ImmutablePropTypes.map.isRequired,\n  fields: ImmutablePropTypes.list.isRequired,\n  fieldsMetaData: ImmutablePropTypes.map.isRequired,\n  fieldsErrors: ImmutablePropTypes.map.isRequired,\n  onChange: PropTypes.func.isRequired,\n  onValidate: PropTypes.func.isRequired,\n  onPersist: PropTypes.func.isRequired,\n  showDelete: PropTypes.bool.isRequired,\n  onDelete: PropTypes.func.isRequired,\n  onDeleteUnpublishedChanges: PropTypes.func.isRequired,\n  onPublish: PropTypes.func.isRequired,\n  unPublish: PropTypes.func.isRequired,\n  onDuplicate: PropTypes.func.isRequired,\n  onChangeStatus: PropTypes.func.isRequired,\n  user: PropTypes.object,\n  hasChanged: PropTypes.bool,\n  displayUrl: PropTypes.string,\n  hasWorkflow: PropTypes.bool,\n  useOpenAuthoring: PropTypes.bool,\n  hasUnpublishedChanges: PropTypes.bool,\n  isNewEntry: PropTypes.bool,\n  isModification: PropTypes.bool,\n  currentStatus: PropTypes.string,\n  onLogoutClick: PropTypes.func.isRequired,\n  deployPreview: PropTypes.object,\n  loadDeployPreview: PropTypes.func.isRequired,\n  draftKey: PropTypes.string.isRequired,\n  t: PropTypes.func.isRequired,\n};\n\nexport default EditorInterface;\n"]} */",
|
|
42
34
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__
|
|
43
35
|
}
|
|
44
36
|
};
|
|
45
|
-
const EditorToggle = /*#__PURE__*/(
|
|
37
|
+
const EditorToggle = /*#__PURE__*/_styled(IconButton, {
|
|
46
38
|
target: "e1nx103k7",
|
|
47
39
|
label: "EditorToggle"
|
|
48
40
|
})(process.env.NODE_ENV === "production" ? {
|
|
@@ -51,27 +43,27 @@ const EditorToggle = /*#__PURE__*/(0, _base.default)(_decapCmsUiDefault.IconButt
|
|
|
51
43
|
} : {
|
|
52
44
|
name: "cn3xcj",
|
|
53
45
|
styles: "margin-bottom:12px",
|
|
54
|
-
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/Editor/EditorInterface.js"],"names":[],"mappings":"AAwCuC","file":"../../../../src/components/Editor/EditorInterface.js","sourcesContent":["import PropTypes from 'prop-types';\nimport React, { Component } from 'react';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\nimport { css, Global } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport SplitPane from 'react-split-pane';\nimport {\n  colors,\n  colorsRaw,\n  components,\n  transitions,\n  IconButton,\n  zIndex,\n} from 'decap-cms-ui-default';\nimport { ScrollSync, ScrollSyncPane } from 'react-scroll-sync';\n\nimport EditorControlPane from './EditorControlPane/EditorControlPane';\nimport EditorPreviewPane from './EditorPreviewPane/EditorPreviewPane';\nimport EditorToolbar from './EditorToolbar';\nimport { hasI18n, getI18nInfo, getPreviewEntry } from '../../lib/i18n';\nimport { FILES } from '../../constants/collectionTypes';\nimport { getFileFromSlug } from '../../reducers/collections';\n\nconst PREVIEW_VISIBLE = 'cms.preview-visible';\nconst SCROLL_SYNC_ENABLED = 'cms.scroll-sync-enabled';\nconst SPLIT_PANE_POSITION = 'cms.split-pane-position';\nconst I18N_VISIBLE = 'cms.i18n-visible';\n\nconst styles = {\n  splitPane: css`\n    ${components.card};\n    border-radius: 0;\n    height: 100%;\n  `,\n  pane: css`\n    height: 100%;\n    overflow-y: auto;\n  `,\n};\n\nconst EditorToggle = styled(IconButton)`\n  margin-bottom: 12px;\n`;\n\nfunction ReactSplitPaneGlobalStyles() {\n  return (\n    <Global\n      styles={css`\n        .Resizer.vertical {\n          width: 2px;\n          cursor: col-resize;\n          position: relative;\n          background: none;\n\n          &:before {\n            content: '';\n            width: 2px;\n            height: 100%;\n            position: relative;\n            background-color: ${colors.textFieldBorder};\n            display: block;\n            z-index: 10;\n            transition: background-color ${transitions.main};\n          }\n\n          &:hover,\n          &:active {\n            &:before {\n              width: 4px;\n              left: -1px;\n              background-color: ${colorsRaw.blue};\n            }\n          }\n        }\n      `}\n    />\n  );\n}\n\nconst StyledSplitPane = styled(SplitPane)`\n  ${styles.splitPane};\n\n  /**\n   * Quick fix for preview pane not fully displaying in Safari\n   */\n  .Pane {\n    height: 100%;\n  }\n`;\n\nconst NoPreviewContainer = styled.div`\n  ${styles.splitPane};\n`;\n\nconst EditorContainer = styled.div`\n  width: 100%;\n  min-width: 800px;\n  height: 100%;\n  position: absolute;\n  top: 0;\n  left: 0;\n  overflow: hidden;\n  padding-top: 66px;\n  background-color: ${colors.background};\n`;\n\nconst Editor = styled.div`\n  height: 100%;\n  margin: 0 auto;\n  position: relative;\n`;\n\nconst PreviewPaneContainer = styled.div`\n  height: 100%;\n  pointer-events: ${props => (props.blockEntry ? 'none' : 'auto')};\n  overflow-y: ${props => (props.overFlow ? 'auto' : 'hidden')};\n`;\n\nconst ControlPaneContainer = styled(PreviewPaneContainer)`\n  padding: 0 16px;\n  position: relative;\n  overflow-x: hidden;\n`;\n\nconst ViewControls = styled.div`\n  position: absolute;\n  top: 10px;\n  right: 10px;\n  z-index: ${zIndex.zIndex299};\n`;\n\nfunction EditorContent({\n  i18nVisible,\n  previewVisible,\n  editor,\n  editorWithEditor,\n  editorWithPreview,\n}) {\n  if (i18nVisible) {\n    return editorWithEditor;\n  } else if (previewVisible) {\n    return editorWithPreview;\n  } else {\n    return <NoPreviewContainer>{editor}</NoPreviewContainer>;\n  }\n}\n\nfunction isPreviewEnabled(collection, entry) {\n  if (collection.get('type') === FILES) {\n    const file = getFileFromSlug(collection, entry.get('slug'));\n    const previewEnabled = file?.getIn(['editor', 'preview']);\n    if (previewEnabled != null) return previewEnabled;\n  }\n  return collection.getIn(['editor', 'preview'], true);\n}\n\nclass EditorInterface extends Component {\n  state = {\n    showEventBlocker: false,\n    previewVisible: localStorage.getItem(PREVIEW_VISIBLE) !== 'false',\n    scrollSyncEnabled: localStorage.getItem(SCROLL_SYNC_ENABLED) !== 'false',\n    i18nVisible: localStorage.getItem(I18N_VISIBLE) !== 'false',\n  };\n\n  handleSplitPaneDragStart = () => {\n    this.setState({ showEventBlocker: true });\n  };\n\n  handleSplitPaneDragFinished = () => {\n    this.setState({ showEventBlocker: false });\n  };\n\n  handleOnPersist = async (opts = {}) => {\n    const { createNew = false, duplicate = false } = opts;\n    await this.controlPaneRef.switchToDefaultLocale();\n    this.controlPaneRef.validate();\n    this.props.onPersist({ createNew, duplicate });\n  };\n\n  handleOnPublish = async (opts = {}) => {\n    const { createNew = false, duplicate = false } = opts;\n    await this.controlPaneRef.switchToDefaultLocale();\n    this.controlPaneRef.validate();\n    this.props.onPublish({ createNew, duplicate });\n  };\n\n  handleTogglePreview = () => {\n    const newPreviewVisible = !this.state.previewVisible;\n    this.setState({ previewVisible: newPreviewVisible });\n    localStorage.setItem(PREVIEW_VISIBLE, newPreviewVisible);\n  };\n\n  handleToggleScrollSync = () => {\n    const newScrollSyncEnabled = !this.state.scrollSyncEnabled;\n    this.setState({ scrollSyncEnabled: newScrollSyncEnabled });\n    localStorage.setItem(SCROLL_SYNC_ENABLED, newScrollSyncEnabled);\n  };\n\n  handleToggleI18n = () => {\n    const newI18nVisible = !this.state.i18nVisible;\n    this.setState({ i18nVisible: newI18nVisible });\n    localStorage.setItem(I18N_VISIBLE, newI18nVisible);\n  };\n\n  handleLeftPanelLocaleChange = locale => {\n    this.setState({ leftPanelLocale: locale });\n  };\n\n  render() {\n    const {\n      collection,\n      entry,\n      fields,\n      fieldsMetaData,\n      fieldsErrors,\n      onChange,\n      showDelete,\n      onDelete,\n      onDeleteUnpublishedChanges,\n      onChangeStatus,\n      onPublish,\n      unPublish,\n      onDuplicate,\n      onValidate,\n      user,\n      hasChanged,\n      displayUrl,\n      hasWorkflow,\n      useOpenAuthoring,\n      hasUnpublishedChanges,\n      isNewEntry,\n      isModification,\n      currentStatus,\n      onLogoutClick,\n      loadDeployPreview,\n      deployPreview,\n      draftKey,\n      editorBackLink,\n      t,\n    } = this.props;\n\n    const { scrollSyncEnabled, showEventBlocker } = this.state;\n\n    const previewEnabled = isPreviewEnabled(collection, entry);\n\n    const { locales, defaultLocale } = getI18nInfo(this.props.collection);\n    const collectionI18nEnabled = hasI18n(collection) && locales.length > 1;\n    const editorProps = {\n      collection,\n      entry,\n      fields,\n      fieldsMetaData,\n      fieldsErrors,\n      onChange,\n      onValidate,\n    };\n\n    const leftPanelLocale = this.state.leftPanelLocale || locales?.[0];\n    const editor = (\n      <ControlPaneContainer overFlow blockEntry={showEventBlocker}>\n        <EditorControlPane\n          {...editorProps}\n          ref={c => (this.controlPaneRef = c)}\n          locale={leftPanelLocale}\n          t={t}\n          onLocaleChange={this.handleLeftPanelLocaleChange}\n        />\n      </ControlPaneContainer>\n    );\n\n    const editor2 = (\n      <ControlPaneContainer overFlow={!this.state.scrollSyncEnabled} blockEntry={showEventBlocker}>\n        <EditorControlPane {...editorProps} locale={locales?.[1]} t={t} />\n      </ControlPaneContainer>\n    );\n\n    const previewEntry = collectionI18nEnabled\n      ? getPreviewEntry(entry, leftPanelLocale, defaultLocale)\n      : entry;\n\n    const editorWithPreview = (\n      <ScrollSync enabled={this.state.scrollSyncEnabled}>\n        <div>\n          <ReactSplitPaneGlobalStyles />\n          <StyledSplitPane\n            maxSize={-100}\n            minSize={400}\n            defaultSize={parseInt(localStorage.getItem(SPLIT_PANE_POSITION), 10) || '50%'}\n            onChange={size => localStorage.setItem(SPLIT_PANE_POSITION, size)}\n            onDragStarted={this.handleSplitPaneDragStart}\n            onDragFinished={this.handleSplitPaneDragFinished}\n          >\n            <ScrollSyncPane>{editor}</ScrollSyncPane>\n            <PreviewPaneContainer blockEntry={showEventBlocker}>\n              <EditorPreviewPane\n                collection={collection}\n                entry={previewEntry}\n                fields={fields}\n                fieldsMetaData={fieldsMetaData}\n                locale={leftPanelLocale}\n              />\n            </PreviewPaneContainer>\n          </StyledSplitPane>\n        </div>\n      </ScrollSync>\n    );\n\n    const editorWithEditor = (\n      <ScrollSync enabled={this.state.scrollSyncEnabled}>\n        <div>\n          <StyledSplitPane\n            maxSize={-100}\n            defaultSize={parseInt(localStorage.getItem(SPLIT_PANE_POSITION), 10) || '50%'}\n            onChange={size => localStorage.setItem(SPLIT_PANE_POSITION, size)}\n            onDragStarted={this.handleSplitPaneDragStart}\n            onDragFinished={this.handleSplitPaneDragFinished}\n          >\n            <ScrollSyncPane>{editor}</ScrollSyncPane>\n            <ScrollSyncPane>{editor2}</ScrollSyncPane>\n          </StyledSplitPane>\n        </div>\n      </ScrollSync>\n    );\n\n    const i18nVisible = collectionI18nEnabled && this.state.i18nVisible;\n    const previewVisible = previewEnabled && this.state.previewVisible;\n    const scrollSyncVisible = i18nVisible || previewVisible;\n\n    return (\n      <EditorContainer>\n        <EditorToolbar\n          isPersisting={entry.get('isPersisting')}\n          isPublishing={entry.get('isPublishing')}\n          isUpdatingStatus={entry.get('isUpdatingStatus')}\n          isDeleting={entry.get('isDeleting')}\n          onPersist={this.handleOnPersist}\n          onPersistAndNew={() => this.handleOnPersist({ createNew: true })}\n          onPersistAndDuplicate={() => this.handleOnPersist({ createNew: true, duplicate: true })}\n          onDelete={onDelete}\n          onDeleteUnpublishedChanges={onDeleteUnpublishedChanges}\n          onChangeStatus={onChangeStatus}\n          showDelete={showDelete}\n          onPublish={onPublish}\n          unPublish={unPublish}\n          onDuplicate={onDuplicate}\n          onPublishAndNew={() => this.handleOnPublish({ createNew: true })}\n          onPublishAndDuplicate={() => this.handleOnPublish({ createNew: true, duplicate: true })}\n          user={user}\n          hasChanged={hasChanged}\n          displayUrl={displayUrl}\n          collection={collection}\n          hasWorkflow={hasWorkflow}\n          useOpenAuthoring={useOpenAuthoring}\n          hasUnpublishedChanges={hasUnpublishedChanges}\n          isNewEntry={isNewEntry}\n          isModification={isModification}\n          currentStatus={currentStatus}\n          onLogoutClick={onLogoutClick}\n          loadDeployPreview={loadDeployPreview}\n          deployPreview={deployPreview}\n          editorBackLink={editorBackLink}\n        />\n        <Editor key={draftKey}>\n          <ViewControls>\n            {collectionI18nEnabled && (\n              <EditorToggle\n                isActive={i18nVisible}\n                onClick={this.handleToggleI18n}\n                size=\"large\"\n                type=\"page\"\n                title={t('editor.editorInterface.toggleI18n')}\n                marginTop=\"70px\"\n              />\n            )}\n            {previewEnabled && (\n              <EditorToggle\n                isActive={previewVisible}\n                onClick={this.handleTogglePreview}\n                size=\"large\"\n                type=\"eye\"\n                title={t('editor.editorInterface.togglePreview')}\n              />\n            )}\n            {scrollSyncVisible && (\n              <EditorToggle\n                isActive={scrollSyncEnabled}\n                onClick={this.handleToggleScrollSync}\n                size=\"large\"\n                type=\"scroll\"\n                title={t('editor.editorInterface.toggleScrollSync')}\n              />\n            )}\n          </ViewControls>\n          <EditorContent\n            i18nVisible={i18nVisible}\n            previewVisible={previewVisible}\n            editor={editor}\n            editorWithEditor={editorWithEditor}\n            editorWithPreview={editorWithPreview}\n          />\n        </Editor>\n      </EditorContainer>\n    );\n  }\n}\n\nEditorInterface.propTypes = {\n  collection: ImmutablePropTypes.map.isRequired,\n  entry: ImmutablePropTypes.map.isRequired,\n  fields: ImmutablePropTypes.list.isRequired,\n  fieldsMetaData: ImmutablePropTypes.map.isRequired,\n  fieldsErrors: ImmutablePropTypes.map.isRequired,\n  onChange: PropTypes.func.isRequired,\n  onValidate: PropTypes.func.isRequired,\n  onPersist: PropTypes.func.isRequired,\n  showDelete: PropTypes.bool.isRequired,\n  onDelete: PropTypes.func.isRequired,\n  onDeleteUnpublishedChanges: PropTypes.func.isRequired,\n  onPublish: PropTypes.func.isRequired,\n  unPublish: PropTypes.func.isRequired,\n  onDuplicate: PropTypes.func.isRequired,\n  onChangeStatus: PropTypes.func.isRequired,\n  user: PropTypes.object,\n  hasChanged: PropTypes.bool,\n  displayUrl: PropTypes.string,\n  hasWorkflow: PropTypes.bool,\n  useOpenAuthoring: PropTypes.bool,\n  hasUnpublishedChanges: PropTypes.bool,\n  isNewEntry: PropTypes.bool,\n  isModification: PropTypes.bool,\n  currentStatus: PropTypes.string,\n  onLogoutClick: PropTypes.func.isRequired,\n  deployPreview: PropTypes.object,\n  loadDeployPreview: PropTypes.func.isRequired,\n  draftKey: PropTypes.string.isRequired,\n  t: PropTypes.func.isRequired,\n};\n\nexport default EditorInterface;\n"]} */",
|
|
46
|
+
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/Editor/EditorInterface.js"],"names":[],"mappings":"AAwCuC","file":"../../../../src/components/Editor/EditorInterface.js","sourcesContent":["import PropTypes from 'prop-types';\nimport React, { Component } from 'react';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\nimport { css, Global } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport SplitPane from 'react-split-pane';\nimport {\n  colors,\n  colorsRaw,\n  components,\n  transitions,\n  IconButton,\n  zIndex,\n} from 'decap-cms-ui-default';\nimport { ScrollSync, ScrollSyncPane } from 'react-scroll-sync';\n\nimport EditorControlPane from './EditorControlPane/EditorControlPane';\nimport EditorPreviewPane from './EditorPreviewPane/EditorPreviewPane';\nimport EditorToolbar from './EditorToolbar';\nimport { hasI18n, getI18nInfo, getPreviewEntry } from '../../lib/i18n';\nimport { FILES } from '../../constants/collectionTypes';\nimport { getFileFromSlug } from '../../reducers/collections';\n\nconst PREVIEW_VISIBLE = 'cms.preview-visible';\nconst SCROLL_SYNC_ENABLED = 'cms.scroll-sync-enabled';\nconst SPLIT_PANE_POSITION = 'cms.split-pane-position';\nconst I18N_VISIBLE = 'cms.i18n-visible';\n\nconst styles = {\n  splitPane: css`\n    ${components.card};\n    border-radius: 0;\n    height: 100%;\n  `,\n  pane: css`\n    height: 100%;\n    overflow-y: auto;\n  `,\n};\n\nconst EditorToggle = styled(IconButton)`\n  margin-bottom: 12px;\n`;\n\nfunction ReactSplitPaneGlobalStyles() {\n  return (\n    <Global\n      styles={css`\n        .Resizer.vertical {\n          width: 2px;\n          cursor: col-resize;\n          position: relative;\n          background: none;\n\n          &:before {\n            content: '';\n            width: 2px;\n            height: 100%;\n            position: relative;\n            background-color: ${colors.textFieldBorder};\n            display: block;\n            z-index: 10;\n            transition: background-color ${transitions.main};\n          }\n\n          &:hover,\n          &:active {\n            &:before {\n              width: 4px;\n              left: -1px;\n              background-color: ${colorsRaw.blue};\n            }\n          }\n        }\n      `}\n    />\n  );\n}\n\nconst StyledSplitPane = styled(SplitPane)`\n  ${styles.splitPane};\n\n  /**\n   * Quick fix for preview pane not fully displaying in Safari\n   */\n  .Pane {\n    height: 100%;\n  }\n`;\n\nconst NoPreviewContainer = styled.div`\n  ${styles.splitPane};\n`;\n\nconst EditorContainer = styled.div`\n  width: 100%;\n  min-width: 800px;\n  height: 100%;\n  position: absolute;\n  top: 0;\n  left: 0;\n  overflow: hidden;\n  padding-top: 66px;\n  background-color: ${colors.background};\n`;\n\nconst Editor = styled.div`\n  height: 100%;\n  margin: 0 auto;\n  position: relative;\n`;\n\nconst PreviewPaneContainer = styled.div`\n  height: 100%;\n  pointer-events: ${props => (props.blockEntry ? 'none' : 'auto')};\n  overflow-y: ${props => (props.overFlow ? 'auto' : 'hidden')};\n`;\n\nconst ControlPaneContainer = styled(PreviewPaneContainer)`\n  padding: 0 16px;\n  position: relative;\n  overflow-x: hidden;\n`;\n\nconst ViewControls = styled.div`\n  position: absolute;\n  top: 10px;\n  right: 10px;\n  z-index: ${zIndex.zIndex299};\n`;\n\nfunction EditorContent({\n  i18nVisible,\n  previewVisible,\n  editor,\n  editorWithEditor,\n  editorWithPreview,\n}) {\n  if (i18nVisible) {\n    return editorWithEditor;\n  } else if (previewVisible) {\n    return editorWithPreview;\n  } else {\n    return <NoPreviewContainer>{editor}</NoPreviewContainer>;\n  }\n}\n\nfunction isPreviewEnabled(collection, entry) {\n  if (collection.get('type') === FILES) {\n    const file = getFileFromSlug(collection, entry.get('slug'));\n    const previewEnabled = file?.getIn(['editor', 'preview']);\n    if (previewEnabled != null) return previewEnabled;\n  }\n  return collection.getIn(['editor', 'preview'], true);\n}\n\nclass EditorInterface extends Component {\n  state = {\n    showEventBlocker: false,\n    previewVisible: localStorage.getItem(PREVIEW_VISIBLE) !== 'false',\n    scrollSyncEnabled: localStorage.getItem(SCROLL_SYNC_ENABLED) !== 'false',\n    i18nVisible: localStorage.getItem(I18N_VISIBLE) !== 'false',\n  };\n\n  handleFieldClick = path => {\n    this.controlPaneRef?.focus(path);\n  };\n\n  handleSplitPaneDragStart = () => {\n    this.setState({ showEventBlocker: true });\n  };\n\n  handleSplitPaneDragFinished = () => {\n    this.setState({ showEventBlocker: false });\n  };\n\n  handleOnPersist = async (opts = {}) => {\n    const { createNew = false, duplicate = false } = opts;\n    await this.controlPaneRef.switchToDefaultLocale();\n    this.controlPaneRef.validate();\n    this.props.onPersist({ createNew, duplicate });\n  };\n\n  handleOnPublish = async (opts = {}) => {\n    const { createNew = false, duplicate = false } = opts;\n    await this.controlPaneRef.switchToDefaultLocale();\n    this.controlPaneRef.validate();\n    this.props.onPublish({ createNew, duplicate });\n  };\n\n  handleTogglePreview = () => {\n    const newPreviewVisible = !this.state.previewVisible;\n    this.setState({ previewVisible: newPreviewVisible });\n    localStorage.setItem(PREVIEW_VISIBLE, newPreviewVisible);\n  };\n\n  handleToggleScrollSync = () => {\n    const newScrollSyncEnabled = !this.state.scrollSyncEnabled;\n    this.setState({ scrollSyncEnabled: newScrollSyncEnabled });\n    localStorage.setItem(SCROLL_SYNC_ENABLED, newScrollSyncEnabled);\n  };\n\n  handleToggleI18n = () => {\n    const newI18nVisible = !this.state.i18nVisible;\n    this.setState({ i18nVisible: newI18nVisible });\n    localStorage.setItem(I18N_VISIBLE, newI18nVisible);\n  };\n\n  handleLeftPanelLocaleChange = locale => {\n    this.setState({ leftPanelLocale: locale });\n  };\n\n  render() {\n    const {\n      collection,\n      entry,\n      fields,\n      fieldsMetaData,\n      fieldsErrors,\n      onChange,\n      showDelete,\n      onDelete,\n      onDeleteUnpublishedChanges,\n      onChangeStatus,\n      onPublish,\n      unPublish,\n      onDuplicate,\n      onValidate,\n      user,\n      hasChanged,\n      displayUrl,\n      hasWorkflow,\n      useOpenAuthoring,\n      hasUnpublishedChanges,\n      isNewEntry,\n      isModification,\n      currentStatus,\n      onLogoutClick,\n      loadDeployPreview,\n      deployPreview,\n      draftKey,\n      editorBackLink,\n      t,\n    } = this.props;\n\n    const { scrollSyncEnabled, showEventBlocker } = this.state;\n\n    const previewEnabled = isPreviewEnabled(collection, entry);\n\n    const { locales, defaultLocale } = getI18nInfo(this.props.collection);\n    const collectionI18nEnabled = hasI18n(collection) && locales.length > 1;\n    const editorProps = {\n      collection,\n      entry,\n      fields,\n      fieldsMetaData,\n      fieldsErrors,\n      onChange,\n      onValidate,\n    };\n\n    const leftPanelLocale = this.state.leftPanelLocale || locales?.[0];\n    const editor = (\n      <ControlPaneContainer overFlow blockEntry={showEventBlocker}>\n        <EditorControlPane\n          {...editorProps}\n          ref={c => (this.controlPaneRef = c)}\n          locale={leftPanelLocale}\n          t={t}\n          onLocaleChange={this.handleLeftPanelLocaleChange}\n        />\n      </ControlPaneContainer>\n    );\n\n    const editor2 = (\n      <ControlPaneContainer overFlow={!this.state.scrollSyncEnabled} blockEntry={showEventBlocker}>\n        <EditorControlPane {...editorProps} locale={locales?.[1]} t={t} />\n      </ControlPaneContainer>\n    );\n\n    const previewEntry = collectionI18nEnabled\n      ? getPreviewEntry(entry, leftPanelLocale, defaultLocale)\n      : entry;\n\n    const editorWithPreview = (\n      <ScrollSync enabled={this.state.scrollSyncEnabled}>\n        <div>\n          <ReactSplitPaneGlobalStyles />\n          <StyledSplitPane\n            maxSize={-100}\n            minSize={400}\n            defaultSize={parseInt(localStorage.getItem(SPLIT_PANE_POSITION), 10) || '50%'}\n            onChange={size => localStorage.setItem(SPLIT_PANE_POSITION, size)}\n            onDragStarted={this.handleSplitPaneDragStart}\n            onDragFinished={this.handleSplitPaneDragFinished}\n          >\n            <ScrollSyncPane>{editor}</ScrollSyncPane>\n            <PreviewPaneContainer blockEntry={showEventBlocker}>\n              <EditorPreviewPane\n                collection={collection}\n                entry={previewEntry}\n                fields={fields}\n                fieldsMetaData={fieldsMetaData}\n                locale={leftPanelLocale}\n                onFieldClick={this.handleFieldClick}\n              />\n            </PreviewPaneContainer>\n          </StyledSplitPane>\n        </div>\n      </ScrollSync>\n    );\n\n    const editorWithEditor = (\n      <ScrollSync enabled={this.state.scrollSyncEnabled}>\n        <div>\n          <StyledSplitPane\n            maxSize={-100}\n            defaultSize={parseInt(localStorage.getItem(SPLIT_PANE_POSITION), 10) || '50%'}\n            onChange={size => localStorage.setItem(SPLIT_PANE_POSITION, size)}\n            onDragStarted={this.handleSplitPaneDragStart}\n            onDragFinished={this.handleSplitPaneDragFinished}\n          >\n            <ScrollSyncPane>{editor}</ScrollSyncPane>\n            <ScrollSyncPane>{editor2}</ScrollSyncPane>\n          </StyledSplitPane>\n        </div>\n      </ScrollSync>\n    );\n\n    const i18nVisible = collectionI18nEnabled && this.state.i18nVisible;\n    const previewVisible = previewEnabled && this.state.previewVisible;\n    const scrollSyncVisible = i18nVisible || previewVisible;\n\n    return (\n      <EditorContainer>\n        <EditorToolbar\n          isPersisting={entry.get('isPersisting')}\n          isPublishing={entry.get('isPublishing')}\n          isUpdatingStatus={entry.get('isUpdatingStatus')}\n          isDeleting={entry.get('isDeleting')}\n          onPersist={this.handleOnPersist}\n          onPersistAndNew={() => this.handleOnPersist({ createNew: true })}\n          onPersistAndDuplicate={() => this.handleOnPersist({ createNew: true, duplicate: true })}\n          onDelete={onDelete}\n          onDeleteUnpublishedChanges={onDeleteUnpublishedChanges}\n          onChangeStatus={onChangeStatus}\n          showDelete={showDelete}\n          onPublish={onPublish}\n          unPublish={unPublish}\n          onDuplicate={onDuplicate}\n          onPublishAndNew={() => this.handleOnPublish({ createNew: true })}\n          onPublishAndDuplicate={() => this.handleOnPublish({ createNew: true, duplicate: true })}\n          user={user}\n          hasChanged={hasChanged}\n          displayUrl={displayUrl}\n          collection={collection}\n          hasWorkflow={hasWorkflow}\n          useOpenAuthoring={useOpenAuthoring}\n          hasUnpublishedChanges={hasUnpublishedChanges}\n          isNewEntry={isNewEntry}\n          isModification={isModification}\n          currentStatus={currentStatus}\n          onLogoutClick={onLogoutClick}\n          loadDeployPreview={loadDeployPreview}\n          deployPreview={deployPreview}\n          editorBackLink={editorBackLink}\n        />\n        <Editor key={draftKey}>\n          <ViewControls>\n            {collectionI18nEnabled && (\n              <EditorToggle\n                isActive={i18nVisible}\n                onClick={this.handleToggleI18n}\n                size=\"large\"\n                type=\"page\"\n                title={t('editor.editorInterface.toggleI18n')}\n                marginTop=\"70px\"\n              />\n            )}\n            {previewEnabled && (\n              <EditorToggle\n                isActive={previewVisible}\n                onClick={this.handleTogglePreview}\n                size=\"large\"\n                type=\"eye\"\n                title={t('editor.editorInterface.togglePreview')}\n              />\n            )}\n            {scrollSyncVisible && !collection.getIn(['editor', 'visualEditing']) && (\n              <EditorToggle\n                isActive={scrollSyncEnabled}\n                onClick={this.handleToggleScrollSync}\n                size=\"large\"\n                type=\"scroll\"\n                title={t('editor.editorInterface.toggleScrollSync')}\n              />\n            )}\n          </ViewControls>\n          <EditorContent\n            i18nVisible={i18nVisible}\n            previewVisible={previewVisible}\n            editor={editor}\n            editorWithEditor={editorWithEditor}\n            editorWithPreview={editorWithPreview}\n          />\n        </Editor>\n      </EditorContainer>\n    );\n  }\n}\n\nEditorInterface.propTypes = {\n  collection: ImmutablePropTypes.map.isRequired,\n  entry: ImmutablePropTypes.map.isRequired,\n  fields: ImmutablePropTypes.list.isRequired,\n  fieldsMetaData: ImmutablePropTypes.map.isRequired,\n  fieldsErrors: ImmutablePropTypes.map.isRequired,\n  onChange: PropTypes.func.isRequired,\n  onValidate: PropTypes.func.isRequired,\n  onPersist: PropTypes.func.isRequired,\n  showDelete: PropTypes.bool.isRequired,\n  onDelete: PropTypes.func.isRequired,\n  onDeleteUnpublishedChanges: PropTypes.func.isRequired,\n  onPublish: PropTypes.func.isRequired,\n  unPublish: PropTypes.func.isRequired,\n  onDuplicate: PropTypes.func.isRequired,\n  onChangeStatus: PropTypes.func.isRequired,\n  user: PropTypes.object,\n  hasChanged: PropTypes.bool,\n  displayUrl: PropTypes.string,\n  hasWorkflow: PropTypes.bool,\n  useOpenAuthoring: PropTypes.bool,\n  hasUnpublishedChanges: PropTypes.bool,\n  isNewEntry: PropTypes.bool,\n  isModification: PropTypes.bool,\n  currentStatus: PropTypes.string,\n  onLogoutClick: PropTypes.func.isRequired,\n  deployPreview: PropTypes.object,\n  loadDeployPreview: PropTypes.func.isRequired,\n  draftKey: PropTypes.string.isRequired,\n  t: PropTypes.func.isRequired,\n};\n\nexport default EditorInterface;\n"]} */",
|
|
55
47
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__
|
|
56
48
|
});
|
|
57
49
|
function ReactSplitPaneGlobalStyles() {
|
|
58
|
-
return (
|
|
59
|
-
styles: /*#__PURE__*/(0, _react2.css)(".Resizer.vertical{width:2px;cursor:col-resize;position:relative;background:none;&:before{content:'';width:2px;height:100%;position:relative;background-color:", _decapCmsUiDefault.colors.textFieldBorder, ";display:block;z-index:10;transition:background-color ", _decapCmsUiDefault.transitions.main, ";}&:hover,&:active{&:before{width:4px;left:-1px;background-color:", _decapCmsUiDefault.colorsRaw.blue, ";}}};label:ReactSplitPaneGlobalStyles;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/Editor/EditorInterface.js"],"names":[],"mappings":"AA+CiB","file":"../../../../src/components/Editor/EditorInterface.js","sourcesContent":["import PropTypes from 'prop-types';\nimport React, { Component } from 'react';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\nimport { css, Global } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport SplitPane from 'react-split-pane';\nimport {\n  colors,\n  colorsRaw,\n  components,\n  transitions,\n  IconButton,\n  zIndex,\n} from 'decap-cms-ui-default';\nimport { ScrollSync, ScrollSyncPane } from 'react-scroll-sync';\n\nimport EditorControlPane from './EditorControlPane/EditorControlPane';\nimport EditorPreviewPane from './EditorPreviewPane/EditorPreviewPane';\nimport EditorToolbar from './EditorToolbar';\nimport { hasI18n, getI18nInfo, getPreviewEntry } from '../../lib/i18n';\nimport { FILES } from '../../constants/collectionTypes';\nimport { getFileFromSlug } from '../../reducers/collections';\n\nconst PREVIEW_VISIBLE = 'cms.preview-visible';\nconst SCROLL_SYNC_ENABLED = 'cms.scroll-sync-enabled';\nconst SPLIT_PANE_POSITION = 'cms.split-pane-position';\nconst I18N_VISIBLE = 'cms.i18n-visible';\n\nconst styles = {\n  splitPane: css`\n    ${components.card};\n    border-radius: 0;\n    height: 100%;\n  `,\n  pane: css`\n    height: 100%;\n    overflow-y: auto;\n  `,\n};\n\nconst EditorToggle = styled(IconButton)`\n  margin-bottom: 12px;\n`;\n\nfunction ReactSplitPaneGlobalStyles() {\n  return (\n    <Global\n      styles={css`\n        .Resizer.vertical {\n          width: 2px;\n          cursor: col-resize;\n          position: relative;\n          background: none;\n\n          &:before {\n            content: '';\n            width: 2px;\n            height: 100%;\n            position: relative;\n            background-color: ${colors.textFieldBorder};\n            display: block;\n            z-index: 10;\n            transition: background-color ${transitions.main};\n          }\n\n          &:hover,\n          &:active {\n            &:before {\n              width: 4px;\n              left: -1px;\n              background-color: ${colorsRaw.blue};\n            }\n          }\n        }\n      `}\n    />\n  );\n}\n\nconst StyledSplitPane = styled(SplitPane)`\n  ${styles.splitPane};\n\n  /**\n   * Quick fix for preview pane not fully displaying in Safari\n   */\n  .Pane {\n    height: 100%;\n  }\n`;\n\nconst NoPreviewContainer = styled.div`\n  ${styles.splitPane};\n`;\n\nconst EditorContainer = styled.div`\n  width: 100%;\n  min-width: 800px;\n  height: 100%;\n  position: absolute;\n  top: 0;\n  left: 0;\n  overflow: hidden;\n  padding-top: 66px;\n  background-color: ${colors.background};\n`;\n\nconst Editor = styled.div`\n  height: 100%;\n  margin: 0 auto;\n  position: relative;\n`;\n\nconst PreviewPaneContainer = styled.div`\n  height: 100%;\n  pointer-events: ${props => (props.blockEntry ? 'none' : 'auto')};\n  overflow-y: ${props => (props.overFlow ? 'auto' : 'hidden')};\n`;\n\nconst ControlPaneContainer = styled(PreviewPaneContainer)`\n  padding: 0 16px;\n  position: relative;\n  overflow-x: hidden;\n`;\n\nconst ViewControls = styled.div`\n  position: absolute;\n  top: 10px;\n  right: 10px;\n  z-index: ${zIndex.zIndex299};\n`;\n\nfunction EditorContent({\n  i18nVisible,\n  previewVisible,\n  editor,\n  editorWithEditor,\n  editorWithPreview,\n}) {\n  if (i18nVisible) {\n    return editorWithEditor;\n  } else if (previewVisible) {\n    return editorWithPreview;\n  } else {\n    return <NoPreviewContainer>{editor}</NoPreviewContainer>;\n  }\n}\n\nfunction isPreviewEnabled(collection, entry) {\n  if (collection.get('type') === FILES) {\n    const file = getFileFromSlug(collection, entry.get('slug'));\n    const previewEnabled = file?.getIn(['editor', 'preview']);\n    if (previewEnabled != null) return previewEnabled;\n  }\n  return collection.getIn(['editor', 'preview'], true);\n}\n\nclass EditorInterface extends Component {\n  state = {\n    showEventBlocker: false,\n    previewVisible: localStorage.getItem(PREVIEW_VISIBLE) !== 'false',\n    scrollSyncEnabled: localStorage.getItem(SCROLL_SYNC_ENABLED) !== 'false',\n    i18nVisible: localStorage.getItem(I18N_VISIBLE) !== 'false',\n  };\n\n  handleSplitPaneDragStart = () => {\n    this.setState({ showEventBlocker: true });\n  };\n\n  handleSplitPaneDragFinished = () => {\n    this.setState({ showEventBlocker: false });\n  };\n\n  handleOnPersist = async (opts = {}) => {\n    const { createNew = false, duplicate = false } = opts;\n    await this.controlPaneRef.switchToDefaultLocale();\n    this.controlPaneRef.validate();\n    this.props.onPersist({ createNew, duplicate });\n  };\n\n  handleOnPublish = async (opts = {}) => {\n    const { createNew = false, duplicate = false } = opts;\n    await this.controlPaneRef.switchToDefaultLocale();\n    this.controlPaneRef.validate();\n    this.props.onPublish({ createNew, duplicate });\n  };\n\n  handleTogglePreview = () => {\n    const newPreviewVisible = !this.state.previewVisible;\n    this.setState({ previewVisible: newPreviewVisible });\n    localStorage.setItem(PREVIEW_VISIBLE, newPreviewVisible);\n  };\n\n  handleToggleScrollSync = () => {\n    const newScrollSyncEnabled = !this.state.scrollSyncEnabled;\n    this.setState({ scrollSyncEnabled: newScrollSyncEnabled });\n    localStorage.setItem(SCROLL_SYNC_ENABLED, newScrollSyncEnabled);\n  };\n\n  handleToggleI18n = () => {\n    const newI18nVisible = !this.state.i18nVisible;\n    this.setState({ i18nVisible: newI18nVisible });\n    localStorage.setItem(I18N_VISIBLE, newI18nVisible);\n  };\n\n  handleLeftPanelLocaleChange = locale => {\n    this.setState({ leftPanelLocale: locale });\n  };\n\n  render() {\n    const {\n      collection,\n      entry,\n      fields,\n      fieldsMetaData,\n      fieldsErrors,\n      onChange,\n      showDelete,\n      onDelete,\n      onDeleteUnpublishedChanges,\n      onChangeStatus,\n      onPublish,\n      unPublish,\n      onDuplicate,\n      onValidate,\n      user,\n      hasChanged,\n      displayUrl,\n      hasWorkflow,\n      useOpenAuthoring,\n      hasUnpublishedChanges,\n      isNewEntry,\n      isModification,\n      currentStatus,\n      onLogoutClick,\n      loadDeployPreview,\n      deployPreview,\n      draftKey,\n      editorBackLink,\n      t,\n    } = this.props;\n\n    const { scrollSyncEnabled, showEventBlocker } = this.state;\n\n    const previewEnabled = isPreviewEnabled(collection, entry);\n\n    const { locales, defaultLocale } = getI18nInfo(this.props.collection);\n    const collectionI18nEnabled = hasI18n(collection) && locales.length > 1;\n    const editorProps = {\n      collection,\n      entry,\n      fields,\n      fieldsMetaData,\n      fieldsErrors,\n      onChange,\n      onValidate,\n    };\n\n    const leftPanelLocale = this.state.leftPanelLocale || locales?.[0];\n    const editor = (\n      <ControlPaneContainer overFlow blockEntry={showEventBlocker}>\n        <EditorControlPane\n          {...editorProps}\n          ref={c => (this.controlPaneRef = c)}\n          locale={leftPanelLocale}\n          t={t}\n          onLocaleChange={this.handleLeftPanelLocaleChange}\n        />\n      </ControlPaneContainer>\n    );\n\n    const editor2 = (\n      <ControlPaneContainer overFlow={!this.state.scrollSyncEnabled} blockEntry={showEventBlocker}>\n        <EditorControlPane {...editorProps} locale={locales?.[1]} t={t} />\n      </ControlPaneContainer>\n    );\n\n    const previewEntry = collectionI18nEnabled\n      ? getPreviewEntry(entry, leftPanelLocale, defaultLocale)\n      : entry;\n\n    const editorWithPreview = (\n      <ScrollSync enabled={this.state.scrollSyncEnabled}>\n        <div>\n          <ReactSplitPaneGlobalStyles />\n          <StyledSplitPane\n            maxSize={-100}\n            minSize={400}\n            defaultSize={parseInt(localStorage.getItem(SPLIT_PANE_POSITION), 10) || '50%'}\n            onChange={size => localStorage.setItem(SPLIT_PANE_POSITION, size)}\n            onDragStarted={this.handleSplitPaneDragStart}\n            onDragFinished={this.handleSplitPaneDragFinished}\n          >\n            <ScrollSyncPane>{editor}</ScrollSyncPane>\n            <PreviewPaneContainer blockEntry={showEventBlocker}>\n              <EditorPreviewPane\n                collection={collection}\n                entry={previewEntry}\n                fields={fields}\n                fieldsMetaData={fieldsMetaData}\n                locale={leftPanelLocale}\n              />\n            </PreviewPaneContainer>\n          </StyledSplitPane>\n        </div>\n      </ScrollSync>\n    );\n\n    const editorWithEditor = (\n      <ScrollSync enabled={this.state.scrollSyncEnabled}>\n        <div>\n          <StyledSplitPane\n            maxSize={-100}\n            defaultSize={parseInt(localStorage.getItem(SPLIT_PANE_POSITION), 10) || '50%'}\n            onChange={size => localStorage.setItem(SPLIT_PANE_POSITION, size)}\n            onDragStarted={this.handleSplitPaneDragStart}\n            onDragFinished={this.handleSplitPaneDragFinished}\n          >\n            <ScrollSyncPane>{editor}</ScrollSyncPane>\n            <ScrollSyncPane>{editor2}</ScrollSyncPane>\n          </StyledSplitPane>\n        </div>\n      </ScrollSync>\n    );\n\n    const i18nVisible = collectionI18nEnabled && this.state.i18nVisible;\n    const previewVisible = previewEnabled && this.state.previewVisible;\n    const scrollSyncVisible = i18nVisible || previewVisible;\n\n    return (\n      <EditorContainer>\n        <EditorToolbar\n          isPersisting={entry.get('isPersisting')}\n          isPublishing={entry.get('isPublishing')}\n          isUpdatingStatus={entry.get('isUpdatingStatus')}\n          isDeleting={entry.get('isDeleting')}\n          onPersist={this.handleOnPersist}\n          onPersistAndNew={() => this.handleOnPersist({ createNew: true })}\n          onPersistAndDuplicate={() => this.handleOnPersist({ createNew: true, duplicate: true })}\n          onDelete={onDelete}\n          onDeleteUnpublishedChanges={onDeleteUnpublishedChanges}\n          onChangeStatus={onChangeStatus}\n          showDelete={showDelete}\n          onPublish={onPublish}\n          unPublish={unPublish}\n          onDuplicate={onDuplicate}\n          onPublishAndNew={() => this.handleOnPublish({ createNew: true })}\n          onPublishAndDuplicate={() => this.handleOnPublish({ createNew: true, duplicate: true })}\n          user={user}\n          hasChanged={hasChanged}\n          displayUrl={displayUrl}\n          collection={collection}\n          hasWorkflow={hasWorkflow}\n          useOpenAuthoring={useOpenAuthoring}\n          hasUnpublishedChanges={hasUnpublishedChanges}\n          isNewEntry={isNewEntry}\n          isModification={isModification}\n          currentStatus={currentStatus}\n          onLogoutClick={onLogoutClick}\n          loadDeployPreview={loadDeployPreview}\n          deployPreview={deployPreview}\n          editorBackLink={editorBackLink}\n        />\n        <Editor key={draftKey}>\n          <ViewControls>\n            {collectionI18nEnabled && (\n              <EditorToggle\n                isActive={i18nVisible}\n                onClick={this.handleToggleI18n}\n                size=\"large\"\n                type=\"page\"\n                title={t('editor.editorInterface.toggleI18n')}\n                marginTop=\"70px\"\n              />\n            )}\n            {previewEnabled && (\n              <EditorToggle\n                isActive={previewVisible}\n                onClick={this.handleTogglePreview}\n                size=\"large\"\n                type=\"eye\"\n                title={t('editor.editorInterface.togglePreview')}\n              />\n            )}\n            {scrollSyncVisible && (\n              <EditorToggle\n                isActive={scrollSyncEnabled}\n                onClick={this.handleToggleScrollSync}\n                size=\"large\"\n                type=\"scroll\"\n                title={t('editor.editorInterface.toggleScrollSync')}\n              />\n            )}\n          </ViewControls>\n          <EditorContent\n            i18nVisible={i18nVisible}\n            previewVisible={previewVisible}\n            editor={editor}\n            editorWithEditor={editorWithEditor}\n            editorWithPreview={editorWithPreview}\n          />\n        </Editor>\n      </EditorContainer>\n    );\n  }\n}\n\nEditorInterface.propTypes = {\n  collection: ImmutablePropTypes.map.isRequired,\n  entry: ImmutablePropTypes.map.isRequired,\n  fields: ImmutablePropTypes.list.isRequired,\n  fieldsMetaData: ImmutablePropTypes.map.isRequired,\n  fieldsErrors: ImmutablePropTypes.map.isRequired,\n  onChange: PropTypes.func.isRequired,\n  onValidate: PropTypes.func.isRequired,\n  onPersist: PropTypes.func.isRequired,\n  showDelete: PropTypes.bool.isRequired,\n  onDelete: PropTypes.func.isRequired,\n  onDeleteUnpublishedChanges: PropTypes.func.isRequired,\n  onPublish: PropTypes.func.isRequired,\n  unPublish: PropTypes.func.isRequired,\n  onDuplicate: PropTypes.func.isRequired,\n  onChangeStatus: PropTypes.func.isRequired,\n  user: PropTypes.object,\n  hasChanged: PropTypes.bool,\n  displayUrl: PropTypes.string,\n  hasWorkflow: PropTypes.bool,\n  useOpenAuthoring: PropTypes.bool,\n  hasUnpublishedChanges: PropTypes.bool,\n  isNewEntry: PropTypes.bool,\n  isModification: PropTypes.bool,\n  currentStatus: PropTypes.string,\n  onLogoutClick: PropTypes.func.isRequired,\n  deployPreview: PropTypes.object,\n  loadDeployPreview: PropTypes.func.isRequired,\n  draftKey: PropTypes.string.isRequired,\n  t: PropTypes.func.isRequired,\n};\n\nexport default EditorInterface;\n"]} */"))
|
|
50
|
+
return ___EmotionJSX(Global, {
|
|
51
|
+
styles: /*#__PURE__*/css(".Resizer.vertical{width:2px;cursor:col-resize;position:relative;background:none;&:before{content:'';width:2px;height:100%;position:relative;background-color:", colors.textFieldBorder, ";display:block;z-index:10;transition:background-color ", transitions.main, ";}&:hover,&:active{&:before{width:4px;left:-1px;background-color:", colorsRaw.blue, ";}}};label:ReactSplitPaneGlobalStyles;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/Editor/EditorInterface.js"],"names":[],"mappings":"AA+CiB","file":"../../../../src/components/Editor/EditorInterface.js","sourcesContent":["import PropTypes from 'prop-types';\nimport React, { Component } from 'react';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\nimport { css, Global } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport SplitPane from 'react-split-pane';\nimport {\n  colors,\n  colorsRaw,\n  components,\n  transitions,\n  IconButton,\n  zIndex,\n} from 'decap-cms-ui-default';\nimport { ScrollSync, ScrollSyncPane } from 'react-scroll-sync';\n\nimport EditorControlPane from './EditorControlPane/EditorControlPane';\nimport EditorPreviewPane from './EditorPreviewPane/EditorPreviewPane';\nimport EditorToolbar from './EditorToolbar';\nimport { hasI18n, getI18nInfo, getPreviewEntry } from '../../lib/i18n';\nimport { FILES } from '../../constants/collectionTypes';\nimport { getFileFromSlug } from '../../reducers/collections';\n\nconst PREVIEW_VISIBLE = 'cms.preview-visible';\nconst SCROLL_SYNC_ENABLED = 'cms.scroll-sync-enabled';\nconst SPLIT_PANE_POSITION = 'cms.split-pane-position';\nconst I18N_VISIBLE = 'cms.i18n-visible';\n\nconst styles = {\n  splitPane: css`\n    ${components.card};\n    border-radius: 0;\n    height: 100%;\n  `,\n  pane: css`\n    height: 100%;\n    overflow-y: auto;\n  `,\n};\n\nconst EditorToggle = styled(IconButton)`\n  margin-bottom: 12px;\n`;\n\nfunction ReactSplitPaneGlobalStyles() {\n  return (\n    <Global\n      styles={css`\n        .Resizer.vertical {\n          width: 2px;\n          cursor: col-resize;\n          position: relative;\n          background: none;\n\n          &:before {\n            content: '';\n            width: 2px;\n            height: 100%;\n            position: relative;\n            background-color: ${colors.textFieldBorder};\n            display: block;\n            z-index: 10;\n            transition: background-color ${transitions.main};\n          }\n\n          &:hover,\n          &:active {\n            &:before {\n              width: 4px;\n              left: -1px;\n              background-color: ${colorsRaw.blue};\n            }\n          }\n        }\n      `}\n    />\n  );\n}\n\nconst StyledSplitPane = styled(SplitPane)`\n  ${styles.splitPane};\n\n  /**\n   * Quick fix for preview pane not fully displaying in Safari\n   */\n  .Pane {\n    height: 100%;\n  }\n`;\n\nconst NoPreviewContainer = styled.div`\n  ${styles.splitPane};\n`;\n\nconst EditorContainer = styled.div`\n  width: 100%;\n  min-width: 800px;\n  height: 100%;\n  position: absolute;\n  top: 0;\n  left: 0;\n  overflow: hidden;\n  padding-top: 66px;\n  background-color: ${colors.background};\n`;\n\nconst Editor = styled.div`\n  height: 100%;\n  margin: 0 auto;\n  position: relative;\n`;\n\nconst PreviewPaneContainer = styled.div`\n  height: 100%;\n  pointer-events: ${props => (props.blockEntry ? 'none' : 'auto')};\n  overflow-y: ${props => (props.overFlow ? 'auto' : 'hidden')};\n`;\n\nconst ControlPaneContainer = styled(PreviewPaneContainer)`\n  padding: 0 16px;\n  position: relative;\n  overflow-x: hidden;\n`;\n\nconst ViewControls = styled.div`\n  position: absolute;\n  top: 10px;\n  right: 10px;\n  z-index: ${zIndex.zIndex299};\n`;\n\nfunction EditorContent({\n  i18nVisible,\n  previewVisible,\n  editor,\n  editorWithEditor,\n  editorWithPreview,\n}) {\n  if (i18nVisible) {\n    return editorWithEditor;\n  } else if (previewVisible) {\n    return editorWithPreview;\n  } else {\n    return <NoPreviewContainer>{editor}</NoPreviewContainer>;\n  }\n}\n\nfunction isPreviewEnabled(collection, entry) {\n  if (collection.get('type') === FILES) {\n    const file = getFileFromSlug(collection, entry.get('slug'));\n    const previewEnabled = file?.getIn(['editor', 'preview']);\n    if (previewEnabled != null) return previewEnabled;\n  }\n  return collection.getIn(['editor', 'preview'], true);\n}\n\nclass EditorInterface extends Component {\n  state = {\n    showEventBlocker: false,\n    previewVisible: localStorage.getItem(PREVIEW_VISIBLE) !== 'false',\n    scrollSyncEnabled: localStorage.getItem(SCROLL_SYNC_ENABLED) !== 'false',\n    i18nVisible: localStorage.getItem(I18N_VISIBLE) !== 'false',\n  };\n\n  handleFieldClick = path => {\n    this.controlPaneRef?.focus(path);\n  };\n\n  handleSplitPaneDragStart = () => {\n    this.setState({ showEventBlocker: true });\n  };\n\n  handleSplitPaneDragFinished = () => {\n    this.setState({ showEventBlocker: false });\n  };\n\n  handleOnPersist = async (opts = {}) => {\n    const { createNew = false, duplicate = false } = opts;\n    await this.controlPaneRef.switchToDefaultLocale();\n    this.controlPaneRef.validate();\n    this.props.onPersist({ createNew, duplicate });\n  };\n\n  handleOnPublish = async (opts = {}) => {\n    const { createNew = false, duplicate = false } = opts;\n    await this.controlPaneRef.switchToDefaultLocale();\n    this.controlPaneRef.validate();\n    this.props.onPublish({ createNew, duplicate });\n  };\n\n  handleTogglePreview = () => {\n    const newPreviewVisible = !this.state.previewVisible;\n    this.setState({ previewVisible: newPreviewVisible });\n    localStorage.setItem(PREVIEW_VISIBLE, newPreviewVisible);\n  };\n\n  handleToggleScrollSync = () => {\n    const newScrollSyncEnabled = !this.state.scrollSyncEnabled;\n    this.setState({ scrollSyncEnabled: newScrollSyncEnabled });\n    localStorage.setItem(SCROLL_SYNC_ENABLED, newScrollSyncEnabled);\n  };\n\n  handleToggleI18n = () => {\n    const newI18nVisible = !this.state.i18nVisible;\n    this.setState({ i18nVisible: newI18nVisible });\n    localStorage.setItem(I18N_VISIBLE, newI18nVisible);\n  };\n\n  handleLeftPanelLocaleChange = locale => {\n    this.setState({ leftPanelLocale: locale });\n  };\n\n  render() {\n    const {\n      collection,\n      entry,\n      fields,\n      fieldsMetaData,\n      fieldsErrors,\n      onChange,\n      showDelete,\n      onDelete,\n      onDeleteUnpublishedChanges,\n      onChangeStatus,\n      onPublish,\n      unPublish,\n      onDuplicate,\n      onValidate,\n      user,\n      hasChanged,\n      displayUrl,\n      hasWorkflow,\n      useOpenAuthoring,\n      hasUnpublishedChanges,\n      isNewEntry,\n      isModification,\n      currentStatus,\n      onLogoutClick,\n      loadDeployPreview,\n      deployPreview,\n      draftKey,\n      editorBackLink,\n      t,\n    } = this.props;\n\n    const { scrollSyncEnabled, showEventBlocker } = this.state;\n\n    const previewEnabled = isPreviewEnabled(collection, entry);\n\n    const { locales, defaultLocale } = getI18nInfo(this.props.collection);\n    const collectionI18nEnabled = hasI18n(collection) && locales.length > 1;\n    const editorProps = {\n      collection,\n      entry,\n      fields,\n      fieldsMetaData,\n      fieldsErrors,\n      onChange,\n      onValidate,\n    };\n\n    const leftPanelLocale = this.state.leftPanelLocale || locales?.[0];\n    const editor = (\n      <ControlPaneContainer overFlow blockEntry={showEventBlocker}>\n        <EditorControlPane\n          {...editorProps}\n          ref={c => (this.controlPaneRef = c)}\n          locale={leftPanelLocale}\n          t={t}\n          onLocaleChange={this.handleLeftPanelLocaleChange}\n        />\n      </ControlPaneContainer>\n    );\n\n    const editor2 = (\n      <ControlPaneContainer overFlow={!this.state.scrollSyncEnabled} blockEntry={showEventBlocker}>\n        <EditorControlPane {...editorProps} locale={locales?.[1]} t={t} />\n      </ControlPaneContainer>\n    );\n\n    const previewEntry = collectionI18nEnabled\n      ? getPreviewEntry(entry, leftPanelLocale, defaultLocale)\n      : entry;\n\n    const editorWithPreview = (\n      <ScrollSync enabled={this.state.scrollSyncEnabled}>\n        <div>\n          <ReactSplitPaneGlobalStyles />\n          <StyledSplitPane\n            maxSize={-100}\n            minSize={400}\n            defaultSize={parseInt(localStorage.getItem(SPLIT_PANE_POSITION), 10) || '50%'}\n            onChange={size => localStorage.setItem(SPLIT_PANE_POSITION, size)}\n            onDragStarted={this.handleSplitPaneDragStart}\n            onDragFinished={this.handleSplitPaneDragFinished}\n          >\n            <ScrollSyncPane>{editor}</ScrollSyncPane>\n            <PreviewPaneContainer blockEntry={showEventBlocker}>\n              <EditorPreviewPane\n                collection={collection}\n                entry={previewEntry}\n                fields={fields}\n                fieldsMetaData={fieldsMetaData}\n                locale={leftPanelLocale}\n                onFieldClick={this.handleFieldClick}\n              />\n            </PreviewPaneContainer>\n          </StyledSplitPane>\n        </div>\n      </ScrollSync>\n    );\n\n    const editorWithEditor = (\n      <ScrollSync enabled={this.state.scrollSyncEnabled}>\n        <div>\n          <StyledSplitPane\n            maxSize={-100}\n            defaultSize={parseInt(localStorage.getItem(SPLIT_PANE_POSITION), 10) || '50%'}\n            onChange={size => localStorage.setItem(SPLIT_PANE_POSITION, size)}\n            onDragStarted={this.handleSplitPaneDragStart}\n            onDragFinished={this.handleSplitPaneDragFinished}\n          >\n            <ScrollSyncPane>{editor}</ScrollSyncPane>\n            <ScrollSyncPane>{editor2}</ScrollSyncPane>\n          </StyledSplitPane>\n        </div>\n      </ScrollSync>\n    );\n\n    const i18nVisible = collectionI18nEnabled && this.state.i18nVisible;\n    const previewVisible = previewEnabled && this.state.previewVisible;\n    const scrollSyncVisible = i18nVisible || previewVisible;\n\n    return (\n      <EditorContainer>\n        <EditorToolbar\n          isPersisting={entry.get('isPersisting')}\n          isPublishing={entry.get('isPublishing')}\n          isUpdatingStatus={entry.get('isUpdatingStatus')}\n          isDeleting={entry.get('isDeleting')}\n          onPersist={this.handleOnPersist}\n          onPersistAndNew={() => this.handleOnPersist({ createNew: true })}\n          onPersistAndDuplicate={() => this.handleOnPersist({ createNew: true, duplicate: true })}\n          onDelete={onDelete}\n          onDeleteUnpublishedChanges={onDeleteUnpublishedChanges}\n          onChangeStatus={onChangeStatus}\n          showDelete={showDelete}\n          onPublish={onPublish}\n          unPublish={unPublish}\n          onDuplicate={onDuplicate}\n          onPublishAndNew={() => this.handleOnPublish({ createNew: true })}\n          onPublishAndDuplicate={() => this.handleOnPublish({ createNew: true, duplicate: true })}\n          user={user}\n          hasChanged={hasChanged}\n          displayUrl={displayUrl}\n          collection={collection}\n          hasWorkflow={hasWorkflow}\n          useOpenAuthoring={useOpenAuthoring}\n          hasUnpublishedChanges={hasUnpublishedChanges}\n          isNewEntry={isNewEntry}\n          isModification={isModification}\n          currentStatus={currentStatus}\n          onLogoutClick={onLogoutClick}\n          loadDeployPreview={loadDeployPreview}\n          deployPreview={deployPreview}\n          editorBackLink={editorBackLink}\n        />\n        <Editor key={draftKey}>\n          <ViewControls>\n            {collectionI18nEnabled && (\n              <EditorToggle\n                isActive={i18nVisible}\n                onClick={this.handleToggleI18n}\n                size=\"large\"\n                type=\"page\"\n                title={t('editor.editorInterface.toggleI18n')}\n                marginTop=\"70px\"\n              />\n            )}\n            {previewEnabled && (\n              <EditorToggle\n                isActive={previewVisible}\n                onClick={this.handleTogglePreview}\n                size=\"large\"\n                type=\"eye\"\n                title={t('editor.editorInterface.togglePreview')}\n              />\n            )}\n            {scrollSyncVisible && !collection.getIn(['editor', 'visualEditing']) && (\n              <EditorToggle\n                isActive={scrollSyncEnabled}\n                onClick={this.handleToggleScrollSync}\n                size=\"large\"\n                type=\"scroll\"\n                title={t('editor.editorInterface.toggleScrollSync')}\n              />\n            )}\n          </ViewControls>\n          <EditorContent\n            i18nVisible={i18nVisible}\n            previewVisible={previewVisible}\n            editor={editor}\n            editorWithEditor={editorWithEditor}\n            editorWithPreview={editorWithPreview}\n          />\n        </Editor>\n      </EditorContainer>\n    );\n  }\n}\n\nEditorInterface.propTypes = {\n  collection: ImmutablePropTypes.map.isRequired,\n  entry: ImmutablePropTypes.map.isRequired,\n  fields: ImmutablePropTypes.list.isRequired,\n  fieldsMetaData: ImmutablePropTypes.map.isRequired,\n  fieldsErrors: ImmutablePropTypes.map.isRequired,\n  onChange: PropTypes.func.isRequired,\n  onValidate: PropTypes.func.isRequired,\n  onPersist: PropTypes.func.isRequired,\n  showDelete: PropTypes.bool.isRequired,\n  onDelete: PropTypes.func.isRequired,\n  onDeleteUnpublishedChanges: PropTypes.func.isRequired,\n  onPublish: PropTypes.func.isRequired,\n  unPublish: PropTypes.func.isRequired,\n  onDuplicate: PropTypes.func.isRequired,\n  onChangeStatus: PropTypes.func.isRequired,\n  user: PropTypes.object,\n  hasChanged: PropTypes.bool,\n  displayUrl: PropTypes.string,\n  hasWorkflow: PropTypes.bool,\n  useOpenAuthoring: PropTypes.bool,\n  hasUnpublishedChanges: PropTypes.bool,\n  isNewEntry: PropTypes.bool,\n  isModification: PropTypes.bool,\n  currentStatus: PropTypes.string,\n  onLogoutClick: PropTypes.func.isRequired,\n  deployPreview: PropTypes.object,\n  loadDeployPreview: PropTypes.func.isRequired,\n  draftKey: PropTypes.string.isRequired,\n  t: PropTypes.func.isRequired,\n};\n\nexport default EditorInterface;\n"]} */"))
|
|
60
52
|
});
|
|
61
53
|
}
|
|
62
|
-
const StyledSplitPane = /*#__PURE__*/(
|
|
54
|
+
const StyledSplitPane = /*#__PURE__*/_styled(SplitPane, {
|
|
63
55
|
target: "e1nx103k6",
|
|
64
56
|
label: "StyledSplitPane"
|
|
65
|
-
})(styles.splitPane, ";.Pane{height:100%;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/Editor/EditorInterface.js"],"names":[],"mappings":"AA+EyC","file":"../../../../src/components/Editor/EditorInterface.js","sourcesContent":["import PropTypes from 'prop-types';\nimport React, { Component } from 'react';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\nimport { css, Global } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport SplitPane from 'react-split-pane';\nimport {\n  colors,\n  colorsRaw,\n  components,\n  transitions,\n  IconButton,\n  zIndex,\n} from 'decap-cms-ui-default';\nimport { ScrollSync, ScrollSyncPane } from 'react-scroll-sync';\n\nimport EditorControlPane from './EditorControlPane/EditorControlPane';\nimport EditorPreviewPane from './EditorPreviewPane/EditorPreviewPane';\nimport EditorToolbar from './EditorToolbar';\nimport { hasI18n, getI18nInfo, getPreviewEntry } from '../../lib/i18n';\nimport { FILES } from '../../constants/collectionTypes';\nimport { getFileFromSlug } from '../../reducers/collections';\n\nconst PREVIEW_VISIBLE = 'cms.preview-visible';\nconst SCROLL_SYNC_ENABLED = 'cms.scroll-sync-enabled';\nconst SPLIT_PANE_POSITION = 'cms.split-pane-position';\nconst I18N_VISIBLE = 'cms.i18n-visible';\n\nconst styles = {\n  splitPane: css`\n    ${components.card};\n    border-radius: 0;\n    height: 100%;\n  `,\n  pane: css`\n    height: 100%;\n    overflow-y: auto;\n  `,\n};\n\nconst EditorToggle = styled(IconButton)`\n  margin-bottom: 12px;\n`;\n\nfunction ReactSplitPaneGlobalStyles() {\n  return (\n    <Global\n      styles={css`\n        .Resizer.vertical {\n          width: 2px;\n          cursor: col-resize;\n          position: relative;\n          background: none;\n\n          &:before {\n            content: '';\n            width: 2px;\n            height: 100%;\n            position: relative;\n            background-color: ${colors.textFieldBorder};\n            display: block;\n            z-index: 10;\n            transition: background-color ${transitions.main};\n          }\n\n          &:hover,\n          &:active {\n            &:before {\n              width: 4px;\n              left: -1px;\n              background-color: ${colorsRaw.blue};\n            }\n          }\n        }\n      `}\n    />\n  );\n}\n\nconst StyledSplitPane = styled(SplitPane)`\n  ${styles.splitPane};\n\n  /**\n   * Quick fix for preview pane not fully displaying in Safari\n   */\n  .Pane {\n    height: 100%;\n  }\n`;\n\nconst NoPreviewContainer = styled.div`\n  ${styles.splitPane};\n`;\n\nconst EditorContainer = styled.div`\n  width: 100%;\n  min-width: 800px;\n  height: 100%;\n  position: absolute;\n  top: 0;\n  left: 0;\n  overflow: hidden;\n  padding-top: 66px;\n  background-color: ${colors.background};\n`;\n\nconst Editor = styled.div`\n  height: 100%;\n  margin: 0 auto;\n  position: relative;\n`;\n\nconst PreviewPaneContainer = styled.div`\n  height: 100%;\n  pointer-events: ${props => (props.blockEntry ? 'none' : 'auto')};\n  overflow-y: ${props => (props.overFlow ? 'auto' : 'hidden')};\n`;\n\nconst ControlPaneContainer = styled(PreviewPaneContainer)`\n  padding: 0 16px;\n  position: relative;\n  overflow-x: hidden;\n`;\n\nconst ViewControls = styled.div`\n  position: absolute;\n  top: 10px;\n  right: 10px;\n  z-index: ${zIndex.zIndex299};\n`;\n\nfunction EditorContent({\n  i18nVisible,\n  previewVisible,\n  editor,\n  editorWithEditor,\n  editorWithPreview,\n}) {\n  if (i18nVisible) {\n    return editorWithEditor;\n  } else if (previewVisible) {\n    return editorWithPreview;\n  } else {\n    return <NoPreviewContainer>{editor}</NoPreviewContainer>;\n  }\n}\n\nfunction isPreviewEnabled(collection, entry) {\n  if (collection.get('type') === FILES) {\n    const file = getFileFromSlug(collection, entry.get('slug'));\n    const previewEnabled = file?.getIn(['editor', 'preview']);\n    if (previewEnabled != null) return previewEnabled;\n  }\n  return collection.getIn(['editor', 'preview'], true);\n}\n\nclass EditorInterface extends Component {\n  state = {\n    showEventBlocker: false,\n    previewVisible: localStorage.getItem(PREVIEW_VISIBLE) !== 'false',\n    scrollSyncEnabled: localStorage.getItem(SCROLL_SYNC_ENABLED) !== 'false',\n    i18nVisible: localStorage.getItem(I18N_VISIBLE) !== 'false',\n  };\n\n  handleSplitPaneDragStart = () => {\n    this.setState({ showEventBlocker: true });\n  };\n\n  handleSplitPaneDragFinished = () => {\n    this.setState({ showEventBlocker: false });\n  };\n\n  handleOnPersist = async (opts = {}) => {\n    const { createNew = false, duplicate = false } = opts;\n    await this.controlPaneRef.switchToDefaultLocale();\n    this.controlPaneRef.validate();\n    this.props.onPersist({ createNew, duplicate });\n  };\n\n  handleOnPublish = async (opts = {}) => {\n    const { createNew = false, duplicate = false } = opts;\n    await this.controlPaneRef.switchToDefaultLocale();\n    this.controlPaneRef.validate();\n    this.props.onPublish({ createNew, duplicate });\n  };\n\n  handleTogglePreview = () => {\n    const newPreviewVisible = !this.state.previewVisible;\n    this.setState({ previewVisible: newPreviewVisible });\n    localStorage.setItem(PREVIEW_VISIBLE, newPreviewVisible);\n  };\n\n  handleToggleScrollSync = () => {\n    const newScrollSyncEnabled = !this.state.scrollSyncEnabled;\n    this.setState({ scrollSyncEnabled: newScrollSyncEnabled });\n    localStorage.setItem(SCROLL_SYNC_ENABLED, newScrollSyncEnabled);\n  };\n\n  handleToggleI18n = () => {\n    const newI18nVisible = !this.state.i18nVisible;\n    this.setState({ i18nVisible: newI18nVisible });\n    localStorage.setItem(I18N_VISIBLE, newI18nVisible);\n  };\n\n  handleLeftPanelLocaleChange = locale => {\n    this.setState({ leftPanelLocale: locale });\n  };\n\n  render() {\n    const {\n      collection,\n      entry,\n      fields,\n      fieldsMetaData,\n      fieldsErrors,\n      onChange,\n      showDelete,\n      onDelete,\n      onDeleteUnpublishedChanges,\n      onChangeStatus,\n      onPublish,\n      unPublish,\n      onDuplicate,\n      onValidate,\n      user,\n      hasChanged,\n      displayUrl,\n      hasWorkflow,\n      useOpenAuthoring,\n      hasUnpublishedChanges,\n      isNewEntry,\n      isModification,\n      currentStatus,\n      onLogoutClick,\n      loadDeployPreview,\n      deployPreview,\n      draftKey,\n      editorBackLink,\n      t,\n    } = this.props;\n\n    const { scrollSyncEnabled, showEventBlocker } = this.state;\n\n    const previewEnabled = isPreviewEnabled(collection, entry);\n\n    const { locales, defaultLocale } = getI18nInfo(this.props.collection);\n    const collectionI18nEnabled = hasI18n(collection) && locales.length > 1;\n    const editorProps = {\n      collection,\n      entry,\n      fields,\n      fieldsMetaData,\n      fieldsErrors,\n      onChange,\n      onValidate,\n    };\n\n    const leftPanelLocale = this.state.leftPanelLocale || locales?.[0];\n    const editor = (\n      <ControlPaneContainer overFlow blockEntry={showEventBlocker}>\n        <EditorControlPane\n          {...editorProps}\n          ref={c => (this.controlPaneRef = c)}\n          locale={leftPanelLocale}\n          t={t}\n          onLocaleChange={this.handleLeftPanelLocaleChange}\n        />\n      </ControlPaneContainer>\n    );\n\n    const editor2 = (\n      <ControlPaneContainer overFlow={!this.state.scrollSyncEnabled} blockEntry={showEventBlocker}>\n        <EditorControlPane {...editorProps} locale={locales?.[1]} t={t} />\n      </ControlPaneContainer>\n    );\n\n    const previewEntry = collectionI18nEnabled\n      ? getPreviewEntry(entry, leftPanelLocale, defaultLocale)\n      : entry;\n\n    const editorWithPreview = (\n      <ScrollSync enabled={this.state.scrollSyncEnabled}>\n        <div>\n          <ReactSplitPaneGlobalStyles />\n          <StyledSplitPane\n            maxSize={-100}\n            minSize={400}\n            defaultSize={parseInt(localStorage.getItem(SPLIT_PANE_POSITION), 10) || '50%'}\n            onChange={size => localStorage.setItem(SPLIT_PANE_POSITION, size)}\n            onDragStarted={this.handleSplitPaneDragStart}\n            onDragFinished={this.handleSplitPaneDragFinished}\n          >\n            <ScrollSyncPane>{editor}</ScrollSyncPane>\n            <PreviewPaneContainer blockEntry={showEventBlocker}>\n              <EditorPreviewPane\n                collection={collection}\n                entry={previewEntry}\n                fields={fields}\n                fieldsMetaData={fieldsMetaData}\n                locale={leftPanelLocale}\n              />\n            </PreviewPaneContainer>\n          </StyledSplitPane>\n        </div>\n      </ScrollSync>\n    );\n\n    const editorWithEditor = (\n      <ScrollSync enabled={this.state.scrollSyncEnabled}>\n        <div>\n          <StyledSplitPane\n            maxSize={-100}\n            defaultSize={parseInt(localStorage.getItem(SPLIT_PANE_POSITION), 10) || '50%'}\n            onChange={size => localStorage.setItem(SPLIT_PANE_POSITION, size)}\n            onDragStarted={this.handleSplitPaneDragStart}\n            onDragFinished={this.handleSplitPaneDragFinished}\n          >\n            <ScrollSyncPane>{editor}</ScrollSyncPane>\n            <ScrollSyncPane>{editor2}</ScrollSyncPane>\n          </StyledSplitPane>\n        </div>\n      </ScrollSync>\n    );\n\n    const i18nVisible = collectionI18nEnabled && this.state.i18nVisible;\n    const previewVisible = previewEnabled && this.state.previewVisible;\n    const scrollSyncVisible = i18nVisible || previewVisible;\n\n    return (\n      <EditorContainer>\n        <EditorToolbar\n          isPersisting={entry.get('isPersisting')}\n          isPublishing={entry.get('isPublishing')}\n          isUpdatingStatus={entry.get('isUpdatingStatus')}\n          isDeleting={entry.get('isDeleting')}\n          onPersist={this.handleOnPersist}\n          onPersistAndNew={() => this.handleOnPersist({ createNew: true })}\n          onPersistAndDuplicate={() => this.handleOnPersist({ createNew: true, duplicate: true })}\n          onDelete={onDelete}\n          onDeleteUnpublishedChanges={onDeleteUnpublishedChanges}\n          onChangeStatus={onChangeStatus}\n          showDelete={showDelete}\n          onPublish={onPublish}\n          unPublish={unPublish}\n          onDuplicate={onDuplicate}\n          onPublishAndNew={() => this.handleOnPublish({ createNew: true })}\n          onPublishAndDuplicate={() => this.handleOnPublish({ createNew: true, duplicate: true })}\n          user={user}\n          hasChanged={hasChanged}\n          displayUrl={displayUrl}\n          collection={collection}\n          hasWorkflow={hasWorkflow}\n          useOpenAuthoring={useOpenAuthoring}\n          hasUnpublishedChanges={hasUnpublishedChanges}\n          isNewEntry={isNewEntry}\n          isModification={isModification}\n          currentStatus={currentStatus}\n          onLogoutClick={onLogoutClick}\n          loadDeployPreview={loadDeployPreview}\n          deployPreview={deployPreview}\n          editorBackLink={editorBackLink}\n        />\n        <Editor key={draftKey}>\n          <ViewControls>\n            {collectionI18nEnabled && (\n              <EditorToggle\n                isActive={i18nVisible}\n                onClick={this.handleToggleI18n}\n                size=\"large\"\n                type=\"page\"\n                title={t('editor.editorInterface.toggleI18n')}\n                marginTop=\"70px\"\n              />\n            )}\n            {previewEnabled && (\n              <EditorToggle\n                isActive={previewVisible}\n                onClick={this.handleTogglePreview}\n                size=\"large\"\n                type=\"eye\"\n                title={t('editor.editorInterface.togglePreview')}\n              />\n            )}\n            {scrollSyncVisible && (\n              <EditorToggle\n                isActive={scrollSyncEnabled}\n                onClick={this.handleToggleScrollSync}\n                size=\"large\"\n                type=\"scroll\"\n                title={t('editor.editorInterface.toggleScrollSync')}\n              />\n            )}\n          </ViewControls>\n          <EditorContent\n            i18nVisible={i18nVisible}\n            previewVisible={previewVisible}\n            editor={editor}\n            editorWithEditor={editorWithEditor}\n            editorWithPreview={editorWithPreview}\n          />\n        </Editor>\n      </EditorContainer>\n    );\n  }\n}\n\nEditorInterface.propTypes = {\n  collection: ImmutablePropTypes.map.isRequired,\n  entry: ImmutablePropTypes.map.isRequired,\n  fields: ImmutablePropTypes.list.isRequired,\n  fieldsMetaData: ImmutablePropTypes.map.isRequired,\n  fieldsErrors: ImmutablePropTypes.map.isRequired,\n  onChange: PropTypes.func.isRequired,\n  onValidate: PropTypes.func.isRequired,\n  onPersist: PropTypes.func.isRequired,\n  showDelete: PropTypes.bool.isRequired,\n  onDelete: PropTypes.func.isRequired,\n  onDeleteUnpublishedChanges: PropTypes.func.isRequired,\n  onPublish: PropTypes.func.isRequired,\n  unPublish: PropTypes.func.isRequired,\n  onDuplicate: PropTypes.func.isRequired,\n  onChangeStatus: PropTypes.func.isRequired,\n  user: PropTypes.object,\n  hasChanged: PropTypes.bool,\n  displayUrl: PropTypes.string,\n  hasWorkflow: PropTypes.bool,\n  useOpenAuthoring: PropTypes.bool,\n  hasUnpublishedChanges: PropTypes.bool,\n  isNewEntry: PropTypes.bool,\n  isModification: PropTypes.bool,\n  currentStatus: PropTypes.string,\n  onLogoutClick: PropTypes.func.isRequired,\n  deployPreview: PropTypes.object,\n  loadDeployPreview: PropTypes.func.isRequired,\n  draftKey: PropTypes.string.isRequired,\n  t: PropTypes.func.isRequired,\n};\n\nexport default EditorInterface;\n"]} */"));
|
|
66
|
-
const NoPreviewContainer = /*#__PURE__*/(
|
|
57
|
+
})(styles.splitPane, ";.Pane{height:100%;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/Editor/EditorInterface.js"],"names":[],"mappings":"AA+EyC","file":"../../../../src/components/Editor/EditorInterface.js","sourcesContent":["import PropTypes from 'prop-types';\nimport React, { Component } from 'react';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\nimport { css, Global } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport SplitPane from 'react-split-pane';\nimport {\n  colors,\n  colorsRaw,\n  components,\n  transitions,\n  IconButton,\n  zIndex,\n} from 'decap-cms-ui-default';\nimport { ScrollSync, ScrollSyncPane } from 'react-scroll-sync';\n\nimport EditorControlPane from './EditorControlPane/EditorControlPane';\nimport EditorPreviewPane from './EditorPreviewPane/EditorPreviewPane';\nimport EditorToolbar from './EditorToolbar';\nimport { hasI18n, getI18nInfo, getPreviewEntry } from '../../lib/i18n';\nimport { FILES } from '../../constants/collectionTypes';\nimport { getFileFromSlug } from '../../reducers/collections';\n\nconst PREVIEW_VISIBLE = 'cms.preview-visible';\nconst SCROLL_SYNC_ENABLED = 'cms.scroll-sync-enabled';\nconst SPLIT_PANE_POSITION = 'cms.split-pane-position';\nconst I18N_VISIBLE = 'cms.i18n-visible';\n\nconst styles = {\n  splitPane: css`\n    ${components.card};\n    border-radius: 0;\n    height: 100%;\n  `,\n  pane: css`\n    height: 100%;\n    overflow-y: auto;\n  `,\n};\n\nconst EditorToggle = styled(IconButton)`\n  margin-bottom: 12px;\n`;\n\nfunction ReactSplitPaneGlobalStyles() {\n  return (\n    <Global\n      styles={css`\n        .Resizer.vertical {\n          width: 2px;\n          cursor: col-resize;\n          position: relative;\n          background: none;\n\n          &:before {\n            content: '';\n            width: 2px;\n            height: 100%;\n            position: relative;\n            background-color: ${colors.textFieldBorder};\n            display: block;\n            z-index: 10;\n            transition: background-color ${transitions.main};\n          }\n\n          &:hover,\n          &:active {\n            &:before {\n              width: 4px;\n              left: -1px;\n              background-color: ${colorsRaw.blue};\n            }\n          }\n        }\n      `}\n    />\n  );\n}\n\nconst StyledSplitPane = styled(SplitPane)`\n  ${styles.splitPane};\n\n  /**\n   * Quick fix for preview pane not fully displaying in Safari\n   */\n  .Pane {\n    height: 100%;\n  }\n`;\n\nconst NoPreviewContainer = styled.div`\n  ${styles.splitPane};\n`;\n\nconst EditorContainer = styled.div`\n  width: 100%;\n  min-width: 800px;\n  height: 100%;\n  position: absolute;\n  top: 0;\n  left: 0;\n  overflow: hidden;\n  padding-top: 66px;\n  background-color: ${colors.background};\n`;\n\nconst Editor = styled.div`\n  height: 100%;\n  margin: 0 auto;\n  position: relative;\n`;\n\nconst PreviewPaneContainer = styled.div`\n  height: 100%;\n  pointer-events: ${props => (props.blockEntry ? 'none' : 'auto')};\n  overflow-y: ${props => (props.overFlow ? 'auto' : 'hidden')};\n`;\n\nconst ControlPaneContainer = styled(PreviewPaneContainer)`\n  padding: 0 16px;\n  position: relative;\n  overflow-x: hidden;\n`;\n\nconst ViewControls = styled.div`\n  position: absolute;\n  top: 10px;\n  right: 10px;\n  z-index: ${zIndex.zIndex299};\n`;\n\nfunction EditorContent({\n  i18nVisible,\n  previewVisible,\n  editor,\n  editorWithEditor,\n  editorWithPreview,\n}) {\n  if (i18nVisible) {\n    return editorWithEditor;\n  } else if (previewVisible) {\n    return editorWithPreview;\n  } else {\n    return <NoPreviewContainer>{editor}</NoPreviewContainer>;\n  }\n}\n\nfunction isPreviewEnabled(collection, entry) {\n  if (collection.get('type') === FILES) {\n    const file = getFileFromSlug(collection, entry.get('slug'));\n    const previewEnabled = file?.getIn(['editor', 'preview']);\n    if (previewEnabled != null) return previewEnabled;\n  }\n  return collection.getIn(['editor', 'preview'], true);\n}\n\nclass EditorInterface extends Component {\n  state = {\n    showEventBlocker: false,\n    previewVisible: localStorage.getItem(PREVIEW_VISIBLE) !== 'false',\n    scrollSyncEnabled: localStorage.getItem(SCROLL_SYNC_ENABLED) !== 'false',\n    i18nVisible: localStorage.getItem(I18N_VISIBLE) !== 'false',\n  };\n\n  handleFieldClick = path => {\n    this.controlPaneRef?.focus(path);\n  };\n\n  handleSplitPaneDragStart = () => {\n    this.setState({ showEventBlocker: true });\n  };\n\n  handleSplitPaneDragFinished = () => {\n    this.setState({ showEventBlocker: false });\n  };\n\n  handleOnPersist = async (opts = {}) => {\n    const { createNew = false, duplicate = false } = opts;\n    await this.controlPaneRef.switchToDefaultLocale();\n    this.controlPaneRef.validate();\n    this.props.onPersist({ createNew, duplicate });\n  };\n\n  handleOnPublish = async (opts = {}) => {\n    const { createNew = false, duplicate = false } = opts;\n    await this.controlPaneRef.switchToDefaultLocale();\n    this.controlPaneRef.validate();\n    this.props.onPublish({ createNew, duplicate });\n  };\n\n  handleTogglePreview = () => {\n    const newPreviewVisible = !this.state.previewVisible;\n    this.setState({ previewVisible: newPreviewVisible });\n    localStorage.setItem(PREVIEW_VISIBLE, newPreviewVisible);\n  };\n\n  handleToggleScrollSync = () => {\n    const newScrollSyncEnabled = !this.state.scrollSyncEnabled;\n    this.setState({ scrollSyncEnabled: newScrollSyncEnabled });\n    localStorage.setItem(SCROLL_SYNC_ENABLED, newScrollSyncEnabled);\n  };\n\n  handleToggleI18n = () => {\n    const newI18nVisible = !this.state.i18nVisible;\n    this.setState({ i18nVisible: newI18nVisible });\n    localStorage.setItem(I18N_VISIBLE, newI18nVisible);\n  };\n\n  handleLeftPanelLocaleChange = locale => {\n    this.setState({ leftPanelLocale: locale });\n  };\n\n  render() {\n    const {\n      collection,\n      entry,\n      fields,\n      fieldsMetaData,\n      fieldsErrors,\n      onChange,\n      showDelete,\n      onDelete,\n      onDeleteUnpublishedChanges,\n      onChangeStatus,\n      onPublish,\n      unPublish,\n      onDuplicate,\n      onValidate,\n      user,\n      hasChanged,\n      displayUrl,\n      hasWorkflow,\n      useOpenAuthoring,\n      hasUnpublishedChanges,\n      isNewEntry,\n      isModification,\n      currentStatus,\n      onLogoutClick,\n      loadDeployPreview,\n      deployPreview,\n      draftKey,\n      editorBackLink,\n      t,\n    } = this.props;\n\n    const { scrollSyncEnabled, showEventBlocker } = this.state;\n\n    const previewEnabled = isPreviewEnabled(collection, entry);\n\n    const { locales, defaultLocale } = getI18nInfo(this.props.collection);\n    const collectionI18nEnabled = hasI18n(collection) && locales.length > 1;\n    const editorProps = {\n      collection,\n      entry,\n      fields,\n      fieldsMetaData,\n      fieldsErrors,\n      onChange,\n      onValidate,\n    };\n\n    const leftPanelLocale = this.state.leftPanelLocale || locales?.[0];\n    const editor = (\n      <ControlPaneContainer overFlow blockEntry={showEventBlocker}>\n        <EditorControlPane\n          {...editorProps}\n          ref={c => (this.controlPaneRef = c)}\n          locale={leftPanelLocale}\n          t={t}\n          onLocaleChange={this.handleLeftPanelLocaleChange}\n        />\n      </ControlPaneContainer>\n    );\n\n    const editor2 = (\n      <ControlPaneContainer overFlow={!this.state.scrollSyncEnabled} blockEntry={showEventBlocker}>\n        <EditorControlPane {...editorProps} locale={locales?.[1]} t={t} />\n      </ControlPaneContainer>\n    );\n\n    const previewEntry = collectionI18nEnabled\n      ? getPreviewEntry(entry, leftPanelLocale, defaultLocale)\n      : entry;\n\n    const editorWithPreview = (\n      <ScrollSync enabled={this.state.scrollSyncEnabled}>\n        <div>\n          <ReactSplitPaneGlobalStyles />\n          <StyledSplitPane\n            maxSize={-100}\n            minSize={400}\n            defaultSize={parseInt(localStorage.getItem(SPLIT_PANE_POSITION), 10) || '50%'}\n            onChange={size => localStorage.setItem(SPLIT_PANE_POSITION, size)}\n            onDragStarted={this.handleSplitPaneDragStart}\n            onDragFinished={this.handleSplitPaneDragFinished}\n          >\n            <ScrollSyncPane>{editor}</ScrollSyncPane>\n            <PreviewPaneContainer blockEntry={showEventBlocker}>\n              <EditorPreviewPane\n                collection={collection}\n                entry={previewEntry}\n                fields={fields}\n                fieldsMetaData={fieldsMetaData}\n                locale={leftPanelLocale}\n                onFieldClick={this.handleFieldClick}\n              />\n            </PreviewPaneContainer>\n          </StyledSplitPane>\n        </div>\n      </ScrollSync>\n    );\n\n    const editorWithEditor = (\n      <ScrollSync enabled={this.state.scrollSyncEnabled}>\n        <div>\n          <StyledSplitPane\n            maxSize={-100}\n            defaultSize={parseInt(localStorage.getItem(SPLIT_PANE_POSITION), 10) || '50%'}\n            onChange={size => localStorage.setItem(SPLIT_PANE_POSITION, size)}\n            onDragStarted={this.handleSplitPaneDragStart}\n            onDragFinished={this.handleSplitPaneDragFinished}\n          >\n            <ScrollSyncPane>{editor}</ScrollSyncPane>\n            <ScrollSyncPane>{editor2}</ScrollSyncPane>\n          </StyledSplitPane>\n        </div>\n      </ScrollSync>\n    );\n\n    const i18nVisible = collectionI18nEnabled && this.state.i18nVisible;\n    const previewVisible = previewEnabled && this.state.previewVisible;\n    const scrollSyncVisible = i18nVisible || previewVisible;\n\n    return (\n      <EditorContainer>\n        <EditorToolbar\n          isPersisting={entry.get('isPersisting')}\n          isPublishing={entry.get('isPublishing')}\n          isUpdatingStatus={entry.get('isUpdatingStatus')}\n          isDeleting={entry.get('isDeleting')}\n          onPersist={this.handleOnPersist}\n          onPersistAndNew={() => this.handleOnPersist({ createNew: true })}\n          onPersistAndDuplicate={() => this.handleOnPersist({ createNew: true, duplicate: true })}\n          onDelete={onDelete}\n          onDeleteUnpublishedChanges={onDeleteUnpublishedChanges}\n          onChangeStatus={onChangeStatus}\n          showDelete={showDelete}\n          onPublish={onPublish}\n          unPublish={unPublish}\n          onDuplicate={onDuplicate}\n          onPublishAndNew={() => this.handleOnPublish({ createNew: true })}\n          onPublishAndDuplicate={() => this.handleOnPublish({ createNew: true, duplicate: true })}\n          user={user}\n          hasChanged={hasChanged}\n          displayUrl={displayUrl}\n          collection={collection}\n          hasWorkflow={hasWorkflow}\n          useOpenAuthoring={useOpenAuthoring}\n          hasUnpublishedChanges={hasUnpublishedChanges}\n          isNewEntry={isNewEntry}\n          isModification={isModification}\n          currentStatus={currentStatus}\n          onLogoutClick={onLogoutClick}\n          loadDeployPreview={loadDeployPreview}\n          deployPreview={deployPreview}\n          editorBackLink={editorBackLink}\n        />\n        <Editor key={draftKey}>\n          <ViewControls>\n            {collectionI18nEnabled && (\n              <EditorToggle\n                isActive={i18nVisible}\n                onClick={this.handleToggleI18n}\n                size=\"large\"\n                type=\"page\"\n                title={t('editor.editorInterface.toggleI18n')}\n                marginTop=\"70px\"\n              />\n            )}\n            {previewEnabled && (\n              <EditorToggle\n                isActive={previewVisible}\n                onClick={this.handleTogglePreview}\n                size=\"large\"\n                type=\"eye\"\n                title={t('editor.editorInterface.togglePreview')}\n              />\n            )}\n            {scrollSyncVisible && !collection.getIn(['editor', 'visualEditing']) && (\n              <EditorToggle\n                isActive={scrollSyncEnabled}\n                onClick={this.handleToggleScrollSync}\n                size=\"large\"\n                type=\"scroll\"\n                title={t('editor.editorInterface.toggleScrollSync')}\n              />\n            )}\n          </ViewControls>\n          <EditorContent\n            i18nVisible={i18nVisible}\n            previewVisible={previewVisible}\n            editor={editor}\n            editorWithEditor={editorWithEditor}\n            editorWithPreview={editorWithPreview}\n          />\n        </Editor>\n      </EditorContainer>\n    );\n  }\n}\n\nEditorInterface.propTypes = {\n  collection: ImmutablePropTypes.map.isRequired,\n  entry: ImmutablePropTypes.map.isRequired,\n  fields: ImmutablePropTypes.list.isRequired,\n  fieldsMetaData: ImmutablePropTypes.map.isRequired,\n  fieldsErrors: ImmutablePropTypes.map.isRequired,\n  onChange: PropTypes.func.isRequired,\n  onValidate: PropTypes.func.isRequired,\n  onPersist: PropTypes.func.isRequired,\n  showDelete: PropTypes.bool.isRequired,\n  onDelete: PropTypes.func.isRequired,\n  onDeleteUnpublishedChanges: PropTypes.func.isRequired,\n  onPublish: PropTypes.func.isRequired,\n  unPublish: PropTypes.func.isRequired,\n  onDuplicate: PropTypes.func.isRequired,\n  onChangeStatus: PropTypes.func.isRequired,\n  user: PropTypes.object,\n  hasChanged: PropTypes.bool,\n  displayUrl: PropTypes.string,\n  hasWorkflow: PropTypes.bool,\n  useOpenAuthoring: PropTypes.bool,\n  hasUnpublishedChanges: PropTypes.bool,\n  isNewEntry: PropTypes.bool,\n  isModification: PropTypes.bool,\n  currentStatus: PropTypes.string,\n  onLogoutClick: PropTypes.func.isRequired,\n  deployPreview: PropTypes.object,\n  loadDeployPreview: PropTypes.func.isRequired,\n  draftKey: PropTypes.string.isRequired,\n  t: PropTypes.func.isRequired,\n};\n\nexport default EditorInterface;\n"]} */"));
|
|
58
|
+
const NoPreviewContainer = /*#__PURE__*/_styled("div", {
|
|
67
59
|
target: "e1nx103k5",
|
|
68
60
|
label: "NoPreviewContainer"
|
|
69
|
-
})(styles.splitPane, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/Editor/EditorInterface.js"],"names":[],"mappings":"AA0FqC","file":"../../../../src/components/Editor/EditorInterface.js","sourcesContent":["import PropTypes from 'prop-types';\nimport React, { Component } from 'react';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\nimport { css, Global } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport SplitPane from 'react-split-pane';\nimport {\n  colors,\n  colorsRaw,\n  components,\n  transitions,\n  IconButton,\n  zIndex,\n} from 'decap-cms-ui-default';\nimport { ScrollSync, ScrollSyncPane } from 'react-scroll-sync';\n\nimport EditorControlPane from './EditorControlPane/EditorControlPane';\nimport EditorPreviewPane from './EditorPreviewPane/EditorPreviewPane';\nimport EditorToolbar from './EditorToolbar';\nimport { hasI18n, getI18nInfo, getPreviewEntry } from '../../lib/i18n';\nimport { FILES } from '../../constants/collectionTypes';\nimport { getFileFromSlug } from '../../reducers/collections';\n\nconst PREVIEW_VISIBLE = 'cms.preview-visible';\nconst SCROLL_SYNC_ENABLED = 'cms.scroll-sync-enabled';\nconst SPLIT_PANE_POSITION = 'cms.split-pane-position';\nconst I18N_VISIBLE = 'cms.i18n-visible';\n\nconst styles = {\n  splitPane: css`\n    ${components.card};\n    border-radius: 0;\n    height: 100%;\n  `,\n  pane: css`\n    height: 100%;\n    overflow-y: auto;\n  `,\n};\n\nconst EditorToggle = styled(IconButton)`\n  margin-bottom: 12px;\n`;\n\nfunction ReactSplitPaneGlobalStyles() {\n  return (\n    <Global\n      styles={css`\n        .Resizer.vertical {\n          width: 2px;\n          cursor: col-resize;\n          position: relative;\n          background: none;\n\n          &:before {\n            content: '';\n            width: 2px;\n            height: 100%;\n            position: relative;\n            background-color: ${colors.textFieldBorder};\n            display: block;\n            z-index: 10;\n            transition: background-color ${transitions.main};\n          }\n\n          &:hover,\n          &:active {\n            &:before {\n              width: 4px;\n              left: -1px;\n              background-color: ${colorsRaw.blue};\n            }\n          }\n        }\n      `}\n    />\n  );\n}\n\nconst StyledSplitPane = styled(SplitPane)`\n  ${styles.splitPane};\n\n  /**\n   * Quick fix for preview pane not fully displaying in Safari\n   */\n  .Pane {\n    height: 100%;\n  }\n`;\n\nconst NoPreviewContainer = styled.div`\n  ${styles.splitPane};\n`;\n\nconst EditorContainer = styled.div`\n  width: 100%;\n  min-width: 800px;\n  height: 100%;\n  position: absolute;\n  top: 0;\n  left: 0;\n  overflow: hidden;\n  padding-top: 66px;\n  background-color: ${colors.background};\n`;\n\nconst Editor = styled.div`\n  height: 100%;\n  margin: 0 auto;\n  position: relative;\n`;\n\nconst PreviewPaneContainer = styled.div`\n  height: 100%;\n  pointer-events: ${props => (props.blockEntry ? 'none' : 'auto')};\n  overflow-y: ${props => (props.overFlow ? 'auto' : 'hidden')};\n`;\n\nconst ControlPaneContainer = styled(PreviewPaneContainer)`\n  padding: 0 16px;\n  position: relative;\n  overflow-x: hidden;\n`;\n\nconst ViewControls = styled.div`\n  position: absolute;\n  top: 10px;\n  right: 10px;\n  z-index: ${zIndex.zIndex299};\n`;\n\nfunction EditorContent({\n  i18nVisible,\n  previewVisible,\n  editor,\n  editorWithEditor,\n  editorWithPreview,\n}) {\n  if (i18nVisible) {\n    return editorWithEditor;\n  } else if (previewVisible) {\n    return editorWithPreview;\n  } else {\n    return <NoPreviewContainer>{editor}</NoPreviewContainer>;\n  }\n}\n\nfunction isPreviewEnabled(collection, entry) {\n  if (collection.get('type') === FILES) {\n    const file = getFileFromSlug(collection, entry.get('slug'));\n    const previewEnabled = file?.getIn(['editor', 'preview']);\n    if (previewEnabled != null) return previewEnabled;\n  }\n  return collection.getIn(['editor', 'preview'], true);\n}\n\nclass EditorInterface extends Component {\n  state = {\n    showEventBlocker: false,\n    previewVisible: localStorage.getItem(PREVIEW_VISIBLE) !== 'false',\n    scrollSyncEnabled: localStorage.getItem(SCROLL_SYNC_ENABLED) !== 'false',\n    i18nVisible: localStorage.getItem(I18N_VISIBLE) !== 'false',\n  };\n\n  handleSplitPaneDragStart = () => {\n    this.setState({ showEventBlocker: true });\n  };\n\n  handleSplitPaneDragFinished = () => {\n    this.setState({ showEventBlocker: false });\n  };\n\n  handleOnPersist = async (opts = {}) => {\n    const { createNew = false, duplicate = false } = opts;\n    await this.controlPaneRef.switchToDefaultLocale();\n    this.controlPaneRef.validate();\n    this.props.onPersist({ createNew, duplicate });\n  };\n\n  handleOnPublish = async (opts = {}) => {\n    const { createNew = false, duplicate = false } = opts;\n    await this.controlPaneRef.switchToDefaultLocale();\n    this.controlPaneRef.validate();\n    this.props.onPublish({ createNew, duplicate });\n  };\n\n  handleTogglePreview = () => {\n    const newPreviewVisible = !this.state.previewVisible;\n    this.setState({ previewVisible: newPreviewVisible });\n    localStorage.setItem(PREVIEW_VISIBLE, newPreviewVisible);\n  };\n\n  handleToggleScrollSync = () => {\n    const newScrollSyncEnabled = !this.state.scrollSyncEnabled;\n    this.setState({ scrollSyncEnabled: newScrollSyncEnabled });\n    localStorage.setItem(SCROLL_SYNC_ENABLED, newScrollSyncEnabled);\n  };\n\n  handleToggleI18n = () => {\n    const newI18nVisible = !this.state.i18nVisible;\n    this.setState({ i18nVisible: newI18nVisible });\n    localStorage.setItem(I18N_VISIBLE, newI18nVisible);\n  };\n\n  handleLeftPanelLocaleChange = locale => {\n    this.setState({ leftPanelLocale: locale });\n  };\n\n  render() {\n    const {\n      collection,\n      entry,\n      fields,\n      fieldsMetaData,\n      fieldsErrors,\n      onChange,\n      showDelete,\n      onDelete,\n      onDeleteUnpublishedChanges,\n      onChangeStatus,\n      onPublish,\n      unPublish,\n      onDuplicate,\n      onValidate,\n      user,\n      hasChanged,\n      displayUrl,\n      hasWorkflow,\n      useOpenAuthoring,\n      hasUnpublishedChanges,\n      isNewEntry,\n      isModification,\n      currentStatus,\n      onLogoutClick,\n      loadDeployPreview,\n      deployPreview,\n      draftKey,\n      editorBackLink,\n      t,\n    } = this.props;\n\n    const { scrollSyncEnabled, showEventBlocker } = this.state;\n\n    const previewEnabled = isPreviewEnabled(collection, entry);\n\n    const { locales, defaultLocale } = getI18nInfo(this.props.collection);\n    const collectionI18nEnabled = hasI18n(collection) && locales.length > 1;\n    const editorProps = {\n      collection,\n      entry,\n      fields,\n      fieldsMetaData,\n      fieldsErrors,\n      onChange,\n      onValidate,\n    };\n\n    const leftPanelLocale = this.state.leftPanelLocale || locales?.[0];\n    const editor = (\n      <ControlPaneContainer overFlow blockEntry={showEventBlocker}>\n        <EditorControlPane\n          {...editorProps}\n          ref={c => (this.controlPaneRef = c)}\n          locale={leftPanelLocale}\n          t={t}\n          onLocaleChange={this.handleLeftPanelLocaleChange}\n        />\n      </ControlPaneContainer>\n    );\n\n    const editor2 = (\n      <ControlPaneContainer overFlow={!this.state.scrollSyncEnabled} blockEntry={showEventBlocker}>\n        <EditorControlPane {...editorProps} locale={locales?.[1]} t={t} />\n      </ControlPaneContainer>\n    );\n\n    const previewEntry = collectionI18nEnabled\n      ? getPreviewEntry(entry, leftPanelLocale, defaultLocale)\n      : entry;\n\n    const editorWithPreview = (\n      <ScrollSync enabled={this.state.scrollSyncEnabled}>\n        <div>\n          <ReactSplitPaneGlobalStyles />\n          <StyledSplitPane\n            maxSize={-100}\n            minSize={400}\n            defaultSize={parseInt(localStorage.getItem(SPLIT_PANE_POSITION), 10) || '50%'}\n            onChange={size => localStorage.setItem(SPLIT_PANE_POSITION, size)}\n            onDragStarted={this.handleSplitPaneDragStart}\n            onDragFinished={this.handleSplitPaneDragFinished}\n          >\n            <ScrollSyncPane>{editor}</ScrollSyncPane>\n            <PreviewPaneContainer blockEntry={showEventBlocker}>\n              <EditorPreviewPane\n                collection={collection}\n                entry={previewEntry}\n                fields={fields}\n                fieldsMetaData={fieldsMetaData}\n                locale={leftPanelLocale}\n              />\n            </PreviewPaneContainer>\n          </StyledSplitPane>\n        </div>\n      </ScrollSync>\n    );\n\n    const editorWithEditor = (\n      <ScrollSync enabled={this.state.scrollSyncEnabled}>\n        <div>\n          <StyledSplitPane\n            maxSize={-100}\n            defaultSize={parseInt(localStorage.getItem(SPLIT_PANE_POSITION), 10) || '50%'}\n            onChange={size => localStorage.setItem(SPLIT_PANE_POSITION, size)}\n            onDragStarted={this.handleSplitPaneDragStart}\n            onDragFinished={this.handleSplitPaneDragFinished}\n          >\n            <ScrollSyncPane>{editor}</ScrollSyncPane>\n            <ScrollSyncPane>{editor2}</ScrollSyncPane>\n          </StyledSplitPane>\n        </div>\n      </ScrollSync>\n    );\n\n    const i18nVisible = collectionI18nEnabled && this.state.i18nVisible;\n    const previewVisible = previewEnabled && this.state.previewVisible;\n    const scrollSyncVisible = i18nVisible || previewVisible;\n\n    return (\n      <EditorContainer>\n        <EditorToolbar\n          isPersisting={entry.get('isPersisting')}\n          isPublishing={entry.get('isPublishing')}\n          isUpdatingStatus={entry.get('isUpdatingStatus')}\n          isDeleting={entry.get('isDeleting')}\n          onPersist={this.handleOnPersist}\n          onPersistAndNew={() => this.handleOnPersist({ createNew: true })}\n          onPersistAndDuplicate={() => this.handleOnPersist({ createNew: true, duplicate: true })}\n          onDelete={onDelete}\n          onDeleteUnpublishedChanges={onDeleteUnpublishedChanges}\n          onChangeStatus={onChangeStatus}\n          showDelete={showDelete}\n          onPublish={onPublish}\n          unPublish={unPublish}\n          onDuplicate={onDuplicate}\n          onPublishAndNew={() => this.handleOnPublish({ createNew: true })}\n          onPublishAndDuplicate={() => this.handleOnPublish({ createNew: true, duplicate: true })}\n          user={user}\n          hasChanged={hasChanged}\n          displayUrl={displayUrl}\n          collection={collection}\n          hasWorkflow={hasWorkflow}\n          useOpenAuthoring={useOpenAuthoring}\n          hasUnpublishedChanges={hasUnpublishedChanges}\n          isNewEntry={isNewEntry}\n          isModification={isModification}\n          currentStatus={currentStatus}\n          onLogoutClick={onLogoutClick}\n          loadDeployPreview={loadDeployPreview}\n          deployPreview={deployPreview}\n          editorBackLink={editorBackLink}\n        />\n        <Editor key={draftKey}>\n          <ViewControls>\n            {collectionI18nEnabled && (\n              <EditorToggle\n                isActive={i18nVisible}\n                onClick={this.handleToggleI18n}\n                size=\"large\"\n                type=\"page\"\n                title={t('editor.editorInterface.toggleI18n')}\n                marginTop=\"70px\"\n              />\n            )}\n            {previewEnabled && (\n              <EditorToggle\n                isActive={previewVisible}\n                onClick={this.handleTogglePreview}\n                size=\"large\"\n                type=\"eye\"\n                title={t('editor.editorInterface.togglePreview')}\n              />\n            )}\n            {scrollSyncVisible && (\n              <EditorToggle\n                isActive={scrollSyncEnabled}\n                onClick={this.handleToggleScrollSync}\n                size=\"large\"\n                type=\"scroll\"\n                title={t('editor.editorInterface.toggleScrollSync')}\n              />\n            )}\n          </ViewControls>\n          <EditorContent\n            i18nVisible={i18nVisible}\n            previewVisible={previewVisible}\n            editor={editor}\n            editorWithEditor={editorWithEditor}\n            editorWithPreview={editorWithPreview}\n          />\n        </Editor>\n      </EditorContainer>\n    );\n  }\n}\n\nEditorInterface.propTypes = {\n  collection: ImmutablePropTypes.map.isRequired,\n  entry: ImmutablePropTypes.map.isRequired,\n  fields: ImmutablePropTypes.list.isRequired,\n  fieldsMetaData: ImmutablePropTypes.map.isRequired,\n  fieldsErrors: ImmutablePropTypes.map.isRequired,\n  onChange: PropTypes.func.isRequired,\n  onValidate: PropTypes.func.isRequired,\n  onPersist: PropTypes.func.isRequired,\n  showDelete: PropTypes.bool.isRequired,\n  onDelete: PropTypes.func.isRequired,\n  onDeleteUnpublishedChanges: PropTypes.func.isRequired,\n  onPublish: PropTypes.func.isRequired,\n  unPublish: PropTypes.func.isRequired,\n  onDuplicate: PropTypes.func.isRequired,\n  onChangeStatus: PropTypes.func.isRequired,\n  user: PropTypes.object,\n  hasChanged: PropTypes.bool,\n  displayUrl: PropTypes.string,\n  hasWorkflow: PropTypes.bool,\n  useOpenAuthoring: PropTypes.bool,\n  hasUnpublishedChanges: PropTypes.bool,\n  isNewEntry: PropTypes.bool,\n  isModification: PropTypes.bool,\n  currentStatus: PropTypes.string,\n  onLogoutClick: PropTypes.func.isRequired,\n  deployPreview: PropTypes.object,\n  loadDeployPreview: PropTypes.func.isRequired,\n  draftKey: PropTypes.string.isRequired,\n  t: PropTypes.func.isRequired,\n};\n\nexport default EditorInterface;\n"]} */"));
|
|
70
|
-
const EditorContainer = /*#__PURE__*/(
|
|
61
|
+
})(styles.splitPane, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/Editor/EditorInterface.js"],"names":[],"mappings":"AA0FqC","file":"../../../../src/components/Editor/EditorInterface.js","sourcesContent":["import PropTypes from 'prop-types';\nimport React, { Component } from 'react';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\nimport { css, Global } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport SplitPane from 'react-split-pane';\nimport {\n  colors,\n  colorsRaw,\n  components,\n  transitions,\n  IconButton,\n  zIndex,\n} from 'decap-cms-ui-default';\nimport { ScrollSync, ScrollSyncPane } from 'react-scroll-sync';\n\nimport EditorControlPane from './EditorControlPane/EditorControlPane';\nimport EditorPreviewPane from './EditorPreviewPane/EditorPreviewPane';\nimport EditorToolbar from './EditorToolbar';\nimport { hasI18n, getI18nInfo, getPreviewEntry } from '../../lib/i18n';\nimport { FILES } from '../../constants/collectionTypes';\nimport { getFileFromSlug } from '../../reducers/collections';\n\nconst PREVIEW_VISIBLE = 'cms.preview-visible';\nconst SCROLL_SYNC_ENABLED = 'cms.scroll-sync-enabled';\nconst SPLIT_PANE_POSITION = 'cms.split-pane-position';\nconst I18N_VISIBLE = 'cms.i18n-visible';\n\nconst styles = {\n  splitPane: css`\n    ${components.card};\n    border-radius: 0;\n    height: 100%;\n  `,\n  pane: css`\n    height: 100%;\n    overflow-y: auto;\n  `,\n};\n\nconst EditorToggle = styled(IconButton)`\n  margin-bottom: 12px;\n`;\n\nfunction ReactSplitPaneGlobalStyles() {\n  return (\n    <Global\n      styles={css`\n        .Resizer.vertical {\n          width: 2px;\n          cursor: col-resize;\n          position: relative;\n          background: none;\n\n          &:before {\n            content: '';\n            width: 2px;\n            height: 100%;\n            position: relative;\n            background-color: ${colors.textFieldBorder};\n            display: block;\n            z-index: 10;\n            transition: background-color ${transitions.main};\n          }\n\n          &:hover,\n          &:active {\n            &:before {\n              width: 4px;\n              left: -1px;\n              background-color: ${colorsRaw.blue};\n            }\n          }\n        }\n      `}\n    />\n  );\n}\n\nconst StyledSplitPane = styled(SplitPane)`\n  ${styles.splitPane};\n\n  /**\n   * Quick fix for preview pane not fully displaying in Safari\n   */\n  .Pane {\n    height: 100%;\n  }\n`;\n\nconst NoPreviewContainer = styled.div`\n  ${styles.splitPane};\n`;\n\nconst EditorContainer = styled.div`\n  width: 100%;\n  min-width: 800px;\n  height: 100%;\n  position: absolute;\n  top: 0;\n  left: 0;\n  overflow: hidden;\n  padding-top: 66px;\n  background-color: ${colors.background};\n`;\n\nconst Editor = styled.div`\n  height: 100%;\n  margin: 0 auto;\n  position: relative;\n`;\n\nconst PreviewPaneContainer = styled.div`\n  height: 100%;\n  pointer-events: ${props => (props.blockEntry ? 'none' : 'auto')};\n  overflow-y: ${props => (props.overFlow ? 'auto' : 'hidden')};\n`;\n\nconst ControlPaneContainer = styled(PreviewPaneContainer)`\n  padding: 0 16px;\n  position: relative;\n  overflow-x: hidden;\n`;\n\nconst ViewControls = styled.div`\n  position: absolute;\n  top: 10px;\n  right: 10px;\n  z-index: ${zIndex.zIndex299};\n`;\n\nfunction EditorContent({\n  i18nVisible,\n  previewVisible,\n  editor,\n  editorWithEditor,\n  editorWithPreview,\n}) {\n  if (i18nVisible) {\n    return editorWithEditor;\n  } else if (previewVisible) {\n    return editorWithPreview;\n  } else {\n    return <NoPreviewContainer>{editor}</NoPreviewContainer>;\n  }\n}\n\nfunction isPreviewEnabled(collection, entry) {\n  if (collection.get('type') === FILES) {\n    const file = getFileFromSlug(collection, entry.get('slug'));\n    const previewEnabled = file?.getIn(['editor', 'preview']);\n    if (previewEnabled != null) return previewEnabled;\n  }\n  return collection.getIn(['editor', 'preview'], true);\n}\n\nclass EditorInterface extends Component {\n  state = {\n    showEventBlocker: false,\n    previewVisible: localStorage.getItem(PREVIEW_VISIBLE) !== 'false',\n    scrollSyncEnabled: localStorage.getItem(SCROLL_SYNC_ENABLED) !== 'false',\n    i18nVisible: localStorage.getItem(I18N_VISIBLE) !== 'false',\n  };\n\n  handleFieldClick = path => {\n    this.controlPaneRef?.focus(path);\n  };\n\n  handleSplitPaneDragStart = () => {\n    this.setState({ showEventBlocker: true });\n  };\n\n  handleSplitPaneDragFinished = () => {\n    this.setState({ showEventBlocker: false });\n  };\n\n  handleOnPersist = async (opts = {}) => {\n    const { createNew = false, duplicate = false } = opts;\n    await this.controlPaneRef.switchToDefaultLocale();\n    this.controlPaneRef.validate();\n    this.props.onPersist({ createNew, duplicate });\n  };\n\n  handleOnPublish = async (opts = {}) => {\n    const { createNew = false, duplicate = false } = opts;\n    await this.controlPaneRef.switchToDefaultLocale();\n    this.controlPaneRef.validate();\n    this.props.onPublish({ createNew, duplicate });\n  };\n\n  handleTogglePreview = () => {\n    const newPreviewVisible = !this.state.previewVisible;\n    this.setState({ previewVisible: newPreviewVisible });\n    localStorage.setItem(PREVIEW_VISIBLE, newPreviewVisible);\n  };\n\n  handleToggleScrollSync = () => {\n    const newScrollSyncEnabled = !this.state.scrollSyncEnabled;\n    this.setState({ scrollSyncEnabled: newScrollSyncEnabled });\n    localStorage.setItem(SCROLL_SYNC_ENABLED, newScrollSyncEnabled);\n  };\n\n  handleToggleI18n = () => {\n    const newI18nVisible = !this.state.i18nVisible;\n    this.setState({ i18nVisible: newI18nVisible });\n    localStorage.setItem(I18N_VISIBLE, newI18nVisible);\n  };\n\n  handleLeftPanelLocaleChange = locale => {\n    this.setState({ leftPanelLocale: locale });\n  };\n\n  render() {\n    const {\n      collection,\n      entry,\n      fields,\n      fieldsMetaData,\n      fieldsErrors,\n      onChange,\n      showDelete,\n      onDelete,\n      onDeleteUnpublishedChanges,\n      onChangeStatus,\n      onPublish,\n      unPublish,\n      onDuplicate,\n      onValidate,\n      user,\n      hasChanged,\n      displayUrl,\n      hasWorkflow,\n      useOpenAuthoring,\n      hasUnpublishedChanges,\n      isNewEntry,\n      isModification,\n      currentStatus,\n      onLogoutClick,\n      loadDeployPreview,\n      deployPreview,\n      draftKey,\n      editorBackLink,\n      t,\n    } = this.props;\n\n    const { scrollSyncEnabled, showEventBlocker } = this.state;\n\n    const previewEnabled = isPreviewEnabled(collection, entry);\n\n    const { locales, defaultLocale } = getI18nInfo(this.props.collection);\n    const collectionI18nEnabled = hasI18n(collection) && locales.length > 1;\n    const editorProps = {\n      collection,\n      entry,\n      fields,\n      fieldsMetaData,\n      fieldsErrors,\n      onChange,\n      onValidate,\n    };\n\n    const leftPanelLocale = this.state.leftPanelLocale || locales?.[0];\n    const editor = (\n      <ControlPaneContainer overFlow blockEntry={showEventBlocker}>\n        <EditorControlPane\n          {...editorProps}\n          ref={c => (this.controlPaneRef = c)}\n          locale={leftPanelLocale}\n          t={t}\n          onLocaleChange={this.handleLeftPanelLocaleChange}\n        />\n      </ControlPaneContainer>\n    );\n\n    const editor2 = (\n      <ControlPaneContainer overFlow={!this.state.scrollSyncEnabled} blockEntry={showEventBlocker}>\n        <EditorControlPane {...editorProps} locale={locales?.[1]} t={t} />\n      </ControlPaneContainer>\n    );\n\n    const previewEntry = collectionI18nEnabled\n      ? getPreviewEntry(entry, leftPanelLocale, defaultLocale)\n      : entry;\n\n    const editorWithPreview = (\n      <ScrollSync enabled={this.state.scrollSyncEnabled}>\n        <div>\n          <ReactSplitPaneGlobalStyles />\n          <StyledSplitPane\n            maxSize={-100}\n            minSize={400}\n            defaultSize={parseInt(localStorage.getItem(SPLIT_PANE_POSITION), 10) || '50%'}\n            onChange={size => localStorage.setItem(SPLIT_PANE_POSITION, size)}\n            onDragStarted={this.handleSplitPaneDragStart}\n            onDragFinished={this.handleSplitPaneDragFinished}\n          >\n            <ScrollSyncPane>{editor}</ScrollSyncPane>\n            <PreviewPaneContainer blockEntry={showEventBlocker}>\n              <EditorPreviewPane\n                collection={collection}\n                entry={previewEntry}\n                fields={fields}\n                fieldsMetaData={fieldsMetaData}\n                locale={leftPanelLocale}\n                onFieldClick={this.handleFieldClick}\n              />\n            </PreviewPaneContainer>\n          </StyledSplitPane>\n        </div>\n      </ScrollSync>\n    );\n\n    const editorWithEditor = (\n      <ScrollSync enabled={this.state.scrollSyncEnabled}>\n        <div>\n          <StyledSplitPane\n            maxSize={-100}\n            defaultSize={parseInt(localStorage.getItem(SPLIT_PANE_POSITION), 10) || '50%'}\n            onChange={size => localStorage.setItem(SPLIT_PANE_POSITION, size)}\n            onDragStarted={this.handleSplitPaneDragStart}\n            onDragFinished={this.handleSplitPaneDragFinished}\n          >\n            <ScrollSyncPane>{editor}</ScrollSyncPane>\n            <ScrollSyncPane>{editor2}</ScrollSyncPane>\n          </StyledSplitPane>\n        </div>\n      </ScrollSync>\n    );\n\n    const i18nVisible = collectionI18nEnabled && this.state.i18nVisible;\n    const previewVisible = previewEnabled && this.state.previewVisible;\n    const scrollSyncVisible = i18nVisible || previewVisible;\n\n    return (\n      <EditorContainer>\n        <EditorToolbar\n          isPersisting={entry.get('isPersisting')}\n          isPublishing={entry.get('isPublishing')}\n          isUpdatingStatus={entry.get('isUpdatingStatus')}\n          isDeleting={entry.get('isDeleting')}\n          onPersist={this.handleOnPersist}\n          onPersistAndNew={() => this.handleOnPersist({ createNew: true })}\n          onPersistAndDuplicate={() => this.handleOnPersist({ createNew: true, duplicate: true })}\n          onDelete={onDelete}\n          onDeleteUnpublishedChanges={onDeleteUnpublishedChanges}\n          onChangeStatus={onChangeStatus}\n          showDelete={showDelete}\n          onPublish={onPublish}\n          unPublish={unPublish}\n          onDuplicate={onDuplicate}\n          onPublishAndNew={() => this.handleOnPublish({ createNew: true })}\n          onPublishAndDuplicate={() => this.handleOnPublish({ createNew: true, duplicate: true })}\n          user={user}\n          hasChanged={hasChanged}\n          displayUrl={displayUrl}\n          collection={collection}\n          hasWorkflow={hasWorkflow}\n          useOpenAuthoring={useOpenAuthoring}\n          hasUnpublishedChanges={hasUnpublishedChanges}\n          isNewEntry={isNewEntry}\n          isModification={isModification}\n          currentStatus={currentStatus}\n          onLogoutClick={onLogoutClick}\n          loadDeployPreview={loadDeployPreview}\n          deployPreview={deployPreview}\n          editorBackLink={editorBackLink}\n        />\n        <Editor key={draftKey}>\n          <ViewControls>\n            {collectionI18nEnabled && (\n              <EditorToggle\n                isActive={i18nVisible}\n                onClick={this.handleToggleI18n}\n                size=\"large\"\n                type=\"page\"\n                title={t('editor.editorInterface.toggleI18n')}\n                marginTop=\"70px\"\n              />\n            )}\n            {previewEnabled && (\n              <EditorToggle\n                isActive={previewVisible}\n                onClick={this.handleTogglePreview}\n                size=\"large\"\n                type=\"eye\"\n                title={t('editor.editorInterface.togglePreview')}\n              />\n            )}\n            {scrollSyncVisible && !collection.getIn(['editor', 'visualEditing']) && (\n              <EditorToggle\n                isActive={scrollSyncEnabled}\n                onClick={this.handleToggleScrollSync}\n                size=\"large\"\n                type=\"scroll\"\n                title={t('editor.editorInterface.toggleScrollSync')}\n              />\n            )}\n          </ViewControls>\n          <EditorContent\n            i18nVisible={i18nVisible}\n            previewVisible={previewVisible}\n            editor={editor}\n            editorWithEditor={editorWithEditor}\n            editorWithPreview={editorWithPreview}\n          />\n        </Editor>\n      </EditorContainer>\n    );\n  }\n}\n\nEditorInterface.propTypes = {\n  collection: ImmutablePropTypes.map.isRequired,\n  entry: ImmutablePropTypes.map.isRequired,\n  fields: ImmutablePropTypes.list.isRequired,\n  fieldsMetaData: ImmutablePropTypes.map.isRequired,\n  fieldsErrors: ImmutablePropTypes.map.isRequired,\n  onChange: PropTypes.func.isRequired,\n  onValidate: PropTypes.func.isRequired,\n  onPersist: PropTypes.func.isRequired,\n  showDelete: PropTypes.bool.isRequired,\n  onDelete: PropTypes.func.isRequired,\n  onDeleteUnpublishedChanges: PropTypes.func.isRequired,\n  onPublish: PropTypes.func.isRequired,\n  unPublish: PropTypes.func.isRequired,\n  onDuplicate: PropTypes.func.isRequired,\n  onChangeStatus: PropTypes.func.isRequired,\n  user: PropTypes.object,\n  hasChanged: PropTypes.bool,\n  displayUrl: PropTypes.string,\n  hasWorkflow: PropTypes.bool,\n  useOpenAuthoring: PropTypes.bool,\n  hasUnpublishedChanges: PropTypes.bool,\n  isNewEntry: PropTypes.bool,\n  isModification: PropTypes.bool,\n  currentStatus: PropTypes.string,\n  onLogoutClick: PropTypes.func.isRequired,\n  deployPreview: PropTypes.object,\n  loadDeployPreview: PropTypes.func.isRequired,\n  draftKey: PropTypes.string.isRequired,\n  t: PropTypes.func.isRequired,\n};\n\nexport default EditorInterface;\n"]} */"));
|
|
62
|
+
const EditorContainer = /*#__PURE__*/_styled("div", {
|
|
71
63
|
target: "e1nx103k4",
|
|
72
64
|
label: "EditorContainer"
|
|
73
|
-
})("width:100%;min-width:800px;height:100%;position:absolute;top:0;left:0;overflow:hidden;padding-top:66px;background-color:", _decapCmsUiDefault.colors.background, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/Editor/EditorInterface.js"],"names":[],"mappings":"AA8FkC","file":"../../../../src/components/Editor/EditorInterface.js","sourcesContent":["import PropTypes from 'prop-types';\nimport React, { Component } from 'react';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\nimport { css, Global } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport SplitPane from 'react-split-pane';\nimport {\n  colors,\n  colorsRaw,\n  components,\n  transitions,\n  IconButton,\n  zIndex,\n} from 'decap-cms-ui-default';\nimport { ScrollSync, ScrollSyncPane } from 'react-scroll-sync';\n\nimport EditorControlPane from './EditorControlPane/EditorControlPane';\nimport EditorPreviewPane from './EditorPreviewPane/EditorPreviewPane';\nimport EditorToolbar from './EditorToolbar';\nimport { hasI18n, getI18nInfo, getPreviewEntry } from '../../lib/i18n';\nimport { FILES } from '../../constants/collectionTypes';\nimport { getFileFromSlug } from '../../reducers/collections';\n\nconst PREVIEW_VISIBLE = 'cms.preview-visible';\nconst SCROLL_SYNC_ENABLED = 'cms.scroll-sync-enabled';\nconst SPLIT_PANE_POSITION = 'cms.split-pane-position';\nconst I18N_VISIBLE = 'cms.i18n-visible';\n\nconst styles = {\n  splitPane: css`\n    ${components.card};\n    border-radius: 0;\n    height: 100%;\n  `,\n  pane: css`\n    height: 100%;\n    overflow-y: auto;\n  `,\n};\n\nconst EditorToggle = styled(IconButton)`\n  margin-bottom: 12px;\n`;\n\nfunction ReactSplitPaneGlobalStyles() {\n  return (\n    <Global\n      styles={css`\n        .Resizer.vertical {\n          width: 2px;\n          cursor: col-resize;\n          position: relative;\n          background: none;\n\n          &:before {\n            content: '';\n            width: 2px;\n            height: 100%;\n            position: relative;\n            background-color: ${colors.textFieldBorder};\n            display: block;\n            z-index: 10;\n            transition: background-color ${transitions.main};\n          }\n\n          &:hover,\n          &:active {\n            &:before {\n              width: 4px;\n              left: -1px;\n              background-color: ${colorsRaw.blue};\n            }\n          }\n        }\n      `}\n    />\n  );\n}\n\nconst StyledSplitPane = styled(SplitPane)`\n  ${styles.splitPane};\n\n  /**\n   * Quick fix for preview pane not fully displaying in Safari\n   */\n  .Pane {\n    height: 100%;\n  }\n`;\n\nconst NoPreviewContainer = styled.div`\n  ${styles.splitPane};\n`;\n\nconst EditorContainer = styled.div`\n  width: 100%;\n  min-width: 800px;\n  height: 100%;\n  position: absolute;\n  top: 0;\n  left: 0;\n  overflow: hidden;\n  padding-top: 66px;\n  background-color: ${colors.background};\n`;\n\nconst Editor = styled.div`\n  height: 100%;\n  margin: 0 auto;\n  position: relative;\n`;\n\nconst PreviewPaneContainer = styled.div`\n  height: 100%;\n  pointer-events: ${props => (props.blockEntry ? 'none' : 'auto')};\n  overflow-y: ${props => (props.overFlow ? 'auto' : 'hidden')};\n`;\n\nconst ControlPaneContainer = styled(PreviewPaneContainer)`\n  padding: 0 16px;\n  position: relative;\n  overflow-x: hidden;\n`;\n\nconst ViewControls = styled.div`\n  position: absolute;\n  top: 10px;\n  right: 10px;\n  z-index: ${zIndex.zIndex299};\n`;\n\nfunction EditorContent({\n  i18nVisible,\n  previewVisible,\n  editor,\n  editorWithEditor,\n  editorWithPreview,\n}) {\n  if (i18nVisible) {\n    return editorWithEditor;\n  } else if (previewVisible) {\n    return editorWithPreview;\n  } else {\n    return <NoPreviewContainer>{editor}</NoPreviewContainer>;\n  }\n}\n\nfunction isPreviewEnabled(collection, entry) {\n  if (collection.get('type') === FILES) {\n    const file = getFileFromSlug(collection, entry.get('slug'));\n    const previewEnabled = file?.getIn(['editor', 'preview']);\n    if (previewEnabled != null) return previewEnabled;\n  }\n  return collection.getIn(['editor', 'preview'], true);\n}\n\nclass EditorInterface extends Component {\n  state = {\n    showEventBlocker: false,\n    previewVisible: localStorage.getItem(PREVIEW_VISIBLE) !== 'false',\n    scrollSyncEnabled: localStorage.getItem(SCROLL_SYNC_ENABLED) !== 'false',\n    i18nVisible: localStorage.getItem(I18N_VISIBLE) !== 'false',\n  };\n\n  handleSplitPaneDragStart = () => {\n    this.setState({ showEventBlocker: true });\n  };\n\n  handleSplitPaneDragFinished = () => {\n    this.setState({ showEventBlocker: false });\n  };\n\n  handleOnPersist = async (opts = {}) => {\n    const { createNew = false, duplicate = false } = opts;\n    await this.controlPaneRef.switchToDefaultLocale();\n    this.controlPaneRef.validate();\n    this.props.onPersist({ createNew, duplicate });\n  };\n\n  handleOnPublish = async (opts = {}) => {\n    const { createNew = false, duplicate = false } = opts;\n    await this.controlPaneRef.switchToDefaultLocale();\n    this.controlPaneRef.validate();\n    this.props.onPublish({ createNew, duplicate });\n  };\n\n  handleTogglePreview = () => {\n    const newPreviewVisible = !this.state.previewVisible;\n    this.setState({ previewVisible: newPreviewVisible });\n    localStorage.setItem(PREVIEW_VISIBLE, newPreviewVisible);\n  };\n\n  handleToggleScrollSync = () => {\n    const newScrollSyncEnabled = !this.state.scrollSyncEnabled;\n    this.setState({ scrollSyncEnabled: newScrollSyncEnabled });\n    localStorage.setItem(SCROLL_SYNC_ENABLED, newScrollSyncEnabled);\n  };\n\n  handleToggleI18n = () => {\n    const newI18nVisible = !this.state.i18nVisible;\n    this.setState({ i18nVisible: newI18nVisible });\n    localStorage.setItem(I18N_VISIBLE, newI18nVisible);\n  };\n\n  handleLeftPanelLocaleChange = locale => {\n    this.setState({ leftPanelLocale: locale });\n  };\n\n  render() {\n    const {\n      collection,\n      entry,\n      fields,\n      fieldsMetaData,\n      fieldsErrors,\n      onChange,\n      showDelete,\n      onDelete,\n      onDeleteUnpublishedChanges,\n      onChangeStatus,\n      onPublish,\n      unPublish,\n      onDuplicate,\n      onValidate,\n      user,\n      hasChanged,\n      displayUrl,\n      hasWorkflow,\n      useOpenAuthoring,\n      hasUnpublishedChanges,\n      isNewEntry,\n      isModification,\n      currentStatus,\n      onLogoutClick,\n      loadDeployPreview,\n      deployPreview,\n      draftKey,\n      editorBackLink,\n      t,\n    } = this.props;\n\n    const { scrollSyncEnabled, showEventBlocker } = this.state;\n\n    const previewEnabled = isPreviewEnabled(collection, entry);\n\n    const { locales, defaultLocale } = getI18nInfo(this.props.collection);\n    const collectionI18nEnabled = hasI18n(collection) && locales.length > 1;\n    const editorProps = {\n      collection,\n      entry,\n      fields,\n      fieldsMetaData,\n      fieldsErrors,\n      onChange,\n      onValidate,\n    };\n\n    const leftPanelLocale = this.state.leftPanelLocale || locales?.[0];\n    const editor = (\n      <ControlPaneContainer overFlow blockEntry={showEventBlocker}>\n        <EditorControlPane\n          {...editorProps}\n          ref={c => (this.controlPaneRef = c)}\n          locale={leftPanelLocale}\n          t={t}\n          onLocaleChange={this.handleLeftPanelLocaleChange}\n        />\n      </ControlPaneContainer>\n    );\n\n    const editor2 = (\n      <ControlPaneContainer overFlow={!this.state.scrollSyncEnabled} blockEntry={showEventBlocker}>\n        <EditorControlPane {...editorProps} locale={locales?.[1]} t={t} />\n      </ControlPaneContainer>\n    );\n\n    const previewEntry = collectionI18nEnabled\n      ? getPreviewEntry(entry, leftPanelLocale, defaultLocale)\n      : entry;\n\n    const editorWithPreview = (\n      <ScrollSync enabled={this.state.scrollSyncEnabled}>\n        <div>\n          <ReactSplitPaneGlobalStyles />\n          <StyledSplitPane\n            maxSize={-100}\n            minSize={400}\n            defaultSize={parseInt(localStorage.getItem(SPLIT_PANE_POSITION), 10) || '50%'}\n            onChange={size => localStorage.setItem(SPLIT_PANE_POSITION, size)}\n            onDragStarted={this.handleSplitPaneDragStart}\n            onDragFinished={this.handleSplitPaneDragFinished}\n          >\n            <ScrollSyncPane>{editor}</ScrollSyncPane>\n            <PreviewPaneContainer blockEntry={showEventBlocker}>\n              <EditorPreviewPane\n                collection={collection}\n                entry={previewEntry}\n                fields={fields}\n                fieldsMetaData={fieldsMetaData}\n                locale={leftPanelLocale}\n              />\n            </PreviewPaneContainer>\n          </StyledSplitPane>\n        </div>\n      </ScrollSync>\n    );\n\n    const editorWithEditor = (\n      <ScrollSync enabled={this.state.scrollSyncEnabled}>\n        <div>\n          <StyledSplitPane\n            maxSize={-100}\n            defaultSize={parseInt(localStorage.getItem(SPLIT_PANE_POSITION), 10) || '50%'}\n            onChange={size => localStorage.setItem(SPLIT_PANE_POSITION, size)}\n            onDragStarted={this.handleSplitPaneDragStart}\n            onDragFinished={this.handleSplitPaneDragFinished}\n          >\n            <ScrollSyncPane>{editor}</ScrollSyncPane>\n            <ScrollSyncPane>{editor2}</ScrollSyncPane>\n          </StyledSplitPane>\n        </div>\n      </ScrollSync>\n    );\n\n    const i18nVisible = collectionI18nEnabled && this.state.i18nVisible;\n    const previewVisible = previewEnabled && this.state.previewVisible;\n    const scrollSyncVisible = i18nVisible || previewVisible;\n\n    return (\n      <EditorContainer>\n        <EditorToolbar\n          isPersisting={entry.get('isPersisting')}\n          isPublishing={entry.get('isPublishing')}\n          isUpdatingStatus={entry.get('isUpdatingStatus')}\n          isDeleting={entry.get('isDeleting')}\n          onPersist={this.handleOnPersist}\n          onPersistAndNew={() => this.handleOnPersist({ createNew: true })}\n          onPersistAndDuplicate={() => this.handleOnPersist({ createNew: true, duplicate: true })}\n          onDelete={onDelete}\n          onDeleteUnpublishedChanges={onDeleteUnpublishedChanges}\n          onChangeStatus={onChangeStatus}\n          showDelete={showDelete}\n          onPublish={onPublish}\n          unPublish={unPublish}\n          onDuplicate={onDuplicate}\n          onPublishAndNew={() => this.handleOnPublish({ createNew: true })}\n          onPublishAndDuplicate={() => this.handleOnPublish({ createNew: true, duplicate: true })}\n          user={user}\n          hasChanged={hasChanged}\n          displayUrl={displayUrl}\n          collection={collection}\n          hasWorkflow={hasWorkflow}\n          useOpenAuthoring={useOpenAuthoring}\n          hasUnpublishedChanges={hasUnpublishedChanges}\n          isNewEntry={isNewEntry}\n          isModification={isModification}\n          currentStatus={currentStatus}\n          onLogoutClick={onLogoutClick}\n          loadDeployPreview={loadDeployPreview}\n          deployPreview={deployPreview}\n          editorBackLink={editorBackLink}\n        />\n        <Editor key={draftKey}>\n          <ViewControls>\n            {collectionI18nEnabled && (\n              <EditorToggle\n                isActive={i18nVisible}\n                onClick={this.handleToggleI18n}\n                size=\"large\"\n                type=\"page\"\n                title={t('editor.editorInterface.toggleI18n')}\n                marginTop=\"70px\"\n              />\n            )}\n            {previewEnabled && (\n              <EditorToggle\n                isActive={previewVisible}\n                onClick={this.handleTogglePreview}\n                size=\"large\"\n                type=\"eye\"\n                title={t('editor.editorInterface.togglePreview')}\n              />\n            )}\n            {scrollSyncVisible && (\n              <EditorToggle\n                isActive={scrollSyncEnabled}\n                onClick={this.handleToggleScrollSync}\n                size=\"large\"\n                type=\"scroll\"\n                title={t('editor.editorInterface.toggleScrollSync')}\n              />\n            )}\n          </ViewControls>\n          <EditorContent\n            i18nVisible={i18nVisible}\n            previewVisible={previewVisible}\n            editor={editor}\n            editorWithEditor={editorWithEditor}\n            editorWithPreview={editorWithPreview}\n          />\n        </Editor>\n      </EditorContainer>\n    );\n  }\n}\n\nEditorInterface.propTypes = {\n  collection: ImmutablePropTypes.map.isRequired,\n  entry: ImmutablePropTypes.map.isRequired,\n  fields: ImmutablePropTypes.list.isRequired,\n  fieldsMetaData: ImmutablePropTypes.map.isRequired,\n  fieldsErrors: ImmutablePropTypes.map.isRequired,\n  onChange: PropTypes.func.isRequired,\n  onValidate: PropTypes.func.isRequired,\n  onPersist: PropTypes.func.isRequired,\n  showDelete: PropTypes.bool.isRequired,\n  onDelete: PropTypes.func.isRequired,\n  onDeleteUnpublishedChanges: PropTypes.func.isRequired,\n  onPublish: PropTypes.func.isRequired,\n  unPublish: PropTypes.func.isRequired,\n  onDuplicate: PropTypes.func.isRequired,\n  onChangeStatus: PropTypes.func.isRequired,\n  user: PropTypes.object,\n  hasChanged: PropTypes.bool,\n  displayUrl: PropTypes.string,\n  hasWorkflow: PropTypes.bool,\n  useOpenAuthoring: PropTypes.bool,\n  hasUnpublishedChanges: PropTypes.bool,\n  isNewEntry: PropTypes.bool,\n  isModification: PropTypes.bool,\n  currentStatus: PropTypes.string,\n  onLogoutClick: PropTypes.func.isRequired,\n  deployPreview: PropTypes.object,\n  loadDeployPreview: PropTypes.func.isRequired,\n  draftKey: PropTypes.string.isRequired,\n  t: PropTypes.func.isRequired,\n};\n\nexport default EditorInterface;\n"]} */"));
|
|
74
|
-
const Editor = /*#__PURE__*/(
|
|
65
|
+
})("width:100%;min-width:800px;height:100%;position:absolute;top:0;left:0;overflow:hidden;padding-top:66px;background-color:", colors.background, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/Editor/EditorInterface.js"],"names":[],"mappings":"AA8FkC","file":"../../../../src/components/Editor/EditorInterface.js","sourcesContent":["import PropTypes from 'prop-types';\nimport React, { Component } from 'react';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\nimport { css, Global } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport SplitPane from 'react-split-pane';\nimport {\n  colors,\n  colorsRaw,\n  components,\n  transitions,\n  IconButton,\n  zIndex,\n} from 'decap-cms-ui-default';\nimport { ScrollSync, ScrollSyncPane } from 'react-scroll-sync';\n\nimport EditorControlPane from './EditorControlPane/EditorControlPane';\nimport EditorPreviewPane from './EditorPreviewPane/EditorPreviewPane';\nimport EditorToolbar from './EditorToolbar';\nimport { hasI18n, getI18nInfo, getPreviewEntry } from '../../lib/i18n';\nimport { FILES } from '../../constants/collectionTypes';\nimport { getFileFromSlug } from '../../reducers/collections';\n\nconst PREVIEW_VISIBLE = 'cms.preview-visible';\nconst SCROLL_SYNC_ENABLED = 'cms.scroll-sync-enabled';\nconst SPLIT_PANE_POSITION = 'cms.split-pane-position';\nconst I18N_VISIBLE = 'cms.i18n-visible';\n\nconst styles = {\n  splitPane: css`\n    ${components.card};\n    border-radius: 0;\n    height: 100%;\n  `,\n  pane: css`\n    height: 100%;\n    overflow-y: auto;\n  `,\n};\n\nconst EditorToggle = styled(IconButton)`\n  margin-bottom: 12px;\n`;\n\nfunction ReactSplitPaneGlobalStyles() {\n  return (\n    <Global\n      styles={css`\n        .Resizer.vertical {\n          width: 2px;\n          cursor: col-resize;\n          position: relative;\n          background: none;\n\n          &:before {\n            content: '';\n            width: 2px;\n            height: 100%;\n            position: relative;\n            background-color: ${colors.textFieldBorder};\n            display: block;\n            z-index: 10;\n            transition: background-color ${transitions.main};\n          }\n\n          &:hover,\n          &:active {\n            &:before {\n              width: 4px;\n              left: -1px;\n              background-color: ${colorsRaw.blue};\n            }\n          }\n        }\n      `}\n    />\n  );\n}\n\nconst StyledSplitPane = styled(SplitPane)`\n  ${styles.splitPane};\n\n  /**\n   * Quick fix for preview pane not fully displaying in Safari\n   */\n  .Pane {\n    height: 100%;\n  }\n`;\n\nconst NoPreviewContainer = styled.div`\n  ${styles.splitPane};\n`;\n\nconst EditorContainer = styled.div`\n  width: 100%;\n  min-width: 800px;\n  height: 100%;\n  position: absolute;\n  top: 0;\n  left: 0;\n  overflow: hidden;\n  padding-top: 66px;\n  background-color: ${colors.background};\n`;\n\nconst Editor = styled.div`\n  height: 100%;\n  margin: 0 auto;\n  position: relative;\n`;\n\nconst PreviewPaneContainer = styled.div`\n  height: 100%;\n  pointer-events: ${props => (props.blockEntry ? 'none' : 'auto')};\n  overflow-y: ${props => (props.overFlow ? 'auto' : 'hidden')};\n`;\n\nconst ControlPaneContainer = styled(PreviewPaneContainer)`\n  padding: 0 16px;\n  position: relative;\n  overflow-x: hidden;\n`;\n\nconst ViewControls = styled.div`\n  position: absolute;\n  top: 10px;\n  right: 10px;\n  z-index: ${zIndex.zIndex299};\n`;\n\nfunction EditorContent({\n  i18nVisible,\n  previewVisible,\n  editor,\n  editorWithEditor,\n  editorWithPreview,\n}) {\n  if (i18nVisible) {\n    return editorWithEditor;\n  } else if (previewVisible) {\n    return editorWithPreview;\n  } else {\n    return <NoPreviewContainer>{editor}</NoPreviewContainer>;\n  }\n}\n\nfunction isPreviewEnabled(collection, entry) {\n  if (collection.get('type') === FILES) {\n    const file = getFileFromSlug(collection, entry.get('slug'));\n    const previewEnabled = file?.getIn(['editor', 'preview']);\n    if (previewEnabled != null) return previewEnabled;\n  }\n  return collection.getIn(['editor', 'preview'], true);\n}\n\nclass EditorInterface extends Component {\n  state = {\n    showEventBlocker: false,\n    previewVisible: localStorage.getItem(PREVIEW_VISIBLE) !== 'false',\n    scrollSyncEnabled: localStorage.getItem(SCROLL_SYNC_ENABLED) !== 'false',\n    i18nVisible: localStorage.getItem(I18N_VISIBLE) !== 'false',\n  };\n\n  handleFieldClick = path => {\n    this.controlPaneRef?.focus(path);\n  };\n\n  handleSplitPaneDragStart = () => {\n    this.setState({ showEventBlocker: true });\n  };\n\n  handleSplitPaneDragFinished = () => {\n    this.setState({ showEventBlocker: false });\n  };\n\n  handleOnPersist = async (opts = {}) => {\n    const { createNew = false, duplicate = false } = opts;\n    await this.controlPaneRef.switchToDefaultLocale();\n    this.controlPaneRef.validate();\n    this.props.onPersist({ createNew, duplicate });\n  };\n\n  handleOnPublish = async (opts = {}) => {\n    const { createNew = false, duplicate = false } = opts;\n    await this.controlPaneRef.switchToDefaultLocale();\n    this.controlPaneRef.validate();\n    this.props.onPublish({ createNew, duplicate });\n  };\n\n  handleTogglePreview = () => {\n    const newPreviewVisible = !this.state.previewVisible;\n    this.setState({ previewVisible: newPreviewVisible });\n    localStorage.setItem(PREVIEW_VISIBLE, newPreviewVisible);\n  };\n\n  handleToggleScrollSync = () => {\n    const newScrollSyncEnabled = !this.state.scrollSyncEnabled;\n    this.setState({ scrollSyncEnabled: newScrollSyncEnabled });\n    localStorage.setItem(SCROLL_SYNC_ENABLED, newScrollSyncEnabled);\n  };\n\n  handleToggleI18n = () => {\n    const newI18nVisible = !this.state.i18nVisible;\n    this.setState({ i18nVisible: newI18nVisible });\n    localStorage.setItem(I18N_VISIBLE, newI18nVisible);\n  };\n\n  handleLeftPanelLocaleChange = locale => {\n    this.setState({ leftPanelLocale: locale });\n  };\n\n  render() {\n    const {\n      collection,\n      entry,\n      fields,\n      fieldsMetaData,\n      fieldsErrors,\n      onChange,\n      showDelete,\n      onDelete,\n      onDeleteUnpublishedChanges,\n      onChangeStatus,\n      onPublish,\n      unPublish,\n      onDuplicate,\n      onValidate,\n      user,\n      hasChanged,\n      displayUrl,\n      hasWorkflow,\n      useOpenAuthoring,\n      hasUnpublishedChanges,\n      isNewEntry,\n      isModification,\n      currentStatus,\n      onLogoutClick,\n      loadDeployPreview,\n      deployPreview,\n      draftKey,\n      editorBackLink,\n      t,\n    } = this.props;\n\n    const { scrollSyncEnabled, showEventBlocker } = this.state;\n\n    const previewEnabled = isPreviewEnabled(collection, entry);\n\n    const { locales, defaultLocale } = getI18nInfo(this.props.collection);\n    const collectionI18nEnabled = hasI18n(collection) && locales.length > 1;\n    const editorProps = {\n      collection,\n      entry,\n      fields,\n      fieldsMetaData,\n      fieldsErrors,\n      onChange,\n      onValidate,\n    };\n\n    const leftPanelLocale = this.state.leftPanelLocale || locales?.[0];\n    const editor = (\n      <ControlPaneContainer overFlow blockEntry={showEventBlocker}>\n        <EditorControlPane\n          {...editorProps}\n          ref={c => (this.controlPaneRef = c)}\n          locale={leftPanelLocale}\n          t={t}\n          onLocaleChange={this.handleLeftPanelLocaleChange}\n        />\n      </ControlPaneContainer>\n    );\n\n    const editor2 = (\n      <ControlPaneContainer overFlow={!this.state.scrollSyncEnabled} blockEntry={showEventBlocker}>\n        <EditorControlPane {...editorProps} locale={locales?.[1]} t={t} />\n      </ControlPaneContainer>\n    );\n\n    const previewEntry = collectionI18nEnabled\n      ? getPreviewEntry(entry, leftPanelLocale, defaultLocale)\n      : entry;\n\n    const editorWithPreview = (\n      <ScrollSync enabled={this.state.scrollSyncEnabled}>\n        <div>\n          <ReactSplitPaneGlobalStyles />\n          <StyledSplitPane\n            maxSize={-100}\n            minSize={400}\n            defaultSize={parseInt(localStorage.getItem(SPLIT_PANE_POSITION), 10) || '50%'}\n            onChange={size => localStorage.setItem(SPLIT_PANE_POSITION, size)}\n            onDragStarted={this.handleSplitPaneDragStart}\n            onDragFinished={this.handleSplitPaneDragFinished}\n          >\n            <ScrollSyncPane>{editor}</ScrollSyncPane>\n            <PreviewPaneContainer blockEntry={showEventBlocker}>\n              <EditorPreviewPane\n                collection={collection}\n                entry={previewEntry}\n                fields={fields}\n                fieldsMetaData={fieldsMetaData}\n                locale={leftPanelLocale}\n                onFieldClick={this.handleFieldClick}\n              />\n            </PreviewPaneContainer>\n          </StyledSplitPane>\n        </div>\n      </ScrollSync>\n    );\n\n    const editorWithEditor = (\n      <ScrollSync enabled={this.state.scrollSyncEnabled}>\n        <div>\n          <StyledSplitPane\n            maxSize={-100}\n            defaultSize={parseInt(localStorage.getItem(SPLIT_PANE_POSITION), 10) || '50%'}\n            onChange={size => localStorage.setItem(SPLIT_PANE_POSITION, size)}\n            onDragStarted={this.handleSplitPaneDragStart}\n            onDragFinished={this.handleSplitPaneDragFinished}\n          >\n            <ScrollSyncPane>{editor}</ScrollSyncPane>\n            <ScrollSyncPane>{editor2}</ScrollSyncPane>\n          </StyledSplitPane>\n        </div>\n      </ScrollSync>\n    );\n\n    const i18nVisible = collectionI18nEnabled && this.state.i18nVisible;\n    const previewVisible = previewEnabled && this.state.previewVisible;\n    const scrollSyncVisible = i18nVisible || previewVisible;\n\n    return (\n      <EditorContainer>\n        <EditorToolbar\n          isPersisting={entry.get('isPersisting')}\n          isPublishing={entry.get('isPublishing')}\n          isUpdatingStatus={entry.get('isUpdatingStatus')}\n          isDeleting={entry.get('isDeleting')}\n          onPersist={this.handleOnPersist}\n          onPersistAndNew={() => this.handleOnPersist({ createNew: true })}\n          onPersistAndDuplicate={() => this.handleOnPersist({ createNew: true, duplicate: true })}\n          onDelete={onDelete}\n          onDeleteUnpublishedChanges={onDeleteUnpublishedChanges}\n          onChangeStatus={onChangeStatus}\n          showDelete={showDelete}\n          onPublish={onPublish}\n          unPublish={unPublish}\n          onDuplicate={onDuplicate}\n          onPublishAndNew={() => this.handleOnPublish({ createNew: true })}\n          onPublishAndDuplicate={() => this.handleOnPublish({ createNew: true, duplicate: true })}\n          user={user}\n          hasChanged={hasChanged}\n          displayUrl={displayUrl}\n          collection={collection}\n          hasWorkflow={hasWorkflow}\n          useOpenAuthoring={useOpenAuthoring}\n          hasUnpublishedChanges={hasUnpublishedChanges}\n          isNewEntry={isNewEntry}\n          isModification={isModification}\n          currentStatus={currentStatus}\n          onLogoutClick={onLogoutClick}\n          loadDeployPreview={loadDeployPreview}\n          deployPreview={deployPreview}\n          editorBackLink={editorBackLink}\n        />\n        <Editor key={draftKey}>\n          <ViewControls>\n            {collectionI18nEnabled && (\n              <EditorToggle\n                isActive={i18nVisible}\n                onClick={this.handleToggleI18n}\n                size=\"large\"\n                type=\"page\"\n                title={t('editor.editorInterface.toggleI18n')}\n                marginTop=\"70px\"\n              />\n            )}\n            {previewEnabled && (\n              <EditorToggle\n                isActive={previewVisible}\n                onClick={this.handleTogglePreview}\n                size=\"large\"\n                type=\"eye\"\n                title={t('editor.editorInterface.togglePreview')}\n              />\n            )}\n            {scrollSyncVisible && !collection.getIn(['editor', 'visualEditing']) && (\n              <EditorToggle\n                isActive={scrollSyncEnabled}\n                onClick={this.handleToggleScrollSync}\n                size=\"large\"\n                type=\"scroll\"\n                title={t('editor.editorInterface.toggleScrollSync')}\n              />\n            )}\n          </ViewControls>\n          <EditorContent\n            i18nVisible={i18nVisible}\n            previewVisible={previewVisible}\n            editor={editor}\n            editorWithEditor={editorWithEditor}\n            editorWithPreview={editorWithPreview}\n          />\n        </Editor>\n      </EditorContainer>\n    );\n  }\n}\n\nEditorInterface.propTypes = {\n  collection: ImmutablePropTypes.map.isRequired,\n  entry: ImmutablePropTypes.map.isRequired,\n  fields: ImmutablePropTypes.list.isRequired,\n  fieldsMetaData: ImmutablePropTypes.map.isRequired,\n  fieldsErrors: ImmutablePropTypes.map.isRequired,\n  onChange: PropTypes.func.isRequired,\n  onValidate: PropTypes.func.isRequired,\n  onPersist: PropTypes.func.isRequired,\n  showDelete: PropTypes.bool.isRequired,\n  onDelete: PropTypes.func.isRequired,\n  onDeleteUnpublishedChanges: PropTypes.func.isRequired,\n  onPublish: PropTypes.func.isRequired,\n  unPublish: PropTypes.func.isRequired,\n  onDuplicate: PropTypes.func.isRequired,\n  onChangeStatus: PropTypes.func.isRequired,\n  user: PropTypes.object,\n  hasChanged: PropTypes.bool,\n  displayUrl: PropTypes.string,\n  hasWorkflow: PropTypes.bool,\n  useOpenAuthoring: PropTypes.bool,\n  hasUnpublishedChanges: PropTypes.bool,\n  isNewEntry: PropTypes.bool,\n  isModification: PropTypes.bool,\n  currentStatus: PropTypes.string,\n  onLogoutClick: PropTypes.func.isRequired,\n  deployPreview: PropTypes.object,\n  loadDeployPreview: PropTypes.func.isRequired,\n  draftKey: PropTypes.string.isRequired,\n  t: PropTypes.func.isRequired,\n};\n\nexport default EditorInterface;\n"]} */"));
|
|
66
|
+
const Editor = /*#__PURE__*/_styled("div", {
|
|
75
67
|
target: "e1nx103k3",
|
|
76
68
|
label: "Editor"
|
|
77
69
|
})(process.env.NODE_ENV === "production" ? {
|
|
@@ -80,14 +72,14 @@ const Editor = /*#__PURE__*/(0, _base.default)("div", {
|
|
|
80
72
|
} : {
|
|
81
73
|
name: "yd3x82",
|
|
82
74
|
styles: "height:100%;margin:0 auto;position:relative",
|
|
83
|
-
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/Editor/EditorInterface.js"],"names":[],"mappings":"AA0GyB","file":"../../../../src/components/Editor/EditorInterface.js","sourcesContent":["import PropTypes from 'prop-types';\nimport React, { Component } from 'react';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\nimport { css, Global } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport SplitPane from 'react-split-pane';\nimport {\n  colors,\n  colorsRaw,\n  components,\n  transitions,\n  IconButton,\n  zIndex,\n} from 'decap-cms-ui-default';\nimport { ScrollSync, ScrollSyncPane } from 'react-scroll-sync';\n\nimport EditorControlPane from './EditorControlPane/EditorControlPane';\nimport EditorPreviewPane from './EditorPreviewPane/EditorPreviewPane';\nimport EditorToolbar from './EditorToolbar';\nimport { hasI18n, getI18nInfo, getPreviewEntry } from '../../lib/i18n';\nimport { FILES } from '../../constants/collectionTypes';\nimport { getFileFromSlug } from '../../reducers/collections';\n\nconst PREVIEW_VISIBLE = 'cms.preview-visible';\nconst SCROLL_SYNC_ENABLED = 'cms.scroll-sync-enabled';\nconst SPLIT_PANE_POSITION = 'cms.split-pane-position';\nconst I18N_VISIBLE = 'cms.i18n-visible';\n\nconst styles = {\n  splitPane: css`\n    ${components.card};\n    border-radius: 0;\n    height: 100%;\n  `,\n  pane: css`\n    height: 100%;\n    overflow-y: auto;\n  `,\n};\n\nconst EditorToggle = styled(IconButton)`\n  margin-bottom: 12px;\n`;\n\nfunction ReactSplitPaneGlobalStyles() {\n  return (\n    <Global\n      styles={css`\n        .Resizer.vertical {\n          width: 2px;\n          cursor: col-resize;\n          position: relative;\n          background: none;\n\n          &:before {\n            content: '';\n            width: 2px;\n            height: 100%;\n            position: relative;\n            background-color: ${colors.textFieldBorder};\n            display: block;\n            z-index: 10;\n            transition: background-color ${transitions.main};\n          }\n\n          &:hover,\n          &:active {\n            &:before {\n              width: 4px;\n              left: -1px;\n              background-color: ${colorsRaw.blue};\n            }\n          }\n        }\n      `}\n    />\n  );\n}\n\nconst StyledSplitPane = styled(SplitPane)`\n  ${styles.splitPane};\n\n  /**\n   * Quick fix for preview pane not fully displaying in Safari\n   */\n  .Pane {\n    height: 100%;\n  }\n`;\n\nconst NoPreviewContainer = styled.div`\n  ${styles.splitPane};\n`;\n\nconst EditorContainer = styled.div`\n  width: 100%;\n  min-width: 800px;\n  height: 100%;\n  position: absolute;\n  top: 0;\n  left: 0;\n  overflow: hidden;\n  padding-top: 66px;\n  background-color: ${colors.background};\n`;\n\nconst Editor = styled.div`\n  height: 100%;\n  margin: 0 auto;\n  position: relative;\n`;\n\nconst PreviewPaneContainer = styled.div`\n  height: 100%;\n  pointer-events: ${props => (props.blockEntry ? 'none' : 'auto')};\n  overflow-y: ${props => (props.overFlow ? 'auto' : 'hidden')};\n`;\n\nconst ControlPaneContainer = styled(PreviewPaneContainer)`\n  padding: 0 16px;\n  position: relative;\n  overflow-x: hidden;\n`;\n\nconst ViewControls = styled.div`\n  position: absolute;\n  top: 10px;\n  right: 10px;\n  z-index: ${zIndex.zIndex299};\n`;\n\nfunction EditorContent({\n  i18nVisible,\n  previewVisible,\n  editor,\n  editorWithEditor,\n  editorWithPreview,\n}) {\n  if (i18nVisible) {\n    return editorWithEditor;\n  } else if (previewVisible) {\n    return editorWithPreview;\n  } else {\n    return <NoPreviewContainer>{editor}</NoPreviewContainer>;\n  }\n}\n\nfunction isPreviewEnabled(collection, entry) {\n  if (collection.get('type') === FILES) {\n    const file = getFileFromSlug(collection, entry.get('slug'));\n    const previewEnabled = file?.getIn(['editor', 'preview']);\n    if (previewEnabled != null) return previewEnabled;\n  }\n  return collection.getIn(['editor', 'preview'], true);\n}\n\nclass EditorInterface extends Component {\n  state = {\n    showEventBlocker: false,\n    previewVisible: localStorage.getItem(PREVIEW_VISIBLE) !== 'false',\n    scrollSyncEnabled: localStorage.getItem(SCROLL_SYNC_ENABLED) !== 'false',\n    i18nVisible: localStorage.getItem(I18N_VISIBLE) !== 'false',\n  };\n\n  handleSplitPaneDragStart = () => {\n    this.setState({ showEventBlocker: true });\n  };\n\n  handleSplitPaneDragFinished = () => {\n    this.setState({ showEventBlocker: false });\n  };\n\n  handleOnPersist = async (opts = {}) => {\n    const { createNew = false, duplicate = false } = opts;\n    await this.controlPaneRef.switchToDefaultLocale();\n    this.controlPaneRef.validate();\n    this.props.onPersist({ createNew, duplicate });\n  };\n\n  handleOnPublish = async (opts = {}) => {\n    const { createNew = false, duplicate = false } = opts;\n    await this.controlPaneRef.switchToDefaultLocale();\n    this.controlPaneRef.validate();\n    this.props.onPublish({ createNew, duplicate });\n  };\n\n  handleTogglePreview = () => {\n    const newPreviewVisible = !this.state.previewVisible;\n    this.setState({ previewVisible: newPreviewVisible });\n    localStorage.setItem(PREVIEW_VISIBLE, newPreviewVisible);\n  };\n\n  handleToggleScrollSync = () => {\n    const newScrollSyncEnabled = !this.state.scrollSyncEnabled;\n    this.setState({ scrollSyncEnabled: newScrollSyncEnabled });\n    localStorage.setItem(SCROLL_SYNC_ENABLED, newScrollSyncEnabled);\n  };\n\n  handleToggleI18n = () => {\n    const newI18nVisible = !this.state.i18nVisible;\n    this.setState({ i18nVisible: newI18nVisible });\n    localStorage.setItem(I18N_VISIBLE, newI18nVisible);\n  };\n\n  handleLeftPanelLocaleChange = locale => {\n    this.setState({ leftPanelLocale: locale });\n  };\n\n  render() {\n    const {\n      collection,\n      entry,\n      fields,\n      fieldsMetaData,\n      fieldsErrors,\n      onChange,\n      showDelete,\n      onDelete,\n      onDeleteUnpublishedChanges,\n      onChangeStatus,\n      onPublish,\n      unPublish,\n      onDuplicate,\n      onValidate,\n      user,\n      hasChanged,\n      displayUrl,\n      hasWorkflow,\n      useOpenAuthoring,\n      hasUnpublishedChanges,\n      isNewEntry,\n      isModification,\n      currentStatus,\n      onLogoutClick,\n      loadDeployPreview,\n      deployPreview,\n      draftKey,\n      editorBackLink,\n      t,\n    } = this.props;\n\n    const { scrollSyncEnabled, showEventBlocker } = this.state;\n\n    const previewEnabled = isPreviewEnabled(collection, entry);\n\n    const { locales, defaultLocale } = getI18nInfo(this.props.collection);\n    const collectionI18nEnabled = hasI18n(collection) && locales.length > 1;\n    const editorProps = {\n      collection,\n      entry,\n      fields,\n      fieldsMetaData,\n      fieldsErrors,\n      onChange,\n      onValidate,\n    };\n\n    const leftPanelLocale = this.state.leftPanelLocale || locales?.[0];\n    const editor = (\n      <ControlPaneContainer overFlow blockEntry={showEventBlocker}>\n        <EditorControlPane\n          {...editorProps}\n          ref={c => (this.controlPaneRef = c)}\n          locale={leftPanelLocale}\n          t={t}\n          onLocaleChange={this.handleLeftPanelLocaleChange}\n        />\n      </ControlPaneContainer>\n    );\n\n    const editor2 = (\n      <ControlPaneContainer overFlow={!this.state.scrollSyncEnabled} blockEntry={showEventBlocker}>\n        <EditorControlPane {...editorProps} locale={locales?.[1]} t={t} />\n      </ControlPaneContainer>\n    );\n\n    const previewEntry = collectionI18nEnabled\n      ? getPreviewEntry(entry, leftPanelLocale, defaultLocale)\n      : entry;\n\n    const editorWithPreview = (\n      <ScrollSync enabled={this.state.scrollSyncEnabled}>\n        <div>\n          <ReactSplitPaneGlobalStyles />\n          <StyledSplitPane\n            maxSize={-100}\n            minSize={400}\n            defaultSize={parseInt(localStorage.getItem(SPLIT_PANE_POSITION), 10) || '50%'}\n            onChange={size => localStorage.setItem(SPLIT_PANE_POSITION, size)}\n            onDragStarted={this.handleSplitPaneDragStart}\n            onDragFinished={this.handleSplitPaneDragFinished}\n          >\n            <ScrollSyncPane>{editor}</ScrollSyncPane>\n            <PreviewPaneContainer blockEntry={showEventBlocker}>\n              <EditorPreviewPane\n                collection={collection}\n                entry={previewEntry}\n                fields={fields}\n                fieldsMetaData={fieldsMetaData}\n                locale={leftPanelLocale}\n              />\n            </PreviewPaneContainer>\n          </StyledSplitPane>\n        </div>\n      </ScrollSync>\n    );\n\n    const editorWithEditor = (\n      <ScrollSync enabled={this.state.scrollSyncEnabled}>\n        <div>\n          <StyledSplitPane\n            maxSize={-100}\n            defaultSize={parseInt(localStorage.getItem(SPLIT_PANE_POSITION), 10) || '50%'}\n            onChange={size => localStorage.setItem(SPLIT_PANE_POSITION, size)}\n            onDragStarted={this.handleSplitPaneDragStart}\n            onDragFinished={this.handleSplitPaneDragFinished}\n          >\n            <ScrollSyncPane>{editor}</ScrollSyncPane>\n            <ScrollSyncPane>{editor2}</ScrollSyncPane>\n          </StyledSplitPane>\n        </div>\n      </ScrollSync>\n    );\n\n    const i18nVisible = collectionI18nEnabled && this.state.i18nVisible;\n    const previewVisible = previewEnabled && this.state.previewVisible;\n    const scrollSyncVisible = i18nVisible || previewVisible;\n\n    return (\n      <EditorContainer>\n        <EditorToolbar\n          isPersisting={entry.get('isPersisting')}\n          isPublishing={entry.get('isPublishing')}\n          isUpdatingStatus={entry.get('isUpdatingStatus')}\n          isDeleting={entry.get('isDeleting')}\n          onPersist={this.handleOnPersist}\n          onPersistAndNew={() => this.handleOnPersist({ createNew: true })}\n          onPersistAndDuplicate={() => this.handleOnPersist({ createNew: true, duplicate: true })}\n          onDelete={onDelete}\n          onDeleteUnpublishedChanges={onDeleteUnpublishedChanges}\n          onChangeStatus={onChangeStatus}\n          showDelete={showDelete}\n          onPublish={onPublish}\n          unPublish={unPublish}\n          onDuplicate={onDuplicate}\n          onPublishAndNew={() => this.handleOnPublish({ createNew: true })}\n          onPublishAndDuplicate={() => this.handleOnPublish({ createNew: true, duplicate: true })}\n          user={user}\n          hasChanged={hasChanged}\n          displayUrl={displayUrl}\n          collection={collection}\n          hasWorkflow={hasWorkflow}\n          useOpenAuthoring={useOpenAuthoring}\n          hasUnpublishedChanges={hasUnpublishedChanges}\n          isNewEntry={isNewEntry}\n          isModification={isModification}\n          currentStatus={currentStatus}\n          onLogoutClick={onLogoutClick}\n          loadDeployPreview={loadDeployPreview}\n          deployPreview={deployPreview}\n          editorBackLink={editorBackLink}\n        />\n        <Editor key={draftKey}>\n          <ViewControls>\n            {collectionI18nEnabled && (\n              <EditorToggle\n                isActive={i18nVisible}\n                onClick={this.handleToggleI18n}\n                size=\"large\"\n                type=\"page\"\n                title={t('editor.editorInterface.toggleI18n')}\n                marginTop=\"70px\"\n              />\n            )}\n            {previewEnabled && (\n              <EditorToggle\n                isActive={previewVisible}\n                onClick={this.handleTogglePreview}\n                size=\"large\"\n                type=\"eye\"\n                title={t('editor.editorInterface.togglePreview')}\n              />\n            )}\n            {scrollSyncVisible && (\n              <EditorToggle\n                isActive={scrollSyncEnabled}\n                onClick={this.handleToggleScrollSync}\n                size=\"large\"\n                type=\"scroll\"\n                title={t('editor.editorInterface.toggleScrollSync')}\n              />\n            )}\n          </ViewControls>\n          <EditorContent\n            i18nVisible={i18nVisible}\n            previewVisible={previewVisible}\n            editor={editor}\n            editorWithEditor={editorWithEditor}\n            editorWithPreview={editorWithPreview}\n          />\n        </Editor>\n      </EditorContainer>\n    );\n  }\n}\n\nEditorInterface.propTypes = {\n  collection: ImmutablePropTypes.map.isRequired,\n  entry: ImmutablePropTypes.map.isRequired,\n  fields: ImmutablePropTypes.list.isRequired,\n  fieldsMetaData: ImmutablePropTypes.map.isRequired,\n  fieldsErrors: ImmutablePropTypes.map.isRequired,\n  onChange: PropTypes.func.isRequired,\n  onValidate: PropTypes.func.isRequired,\n  onPersist: PropTypes.func.isRequired,\n  showDelete: PropTypes.bool.isRequired,\n  onDelete: PropTypes.func.isRequired,\n  onDeleteUnpublishedChanges: PropTypes.func.isRequired,\n  onPublish: PropTypes.func.isRequired,\n  unPublish: PropTypes.func.isRequired,\n  onDuplicate: PropTypes.func.isRequired,\n  onChangeStatus: PropTypes.func.isRequired,\n  user: PropTypes.object,\n  hasChanged: PropTypes.bool,\n  displayUrl: PropTypes.string,\n  hasWorkflow: PropTypes.bool,\n  useOpenAuthoring: PropTypes.bool,\n  hasUnpublishedChanges: PropTypes.bool,\n  isNewEntry: PropTypes.bool,\n  isModification: PropTypes.bool,\n  currentStatus: PropTypes.string,\n  onLogoutClick: PropTypes.func.isRequired,\n  deployPreview: PropTypes.object,\n  loadDeployPreview: PropTypes.func.isRequired,\n  draftKey: PropTypes.string.isRequired,\n  t: PropTypes.func.isRequired,\n};\n\nexport default EditorInterface;\n"]} */",
|
|
75
|
+
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/Editor/EditorInterface.js"],"names":[],"mappings":"AA0GyB","file":"../../../../src/components/Editor/EditorInterface.js","sourcesContent":["import PropTypes from 'prop-types';\nimport React, { Component } from 'react';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\nimport { css, Global } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport SplitPane from 'react-split-pane';\nimport {\n  colors,\n  colorsRaw,\n  components,\n  transitions,\n  IconButton,\n  zIndex,\n} from 'decap-cms-ui-default';\nimport { ScrollSync, ScrollSyncPane } from 'react-scroll-sync';\n\nimport EditorControlPane from './EditorControlPane/EditorControlPane';\nimport EditorPreviewPane from './EditorPreviewPane/EditorPreviewPane';\nimport EditorToolbar from './EditorToolbar';\nimport { hasI18n, getI18nInfo, getPreviewEntry } from '../../lib/i18n';\nimport { FILES } from '../../constants/collectionTypes';\nimport { getFileFromSlug } from '../../reducers/collections';\n\nconst PREVIEW_VISIBLE = 'cms.preview-visible';\nconst SCROLL_SYNC_ENABLED = 'cms.scroll-sync-enabled';\nconst SPLIT_PANE_POSITION = 'cms.split-pane-position';\nconst I18N_VISIBLE = 'cms.i18n-visible';\n\nconst styles = {\n  splitPane: css`\n    ${components.card};\n    border-radius: 0;\n    height: 100%;\n  `,\n  pane: css`\n    height: 100%;\n    overflow-y: auto;\n  `,\n};\n\nconst EditorToggle = styled(IconButton)`\n  margin-bottom: 12px;\n`;\n\nfunction ReactSplitPaneGlobalStyles() {\n  return (\n    <Global\n      styles={css`\n        .Resizer.vertical {\n          width: 2px;\n          cursor: col-resize;\n          position: relative;\n          background: none;\n\n          &:before {\n            content: '';\n            width: 2px;\n            height: 100%;\n            position: relative;\n            background-color: ${colors.textFieldBorder};\n            display: block;\n            z-index: 10;\n            transition: background-color ${transitions.main};\n          }\n\n          &:hover,\n          &:active {\n            &:before {\n              width: 4px;\n              left: -1px;\n              background-color: ${colorsRaw.blue};\n            }\n          }\n        }\n      `}\n    />\n  );\n}\n\nconst StyledSplitPane = styled(SplitPane)`\n  ${styles.splitPane};\n\n  /**\n   * Quick fix for preview pane not fully displaying in Safari\n   */\n  .Pane {\n    height: 100%;\n  }\n`;\n\nconst NoPreviewContainer = styled.div`\n  ${styles.splitPane};\n`;\n\nconst EditorContainer = styled.div`\n  width: 100%;\n  min-width: 800px;\n  height: 100%;\n  position: absolute;\n  top: 0;\n  left: 0;\n  overflow: hidden;\n  padding-top: 66px;\n  background-color: ${colors.background};\n`;\n\nconst Editor = styled.div`\n  height: 100%;\n  margin: 0 auto;\n  position: relative;\n`;\n\nconst PreviewPaneContainer = styled.div`\n  height: 100%;\n  pointer-events: ${props => (props.blockEntry ? 'none' : 'auto')};\n  overflow-y: ${props => (props.overFlow ? 'auto' : 'hidden')};\n`;\n\nconst ControlPaneContainer = styled(PreviewPaneContainer)`\n  padding: 0 16px;\n  position: relative;\n  overflow-x: hidden;\n`;\n\nconst ViewControls = styled.div`\n  position: absolute;\n  top: 10px;\n  right: 10px;\n  z-index: ${zIndex.zIndex299};\n`;\n\nfunction EditorContent({\n  i18nVisible,\n  previewVisible,\n  editor,\n  editorWithEditor,\n  editorWithPreview,\n}) {\n  if (i18nVisible) {\n    return editorWithEditor;\n  } else if (previewVisible) {\n    return editorWithPreview;\n  } else {\n    return <NoPreviewContainer>{editor}</NoPreviewContainer>;\n  }\n}\n\nfunction isPreviewEnabled(collection, entry) {\n  if (collection.get('type') === FILES) {\n    const file = getFileFromSlug(collection, entry.get('slug'));\n    const previewEnabled = file?.getIn(['editor', 'preview']);\n    if (previewEnabled != null) return previewEnabled;\n  }\n  return collection.getIn(['editor', 'preview'], true);\n}\n\nclass EditorInterface extends Component {\n  state = {\n    showEventBlocker: false,\n    previewVisible: localStorage.getItem(PREVIEW_VISIBLE) !== 'false',\n    scrollSyncEnabled: localStorage.getItem(SCROLL_SYNC_ENABLED) !== 'false',\n    i18nVisible: localStorage.getItem(I18N_VISIBLE) !== 'false',\n  };\n\n  handleFieldClick = path => {\n    this.controlPaneRef?.focus(path);\n  };\n\n  handleSplitPaneDragStart = () => {\n    this.setState({ showEventBlocker: true });\n  };\n\n  handleSplitPaneDragFinished = () => {\n    this.setState({ showEventBlocker: false });\n  };\n\n  handleOnPersist = async (opts = {}) => {\n    const { createNew = false, duplicate = false } = opts;\n    await this.controlPaneRef.switchToDefaultLocale();\n    this.controlPaneRef.validate();\n    this.props.onPersist({ createNew, duplicate });\n  };\n\n  handleOnPublish = async (opts = {}) => {\n    const { createNew = false, duplicate = false } = opts;\n    await this.controlPaneRef.switchToDefaultLocale();\n    this.controlPaneRef.validate();\n    this.props.onPublish({ createNew, duplicate });\n  };\n\n  handleTogglePreview = () => {\n    const newPreviewVisible = !this.state.previewVisible;\n    this.setState({ previewVisible: newPreviewVisible });\n    localStorage.setItem(PREVIEW_VISIBLE, newPreviewVisible);\n  };\n\n  handleToggleScrollSync = () => {\n    const newScrollSyncEnabled = !this.state.scrollSyncEnabled;\n    this.setState({ scrollSyncEnabled: newScrollSyncEnabled });\n    localStorage.setItem(SCROLL_SYNC_ENABLED, newScrollSyncEnabled);\n  };\n\n  handleToggleI18n = () => {\n    const newI18nVisible = !this.state.i18nVisible;\n    this.setState({ i18nVisible: newI18nVisible });\n    localStorage.setItem(I18N_VISIBLE, newI18nVisible);\n  };\n\n  handleLeftPanelLocaleChange = locale => {\n    this.setState({ leftPanelLocale: locale });\n  };\n\n  render() {\n    const {\n      collection,\n      entry,\n      fields,\n      fieldsMetaData,\n      fieldsErrors,\n      onChange,\n      showDelete,\n      onDelete,\n      onDeleteUnpublishedChanges,\n      onChangeStatus,\n      onPublish,\n      unPublish,\n      onDuplicate,\n      onValidate,\n      user,\n      hasChanged,\n      displayUrl,\n      hasWorkflow,\n      useOpenAuthoring,\n      hasUnpublishedChanges,\n      isNewEntry,\n      isModification,\n      currentStatus,\n      onLogoutClick,\n      loadDeployPreview,\n      deployPreview,\n      draftKey,\n      editorBackLink,\n      t,\n    } = this.props;\n\n    const { scrollSyncEnabled, showEventBlocker } = this.state;\n\n    const previewEnabled = isPreviewEnabled(collection, entry);\n\n    const { locales, defaultLocale } = getI18nInfo(this.props.collection);\n    const collectionI18nEnabled = hasI18n(collection) && locales.length > 1;\n    const editorProps = {\n      collection,\n      entry,\n      fields,\n      fieldsMetaData,\n      fieldsErrors,\n      onChange,\n      onValidate,\n    };\n\n    const leftPanelLocale = this.state.leftPanelLocale || locales?.[0];\n    const editor = (\n      <ControlPaneContainer overFlow blockEntry={showEventBlocker}>\n        <EditorControlPane\n          {...editorProps}\n          ref={c => (this.controlPaneRef = c)}\n          locale={leftPanelLocale}\n          t={t}\n          onLocaleChange={this.handleLeftPanelLocaleChange}\n        />\n      </ControlPaneContainer>\n    );\n\n    const editor2 = (\n      <ControlPaneContainer overFlow={!this.state.scrollSyncEnabled} blockEntry={showEventBlocker}>\n        <EditorControlPane {...editorProps} locale={locales?.[1]} t={t} />\n      </ControlPaneContainer>\n    );\n\n    const previewEntry = collectionI18nEnabled\n      ? getPreviewEntry(entry, leftPanelLocale, defaultLocale)\n      : entry;\n\n    const editorWithPreview = (\n      <ScrollSync enabled={this.state.scrollSyncEnabled}>\n        <div>\n          <ReactSplitPaneGlobalStyles />\n          <StyledSplitPane\n            maxSize={-100}\n            minSize={400}\n            defaultSize={parseInt(localStorage.getItem(SPLIT_PANE_POSITION), 10) || '50%'}\n            onChange={size => localStorage.setItem(SPLIT_PANE_POSITION, size)}\n            onDragStarted={this.handleSplitPaneDragStart}\n            onDragFinished={this.handleSplitPaneDragFinished}\n          >\n            <ScrollSyncPane>{editor}</ScrollSyncPane>\n            <PreviewPaneContainer blockEntry={showEventBlocker}>\n              <EditorPreviewPane\n                collection={collection}\n                entry={previewEntry}\n                fields={fields}\n                fieldsMetaData={fieldsMetaData}\n                locale={leftPanelLocale}\n                onFieldClick={this.handleFieldClick}\n              />\n            </PreviewPaneContainer>\n          </StyledSplitPane>\n        </div>\n      </ScrollSync>\n    );\n\n    const editorWithEditor = (\n      <ScrollSync enabled={this.state.scrollSyncEnabled}>\n        <div>\n          <StyledSplitPane\n            maxSize={-100}\n            defaultSize={parseInt(localStorage.getItem(SPLIT_PANE_POSITION), 10) || '50%'}\n            onChange={size => localStorage.setItem(SPLIT_PANE_POSITION, size)}\n            onDragStarted={this.handleSplitPaneDragStart}\n            onDragFinished={this.handleSplitPaneDragFinished}\n          >\n            <ScrollSyncPane>{editor}</ScrollSyncPane>\n            <ScrollSyncPane>{editor2}</ScrollSyncPane>\n          </StyledSplitPane>\n        </div>\n      </ScrollSync>\n    );\n\n    const i18nVisible = collectionI18nEnabled && this.state.i18nVisible;\n    const previewVisible = previewEnabled && this.state.previewVisible;\n    const scrollSyncVisible = i18nVisible || previewVisible;\n\n    return (\n      <EditorContainer>\n        <EditorToolbar\n          isPersisting={entry.get('isPersisting')}\n          isPublishing={entry.get('isPublishing')}\n          isUpdatingStatus={entry.get('isUpdatingStatus')}\n          isDeleting={entry.get('isDeleting')}\n          onPersist={this.handleOnPersist}\n          onPersistAndNew={() => this.handleOnPersist({ createNew: true })}\n          onPersistAndDuplicate={() => this.handleOnPersist({ createNew: true, duplicate: true })}\n          onDelete={onDelete}\n          onDeleteUnpublishedChanges={onDeleteUnpublishedChanges}\n          onChangeStatus={onChangeStatus}\n          showDelete={showDelete}\n          onPublish={onPublish}\n          unPublish={unPublish}\n          onDuplicate={onDuplicate}\n          onPublishAndNew={() => this.handleOnPublish({ createNew: true })}\n          onPublishAndDuplicate={() => this.handleOnPublish({ createNew: true, duplicate: true })}\n          user={user}\n          hasChanged={hasChanged}\n          displayUrl={displayUrl}\n          collection={collection}\n          hasWorkflow={hasWorkflow}\n          useOpenAuthoring={useOpenAuthoring}\n          hasUnpublishedChanges={hasUnpublishedChanges}\n          isNewEntry={isNewEntry}\n          isModification={isModification}\n          currentStatus={currentStatus}\n          onLogoutClick={onLogoutClick}\n          loadDeployPreview={loadDeployPreview}\n          deployPreview={deployPreview}\n          editorBackLink={editorBackLink}\n        />\n        <Editor key={draftKey}>\n          <ViewControls>\n            {collectionI18nEnabled && (\n              <EditorToggle\n                isActive={i18nVisible}\n                onClick={this.handleToggleI18n}\n                size=\"large\"\n                type=\"page\"\n                title={t('editor.editorInterface.toggleI18n')}\n                marginTop=\"70px\"\n              />\n            )}\n            {previewEnabled && (\n              <EditorToggle\n                isActive={previewVisible}\n                onClick={this.handleTogglePreview}\n                size=\"large\"\n                type=\"eye\"\n                title={t('editor.editorInterface.togglePreview')}\n              />\n            )}\n            {scrollSyncVisible && !collection.getIn(['editor', 'visualEditing']) && (\n              <EditorToggle\n                isActive={scrollSyncEnabled}\n                onClick={this.handleToggleScrollSync}\n                size=\"large\"\n                type=\"scroll\"\n                title={t('editor.editorInterface.toggleScrollSync')}\n              />\n            )}\n          </ViewControls>\n          <EditorContent\n            i18nVisible={i18nVisible}\n            previewVisible={previewVisible}\n            editor={editor}\n            editorWithEditor={editorWithEditor}\n            editorWithPreview={editorWithPreview}\n          />\n        </Editor>\n      </EditorContainer>\n    );\n  }\n}\n\nEditorInterface.propTypes = {\n  collection: ImmutablePropTypes.map.isRequired,\n  entry: ImmutablePropTypes.map.isRequired,\n  fields: ImmutablePropTypes.list.isRequired,\n  fieldsMetaData: ImmutablePropTypes.map.isRequired,\n  fieldsErrors: ImmutablePropTypes.map.isRequired,\n  onChange: PropTypes.func.isRequired,\n  onValidate: PropTypes.func.isRequired,\n  onPersist: PropTypes.func.isRequired,\n  showDelete: PropTypes.bool.isRequired,\n  onDelete: PropTypes.func.isRequired,\n  onDeleteUnpublishedChanges: PropTypes.func.isRequired,\n  onPublish: PropTypes.func.isRequired,\n  unPublish: PropTypes.func.isRequired,\n  onDuplicate: PropTypes.func.isRequired,\n  onChangeStatus: PropTypes.func.isRequired,\n  user: PropTypes.object,\n  hasChanged: PropTypes.bool,\n  displayUrl: PropTypes.string,\n  hasWorkflow: PropTypes.bool,\n  useOpenAuthoring: PropTypes.bool,\n  hasUnpublishedChanges: PropTypes.bool,\n  isNewEntry: PropTypes.bool,\n  isModification: PropTypes.bool,\n  currentStatus: PropTypes.string,\n  onLogoutClick: PropTypes.func.isRequired,\n  deployPreview: PropTypes.object,\n  loadDeployPreview: PropTypes.func.isRequired,\n  draftKey: PropTypes.string.isRequired,\n  t: PropTypes.func.isRequired,\n};\n\nexport default EditorInterface;\n"]} */",
|
|
84
76
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__
|
|
85
77
|
});
|
|
86
|
-
const PreviewPaneContainer = /*#__PURE__*/(
|
|
78
|
+
const PreviewPaneContainer = /*#__PURE__*/_styled("div", {
|
|
87
79
|
target: "e1nx103k2",
|
|
88
80
|
label: "PreviewPaneContainer"
|
|
89
|
-
})("height:100%;pointer-events:", props => props.blockEntry ? 'none' : 'auto', ";overflow-y:", props => props.overFlow ? 'auto' : 'hidden', ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/Editor/EditorInterface.js"],"names":[],"mappings":"AAgHuC","file":"../../../../src/components/Editor/EditorInterface.js","sourcesContent":["import PropTypes from 'prop-types';\nimport React, { Component } from 'react';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\nimport { css, Global } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport SplitPane from 'react-split-pane';\nimport {\n  colors,\n  colorsRaw,\n  components,\n  transitions,\n  IconButton,\n  zIndex,\n} from 'decap-cms-ui-default';\nimport { ScrollSync, ScrollSyncPane } from 'react-scroll-sync';\n\nimport EditorControlPane from './EditorControlPane/EditorControlPane';\nimport EditorPreviewPane from './EditorPreviewPane/EditorPreviewPane';\nimport EditorToolbar from './EditorToolbar';\nimport { hasI18n, getI18nInfo, getPreviewEntry } from '../../lib/i18n';\nimport { FILES } from '../../constants/collectionTypes';\nimport { getFileFromSlug } from '../../reducers/collections';\n\nconst PREVIEW_VISIBLE = 'cms.preview-visible';\nconst SCROLL_SYNC_ENABLED = 'cms.scroll-sync-enabled';\nconst SPLIT_PANE_POSITION = 'cms.split-pane-position';\nconst I18N_VISIBLE = 'cms.i18n-visible';\n\nconst styles = {\n  splitPane: css`\n    ${components.card};\n    border-radius: 0;\n    height: 100%;\n  `,\n  pane: css`\n    height: 100%;\n    overflow-y: auto;\n  `,\n};\n\nconst EditorToggle = styled(IconButton)`\n  margin-bottom: 12px;\n`;\n\nfunction ReactSplitPaneGlobalStyles() {\n  return (\n    <Global\n      styles={css`\n        .Resizer.vertical {\n          width: 2px;\n          cursor: col-resize;\n          position: relative;\n          background: none;\n\n          &:before {\n            content: '';\n            width: 2px;\n            height: 100%;\n            position: relative;\n            background-color: ${colors.textFieldBorder};\n            display: block;\n            z-index: 10;\n            transition: background-color ${transitions.main};\n          }\n\n          &:hover,\n          &:active {\n            &:before {\n              width: 4px;\n              left: -1px;\n              background-color: ${colorsRaw.blue};\n            }\n          }\n        }\n      `}\n    />\n  );\n}\n\nconst StyledSplitPane = styled(SplitPane)`\n  ${styles.splitPane};\n\n  /**\n   * Quick fix for preview pane not fully displaying in Safari\n   */\n  .Pane {\n    height: 100%;\n  }\n`;\n\nconst NoPreviewContainer = styled.div`\n  ${styles.splitPane};\n`;\n\nconst EditorContainer = styled.div`\n  width: 100%;\n  min-width: 800px;\n  height: 100%;\n  position: absolute;\n  top: 0;\n  left: 0;\n  overflow: hidden;\n  padding-top: 66px;\n  background-color: ${colors.background};\n`;\n\nconst Editor = styled.div`\n  height: 100%;\n  margin: 0 auto;\n  position: relative;\n`;\n\nconst PreviewPaneContainer = styled.div`\n  height: 100%;\n  pointer-events: ${props => (props.blockEntry ? 'none' : 'auto')};\n  overflow-y: ${props => (props.overFlow ? 'auto' : 'hidden')};\n`;\n\nconst ControlPaneContainer = styled(PreviewPaneContainer)`\n  padding: 0 16px;\n  position: relative;\n  overflow-x: hidden;\n`;\n\nconst ViewControls = styled.div`\n  position: absolute;\n  top: 10px;\n  right: 10px;\n  z-index: ${zIndex.zIndex299};\n`;\n\nfunction EditorContent({\n  i18nVisible,\n  previewVisible,\n  editor,\n  editorWithEditor,\n  editorWithPreview,\n}) {\n  if (i18nVisible) {\n    return editorWithEditor;\n  } else if (previewVisible) {\n    return editorWithPreview;\n  } else {\n    return <NoPreviewContainer>{editor}</NoPreviewContainer>;\n  }\n}\n\nfunction isPreviewEnabled(collection, entry) {\n  if (collection.get('type') === FILES) {\n    const file = getFileFromSlug(collection, entry.get('slug'));\n    const previewEnabled = file?.getIn(['editor', 'preview']);\n    if (previewEnabled != null) return previewEnabled;\n  }\n  return collection.getIn(['editor', 'preview'], true);\n}\n\nclass EditorInterface extends Component {\n  state = {\n    showEventBlocker: false,\n    previewVisible: localStorage.getItem(PREVIEW_VISIBLE) !== 'false',\n    scrollSyncEnabled: localStorage.getItem(SCROLL_SYNC_ENABLED) !== 'false',\n    i18nVisible: localStorage.getItem(I18N_VISIBLE) !== 'false',\n  };\n\n  handleSplitPaneDragStart = () => {\n    this.setState({ showEventBlocker: true });\n  };\n\n  handleSplitPaneDragFinished = () => {\n    this.setState({ showEventBlocker: false });\n  };\n\n  handleOnPersist = async (opts = {}) => {\n    const { createNew = false, duplicate = false } = opts;\n    await this.controlPaneRef.switchToDefaultLocale();\n    this.controlPaneRef.validate();\n    this.props.onPersist({ createNew, duplicate });\n  };\n\n  handleOnPublish = async (opts = {}) => {\n    const { createNew = false, duplicate = false } = opts;\n    await this.controlPaneRef.switchToDefaultLocale();\n    this.controlPaneRef.validate();\n    this.props.onPublish({ createNew, duplicate });\n  };\n\n  handleTogglePreview = () => {\n    const newPreviewVisible = !this.state.previewVisible;\n    this.setState({ previewVisible: newPreviewVisible });\n    localStorage.setItem(PREVIEW_VISIBLE, newPreviewVisible);\n  };\n\n  handleToggleScrollSync = () => {\n    const newScrollSyncEnabled = !this.state.scrollSyncEnabled;\n    this.setState({ scrollSyncEnabled: newScrollSyncEnabled });\n    localStorage.setItem(SCROLL_SYNC_ENABLED, newScrollSyncEnabled);\n  };\n\n  handleToggleI18n = () => {\n    const newI18nVisible = !this.state.i18nVisible;\n    this.setState({ i18nVisible: newI18nVisible });\n    localStorage.setItem(I18N_VISIBLE, newI18nVisible);\n  };\n\n  handleLeftPanelLocaleChange = locale => {\n    this.setState({ leftPanelLocale: locale });\n  };\n\n  render() {\n    const {\n      collection,\n      entry,\n      fields,\n      fieldsMetaData,\n      fieldsErrors,\n      onChange,\n      showDelete,\n      onDelete,\n      onDeleteUnpublishedChanges,\n      onChangeStatus,\n      onPublish,\n      unPublish,\n      onDuplicate,\n      onValidate,\n      user,\n      hasChanged,\n      displayUrl,\n      hasWorkflow,\n      useOpenAuthoring,\n      hasUnpublishedChanges,\n      isNewEntry,\n      isModification,\n      currentStatus,\n      onLogoutClick,\n      loadDeployPreview,\n      deployPreview,\n      draftKey,\n      editorBackLink,\n      t,\n    } = this.props;\n\n    const { scrollSyncEnabled, showEventBlocker } = this.state;\n\n    const previewEnabled = isPreviewEnabled(collection, entry);\n\n    const { locales, defaultLocale } = getI18nInfo(this.props.collection);\n    const collectionI18nEnabled = hasI18n(collection) && locales.length > 1;\n    const editorProps = {\n      collection,\n      entry,\n      fields,\n      fieldsMetaData,\n      fieldsErrors,\n      onChange,\n      onValidate,\n    };\n\n    const leftPanelLocale = this.state.leftPanelLocale || locales?.[0];\n    const editor = (\n      <ControlPaneContainer overFlow blockEntry={showEventBlocker}>\n        <EditorControlPane\n          {...editorProps}\n          ref={c => (this.controlPaneRef = c)}\n          locale={leftPanelLocale}\n          t={t}\n          onLocaleChange={this.handleLeftPanelLocaleChange}\n        />\n      </ControlPaneContainer>\n    );\n\n    const editor2 = (\n      <ControlPaneContainer overFlow={!this.state.scrollSyncEnabled} blockEntry={showEventBlocker}>\n        <EditorControlPane {...editorProps} locale={locales?.[1]} t={t} />\n      </ControlPaneContainer>\n    );\n\n    const previewEntry = collectionI18nEnabled\n      ? getPreviewEntry(entry, leftPanelLocale, defaultLocale)\n      : entry;\n\n    const editorWithPreview = (\n      <ScrollSync enabled={this.state.scrollSyncEnabled}>\n        <div>\n          <ReactSplitPaneGlobalStyles />\n          <StyledSplitPane\n            maxSize={-100}\n            minSize={400}\n            defaultSize={parseInt(localStorage.getItem(SPLIT_PANE_POSITION), 10) || '50%'}\n            onChange={size => localStorage.setItem(SPLIT_PANE_POSITION, size)}\n            onDragStarted={this.handleSplitPaneDragStart}\n            onDragFinished={this.handleSplitPaneDragFinished}\n          >\n            <ScrollSyncPane>{editor}</ScrollSyncPane>\n            <PreviewPaneContainer blockEntry={showEventBlocker}>\n              <EditorPreviewPane\n                collection={collection}\n                entry={previewEntry}\n                fields={fields}\n                fieldsMetaData={fieldsMetaData}\n                locale={leftPanelLocale}\n              />\n            </PreviewPaneContainer>\n          </StyledSplitPane>\n        </div>\n      </ScrollSync>\n    );\n\n    const editorWithEditor = (\n      <ScrollSync enabled={this.state.scrollSyncEnabled}>\n        <div>\n          <StyledSplitPane\n            maxSize={-100}\n            defaultSize={parseInt(localStorage.getItem(SPLIT_PANE_POSITION), 10) || '50%'}\n            onChange={size => localStorage.setItem(SPLIT_PANE_POSITION, size)}\n            onDragStarted={this.handleSplitPaneDragStart}\n            onDragFinished={this.handleSplitPaneDragFinished}\n          >\n            <ScrollSyncPane>{editor}</ScrollSyncPane>\n            <ScrollSyncPane>{editor2}</ScrollSyncPane>\n          </StyledSplitPane>\n        </div>\n      </ScrollSync>\n    );\n\n    const i18nVisible = collectionI18nEnabled && this.state.i18nVisible;\n    const previewVisible = previewEnabled && this.state.previewVisible;\n    const scrollSyncVisible = i18nVisible || previewVisible;\n\n    return (\n      <EditorContainer>\n        <EditorToolbar\n          isPersisting={entry.get('isPersisting')}\n          isPublishing={entry.get('isPublishing')}\n          isUpdatingStatus={entry.get('isUpdatingStatus')}\n          isDeleting={entry.get('isDeleting')}\n          onPersist={this.handleOnPersist}\n          onPersistAndNew={() => this.handleOnPersist({ createNew: true })}\n          onPersistAndDuplicate={() => this.handleOnPersist({ createNew: true, duplicate: true })}\n          onDelete={onDelete}\n          onDeleteUnpublishedChanges={onDeleteUnpublishedChanges}\n          onChangeStatus={onChangeStatus}\n          showDelete={showDelete}\n          onPublish={onPublish}\n          unPublish={unPublish}\n          onDuplicate={onDuplicate}\n          onPublishAndNew={() => this.handleOnPublish({ createNew: true })}\n          onPublishAndDuplicate={() => this.handleOnPublish({ createNew: true, duplicate: true })}\n          user={user}\n          hasChanged={hasChanged}\n          displayUrl={displayUrl}\n          collection={collection}\n          hasWorkflow={hasWorkflow}\n          useOpenAuthoring={useOpenAuthoring}\n          hasUnpublishedChanges={hasUnpublishedChanges}\n          isNewEntry={isNewEntry}\n          isModification={isModification}\n          currentStatus={currentStatus}\n          onLogoutClick={onLogoutClick}\n          loadDeployPreview={loadDeployPreview}\n          deployPreview={deployPreview}\n          editorBackLink={editorBackLink}\n        />\n        <Editor key={draftKey}>\n          <ViewControls>\n            {collectionI18nEnabled && (\n              <EditorToggle\n                isActive={i18nVisible}\n                onClick={this.handleToggleI18n}\n                size=\"large\"\n                type=\"page\"\n                title={t('editor.editorInterface.toggleI18n')}\n                marginTop=\"70px\"\n              />\n            )}\n            {previewEnabled && (\n              <EditorToggle\n                isActive={previewVisible}\n                onClick={this.handleTogglePreview}\n                size=\"large\"\n                type=\"eye\"\n                title={t('editor.editorInterface.togglePreview')}\n              />\n            )}\n            {scrollSyncVisible && (\n              <EditorToggle\n                isActive={scrollSyncEnabled}\n                onClick={this.handleToggleScrollSync}\n                size=\"large\"\n                type=\"scroll\"\n                title={t('editor.editorInterface.toggleScrollSync')}\n              />\n            )}\n          </ViewControls>\n          <EditorContent\n            i18nVisible={i18nVisible}\n            previewVisible={previewVisible}\n            editor={editor}\n            editorWithEditor={editorWithEditor}\n            editorWithPreview={editorWithPreview}\n          />\n        </Editor>\n      </EditorContainer>\n    );\n  }\n}\n\nEditorInterface.propTypes = {\n  collection: ImmutablePropTypes.map.isRequired,\n  entry: ImmutablePropTypes.map.isRequired,\n  fields: ImmutablePropTypes.list.isRequired,\n  fieldsMetaData: ImmutablePropTypes.map.isRequired,\n  fieldsErrors: ImmutablePropTypes.map.isRequired,\n  onChange: PropTypes.func.isRequired,\n  onValidate: PropTypes.func.isRequired,\n  onPersist: PropTypes.func.isRequired,\n  showDelete: PropTypes.bool.isRequired,\n  onDelete: PropTypes.func.isRequired,\n  onDeleteUnpublishedChanges: PropTypes.func.isRequired,\n  onPublish: PropTypes.func.isRequired,\n  unPublish: PropTypes.func.isRequired,\n  onDuplicate: PropTypes.func.isRequired,\n  onChangeStatus: PropTypes.func.isRequired,\n  user: PropTypes.object,\n  hasChanged: PropTypes.bool,\n  displayUrl: PropTypes.string,\n  hasWorkflow: PropTypes.bool,\n  useOpenAuthoring: PropTypes.bool,\n  hasUnpublishedChanges: PropTypes.bool,\n  isNewEntry: PropTypes.bool,\n  isModification: PropTypes.bool,\n  currentStatus: PropTypes.string,\n  onLogoutClick: PropTypes.func.isRequired,\n  deployPreview: PropTypes.object,\n  loadDeployPreview: PropTypes.func.isRequired,\n  draftKey: PropTypes.string.isRequired,\n  t: PropTypes.func.isRequired,\n};\n\nexport default EditorInterface;\n"]} */"));
|
|
90
|
-
const ControlPaneContainer = /*#__PURE__*/(
|
|
81
|
+
})("height:100%;pointer-events:", props => props.blockEntry ? 'none' : 'auto', ";overflow-y:", props => props.overFlow ? 'auto' : 'hidden', ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/Editor/EditorInterface.js"],"names":[],"mappings":"AAgHuC","file":"../../../../src/components/Editor/EditorInterface.js","sourcesContent":["import PropTypes from 'prop-types';\nimport React, { Component } from 'react';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\nimport { css, Global } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport SplitPane from 'react-split-pane';\nimport {\n  colors,\n  colorsRaw,\n  components,\n  transitions,\n  IconButton,\n  zIndex,\n} from 'decap-cms-ui-default';\nimport { ScrollSync, ScrollSyncPane } from 'react-scroll-sync';\n\nimport EditorControlPane from './EditorControlPane/EditorControlPane';\nimport EditorPreviewPane from './EditorPreviewPane/EditorPreviewPane';\nimport EditorToolbar from './EditorToolbar';\nimport { hasI18n, getI18nInfo, getPreviewEntry } from '../../lib/i18n';\nimport { FILES } from '../../constants/collectionTypes';\nimport { getFileFromSlug } from '../../reducers/collections';\n\nconst PREVIEW_VISIBLE = 'cms.preview-visible';\nconst SCROLL_SYNC_ENABLED = 'cms.scroll-sync-enabled';\nconst SPLIT_PANE_POSITION = 'cms.split-pane-position';\nconst I18N_VISIBLE = 'cms.i18n-visible';\n\nconst styles = {\n  splitPane: css`\n    ${components.card};\n    border-radius: 0;\n    height: 100%;\n  `,\n  pane: css`\n    height: 100%;\n    overflow-y: auto;\n  `,\n};\n\nconst EditorToggle = styled(IconButton)`\n  margin-bottom: 12px;\n`;\n\nfunction ReactSplitPaneGlobalStyles() {\n  return (\n    <Global\n      styles={css`\n        .Resizer.vertical {\n          width: 2px;\n          cursor: col-resize;\n          position: relative;\n          background: none;\n\n          &:before {\n            content: '';\n            width: 2px;\n            height: 100%;\n            position: relative;\n            background-color: ${colors.textFieldBorder};\n            display: block;\n            z-index: 10;\n            transition: background-color ${transitions.main};\n          }\n\n          &:hover,\n          &:active {\n            &:before {\n              width: 4px;\n              left: -1px;\n              background-color: ${colorsRaw.blue};\n            }\n          }\n        }\n      `}\n    />\n  );\n}\n\nconst StyledSplitPane = styled(SplitPane)`\n  ${styles.splitPane};\n\n  /**\n   * Quick fix for preview pane not fully displaying in Safari\n   */\n  .Pane {\n    height: 100%;\n  }\n`;\n\nconst NoPreviewContainer = styled.div`\n  ${styles.splitPane};\n`;\n\nconst EditorContainer = styled.div`\n  width: 100%;\n  min-width: 800px;\n  height: 100%;\n  position: absolute;\n  top: 0;\n  left: 0;\n  overflow: hidden;\n  padding-top: 66px;\n  background-color: ${colors.background};\n`;\n\nconst Editor = styled.div`\n  height: 100%;\n  margin: 0 auto;\n  position: relative;\n`;\n\nconst PreviewPaneContainer = styled.div`\n  height: 100%;\n  pointer-events: ${props => (props.blockEntry ? 'none' : 'auto')};\n  overflow-y: ${props => (props.overFlow ? 'auto' : 'hidden')};\n`;\n\nconst ControlPaneContainer = styled(PreviewPaneContainer)`\n  padding: 0 16px;\n  position: relative;\n  overflow-x: hidden;\n`;\n\nconst ViewControls = styled.div`\n  position: absolute;\n  top: 10px;\n  right: 10px;\n  z-index: ${zIndex.zIndex299};\n`;\n\nfunction EditorContent({\n  i18nVisible,\n  previewVisible,\n  editor,\n  editorWithEditor,\n  editorWithPreview,\n}) {\n  if (i18nVisible) {\n    return editorWithEditor;\n  } else if (previewVisible) {\n    return editorWithPreview;\n  } else {\n    return <NoPreviewContainer>{editor}</NoPreviewContainer>;\n  }\n}\n\nfunction isPreviewEnabled(collection, entry) {\n  if (collection.get('type') === FILES) {\n    const file = getFileFromSlug(collection, entry.get('slug'));\n    const previewEnabled = file?.getIn(['editor', 'preview']);\n    if (previewEnabled != null) return previewEnabled;\n  }\n  return collection.getIn(['editor', 'preview'], true);\n}\n\nclass EditorInterface extends Component {\n  state = {\n    showEventBlocker: false,\n    previewVisible: localStorage.getItem(PREVIEW_VISIBLE) !== 'false',\n    scrollSyncEnabled: localStorage.getItem(SCROLL_SYNC_ENABLED) !== 'false',\n    i18nVisible: localStorage.getItem(I18N_VISIBLE) !== 'false',\n  };\n\n  handleFieldClick = path => {\n    this.controlPaneRef?.focus(path);\n  };\n\n  handleSplitPaneDragStart = () => {\n    this.setState({ showEventBlocker: true });\n  };\n\n  handleSplitPaneDragFinished = () => {\n    this.setState({ showEventBlocker: false });\n  };\n\n  handleOnPersist = async (opts = {}) => {\n    const { createNew = false, duplicate = false } = opts;\n    await this.controlPaneRef.switchToDefaultLocale();\n    this.controlPaneRef.validate();\n    this.props.onPersist({ createNew, duplicate });\n  };\n\n  handleOnPublish = async (opts = {}) => {\n    const { createNew = false, duplicate = false } = opts;\n    await this.controlPaneRef.switchToDefaultLocale();\n    this.controlPaneRef.validate();\n    this.props.onPublish({ createNew, duplicate });\n  };\n\n  handleTogglePreview = () => {\n    const newPreviewVisible = !this.state.previewVisible;\n    this.setState({ previewVisible: newPreviewVisible });\n    localStorage.setItem(PREVIEW_VISIBLE, newPreviewVisible);\n  };\n\n  handleToggleScrollSync = () => {\n    const newScrollSyncEnabled = !this.state.scrollSyncEnabled;\n    this.setState({ scrollSyncEnabled: newScrollSyncEnabled });\n    localStorage.setItem(SCROLL_SYNC_ENABLED, newScrollSyncEnabled);\n  };\n\n  handleToggleI18n = () => {\n    const newI18nVisible = !this.state.i18nVisible;\n    this.setState({ i18nVisible: newI18nVisible });\n    localStorage.setItem(I18N_VISIBLE, newI18nVisible);\n  };\n\n  handleLeftPanelLocaleChange = locale => {\n    this.setState({ leftPanelLocale: locale });\n  };\n\n  render() {\n    const {\n      collection,\n      entry,\n      fields,\n      fieldsMetaData,\n      fieldsErrors,\n      onChange,\n      showDelete,\n      onDelete,\n      onDeleteUnpublishedChanges,\n      onChangeStatus,\n      onPublish,\n      unPublish,\n      onDuplicate,\n      onValidate,\n      user,\n      hasChanged,\n      displayUrl,\n      hasWorkflow,\n      useOpenAuthoring,\n      hasUnpublishedChanges,\n      isNewEntry,\n      isModification,\n      currentStatus,\n      onLogoutClick,\n      loadDeployPreview,\n      deployPreview,\n      draftKey,\n      editorBackLink,\n      t,\n    } = this.props;\n\n    const { scrollSyncEnabled, showEventBlocker } = this.state;\n\n    const previewEnabled = isPreviewEnabled(collection, entry);\n\n    const { locales, defaultLocale } = getI18nInfo(this.props.collection);\n    const collectionI18nEnabled = hasI18n(collection) && locales.length > 1;\n    const editorProps = {\n      collection,\n      entry,\n      fields,\n      fieldsMetaData,\n      fieldsErrors,\n      onChange,\n      onValidate,\n    };\n\n    const leftPanelLocale = this.state.leftPanelLocale || locales?.[0];\n    const editor = (\n      <ControlPaneContainer overFlow blockEntry={showEventBlocker}>\n        <EditorControlPane\n          {...editorProps}\n          ref={c => (this.controlPaneRef = c)}\n          locale={leftPanelLocale}\n          t={t}\n          onLocaleChange={this.handleLeftPanelLocaleChange}\n        />\n      </ControlPaneContainer>\n    );\n\n    const editor2 = (\n      <ControlPaneContainer overFlow={!this.state.scrollSyncEnabled} blockEntry={showEventBlocker}>\n        <EditorControlPane {...editorProps} locale={locales?.[1]} t={t} />\n      </ControlPaneContainer>\n    );\n\n    const previewEntry = collectionI18nEnabled\n      ? getPreviewEntry(entry, leftPanelLocale, defaultLocale)\n      : entry;\n\n    const editorWithPreview = (\n      <ScrollSync enabled={this.state.scrollSyncEnabled}>\n        <div>\n          <ReactSplitPaneGlobalStyles />\n          <StyledSplitPane\n            maxSize={-100}\n            minSize={400}\n            defaultSize={parseInt(localStorage.getItem(SPLIT_PANE_POSITION), 10) || '50%'}\n            onChange={size => localStorage.setItem(SPLIT_PANE_POSITION, size)}\n            onDragStarted={this.handleSplitPaneDragStart}\n            onDragFinished={this.handleSplitPaneDragFinished}\n          >\n            <ScrollSyncPane>{editor}</ScrollSyncPane>\n            <PreviewPaneContainer blockEntry={showEventBlocker}>\n              <EditorPreviewPane\n                collection={collection}\n                entry={previewEntry}\n                fields={fields}\n                fieldsMetaData={fieldsMetaData}\n                locale={leftPanelLocale}\n                onFieldClick={this.handleFieldClick}\n              />\n            </PreviewPaneContainer>\n          </StyledSplitPane>\n        </div>\n      </ScrollSync>\n    );\n\n    const editorWithEditor = (\n      <ScrollSync enabled={this.state.scrollSyncEnabled}>\n        <div>\n          <StyledSplitPane\n            maxSize={-100}\n            defaultSize={parseInt(localStorage.getItem(SPLIT_PANE_POSITION), 10) || '50%'}\n            onChange={size => localStorage.setItem(SPLIT_PANE_POSITION, size)}\n            onDragStarted={this.handleSplitPaneDragStart}\n            onDragFinished={this.handleSplitPaneDragFinished}\n          >\n            <ScrollSyncPane>{editor}</ScrollSyncPane>\n            <ScrollSyncPane>{editor2}</ScrollSyncPane>\n          </StyledSplitPane>\n        </div>\n      </ScrollSync>\n    );\n\n    const i18nVisible = collectionI18nEnabled && this.state.i18nVisible;\n    const previewVisible = previewEnabled && this.state.previewVisible;\n    const scrollSyncVisible = i18nVisible || previewVisible;\n\n    return (\n      <EditorContainer>\n        <EditorToolbar\n          isPersisting={entry.get('isPersisting')}\n          isPublishing={entry.get('isPublishing')}\n          isUpdatingStatus={entry.get('isUpdatingStatus')}\n          isDeleting={entry.get('isDeleting')}\n          onPersist={this.handleOnPersist}\n          onPersistAndNew={() => this.handleOnPersist({ createNew: true })}\n          onPersistAndDuplicate={() => this.handleOnPersist({ createNew: true, duplicate: true })}\n          onDelete={onDelete}\n          onDeleteUnpublishedChanges={onDeleteUnpublishedChanges}\n          onChangeStatus={onChangeStatus}\n          showDelete={showDelete}\n          onPublish={onPublish}\n          unPublish={unPublish}\n          onDuplicate={onDuplicate}\n          onPublishAndNew={() => this.handleOnPublish({ createNew: true })}\n          onPublishAndDuplicate={() => this.handleOnPublish({ createNew: true, duplicate: true })}\n          user={user}\n          hasChanged={hasChanged}\n          displayUrl={displayUrl}\n          collection={collection}\n          hasWorkflow={hasWorkflow}\n          useOpenAuthoring={useOpenAuthoring}\n          hasUnpublishedChanges={hasUnpublishedChanges}\n          isNewEntry={isNewEntry}\n          isModification={isModification}\n          currentStatus={currentStatus}\n          onLogoutClick={onLogoutClick}\n          loadDeployPreview={loadDeployPreview}\n          deployPreview={deployPreview}\n          editorBackLink={editorBackLink}\n        />\n        <Editor key={draftKey}>\n          <ViewControls>\n            {collectionI18nEnabled && (\n              <EditorToggle\n                isActive={i18nVisible}\n                onClick={this.handleToggleI18n}\n                size=\"large\"\n                type=\"page\"\n                title={t('editor.editorInterface.toggleI18n')}\n                marginTop=\"70px\"\n              />\n            )}\n            {previewEnabled && (\n              <EditorToggle\n                isActive={previewVisible}\n                onClick={this.handleTogglePreview}\n                size=\"large\"\n                type=\"eye\"\n                title={t('editor.editorInterface.togglePreview')}\n              />\n            )}\n            {scrollSyncVisible && !collection.getIn(['editor', 'visualEditing']) && (\n              <EditorToggle\n                isActive={scrollSyncEnabled}\n                onClick={this.handleToggleScrollSync}\n                size=\"large\"\n                type=\"scroll\"\n                title={t('editor.editorInterface.toggleScrollSync')}\n              />\n            )}\n          </ViewControls>\n          <EditorContent\n            i18nVisible={i18nVisible}\n            previewVisible={previewVisible}\n            editor={editor}\n            editorWithEditor={editorWithEditor}\n            editorWithPreview={editorWithPreview}\n          />\n        </Editor>\n      </EditorContainer>\n    );\n  }\n}\n\nEditorInterface.propTypes = {\n  collection: ImmutablePropTypes.map.isRequired,\n  entry: ImmutablePropTypes.map.isRequired,\n  fields: ImmutablePropTypes.list.isRequired,\n  fieldsMetaData: ImmutablePropTypes.map.isRequired,\n  fieldsErrors: ImmutablePropTypes.map.isRequired,\n  onChange: PropTypes.func.isRequired,\n  onValidate: PropTypes.func.isRequired,\n  onPersist: PropTypes.func.isRequired,\n  showDelete: PropTypes.bool.isRequired,\n  onDelete: PropTypes.func.isRequired,\n  onDeleteUnpublishedChanges: PropTypes.func.isRequired,\n  onPublish: PropTypes.func.isRequired,\n  unPublish: PropTypes.func.isRequired,\n  onDuplicate: PropTypes.func.isRequired,\n  onChangeStatus: PropTypes.func.isRequired,\n  user: PropTypes.object,\n  hasChanged: PropTypes.bool,\n  displayUrl: PropTypes.string,\n  hasWorkflow: PropTypes.bool,\n  useOpenAuthoring: PropTypes.bool,\n  hasUnpublishedChanges: PropTypes.bool,\n  isNewEntry: PropTypes.bool,\n  isModification: PropTypes.bool,\n  currentStatus: PropTypes.string,\n  onLogoutClick: PropTypes.func.isRequired,\n  deployPreview: PropTypes.object,\n  loadDeployPreview: PropTypes.func.isRequired,\n  draftKey: PropTypes.string.isRequired,\n  t: PropTypes.func.isRequired,\n};\n\nexport default EditorInterface;\n"]} */"));
|
|
82
|
+
const ControlPaneContainer = /*#__PURE__*/_styled(PreviewPaneContainer, {
|
|
91
83
|
target: "e1nx103k1",
|
|
92
84
|
label: "ControlPaneContainer"
|
|
93
85
|
})(process.env.NODE_ENV === "production" ? {
|
|
@@ -96,13 +88,13 @@ const ControlPaneContainer = /*#__PURE__*/(0, _base.default)(PreviewPaneContaine
|
|
|
96
88
|
} : {
|
|
97
89
|
name: "b2tic3",
|
|
98
90
|
styles: "padding:0 16px;position:relative;overflow-x:hidden",
|
|
99
|
-
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/Editor/EditorInterface.js"],"names":[],"mappings":"AAsHyD","file":"../../../../src/components/Editor/EditorInterface.js","sourcesContent":["import PropTypes from 'prop-types';\nimport React, { Component } from 'react';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\nimport { css, Global } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport SplitPane from 'react-split-pane';\nimport {\n  colors,\n  colorsRaw,\n  components,\n  transitions,\n  IconButton,\n  zIndex,\n} from 'decap-cms-ui-default';\nimport { ScrollSync, ScrollSyncPane } from 'react-scroll-sync';\n\nimport EditorControlPane from './EditorControlPane/EditorControlPane';\nimport EditorPreviewPane from './EditorPreviewPane/EditorPreviewPane';\nimport EditorToolbar from './EditorToolbar';\nimport { hasI18n, getI18nInfo, getPreviewEntry } from '../../lib/i18n';\nimport { FILES } from '../../constants/collectionTypes';\nimport { getFileFromSlug } from '../../reducers/collections';\n\nconst PREVIEW_VISIBLE = 'cms.preview-visible';\nconst SCROLL_SYNC_ENABLED = 'cms.scroll-sync-enabled';\nconst SPLIT_PANE_POSITION = 'cms.split-pane-position';\nconst I18N_VISIBLE = 'cms.i18n-visible';\n\nconst styles = {\n  splitPane: css`\n    ${components.card};\n    border-radius: 0;\n    height: 100%;\n  `,\n  pane: css`\n    height: 100%;\n    overflow-y: auto;\n  `,\n};\n\nconst EditorToggle = styled(IconButton)`\n  margin-bottom: 12px;\n`;\n\nfunction ReactSplitPaneGlobalStyles() {\n  return (\n    <Global\n      styles={css`\n        .Resizer.vertical {\n          width: 2px;\n          cursor: col-resize;\n          position: relative;\n          background: none;\n\n          &:before {\n            content: '';\n            width: 2px;\n            height: 100%;\n            position: relative;\n            background-color: ${colors.textFieldBorder};\n            display: block;\n            z-index: 10;\n            transition: background-color ${transitions.main};\n          }\n\n          &:hover,\n          &:active {\n            &:before {\n              width: 4px;\n              left: -1px;\n              background-color: ${colorsRaw.blue};\n            }\n          }\n        }\n      `}\n    />\n  );\n}\n\nconst StyledSplitPane = styled(SplitPane)`\n  ${styles.splitPane};\n\n  /**\n   * Quick fix for preview pane not fully displaying in Safari\n   */\n  .Pane {\n    height: 100%;\n  }\n`;\n\nconst NoPreviewContainer = styled.div`\n  ${styles.splitPane};\n`;\n\nconst EditorContainer = styled.div`\n  width: 100%;\n  min-width: 800px;\n  height: 100%;\n  position: absolute;\n  top: 0;\n  left: 0;\n  overflow: hidden;\n  padding-top: 66px;\n  background-color: ${colors.background};\n`;\n\nconst Editor = styled.div`\n  height: 100%;\n  margin: 0 auto;\n  position: relative;\n`;\n\nconst PreviewPaneContainer = styled.div`\n  height: 100%;\n  pointer-events: ${props => (props.blockEntry ? 'none' : 'auto')};\n  overflow-y: ${props => (props.overFlow ? 'auto' : 'hidden')};\n`;\n\nconst ControlPaneContainer = styled(PreviewPaneContainer)`\n  padding: 0 16px;\n  position: relative;\n  overflow-x: hidden;\n`;\n\nconst ViewControls = styled.div`\n  position: absolute;\n  top: 10px;\n  right: 10px;\n  z-index: ${zIndex.zIndex299};\n`;\n\nfunction EditorContent({\n  i18nVisible,\n  previewVisible,\n  editor,\n  editorWithEditor,\n  editorWithPreview,\n}) {\n  if (i18nVisible) {\n    return editorWithEditor;\n  } else if (previewVisible) {\n    return editorWithPreview;\n  } else {\n    return <NoPreviewContainer>{editor}</NoPreviewContainer>;\n  }\n}\n\nfunction isPreviewEnabled(collection, entry) {\n  if (collection.get('type') === FILES) {\n    const file = getFileFromSlug(collection, entry.get('slug'));\n    const previewEnabled = file?.getIn(['editor', 'preview']);\n    if (previewEnabled != null) return previewEnabled;\n  }\n  return collection.getIn(['editor', 'preview'], true);\n}\n\nclass EditorInterface extends Component {\n  state = {\n    showEventBlocker: false,\n    previewVisible: localStorage.getItem(PREVIEW_VISIBLE) !== 'false',\n    scrollSyncEnabled: localStorage.getItem(SCROLL_SYNC_ENABLED) !== 'false',\n    i18nVisible: localStorage.getItem(I18N_VISIBLE) !== 'false',\n  };\n\n  handleSplitPaneDragStart = () => {\n    this.setState({ showEventBlocker: true });\n  };\n\n  handleSplitPaneDragFinished = () => {\n    this.setState({ showEventBlocker: false });\n  };\n\n  handleOnPersist = async (opts = {}) => {\n    const { createNew = false, duplicate = false } = opts;\n    await this.controlPaneRef.switchToDefaultLocale();\n    this.controlPaneRef.validate();\n    this.props.onPersist({ createNew, duplicate });\n  };\n\n  handleOnPublish = async (opts = {}) => {\n    const { createNew = false, duplicate = false } = opts;\n    await this.controlPaneRef.switchToDefaultLocale();\n    this.controlPaneRef.validate();\n    this.props.onPublish({ createNew, duplicate });\n  };\n\n  handleTogglePreview = () => {\n    const newPreviewVisible = !this.state.previewVisible;\n    this.setState({ previewVisible: newPreviewVisible });\n    localStorage.setItem(PREVIEW_VISIBLE, newPreviewVisible);\n  };\n\n  handleToggleScrollSync = () => {\n    const newScrollSyncEnabled = !this.state.scrollSyncEnabled;\n    this.setState({ scrollSyncEnabled: newScrollSyncEnabled });\n    localStorage.setItem(SCROLL_SYNC_ENABLED, newScrollSyncEnabled);\n  };\n\n  handleToggleI18n = () => {\n    const newI18nVisible = !this.state.i18nVisible;\n    this.setState({ i18nVisible: newI18nVisible });\n    localStorage.setItem(I18N_VISIBLE, newI18nVisible);\n  };\n\n  handleLeftPanelLocaleChange = locale => {\n    this.setState({ leftPanelLocale: locale });\n  };\n\n  render() {\n    const {\n      collection,\n      entry,\n      fields,\n      fieldsMetaData,\n      fieldsErrors,\n      onChange,\n      showDelete,\n      onDelete,\n      onDeleteUnpublishedChanges,\n      onChangeStatus,\n      onPublish,\n      unPublish,\n      onDuplicate,\n      onValidate,\n      user,\n      hasChanged,\n      displayUrl,\n      hasWorkflow,\n      useOpenAuthoring,\n      hasUnpublishedChanges,\n      isNewEntry,\n      isModification,\n      currentStatus,\n      onLogoutClick,\n      loadDeployPreview,\n      deployPreview,\n      draftKey,\n      editorBackLink,\n      t,\n    } = this.props;\n\n    const { scrollSyncEnabled, showEventBlocker } = this.state;\n\n    const previewEnabled = isPreviewEnabled(collection, entry);\n\n    const { locales, defaultLocale } = getI18nInfo(this.props.collection);\n    const collectionI18nEnabled = hasI18n(collection) && locales.length > 1;\n    const editorProps = {\n      collection,\n      entry,\n      fields,\n      fieldsMetaData,\n      fieldsErrors,\n      onChange,\n      onValidate,\n    };\n\n    const leftPanelLocale = this.state.leftPanelLocale || locales?.[0];\n    const editor = (\n      <ControlPaneContainer overFlow blockEntry={showEventBlocker}>\n        <EditorControlPane\n          {...editorProps}\n          ref={c => (this.controlPaneRef = c)}\n          locale={leftPanelLocale}\n          t={t}\n          onLocaleChange={this.handleLeftPanelLocaleChange}\n        />\n      </ControlPaneContainer>\n    );\n\n    const editor2 = (\n      <ControlPaneContainer overFlow={!this.state.scrollSyncEnabled} blockEntry={showEventBlocker}>\n        <EditorControlPane {...editorProps} locale={locales?.[1]} t={t} />\n      </ControlPaneContainer>\n    );\n\n    const previewEntry = collectionI18nEnabled\n      ? getPreviewEntry(entry, leftPanelLocale, defaultLocale)\n      : entry;\n\n    const editorWithPreview = (\n      <ScrollSync enabled={this.state.scrollSyncEnabled}>\n        <div>\n          <ReactSplitPaneGlobalStyles />\n          <StyledSplitPane\n            maxSize={-100}\n            minSize={400}\n            defaultSize={parseInt(localStorage.getItem(SPLIT_PANE_POSITION), 10) || '50%'}\n            onChange={size => localStorage.setItem(SPLIT_PANE_POSITION, size)}\n            onDragStarted={this.handleSplitPaneDragStart}\n            onDragFinished={this.handleSplitPaneDragFinished}\n          >\n            <ScrollSyncPane>{editor}</ScrollSyncPane>\n            <PreviewPaneContainer blockEntry={showEventBlocker}>\n              <EditorPreviewPane\n                collection={collection}\n                entry={previewEntry}\n                fields={fields}\n                fieldsMetaData={fieldsMetaData}\n                locale={leftPanelLocale}\n              />\n            </PreviewPaneContainer>\n          </StyledSplitPane>\n        </div>\n      </ScrollSync>\n    );\n\n    const editorWithEditor = (\n      <ScrollSync enabled={this.state.scrollSyncEnabled}>\n        <div>\n          <StyledSplitPane\n            maxSize={-100}\n            defaultSize={parseInt(localStorage.getItem(SPLIT_PANE_POSITION), 10) || '50%'}\n            onChange={size => localStorage.setItem(SPLIT_PANE_POSITION, size)}\n            onDragStarted={this.handleSplitPaneDragStart}\n            onDragFinished={this.handleSplitPaneDragFinished}\n          >\n            <ScrollSyncPane>{editor}</ScrollSyncPane>\n            <ScrollSyncPane>{editor2}</ScrollSyncPane>\n          </StyledSplitPane>\n        </div>\n      </ScrollSync>\n    );\n\n    const i18nVisible = collectionI18nEnabled && this.state.i18nVisible;\n    const previewVisible = previewEnabled && this.state.previewVisible;\n    const scrollSyncVisible = i18nVisible || previewVisible;\n\n    return (\n      <EditorContainer>\n        <EditorToolbar\n          isPersisting={entry.get('isPersisting')}\n          isPublishing={entry.get('isPublishing')}\n          isUpdatingStatus={entry.get('isUpdatingStatus')}\n          isDeleting={entry.get('isDeleting')}\n          onPersist={this.handleOnPersist}\n          onPersistAndNew={() => this.handleOnPersist({ createNew: true })}\n          onPersistAndDuplicate={() => this.handleOnPersist({ createNew: true, duplicate: true })}\n          onDelete={onDelete}\n          onDeleteUnpublishedChanges={onDeleteUnpublishedChanges}\n          onChangeStatus={onChangeStatus}\n          showDelete={showDelete}\n          onPublish={onPublish}\n          unPublish={unPublish}\n          onDuplicate={onDuplicate}\n          onPublishAndNew={() => this.handleOnPublish({ createNew: true })}\n          onPublishAndDuplicate={() => this.handleOnPublish({ createNew: true, duplicate: true })}\n          user={user}\n          hasChanged={hasChanged}\n          displayUrl={displayUrl}\n          collection={collection}\n          hasWorkflow={hasWorkflow}\n          useOpenAuthoring={useOpenAuthoring}\n          hasUnpublishedChanges={hasUnpublishedChanges}\n          isNewEntry={isNewEntry}\n          isModification={isModification}\n          currentStatus={currentStatus}\n          onLogoutClick={onLogoutClick}\n          loadDeployPreview={loadDeployPreview}\n          deployPreview={deployPreview}\n          editorBackLink={editorBackLink}\n        />\n        <Editor key={draftKey}>\n          <ViewControls>\n            {collectionI18nEnabled && (\n              <EditorToggle\n                isActive={i18nVisible}\n                onClick={this.handleToggleI18n}\n                size=\"large\"\n                type=\"page\"\n                title={t('editor.editorInterface.toggleI18n')}\n                marginTop=\"70px\"\n              />\n            )}\n            {previewEnabled && (\n              <EditorToggle\n                isActive={previewVisible}\n                onClick={this.handleTogglePreview}\n                size=\"large\"\n                type=\"eye\"\n                title={t('editor.editorInterface.togglePreview')}\n              />\n            )}\n            {scrollSyncVisible && (\n              <EditorToggle\n                isActive={scrollSyncEnabled}\n                onClick={this.handleToggleScrollSync}\n                size=\"large\"\n                type=\"scroll\"\n                title={t('editor.editorInterface.toggleScrollSync')}\n              />\n            )}\n          </ViewControls>\n          <EditorContent\n            i18nVisible={i18nVisible}\n            previewVisible={previewVisible}\n            editor={editor}\n            editorWithEditor={editorWithEditor}\n            editorWithPreview={editorWithPreview}\n          />\n        </Editor>\n      </EditorContainer>\n    );\n  }\n}\n\nEditorInterface.propTypes = {\n  collection: ImmutablePropTypes.map.isRequired,\n  entry: ImmutablePropTypes.map.isRequired,\n  fields: ImmutablePropTypes.list.isRequired,\n  fieldsMetaData: ImmutablePropTypes.map.isRequired,\n  fieldsErrors: ImmutablePropTypes.map.isRequired,\n  onChange: PropTypes.func.isRequired,\n  onValidate: PropTypes.func.isRequired,\n  onPersist: PropTypes.func.isRequired,\n  showDelete: PropTypes.bool.isRequired,\n  onDelete: PropTypes.func.isRequired,\n  onDeleteUnpublishedChanges: PropTypes.func.isRequired,\n  onPublish: PropTypes.func.isRequired,\n  unPublish: PropTypes.func.isRequired,\n  onDuplicate: PropTypes.func.isRequired,\n  onChangeStatus: PropTypes.func.isRequired,\n  user: PropTypes.object,\n  hasChanged: PropTypes.bool,\n  displayUrl: PropTypes.string,\n  hasWorkflow: PropTypes.bool,\n  useOpenAuthoring: PropTypes.bool,\n  hasUnpublishedChanges: PropTypes.bool,\n  isNewEntry: PropTypes.bool,\n  isModification: PropTypes.bool,\n  currentStatus: PropTypes.string,\n  onLogoutClick: PropTypes.func.isRequired,\n  deployPreview: PropTypes.object,\n  loadDeployPreview: PropTypes.func.isRequired,\n  draftKey: PropTypes.string.isRequired,\n  t: PropTypes.func.isRequired,\n};\n\nexport default EditorInterface;\n"]} */",
|
|
91
|
+
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/Editor/EditorInterface.js"],"names":[],"mappings":"AAsHyD","file":"../../../../src/components/Editor/EditorInterface.js","sourcesContent":["import PropTypes from 'prop-types';\nimport React, { Component } from 'react';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\nimport { css, Global } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport SplitPane from 'react-split-pane';\nimport {\n  colors,\n  colorsRaw,\n  components,\n  transitions,\n  IconButton,\n  zIndex,\n} from 'decap-cms-ui-default';\nimport { ScrollSync, ScrollSyncPane } from 'react-scroll-sync';\n\nimport EditorControlPane from './EditorControlPane/EditorControlPane';\nimport EditorPreviewPane from './EditorPreviewPane/EditorPreviewPane';\nimport EditorToolbar from './EditorToolbar';\nimport { hasI18n, getI18nInfo, getPreviewEntry } from '../../lib/i18n';\nimport { FILES } from '../../constants/collectionTypes';\nimport { getFileFromSlug } from '../../reducers/collections';\n\nconst PREVIEW_VISIBLE = 'cms.preview-visible';\nconst SCROLL_SYNC_ENABLED = 'cms.scroll-sync-enabled';\nconst SPLIT_PANE_POSITION = 'cms.split-pane-position';\nconst I18N_VISIBLE = 'cms.i18n-visible';\n\nconst styles = {\n  splitPane: css`\n    ${components.card};\n    border-radius: 0;\n    height: 100%;\n  `,\n  pane: css`\n    height: 100%;\n    overflow-y: auto;\n  `,\n};\n\nconst EditorToggle = styled(IconButton)`\n  margin-bottom: 12px;\n`;\n\nfunction ReactSplitPaneGlobalStyles() {\n  return (\n    <Global\n      styles={css`\n        .Resizer.vertical {\n          width: 2px;\n          cursor: col-resize;\n          position: relative;\n          background: none;\n\n          &:before {\n            content: '';\n            width: 2px;\n            height: 100%;\n            position: relative;\n            background-color: ${colors.textFieldBorder};\n            display: block;\n            z-index: 10;\n            transition: background-color ${transitions.main};\n          }\n\n          &:hover,\n          &:active {\n            &:before {\n              width: 4px;\n              left: -1px;\n              background-color: ${colorsRaw.blue};\n            }\n          }\n        }\n      `}\n    />\n  );\n}\n\nconst StyledSplitPane = styled(SplitPane)`\n  ${styles.splitPane};\n\n  /**\n   * Quick fix for preview pane not fully displaying in Safari\n   */\n  .Pane {\n    height: 100%;\n  }\n`;\n\nconst NoPreviewContainer = styled.div`\n  ${styles.splitPane};\n`;\n\nconst EditorContainer = styled.div`\n  width: 100%;\n  min-width: 800px;\n  height: 100%;\n  position: absolute;\n  top: 0;\n  left: 0;\n  overflow: hidden;\n  padding-top: 66px;\n  background-color: ${colors.background};\n`;\n\nconst Editor = styled.div`\n  height: 100%;\n  margin: 0 auto;\n  position: relative;\n`;\n\nconst PreviewPaneContainer = styled.div`\n  height: 100%;\n  pointer-events: ${props => (props.blockEntry ? 'none' : 'auto')};\n  overflow-y: ${props => (props.overFlow ? 'auto' : 'hidden')};\n`;\n\nconst ControlPaneContainer = styled(PreviewPaneContainer)`\n  padding: 0 16px;\n  position: relative;\n  overflow-x: hidden;\n`;\n\nconst ViewControls = styled.div`\n  position: absolute;\n  top: 10px;\n  right: 10px;\n  z-index: ${zIndex.zIndex299};\n`;\n\nfunction EditorContent({\n  i18nVisible,\n  previewVisible,\n  editor,\n  editorWithEditor,\n  editorWithPreview,\n}) {\n  if (i18nVisible) {\n    return editorWithEditor;\n  } else if (previewVisible) {\n    return editorWithPreview;\n  } else {\n    return <NoPreviewContainer>{editor}</NoPreviewContainer>;\n  }\n}\n\nfunction isPreviewEnabled(collection, entry) {\n  if (collection.get('type') === FILES) {\n    const file = getFileFromSlug(collection, entry.get('slug'));\n    const previewEnabled = file?.getIn(['editor', 'preview']);\n    if (previewEnabled != null) return previewEnabled;\n  }\n  return collection.getIn(['editor', 'preview'], true);\n}\n\nclass EditorInterface extends Component {\n  state = {\n    showEventBlocker: false,\n    previewVisible: localStorage.getItem(PREVIEW_VISIBLE) !== 'false',\n    scrollSyncEnabled: localStorage.getItem(SCROLL_SYNC_ENABLED) !== 'false',\n    i18nVisible: localStorage.getItem(I18N_VISIBLE) !== 'false',\n  };\n\n  handleFieldClick = path => {\n    this.controlPaneRef?.focus(path);\n  };\n\n  handleSplitPaneDragStart = () => {\n    this.setState({ showEventBlocker: true });\n  };\n\n  handleSplitPaneDragFinished = () => {\n    this.setState({ showEventBlocker: false });\n  };\n\n  handleOnPersist = async (opts = {}) => {\n    const { createNew = false, duplicate = false } = opts;\n    await this.controlPaneRef.switchToDefaultLocale();\n    this.controlPaneRef.validate();\n    this.props.onPersist({ createNew, duplicate });\n  };\n\n  handleOnPublish = async (opts = {}) => {\n    const { createNew = false, duplicate = false } = opts;\n    await this.controlPaneRef.switchToDefaultLocale();\n    this.controlPaneRef.validate();\n    this.props.onPublish({ createNew, duplicate });\n  };\n\n  handleTogglePreview = () => {\n    const newPreviewVisible = !this.state.previewVisible;\n    this.setState({ previewVisible: newPreviewVisible });\n    localStorage.setItem(PREVIEW_VISIBLE, newPreviewVisible);\n  };\n\n  handleToggleScrollSync = () => {\n    const newScrollSyncEnabled = !this.state.scrollSyncEnabled;\n    this.setState({ scrollSyncEnabled: newScrollSyncEnabled });\n    localStorage.setItem(SCROLL_SYNC_ENABLED, newScrollSyncEnabled);\n  };\n\n  handleToggleI18n = () => {\n    const newI18nVisible = !this.state.i18nVisible;\n    this.setState({ i18nVisible: newI18nVisible });\n    localStorage.setItem(I18N_VISIBLE, newI18nVisible);\n  };\n\n  handleLeftPanelLocaleChange = locale => {\n    this.setState({ leftPanelLocale: locale });\n  };\n\n  render() {\n    const {\n      collection,\n      entry,\n      fields,\n      fieldsMetaData,\n      fieldsErrors,\n      onChange,\n      showDelete,\n      onDelete,\n      onDeleteUnpublishedChanges,\n      onChangeStatus,\n      onPublish,\n      unPublish,\n      onDuplicate,\n      onValidate,\n      user,\n      hasChanged,\n      displayUrl,\n      hasWorkflow,\n      useOpenAuthoring,\n      hasUnpublishedChanges,\n      isNewEntry,\n      isModification,\n      currentStatus,\n      onLogoutClick,\n      loadDeployPreview,\n      deployPreview,\n      draftKey,\n      editorBackLink,\n      t,\n    } = this.props;\n\n    const { scrollSyncEnabled, showEventBlocker } = this.state;\n\n    const previewEnabled = isPreviewEnabled(collection, entry);\n\n    const { locales, defaultLocale } = getI18nInfo(this.props.collection);\n    const collectionI18nEnabled = hasI18n(collection) && locales.length > 1;\n    const editorProps = {\n      collection,\n      entry,\n      fields,\n      fieldsMetaData,\n      fieldsErrors,\n      onChange,\n      onValidate,\n    };\n\n    const leftPanelLocale = this.state.leftPanelLocale || locales?.[0];\n    const editor = (\n      <ControlPaneContainer overFlow blockEntry={showEventBlocker}>\n        <EditorControlPane\n          {...editorProps}\n          ref={c => (this.controlPaneRef = c)}\n          locale={leftPanelLocale}\n          t={t}\n          onLocaleChange={this.handleLeftPanelLocaleChange}\n        />\n      </ControlPaneContainer>\n    );\n\n    const editor2 = (\n      <ControlPaneContainer overFlow={!this.state.scrollSyncEnabled} blockEntry={showEventBlocker}>\n        <EditorControlPane {...editorProps} locale={locales?.[1]} t={t} />\n      </ControlPaneContainer>\n    );\n\n    const previewEntry = collectionI18nEnabled\n      ? getPreviewEntry(entry, leftPanelLocale, defaultLocale)\n      : entry;\n\n    const editorWithPreview = (\n      <ScrollSync enabled={this.state.scrollSyncEnabled}>\n        <div>\n          <ReactSplitPaneGlobalStyles />\n          <StyledSplitPane\n            maxSize={-100}\n            minSize={400}\n            defaultSize={parseInt(localStorage.getItem(SPLIT_PANE_POSITION), 10) || '50%'}\n            onChange={size => localStorage.setItem(SPLIT_PANE_POSITION, size)}\n            onDragStarted={this.handleSplitPaneDragStart}\n            onDragFinished={this.handleSplitPaneDragFinished}\n          >\n            <ScrollSyncPane>{editor}</ScrollSyncPane>\n            <PreviewPaneContainer blockEntry={showEventBlocker}>\n              <EditorPreviewPane\n                collection={collection}\n                entry={previewEntry}\n                fields={fields}\n                fieldsMetaData={fieldsMetaData}\n                locale={leftPanelLocale}\n                onFieldClick={this.handleFieldClick}\n              />\n            </PreviewPaneContainer>\n          </StyledSplitPane>\n        </div>\n      </ScrollSync>\n    );\n\n    const editorWithEditor = (\n      <ScrollSync enabled={this.state.scrollSyncEnabled}>\n        <div>\n          <StyledSplitPane\n            maxSize={-100}\n            defaultSize={parseInt(localStorage.getItem(SPLIT_PANE_POSITION), 10) || '50%'}\n            onChange={size => localStorage.setItem(SPLIT_PANE_POSITION, size)}\n            onDragStarted={this.handleSplitPaneDragStart}\n            onDragFinished={this.handleSplitPaneDragFinished}\n          >\n            <ScrollSyncPane>{editor}</ScrollSyncPane>\n            <ScrollSyncPane>{editor2}</ScrollSyncPane>\n          </StyledSplitPane>\n        </div>\n      </ScrollSync>\n    );\n\n    const i18nVisible = collectionI18nEnabled && this.state.i18nVisible;\n    const previewVisible = previewEnabled && this.state.previewVisible;\n    const scrollSyncVisible = i18nVisible || previewVisible;\n\n    return (\n      <EditorContainer>\n        <EditorToolbar\n          isPersisting={entry.get('isPersisting')}\n          isPublishing={entry.get('isPublishing')}\n          isUpdatingStatus={entry.get('isUpdatingStatus')}\n          isDeleting={entry.get('isDeleting')}\n          onPersist={this.handleOnPersist}\n          onPersistAndNew={() => this.handleOnPersist({ createNew: true })}\n          onPersistAndDuplicate={() => this.handleOnPersist({ createNew: true, duplicate: true })}\n          onDelete={onDelete}\n          onDeleteUnpublishedChanges={onDeleteUnpublishedChanges}\n          onChangeStatus={onChangeStatus}\n          showDelete={showDelete}\n          onPublish={onPublish}\n          unPublish={unPublish}\n          onDuplicate={onDuplicate}\n          onPublishAndNew={() => this.handleOnPublish({ createNew: true })}\n          onPublishAndDuplicate={() => this.handleOnPublish({ createNew: true, duplicate: true })}\n          user={user}\n          hasChanged={hasChanged}\n          displayUrl={displayUrl}\n          collection={collection}\n          hasWorkflow={hasWorkflow}\n          useOpenAuthoring={useOpenAuthoring}\n          hasUnpublishedChanges={hasUnpublishedChanges}\n          isNewEntry={isNewEntry}\n          isModification={isModification}\n          currentStatus={currentStatus}\n          onLogoutClick={onLogoutClick}\n          loadDeployPreview={loadDeployPreview}\n          deployPreview={deployPreview}\n          editorBackLink={editorBackLink}\n        />\n        <Editor key={draftKey}>\n          <ViewControls>\n            {collectionI18nEnabled && (\n              <EditorToggle\n                isActive={i18nVisible}\n                onClick={this.handleToggleI18n}\n                size=\"large\"\n                type=\"page\"\n                title={t('editor.editorInterface.toggleI18n')}\n                marginTop=\"70px\"\n              />\n            )}\n            {previewEnabled && (\n              <EditorToggle\n                isActive={previewVisible}\n                onClick={this.handleTogglePreview}\n                size=\"large\"\n                type=\"eye\"\n                title={t('editor.editorInterface.togglePreview')}\n              />\n            )}\n            {scrollSyncVisible && !collection.getIn(['editor', 'visualEditing']) && (\n              <EditorToggle\n                isActive={scrollSyncEnabled}\n                onClick={this.handleToggleScrollSync}\n                size=\"large\"\n                type=\"scroll\"\n                title={t('editor.editorInterface.toggleScrollSync')}\n              />\n            )}\n          </ViewControls>\n          <EditorContent\n            i18nVisible={i18nVisible}\n            previewVisible={previewVisible}\n            editor={editor}\n            editorWithEditor={editorWithEditor}\n            editorWithPreview={editorWithPreview}\n          />\n        </Editor>\n      </EditorContainer>\n    );\n  }\n}\n\nEditorInterface.propTypes = {\n  collection: ImmutablePropTypes.map.isRequired,\n  entry: ImmutablePropTypes.map.isRequired,\n  fields: ImmutablePropTypes.list.isRequired,\n  fieldsMetaData: ImmutablePropTypes.map.isRequired,\n  fieldsErrors: ImmutablePropTypes.map.isRequired,\n  onChange: PropTypes.func.isRequired,\n  onValidate: PropTypes.func.isRequired,\n  onPersist: PropTypes.func.isRequired,\n  showDelete: PropTypes.bool.isRequired,\n  onDelete: PropTypes.func.isRequired,\n  onDeleteUnpublishedChanges: PropTypes.func.isRequired,\n  onPublish: PropTypes.func.isRequired,\n  unPublish: PropTypes.func.isRequired,\n  onDuplicate: PropTypes.func.isRequired,\n  onChangeStatus: PropTypes.func.isRequired,\n  user: PropTypes.object,\n  hasChanged: PropTypes.bool,\n  displayUrl: PropTypes.string,\n  hasWorkflow: PropTypes.bool,\n  useOpenAuthoring: PropTypes.bool,\n  hasUnpublishedChanges: PropTypes.bool,\n  isNewEntry: PropTypes.bool,\n  isModification: PropTypes.bool,\n  currentStatus: PropTypes.string,\n  onLogoutClick: PropTypes.func.isRequired,\n  deployPreview: PropTypes.object,\n  loadDeployPreview: PropTypes.func.isRequired,\n  draftKey: PropTypes.string.isRequired,\n  t: PropTypes.func.isRequired,\n};\n\nexport default EditorInterface;\n"]} */",
|
|
100
92
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__
|
|
101
93
|
});
|
|
102
|
-
const ViewControls = /*#__PURE__*/(
|
|
94
|
+
const ViewControls = /*#__PURE__*/_styled("div", {
|
|
103
95
|
target: "e1nx103k0",
|
|
104
96
|
label: "ViewControls"
|
|
105
|
-
})("position:absolute;top:10px;right:10px;z-index:", _decapCmsUiDefault.zIndex.zIndex299, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/Editor/EditorInterface.js"],"names":[],"mappings":"AA4H+B","file":"../../../../src/components/Editor/EditorInterface.js","sourcesContent":["import PropTypes from 'prop-types';\nimport React, { Component } from 'react';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\nimport { css, Global } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport SplitPane from 'react-split-pane';\nimport {\n  colors,\n  colorsRaw,\n  components,\n  transitions,\n  IconButton,\n  zIndex,\n} from 'decap-cms-ui-default';\nimport { ScrollSync, ScrollSyncPane } from 'react-scroll-sync';\n\nimport EditorControlPane from './EditorControlPane/EditorControlPane';\nimport EditorPreviewPane from './EditorPreviewPane/EditorPreviewPane';\nimport EditorToolbar from './EditorToolbar';\nimport { hasI18n, getI18nInfo, getPreviewEntry } from '../../lib/i18n';\nimport { FILES } from '../../constants/collectionTypes';\nimport { getFileFromSlug } from '../../reducers/collections';\n\nconst PREVIEW_VISIBLE = 'cms.preview-visible';\nconst SCROLL_SYNC_ENABLED = 'cms.scroll-sync-enabled';\nconst SPLIT_PANE_POSITION = 'cms.split-pane-position';\nconst I18N_VISIBLE = 'cms.i18n-visible';\n\nconst styles = {\n  splitPane: css`\n    ${components.card};\n    border-radius: 0;\n    height: 100%;\n  `,\n  pane: css`\n    height: 100%;\n    overflow-y: auto;\n  `,\n};\n\nconst EditorToggle = styled(IconButton)`\n  margin-bottom: 12px;\n`;\n\nfunction ReactSplitPaneGlobalStyles() {\n  return (\n    <Global\n      styles={css`\n        .Resizer.vertical {\n          width: 2px;\n          cursor: col-resize;\n          position: relative;\n          background: none;\n\n          &:before {\n            content: '';\n            width: 2px;\n            height: 100%;\n            position: relative;\n            background-color: ${colors.textFieldBorder};\n            display: block;\n            z-index: 10;\n            transition: background-color ${transitions.main};\n          }\n\n          &:hover,\n          &:active {\n            &:before {\n              width: 4px;\n              left: -1px;\n              background-color: ${colorsRaw.blue};\n            }\n          }\n        }\n      `}\n    />\n  );\n}\n\nconst StyledSplitPane = styled(SplitPane)`\n  ${styles.splitPane};\n\n  /**\n   * Quick fix for preview pane not fully displaying in Safari\n   */\n  .Pane {\n    height: 100%;\n  }\n`;\n\nconst NoPreviewContainer = styled.div`\n  ${styles.splitPane};\n`;\n\nconst EditorContainer = styled.div`\n  width: 100%;\n  min-width: 800px;\n  height: 100%;\n  position: absolute;\n  top: 0;\n  left: 0;\n  overflow: hidden;\n  padding-top: 66px;\n  background-color: ${colors.background};\n`;\n\nconst Editor = styled.div`\n  height: 100%;\n  margin: 0 auto;\n  position: relative;\n`;\n\nconst PreviewPaneContainer = styled.div`\n  height: 100%;\n  pointer-events: ${props => (props.blockEntry ? 'none' : 'auto')};\n  overflow-y: ${props => (props.overFlow ? 'auto' : 'hidden')};\n`;\n\nconst ControlPaneContainer = styled(PreviewPaneContainer)`\n  padding: 0 16px;\n  position: relative;\n  overflow-x: hidden;\n`;\n\nconst ViewControls = styled.div`\n  position: absolute;\n  top: 10px;\n  right: 10px;\n  z-index: ${zIndex.zIndex299};\n`;\n\nfunction EditorContent({\n  i18nVisible,\n  previewVisible,\n  editor,\n  editorWithEditor,\n  editorWithPreview,\n}) {\n  if (i18nVisible) {\n    return editorWithEditor;\n  } else if (previewVisible) {\n    return editorWithPreview;\n  } else {\n    return <NoPreviewContainer>{editor}</NoPreviewContainer>;\n  }\n}\n\nfunction isPreviewEnabled(collection, entry) {\n  if (collection.get('type') === FILES) {\n    const file = getFileFromSlug(collection, entry.get('slug'));\n    const previewEnabled = file?.getIn(['editor', 'preview']);\n    if (previewEnabled != null) return previewEnabled;\n  }\n  return collection.getIn(['editor', 'preview'], true);\n}\n\nclass EditorInterface extends Component {\n  state = {\n    showEventBlocker: false,\n    previewVisible: localStorage.getItem(PREVIEW_VISIBLE) !== 'false',\n    scrollSyncEnabled: localStorage.getItem(SCROLL_SYNC_ENABLED) !== 'false',\n    i18nVisible: localStorage.getItem(I18N_VISIBLE) !== 'false',\n  };\n\n  handleSplitPaneDragStart = () => {\n    this.setState({ showEventBlocker: true });\n  };\n\n  handleSplitPaneDragFinished = () => {\n    this.setState({ showEventBlocker: false });\n  };\n\n  handleOnPersist = async (opts = {}) => {\n    const { createNew = false, duplicate = false } = opts;\n    await this.controlPaneRef.switchToDefaultLocale();\n    this.controlPaneRef.validate();\n    this.props.onPersist({ createNew, duplicate });\n  };\n\n  handleOnPublish = async (opts = {}) => {\n    const { createNew = false, duplicate = false } = opts;\n    await this.controlPaneRef.switchToDefaultLocale();\n    this.controlPaneRef.validate();\n    this.props.onPublish({ createNew, duplicate });\n  };\n\n  handleTogglePreview = () => {\n    const newPreviewVisible = !this.state.previewVisible;\n    this.setState({ previewVisible: newPreviewVisible });\n    localStorage.setItem(PREVIEW_VISIBLE, newPreviewVisible);\n  };\n\n  handleToggleScrollSync = () => {\n    const newScrollSyncEnabled = !this.state.scrollSyncEnabled;\n    this.setState({ scrollSyncEnabled: newScrollSyncEnabled });\n    localStorage.setItem(SCROLL_SYNC_ENABLED, newScrollSyncEnabled);\n  };\n\n  handleToggleI18n = () => {\n    const newI18nVisible = !this.state.i18nVisible;\n    this.setState({ i18nVisible: newI18nVisible });\n    localStorage.setItem(I18N_VISIBLE, newI18nVisible);\n  };\n\n  handleLeftPanelLocaleChange = locale => {\n    this.setState({ leftPanelLocale: locale });\n  };\n\n  render() {\n    const {\n      collection,\n      entry,\n      fields,\n      fieldsMetaData,\n      fieldsErrors,\n      onChange,\n      showDelete,\n      onDelete,\n      onDeleteUnpublishedChanges,\n      onChangeStatus,\n      onPublish,\n      unPublish,\n      onDuplicate,\n      onValidate,\n      user,\n      hasChanged,\n      displayUrl,\n      hasWorkflow,\n      useOpenAuthoring,\n      hasUnpublishedChanges,\n      isNewEntry,\n      isModification,\n      currentStatus,\n      onLogoutClick,\n      loadDeployPreview,\n      deployPreview,\n      draftKey,\n      editorBackLink,\n      t,\n    } = this.props;\n\n    const { scrollSyncEnabled, showEventBlocker } = this.state;\n\n    const previewEnabled = isPreviewEnabled(collection, entry);\n\n    const { locales, defaultLocale } = getI18nInfo(this.props.collection);\n    const collectionI18nEnabled = hasI18n(collection) && locales.length > 1;\n    const editorProps = {\n      collection,\n      entry,\n      fields,\n      fieldsMetaData,\n      fieldsErrors,\n      onChange,\n      onValidate,\n    };\n\n    const leftPanelLocale = this.state.leftPanelLocale || locales?.[0];\n    const editor = (\n      <ControlPaneContainer overFlow blockEntry={showEventBlocker}>\n        <EditorControlPane\n          {...editorProps}\n          ref={c => (this.controlPaneRef = c)}\n          locale={leftPanelLocale}\n          t={t}\n          onLocaleChange={this.handleLeftPanelLocaleChange}\n        />\n      </ControlPaneContainer>\n    );\n\n    const editor2 = (\n      <ControlPaneContainer overFlow={!this.state.scrollSyncEnabled} blockEntry={showEventBlocker}>\n        <EditorControlPane {...editorProps} locale={locales?.[1]} t={t} />\n      </ControlPaneContainer>\n    );\n\n    const previewEntry = collectionI18nEnabled\n      ? getPreviewEntry(entry, leftPanelLocale, defaultLocale)\n      : entry;\n\n    const editorWithPreview = (\n      <ScrollSync enabled={this.state.scrollSyncEnabled}>\n        <div>\n          <ReactSplitPaneGlobalStyles />\n          <StyledSplitPane\n            maxSize={-100}\n            minSize={400}\n            defaultSize={parseInt(localStorage.getItem(SPLIT_PANE_POSITION), 10) || '50%'}\n            onChange={size => localStorage.setItem(SPLIT_PANE_POSITION, size)}\n            onDragStarted={this.handleSplitPaneDragStart}\n            onDragFinished={this.handleSplitPaneDragFinished}\n          >\n            <ScrollSyncPane>{editor}</ScrollSyncPane>\n            <PreviewPaneContainer blockEntry={showEventBlocker}>\n              <EditorPreviewPane\n                collection={collection}\n                entry={previewEntry}\n                fields={fields}\n                fieldsMetaData={fieldsMetaData}\n                locale={leftPanelLocale}\n              />\n            </PreviewPaneContainer>\n          </StyledSplitPane>\n        </div>\n      </ScrollSync>\n    );\n\n    const editorWithEditor = (\n      <ScrollSync enabled={this.state.scrollSyncEnabled}>\n        <div>\n          <StyledSplitPane\n            maxSize={-100}\n            defaultSize={parseInt(localStorage.getItem(SPLIT_PANE_POSITION), 10) || '50%'}\n            onChange={size => localStorage.setItem(SPLIT_PANE_POSITION, size)}\n            onDragStarted={this.handleSplitPaneDragStart}\n            onDragFinished={this.handleSplitPaneDragFinished}\n          >\n            <ScrollSyncPane>{editor}</ScrollSyncPane>\n            <ScrollSyncPane>{editor2}</ScrollSyncPane>\n          </StyledSplitPane>\n        </div>\n      </ScrollSync>\n    );\n\n    const i18nVisible = collectionI18nEnabled && this.state.i18nVisible;\n    const previewVisible = previewEnabled && this.state.previewVisible;\n    const scrollSyncVisible = i18nVisible || previewVisible;\n\n    return (\n      <EditorContainer>\n        <EditorToolbar\n          isPersisting={entry.get('isPersisting')}\n          isPublishing={entry.get('isPublishing')}\n          isUpdatingStatus={entry.get('isUpdatingStatus')}\n          isDeleting={entry.get('isDeleting')}\n          onPersist={this.handleOnPersist}\n          onPersistAndNew={() => this.handleOnPersist({ createNew: true })}\n          onPersistAndDuplicate={() => this.handleOnPersist({ createNew: true, duplicate: true })}\n          onDelete={onDelete}\n          onDeleteUnpublishedChanges={onDeleteUnpublishedChanges}\n          onChangeStatus={onChangeStatus}\n          showDelete={showDelete}\n          onPublish={onPublish}\n          unPublish={unPublish}\n          onDuplicate={onDuplicate}\n          onPublishAndNew={() => this.handleOnPublish({ createNew: true })}\n          onPublishAndDuplicate={() => this.handleOnPublish({ createNew: true, duplicate: true })}\n          user={user}\n          hasChanged={hasChanged}\n          displayUrl={displayUrl}\n          collection={collection}\n          hasWorkflow={hasWorkflow}\n          useOpenAuthoring={useOpenAuthoring}\n          hasUnpublishedChanges={hasUnpublishedChanges}\n          isNewEntry={isNewEntry}\n          isModification={isModification}\n          currentStatus={currentStatus}\n          onLogoutClick={onLogoutClick}\n          loadDeployPreview={loadDeployPreview}\n          deployPreview={deployPreview}\n          editorBackLink={editorBackLink}\n        />\n        <Editor key={draftKey}>\n          <ViewControls>\n            {collectionI18nEnabled && (\n              <EditorToggle\n                isActive={i18nVisible}\n                onClick={this.handleToggleI18n}\n                size=\"large\"\n                type=\"page\"\n                title={t('editor.editorInterface.toggleI18n')}\n                marginTop=\"70px\"\n              />\n            )}\n            {previewEnabled && (\n              <EditorToggle\n                isActive={previewVisible}\n                onClick={this.handleTogglePreview}\n                size=\"large\"\n                type=\"eye\"\n                title={t('editor.editorInterface.togglePreview')}\n              />\n            )}\n            {scrollSyncVisible && (\n              <EditorToggle\n                isActive={scrollSyncEnabled}\n                onClick={this.handleToggleScrollSync}\n                size=\"large\"\n                type=\"scroll\"\n                title={t('editor.editorInterface.toggleScrollSync')}\n              />\n            )}\n          </ViewControls>\n          <EditorContent\n            i18nVisible={i18nVisible}\n            previewVisible={previewVisible}\n            editor={editor}\n            editorWithEditor={editorWithEditor}\n            editorWithPreview={editorWithPreview}\n          />\n        </Editor>\n      </EditorContainer>\n    );\n  }\n}\n\nEditorInterface.propTypes = {\n  collection: ImmutablePropTypes.map.isRequired,\n  entry: ImmutablePropTypes.map.isRequired,\n  fields: ImmutablePropTypes.list.isRequired,\n  fieldsMetaData: ImmutablePropTypes.map.isRequired,\n  fieldsErrors: ImmutablePropTypes.map.isRequired,\n  onChange: PropTypes.func.isRequired,\n  onValidate: PropTypes.func.isRequired,\n  onPersist: PropTypes.func.isRequired,\n  showDelete: PropTypes.bool.isRequired,\n  onDelete: PropTypes.func.isRequired,\n  onDeleteUnpublishedChanges: PropTypes.func.isRequired,\n  onPublish: PropTypes.func.isRequired,\n  unPublish: PropTypes.func.isRequired,\n  onDuplicate: PropTypes.func.isRequired,\n  onChangeStatus: PropTypes.func.isRequired,\n  user: PropTypes.object,\n  hasChanged: PropTypes.bool,\n  displayUrl: PropTypes.string,\n  hasWorkflow: PropTypes.bool,\n  useOpenAuthoring: PropTypes.bool,\n  hasUnpublishedChanges: PropTypes.bool,\n  isNewEntry: PropTypes.bool,\n  isModification: PropTypes.bool,\n  currentStatus: PropTypes.string,\n  onLogoutClick: PropTypes.func.isRequired,\n  deployPreview: PropTypes.object,\n  loadDeployPreview: PropTypes.func.isRequired,\n  draftKey: PropTypes.string.isRequired,\n  t: PropTypes.func.isRequired,\n};\n\nexport default EditorInterface;\n"]} */"));
|
|
97
|
+
})("position:absolute;top:10px;right:10px;z-index:", zIndex.zIndex299, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/Editor/EditorInterface.js"],"names":[],"mappings":"AA4H+B","file":"../../../../src/components/Editor/EditorInterface.js","sourcesContent":["import PropTypes from 'prop-types';\nimport React, { Component } from 'react';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\nimport { css, Global } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport SplitPane from 'react-split-pane';\nimport {\n  colors,\n  colorsRaw,\n  components,\n  transitions,\n  IconButton,\n  zIndex,\n} from 'decap-cms-ui-default';\nimport { ScrollSync, ScrollSyncPane } from 'react-scroll-sync';\n\nimport EditorControlPane from './EditorControlPane/EditorControlPane';\nimport EditorPreviewPane from './EditorPreviewPane/EditorPreviewPane';\nimport EditorToolbar from './EditorToolbar';\nimport { hasI18n, getI18nInfo, getPreviewEntry } from '../../lib/i18n';\nimport { FILES } from '../../constants/collectionTypes';\nimport { getFileFromSlug } from '../../reducers/collections';\n\nconst PREVIEW_VISIBLE = 'cms.preview-visible';\nconst SCROLL_SYNC_ENABLED = 'cms.scroll-sync-enabled';\nconst SPLIT_PANE_POSITION = 'cms.split-pane-position';\nconst I18N_VISIBLE = 'cms.i18n-visible';\n\nconst styles = {\n  splitPane: css`\n    ${components.card};\n    border-radius: 0;\n    height: 100%;\n  `,\n  pane: css`\n    height: 100%;\n    overflow-y: auto;\n  `,\n};\n\nconst EditorToggle = styled(IconButton)`\n  margin-bottom: 12px;\n`;\n\nfunction ReactSplitPaneGlobalStyles() {\n  return (\n    <Global\n      styles={css`\n        .Resizer.vertical {\n          width: 2px;\n          cursor: col-resize;\n          position: relative;\n          background: none;\n\n          &:before {\n            content: '';\n            width: 2px;\n            height: 100%;\n            position: relative;\n            background-color: ${colors.textFieldBorder};\n            display: block;\n            z-index: 10;\n            transition: background-color ${transitions.main};\n          }\n\n          &:hover,\n          &:active {\n            &:before {\n              width: 4px;\n              left: -1px;\n              background-color: ${colorsRaw.blue};\n            }\n          }\n        }\n      `}\n    />\n  );\n}\n\nconst StyledSplitPane = styled(SplitPane)`\n  ${styles.splitPane};\n\n  /**\n   * Quick fix for preview pane not fully displaying in Safari\n   */\n  .Pane {\n    height: 100%;\n  }\n`;\n\nconst NoPreviewContainer = styled.div`\n  ${styles.splitPane};\n`;\n\nconst EditorContainer = styled.div`\n  width: 100%;\n  min-width: 800px;\n  height: 100%;\n  position: absolute;\n  top: 0;\n  left: 0;\n  overflow: hidden;\n  padding-top: 66px;\n  background-color: ${colors.background};\n`;\n\nconst Editor = styled.div`\n  height: 100%;\n  margin: 0 auto;\n  position: relative;\n`;\n\nconst PreviewPaneContainer = styled.div`\n  height: 100%;\n  pointer-events: ${props => (props.blockEntry ? 'none' : 'auto')};\n  overflow-y: ${props => (props.overFlow ? 'auto' : 'hidden')};\n`;\n\nconst ControlPaneContainer = styled(PreviewPaneContainer)`\n  padding: 0 16px;\n  position: relative;\n  overflow-x: hidden;\n`;\n\nconst ViewControls = styled.div`\n  position: absolute;\n  top: 10px;\n  right: 10px;\n  z-index: ${zIndex.zIndex299};\n`;\n\nfunction EditorContent({\n  i18nVisible,\n  previewVisible,\n  editor,\n  editorWithEditor,\n  editorWithPreview,\n}) {\n  if (i18nVisible) {\n    return editorWithEditor;\n  } else if (previewVisible) {\n    return editorWithPreview;\n  } else {\n    return <NoPreviewContainer>{editor}</NoPreviewContainer>;\n  }\n}\n\nfunction isPreviewEnabled(collection, entry) {\n  if (collection.get('type') === FILES) {\n    const file = getFileFromSlug(collection, entry.get('slug'));\n    const previewEnabled = file?.getIn(['editor', 'preview']);\n    if (previewEnabled != null) return previewEnabled;\n  }\n  return collection.getIn(['editor', 'preview'], true);\n}\n\nclass EditorInterface extends Component {\n  state = {\n    showEventBlocker: false,\n    previewVisible: localStorage.getItem(PREVIEW_VISIBLE) !== 'false',\n    scrollSyncEnabled: localStorage.getItem(SCROLL_SYNC_ENABLED) !== 'false',\n    i18nVisible: localStorage.getItem(I18N_VISIBLE) !== 'false',\n  };\n\n  handleFieldClick = path => {\n    this.controlPaneRef?.focus(path);\n  };\n\n  handleSplitPaneDragStart = () => {\n    this.setState({ showEventBlocker: true });\n  };\n\n  handleSplitPaneDragFinished = () => {\n    this.setState({ showEventBlocker: false });\n  };\n\n  handleOnPersist = async (opts = {}) => {\n    const { createNew = false, duplicate = false } = opts;\n    await this.controlPaneRef.switchToDefaultLocale();\n    this.controlPaneRef.validate();\n    this.props.onPersist({ createNew, duplicate });\n  };\n\n  handleOnPublish = async (opts = {}) => {\n    const { createNew = false, duplicate = false } = opts;\n    await this.controlPaneRef.switchToDefaultLocale();\n    this.controlPaneRef.validate();\n    this.props.onPublish({ createNew, duplicate });\n  };\n\n  handleTogglePreview = () => {\n    const newPreviewVisible = !this.state.previewVisible;\n    this.setState({ previewVisible: newPreviewVisible });\n    localStorage.setItem(PREVIEW_VISIBLE, newPreviewVisible);\n  };\n\n  handleToggleScrollSync = () => {\n    const newScrollSyncEnabled = !this.state.scrollSyncEnabled;\n    this.setState({ scrollSyncEnabled: newScrollSyncEnabled });\n    localStorage.setItem(SCROLL_SYNC_ENABLED, newScrollSyncEnabled);\n  };\n\n  handleToggleI18n = () => {\n    const newI18nVisible = !this.state.i18nVisible;\n    this.setState({ i18nVisible: newI18nVisible });\n    localStorage.setItem(I18N_VISIBLE, newI18nVisible);\n  };\n\n  handleLeftPanelLocaleChange = locale => {\n    this.setState({ leftPanelLocale: locale });\n  };\n\n  render() {\n    const {\n      collection,\n      entry,\n      fields,\n      fieldsMetaData,\n      fieldsErrors,\n      onChange,\n      showDelete,\n      onDelete,\n      onDeleteUnpublishedChanges,\n      onChangeStatus,\n      onPublish,\n      unPublish,\n      onDuplicate,\n      onValidate,\n      user,\n      hasChanged,\n      displayUrl,\n      hasWorkflow,\n      useOpenAuthoring,\n      hasUnpublishedChanges,\n      isNewEntry,\n      isModification,\n      currentStatus,\n      onLogoutClick,\n      loadDeployPreview,\n      deployPreview,\n      draftKey,\n      editorBackLink,\n      t,\n    } = this.props;\n\n    const { scrollSyncEnabled, showEventBlocker } = this.state;\n\n    const previewEnabled = isPreviewEnabled(collection, entry);\n\n    const { locales, defaultLocale } = getI18nInfo(this.props.collection);\n    const collectionI18nEnabled = hasI18n(collection) && locales.length > 1;\n    const editorProps = {\n      collection,\n      entry,\n      fields,\n      fieldsMetaData,\n      fieldsErrors,\n      onChange,\n      onValidate,\n    };\n\n    const leftPanelLocale = this.state.leftPanelLocale || locales?.[0];\n    const editor = (\n      <ControlPaneContainer overFlow blockEntry={showEventBlocker}>\n        <EditorControlPane\n          {...editorProps}\n          ref={c => (this.controlPaneRef = c)}\n          locale={leftPanelLocale}\n          t={t}\n          onLocaleChange={this.handleLeftPanelLocaleChange}\n        />\n      </ControlPaneContainer>\n    );\n\n    const editor2 = (\n      <ControlPaneContainer overFlow={!this.state.scrollSyncEnabled} blockEntry={showEventBlocker}>\n        <EditorControlPane {...editorProps} locale={locales?.[1]} t={t} />\n      </ControlPaneContainer>\n    );\n\n    const previewEntry = collectionI18nEnabled\n      ? getPreviewEntry(entry, leftPanelLocale, defaultLocale)\n      : entry;\n\n    const editorWithPreview = (\n      <ScrollSync enabled={this.state.scrollSyncEnabled}>\n        <div>\n          <ReactSplitPaneGlobalStyles />\n          <StyledSplitPane\n            maxSize={-100}\n            minSize={400}\n            defaultSize={parseInt(localStorage.getItem(SPLIT_PANE_POSITION), 10) || '50%'}\n            onChange={size => localStorage.setItem(SPLIT_PANE_POSITION, size)}\n            onDragStarted={this.handleSplitPaneDragStart}\n            onDragFinished={this.handleSplitPaneDragFinished}\n          >\n            <ScrollSyncPane>{editor}</ScrollSyncPane>\n            <PreviewPaneContainer blockEntry={showEventBlocker}>\n              <EditorPreviewPane\n                collection={collection}\n                entry={previewEntry}\n                fields={fields}\n                fieldsMetaData={fieldsMetaData}\n                locale={leftPanelLocale}\n                onFieldClick={this.handleFieldClick}\n              />\n            </PreviewPaneContainer>\n          </StyledSplitPane>\n        </div>\n      </ScrollSync>\n    );\n\n    const editorWithEditor = (\n      <ScrollSync enabled={this.state.scrollSyncEnabled}>\n        <div>\n          <StyledSplitPane\n            maxSize={-100}\n            defaultSize={parseInt(localStorage.getItem(SPLIT_PANE_POSITION), 10) || '50%'}\n            onChange={size => localStorage.setItem(SPLIT_PANE_POSITION, size)}\n            onDragStarted={this.handleSplitPaneDragStart}\n            onDragFinished={this.handleSplitPaneDragFinished}\n          >\n            <ScrollSyncPane>{editor}</ScrollSyncPane>\n            <ScrollSyncPane>{editor2}</ScrollSyncPane>\n          </StyledSplitPane>\n        </div>\n      </ScrollSync>\n    );\n\n    const i18nVisible = collectionI18nEnabled && this.state.i18nVisible;\n    const previewVisible = previewEnabled && this.state.previewVisible;\n    const scrollSyncVisible = i18nVisible || previewVisible;\n\n    return (\n      <EditorContainer>\n        <EditorToolbar\n          isPersisting={entry.get('isPersisting')}\n          isPublishing={entry.get('isPublishing')}\n          isUpdatingStatus={entry.get('isUpdatingStatus')}\n          isDeleting={entry.get('isDeleting')}\n          onPersist={this.handleOnPersist}\n          onPersistAndNew={() => this.handleOnPersist({ createNew: true })}\n          onPersistAndDuplicate={() => this.handleOnPersist({ createNew: true, duplicate: true })}\n          onDelete={onDelete}\n          onDeleteUnpublishedChanges={onDeleteUnpublishedChanges}\n          onChangeStatus={onChangeStatus}\n          showDelete={showDelete}\n          onPublish={onPublish}\n          unPublish={unPublish}\n          onDuplicate={onDuplicate}\n          onPublishAndNew={() => this.handleOnPublish({ createNew: true })}\n          onPublishAndDuplicate={() => this.handleOnPublish({ createNew: true, duplicate: true })}\n          user={user}\n          hasChanged={hasChanged}\n          displayUrl={displayUrl}\n          collection={collection}\n          hasWorkflow={hasWorkflow}\n          useOpenAuthoring={useOpenAuthoring}\n          hasUnpublishedChanges={hasUnpublishedChanges}\n          isNewEntry={isNewEntry}\n          isModification={isModification}\n          currentStatus={currentStatus}\n          onLogoutClick={onLogoutClick}\n          loadDeployPreview={loadDeployPreview}\n          deployPreview={deployPreview}\n          editorBackLink={editorBackLink}\n        />\n        <Editor key={draftKey}>\n          <ViewControls>\n            {collectionI18nEnabled && (\n              <EditorToggle\n                isActive={i18nVisible}\n                onClick={this.handleToggleI18n}\n                size=\"large\"\n                type=\"page\"\n                title={t('editor.editorInterface.toggleI18n')}\n                marginTop=\"70px\"\n              />\n            )}\n            {previewEnabled && (\n              <EditorToggle\n                isActive={previewVisible}\n                onClick={this.handleTogglePreview}\n                size=\"large\"\n                type=\"eye\"\n                title={t('editor.editorInterface.togglePreview')}\n              />\n            )}\n            {scrollSyncVisible && !collection.getIn(['editor', 'visualEditing']) && (\n              <EditorToggle\n                isActive={scrollSyncEnabled}\n                onClick={this.handleToggleScrollSync}\n                size=\"large\"\n                type=\"scroll\"\n                title={t('editor.editorInterface.toggleScrollSync')}\n              />\n            )}\n          </ViewControls>\n          <EditorContent\n            i18nVisible={i18nVisible}\n            previewVisible={previewVisible}\n            editor={editor}\n            editorWithEditor={editorWithEditor}\n            editorWithPreview={editorWithPreview}\n          />\n        </Editor>\n      </EditorContainer>\n    );\n  }\n}\n\nEditorInterface.propTypes = {\n  collection: ImmutablePropTypes.map.isRequired,\n  entry: ImmutablePropTypes.map.isRequired,\n  fields: ImmutablePropTypes.list.isRequired,\n  fieldsMetaData: ImmutablePropTypes.map.isRequired,\n  fieldsErrors: ImmutablePropTypes.map.isRequired,\n  onChange: PropTypes.func.isRequired,\n  onValidate: PropTypes.func.isRequired,\n  onPersist: PropTypes.func.isRequired,\n  showDelete: PropTypes.bool.isRequired,\n  onDelete: PropTypes.func.isRequired,\n  onDeleteUnpublishedChanges: PropTypes.func.isRequired,\n  onPublish: PropTypes.func.isRequired,\n  unPublish: PropTypes.func.isRequired,\n  onDuplicate: PropTypes.func.isRequired,\n  onChangeStatus: PropTypes.func.isRequired,\n  user: PropTypes.object,\n  hasChanged: PropTypes.bool,\n  displayUrl: PropTypes.string,\n  hasWorkflow: PropTypes.bool,\n  useOpenAuthoring: PropTypes.bool,\n  hasUnpublishedChanges: PropTypes.bool,\n  isNewEntry: PropTypes.bool,\n  isModification: PropTypes.bool,\n  currentStatus: PropTypes.string,\n  onLogoutClick: PropTypes.func.isRequired,\n  deployPreview: PropTypes.object,\n  loadDeployPreview: PropTypes.func.isRequired,\n  draftKey: PropTypes.string.isRequired,\n  t: PropTypes.func.isRequired,\n};\n\nexport default EditorInterface;\n"]} */"));
|
|
106
98
|
function EditorContent({
|
|
107
99
|
i18nVisible,
|
|
108
100
|
previewVisible,
|
|
@@ -115,18 +107,18 @@ function EditorContent({
|
|
|
115
107
|
} else if (previewVisible) {
|
|
116
108
|
return editorWithPreview;
|
|
117
109
|
} else {
|
|
118
|
-
return (
|
|
110
|
+
return ___EmotionJSX(NoPreviewContainer, null, editor);
|
|
119
111
|
}
|
|
120
112
|
}
|
|
121
113
|
function isPreviewEnabled(collection, entry) {
|
|
122
|
-
if (collection.get('type') ===
|
|
123
|
-
const file =
|
|
114
|
+
if (collection.get('type') === FILES) {
|
|
115
|
+
const file = getFileFromSlug(collection, entry.get('slug'));
|
|
124
116
|
const previewEnabled = file === null || file === void 0 ? void 0 : file.getIn(['editor', 'preview']);
|
|
125
117
|
if (previewEnabled != null) return previewEnabled;
|
|
126
118
|
}
|
|
127
119
|
return collection.getIn(['editor', 'preview'], true);
|
|
128
120
|
}
|
|
129
|
-
class EditorInterface extends
|
|
121
|
+
class EditorInterface extends Component {
|
|
130
122
|
constructor(...args) {
|
|
131
123
|
super(...args);
|
|
132
124
|
_defineProperty(this, "state", {
|
|
@@ -135,6 +127,10 @@ class EditorInterface extends _react.Component {
|
|
|
135
127
|
scrollSyncEnabled: localStorage.getItem(SCROLL_SYNC_ENABLED) !== 'false',
|
|
136
128
|
i18nVisible: localStorage.getItem(I18N_VISIBLE) !== 'false'
|
|
137
129
|
});
|
|
130
|
+
_defineProperty(this, "handleFieldClick", path => {
|
|
131
|
+
var _this$controlPaneRef;
|
|
132
|
+
(_this$controlPaneRef = this.controlPaneRef) === null || _this$controlPaneRef === void 0 ? void 0 : _this$controlPaneRef.focus(path);
|
|
133
|
+
});
|
|
138
134
|
_defineProperty(this, "handleSplitPaneDragStart", () => {
|
|
139
135
|
this.setState({
|
|
140
136
|
showEventBlocker: true
|
|
@@ -236,8 +232,8 @@ class EditorInterface extends _react.Component {
|
|
|
236
232
|
const {
|
|
237
233
|
locales,
|
|
238
234
|
defaultLocale
|
|
239
|
-
} =
|
|
240
|
-
const collectionI18nEnabled =
|
|
235
|
+
} = getI18nInfo(this.props.collection);
|
|
236
|
+
const collectionI18nEnabled = hasI18n(collection) && locales.length > 1;
|
|
241
237
|
const editorProps = {
|
|
242
238
|
collection,
|
|
243
239
|
entry,
|
|
@@ -248,54 +244,55 @@ class EditorInterface extends _react.Component {
|
|
|
248
244
|
onValidate
|
|
249
245
|
};
|
|
250
246
|
const leftPanelLocale = this.state.leftPanelLocale || (locales === null || locales === void 0 ? void 0 : locales[0]);
|
|
251
|
-
const editor = (
|
|
247
|
+
const editor = ___EmotionJSX(ControlPaneContainer, {
|
|
252
248
|
overFlow: true,
|
|
253
249
|
blockEntry: showEventBlocker
|
|
254
|
-
}, (
|
|
250
|
+
}, ___EmotionJSX(EditorControlPane, _extends({}, editorProps, {
|
|
255
251
|
ref: c => this.controlPaneRef = c,
|
|
256
252
|
locale: leftPanelLocale,
|
|
257
253
|
t: t,
|
|
258
254
|
onLocaleChange: this.handleLeftPanelLocaleChange
|
|
259
255
|
})));
|
|
260
|
-
const editor2 = (
|
|
256
|
+
const editor2 = ___EmotionJSX(ControlPaneContainer, {
|
|
261
257
|
overFlow: !this.state.scrollSyncEnabled,
|
|
262
258
|
blockEntry: showEventBlocker
|
|
263
|
-
}, (
|
|
259
|
+
}, ___EmotionJSX(EditorControlPane, _extends({}, editorProps, {
|
|
264
260
|
locale: locales === null || locales === void 0 ? void 0 : locales[1],
|
|
265
261
|
t: t
|
|
266
262
|
})));
|
|
267
|
-
const previewEntry = collectionI18nEnabled ?
|
|
268
|
-
const editorWithPreview = (
|
|
263
|
+
const previewEntry = collectionI18nEnabled ? getPreviewEntry(entry, leftPanelLocale, defaultLocale) : entry;
|
|
264
|
+
const editorWithPreview = ___EmotionJSX(ScrollSync, {
|
|
269
265
|
enabled: this.state.scrollSyncEnabled
|
|
270
|
-
}, (
|
|
266
|
+
}, ___EmotionJSX("div", null, ___EmotionJSX(ReactSplitPaneGlobalStyles, null), ___EmotionJSX(StyledSplitPane, {
|
|
271
267
|
maxSize: -100,
|
|
272
268
|
minSize: 400,
|
|
273
269
|
defaultSize: parseInt(localStorage.getItem(SPLIT_PANE_POSITION), 10) || '50%',
|
|
274
270
|
onChange: size => localStorage.setItem(SPLIT_PANE_POSITION, size),
|
|
275
271
|
onDragStarted: this.handleSplitPaneDragStart,
|
|
276
272
|
onDragFinished: this.handleSplitPaneDragFinished
|
|
277
|
-
}, (
|
|
273
|
+
}, ___EmotionJSX(ScrollSyncPane, null, editor), ___EmotionJSX(PreviewPaneContainer, {
|
|
278
274
|
blockEntry: showEventBlocker
|
|
279
|
-
}, (
|
|
275
|
+
}, ___EmotionJSX(EditorPreviewPane, {
|
|
280
276
|
collection: collection,
|
|
281
277
|
entry: previewEntry,
|
|
282
278
|
fields: fields,
|
|
283
279
|
fieldsMetaData: fieldsMetaData,
|
|
284
|
-
locale: leftPanelLocale
|
|
280
|
+
locale: leftPanelLocale,
|
|
281
|
+
onFieldClick: this.handleFieldClick
|
|
285
282
|
})))));
|
|
286
|
-
const editorWithEditor = (
|
|
283
|
+
const editorWithEditor = ___EmotionJSX(ScrollSync, {
|
|
287
284
|
enabled: this.state.scrollSyncEnabled
|
|
288
|
-
}, (
|
|
285
|
+
}, ___EmotionJSX("div", null, ___EmotionJSX(StyledSplitPane, {
|
|
289
286
|
maxSize: -100,
|
|
290
287
|
defaultSize: parseInt(localStorage.getItem(SPLIT_PANE_POSITION), 10) || '50%',
|
|
291
288
|
onChange: size => localStorage.setItem(SPLIT_PANE_POSITION, size),
|
|
292
289
|
onDragStarted: this.handleSplitPaneDragStart,
|
|
293
290
|
onDragFinished: this.handleSplitPaneDragFinished
|
|
294
|
-
}, (
|
|
291
|
+
}, ___EmotionJSX(ScrollSyncPane, null, editor), ___EmotionJSX(ScrollSyncPane, null, editor2))));
|
|
295
292
|
const i18nVisible = collectionI18nEnabled && this.state.i18nVisible;
|
|
296
293
|
const previewVisible = previewEnabled && this.state.previewVisible;
|
|
297
294
|
const scrollSyncVisible = i18nVisible || previewVisible;
|
|
298
|
-
return (
|
|
295
|
+
return ___EmotionJSX(EditorContainer, null, ___EmotionJSX(EditorToolbar, {
|
|
299
296
|
isPersisting: entry.get('isPersisting'),
|
|
300
297
|
isPublishing: entry.get('isPublishing'),
|
|
301
298
|
isUpdatingStatus: entry.get('isUpdatingStatus'),
|
|
@@ -336,28 +333,28 @@ class EditorInterface extends _react.Component {
|
|
|
336
333
|
loadDeployPreview: loadDeployPreview,
|
|
337
334
|
deployPreview: deployPreview,
|
|
338
335
|
editorBackLink: editorBackLink
|
|
339
|
-
}), (
|
|
336
|
+
}), ___EmotionJSX(Editor, {
|
|
340
337
|
key: draftKey
|
|
341
|
-
}, (
|
|
338
|
+
}, ___EmotionJSX(ViewControls, null, collectionI18nEnabled && ___EmotionJSX(EditorToggle, {
|
|
342
339
|
isActive: i18nVisible,
|
|
343
340
|
onClick: this.handleToggleI18n,
|
|
344
341
|
size: "large",
|
|
345
342
|
type: "page",
|
|
346
343
|
title: t('editor.editorInterface.toggleI18n'),
|
|
347
344
|
marginTop: "70px"
|
|
348
|
-
}), previewEnabled && (
|
|
345
|
+
}), previewEnabled && ___EmotionJSX(EditorToggle, {
|
|
349
346
|
isActive: previewVisible,
|
|
350
347
|
onClick: this.handleTogglePreview,
|
|
351
348
|
size: "large",
|
|
352
349
|
type: "eye",
|
|
353
350
|
title: t('editor.editorInterface.togglePreview')
|
|
354
|
-
}), scrollSyncVisible && (
|
|
351
|
+
}), scrollSyncVisible && !collection.getIn(['editor', 'visualEditing']) && ___EmotionJSX(EditorToggle, {
|
|
355
352
|
isActive: scrollSyncEnabled,
|
|
356
353
|
onClick: this.handleToggleScrollSync,
|
|
357
354
|
size: "large",
|
|
358
355
|
type: "scroll",
|
|
359
356
|
title: t('editor.editorInterface.toggleScrollSync')
|
|
360
|
-
})), (
|
|
357
|
+
})), ___EmotionJSX(EditorContent, {
|
|
361
358
|
i18nVisible: i18nVisible,
|
|
362
359
|
previewVisible: previewVisible,
|
|
363
360
|
editor: editor,
|
|
@@ -367,34 +364,34 @@ class EditorInterface extends _react.Component {
|
|
|
367
364
|
}
|
|
368
365
|
}
|
|
369
366
|
EditorInterface.propTypes = {
|
|
370
|
-
collection:
|
|
371
|
-
entry:
|
|
372
|
-
fields:
|
|
373
|
-
fieldsMetaData:
|
|
374
|
-
fieldsErrors:
|
|
375
|
-
onChange:
|
|
376
|
-
onValidate:
|
|
377
|
-
onPersist:
|
|
378
|
-
showDelete:
|
|
379
|
-
onDelete:
|
|
380
|
-
onDeleteUnpublishedChanges:
|
|
381
|
-
onPublish:
|
|
382
|
-
unPublish:
|
|
383
|
-
onDuplicate:
|
|
384
|
-
onChangeStatus:
|
|
385
|
-
user:
|
|
386
|
-
hasChanged:
|
|
387
|
-
displayUrl:
|
|
388
|
-
hasWorkflow:
|
|
389
|
-
useOpenAuthoring:
|
|
390
|
-
hasUnpublishedChanges:
|
|
391
|
-
isNewEntry:
|
|
392
|
-
isModification:
|
|
393
|
-
currentStatus:
|
|
394
|
-
onLogoutClick:
|
|
395
|
-
deployPreview:
|
|
396
|
-
loadDeployPreview:
|
|
397
|
-
draftKey:
|
|
398
|
-
t:
|
|
367
|
+
collection: ImmutablePropTypes.map.isRequired,
|
|
368
|
+
entry: ImmutablePropTypes.map.isRequired,
|
|
369
|
+
fields: ImmutablePropTypes.list.isRequired,
|
|
370
|
+
fieldsMetaData: ImmutablePropTypes.map.isRequired,
|
|
371
|
+
fieldsErrors: ImmutablePropTypes.map.isRequired,
|
|
372
|
+
onChange: PropTypes.func.isRequired,
|
|
373
|
+
onValidate: PropTypes.func.isRequired,
|
|
374
|
+
onPersist: PropTypes.func.isRequired,
|
|
375
|
+
showDelete: PropTypes.bool.isRequired,
|
|
376
|
+
onDelete: PropTypes.func.isRequired,
|
|
377
|
+
onDeleteUnpublishedChanges: PropTypes.func.isRequired,
|
|
378
|
+
onPublish: PropTypes.func.isRequired,
|
|
379
|
+
unPublish: PropTypes.func.isRequired,
|
|
380
|
+
onDuplicate: PropTypes.func.isRequired,
|
|
381
|
+
onChangeStatus: PropTypes.func.isRequired,
|
|
382
|
+
user: PropTypes.object,
|
|
383
|
+
hasChanged: PropTypes.bool,
|
|
384
|
+
displayUrl: PropTypes.string,
|
|
385
|
+
hasWorkflow: PropTypes.bool,
|
|
386
|
+
useOpenAuthoring: PropTypes.bool,
|
|
387
|
+
hasUnpublishedChanges: PropTypes.bool,
|
|
388
|
+
isNewEntry: PropTypes.bool,
|
|
389
|
+
isModification: PropTypes.bool,
|
|
390
|
+
currentStatus: PropTypes.string,
|
|
391
|
+
onLogoutClick: PropTypes.func.isRequired,
|
|
392
|
+
deployPreview: PropTypes.object,
|
|
393
|
+
loadDeployPreview: PropTypes.func.isRequired,
|
|
394
|
+
draftKey: PropTypes.string.isRequired,
|
|
395
|
+
t: PropTypes.func.isRequired
|
|
399
396
|
};
|
|
400
|
-
|
|
397
|
+
export default EditorInterface;
|