Disable buttons based on permissions (#209)

This commit is contained in:
jbirddog 2023-04-11 14:38:41 -04:00 committed by GitHub
parent 3dba9690bf
commit 674169e3f4
1 changed files with 63 additions and 32 deletions

View File

@ -1,18 +1,24 @@
/* eslint-disable sonarjs/cognitive-complexity */
import { useEffect, useState } from 'react'; import { useEffect, useState } from 'react';
import Editor from '@monaco-editor/react'; import Editor from '@monaco-editor/react';
import { useNavigate, useParams, useSearchParams } from 'react-router-dom'; import { useNavigate, useParams, useSearchParams } from 'react-router-dom';
// @ts-ignore // @ts-ignore
import { Button, Modal } from '@carbon/react'; import { Button, Modal } from '@carbon/react';
import { Can } from '@casl/react';
import ProcessBreadcrumb from '../components/ProcessBreadcrumb'; import ProcessBreadcrumb from '../components/ProcessBreadcrumb';
import HttpService from '../services/HttpService'; import HttpService from '../services/HttpService';
import ButtonWithConfirmation from '../components/ButtonWithConfirmation'; import ButtonWithConfirmation from '../components/ButtonWithConfirmation';
import { modifyProcessIdentifierForPathParam } from '../helpers'; import { modifyProcessIdentifierForPathParam } from '../helpers';
import { ProcessFile } from '../interfaces'; import { ProcessFile, PermissionsToCheck } from '../interfaces';
import { Notification } from '../components/Notification'; import { Notification } from '../components/Notification';
import useAPIError from '../hooks/UseApiError'; import useAPIError from '../hooks/UseApiError';
import { usePermissionFetcher } from '../hooks/PermissionService';
import { useUriListForPermissions } from '../hooks/UriListForPermissions';
// NOTE: This is mostly the same as ProcessModelEditDiagram and if we go this route could // NOTE: This is mostly the same as ProcessModelEditDiagram and if we go this route could
// possibly be merged into it. I'm leaving as a separate file now in case it does // possibly be merged into it. I'm leaving as a separate file now in case it does
// end up diverging greatly // end up diverging greatly
export default function ReactFormEditor() { export default function ReactFormEditor() {
const params = useParams(); const params = useParams();
const { addError, removeError } = useAPIError(); const { addError, removeError } = useAPIError();
@ -20,6 +26,12 @@ export default function ReactFormEditor() {
const [newFileName, setNewFileName] = useState(''); const [newFileName, setNewFileName] = useState('');
const searchParams = useSearchParams()[0]; const searchParams = useSearchParams()[0];
const handleShowFileNameEditor = () => setShowFileNameEditor(true); const handleShowFileNameEditor = () => setShowFileNameEditor(true);
const { targetUris } = useUriListForPermissions();
const permissionRequestData: PermissionsToCheck = {
[targetUris.processModelShowPath]: ['PUT'],
[targetUris.processModelFileShowPath]: ['POST', 'GET', 'PUT', 'DELETE'],
};
const { ability } = usePermissionFetcher(permissionRequestData);
const navigate = useNavigate(); const navigate = useNavigate();
const [displaySaveFileMessage, setDisplaySaveFileMessage] = const [displaySaveFileMessage, setDisplaySaveFileMessage] =
@ -42,6 +54,7 @@ export default function ReactFormEditor() {
})(); })();
const hasDiagram = fileExtension === 'bpmn' || fileExtension === 'dmn'; const hasDiagram = fileExtension === 'bpmn' || fileExtension === 'dmn';
const hasFormBuilder = fileExtension === 'json';
const editorDefaultLanguage = (() => { const editorDefaultLanguage = (() => {
if (fileExtension === 'json') { if (fileExtension === 'json') {
@ -210,10 +223,21 @@ export default function ReactFormEditor() {
</h1> </h1>
{newFileNameBox()} {newFileNameBox()}
{saveFileMessage()} {saveFileMessage()}
<Button onClick={saveFile} variant="danger" data-qa="file-save-button">
<Can I="PUT" a={targetUris.processModelFileShowPath} ability={ability}>
<Button
onClick={saveFile}
variant="danger"
data-qa="file-save-button"
>
Save Save
</Button> </Button>
</Can>
<Can
I="DELETE"
a={targetUris.processModelFileShowPath}
ability={ability}
>
{params.file_name ? ( {params.file_name ? (
<ButtonWithConfirmation <ButtonWithConfirmation
data-qa="delete-process-model-file" data-qa="delete-process-model-file"
@ -222,6 +246,9 @@ export default function ReactFormEditor() {
buttonLabel="Delete" buttonLabel="Delete"
/> />
) : null} ) : null}
</Can>
<Can I="PUT" a={targetUris.processModelFileShowPath} ability={ability}>
{hasFormBuilder ? (
<Button <Button
onClick={() => onClick={() =>
navigate( navigate(
@ -233,6 +260,9 @@ export default function ReactFormEditor() {
> >
Form Builder Form Builder
</Button> </Button>
) : null}
</Can>
<Can I="GET" a={targetUris.processModelFileShowPath} ability={ability}>
{hasDiagram ? ( {hasDiagram ? (
<Button <Button
onClick={() => onClick={() =>
@ -246,6 +276,7 @@ export default function ReactFormEditor() {
View Diagram View Diagram
</Button> </Button>
) : null} ) : null}
</Can>
<Editor <Editor
height={600} height={600}
width="auto" width="auto"