import { AxiosError } from 'axios'; import * as React from 'react'; import { defineMessages, FormattedMessage, useIntl } from 'react-intl'; import { useDispatch } from 'react-redux'; import { Redirect } from 'react-router-dom'; import { logIn, verifyCredentials } from 'soapbox/actions/auth'; import { fetchInstance } from 'soapbox/actions/instance'; import { startOnboarding } from 'soapbox/actions/onboarding'; import snackbar from 'soapbox/actions/snackbar'; import { createAccount, removeStoredVerification } from 'soapbox/actions/verification'; import { Button, Form, FormGroup, Input } from 'soapbox/components/ui'; import { useAppSelector } from 'soapbox/hooks'; import { getRedirectUrl } from 'soapbox/utils/redirect'; const messages = defineMessages({ success: { id: 'registrations.success', defaultMessage: 'Welcome to {siteTitle}!', }, usernameTaken: { id: 'registrations.unprocessable_entity', defaultMessage: 'This username has already been taken.', }, error: { id: 'registrations.error', defaultMessage: 'Failed to register your account.', }, }); const initialState = { username: '', password: '', }; const Registration = () => { const dispatch = useDispatch(); const intl = useIntl(); const isLoading = useAppSelector((state) => state.verification.get('isLoading') as boolean); const siteTitle = useAppSelector((state) => state.instance.title); const [state, setState] = React.useState(initialState); const [shouldRedirect, setShouldRedirect] = React.useState(false); const { username, password } = state; const handleSubmit = React.useCallback((event) => { event.preventDefault(); // TODO: handle validation errors from Pepe dispatch(createAccount(username, password)) .then(() => dispatch(logIn(intl, username, password))) .then(({ access_token }: any) => dispatch(verifyCredentials(access_token))) .then(() => dispatch(fetchInstance())) .then(() => { setShouldRedirect(true); removeStoredVerification(); dispatch(startOnboarding()); dispatch( snackbar.success( intl.formatMessage(messages.success, { siteTitle }), ), ); }) .catch((error: AxiosError) => { if (error?.response?.status === 422) { dispatch( snackbar.error( intl.formatMessage(messages.usernameTaken), ), ); } else { dispatch( snackbar.error( intl.formatMessage(messages.error), ), ); } }); }, [username, password]); const handleInputChange = React.useCallback((event) => { event.persist(); setState((prevState) => ({ ...prevState, [event.target.name]: event.target.value })); }, []); if (shouldRedirect) { const redirectUri = getRedirectUrl(); return ; } return (

); }; export default Registration;