diff options
Diffstat (limited to 'packages/excalidraw/actions/actionToggleZenMode.tsx')
| -rw-r--r-- | packages/excalidraw/actions/actionToggleZenMode.tsx | 31 |
1 files changed, 31 insertions, 0 deletions
diff --git a/packages/excalidraw/actions/actionToggleZenMode.tsx b/packages/excalidraw/actions/actionToggleZenMode.tsx new file mode 100644 index 0000000..31afd3f --- /dev/null +++ b/packages/excalidraw/actions/actionToggleZenMode.tsx @@ -0,0 +1,31 @@ +import { coffeeIcon } from "../components/icons"; +import { CODES, KEYS } from "../keys"; +import { CaptureUpdateAction } from "../store"; +import { register } from "./register"; + +export const actionToggleZenMode = register({ + name: "zenMode", + label: "buttons.zenMode", + icon: coffeeIcon, + paletteName: "Toggle zen mode", + viewMode: true, + trackEvent: { + category: "canvas", + predicate: (appState) => !appState.zenModeEnabled, + }, + perform(elements, appState) { + return { + appState: { + ...appState, + zenModeEnabled: !this.checked!(appState), + }, + captureUpdate: CaptureUpdateAction.EVENTUALLY, + }; + }, + checked: (appState) => appState.zenModeEnabled, + predicate: (elements, appState, appProps) => { + return typeof appProps.zenModeEnabled === "undefined"; + }, + keyTest: (event) => + !event[KEYS.CTRL_OR_CMD] && event.altKey && event.code === CODES.Z, +}); |
