首頁  >  問答  >  主體

已棄用:不再支援具有 props 的選擇器

在第二行,我收到此錯誤:不建議使用帶有 props 的選擇器。

const getUserProfileState = createFeatureSelector<UserProfileState>(authorizationFeatureKey);

const hasPermission = createSelector(
    getUserProfileState,
    (state: UserProfileState, permission: GQLPermission): boolean => {
        const result =
            state.permissions &&
            state.permissions.some((p) => p && p.resource === permission.resource && p.action === permission.action);
        return !!result;
    }
);

const hasCreateCasePermission = createSelector(getUserProfileState, (state: UserProfileState): boolean =>
    hasPermission.projector(state, {
        resource: PermissionResource.case,
        action: PermissionAction.create,
    })
);

我正在嘗試重構「hasPermission」函數,如下所示:

const hasPermission = (permission: GQLPermission) => createSelector(
    getUserProfileState,
    (state: UserProfileState): boolean => {
        const result =
            state.permissions &&
            state.permissions.some((p) => p && p.resource === permission.resource && p.action === permission.action);
        return !!result;
    }
);

但是我在如何基於這個 hasCreateCasePermission 進行重構方面遇到了困難。

P粉786800174P粉786800174240 天前378

全部回覆(1)我來回復

  • P粉465287592

    P粉4652875922024-02-22 14:34:19

    附註:第一個範例中使用 .projector 有點味道。 您可以執行以下操作:

    const hasCreateCasePermission = hasPermission({
            resource: PermissionResource.case,
            action: PermissionAction.create,
    });

    回覆
    0
  • 取消回覆