//
// SPDX-License-Identifier: AGPL-3.0
-import * as React from 'react';
-import { getInputLabel, isRequiredInput, StringCommandInputParameter } from '~/models/workflow';
+import React from 'react';
+import { memoize } from 'lodash/fp';
+import { isRequiredInput, StringCommandInputParameter } from 'models/workflow';
import { Field } from 'redux-form';
-import { TextField } from '~/components/text-field/text-field';
-import { require } from '~/validators/require';
+import { require } from 'validators/require';
+import { GenericInputProps, GenericInput } from 'views/run-process-panel/inputs/generic-input';
+import { Input as MaterialInput } from '@material-ui/core';
export interface StringInputProps {
input: StringCommandInputParameter;
export const StringInput = ({ input }: StringInputProps) =>
<Field
name={input.id}
- label={getInputLabel(input)}
- component={TextField}
- validate={[
- isRequiredInput(input)
- ? require
- : () => undefined,
- ]} />;
+ commandInput={input}
+ component={StringInputComponent}
+ validate={getValidation(input)} />;
+const getValidation = memoize(
+ (input: StringCommandInputParameter) => ([
+ isRequiredInput(input)
+ ? require
+ : () => undefined,
+ ]));
+
+const StringInputComponent = (props: GenericInputProps) =>
+ <GenericInput
+ component={Input}
+ {...props} />;
+
+const Input = (props: GenericInputProps) =>
+ <MaterialInput
+ fullWidth
+ error={props.meta.touched && !!props.meta.error}
+ disabled={props.commandInput.disabled}
+ {...props.input} />;
\ No newline at end of file