-
Notifications
You must be signed in to change notification settings - Fork 7
/
Copy pathApp.js
107 lines (100 loc) · 3.23 KB
/
App.js
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
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
// IMPORTING CSS
import "../node_modules/bootstrap/dist/css/bootstrap.min.css";
import LayoutWelcome from "./pages/LayoutWelcome";
import "./styles/style.css";
// IMPORTING ROUTER AND SWITCH
import { Redirect, Route, Switch } from "react-router-dom";
import { useEffect, useState } from "react";
import LayoutAction from "./pages/LayoutAction";
import LayoutActionTable from "./pages/LayoutActionTable";
import LoadingOverlay from "react-loading-overlay";
import ConnectDatabase from "./pages/ConnectDatabase";
import LayoutSettings from "./pages/LayoutSettings";
import LayoutAuditTable from "./pages/LayoutAuditTable";
import NotFound from "./pages/NotFound";
// import the health check component, serivng as a protection guard to ensure BE uptime
import CheckBEHealth from "./util/HealthCheck";
function App() {
const [mode, setMode] = useState(1);
const [loading, setLoading] = useState(false);
let localMode = localStorage.getItem("modeLocal");
useEffect(() => {
if (!localMode) {
localStorage.setItem("modeLocal", "1");
setMode(1);
}
if (!localMode) {
document.body.style.background = "#f5f6f8";
} else if (localMode === "1") {
document.body.style.background = "#f5f6f8";
} else if (localMode && localMode === "2") {
document.body.style.background = "#212121";
}
}, [localMode, mode]);
return (
<div
className={`${
(!localMode && "light") || (localMode === "1" && "light") || "dark"
}`}
>
<LoadingOverlay
active={loading}
// spinner={<BounceLoader />}
spinner={true}
text="Loading..."
>
<Switch>
<Route exact path="/">
<CheckBEHealth>
<LayoutActionTable />
</CheckBEHealth>
</Route>
<Route exact path="/audit">
<CheckBEHealth>
<LayoutAuditTable />
</CheckBEHealth>
</Route>
<Route exact path="/welcome">
{/* CheckBEHealth to ensure uptime before routing, pass in the component as props */}
<CheckBEHealth>
<LayoutWelcome setLoading={setLoading} />
</CheckBEHealth>
</Route>
<Route exact path="/connect-database">
<CheckBEHealth>
<ConnectDatabase setLoading={setLoading} />
</CheckBEHealth>
</Route>
<Route exact path="/settings">
<LayoutSettings
localMode={localMode}
mode={mode}
setMode={setMode}
/>
</Route>
<Route exact path="/create-action">
<CheckBEHealth>
<LayoutAction
localMode={localMode}
setLoading={setLoading}
type="Create"
/>
</CheckBEHealth>
</Route>
<Route exact path="/edit-action">
<CheckBEHealth>
<LayoutAction
localMode={localMode}
setLoading={setLoading}
type="Edit"
/>
</CheckBEHealth>
</Route>
<Route path="/404" component={NotFound} />
<Redirect to="/404" />
</Switch>
</LoadingOverlay>
</div>
);
}
export default App;