import React from 'react'; import PropTypes from 'prop-types'; import Button from '../../../components/button'; import ImmutablePureComponent from 'react-immutable-pure-component'; import Atrament from 'atrament'; // the doodling library export default class DoodleModal extends ImmutablePureComponent { static contextTypes = { router: PropTypes.object, }; static propTypes = { onDoodleSubmit: PropTypes.func.isRequired, // gets the base64 as argument onClose: PropTypes.func.isRequired, }; handleKeyUp = (e) => { if (e.key === 'Delete' || e.key === 'Backspace') { this.clearScreen(); } } clearScreen () { this.sketcher.context.fillStyle = 'white'; this.sketcher.context.fillRect(0, 0, this.canvas.width, this.canvas.height); } componentDidMount () { window.addEventListener('keyup', this.handleKeyUp, false); } handleDone = () => { this.props.onDoodleSubmit(this.sketcher.toImage()); this.sketcher.destroy(); this.props.onClose(); } setCanvasRef = (elem) => { this.canvas = elem; if (elem) { this.sketcher = new Atrament(elem, 500, 500, 'black'); this.clearScreen(); // .smoothing looks good with mouse but works really poorly with a tablet this.sketcher.smoothing = false; // There's a bunch of options we should add UI controls for later // ref: https://github.com/jakubfiala/atrament.js } } render () { return (
); } }