This validates an escrow form using Zod, including wallet addresses, change status properties and milestone index.
import{isValidWallet}from"@/helpers/valid-data.helper";import{z}from"zod";exportconstformSchema=z.object({contractId:z.string().min(1,"Contract ID is required"),milestoneIndex:z.string().min(1,"Milestone index is required"),newStatus:z.string().min(1,"New status is required"),serviceProvider:z.string().min(1,{message:"Service provider is required.",}).refine((value)=>isValidWallet(value),{message:"Service provider must be a valid wallet.",}),evidence:z.string().optional(),});
Custom Hook
This contains all the form logic, including schema validation, onSubmit function and others states and functionalities.
Form
This form is built with react hook form. We use the custom hook and zod schema mentioned before.