From e15f7744887d46474dceb1357f8b2e688e61becc Mon Sep 17 00:00:00 2001 From: simeng-li Date: Tue, 14 Feb 2023 15:50:17 +0800 Subject: [PATCH] refactor(ui): refactor forgot password flow refactor forgot password flow --- packages/phrases-ui/src/locales/de.ts | 6 +- packages/phrases-ui/src/locales/en.ts | 6 +- packages/phrases-ui/src/locales/fr.ts | 6 +- packages/phrases-ui/src/locales/ko.ts | 6 +- packages/phrases-ui/src/locales/pt-br.ts | 6 +- packages/phrases-ui/src/locales/pt-pt.ts | 6 +- packages/phrases-ui/src/locales/tr-tr.ts | 6 +- packages/phrases-ui/src/locales/zh-cn.ts | 3 +- packages/ui/src/App.tsx | 2 +- .../CountryCodeSelector/index.tsx | 2 +- .../InputFields/SmartInputField/index.tsx | 4 + .../SmartInputField/use-smart-input-field.ts | 22 ++- .../EmailForm/EmailResetPassword.test.tsx | 56 ------- .../EmailForm/EmailResetPassword.tsx | 33 ---- .../ui/src/containers/EmailForm/index.tsx | 1 - .../ForgotPasswordLink/index.tsx | 10 +- .../PhoneForm/PhoneResetPassword.test.tsx | 64 -------- .../PhoneForm/PhoneResetPassword.tsx | 33 ---- .../ui/src/containers/PhoneForm/index.tsx | 1 - packages/ui/src/hooks/use-sie.ts | 36 ++-- .../ForgotPasswordForm/index.module.scss | 19 +++ .../ForgotPasswordForm/index.test.tsx | 93 +++++++++++ .../ForgotPasswordForm/index.tsx | 119 ++++++++++++++ .../src/pages/ForgotPassword/index.test.tsx | 154 ++++++++++-------- .../ui/src/pages/ForgotPassword/index.tsx | 64 +++++--- .../IdentifierRegisterForm/index.module.scss | 1 + .../IdentifierSignInForm/index.module.scss | 1 + .../PasswordSignInForm/index.module.scss | 1 + .../pages/SignIn/PasswordSignInForm/index.tsx | 15 +- .../SignInPassword/PasswordForm/index.tsx | 9 +- packages/ui/src/types/guard.ts | 22 +-- packages/ui/src/utils/country-code.ts | 6 +- packages/ui/src/utils/form.ts | 25 ++- 33 files changed, 463 insertions(+), 375 deletions(-) delete mode 100644 packages/ui/src/containers/EmailForm/EmailResetPassword.test.tsx delete mode 100644 packages/ui/src/containers/EmailForm/EmailResetPassword.tsx rename packages/ui/src/{components => containers}/ForgotPasswordLink/index.tsx (58%) delete mode 100644 packages/ui/src/containers/PhoneForm/PhoneResetPassword.test.tsx delete mode 100644 packages/ui/src/containers/PhoneForm/PhoneResetPassword.tsx create mode 100644 packages/ui/src/pages/ForgotPassword/ForgotPasswordForm/index.module.scss create mode 100644 packages/ui/src/pages/ForgotPassword/ForgotPasswordForm/index.test.tsx create mode 100644 packages/ui/src/pages/ForgotPassword/ForgotPasswordForm/index.tsx diff --git a/packages/phrases-ui/src/locales/de.ts b/packages/phrases-ui/src/locales/de.ts index b6c78afd5..8c5343beb 100644 --- a/packages/phrases-ui/src/locales/de.ts +++ b/packages/phrases-ui/src/locales/de.ts @@ -70,10 +70,8 @@ const translation = { social_link_email_or_phone: 'Du kannst eine weitere Email oder Telefonnummer verknüpfen', social_bind_with_existing: 'Wir haben ein Konto gefunden, das du verknüpfen kannst.', reset_password: 'Passwort zurücksetzen', - reset_password_description_email: - 'Gib die Email Adresse deines Kontos ein und wir senden dir einen Bestätigungscode um dein Passwort zurückzusetzen.', - reset_password_description_phone: - 'Gib die Telefonnummer deines Kontos ein und wir senden dir einen Bestätigungscode um dein Passwort zurückzusetzen.', + reset_password_description: + 'Gib die {{types, list(type: disjunction;)}} deines Kontos ein und wir senden dir einen Bestätigungscode um dein Passwort zurückzusetzen.', new_password: 'Neues Passwort', set_password: 'Passwort setzen', password_changed: 'Passwort geändert', diff --git a/packages/phrases-ui/src/locales/en.ts b/packages/phrases-ui/src/locales/en.ts index f1df8e581..c6d8c0250 100644 --- a/packages/phrases-ui/src/locales/en.ts +++ b/packages/phrases-ui/src/locales/en.ts @@ -68,10 +68,8 @@ const translation = { social_link_email_or_phone: 'You can link another email or phone', social_bind_with_existing: 'We find a related account, you can link it directly.', reset_password: 'Reset password', - reset_password_description_email: - 'Enter the email address associated with your account, and we’ll email you the verification code to reset your password.', - reset_password_description_phone: - 'Enter the phone number associated with your account, and we’ll message you the verification code to reset your password.', + reset_password_description: + 'Enter the {{types, list(type: disjunction;)}} associated with your account, and we’ll send you the verification code to reset your password.', new_password: 'New password', set_password: 'Set password', password_changed: 'Password Changed', diff --git a/packages/phrases-ui/src/locales/fr.ts b/packages/phrases-ui/src/locales/fr.ts index 3bae0f723..e9e93ca70 100644 --- a/packages/phrases-ui/src/locales/fr.ts +++ b/packages/phrases-ui/src/locales/fr.ts @@ -71,10 +71,8 @@ const translation = { social_bind_with_existing: 'Nous trouvons un compte connexe, vous pouvez le relier directement.', reset_password: 'Réinitialiser le mot de passe', - reset_password_description_email: - "Entrez l'adresse e-mail associée à votre compte et nous vous enverrons par e-mail le code de vérification pour réinitialiser votre mot de passe.", - reset_password_description_phone: - 'Entrez le numéro de téléphone associé à votre compte et nous vous enverrons le code de vérification par SMS pour réinitialiser votre mot de passe.', + reset_password_description: + 'Entrez le {{types, list(type: disjunction;)}} associé à votre compte et nous vous enverrons le code de vérification pour réinitialiser votre mot de passe.', new_password: 'Nouveau mot de passe', set_password: 'Set password', // UNTRANSLATED password_changed: 'Password Changed', // UNTRANSLATED diff --git a/packages/phrases-ui/src/locales/ko.ts b/packages/phrases-ui/src/locales/ko.ts index 961c7e875..d539aa4a1 100644 --- a/packages/phrases-ui/src/locales/ko.ts +++ b/packages/phrases-ui/src/locales/ko.ts @@ -67,10 +67,8 @@ const translation = { social_link_email_or_phone: '다른 이메일이나 휴대전화를 연동할 수 있어요', social_bind_with_existing: '관련된 계정을 찾았어요. 해당 계정과 연동할 수 있어요.', reset_password: '암호를 재설정', - reset_password_description_email: - '계정과 연결된 이메일 주소를 입력하면 비밀번호 재설정을 위한 인증 코드를 이메일로 보내드립니다.', - reset_password_description_phone: - '계정과 연결된 전화번호를 입력하면 비밀번호 재설정을 위한 인증 코드를 문자로 보내드립니다.', + reset_password_description: + 'Enter the {{types, list(type: disjunction;)}} associated with your account, and we’ll send you the verification code to reset your password.', // UNTRANSLATED new_password: '새 비밀번호', set_password: '비밀번호 설정', password_changed: '비밀번호 변경됨', diff --git a/packages/phrases-ui/src/locales/pt-br.ts b/packages/phrases-ui/src/locales/pt-br.ts index b72ff68d7..1a5add0b0 100644 --- a/packages/phrases-ui/src/locales/pt-br.ts +++ b/packages/phrases-ui/src/locales/pt-br.ts @@ -70,10 +70,8 @@ const translation = { social_bind_with_existing: 'Encontramos uma conta relacionada, você pode vinculá-la diretamente.', reset_password: 'Redefinir senha', - reset_password_description_email: - 'Digite o endereço de e-mail associado à sua conta e enviaremos por e-mail o código de verificação para redefinir sua senha.', - reset_password_description_phone: - 'Digite o número de telefone associado à sua conta e enviaremos a você o código de verificação para redefinir sua senha.', + reset_password_description: + 'Digite o {{types, list(type: disjunction;)}} à sua conta e enviaremos a você o código de verificação para redefinir sua senha.', new_password: 'Nova senha', set_password: 'Configurar senha', password_changed: 'Senha alterada', diff --git a/packages/phrases-ui/src/locales/pt-pt.ts b/packages/phrases-ui/src/locales/pt-pt.ts index 65af47dee..58abdebfc 100644 --- a/packages/phrases-ui/src/locales/pt-pt.ts +++ b/packages/phrases-ui/src/locales/pt-pt.ts @@ -68,10 +68,8 @@ const translation = { social_link_email_or_phone: 'You can link another email or phone', // UNTRANSLATED, social_bind_with_existing: 'Encontramos uma conta relacionada, pode agrega-la diretamente.', reset_password: 'Redefinir Password', - reset_password_description_email: - 'Digite o endereço de email associado à sua conta e enviaremos um email com o código de verificação para redefinir sua senha.', - reset_password_description_phone: - 'Digite o número de telefone associado à sua conta e enviaremos uma mensagem de texto com o código de verificação para redefinir sua senha.', + reset_password_description: + 'Enter the {{types, list(type: disjunction;)}} associated with your account, and we’ll send you the verification code to reset your password.', // UNTRANSLATED new_password: 'Nova Senha', set_password: 'Set password', // UNTRANSLATED password_changed: 'Password Changed', // UNTRANSLATED diff --git a/packages/phrases-ui/src/locales/tr-tr.ts b/packages/phrases-ui/src/locales/tr-tr.ts index f69ea2f23..2cf5c7098 100644 --- a/packages/phrases-ui/src/locales/tr-tr.ts +++ b/packages/phrases-ui/src/locales/tr-tr.ts @@ -69,10 +69,8 @@ const translation = { social_link_email_or_phone: 'You can link another email or phone', // UNTRANSLATED, social_bind_with_existing: 'İlgili bir hesap bulduk, hemen bağlayabilirsiniz.', reset_password: 'Şifre yenile', - reset_password_description_email: - 'Hesabınızla ilişkili e-posta adresini girin, şifrenizi sıfırlamak için size doğrulama kodunu e-posta ile gönderelim.', - reset_password_description_phone: - 'Hesabınızla ilişkili telefon numarasını girin, şifrenizi sıfırlamak için size doğrulama kodunu kısa mesajla gönderelim.', + reset_password_description: + 'Enter the {{types, list(type: disjunction;)}} associated with your account, and we’ll send you the verification code to reset your password.', // UNTRANSLATED new_password: 'Yeni Şifre', set_password: 'Set password', // UNTRANSLATED password_changed: 'Password Changed', // UNTRANSLATED diff --git a/packages/phrases-ui/src/locales/zh-cn.ts b/packages/phrases-ui/src/locales/zh-cn.ts index 1c1d7dd4f..7c338577b 100644 --- a/packages/phrases-ui/src/locales/zh-cn.ts +++ b/packages/phrases-ui/src/locales/zh-cn.ts @@ -68,8 +68,7 @@ const translation = { social_link_email_or_phone: 'You can link another email or phone', // UNTRANSLATED, social_bind_with_existing: '找到了一个匹配的帐号,你可以直接绑定。', reset_password: '重设密码', - reset_password_description_email: '输入邮件地址,领取验证码以重设密码。', - reset_password_description_phone: '输入手机号,领取验证码以重设密码。', + reset_password_description: '输入{{types, list(type: disjunction;)}},领取验证码以重设密码。', new_password: '新密码', set_password: '设置密码', password_changed: '已重置密码!', diff --git a/packages/ui/src/App.tsx b/packages/ui/src/App.tsx index 5fd158467..7a60fe94e 100644 --- a/packages/ui/src/App.tsx +++ b/packages/ui/src/App.tsx @@ -92,8 +92,8 @@ const App = () => { {/* Forgot password */} + } /> } /> - } /> {/* Continue set up missing profile */} diff --git a/packages/ui/src/components/InputFields/SmartInputField/CountryCodeSelector/index.tsx b/packages/ui/src/components/InputFields/SmartInputField/CountryCodeSelector/index.tsx index a52eab8b8..c4a6e9678 100644 --- a/packages/ui/src/components/InputFields/SmartInputField/CountryCodeSelector/index.tsx +++ b/packages/ui/src/components/InputFields/SmartInputField/CountryCodeSelector/index.tsx @@ -28,7 +28,7 @@ const CountryCodeSelector = ( {`+${countryCode}`} - {countryList.map(({ countryCallingCode, countryCode }) => (