119 lines
3.0 KiB
TypeScript
119 lines
3.0 KiB
TypeScript
|
"use client"
|
||
|
|
||
|
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,
|
||
|
}
|