@excalidraw/common 0.18.0-b9d27d3 → 0.18.0-c158187

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 (202) hide show
  1. package/dist/dev/index.js +1390 -59
  2. package/dist/dev/index.js.map +4 -4
  3. package/dist/prod/index.js +3 -3
  4. package/dist/types/common/src/bounds.d.ts +10 -0
  5. package/dist/types/common/src/colors.d.ts +5 -2
  6. package/dist/types/common/src/constants.d.ts +23 -25
  7. package/dist/types/common/src/editorInterface.d.ts +34 -0
  8. package/dist/types/common/src/font-metadata.d.ts +1 -3
  9. package/dist/types/common/src/index.d.ts +3 -0
  10. package/dist/types/common/src/keys.d.ts +1 -1
  11. package/dist/types/common/src/utility-types.d.ts +0 -1
  12. package/dist/types/common/src/utils.d.ts +50 -34
  13. package/dist/types/common/src/visualdebug.d.ts +41 -0
  14. package/dist/types/element/src/Scene.d.ts +4 -4
  15. package/dist/types/element/src/binding.d.ts +58 -44
  16. package/dist/types/element/src/bounds.d.ts +2 -10
  17. package/dist/types/element/src/collision.d.ts +6 -2
  18. package/dist/types/element/src/comparisons.d.ts +7 -7
  19. package/dist/types/element/src/dragElements.d.ts +3 -3
  20. package/dist/types/element/src/duplicate.d.ts +3 -3
  21. package/dist/types/element/src/fractionalIndex.d.ts +2 -2
  22. package/dist/types/element/src/frame.d.ts +7 -3
  23. package/dist/types/element/src/heading.d.ts +2 -1
  24. package/dist/types/element/src/image.d.ts +1 -11
  25. package/dist/types/element/src/index.d.ts +1 -3
  26. package/dist/types/element/src/linearElementEditor.d.ts +16 -20
  27. package/dist/types/element/src/mutateElement.d.ts +3 -1
  28. package/dist/types/element/src/newElement.d.ts +6 -6
  29. package/dist/types/element/src/renderElement.d.ts +4 -7
  30. package/dist/types/element/src/resizeElements.d.ts +10 -10
  31. package/dist/types/element/src/resizeTest.d.ts +6 -5
  32. package/dist/types/element/src/selection.d.ts +3 -7
  33. package/dist/types/element/src/shape.d.ts +8 -7
  34. package/dist/types/element/src/textMeasurements.d.ts +1 -3
  35. package/dist/types/{excalidraw/data → element/src}/transform.d.ts +3 -3
  36. package/dist/types/element/src/transformHandles.d.ts +8 -27
  37. package/dist/types/element/src/typeChecks.d.ts +4 -7
  38. package/dist/types/element/src/types.d.ts +7 -11
  39. package/dist/types/element/src/utils.d.ts +5 -2
  40. package/dist/types/element/src/zindex.d.ts +7 -1
  41. package/dist/types/excalidraw/actions/actionAddToLibrary.d.ts +138 -181
  42. package/dist/types/excalidraw/actions/actionAlign.d.ts +6 -7
  43. package/dist/types/excalidraw/actions/actionBoundText.d.ts +67 -96
  44. package/dist/types/excalidraw/actions/actionCanvas.d.ts +401 -771
  45. package/dist/types/excalidraw/actions/actionClipboard.d.ts +103 -873
  46. package/dist/types/excalidraw/actions/actionCropEditor.d.ts +32 -47
  47. package/dist/types/excalidraw/actions/actionDeleteSelected.d.ts +110 -159
  48. package/dist/types/excalidraw/actions/actionDistribute.d.ts +2 -3
  49. package/dist/types/excalidraw/actions/actionDuplicateSelection.d.ts +3 -4
  50. package/dist/types/excalidraw/actions/actionElementLink.d.ts +47 -64
  51. package/dist/types/excalidraw/actions/actionElementLock.d.ts +66 -95
  52. package/dist/types/excalidraw/actions/actionEmbeddable.d.ts +49 -64
  53. package/dist/types/excalidraw/actions/actionExport.d.ts +144 -1104
  54. package/dist/types/excalidraw/actions/actionFinalize.d.ts +10 -394
  55. package/dist/types/excalidraw/actions/actionFlip.d.ts +2 -3
  56. package/dist/types/excalidraw/actions/actionFrame.d.ts +252 -347
  57. package/dist/types/excalidraw/actions/actionGroup.d.ts +70 -107
  58. package/dist/types/excalidraw/actions/actionLinearEditor.d.ts +165 -220
  59. package/dist/types/excalidraw/actions/actionLink.d.ts +49 -64
  60. package/dist/types/excalidraw/actions/actionMenu.d.ts +42 -425
  61. package/dist/types/excalidraw/actions/actionNavigate.d.ts +18 -359
  62. package/dist/types/excalidraw/actions/actionProperties.d.ts +129 -2488
  63. package/dist/types/excalidraw/actions/actionSelectAll.d.ts +35 -54
  64. package/dist/types/excalidraw/actions/actionStyles.d.ts +32 -47
  65. package/dist/types/excalidraw/actions/actionTextAutoResize.d.ts +3 -3
  66. package/dist/types/excalidraw/actions/actionToggleGridMode.d.ts +49 -64
  67. package/dist/types/excalidraw/actions/actionToggleObjectsSnapMode.d.ts +49 -64
  68. package/dist/types/excalidraw/actions/actionToggleSearchMenu.d.ts +41 -58
  69. package/dist/types/excalidraw/actions/actionToggleShapeSwitch.d.ts +1 -1
  70. package/dist/types/excalidraw/actions/actionToggleStats.d.ts +48 -63
  71. package/dist/types/excalidraw/actions/actionToggleViewMode.d.ts +49 -64
  72. package/dist/types/excalidraw/actions/actionToggleZenMode.d.ts +49 -64
  73. package/dist/types/excalidraw/actions/actionZindex.d.ts +8 -9
  74. package/dist/types/excalidraw/actions/index.d.ts +2 -2
  75. package/dist/types/excalidraw/actions/register.d.ts +2 -2
  76. package/dist/types/excalidraw/actions/types.d.ts +4 -4
  77. package/dist/types/excalidraw/appState.d.ts +20 -15
  78. package/dist/types/excalidraw/clipboard.d.ts +7 -29
  79. package/dist/types/excalidraw/components/Actions.d.ts +22 -5
  80. package/dist/types/excalidraw/components/App.d.ts +58 -59
  81. package/dist/types/excalidraw/components/Card.d.ts +0 -1
  82. package/dist/types/excalidraw/components/ColorPicker/ColorInput.d.ts +7 -4
  83. package/dist/types/excalidraw/components/ColorPicker/ColorPicker.d.ts +0 -1
  84. package/dist/types/excalidraw/components/ColorPicker/Picker.d.ts +2 -0
  85. package/dist/types/excalidraw/components/ColorPicker/PickerColorList.d.ts +2 -1
  86. package/dist/types/excalidraw/components/ColorPicker/ShadeList.d.ts +2 -1
  87. package/dist/types/excalidraw/components/ColorPicker/keyboardNavHandlers.d.ts +0 -1
  88. package/dist/types/excalidraw/components/CommandPalette/CommandPalette.d.ts +1 -0
  89. package/dist/types/excalidraw/components/CommandPalette/types.d.ts +1 -3
  90. package/dist/types/excalidraw/components/ConvertElementTypePopup.d.ts +2 -2
  91. package/dist/types/excalidraw/components/DarkModeToggle.d.ts +1 -1
  92. package/dist/types/excalidraw/components/DefaultSidebar.d.ts +9 -13
  93. package/dist/types/excalidraw/components/ElementLinkDialog.d.ts +1 -1
  94. package/dist/types/excalidraw/components/Ellipsify.d.ts +1 -2
  95. package/dist/types/excalidraw/components/ErrorDialog.d.ts +1 -1
  96. package/dist/types/excalidraw/components/ExcalidrawLogo.d.ts +1 -2
  97. package/dist/types/excalidraw/components/EyeDropper.d.ts +0 -1
  98. package/dist/types/excalidraw/components/FilledButton.d.ts +1 -1
  99. package/dist/types/excalidraw/components/FontPicker/FontPicker.d.ts +2 -1
  100. package/dist/types/excalidraw/components/FontPicker/FontPickerTrigger.d.ts +3 -1
  101. package/dist/types/excalidraw/components/FontPicker/keyboardNavHandlers.d.ts +0 -1
  102. package/dist/types/excalidraw/components/HelpDialog.d.ts +1 -1
  103. package/dist/types/excalidraw/components/HintViewer.d.ts +4 -3
  104. package/dist/types/excalidraw/components/InlineIcon.d.ts +3 -1
  105. package/dist/types/excalidraw/components/LayerUI.d.ts +2 -1
  106. package/dist/types/excalidraw/components/LibraryMenuControlButtons.d.ts +1 -1
  107. package/dist/types/excalidraw/components/LibraryMenuHeaderContent.d.ts +1 -2
  108. package/dist/types/excalidraw/components/LibraryMenuSection.d.ts +1 -1
  109. package/dist/types/excalidraw/components/LibraryUnit.d.ts +2 -3
  110. package/dist/types/excalidraw/components/LoadingMessage.d.ts +0 -1
  111. package/dist/types/excalidraw/components/MobileMenu.d.ts +3 -5
  112. package/dist/types/excalidraw/components/MobileToolBar.d.ts +10 -0
  113. package/dist/types/excalidraw/components/Modal.d.ts +0 -1
  114. package/dist/types/excalidraw/components/OverwriteConfirm/OverwriteConfirm.d.ts +1 -1
  115. package/dist/types/excalidraw/components/Popover.d.ts +2 -1
  116. package/dist/types/excalidraw/components/PropertiesPopover.d.ts +1 -0
  117. package/dist/types/excalidraw/components/RadioGroup.d.ts +0 -1
  118. package/dist/types/excalidraw/components/RadioSelection.d.ts +4 -4
  119. package/dist/types/excalidraw/components/ScrollableList.d.ts +0 -1
  120. package/dist/types/excalidraw/components/Sidebar/Sidebar.d.ts +15 -21
  121. package/dist/types/excalidraw/components/Sidebar/SidebarHeader.d.ts +1 -1
  122. package/dist/types/excalidraw/components/Sidebar/SidebarTab.d.ts +1 -2
  123. package/dist/types/excalidraw/components/Sidebar/SidebarTabTrigger.d.ts +1 -2
  124. package/dist/types/excalidraw/components/Sidebar/SidebarTabTriggers.d.ts +1 -2
  125. package/dist/types/excalidraw/components/Sidebar/SidebarTabs.d.ts +1 -2
  126. package/dist/types/excalidraw/components/Spinner.d.ts +4 -4
  127. package/dist/types/excalidraw/components/Stats/CanvasGrid.d.ts +0 -1
  128. package/dist/types/excalidraw/components/Stats/Collapsible.d.ts +0 -1
  129. package/dist/types/excalidraw/components/Stats/DragInput.d.ts +0 -1
  130. package/dist/types/excalidraw/components/Stats/index.d.ts +7 -8
  131. package/dist/types/excalidraw/components/Stats/utils.d.ts +1 -1
  132. package/dist/types/excalidraw/components/TTDDialog/TTDDialog.d.ts +1 -2
  133. package/dist/types/excalidraw/components/TTDDialog/TTDDialogOutput.d.ts +0 -1
  134. package/dist/types/excalidraw/components/TTDDialog/TTDDialogTab.d.ts +1 -2
  135. package/dist/types/excalidraw/components/TTDDialog/TTDDialogTabTrigger.d.ts +1 -2
  136. package/dist/types/excalidraw/components/TTDDialog/TTDDialogTabTriggers.d.ts +1 -2
  137. package/dist/types/excalidraw/components/TTDDialog/TTDDialogTrigger.d.ts +2 -3
  138. package/dist/types/excalidraw/components/TTDDialog/common.d.ts +2 -3
  139. package/dist/types/excalidraw/components/TextField.d.ts +1 -0
  140. package/dist/types/excalidraw/components/Toast.d.ts +3 -3
  141. package/dist/types/excalidraw/components/ToolPopover.d.ts +25 -0
  142. package/dist/types/excalidraw/components/Trans.d.ts +2 -2
  143. package/dist/types/excalidraw/components/canvases/InteractiveCanvas.d.ts +6 -3
  144. package/dist/types/excalidraw/components/dropdownMenu/DropdownMenu.d.ts +30 -32
  145. package/dist/types/excalidraw/components/dropdownMenu/DropdownMenuContent.d.ts +6 -5
  146. package/dist/types/excalidraw/components/dropdownMenu/DropdownMenuGroup.d.ts +3 -3
  147. package/dist/types/excalidraw/components/dropdownMenu/DropdownMenuItem.d.ts +10 -18
  148. package/dist/types/excalidraw/components/dropdownMenu/DropdownMenuItemContent.d.ts +3 -3
  149. package/dist/types/excalidraw/components/dropdownMenu/DropdownMenuItemContentRadio.d.ts +0 -1
  150. package/dist/types/excalidraw/components/dropdownMenu/DropdownMenuItemCustom.d.ts +2 -2
  151. package/dist/types/excalidraw/components/dropdownMenu/DropdownMenuItemLink.d.ts +6 -6
  152. package/dist/types/excalidraw/components/dropdownMenu/DropdownMenuTrigger.d.ts +3 -4
  153. package/dist/types/excalidraw/components/dropdownMenu/common.d.ts +1 -1
  154. package/dist/types/excalidraw/components/hoc/withInternalFallback.d.ts +1 -1
  155. package/dist/types/excalidraw/components/hyperlink/helpers.d.ts +1 -1
  156. package/dist/types/excalidraw/components/icons.d.ts +21 -11
  157. package/dist/types/excalidraw/components/live-collaboration/LiveCollaborationTrigger.d.ts +4 -3
  158. package/dist/types/excalidraw/components/main-menu/DefaultItems.d.ts +2 -2
  159. package/dist/types/excalidraw/components/main-menu/MainMenu.d.ts +25 -30
  160. package/dist/types/excalidraw/components/shapes.d.ts +1 -1
  161. package/dist/types/excalidraw/components/welcome-screen/WelcomeScreen.Center.d.ts +6 -6
  162. package/dist/types/excalidraw/components/welcome-screen/WelcomeScreen.d.ts +15 -16
  163. package/dist/types/excalidraw/data/blob.d.ts +323 -5
  164. package/dist/types/excalidraw/data/encode.d.ts +4 -4
  165. package/dist/types/excalidraw/data/encryption.d.ts +5 -5
  166. package/dist/types/excalidraw/data/filesystem.d.ts +2 -2
  167. package/dist/types/excalidraw/data/index.d.ts +3 -3
  168. package/dist/types/excalidraw/data/json.d.ts +159 -2
  169. package/dist/types/excalidraw/data/library.d.ts +24 -9
  170. package/dist/types/excalidraw/data/restore.d.ts +25 -10
  171. package/dist/types/excalidraw/data/types.d.ts +4 -1
  172. package/dist/types/excalidraw/editor-jotai.d.ts +11 -11
  173. package/dist/types/excalidraw/hooks/useLibraryItemSvg.d.ts +1 -1
  174. package/dist/types/excalidraw/hooks/useOutsideClick.d.ts +4 -3
  175. package/dist/types/excalidraw/hooks/useScrollPosition.d.ts +1 -2
  176. package/dist/types/excalidraw/hooks/useTextEditorFocus.d.ts +14 -0
  177. package/dist/types/excalidraw/i18n.d.ts +2 -2
  178. package/dist/types/excalidraw/index.d.ts +4 -7
  179. package/dist/types/excalidraw/renderer/animation.d.ts +12 -0
  180. package/dist/types/excalidraw/renderer/helpers.d.ts +6 -8
  181. package/dist/types/excalidraw/renderer/interactiveScene.d.ts +8 -14
  182. package/dist/types/excalidraw/scene/Renderer.d.ts +5 -2
  183. package/dist/types/excalidraw/scene/export.d.ts +2 -2
  184. package/dist/types/excalidraw/scene/scroll.d.ts +1 -6
  185. package/dist/types/excalidraw/scene/types.d.ts +22 -5
  186. package/dist/types/excalidraw/shortcut.d.ts +1 -0
  187. package/dist/types/excalidraw/snapping.d.ts +5 -5
  188. package/dist/types/excalidraw/subset/harfbuzz/harfbuzz-bindings.d.ts +1 -1
  189. package/dist/types/excalidraw/subset/harfbuzz/harfbuzz-loader.d.ts +1 -1
  190. package/dist/types/excalidraw/subset/harfbuzz/harfbuzz-wasm.d.ts +1 -1
  191. package/dist/types/excalidraw/subset/woff2/woff2-loader.d.ts +2 -2
  192. package/dist/types/excalidraw/subset/woff2/woff2-wasm.d.ts +1 -1
  193. package/dist/types/excalidraw/types.d.ts +31 -21
  194. package/dist/types/excalidraw/wysiwyg/textWysiwyg.d.ts +2 -2
  195. package/dist/types/math/src/polygon.d.ts +2 -2
  196. package/dist/types/math/src/range.d.ts +1 -3
  197. package/dist/types/math/src/segment.d.ts +4 -3
  198. package/dist/types/utils/src/bbox.d.ts +1 -1
  199. package/dist/types/utils/src/export.d.ts +5 -5
  200. package/dist/types/utils/src/shape.d.ts +6 -6
  201. package/dist/types/utils/src/withinBounds.d.ts +2 -2
  202. package/package.json +7 -1
@@ -1,14 +1,14 @@
1
- import type { ExcalidrawBindableElement, FontFamilyValues, FontString } from "@excalidraw/element/types";
1
+ import type { FontFamilyValues, FontString } from "@excalidraw/element/types";
2
2
  import type { ActiveTool, AppState, ToolType, UnsubscribeCallback, Zoom } from "@excalidraw/excalidraw/types";
3
- import type { MaybePromise } from "./utility-types";
3
+ import type { MaybePromise, ResolutionType } from "./utility-types";
4
4
  import type { EVENT } from "./constants";
5
5
  export declare const setDateTimeForTests: (dateTime: string) => void;
6
6
  export declare const getDateTime: () => string;
7
7
  export declare const capitalizeString: (str: string) => string;
8
8
  export declare const isToolIcon: (target: Element | EventTarget | null) => target is HTMLElement;
9
- export declare const isInputLike: (target: Element | EventTarget | null) => target is HTMLBRElement | HTMLDivElement | HTMLInputElement | HTMLSelectElement | HTMLTextAreaElement;
9
+ export declare const isInputLike: (target: Element | EventTarget | null) => target is HTMLInputElement | HTMLTextAreaElement | HTMLSelectElement | HTMLBRElement | HTMLDivElement;
10
10
  export declare const isInteractive: (target: Element | EventTarget | null) => boolean;
11
- export declare const isWritableElement: (target: Element | EventTarget | null) => target is HTMLBRElement | HTMLDivElement | HTMLInputElement | HTMLTextAreaElement;
11
+ export declare const isWritableElement: (target: Element | EventTarget | null) => target is HTMLInputElement | HTMLTextAreaElement | HTMLBRElement | HTMLDivElement;
12
12
  export declare const getFontFamilyString: ({ fontFamily, }: {
13
13
  fontFamily: FontFamilyValues;
14
14
  }) => string;
@@ -17,6 +17,8 @@ export declare const getFontString: ({ fontSize, fontFamily, }: {
17
17
  fontSize: number;
18
18
  fontFamily: FontFamilyValues;
19
19
  }) => FontString;
20
+ /** executes callback in the frame that's after the current one */
21
+ export declare const nextAnimationFrame: (cb: () => any) => Promise<void>;
20
22
  export declare const debounce: <T extends any[]>(fn: (...args: T) => void, timeout: number) => {
21
23
  (...args: T): void;
22
24
  flush(): void;
@@ -69,17 +71,20 @@ export declare const easeToValuesRAF: <T extends Record<keyof T, number>, K exte
69
71
  * Interpolate a single value.
70
72
  * Return undefined to be handled by the default interpolator.
71
73
  */
72
- interpolateValue?: ((fromValue: number, toValue: number, progress: number, key: K) => number | undefined) | undefined;
74
+ interpolateValue?: (fromValue: number, toValue: number,
75
+ /** no easing applied */
76
+ progress: number, key: K) => number | undefined;
73
77
  onStep: (values: T) => void;
74
- duration?: number | undefined;
75
- onStart?: (() => void) | undefined;
76
- onEnd?: (() => void) | undefined;
77
- onCancel?: (() => void) | undefined;
78
+ duration?: number;
79
+ onStart?: () => void;
80
+ onEnd?: () => void;
81
+ onCancel?: () => void;
78
82
  }) => () => void;
79
- export declare const chunk: <T extends unknown>(array: readonly T[], size: number) => T[][];
83
+ export declare const chunk: <T extends any>(array: readonly T[], size: number) => T[][];
80
84
  export declare const selectNode: (node: Element) => void;
81
85
  export declare const removeSelection: () => void;
82
86
  export declare const distance: (x: number, y: number) => number;
87
+ export declare const isSelectionLikeTool: (type: ToolType | "custom") => type is "selection" | "lasso";
83
88
  export declare const updateActiveTool: (appState: Pick<AppState, "activeTool">, data: (({
84
89
  type: ToolType;
85
90
  } | {
@@ -94,7 +99,6 @@ export declare const updateActiveTool: (appState: Pick<AppState, "activeTool">,
94
99
  export declare const isFullScreen: () => boolean;
95
100
  export declare const allowFullScreen: () => Promise<void>;
96
101
  export declare const exitFullScreen: () => Promise<void>;
97
- export declare const getShortcutKey: (shortcut: string) => string;
98
102
  export declare const viewportCoordsToSceneCoords: ({ clientX, clientY }: {
99
103
  clientX: number;
100
104
  clientY: number;
@@ -138,9 +142,8 @@ export declare const muteFSAbortError: (error?: Error) => void;
138
142
  export declare const findIndex: <T>(array: readonly T[], cb: (element: T, index: number, array: readonly T[]) => boolean, fromIndex?: number) => number;
139
143
  export declare const findLastIndex: <T>(array: readonly T[], cb: (element: T, index: number, array: readonly T[]) => boolean, fromIndex?: number) => number;
140
144
  /** returns the first non-null mapped value */
141
- export declare const mapFind: <T, K>(collection: readonly T[], iteratee: (value: T, index: number) => K | null | undefined) => K | undefined;
145
+ export declare const mapFind: <T, K>(collection: readonly T[], iteratee: (value: T, index: number) => K | undefined | null) => K | undefined;
142
146
  export declare const isTransparent: (color: string) => boolean;
143
- export declare const isBindingFallthroughEnabled: (el: ExcalidrawBindableElement) => boolean;
144
147
  export type ResolvablePromise<T> = Promise<T> & {
145
148
  resolve: [T] extends [undefined] ? (value?: MaybePromise<Awaited<T>>) => void : (value: MaybePromise<Awaited<T>>) => void;
146
149
  reject: (error: Error) => void;
@@ -158,16 +161,16 @@ export declare const getUpdatedTimestamp: () => number;
158
161
  * Transforms array of objects containing `id` attribute,
159
162
  * or array of ids (strings), into a Map, keyd by `id`.
160
163
  */
161
- export declare const arrayToMap: <T extends string | {
164
+ export declare const arrayToMap: <T extends {
162
165
  id: string;
163
- }>(items: Map<string, T> | readonly T[]) => Map<string, T>;
166
+ } | string>(items: readonly T[] | Map<string, T>) => Map<string, T>;
164
167
  export declare const arrayToMapWithIndex: <T extends {
165
168
  id: string;
166
169
  }>(elements: readonly T[]) => Map<string, [element: T, index: number]>;
167
170
  /**
168
171
  * Transform array into an object, use only when array order is irrelevant.
169
172
  */
170
- export declare const arrayToObject: <T>(array: readonly T[], groupBy?: ((value: T) => string | number) | undefined) => {
173
+ export declare const arrayToObject: <T>(array: readonly T[], groupBy?: (value: T) => string | number) => {
171
174
  [key: string]: T;
172
175
  };
173
176
  /** Doubly linked node */
@@ -183,11 +186,11 @@ export declare const arrayToList: <T>(array: readonly T[]) => Node<T>[];
183
186
  * Converts a readonly array or map into an iterable.
184
187
  * Useful for avoiding entry allocations when iterating object / map on each iteration.
185
188
  */
186
- export declare const toIterable: <T>(values: ReadonlyMap<string, T> | readonly T[]) => Iterable<T>;
189
+ export declare const toIterable: <T>(values: readonly T[] | ReadonlyMap<string, T>) => Iterable<T>;
187
190
  /**
188
191
  * Converts a readonly array or map into an array.
189
192
  */
190
- export declare const toArray: <T>(values: ReadonlyMap<string, T> | readonly T[]) => T[];
193
+ export declare const toArray: <T>(values: readonly T[] | ReadonlyMap<string, T>) => T[];
191
194
  export declare const isTestEnv: () => boolean;
192
195
  export declare const isDevEnv: () => boolean;
193
196
  export declare const isProdEnv: () => boolean;
@@ -197,20 +200,20 @@ export declare const wrapEvent: <T extends Event>(name: EVENT, nativeEvent: T) =
197
200
  }>;
198
201
  export declare const updateObject: <T extends Record<string, any>>(obj: T, updates: Partial<T>) => T;
199
202
  export declare const isPrimitive: (val: any) => boolean;
200
- export declare const getFrame: () => "iframe" | "top";
203
+ export declare const getFrame: () => "top" | "iframe";
201
204
  export declare const isRunningInIframe: () => boolean;
202
- export declare const isPromiseLike: (value: any) => value is Promise<any>;
205
+ export declare const isPromiseLike: (value: any) => value is Promise<ResolutionType<typeof value>>;
203
206
  export declare const queryFocusableElements: (container: HTMLElement | null) => HTMLElement[];
204
207
  /**
205
208
  * Returns whether object/array is shallow equal.
206
209
  * Considers empty object/arrays as equal (whether top-level or second-level).
207
210
  */
208
- export declare const isShallowEqual: <T extends Record<string, any>, K extends readonly unknown[]>(objA: T, objB: T, comparators?: { [key in keyof T]?: ((a: T[key], b: T[key]) => boolean) | undefined; } | (keyof T extends K[number] ? K extends readonly (keyof T)[] ? K : {
211
+ export declare const isShallowEqual: <T extends Record<string, any>, K extends readonly unknown[]>(objA: T, objB: T, comparators?: { [key in keyof T]?: (a: T[key], b: T[key]) => boolean; } | (keyof T extends K[number] ? K extends readonly (keyof T)[] ? K : {
209
212
  _error: "keys are either missing or include keys not in compared obj";
210
213
  } : {
211
214
  _error: "keys are either missing or include keys not in compared obj";
212
- }) | undefined, debug?: boolean) => boolean;
213
- export declare const composeEventHandlers: <E>(originalEventHandler?: ((event: E) => void) | undefined, ourEventHandler?: ((event: E) => void) | undefined, { checkForDefaultPrevented }?: {
215
+ }), debug?: boolean) => boolean;
216
+ export declare const composeEventHandlers: <E>(originalEventHandler?: (event: E) => void, ourEventHandler?: (event: E) => void, { checkForDefaultPrevented }?: {
214
217
  checkForDefaultPrevented?: boolean | undefined;
215
218
  }) => (event: E) => void;
216
219
  /**
@@ -222,11 +225,15 @@ export declare function invariant(condition: any, message: string): asserts cond
222
225
  /**
223
226
  * Memoizes on values of `opts` object (strict equality).
224
227
  */
225
- export declare const memoize: <T extends Record<string, any>, R extends unknown>(func: (opts: T) => R) => ((opts: T) => R) & {
228
+ export declare const memoize: <T extends Record<string, any>, R extends any>(func: (opts: T) => R) => typeof func & {
226
229
  clear: () => void;
227
230
  };
228
231
  /** Checks if value is inside given collection. Useful for type-safety. */
229
- export declare const isMemberOf: <T extends string>(collection: Set<T> | Record<T, any> | Map<T, any> | readonly T[], value: string) => value is T;
232
+ export declare const isMemberOf: <T extends string>(
233
+ /** Set/Map/Array/Object */
234
+ collection: Set<T> | readonly T[] | Record<T, any> | Map<T, any>,
235
+ /** value to look for */
236
+ value: string) => value is T;
230
237
  export declare const cloneJSON: <T>(obj: T) => T;
231
238
  export declare const updateStable: <T extends any[] | Record<string, any>>(prevValue: T, nextValue: T) => T;
232
239
  export declare function addEventListener<K extends keyof WindowEventMap>(target: Window & typeof globalThis, type: K, listener: (this: Window, ev: WindowEventMap[K]) => any, options?: boolean | AddEventListenerOptions): UnsubscribeCallback;
@@ -237,21 +244,25 @@ export declare function addEventListener<K extends keyof FontFaceSetEventMap>(ta
237
244
  export declare function addEventListener<K extends keyof HTMLElementEventMap>(target: Document | (Window & typeof globalThis) | HTMLElement | undefined | null | false, type: K, listener: (this: HTMLDivElement, ev: HTMLElementEventMap[K]) => any, options?: boolean | AddEventListenerOptions): UnsubscribeCallback;
238
245
  export declare function getSvgPathFromStroke(points: number[][], closed?: boolean): string;
239
246
  export declare const normalizeEOL: (str: string) => string;
240
- type HasBrand<T> = {
241
- [K in keyof T]: K extends `~brand${infer _}` ? true : never;
247
+ export type HasBrand<T> = {
248
+ [K in keyof T]: K extends `~brand${infer _}` | "_brand" ? true : never;
242
249
  }[keyof T];
243
250
  type RemoveAllBrands<T> = HasBrand<T> extends true ? {
244
- [K in keyof T as K extends `~brand~${infer _}` ? never : K]: T[K];
245
- } : never;
246
- type Unbrand<T> = T extends Map<infer E, infer F> ? Map<E, F> : T extends Set<infer E> ? Set<E> : T extends Array<infer E> ? Array<E> : RemoveAllBrands<T>;
251
+ [K in keyof T as K extends `~brand~${infer _}` | "_brand" ? never : K]: T[K];
252
+ } : T;
253
+ type UnbrandForValue<T> = T extends Map<infer E, infer F> ? Map<UnbrandForValue<E>, UnbrandForValue<F>> : T extends Set<infer E> ? Set<UnbrandForValue<E>> : T extends readonly any[] ? T extends any[] ? unknown[] : readonly unknown[] : RemoveAllBrands<T>;
254
+ export type Unbrand<T> = T extends Map<infer E, infer F> ? Map<Unbrand<E>, Unbrand<F>> : T extends Set<infer E> ? Set<Unbrand<E>> : T extends readonly (infer E)[] ? Array<Unbrand<E>> : RemoveAllBrands<T>;
255
+ export type CombineBrands<BrandedType, CurrentType> = BrandedType extends readonly (infer BE)[] ? CurrentType extends readonly (infer CE)[] ? Array<CE & BE> : CurrentType & BrandedType : CurrentType & BrandedType;
256
+ export type CombineBrandsIfNeeded<T, Required> = [T] extends [Required] ? T[] : HasBrand<T> extends true ? CombineBrands<T, Required>[] : Required[];
247
257
  /**
248
258
  * Makes type into a branded type, ensuring that value is assignable to
249
- * the base ubranded type. Optionally you can explicitly supply current value
259
+ * the base unbranded type. Optionally you can explicitly supply current value
250
260
  * type to combine both (useful for composite branded types. Make sure you
251
261
  * compose branded types which are not composite themselves.)
252
262
  */
253
- export declare const toBrandedType: <BrandedType, CurrentType = BrandedType>(value: Unbrand<BrandedType>) => CurrentType & BrandedType;
254
- export declare const promiseTry: <TValue, TArgs extends unknown[]>(fn: (...args: TArgs) => TValue | PromiseLike<TValue>, ...args: TArgs) => Promise<TValue>;
263
+ export declare function toBrandedType<BrandedType>(value: UnbrandForValue<BrandedType>): BrandedType;
264
+ export declare function toBrandedType<BrandedType, CurrentType>(value: CurrentType): CombineBrands<BrandedType, CurrentType>;
265
+ export declare const promiseTry: <TValue, TArgs extends unknown[]>(fn: (...args: TArgs) => PromiseLike<TValue> | TValue, ...args: TArgs) => Promise<TValue>;
255
266
  export declare const isAnyTrue: (...args: boolean[]) => boolean;
256
267
  export declare const safelyParseJSON: (json: string) => Record<string, any> | null;
257
268
  /**
@@ -263,5 +274,10 @@ export declare const castArray: <T>(value: T | T[]) => T[];
263
274
  /** hack for Array.isArray type guard not working with readonly value[] */
264
275
  export declare const isReadonlyArray: (value?: any) => value is readonly any[];
265
276
  export declare const sizeOf: (value: readonly unknown[] | Readonly<Map<string, unknown>> | Readonly<Record<string, unknown>> | ReadonlySet<unknown>) => number;
266
- export declare const reduceToCommonValue: <T, R = T>(collection: ReadonlySet<T> | readonly T[], getValue?: ((item: T) => R) | undefined) => R | null;
277
+ export declare const reduceToCommonValue: <T, R = T>(collection: readonly T[] | ReadonlySet<T>, getValue?: (item: T) => R) => R | null;
278
+ type FEATURE_FLAGS = {
279
+ COMPLEX_BINDINGS: boolean;
280
+ };
281
+ export declare const getFeatureFlag: <F extends keyof FEATURE_FLAGS>(flag: F) => FEATURE_FLAGS[F];
282
+ export declare const setFeatureFlag: <F extends keyof FEATURE_FLAGS>(flag: F, value: FEATURE_FLAGS[F]) => void;
267
283
  export {};
@@ -0,0 +1,41 @@
1
+ import { type GlobalPoint, type LocalPoint } from "@excalidraw/math";
2
+ import type { Curve } from "@excalidraw/math";
3
+ import type { LineSegment } from "@excalidraw/utils";
4
+ import { type Bounds } from "./bounds";
5
+ declare global {
6
+ interface Window {
7
+ visualDebug?: {
8
+ data: DebugElement[][];
9
+ currentFrame?: number;
10
+ };
11
+ }
12
+ }
13
+ export type DebugElement = {
14
+ color: string;
15
+ data: LineSegment<GlobalPoint> | Curve<GlobalPoint>;
16
+ permanent: boolean;
17
+ };
18
+ export declare const debugDrawCubicBezier: (c: Curve<GlobalPoint>, opts?: {
19
+ color?: string;
20
+ permanent?: boolean;
21
+ }) => void;
22
+ export declare const debugDrawLine: (segment: LineSegment<GlobalPoint> | LineSegment<GlobalPoint>[], opts?: {
23
+ color?: string;
24
+ permanent?: boolean;
25
+ }) => void;
26
+ export declare const debugDrawPoint: (p: GlobalPoint, opts?: {
27
+ color?: string;
28
+ permanent?: boolean;
29
+ fuzzy?: boolean;
30
+ }) => void;
31
+ export declare const debugDrawBounds: (box: Bounds | Bounds[], opts?: {
32
+ color?: string;
33
+ permanent?: boolean;
34
+ }) => void;
35
+ export declare const debugDrawPoints: ({ x, y, points, }: {
36
+ x: number;
37
+ y: number;
38
+ points: readonly LocalPoint[];
39
+ }, options?: any) => void;
40
+ export declare const debugCloseFrame: () => void;
41
+ export declare const debugClear: () => void;
@@ -1,5 +1,5 @@
1
1
  import { type ElementUpdate } from "@excalidraw/element";
2
- import type { ExcalidrawElement, NonDeletedExcalidrawElement, NonDeleted, ExcalidrawFrameLikeElement, ElementsMapOrArray, OrderedExcalidrawElement, Ordered } from "@excalidraw/element/types";
2
+ import type { ExcalidrawElement, NonDeletedExcalidrawElement, NonDeleted, ExcalidrawFrameLikeElement, ElementsMapOrArray, SceneElementsMap, NonDeletedSceneElementsMap, OrderedExcalidrawElement, Ordered } from "@excalidraw/element/types";
3
3
  import type { Mutable } from "@excalidraw/common/utility-types";
4
4
  import type { AppState } from "../../excalidraw/types";
5
5
  type SceneStateCallback = () => void;
@@ -22,9 +22,9 @@ export declare class Scene {
22
22
  */
23
23
  private sceneNonce;
24
24
  getSceneNonce(): number | undefined;
25
- getNonDeletedElementsMap(): Map<string, Ordered<NonDeletedExcalidrawElement>> & import("@excalidraw/common/utility-types").MakeBrand<"NonDeletedSceneElementsMap">;
25
+ getNonDeletedElementsMap(): NonDeletedSceneElementsMap;
26
26
  getElementsIncludingDeleted(): readonly OrderedExcalidrawElement[];
27
- getElementsMapIncludingDeleted(): Map<string, Ordered<ExcalidrawElement>> & import("@excalidraw/common/utility-types").MakeBrand<"SceneElementsMap">;
27
+ getElementsMapIncludingDeleted(): SceneElementsMap;
28
28
  getNonDeletedElements(): readonly Ordered<NonDeletedExcalidrawElement>[];
29
29
  getFramesIncludingDeleted(): readonly ExcalidrawFrameLikeElement[];
30
30
  constructor(elements?: ElementsMapOrArray | null, options?: {
@@ -70,7 +70,7 @@ export declare class Scene {
70
70
  getElementIndex(elementId: string): number;
71
71
  getContainerElement: (element: (ExcalidrawElement & {
72
72
  containerId: ExcalidrawElement["id"] | null;
73
- }) | null) => import("@excalidraw/element/types").ExcalidrawTextElement | import("@excalidraw/element/types").ExcalidrawRectangleElement | import("@excalidraw/element/types").ExcalidrawDiamondElement | import("@excalidraw/element/types").ExcalidrawFrameElement | import("@excalidraw/element/types").ExcalidrawMagicFrameElement | import("@excalidraw/element/types").ExcalidrawEmbeddableElement | import("@excalidraw/element/types").ExcalidrawImageElement | import("@excalidraw/element/types").ExcalidrawIframeElement | import("@excalidraw/element/types").ExcalidrawSelectionElement | import("@excalidraw/element/types").ExcalidrawEllipseElement | import("@excalidraw/element/types").ExcalidrawLinearElement | import("@excalidraw/element/types").ExcalidrawFreeDrawElement | null;
73
+ }) | null) => import("@excalidraw/element/types").ExcalidrawLinearElement | import("@excalidraw/element/types").ExcalidrawSelectionElement | import("@excalidraw/element/types").ExcalidrawRectangleElement | import("@excalidraw/element/types").ExcalidrawDiamondElement | import("@excalidraw/element/types").ExcalidrawEllipseElement | import("@excalidraw/element/types").ExcalidrawEmbeddableElement | import("@excalidraw/element/types").ExcalidrawIframeElement | import("@excalidraw/element/types").ExcalidrawImageElement | import("@excalidraw/element/types").ExcalidrawFrameElement | import("@excalidraw/element/types").ExcalidrawMagicFrameElement | import("@excalidraw/element/types").ExcalidrawTextElement | import("@excalidraw/element/types").ExcalidrawFreeDrawElement | null;
74
74
  getElementsFromId: (id: string) => ExcalidrawElement[];
75
75
  mutateElement<TElement extends Mutable<ExcalidrawElement>>(element: TElement, updates: ElementUpdate<TElement>, options?: {
76
76
  informMutation: boolean;
@@ -1,68 +1,81 @@
1
1
  import { type GlobalPoint } from "@excalidraw/math";
2
- import type { LocalPoint } from "@excalidraw/math";
2
+ import type { LineSegment, LocalPoint } from "@excalidraw/math";
3
3
  import type { AppState } from "@excalidraw/excalidraw/types";
4
+ import type { Bounds } from "@excalidraw/common";
4
5
  import { type Heading } from "./heading";
5
6
  import type { Scene } from "./Scene";
6
- import type { Bounds } from "./bounds";
7
7
  import type { ElementUpdate } from "./mutateElement";
8
- import type { ExcalidrawBindableElement, ExcalidrawElement, NonDeleted, ExcalidrawLinearElement, NonDeletedExcalidrawElement, ElementsMap, NonDeletedSceneElementsMap, ExcalidrawElbowArrowElement, FixedPoint } from "./types";
9
- export type SuggestedBinding = NonDeleted<ExcalidrawBindableElement> | SuggestedPointBinding;
10
- export type SuggestedPointBinding = [
11
- NonDeleted<ExcalidrawLinearElement>,
12
- "start" | "end" | "both",
13
- NonDeleted<ExcalidrawBindableElement>
14
- ];
8
+ import type { BindMode, ElementsMap, ExcalidrawArrowElement, ExcalidrawBindableElement, ExcalidrawElbowArrowElement, ExcalidrawElement, FixedPoint, FixedPointBinding, NonDeleted, NonDeletedExcalidrawElement, NonDeletedSceneElementsMap, Ordered, PointsPositionUpdates } from "./types";
9
+ export type BindingStrategy = {
10
+ mode: BindMode;
11
+ element: NonDeleted<ExcalidrawBindableElement>;
12
+ focusPoint: GlobalPoint;
13
+ } | {
14
+ mode: null;
15
+ element?: undefined;
16
+ focusPoint?: undefined;
17
+ } | {
18
+ mode: undefined;
19
+ element?: undefined;
20
+ focusPoint?: undefined;
21
+ };
22
+ /**
23
+ * gaps exclude element strokeWidth
24
+ *
25
+ * IMPORTANT: currently must be > 0 (this also applies to the computed gap)
26
+ */
27
+ export declare const BASE_BINDING_GAP = 10;
28
+ export declare const BASE_BINDING_GAP_ELBOW = 5;
29
+ export declare const getBindingGap: (bindTarget: ExcalidrawBindableElement, opts: Pick<ExcalidrawArrowElement, "elbowed">) => number;
30
+ export declare const maxBindingDistance_simple: (zoom?: AppState["zoom"]) => number;
15
31
  export declare const shouldEnableBindingForPointerEvent: (event: React.PointerEvent<HTMLElement>) => boolean;
16
32
  export declare const isBindingEnabled: (appState: AppState) => boolean;
17
- export declare const FIXED_BINDING_DISTANCE = 5;
18
- export declare const BINDING_HIGHLIGHT_THICKNESS = 10;
19
- export declare const bindOrUnbindLinearElement: (linearElement: NonDeleted<ExcalidrawLinearElement>, startBindingElement: ExcalidrawBindableElement | null | "keep", endBindingElement: ExcalidrawBindableElement | null | "keep", scene: Scene) => void;
20
- export declare const bindOrUnbindLinearElements: (selectedElements: NonDeleted<ExcalidrawLinearElement>[], isBindingEnabled: boolean, draggingPoints: readonly number[] | null, scene: Scene, zoom?: AppState["zoom"]) => void;
21
- export declare const getSuggestedBindingsForArrows: (selectedElements: NonDeleted<ExcalidrawElement>[], elementsMap: NonDeletedSceneElementsMap, zoom: AppState["zoom"]) => SuggestedBinding[];
22
- export declare const maybeSuggestBindingsForLinearElementAtCoords: (linearElement: NonDeleted<ExcalidrawLinearElement>, pointerCoords: {
23
- x: number;
24
- y: number;
25
- }[], scene: Scene, zoom: AppState["zoom"], oppositeBindingBoundElement?: ExcalidrawBindableElement | null) => ExcalidrawBindableElement[];
26
- export declare const maybeBindLinearElement: (linearElement: NonDeleted<ExcalidrawLinearElement>, appState: AppState, pointerCoords: {
27
- x: number;
28
- y: number;
29
- }, scene: Scene) => void;
30
- export declare const bindLinearElement: (linearElement: NonDeleted<ExcalidrawLinearElement>, hoveredElement: ExcalidrawBindableElement, startOrEnd: "start" | "end", scene: Scene) => void;
31
- export declare const isLinearElementSimpleAndAlreadyBound: (linearElement: NonDeleted<ExcalidrawLinearElement>, alreadyBoundToId: ExcalidrawBindableElement["id"] | undefined, bindableElement: ExcalidrawBindableElement) => boolean;
32
- export declare const getHoveredElementForBinding: (pointerCoords: {
33
- x: number;
34
- y: number;
35
- }, elements: readonly NonDeletedExcalidrawElement[], elementsMap: NonDeletedSceneElementsMap, zoom?: AppState["zoom"], fullShape?: boolean, considerAllElements?: boolean) => NonDeleted<ExcalidrawBindableElement> | null;
33
+ export declare const bindOrUnbindBindingElement: (arrow: NonDeleted<ExcalidrawArrowElement>, draggingPoints: PointsPositionUpdates, scenePointerX: number, scenePointerY: number, scene: Scene, appState: AppState, opts?: {
34
+ newArrow?: boolean;
35
+ altKey?: boolean;
36
+ angleLocked?: boolean;
37
+ initialBinding?: boolean;
38
+ }) => {
39
+ start: BindingStrategy;
40
+ end: BindingStrategy;
41
+ };
42
+ export declare const getBindingStrategyForDraggingBindingElementEndpoints: (arrow: NonDeleted<ExcalidrawArrowElement>, draggingPoints: PointsPositionUpdates, screenPointerX: number, screenPointerY: number, elementsMap: NonDeletedSceneElementsMap, elements: readonly Ordered<NonDeletedExcalidrawElement>[], appState: AppState, opts?: {
43
+ newArrow?: boolean;
44
+ angleLocked?: boolean;
45
+ altKey?: boolean;
46
+ finalize?: boolean;
47
+ initialBinding?: boolean;
48
+ zoom?: AppState["zoom"];
49
+ }) => {
50
+ start: BindingStrategy;
51
+ end: BindingStrategy;
52
+ };
53
+ export declare const bindOrUnbindBindingElements: (selectedArrows: NonDeleted<ExcalidrawArrowElement>[], scene: Scene, appState: AppState) => void;
54
+ export declare const bindBindingElement: (arrow: NonDeleted<ExcalidrawArrowElement>, hoveredElement: ExcalidrawBindableElement, mode: BindMode, startOrEnd: "start" | "end", scene: Scene, focusPoint?: GlobalPoint) => void;
55
+ export declare const unbindBindingElement: (arrow: NonDeleted<ExcalidrawArrowElement>, startOrEnd: "start" | "end", scene: Scene) => ExcalidrawBindableElement["id"] | null;
36
56
  export declare const updateBoundElements: (changedElement: NonDeletedExcalidrawElement, scene: Scene, options?: {
37
57
  simultaneouslyUpdated?: readonly ExcalidrawElement[];
38
- newSize?: {
39
- width: number;
40
- height: number;
41
- };
42
58
  changedElements?: Map<string, ExcalidrawElement>;
43
59
  }) => void;
44
- export declare const updateBindings: (latestElement: ExcalidrawElement, scene: Scene, options?: {
60
+ export declare const updateBindings: (latestElement: ExcalidrawElement, scene: Scene, appState: AppState, options?: {
45
61
  simultaneouslyUpdated?: readonly ExcalidrawElement[];
46
62
  newSize?: {
47
63
  width: number;
48
64
  height: number;
49
65
  };
50
- zoom?: AppState["zoom"];
51
66
  }) => void;
52
67
  export declare const getHeadingForElbowArrowSnap: (p: Readonly<GlobalPoint>, otherPoint: Readonly<GlobalPoint>, bindableElement: ExcalidrawBindableElement | undefined | null, aabb: Bounds | undefined | null, origPoint: GlobalPoint, elementsMap: ElementsMap, zoom?: AppState["zoom"]) => Heading;
53
- export declare const bindPointToSnapToElementOutline: (arrow: ExcalidrawElbowArrowElement, bindableElement: ExcalidrawBindableElement, startOrEnd: "start" | "end", elementsMap: ElementsMap) => GlobalPoint;
54
- export declare const avoidRectangularCorner: (element: ExcalidrawBindableElement, elementsMap: ElementsMap, p: GlobalPoint) => GlobalPoint;
55
- export declare const snapToMid: (element: ExcalidrawBindableElement, elementsMap: ElementsMap, p: GlobalPoint, tolerance?: number) => GlobalPoint;
68
+ export declare const bindPointToSnapToElementOutline: (arrowElement: ExcalidrawArrowElement, bindableElement: ExcalidrawBindableElement, startOrEnd: "start" | "end", elementsMap: ElementsMap, customIntersector?: LineSegment<GlobalPoint>) => GlobalPoint;
69
+ export declare const avoidRectangularCorner: (arrowElement: ExcalidrawArrowElement, bindTarget: ExcalidrawBindableElement, elementsMap: ElementsMap, p: GlobalPoint) => GlobalPoint;
70
+ export declare const updateBoundPoint: (arrow: NonDeleted<ExcalidrawArrowElement>, startOrEnd: "startBinding" | "endBinding", binding: FixedPointBinding | null | undefined, bindableElement: ExcalidrawBindableElement, elementsMap: ElementsMap, customIntersector?: LineSegment<GlobalPoint>) => LocalPoint | null;
56
71
  export declare const calculateFixedPointForElbowArrowBinding: (linearElement: NonDeleted<ExcalidrawElbowArrowElement>, hoveredElement: ExcalidrawBindableElement, startOrEnd: "start" | "end", elementsMap: ElementsMap) => {
57
72
  fixedPoint: FixedPoint;
58
73
  };
74
+ export declare const calculateFixedPointForNonElbowArrowBinding: (linearElement: NonDeleted<ExcalidrawArrowElement>, hoveredElement: ExcalidrawBindableElement, startOrEnd: "start" | "end", elementsMap: ElementsMap, focusPoint?: GlobalPoint) => {
75
+ fixedPoint: FixedPoint;
76
+ };
59
77
  export declare const fixDuplicatedBindingsAfterDuplication: (duplicatedElements: ExcalidrawElement[], origIdToDuplicateId: Map<ExcalidrawElement["id"], ExcalidrawElement["id"]>, duplicateElementsMap: NonDeletedSceneElementsMap) => void;
60
78
  export declare const fixBindingsAfterDeletion: (sceneElements: readonly ExcalidrawElement[], deletedElements: readonly ExcalidrawElement[]) => void;
61
- export declare const bindingBorderTest: (element: NonDeleted<ExcalidrawBindableElement>, { x, y }: {
62
- x: number;
63
- y: number;
64
- }, elementsMap: NonDeletedSceneElementsMap, zoom?: AppState["zoom"], fullShape?: boolean) => boolean;
65
- export declare const maxBindingGap: (element: ExcalidrawElement, elementWidth: number, elementHeight: number, zoom?: AppState["zoom"]) => number;
66
79
  export declare const bindingProperties: Set<BindableProp | BindingProp>;
67
80
  export type BindableProp = "boundElements";
68
81
  export type BindingProp = "frameId" | "containerId" | "startBinding" | "endBinding";
@@ -104,7 +117,8 @@ export declare class BindableElement {
104
117
  */
105
118
  static rebindAffected: (elements: ElementsMap, bindableElement: ExcalidrawElement | undefined, updateElementWith: (affected: ExcalidrawElement, updates: ElementUpdate<ExcalidrawElement>) => void) => void;
106
119
  }
107
- export declare const getGlobalFixedPointForBindableElement: (fixedPointRatio: [number, number], element: ExcalidrawBindableElement, elementsMap: ElementsMap) => GlobalPoint;
108
- export declare const getGlobalFixedPoints: (arrow: ExcalidrawElbowArrowElement, elementsMap: ElementsMap) => [GlobalPoint, GlobalPoint];
120
+ export declare const getGlobalFixedPointForBindableElement: (fixedPointRatio: FixedPoint, element: ExcalidrawBindableElement, elementsMap: ElementsMap) => GlobalPoint;
121
+ export declare const getGlobalFixedPoints: (arrow: ExcalidrawArrowElement, elementsMap: ElementsMap) => [GlobalPoint, GlobalPoint];
109
122
  export declare const getArrowLocalFixedPoints: (arrow: ExcalidrawElbowArrowElement, elementsMap: ElementsMap) => LocalPoint[];
110
123
  export declare const normalizeFixedPoint: <T extends FixedPoint | null>(fixedPoint: T) => T extends null ? null : FixedPoint;
124
+ export declare const getBindingSideMidPoint: (binding: FixedPointBinding, elementsMap: ElementsMap) => GlobalPoint | LocalPoint | null;
@@ -1,3 +1,4 @@
1
+ import { type Bounds } from "@excalidraw/common";
1
2
  import type { Degrees, GlobalPoint, LineSegment, LocalPoint } from "@excalidraw/math";
2
3
  import type { AppState } from "@excalidraw/excalidraw/types";
3
4
  import type { Drawable, Op } from "roughjs/bin/core";
@@ -9,15 +10,6 @@ export type RectangleBox = {
9
10
  height: number;
10
11
  angle: number;
11
12
  };
12
- /**
13
- * x and y position of top left corner, x and y position of bottom right corner
14
- */
15
- export type Bounds = readonly [
16
- minX: number,
17
- minY: number,
18
- maxX: number,
19
- maxY: number
20
- ];
21
13
  export type SceneBounds = readonly [
22
14
  sceneX: number,
23
15
  sceneY: number,
@@ -45,7 +37,7 @@ export declare const getElementLineSegments: (element: ExcalidrawElement, elemen
45
37
  export declare const getRectangleBoxAbsoluteCoords: (boxSceneCoords: RectangleBox) => number[];
46
38
  export declare const getDiamondPoints: (element: ExcalidrawElement) => number[];
47
39
  export declare const getCubicBezierCurveBound: (p0: GlobalPoint, p1: GlobalPoint, p2: GlobalPoint, p3: GlobalPoint) => Bounds;
48
- export declare const getMinMaxXYFromCurvePathOps: (ops: Op[], transformXY?: ((p: GlobalPoint) => GlobalPoint) | undefined) => Bounds;
40
+ export declare const getMinMaxXYFromCurvePathOps: (ops: Op[], transformXY?: (p: GlobalPoint) => GlobalPoint) => Bounds;
49
41
  export declare const getBoundsFromPoints: (points: ExcalidrawFreeDrawElement["points"]) => Bounds;
50
42
  /** @returns number in pixels */
51
43
  export declare const getArrowheadSize: (arrowhead: Arrowhead) => number;
@@ -1,6 +1,6 @@
1
1
  import type { GlobalPoint, LineSegment } from "@excalidraw/math";
2
2
  import type { FrameNameBounds } from "@excalidraw/excalidraw/types";
3
- import type { ElementsMap, ExcalidrawElement } from "./types";
3
+ import type { ElementsMap, ExcalidrawBindableElement, ExcalidrawElement, NonDeleted, NonDeletedExcalidrawElement, NonDeletedSceneElementsMap, Ordered } from "./types";
4
4
  export declare const shouldTestInside: (element: ExcalidrawElement) => boolean;
5
5
  export type HitTestArgs = {
6
6
  point: GlobalPoint;
@@ -8,11 +8,14 @@ export type HitTestArgs = {
8
8
  threshold: number;
9
9
  elementsMap: ElementsMap;
10
10
  frameNameBound?: FrameNameBounds | null;
11
+ overrideShouldTestInside?: boolean;
11
12
  };
12
- export declare const hitElementItself: ({ point, element, threshold, elementsMap, frameNameBound, }: HitTestArgs) => boolean;
13
+ export declare const hitElementItself: ({ point, element, threshold, elementsMap, frameNameBound, overrideShouldTestInside, }: HitTestArgs) => boolean;
13
14
  export declare const hitElementBoundingBox: (point: GlobalPoint, element: ExcalidrawElement, elementsMap: ElementsMap, tolerance?: number) => boolean;
14
15
  export declare const hitElementBoundingBoxOnly: (hitArgs: HitTestArgs, elementsMap: ElementsMap) => boolean;
15
16
  export declare const hitElementBoundText: (point: GlobalPoint, element: ExcalidrawElement, elementsMap: ElementsMap) => boolean;
17
+ export declare const getAllHoveredElementAtPoint: (point: Readonly<GlobalPoint>, elements: readonly Ordered<NonDeletedExcalidrawElement>[], elementsMap: NonDeletedSceneElementsMap, toleranceFn?: (element: ExcalidrawBindableElement) => number) => NonDeleted<ExcalidrawBindableElement>[];
18
+ export declare const getHoveredElementForBinding: (point: Readonly<GlobalPoint>, elements: readonly Ordered<NonDeletedExcalidrawElement>[], elementsMap: NonDeletedSceneElementsMap, toleranceFn?: (element: ExcalidrawBindableElement) => number) => NonDeleted<ExcalidrawBindableElement> | null;
16
19
  /**
17
20
  * Intersect a line with an element for binding test
18
21
  *
@@ -30,3 +33,4 @@ export declare const intersectElementWithLineSegment: (element: ExcalidrawElemen
30
33
  * @returns
31
34
  */
32
35
  export declare const isPointInElement: (point: GlobalPoint, element: ExcalidrawElement, elementsMap: ElementsMap) => boolean;
36
+ export declare const isBindableElementInsideOtherBindable: (innerElement: ExcalidrawBindableElement, outerElement: ExcalidrawBindableElement, elementsMap: ElementsMap) => boolean;
@@ -1,8 +1,8 @@
1
1
  import type { ElementOrToolType } from "@excalidraw/excalidraw/types";
2
- export declare const hasBackground: (type: ElementOrToolType) => boolean;
3
- export declare const hasStrokeColor: (type: ElementOrToolType) => boolean;
4
- export declare const hasStrokeWidth: (type: ElementOrToolType) => boolean;
5
- export declare const hasStrokeStyle: (type: ElementOrToolType) => boolean;
6
- export declare const canChangeRoundness: (type: ElementOrToolType) => boolean;
7
- export declare const toolIsArrow: (type: ElementOrToolType) => boolean;
8
- export declare const canHaveArrowheads: (type: ElementOrToolType) => boolean;
2
+ export declare const hasBackground: (type: ElementOrToolType) => type is "line" | "rectangle" | "diamond" | "ellipse" | "embeddable" | "iframe" | "freedraw";
3
+ export declare const hasStrokeColor: (type: ElementOrToolType) => type is "line" | "arrow" | "text" | "rectangle" | "diamond" | "ellipse" | "embeddable" | "freedraw";
4
+ export declare const hasStrokeWidth: (type: ElementOrToolType) => type is "line" | "arrow" | "rectangle" | "diamond" | "ellipse" | "embeddable" | "iframe" | "freedraw";
5
+ export declare const hasStrokeStyle: (type: ElementOrToolType) => type is "line" | "arrow" | "rectangle" | "diamond" | "ellipse" | "embeddable" | "iframe";
6
+ export declare const canChangeRoundness: (type: ElementOrToolType) => type is "line" | "rectangle" | "diamond" | "embeddable" | "iframe" | "image";
7
+ export declare const toolIsArrow: (type: ElementOrToolType) => type is "arrow";
8
+ export declare const canHaveArrowheads: (type: ElementOrToolType) => type is "arrow";
@@ -24,10 +24,10 @@ export declare const dragNewElement: ({ newElement, elementType, originX, origin
24
24
  scene: Scene;
25
25
  /** whether to keep given aspect ratio when `isResizeWithSidesSameLength` is
26
26
  true */
27
- widthAspectRatio?: number | null | undefined;
27
+ widthAspectRatio?: number | null;
28
28
  originOffset?: {
29
29
  x: number;
30
30
  y: number;
31
- } | null | undefined;
32
- informMutation?: boolean | undefined;
31
+ } | null;
32
+ informMutation?: boolean;
33
33
  }) => void;
@@ -17,12 +17,12 @@ import type { ExcalidrawElement, GroupId } from "./types";
17
17
  export declare const duplicateElement: <TElement extends ExcalidrawElement>(editingGroupId: AppState["editingGroupId"], groupIdMapForOperation: Map<GroupId, GroupId>, element: TElement, randomizeSeed?: boolean) => Readonly<TElement>;
18
18
  export declare const duplicateElements: (opts: {
19
19
  elements: readonly ExcalidrawElement[];
20
- randomizeSeed?: boolean | undefined;
21
- overrides?: ((data: {
20
+ randomizeSeed?: boolean;
21
+ overrides?: (data: {
22
22
  duplicateElement: ExcalidrawElement;
23
23
  origElement: ExcalidrawElement;
24
24
  origIdToDuplicateId: Map<ExcalidrawElement["id"], ExcalidrawElement["id"]>;
25
- }) => Partial<ExcalidrawElement>) | undefined;
25
+ }) => Partial<ExcalidrawElement>;
26
26
  } & ({
27
27
  /**
28
28
  * Duplicates all elements in array.
@@ -26,11 +26,11 @@ export declare class InvalidFractionalIndexError extends Error {
26
26
  export declare const validateFractionalIndices: (elements: readonly ExcalidrawElement[], { shouldThrow, includeBoundTextValidation, ignoreLogs, reconciliationContext, }: {
27
27
  shouldThrow: boolean;
28
28
  includeBoundTextValidation: boolean;
29
- ignoreLogs?: true | undefined;
29
+ ignoreLogs?: true;
30
30
  reconciliationContext?: {
31
31
  localElements: ReadonlyArray<ExcalidrawElement>;
32
32
  remoteElements: ReadonlyArray<ExcalidrawElement>;
33
- } | undefined;
33
+ };
34
34
  }) => void;
35
35
  /**
36
36
  * Order the elements based on the fractional indices.
@@ -31,8 +31,8 @@ export declare const getFrameLikeElements: (allElements: ExcalidrawElementsInclu
31
31
  */
32
32
  export declare const getRootElements: (allElements: ExcalidrawElementsIncludingDeleted) => ExcalidrawElement[];
33
33
  export declare const getElementsInResizingFrame: (allElements: ExcalidrawElementsIncludingDeleted, frame: ExcalidrawFrameLikeElement, appState: AppState, elementsMap: ElementsMap) => ExcalidrawElement[];
34
- export declare const getElementsInNewFrame: (elements: ExcalidrawElementsIncludingDeleted, frame: ExcalidrawFrameLikeElement, elementsMap: ElementsMap) => (import("./types").ExcalidrawTextElement | import("./types").ExcalidrawRectangleElement | import("./types").ExcalidrawDiamondElement | import("./types").ExcalidrawFrameElement | import("./types").ExcalidrawMagicFrameElement | import("./types").ExcalidrawEmbeddableElement | import("./types").ExcalidrawImageElement | import("./types").ExcalidrawIframeElement | import("./types").ExcalidrawSelectionElement | import("./types").ExcalidrawEllipseElement | import("./types").ExcalidrawLinearElement | import("./types").ExcalidrawFreeDrawElement)[];
35
- export declare const omitPartialGroups: (elements: ExcalidrawElement[], frame: ExcalidrawFrameLikeElement, allElementsMap: ElementsMap) => (import("./types").ExcalidrawTextElement | import("./types").ExcalidrawRectangleElement | import("./types").ExcalidrawDiamondElement | import("./types").ExcalidrawFrameElement | import("./types").ExcalidrawMagicFrameElement | import("./types").ExcalidrawEmbeddableElement | import("./types").ExcalidrawImageElement | import("./types").ExcalidrawIframeElement | import("./types").ExcalidrawSelectionElement | import("./types").ExcalidrawEllipseElement | import("./types").ExcalidrawLinearElement | import("./types").ExcalidrawFreeDrawElement)[];
34
+ export declare const getElementsInNewFrame: (elements: ExcalidrawElementsIncludingDeleted, frame: ExcalidrawFrameLikeElement, elementsMap: ElementsMap) => (import("./types").ExcalidrawLinearElement | import("./types").ExcalidrawSelectionElement | import("./types").ExcalidrawRectangleElement | import("./types").ExcalidrawDiamondElement | import("./types").ExcalidrawEllipseElement | import("./types").ExcalidrawEmbeddableElement | import("./types").ExcalidrawIframeElement | import("./types").ExcalidrawImageElement | import("./types").ExcalidrawFrameElement | import("./types").ExcalidrawMagicFrameElement | import("./types").ExcalidrawTextElement | import("./types").ExcalidrawFreeDrawElement)[];
35
+ export declare const omitPartialGroups: (elements: ExcalidrawElement[], frame: ExcalidrawFrameLikeElement, allElementsMap: ElementsMap) => (import("./types").ExcalidrawLinearElement | import("./types").ExcalidrawSelectionElement | import("./types").ExcalidrawRectangleElement | import("./types").ExcalidrawDiamondElement | import("./types").ExcalidrawEllipseElement | import("./types").ExcalidrawEmbeddableElement | import("./types").ExcalidrawIframeElement | import("./types").ExcalidrawImageElement | import("./types").ExcalidrawFrameElement | import("./types").ExcalidrawMagicFrameElement | import("./types").ExcalidrawTextElement | import("./types").ExcalidrawFreeDrawElement)[];
36
36
  export declare const getContainingFrame: (element: ExcalidrawElement, elementsMap: ElementsMap) => ExcalidrawFrameLikeElement | null;
37
37
  /** */
38
38
  export declare const filterElementsEligibleAsFrameChildren: (elements: readonly ExcalidrawElement[], frame: ExcalidrawFrameLikeElement) => ExcalidrawElement[];
@@ -53,7 +53,11 @@ export declare const updateFrameMembershipOfSelectedElements: <T extends Element
53
53
  * filters out elements that are inside groups that contain a frame element
54
54
  * anywhere in the group tree
55
55
  */
56
- export declare const omitGroupsContainingFrameLikes: (allElements: ElementsMapOrArray, selectedElements?: readonly ExcalidrawElement[]) => ExcalidrawElement[];
56
+ export declare const omitGroupsContainingFrameLikes: (allElements: ElementsMapOrArray,
57
+ /** subset of elements you want to filter. Optional perf optimization so we
58
+ * don't have to filter all elements unnecessarily
59
+ */
60
+ selectedElements?: readonly ExcalidrawElement[]) => ExcalidrawElement[];
57
61
  /**
58
62
  * depending on the appState, return target frame, which is the frame the given element
59
63
  * is going to be added to or remove from
@@ -1,3 +1,4 @@
1
+ import { type Bounds } from "@excalidraw/common";
1
2
  import type { LocalPoint, GlobalPoint, Vector } from "@excalidraw/math";
2
3
  import type { ExcalidrawBindableElement } from "./types";
3
4
  export declare const HEADING_RIGHT: Heading;
@@ -11,5 +12,5 @@ export declare const headingForPointIsHorizontal: <P extends GlobalPoint | Local
11
12
  export declare const compareHeading: (a: Heading, b: Heading) => boolean;
12
13
  export declare const headingIsHorizontal: (a: Heading) => boolean;
13
14
  export declare const headingIsVertical: (a: Heading) => boolean;
14
- export declare const headingForPointFromElement: <Point extends GlobalPoint>(element: Readonly<ExcalidrawBindableElement>, aabb: readonly [minX: number, minY: number, maxX: number, maxY: number], p: Readonly<Point>) => Heading;
15
+ export declare const headingForPointFromElement: <Point extends GlobalPoint>(element: Readonly<ExcalidrawBindableElement>, aabb: Readonly<Bounds>, p: Readonly<Point>) => Heading;
15
16
  export declare const flipHeading: (h: Heading) => Heading;
@@ -10,17 +10,7 @@ export declare const updateImageCache: ({ fileIds, files, imageCache, }: {
10
10
  }) => Promise<{
11
11
  imageCache: Map<FileId, {
12
12
  image: HTMLImageElement | Promise<HTMLImageElement>;
13
- mimeType: import("@excalidraw/common/utility-types").ValueOf<{
14
- readonly svg: "image/svg+xml";
15
- readonly png: "image/png";
16
- readonly jpg: "image/jpeg";
17
- readonly gif: "image/gif";
18
- readonly webp: "image/webp";
19
- readonly bmp: "image/bmp";
20
- readonly ico: "image/x-icon";
21
- readonly avif: "image/avif";
22
- readonly jfif: "image/jfif";
23
- }>;
13
+ mimeType: import("@excalidraw/common/utility-types").ValueOf<typeof import("@excalidraw/common").IMAGE_MIME_TYPES>;
24
14
  }>;
25
15
  /** includes errored files because they cache was updated nonetheless */
26
16
  updatedFiles: Map<FileId, true>;