import * as React from 'react';
import { useIntl } from 'react-intl';
import { useDispatch, useSelector } from 'react-redux';
import { Redirect } from 'react-router-dom';
import { logIn, verifyCredentials } from 'soapbox/actions/auth';
import { fetchInstance } from 'soapbox/actions/instance';
import snackbar from 'soapbox/actions/snackbar';
import { createAccount } from 'soapbox/actions/verification';
import { removeStoredVerification } from 'soapbox/actions/verification';
import { Button, Form, FormGroup, Input } from '../../components/ui';
const initialState = {
username: '',
password: '',
};
const Registration = () => {
const dispatch = useDispatch();
const intl = useIntl();
const isLoading = useSelector((state) => state.verification.get('isLoading'));
const siteTitle = useSelector((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 }) => dispatch(verifyCredentials(access_token)))
.then(() => dispatch(fetchInstance()))
.then(() => {
setShouldRedirect(true);
removeStoredVerification();
dispatch(
snackbar.success(
intl.formatMessage({
id: 'registrations.success',
defaultMessage: 'Welcome to {siteTitle}!',
}, { siteTitle }),
),
);
})
.catch((error) => {
if (error?.response?.status === 422) {
dispatch(
snackbar.error(
intl.formatMessage({
id: 'registrations.unprocessable_entity',
defaultMessage: 'This username has already been taken.',
}),
),
);
} else {
dispatch(
snackbar.error(
intl.formatMessage({
id: 'registrations.error',
defaultMessage: 'Failed to register your account.',
}),
),
);
}
});
}, [username, password]);
const handleInputChange = React.useCallback((event) => {
event.persist();
setState((prevState) => ({ ...prevState, [event.target.name]: event.target.value }));
}, []);
if (shouldRedirect) {
return