import React from "react"; import { AppState } from "../types"; import { ActionManager } from "../actions/manager"; import { t } from "../i18n"; import Stack from "./Stack"; import { showSelectedShapeActions } from "../element"; import { NonDeletedExcalidrawElement } from "../element/types"; import { FixedSideContainer } from "./FixedSideContainer"; import { Island } from "./Island"; import { HintViewer } from "./HintViewer"; import { calculateScrollCenter } from "../scene"; import { SelectedShapeActions, ShapesSwitcher } from "./Actions"; import { Section } from "./Section"; import CollabButton from "./CollabButton"; import { SCROLLBAR_WIDTH, SCROLLBAR_MARGIN } from "../scene/scrollbars"; import { LockIcon } from "./LockIcon"; import { UserList } from "./UserList"; import { BackgroundPickerAndDarkModeToggle } from "./BackgroundPickerAndDarkModeToggle"; type MobileMenuProps = { appState: AppState; actionManager: ActionManager; exportButton: React.ReactNode; setAppState: React.Component["setState"]; elements: readonly NonDeletedExcalidrawElement[]; libraryMenu: JSX.Element | null; onCollabButtonClick?: () => void; onLockToggle: () => void; canvas: HTMLCanvasElement | null; isCollaborating: boolean; renderCustomFooter?: (isMobile: boolean) => JSX.Element; viewModeEnabled: boolean; }; export const MobileMenu = ({ appState, elements, libraryMenu, actionManager, exportButton, setAppState, onCollabButtonClick, onLockToggle, canvas, isCollaborating, renderCustomFooter, viewModeEnabled, }: MobileMenuProps) => { const renderToolbar = () => { return (
{(heading) => ( {heading} {libraryMenu} )}
); }; const renderAppToolbar = () => { if (viewModeEnabled) { return (
{actionManager.renderAction("toggleCanvasMenu")}
); } return (
{actionManager.renderAction("toggleCanvasMenu")} {actionManager.renderAction("toggleEditMenu")} {actionManager.renderAction("undo")} {actionManager.renderAction("redo")} {actionManager.renderAction( appState.multiElement ? "finalize" : "duplicateSelection", )} {actionManager.renderAction("deleteSelectedElements")}
); }; const renderCanvasActions = () => { if (viewModeEnabled) { return ( <> {actionManager.renderAction("saveScene")} {actionManager.renderAction("saveAsScene")} {exportButton} ); } return ( <> {actionManager.renderAction("loadScene")} {actionManager.renderAction("saveScene")} {actionManager.renderAction("saveAsScene")} {exportButton} {actionManager.renderAction("clearCanvas")} {onCollabButtonClick && ( )} { } ); }; return ( <> {!viewModeEnabled && renderToolbar()}
{appState.openMenu === "canvas" ? (
{renderCanvasActions()} {renderCustomFooter?.(true)} {appState.collaborators.size > 0 && (
{t("labels.collaborators")} {Array.from(appState.collaborators) // Collaborator is either not initialized or is actually the current user. .filter( ([_, client]) => Object.keys(client).length !== 0, ) .map(([clientId, client]) => ( {actionManager.renderAction( "goToCollaborator", clientId, )} ))}
)}
) : appState.openMenu === "shape" && !viewModeEnabled && showSelectedShapeActions(appState, elements) ? (
) : null}
); };