2022-10-12 10:21:49 -04:00
import { useContext , useEffect , useState } from 'react' ;
2022-11-07 17:32:29 -05:00
import { Link , useNavigate , useParams } from 'react-router-dom' ;
2022-10-31 15:09:21 -04:00
// @ts-ignore
2022-11-07 17:32:29 -05:00
import { Add , Upload } from '@carbon/icons-react' ;
import {
Accordion ,
AccordionItem ,
Grid ,
Column ,
Dropdown ,
Button ,
Stack ,
ButtonSet ,
Modal ,
FileUploader ,
// @ts-ignore
} from '@carbon/react' ;
2022-10-12 10:21:49 -04:00
import ProcessBreadcrumb from '../components/ProcessBreadcrumb' ;
import FileInput from '../components/FileInput' ;
import HttpService from '../services/HttpService' ;
import ErrorContext from '../contexts/ErrorContext' ;
2022-11-07 17:32:29 -05:00
import { ProcessModel , RecentProcessModel } from '../interfaces' ;
2022-10-12 10:21:49 -04:00
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 ] ;
2022-11-07 17:32:29 -05:00
const [ processModel , setProcessModel ] = useState < ProcessModel | null > ( null ) ;
2022-10-12 10:21:49 -04:00
const [ processInstanceResult , setProcessInstanceResult ] = useState ( null ) ;
2022-11-07 17:32:29 -05:00
const [ reloadModel , setReloadModel ] = useState < boolean > ( false ) ;
const [ filesToUpload , setFilesToUpload ] = useState < any > ( null ) ;
const [ showFileUploadModal , setShowFileUploadModal ] =
useState < boolean > ( false ) ;
const navigate = useNavigate ( ) ;
2022-10-12 10:21:49 -04:00
useEffect ( ( ) = > {
2022-11-07 17:32:29 -05:00
const processResult = ( result : ProcessModel ) = > {
2022-10-12 10:21:49 -04:00
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 ) = > {
2022-10-18 16:41:13 -04:00
setErrorMessage ( null ) ;
2022-10-12 10:21:49 -04:00
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' ,
} ) ;
} ;
2022-11-07 17:32:29 -05:00
const processInstanceResultTag = ( ) = > {
if ( processModel && 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 = (
< span >
You have a task to complete . Go to { ' ' }
< Link to = { ` /tasks/ ${ processInstanceId } / ${ nextTask . id } ` } >
my task
< / Link >
.
< / span >
) ;
}
return (
< div className = "alert alert-success" role = "alert" >
< p >
Process Instance { processInstanceId } kicked off (
< Link
to = { ` /admin/process-models/ ${ processModel . process_group_id } / ${
( processModel as any ) . id
} / process - instances / $ { processInstanceId } ` }
data - qa = "process-instance-show-link"
>
view
< / Link >
) . { takeMeToMyTaskBlurb }
< / p >
< / div >
2022-10-12 10:21:49 -04:00
) ;
}
2022-11-07 17:32:29 -05:00
return null ;
} ;
2022-10-12 10:21:49 -04:00
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 = (
< li key = { processModelFile . name } >
< Link
to = { ` /admin/process-models/ ${
( processModel as any ) . process_group_id
} / $ { ( processModel as any ) . id } / files / $ { processModelFile . name } ` }
>
{ processModelFile . name }
< / Link >
{ primarySuffix }
< / li >
) ;
} else if ( processModelFile . name . match ( /\.(json|md)$/ ) ) {
constructedTag = (
< li key = { processModelFile . name } >
< Link
to = { ` /admin/process-models/ ${
( processModel as any ) . process_group_id
} / $ { ( processModel as any ) . id } / form / $ { processModelFile . name } ` }
>
{ processModelFile . name }
< / Link >
< / li >
) ;
} else {
constructedTag = (
< li key = { processModelFile . name } > { processModelFile . name } < / li >
) ;
}
return constructedTag ;
} ) ;
return < ul > { tags } < / ul > ;
} ;
const processInstancesUl = ( ) = > {
return (
< ul >
< li >
< Link
to = { ` /admin/process-instances?process_group_identifier= ${
( processModel as any ) . process_group_id
} & process_model_identifier = $ { ( processModel as any ) . id } ` }
data - qa = "process-instance-list-link"
>
List
< / Link >
< / li >
< li >
< Link
to = { ` /admin/process-models/ ${
( processModel as any ) . process_group_id
} / $ { ( processModel as any ) . id } / process - instances / reports ` }
data - qa = "process-instance-reports-link"
>
Reports
< / Link >
< / li >
< / ul >
) ;
} ;
2022-11-07 17:32:29 -05:00
const handleFileUploadCancel = ( ) = > {
setShowFileUploadModal ( false ) ;
} ;
const handleFileUpload = ( event : any ) = > {
event . preventDefault ( ) ;
const url = ` /process-models/ ${ ( processModel as any ) . process_group_id } / ${
( processModel as any ) . id
} / files ` ;
const formData = new FormData ( ) ;
formData . append ( 'file' , filesToUpload [ 0 ] ) ;
formData . append ( 'fileName' , filesToUpload [ 0 ] . name ) ;
HttpService . makeCallToBackend ( {
path : url ,
successCallback : onUploadedCallback ,
httpMethod : 'POST' ,
postBody : formData ,
} ) ;
setShowFileUploadModal ( false ) ;
} ;
const fileUploadModal = ( ) = > {
return (
< Modal
open = { showFileUploadModal }
modalHeading = "Upload File"
primaryButtonText = "Upload"
secondaryButtonText = "Cancel"
onSecondarySubmit = { handleFileUploadCancel }
onRequestClose = { handleFileUploadCancel }
onRequestSubmit = { handleFileUpload }
>
< FileUploader
labelTitle = "Upload files"
labelDescription = "Max file size is 500mb. Only .bpmn, .dmn, and .json files are supported."
buttonLabel = "Add file"
buttonKind = "primary"
size = "md"
filenameStatus = "edit"
role = "button"
accept = { [ '.bpmn' , '.dmn' , '.json' ] }
disabled = { false }
iconDescription = "Delete file"
name = ""
multiple = { false }
onChange = { ( event : any ) = > setFilesToUpload ( event . target . files ) }
/ >
< / Modal >
) ;
} ;
2022-10-12 10:21:49 -04:00
const processModelButtons = ( ) = > {
return (
2022-11-07 17:32:29 -05:00
< Accordion >
< AccordionItem
title = {
< Stack orientation = "horizontal" >
< span >
< Button size = "sm" kind = "ghost" >
Files
< / Button >
< / span >
< / Stack >
}
2022-10-12 10:21:49 -04:00
>
2022-11-07 17:32:29 -05:00
< ButtonSet >
< Button
renderIcon = { Upload }
onClick = { ( ) = > setShowFileUploadModal ( true ) }
size = "sm"
kind = ""
className = "button-white-background"
>
Upload File
< / Button >
< Button
renderIcon = { Add }
href = { ` /admin/process-models/ ${
( processModel as any ) . process_group_id
} / $ { ( processModel as any ) . id } / files ? file_type = dmn ` }
size = "sm"
>
New DMN File
< / Button >
< Button
renderIcon = { Add }
href = { ` /admin/process-models/ ${
( processModel as any ) . process_group_id
} / $ { ( processModel as any ) . id } / form ? file_ext = json ` }
size = "sm"
>
New JSON File
< / Button >
< Button
renderIcon = { Add }
href = { ` /admin/process-models/ ${
( processModel as any ) . process_group_id
} / $ { ( processModel as any ) . id } / form ? file_ext = md ` }
size = "sm"
>
New Markdown File
< / Button >
< / ButtonSet >
< br / >
{ processModelFileList ( ) }
< / AccordionItem >
< / Accordion >
2022-10-12 10:21:49 -04:00
) ;
} ;
2022-11-07 17:32:29 -05:00
if ( processModel ) {
2022-10-12 10:21:49 -04:00
return (
< >
< ProcessBreadcrumb
2022-11-07 17:32:29 -05:00
processGroupId = { processModel . process_group_id }
processModelId = { processModel . id }
2022-10-12 10:21:49 -04:00
/ >
2022-11-07 17:32:29 -05:00
{ fileUploadModal ( ) }
{ processInstanceResultTag ( ) }
2022-10-12 10:21:49 -04:00
< br / >
{ processModelButtons ( ) }
< br / >
< br / >
< h3 > Process Instances < / h3 >
{ processInstancesUl ( ) }
< / >
) ;
}
return null ;
}