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/components/ErrorDialog.tsx | |
| parent | 16c8578b15c727f22921f8a80a56ee4d4e7f2272 (diff) | |
refactor: packages/
Diffstat (limited to 'packages/excalidraw/components/ErrorDialog.tsx')
| -rw-r--r-- | packages/excalidraw/components/ErrorDialog.tsx | 40 |
1 files changed, 40 insertions, 0 deletions
diff --git a/packages/excalidraw/components/ErrorDialog.tsx b/packages/excalidraw/components/ErrorDialog.tsx new file mode 100644 index 0000000..74d265f --- /dev/null +++ b/packages/excalidraw/components/ErrorDialog.tsx @@ -0,0 +1,40 @@ +import React, { useState } from "react"; +import { t } from "../i18n"; + +import { Dialog } from "./Dialog"; +import { useExcalidrawContainer } from "./App"; + +export const ErrorDialog = ({ + children, + onClose, +}: { + children?: React.ReactNode; + onClose?: () => void; +}) => { + const [modalIsShown, setModalIsShown] = useState(!!children); + const { container: excalidrawContainer } = useExcalidrawContainer(); + + const handleClose = React.useCallback(() => { + setModalIsShown(false); + + if (onClose) { + onClose(); + } + // TODO: Fix the A11y issues so this is never needed since we should always focus on last active element + excalidrawContainer?.focus(); + }, [onClose, excalidrawContainer]); + + return ( + <> + {modalIsShown && ( + <Dialog + size="small" + onCloseRequest={handleClose} + title={t("errorDialog.title")} + > + <div style={{ whiteSpace: "pre-wrap" }}>{children}</div> + </Dialog> + )} + </> + ); +}; |
