X-Git-Url: https://git.arvados.org/arvados-workbench2.git/blobdiff_plain/b7de31f185fccd2f9b276c1e89754d288e7facfe..f75b0aa3966895160535bad24b05c1a763665a5a:/src/store/workflow-panel/workflow-panel-actions.ts diff --git a/src/store/workflow-panel/workflow-panel-actions.ts b/src/store/workflow-panel/workflow-panel-actions.ts index 3d51cbb8..66a15a9e 100644 --- a/src/store/workflow-panel/workflow-panel-actions.ts +++ b/src/store/workflow-panel/workflow-panel-actions.ts @@ -3,15 +3,28 @@ // SPDX-License-Identifier: AGPL-3.0 import { Dispatch } from 'redux'; -import { RootState } from '~/store/store'; -import { ServiceRepository } from '~/services/services'; -import { bindDataExplorerActions } from '~/store/data-explorer/data-explorer-action'; -import { propertiesActions } from '~/store/properties/properties-actions'; -import { getResource } from '../resources/resources'; -import { getProperty } from '~/store/properties/properties'; -import { WorkflowResource } from '~/models/workflow'; -import { navigateToRunProcess } from '~/store/navigation/navigation-action'; -import { goToStep, runProcessPanelActions } from '~/store/run-process-panel/run-process-panel-actions'; +import { RootState } from 'store/store'; +import { ServiceRepository } from 'services/services'; +import { bindDataExplorerActions } from 'store/data-explorer/data-explorer-action'; +import { propertiesActions } from 'store/properties/properties-actions'; +import { getProperty } from 'store/properties/properties'; +import { navigateToRunProcess } from 'store/navigation/navigation-action'; +import { + goToStep, + runProcessPanelActions, + loadPresets, + getWorkflowRunnerSettings +} from 'store/run-process-panel/run-process-panel-actions'; +import { snackbarActions } from 'store/snackbar/snackbar-actions'; +import { initialize } from 'redux-form'; +import { RUN_PROCESS_BASIC_FORM } from 'views/run-process-panel/run-process-basic-form'; +import { RUN_PROCESS_INPUTS_FORM } from 'views/run-process-panel/run-process-inputs-form'; +import { RUN_PROCESS_ADVANCED_FORM } from 'views/run-process-panel/run-process-advanced-form'; +import { getResource } from 'store/resources/resources'; +import { ProjectResource } from 'models/project'; +import { UserResource } from 'models/user'; +import { getUserUuid } from "common/getuser"; +import { getWorkflowInputs, parseWorkflowDefinition } from 'models/workflow'; export const WORKFLOW_PANEL_ID = "workflowPanel"; const UUID_PREFIX_PROPERTY_NAME = 'uuidPrefix'; @@ -32,23 +45,62 @@ export const getUuidPrefix = (state: RootState) => { return state.properties.uuidPrefix; }; -export const openRunProcess = (uuid: string) => - async (dispatch: Dispatch, getState: () => RootState, services: ServiceRepository) => { +export const openRunProcess = (workflowUuid: string, ownerUuid?: string, name?: string, inputObj?: { [key: string]: any }) => + async (dispatch: Dispatch, getState: () => RootState, services: ServiceRepository) => { + const response = await services.workflowService.list(); + dispatch(runProcessPanelActions.SET_WORKFLOWS(response.items)); + const workflows = getState().runProcessPanel.searchWorkflows; - const workflow = workflows.find(workflow => workflow.uuid === uuid); - dispatch(navigateToRunProcess); - dispatch(runProcessPanelActions.RESET_RUN_PROCESS_PANEL()); - dispatch(goToStep(1)); - dispatch(runProcessPanelActions.SET_STEP_CHANGED(true)); - dispatch(runProcessPanelActions.SET_SELECTED_WORKFLOW(workflow!)); + const workflow = workflows.find(workflow => workflow.uuid === workflowUuid); + if (workflow) { + dispatch(navigateToRunProcess); + dispatch(goToStep(1)); + dispatch(runProcessPanelActions.SET_STEP_CHANGED(true)); + dispatch(runProcessPanelActions.SET_SELECTED_WORKFLOW(workflow)); + dispatch(loadPresets(workflow.uuid)); + + dispatch(initialize(RUN_PROCESS_ADVANCED_FORM, getWorkflowRunnerSettings(workflow))); + let owner; + if (ownerUuid) { + // Must be writable. + const userUuid = getUserUuid(getState()); + owner = getResource(ownerUuid)(getState().resources); + if (!owner || !userUuid || owner.writableBy.indexOf(userUuid) === -1) { + owner = undefined; + } + } + if (owner) { + dispatch(runProcessPanelActions.SET_PROCESS_OWNER_UUID(owner.uuid)); + } + + dispatch(initialize(RUN_PROCESS_BASIC_FORM, { name, owner })); + + const definition = parseWorkflowDefinition(workflow); + if (definition) { + const inputs = getWorkflowInputs(definition); + if (inputs) { + const values = inputs.reduce((values, input) => ({ + ...values, + [input.id]: input.default, + }), {}); + dispatch(initialize(RUN_PROCESS_INPUTS_FORM, values)); + } + } + + if (inputObj) { + dispatch(initialize(RUN_PROCESS_INPUTS_FORM, inputObj)); + } + } else { + dispatch(snackbarActions.OPEN_SNACKBAR({ message: `You can't run this process` })); + } }; export const getPublicUserUuid = (state: RootState) => { - const prefix = getProperty(UUID_PREFIX_PROPERTY_NAME)(state.properties); + const prefix = state.auth.localCluster; return `${prefix}-tpzed-anonymouspublic`; }; export const getPublicGroupUuid = (state: RootState) => { - const prefix = getProperty(UUID_PREFIX_PROPERTY_NAME)(state.properties); + const prefix = state.auth.localCluster; return `${prefix}-j7d0g-anonymouspublic`; }; @@ -57,5 +109,7 @@ export const showWorkflowDetails = (uuid: string) => export const getWorkflowDetails = (state: RootState) => { const uuid = getProperty(WORKFLOW_PANEL_DETAILS_UUID)(state.properties); - return uuid ? getResource(uuid)(state.resources) : undefined; + const workflows = state.runProcessPanel.workflows; + const workflow = workflows.find(workflow => workflow.uuid === uuid); + return workflow || undefined; };