registry:component
Motion Radio Group
v1.0.0ga
Radio group primitive with animated selection indicators.
Registry Endpoint
Open JSONhttps://registry.aavya.com/r/ui-motion-radio-group.json
npx shadcn@latest add https://registry.aavya.com/r/ui-motion-radio-group.json
Live Preview
Usage Snippet
import MotionRadioGroup from '@/components/ui/motion-radio-group.tsx'
export default function Example() {
return (
<div className="p-6">
<MotionRadioGroup />
</div>
)
}
Source Preview
'use client'
import * as React from 'react'
import * as RadioGroupPrimitive from '@radix-ui/react-radio-group'
import { AnimatePresence, motion, type HTMLMotionProps, type Transition } from 'motion/react'
import { CircleIcon } from 'lucide-react'
import { cn } from '@/lib/utils'
type RadioGroupItemProps = React.ComponentProps<typeof RadioGroupPrimitive.Item> &
HTMLMotionProps<'button'> & {
transition?: Transition
}
function RadioGroup({ className, ...props }: React.ComponentProps<typeof RadioGroupPrimitive.Root>) {
return <RadioGroupPrimitive.Root data-slot='radio-group' className={cn('grid gap-3', className)} {...props} />
}
function RadioGroupItem({
className,
transition = { type: 'spring', stiffness: 200, damping: 16 },
...props
}: RadioGroupItemProps) {
return (
<RadioGroupPrimitive.Item asChild {...props}>
<motion.button
data-slot='radio-group-item'
className={cn(
'border-input text-primary focus-visible:border-ring focus-visible:ring-ring/50 aria-invalid:ring-destructive/20 dark:aria-invalid:ring-destructive/40 aria-invalid:border-destructive dark:bg-input/30 aspect-square size-5 shrink-0 rounded-full border shadow-xs transition-[color,box-shadow] outline-none focus-visible:ring-[3px] disabled:cursor-not-allowed disabled:opacity-50',
className
)}
whileHover={{ scale: 1.05 }}
whil