X-Git-Url: https://git.arvados.org/arvados-workbench2.git/blobdiff_plain/454ef1c106b3d738526d65ecfae8db98ad7bebc2..627132ee694565c5f3cf347fa0bbee8e514de884:/src/store/process-panel/process-panel-actions.ts diff --git a/src/store/process-panel/process-panel-actions.ts b/src/store/process-panel/process-panel-actions.ts index 2aa914af..b62a4886 100644 --- a/src/store/process-panel/process-panel-actions.ts +++ b/src/store/process-panel/process-panel-actions.ts @@ -2,46 +2,94 @@ // // SPDX-License-Identifier: AGPL-3.0 -import { unionize, ofType, UnionOf } from "~/common/unionize"; -import { loadProcess } from '~/store/processes/processes-actions'; +import { unionize, ofType, UnionOf } from "common/unionize"; +import { getRawOutputs, loadProcess } from 'store/processes/processes-actions'; import { Dispatch } from 'redux'; -import { ProcessStatus } from '~/store/processes/process'; -import { RootState } from '~/store/store'; -import { ServiceRepository } from "~/services/services"; -import { navigateToCollection } from '~/store/navigation/navigation-action'; -import { snackbarActions } from '~/store/snackbar/snackbar-actions'; +import { ProcessStatus } from 'store/processes/process'; +import { RootState } from 'store/store'; +import { ServiceRepository } from "services/services"; +import { navigateTo, navigateToWorkflows } from 'store/navigation/navigation-action'; +import { snackbarActions } from 'store/snackbar/snackbar-actions'; 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"; +import { ContainerRequestResource } from "models/container-request"; -export const procesPanelActions = unionize({ +export const processPanelActions = unionize({ + SET_PROCESS_PANEL_CONTAINER_REQUEST_UUID: ofType(), SET_PROCESS_PANEL_FILTERS: ofType(), TOGGLE_PROCESS_PANEL_FILTER: ofType(), }); -export type ProcessPanelAction = UnionOf; +export type ProcessPanelAction = UnionOf; -export const toggleProcessPanelFilter = procesPanelActions.TOGGLE_PROCESS_PANEL_FILTER; +export const toggleProcessPanelFilter = processPanelActions.TOGGLE_PROCESS_PANEL_FILTER; export const loadProcessPanel = (uuid: string) => - (dispatch: Dispatch) => { - dispatch(loadProcess(uuid)); + async (dispatch: Dispatch) => { + dispatch(processLogsPanelActions.RESET_PROCESS_LOGS_PANEL()); + dispatch(processPanelActions.SET_PROCESS_PANEL_CONTAINER_REQUEST_UUID(uuid)); + await dispatch(loadProcess(uuid)); dispatch(initProcessPanelFilters); + dispatch(initProcessLogsPanel(uuid)); + dispatch(loadSubprocessPanel()); }; export const navigateToOutput = (uuid: string) => async (dispatch: Dispatch, getState: () => RootState, services: ServiceRepository) => { try { await services.collectionService.get(uuid); - dispatch(navigateToCollection(uuid)); + dispatch(navigateTo(uuid)); } catch { dispatch(snackbarActions.OPEN_SNACKBAR({ message: 'This collection does not exists!', hideDuration: 2000, kind: SnackbarKind.ERROR })); } }; -export const initProcessPanelFilters = procesPanelActions.SET_PROCESS_PANEL_FILTERS([ +export const loadOutputs = (containerRequest: ContainerRequestResource, setOutputs) => + async (dispatch: Dispatch, getState: () => RootState, services: ServiceRepository) => { + if (!containerRequest.outputUuid) {setOutputs({}); return;}; + try { + const propsOutputs = getRawOutputs(containerRequest); + const filesPromise = services.collectionService.files(containerRequest.outputUuid); + const collectionPromise = services.collectionService.get(containerRequest.outputUuid); + const [files, collection] = await Promise.all([filesPromise, collectionPromise]); + + // If has propsOutput, skip fetching cwl.output.json + if (propsOutputs !== undefined) { + setOutputs({rawOutputs: propsOutputs, pdh: collection.portableDataHash}); + } else { + // Fetch outputs from keep + 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); + dispatch(showWorkflowDetails(uuid)); + }; + +export const initProcessPanelFilters = processPanelActions.SET_PROCESS_PANEL_FILTERS([ ProcessStatus.QUEUED, ProcessStatus.COMPLETED, ProcessStatus.FAILED, ProcessStatus.RUNNING, - ProcessStatus.LOCKED, + ProcessStatus.ONHOLD, + ProcessStatus.FAILING, + ProcessStatus.WARNING, ProcessStatus.CANCELLED ]);