pleroma/app/soapbox/features/verification/waitlist-page.tsx

80 lines
2.8 KiB
TypeScript
Raw Normal View History

import React, { useEffect } from 'react';
import { FormattedMessage } from 'react-intl';
2022-03-21 11:09:01 -07:00
import { Link } from 'react-router-dom';
import { logOut } from 'soapbox/actions/auth';
import { openModal } from 'soapbox/actions/modals';
import LandingGradient from 'soapbox/components/landing-gradient';
import SiteLogo from 'soapbox/components/site-logo';
import { Button, Stack, Text } from 'soapbox/components/ui';
import { useAppDispatch, useInstance, useOwnAccount } from 'soapbox/hooks';
2022-03-21 11:09:01 -07:00
2022-11-26 08:38:16 -08:00
const WaitlistPage = () => {
const dispatch = useAppDispatch();
2022-11-26 08:38:16 -08:00
const instance = useInstance();
2023-06-25 10:35:09 -07:00
const { account: me } = useOwnAccount();
2023-06-20 12:24:39 -07:00
const isSmsVerified = me?.source?.sms_verified ?? true;
2022-03-21 11:09:01 -07:00
const onClickLogOut: React.MouseEventHandler = (event) => {
2022-03-21 11:09:01 -07:00
event.preventDefault();
dispatch(logOut());
2022-03-21 11:09:01 -07:00
};
const openVerifySmsModal = () => dispatch(openModal('VERIFY_SMS'));
useEffect(() => {
if (!isSmsVerified) {
openVerifySmsModal();
}
}, []);
2022-03-21 11:09:01 -07:00
return (
<div>
<LandingGradient />
2023-02-01 14:13:42 -08:00
<main className='relative mx-auto flex h-screen max-w-7xl flex-col px-2 sm:px-6 lg:px-8'>
<header className='relative flex h-16 justify-between'>
<div className='relative flex flex-1 items-stretch justify-center'>
<Link to='/' className='flex shrink-0 cursor-pointer items-center'>
<SiteLogo alt='Logo' className='h-7' />
2022-03-21 11:09:01 -07:00
</Link>
<div className='absolute inset-y-0 right-0 flex items-center pr-2'>
2022-04-19 12:37:48 -07:00
<Button onClick={onClickLogOut} theme='primary' to='/logout'>
<FormattedMessage id='navigation_bar.logout' defaultMessage='Logout' />
2022-03-21 11:09:01 -07:00
</Button>
</div>
</div>
</header>
2023-02-01 14:13:42 -08:00
<div className='-mt-16 flex h-full flex-col items-center justify-center'>
<div className='max-w-xl'>
2022-03-21 11:09:01 -07:00
<Stack space={4}>
2023-02-01 14:13:42 -08:00
<img src='/instance/images/waitlist.png' className='mx-auto h-32 w-32' alt='Waitlisted' />
2022-03-21 11:09:01 -07:00
<Stack space={2}>
<Text size='lg' theme='muted' align='center' weight='medium'>
<FormattedMessage
id='waitlist.body'
defaultMessage='Welcome back to {title}! You were previously placed on our waitlist. Please verify your phone number to receive immediate access to your account!'
values={{ title: instance.title }}
/>
2022-03-21 11:09:01 -07:00
</Text>
<div className='text-center'>
<Button onClick={openVerifySmsModal} theme='primary'>
<FormattedMessage id='waitlist.actions.verify_number' defaultMessage='Verify phone number' />
</Button>
</div>
2022-03-21 11:09:01 -07:00
</Stack>
</Stack>
</div>
</div>
</main>
</div>
);
};
export default WaitlistPage;