summaryrefslogtreecommitdiff
path: root/frontend/src/routes/index.js
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