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 { connect } from 'react-redux'; import { switchVisualMode } from '../../actions/editor'; class MarkdownControl extends React.Component { componentWillMount() { this.useRawEditor(); processEditorPlugins(registry.getEditorComponents()); } useVisualEditor = () => { this.props.switchVisualMode(true); }; useRawEditor = () => { this.props.switchVisualMode(false); }; renderEditor() { const { editor, onChange, onAddMedia, getMedia, value } = this.props; if (editor.get('useVisualMode')) { return (
{null && }
); } else { return (
{null && }
); } } render() { return (
{this.renderEditor()}
); } } MarkdownControl.propTypes = { editor: PropTypes.object.isRequired, onChange: PropTypes.func.isRequired, onAddMedia: PropTypes.func.isRequired, getMedia: PropTypes.func.isRequired, switchVisualMode: PropTypes.func.isRequired, value: PropTypes.node, }; MarkdownControl.contextTypes = { plugins: PropTypes.object, }; export default connect( state => ({ editor: state.editor }), { switchVisualMode } )(MarkdownControl);