mirror of
				https://github.com/excalidraw/excalidraw.git
				synced 2025-10-25 17:04:40 +02:00 
			
		
		
		
	
		
			
				
	
	
		
			82 lines
		
	
	
		
			2.2 KiB
		
	
	
	
		
			TypeScript
		
	
	
	
	
	
			
		
		
	
	
			82 lines
		
	
	
		
			2.2 KiB
		
	
	
	
		
			TypeScript
		
	
	
	
	
	
| import { HamburgerMenuIcon, HelpIconThin, palette } from "../components/icons";
 | |
| import { ToolButton } from "../components/ToolButton";
 | |
| import { t } from "../i18n";
 | |
| import { showSelectedShapeActions, getNonDeletedElements } from "../element";
 | |
| import { register } from "./register";
 | |
| import { KEYS } from "../keys";
 | |
| import { StoreAction } from "../store";
 | |
| 
 | |
| export const actionToggleCanvasMenu = register({
 | |
|   name: "toggleCanvasMenu",
 | |
|   label: "buttons.menu",
 | |
|   trackEvent: { category: "menu" },
 | |
|   perform: (_, appState) => ({
 | |
|     appState: {
 | |
|       ...appState,
 | |
|       openMenu: appState.openMenu === "canvas" ? null : "canvas",
 | |
|     },
 | |
|     storeAction: StoreAction.NONE,
 | |
|   }),
 | |
|   PanelComponent: ({ appState, updateData }) => (
 | |
|     <ToolButton
 | |
|       type="button"
 | |
|       icon={HamburgerMenuIcon}
 | |
|       aria-label={t("buttons.menu")}
 | |
|       onClick={updateData}
 | |
|       selected={appState.openMenu === "canvas"}
 | |
|     />
 | |
|   ),
 | |
| });
 | |
| 
 | |
| export const actionToggleEditMenu = register({
 | |
|   name: "toggleEditMenu",
 | |
|   label: "buttons.edit",
 | |
|   trackEvent: { category: "menu" },
 | |
|   perform: (_elements, appState) => ({
 | |
|     appState: {
 | |
|       ...appState,
 | |
|       openMenu: appState.openMenu === "shape" ? null : "shape",
 | |
|     },
 | |
|     storeAction: StoreAction.NONE,
 | |
|   }),
 | |
|   PanelComponent: ({ elements, appState, updateData }) => (
 | |
|     <ToolButton
 | |
|       visible={showSelectedShapeActions(
 | |
|         appState,
 | |
|         getNonDeletedElements(elements),
 | |
|       )}
 | |
|       type="button"
 | |
|       icon={palette}
 | |
|       aria-label={t("buttons.edit")}
 | |
|       onClick={updateData}
 | |
|       selected={appState.openMenu === "shape"}
 | |
|     />
 | |
|   ),
 | |
| });
 | |
| 
 | |
| export const actionShortcuts = register({
 | |
|   name: "toggleShortcuts",
 | |
|   label: "welcomeScreen.defaults.helpHint",
 | |
|   icon: HelpIconThin,
 | |
|   viewMode: true,
 | |
|   trackEvent: { category: "menu", action: "toggleHelpDialog" },
 | |
|   perform: (_elements, appState, _, { focusContainer }) => {
 | |
|     if (appState.openDialog?.name === "help") {
 | |
|       focusContainer();
 | |
|     }
 | |
|     return {
 | |
|       appState: {
 | |
|         ...appState,
 | |
|         openDialog:
 | |
|           appState.openDialog?.name === "help"
 | |
|             ? null
 | |
|             : {
 | |
|                 name: "help",
 | |
|               },
 | |
|       },
 | |
|       storeAction: StoreAction.NONE,
 | |
|     };
 | |
|   },
 | |
|   keyTest: (event) => event.key === KEYS.QUESTION_MARK,
 | |
| });
 | 
