Add TeamList ui component and teamList selectors

This commit is contained in:
memeriau
2022-01-22 00:16:20 +01:00
parent 93e82a36ee
commit 9469a670d6
8 changed files with 101 additions and 5 deletions

View File

@@ -1,8 +1,8 @@
import { PayloadAction, createSlice, createEntityAdapter } from "@reduxjs/toolkit"
import { PayloadAction, createSlice, createEntityAdapter, createSelector } from "@reduxjs/toolkit"
import { StateRequest, toastError, elementListFetch } from "./utils"
import { Team, teamListGet } from "../services/teams"
import { AppThunk, AppState } from "."
import { AppThunk, AppState, EntitiesRequest } from "."
const teamAdapter = createEntityAdapter<Team>()
@@ -46,3 +46,13 @@ export const fetchTeamListIfNeed = (): AppThunk => (dispatch, getState) => {
return null
}
export const selectTeamListState = (state: AppState): EntitiesRequest<Team> => state.teamList
export const selectTeamList = createSelector(
selectTeamListState,
({ ids, entities, readyStatus }) => {
if (readyStatus !== "success") return []
return ids.map((id) => entities[id])
}
)