UNPKG

ra-core

Version:

Core components of react-admin, a frontend Framework for building admin applications on top of REST services, using ES6, React

100 lines 3.85 kB
"use strict"; var __importDefault = (this && this.__importDefault) || function (mod) { return (mod && mod.__esModule) ? mod : { "default": mod }; }; Object.defineProperty(exports, "__esModule", { value: true }); exports.useCanAccessResources = void 0; const react_1 = require("react"); const react_query_1 = require("@tanstack/react-query"); const useAuthProvider_1 = __importDefault(require("./useAuthProvider.cjs")); const controller_1 = require("../controller/index.cjs"); /** * Checks whether users can access the provided resources. * * `useCanAccessResources` returns an object describing the state of the request: * * - start: { isPending: true } * - success: { canAccess: Object<string, boolean>, isPending: false } * - error: { error: [error from provider], isPending: false } * * @param {Object} params Any params you want to pass to the authProvider * @param {string} params.action The action to check access for * @param {string[]} params.resources The list of resources to check access for * @param {Object} params.record Optional. The record to check access for * * @returns Return the react-query result and a canAccess property which is a map of the resources and their access status { [resource: string]: boolean } * * @example * import { useCanAccessResources } from 'react-admin'; * * const UserList = ({ record }) => { * const { isPending, canAccess } = useCanAccessResources({ * action: 'read', * resources: ['users.id', 'users.name', 'users.email'], * record * }); * * if (isPending) { * return null; * } * return ( * <SimpleList * primaryText={record => canAccess.users.name ? record.name : ''} * secondaryText={record => canAccess.users.email ? record.email : ''} * tertiaryText={record => canAccess.users.id ? record.id : ''} * /> * ); * }; */ const useCanAccessResources = (params) => { const authProvider = (0, useAuthProvider_1.default)(); const record = (0, controller_1.useRecordContext)(params); const { action, resources, ...options } = params; const queryResult = (0, react_query_1.useQuery)({ queryKey: ['auth', 'canAccess', resources, action, record], queryFn: async ({ signal }) => { const queries = await Promise.all(resources.map(async (resource) => { if (!authProvider || !authProvider.canAccess) { return { canAccess: true, resource }; } const canAccess = await authProvider.canAccess({ resource, action, record, signal: authProvider.supportAbortSignal ? signal : undefined, }); return { canAccess, resource }; })); const result = queries.reduce((acc, { resource, canAccess }) => { acc[resource] = canAccess; return acc; }, {}); return result; }, ...options, }); const result = (0, react_1.useMemo)(() => { return { canAccess: queryResult.data, ...queryResult, }; }, [queryResult]); const resultWithoutAuthProvider = (0, react_1.useMemo)(() => { return { canAccess: resources.reduce((acc, resource) => { acc[resource] = true; return acc; }, {}), isPending: false, isError: false, error: null, }; }, [resources]); return !authProvider || !authProvider.canAccess ? resultWithoutAuthProvider : result; }; exports.useCanAccessResources = useCanAccessResources; //# sourceMappingURL=useCanAccessResources.js.map