import * as React from "react"; import { Slot } from "@radix-ui/react-slot"; import { cva, type VariantProps } from "class-variance-authority"; import { cn } from "@/lib/utils"; import { Separator } from "@/components/ui/separator"; function ItemGroup({ className, ...props }: React.ComponentProps<"div">) { return (
); } function ItemSeparator({ className, ...props }: React.ComponentProps) { return ( ); } const itemVariants = cva( "group/item flex items-center border border-transparent text-sm rounded-md transition-colors [a&]:hover:bg-accent/50 [a&]:transition-colors duration-100 flex-wrap outline-none focus-visible:border-ring focus-visible:ring-ring/50 focus-visible:ring-[3px]", { variants: { variant: { default: "bg-transparent", outline: "border-border", muted: "bg-muted/50", }, size: { default: "p-4 gap-4 ", sm: "py-3 px-4 gap-2.5", }, }, defaultVariants: { variant: "default", size: "default", }, }, ); function Item({ className, variant = "default", size = "default", asChild = false, ...props }: React.ComponentProps<"div"> & VariantProps & { asChild?: boolean }) { const Comp = asChild ? Slot : "div"; return ( ); } const itemMediaVariants = cva( "flex shrink-0 items-center justify-center gap-2 group-has-[[data-slot=item-description]]/item:self-start [&_svg]:pointer-events-none group-has-[[data-slot=item-description]]/item:translate-y-0.5", { variants: { variant: { default: "bg-transparent", icon: "size-8 border rounded-sm bg-muted [&_svg:not([class*='size-'])]:size-4", image: "size-10 rounded-sm overflow-hidden [&_img]:size-full [&_img]:object-cover", }, }, defaultVariants: { variant: "default", }, }, ); function ItemMedia({ className, variant = "default", ...props }: React.ComponentProps<"div"> & VariantProps) { return (
); } function ItemContent({ className, ...props }: React.ComponentProps<"div">) { return (
); } function ItemTitle({ className, ...props }: React.ComponentProps<"div">) { return (
); } function ItemDescription({ className, ...props }: React.ComponentProps<"p">) { return (

a:hover]:text-primary [&>a]:underline [&>a]:underline-offset-4", className, )} {...props} /> ); } function ItemActions({ className, ...props }: React.ComponentProps<"div">) { return (

); } function ItemHeader({ className, ...props }: React.ComponentProps<"div">) { return (
); } function ItemFooter({ className, ...props }: React.ComponentProps<"div">) { return (
); } export { Item, ItemMedia, ItemContent, ItemActions, ItemGroup, ItemSeparator, ItemTitle, ItemDescription, ItemHeader, ItemFooter, };