zcash-grant-system/admin/src/Routes.tsx

70 lines
2.7 KiB
TypeScript
Raw Normal View History

import React from 'react';
import { view } from 'react-easy-state';
import { hot } from 'react-hot-loader';
import { Switch, Route, RouteComponentProps, withRouter } from 'react-router';
import Template from 'components/Template';
import store from './store';
import Login from 'components/Login';
2019-02-21 14:23:46 -08:00
import MFAuth from 'components/MFAuth';
import Home from 'components/Home';
import Users from 'components/Users';
import UserDetail from 'components/UserDetail';
import Emails from 'components/Emails';
import Proposals from 'components/Proposals';
import ProposalDetail from 'components/ProposalDetail';
import RFPs from 'components/RFPs';
import RFPForm from 'components/RFPForm';
import RFPDetail from 'components/RFPDetail';
import Contributions from 'components/Contributions';
import ContributionForm from 'components/ContributionForm';
import ContributionDetail from 'components/ContributionDetail';
import Moderation from 'components/Moderation';
2019-02-21 21:22:16 -08:00
import Settings from 'components/Settings';
import 'styles/style.less';
type Props = RouteComponentProps<any>;
class Routes extends React.Component<Props> {
render() {
const { hasCheckedLogin, isLoggedIn, is2faAuthed } = store;
if (!hasCheckedLogin) {
return <div>checking auth status...</div>;
}
2019-02-21 14:23:46 -08:00
return (
<Template>
2019-02-21 14:23:46 -08:00
{!isLoggedIn ? (
<Login />
2019-02-21 14:23:46 -08:00
) : !is2faAuthed ? (
<MFAuth />
) : (
<Switch>
<Route path="/" exact={true} component={Home} />
<Route path="/users/:id" component={UserDetail} />
<Route path="/users" component={Users} />
<Route path="/proposals/:id" component={ProposalDetail} />
<Route path="/proposals" component={Proposals} />
<Route path="/rfps/new" component={RFPForm} />
<Route path="/rfps/:id/edit" component={RFPForm} />
<Route path="/rfps/:id" component={RFPDetail} />
<Route path="/rfps" component={RFPs} />
<Route path="/contributions/new" component={ContributionForm} />
<Route path="/contributions/:id/edit" component={ContributionForm} />
<Route path="/contributions/:id" component={ContributionDetail} />
<Route path="/contributions" component={Contributions} />
<Route path="/emails/:type?" component={Emails} />
<Route path="/moderation" component={Moderation} />
2019-02-21 21:22:16 -08:00
<Route path="/settings/2fa-reset" render={() => <MFAuth isReset={true} />} />
<Route path="/settings" component={Settings} />
</Switch>
)}
</Template>
);
}
}
const ConnectedRoutes = withRouter(view(Routes));
export default hot(module)(ConnectedRoutes);