import React from "react"; import { AppState } from "../types"; import { ActionManager } from "../actions/manager"; import { t, setLanguage } from "../i18n"; import Stack from "./Stack"; import { LanguageList } from "./LanguageList"; 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 { RoomDialog } from "./RoomDialog"; import { SCROLLBAR_WIDTH, SCROLLBAR_MARGIN } from "../scene/scrollbars"; import { LockIcon } from "./LockIcon"; import { LoadingMessage } from "./LoadingMessage"; import { UserList } from "./UserList"; type MobileMenuProps = { appState: AppState; actionManager: ActionManager; exportButton: React.ReactNode; setAppState: any; elements: readonly NonDeletedExcalidrawElement[]; libraryMenu: JSX.Element | null; onRoomCreate: () => void; onUsernameChange: (username: string) => void; onRoomDestroy: () => void; onLockToggle: () => void; canvas: HTMLCanvasElement | null; }; export const MobileMenu = ({ appState, elements, libraryMenu, actionManager, exportButton, setAppState, onRoomCreate, onUsernameChange, onRoomDestroy, onLockToggle, canvas, }: MobileMenuProps) => ( <> {appState.isLoading && }
{(heading) => ( {heading} {libraryMenu} )}
{appState.openMenu === "canvas" ? (
{actionManager.renderAction("loadScene")} {actionManager.renderAction("saveScene")} {actionManager.renderAction("saveAsScene")} {exportButton} {actionManager.renderAction("clearCanvas")} {actionManager.renderAction("changeViewBackgroundColor")}
{t("labels.language")} { await setLanguage(lng); setAppState({}); }} />
{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" && showSelectedShapeActions(appState, elements) ? (
) : null}
);