From 0ec85107894477193c417238dc4e65623bed5ec4 Mon Sep 17 00:00:00 2001 From: Xiao Yijun Date: Wed, 21 Aug 2024 13:30:53 +0800 Subject: [PATCH] fix(experience): add sso form mode context provider for identifier sign-in/register pages (#6482) --- .../IdentifierRegisterForm/index.test.tsx | 2 ++ .../src/components/IdentifierRegisterForm/index.tsx | 11 ++++++++--- .../src/pages/IdentifierRegister/index.tsx | 5 ++++- .../experience/src/pages/IdentifierSignIn/index.tsx | 13 ++++++++----- 4 files changed, 22 insertions(+), 9 deletions(-) diff --git a/packages/experience/src/components/IdentifierRegisterForm/index.test.tsx b/packages/experience/src/components/IdentifierRegisterForm/index.test.tsx index e7543f5b2..57ae0b43a 100644 --- a/packages/experience/src/components/IdentifierRegisterForm/index.test.tsx +++ b/packages/experience/src/components/IdentifierRegisterForm/index.test.tsx @@ -394,11 +394,13 @@ describe('', () => { mockSsoConnectors ); const emailInput = container.querySelector('input[name="id"]'); + const termsButton = getByText('description.agree_with_terms'); assert(emailInput, new Error('username input not found')); act(() => { fireEvent.change(emailInput, { target: { value: email } }); + fireEvent.click(termsButton); }); await waitFor(() => { diff --git a/packages/experience/src/components/IdentifierRegisterForm/index.tsx b/packages/experience/src/components/IdentifierRegisterForm/index.tsx index e0df93ff1..383a037e4 100644 --- a/packages/experience/src/components/IdentifierRegisterForm/index.tsx +++ b/packages/experience/src/components/IdentifierRegisterForm/index.tsx @@ -71,12 +71,16 @@ const IdentifierRegisterForm = ({ className, autoFocus, signUpMethods }: Props) setIdentifierInputValue({ type, value }); - if (showSingleSignOnForm) { - await navigateToSingleSignOn(); + if ( + agreeToTermsPolicy && + agreeToTermsPolicy !== AgreeToTermsPolicy.Automatic && + !(await termsValidation()) + ) { return; } - if (!(await termsValidation())) { + if (showSingleSignOnForm) { + await navigateToSingleSignOn(); return; } @@ -84,6 +88,7 @@ const IdentifierRegisterForm = ({ className, autoFocus, signUpMethods }: Props) })(event); }, [ + agreeToTermsPolicy, clearErrorMessage, handleSubmit, navigateToSingleSignOn, diff --git a/packages/experience/src/pages/IdentifierRegister/index.tsx b/packages/experience/src/pages/IdentifierRegister/index.tsx index 41c2be9d0..09477f1cb 100644 --- a/packages/experience/src/pages/IdentifierRegister/index.tsx +++ b/packages/experience/src/pages/IdentifierRegister/index.tsx @@ -3,6 +3,7 @@ import { useTranslation } from 'react-i18next'; import { Navigate } from 'react-router-dom'; import FocusedAuthPageLayout from '@/Layout/FocusedAuthPageLayout'; +import SingleSignOnFormModeContextProvider from '@/Providers/SingleSignOnFormModeContextProvider'; import IdentifierRegisterForm from '@/components/IdentifierRegisterForm'; import { useSieMethods } from '@/hooks/use-sie'; import { identifierInputDescriptionMap } from '@/utils/form'; @@ -36,7 +37,9 @@ const IdentifierRegister = () => { text: 'description.all_account_creation_options', }} > - + + + ); }; diff --git a/packages/experience/src/pages/IdentifierSignIn/index.tsx b/packages/experience/src/pages/IdentifierSignIn/index.tsx index d9e8bc352..f81a8ed91 100644 --- a/packages/experience/src/pages/IdentifierSignIn/index.tsx +++ b/packages/experience/src/pages/IdentifierSignIn/index.tsx @@ -4,6 +4,7 @@ import { useTranslation } from 'react-i18next'; import { Navigate } from 'react-router-dom'; import FocusedAuthPageLayout from '@/Layout/FocusedAuthPageLayout'; +import SingleSignOnFormModeContextProvider from '@/Providers/SingleSignOnFormModeContextProvider'; import IdentifierSignInForm from '@/components/IdentifierSignInForm'; import PasswordSignInForm from '@/components/PasswordSignInForm'; import { identifierInputDescriptionMap } from '@/utils/form'; @@ -43,11 +44,13 @@ const IdentifierSignIn = () => { text: 'description.all_sign_in_options', }} > - {isPasswordOnly ? ( - identifier)} /> - ) : ( - - )} + + {isPasswordOnly ? ( + identifier)} /> + ) : ( + + )} + ); };