import PropTypes from 'prop-types'; import React, { Component } from 'react'; import ImmutablePropTypes from 'react-immutable-proptypes'; import SplitPane from 'react-split-pane'; import Button from 'react-toolbox/lib/button'; import classnames from 'classnames'; import { ScrollSync, ScrollSyncPane } from '../ScrollSync'; import ControlPane from '../ControlPanel/ControlPane'; import PreviewPane from '../PreviewPane/PreviewPane'; import Toolbar from './EntryEditorToolbar'; import { StickyContext } from '../UI/Sticky/Sticky'; import styles from './EntryEditor.css'; import stickyStyles from '../UI/Sticky/Sticky.css'; const PREVIEW_VISIBLE = 'cms.preview-visible'; class EntryEditor extends Component { state = { showEventBlocker: false, previewVisible: localStorage.getItem(PREVIEW_VISIBLE) !== "false", }; handleSplitPaneDragStart = () => { this.setState({ showEventBlocker: true }); }; handleSplitPaneDragFinished = () => { this.setState({ showEventBlocker: false }); }; handleOnPersist = () => { this.controlPaneRef.validate(); this.props.onPersist(); }; handleTogglePreview = () => { const newPreviewVisible = !this.state.previewVisible; this.setState({ previewVisible: newPreviewVisible }); localStorage.setItem(PREVIEW_VISIBLE, newPreviewVisible); }; render() { const { collection, entry, fields, fieldsMetaData, fieldsErrors, getAsset, onChange, enableSave, showDelete, onDelete, onValidate, onAddAsset, onRemoveAsset, onCancelEdit, } = this.props; const { previewVisible, showEventBlocker } = this.state; const collectionPreviewEnabled = collection.getIn(['editor', 'preview'], true); const togglePreviewButton = (