mirror of
https://github.com/Paris-est-Ludique/intranet.git
synced 2025-06-12 10:34:20 +02:00
40 lines
1.2 KiB
TypeScript
40 lines
1.2 KiB
TypeScript
import { PayloadAction, createSlice, createEntityAdapter } from "@reduxjs/toolkit"
|
|
|
|
import { StateRequest, elementAddFetch } from "./utils"
|
|
import { Volunteer } from "../services/volunteers"
|
|
import { volunteerPartialAdd } from "../services/volunteersAccessors"
|
|
|
|
const volunteerAdapter = createEntityAdapter<Volunteer>()
|
|
|
|
const volunteerPartialAddSlice = createSlice({
|
|
name: "volunteerAdd",
|
|
initialState: volunteerAdapter.getInitialState({
|
|
readyStatus: "idle",
|
|
} as StateRequest),
|
|
reducers: {
|
|
getRequesting: (state) => {
|
|
state.readyStatus = "request"
|
|
},
|
|
getSuccess: (state, { payload }: PayloadAction<Volunteer>) => {
|
|
state.readyStatus = "success"
|
|
volunteerAdapter.setOne(state, payload)
|
|
},
|
|
getFailure: (state, { payload }: PayloadAction<string>) => {
|
|
state.readyStatus = "failure"
|
|
state.error = payload
|
|
},
|
|
},
|
|
})
|
|
|
|
export default volunteerPartialAddSlice.reducer
|
|
export const { getRequesting, getSuccess, getFailure } = volunteerPartialAddSlice.actions
|
|
|
|
export const fetchVolunteerPartialAdd = elementAddFetch(
|
|
volunteerPartialAdd,
|
|
getRequesting,
|
|
getSuccess,
|
|
getFailure,
|
|
() => null,
|
|
() => null
|
|
)
|