Form
Form field wrappers integrating react-hook-form with accessible labels, descriptions, and error messages.
Form integrates react-hook-form with accessible validation. See docs for full usage example.
We'll never share your email.
This field is required.
Installation
1
Run the CLI
$npx particleui-cli add form
Usage
TSX
"use client"
import { useForm } from "react-hook-form"
import { zodResolver } from "@hookform/resolvers/zod"
import { z } from "zod"
import { Form, FormField, FormItem, FormLabel, FormControl, FormMessage } from "@/components/ui/form"
import { Input } from "@/components/ui/input"
import { Button } from "@/components/ui/button"
const schema = z.object({ email: z.string().email() })
export default function Example() {
const form = useForm({ resolver: zodResolver(schema), defaultValues: { email: "" } })
return (
<Form {...form}>
<form onSubmit={form.handleSubmit(console.log)} className="space-y-4 max-w-sm">
<FormField control={form.control} name="email" render={({ field }) => (
<FormItem>
<FormLabel>Email</FormLabel>
<FormControl><Input placeholder="you@example.com" {...field} /></FormControl>
<FormMessage />
</FormItem>
)} />
<Button type="submit">Submit</Button>
</form>
</Form>
)
}Details
Source filecomponents/ui/form.tsx
Typeui
Categoriesforms, core
npm dependencies@radix-ui/react-label, @radix-ui/react-slot, react-hook-form
Registry deps
Claude skill—