summaryrefslogtreecommitdiff
path: root/client/src/slices
diff options
context:
space:
mode:
authorMichael Hunteman <michael@huntm.net>2024-09-20 11:19:34 -0700
committerMichael Hunteman <michael@huntm.net>2024-09-20 11:19:34 -0700
commita54a93b724a6104213b17271fc298e37adedc1c5 (patch)
treeea5d013e5a25806788b0dfd18d5e638ed141e4a7 /client/src/slices
parent3aad1960e4ee9bce1155b4154c596daf09ee0ae5 (diff)
Use redux for updating snackbar
Diffstat (limited to 'client/src/slices')
-rw-r--r--client/src/slices/auth/adminSlice.ts4
-rw-r--r--client/src/slices/auth/guestSlice.ts4
-rw-r--r--client/src/slices/snackbarSlice.ts32
3 files changed, 34 insertions, 6 deletions
diff --git a/client/src/slices/auth/adminSlice.ts b/client/src/slices/auth/adminSlice.ts
index cc2205e..3007059 100644
--- a/client/src/slices/auth/adminSlice.ts
+++ b/client/src/slices/auth/adminSlice.ts
@@ -23,7 +23,5 @@ const adminSlice = createSlice({
});
export const { setAdmin } = adminSlice.actions;
-
-export default adminSlice.reducer;
-
export const selectGuests = (state: RootState) => state.admin.guests;
+export default adminSlice.reducer;
diff --git a/client/src/slices/auth/guestSlice.ts b/client/src/slices/auth/guestSlice.ts
index fb4afaf..238781f 100644
--- a/client/src/slices/auth/guestSlice.ts
+++ b/client/src/slices/auth/guestSlice.ts
@@ -23,7 +23,5 @@ const guestSlice = createSlice({
});
export const { setGuest } = guestSlice.actions;
-
-export default guestSlice.reducer;
-
export const selectGuest = (state: RootState) => state.guest.guest;
+export default guestSlice.reducer;
diff --git a/client/src/slices/snackbarSlice.ts b/client/src/slices/snackbarSlice.ts
new file mode 100644
index 0000000..eca9575
--- /dev/null
+++ b/client/src/slices/snackbarSlice.ts
@@ -0,0 +1,32 @@
+import { createSlice } from '@reduxjs/toolkit';
+import type { RootState } from '../store';
+
+export interface SnackbarState {
+ open: boolean;
+ message: string;
+ severity?: 'success' | 'error';
+}
+
+const initialState: SnackbarState = {
+ open: false,
+ message: '',
+};
+
+export const snackbarSlice = createSlice({
+ name: 'snackbar',
+ initialState,
+ reducers: {
+ open(state, action) {
+ state.open = true;
+ state.message = action.payload.message;
+ state.severity = action.payload.severity;
+ },
+ close(state) {
+ state.open = false;
+ },
+ },
+});
+
+export const { open, close } = snackbarSlice.actions;
+export const selectSnackbarState = (state: RootState) => state.snackbar;
+export default snackbarSlice.reducer;