Merge branch 'login-add' into 'develop'

Redirect /login when a user is signed in, add /login/add for multiple accounts

See merge request soapbox-pub/soapbox-fe!1586
This commit is contained in:
Alex Gleason 2022-06-29 18:46:12 +00:00
commit 68b0e3bf35
3 changed files with 8 additions and 3 deletions

View file

@ -189,7 +189,7 @@ const SidebarMenu: React.FC = (): JSX.Element | null => {
<div className='border-t border-solid border-gray-200'> <div className='border-t border-solid border-gray-200'>
{otherAccounts.map(account => renderAccount(account))} {otherAccounts.map(account => renderAccount(account))}
<NavLink className='flex py-2 space-x-1' to='/login' onClick={handleClose}> <NavLink className='flex py-2 space-x-1' to='/login/add' onClick={handleClose}>
<Icon className='dark:text-white' src={require('@tabler/icons/icons/plus.svg')} /> <Icon className='dark:text-white' src={require('@tabler/icons/icons/plus.svg')} />
<Text>{intl.formatMessage(messages.addAccount)}</Text> <Text>{intl.formatMessage(messages.addAccount)}</Text>
</NavLink> </NavLink>

View file

@ -4,7 +4,7 @@ import { Link, Redirect, Route, Switch, useHistory, useLocation } from 'react-ro
import LandingGradient from 'soapbox/components/landing-gradient'; import LandingGradient from 'soapbox/components/landing-gradient';
import SiteLogo from 'soapbox/components/site-logo'; import SiteLogo from 'soapbox/components/site-logo';
import { useAppSelector, useFeatures, useSoapboxConfig } from 'soapbox/hooks'; import { useAppSelector, useFeatures, useSoapboxConfig, useOwnAccount } from 'soapbox/hooks';
import { Button, Card, CardBody } from '../../components/ui'; import { Button, Card, CardBody } from '../../components/ui';
import LoginPage from '../auth_login/components/login_page'; import LoginPage from '../auth_login/components/login_page';
@ -25,6 +25,7 @@ const AuthLayout = () => {
const history = useHistory(); const history = useHistory();
const { search } = useLocation(); const { search } = useLocation();
const account = useOwnAccount();
const siteTitle = useAppSelector(state => state.instance.title); const siteTitle = useAppSelector(state => state.instance.title);
const soapboxConfig = useSoapboxConfig(); const soapboxConfig = useSoapboxConfig();
const pepeEnabled = soapboxConfig.getIn(['extensions', 'pepe', 'enabled']) === true; const pepeEnabled = soapboxConfig.getIn(['extensions', 'pepe', 'enabled']) === true;
@ -67,9 +68,13 @@ const AuthLayout = () => {
<Card variant='rounded' size='xl'> <Card variant='rounded' size='xl'>
<CardBody> <CardBody>
<Switch> <Switch>
{/* If already logged in, redirect home. */}
{account && <Redirect from='/login' to='/' exact />}
<Route exact path='/verify' component={Verification} /> <Route exact path='/verify' component={Verification} />
<Route exact path='/verify/email/:token' component={EmailPassthru} /> <Route exact path='/verify/email/:token' component={EmailPassthru} />
<Route exact path='/login/external' component={ExternalLoginForm} /> <Route exact path='/login/external' component={ExternalLoginForm} />
<Route exact path='/login/add' component={LoginPage} />
<Route exact path='/login' component={LoginPage} /> <Route exact path='/login' component={LoginPage} />
<Route exact path='/signup' component={RegistrationForm} /> <Route exact path='/signup' component={RegistrationForm} />
<Route exact path='/reset-password' component={PasswordReset} /> <Route exact path='/reset-password' component={PasswordReset} />

View file

@ -82,7 +82,7 @@ const ProfileDropdown: React.FC<IProfileDropdown> = ({ account, children }) => {
menu.push({ menu.push({
text: intl.formatMessage(messages.add), text: intl.formatMessage(messages.add),
to: '/login', to: '/login/add',
icon: require('@tabler/icons/icons/plus.svg'), icon: require('@tabler/icons/icons/plus.svg'),
}); });