Search Components...

Radio Group - React Hook Form

A Radio Group component that uses react-hook-form Controller.

Installation

npx shadcn@latest add /registry/rhf-radio-group.json

Manual Installation

1. Copy and paste the following code into your project.

"use client";
import type { ComponentPropsWithoutRef, ReactNode } from "react";
import { Controller, type FieldPath, type FieldValues, useFormContext } from "react-hook-form";
import { RadioGroup } from "@/components/ui/radio-group";
import { cn } from "@/lib/utils";
 
// ----------------------------------------------------------------------
 
interface RHFRadioGroupProps<TFieldValues extends FieldValues>
	extends Omit<ComponentPropsWithoutRef<typeof Controller>, "name" | "control" | "render">,
		Omit<ComponentPropsWithoutRef<typeof RadioGroup>, "name" | "defaultValue"> {
	name: FieldPath<TFieldValues>;
	helperText?: string;
	children: ReactNode;
}
 
export default function CustomRHFRadioGroup<TFieldValues extends FieldValues>({
	name,
	helperText,
	defaultValue,
	rules,
	className,
	children,
	...other
}: RHFRadioGroupProps<TFieldValues>) {
	const { control } = useFormContext();
	return (
		<Controller
			name={name}
			control={control}
			defaultValue={defaultValue}
			rules={rules}
			render={({ field, fieldState: { error } }) => (
				<RadioGroup
					onValueChange={field.onChange}
					defaultValue={field.value}
					value={field.value}
					className={cn("group/radio peer", className)}
					data-state-error={!!error}
					aria-invalid={!!error}
					{...other}>
					{children}
					{!!helperText && <p className="text-sm leading-none text-muted-foreground ml-1.5 mt-2">{helperText}</p>}
					{!!error && <p className="text-sm leading-none text-error ml-1.5 mt-2">{error?.message}</p>}
				</RadioGroup>
			)}
		/>
	);
}

2. Add this to your @/components/ui/hook-form/index.tsx file for easy import.

export { default as RHFRadioGroup } from "./rhf-radio-group";

Shadcn

This radio-group component is built on top of the excellent foundation provided by Shadcn/UI.

For a deeper dive into the core concepts and building blocks, check out the original Shadcn radio-group component.