diff options
| author | kj_sh604 | 2026-03-15 16:19:35 -0400 |
|---|---|---|
| committer | kj_sh604 | 2026-03-15 16:19:35 -0400 |
| commit | 6ec259a0e71174651bae95d4628138bf6fd68742 (patch) | |
| tree | 5e33c6a5ec091ecabfcb257fdc7b6a88ed8754ac /packages/excalidraw/hooks/useCreatePortalContainer.ts | |
| parent | 16c8578b15c727f22921f8a80a56ee4d4e7f2272 (diff) | |
refactor: packages/
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; +}; |
