2019-12-10 09:47:32 +02:00
|
|
|
import React from 'react';
|
2017-09-09 21:01:02 +03:00
|
|
|
import { connect } from 'react-redux';
|
2019-12-07 21:02:00 +02:00
|
|
|
import { resetAuth } from 'app/components/auth/actions';
|
2019-06-30 16:32:50 +03:00
|
|
|
import { withRouter } from 'react-router-dom';
|
2016-05-20 00:30:28 +03:00
|
|
|
import { FormattedMessage as Message } from 'react-intl';
|
2017-05-25 22:11:57 +03:00
|
|
|
import { Route, Link, Switch } from 'react-router-dom';
|
2019-12-30 09:29:39 +02:00
|
|
|
import { Helmet } from 'react-helmet-async';
|
2019-12-07 21:43:08 +02:00
|
|
|
import clsx from 'clsx';
|
2019-12-07 21:02:00 +02:00
|
|
|
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';
|
2020-01-17 23:37:52 +03:00
|
|
|
import * as loader from 'app/services/loader';
|
2019-12-07 21:02:00 +02:00
|
|
|
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';
|
2016-05-20 00:30:28 +03:00
|
|
|
import messages from './RootPage.intl.json';
|
|
|
|
|
2019-12-30 10:15:40 +02:00
|
|
|
const ProfilePage = React.lazy(() =>
|
|
|
|
import(
|
|
|
|
/* webpackChunkName: "page-profile-all" */ 'app/pages/profile/ProfilePage'
|
|
|
|
),
|
|
|
|
);
|
|
|
|
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-10 09:47:32 +02:00
|
|
|
class RootPage extends React.PureComponent<{
|
2019-12-07 13:28:52 +02:00
|
|
|
account: Account | null;
|
|
|
|
user: User;
|
|
|
|
isPopupActive: boolean;
|
|
|
|
onLogoClick: (event: React.MouseEvent<HTMLAnchorElement>) => void;
|
2019-11-27 11:03:32 +02:00
|
|
|
location: {
|
2019-12-07 13:28:52 +02:00
|
|
|
pathname: string;
|
|
|
|
};
|
2017-08-22 23:31:41 +03:00
|
|
|
}> {
|
2019-11-27 11:03:32 +02:00
|
|
|
componentDidMount() {
|
|
|
|
this.onPageUpdate();
|
|
|
|
}
|
2017-05-25 22:11:57 +03:00
|
|
|
|
2019-11-27 11:03:32 +02:00
|
|
|
componentDidUpdate() {
|
|
|
|
this.onPageUpdate();
|
|
|
|
}
|
2017-05-25 22:11:57 +03:00
|
|
|
|
2019-11-27 11:03:32 +02:00
|
|
|
onPageUpdate() {
|
|
|
|
loader.hide();
|
|
|
|
}
|
2016-06-05 13:31:17 +03:00
|
|
|
|
2019-11-27 11:03:32 +02:00
|
|
|
render() {
|
|
|
|
const { props } = this;
|
|
|
|
const { user, account, isPopupActive, onLogoClick } = this.props;
|
|
|
|
const isRegisterPage = props.location.pathname === '/register';
|
2016-10-09 20:54:35 +03:00
|
|
|
|
2019-11-27 11:03:32 +02:00
|
|
|
if (document && document.body) {
|
|
|
|
document.body.style.overflow = isPopupActive ? 'hidden' : '';
|
|
|
|
}
|
2017-05-25 22:11:57 +03:00
|
|
|
|
2019-11-27 11:03:32 +02:00
|
|
|
return (
|
|
|
|
<div className={styles.root}>
|
|
|
|
<Helmet>
|
|
|
|
<html lang={user.lang} />
|
|
|
|
</Helmet>
|
2017-10-28 16:38:07 +03:00
|
|
|
|
2019-11-27 11:03:32 +02:00
|
|
|
<ScrollIntoView top />
|
2017-10-28 16:38:07 +03:00
|
|
|
|
2019-11-27 11:03:32 +02:00
|
|
|
<div
|
|
|
|
id="view-port"
|
2019-12-07 21:43:08 +02:00
|
|
|
className={clsx(styles.viewPort, {
|
2019-11-27 11:03:32 +02:00
|
|
|
[styles.isPopupActive]: isPopupActive,
|
|
|
|
})}
|
|
|
|
>
|
2019-12-27 21:01:59 +02:00
|
|
|
<div className={styles.header} data-testid="toolbar">
|
2019-11-27 11:03:32 +02:00
|
|
|
<div className={styles.headerContent}>
|
2019-12-29 18:26:51 +02:00
|
|
|
<Link
|
|
|
|
to="/"
|
|
|
|
className={styles.logo}
|
|
|
|
onClick={onLogoClick}
|
|
|
|
data-testid="home-page"
|
|
|
|
>
|
2019-11-27 11:03:32 +02:00
|
|
|
<Message {...messages.siteName} />
|
|
|
|
</Link>
|
|
|
|
<div className={styles.userbar}>
|
|
|
|
<Userbar
|
|
|
|
account={account}
|
|
|
|
guestAction={isRegisterPage ? 'login' : 'register'}
|
|
|
|
/>
|
|
|
|
</div>
|
2016-01-03 23:18:42 +02:00
|
|
|
</div>
|
2019-11-27 11:03:32 +02:00
|
|
|
</div>
|
|
|
|
<div className={styles.body}>
|
2019-12-30 10:15:40 +02:00
|
|
|
<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
|
|
|
|
2019-12-30 10:15:40 +02:00
|
|
|
<AuthFlowRoute
|
|
|
|
exact
|
|
|
|
path="/"
|
|
|
|
key="indexPage"
|
|
|
|
component={user.isGuest ? AuthPage : ProfilePage}
|
|
|
|
/>
|
|
|
|
<AuthFlowRoute path="/" component={AuthPage} />
|
2019-12-26 14:18:58 +02:00
|
|
|
|
2019-12-30 10:15:40 +02:00
|
|
|
<Route component={PageNotFound} />
|
|
|
|
</Switch>
|
|
|
|
</React.Suspense>
|
2019-11-27 11:03:32 +02:00
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
<PopupStack />
|
|
|
|
</div>
|
|
|
|
);
|
|
|
|
}
|
2016-01-03 23:18:42 +02:00
|
|
|
}
|
2016-02-13 17:28:47 +02:00
|
|
|
|
2019-11-27 11:03:32 +02:00
|
|
|
export default withRouter(
|
|
|
|
connect(
|
2019-12-07 13:28:52 +02:00
|
|
|
(state: RootState) => ({
|
2019-11-27 11:03:32 +02:00
|
|
|
user: state.user,
|
|
|
|
account: getActiveAccount(state),
|
|
|
|
isPopupActive: state.popup.popups.length > 0,
|
|
|
|
}),
|
|
|
|
{
|
|
|
|
onLogoClick: resetAuth,
|
|
|
|
},
|
|
|
|
)(RootPage),
|
|
|
|
);
|