125 lines
4.7 KiB
TypeScript
Raw Normal View History

2019-12-10 09:47:32 +02:00
import React from 'react';
import { connect } from 'react-redux';
import { resetAuth } from 'app/components/auth/actions';
import { withRouter } from 'react-router-dom';
import { FormattedMessage as Message } from 'react-intl';
import { Route, Link, Switch } from 'react-router-dom';
import { Helmet } from 'react-helmet-async';
2019-12-07 21:43:08 +02:00
import clsx from 'clsx';
import { ScrollIntoView } from 'app/components/ui/scroll';
import PrivateRoute from 'app/containers/PrivateRoute';
import AuthFlowRoute from 'app/containers/AuthFlowRoute';
import Userbar from 'app/components/userbar/Userbar';
import PopupStack from 'app/components/ui/popup/PopupStack';
import * as loader from 'app/services/loader';
import { getActiveAccount } from 'app/components/accounts/reducer';
import { User } from 'app/components/user';
import { Account } from 'app/components/accounts/reducer';
import { RootState } from 'app/reducers';
2019-12-30 10:15:40 +02:00
import { ComponentLoader } from 'app/components/ui/loader';
2016-01-03 23:18:42 +02:00
import styles from './root.scss';
import siteName from './siteName.intl';
2019-12-30 10:15:40 +02:00
const ProfilePage = React.lazy(() =>
2020-05-24 02:08:24 +03:00
import(/* webpackChunkName: "page-profile-all" */ 'app/pages/profile/ProfilePage'),
2019-12-30 10:15:40 +02:00
);
2020-05-24 02:08:24 +03:00
const PageNotFound = React.lazy(() => import(/* webpackChunkName: "page-not-found" */ 'app/pages/404/PageNotFound'));
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
2019-12-10 09:47:32 +02:00
class RootPage extends React.PureComponent<{
2020-05-24 02:08:24 +03:00
account: Account | null;
user: User;
isPopupActive: boolean;
onLogoClick: (event: React.MouseEvent<HTMLAnchorElement>) => void;
location: {
pathname: string;
};
2017-08-22 23:31:41 +03:00
}> {
2020-05-24 02:08:24 +03:00
componentDidMount() {
this.onPageUpdate();
}
2020-05-24 02:08:24 +03:00
componentDidUpdate() {
this.onPageUpdate();
}
2020-05-24 02:08:24 +03:00
onPageUpdate() {
loader.hide();
}
2020-05-24 02:08:24 +03:00
render() {
const { props } = this;
const { user, account, isPopupActive, onLogoClick } = this.props;
const isRegisterPage = props.location.pathname === '/register';
2020-05-24 02:08:24 +03:00
if (document && document.body) {
document.body.style.overflow = isPopupActive ? 'hidden' : '';
}
2020-05-24 02:08:24 +03:00
return (
<div className={styles.root}>
<Helmet>
<html lang={user.lang} />
</Helmet>
2020-05-24 02:08:24 +03:00
<ScrollIntoView top />
2020-05-24 02:08:24 +03:00
<div
id="view-port"
className={clsx(styles.viewPort, {
[styles.isPopupActive]: isPopupActive,
})}
>
<div className={styles.header} data-testid="toolbar">
<div className={styles.headerContent}>
<Link to="/" className={styles.logo} onClick={onLogoClick} data-testid="home-page">
<Message {...siteName} />
2020-05-24 02:08:24 +03:00
</Link>
<div className={styles.userbar}>
<Userbar account={account} guestAction={isRegisterPage ? 'login' : 'register'} />
</div>
</div>
</div>
<div className={styles.body}>
<React.Suspense fallback={<ComponentLoader />}>
<Switch>
<PrivateRoute path="/profile" component={ProfilePage} />
<Route path="/404" component={PageNotFound} />
<Route path="/rules" component={RulesPage} />
<Route path="/dev" component={DevPage} />
2019-12-10 09:47:32 +02:00
2020-05-24 02:08:24 +03:00
<AuthFlowRoute
exact
path="/"
key="indexPage"
component={user.isGuest ? AuthPage : ProfilePage}
/>
<AuthFlowRoute path="/" component={AuthPage} />
2020-05-24 02:08:24 +03:00
<Route component={PageNotFound} />
</Switch>
</React.Suspense>
</div>
</div>
<PopupStack />
</div>
);
}
2016-01-03 23:18:42 +02:00
}
export default withRouter(
2020-05-24 02:08:24 +03:00
connect(
(state: RootState) => ({
user: state.user,
account: getActiveAccount(state),
isPopupActive: state.popup.popups.length > 0,
}),
{
onLogoClick: resetAuth,
},
)(RootPage),
);