NGRX - Как использовать селектор на карте в другом селекторе?

Я пытаюсь создать селектор, который возвращает список объектов с дополнительными полями, добавленными из другого селектора. Вот селектор, который я пытаюсь использовать:

      //Get a full list of Users with their Roles added
export const getUsersWithRoles = createSelector(
  getAllUsers,
  (userList) => userList.map(user => getUserWithRolesById(user.userId))
);


//Get User and add their Roles to the object
export const getUserWithRolesById= (userId: string) => createSelector(
  getUserById(userId),
  getRoleListByUserId(userId),
  (user, roles) => {
    const userWithMembership = {...user, roles: roles} as UserTableItem;
    return userWithMembership;
  }
);

Однако getUsersWithRolesselector возвращает массив MemoizedSelectors вместо массива объектов. Как я могу это использовать getUserWithRolesById селектор в map по первому селектору?

Все остальное работает, как ожидалось, с шаблоном сущности ngrx, но я перечислю некоторые из селекторов, которые вызываются в приведенном выше коде:

      //Selectors


export const getUserManagerDataState = createFeatureSelector<UserManagerState>(USER_MANAGER_DATA_FEATURE_KEY);

export const getUsersState = createSelector(
  getUserManagerDataState,
  (state) => state.userState
);

export const getAllUsers = createSelector(
  getUsersState,
  UserAdapterSelectors.selectAll
);

export const getUserById = (userId: string) => createSelector(
  getUserManagerDataState,
  state => state.userState.entities[userId]
);

0 ответов

Другие вопросы по тегам