Radio Group

Group of radio buttons for single-selection input.

Report a bug

Preview

Switch between light and dark to inspect the embedded Storybook preview.

Installation

pnpm dlx shadcn@latest add https://ui.vllnt.ai/r/radio-group.json

Storybook

Explore all variants, controls, and accessibility checks in the interactive Storybook playground.

View in Storybook

Code

"use client"; import * as RadioGroupPrimitive from "@radix-ui/react-radio-group"; import { Circle } from "lucide-react"; import { cn } from "../../lib/utils"; const RadioGroup = ({ className, ref, ...props }: React.ComponentPropsWithoutRef<typeof RadioGroupPrimitive.Root> & { ref?: React.Ref<React.ComponentRef<typeof RadioGroupPrimitive.Root>>; }) => { return ( <RadioGroupPrimitive.Root className={cn("grid gap-2", className)} {...props} ref={ref} /> ); }; RadioGroup.displayName = RadioGroupPrimitive.Root.displayName; const RadioGroupItem = ({ className, ref, ...props }: React.ComponentPropsWithoutRef<typeof RadioGroupPrimitive.Item> & { ref?: React.Ref<React.ComponentRef<typeof RadioGroupPrimitive.Item>>; }) => { return ( <RadioGroupPrimitive.Item className={cn( "aspect-square size-4 rounded-full border border-primary text-primary ring-offset-background focus:outline-none focus-visible:ring-2 focus-visible:ring-ring focus-visible:ring-offset-2 disabled:cursor-not-allowed disabled:opacity-50", className, )} ref={ref} {...props} > <RadioGroupPrimitive.Indicator className="flex items-center justify-center"> <Circle className="size-2.5 fill-current text-current" /> </RadioGroupPrimitive.Indicator> </RadioGroupPrimitive.Item> ); }; RadioGroupItem.displayName = RadioGroupPrimitive.Item.displayName; export { RadioGroup, RadioGroupItem };

Dependencies

  • @vllnt/ui@^0.3.0