feat(SW-360): trigger validation on form submission

This commit is contained in:
Chuma McPhoy
2024-10-23 14:51:27 +02:00
parent 94744a4260
commit 1056eee7e9
2 changed files with 24 additions and 10 deletions

View File

@@ -3,7 +3,7 @@ import { redirect } from "next/navigation"
import { overview } from "@/constants/routes/myPages" import { overview } from "@/constants/routes/myPages"
import { auth } from "@/auth" import { auth } from "@/auth"
import Form from "@/components/Forms/Signup" import SignupForm from "@/components/Forms/Signup"
import { getLang } from "@/i18n/serverContext" import { getLang } from "@/i18n/serverContext"
import { SignupFormWrapperProps } from "@/types/components/blocks/dynamicContent" import { SignupFormWrapperProps } from "@/types/components/blocks/dynamicContent"
@@ -16,5 +16,5 @@ export default async function SignupFormWrapper({
// We don't want to allow users to access signup if they are already authenticated. // We don't want to allow users to access signup if they are already authenticated.
redirect(overview[getLang()]) redirect(overview[getLang()])
} }
return <Form {...dynamic_content} /> return <SignupForm {...dynamic_content} />
} }

View File

@@ -1,7 +1,7 @@
"use client" "use client"
import { zodResolver } from "@hookform/resolvers/zod" import { zodResolver } from "@hookform/resolvers/zod"
import { useEffect,useState } from "react" import { useEffect, useState } from "react"
import { FormProvider, useForm } from "react-hook-form" import { FormProvider, useForm } from "react-hook-form"
import { useIntl } from "react-intl" import { useIntl } from "react-intl"
@@ -29,9 +29,16 @@ import styles from "./form.module.css"
import type { SignUpFormProps } from "@/types/components/form/signupForm" import type { SignUpFormProps } from "@/types/components/form/signupForm"
export default function Form({ link, subtitle, title }: SignUpFormProps) { export default function SignupForm({ link, subtitle, title }: SignUpFormProps) {
const intl = useIntl() const intl = useIntl()
const lang = useLang() const lang = useLang()
const country = intl.formatMessage({ id: "Country" })
const email = `${intl.formatMessage({ id: "Email" })} ${intl.formatMessage({ id: "Address" }).toLowerCase()}`
const phoneNumber = intl.formatMessage({ id: "Phone number" })
const zipCode = intl.formatMessage({ id: "Zip code" })
const [isSubmitAttempted, setIsSubmitAttempted] = useState(false)
const methods = useForm<SignUpSchema>({ const methods = useForm<SignUpSchema>({
defaultValues: { defaultValues: {
firstName: "", firstName: "",
@@ -51,12 +58,18 @@ export default function Form({ link, subtitle, title }: SignUpFormProps) {
resolver: zodResolver(signUpSchema), resolver: zodResolver(signUpSchema),
reValidateMode: "onChange", reValidateMode: "onChange",
}) })
const country = intl.formatMessage({ id: "Country" })
const email = `${intl.formatMessage({ id: "Email" })} ${intl.formatMessage({ id: "Address" }).toLowerCase()}`
const phoneNumber = intl.formatMessage({ id: "Phone number" })
const zipCode = intl.formatMessage({ id: "Zip code" })
async function handleSubmit(data: SignUpSchema) { // Trigger validation for all fields upon invalid submissions.
useEffect(() => {
if (
isSubmitAttempted &&
(!methods.formState.isValid || !methods.formState.isSubmitting)
) {
methods.trigger()
}
}, [isSubmitAttempted, methods])
async function onSubmit(data: SignUpSchema) {
try { try {
const result = await registerUser(data) const result = await registerUser(data)
if (result && !result.success) { if (result && !result.success) {
@@ -79,12 +92,12 @@ export default function Form({ link, subtitle, title }: SignUpFormProps) {
<form <form
className={styles.form} className={styles.form}
id="register" id="register"
onSubmit={methods.handleSubmit(onSubmit)}
/** /**
* Ignoring since ts doesn't recognize that tRPC * Ignoring since ts doesn't recognize that tRPC
* parses FormData before reaching the route * parses FormData before reaching the route
* @ts-ignore */ * @ts-ignore */
action={registerUser} action={registerUser}
onSubmit={methods.handleSubmit(handleSubmit)}
> >
<section className={styles.userInfo}> <section className={styles.userInfo}>
<div className={styles.container}> <div className={styles.container}>
@@ -178,6 +191,7 @@ export default function Form({ link, subtitle, title }: SignUpFormProps) {
intent="primary" intent="primary"
disabled={methods.formState.isSubmitting} disabled={methods.formState.isSubmitting}
data-testid="submit" data-testid="submit"
onClick={() => setIsSubmitAttempted(true)}
> >
{intl.formatMessage({ id: "Sign up to Scandic Friends" })} {intl.formatMessage({ id: "Sign up to Scandic Friends" })}
</Button> </Button>