1 // Copyright (C) The Arvados Authors. All rights reserved.
3 // SPDX-License-Identifier: AGPL-3.0
5 import * as React from 'react';
6 import { reduxForm, InjectedFormProps } from 'redux-form';
7 import { CommandInputParameter, CWLType, IntCommandInputParameter, BooleanCommandInputParameter, FileCommandInputParameter, DirectoryCommandInputParameter } from '~/models/workflow';
8 import { IntInput } from '~/views/run-process-panel/inputs/int-input';
9 import { StringInput } from '~/views/run-process-panel/inputs/string-input';
10 import { StringCommandInputParameter, FloatCommandInputParameter, isPrimitiveOfType, File, Directory, WorkflowInputsData, EnumCommandInputParameter, isArrayOfType, StringArrayCommandInputParameter } from '../../models/workflow';
11 import { FloatInput } from '~/views/run-process-panel/inputs/float-input';
12 import { BooleanInput } from './inputs/boolean-input';
13 import { FileInput } from './inputs/file-input';
14 import { connect } from 'react-redux';
15 import { compose } from 'redux';
16 import { Grid, StyleRulesCallback, withStyles, WithStyles } from '@material-ui/core';
17 import { EnumInput } from './inputs/enum-input';
18 import { DirectoryInput } from './inputs/directory-input';
19 import { StringArrayInput } from './inputs/string-array-input';
20 import { createStructuredSelector, createSelector } from 'reselect';
22 export const RUN_PROCESS_INPUTS_FORM = 'runProcessInputsForm';
24 export interface RunProcessInputFormProps {
25 inputs: CommandInputParameter[];
28 const inputsSelector = (props: RunProcessInputFormProps) =>
31 const initialValuesSelector = createSelector(
33 inputs => inputs.reduce(
34 (values, input) => ({ ...values, [input.id]: input.default }),
37 const propsSelector = createStructuredSelector({
38 initialValues: initialValuesSelector,
41 const mapStateToProps = (_: any, props: RunProcessInputFormProps) =>
44 export const RunProcessInputsForm = compose(
45 connect(mapStateToProps),
46 reduxForm<WorkflowInputsData, RunProcessInputFormProps>({
47 form: RUN_PROCESS_INPUTS_FORM
49 (props: InjectedFormProps & RunProcessInputFormProps) =>
51 <Grid container spacing={32}>
52 {props.inputs.map(input =>
53 <InputItem input={input} key={input.id} />)}
57 type CssRules = 'inputItem';
59 const styles: StyleRulesCallback<CssRules> = theme => ({
61 marginBottom: theme.spacing.unit * 2,
65 const InputItem = withStyles(styles)(
66 (props: WithStyles<CssRules> & { input: CommandInputParameter }) =>
67 <Grid item xs={12} md={6} className={props.classes.inputItem}>
68 {getInputComponent(props.input)}
71 const getInputComponent = (input: CommandInputParameter) => {
73 case isPrimitiveOfType(input, CWLType.BOOLEAN):
74 return <BooleanInput input={input as BooleanCommandInputParameter} />;
76 case isPrimitiveOfType(input, CWLType.INT):
77 case isPrimitiveOfType(input, CWLType.LONG):
78 return <IntInput input={input as IntCommandInputParameter} />;
80 case isPrimitiveOfType(input, CWLType.FLOAT):
81 case isPrimitiveOfType(input, CWLType.DOUBLE):
82 return <FloatInput input={input as FloatCommandInputParameter} />;
84 case isPrimitiveOfType(input, CWLType.STRING):
85 return <StringInput input={input as StringCommandInputParameter} />;
87 case isPrimitiveOfType(input, CWLType.FILE):
88 return <FileInput input={input as FileCommandInputParameter} />;
90 case isPrimitiveOfType(input, CWLType.DIRECTORY):
91 return <DirectoryInput input={input as DirectoryCommandInputParameter} />;
93 case typeof input.type === 'object' &&
94 !(input.type instanceof Array) &&
95 input.type.type === 'enum':
96 return <EnumInput input={input as EnumCommandInputParameter} />;
98 case isArrayOfType(input, CWLType.STRING):
99 return <StringArrayInput input={input as StringArrayCommandInputParameter} />;