31 lines
1,001 B
TypeScript
31 lines
1,001 B
TypeScript
import { action, Action } from 'easy-peasy';
|
|
import { ServerDatabase } from '@/api/server/databases/getServerDatabases';
|
|
|
|
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;
|