2016-06-16 19:20:36 -03:00
|
|
|
import React, { PropTypes } from 'react';
|
2016-09-12 11:14:21 +02:00
|
|
|
import registry from '../../lib/registry';
|
2016-08-11 18:21:32 -03:00
|
|
|
import RawEditor from './MarkdownControlElements/RawEditor';
|
2016-08-11 11:27:09 -03:00
|
|
|
import VisualEditor from './MarkdownControlElements/VisualEditor';
|
2016-08-18 10:51:38 -03:00
|
|
|
import { processEditorPlugins } from './richText';
|
2016-08-11 18:21:32 -03:00
|
|
|
import { connect } from 'react-redux';
|
|
|
|
import { switchVisualMode } from '../../actions/editor';
|
2016-08-03 10:30:42 -03:00
|
|
|
|
2016-08-01 16:41:55 -03:00
|
|
|
class MarkdownControl extends React.Component {
|
2016-08-18 10:51:38 -03:00
|
|
|
constructor(props, context) {
|
|
|
|
super(props, context);
|
2016-08-11 18:21:32 -03:00
|
|
|
this.useVisualEditor = this.useVisualEditor.bind(this);
|
|
|
|
this.useRawEditor = this.useRawEditor.bind(this);
|
|
|
|
}
|
|
|
|
|
2016-08-18 10:51:38 -03:00
|
|
|
componentWillMount() {
|
2016-09-12 11:14:21 +02:00
|
|
|
this.useRawEditor();
|
|
|
|
processEditorPlugins(registry.getEditorComponents());
|
2016-08-18 10:51:38 -03:00
|
|
|
}
|
|
|
|
|
2016-08-17 09:52:06 -03:00
|
|
|
useVisualEditor() {
|
2016-08-11 18:21:32 -03:00
|
|
|
this.props.switchVisualMode(true);
|
|
|
|
}
|
|
|
|
|
2016-08-17 09:52:06 -03:00
|
|
|
useRawEditor() {
|
2016-08-11 18:21:32 -03:00
|
|
|
this.props.switchVisualMode(false);
|
|
|
|
}
|
|
|
|
|
|
|
|
renderEditor() {
|
|
|
|
const { editor, onChange, onAddMedia, getMedia, value } = this.props;
|
|
|
|
if (editor.get('useVisualMode')) {
|
|
|
|
return (
|
2016-09-12 11:14:21 +02:00
|
|
|
<div className='cms-editor-visual'>
|
|
|
|
{null && <button onClick={this.useRawEditor}>Switch to Raw Editor</button>}
|
2016-08-11 18:21:32 -03:00
|
|
|
<VisualEditor
|
|
|
|
onChange={onChange}
|
|
|
|
onAddMedia={onAddMedia}
|
|
|
|
getMedia={getMedia}
|
2016-08-17 09:52:06 -03:00
|
|
|
registeredComponents={editor.get('registeredComponents')}
|
2016-08-11 18:21:32 -03:00
|
|
|
value={value}
|
|
|
|
/>
|
|
|
|
</div>
|
|
|
|
);
|
|
|
|
} else {
|
|
|
|
return (
|
2016-09-12 11:14:21 +02:00
|
|
|
<div className='cms-editor-raw'>
|
|
|
|
{null && <button onClick={this.useVisualEditor}>Switch to Visual Editor</button>}
|
2016-08-11 18:21:32 -03:00
|
|
|
<RawEditor
|
|
|
|
onChange={onChange}
|
|
|
|
onAddMedia={onAddMedia}
|
|
|
|
getMedia={getMedia}
|
|
|
|
value={value}
|
|
|
|
/>
|
|
|
|
</div>
|
|
|
|
);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2016-05-30 16:55:32 -07:00
|
|
|
render() {
|
|
|
|
return (
|
2016-08-11 18:21:32 -03:00
|
|
|
<div>
|
|
|
|
|
2016-09-13 15:30:58 +02:00
|
|
|
{this.renderEditor()}
|
2016-08-11 18:21:32 -03:00
|
|
|
</div>
|
2016-08-01 16:41:55 -03:00
|
|
|
);
|
2016-05-30 16:55:32 -07:00
|
|
|
}
|
|
|
|
}
|
2016-06-16 19:20:36 -03:00
|
|
|
|
|
|
|
MarkdownControl.propTypes = {
|
2016-08-11 18:21:32 -03:00
|
|
|
editor: PropTypes.object.isRequired,
|
2016-06-16 19:20:36 -03:00
|
|
|
onChange: PropTypes.func.isRequired,
|
2016-08-08 18:51:53 -03:00
|
|
|
onAddMedia: PropTypes.func.isRequired,
|
|
|
|
getMedia: PropTypes.func.isRequired,
|
2016-08-11 18:21:32 -03:00
|
|
|
switchVisualMode: PropTypes.func.isRequired,
|
2016-06-16 19:20:36 -03:00
|
|
|
value: PropTypes.node,
|
|
|
|
};
|
2016-08-11 18:21:32 -03:00
|
|
|
|
2016-08-18 10:51:38 -03:00
|
|
|
MarkdownControl.contextTypes = {
|
|
|
|
plugins: PropTypes.object,
|
|
|
|
};
|
|
|
|
|
2016-08-11 18:21:32 -03:00
|
|
|
export default connect(
|
|
|
|
state => ({ editor: state.editor }),
|
|
|
|
{ switchVisualMode }
|
|
|
|
)(MarkdownControl);
|