2022-06-09 12:22:19 -07:00
import React from 'react' ;
2022-05-24 03:24:26 -07:00
import { defineMessages , FormattedMessage , useIntl } from 'react-intl' ;
2022-03-21 11:09:01 -07:00
import { verifyAge } from 'soapbox/actions/verification' ;
2022-06-08 09:06:05 -07:00
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
2022-05-24 03:24:26 -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
2022-06-09 12:22:19 -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 ( ) ;
2022-06-09 12:22:19 -07:00
const dispatch = useAppDispatch ( ) ;
2022-11-26 08:38:16 -08:00
const instance = useInstance ( ) ;
2022-03-21 11:09:01 -07:00
2022-06-20 06:46:43 -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' >
2022-05-24 03:24:26 -07:00
< 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 } >
2022-06-08 09:06:05 -07:00
< Datepicker onChange = { onChange } / >
2022-03-21 11:09:01 -07:00
< Text theme = 'muted' size = 'sm' >
2022-11-26 05:09:28 -08:00
< FormattedMessage
id = 'age_verification.body'
2023-06-05 07:25:48 -07:00
defaultMessage = '{siteTitle} requires users to be at least {ageMinimum, plural, one {# year} other {# years}} old to access its platform. Anyone under the age of {ageMinimum, plural, one {# year} other {# years}} old cannot access this platform.'
2022-11-26 05:09:28 -08:00
values = { {
2022-11-26 08:45:13 -08:00
siteTitle : instance.title ,
2022-11-26 05:09:28 -08:00
ageMinimum ,
} }
/ >
2022-03-21 11:09:01 -07:00
< / Text >
< div className = 'text-center' >
2022-11-26 05:09:28 -08:00
< 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 ;