import React, { PropTypes } from 'react'; import registry from '../../lib/registry'; import RawEditor from './MarkdownControlElements/RawEditor'; import VisualEditor from './MarkdownControlElements/VisualEditor'; import { processEditorPlugins } from './richText'; import { StickyContainer } from '../UI/Sticky/Sticky'; const MODE_STORAGE_KEY = 'cms.md-mode'; export default class MarkdownControl extends React.Component { static propTypes = { onChange: PropTypes.func.isRequired, onAddAsset: PropTypes.func.isRequired, onRemoveAsset: PropTypes.func.isRequired, getAsset: PropTypes.func.isRequired, value: PropTypes.node, }; constructor(props) { super(props); this.state = { mode: localStorage.getItem(MODE_STORAGE_KEY) || 'visual' }; } componentWillMount() { processEditorPlugins(registry.getEditorComponents()); } handleMode = (mode) => { this.setState({ mode }); localStorage.setItem(MODE_STORAGE_KEY, mode); }; render() { const { onChange, onAddAsset, onRemoveAsset, getAsset, value } = this.props; const { mode } = this.state; const visualEditor = (
); const rawEditor = (
); return { mode === 'visual' ? visualEditor : rawEditor }; } }