import "./ExportDialog.css"; import React, { useState, useEffect, useRef } from "react"; import { Modal } from "./Modal"; import { ToolIcon } from "./ToolIcon"; import { clipboard, exportFile, downloadFile } from "./icons"; import { Island } from "./Island"; import { ExcalidrawElement } from "../element/types"; import { AppState } from "../types"; import { getExportCanvasPreview } from "../scene/data"; import { ActionsManagerInterface, UpdaterFn } from "../actions/types"; import Stack from "./Stack"; const probablySupportsClipboard = "toBlob" in HTMLCanvasElement.prototype && "clipboard" in navigator && "write" in navigator.clipboard && "ClipboardItem" in window; export function ExportDialog({ elements, appState, exportPadding = 10, actionManager, syncActionResult, onExportToPng, onExportToClipboard }: { appState: AppState; elements: readonly ExcalidrawElement[]; exportPadding?: number; actionManager: ActionsManagerInterface; syncActionResult: UpdaterFn; onExportToPng(elements: readonly ExcalidrawElement[]): void; onExportToClipboard(elements: readonly ExcalidrawElement[]): void; }) { const someElementIsSelected = elements.some(element => element.isSelected); const [modalIsShown, setModalIsShown] = useState(false); const [exportSelected, setExportSelected] = useState(someElementIsSelected); const previeRef = useRef(null); const { exportBackground, viewBackgroundColor } = appState; const exportedElements = exportSelected ? elements.filter(element => element.isSelected) : elements; useEffect(() => { setExportSelected(someElementIsSelected); }, [someElementIsSelected]); useEffect(() => { const previewNode = previeRef.current; const canvas = getExportCanvasPreview(exportedElements, { exportBackground, viewBackgroundColor, exportPadding }); previewNode?.appendChild(canvas); return () => { previewNode?.removeChild(canvas); }; }, [ modalIsShown, exportedElements, exportBackground, exportPadding, viewBackgroundColor ]); function handleClose() { setModalIsShown(false); setExportSelected(someElementIsSelected); } return ( <> setModalIsShown(true)} icon={exportFile} type="button" aria-label="Show export dialog" title="Export" /> {modalIsShown && (

Export

onExportToPng(exportedElements)} /> {probablySupportsClipboard && ( onExportToClipboard(exportedElements)} /> )} {actionManager.renderAction( "changeProjectName", elements, appState, syncActionResult )} {actionManager.renderAction( "changeExportBackground", elements, appState, syncActionResult )} {someElementIsSelected && (
)}
)} ); }