From 73a5c7fae9ffbe9ada721148c8c454a643aceebe Mon Sep 17 00:00:00 2001 From: Armand Philippot Date: Sun, 20 Feb 2022 16:11:50 +0100 Subject: 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. --- .../apps/todos/src/store/users/users.slice.js | 39 ++++++++++++++++++++++ 1 file changed, 39 insertions(+) create mode 100644 public/projects/react-small-apps/apps/todos/src/store/users/users.slice.js (limited to 'public/projects/react-small-apps/apps/todos/src/store/users/users.slice.js') diff --git a/public/projects/react-small-apps/apps/todos/src/store/users/users.slice.js b/public/projects/react-small-apps/apps/todos/src/store/users/users.slice.js new file mode 100644 index 0000000..ecce733 --- /dev/null +++ b/public/projects/react-small-apps/apps/todos/src/store/users/users.slice.js @@ -0,0 +1,39 @@ +import { createSlice, nanoid } from "@reduxjs/toolkit"; + +export const usersSlice = createSlice({ + name: "users", + initialState: [ + { + id: "demo", + createdAt: new Date().toISOString(), + username: "Demo", + email: "demo@email.com", + password: "demo", + }, + ], + reducers: { + addUser: { + reducer: (state, action) => { + state.push(action.payload); + }, + prepare: (username, email, password) => { + const id = nanoid(); + const createdAt = new Date().toISOString(); + return { payload: { id, username, email, password, createdAt } }; + }, + }, + deleteUser: (state, action) => { + state.filter((user) => user.id !== action.payload); + }, + updateUser: (state, action) => { + state.map((user) => { + if (user.id !== action.payload.id) return user; + return { ...user, ...action.payload }; + }); + }, + }, +}); + +export const { addUser, deleteUser, updateUser } = usersSlice.actions; + +export default usersSlice.reducer; -- cgit v1.2.3