blob: 7e8b5e3c10306b52b86941df2ac69c16f1744fd7 [file] [log] [blame]
giod0026612025-05-08 13:00:36 +00001import * as React from "react";
2import * as PopoverPrimitive from "@radix-ui/react-popover";
gio5f2f1002025-03-20 18:38:48 +04003
giod0026612025-05-08 13:00:36 +00004import { cn } from "@/lib/utils";
gio5f2f1002025-03-20 18:38:48 +04005
giod0026612025-05-08 13:00:36 +00006const Popover = PopoverPrimitive.Root;
gio5f2f1002025-03-20 18:38:48 +04007
giod0026612025-05-08 13:00:36 +00008const PopoverTrigger = PopoverPrimitive.Trigger;
gio5f2f1002025-03-20 18:38:48 +04009
giod0026612025-05-08 13:00:36 +000010const PopoverAnchor = PopoverPrimitive.Anchor;
gio5f2f1002025-03-20 18:38:48 +040011
12const PopoverContent = React.forwardRef<
giod0026612025-05-08 13:00:36 +000013 React.ElementRef<typeof PopoverPrimitive.Content>,
14 React.ComponentPropsWithoutRef<typeof PopoverPrimitive.Content>
gio5f2f1002025-03-20 18:38:48 +040015>(({ className, align = "center", sideOffset = 4, ...props }, ref) => (
giod0026612025-05-08 13:00:36 +000016 <PopoverPrimitive.Portal>
17 <PopoverPrimitive.Content
18 ref={ref}
19 align={align}
20 sideOffset={sideOffset}
21 className={cn(
22 "z-50 w-72 rounded-md border bg-popover p-4 text-popover-foreground shadow-md outline-none data-[state=open]:animate-in data-[state=closed]:animate-out data-[state=closed]:fade-out-0 data-[state=open]:fade-in-0 data-[state=closed]:zoom-out-95 data-[state=open]:zoom-in-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",
23 className,
24 )}
25 {...props}
26 />
27 </PopoverPrimitive.Portal>
28));
29PopoverContent.displayName = PopoverPrimitive.Content.displayName;
gio5f2f1002025-03-20 18:38:48 +040030
giod0026612025-05-08 13:00:36 +000031export { Popover, PopoverTrigger, PopoverContent, PopoverAnchor };