refactor and cleanup

This commit is contained in:
ISA
2025-05-23 08:36:38 +02:00
parent 41e270cc53
commit 8cb995040d
16 changed files with 88 additions and 92 deletions

View File

@@ -0,0 +1,38 @@
import { createSlice } from "@reduxjs/toolkit";
import { addPoiThunk } from "../../thunks/database/addPoiThunk";
const initialState = {
status: "idle", // idle | loading | succeeded | failed
error: null,
};
const addPoiSlice = createSlice({
name: "addPoi",
initialState,
reducers: {
resetAddPoiStatus: (state) => {
state.status = "idle";
state.error = null;
},
},
extraReducers: (builder) => {
builder
.addCase(addPoiThunk.pending, (state) => {
state.status = "loading";
})
.addCase(addPoiThunk.fulfilled, (state) => {
state.status = "succeeded";
state.error = null;
})
.addCase(addPoiThunk.rejected, (state, action) => {
state.status = "failed";
state.error = action.payload;
});
},
});
export const { resetAddPoiStatus } = addPoiSlice.actions;
export default addPoiSlice.reducer;
export const selectAddPoiStatus = (state) => state.addPoi.status;
export const selectAddPoiError = (state) => state.addPoi.error;

View File

@@ -27,6 +27,7 @@ import gisStationsMeasurementsReducer from "./slices/webservice/gisStationsMeasu
import gisSystemStaticReducer from "./slices/webservice/gisSystemStaticSlice";
import userRightsReducer from "./slices/webservice/userRightsSlice";
import gisLinesStatusFromWebserviceReducer from "./slices/webservice/gisLinesStatusSlice";
import addPoiReducer from "./slices/database/addPoiSlice";
export const store = configureStore({
reducer: {
@@ -55,5 +56,6 @@ export const store = configureStore({
zoomTrigger: zoomTriggerReducer,
urlParameter: urlParameterReducer,
priorityConfig: priorityConfigReducer,
addPoi: addPoiReducer,
},
});

View File

@@ -0,0 +1,11 @@
// /redux/thunks/database/addPoiThunk.js
import { createAsyncThunk } from "@reduxjs/toolkit";
import { addPoiService } from "../../../services/database/addPoiService";
export const addPoiThunk = createAsyncThunk("poi/add", async (formData, thunkAPI) => {
try {
return await addPoiService(formData);
} catch (error) {
return thunkAPI.rejectWithValue(error.message);
}
});