pleroma/app/soapbox/features/landing_page/index.tsx

102 lines
3.4 KiB
TypeScript
Raw Normal View History

2022-03-21 11:09:01 -07:00
import * as React from 'react';
import { FormattedMessage } from 'react-intl';
2022-03-21 11:09:01 -07:00
import VerificationBadge from 'soapbox/components/verification_badge';
import RegistrationForm from 'soapbox/features/auth_login/components/registration_form';
import { useAppSelector, useFeatures, useSoapboxConfig } from 'soapbox/hooks';
2022-03-21 11:45:57 -07:00
import { Button, Card, CardBody, Stack, Text } from '../../components/ui';
2022-03-21 11:09:01 -07:00
const LandingPage = () => {
const features = useFeatures();
const soapboxConfig = useSoapboxConfig();
const pepeEnabled = soapboxConfig.getIn(['extensions', 'pepe', 'enabled']) === true;
const instance = useAppSelector((state) => state.instance);
const pepeOpen = useAppSelector(state => state.verification.getIn(['instance', 'registrations'], false) === true);
/** Registrations are closed */
2022-03-21 11:09:01 -07:00
const renderClosed = () => {
return (
<Stack space={3} data-testid='registrations-closed'>
2022-03-21 11:09:01 -07:00
<Text size='xl' weight='bold' align='center'>
<FormattedMessage
id='registration.closed_title'
defaultMessage='Registrations Closed'
/>
2022-03-21 11:09:01 -07:00
</Text>
<Text theme='muted' align='center'>
<FormattedMessage
id='registration.closed_message'
2022-03-21 11:09:01 -07:00
defaultMessage='{instance} is not accepting new members.'
values={{ instance: instance.title }}
/>
2022-03-21 11:09:01 -07:00
</Text>
</Stack>
);
2022-03-21 11:09:01 -07:00
};
/** Mastodon API registrations are open */
const renderOpen = () => {
return <RegistrationForm />;
};
/** Pepe API registrations are open */
const renderPepe = () => {
return (
<Stack space={3} data-testid='registrations-pepe'>
<VerificationBadge className='h-16 w-16 mx-auto' />
<Stack>
<Text size='2xl' weight='bold' align='center'>Let&apos;s get started!</Text>
<Text theme='muted' align='center'>Social Media Without Discrimination</Text>
</Stack>
2022-04-30 09:28:18 -07:00
<Button to='/verify' theme='primary' block>Create an account</Button>
</Stack>
);
};
// Render registration flow depending on features
const renderBody = () => {
if (pepeEnabled && pepeOpen) {
return renderPepe();
} else if (features.accountCreation && instance.registrations) {
return renderOpen();
} else {
return renderClosed();
}
};
2022-03-21 11:09:01 -07:00
return (
2022-04-21 12:29:25 -07:00
<main className='mt-16 sm:mt-24' data-testid='homepage'>
2022-03-21 11:09:01 -07:00
<div className='mx-auto max-w-7xl'>
2022-05-10 12:52:12 -07:00
<div className='grid grid-cols-1 lg:grid-cols-12 gap-8 py-12'>
2022-04-19 15:27:23 -07:00
<div className='px-4 sm:px-6 sm:text-center md:max-w-2xl md:mx-auto lg:col-span-6 lg:text-left lg:flex'>
2022-03-21 11:09:01 -07:00
<div>
<Stack space={3}>
2022-05-07 13:45:29 -07:00
<h1 className='text-5xl font-extrabold text-transparent bg-clip-text bg-gradient-to-br from-accent-500 via-primary-500 to-gradient-end sm:mt-5 sm:leading-none lg:mt-6 lg:text-6xl xl:text-7xl'>
2022-03-21 11:45:57 -07:00
{instance.title}
2022-03-21 11:09:01 -07:00
</h1>
2022-05-10 12:52:12 -07:00
2022-03-21 11:09:01 -07:00
<Text size='lg'>
2022-03-21 11:45:57 -07:00
{instance.description}
2022-03-21 11:09:01 -07:00
</Text>
</Stack>
2020-04-10 13:24:12 -07:00
</div>
</div>
<div className='sm:mt-24 lg:mt-0 lg:col-span-6 self-center'>
2022-03-21 11:09:01 -07:00
<Card size='xl' variant='rounded' className='sm:max-w-md sm:w-full sm:mx-auto'>
<CardBody>
{renderBody()}
2022-03-21 11:09:01 -07:00
</CardBody>
</Card>
2020-04-10 13:24:12 -07:00
</div>
</div>
2022-03-21 11:09:01 -07:00
</div>
</main>
);
};
2022-03-21 11:09:01 -07:00
export default LandingPage;