mirror of
https://github.com/excalidraw/excalidraw.git
synced 2025-05-03 10:00:07 -04:00
102 lines
3.1 KiB
TypeScript
102 lines
3.1 KiB
TypeScript
import React from "react";
|
|
import {
|
|
useDevice,
|
|
useExcalidrawAppState,
|
|
useExcalidrawSetAppState,
|
|
} from "../App";
|
|
import DropdownMenu from "../dropdownMenu/DropdownMenu";
|
|
|
|
import * as DefaultItems from "./DefaultItems";
|
|
|
|
import { UserList } from "../UserList";
|
|
import { t } from "../../i18n";
|
|
import { HamburgerMenuIcon } from "../icons";
|
|
import { withInternalFallback } from "../hoc/withInternalFallback";
|
|
import { composeEventHandlers } from "../../utils";
|
|
import { useTunnels } from "../context/tunnels";
|
|
import DropdownMenuSub from "../dropdownMenu/DropdownMenuSub";
|
|
|
|
import * as Portal from "@radix-ui/react-portal";
|
|
|
|
const MainMenu = Object.assign(
|
|
withInternalFallback(
|
|
"MainMenu",
|
|
({
|
|
children,
|
|
onSelect,
|
|
}: {
|
|
children?: React.ReactNode;
|
|
/**
|
|
* Called when any menu item is selected (clicked on).
|
|
*/
|
|
onSelect?: (event: Event) => void;
|
|
}) => {
|
|
const { mainMenuTunnel } = useTunnels();
|
|
const device = useDevice();
|
|
const appState = useExcalidrawAppState();
|
|
const setAppState = useExcalidrawSetAppState();
|
|
const onClickOutside = device.isMobile
|
|
? undefined
|
|
: () => setAppState({ openMenu: null });
|
|
|
|
return (
|
|
<mainMenuTunnel.In>
|
|
{appState.openMenu === "canvas" && device.isMobile && (
|
|
<Portal.Root
|
|
style={{
|
|
backgroundColor: "rgba(18, 18, 18, 0.2)",
|
|
position: "fixed",
|
|
inset: "0px",
|
|
zIndex: "var(--zIndex-layerUI)",
|
|
}}
|
|
onClick={() => setAppState({ openMenu: null })}
|
|
/>
|
|
)}
|
|
<DropdownMenu open={appState.openMenu === "canvas"}>
|
|
<DropdownMenu.Trigger
|
|
onToggle={() => {
|
|
setAppState({
|
|
openMenu: appState.openMenu === "canvas" ? null : "canvas",
|
|
});
|
|
}}
|
|
>
|
|
{HamburgerMenuIcon}
|
|
</DropdownMenu.Trigger>
|
|
<DropdownMenu.Content
|
|
// style={{ zIndex: 11 }}
|
|
sideOffset={device.isMobile ? 20 : undefined}
|
|
className="main-menu-content"
|
|
onClickOutside={onClickOutside}
|
|
onSelect={composeEventHandlers(onSelect, () => {
|
|
setAppState({ openMenu: null });
|
|
})}
|
|
>
|
|
{children}
|
|
{device.isMobile && appState.collaborators.size > 0 && (
|
|
<fieldset className="UserList-Wrapper">
|
|
<legend>{t("labels.collaborators")}</legend>
|
|
<UserList
|
|
mobile={true}
|
|
collaborators={appState.collaborators}
|
|
/>
|
|
</fieldset>
|
|
)}
|
|
</DropdownMenu.Content>
|
|
</DropdownMenu>
|
|
</mainMenuTunnel.In>
|
|
);
|
|
},
|
|
),
|
|
{
|
|
Trigger: DropdownMenu.Trigger,
|
|
Item: DropdownMenu.Item,
|
|
ItemLink: DropdownMenu.ItemLink,
|
|
ItemCustom: DropdownMenu.ItemCustom,
|
|
Group: DropdownMenu.Group,
|
|
Separator: DropdownMenu.Separator,
|
|
Sub: DropdownMenuSub,
|
|
DefaultItems,
|
|
},
|
|
);
|
|
|
|
export default MainMenu;
|