Merge branch '18874-merge-wb2'
[arvados.git] / services / workbench2 / src / views / run-process-panel / inputs / generic-input.tsx
diff --git a/services/workbench2/src/views/run-process-panel/inputs/generic-input.tsx b/services/workbench2/src/views/run-process-panel/inputs/generic-input.tsx
new file mode 100644 (file)
index 0000000..963998f
--- /dev/null
@@ -0,0 +1,35 @@
+// Copyright (C) The Arvados Authors. All rights reserved.
+//
+// SPDX-License-Identifier: AGPL-3.0
+
+import React from 'react';
+import { WrappedFieldProps } from 'redux-form';
+import { FormGroup, FormLabel, FormHelperText } from '@material-ui/core';
+import { GenericCommandInputParameter, getInputLabel, isRequiredInput } from 'models/workflow';
+
+export type GenericInputProps = WrappedFieldProps & {
+    commandInput: GenericCommandInputParameter<any, any>;
+};
+
+type GenericInputContainerProps = GenericInputProps & {
+    component: React.ComponentType<GenericInputProps>;
+    required?: boolean;
+};
+export const GenericInput = ({ component: Component, ...props }: GenericInputContainerProps) => {
+    return <FormGroup>
+        <FormLabel
+            focused={props.meta.active}
+            required={props.required !== undefined ? props.required : isRequiredInput(props.commandInput)}
+            error={props.meta.touched && !!props.meta.error}>
+            {getInputLabel(props.commandInput)}
+        </FormLabel>
+        <Component {...props} />
+        <FormHelperText error={props.meta.touched && !!props.meta.error}>
+            {
+                props.meta.touched && props.meta.error
+                    ? props.meta.error
+                    : props.commandInput.doc
+            }
+        </FormHelperText>
+    </FormGroup>;
+};