summaryrefslogtreecommitdiff
path: root/frontend/src/store/configure-store.js
diff options
context:
space:
mode:
authorGeorgios Andreadis <info@gandreadis.com>2020-06-29 15:47:09 +0200
committerFabian Mastenbroek <mail.fabianm@gmail.com>2020-08-24 16:08:41 +0200
commit90fae26aa4bd0e0eb3272ff6e6524060e9004fbb (patch)
treebf6943882f5fa5f3114c01fc571503c79ee1056d /frontend/src/store/configure-store.js
parent7032a007d4431f5a0c4c5e2d3f3bd20462d49950 (diff)
Prepare frontend repository for monorepo
This change prepares the frontend Git repository for the monorepo residing at https://github.com/atlarge-research.com/opendc. To accomodate for this, we move all files into a frontend subdirectory.
Diffstat (limited to 'frontend/src/store/configure-store.js')
-rw-r--r--frontend/src/store/configure-store.js41
1 files changed, 41 insertions, 0 deletions
diff --git a/frontend/src/store/configure-store.js b/frontend/src/store/configure-store.js
new file mode 100644
index 00000000..29af25ab
--- /dev/null
+++ b/frontend/src/store/configure-store.js
@@ -0,0 +1,41 @@
+import { applyMiddleware, compose, createStore } from "redux";
+import persistState from "redux-localstorage";
+import { createLogger } from "redux-logger";
+import createSagaMiddleware from "redux-saga";
+import thunk from "redux-thunk";
+import { authRedirectMiddleware } from "../auth/index";
+import rootReducer from "../reducers/index";
+import rootSaga from "../sagas/index";
+import { dummyMiddleware } from "./middlewares/dummy-middleware";
+import { viewportAdjustmentMiddleware } from "./middlewares/viewport-adjustment";
+
+const sagaMiddleware = createSagaMiddleware();
+
+let logger;
+if (process.env.NODE_ENV !== "production") {
+ logger = createLogger();
+}
+
+const middlewares = [
+ process.env.NODE_ENV === "production" ? dummyMiddleware : logger,
+ thunk,
+ sagaMiddleware,
+ authRedirectMiddleware,
+ viewportAdjustmentMiddleware
+];
+
+export let store = undefined;
+
+export default function configureStore() {
+ const configuredStore = createStore(
+ rootReducer,
+ compose(
+ persistState("auth"),
+ applyMiddleware(...middlewares)
+ )
+ );
+ sagaMiddleware.run(rootSaga);
+ store = configuredStore;
+
+ return configuredStore;
+}