forked from StackStorm/st2web
-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathmain.js
More file actions
73 lines (63 loc) · 1.8 KB
/
main.js
File metadata and controls
73 lines (63 loc) · 1.8 KB
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
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
import React from 'react';
import ReactDOM from 'react-dom';
import {
Router,
Redirect,
Route,
Switch,
} from 'react-router-dom';
import createHashHistory from 'history/createHashHistory';
import api from '@stackstorm/module-api';
import Login from '@stackstorm/module-login';
import Actions from '@stackstorm/app-actions';
import Docs from '@stackstorm/app-docs';
import History from '@stackstorm/app-history';
import Packs from '@stackstorm/app-packs';
import Rules from '@stackstorm/app-rules';
import './style.less';
const history = window.routerHistory = createHashHistory({});
const routes = [
Actions,
Docs,
History,
Packs,
Rules,
];
export class Container extends React.Component {
render() {
return (
<div className="wrapper">
<Router history={history}>
<Switch>
<Route exact path="/" render={() => <Redirect to="/history" />} />
{ routes.map(({ url, Component }) => {
if (!url) {
return null;
}
return (
<Route
key={url}
path={`${url}/:ref?/:section?`}
render={({ history, match, location }) => {
if (!api.isConnected()) {
return <Login onConnect={() => history.replace()} />;
}
return (
<Component
history={history}
match={match}
location={location}
routes={routes}
/>
);
}}
/>
);
}) }
</Switch>
</Router>
</div>
);
}
}
ReactDOM.render(<Container />, document.querySelector('#container'));