31 lines
979 B
TypeScript
31 lines
979 B
TypeScript
import { action, Action } from 'easy-peasy';
|
|
import { ServerDatabase } from '@definitions/user';
|
|
|
|
export interface ServerDatabaseStore {
|
|
data: ServerDatabase[];
|
|
setDatabases: Action<ServerDatabaseStore, ServerDatabase[]>;
|
|
appendDatabase: Action<ServerDatabaseStore, ServerDatabase>;
|
|
removeDatabase: Action<ServerDatabaseStore, string>;
|
|
}
|
|
|
|
const databases: ServerDatabaseStore = {
|
|
data: [],
|
|
|
|
setDatabases: action((state, payload) => {
|
|
state.data = payload;
|
|
}),
|
|
|
|
appendDatabase: 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 ];
|
|
}
|
|
}),
|
|
|
|
removeDatabase: action((state, payload) => {
|
|
state.data = [ ...state.data.filter(database => database.id !== payload) ];
|
|
}),
|
|
};
|
|
|
|
export default databases;
|