import React, { useEffect, useCallback, useRef } from 'react' import { X } from 'lucide-react' const sizeClasses = { sm: 'max-w-sm', md: 'max-w-md', lg: 'max-w-lg', xl: 'max-w-2xl', '2xl': 'max-w-4xl', } export default function Modal({ isOpen, onClose, title, children, size = 'md', footer, hideCloseButton = false, }) { const handleEsc = useCallback((e) => { if (e.key === 'Escape') onClose() }, [onClose]) useEffect(() => { if (isOpen) { document.addEventListener('keydown', handleEsc) document.body.style.overflow = 'hidden' } return () => { document.removeEventListener('keydown', handleEsc) document.body.style.overflow = '' } }, [isOpen, handleEsc]) const mouseDownTarget = useRef(null) if (!isOpen) return null return (