import PropTypes from 'prop-types'; import React from 'react'; import { injectIntl, FormattedMessage } from 'react-intl'; import { Modal } from 'soapbox/components/ui'; import { SimpleForm, FieldsGroup, Checkbox } from 'soapbox/features/forms'; export default @injectIntl class ConfirmationModal extends React.PureComponent { static propTypes = { heading: PropTypes.node, icon: PropTypes.node, message: PropTypes.node.isRequired, confirm: PropTypes.node.isRequired, onClose: PropTypes.func.isRequired, onConfirm: PropTypes.func.isRequired, secondary: PropTypes.string, onSecondary: PropTypes.func, intl: PropTypes.object.isRequired, onCancel: PropTypes.func, checkbox: PropTypes.node, }; state = { checked: false, } handleClick = () => { this.props.onClose('CONFIRM'); this.props.onConfirm(); } handleSecondary = () => { this.props.onClose('CONFIRM'); this.props.onSecondary(); } handleCancel = () => { const { onClose, onCancel } = this.props; onClose('CONFIRM'); if (onCancel) onCancel(); } handleCheckboxChange = e => { this.setState({ checked: e.target.checked }); } render() { const { heading, message, confirm, secondary, checkbox } = this.props; const { checked } = this.state; return ( } cancelAction={this.handleCancel} secondaryText={secondary} secondaryAction={this.props.onSecondary && this.handleSecondary} >

{message}

{checkbox &&
}
); } }