cameraSlice.js
1.25 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
import {
createAsyncThunk,
createEntityAdapter,
createSlice,
} from '@reduxjs/toolkit';
import api from '../../api';
export const fetchCameras = createAsyncThunk(
'cameras/fetchCameras',
async () => {
return api.cameras.getCameras();
},
);
const cameraAdapter = createEntityAdapter();
const initialState = cameraAdapter.getInitialState({
status: 'idle',
error: null,
});
const camerasSlice = createSlice({
name: 'cameras',
initialState,
reducers: {},
extraReducers(builder) {
builder
.addCase(fetchCameras.pending, state => {
state.status = 'loading';
})
.addCase(fetchCameras.fulfilled, (state, action) => {
state.status = 'succeeded';
console.log(action.payload);
// state.cameras = state.cameras.concat(action.payload.results);
cameraAdapter.upsertMany(state, action.payload.results);
})
.addCase(fetchCameras.rejected, (state, action) => {
state.status = 'failed';
state.error = action.payload.message;
});
},
});
export default camerasSlice.reducer;
// export const selectAllCameras = (state) => state.cameras.cameras;
export const {selectAll: selectAllCameras, selectById: selectCameraById} =
cameraAdapter.getSelectors(state => state.cameras);