35bcb63300
Componentes React accesibles basados en Radix UI con soporte de temas via CSS variables. Incluye barrel export en index.ts. Co-Authored-By: Claude Opus 4.6 (1M context) <noreply@anthropic.com>
58 lines
2.3 KiB
TypeScript
58 lines
2.3 KiB
TypeScript
import * as React from "react"
|
|
import { Popover as PopoverPrimitive } from "@base-ui/react/popover"
|
|
import { cn } from "../core/cn"
|
|
|
|
function Popover({ ...props }: PopoverPrimitive.Root.Props) {
|
|
return <PopoverPrimitive.Root data-slot="popover" {...props} />
|
|
}
|
|
|
|
function PopoverTrigger({ ...props }: PopoverPrimitive.Trigger.Props) {
|
|
return <PopoverPrimitive.Trigger data-slot="popover-trigger" {...props} />
|
|
}
|
|
|
|
function PopoverPortal({ ...props }: PopoverPrimitive.Portal.Props) {
|
|
return <PopoverPrimitive.Portal data-slot="popover-portal" {...props} />
|
|
}
|
|
|
|
function PopoverContent({ className, sideOffset = 4, ...props }: PopoverPrimitive.Positioner.Props) {
|
|
return (
|
|
<PopoverPortal>
|
|
<PopoverPrimitive.Positioner
|
|
data-slot="popover-content"
|
|
sideOffset={sideOffset}
|
|
className={cn("z-50", className)}
|
|
{...props}
|
|
>
|
|
<PopoverPrimitive.Popup
|
|
className={cn(
|
|
"w-72 rounded-xl border bg-popover p-4 text-popover-foreground shadow-md outline-none",
|
|
"data-open:animate-in data-open:fade-in-0 data-open:zoom-in-95",
|
|
"data-closed:animate-out data-closed:fade-out-0 data-closed:zoom-out-95",
|
|
"data-[side=bottom]:slide-in-from-top-2 data-[side=left]:slide-in-from-right-2 data-[side=right]:slide-in-from-left-2 data-[side=top]:slide-in-from-bottom-2"
|
|
)}
|
|
>
|
|
{props.children}
|
|
</PopoverPrimitive.Popup>
|
|
</PopoverPrimitive.Positioner>
|
|
</PopoverPortal>
|
|
)
|
|
}
|
|
|
|
function PopoverClose({ ...props }: PopoverPrimitive.Close.Props) {
|
|
return <PopoverPrimitive.Close data-slot="popover-close" {...props} />
|
|
}
|
|
|
|
function PopoverHeader({ className, ...props }: React.ComponentProps<"div">) {
|
|
return <div data-slot="popover-header" className={cn("flex flex-col gap-1.5", className)} {...props} />
|
|
}
|
|
|
|
function PopoverTitle({ className, ...props }: React.ComponentProps<"h4">) {
|
|
return <h4 data-slot="popover-title" className={cn("text-sm font-semibold leading-none", className)} {...props} />
|
|
}
|
|
|
|
function PopoverDescription({ className, ...props }: React.ComponentProps<"p">) {
|
|
return <p data-slot="popover-description" className={cn("text-sm text-muted-foreground", className)} {...props} />
|
|
}
|
|
|
|
export { Popover, PopoverClose, PopoverContent, PopoverDescription, PopoverHeader, PopoverPortal, PopoverTitle, PopoverTrigger }
|