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 (
{ mouseDownTarget.current = e.target }} onClick={e => { if (e.target === e.currentTarget && mouseDownTarget.current === e.currentTarget) onClose() mouseDownTarget.current = null }} >
e.stopPropagation()} > {/* Header */}

{title}

{!hideCloseButton && ( )}
{/* Body */}
{children}
{/* Footer */} {footer && (
{footer}
)}
) }