Files
outline/app/hooks/usePolicy.ts

39 lines
1.1 KiB
TypeScript

import * as React from "react";
import Model from "~/models/base/Model";
import useCurrentUser from "./useCurrentUser";
import useStores from "./useStores";
/**
* Retrieve the abilities of a policy for a given entity, if the policy is not
* located in the store, it will be fetched from the server.
*
* @param entity The model or model id
* @returns The policy for the model
*/
export default function usePolicy(entity?: string | Model | null) {
const { policies } = useStores();
const user = useCurrentUser({ rejectOnEmpty: false });
const entityId = entity
? typeof entity === "string"
? entity
: entity.id
: "";
React.useEffect(() => {
if (
entity &&
typeof entity !== "string" &&
!entity.isNew &&
!entity.isSaving
) {
// The policy for this model is missing and we have an authenticated session, attempt to
// reload relationships for this model.
if (!policies.get(entity.id) && user) {
void entity.loadRelations();
}
}
}, [policies, user, entity]);
return policies.abilities(entityId);
}