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