34 lines
1.1 KiB
JavaScript
34 lines
1.1 KiB
JavaScript
// /redux/slices/database/locationDevicesFromDBSlice.js
|
|
import { createSlice, createAsyncThunk } from "@reduxjs/toolkit";
|
|
import { fetchLocationDevices } from "../../api/fromDB/fetchLocationDevices";
|
|
|
|
export const fetchLocationDevicesFromDB = createAsyncThunk("locationDevicesFromDB/fetchLocationDevicesFromDB", async () => {
|
|
return fetchLocationDevices();
|
|
});
|
|
|
|
const locationDevicesFromDBSlice = createSlice({
|
|
name: "locationDevicesFromDB",
|
|
initialState: {
|
|
devices: [],
|
|
status: "idle",
|
|
error: null,
|
|
},
|
|
reducers: {},
|
|
extraReducers: (builder) => {
|
|
builder
|
|
.addCase(fetchLocationDevicesFromDB.pending, (state) => {
|
|
state.status = "loading";
|
|
})
|
|
.addCase(fetchLocationDevicesFromDB.fulfilled, (state, action) => {
|
|
state.status = "succeeded";
|
|
state.devices = action.payload; // <-- Hier landen die Daten
|
|
})
|
|
.addCase(fetchLocationDevicesFromDB.rejected, (state, action) => {
|
|
state.status = "failed";
|
|
state.error = action.error.message;
|
|
});
|
|
},
|
|
});
|
|
|
|
export default locationDevicesFromDBSlice.reducer;
|