import * as React from 'react'; import { Close, Content, Portal } from '@radix-ui/react-dialog'; import { cva } from 'class-variance-authority'; import type { VariantProps } from 'class-variance-authority'; import { XIcon } from 'lucide-react'; import { cn } from '#utils'; import { SheetOverlay } from './SheetOverlay.tsx'; export const sheetVariants = cva( 'fixed z-50 gap-4 bg-background p-6 shadow-lg transition ease-in-out data-[state=open]:animate-in data-[state=closed]:animate-out data-[state=closed]:duration-300 data-[state=open]:duration-500', { defaultVariants: { side: 'right' }, variants: { side: { bottom: 'inset-x-0 bottom-0 border-t data-[state=closed]:slide-out-to-bottom data-[state=open]:slide-in-from-bottom', left: 'inset-y-0 left-0 h-full w-3/4 border-r data-[state=closed]:slide-out-to-left data-[state=open]:slide-in-from-left sm:max-w-sm', right: 'inset-y-0 right-0 h-full w-3/4 border-l data-[state=closed]:slide-out-to-right data-[state=open]:slide-in-from-right sm:max-w-sm', top: 'inset-x-0 top-0 border-b data-[state=closed]:slide-out-to-top data-[state=open]:slide-in-from-top' } } } ); export type SheetContentProps = React.ComponentPropsWithoutRef & VariantProps; export const SheetContent = React.forwardRef, SheetContentProps>(function SheetContent( { children, className, side = 'right', ...props }, ref ) { return ( {children} Close ); });