diff options
Diffstat (limited to 'packages/excalidraw/hooks/useCreatePortalContainer.ts')
| -rw-r--r-- | packages/excalidraw/hooks/useCreatePortalContainer.ts | 47 |
1 files changed, 47 insertions, 0 deletions
diff --git a/packages/excalidraw/hooks/useCreatePortalContainer.ts b/packages/excalidraw/hooks/useCreatePortalContainer.ts new file mode 100644 index 0000000..e8f5e3d --- /dev/null +++ b/packages/excalidraw/hooks/useCreatePortalContainer.ts @@ -0,0 +1,47 @@ +import { useState, useLayoutEffect } from "react"; +import { useDevice, useExcalidrawContainer } from "../components/App"; +import { THEME } from "../constants"; +import { useUIAppState } from "../context/ui-appState"; + +export const useCreatePortalContainer = (opts?: { + className?: string; + parentSelector?: string; +}) => { + const [div, setDiv] = useState<HTMLDivElement | null>(null); + + const device = useDevice(); + const { theme } = useUIAppState(); + + const { container: excalidrawContainer } = useExcalidrawContainer(); + + useLayoutEffect(() => { + if (div) { + div.className = ""; + div.classList.add("excalidraw", ...(opts?.className?.split(/\s+/) || [])); + div.classList.toggle("excalidraw--mobile", device.editor.isMobile); + div.classList.toggle("theme--dark", theme === THEME.DARK); + } + }, [div, theme, device.editor.isMobile, opts?.className]); + + useLayoutEffect(() => { + const container = opts?.parentSelector + ? excalidrawContainer?.querySelector(opts.parentSelector) + : document.body; + + if (!container) { + return; + } + + const div = document.createElement("div"); + + container.appendChild(div); + + setDiv(div); + + return () => { + container.removeChild(div); + }; + }, [excalidrawContainer, opts?.parentSelector]); + + return div; +}; |
