pass full tasks list to react diagram editor for coloring w/ burnettk
This commit is contained in:
parent
1b65a277c4
commit
48ff72b00b
|
@ -1,6 +1,10 @@
|
||||||
import { Notification } from './Notification';
|
import { Notification } from './Notification';
|
||||||
import useAPIError from '../hooks/UseApiError';
|
import useAPIError from '../hooks/UseApiError';
|
||||||
import { ErrorForDisplay } from '../interfaces';
|
import {
|
||||||
|
ErrorForDisplay,
|
||||||
|
ProcessInstanceEventErrorDetail,
|
||||||
|
ProcessInstanceLogEntry,
|
||||||
|
} from '../interfaces';
|
||||||
|
|
||||||
function errorDetailDisplay(
|
function errorDetailDisplay(
|
||||||
errorObject: any,
|
errorObject: any,
|
||||||
|
@ -19,6 +23,23 @@ function errorDetailDisplay(
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
export const errorForDisplayFromProcessInstanceErrorDetail = (
|
||||||
|
processInstanceEvent: ProcessInstanceLogEntry,
|
||||||
|
processInstanceErrorEventDetail: ProcessInstanceEventErrorDetail
|
||||||
|
) => {
|
||||||
|
const errorForDisplay: ErrorForDisplay = {
|
||||||
|
message: processInstanceErrorEventDetail.message,
|
||||||
|
messageClassName: 'failure-string',
|
||||||
|
task_name: processInstanceEvent.task_definition_name,
|
||||||
|
task_id: processInstanceEvent.task_definition_identifier,
|
||||||
|
line_number: processInstanceErrorEventDetail.task_line_number,
|
||||||
|
error_line: processInstanceErrorEventDetail.task_line_contents,
|
||||||
|
task_trace: processInstanceErrorEventDetail.task_trace,
|
||||||
|
stacktrace: processInstanceErrorEventDetail.stacktrace,
|
||||||
|
};
|
||||||
|
return errorForDisplay;
|
||||||
|
};
|
||||||
|
|
||||||
export const childrenForErrorObject = (errorObject: ErrorForDisplay) => {
|
export const childrenForErrorObject = (errorObject: ErrorForDisplay) => {
|
||||||
let sentryLinkTag = null;
|
let sentryLinkTag = null;
|
||||||
if (errorObject.sentry_link) {
|
if (errorObject.sentry_link) {
|
||||||
|
|
|
@ -66,10 +66,7 @@ import { usePermissionFetcher } from '../hooks/PermissionService';
|
||||||
type OwnProps = {
|
type OwnProps = {
|
||||||
processModelId: string;
|
processModelId: string;
|
||||||
diagramType: string;
|
diagramType: string;
|
||||||
readyOrWaitingProcessInstanceTasks?: Task[] | null;
|
tasks?: Task[] | null;
|
||||||
completedProcessInstanceTasks?: Task[] | null;
|
|
||||||
cancelledProcessInstanceTasks?: Task[] | null;
|
|
||||||
erroredProcessInstanceTasks?: Task[] | null;
|
|
||||||
saveDiagram?: (..._args: any[]) => any;
|
saveDiagram?: (..._args: any[]) => any;
|
||||||
onDeleteFile?: (..._args: any[]) => any;
|
onDeleteFile?: (..._args: any[]) => any;
|
||||||
isPrimaryFile?: boolean;
|
isPrimaryFile?: boolean;
|
||||||
|
@ -94,10 +91,7 @@ type OwnProps = {
|
||||||
export default function ReactDiagramEditor({
|
export default function ReactDiagramEditor({
|
||||||
processModelId,
|
processModelId,
|
||||||
diagramType,
|
diagramType,
|
||||||
readyOrWaitingProcessInstanceTasks,
|
tasks,
|
||||||
completedProcessInstanceTasks,
|
|
||||||
cancelledProcessInstanceTasks,
|
|
||||||
erroredProcessInstanceTasks,
|
|
||||||
saveDiagram,
|
saveDiagram,
|
||||||
onDeleteFile,
|
onDeleteFile,
|
||||||
isPrimaryFile,
|
isPrimaryFile,
|
||||||
|
@ -420,56 +414,29 @@ export default function ReactDiagramEditor({
|
||||||
// highlighting a field
|
// highlighting a field
|
||||||
// Option 3 at:
|
// Option 3 at:
|
||||||
// https://github.com/bpmn-io/bpmn-js-examples/tree/master/colors
|
// https://github.com/bpmn-io/bpmn-js-examples/tree/master/colors
|
||||||
if (readyOrWaitingProcessInstanceTasks) {
|
if (tasks) {
|
||||||
const bpmnProcessIdentifiers = getBpmnProcessIdentifiers(
|
const bpmnProcessIdentifiers = getBpmnProcessIdentifiers(
|
||||||
canvas.getRootElement()
|
canvas.getRootElement()
|
||||||
);
|
);
|
||||||
readyOrWaitingProcessInstanceTasks.forEach((readyOrWaitingBpmnTask) => {
|
tasks.forEach((task: Task) => {
|
||||||
highlightBpmnIoElement(
|
let className = '';
|
||||||
canvas,
|
if (task.state === 'COMPLETED') {
|
||||||
readyOrWaitingBpmnTask,
|
className = 'completed-task-highlight';
|
||||||
'active-task-highlight',
|
} else if (task.state === 'READY' || task.state === 'WAITING') {
|
||||||
bpmnProcessIdentifiers
|
className = 'active-task-highlight';
|
||||||
);
|
} else if (task.state === 'CANCELLED') {
|
||||||
});
|
className = 'cancelled-task-highlight';
|
||||||
|
} else if (task.state === 'ERROR') {
|
||||||
|
className = 'errored-task-highlight';
|
||||||
}
|
}
|
||||||
if (completedProcessInstanceTasks) {
|
if (className) {
|
||||||
const bpmnProcessIdentifiers = getBpmnProcessIdentifiers(
|
|
||||||
canvas.getRootElement()
|
|
||||||
);
|
|
||||||
completedProcessInstanceTasks.forEach((completedTask) => {
|
|
||||||
highlightBpmnIoElement(
|
highlightBpmnIoElement(
|
||||||
canvas,
|
canvas,
|
||||||
completedTask,
|
task,
|
||||||
'completed-task-highlight',
|
className,
|
||||||
bpmnProcessIdentifiers
|
bpmnProcessIdentifiers
|
||||||
);
|
);
|
||||||
});
|
|
||||||
}
|
}
|
||||||
if (cancelledProcessInstanceTasks) {
|
|
||||||
const bpmnProcessIdentifiers = getBpmnProcessIdentifiers(
|
|
||||||
canvas.getRootElement()
|
|
||||||
);
|
|
||||||
cancelledProcessInstanceTasks.forEach((cancelledTask) => {
|
|
||||||
highlightBpmnIoElement(
|
|
||||||
canvas,
|
|
||||||
cancelledTask,
|
|
||||||
'cancelled-task-highlight',
|
|
||||||
bpmnProcessIdentifiers
|
|
||||||
);
|
|
||||||
});
|
|
||||||
}
|
|
||||||
if (erroredProcessInstanceTasks) {
|
|
||||||
const bpmnProcessIdentifiers = getBpmnProcessIdentifiers(
|
|
||||||
canvas.getRootElement()
|
|
||||||
);
|
|
||||||
erroredProcessInstanceTasks.forEach((erroredTask) => {
|
|
||||||
highlightBpmnIoElement(
|
|
||||||
canvas,
|
|
||||||
erroredTask,
|
|
||||||
'errored-task-highlight',
|
|
||||||
bpmnProcessIdentifiers
|
|
||||||
);
|
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -549,10 +516,8 @@ export default function ReactDiagramEditor({
|
||||||
diagramType,
|
diagramType,
|
||||||
diagramXML,
|
diagramXML,
|
||||||
diagramXMLString,
|
diagramXMLString,
|
||||||
readyOrWaitingProcessInstanceTasks,
|
|
||||||
completedProcessInstanceTasks,
|
|
||||||
cancelledProcessInstanceTasks,
|
|
||||||
fileName,
|
fileName,
|
||||||
|
tasks,
|
||||||
performingXmlUpdates,
|
performingXmlUpdates,
|
||||||
processModelId,
|
processModelId,
|
||||||
url,
|
url,
|
||||||
|
|
|
@ -37,6 +37,7 @@ export interface EventDefinition {
|
||||||
message_var?: string;
|
message_var?: string;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// TODO: merge with ProcessInstanceTask
|
||||||
export interface Task {
|
export interface Task {
|
||||||
id: number;
|
id: number;
|
||||||
guid: string;
|
guid: string;
|
||||||
|
@ -55,13 +56,6 @@ export interface Task {
|
||||||
event_definition?: EventDefinition;
|
event_definition?: EventDefinition;
|
||||||
}
|
}
|
||||||
|
|
||||||
export interface TaskIds {
|
|
||||||
completed: Task[];
|
|
||||||
readyOrWaiting: Task[];
|
|
||||||
cancelled: Task[];
|
|
||||||
errored: Task[];
|
|
||||||
}
|
|
||||||
|
|
||||||
export interface ProcessInstanceTask {
|
export interface ProcessInstanceTask {
|
||||||
id: string;
|
id: string;
|
||||||
task_id: string;
|
task_id: string;
|
||||||
|
|
|
@ -32,14 +32,16 @@ import {
|
||||||
import HttpService from '../services/HttpService';
|
import HttpService from '../services/HttpService';
|
||||||
import { useUriListForPermissions } from '../hooks/UriListForPermissions';
|
import { useUriListForPermissions } from '../hooks/UriListForPermissions';
|
||||||
import {
|
import {
|
||||||
ErrorForDisplay,
|
|
||||||
PermissionsToCheck,
|
PermissionsToCheck,
|
||||||
ProcessInstanceEventErrorDetail,
|
ProcessInstanceEventErrorDetail,
|
||||||
ProcessInstanceLogEntry,
|
ProcessInstanceLogEntry,
|
||||||
} from '../interfaces';
|
} from '../interfaces';
|
||||||
import Filters from '../components/Filters';
|
import Filters from '../components/Filters';
|
||||||
import { usePermissionFetcher } from '../hooks/PermissionService';
|
import { usePermissionFetcher } from '../hooks/PermissionService';
|
||||||
import { childrenForErrorObject } from '../components/ErrorDisplay';
|
import {
|
||||||
|
childrenForErrorObject,
|
||||||
|
errorForDisplayFromProcessInstanceErrorDetail,
|
||||||
|
} from '../components/ErrorDisplay';
|
||||||
|
|
||||||
type OwnProps = {
|
type OwnProps = {
|
||||||
variant: string;
|
variant: string;
|
||||||
|
@ -158,17 +160,12 @@ export default function ProcessInstanceLogList({ variant }: OwnProps) {
|
||||||
<Loading className="some-class" withOverlay={false} small />
|
<Loading className="some-class" withOverlay={false} small />
|
||||||
);
|
);
|
||||||
if (eventErrorDetails) {
|
if (eventErrorDetails) {
|
||||||
const errorForDisplay: ErrorForDisplay = {
|
const errorForDisplay = errorForDisplayFromProcessInstanceErrorDetail(
|
||||||
message: eventErrorDetails.message,
|
eventForModal,
|
||||||
messageClassName: 'failure-string',
|
eventErrorDetails
|
||||||
task_name: eventForModal.task_definition_name,
|
);
|
||||||
task_id: eventForModal.task_definition_identifier,
|
|
||||||
line_number: eventErrorDetails.task_line_number,
|
|
||||||
error_line: eventErrorDetails.task_line_contents,
|
|
||||||
task_trace: eventErrorDetails.task_trace,
|
|
||||||
stacktrace: eventErrorDetails.stacktrace,
|
|
||||||
};
|
|
||||||
const errorChildren = childrenForErrorObject(errorForDisplay);
|
const errorChildren = childrenForErrorObject(errorForDisplay);
|
||||||
|
// eslint-disable-next-line react/jsx-no-useless-fragment
|
||||||
errorMessageTag = <>{errorChildren}</>;
|
errorMessageTag = <>{errorChildren}</>;
|
||||||
}
|
}
|
||||||
return (
|
return (
|
||||||
|
|
|
@ -47,7 +47,6 @@ import {
|
||||||
ProcessInstanceMetadata,
|
ProcessInstanceMetadata,
|
||||||
Task,
|
Task,
|
||||||
TaskDefinitionPropertiesJson,
|
TaskDefinitionPropertiesJson,
|
||||||
TaskIds,
|
|
||||||
} from '../interfaces';
|
} from '../interfaces';
|
||||||
import { usePermissionFetcher } from '../hooks/PermissionService';
|
import { usePermissionFetcher } from '../hooks/PermissionService';
|
||||||
import ProcessInstanceClass from '../classes/ProcessInstanceClass';
|
import ProcessInstanceClass from '../classes/ProcessInstanceClass';
|
||||||
|
@ -230,30 +229,6 @@ export default function ProcessInstanceShow({ variant }: OwnProps) {
|
||||||
});
|
});
|
||||||
};
|
};
|
||||||
|
|
||||||
const getTaskIds = () => {
|
|
||||||
const taskIds: TaskIds = {
|
|
||||||
completed: [],
|
|
||||||
readyOrWaiting: [],
|
|
||||||
cancelled: [],
|
|
||||||
errored: [],
|
|
||||||
};
|
|
||||||
if (tasks) {
|
|
||||||
tasks.forEach(function getUserTasksElement(task: Task) {
|
|
||||||
if (task.state === 'COMPLETED') {
|
|
||||||
taskIds.completed.push(task);
|
|
||||||
} else if (task.state === 'READY' || task.state === 'WAITING') {
|
|
||||||
taskIds.readyOrWaiting.push(task);
|
|
||||||
} else if (task.state === 'CANCELLED') {
|
|
||||||
taskIds.cancelled.push(task);
|
|
||||||
} else if (task.state === 'ERROR') {
|
|
||||||
taskIds.errored.push(task);
|
|
||||||
}
|
|
||||||
return null;
|
|
||||||
});
|
|
||||||
}
|
|
||||||
return taskIds;
|
|
||||||
};
|
|
||||||
|
|
||||||
const currentToTaskGuid = () => {
|
const currentToTaskGuid = () => {
|
||||||
if (taskToTimeTravelTo) {
|
if (taskToTimeTravelTo) {
|
||||||
return taskToTimeTravelTo.guid;
|
return taskToTimeTravelTo.guid;
|
||||||
|
@ -1101,7 +1076,6 @@ export default function ProcessInstanceShow({ variant }: OwnProps) {
|
||||||
};
|
};
|
||||||
|
|
||||||
if (processInstance && (tasks || tasksCallHadError)) {
|
if (processInstance && (tasks || tasksCallHadError)) {
|
||||||
const taskIds = getTaskIds();
|
|
||||||
const processModelId = unModifyProcessIdentifierForPathParam(
|
const processModelId = unModifyProcessIdentifierForPathParam(
|
||||||
params.process_model_id ? params.process_model_id : ''
|
params.process_model_id ? params.process_model_id : ''
|
||||||
);
|
);
|
||||||
|
@ -1159,10 +1133,7 @@ export default function ProcessInstanceShow({ variant }: OwnProps) {
|
||||||
processModelId={processModelId || ''}
|
processModelId={processModelId || ''}
|
||||||
diagramXML={processInstance.bpmn_xml_file_contents || ''}
|
diagramXML={processInstance.bpmn_xml_file_contents || ''}
|
||||||
fileName={processInstance.bpmn_xml_file_contents || ''}
|
fileName={processInstance.bpmn_xml_file_contents || ''}
|
||||||
readyOrWaitingProcessInstanceTasks={taskIds.readyOrWaiting}
|
tasks={tasks}
|
||||||
completedProcessInstanceTasks={taskIds.completed}
|
|
||||||
cancelledProcessInstanceTasks={taskIds.cancelled}
|
|
||||||
erroredProcessInstanceTasks={taskIds.errored}
|
|
||||||
diagramType="readonly"
|
diagramType="readonly"
|
||||||
onElementClick={handleClickedDiagramTask}
|
onElementClick={handleClickedDiagramTask}
|
||||||
/>
|
/>
|
||||||
|
|
Loading…
Reference in New Issue