mirror of
https://github.com/sartography/spiff-arena.git
synced 2025-01-12 02:24:15 +00:00
redirect to the non-for-me page if allowed when performing an admin action w/ burnettk
This commit is contained in:
parent
5d19d7cd61
commit
dc9ce04728
@ -105,7 +105,7 @@ export default function ProcessInstanceShow({ variant }: OwnProps) {
|
|||||||
[`${targetUris.processInstanceTerminatePath}`]: ['POST'],
|
[`${targetUris.processInstanceTerminatePath}`]: ['POST'],
|
||||||
[targetUris.processInstanceResetPath]: ['POST'],
|
[targetUris.processInstanceResetPath]: ['POST'],
|
||||||
[targetUris.messageInstanceListPath]: ['GET'],
|
[targetUris.messageInstanceListPath]: ['GET'],
|
||||||
[targetUris.processInstanceActionPath]: ['DELETE'],
|
[targetUris.processInstanceActionPath]: ['DELETE', 'GET'],
|
||||||
[targetUris.processInstanceLogListPath]: ['GET'],
|
[targetUris.processInstanceLogListPath]: ['GET'],
|
||||||
[targetUris.processInstanceTaskDataPath]: ['GET', 'PUT'],
|
[targetUris.processInstanceTaskDataPath]: ['GET', 'PUT'],
|
||||||
[targetUris.processInstanceSendEventPath]: ['POST'],
|
[targetUris.processInstanceSendEventPath]: ['POST'],
|
||||||
@ -125,8 +125,9 @@ export default function ProcessInstanceShow({ variant }: OwnProps) {
|
|||||||
|
|
||||||
let processInstanceShowPageBaseUrl = `/admin/process-instances/for-me/${params.process_model_id}/${params.process_instance_id}`;
|
let processInstanceShowPageBaseUrl = `/admin/process-instances/for-me/${params.process_model_id}/${params.process_instance_id}`;
|
||||||
let processInstanceLogListPageBaseUrl = `/admin/logs/for-me/${params.process_model_id}/${params.process_instance_id}`;
|
let processInstanceLogListPageBaseUrl = `/admin/logs/for-me/${params.process_model_id}/${params.process_instance_id}`;
|
||||||
|
const processInstanceShowPageBaseUrlAllVariant = `/admin/process-instances/${params.process_model_id}/${params.process_instance_id}`;
|
||||||
if (variant === 'all') {
|
if (variant === 'all') {
|
||||||
processInstanceShowPageBaseUrl = `/admin/process-instances/${params.process_model_id}/${params.process_instance_id}`;
|
processInstanceShowPageBaseUrl = processInstanceShowPageBaseUrlAllVariant;
|
||||||
processInstanceLogListPageBaseUrl = `/admin/logs/${params.process_model_id}/${params.process_instance_id}`;
|
processInstanceLogListPageBaseUrl = `/admin/logs/${params.process_model_id}/${params.process_instance_id}`;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -209,9 +210,33 @@ export default function ProcessInstanceShow({ variant }: OwnProps) {
|
|||||||
});
|
});
|
||||||
};
|
};
|
||||||
|
|
||||||
|
const queryParams = () => {
|
||||||
|
const processIdentifier = searchParams.get('process_identifier');
|
||||||
|
const callActivityTaskId = searchParams.get('bpmn_process_guid');
|
||||||
|
const queryParamArray = [];
|
||||||
|
if (processIdentifier) {
|
||||||
|
queryParamArray.push(`process_identifier=${processIdentifier}`);
|
||||||
|
}
|
||||||
|
if (callActivityTaskId) {
|
||||||
|
queryParamArray.push(`bpmn_process_guid=${callActivityTaskId}`);
|
||||||
|
}
|
||||||
|
let queryParamString = '';
|
||||||
|
if (queryParamArray.length > 0) {
|
||||||
|
queryParamString = `?${queryParamArray.join('&')}`;
|
||||||
|
}
|
||||||
|
return queryParamString;
|
||||||
|
};
|
||||||
|
|
||||||
// to force update the diagram since it could have changed
|
// to force update the diagram since it could have changed
|
||||||
const refreshPage = () => {
|
const refreshPage = () => {
|
||||||
|
// redirect to the all variant page if possible to avoid potential user/task association issues.
|
||||||
|
// such as terminating a process instance with a task that the current user is assigned to which
|
||||||
|
// will remove the task assigned to them and could potentially remove that users association to the process instance
|
||||||
|
if (ability.can('GET', targetUris.processInstanceActionPath)) {
|
||||||
|
window.location.href = `${processInstanceShowPageBaseUrlAllVariant}${queryParams()}`;
|
||||||
|
} else {
|
||||||
window.location.reload();
|
window.location.reload();
|
||||||
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
const terminateProcessInstance = () => {
|
const terminateProcessInstance = () => {
|
||||||
@ -252,23 +277,6 @@ export default function ProcessInstanceShow({ variant }: OwnProps) {
|
|||||||
return !taskToTimeTravelTo;
|
return !taskToTimeTravelTo;
|
||||||
};
|
};
|
||||||
|
|
||||||
const queryParams = () => {
|
|
||||||
const processIdentifier = searchParams.get('process_identifier');
|
|
||||||
const callActivityTaskId = searchParams.get('bpmn_process_guid');
|
|
||||||
const queryParamArray = [];
|
|
||||||
if (processIdentifier) {
|
|
||||||
queryParamArray.push(`process_identifier=${processIdentifier}`);
|
|
||||||
}
|
|
||||||
if (callActivityTaskId) {
|
|
||||||
queryParamArray.push(`bpmn_process_guid=${callActivityTaskId}`);
|
|
||||||
}
|
|
||||||
let queryParamString = '';
|
|
||||||
if (queryParamArray.length > 0) {
|
|
||||||
queryParamString = `?${queryParamArray.join('&')}`;
|
|
||||||
}
|
|
||||||
return queryParamString;
|
|
||||||
};
|
|
||||||
|
|
||||||
const completionViewLink = (label: any, taskGuid: string) => {
|
const completionViewLink = (label: any, taskGuid: string) => {
|
||||||
return (
|
return (
|
||||||
<Link
|
<Link
|
||||||
|
Loading…
x
Reference in New Issue
Block a user