16073: Add process IO panels with image preview and raw view
[arvados.git] / src / store / process-panel / process-panel-actions.ts
index 962f5dfcf3b6a123aaaa3a7993ef7844bf77a39c..d21b9b83d0669108b2bf017b72bb43cb44cfb9c4 100644 (file)
@@ -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<string>(),
@@ -45,6 +46,26 @@ export const navigateToOutput = (uuid: string) =>
         }
     };
 
+export const loadOutputs = (uuid: string, setOutputs) =>
+    async (dispatch: Dispatch<any>, 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<any>(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
 ]);