blob: ea7035673ef4f7c6bf9a07ef664c03cabf35b9bc (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
|
import React from 'react'
import { BrowserRouter, Redirect, Route, Switch } from 'react-router-dom'
import { userIsLoggedIn } from '../auth/index'
import App from '../pages/App'
import Experiments from '../pages/Experiments'
import Home from '../pages/Home'
import NotFound from '../pages/NotFound'
import Profile from '../pages/Profile'
import Simulations from '../pages/Simulations'
const ProtectedComponent = (component) => () => (userIsLoggedIn() ? component : <Redirect to="/" />)
const AppComponent = ({ match }) =>
userIsLoggedIn() ? <App simulationId={match.params.simulationId} /> : <Redirect to="/" />
const ExperimentsComponent = ({ match }) =>
userIsLoggedIn() ? <Experiments simulationId={match.params.simulationId} /> : <Redirect to="/" />
const SimulationComponent = ({ match }) =>
userIsLoggedIn() ? (
<App simulationId={match.params.simulationId} inSimulation={true} experimentId={match.params.experimentId} />
) : (
<Redirect to="/" />
)
const Routes = () => (
<BrowserRouter>
<Switch>
<Route exact path="/" component={Home} />
<Route exact path="/simulations" render={ProtectedComponent(<Simulations />)} />
<Route exact path="/simulations/:simulationId" component={AppComponent} />
<Route exact path="/simulations/:simulationId/experiments" component={ExperimentsComponent} />
<Route exact path="/simulations/:simulationId/experiments/:experimentId" component={SimulationComponent} />
<Route exact path="/profile" render={ProtectedComponent(<Profile />)} />
<Route path="/*" component={NotFound} />
</Switch>
</BrowserRouter>
)
export default Routes
|