| 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, |
| } |
|
|