-
Notifications
You must be signed in to change notification settings - Fork 1
/
UserDataSlice.tsx
44 lines (39 loc) · 1.22 KB
/
UserDataSlice.tsx
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
import { PayloadAction, createSlice } from "@reduxjs/toolkit";
import vmd, { UserData } from "../virtualmodel/VMD";
interface UserDataState {
users: UserData[]
}
// Global state that keeps in memory the user info data
const userDataSlice = createSlice({
name: "userData",
initialState: { users: [] },
reducers: {
setUserData: (state: UserDataState, action: PayloadAction<UserData[]>) => {
state.users = action.payload;
},
updateUserData: (state: UserDataState, action: PayloadAction<UserData>) => {
let found = false;
const updatedUser = action.payload;
const newUserData = state.users.map((user) => {
if (user.email === updatedUser.email) {
found = true;
return {...user, ...updatedUser}
}
else{
return user;
}
});
if(!found){
newUserData.push(updatedUser)
}
state.users = newUserData;
},
// saveUserDataToDB: (state: UserDataState, action: PayloadAction<UserData>) => {
// const updateUserDataFA = vmd.getFunctionAccessor('meta', 'update_user_data');
// updateUserDataFA.setBody({user: action.payload});
// updateUserDataFA.executeFunction();
// }
},
});
export const { setUserData, updateUserData} = userDataSlice.actions;
export default userDataSlice.reducer;