import React from 'react'; import { defineMessages, useIntl } from 'react-intl'; import { changeEmail } from 'soapbox/actions/security'; import { Button, Column, Form, FormActions, FormGroup, Input } from 'soapbox/components/ui'; import { useAppDispatch } from 'soapbox/hooks'; import toast from 'soapbox/toast'; const messages = defineMessages({ header: { id: 'edit_email.header', defaultMessage: 'Change Email' }, updateEmailSuccess: { id: 'security.update_email.success', defaultMessage: 'Email successfully updated.' }, updateEmailFail: { id: 'security.update_email.fail', defaultMessage: 'Update email failed.' }, emailFieldLabel: { id: 'security.fields.email.label', defaultMessage: 'Email address' }, emailFieldPlaceholder: { id: 'edit_email.placeholder', defaultMessage: 'me@example.com' }, passwordFieldLabel: { id: 'security.fields.password.label', defaultMessage: 'Password' }, submit: { id: 'security.submit', defaultMessage: 'Save changes' }, cancel: { id: 'common.cancel', defaultMessage: 'Cancel' }, }); const initialState = { email: '', password: '' }; const EditEmail = () => { const intl = useIntl(); const dispatch = useAppDispatch(); const [state, setState] = React.useState(initialState); const [isLoading, setLoading] = React.useState(false); const { email, password } = state; const handleInputChange: React.ChangeEventHandler = React.useCallback((event) => { event.persist(); setState((prevState) => ({ ...prevState, [event.target.name]: event.target.value })); }, []); const handleSubmit = React.useCallback(() => { setLoading(true); dispatch(changeEmail(email, password)).then(() => { setState(initialState); toast.success(intl.formatMessage(messages.updateEmailSuccess)); }).finally(() => { setLoading(false); }).catch(() => { setState((prevState) => ({ ...prevState, password: '' })); toast.error(intl.formatMessage(messages.updateEmailFail)); }); }, [email, password, dispatch, intl]); return (
); }; export default EditEmail;