From 0af95d790bad7ec4584f52a399b2ab6297b11be2 Mon Sep 17 00:00:00 2001 From: Xiao Yijun Date: Wed, 16 Nov 2022 18:31:42 +0800 Subject: [PATCH] refactor(console): validate sign-up identifier (#2446) --- .../tabs/SignUpAndSignInTab/SignUpForm.tsx | 21 ++++++++++++++++++- 1 file changed, 20 insertions(+), 1 deletion(-) diff --git a/packages/console/src/pages/SignInExperience/tabs/SignUpAndSignInTab/SignUpForm.tsx b/packages/console/src/pages/SignInExperience/tabs/SignUpAndSignInTab/SignUpForm.tsx index ed7f29143..968ffd21f 100644 --- a/packages/console/src/pages/SignInExperience/tabs/SignUpAndSignInTab/SignUpForm.tsx +++ b/packages/console/src/pages/SignInExperience/tabs/SignUpAndSignInTab/SignUpForm.tsx @@ -6,6 +6,7 @@ import { snakeCase } from 'snake-case'; import Checkbox from '@/components/Checkbox'; import FormField from '@/components/FormField'; import Select from '@/components/Select'; +import useEnabledConnectorTypes from '@/hooks/use-enabled-connector-types'; import type { SignInExperienceForm } from '../../types'; import ConnectorSetupWarning from './components/ConnectorSetupWarning'; @@ -18,7 +19,13 @@ import * as styles from './index.module.scss'; const SignUpForm = () => { const { t } = useTranslation(undefined, { keyPrefix: 'admin_console' }); - const { control, setValue, watch } = useFormContext(); + const { + control, + setValue, + watch, + formState: { errors }, + } = useFormContext(); + const { isConnectorTypeEnabled } = useEnabledConnectorTypes(); const signUpIdentifier = watch('signUp.identifier'); @@ -56,9 +63,21 @@ const SignUpForm = () => { { + if (!value) { + return false; + } + + return signUpIdentifierToRequiredConnectorMapping[value].every((connectorType) => + isConnectorTypeEnabled(connectorType) + ); + }, + }} render={({ field: { value, onChange } }) => (