import { useContext, useEffect, useState } from 'react'; import { Link, useParams } from 'react-router-dom'; // @ts-ignore import { Button, Stack } from '@carbon/react'; import ProcessBreadcrumb from '../components/ProcessBreadcrumb'; import FileInput from '../components/FileInput'; import HttpService from '../services/HttpService'; import ErrorContext from '../contexts/ErrorContext'; import { RecentProcessModel } from '../interfaces'; const storeRecentProcessModelInLocalStorage = ( processModelForStorage: any, params: any ) => { if ( params.process_group_id === undefined || params.process_model_id === undefined ) { return; } // All values stored in localStorage are strings. // Grab our recentProcessModels string from localStorage. const stringFromLocalStorage = window.localStorage.getItem( 'recentProcessModels' ); // adapted from https://stackoverflow.com/a/59424458/6090676 // If that value is null (meaning that we've never saved anything to that spot in localStorage before), use an empty array as our array. Otherwise, use the value we parse out. let array: RecentProcessModel[] = []; if (stringFromLocalStorage !== null) { // Then parse that string into an actual value. array = JSON.parse(stringFromLocalStorage); } // Here's the value we want to add const value = { processGroupIdentifier: processModelForStorage.process_group_id, processModelIdentifier: processModelForStorage.id, processModelDisplayName: processModelForStorage.display_name, }; // If our parsed/empty array doesn't already have this value in it... const matchingItem = array.find( (item) => item.processGroupIdentifier === value.processGroupIdentifier && item.processModelIdentifier === value.processModelIdentifier ); if (matchingItem === undefined) { // add the value to the beginning of the array array.unshift(value); // Keep the array to 3 items if (array.length > 3) { array.pop(); } // turn the array WITH THE NEW VALUE IN IT into a string to prepare it to be stored in localStorage const stringRepresentingArray = JSON.stringify(array); // and store it in localStorage as "recentProcessModels" window.localStorage.setItem('recentProcessModels', stringRepresentingArray); } }; export default function ProcessModelShow() { const params = useParams(); const setErrorMessage = (useContext as any)(ErrorContext)[1]; const [processModel, setProcessModel] = useState({}); const [processInstanceResult, setProcessInstanceResult] = useState(null); const [reloadModel, setReloadModel] = useState(false); useEffect(() => { const processResult = (result: object) => { setProcessModel(result); setReloadModel(false); storeRecentProcessModelInLocalStorage(result, params); }; HttpService.makeCallToBackend({ path: `/process-models/${params.process_group_id}/${params.process_model_id}`, successCallback: processResult, }); }, [params, reloadModel]); const processModelRun = (processInstance: any) => { setErrorMessage(null); HttpService.makeCallToBackend({ path: `/process-models/${params.process_group_id}/${params.process_model_id}/process-instances/${processInstance.id}/run`, successCallback: setProcessInstanceResult, failureCallback: setErrorMessage, httpMethod: 'POST', }); }; const processInstanceCreateAndRun = () => { HttpService.makeCallToBackend({ path: `/process-models/${params.process_group_id}/${params.process_model_id}/process-instances`, successCallback: processModelRun, httpMethod: 'POST', }); }; let processInstanceResultTag = null; if (processInstanceResult) { let takeMeToMyTaskBlurb = null; // FIXME: ensure that the task is actually for the current user as well const processInstanceId = (processInstanceResult as any).id; const nextTask = (processInstanceResult as any).next_task; if (nextTask && nextTask.state === 'READY') { takeMeToMyTaskBlurb = ( You have a task to complete. Go to{' '} my task . ); } processInstanceResultTag = (

Process Instance {processInstanceId} kicked off ( view ). {takeMeToMyTaskBlurb}

); } const onUploadedCallback = () => { setReloadModel(true); }; const processModelFileList = () => { let constructedTag; const tags = (processModel as any).files.map((processModelFile: any) => { if (processModelFile.name.match(/\.(dmn|bpmn)$/)) { let primarySuffix = ''; if (processModelFile.name === (processModel as any).primary_file_name) { primarySuffix = '- Primary File'; } constructedTag = (
  • {processModelFile.name} {primarySuffix}
  • ); } else if (processModelFile.name.match(/\.(json|md)$/)) { constructedTag = (
  • {processModelFile.name}
  • ); } else { constructedTag = (
  • {processModelFile.name}
  • ); } return constructedTag; }); return ; }; const processInstancesUl = () => { return ( ); }; const processModelButtons = () => { return ( ); }; if (Object.keys(processModel).length > 1) { return ( <> {processInstanceResultTag}
    {processModelButtons()}

    Process Instances

    {processInstancesUl()}

    Files

    {processModelFileList()} ); } return null; }