mirror of
https://github.com/stolksdorf/homebrewery.git
synced 2025-12-16 03:35:56 +00:00
110 lines
2.7 KiB
JavaScript
110 lines
2.7 KiB
JavaScript
const React = require('react');
|
|
const _ = require('lodash');
|
|
const cx = require('classnames');
|
|
|
|
const CodeEditor = require('naturalcrit/codeEditor/codeEditor.jsx');
|
|
const SnippetBar = require('./snippetbar/snippetbar.jsx');
|
|
const MetadataEditor = require('./metadataEditor/metadataEditor.jsx');
|
|
|
|
|
|
const splice = function(str, index, inject){
|
|
return str.slice(0, index) + inject + str.slice(index);
|
|
};
|
|
|
|
const SNIPPETBAR_HEIGHT = 25;
|
|
|
|
const Editor = React.createClass({
|
|
getDefaultProps: function() {
|
|
return {
|
|
value : '',
|
|
onChange : ()=>{},
|
|
|
|
metadata : {},
|
|
onMetadataChange : ()=>{},
|
|
};
|
|
},
|
|
getInitialState: function() {
|
|
return {
|
|
showMetadataEditor: false
|
|
};
|
|
},
|
|
cursorPosition : {
|
|
line : 0,
|
|
ch : 0
|
|
},
|
|
|
|
componentDidMount: function() {
|
|
this.updateEditorSize();
|
|
window.addEventListener("resize", this.updateEditorSize);
|
|
},
|
|
componentWillUnmount: function() {
|
|
window.removeEventListener("resize", this.updateEditorSize);
|
|
},
|
|
|
|
updateEditorSize : function() {
|
|
let paneHeight = this.refs.main.parentNode.clientHeight;
|
|
paneHeight -= SNIPPETBAR_HEIGHT + 1;
|
|
this.refs.codeEditor.codeMirror.setSize(null, paneHeight);
|
|
},
|
|
|
|
handleTextChange : function(text){
|
|
this.props.onChange(text);
|
|
},
|
|
handleCursorActivty : function(curpos){
|
|
this.cursorPosition = curpos;
|
|
},
|
|
handleInject : function(injectText){
|
|
const lines = this.props.value.split('\n');
|
|
lines[this.cursorPosition.line] = splice(lines[this.cursorPosition.line], this.cursorPosition.ch, injectText);
|
|
|
|
this.handleTextChange(lines.join('\n'));
|
|
this.refs.codeEditor.setCursorPosition(this.cursorPosition.line, this.cursorPosition.ch + injectText.length);
|
|
},
|
|
handgleToggle : function(){
|
|
this.setState({
|
|
showMetadataEditor : !this.state.showMetadataEditor
|
|
})
|
|
},
|
|
|
|
//Called when there are changes to the editor's dimensions
|
|
update : function(){
|
|
this.refs.codeEditor.updateSize();
|
|
},
|
|
|
|
renderMetadataEditor : function(){
|
|
if(!this.state.showMetadataEditor) return;
|
|
return <MetadataEditor
|
|
metadata={this.props.metadata}
|
|
onChange={this.props.onMetadataChange}
|
|
/>
|
|
},
|
|
|
|
render : function(){
|
|
return(
|
|
<div className='editor' ref='main'>
|
|
<SnippetBar
|
|
brew={this.props.value}
|
|
onInject={this.handleInject}
|
|
onToggle={this.handgleToggle}
|
|
showmeta={this.state.showMetadataEditor} />
|
|
{this.renderMetadataEditor()}
|
|
<CodeEditor
|
|
ref='codeEditor'
|
|
wrap={true}
|
|
language='gfm'
|
|
value={this.props.value}
|
|
onChange={this.handleTextChange}
|
|
onCursorActivity={this.handleCursorActivty} />
|
|
</div>
|
|
);
|
|
}
|
|
});
|
|
|
|
module.exports = Editor;
|
|
|
|
|
|
|
|
|
|
|
|
|