pleroma/app/soapbox/features/verification/steps/age-verification.tsx

85 lines
2.8 KiB
TypeScript
Raw Normal View History

import React from 'react';
import { defineMessages, FormattedMessage, useIntl } from 'react-intl';
2022-03-21 11:09:01 -07:00
import { verifyAge } from 'soapbox/actions/verification';
import { Button, Datepicker, Form, Text } from 'soapbox/components/ui';
2022-11-26 08:38:16 -08:00
import { useAppDispatch, useAppSelector, useInstance } from 'soapbox/hooks';
2022-12-20 08:34:53 -08:00
import toast from 'soapbox/toast';
2022-03-21 11:09:01 -07:00
const messages = defineMessages({
fail: {
id: 'age_verification.fail',
defaultMessage: 'You must be {ageMinimum, plural, one {# year} other {# years}} old or older.',
},
});
2022-03-21 11:09:01 -07:00
function meetsAgeMinimum(birthday: Date, ageMinimum: number) {
2022-03-21 11:09:01 -07:00
const month = birthday.getUTCMonth();
const day = birthday.getUTCDate();
const year = birthday.getUTCFullYear();
return new Date(year + ageMinimum, month, day) <= new Date();
}
const AgeVerification = () => {
const intl = useIntl();
const dispatch = useAppDispatch();
2022-11-26 08:38:16 -08:00
const instance = useInstance();
2022-03-21 11:09:01 -07:00
const isLoading = useAppSelector((state) => state.verification.isLoading) as boolean;
const ageMinimum = useAppSelector((state) => state.verification.ageMinimum) as any;
2022-03-21 11:09:01 -07:00
2023-01-10 15:03:15 -08:00
const [date, setDate] = React.useState<Date>();
2022-03-21 11:09:01 -07:00
const isValid = typeof date === 'object';
2023-01-10 15:03:15 -08:00
const onChange = React.useCallback((date: Date) => setDate(date), []);
2022-03-21 11:09:01 -07:00
2023-01-10 15:03:15 -08:00
const handleSubmit: React.FormEventHandler = React.useCallback((event) => {
2022-03-21 11:09:01 -07:00
event.preventDefault();
2023-01-10 15:03:15 -08:00
const birthday = new Date(date!);
2022-03-21 11:09:01 -07:00
if (meetsAgeMinimum(birthday, ageMinimum)) {
dispatch(verifyAge(birthday));
} else {
2022-12-20 08:34:53 -08:00
toast.error(intl.formatMessage(messages.fail, { ageMinimum }));
2022-03-21 11:09:01 -07:00
}
}, [date, ageMinimum]);
return (
<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'>
<h1 className='text-center text-2xl font-bold'>
<FormattedMessage id='age_verification.header' defaultMessage='Enter your birth date' />
2022-03-21 11:09:01 -07:00
</h1>
</div>
2023-02-01 14:13:42 -08:00
<div className='mx-auto sm:pt-10 md:w-2/3'>
2022-04-04 08:54:00 -07:00
<Form onSubmit={handleSubmit}>
<Datepicker onChange={onChange} />
2022-03-21 11:09:01 -07:00
<Text theme='muted' size='sm'>
<FormattedMessage
id='age_verification.body'
defaultMessage='{siteTitle} requires users to be at least {ageMinimum, plural, one {# year} other {# years}} years old to access its platform. Anyone under the age of {ageMinimum, plural, one {# year} other {# years}} old cannot access this platform.'
values={{
siteTitle: instance.title,
ageMinimum,
}}
/>
2022-03-21 11:09:01 -07:00
</Text>
<div className='text-center'>
<Button block theme='primary' type='submit' disabled={isLoading || !isValid}>
<FormattedMessage id='onboarding.next' defaultMessage='Next' />
</Button>
2022-03-21 11:09:01 -07:00
</div>
</Form>
</div>
</div>
);
};
export default AgeVerification;