Popover
Displays rich content in a portal, triggered by a button.
tsx
import { Button } from "@/components/ui/button"import { Input } from "@/components/ui/input"import { Label } from "@/components/ui/label"import { Popover, PopoverContent, PopoverTrigger,} from "@/components/ui/popover"
export function PopoverDemo() { return ( <Popover> <PopoverTrigger asChild> <Button variant="outline">Open popover</Button> </PopoverTrigger> <PopoverContent className="w-80"> <div className="grid gap-4"> <div className="space-y-2"> <h4 className="font-medium leading-none">Dimensions</h4> <p className="text-sm text-muted-foreground"> Set the dimensions for the layer. </p> </div> <div className="grid gap-2"> <div className="grid grid-cols-3 items-center gap-4"> <Label htmlFor="width">Width</Label> <Input id="width" defaultValue="100%" className="col-span-2 h-8" /> </div> <div className="grid grid-cols-3 items-center gap-4"> <Label htmlFor="maxWidth">Max. width</Label> <Input id="maxWidth" defaultValue="300px" className="col-span-2 h-8" /> </div> <div className="grid grid-cols-3 items-center gap-4"> <Label htmlFor="height">Height</Label> <Input id="height" defaultValue="25px" className="col-span-2 h-8" /> </div> <div className="grid grid-cols-3 items-center gap-4"> <Label htmlFor="maxHeight">Max. height</Label> <Input id="maxHeight" defaultValue="none" className="col-span-2 h-8" /> </div> </div> </div> </PopoverContent> </Popover> )}
Installation
CLI
bash
npx fivui add popover
Manual
Copy and paste the following code into your project.
bash
npm install @radix-ui/react-popover
components/ui/popover.tsx
"use client"
import * as React from "react"import * as PopoverPrimitive from "@radix-ui/react-popover"
import { cn } from "@/lib/utils"
const Popover = PopoverPrimitive.Root
const PopoverTrigger = PopoverPrimitive.Trigger
const PopoverContent = React.forwardRef< React.ElementRef<typeof PopoverPrimitive.Content>, React.ComponentPropsWithoutRef<typeof PopoverPrimitive.Content>>(({ className, align = "center", sideOffset = 4, ...props }, ref) => ( <PopoverPrimitive.Portal> <PopoverPrimitive.Content ref={ref} align={align} sideOffset={sideOffset} className={cn( "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", className )} {...props} /> </PopoverPrimitive.Portal>))PopoverContent.displayName = PopoverPrimitive.Content.displayName
export { Popover, PopoverTrigger, PopoverContent }
Usage
tsx
import { Popover, PopoverContent, PopoverTrigger,} from "@/components/ui/popover"
<Popover> <PopoverTrigger>Open</PopoverTrigger> <PopoverContent>Place content for the popover here.</PopoverContent></Popover>
API Reference
Popover
Prop | Type | Default | Description |
---|---|---|---|
open | boolean | - | The controlled open state of the popover |
defaultOpen | boolean | false | The open state of the popover when it is initially rendered |
onOpenChange | function | - | Event handler called when the open state of the popover changes |
modal | boolean | false | The modality of the popover. When set to true, interaction with outside elements will be disabled |
PopoverTrigger
Prop | Type | Default | Description |
---|---|---|---|
asChild | boolean | false | Change the default rendered element for the one passed as a child |
PopoverContent
Prop | Type | Default | Description |
---|---|---|---|
align | "start" | "center" | "end" | "center" | The preferred alignment against the trigger |
side | "top" | "right" | "bottom" | "left" | "bottom" | The preferred side of the trigger to render against |
sideOffset | number | 4 | The distance in pixels from the trigger |
alignOffset | number | 0 | An offset in pixels from the "start" or "end" alignment options |
For more detailed information about all available props and behaviors, refer to the Radix UI documentation.
View Radix Docs