From 6238a53fdd856df5f9a4e1c5676382dfb8f3a1b4 Mon Sep 17 00:00:00 2001 From: blessedcoolant <54517381+blessedcoolant@users.noreply.github.com> Date: Wed, 12 Jul 2023 20:11:05 +1200 Subject: [PATCH] feat: Add basic form validation for path input --- .../AddModelsPanel/AddDiffusersModel.tsx | 17 +++-------------- .../ModelManagerPanel/CheckpointModelEdit.tsx | 14 +++++++++----- .../ModelManagerPanel/DiffusersModelEdit.tsx | 12 ++++++++---- 3 files changed, 20 insertions(+), 23 deletions(-) diff --git a/invokeai/frontend/web/src/features/ui/components/tabs/ModelManager/subpanels/AddModelsPanel/AddDiffusersModel.tsx b/invokeai/frontend/web/src/features/ui/components/tabs/ModelManager/subpanels/AddModelsPanel/AddDiffusersModel.tsx index dd491828da..c871a0ede5 100644 --- a/invokeai/frontend/web/src/features/ui/components/tabs/ModelManager/subpanels/AddModelsPanel/AddDiffusersModel.tsx +++ b/invokeai/frontend/web/src/features/ui/components/tabs/ModelManager/subpanels/AddModelsPanel/AddDiffusersModel.tsx @@ -66,13 +66,13 @@ export default function AddDiffusersModel() { }; return ( - + {({ handleSubmit, errors, touched }) => ( - + {/* Name */} @@ -90,7 +90,6 @@ export default function AddDiffusersModel() { name="name" type="text" validate={baseValidation} - width="2xl" isRequired /> {!!errors.name && touched.name ? ( @@ -119,7 +118,6 @@ export default function AddDiffusersModel() { id="description" name="description" type="text" - width="2xl" isRequired /> {!!errors.description && touched.description ? ( @@ -153,13 +151,7 @@ export default function AddDiffusersModel() { {t('modelManager.modelLocation')} - + {!!errors.path && touched.path ? ( {errors.path} ) : ( @@ -181,7 +173,6 @@ export default function AddDiffusersModel() { id="repo_id" name="repo_id" type="text" - width="2xl" /> {!!errors.repo_id && touched.repo_id ? ( {errors.repo_id} @@ -220,7 +211,6 @@ export default function AddDiffusersModel() { id="vae.path" name="vae.path" type="text" - width="2xl" /> {!!errors.vae?.path && touched.vae?.path ? ( {errors.vae?.path} @@ -245,7 +235,6 @@ export default function AddDiffusersModel() { id="vae.repo_id" name="vae.repo_id" type="text" - width="2xl" /> {!!errors.vae?.repo_id && touched.vae?.repo_id ? ( {errors.vae?.repo_id} diff --git a/invokeai/frontend/web/src/features/ui/components/tabs/ModelManager/subpanels/ModelManagerPanel/CheckpointModelEdit.tsx b/invokeai/frontend/web/src/features/ui/components/tabs/ModelManager/subpanels/ModelManagerPanel/CheckpointModelEdit.tsx index 1eeb6d2fc8..8f70a4f322 100644 --- a/invokeai/frontend/web/src/features/ui/components/tabs/ModelManager/subpanels/ModelManagerPanel/CheckpointModelEdit.tsx +++ b/invokeai/frontend/web/src/features/ui/components/tabs/ModelManager/subpanels/ModelManagerPanel/CheckpointModelEdit.tsx @@ -8,11 +8,11 @@ import { useTranslation } from 'react-i18next'; import type { RootState } from 'app/store/store'; import IAIButton from 'common/components/IAIButton'; -import IAIInput from 'common/components/IAIInput'; import IAIMantineSelect from 'common/components/IAIMantineSelect'; import { MODEL_TYPE_MAP } from 'features/system/components/ModelSelect'; import { makeToast } from 'app/components/Toaster'; +import IAIMantineTextInput from 'common/components/IAIMantineInput'; import { addToast } from 'features/system/store/systemSlice'; import { useUpdateMainModelsMutation } from 'services/api/endpoints/models'; import { components } from 'services/api/schema'; @@ -62,6 +62,10 @@ export default function CheckpointModelEdit(props: CheckpointModelEditProps) { config: retrievedModel.config ? retrievedModel.config : '', variant: retrievedModel.variant, }, + validate: { + path: (value) => + value.trim().length === 0 ? 'Must provide a path' : null, + }, }); const editModelFormSubmitHandler = (values: CheckpointModelConfig) => { @@ -119,7 +123,7 @@ export default function CheckpointModelEdit(props: CheckpointModelEditProps) { )} > - @@ -133,15 +137,15 @@ export default function CheckpointModelEdit(props: CheckpointModelEditProps) { data={variantSelectData} {...checkpointEditForm.getInputProps('variant')} /> - - - diff --git a/invokeai/frontend/web/src/features/ui/components/tabs/ModelManager/subpanels/ModelManagerPanel/DiffusersModelEdit.tsx b/invokeai/frontend/web/src/features/ui/components/tabs/ModelManager/subpanels/ModelManagerPanel/DiffusersModelEdit.tsx index 377317775b..68135a26d4 100644 --- a/invokeai/frontend/web/src/features/ui/components/tabs/ModelManager/subpanels/ModelManagerPanel/DiffusersModelEdit.tsx +++ b/invokeai/frontend/web/src/features/ui/components/tabs/ModelManager/subpanels/ModelManagerPanel/DiffusersModelEdit.tsx @@ -9,7 +9,7 @@ import { useForm } from '@mantine/form'; import { makeToast } from 'app/components/Toaster'; import type { RootState } from 'app/store/store'; import IAIButton from 'common/components/IAIButton'; -import IAIInput from 'common/components/IAIInput'; +import IAIMantineTextInput from 'common/components/IAIMantineInput'; import IAIMantineSelect from 'common/components/IAIMantineSelect'; import { MODEL_TYPE_MAP } from 'features/system/components/ModelSelect'; import { addToast } from 'features/system/store/systemSlice'; @@ -58,6 +58,10 @@ export default function DiffusersModelEdit(props: DiffusersModelEditProps) { vae: retrievedModel.vae ? retrievedModel.vae : '', variant: retrievedModel.variant, }, + validate: { + path: (value) => + value.trim().length === 0 ? 'Must provide a path' : null, + }, }); const editModelFormSubmitHandler = (values: DiffusersModelConfig) => { @@ -107,7 +111,7 @@ export default function DiffusersModelEdit(props: DiffusersModelEditProps) { )} > - @@ -121,11 +125,11 @@ export default function DiffusersModelEdit(props: DiffusersModelEditProps) { data={variantSelectData} {...diffusersEditForm.getInputProps('variant')} /> - -