popover.tsx

 1import { Popover as PopoverPrimitive } from "radix-ui";
 2import * as React from "react";
 3
 4import { cn } from "@/lib/utils";
 5
 6const Popover = PopoverPrimitive.Root;
 7const PopoverTrigger = PopoverPrimitive.Trigger;
 8const PopoverAnchor = PopoverPrimitive.Anchor;
 9
10const PopoverContent = React.forwardRef<
11  React.ElementRef<typeof PopoverPrimitive.Content>,
12  React.ComponentPropsWithoutRef<typeof PopoverPrimitive.Content>
13>(({ className, align = "center", sideOffset = 4, ...props }, ref) => (
14  <PopoverPrimitive.Portal>
15    <PopoverPrimitive.Content
16      ref={ref}
17      align={align}
18      sideOffset={sideOffset}
19      className={cn(
20        "z-50 w-72 rounded-md border border-border bg-popover p-4 text-popover-foreground shadow-md outline-hidden 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",
21        className,
22      )}
23      {...props}
24    />
25  </PopoverPrimitive.Portal>
26));
27PopoverContent.displayName = PopoverPrimitive.Content.displayName;
28
29export { Popover, PopoverTrigger, PopoverAnchor, PopoverContent };