From 1227dc7cdefdf53a6d65b3194efd419c6a3baf80 Mon Sep 17 00:00:00 2001 From: roshni73 Date: Tue, 12 Nov 2024 12:18:14 +0545 Subject: [PATCH] Add Validation Email page --- src/App/routes/index.tsx | 13 ++ src/views/Login/index.tsx | 2 +- src/views/ResendValidationEmail/i18n.json | 10 ++ src/views/ResendValidationEmail/index.tsx | 111 ++++++++++++++++++ .../ResendValidationEmail/styles.module.css | 21 ++++ 5 files changed, 156 insertions(+), 1 deletion(-) create mode 100644 src/views/ResendValidationEmail/i18n.json create mode 100644 src/views/ResendValidationEmail/index.tsx create mode 100644 src/views/ResendValidationEmail/styles.module.css diff --git a/src/App/routes/index.tsx b/src/App/routes/index.tsx index 8859e413..adfd2fe4 100644 --- a/src/App/routes/index.tsx +++ b/src/App/routes/index.tsx @@ -217,6 +217,18 @@ const recoverAccount = customWrapRoute({ visibility: 'is-not-authenticated', }, }); +const resendValidationEmail = customWrapRoute({ + parent: rootLayout, + path: 'resend-validation-email', + component: { + render: () => import('#views/ResendValidationEmail'), + props: {}, + }, + context: { + title: 'Resend Validation Email', + visibility: 'is-not-authenticated', + }, +}); const wrappedRoutes = { rootLayout, @@ -232,6 +244,7 @@ const wrappedRoutes = { pageNotFound, login, recoverAccount, + resendValidationEmail, mySubscription, }; diff --git a/src/views/Login/index.tsx b/src/views/Login/index.tsx index 3ac7edac..6ae0dd87 100644 --- a/src/views/Login/index.tsx +++ b/src/views/Login/index.tsx @@ -124,7 +124,7 @@ export function Component() { {strings.loginForgotUserPass} diff --git a/src/views/ResendValidationEmail/i18n.json b/src/views/ResendValidationEmail/i18n.json new file mode 100644 index 00000000..df3c4948 --- /dev/null +++ b/src/views/ResendValidationEmail/i18n.json @@ -0,0 +1,10 @@ +{ + "namespace": "resendValidationEmail", + "strings": { + "pageTitle": "IFRC Alert-Hub - Resend Validation Email", + "pageHeading": "Resend Validation Email", + "pageDescription": "Enter the email you used during registration", + "emailInputLabel": "Email", + "submitButtonLabel": "Resend" + } +} diff --git a/src/views/ResendValidationEmail/index.tsx b/src/views/ResendValidationEmail/index.tsx new file mode 100644 index 00000000..ff6308f7 --- /dev/null +++ b/src/views/ResendValidationEmail/index.tsx @@ -0,0 +1,111 @@ +import { useMemo } from 'react'; +import { + Button, + TextInput, +} from '@ifrc-go/ui'; +import { useTranslation } from '@ifrc-go/ui/hooks'; +import { + createSubmitHandler, + getErrorObject, + type ObjectSchema, + requiredStringCondition, + useForm, +} from '@togglecorp/toggle-form'; + +import HCaptcha from '#components/Captcha'; +import Page from '#components/Page'; + +import i18n from './i18n.json'; +import styles from './styles.module.css'; + +interface FormFields { + email?: string; + captcha?:string; +} + +const defaultFormValue: FormFields = { +}; + +type FormSchema = ObjectSchema; +type FormSchemaFields = ReturnType + +const formSchema: FormSchema = { + fields: (): FormSchemaFields => ({ + email: { + required: true, + requiredValidation: requiredStringCondition, + }, + captcha: { + required: true, + requiredValidation: requiredStringCondition, + }, + }), +}; + +// eslint-disable-next-line import/prefer-default-export +export function Component() { + const strings = useTranslation(i18n); + + const { + value: formValue, + error: formError, + setFieldValue, + setError, + validate, + } = useForm(formSchema, { value: defaultFormValue }); + + const handleFormSubmit = useMemo( + () => createSubmitHandler( + validate, + setError, + // FIXME: Add Submit logic here + () => {}, + ), + [validate, setError], + ); + + const fieldError = getErrorObject(formError); + + return ( + +
+ + +
+ + +
+ + +
+ ); +} + +Component.displayName = 'ResendValidationEmail'; diff --git a/src/views/ResendValidationEmail/styles.module.css b/src/views/ResendValidationEmail/styles.module.css new file mode 100644 index 00000000..813c615b --- /dev/null +++ b/src/views/ResendValidationEmail/styles.module.css @@ -0,0 +1,21 @@ +.resend-validation-email { + .form { + display: flex; + flex-direction: column; + flex-grow: 1; + gap: var(--go-ui-spacing-lg); + margin: 0 auto; + max-width: var(--go-ui-width-content-max); + + .submit-button { + align-self: center; + } + + .actions { + display: flex; + flex-direction: column; + gap: var(--go-ui-spacing-lg); + align-items: center; + } + } +}