@excalidraw/element 0.18.0-c141960 → 0.18.0-c1dbbdf

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 (233) hide show
  1. package/dist/dev/index.js +2698 -954
  2. package/dist/dev/index.js.map +4 -4
  3. package/dist/prod/index.js +18 -18
  4. package/dist/types/common/debug.d.ts +21 -0
  5. package/dist/types/common/src/bounds.d.ts +10 -0
  6. package/dist/types/common/src/colors.d.ts +59 -39
  7. package/dist/types/common/src/constants.d.ts +17 -11
  8. package/dist/types/common/src/editorInterface.d.ts +1 -1
  9. package/dist/types/common/src/font-metadata.d.ts +1 -3
  10. package/dist/types/common/src/index.d.ts +2 -1
  11. package/dist/types/common/src/keys.d.ts +1 -1
  12. package/dist/types/common/src/utility-types.d.ts +0 -1
  13. package/dist/types/common/src/utils.d.ts +46 -38
  14. package/dist/types/element/src/Scene.d.ts +5 -3
  15. package/dist/types/element/src/arrows/focus.d.ts +27 -0
  16. package/dist/types/element/src/arrows/helpers.d.ts +5 -0
  17. package/dist/types/element/src/binding.d.ts +19 -12
  18. package/dist/types/element/src/bounds.d.ts +2 -10
  19. package/dist/types/element/src/collision.d.ts +4 -3
  20. package/dist/types/element/src/comparisons.d.ts +7 -7
  21. package/dist/types/element/src/distribute.d.ts +2 -1
  22. package/dist/types/element/src/dragElements.d.ts +3 -3
  23. package/dist/types/element/src/duplicate.d.ts +3 -3
  24. package/dist/types/element/src/elbowArrow.d.ts +2 -0
  25. package/dist/types/element/src/fractionalIndex.d.ts +2 -2
  26. package/dist/types/element/src/frame.d.ts +5 -1
  27. package/dist/types/element/src/heading.d.ts +2 -1
  28. package/dist/types/element/src/image.d.ts +1 -11
  29. package/dist/types/element/src/index.d.ts +3 -0
  30. package/dist/types/element/src/linearElementEditor.d.ts +6 -2
  31. package/dist/types/element/src/mutateElement.d.ts +5 -1
  32. package/dist/types/element/src/newElement.d.ts +6 -6
  33. package/dist/types/element/src/renderElement.d.ts +0 -6
  34. package/dist/types/element/src/resizeElements.d.ts +10 -10
  35. package/dist/types/element/src/resizeTest.d.ts +1 -1
  36. package/dist/types/element/src/selection.d.ts +3 -7
  37. package/dist/types/element/src/shape.d.ts +8 -7
  38. package/dist/types/element/src/textMeasurements.d.ts +1 -3
  39. package/dist/types/{excalidraw/data → element/src}/transform.d.ts +3 -3
  40. package/dist/types/element/src/transformHandles.d.ts +3 -23
  41. package/dist/types/element/src/typeChecks.d.ts +2 -4
  42. package/dist/types/element/src/types.d.ts +1 -1
  43. package/dist/types/element/src/utils.d.ts +8 -4
  44. package/dist/types/{common → element}/src/visualdebug.d.ts +20 -2
  45. package/dist/types/element/src/zindex.d.ts +1 -1
  46. package/dist/types/excalidraw/actions/actionAddToLibrary.d.ts +92 -153
  47. package/dist/types/excalidraw/actions/actionAlign.d.ts +0 -1
  48. package/dist/types/excalidraw/actions/actionBoundText.d.ts +64 -105
  49. package/dist/types/excalidraw/actions/actionCanvas.d.ts +383 -618
  50. package/dist/types/excalidraw/actions/actionClipboard.d.ts +64 -105
  51. package/dist/types/excalidraw/actions/actionCropEditor.d.ts +31 -52
  52. package/dist/types/excalidraw/actions/actionDeleteSelected.d.ts +106 -169
  53. package/dist/types/excalidraw/actions/actionDistribute.d.ts +0 -1
  54. package/dist/types/excalidraw/actions/actionDuplicateSelection.d.ts +0 -1
  55. package/dist/types/excalidraw/actions/actionElementLink.d.ts +24 -49
  56. package/dist/types/excalidraw/actions/actionElementLock.d.ts +65 -106
  57. package/dist/types/excalidraw/actions/actionEmbeddable.d.ts +32 -53
  58. package/dist/types/excalidraw/actions/actionExport.d.ts +126 -211
  59. package/dist/types/excalidraw/actions/actionFinalize.d.ts +1 -2
  60. package/dist/types/excalidraw/actions/actionFlip.d.ts +0 -1
  61. package/dist/types/excalidraw/actions/actionFrame.d.ts +221 -338
  62. package/dist/types/excalidraw/actions/actionGroup.d.ts +68 -117
  63. package/dist/types/excalidraw/actions/actionLinearEditor.d.ts +134 -189
  64. package/dist/types/excalidraw/actions/actionLink.d.ts +32 -53
  65. package/dist/types/excalidraw/actions/actionMenu.d.ts +23 -48
  66. package/dist/types/excalidraw/actions/actionNavigate.d.ts +14 -17
  67. package/dist/types/excalidraw/actions/actionProperties.d.ts +79 -120
  68. package/dist/types/excalidraw/actions/actionSelectAll.d.ts +34 -59
  69. package/dist/types/excalidraw/actions/actionStyles.d.ts +30 -51
  70. package/dist/types/excalidraw/actions/actionToggleArrowBinding.d.ts +172 -0
  71. package/dist/types/excalidraw/actions/actionToggleGridMode.d.ts +32 -53
  72. package/dist/types/excalidraw/actions/actionToggleMidpointSnapping.d.ts +172 -0
  73. package/dist/types/excalidraw/actions/actionToggleObjectsSnapMode.d.ts +32 -53
  74. package/dist/types/excalidraw/actions/actionToggleSearchMenu.d.ts +22 -47
  75. package/dist/types/excalidraw/actions/actionToggleStats.d.ts +32 -53
  76. package/dist/types/excalidraw/actions/actionToggleViewMode.d.ts +32 -53
  77. package/dist/types/excalidraw/actions/actionToggleZenMode.d.ts +32 -53
  78. package/dist/types/excalidraw/actions/actionZindex.d.ts +0 -1
  79. package/dist/types/excalidraw/actions/index.d.ts +2 -0
  80. package/dist/types/excalidraw/actions/manager.d.ts +1 -1
  81. package/dist/types/excalidraw/actions/register.d.ts +2 -2
  82. package/dist/types/excalidraw/actions/shortcuts.d.ts +1 -1
  83. package/dist/types/excalidraw/actions/types.d.ts +1 -1
  84. package/dist/types/excalidraw/appState.d.ts +12 -10
  85. package/dist/types/excalidraw/charts/charts.bar.d.ts +2 -0
  86. package/dist/types/excalidraw/charts/charts.constants.d.ts +48 -0
  87. package/dist/types/excalidraw/charts/charts.helpers.d.ts +32 -0
  88. package/dist/types/excalidraw/charts/charts.line.d.ts +2 -0
  89. package/dist/types/excalidraw/charts/charts.parse.d.ts +10 -0
  90. package/dist/types/excalidraw/charts/charts.radar.d.ts +2 -0
  91. package/dist/types/excalidraw/charts/charts.types.d.ts +18 -0
  92. package/dist/types/excalidraw/charts/index.d.ts +7 -0
  93. package/dist/types/excalidraw/clipboard.d.ts +11 -35
  94. package/dist/types/excalidraw/components/Actions.d.ts +1 -1
  95. package/dist/types/excalidraw/components/App.d.ts +43 -44
  96. package/dist/types/excalidraw/components/Card.d.ts +1 -3
  97. package/dist/types/excalidraw/components/ColorPicker/ColorInput.d.ts +2 -4
  98. package/dist/types/excalidraw/components/ColorPicker/ColorPicker.d.ts +0 -1
  99. package/dist/types/excalidraw/components/ColorPicker/colorPickerUtils.d.ts +0 -1
  100. package/dist/types/excalidraw/components/ColorPicker/keyboardNavHandlers.d.ts +0 -1
  101. package/dist/types/excalidraw/components/CommandPalette/types.d.ts +1 -2
  102. package/dist/types/excalidraw/components/ConvertElementTypePopup.d.ts +2 -2
  103. package/dist/types/excalidraw/components/DarkModeToggle.d.ts +1 -1
  104. package/dist/types/excalidraw/components/DefaultSidebar.d.ts +9 -13
  105. package/dist/types/excalidraw/components/ElementLinkDialog.d.ts +1 -1
  106. package/dist/types/excalidraw/components/Ellipsify.d.ts +1 -2
  107. package/dist/types/excalidraw/components/ErrorDialog.d.ts +1 -1
  108. package/dist/types/excalidraw/components/ExcalidrawLogo.d.ts +0 -1
  109. package/dist/types/excalidraw/components/EyeDropper.d.ts +0 -1
  110. package/dist/types/excalidraw/components/FilledButton.d.ts +1 -0
  111. package/dist/types/excalidraw/components/FontPicker/keyboardNavHandlers.d.ts +0 -1
  112. package/dist/types/excalidraw/components/HelpDialog.d.ts +1 -1
  113. package/dist/types/excalidraw/components/InlineIcon.d.ts +2 -2
  114. package/dist/types/excalidraw/components/LibraryMenuControlButtons.d.ts +1 -1
  115. package/dist/types/excalidraw/components/LibraryMenuHeaderContent.d.ts +1 -2
  116. package/dist/types/excalidraw/components/LibraryUnit.d.ts +2 -3
  117. package/dist/types/excalidraw/components/LoadingMessage.d.ts +0 -1
  118. package/dist/types/excalidraw/components/MobileToolBar.d.ts +0 -1
  119. package/dist/types/excalidraw/components/Modal.d.ts +0 -1
  120. package/dist/types/excalidraw/components/OverwriteConfirm/OverwriteConfirm.d.ts +1 -1
  121. package/dist/types/excalidraw/components/PasteChartDialog.d.ts +4 -5
  122. package/dist/types/excalidraw/components/PropertiesPopover.d.ts +1 -1
  123. package/dist/types/excalidraw/components/RadioGroup.d.ts +0 -1
  124. package/dist/types/excalidraw/components/RadioSelection.d.ts +4 -4
  125. package/dist/types/excalidraw/components/ScrollableList.d.ts +0 -1
  126. package/dist/types/excalidraw/components/Sidebar/Sidebar.d.ts +15 -21
  127. package/dist/types/excalidraw/components/Sidebar/SidebarHeader.d.ts +1 -1
  128. package/dist/types/excalidraw/components/Sidebar/SidebarTab.d.ts +1 -2
  129. package/dist/types/excalidraw/components/Sidebar/SidebarTabTrigger.d.ts +1 -2
  130. package/dist/types/excalidraw/components/Sidebar/SidebarTabTriggers.d.ts +1 -2
  131. package/dist/types/excalidraw/components/Sidebar/SidebarTabs.d.ts +1 -2
  132. package/dist/types/excalidraw/components/Spinner.d.ts +4 -4
  133. package/dist/types/excalidraw/components/Stats/CanvasGrid.d.ts +0 -1
  134. package/dist/types/excalidraw/components/Stats/Collapsible.d.ts +0 -1
  135. package/dist/types/excalidraw/components/Stats/DragInput.d.ts +0 -1
  136. package/dist/types/excalidraw/components/Stats/index.d.ts +7 -8
  137. package/dist/types/excalidraw/components/TTDDialog/Chat/ChatHistoryMenu.d.ts +15 -0
  138. package/dist/types/excalidraw/components/TTDDialog/Chat/ChatInterface.d.ts +23 -0
  139. package/dist/types/excalidraw/components/TTDDialog/Chat/ChatMessage.d.ts +14 -0
  140. package/dist/types/excalidraw/components/TTDDialog/Chat/TTDChatPanel.d.ts +27 -0
  141. package/dist/types/excalidraw/components/TTDDialog/Chat/index.d.ts +3 -0
  142. package/dist/types/excalidraw/components/TTDDialog/Chat/useChatAgent.d.ts +8 -0
  143. package/dist/types/excalidraw/components/TTDDialog/CodeMirrorEditor.d.ts +11 -0
  144. package/dist/types/excalidraw/components/TTDDialog/MermaidToExcalidraw.d.ts +3 -2
  145. package/dist/types/excalidraw/components/TTDDialog/TTDContext.d.ts +13 -0
  146. package/dist/types/excalidraw/components/TTDDialog/TTDDialog.d.ts +12 -29
  147. package/dist/types/excalidraw/components/TTDDialog/TTDDialogInput.d.ts +3 -3
  148. package/dist/types/excalidraw/components/TTDDialog/TTDDialogOutput.d.ts +5 -2
  149. package/dist/types/excalidraw/components/TTDDialog/TTDDialogPanel.d.ts +13 -9
  150. package/dist/types/excalidraw/components/TTDDialog/TTDDialogTab.d.ts +1 -2
  151. package/dist/types/excalidraw/components/TTDDialog/TTDDialogTabTrigger.d.ts +1 -2
  152. package/dist/types/excalidraw/components/TTDDialog/TTDDialogTabTriggers.d.ts +1 -2
  153. package/dist/types/excalidraw/components/TTDDialog/TTDDialogTrigger.d.ts +1 -1
  154. package/dist/types/excalidraw/components/TTDDialog/TTDPreviewPanel.d.ts +9 -0
  155. package/dist/types/excalidraw/components/TTDDialog/TTDWelcomeMessage.d.ts +1 -0
  156. package/dist/types/excalidraw/components/TTDDialog/TextToDiagram.d.ts +9 -0
  157. package/dist/types/excalidraw/components/TTDDialog/common.d.ts +16 -16
  158. package/dist/types/excalidraw/components/TTDDialog/hooks/useChatManagement.d.ts +13 -0
  159. package/dist/types/excalidraw/components/TTDDialog/hooks/useMermaidRenderer.d.ts +14 -0
  160. package/dist/types/excalidraw/components/TTDDialog/hooks/useTextGeneration.d.ts +7 -0
  161. package/dist/types/excalidraw/components/TTDDialog/mermaid-lang-lite.d.ts +2 -0
  162. package/dist/types/excalidraw/components/TTDDialog/types.d.ts +95 -0
  163. package/dist/types/excalidraw/components/TTDDialog/useTTDChatStorage.d.ts +22 -0
  164. package/dist/types/excalidraw/components/TTDDialog/utils/TTDStreamFetch.d.ts +24 -0
  165. package/dist/types/excalidraw/components/TTDDialog/utils/chat.d.ts +10 -0
  166. package/dist/types/excalidraw/components/TTDDialog/utils/mermaidAutoFix.d.ts +1 -0
  167. package/dist/types/excalidraw/components/TTDDialog/utils/mermaidError.d.ts +10 -0
  168. package/dist/types/excalidraw/components/TTDDialog/utils/mermaidValidation.d.ts +1 -0
  169. package/dist/types/excalidraw/components/Toast.d.ts +3 -3
  170. package/dist/types/excalidraw/components/Trans.d.ts +2 -2
  171. package/dist/types/excalidraw/components/dropdownMenu/DropdownMenu.d.ts +48 -38
  172. package/dist/types/excalidraw/components/dropdownMenu/DropdownMenuContent.d.ts +7 -6
  173. package/dist/types/excalidraw/components/dropdownMenu/DropdownMenuGroup.d.ts +3 -3
  174. package/dist/types/excalidraw/components/dropdownMenu/DropdownMenuItem.d.ts +13 -22
  175. package/dist/types/excalidraw/components/dropdownMenu/DropdownMenuItemCheckbox.d.ts +5 -0
  176. package/dist/types/excalidraw/components/dropdownMenu/DropdownMenuItemContent.d.ts +5 -4
  177. package/dist/types/excalidraw/components/dropdownMenu/DropdownMenuItemContentRadio.d.ts +0 -1
  178. package/dist/types/excalidraw/components/dropdownMenu/DropdownMenuItemCustom.d.ts +2 -2
  179. package/dist/types/excalidraw/components/dropdownMenu/DropdownMenuItemLink.d.ts +6 -6
  180. package/dist/types/excalidraw/components/dropdownMenu/DropdownMenuSub.d.ts +23 -0
  181. package/dist/types/excalidraw/components/dropdownMenu/DropdownMenuSubContent.d.ts +8 -0
  182. package/dist/types/excalidraw/components/dropdownMenu/DropdownMenuSubTrigger.d.ts +12 -0
  183. package/dist/types/excalidraw/components/dropdownMenu/DropdownMenuTrigger.d.ts +3 -4
  184. package/dist/types/excalidraw/components/dropdownMenu/common.d.ts +2 -2
  185. package/dist/types/excalidraw/components/dropdownMenu/dropdownMenuUtils.d.ts +2 -0
  186. package/dist/types/excalidraw/components/hoc/withInternalFallback.d.ts +1 -1
  187. package/dist/types/excalidraw/components/hyperlink/helpers.d.ts +1 -1
  188. package/dist/types/excalidraw/components/icons.d.ts +22 -13
  189. package/dist/types/excalidraw/components/live-collaboration/LiveCollaborationTrigger.d.ts +2 -13
  190. package/dist/types/excalidraw/components/main-menu/DefaultItems.d.ts +19 -2
  191. package/dist/types/excalidraw/components/main-menu/MainMenu.d.ts +39 -32
  192. package/dist/types/excalidraw/components/shapes.d.ts +74 -1
  193. package/dist/types/excalidraw/components/welcome-screen/WelcomeScreen.Center.d.ts +6 -6
  194. package/dist/types/excalidraw/components/welcome-screen/WelcomeScreen.d.ts +15 -16
  195. package/dist/types/excalidraw/data/blob.d.ts +323 -3
  196. package/dist/types/excalidraw/data/encode.d.ts +4 -4
  197. package/dist/types/excalidraw/data/encryption.d.ts +5 -5
  198. package/dist/types/excalidraw/data/filesystem.d.ts +2 -2
  199. package/dist/types/excalidraw/data/index.d.ts +3 -3
  200. package/dist/types/excalidraw/data/json.d.ts +160 -2
  201. package/dist/types/excalidraw/data/library.d.ts +24 -9
  202. package/dist/types/excalidraw/data/restore.d.ts +25 -10
  203. package/dist/types/excalidraw/editor-jotai.d.ts +11 -11
  204. package/dist/types/excalidraw/errors.d.ts +14 -0
  205. package/dist/types/excalidraw/hooks/useOutsideClick.d.ts +1 -2
  206. package/dist/types/excalidraw/hooks/useScrollPosition.d.ts +1 -2
  207. package/dist/types/excalidraw/i18n.d.ts +2 -2
  208. package/dist/types/excalidraw/index.d.ts +6 -4
  209. package/dist/types/excalidraw/renderer/helpers.d.ts +6 -4
  210. package/dist/types/excalidraw/renderer/interactiveScene.d.ts +8 -6
  211. package/dist/types/excalidraw/scene/Renderer.d.ts +5 -2
  212. package/dist/types/excalidraw/scene/export.d.ts +2 -2
  213. package/dist/types/excalidraw/scene/scroll.d.ts +1 -6
  214. package/dist/types/excalidraw/scene/types.d.ts +7 -2
  215. package/dist/types/excalidraw/snapping.d.ts +5 -5
  216. package/dist/types/excalidraw/subset/harfbuzz/harfbuzz-bindings.d.ts +1 -1
  217. package/dist/types/excalidraw/subset/harfbuzz/harfbuzz-loader.d.ts +1 -1
  218. package/dist/types/excalidraw/subset/harfbuzz/harfbuzz-wasm.d.ts +1 -1
  219. package/dist/types/excalidraw/subset/woff2/woff2-loader.d.ts +2 -2
  220. package/dist/types/excalidraw/subset/woff2/woff2-wasm.d.ts +1 -1
  221. package/dist/types/excalidraw/types.d.ts +25 -14
  222. package/dist/types/excalidraw/wysiwyg/textWysiwyg.d.ts +2 -2
  223. package/dist/types/math/src/point.d.ts +6 -1
  224. package/dist/types/math/src/polygon.d.ts +2 -2
  225. package/dist/types/math/src/range.d.ts +1 -3
  226. package/dist/types/math/src/segment.d.ts +3 -3
  227. package/dist/types/math/src/types.d.ts +25 -1
  228. package/dist/types/utils/src/bbox.d.ts +1 -1
  229. package/dist/types/utils/src/export.d.ts +5 -5
  230. package/dist/types/utils/src/shape.d.ts +6 -6
  231. package/dist/types/utils/src/withinBounds.d.ts +2 -2
  232. package/package.json +9 -3
  233. package/dist/types/excalidraw/charts.d.ts +0 -27
@@ -0,0 +1,21 @@
1
+ export declare class Debug {
2
+ static DEBUG_LOG_TIMES: boolean;
3
+ private static TIMES_AGGR;
4
+ private static TIMES_AVG;
5
+ private static LAST_DEBUG_LOG_CALL;
6
+ private static DEBUG_LOG_INTERVAL_ID;
7
+ private static LAST_FRAME_TIMESTAMP;
8
+ private static FRAME_COUNT;
9
+ private static ANIMATION_FRAME_ID;
10
+ private static scheduleAnimationFrame;
11
+ private static setupInterval;
12
+ private static debugLogger;
13
+ static logTime: (time?: number, name?: string) => void;
14
+ static logTimeAverage: (time?: number, name?: string) => void;
15
+ private static logWrapper;
16
+ static logTimeWrap: <T extends any[], R>(fn: (...args: T) => R, name?: string) => (...args: T) => R;
17
+ static logTimeAverageWrap: <T extends any[], R>(fn: (...args: T) => R, name?: string) => (...args: T) => R;
18
+ static perfWrap: <T extends any[], R>(fn: (...args: T) => R, name?: string) => (...args: T) => R;
19
+ private static CHANGED_CACHE;
20
+ static logChanged(name: string, obj: Record<string, unknown>): void;
21
+ }
@@ -0,0 +1,10 @@
1
+ /**
2
+ * x and y position of top left corner, x and y position of bottom right corner
3
+ */
4
+ export type Bounds = readonly [
5
+ minX: number,
6
+ minY: number,
7
+ maxX: number,
8
+ maxY: number
9
+ ];
10
+ export declare const isBounds: (box: unknown) => box is Bounds;
@@ -1,13 +1,5 @@
1
- import oc from "open-color";
2
- import type { Merge } from "./utility-types";
3
- export declare const COLOR_OUTLINE_CONTRAST_THRESHOLD = 240;
4
- export type ColorPickerColor = Exclude<keyof oc, "indigo" | "lime"> | "transparent" | "bronze";
1
+ export declare const applyDarkModeFilter: (color: string) => string;
5
2
  export type ColorTuple = readonly [string, string, string, string, string];
6
- export type ColorPalette = Merge<Record<ColorPickerColor, ColorTuple>, {
7
- black: "#1e1e1e";
8
- white: "#ffffff";
9
- transparent: "transparent";
10
- }>;
11
3
  export type ColorPaletteCustom = {
12
4
  [key: string]: ColorTuple | string;
13
5
  };
@@ -17,46 +9,74 @@ export declare const COLORS_PER_ROW = 5;
17
9
  export declare const DEFAULT_CHART_COLOR_INDEX = 4;
18
10
  export declare const DEFAULT_ELEMENT_STROKE_COLOR_INDEX = 4;
19
11
  export declare const DEFAULT_ELEMENT_BACKGROUND_COLOR_INDEX = 1;
20
- export declare const ELEMENTS_PALETTE_SHADE_INDEXES: readonly [0, 2, 4, 6, 8];
21
- export declare const CANVAS_PALETTE_SHADE_INDEXES: readonly [0, 1, 2, 3, 4];
22
- export declare const getSpecificColorShades: (color: Exclude<ColorPickerColor, "transparent" | "white" | "black" | "bronze">, indexArr: readonly [number, number, number, number, number]) => ColorTuple;
23
- export declare const COLOR_PALETTE: ColorPalette;
12
+ export declare const COLOR_PALETTE: {
13
+ readonly transparent: "transparent";
14
+ readonly black: "#1e1e1e";
15
+ readonly white: "#ffffff";
16
+ readonly gray: readonly ["#f8f9fa", "#e9ecef", "#ced4da", "#868e96", "#343a40"];
17
+ readonly red: readonly ["#fff5f5", "#ffc9c9", "#ff8787", "#fa5252", "#e03131"];
18
+ readonly pink: readonly ["#fff0f6", "#fcc2d7", "#f783ac", "#e64980", "#c2255c"];
19
+ readonly grape: readonly ["#f8f0fc", "#eebefa", "#da77f2", "#be4bdb", "#9c36b5"];
20
+ readonly violet: readonly ["#f3f0ff", "#d0bfff", "#9775fa", "#7950f2", "#6741d9"];
21
+ readonly blue: readonly ["#e7f5ff", "#a5d8ff", "#4dabf7", "#228be6", "#1971c2"];
22
+ readonly cyan: readonly ["#e3fafc", "#99e9f2", "#3bc9db", "#15aabf", "#0c8599"];
23
+ readonly teal: readonly ["#e6fcf5", "#96f2d7", "#38d9a9", "#12b886", "#099268"];
24
+ readonly green: readonly ["#ebfbee", "#b2f2bb", "#69db7c", "#40c057", "#2f9e44"];
25
+ readonly yellow: readonly ["#fff9db", "#ffec99", "#ffd43b", "#fab005", "#f08c00"];
26
+ readonly orange: readonly ["#fff4e6", "#ffd8a8", "#ffa94d", "#fd7e14", "#e8590c"];
27
+ readonly bronze: readonly ["#f8f1ee", "#eaddd7", "#d2bab0", "#a18072", "#846358"];
28
+ };
29
+ export type ColorPalette = typeof COLOR_PALETTE;
30
+ export type ColorPickerColor = keyof typeof COLOR_PALETTE;
24
31
  export declare const DEFAULT_ELEMENT_STROKE_PICKS: ColorTuple;
25
32
  export declare const DEFAULT_ELEMENT_BACKGROUND_PICKS: ColorTuple;
26
33
  export declare const DEFAULT_CANVAS_BACKGROUND_PICKS: ColorTuple;
27
34
  export declare const DEFAULT_ELEMENT_STROKE_COLOR_PALETTE: {
28
- readonly red: ColorTuple;
29
- readonly pink: ColorTuple;
30
- readonly grape: ColorTuple;
31
- readonly violet: ColorTuple;
32
- readonly blue: ColorTuple;
33
- readonly cyan: ColorTuple;
34
- readonly teal: ColorTuple;
35
- readonly green: ColorTuple;
36
- readonly yellow: ColorTuple;
37
- readonly orange: ColorTuple;
35
+ readonly cyan: readonly ["#e3fafc", "#99e9f2", "#3bc9db", "#15aabf", "#0c8599"];
36
+ readonly blue: readonly ["#e7f5ff", "#a5d8ff", "#4dabf7", "#228be6", "#1971c2"];
37
+ readonly violet: readonly ["#f3f0ff", "#d0bfff", "#9775fa", "#7950f2", "#6741d9"];
38
+ readonly grape: readonly ["#f8f0fc", "#eebefa", "#da77f2", "#be4bdb", "#9c36b5"];
39
+ readonly pink: readonly ["#fff0f6", "#fcc2d7", "#f783ac", "#e64980", "#c2255c"];
40
+ readonly green: readonly ["#ebfbee", "#b2f2bb", "#69db7c", "#40c057", "#2f9e44"];
41
+ readonly teal: readonly ["#e6fcf5", "#96f2d7", "#38d9a9", "#12b886", "#099268"];
42
+ readonly yellow: readonly ["#fff9db", "#ffec99", "#ffd43b", "#fab005", "#f08c00"];
43
+ readonly orange: readonly ["#fff4e6", "#ffd8a8", "#ffa94d", "#fd7e14", "#e8590c"];
44
+ readonly red: readonly ["#fff5f5", "#ffc9c9", "#ff8787", "#fa5252", "#e03131"];
38
45
  readonly transparent: "transparent";
39
46
  readonly white: "#ffffff";
40
- readonly gray: ColorTuple;
47
+ readonly gray: readonly ["#f8f9fa", "#e9ecef", "#ced4da", "#868e96", "#343a40"];
41
48
  readonly black: "#1e1e1e";
42
- readonly bronze: ColorTuple;
49
+ readonly bronze: readonly ["#f8f1ee", "#eaddd7", "#d2bab0", "#a18072", "#846358"];
43
50
  };
44
51
  export declare const DEFAULT_ELEMENT_BACKGROUND_COLOR_PALETTE: {
45
- readonly red: ColorTuple;
46
- readonly pink: ColorTuple;
47
- readonly grape: ColorTuple;
48
- readonly violet: ColorTuple;
49
- readonly blue: ColorTuple;
50
- readonly cyan: ColorTuple;
51
- readonly teal: ColorTuple;
52
- readonly green: ColorTuple;
53
- readonly yellow: ColorTuple;
54
- readonly orange: ColorTuple;
52
+ readonly cyan: readonly ["#e3fafc", "#99e9f2", "#3bc9db", "#15aabf", "#0c8599"];
53
+ readonly blue: readonly ["#e7f5ff", "#a5d8ff", "#4dabf7", "#228be6", "#1971c2"];
54
+ readonly violet: readonly ["#f3f0ff", "#d0bfff", "#9775fa", "#7950f2", "#6741d9"];
55
+ readonly grape: readonly ["#f8f0fc", "#eebefa", "#da77f2", "#be4bdb", "#9c36b5"];
56
+ readonly pink: readonly ["#fff0f6", "#fcc2d7", "#f783ac", "#e64980", "#c2255c"];
57
+ readonly green: readonly ["#ebfbee", "#b2f2bb", "#69db7c", "#40c057", "#2f9e44"];
58
+ readonly teal: readonly ["#e6fcf5", "#96f2d7", "#38d9a9", "#12b886", "#099268"];
59
+ readonly yellow: readonly ["#fff9db", "#ffec99", "#ffd43b", "#fab005", "#f08c00"];
60
+ readonly orange: readonly ["#fff4e6", "#ffd8a8", "#ffa94d", "#fd7e14", "#e8590c"];
61
+ readonly red: readonly ["#fff5f5", "#ffc9c9", "#ff8787", "#fa5252", "#e03131"];
55
62
  readonly transparent: "transparent";
56
63
  readonly white: "#ffffff";
57
- readonly gray: ColorTuple;
64
+ readonly gray: readonly ["#f8f9fa", "#e9ecef", "#ced4da", "#868e96", "#343a40"];
58
65
  readonly black: "#1e1e1e";
59
- readonly bronze: ColorTuple;
66
+ readonly bronze: readonly ["#f8f1ee", "#eaddd7", "#d2bab0", "#a18072", "#846358"];
60
67
  };
61
- export declare const getAllColorsSpecificShade: (index: 0 | 1 | 2 | 3 | 4) => readonly [string, string, string, string, string, string, string, string, string, string];
62
- export declare const rgbToHex: (r: number, g: number, b: number) => string;
68
+ export declare const getAllColorsSpecificShade: (index: 0 | 1 | 2 | 3 | 4) => ("#fff5f5" | "#ffc9c9" | "#ff8787" | "#fa5252" | "#e03131" | "#fff0f6" | "#fcc2d7" | "#f783ac" | "#e64980" | "#c2255c" | "#f8f0fc" | "#eebefa" | "#da77f2" | "#be4bdb" | "#9c36b5" | "#f3f0ff" | "#d0bfff" | "#9775fa" | "#7950f2" | "#6741d9" | "#e7f5ff" | "#a5d8ff" | "#4dabf7" | "#228be6" | "#1971c2" | "#e3fafc" | "#99e9f2" | "#3bc9db" | "#15aabf" | "#0c8599" | "#e6fcf5" | "#96f2d7" | "#38d9a9" | "#12b886" | "#099268" | "#ebfbee" | "#b2f2bb" | "#69db7c" | "#40c057" | "#2f9e44" | "#fff9db" | "#ffec99" | "#ffd43b" | "#fab005" | "#f08c00" | "#fff4e6" | "#ffd8a8" | "#ffa94d" | "#fd7e14" | "#e8590c")[];
69
+ export declare const rgbToHex: (r: number, g: number, b: number, a?: number) => string;
70
+ /**
71
+ * @returns #RRGGBB or #RRGGBBAA based on color containing non-opaque alpha,
72
+ * null if not valid color
73
+ */
74
+ export declare const colorToHex: (color: string) => string | null;
75
+ export declare const isTransparent: (color: string) => boolean;
76
+ export declare const COLOR_OUTLINE_CONTRAST_THRESHOLD = 240;
77
+ export declare const isColorDark: (color: string, threshold?: number) => boolean;
78
+ /**
79
+ * tries to keep the input color as-is if it's valid, making minimal adjustments
80
+ * (trimming whitespace or adding `#` to hex colors)
81
+ */
82
+ export declare const normalizeInputColor: (color: string) => string | null;
@@ -85,6 +85,13 @@ export declare const CLASSES: {
85
85
  CONVERT_ELEMENT_TYPE_POPUP: string;
86
86
  SHAPE_ACTIONS_THEME_SCOPE: string;
87
87
  FRAME_NAME: string;
88
+ DROPDOWN_MENU_EVENT_WRAPPER: string;
89
+ };
90
+ export declare const FONT_SIZES: {
91
+ readonly sm: 16;
92
+ readonly md: 20;
93
+ readonly lg: 28;
94
+ readonly xl: 36;
88
95
  };
89
96
  export declare const CJK_HAND_DRAWN_FALLBACK_FONT = "Xiaolai";
90
97
  export declare const WINDOWS_EMOJI_FALLBACK_FONT = "Segoe UI Emoji";
@@ -125,17 +132,15 @@ export declare const THEME: {
125
132
  readonly LIGHT: "light";
126
133
  readonly DARK: "dark";
127
134
  };
135
+ export declare const DARK_THEME_FILTER = "invert(93%) hue-rotate(180deg)";
128
136
  export declare const FRAME_STYLE: {
129
- strokeColor: string;
130
- strokeWidth: number;
131
- strokeStyle: import("@excalidraw/element/types").StrokeStyle;
132
- fillStyle: import("@excalidraw/element/types").FillStyle;
133
- roughness: number;
134
- roundness: {
135
- type: import("@excalidraw/element/types").RoundnessType;
136
- value?: number | undefined;
137
- } | null;
138
- backgroundColor: string;
137
+ strokeColor: ExcalidrawElement["strokeColor"];
138
+ strokeWidth: ExcalidrawElement["strokeWidth"];
139
+ strokeStyle: ExcalidrawElement["strokeStyle"];
140
+ fillStyle: ExcalidrawElement["fillStyle"];
141
+ roughness: ExcalidrawElement["roughness"];
142
+ roundness: ExcalidrawElement["roundness"];
143
+ backgroundColor: ExcalidrawElement["backgroundColor"];
139
144
  radius: number;
140
145
  nameOffsetY: number;
141
146
  nameColorLightTheme: string;
@@ -175,6 +180,7 @@ export declare const STRING_MIME_TYPES: {
175
180
  readonly html: "text/html";
176
181
  readonly json: "application/json";
177
182
  readonly excalidraw: "application/vnd.excalidraw+json";
183
+ readonly excalidrawClipboard: "application/vnd.excalidraw.clipboard+json";
178
184
  readonly excalidrawlib: "application/vnd.excalidrawlib+json";
179
185
  readonly excalidrawlibIds: "application/vnd.excalidrawlib.ids+json";
180
186
  };
@@ -195,6 +201,7 @@ export declare const MIME_TYPES: {
195
201
  readonly html: "text/html";
196
202
  readonly json: "application/json";
197
203
  readonly excalidraw: "application/vnd.excalidraw+json";
204
+ readonly excalidrawClipboard: "application/vnd.excalidraw.clipboard+json";
198
205
  readonly excalidrawlib: "application/vnd.excalidrawlib+json";
199
206
  readonly excalidrawlibIds: "application/vnd.excalidrawlib.ids+json";
200
207
  };
@@ -223,7 +230,6 @@ export declare const MAX_ZOOM = 30;
223
230
  export declare const HYPERLINK_TOOLTIP_DELAY = 300;
224
231
  export declare const IDLE_THRESHOLD = 60000;
225
232
  export declare const ACTIVE_THRESHOLD = 3000;
226
- export declare const THEME_FILTER = "invert(93%) hue-rotate(180deg)";
227
233
  export declare const URL_QUERY_KEYS: {
228
234
  readonly addLibrary: "addLibrary";
229
235
  };
@@ -14,7 +14,7 @@ export declare const MQ_MAX_MOBILE = 599;
14
14
  export declare const MQ_MAX_WIDTH_LANDSCAPE = 1000;
15
15
  export declare const MQ_MAX_HEIGHT_LANDSCAPE = 500;
16
16
  export declare const MQ_MIN_TABLET: number;
17
- export declare const MQ_MAX_TABLET = 1400;
17
+ export declare const MQ_MAX_TABLET = 1180;
18
18
  export declare const MQ_MIN_WIDTH_DESKTOP = 1440;
19
19
  export declare const MQ_RIGHT_SIDEBAR_MIN_WIDTH = 1229;
20
20
  export declare const isDarwin: boolean;
@@ -43,6 +43,4 @@ export declare const getVerticalOffset: (fontFamily: ExcalidrawTextElement["font
43
43
  /**
44
44
  * Gets line height for a selected family.
45
45
  */
46
- export declare const getLineHeight: (fontFamily: FontFamilyValues) => number & {
47
- _brand: "unitlessLineHeight";
48
- };
46
+ export declare const getLineHeight: (fontFamily: FontFamilyValues) => ExcalidrawTextElement["lineHeight"];
@@ -1,4 +1,5 @@
1
1
  export * from "./binary-heap";
2
+ export * from "./bounds";
2
3
  export * from "./colors";
3
4
  export * from "./constants";
4
5
  export * from "./font-metadata";
@@ -10,5 +11,5 @@ export * from "./random";
10
11
  export * from "./url";
11
12
  export * from "./utils";
12
13
  export * from "./emitter";
13
- export * from "./visualdebug";
14
14
  export * from "./editorInterface";
15
+ export { Debug } from "../debug";
@@ -183,7 +183,7 @@ export declare const isLatinChar: (key: string) => boolean;
183
183
  * More details in https://github.com/excalidraw/excalidraw/pull/5944
184
184
  */
185
185
  export declare const matchKey: (event: KeyboardEvent | React.KeyboardEvent<Element>, key: ValueOf<typeof KEYS>) => boolean;
186
- export declare const isArrowKey: (key: string) => boolean;
186
+ export declare const isArrowKey: (key: string) => key is "ArrowDown" | "ArrowLeft" | "ArrowRight" | "ArrowUp";
187
187
  export declare const shouldResizeFromCenter: (event: MouseEvent | KeyboardEvent) => boolean;
188
188
  export declare const shouldMaintainAspectRatio: (event: MouseEvent | KeyboardEvent) => boolean;
189
189
  export declare const shouldRotateWithDiscreteAngle: (event: MouseEvent | KeyboardEvent | React.PointerEvent<HTMLCanvasElement>) => boolean;
@@ -1,4 +1,3 @@
1
- /// <reference types="react" />
2
1
  export type Mutable<T> = {
3
2
  -readonly [P in keyof T]: T[P];
4
3
  };
@@ -1,14 +1,15 @@
1
+ import type { GlobalCoord } from "@excalidraw/math";
1
2
  import type { FontFamilyValues, FontString } from "@excalidraw/element/types";
2
3
  import type { ActiveTool, AppState, ToolType, UnsubscribeCallback, Zoom } from "@excalidraw/excalidraw/types";
3
- import type { MaybePromise } from "./utility-types";
4
+ import type { MaybePromise, ResolutionType } from "./utility-types";
4
5
  import type { EVENT } from "./constants";
5
6
  export declare const setDateTimeForTests: (dateTime: string) => void;
6
7
  export declare const getDateTime: () => string;
7
8
  export declare const capitalizeString: (str: string) => string;
8
9
  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;
10
+ export declare const isInputLike: (target: Element | EventTarget | null) => target is HTMLInputElement | HTMLTextAreaElement | HTMLSelectElement | HTMLBRElement | HTMLDivElement;
10
11
  export declare const isInteractive: (target: Element | EventTarget | null) => boolean;
11
- export declare const isWritableElement: (target: Element | EventTarget | null) => target is HTMLBRElement | HTMLDivElement | HTMLInputElement | HTMLTextAreaElement;
12
+ export declare const isWritableElement: (target: Element | EventTarget | null) => target is HTMLInputElement | HTMLTextAreaElement | HTMLBRElement | HTMLDivElement;
12
13
  export declare const getFontFamilyString: ({ fontFamily, }: {
13
14
  fontFamily: FontFamilyValues;
14
15
  }) => string;
@@ -71,18 +72,20 @@ export declare const easeToValuesRAF: <T extends Record<keyof T, number>, K exte
71
72
  * Interpolate a single value.
72
73
  * Return undefined to be handled by the default interpolator.
73
74
  */
74
- interpolateValue?: ((fromValue: number, toValue: number, progress: number, key: K) => number | undefined) | undefined;
75
+ interpolateValue?: (fromValue: number, toValue: number,
76
+ /** no easing applied */
77
+ progress: number, key: K) => number | undefined;
75
78
  onStep: (values: T) => void;
76
- duration?: number | undefined;
77
- onStart?: (() => void) | undefined;
78
- onEnd?: (() => void) | undefined;
79
- onCancel?: (() => void) | undefined;
79
+ duration?: number;
80
+ onStart?: () => void;
81
+ onEnd?: () => void;
82
+ onCancel?: () => void;
80
83
  }) => () => void;
81
- export declare const chunk: <T extends unknown>(array: readonly T[], size: number) => T[][];
84
+ export declare const chunk: <T extends any>(array: readonly T[], size: number) => T[][];
82
85
  export declare const selectNode: (node: Element) => void;
83
86
  export declare const removeSelection: () => void;
84
87
  export declare const distance: (x: number, y: number) => number;
85
- export declare const isSelectionLikeTool: (type: ToolType | "custom") => boolean;
88
+ export declare const isSelectionLikeTool: (type: ToolType | "custom") => type is "selection" | "lasso";
86
89
  export declare const updateActiveTool: (appState: Pick<AppState, "activeTool">, data: (({
87
90
  type: ToolType;
88
91
  } | {
@@ -106,10 +109,7 @@ export declare const viewportCoordsToSceneCoords: ({ clientX, clientY }: {
106
109
  offsetTop: number;
107
110
  scrollX: number;
108
111
  scrollY: number;
109
- }) => {
110
- x: number;
111
- y: number;
112
- };
112
+ }) => GlobalCoord;
113
113
  export declare const sceneCoordsToViewportCoords: ({ sceneX, sceneY }: {
114
114
  sceneX: number;
115
115
  sceneY: number;
@@ -140,8 +140,7 @@ export declare const muteFSAbortError: (error?: Error) => void;
140
140
  export declare const findIndex: <T>(array: readonly T[], cb: (element: T, index: number, array: readonly T[]) => boolean, fromIndex?: number) => number;
141
141
  export declare const findLastIndex: <T>(array: readonly T[], cb: (element: T, index: number, array: readonly T[]) => boolean, fromIndex?: number) => number;
142
142
  /** returns the first non-null mapped value */
143
- export declare const mapFind: <T, K>(collection: readonly T[], iteratee: (value: T, index: number) => K | null | undefined) => K | undefined;
144
- export declare const isTransparent: (color: string) => boolean;
143
+ export declare const mapFind: <T, K>(collection: readonly T[], iteratee: (value: T, index: number) => K | undefined | null) => K | undefined;
145
144
  export type ResolvablePromise<T> = Promise<T> & {
146
145
  resolve: [T] extends [undefined] ? (value?: MaybePromise<Awaited<T>>) => void : (value: MaybePromise<Awaited<T>>) => void;
147
146
  reject: (error: Error) => void;
@@ -159,16 +158,16 @@ export declare const getUpdatedTimestamp: () => number;
159
158
  * Transforms array of objects containing `id` attribute,
160
159
  * or array of ids (strings), into a Map, keyd by `id`.
161
160
  */
162
- export declare const arrayToMap: <T extends string | {
161
+ export declare const arrayToMap: <T extends {
163
162
  id: string;
164
- }>(items: Map<string, T> | readonly T[]) => Map<string, T>;
163
+ } | string>(items: readonly T[] | Map<string, T>) => Map<string, T>;
165
164
  export declare const arrayToMapWithIndex: <T extends {
166
165
  id: string;
167
166
  }>(elements: readonly T[]) => Map<string, [element: T, index: number]>;
168
167
  /**
169
168
  * Transform array into an object, use only when array order is irrelevant.
170
169
  */
171
- export declare const arrayToObject: <T>(array: readonly T[], groupBy?: ((value: T) => string | number) | undefined) => {
170
+ export declare const arrayToObject: <T>(array: readonly T[], groupBy?: (value: T) => string | number) => {
172
171
  [key: string]: T;
173
172
  };
174
173
  /** Doubly linked node */
@@ -184,11 +183,11 @@ export declare const arrayToList: <T>(array: readonly T[]) => Node<T>[];
184
183
  * Converts a readonly array or map into an iterable.
185
184
  * Useful for avoiding entry allocations when iterating object / map on each iteration.
186
185
  */
187
- export declare const toIterable: <T>(values: ReadonlyMap<string, T> | readonly T[]) => Iterable<T>;
186
+ export declare const toIterable: <T>(values: readonly T[] | ReadonlyMap<string, T>) => Iterable<T>;
188
187
  /**
189
188
  * Converts a readonly array or map into an array.
190
189
  */
191
- export declare const toArray: <T>(values: ReadonlyMap<string, T> | readonly T[]) => T[];
190
+ export declare const toArray: <T>(values: readonly T[] | ReadonlyMap<string, T>) => T[];
192
191
  export declare const isTestEnv: () => boolean;
193
192
  export declare const isDevEnv: () => boolean;
194
193
  export declare const isProdEnv: () => boolean;
@@ -200,18 +199,18 @@ export declare const updateObject: <T extends Record<string, any>>(obj: T, updat
200
199
  export declare const isPrimitive: (val: any) => boolean;
201
200
  export declare const getFrame: () => "top" | "iframe";
202
201
  export declare const isRunningInIframe: () => boolean;
203
- export declare const isPromiseLike: (value: any) => value is Promise<any>;
202
+ export declare const isPromiseLike: (value: any) => value is Promise<ResolutionType<typeof value>>;
204
203
  export declare const queryFocusableElements: (container: HTMLElement | null) => HTMLElement[];
205
204
  /**
206
205
  * Returns whether object/array is shallow equal.
207
206
  * Considers empty object/arrays as equal (whether top-level or second-level).
208
207
  */
209
- 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 : {
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; } | (keyof T extends K[number] ? K extends readonly (keyof T)[] ? K : {
210
209
  _error: "keys are either missing or include keys not in compared obj";
211
210
  } : {
212
211
  _error: "keys are either missing or include keys not in compared obj";
213
- }) | undefined, debug?: boolean) => boolean;
214
- export declare const composeEventHandlers: <E>(originalEventHandler?: ((event: E) => void) | undefined, ourEventHandler?: ((event: E) => void) | undefined, { checkForDefaultPrevented }?: {
212
+ }), debug?: boolean) => boolean;
213
+ export declare const composeEventHandlers: <E>(originalEventHandler?: (event: E) => void, ourEventHandler?: (event: E) => void, { checkForDefaultPrevented }?: {
215
214
  checkForDefaultPrevented?: boolean | undefined;
216
215
  }) => (event: E) => void;
217
216
  /**
@@ -223,11 +222,15 @@ export declare function invariant(condition: any, message: string): asserts cond
223
222
  /**
224
223
  * Memoizes on values of `opts` object (strict equality).
225
224
  */
226
- export declare const memoize: <T extends Record<string, any>, R extends unknown>(func: (opts: T) => R) => ((opts: T) => R) & {
225
+ export declare const memoize: <T extends Record<string, any>, R extends any>(func: (opts: T) => R) => typeof func & {
227
226
  clear: () => void;
228
227
  };
229
228
  /** Checks if value is inside given collection. Useful for type-safety. */
230
- export declare const isMemberOf: <T extends string>(collection: Set<T> | Record<T, any> | Map<T, any> | readonly T[], value: string) => value is T;
229
+ export declare const isMemberOf: <T extends string>(
230
+ /** Set/Map/Array/Object */
231
+ collection: Set<T> | readonly T[] | Record<T, any> | Map<T, any>,
232
+ /** value to look for */
233
+ value: string) => value is T;
231
234
  export declare const cloneJSON: <T>(obj: T) => T;
232
235
  export declare const updateStable: <T extends any[] | Record<string, any>>(prevValue: T, nextValue: T) => T;
233
236
  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;
@@ -238,21 +241,25 @@ export declare function addEventListener<K extends keyof FontFaceSetEventMap>(ta
238
241
  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;
239
242
  export declare function getSvgPathFromStroke(points: number[][], closed?: boolean): string;
240
243
  export declare const normalizeEOL: (str: string) => string;
241
- type HasBrand<T> = {
242
- [K in keyof T]: K extends `~brand${infer _}` ? true : never;
244
+ export type HasBrand<T> = {
245
+ [K in keyof T]: K extends `~brand${infer _}` | "_brand" ? true : never;
243
246
  }[keyof T];
244
247
  type RemoveAllBrands<T> = HasBrand<T> extends true ? {
245
- [K in keyof T as K extends `~brand~${infer _}` ? never : K]: T[K];
246
- } : never;
247
- 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>;
248
+ [K in keyof T as K extends `~brand~${infer _}` | "_brand" ? never : K]: T[K];
249
+ } : T;
250
+ 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>;
251
+ 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>;
252
+ export type CombineBrands<BrandedType, CurrentType> = BrandedType extends readonly (infer BE)[] ? CurrentType extends readonly (infer CE)[] ? Array<CE & BE> : CurrentType & BrandedType : CurrentType & BrandedType;
253
+ export type CombineBrandsIfNeeded<T, Required> = [T] extends [Required] ? T[] : HasBrand<T> extends true ? CombineBrands<T, Required>[] : Required[];
248
254
  /**
249
255
  * Makes type into a branded type, ensuring that value is assignable to
250
- * the base ubranded type. Optionally you can explicitly supply current value
256
+ * the base unbranded type. Optionally you can explicitly supply current value
251
257
  * type to combine both (useful for composite branded types. Make sure you
252
258
  * compose branded types which are not composite themselves.)
253
259
  */
254
- export declare const toBrandedType: <BrandedType, CurrentType = BrandedType>(value: Unbrand<BrandedType>) => CurrentType & BrandedType;
255
- export declare const promiseTry: <TValue, TArgs extends unknown[]>(fn: (...args: TArgs) => TValue | PromiseLike<TValue>, ...args: TArgs) => Promise<TValue>;
260
+ export declare function toBrandedType<BrandedType>(value: UnbrandForValue<BrandedType>): BrandedType;
261
+ export declare function toBrandedType<BrandedType, CurrentType>(value: CurrentType): CombineBrands<BrandedType, CurrentType>;
262
+ export declare const promiseTry: <TValue, TArgs extends unknown[]>(fn: (...args: TArgs) => PromiseLike<TValue> | TValue, ...args: TArgs) => Promise<TValue>;
256
263
  export declare const isAnyTrue: (...args: boolean[]) => boolean;
257
264
  export declare const safelyParseJSON: (json: string) => Record<string, any> | null;
258
265
  /**
@@ -264,10 +271,11 @@ export declare const castArray: <T>(value: T | T[]) => T[];
264
271
  /** hack for Array.isArray type guard not working with readonly value[] */
265
272
  export declare const isReadonlyArray: (value?: any) => value is readonly any[];
266
273
  export declare const sizeOf: (value: readonly unknown[] | Readonly<Map<string, unknown>> | Readonly<Record<string, unknown>> | ReadonlySet<unknown>) => number;
267
- export declare const reduceToCommonValue: <T, R = T>(collection: ReadonlySet<T> | readonly T[], getValue?: ((item: T) => R) | undefined) => R | null;
274
+ export declare const reduceToCommonValue: <T, R = T>(collection: readonly T[] | ReadonlySet<T>, getValue?: (item: T) => R) => R | null;
268
275
  type FEATURE_FLAGS = {
269
276
  COMPLEX_BINDINGS: boolean;
270
277
  };
271
- export declare const getFeatureFlag: <F extends "COMPLEX_BINDINGS">(flag: F) => FEATURE_FLAGS[F];
272
- export declare const setFeatureFlag: <F extends "COMPLEX_BINDINGS">(flag: F, value: FEATURE_FLAGS[F]) => void;
278
+ export declare const getFeatureFlag: <F extends keyof FEATURE_FLAGS>(flag: F) => FEATURE_FLAGS[F];
279
+ export declare const setFeatureFlag: <F extends keyof FEATURE_FLAGS>(flag: F, value: FEATURE_FLAGS[F]) => void;
280
+ export declare const oneOf: <N extends string | number | symbol | null, H extends N>(needle: N, haystack: readonly H[]) => needle is H;
273
281
  export {};
@@ -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?: {
@@ -75,6 +75,8 @@ export declare class Scene {
75
75
  mutateElement<TElement extends Mutable<ExcalidrawElement>>(element: TElement, updates: ElementUpdate<TElement>, options?: {
76
76
  informMutation: boolean;
77
77
  isDragging: boolean;
78
+ isBindingEnabled?: boolean;
79
+ isMidpointSnappingEnabled?: boolean;
78
80
  }): TElement;
79
81
  }
80
82
  export {};
@@ -0,0 +1,27 @@
1
+ import { type GlobalPoint } from "@excalidraw/math";
2
+ import type { AppState, NullableGridSize } from "@excalidraw/excalidraw/types";
3
+ import { LinearElementEditor } from "../linearElementEditor";
4
+ import type { ElementsMap, ExcalidrawArrowElement, ExcalidrawBindableElement, NonDeletedSceneElementsMap } from "../types";
5
+ import type { Scene } from "../Scene";
6
+ export declare const isFocusPointVisible: (focusPoint: GlobalPoint, arrow: ExcalidrawArrowElement, bindableElement: ExcalidrawBindableElement, elementsMap: ElementsMap, appState: {
7
+ isBindingEnabled: AppState["isBindingEnabled"];
8
+ zoom: AppState["zoom"];
9
+ }, startOrEnd: "start" | "end", ignoreOverlap?: boolean) => boolean;
10
+ export declare const handleFocusPointDrag: (linearElementEditor: LinearElementEditor, elementsMap: NonDeletedSceneElementsMap, pointerCoords: {
11
+ x: number;
12
+ y: number;
13
+ }, scene: Scene, appState: AppState, gridSize: NullableGridSize, switchToInsideBinding: boolean) => void;
14
+ export declare const handleFocusPointPointerDown: (arrow: ExcalidrawArrowElement, pointerDownState: {
15
+ origin: {
16
+ x: number;
17
+ y: number;
18
+ };
19
+ }, elementsMap: NonDeletedSceneElementsMap, appState: AppState) => {
20
+ hitFocusPoint: "start" | "end" | null;
21
+ pointerOffset: {
22
+ x: number;
23
+ y: number;
24
+ };
25
+ };
26
+ export declare const handleFocusPointPointerUp: (linearElementEditor: LinearElementEditor, scene: Scene) => void;
27
+ export declare const handleFocusPointHover: (arrow: ExcalidrawArrowElement, scenePointerX: number, scenePointerY: number, scene: Scene, appState: AppState) => "start" | "end" | null;
@@ -0,0 +1,5 @@
1
+ import type { App } from "@excalidraw/excalidraw/types";
2
+ export declare const maybeHandleArrowPointlikeDrag: ({ app, event, }: {
3
+ app: App;
4
+ event: KeyboardEvent | React.KeyboardEvent<Element> | PointerEvent;
5
+ }) => boolean;
@@ -1,9 +1,9 @@
1
1
  import { type GlobalPoint } from "@excalidraw/math";
2
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
8
  import type { BindMode, ElementsMap, ExcalidrawArrowElement, ExcalidrawBindableElement, ExcalidrawElbowArrowElement, ExcalidrawElement, FixedPoint, FixedPointBinding, NonDeleted, NonDeletedExcalidrawElement, NonDeletedSceneElementsMap, Ordered, PointsPositionUpdates } from "./types";
9
9
  export type BindingStrategy = {
@@ -24,23 +24,27 @@ export type BindingStrategy = {
24
24
  *
25
25
  * IMPORTANT: currently must be > 0 (this also applies to the computed gap)
26
26
  */
27
- export declare const BASE_BINDING_GAP = 10;
27
+ export declare const BASE_BINDING_GAP = 5;
28
28
  export declare const BASE_BINDING_GAP_ELBOW = 5;
29
+ export declare const BASE_ARROW_MIN_LENGTH = 10;
30
+ export declare const FOCUS_POINT_SIZE: number;
29
31
  export declare const getBindingGap: (bindTarget: ExcalidrawBindableElement, opts: Pick<ExcalidrawArrowElement, "elbowed">) => number;
30
32
  export declare const maxBindingDistance_simple: (zoom?: AppState["zoom"]) => number;
31
- export declare const shouldEnableBindingForPointerEvent: (event: React.PointerEvent<HTMLElement>) => boolean;
32
- export declare const isBindingEnabled: (appState: AppState) => boolean;
33
- export declare const bindOrUnbindBindingElement: (arrow: NonDeleted<ExcalidrawArrowElement>, draggingPoints: PointsPositionUpdates, scene: Scene, appState: AppState, opts?: {
33
+ export declare const isBindingEnabled: (appState: {
34
+ isBindingEnabled: AppState["isBindingEnabled"];
35
+ }) => boolean;
36
+ export declare const bindOrUnbindBindingElement: (arrow: NonDeleted<ExcalidrawArrowElement>, draggingPoints: PointsPositionUpdates, scenePointerX: number, scenePointerY: number, scene: Scene, appState: AppState, opts?: {
34
37
  newArrow?: boolean;
35
38
  altKey?: boolean;
39
+ angleLocked?: boolean;
36
40
  initialBinding?: boolean;
37
41
  }) => {
38
42
  start: BindingStrategy;
39
43
  end: BindingStrategy;
40
44
  };
41
- export declare const getBindingStrategyForDraggingBindingElementEndpoints: (arrow: NonDeleted<ExcalidrawArrowElement>, draggingPoints: PointsPositionUpdates, elementsMap: NonDeletedSceneElementsMap, elements: readonly Ordered<NonDeletedExcalidrawElement>[], appState: AppState, opts?: {
45
+ export declare const getBindingStrategyForDraggingBindingElementEndpoints: (arrow: NonDeleted<ExcalidrawArrowElement>, draggingPoints: PointsPositionUpdates, screenPointerX: number, screenPointerY: number, elementsMap: NonDeletedSceneElementsMap, elements: readonly Ordered<NonDeletedExcalidrawElement>[], appState: AppState, opts?: {
42
46
  newArrow?: boolean;
43
- shiftKey?: boolean;
47
+ angleLocked?: boolean;
44
48
  altKey?: boolean;
45
49
  finalize?: boolean;
46
50
  initialBinding?: boolean;
@@ -50,7 +54,7 @@ export declare const getBindingStrategyForDraggingBindingElementEndpoints: (arro
50
54
  end: BindingStrategy;
51
55
  };
52
56
  export declare const bindOrUnbindBindingElements: (selectedArrows: NonDeleted<ExcalidrawArrowElement>[], scene: Scene, appState: AppState) => void;
53
- export declare const bindBindingElement: (arrow: NonDeleted<ExcalidrawArrowElement>, hoveredElement: ExcalidrawBindableElement, mode: BindMode, startOrEnd: "start" | "end", scene: Scene, focusPoint?: GlobalPoint) => void;
57
+ export declare const bindBindingElement: (arrow: NonDeleted<ExcalidrawArrowElement>, hoveredElement: ExcalidrawBindableElement, mode: BindMode, startOrEnd: "start" | "end", scene: Scene, focusPoint?: GlobalPoint, shouldSnapToOutline?: boolean) => void;
54
58
  export declare const unbindBindingElement: (arrow: NonDeleted<ExcalidrawArrowElement>, startOrEnd: "start" | "end", scene: Scene) => ExcalidrawBindableElement["id"] | null;
55
59
  export declare const updateBoundElements: (changedElement: NonDeletedExcalidrawElement, scene: Scene, options?: {
56
60
  simultaneouslyUpdated?: readonly ExcalidrawElement[];
@@ -64,10 +68,11 @@ export declare const updateBindings: (latestElement: ExcalidrawElement, scene: S
64
68
  };
65
69
  }) => void;
66
70
  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;
67
- export declare const bindPointToSnapToElementOutline: (arrowElement: ExcalidrawArrowElement, bindableElement: ExcalidrawBindableElement, startOrEnd: "start" | "end", elementsMap: ElementsMap, customIntersector?: LineSegment<GlobalPoint>) => GlobalPoint;
71
+ export declare const bindPointToSnapToElementOutline: (arrowElement: ExcalidrawArrowElement, bindableElement: ExcalidrawBindableElement, startOrEnd: "start" | "end", elementsMap: ElementsMap, customIntersector?: LineSegment<GlobalPoint>, isMidpointSnappingEnabled?: boolean) => GlobalPoint;
68
72
  export declare const avoidRectangularCorner: (arrowElement: ExcalidrawArrowElement, bindTarget: ExcalidrawBindableElement, elementsMap: ElementsMap, p: GlobalPoint) => GlobalPoint;
69
- export declare const updateBoundPoint: (arrow: NonDeleted<ExcalidrawArrowElement>, startOrEnd: "startBinding" | "endBinding", binding: FixedPointBinding | null | undefined, bindableElement: ExcalidrawBindableElement, elementsMap: ElementsMap, customIntersector?: LineSegment<GlobalPoint>) => LocalPoint | null;
70
- export declare const calculateFixedPointForElbowArrowBinding: (linearElement: NonDeleted<ExcalidrawElbowArrowElement>, hoveredElement: ExcalidrawBindableElement, startOrEnd: "start" | "end", elementsMap: ElementsMap) => {
73
+ export declare const snapToMid: (bindTarget: ExcalidrawBindableElement, elementsMap: ElementsMap, p: GlobalPoint, tolerance?: number, arrowElement?: ExcalidrawArrowElement) => GlobalPoint | undefined;
74
+ export declare const updateBoundPoint: (arrow: NonDeleted<ExcalidrawArrowElement>, startOrEnd: "startBinding" | "endBinding", binding: FixedPointBinding | null | undefined, bindableElement: ExcalidrawBindableElement, elementsMap: ElementsMap, dragging?: boolean) => LocalPoint | null;
75
+ export declare const calculateFixedPointForElbowArrowBinding: (linearElement: NonDeleted<ExcalidrawElbowArrowElement>, hoveredElement: ExcalidrawBindableElement, startOrEnd: "start" | "end", elementsMap: ElementsMap, shouldSnapToOutline?: boolean, isMidpointSnappingEnabled?: boolean) => {
71
76
  fixedPoint: FixedPoint;
72
77
  };
73
78
  export declare const calculateFixedPointForNonElbowArrowBinding: (linearElement: NonDeleted<ExcalidrawArrowElement>, hoveredElement: ExcalidrawBindableElement, startOrEnd: "start" | "end", elementsMap: ElementsMap, focusPoint?: GlobalPoint) => {
@@ -119,4 +124,6 @@ export declare class BindableElement {
119
124
  export declare const getGlobalFixedPointForBindableElement: (fixedPointRatio: FixedPoint, element: ExcalidrawBindableElement, elementsMap: ElementsMap) => GlobalPoint;
120
125
  export declare const getGlobalFixedPoints: (arrow: ExcalidrawArrowElement, elementsMap: ElementsMap) => [GlobalPoint, GlobalPoint];
121
126
  export declare const getArrowLocalFixedPoints: (arrow: ExcalidrawElbowArrowElement, elementsMap: ElementsMap) => LocalPoint[];
122
- export declare const normalizeFixedPoint: <T extends FixedPoint | null>(fixedPoint: T) => T extends null ? null : FixedPoint;
127
+ export declare const isFixedPoint: (fixedPoint: any) => fixedPoint is FixedPointBinding["fixedPoint"];
128
+ export declare const normalizeFixedPoint: <T extends FixedPoint>(fixedPoint: T) => FixedPoint;
129
+ export declare const getBindingSideMidPoint: (binding: FixedPointBinding, elementsMap: ElementsMap) => GlobalPoint | LocalPoint | null;