2022-11-25 09:04:11 -08:00
|
|
|
import React from 'react';
|
2022-11-26 05:09:28 -08:00
|
|
|
import { defineMessages, FormattedMessage, useIntl } from 'react-intl';
|
2022-04-12 06:52:04 -07:00
|
|
|
|
|
|
|
import { patchMe } from 'soapbox/actions/me';
|
|
|
|
import { Button, Card, CardBody, FormGroup, Stack, Text, Textarea } from 'soapbox/components/ui';
|
2023-01-09 14:13:12 -08:00
|
|
|
import { useAppDispatch, useOwnAccount } from 'soapbox/hooks';
|
2022-12-20 08:34:53 -08:00
|
|
|
import toast from 'soapbox/toast';
|
2022-04-12 06:52:04 -07:00
|
|
|
|
2022-06-09 12:08:51 -07:00
|
|
|
import type { AxiosError } from 'axios';
|
|
|
|
|
2022-11-26 05:09:28 -08:00
|
|
|
const messages = defineMessages({
|
|
|
|
bioPlaceholder: { id: 'onboarding.bio.placeholder', defaultMessage: 'Tell the world a little about yourself…' },
|
2022-11-26 07:00:54 -08:00
|
|
|
error: { id: 'onboarding.error', defaultMessage: 'An unexpected error occurred. Please try again or skip this step.' },
|
2022-11-26 05:09:28 -08:00
|
|
|
});
|
|
|
|
|
2022-04-12 06:52:04 -07:00
|
|
|
const BioStep = ({ onNext }: { onNext: () => void }) => {
|
2022-11-26 05:09:28 -08:00
|
|
|
const intl = useIntl();
|
2023-01-09 14:13:12 -08:00
|
|
|
const dispatch = useAppDispatch();
|
2022-04-12 06:52:04 -07:00
|
|
|
|
2022-04-20 10:08:49 -07:00
|
|
|
const account = useOwnAccount();
|
2023-06-20 12:24:39 -07:00
|
|
|
const [value, setValue] = React.useState<string>(account?.source?.note ?? '');
|
2022-04-12 06:52:04 -07:00
|
|
|
const [isSubmitting, setSubmitting] = React.useState<boolean>(false);
|
|
|
|
const [errors, setErrors] = React.useState<string[]>([]);
|
|
|
|
|
|
|
|
const handleSubmit = () => {
|
|
|
|
setSubmitting(true);
|
|
|
|
|
|
|
|
const credentials = dispatch(patchMe({ note: value }));
|
|
|
|
|
|
|
|
Promise.all([credentials])
|
|
|
|
.then(() => {
|
|
|
|
setSubmitting(false);
|
|
|
|
onNext();
|
|
|
|
}).catch((error: AxiosError) => {
|
|
|
|
setSubmitting(false);
|
|
|
|
|
|
|
|
if (error.response?.status === 422) {
|
2022-04-29 14:01:46 -07:00
|
|
|
setErrors([(error.response.data as any).error.replace('Validation failed: ', '')]);
|
2022-04-12 06:52:04 -07:00
|
|
|
} else {
|
2022-12-20 08:34:53 -08:00
|
|
|
toast.error(messages.error);
|
2022-04-12 06:52:04 -07:00
|
|
|
}
|
|
|
|
});
|
|
|
|
};
|
|
|
|
|
|
|
|
return (
|
|
|
|
<Card variant='rounded' size='xl'>
|
|
|
|
<CardBody>
|
|
|
|
<div>
|
2023-02-01 14:13:42 -08:00
|
|
|
<div className='-mx-4 mb-4 border-b border-solid border-gray-200 pb-4 dark:border-gray-800 sm:-mx-10 sm:pb-10'>
|
2022-04-12 06:52:04 -07:00
|
|
|
<Stack space={2}>
|
|
|
|
<Text size='2xl' align='center' weight='bold'>
|
2022-04-12 11:25:53 -07:00
|
|
|
<FormattedMessage id='onboarding.note.title' defaultMessage='Write a short bio' />
|
2022-04-12 06:52:04 -07:00
|
|
|
</Text>
|
|
|
|
|
|
|
|
<Text theme='muted' align='center'>
|
2022-04-12 11:25:53 -07:00
|
|
|
<FormattedMessage id='onboarding.note.subtitle' defaultMessage='You can always edit this later.' />
|
2022-04-12 06:52:04 -07:00
|
|
|
</Text>
|
|
|
|
</Stack>
|
|
|
|
</div>
|
|
|
|
|
|
|
|
<Stack space={5}>
|
2023-02-01 14:13:42 -08:00
|
|
|
<div className='mx-auto sm:w-2/3 sm:pt-10'>
|
2022-04-12 06:52:04 -07:00
|
|
|
<FormGroup
|
2022-11-26 05:09:28 -08:00
|
|
|
hintText={<FormattedMessage id='onboarding.bio.hint' defaultMessage='Max 500 characters' />}
|
|
|
|
labelText={<FormattedMessage id='edit_profile.fields.bio_label' defaultMessage='Bio' />}
|
2022-04-12 06:52:04 -07:00
|
|
|
errors={errors}
|
|
|
|
>
|
|
|
|
<Textarea
|
|
|
|
onChange={(event) => setValue(event.target.value)}
|
2022-11-26 05:09:28 -08:00
|
|
|
placeholder={intl.formatMessage(messages.bioPlaceholder)}
|
2022-04-12 06:52:04 -07:00
|
|
|
value={value}
|
|
|
|
maxLength={500}
|
|
|
|
/>
|
|
|
|
</FormGroup>
|
|
|
|
</div>
|
|
|
|
|
2023-02-01 14:13:42 -08:00
|
|
|
<div className='mx-auto sm:w-2/3 md:w-1/2'>
|
2022-04-12 06:52:04 -07:00
|
|
|
<Stack justifyContent='center' space={2}>
|
|
|
|
<Button
|
|
|
|
block
|
|
|
|
theme='primary'
|
|
|
|
type='submit'
|
2022-09-27 07:35:35 -07:00
|
|
|
disabled={isSubmitting}
|
2022-04-12 06:52:04 -07:00
|
|
|
onClick={handleSubmit}
|
|
|
|
>
|
2022-04-12 11:25:53 -07:00
|
|
|
{isSubmitting ? (
|
2022-04-22 09:18:36 -07:00
|
|
|
<FormattedMessage id='onboarding.saving' defaultMessage='Saving…' />
|
2022-04-12 11:25:53 -07:00
|
|
|
) : (
|
|
|
|
<FormattedMessage id='onboarding.next' defaultMessage='Next' />
|
|
|
|
)}
|
2022-04-12 06:52:04 -07:00
|
|
|
</Button>
|
|
|
|
|
2022-07-22 10:30:16 -07:00
|
|
|
<Button block theme='tertiary' type='button' onClick={onNext}>
|
2022-04-12 11:25:53 -07:00
|
|
|
<FormattedMessage id='onboarding.skip' defaultMessage='Skip for now' />
|
|
|
|
</Button>
|
2022-04-12 06:52:04 -07:00
|
|
|
</Stack>
|
|
|
|
</div>
|
|
|
|
</Stack>
|
|
|
|
</div>
|
|
|
|
</CardBody>
|
|
|
|
</Card>
|
|
|
|
);
|
|
|
|
};
|
|
|
|
|
|
|
|
export default BioStep;
|