@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
JavaScript
"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