pelican-panel-mirror/resources/scripts/hoc/RequireServerPermission.tsx
Lance Pioch 8f2413dc7e Add front end translations
Co-authored-by: Miniontoby <tobias.gaarenstroom@gmail.com>
2024-04-25 23:33:08 -04:00

26 lines
726 B
TypeScript

import React from 'react';
import { useTranslation } from 'react-i18next';
import Can from '@/components/elements/Can';
import { ServerError } from '@/components/elements/ScreenBlock';
export interface RequireServerPermissionProps {
permissions: string | string[];
}
const RequireServerPermission: React.FC<RequireServerPermissionProps> = ({ children, permissions }) => {
const { t } = useTranslation('strings');
return (
<Can
action={permissions}
renderOnError={
<ServerError title={t('access_denied.title')} message={t('access_denied.message')} />
}
>
{children}
</Can>
);
};
export default RequireServerPermission;