X-Git-Url: https://git.arvados.org/arvados.git/blobdiff_plain/41f6f1e495c82fcfa79b87cf718fa2e9cd91c726..55acac755ba2516c63e902a11e90c6e3754e5c48:/src/store/process-panel/process-panel-actions.ts?ds=sidebyside diff --git a/src/store/process-panel/process-panel-actions.ts b/src/store/process-panel/process-panel-actions.ts index 962f5dfcf3..d21b9b83d0 100644 --- a/src/store/process-panel/process-panel-actions.ts +++ b/src/store/process-panel/process-panel-actions.ts @@ -14,6 +14,7 @@ import { SnackbarKind } from '../snackbar/snackbar-actions'; import { showWorkflowDetails } from 'store/workflow-panel/workflow-panel-actions'; import { loadSubprocessPanel } from "../subprocess-panel/subprocess-panel-actions"; import { initProcessLogsPanel, processLogsPanelActions } from "store/process-logs-panel/process-logs-panel-actions"; +import { CollectionFile } from "models/collection-file"; export const processPanelActions = unionize({ SET_PROCESS_PANEL_CONTAINER_REQUEST_UUID: ofType(), @@ -45,6 +46,26 @@ export const navigateToOutput = (uuid: string) => } }; +export const loadOutputs = (uuid: string, setOutputs) => + async (dispatch: Dispatch, getState: () => RootState, services: ServiceRepository) => { + try { + const files = await services.collectionService.files(uuid); + const collection = await services.collectionService.get(uuid); + const outputFile = files.find((file) => file.name === 'cwl.output.json') as CollectionFile | undefined; + let outputData = outputFile ? await services.collectionService.getFileContents(outputFile) : undefined; + if ((outputData = JSON.parse(outputData)) && collection.portableDataHash) { + setOutputs({ + rawOutputs: outputData, + pdh: collection.portableDataHash, + }); + } else { + setOutputs({}); + } + } catch { + setOutputs({}); + } + }; + export const openWorkflow = (uuid: string) => (dispatch: Dispatch, getState: () => RootState, services: ServiceRepository) => { dispatch(navigateToWorkflows); @@ -56,6 +77,8 @@ export const initProcessPanelFilters = processPanelActions.SET_PROCESS_PANEL_FIL ProcessStatus.COMPLETED, ProcessStatus.FAILED, ProcessStatus.RUNNING, - ProcessStatus.LOCKED, + ProcessStatus.ONHOLD, + ProcessStatus.FAILING, + ProcessStatus.WARNING, ProcessStatus.CANCELLED ]);