UNPKG

@arolariu/components

Version:

🎨 60+ beautiful, accessible React components built on Radix UI. TypeScript-first, tree-shakeable, SSR-ready. Perfect for modern web apps, design systems & rapid prototyping. Zero config, maximum flexibility! ⚡

30 lines (29 loc) • 1.7 kB
"use client"; import { jsx } from "react/jsx-runtime"; import "react"; import { Indicator, Item, Root } from "@radix-ui/react-radio-group"; import { CircleIcon } from "lucide-react"; import { cn } from "../../lib/utils.js"; function RadioGroup({ className, ...props }) { return /*#__PURE__*/ jsx(Root, { "data-slot": "radio-group", className: cn("grid gap-3", className), ...props }); } function RadioGroupItem({ className, ...props }) { return /*#__PURE__*/ jsx(Item, { "data-slot": "radio-group-item", className: cn("border-neutral-200 text-neutral-900 focus-visible:border-neutral-950 focus-visible:ring-neutral-950/50 aria-invalid:ring-red-500/20 dark:aria-invalid:ring-red-500/40 aria-invalid:border-red-500 dark:bg-neutral-200/30 aspect-square size-4 shrink-0 rounded-full border shadow-xs transition-[color,box-shadow] outline-none focus-visible:ring-[3px] disabled:cursor-not-allowed disabled:opacity-50 dark:border-neutral-800 dark:text-neutral-50 dark:focus-visible:border-neutral-300 dark:focus-visible:ring-neutral-300/50 dark:aria-invalid:ring-red-900/20 dark:dark:aria-invalid:ring-red-900/40 dark:aria-invalid:border-red-900 dark:dark:bg-neutral-800/30", className), ...props, children: /*#__PURE__*/ jsx(Indicator, { "data-slot": "radio-group-indicator", className: "relative flex items-center justify-center", children: /*#__PURE__*/ jsx(CircleIcon, { className: "fill-primary absolute top-1/2 left-1/2 size-2 -translate-x-1/2 -translate-y-1/2" }) }) }); } export { RadioGroup, RadioGroupItem }; //# sourceMappingURL=radio-group.js.map