Extract FileInput's getValidation function
[arvados-workbench2.git] / src / views / run-process-panel / inputs / file-input.tsx
index e5fa9663ceeaf8e613a3ac49decaedcf0facd1d0..c135042d66ea20b42675fc42ca13a902111b68fb 100644 (file)
@@ -3,6 +3,7 @@
 // SPDX-License-Identifier: AGPL-3.0
 
 import * as React from 'react';
+import { memoize } from 'lodash/fp';
 import {
     isRequiredInput,
     FileCommandInputParameter,
@@ -30,11 +31,7 @@ export const FileInput = ({ input }: FileInputProps) =>
         component={FileInputComponent}
         format={format}
         parse={parse}
-        validate={[
-            isRequiredInput(input)
-                ? (file?: File) => file ? undefined : ERROR_MESSAGE
-                : () => undefined,
-        ]} />;
+        validate={getValidation(input)} />;
 
 const format = (value?: File) => value ? value.basename : '';
 
@@ -44,6 +41,13 @@ const parse = (file: CollectionFile): File => ({
     basename: file.name,
 });
 
+const getValidation = memoize(
+    (input: FileCommandInputParameter) => ([
+        isRequiredInput(input)
+            ? (file?: File) => file ? undefined : ERROR_MESSAGE
+            : () => undefined,
+    ]));
+
 interface FileInputComponentState {
     open: boolean;
     file?: CollectionFile;