import { useEffect } from 'react' interface ModalProps { isOpen: boolean onClose: () => void title: string children: React.ReactNode } export function Modal({ isOpen, onClose, title, children }: ModalProps) { // Close modal on Escape key useEffect(() => { const handleEscape = (event: KeyboardEvent) => { if (event.key === 'Escape') { onClose() } } if (isOpen) { document.addEventListener('keydown', handleEscape) // Prevent body scrolling when modal is open document.body.style.overflow = 'hidden' } return () => { document.removeEventListener('keydown', handleEscape) document.body.style.overflow = 'unset' } }, [isOpen, onClose]) if (!isOpen) return null return (