1 // Copyright (C) The Arvados Authors. All rights reserved.
3 // SPDX-License-Identifier: AGPL-3.0
5 import React from 'react';
6 import { Grid, Button } from '@mui/material';
7 import { RunProcessBasicForm, RUN_PROCESS_BASIC_FORM } from './run-process-basic-form';
8 import { RunProcessInputsForm } from 'views/run-process-panel/run-process-inputs-form';
9 import { CommandInputParameter, WorkflowResource } from 'models/workflow';
10 import { connect } from 'react-redux';
11 import { RootState } from 'store/store';
12 import { isValid } from 'redux-form';
13 import { RUN_PROCESS_INPUTS_FORM } from './run-process-inputs-form';
14 import { RunProcessAdvancedForm, RUN_PROCESS_ADVANCED_FORM } from './run-process-advanced-form';
15 import { createStructuredSelector } from 'reselect';
16 import { selectPreset } from 'store/run-process-panel/run-process-panel-actions';
18 export interface RunProcessSecondStepFormDataProps {
19 inputs: CommandInputParameter[];
20 workflow?: WorkflowResource;
21 presets?: WorkflowResource[];
22 selectedPreset?: WorkflowResource;
26 export interface RunProcessSecondStepFormActionProps {
28 runProcess: () => void;
29 onPresetChange: (preset: WorkflowResource) => void;
32 const selectedWorkflowSelector = (state: RootState) =>
33 state.runProcessPanel.selectedWorkflow;
35 const presetsSelector = (state: RootState) =>
36 state.runProcessPanel.presets;
38 const selectedPresetSelector = (state: RootState) =>
39 state.runProcessPanel.selectedPreset;
41 const inputsSelector = (state: RootState) =>
42 state.runProcessPanel.inputs;
44 const validSelector = (state: RootState) =>
45 isValid(RUN_PROCESS_BASIC_FORM)(state) && isValid(RUN_PROCESS_INPUTS_FORM)(state) && isValid(RUN_PROCESS_ADVANCED_FORM)(state);
47 const mapStateToProps = createStructuredSelector({
48 inputs: inputsSelector,
50 workflow: selectedWorkflowSelector,
51 presets: presetsSelector,
52 selectedPreset: selectedPresetSelector,
55 export type RunProcessSecondStepFormProps = RunProcessSecondStepFormDataProps & RunProcessSecondStepFormActionProps;
56 export const RunProcessSecondStepForm = connect(mapStateToProps, { onPresetChange: selectPreset })(
57 ({ inputs, workflow, selectedPreset, presets, onPresetChange, valid, goBack, runProcess }: RunProcessSecondStepFormProps) =>
58 <Grid container spacing={2} data-cy="new-process-panel">
60 <RunProcessBasicForm workflow={workflow} />
61 <RunProcessInputsForm inputs={inputs} />
62 <RunProcessAdvancedForm />
65 <Button color="primary" onClick={goBack}>
68 <Button disabled={!valid} variant="contained" color="primary" onClick={runProcess}>