You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
pizza.krasnikov.pro/.history/redux/cards/slice_20220518125652.ts

38 lines
989 B

import { createSlice, PayloadAction } from '@reduxjs/toolkit';
import { fetchPizzas } from './stock';
import { Pizza, PizzaSliceState, Status } from './types';
const initialState: PizzaSliceState = {
items: [],
status: Status.LOADING, // loading | success | error
};
const pizzaSlice = createSlice({
name: 'pizza',
initialState,
reducers: {
setItems(state, action: PayloadAction<Pizza[]>) {
state.items = action.payload;
},
},
extraReducers: (builder) => {
builder.addCase(fetchPizzas.pending, (state, action) => {
state.status = Status.LOADING;
state.items = [];
});
builder.addCase(fetchPizzas.fulfilled, (state, action) => {
state.items = action.payload;
state.status = Status.SUCCESS;
});
builder.addCase(fetchPizzas.rejected, (state, action) => {
state.status = Status.ERROR;
state.items = [];
});
},
});
export const { setItems } = pizzaSlice.actions;
export default pizzaSlice.reducer;