26 lines
730 B
TypeScript
26 lines
730 B
TypeScript
|
import { useSession } from "next-auth/react";
|
||
|
import { FC, Fragment } from "react";
|
||
|
|
||
|
import { UserPermissionRole } from ".prisma/client";
|
||
|
|
||
|
type AdminRequiredProps = {
|
||
|
as?: keyof JSX.IntrinsicElements;
|
||
|
children?: React.ReactNode;
|
||
|
/**Not needed right now but will be useful if we ever expand our permission roles */
|
||
|
roleRequired?: UserPermissionRole;
|
||
|
};
|
||
|
|
||
|
export const PermissionContainer: FC<AdminRequiredProps> = ({
|
||
|
children,
|
||
|
as,
|
||
|
roleRequired = "ADMIN",
|
||
|
...rest
|
||
|
}) => {
|
||
|
const session = useSession();
|
||
|
|
||
|
// Admin can do everything
|
||
|
if (session.data?.user.role !== roleRequired || !UserPermissionRole.ADMIN) return null;
|
||
|
const Component = as ?? Fragment;
|
||
|
return <Component {...rest}>{children}</Component>;
|
||
|
};
|