|
import * as React from "react" |
|
import { Drawer as DrawerPrimitive } from "vaul" |
|
|
|
import { cn } from "@/lib/utils" |
|
|
|
const Drawer = ({ |
|
shouldScaleBackground = true, |
|
...props |
|
}: React.ComponentProps<typeof DrawerPrimitive.Root>) => ( |
|
<DrawerPrimitive.Root |
|
shouldScaleBackground={shouldScaleBackground} |
|
{...props} |
|
/> |
|
) |
|
Drawer.displayName = "Drawer" |
|
|
|
const DrawerTrigger = DrawerPrimitive.Trigger |
|
|
|
const DrawerPortal = DrawerPrimitive.Portal |
|
|
|
const DrawerClose = DrawerPrimitive.Close |
|
|
|
const DrawerOverlay = React.forwardRef< |
|
React.ElementRef<typeof DrawerPrimitive.Overlay>, |
|
React.ComponentPropsWithoutRef<typeof DrawerPrimitive.Overlay> |
|
>(({ className, ...props }, ref) => ( |
|
<DrawerPrimitive.Overlay |
|
ref={ref} |
|
className={cn("fixed inset-0 z-50 bg-black/80", className)} |
|
{...props} |
|
/> |
|
)) |
|
DrawerOverlay.displayName = DrawerPrimitive.Overlay.displayName |
|
|
|
const DrawerContent = React.forwardRef< |
|
React.ElementRef<typeof DrawerPrimitive.Content>, |
|
React.ComponentPropsWithoutRef<typeof DrawerPrimitive.Content> |
|
>(({ className, children, ...props }, ref) => ( |
|
<DrawerPortal> |
|
<DrawerOverlay /> |
|
<DrawerPrimitive.Content |
|
ref={ref} |
|
className={cn( |
|
"fixed inset-x-0 bottom-0 z-50 mt-24 flex h-auto flex-col rounded-t-[10px] border bg-background", |
|
className |
|
)} |
|
{...props} |
|
> |
|
<div className="mx-auto mt-4 h-2 w-[100px] rounded-full bg-muted" /> |
|
{children} |
|
</DrawerPrimitive.Content> |
|
</DrawerPortal> |
|
)) |
|
DrawerContent.displayName = "DrawerContent" |
|
|
|
const DrawerHeader = ({ |
|
className, |
|
...props |
|
}: React.HTMLAttributes<HTMLDivElement>) => ( |
|
<div |
|
className={cn("grid gap-1.5 p-4 text-center sm:text-left", className)} |
|
{...props} |
|
/> |
|
) |
|
DrawerHeader.displayName = "DrawerHeader" |
|
|
|
const DrawerFooter = ({ |
|
className, |
|
...props |
|
}: React.HTMLAttributes<HTMLDivElement>) => ( |
|
<div |
|
className={cn("mt-auto flex flex-col gap-2 p-4", className)} |
|
{...props} |
|
/> |
|
) |
|
DrawerFooter.displayName = "DrawerFooter" |
|
|
|
const DrawerTitle = React.forwardRef< |
|
React.ElementRef<typeof DrawerPrimitive.Title>, |
|
React.ComponentPropsWithoutRef<typeof DrawerPrimitive.Title> |
|
>(({ className, ...props }, ref) => ( |
|
<DrawerPrimitive.Title |
|
ref={ref} |
|
className={cn( |
|
"text-lg font-semibold leading-none tracking-tight", |
|
className |
|
)} |
|
{...props} |
|
/> |
|
)) |
|
DrawerTitle.displayName = DrawerPrimitive.Title.displayName |
|
|
|
const DrawerDescription = React.forwardRef< |
|
React.ElementRef<typeof DrawerPrimitive.Description>, |
|
React.ComponentPropsWithoutRef<typeof DrawerPrimitive.Description> |
|
>(({ className, ...props }, ref) => ( |
|
<DrawerPrimitive.Description |
|
ref={ref} |
|
className={cn("text-sm text-muted-foreground", className)} |
|
{...props} |
|
/> |
|
)) |
|
DrawerDescription.displayName = DrawerPrimitive.Description.displayName |
|
|
|
export { |
|
Drawer, |
|
DrawerPortal, |
|
DrawerOverlay, |
|
DrawerTrigger, |
|
DrawerClose, |
|
DrawerContent, |
|
DrawerHeader, |
|
DrawerFooter, |
|
DrawerTitle, |
|
DrawerDescription, |
|
} |
|
|