80 lines
3.2 KiB
TypeScript
Raw Permalink Normal View History

import React, { FC, useCallback, useEffect } from 'react';
import { Route, Switch } from 'react-router-dom';
2019-12-07 21:43:08 +02:00
import clsx from 'clsx';
import { useReduxSelector, useReduxDispatch } from 'app/functions';
import { resetAuth } from 'app/components/auth/actions';
import { ScrollIntoView } from 'app/components/ui/scroll';
import PrivateRoute from 'app/containers/PrivateRoute';
import AuthFlowRoute from 'app/containers/AuthFlowRoute';
import { PopupStack } from 'app/components/ui/popup';
import * as loader from 'app/services/loader';
import { getActiveAccount } from 'app/components/accounts/reducer';
2019-12-30 10:15:40 +02:00
import { ComponentLoader } from 'app/components/ui/loader';
import PageNotFound from 'app/pages/404/PageNotFound';
import DeviceCode from 'app/components/auth/deviceCode';
2016-01-03 23:18:42 +02:00
import styles from './root.scss';
import Toolbar from './Toolbar';
2020-07-21 15:53:34 +03:00
2020-10-11 21:19:12 +03:00
const ProfileController = React.lazy(
() => import(/* webpackChunkName: "page-profile-all" */ 'app/pages/profile/ProfileController'),
2019-12-30 10:15:40 +02:00
);
2020-05-24 02:08:24 +03:00
const RulesPage = React.lazy(() => import(/* webpackChunkName: "page-rules" */ 'app/pages/rules/RulesPage'));
const DevPage = React.lazy(() => import(/* webpackChunkName: "page-dev-applications" */ 'app/pages/dev/DevPage'));
const AuthPage = React.lazy(() => import(/* webpackChunkName: "page-auth" */ 'app/pages/auth/AuthPage'));
2019-12-30 10:15:40 +02:00
const RootPage: FC = () => {
const dispatch = useReduxDispatch();
const user = useReduxSelector((state) => state.user);
const account = useReduxSelector(getActiveAccount);
const isPopupActive = useReduxSelector((state) => state.popup.popups.length > 0);
const onLogoClick = useCallback(() => {
dispatch(resetAuth());
}, []);
useEffect(() => {
2020-05-24 02:08:24 +03:00
loader.hide();
}); // No deps, effect must be called on every update
return (
<div className={styles.root}>
<ScrollIntoView top />
<div
id="view-port"
className={clsx(styles.viewPort, {
[styles.isPopupActive]: isPopupActive,
})}
>
<Toolbar account={account} onLogoClick={onLogoClick} />
<div className={styles.body}>
<React.Suspense fallback={<ComponentLoader />}>
<Switch>
<PrivateRoute path="/profile" component={ProfileController} />
<Route path="/404" component={PageNotFound} />
<Route path="/rules" component={RulesPage} />
<Route path="/dev" component={DevPage} />
2019-12-10 09:47:32 +02:00
<AuthFlowRoute
exact
path="/"
key="indexPage"
component={user.isGuest ? AuthPage : ProfileController}
/>
<AuthFlowRoute exact path="/code" component={DeviceCode} />
<AuthFlowRoute path="/" component={AuthPage} />
<Route component={PageNotFound} />
</Switch>
</React.Suspense>
2020-05-24 02:08:24 +03:00
</div>
</div>
<PopupStack />
</div>
);
};
export default RootPage;