import * as React from 'react'; import { Link } from 'react-router-dom'; import requestPasswordResetEmail from '@/api/auth/requestPasswordResetEmail'; import { connect } from 'react-redux'; import { pushFlashMessage, clearAllFlashMessages } from '@/redux/actions/flash'; import { httpErrorToHuman } from '@/api/http'; import LoginFormContainer from '@/components/auth/LoginFormContainer'; type Props = Readonly<{ pushFlashMessage: typeof pushFlashMessage; clearAllFlashMessages: typeof clearAllFlashMessages; }>; type State = Readonly<{ email: string; isSubmitting: boolean; }>; class ForgotPasswordContainer extends React.PureComponent { emailField = React.createRef(); state: State = { email: '', isSubmitting: false, }; handleFieldUpdate = (e: React.ChangeEvent) => this.setState({ email: e.target.value, }); handleSubmission = (e: React.FormEvent) => { e.preventDefault(); this.setState({ isSubmitting: true }, () => { this.props.clearAllFlashMessages(); requestPasswordResetEmail(this.state.email) .then(response => { if (this.emailField.current) { this.emailField.current.value = ''; } this.props.pushFlashMessage({ type: 'success', title: 'Success', message: response, }); }) .catch(error => { console.error(error); this.props.pushFlashMessage({ type: 'error', title: 'Error', message: httpErrorToHuman(error), }); }) .then(() => this.setState({ isSubmitting: false })); }); }; render () { return (

Request Password Reset

Enter your account email address to receive instructions on resetting your password.

Return to Login
); } } const mapDispatchToProps = { pushFlashMessage, clearAllFlashMessages, }; export default connect(null, mapDispatchToProps)(ForgotPasswordContainer);