@dwelle/excalidraw 0.4.0-e1bdbb6 → 0.4.0-e587816

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (240) hide show
  1. package/CHANGELOG.md +714 -0
  2. package/README.md +18 -1422
  3. package/dist/excalidraw-assets/{vendor-2002fe1b8862917b36c1.js → vendor-d415b28e9024dee4bb1b.js} +2 -2
  4. package/dist/excalidraw-assets-dev/{vendor-e6df8519da951026ff69.js → vendor-a14cd58fa2db417e42b2.js} +6 -6
  5. package/dist/excalidraw.development.js +3257 -1444
  6. package/dist/excalidraw.production.min.js +1 -1
  7. package/dist/excalidraw.production.min.js.LICENSE.txt +20 -0
  8. package/main.js +1 -8
  9. package/package.json +9 -4
  10. package/types/actions/actionAddToLibrary.d.ts +124 -64
  11. package/types/actions/actionAlign.d.ts +33 -40
  12. package/types/actions/actionBoundText.d.ts +182 -25
  13. package/types/actions/actionCanvas.d.ts +754 -220
  14. package/types/actions/actionClipboard.d.ts +236 -115
  15. package/types/actions/actionDeleteSelected.d.ts +133 -72
  16. package/types/actions/actionDistribute.d.ts +11 -16
  17. package/types/actions/actionDuplicateSelection.d.ts +4 -7
  18. package/types/actions/actionElementLock.d.ts +271 -0
  19. package/types/actions/actionExport.d.ts +440 -277
  20. package/types/actions/actionFinalize.d.ts +85 -51
  21. package/types/actions/actionFlip.d.ts +8 -11
  22. package/types/actions/actionFrame.d.ts +423 -0
  23. package/types/actions/actionGroup.d.ts +252 -19
  24. package/types/actions/actionHistory.d.ts +1 -1
  25. package/types/actions/actionLinearEditor.d.ts +44 -24
  26. package/types/actions/actionMenu.d.ts +132 -79
  27. package/types/actions/actionNavigate.d.ts +2 -3
  28. package/types/actions/actionProperties.d.ts +569 -334
  29. package/types/actions/actionSelectAll.d.ts +123 -4
  30. package/types/actions/actionStyles.d.ts +46 -27
  31. package/types/actions/actionToggleGridMode.d.ts +46 -25
  32. package/types/actions/{actionToggleLock.d.ts → actionToggleObjectsSnapMode.d.ts} +56 -35
  33. package/types/actions/actionToggleStats.d.ts +45 -25
  34. package/types/actions/actionToggleViewMode.d.ts +46 -25
  35. package/types/actions/actionToggleZenMode.d.ts +46 -25
  36. package/types/actions/actionZindex.d.ts +16 -24
  37. package/types/actions/index.d.ts +2 -1
  38. package/types/actions/manager.d.ts +3 -2
  39. package/types/actions/shortcuts.d.ts +2 -1
  40. package/types/actions/types.d.ts +16 -13
  41. package/types/appState.d.ts +27 -28
  42. package/types/charts.d.ts +2 -2
  43. package/types/clients.d.ts +5 -6
  44. package/types/clipboard.d.ts +9 -3
  45. package/types/colors.d.ts +60 -5
  46. package/types/components/Actions.d.ts +7 -12
  47. package/types/components/ActiveConfirmDialog.d.ts +4 -0
  48. package/types/components/App.d.ts +102 -86
  49. package/types/components/Avatar.d.ts +1 -2
  50. package/types/components/BraveMeasureTextError.d.ts +2 -0
  51. package/types/components/Button.d.ts +16 -0
  52. package/types/components/ButtonIconSelect.d.ts +11 -3
  53. package/types/components/Card.d.ts +6 -0
  54. package/types/components/ColorPicker/ColorInput.d.ts +9 -0
  55. package/types/components/ColorPicker/ColorPicker.d.ts +19 -0
  56. package/types/components/ColorPicker/CustomColorList.d.ts +8 -0
  57. package/types/components/ColorPicker/HotkeyLabel.d.ts +8 -0
  58. package/types/components/ColorPicker/Picker.d.ts +18 -0
  59. package/types/components/ColorPicker/PickerColorList.d.ts +10 -0
  60. package/types/components/ColorPicker/PickerHeading.d.ts +5 -0
  61. package/types/components/ColorPicker/ShadeList.d.ts +8 -0
  62. package/types/components/ColorPicker/TopPicks.d.ts +9 -0
  63. package/types/components/ColorPicker/colorPickerUtils.d.ts +21 -0
  64. package/types/components/ColorPicker/keyboardNavHandlers.d.ts +20 -0
  65. package/types/components/ContextMenu.d.ts +9 -22
  66. package/types/components/DefaultSidebar.d.ts +29 -0
  67. package/types/components/Dialog.d.ts +3 -4
  68. package/types/components/ErrorDialog.d.ts +3 -2
  69. package/types/components/ExcalidrawLogo.d.ts +15 -0
  70. package/types/components/EyeDropper.d.ts +28 -0
  71. package/types/components/FilledButton.d.ts +17 -0
  72. package/types/components/FixedSideContainer.d.ts +1 -1
  73. package/types/components/HandButton.d.ts +10 -0
  74. package/types/components/HelpButton.d.ts +1 -2
  75. package/types/components/HintViewer.d.ts +4 -5
  76. package/types/components/HomeButton.d.ts +1 -1
  77. package/types/components/ImageExportDialog.d.ts +8 -13
  78. package/types/components/Island.d.ts +1 -1
  79. package/types/components/JSONExportDialog.d.ts +7 -5
  80. package/types/components/LaserTool/LaserPathManager.d.ts +28 -0
  81. package/types/components/LaserTool/LaserPointerButton.d.ts +10 -0
  82. package/types/components/LaserTool/LaserTool.d.ts +7 -0
  83. package/types/components/LayerUI.d.ts +11 -19
  84. package/types/components/LibraryMenu.d.ts +13 -14
  85. package/types/components/LibraryMenuBrowseButton.d.ts +2 -2
  86. package/types/components/LibraryMenuControlButtons.d.ts +9 -0
  87. package/types/components/LibraryMenuHeaderContent.d.ts +10 -5
  88. package/types/components/LibraryMenuItems.d.ts +6 -7
  89. package/types/components/LibraryMenuSection.d.ts +22 -0
  90. package/types/components/LibraryUnit.d.ts +6 -3
  91. package/types/components/LoadingMessage.d.ts +0 -1
  92. package/types/components/LockButton.d.ts +1 -2
  93. package/types/components/MobileMenu.d.ts +9 -15
  94. package/types/components/OverwriteConfirm/OverwriteConfirm.d.ts +17 -0
  95. package/types/components/OverwriteConfirm/OverwriteConfirmActions.d.ts +17 -0
  96. package/types/components/OverwriteConfirm/OverwriteConfirmState.d.ts +22 -0
  97. package/types/components/PasteChartDialog.d.ts +4 -5
  98. package/types/components/PenModeButton.d.ts +1 -1
  99. package/types/components/Popover.d.ts +1 -1
  100. package/types/components/ProjectName.d.ts +2 -1
  101. package/types/components/PublishLibrary.d.ts +2 -2
  102. package/types/components/RadioGroup.d.ts +12 -0
  103. package/types/components/Section.d.ts +1 -1
  104. package/types/components/Sidebar/Sidebar.d.ts +66 -63
  105. package/types/components/Sidebar/SidebarHeader.d.ts +6 -19
  106. package/types/components/Sidebar/SidebarTab.d.ts +8 -0
  107. package/types/components/Sidebar/SidebarTabTrigger.d.ts +9 -0
  108. package/types/components/Sidebar/SidebarTabTriggers.d.ts +6 -0
  109. package/types/components/Sidebar/SidebarTabs.d.ts +6 -0
  110. package/types/components/Sidebar/SidebarTrigger.d.ts +6 -0
  111. package/types/components/Sidebar/common.d.ts +24 -7
  112. package/types/components/Spinner.d.ts +2 -1
  113. package/types/components/Stack.d.ts +4 -3
  114. package/types/components/Stats.d.ts +3 -3
  115. package/types/components/Switch.d.ts +9 -0
  116. package/types/components/ToolButton.d.ts +6 -5
  117. package/types/components/Tooltip.d.ts +1 -1
  118. package/types/components/Trans.d.ts +9 -0
  119. package/types/components/UserList.d.ts +0 -2
  120. package/types/components/canvases/InteractiveCanvas.d.ts +27 -0
  121. package/types/components/canvases/StaticCanvas.d.ts +18 -0
  122. package/types/components/canvases/index.d.ts +3 -0
  123. package/types/components/dropdownMenu/DropdownMenu.d.ts +70 -0
  124. package/types/components/dropdownMenu/DropdownMenuContent.d.ts +15 -0
  125. package/types/components/dropdownMenu/DropdownMenuGroup.d.ts +11 -0
  126. package/types/components/dropdownMenu/DropdownMenuItem.d.ts +13 -0
  127. package/types/components/dropdownMenu/DropdownMenuItemContent.d.ts +6 -0
  128. package/types/components/dropdownMenu/DropdownMenuItemCustom.d.ts +7 -0
  129. package/types/components/dropdownMenu/DropdownMenuItemLink.d.ts +14 -0
  130. package/types/components/dropdownMenu/DropdownMenuSeparator.d.ts +5 -0
  131. package/types/components/dropdownMenu/DropdownMenuTrigger.d.ts +10 -0
  132. package/types/components/dropdownMenu/common.d.ts +6 -0
  133. package/types/components/dropdownMenu/dropdownMenuUtils.d.ts +3 -0
  134. package/types/components/footer/Footer.d.ts +12 -0
  135. package/types/components/footer/FooterCenter.d.ts +8 -0
  136. package/types/components/hoc/withInternalFallback.d.ts +4 -0
  137. package/types/components/icons.d.ts +17 -2
  138. package/types/components/live-collaboration/LiveCollaborationTrigger.d.ts +9 -0
  139. package/types/components/main-menu/DefaultItems.d.ts +47 -0
  140. package/types/components/main-menu/MainMenu.d.ts +64 -0
  141. package/types/components/welcome-screen/WelcomeScreen.Center.d.ts +57 -0
  142. package/types/components/welcome-screen/WelcomeScreen.Hints.d.ts +19 -0
  143. package/types/components/welcome-screen/WelcomeScreen.d.ts +84 -0
  144. package/types/constants.d.ts +105 -18
  145. package/types/context/tunnels.d.ts +19 -0
  146. package/types/context/ui-appState.d.ts +4 -0
  147. package/types/cursor.d.ts +5 -0
  148. package/types/data/blob.d.ts +5 -3
  149. package/types/data/encode.d.ts +1 -1
  150. package/types/data/filesystem.d.ts +2 -1
  151. package/types/data/index.d.ts +1 -1
  152. package/types/data/library.d.ts +3 -45
  153. package/types/data/restore.d.ts +10 -4
  154. package/types/data/transform.d.ts +73 -0
  155. package/types/data/types.d.ts +3 -5
  156. package/types/data/url.d.ts +7 -0
  157. package/types/element/Hyperlink.d.ts +57 -36
  158. package/types/element/binding.d.ts +4 -3
  159. package/types/element/bounds.d.ts +41 -10
  160. package/types/element/collision.d.ts +7 -7
  161. package/types/element/dragElements.d.ts +12 -2
  162. package/types/element/embeddable.d.ts +153 -0
  163. package/types/element/image.d.ts +11 -1
  164. package/types/element/index.d.ts +3 -2
  165. package/types/element/linearElementEditor.d.ts +77 -30
  166. package/types/element/mutateElement.d.ts +3 -2
  167. package/types/element/newElement.d.ts +48 -15
  168. package/types/element/resizeElements.d.ts +3 -3
  169. package/types/element/resizeTest.d.ts +2 -1
  170. package/types/element/showSelectedShapeActions.d.ts +2 -2
  171. package/types/element/sizeHelpers.d.ts +8 -1
  172. package/types/element/sortElements.d.ts +2 -0
  173. package/types/element/textElement.d.ts +57 -9
  174. package/types/element/textWysiwyg.d.ts +7 -2
  175. package/types/element/transformHandles.d.ts +15 -8
  176. package/types/element/typeChecks.d.ts +14 -2
  177. package/types/element/types.d.ts +66 -35
  178. package/types/emitter.d.ts +1 -2
  179. package/types/errors.d.ts +1 -1
  180. package/types/frame.d.ts +46 -0
  181. package/types/ga.d.ts +5 -5
  182. package/types/groups.d.ts +15 -11
  183. package/types/history.d.ts +3 -3
  184. package/types/hooks/useCreatePortalContainer.d.ts +4 -0
  185. package/types/hooks/useLibraryItemSvg.d.ts +11 -0
  186. package/types/hooks/useOutsideClick.d.ts +19 -2
  187. package/types/hooks/useScrollPosition.d.ts +1 -0
  188. package/types/hooks/useStable.d.ts +1 -0
  189. package/types/hooks/useTransition.d.ts +2 -0
  190. package/types/i18n.d.ts +11 -2
  191. package/types/jotai.d.ts +20 -108
  192. package/types/keys.d.ts +7 -4
  193. package/types/math.d.ts +7 -1
  194. package/types/packages/bbox.d.ts +11 -0
  195. package/types/packages/excalidraw/example/App.d.ts +7 -1
  196. package/types/packages/excalidraw/example/CustomFooter.d.ts +5 -0
  197. package/types/packages/excalidraw/example/MobileFooter.d.ts +5 -0
  198. package/types/packages/excalidraw/example/initialData.d.ts +182 -64
  199. package/types/packages/excalidraw/index.d.ts +22 -4
  200. package/types/packages/excalidraw/main.d.ts +3 -1
  201. package/types/packages/excalidraw/webpack.dev.config.d.ts +5 -2
  202. package/types/packages/excalidraw/webpack.prod.config.d.ts +3 -0
  203. package/types/packages/utils.d.ts +30 -24
  204. package/types/packages/withinBounds.d.ts +19 -0
  205. package/types/renderer/renderElement.d.ts +13 -22
  206. package/types/renderer/renderScene.d.ts +19 -29
  207. package/types/renderer/renderSnaps.d.ts +2 -0
  208. package/types/renderer/roundRect.d.ts +1 -1
  209. package/types/scene/Fonts.d.ts +21 -0
  210. package/types/scene/Renderer.d.ts +25 -0
  211. package/types/scene/Scene.d.ts +42 -5
  212. package/types/scene/Shape.d.ts +12 -0
  213. package/types/scene/ShapeCache.d.ts +20 -0
  214. package/types/scene/comparisons.d.ts +2 -4
  215. package/types/scene/export.d.ts +183 -10
  216. package/types/scene/index.d.ts +1 -1
  217. package/types/scene/scroll.d.ts +1 -1
  218. package/types/scene/scrollbars.d.ts +2 -6
  219. package/types/scene/selection.d.ts +27 -6
  220. package/types/scene/types.d.ts +70 -26
  221. package/types/snapping.d.ts +108 -0
  222. package/types/types.d.ts +227 -91
  223. package/types/utility-types.d.ts +24 -0
  224. package/types/utils.d.ts +75 -14
  225. package/types/zindex.d.ts +4 -4
  226. package/types/components/ActiveFile.d.ts +0 -7
  227. package/types/components/ClearCanvas.d.ts +0 -4
  228. package/types/components/CollabButton.d.ts +0 -6
  229. package/types/components/ColorPicker.d.ts +0 -14
  230. package/types/components/Footer.d.ts +0 -10
  231. package/types/components/LibraryButton.d.ts +0 -8
  232. package/types/components/MenuItem.d.ts +0 -11
  233. package/types/components/MenuUtils.d.ts +0 -1
  234. package/types/components/SingleLibraryItem.d.ts +0 -10
  235. package/types/components/WelcomeScreen.d.ts +0 -10
  236. package/types/components/WelcomeScreenDecor.d.ts +0 -6
  237. package/types/components/hoc/withUpstreamOverride.d.ts +0 -10
  238. /package/dist/excalidraw-assets/{vendor-2002fe1b8862917b36c1.js.LICENSE.txt → vendor-d415b28e9024dee4bb1b.js.LICENSE.txt} +0 -0
  239. /package/types/packages/excalidraw/dist/excalidraw-assets/{vendor-2002fe1b8862917b36c1.d.ts → vendor-d415b28e9024dee4bb1b.d.ts} +0 -0
  240. /package/types/packages/excalidraw/dist/excalidraw-assets-dev/{vendor-e6df8519da951026ff69.d.ts → vendor-a14cd58fa2db417e42b2.d.ts} +0 -0
@@ -1,15 +1,24 @@
1
- /// <reference types="react" />
2
1
  export declare const actionToggleStats: {
3
2
  name: "stats";
3
+ viewMode: true;
4
4
  trackEvent: {
5
5
  category: "menu";
6
6
  };
7
7
  perform(elements: readonly import("../element/types").ExcalidrawElement[], appState: Readonly<import("../types").AppState>): {
8
8
  appState: {
9
9
  showStats: boolean;
10
+ contextMenu: {
11
+ items: import("../components/ContextMenu").ContextMenuItems;
12
+ top: number;
13
+ left: number;
14
+ } | null;
10
15
  showWelcomeScreen: boolean;
11
16
  isLoading: boolean;
12
- errorMessage: string | null;
17
+ errorMessage: import("react").ReactNode;
18
+ activeEmbeddable: {
19
+ element: import("../element/types").NonDeletedExcalidrawElement;
20
+ state: "active" | "hover";
21
+ } | null;
13
22
  draggingElement: import("../element/types").NonDeletedExcalidrawElement | null;
14
23
  resizingElement: import("../element/types").NonDeletedExcalidrawElement | null;
15
24
  multiElement: import("../element/types").NonDeleted<import("../element/types").ExcalidrawLinearElement> | null;
@@ -17,19 +26,21 @@ export declare const actionToggleStats: {
17
26
  isBindingEnabled: boolean;
18
27
  startBoundElement: import("../element/types").NonDeleted<import("../element/types").ExcalidrawBindableElement> | null;
19
28
  suggestedBindings: import("../element/binding").SuggestedBinding[];
29
+ frameToHighlight: import("../element/types").NonDeleted<import("../element/types").ExcalidrawFrameElement> | null;
30
+ frameRendering: {
31
+ enabled: boolean;
32
+ name: boolean;
33
+ outline: boolean;
34
+ clip: boolean;
35
+ };
36
+ editingFrame: string | null;
37
+ elementsToHighlight: import("../element/types").NonDeleted<import("../element/types").ExcalidrawElement>[] | null;
20
38
  editingElement: import("../element/types").NonDeletedExcalidrawElement | null;
21
39
  editingLinearElement: import("../element/linearElementEditor").LinearElementEditor | null;
22
40
  activeTool: {
23
- type: "line" | "arrow" | "text" | "selection" | "rectangle" | "diamond" | "ellipse" | "image" | "freedraw" | "eraser";
24
- lastActiveToolBeforeEraser: import("../types").LastActiveToolBeforeEraser;
25
- locked: boolean;
26
- customType: null;
27
- } | {
28
- type: "custom";
29
- customType: string;
30
- lastActiveToolBeforeEraser: import("../types").LastActiveToolBeforeEraser;
41
+ lastActiveTool: import("../types").ActiveTool | null;
31
42
  locked: boolean;
32
- };
43
+ } & import("../types").ActiveTool;
33
44
  penMode: boolean;
34
45
  penDetected: boolean;
35
46
  exportBackground: boolean;
@@ -46,10 +57,9 @@ export declare const actionToggleStats: {
46
57
  currentItemFontFamily: number;
47
58
  currentItemFontSize: number;
48
59
  currentItemTextAlign: string;
49
- currentItemStrokeSharpness: import("../element/types").StrokeSharpness;
50
60
  currentItemStartArrowhead: import("../element/types").Arrowhead | null;
51
61
  currentItemEndArrowhead: import("../element/types").Arrowhead | null;
52
- currentItemLinearStrokeSharpness: import("../element/types").StrokeSharpness;
62
+ currentItemRoundness: import("../element/types").StrokeRoundness;
53
63
  viewBackgroundColor: string;
54
64
  scrollX: number;
55
65
  scrollY: number;
@@ -62,17 +72,21 @@ export declare const actionToggleStats: {
62
72
  value: import("../types").NormalizedZoomValue;
63
73
  }>;
64
74
  openMenu: "canvas" | "shape" | null;
65
- openPopup: "canvasColorPicker" | "backgroundColorPicker" | "strokeColorPicker" | null;
66
- openSidebar: "library" | "customSidebar" | null;
67
- openDialog: "imageExport" | "help" | null;
68
- isSidebarDocked: boolean;
75
+ openPopup: "canvasBackground" | "elementBackground" | "elementStroke" | null;
76
+ openSidebar: {
77
+ name: string;
78
+ tab?: string | undefined;
79
+ } | null;
80
+ openDialog: "imageExport" | "help" | "jsonExport" | null;
81
+ defaultSidebarDockedPreference: boolean;
69
82
  lastPointerDownWith: import("../element/types").PointerType;
70
- selectedElementIds: {
71
- [id: string]: boolean;
72
- };
83
+ selectedElementIds: Readonly<{
84
+ [id: string]: true;
85
+ }>;
73
86
  previousSelectedElementIds: {
74
- [id: string]: boolean;
87
+ [id: string]: true;
75
88
  };
89
+ selectedElementsAreBeingDragged: boolean;
76
90
  shouldCacheIgnoreZoom: boolean;
77
91
  toast: {
78
92
  message: string;
@@ -80,7 +94,7 @@ export declare const actionToggleStats: {
80
94
  duration?: number | undefined;
81
95
  } | null;
82
96
  zenModeEnabled: boolean;
83
- theme: string;
97
+ theme: import("../element/types").Theme;
84
98
  gridSize: number | null;
85
99
  viewModeEnabled: boolean;
86
100
  selectedGroupIds: {
@@ -102,14 +116,20 @@ export declare const actionToggleStats: {
102
116
  data: import("../charts").Spreadsheet;
103
117
  };
104
118
  pendingImageElementId: string | null;
105
- showHyperlinkPopup: false | "info" | "editor";
119
+ showHyperlinkPopup: false | "editor" | "info";
106
120
  selectedLinearElement: import("../element/linearElementEditor").LinearElementEditor | null;
121
+ snapLines: readonly import("../snapping").SnapLine[];
122
+ originSnapOffset: {
123
+ x: number;
124
+ y: number;
125
+ } | null;
126
+ objectsSnapModeEnabled: boolean;
107
127
  };
108
128
  commitToHistory: false;
109
129
  };
110
130
  checked: (appState: Readonly<import("../types").AppState>) => boolean;
111
131
  contextItemLabel: string;
112
- keyTest: (event: KeyboardEvent | import("react").KeyboardEvent<Element>) => boolean;
132
+ keyTest: (event: import("react").KeyboardEvent<Element> | KeyboardEvent) => boolean;
113
133
  } & {
114
- keyTest?: ((event: KeyboardEvent | import("react").KeyboardEvent<Element>) => boolean) | undefined;
134
+ keyTest?: ((event: import("react").KeyboardEvent<Element> | KeyboardEvent) => boolean) | undefined;
115
135
  };
@@ -1,6 +1,6 @@
1
- /// <reference types="react" />
2
1
  export declare const actionToggleViewMode: {
3
2
  name: "viewMode";
3
+ viewMode: true;
4
4
  trackEvent: {
5
5
  category: "canvas";
6
6
  predicate: (appState: Readonly<import("../types").AppState>) => boolean;
@@ -8,9 +8,18 @@ export declare const actionToggleViewMode: {
8
8
  perform(elements: readonly import("../element/types").ExcalidrawElement[], appState: Readonly<import("../types").AppState>): {
9
9
  appState: {
10
10
  viewModeEnabled: boolean;
11
+ contextMenu: {
12
+ items: import("../components/ContextMenu").ContextMenuItems;
13
+ top: number;
14
+ left: number;
15
+ } | null;
11
16
  showWelcomeScreen: boolean;
12
17
  isLoading: boolean;
13
- errorMessage: string | null;
18
+ errorMessage: import("react").ReactNode;
19
+ activeEmbeddable: {
20
+ element: import("../element/types").NonDeletedExcalidrawElement;
21
+ state: "active" | "hover";
22
+ } | null;
14
23
  draggingElement: import("../element/types").NonDeletedExcalidrawElement | null;
15
24
  resizingElement: import("../element/types").NonDeletedExcalidrawElement | null;
16
25
  multiElement: import("../element/types").NonDeleted<import("../element/types").ExcalidrawLinearElement> | null;
@@ -18,19 +27,21 @@ export declare const actionToggleViewMode: {
18
27
  isBindingEnabled: boolean;
19
28
  startBoundElement: import("../element/types").NonDeleted<import("../element/types").ExcalidrawBindableElement> | null;
20
29
  suggestedBindings: import("../element/binding").SuggestedBinding[];
30
+ frameToHighlight: import("../element/types").NonDeleted<import("../element/types").ExcalidrawFrameElement> | null;
31
+ frameRendering: {
32
+ enabled: boolean;
33
+ name: boolean;
34
+ outline: boolean;
35
+ clip: boolean;
36
+ };
37
+ editingFrame: string | null;
38
+ elementsToHighlight: import("../element/types").NonDeleted<import("../element/types").ExcalidrawElement>[] | null;
21
39
  editingElement: import("../element/types").NonDeletedExcalidrawElement | null;
22
40
  editingLinearElement: import("../element/linearElementEditor").LinearElementEditor | null;
23
41
  activeTool: {
24
- type: "line" | "arrow" | "text" | "selection" | "rectangle" | "diamond" | "ellipse" | "image" | "freedraw" | "eraser";
25
- lastActiveToolBeforeEraser: import("../types").LastActiveToolBeforeEraser;
26
- locked: boolean;
27
- customType: null;
28
- } | {
29
- type: "custom";
30
- customType: string;
31
- lastActiveToolBeforeEraser: import("../types").LastActiveToolBeforeEraser;
42
+ lastActiveTool: import("../types").ActiveTool | null;
32
43
  locked: boolean;
33
- };
44
+ } & import("../types").ActiveTool;
34
45
  penMode: boolean;
35
46
  penDetected: boolean;
36
47
  exportBackground: boolean;
@@ -47,10 +58,9 @@ export declare const actionToggleViewMode: {
47
58
  currentItemFontFamily: number;
48
59
  currentItemFontSize: number;
49
60
  currentItemTextAlign: string;
50
- currentItemStrokeSharpness: import("../element/types").StrokeSharpness;
51
61
  currentItemStartArrowhead: import("../element/types").Arrowhead | null;
52
62
  currentItemEndArrowhead: import("../element/types").Arrowhead | null;
53
- currentItemLinearStrokeSharpness: import("../element/types").StrokeSharpness;
63
+ currentItemRoundness: import("../element/types").StrokeRoundness;
54
64
  viewBackgroundColor: string;
55
65
  scrollX: number;
56
66
  scrollY: number;
@@ -63,17 +73,21 @@ export declare const actionToggleViewMode: {
63
73
  value: import("../types").NormalizedZoomValue;
64
74
  }>;
65
75
  openMenu: "canvas" | "shape" | null;
66
- openPopup: "canvasColorPicker" | "backgroundColorPicker" | "strokeColorPicker" | null;
67
- openSidebar: "library" | "customSidebar" | null;
68
- openDialog: "imageExport" | "help" | null;
69
- isSidebarDocked: boolean;
76
+ openPopup: "canvasBackground" | "elementBackground" | "elementStroke" | null;
77
+ openSidebar: {
78
+ name: string;
79
+ tab?: string | undefined;
80
+ } | null;
81
+ openDialog: "imageExport" | "help" | "jsonExport" | null;
82
+ defaultSidebarDockedPreference: boolean;
70
83
  lastPointerDownWith: import("../element/types").PointerType;
71
- selectedElementIds: {
72
- [id: string]: boolean;
73
- };
84
+ selectedElementIds: Readonly<{
85
+ [id: string]: true;
86
+ }>;
74
87
  previousSelectedElementIds: {
75
- [id: string]: boolean;
88
+ [id: string]: true;
76
89
  };
90
+ selectedElementsAreBeingDragged: boolean;
77
91
  shouldCacheIgnoreZoom: boolean;
78
92
  toast: {
79
93
  message: string;
@@ -81,7 +95,7 @@ export declare const actionToggleViewMode: {
81
95
  duration?: number | undefined;
82
96
  } | null;
83
97
  zenModeEnabled: boolean;
84
- theme: string;
98
+ theme: import("../element/types").Theme;
85
99
  gridSize: number | null;
86
100
  selectedGroupIds: {
87
101
  [groupId: string]: boolean;
@@ -103,14 +117,21 @@ export declare const actionToggleViewMode: {
103
117
  data: import("../charts").Spreadsheet;
104
118
  };
105
119
  pendingImageElementId: string | null;
106
- showHyperlinkPopup: false | "info" | "editor";
120
+ showHyperlinkPopup: false | "editor" | "info";
107
121
  selectedLinearElement: import("../element/linearElementEditor").LinearElementEditor | null;
122
+ snapLines: readonly import("../snapping").SnapLine[];
123
+ originSnapOffset: {
124
+ x: number;
125
+ y: number;
126
+ } | null;
127
+ objectsSnapModeEnabled: boolean;
108
128
  };
109
129
  commitToHistory: false;
110
130
  };
111
131
  checked: (appState: Readonly<import("../types").AppState>) => boolean;
132
+ predicate: (elements: readonly import("../element/types").ExcalidrawElement[], appState: import("../types").AppState, appProps: import("../types").ExcalidrawProps) => boolean;
112
133
  contextItemLabel: string;
113
- keyTest: (event: KeyboardEvent | import("react").KeyboardEvent<Element>) => boolean;
134
+ keyTest: (event: import("react").KeyboardEvent<Element> | KeyboardEvent) => boolean;
114
135
  } & {
115
- keyTest?: ((event: KeyboardEvent | import("react").KeyboardEvent<Element>) => boolean) | undefined;
136
+ keyTest?: ((event: import("react").KeyboardEvent<Element> | KeyboardEvent) => boolean) | undefined;
116
137
  };
@@ -1,6 +1,6 @@
1
- /// <reference types="react" />
2
1
  export declare const actionToggleZenMode: {
3
2
  name: "zenMode";
3
+ viewMode: true;
4
4
  trackEvent: {
5
5
  category: "canvas";
6
6
  predicate: (appState: Readonly<import("../types").AppState>) => boolean;
@@ -8,9 +8,18 @@ export declare const actionToggleZenMode: {
8
8
  perform(elements: readonly import("../element/types").ExcalidrawElement[], appState: Readonly<import("../types").AppState>): {
9
9
  appState: {
10
10
  zenModeEnabled: boolean;
11
+ contextMenu: {
12
+ items: import("../components/ContextMenu").ContextMenuItems;
13
+ top: number;
14
+ left: number;
15
+ } | null;
11
16
  showWelcomeScreen: boolean;
12
17
  isLoading: boolean;
13
- errorMessage: string | null;
18
+ errorMessage: import("react").ReactNode;
19
+ activeEmbeddable: {
20
+ element: import("../element/types").NonDeletedExcalidrawElement;
21
+ state: "active" | "hover";
22
+ } | null;
14
23
  draggingElement: import("../element/types").NonDeletedExcalidrawElement | null;
15
24
  resizingElement: import("../element/types").NonDeletedExcalidrawElement | null;
16
25
  multiElement: import("../element/types").NonDeleted<import("../element/types").ExcalidrawLinearElement> | null;
@@ -18,19 +27,21 @@ export declare const actionToggleZenMode: {
18
27
  isBindingEnabled: boolean;
19
28
  startBoundElement: import("../element/types").NonDeleted<import("../element/types").ExcalidrawBindableElement> | null;
20
29
  suggestedBindings: import("../element/binding").SuggestedBinding[];
30
+ frameToHighlight: import("../element/types").NonDeleted<import("../element/types").ExcalidrawFrameElement> | null;
31
+ frameRendering: {
32
+ enabled: boolean;
33
+ name: boolean;
34
+ outline: boolean;
35
+ clip: boolean;
36
+ };
37
+ editingFrame: string | null;
38
+ elementsToHighlight: import("../element/types").NonDeleted<import("../element/types").ExcalidrawElement>[] | null;
21
39
  editingElement: import("../element/types").NonDeletedExcalidrawElement | null;
22
40
  editingLinearElement: import("../element/linearElementEditor").LinearElementEditor | null;
23
41
  activeTool: {
24
- type: "line" | "arrow" | "text" | "selection" | "rectangle" | "diamond" | "ellipse" | "image" | "freedraw" | "eraser";
25
- lastActiveToolBeforeEraser: import("../types").LastActiveToolBeforeEraser;
26
- locked: boolean;
27
- customType: null;
28
- } | {
29
- type: "custom";
30
- customType: string;
31
- lastActiveToolBeforeEraser: import("../types").LastActiveToolBeforeEraser;
42
+ lastActiveTool: import("../types").ActiveTool | null;
32
43
  locked: boolean;
33
- };
44
+ } & import("../types").ActiveTool;
34
45
  penMode: boolean;
35
46
  penDetected: boolean;
36
47
  exportBackground: boolean;
@@ -47,10 +58,9 @@ export declare const actionToggleZenMode: {
47
58
  currentItemFontFamily: number;
48
59
  currentItemFontSize: number;
49
60
  currentItemTextAlign: string;
50
- currentItemStrokeSharpness: import("../element/types").StrokeSharpness;
51
61
  currentItemStartArrowhead: import("../element/types").Arrowhead | null;
52
62
  currentItemEndArrowhead: import("../element/types").Arrowhead | null;
53
- currentItemLinearStrokeSharpness: import("../element/types").StrokeSharpness;
63
+ currentItemRoundness: import("../element/types").StrokeRoundness;
54
64
  viewBackgroundColor: string;
55
65
  scrollX: number;
56
66
  scrollY: number;
@@ -63,24 +73,28 @@ export declare const actionToggleZenMode: {
63
73
  value: import("../types").NormalizedZoomValue;
64
74
  }>;
65
75
  openMenu: "canvas" | "shape" | null;
66
- openPopup: "canvasColorPicker" | "backgroundColorPicker" | "strokeColorPicker" | null;
67
- openSidebar: "library" | "customSidebar" | null;
68
- openDialog: "imageExport" | "help" | null;
69
- isSidebarDocked: boolean;
76
+ openPopup: "canvasBackground" | "elementBackground" | "elementStroke" | null;
77
+ openSidebar: {
78
+ name: string;
79
+ tab?: string | undefined;
80
+ } | null;
81
+ openDialog: "imageExport" | "help" | "jsonExport" | null;
82
+ defaultSidebarDockedPreference: boolean;
70
83
  lastPointerDownWith: import("../element/types").PointerType;
71
- selectedElementIds: {
72
- [id: string]: boolean;
73
- };
84
+ selectedElementIds: Readonly<{
85
+ [id: string]: true;
86
+ }>;
74
87
  previousSelectedElementIds: {
75
- [id: string]: boolean;
88
+ [id: string]: true;
76
89
  };
90
+ selectedElementsAreBeingDragged: boolean;
77
91
  shouldCacheIgnoreZoom: boolean;
78
92
  toast: {
79
93
  message: string;
80
94
  closable?: boolean | undefined;
81
95
  duration?: number | undefined;
82
96
  } | null;
83
- theme: string;
97
+ theme: import("../element/types").Theme;
84
98
  gridSize: number | null;
85
99
  viewModeEnabled: boolean;
86
100
  selectedGroupIds: {
@@ -103,14 +117,21 @@ export declare const actionToggleZenMode: {
103
117
  data: import("../charts").Spreadsheet;
104
118
  };
105
119
  pendingImageElementId: string | null;
106
- showHyperlinkPopup: false | "info" | "editor";
120
+ showHyperlinkPopup: false | "editor" | "info";
107
121
  selectedLinearElement: import("../element/linearElementEditor").LinearElementEditor | null;
122
+ snapLines: readonly import("../snapping").SnapLine[];
123
+ originSnapOffset: {
124
+ x: number;
125
+ y: number;
126
+ } | null;
127
+ objectsSnapModeEnabled: boolean;
108
128
  };
109
129
  commitToHistory: false;
110
130
  };
111
131
  checked: (appState: Readonly<import("../types").AppState>) => boolean;
132
+ predicate: (elements: readonly import("../element/types").ExcalidrawElement[], appState: import("../types").AppState, appProps: import("../types").ExcalidrawProps) => boolean;
112
133
  contextItemLabel: string;
113
- keyTest: (event: KeyboardEvent | import("react").KeyboardEvent<Element>) => boolean;
134
+ keyTest: (event: import("react").KeyboardEvent<Element> | KeyboardEvent) => boolean;
114
135
  } & {
115
- keyTest?: ((event: KeyboardEvent | import("react").KeyboardEvent<Element>) => boolean) | undefined;
136
+ keyTest?: ((event: import("react").KeyboardEvent<Element> | KeyboardEvent) => boolean) | undefined;
116
137
  };
@@ -5,18 +5,16 @@ export declare const actionSendBackward: {
5
5
  category: "element";
6
6
  };
7
7
  perform: (elements: readonly import("../element/types").ExcalidrawElement[], appState: Readonly<import("../types").AppState>) => {
8
- elements: (import("../element/types").ExcalidrawLinearElement | import("../element/types").ExcalidrawSelectionElement | import("../element/types").ExcalidrawRectangleElement | import("../element/types").ExcalidrawDiamondElement | import("../element/types").ExcalidrawEllipseElement | import("../element/types").ExcalidrawImageElement | import("../element/types").ExcalidrawTextElement | import("../element/types").ExcalidrawFreeDrawElement)[];
8
+ elements: import("../element/types").ExcalidrawElement[];
9
9
  appState: Readonly<import("../types").AppState>;
10
10
  commitToHistory: true;
11
11
  };
12
12
  contextItemLabel: string;
13
13
  keyPriority: number;
14
- keyTest: (event: KeyboardEvent | React.KeyboardEvent<Element>) => boolean;
15
- PanelComponent: ({ updateData, appState }: import("./types").PanelComponentProps & {
16
- isInHamburgerMenu: boolean;
17
- }) => JSX.Element;
14
+ keyTest: (event: React.KeyboardEvent<Element> | KeyboardEvent) => boolean;
15
+ PanelComponent: ({ updateData, appState }: import("./types").PanelComponentProps) => JSX.Element;
18
16
  } & {
19
- keyTest?: ((event: KeyboardEvent | React.KeyboardEvent<Element>) => boolean) | undefined;
17
+ keyTest?: ((event: React.KeyboardEvent<Element> | KeyboardEvent) => boolean) | undefined;
20
18
  };
21
19
  export declare const actionBringForward: {
22
20
  name: "bringForward";
@@ -24,18 +22,16 @@ export declare const actionBringForward: {
24
22
  category: "element";
25
23
  };
26
24
  perform: (elements: readonly import("../element/types").ExcalidrawElement[], appState: Readonly<import("../types").AppState>) => {
27
- elements: (import("../element/types").ExcalidrawLinearElement | import("../element/types").ExcalidrawSelectionElement | import("../element/types").ExcalidrawRectangleElement | import("../element/types").ExcalidrawDiamondElement | import("../element/types").ExcalidrawEllipseElement | import("../element/types").ExcalidrawImageElement | import("../element/types").ExcalidrawTextElement | import("../element/types").ExcalidrawFreeDrawElement)[];
25
+ elements: import("../element/types").ExcalidrawElement[];
28
26
  appState: Readonly<import("../types").AppState>;
29
27
  commitToHistory: true;
30
28
  };
31
29
  contextItemLabel: string;
32
30
  keyPriority: number;
33
- keyTest: (event: KeyboardEvent | React.KeyboardEvent<Element>) => boolean;
34
- PanelComponent: ({ updateData, appState }: import("./types").PanelComponentProps & {
35
- isInHamburgerMenu: boolean;
36
- }) => JSX.Element;
31
+ keyTest: (event: React.KeyboardEvent<Element> | KeyboardEvent) => boolean;
32
+ PanelComponent: ({ updateData, appState }: import("./types").PanelComponentProps) => JSX.Element;
37
33
  } & {
38
- keyTest?: ((event: KeyboardEvent | React.KeyboardEvent<Element>) => boolean) | undefined;
34
+ keyTest?: ((event: React.KeyboardEvent<Element> | KeyboardEvent) => boolean) | undefined;
39
35
  };
40
36
  export declare const actionSendToBack: {
41
37
  name: "sendToBack";
@@ -43,17 +39,15 @@ export declare const actionSendToBack: {
43
39
  category: "element";
44
40
  };
45
41
  perform: (elements: readonly import("../element/types").ExcalidrawElement[], appState: Readonly<import("../types").AppState>) => {
46
- elements: readonly import("../element/types").ExcalidrawElement[];
42
+ elements: readonly import("../element/types").ExcalidrawElement[] | import("../element/types").ExcalidrawElement[];
47
43
  appState: Readonly<import("../types").AppState>;
48
44
  commitToHistory: true;
49
45
  };
50
46
  contextItemLabel: string;
51
- keyTest: (event: KeyboardEvent | React.KeyboardEvent<Element>) => boolean;
52
- PanelComponent: ({ updateData, appState }: import("./types").PanelComponentProps & {
53
- isInHamburgerMenu: boolean;
54
- }) => JSX.Element;
47
+ keyTest: (event: React.KeyboardEvent<Element> | KeyboardEvent) => boolean;
48
+ PanelComponent: ({ updateData, appState }: import("./types").PanelComponentProps) => JSX.Element;
55
49
  } & {
56
- keyTest?: ((event: KeyboardEvent | React.KeyboardEvent<Element>) => boolean) | undefined;
50
+ keyTest?: ((event: React.KeyboardEvent<Element> | KeyboardEvent) => boolean) | undefined;
57
51
  };
58
52
  export declare const actionBringToFront: {
59
53
  name: "bringToFront";
@@ -61,15 +55,13 @@ export declare const actionBringToFront: {
61
55
  category: "element";
62
56
  };
63
57
  perform: (elements: readonly import("../element/types").ExcalidrawElement[], appState: Readonly<import("../types").AppState>) => {
64
- elements: readonly import("../element/types").ExcalidrawElement[];
58
+ elements: readonly import("../element/types").ExcalidrawElement[] | import("../element/types").ExcalidrawElement[];
65
59
  appState: Readonly<import("../types").AppState>;
66
60
  commitToHistory: true;
67
61
  };
68
62
  contextItemLabel: string;
69
- keyTest: (event: KeyboardEvent | React.KeyboardEvent<Element>) => boolean;
70
- PanelComponent: ({ updateData, appState }: import("./types").PanelComponentProps & {
71
- isInHamburgerMenu: boolean;
72
- }) => JSX.Element;
63
+ keyTest: (event: React.KeyboardEvent<Element> | KeyboardEvent) => boolean;
64
+ PanelComponent: ({ updateData, appState }: import("./types").PanelComponentProps) => JSX.Element;
73
65
  } & {
74
- keyTest?: ((event: KeyboardEvent | React.KeyboardEvent<Element>) => boolean) | undefined;
66
+ keyTest?: ((event: React.KeyboardEvent<Element> | KeyboardEvent) => boolean) | undefined;
75
67
  };
@@ -17,8 +17,9 @@ export { actionFlipHorizontal, actionFlipVertical } from "./actionFlip";
17
17
  export { actionCopy, actionCut, actionCopyAsPng, actionCopyAsSvg, copyText, } from "./actionClipboard";
18
18
  export { actionToggleGridMode } from "./actionToggleGridMode";
19
19
  export { actionToggleZenMode } from "./actionToggleZenMode";
20
+ export { actionToggleObjectsSnapMode } from "./actionToggleObjectsSnapMode";
20
21
  export { actionToggleStats } from "./actionToggleStats";
21
22
  export { actionUnbindText, actionBindText } from "./actionBoundText";
22
23
  export { actionLink } from "../element/Hyperlink";
23
- export { actionToggleLock } from "./actionToggleLock";
24
+ export { actionToggleElementLock } from "./actionElementLock";
24
25
  export { actionToggleLinearEditor } from "./actionLinearEditor";
@@ -12,9 +12,10 @@ export declare class ActionManager {
12
12
  registerAction(action: Action): void;
13
13
  registerAll(actions: readonly Action[]): void;
14
14
  handleKeyDown(event: React.KeyboardEvent | KeyboardEvent): boolean;
15
- executeAction(action: Action, source?: ActionSource): void;
15
+ executeAction(action: Action, source?: ActionSource, value?: any): void;
16
16
  /**
17
17
  * @param data additional data sent to the PanelComponent
18
18
  */
19
- renderAction: (name: ActionName, data?: PanelComponentProps["data"], isInHamburgerMenu?: boolean) => JSX.Element | null;
19
+ renderAction: (name: ActionName, data?: PanelComponentProps["data"]) => JSX.Element | null;
20
+ isActionEnabled: (action: Action) => boolean;
20
21
  }
@@ -1,3 +1,4 @@
1
+ import { SubtypeOf } from "../utility-types";
1
2
  import { ActionName } from "./types";
2
- export declare type ShortcutName = SubtypeOf<ActionName, "toggleTheme" | "loadScene" | "cut" | "copy" | "paste" | "copyStyles" | "pasteStyles" | "selectAll" | "deleteSelectedElements" | "duplicateSelection" | "sendBackward" | "bringForward" | "sendToBack" | "bringToFront" | "copyAsPng" | "copyAsSvg" | "group" | "ungroup" | "gridMode" | "zenMode" | "stats" | "addToLibrary" | "viewMode" | "flipHorizontal" | "flipVertical" | "hyperlink" | "toggleLock"> | "saveScene" | "imageExport";
3
+ export type ShortcutName = SubtypeOf<ActionName, "toggleTheme" | "loadScene" | "clearCanvas" | "cut" | "copy" | "paste" | "copyStyles" | "pasteStyles" | "selectAll" | "deleteSelectedElements" | "duplicateSelection" | "sendBackward" | "bringForward" | "sendToBack" | "bringToFront" | "copyAsPng" | "copyAsSvg" | "group" | "ungroup" | "gridMode" | "zenMode" | "objectsSnapMode" | "stats" | "addToLibrary" | "viewMode" | "flipHorizontal" | "flipVertical" | "hyperlink" | "toggleElementLock"> | "saveScene" | "imageExport";
3
4
  export declare const getShortcutFromShortcutName: (name: ShortcutName) => string;
@@ -1,9 +1,10 @@
1
1
  import React from "react";
2
2
  import { ExcalidrawElement } from "../element/types";
3
3
  import { AppClassProperties, AppState, ExcalidrawProps, BinaryFiles } from "../types";
4
- export declare type ActionSource = "ui" | "keyboard" | "contextMenu" | "api";
4
+ import { MarkOptional } from "../utility-types";
5
+ export type ActionSource = "ui" | "keyboard" | "contextMenu" | "api";
5
6
  /** if false, the action should be prevented */
6
- export declare type ActionResult = {
7
+ export type ActionResult = {
7
8
  elements?: readonly ExcalidrawElement[] | null;
8
9
  appState?: MarkOptional<AppState, "offsetTop" | "offsetLeft" | "width" | "height"> | null;
9
10
  files?: BinaryFiles | null;
@@ -11,32 +12,34 @@ export declare type ActionResult = {
11
12
  syncHistory?: boolean;
12
13
  replaceFiles?: boolean;
13
14
  } | false;
14
- declare type ActionFn = (elements: readonly ExcalidrawElement[], appState: Readonly<AppState>, formData: any, app: AppClassProperties) => ActionResult | Promise<ActionResult>;
15
- export declare type UpdaterFn = (res: ActionResult) => void;
16
- export declare type ActionFilterFn = (action: Action) => void;
17
- export declare type ActionName = "copy" | "cut" | "paste" | "copyAsPng" | "copyAsSvg" | "copyText" | "sendBackward" | "bringForward" | "sendToBack" | "bringToFront" | "copyStyles" | "selectAll" | "pasteStyles" | "gridMode" | "zenMode" | "stats" | "changeStrokeColor" | "changeBackgroundColor" | "changeFillStyle" | "changeStrokeWidth" | "changeStrokeShape" | "changeSloppiness" | "changeStrokeStyle" | "changeArrowhead" | "changeOpacity" | "changeFontSize" | "toggleCanvasMenu" | "toggleEditMenu" | "undo" | "redo" | "finalize" | "changeProjectName" | "changeExportBackground" | "changeExportEmbedScene" | "changeExportScale" | "saveToActiveFile" | "saveFileToDisk" | "loadScene" | "duplicateSelection" | "deleteSelectedElements" | "changeViewBackgroundColor" | "clearCanvas" | "zoomIn" | "zoomOut" | "resetZoom" | "zoomToFit" | "zoomToSelection" | "changeFontFamily" | "changeTextAlign" | "changeVerticalAlign" | "toggleFullScreen" | "toggleShortcuts" | "group" | "ungroup" | "goToCollaborator" | "addToLibrary" | "changeSharpness" | "alignTop" | "alignBottom" | "alignLeft" | "alignRight" | "alignVerticallyCentered" | "alignHorizontallyCentered" | "distributeHorizontally" | "distributeVertically" | "flipHorizontal" | "flipVertical" | "viewMode" | "exportWithDarkMode" | "toggleTheme" | "increaseFontSize" | "decreaseFontSize" | "unbindText" | "hyperlink" | "eraser" | "bindText" | "toggleLock" | "toggleLinearEditor";
18
- export declare type PanelComponentProps = {
15
+ type ActionFn = (elements: readonly ExcalidrawElement[], appState: Readonly<AppState>, formData: any, app: AppClassProperties) => ActionResult | Promise<ActionResult>;
16
+ export type UpdaterFn = (res: ActionResult) => void;
17
+ export type ActionFilterFn = (action: Action) => void;
18
+ export type ActionName = "copy" | "cut" | "paste" | "copyAsPng" | "copyAsSvg" | "copyText" | "sendBackward" | "bringForward" | "sendToBack" | "bringToFront" | "copyStyles" | "selectAll" | "pasteStyles" | "gridMode" | "zenMode" | "objectsSnapMode" | "stats" | "changeStrokeColor" | "changeBackgroundColor" | "changeFillStyle" | "changeStrokeWidth" | "changeStrokeShape" | "changeSloppiness" | "changeStrokeStyle" | "changeArrowhead" | "changeOpacity" | "changeFontSize" | "toggleCanvasMenu" | "toggleEditMenu" | "undo" | "redo" | "finalize" | "changeProjectName" | "changeExportBackground" | "changeExportEmbedScene" | "changeExportScale" | "saveToActiveFile" | "saveFileToDisk" | "loadScene" | "duplicateSelection" | "deleteSelectedElements" | "changeViewBackgroundColor" | "clearCanvas" | "zoomIn" | "zoomOut" | "resetZoom" | "zoomToFit" | "zoomToFitSelection" | "zoomToFitSelectionInViewport" | "changeFontFamily" | "changeTextAlign" | "changeVerticalAlign" | "toggleFullScreen" | "toggleShortcuts" | "group" | "ungroup" | "goToCollaborator" | "addToLibrary" | "changeRoundness" | "alignTop" | "alignBottom" | "alignLeft" | "alignRight" | "alignVerticallyCentered" | "alignHorizontallyCentered" | "distributeHorizontally" | "distributeVertically" | "flipHorizontal" | "flipVertical" | "viewMode" | "exportWithDarkMode" | "toggleTheme" | "increaseFontSize" | "decreaseFontSize" | "unbindText" | "hyperlink" | "bindText" | "unlockAllElements" | "toggleElementLock" | "toggleLinearEditor" | "toggleEraserTool" | "toggleHandTool" | "selectAllElementsInFrame" | "removeAllElementsFromFrame" | "updateFrameRendering" | "setFrameAsActiveTool" | "setEmbeddableAsActiveTool" | "createContainerFromText" | "wrapTextInContainer";
19
+ export type PanelComponentProps = {
19
20
  elements: readonly ExcalidrawElement[];
20
21
  appState: AppState;
21
22
  updateData: (formData?: any) => void;
22
23
  appProps: ExcalidrawProps;
23
24
  data?: Record<string, any>;
25
+ app: AppClassProperties;
24
26
  };
25
27
  export interface Action {
26
28
  name: ActionName;
27
- PanelComponent?: React.FC<PanelComponentProps & {
28
- isInHamburgerMenu: boolean;
29
- }>;
29
+ PanelComponent?: React.FC<PanelComponentProps>;
30
30
  perform: ActionFn;
31
31
  keyPriority?: number;
32
- keyTest?: (event: React.KeyboardEvent | KeyboardEvent, appState: AppState, elements: readonly ExcalidrawElement[]) => boolean;
33
- contextItemLabel?: string | ((elements: readonly ExcalidrawElement[], appState: Readonly<AppState>) => string);
34
- contextItemPredicate?: (elements: readonly ExcalidrawElement[], appState: AppState) => boolean;
32
+ keyTest?: (event: React.KeyboardEvent | KeyboardEvent, appState: AppState, elements: readonly ExcalidrawElement[], app: AppClassProperties) => boolean;
33
+ contextItemLabel?: string | ((elements: readonly ExcalidrawElement[], appState: Readonly<AppState>, app: AppClassProperties) => string);
34
+ predicate?: (elements: readonly ExcalidrawElement[], appState: AppState, appProps: ExcalidrawProps, app: AppClassProperties) => boolean;
35
35
  checked?: (appState: Readonly<AppState>) => boolean;
36
36
  trackEvent: false | {
37
37
  category: "toolbar" | "element" | "canvas" | "export" | "history" | "menu" | "collab" | "hyperlink";
38
38
  action?: string;
39
39
  predicate?: (appState: Readonly<AppState>, elements: readonly ExcalidrawElement[], value: any) => boolean;
40
40
  };
41
+ /** if set to `true`, allow action to be performed in viewMode.
42
+ * Defaults to `false` */
43
+ viewMode?: boolean;
41
44
  }
42
45
  export {};