import * as React from 'react'; import { FormattedMessage } from 'react-intl'; import { Button, Card, CardBody, Stack, Text } from 'soapbox/components/ui'; import VerificationBadge from 'soapbox/components/verification_badge'; import RegistrationForm from 'soapbox/features/auth_login/components/registration_form'; import { useAppSelector, useFeatures, useSoapboxConfig } from 'soapbox/hooks'; 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 */ const renderClosed = () => { return ( ); }; /** Mastodon API registrations are open */ const renderOpen = () => { return ; }; /** Pepe API registrations are open */ const renderPepe = () => { return ( Let's get started! Social Media Without Discrimination Create an account ); }; // Render registration flow depending on features const renderBody = () => { if (pepeEnabled && pepeOpen) { return renderPepe(); } else if (features.accountCreation && instance.registrations) { return renderOpen(); } else { return renderClosed(); } }; return ( {instance.title} {instance.description} {renderBody()} ); }; export default LandingPage;