'use client' import { cn } from "@/lib/utils" import { X } from 'lucide-react' import { useEffect, useCallback } from "react" interface ModalProps { isOpen: boolean onClose: () => void title?: string children: React.ReactNode className?: string } export default function Modal({ isOpen, onClose, title, children, className }: ModalProps) { const handleKeyDown = useCallback( (e: KeyboardEvent) => { if (e.key === "Escape") onClose() }, [onClose] ) useEffect(() => { if (isOpen) { document.addEventListener("keydown", handleKeyDown) document.body.style.overflow = "hidden" } else { document.body.style.overflow = "unset" } return () => { document.removeEventListener("keydown", handleKeyDown) document.body.style.overflow = "unset" } }, [isOpen, handleKeyDown]) if (!isOpen) return null return (