Skip to main content
ParticleUI

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