Ved UI
Components

Select Form

A styled select form component built with Shadcn UI, using Zod for schema validation and React Hook Form for form management.

Installation

npx shadcn@latest add

Manual

Install the following dependencies:

npx shadcn@latest add select form button sonner

Copy and paste the following code into your project.

"use client";
 
import { zodResolver } from "@hookform/resolvers/zod";
import { useForm } from "react-hook-form";
import { z } from "zod";
 
import { Button } from "@/components/ui/button";
import {
  Form,
  FormControl,
  FormField,
  FormItem,
  FormLabel,
  FormMessage,
} from "@/components/ui/form";
import {
  Select,
  SelectContent,
  SelectItem,
  SelectTrigger,
  SelectValue,
} from "@/components/ui/select";
import { toast } from "sonner";
 
const FormSchema = z.object({
  email: z
    .string({
      required_error: "Please select an email to display.",
    })
    .email(),
});
 
export function SelectForm() {
  const form = useForm<z.infer<typeof FormSchema>>({
    resolver: zodResolver(FormSchema),
  });
 
  function onSubmit(data: z.infer<typeof FormSchema>) {
    toast.success(data.email);
  }
 
  return (
    <Form {...form}>
      <form onSubmit={form.handleSubmit(onSubmit)} className="w-2/3 space-y-6">
        <FormField
          control={form.control}
          name="email"
          render={({ field }) => (
            <FormItem>
              <FormLabel>Email</FormLabel>
              <Select onValueChange={field.onChange} defaultValue={field.value}>
                <FormControl>
                  <SelectTrigger>
                    <SelectValue placeholder="Get Schwifty!" />
                  </SelectTrigger>
                </FormControl>
                <SelectContent>
                  <SelectItem value="schwifty@get.schwifty">
                    schwifty@get.schwifty
                  </SelectItem>
                  <SelectItem value="wubbalubbadubdub@universe.com">
                    wubbalubbadubdub@universe.com
                  </SelectItem>
                  <SelectItem value="pickle.rick@dimension.c137">
                    pickle.rick@dimension.c137
                  </SelectItem>
                </SelectContent>
              </Select>
              <FormMessage />
            </FormItem>
          )}
        />
        <Button type="submit">Submit</Button>
      </form>
    </Form>
  );
}

On this page