import * as React from "react" import { cva, type VariantProps } from "class-variance-authority" import { Slot } from "radix-ui" 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( "[a]:hover:bg-muted rounded-lg border text-sm w-full group/item focus-visible:border-ring focus-visible:ring-ring/50 flex items-center flex-wrap outline-none transition-colors duration-100 focus-visible:ring-[3px] [a]:transition-colors", { variants: { variant: { default: "border-transparent", outline: "border-border", muted: "bg-muted/50 border-transparent", }, size: { default: "gap-2.5 px-3 py-2.5", sm: "gap-2.5 px-3 py-2.5", xs: "gap-2 px-2.5 py-2 in-data-[slot=dropdown-menu-content]:p-0", }, }, 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.Root : "div" return ( ) } const itemMediaVariants = cva( "gap-2 group-has-data-[slot=item-description]/item:translate-y-0.5 group-has-data-[slot=item-description]/item:self-start flex shrink-0 items-center justify-center [&_svg]:pointer-events-none", { variants: { variant: { default: "bg-transparent", icon: "[&_svg:not([class*='size-'])]:size-4", image: "size-10 overflow-hidden rounded-sm group-data-[size=sm]/item:size-8 group-data-[size=xs]/item:size-6 [&_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 line-clamp-2 font-normal [&>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, }