Add admin state store, add new role functionality
This commit is contained in:
parent
7369167e28
commit
dc0fdee030
10 changed files with 202 additions and 17 deletions
31
resources/scripts/state/admin/roles.ts
Normal file
31
resources/scripts/state/admin/roles.ts
Normal file
|
@ -0,0 +1,31 @@
|
|||
import { action, Action } from 'easy-peasy';
|
||||
import { Role } from '@/api/admin/roles/getRoles';
|
||||
|
||||
export interface AdminRoleStore {
|
||||
data: Role[];
|
||||
setRoles: Action<AdminRoleStore, Role[]>;
|
||||
appendRole: Action<AdminRoleStore, Role>;
|
||||
removeRole: Action<AdminRoleStore, number>;
|
||||
}
|
||||
|
||||
const roles: AdminRoleStore = {
|
||||
data: [],
|
||||
|
||||
setRoles: action((state, payload) => {
|
||||
state.data = payload;
|
||||
}),
|
||||
|
||||
appendRole: action((state, payload) => {
|
||||
if (state.data.find(database => database.id === payload.id)) {
|
||||
state.data = state.data.map(database => database.id === payload.id ? payload : database);
|
||||
} else {
|
||||
state.data = [ ...state.data, payload ];
|
||||
}
|
||||
}),
|
||||
|
||||
removeRole: action((state, payload) => {
|
||||
state.data = [ ...state.data.filter(role => role.id !== payload) ];
|
||||
}),
|
||||
};
|
||||
|
||||
export default roles;
|
Loading…
Add table
Add a link
Reference in a new issue