import React from 'react'; import { defineMessages, useIntl } from 'react-intl'; import { deleteAccount } from 'soapbox/actions/security'; import snackbar from 'soapbox/actions/snackbar'; import { Button, Card, CardBody, CardHeader, CardTitle, Form, FormActions, FormGroup, Input, Stack, Text } from 'soapbox/components/ui'; import { useAppDispatch, useFeatures } from 'soapbox/hooks'; import toast from 'soapbox/toast'; const messages = defineMessages({ passwordFieldLabel: { id: 'security.fields.password.label', defaultMessage: 'Password' }, deleteHeader: { id: 'security.headers.delete', defaultMessage: 'Delete Account' }, deleteText: { id: 'security.text.delete', defaultMessage: 'To delete your account, enter your password then click Delete Account. This is a permanent action that cannot be undone. Your account will be destroyed from this server, and a deletion request will be sent to other servers. It\'s not guaranteed that all servers will purge your account.' }, localDeleteText: { id: 'security.text.delete.local', defaultMessage: 'To delete your account, enter your password then click Delete Account. This is a permanent action that cannot be undone.' }, deleteSubmit: { id: 'security.submit.delete', defaultMessage: 'Delete Account' }, deleteAccountSuccess: { id: 'security.delete_account.success', defaultMessage: 'Account successfully deleted.' }, deleteAccountFail: { id: 'security.delete_account.fail', defaultMessage: 'Account deletion failed.' }, }); const DeleteAccount = () => { const intl = useIntl(); const dispatch = useAppDispatch(); const features = useFeatures(); const [password, setPassword] = React.useState(''); const [isLoading, setLoading] = React.useState(false); const handleInputChange = React.useCallback((event: React.ChangeEvent) => { event.persist(); setPassword(event.target.value); }, []); const handleSubmit = React.useCallback(() => { setLoading(true); dispatch(deleteAccount(password)).then(() => { setPassword(''); toast.success(intl.formatMessage(messages.deleteAccountSuccess)); }).finally(() => { setLoading(false); }).catch(() => { setPassword(''); dispatch(snackbar.error(intl.formatMessage(messages.deleteAccountFail))); }); }, [password, dispatch, intl]); return ( {intl.formatMessage(features.federating ? messages.deleteText : messages.localDeleteText)}
); }; export default DeleteAccount;