2020-03-29 22:19:17 +01:00
|
|
|
import React from 'react';
|
|
|
|
import { usePermissions } from '@/plugins/usePermissions';
|
2020-03-29 00:25:04 +00:00
|
|
|
|
|
|
|
interface Props {
|
|
|
|
action: string | string[];
|
2020-03-30 05:52:18 +01:00
|
|
|
matchAny?: boolean;
|
2020-03-29 00:25:04 +00:00
|
|
|
renderOnError?: React.ReactNode | null;
|
|
|
|
children: React.ReactNode;
|
|
|
|
}
|
|
|
|
|
2020-03-30 05:52:18 +01:00
|
|
|
const Can = ({ action, matchAny = false, renderOnError, children }: Props) => {
|
2020-03-29 22:19:17 +01:00
|
|
|
const can = usePermissions(action);
|
2020-03-29 00:25:04 +00:00
|
|
|
|
|
|
|
return (
|
|
|
|
<>
|
2020-03-30 05:52:18 +01:00
|
|
|
{
|
|
|
|
((matchAny && can.filter(p => p).length > 0) || (!matchAny && can.every(p => p))) ?
|
|
|
|
children
|
|
|
|
:
|
|
|
|
renderOnError
|
|
|
|
}
|
2020-03-29 00:25:04 +00:00
|
|
|
</>
|
|
|
|
);
|
|
|
|
};
|
|
|
|
|
|
|
|
export default Can;
|