import "./Modal.scss"; import React, { useEffect, useState } from "react"; import { createPortal } from "react-dom"; import { KEYS } from "../keys"; export const Modal = (props: { className?: string; children: React.ReactNode; maxWidth?: number; onCloseRequest(): void; labelledBy: string; }) => { const modalRoot = useBodyRoot(); const handleKeydown = (event: React.KeyboardEvent) => { if (event.key === KEYS.ESCAPE) { event.nativeEvent.stopImmediatePropagation(); props.onCloseRequest(); } }; return createPortal(
{props.children}
, modalRoot, ); }; const useBodyRoot = () => { const createDiv = () => { const isDarkTheme = !!document .querySelector(".excalidraw") ?.classList.contains("Appearance_dark"); const div = document.createElement("div"); div.classList.add("excalidraw"); if (isDarkTheme) { div.classList.add("Appearance_dark"); div.classList.add("Appearance_dark-background-none"); } document.body.appendChild(div); return div; }; const [div] = useState(createDiv); useEffect(() => { return () => { document.body.removeChild(div); }; }, [div]); return div; };