const React = require('react'); const { connect } = require('react-redux'); const { _ } = require('lib/locale.js'); const { themeStyle } = require('../theme.js'); class PromptDialog extends React.Component { componentWillMount() { this.setState({ visible: false, answer: this.props.value ? this.props.value : '', }); this.focusInput_ = true; } componentWillReceiveProps(newProps) { if ('visible' in newProps) { this.setState({ visible: newProps.visible }); if (newProps.visible) this.focusInput_ = true; } if ('value' in newProps) { this.setState({ answer: newProps.value }); } } componentDidUpdate() { if (this.focusInput_ && this.answerInput_) this.answerInput_.focus(); this.focusInput_ = false; } render() { const style = this.props.style; const theme = themeStyle(this.props.theme); const modalLayerStyle = { zIndex: 9999, position: 'absolute', top: 0, left: 0, width: style.width, height: style.height, backgroundColor: 'rgba(0,0,0,0.6)', display: this.state.visible ? 'flex' : 'none', alignItems: 'center', justifyContent: 'center', }; const promptDialogStyle = { backgroundColor: 'white', padding: 16, display: 'inline-block', boxShadow: '6px 6px 20px rgba(0,0,0,0.5)', }; const buttonStyle = { minWidth: theme.buttonMinWidth, minHeight: theme.buttonMinHeight, marginLeft: 5, }; const labelStyle = { marginRight: 5, fontSize: theme.fontSize, color: theme.color, fontFamily: theme.fontFamily, verticalAlign: 'top', }; const inputStyle = { width: 0.5 * style.width, maxWidth: 400, }; const descStyle = Object.assign({}, theme.textStyle, { marginTop: 10, }); const onClose = (accept) => { if (this.props.onClose) this.props.onClose(accept ? this.state.answer : null); this.setState({ visible: false, answer: '' }); } const onChange = (event) => { this.setState({ answer: event.target.value }); } const onKeyDown = (event) => { if (event.key === 'Enter') { onClose(true); } else if (event.key === 'Escape') { onClose(false); } } const descComp = this.props.description ?
{this.props.description}
: null; return (
this.answerInput_ = input} value={this.state.answer} type="text" onChange={(event) => onChange(event)} onKeyDown={(event) => onKeyDown(event)} /> {descComp}
); } } module.exports = { PromptDialog };