aboutsummaryrefslogtreecommitdiffstats
path: root/public/projects/react-small-apps/apps/todos/src/store/index.js
diff options
context:
space:
mode:
authorArmand Philippot <git@armandphilippot.com>2022-02-20 16:11:50 +0100
committerArmand Philippot <git@armandphilippot.com>2022-02-20 16:15:08 +0100
commit73a5c7fae9ffbe9ada721148c8c454a643aceebe (patch)
treec8fad013ed9b5dd589add87f8d45cf02bbfc6e91 /public/projects/react-small-apps/apps/todos/src/store/index.js
parentb01239fbdcc5bbc5921f73ec0e8fee7bedd5c8e8 (diff)
chore!: restructure repo
I separated public files from the config/dev files. It improves repo readability. I also moved dotenv helper to public/inc directory and extract the Matomo tracker in the same directory.
Diffstat (limited to 'public/projects/react-small-apps/apps/todos/src/store/index.js')
-rw-r--r--public/projects/react-small-apps/apps/todos/src/store/index.js56
1 files changed, 56 insertions, 0 deletions
diff --git a/public/projects/react-small-apps/apps/todos/src/store/index.js b/public/projects/react-small-apps/apps/todos/src/store/index.js
new file mode 100644
index 0000000..8d4fe43
--- /dev/null
+++ b/public/projects/react-small-apps/apps/todos/src/store/index.js
@@ -0,0 +1,56 @@
+import { configureStore } from "@reduxjs/toolkit";
+import { LocalStorage } from "../services/LocalStorage.service";
+import authReducer from "./auth/auth.slice";
+import todosReducer from "./todos/todos.slice";
+import usersReducer from "./users/users.slice";
+
+const reducer = {
+ auth: authReducer,
+ todos: todosReducer,
+ users: usersReducer,
+};
+
+const todosMiddleware = (store) => (next) => (action) => {
+ const { type } = action;
+ const result = next(action);
+
+ switch (type) {
+ case "auth/login":
+ const authState = store.getState().auth;
+ LocalStorage.set("todoUser", authState.currentUser);
+ break;
+ case "auth/logout":
+ LocalStorage.remove("todoUser");
+ break;
+ case "todos/updateTodo":
+ const todosState = store.getState().todos;
+ LocalStorage.set("todoList", todosState);
+ break;
+ default:
+ break;
+ }
+
+ return result;
+};
+
+const userFromLocalStorage = LocalStorage.get("todoUser");
+const preloadedAuth = userFromLocalStorage
+ ? { isAuthenticated: true, currentUser: userFromLocalStorage }
+ : undefined;
+
+const todosFromLocalStorage = LocalStorage.get("todoList");
+const preloadedTodos = todosFromLocalStorage
+ ? todosFromLocalStorage
+ : undefined;
+
+const preloadedState = {
+ auth: preloadedAuth,
+ todos: preloadedTodos,
+};
+
+export default configureStore({
+ reducer,
+ middleware: (getDefaultMiddleware) =>
+ getDefaultMiddleware().concat(todosMiddleware),
+ preloadedState,
+});