moved model delete button to show page as an icon w/ burnettk

This commit is contained in:
jasquat 2022-11-18 14:36:54 -05:00
parent 5358a4f200
commit bf22589ecb
2 changed files with 38 additions and 21 deletions

View File

@ -52,14 +52,6 @@ export default function ProcessModelForm({
return identifierToCheck.match(/^[a-z0-9][0-9a-z-]+[a-z0-9]$/); return identifierToCheck.match(/^[a-z0-9][0-9a-z-]+[a-z0-9]$/);
}; };
const deleteProcessModel = () => {
HttpService.makeCallToBackend({
path: `/process-models/${modifiedProcessModelPath}`,
successCallback: navigateToProcessModels,
httpMethod: 'DELETE',
});
};
const handleFormSubmission = (event: any) => { const handleFormSubmission = (event: any) => {
event.preventDefault(); event.preventDefault();
let hasErrors = false; let hasErrors = false;
@ -172,16 +164,6 @@ export default function ProcessModelForm({
Submit Submit
</Button>, </Button>,
]; ];
if (mode === 'edit') {
buttons.push(
<ButtonWithConfirmation
description={`Delete Process Model ${processModel.id}?`}
onConfirmation={deleteProcessModel}
buttonLabel="Delete"
confirmButtonLabel="Delete"
/>
);
}
return <ButtonSet>{buttons}</ButtonSet>; return <ButtonSet>{buttons}</ButtonSet>;
}; };
return ( return (

View File

@ -31,7 +31,10 @@ 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 ErrorContext from '../contexts/ErrorContext'; import ErrorContext from '../contexts/ErrorContext';
import { modifyProcessModelPath } from '../helpers'; import {
getGroupFromModifiedModelId,
modifyProcessModelPath,
} from '../helpers';
import { import {
PermissionsToCheck, PermissionsToCheck,
ProcessFile, ProcessFile,
@ -106,7 +109,7 @@ export default function ProcessModelShow() {
const { targetUris } = useUriListForPermissions(); const { targetUris } = useUriListForPermissions();
const permissionRequestData: PermissionsToCheck = { const permissionRequestData: PermissionsToCheck = {
[targetUris.processModelShowPath]: ['PUT'], [targetUris.processModelShowPath]: ['PUT', 'DELETE'],
[targetUris.processInstanceListPath]: ['GET'], [targetUris.processInstanceListPath]: ['GET'],
[targetUris.processInstanceActionPath]: ['POST'], [targetUris.processInstanceActionPath]: ['POST'],
[targetUris.processModelFileCreatePath]: ['POST', 'GET', 'DELETE'], [targetUris.processModelFileCreatePath]: ['POST', 'GET', 'DELETE'],
@ -251,6 +254,22 @@ export default function ProcessModelShow() {
return null; return null;
}; };
const navigateToProcessModels = (_result: any) => {
navigate(
`/admin/process-groups/${getGroupFromModifiedModelId(
modifiedProcessModelId
)}`
);
};
const deleteProcessModel = () => {
HttpService.makeCallToBackend({
path: `/process-models/${modifiedProcessModelId}`,
successCallback: navigateToProcessModels,
httpMethod: 'DELETE',
});
};
const navigateToFileEdit = (processModelFile: ProcessFile) => { const navigateToFileEdit = (processModelFile: ProcessFile) => {
const url = profileModelFileEditUrl(processModelFile); const url = profileModelFileEditUrl(processModelFile);
if (url) { if (url) {
@ -529,7 +548,23 @@ export default function ProcessModelShow() {
], ],
]} ]}
/> />
<h1>Process Model: {processModel.display_name}</h1> <Stack orientation="horizontal" gap={1}>
<h1 className="with-icons">
Process Model: {processModel.display_name}
</h1>
<Can I="DELETE" a={targetUris.processModelShowPath} ability={ability}>
<ButtonWithConfirmation
kind="ghost"
renderIcon={TrashCan}
iconDescription="Delete Process Model"
hasIconOnly
description={`Delete process model: ${processModel.display_name}`}
onConfirmation={deleteProcessModel}
confirmButtonLabel="Delete"
/>
</Can>
</Stack>
<p className="process-description">{processModel.description}</p> <p className="process-description">{processModel.description}</p>
<Stack orientation="horizontal" gap={3}> <Stack orientation="horizontal" gap={3}>
<Can <Can