scratch-paint/src/components/paint-editor.jsx

58 lines
1.7 KiB
React
Raw Normal View History

2017-07-27 16:41:41 -04:00
import bindAll from 'lodash.bindall';
2017-07-13 14:03:48 -04:00
import React from 'react';
import PaperCanvas from '../containers/paper-canvas.jsx';
import BrushMode from '../containers/brush-mode.jsx';
import EraserMode from '../containers/eraser-mode.jsx';
2017-08-30 10:50:05 -04:00
import PropTypes from 'prop-types';
2017-08-22 15:53:35 -04:00
import LineMode from '../containers/line-mode.jsx';
2017-07-13 14:03:48 -04:00
2017-07-27 11:45:41 -04:00
class PaintEditorComponent extends React.Component {
2017-07-27 16:41:41 -04:00
constructor (props) {
super(props);
bindAll(this, [
'setCanvas'
]);
this.state = {};
}
setCanvas (canvas) {
this.setState({canvas: canvas});
}
2017-07-27 11:45:41 -04:00
render () {
// Modes can't work without a canvas, so we don't render them until we have it
2017-07-27 16:41:41 -04:00
if (this.state.canvas) {
return (
<div>
2017-08-30 10:50:05 -04:00
<PaperCanvas
canvasRef={this.setCanvas}
svg={this.props.svg}
/>
<BrushMode
canvas={this.state.canvas}
onUpdateSvg={this.props.onUpdateSvg}
/>
<EraserMode
canvas={this.state.canvas}
onUpdateSvg={this.props.onUpdateSvg}
/>
<LineMode
canvas={this.state.canvas}
onUpdateSvg={this.props.onUpdateSvg}
/>
2017-07-27 16:41:41 -04:00
</div>
);
}
2017-07-27 11:45:41 -04:00
return (
<div>
2017-07-27 16:41:41 -04:00
<PaperCanvas canvasRef={this.setCanvas} />
2017-07-27 11:45:41 -04:00
</div>
);
}
}
2017-07-13 14:03:48 -04:00
2017-08-30 10:50:05 -04:00
PaintEditorComponent.propTypes = {
onUpdateSvg: PropTypes.func.isRequired,
2017-08-30 10:50:05 -04:00
svg: PropTypes.string
};
2017-07-26 20:39:12 -04:00
export default PaintEditorComponent;