import { PayloadAction, createSlice, createEntityAdapter } from "@reduxjs/toolkit" import { StateRequest, toastError, elementListFetch } from "./utils" import { Volunteer, volunteerListGet } from "../services/volunteers" import { AppThunk, AppState } from "." const volunteerAdapter = createEntityAdapter() export const initialState = volunteerAdapter.getInitialState({ readyStatus: "idle", } as StateRequest) const volunteerList = createSlice({ name: "volunteerList", initialState, reducers: { getRequesting: (state) => { state.readyStatus = "request" }, getSuccess: (state, { payload }: PayloadAction) => { state.readyStatus = "success" volunteerAdapter.setAll(state, payload) }, getFailure: (state, { payload }: PayloadAction) => { state.readyStatus = "failure" state.error = payload }, }, }) export default volunteerList.reducer export const { getRequesting, getSuccess, getFailure } = volunteerList.actions export const fetchVolunteerList = elementListFetch( volunteerListGet, getRequesting, getSuccess, getFailure, (error: Error) => toastError(`Erreur lors du chargement des volunteers: ${error.message}`) ) const shouldFetchVolunteerList = (state: AppState) => state.volunteerList.readyStatus !== "success" export const fetchVolunteerListIfNeed = (): AppThunk => (dispatch, getState) => { if (shouldFetchVolunteerList(getState())) return dispatch(fetchVolunteerList()) return null }