@excalidraw/element 0.18.0-5fffc47 → 0.18.0-60b2758

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 (232) hide show
  1. package/dist/dev/index.js +4410 -2226
  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 +19 -27
  8. package/dist/types/common/src/editorInterface.d.ts +34 -0
  9. package/dist/types/common/src/font-metadata.d.ts +1 -3
  10. package/dist/types/common/src/index.d.ts +3 -0
  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 +50 -39
  14. package/dist/types/element/src/Scene.d.ts +3 -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 +66 -46
  18. package/dist/types/element/src/bounds.d.ts +2 -10
  19. package/dist/types/element/src/collision.d.ts +7 -2
  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/fractionalIndex.d.ts +2 -2
  25. package/dist/types/element/src/frame.d.ts +5 -1
  26. package/dist/types/element/src/heading.d.ts +2 -1
  27. package/dist/types/element/src/image.d.ts +1 -11
  28. package/dist/types/element/src/index.d.ts +3 -3
  29. package/dist/types/element/src/linearElementEditor.d.ts +18 -20
  30. package/dist/types/element/src/mutateElement.d.ts +3 -1
  31. package/dist/types/element/src/newElement.d.ts +6 -6
  32. package/dist/types/element/src/renderElement.d.ts +1 -7
  33. package/dist/types/element/src/resizeElements.d.ts +10 -10
  34. package/dist/types/element/src/resizeTest.d.ts +6 -5
  35. package/dist/types/element/src/selection.d.ts +3 -7
  36. package/dist/types/element/src/shape.d.ts +8 -7
  37. package/dist/types/element/src/textMeasurements.d.ts +1 -3
  38. package/dist/types/{excalidraw/data → element/src}/transform.d.ts +3 -3
  39. package/dist/types/element/src/transformHandles.d.ts +8 -27
  40. package/dist/types/element/src/typeChecks.d.ts +4 -7
  41. package/dist/types/element/src/types.d.ts +8 -12
  42. package/dist/types/element/src/utils.d.ts +8 -3
  43. package/dist/types/element/src/visualdebug.d.ts +59 -0
  44. package/dist/types/element/src/zindex.d.ts +7 -1
  45. package/dist/types/excalidraw/actions/actionAddToLibrary.d.ts +99 -160
  46. package/dist/types/excalidraw/actions/actionAlign.d.ts +6 -7
  47. package/dist/types/excalidraw/actions/actionBoundText.d.ts +71 -112
  48. package/dist/types/excalidraw/actions/actionCanvas.d.ts +424 -858
  49. package/dist/types/excalidraw/actions/actionClipboard.d.ts +90 -892
  50. package/dist/types/excalidraw/actions/actionCropEditor.d.ts +34 -55
  51. package/dist/types/excalidraw/actions/actionDeleteSelected.d.ts +118 -183
  52. package/dist/types/excalidraw/actions/actionDistribute.d.ts +2 -3
  53. package/dist/types/excalidraw/actions/actionDuplicateSelection.d.ts +2 -3
  54. package/dist/types/excalidraw/actions/actionElementLink.d.ts +26 -53
  55. package/dist/types/excalidraw/actions/actionElementLock.d.ts +70 -111
  56. package/dist/types/excalidraw/actions/actionEmbeddable.d.ts +35 -56
  57. package/dist/types/excalidraw/actions/actionExport.d.ts +153 -1166
  58. package/dist/types/excalidraw/actions/actionFinalize.d.ts +10 -404
  59. package/dist/types/excalidraw/actions/actionFlip.d.ts +2 -3
  60. package/dist/types/excalidraw/actions/actionFrame.d.ts +235 -354
  61. package/dist/types/excalidraw/actions/actionGroup.d.ts +74 -123
  62. package/dist/types/excalidraw/actions/actionLinearEditor.d.ts +143 -202
  63. package/dist/types/excalidraw/actions/actionLink.d.ts +33 -54
  64. package/dist/types/excalidraw/actions/actionMenu.d.ts +24 -51
  65. package/dist/types/excalidraw/actions/actionNavigate.d.ts +18 -369
  66. package/dist/types/excalidraw/actions/actionProperties.d.ts +131 -2576
  67. package/dist/types/excalidraw/actions/actionSelectAll.d.ts +37 -62
  68. package/dist/types/excalidraw/actions/actionStyles.d.ts +34 -55
  69. package/dist/types/excalidraw/actions/actionTextAutoResize.d.ts +1 -1
  70. package/dist/types/excalidraw/actions/actionToggleGridMode.d.ts +34 -55
  71. package/dist/types/excalidraw/actions/actionToggleObjectsSnapMode.d.ts +34 -55
  72. package/dist/types/excalidraw/actions/actionToggleSearchMenu.d.ts +23 -50
  73. package/dist/types/excalidraw/actions/actionToggleShapeSwitch.d.ts +1 -1
  74. package/dist/types/excalidraw/actions/actionToggleStats.d.ts +34 -55
  75. package/dist/types/excalidraw/actions/actionToggleViewMode.d.ts +34 -55
  76. package/dist/types/excalidraw/actions/actionToggleZenMode.d.ts +35 -56
  77. package/dist/types/excalidraw/actions/actionZindex.d.ts +2 -3
  78. package/dist/types/excalidraw/actions/register.d.ts +2 -2
  79. package/dist/types/excalidraw/actions/shortcuts.d.ts +1 -1
  80. package/dist/types/excalidraw/actions/types.d.ts +3 -3
  81. package/dist/types/excalidraw/appState.d.ts +13 -13
  82. package/dist/types/excalidraw/charts/charts.bar.d.ts +2 -0
  83. package/dist/types/excalidraw/charts/charts.constants.d.ts +48 -0
  84. package/dist/types/excalidraw/charts/charts.helpers.d.ts +32 -0
  85. package/dist/types/excalidraw/charts/charts.line.d.ts +2 -0
  86. package/dist/types/excalidraw/charts/charts.parse.d.ts +10 -0
  87. package/dist/types/excalidraw/charts/charts.radar.d.ts +2 -0
  88. package/dist/types/excalidraw/charts/charts.types.d.ts +18 -0
  89. package/dist/types/excalidraw/charts/index.d.ts +7 -0
  90. package/dist/types/excalidraw/clipboard.d.ts +11 -35
  91. package/dist/types/excalidraw/components/Actions.d.ts +5 -2
  92. package/dist/types/excalidraw/components/App.d.ts +68 -60
  93. package/dist/types/excalidraw/components/Card.d.ts +1 -3
  94. package/dist/types/excalidraw/components/ColorPicker/ColorInput.d.ts +2 -4
  95. package/dist/types/excalidraw/components/ColorPicker/ColorPicker.d.ts +0 -2
  96. package/dist/types/excalidraw/components/ColorPicker/colorPickerUtils.d.ts +0 -1
  97. package/dist/types/excalidraw/components/ColorPicker/keyboardNavHandlers.d.ts +0 -1
  98. package/dist/types/excalidraw/components/CommandPalette/types.d.ts +2 -4
  99. package/dist/types/excalidraw/components/ConvertElementTypePopup.d.ts +2 -2
  100. package/dist/types/excalidraw/components/DarkModeToggle.d.ts +1 -1
  101. package/dist/types/excalidraw/components/DefaultSidebar.d.ts +9 -13
  102. package/dist/types/excalidraw/components/ElementLinkDialog.d.ts +1 -1
  103. package/dist/types/excalidraw/components/Ellipsify.d.ts +1 -2
  104. package/dist/types/excalidraw/components/ErrorDialog.d.ts +1 -1
  105. package/dist/types/excalidraw/components/ExcalidrawLogo.d.ts +0 -1
  106. package/dist/types/excalidraw/components/EyeDropper.d.ts +0 -1
  107. package/dist/types/excalidraw/components/FilledButton.d.ts +2 -1
  108. package/dist/types/excalidraw/components/FontPicker/keyboardNavHandlers.d.ts +0 -1
  109. package/dist/types/excalidraw/components/HelpDialog.d.ts +1 -1
  110. package/dist/types/excalidraw/components/HintViewer.d.ts +4 -3
  111. package/dist/types/excalidraw/components/InlineIcon.d.ts +2 -2
  112. package/dist/types/excalidraw/components/LibraryMenuControlButtons.d.ts +1 -1
  113. package/dist/types/excalidraw/components/LibraryMenuHeaderContent.d.ts +1 -2
  114. package/dist/types/excalidraw/components/LibraryUnit.d.ts +2 -3
  115. package/dist/types/excalidraw/components/LoadingMessage.d.ts +0 -1
  116. package/dist/types/excalidraw/components/MobileMenu.d.ts +1 -1
  117. package/dist/types/excalidraw/components/MobileToolBar.d.ts +0 -1
  118. package/dist/types/excalidraw/components/Modal.d.ts +0 -1
  119. package/dist/types/excalidraw/components/OverwriteConfirm/OverwriteConfirm.d.ts +1 -1
  120. package/dist/types/excalidraw/components/PasteChartDialog.d.ts +4 -5
  121. package/dist/types/excalidraw/components/Popover.d.ts +2 -1
  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/Stats/utils.d.ts +1 -1
  138. package/dist/types/excalidraw/components/TTDDialog/Chat/ChatHistoryMenu.d.ts +15 -0
  139. package/dist/types/excalidraw/components/TTDDialog/Chat/ChatInterface.d.ts +23 -0
  140. package/dist/types/excalidraw/components/TTDDialog/Chat/ChatMessage.d.ts +14 -0
  141. package/dist/types/excalidraw/components/TTDDialog/Chat/TTDChatPanel.d.ts +27 -0
  142. package/dist/types/excalidraw/components/TTDDialog/Chat/index.d.ts +3 -0
  143. package/dist/types/excalidraw/components/TTDDialog/Chat/useChatAgent.d.ts +8 -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/TTDDialogOutput.d.ts +2 -2
  148. package/dist/types/excalidraw/components/TTDDialog/TTDDialogPanel.d.ts +13 -9
  149. package/dist/types/excalidraw/components/TTDDialog/TTDDialogTab.d.ts +1 -2
  150. package/dist/types/excalidraw/components/TTDDialog/TTDDialogTabTrigger.d.ts +1 -2
  151. package/dist/types/excalidraw/components/TTDDialog/TTDDialogTabTriggers.d.ts +1 -2
  152. package/dist/types/excalidraw/components/TTDDialog/TTDDialogTrigger.d.ts +1 -1
  153. package/dist/types/excalidraw/components/TTDDialog/TTDPreviewPanel.d.ts +9 -0
  154. package/dist/types/excalidraw/components/TTDDialog/TTDWelcomeMessage.d.ts +1 -0
  155. package/dist/types/excalidraw/components/TTDDialog/TextToDiagram.d.ts +9 -0
  156. package/dist/types/excalidraw/components/TTDDialog/common.d.ts +16 -16
  157. package/dist/types/excalidraw/components/TTDDialog/hooks/useChatManagement.d.ts +13 -0
  158. package/dist/types/excalidraw/components/TTDDialog/hooks/useMermaidRenderer.d.ts +14 -0
  159. package/dist/types/excalidraw/components/TTDDialog/hooks/useTextGeneration.d.ts +7 -0
  160. package/dist/types/excalidraw/components/TTDDialog/types.d.ts +95 -0
  161. package/dist/types/excalidraw/components/TTDDialog/useTTDChatStorage.d.ts +22 -0
  162. package/dist/types/excalidraw/components/TTDDialog/utils/TTDStreamFetch.d.ts +24 -0
  163. package/dist/types/excalidraw/components/TTDDialog/utils/chat.d.ts +10 -0
  164. package/dist/types/excalidraw/components/TTDDialog/utils/mermaidValidation.d.ts +1 -0
  165. package/dist/types/excalidraw/components/Toast.d.ts +3 -3
  166. package/dist/types/excalidraw/components/Trans.d.ts +2 -2
  167. package/dist/types/excalidraw/components/canvases/InteractiveCanvas.d.ts +6 -3
  168. package/dist/types/excalidraw/components/dropdownMenu/DropdownMenu.d.ts +48 -38
  169. package/dist/types/excalidraw/components/dropdownMenu/DropdownMenuContent.d.ts +7 -6
  170. package/dist/types/excalidraw/components/dropdownMenu/DropdownMenuGroup.d.ts +3 -3
  171. package/dist/types/excalidraw/components/dropdownMenu/DropdownMenuItem.d.ts +13 -22
  172. package/dist/types/excalidraw/components/dropdownMenu/DropdownMenuItemCheckbox.d.ts +5 -0
  173. package/dist/types/excalidraw/components/dropdownMenu/DropdownMenuItemContent.d.ts +5 -4
  174. package/dist/types/excalidraw/components/dropdownMenu/DropdownMenuItemContentRadio.d.ts +0 -1
  175. package/dist/types/excalidraw/components/dropdownMenu/DropdownMenuItemCustom.d.ts +2 -2
  176. package/dist/types/excalidraw/components/dropdownMenu/DropdownMenuItemLink.d.ts +6 -6
  177. package/dist/types/excalidraw/components/dropdownMenu/DropdownMenuSub.d.ts +23 -0
  178. package/dist/types/excalidraw/components/dropdownMenu/DropdownMenuSubContent.d.ts +8 -0
  179. package/dist/types/excalidraw/components/dropdownMenu/DropdownMenuSubTrigger.d.ts +12 -0
  180. package/dist/types/excalidraw/components/dropdownMenu/DropdownMenuTrigger.d.ts +3 -4
  181. package/dist/types/excalidraw/components/dropdownMenu/common.d.ts +2 -2
  182. package/dist/types/excalidraw/components/dropdownMenu/dropdownMenuUtils.d.ts +2 -0
  183. package/dist/types/excalidraw/components/hoc/withInternalFallback.d.ts +1 -1
  184. package/dist/types/excalidraw/components/hyperlink/helpers.d.ts +1 -1
  185. package/dist/types/excalidraw/components/icons.d.ts +27 -13
  186. package/dist/types/excalidraw/components/live-collaboration/LiveCollaborationTrigger.d.ts +4 -3
  187. package/dist/types/excalidraw/components/main-menu/DefaultItems.d.ts +17 -2
  188. package/dist/types/excalidraw/components/main-menu/MainMenu.d.ts +39 -35
  189. package/dist/types/excalidraw/components/shapes.d.ts +74 -1
  190. package/dist/types/excalidraw/components/welcome-screen/WelcomeScreen.Center.d.ts +6 -6
  191. package/dist/types/excalidraw/components/welcome-screen/WelcomeScreen.d.ts +15 -16
  192. package/dist/types/excalidraw/data/blob.d.ts +319 -3
  193. package/dist/types/excalidraw/data/encode.d.ts +4 -4
  194. package/dist/types/excalidraw/data/encryption.d.ts +5 -5
  195. package/dist/types/excalidraw/data/filesystem.d.ts +2 -2
  196. package/dist/types/excalidraw/data/index.d.ts +3 -3
  197. package/dist/types/excalidraw/data/json.d.ts +158 -2
  198. package/dist/types/excalidraw/data/library.d.ts +24 -9
  199. package/dist/types/excalidraw/data/restore.d.ts +25 -10
  200. package/dist/types/excalidraw/editor-jotai.d.ts +11 -11
  201. package/dist/types/excalidraw/errors.d.ts +14 -0
  202. package/dist/types/excalidraw/hooks/useOutsideClick.d.ts +4 -3
  203. package/dist/types/excalidraw/hooks/useScrollPosition.d.ts +1 -2
  204. package/dist/types/excalidraw/i18n.d.ts +2 -2
  205. package/dist/types/excalidraw/index.d.ts +8 -7
  206. package/dist/types/excalidraw/renderer/animation.d.ts +12 -0
  207. package/dist/types/excalidraw/renderer/helpers.d.ts +6 -8
  208. package/dist/types/excalidraw/renderer/interactiveScene.d.ts +8 -14
  209. package/dist/types/excalidraw/scene/Renderer.d.ts +5 -2
  210. package/dist/types/excalidraw/scene/export.d.ts +2 -2
  211. package/dist/types/excalidraw/scene/scroll.d.ts +1 -6
  212. package/dist/types/excalidraw/scene/types.d.ts +22 -5
  213. package/dist/types/excalidraw/shortcut.d.ts +1 -0
  214. package/dist/types/excalidraw/snapping.d.ts +5 -5
  215. package/dist/types/excalidraw/subset/harfbuzz/harfbuzz-bindings.d.ts +1 -1
  216. package/dist/types/excalidraw/subset/harfbuzz/harfbuzz-loader.d.ts +1 -1
  217. package/dist/types/excalidraw/subset/harfbuzz/harfbuzz-wasm.d.ts +1 -1
  218. package/dist/types/excalidraw/subset/woff2/woff2-loader.d.ts +2 -2
  219. package/dist/types/excalidraw/subset/woff2/woff2-wasm.d.ts +1 -1
  220. package/dist/types/excalidraw/types.d.ts +34 -29
  221. package/dist/types/excalidraw/wysiwyg/textWysiwyg.d.ts +2 -2
  222. package/dist/types/math/src/point.d.ts +6 -1
  223. package/dist/types/math/src/polygon.d.ts +2 -2
  224. package/dist/types/math/src/range.d.ts +1 -3
  225. package/dist/types/math/src/segment.d.ts +3 -3
  226. package/dist/types/math/src/types.d.ts +25 -1
  227. package/dist/types/utils/src/bbox.d.ts +1 -1
  228. package/dist/types/utils/src/export.d.ts +5 -5
  229. package/dist/types/utils/src/shape.d.ts +6 -6
  230. package/dist/types/utils/src/withinBounds.d.ts +2 -2
  231. package/package.json +9 -3
  232. 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;
@@ -1,14 +1,5 @@
1
1
  import type { ExcalidrawElement, FontFamilyValues } from "@excalidraw/element/types";
2
2
  import type { AppProps, AppState } from "@excalidraw/excalidraw/types";
3
- export declare const isDarwin: boolean;
4
- export declare const isWindows: boolean;
5
- export declare const isAndroid: boolean;
6
- export declare const isFirefox: boolean;
7
- export declare const isChrome: boolean;
8
- export declare const isSafari: boolean;
9
- export declare const isIOS: boolean;
10
- export declare const isBrave: () => boolean;
11
- export declare const isMobile: boolean;
12
3
  export declare const supportsResizeObserver: boolean;
13
4
  export declare const APP_NAME = "Excalidraw";
14
5
  export declare const TEXT_AUTOWRAP_THRESHOLD = 36;
@@ -93,6 +84,14 @@ export declare const CLASSES: {
93
84
  SEARCH_MENU_INPUT_WRAPPER: string;
94
85
  CONVERT_ELEMENT_TYPE_POPUP: string;
95
86
  SHAPE_ACTIONS_THEME_SCOPE: string;
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;
96
95
  };
97
96
  export declare const CJK_HAND_DRAWN_FALLBACK_FONT = "Xiaolai";
98
97
  export declare const WINDOWS_EMOJI_FALLBACK_FONT = "Segoe UI Emoji";
@@ -133,17 +132,15 @@ export declare const THEME: {
133
132
  readonly LIGHT: "light";
134
133
  readonly DARK: "dark";
135
134
  };
135
+ export declare const DARK_THEME_FILTER = "invert(93%) hue-rotate(180deg)";
136
136
  export declare const FRAME_STYLE: {
137
- strokeColor: string;
138
- strokeWidth: number;
139
- strokeStyle: import("@excalidraw/element/types").StrokeStyle;
140
- fillStyle: import("@excalidraw/element/types").FillStyle;
141
- roughness: number;
142
- roundness: {
143
- type: import("@excalidraw/element/types").RoundnessType;
144
- value?: number | undefined;
145
- } | null;
146
- 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"];
147
144
  radius: number;
148
145
  nameOffsetY: number;
149
146
  nameColorLightTheme: string;
@@ -183,6 +180,7 @@ export declare const STRING_MIME_TYPES: {
183
180
  readonly html: "text/html";
184
181
  readonly json: "application/json";
185
182
  readonly excalidraw: "application/vnd.excalidraw+json";
183
+ readonly excalidrawClipboard: "application/vnd.excalidraw.clipboard+json";
186
184
  readonly excalidrawlib: "application/vnd.excalidrawlib+json";
187
185
  readonly excalidrawlibIds: "application/vnd.excalidrawlib.ids+json";
188
186
  };
@@ -203,6 +201,7 @@ export declare const MIME_TYPES: {
203
201
  readonly html: "text/html";
204
202
  readonly json: "application/json";
205
203
  readonly excalidraw: "application/vnd.excalidraw+json";
204
+ readonly excalidrawClipboard: "application/vnd.excalidraw.clipboard+json";
206
205
  readonly excalidrawlib: "application/vnd.excalidrawlib+json";
207
206
  readonly excalidrawlibIds: "application/vnd.excalidrawlib.ids+json";
208
207
  };
@@ -231,7 +230,6 @@ export declare const MAX_ZOOM = 30;
231
230
  export declare const HYPERLINK_TOOLTIP_DELAY = 300;
232
231
  export declare const IDLE_THRESHOLD = 60000;
233
232
  export declare const ACTIVE_THRESHOLD = 3000;
234
- export declare const THEME_FILTER = "invert(93%) hue-rotate(180deg)";
235
233
  export declare const URL_QUERY_KEYS: {
236
234
  readonly addLibrary: "addLibrary";
237
235
  };
@@ -239,13 +237,6 @@ export declare const URL_HASH_KEYS: {
239
237
  readonly addLibrary: "addLibrary";
240
238
  };
241
239
  export declare const DEFAULT_UI_OPTIONS: AppProps["UIOptions"];
242
- export declare const MQ_MAX_MOBILE = 599;
243
- export declare const MQ_MAX_WIDTH_LANDSCAPE = 1000;
244
- export declare const MQ_MAX_HEIGHT_LANDSCAPE = 500;
245
- export declare const MQ_MIN_TABLET: number;
246
- export declare const MQ_MAX_TABLET = 1400;
247
- export declare const MQ_MIN_WIDTH_DESKTOP = 1440;
248
- export declare const MQ_RIGHT_SIDEBAR_MIN_WIDTH = 1229;
249
240
  export declare const MAX_DECIMALS_FOR_SVG_EXPORT = 2;
250
241
  export declare const EXPORT_SCALES: number[];
251
242
  export declare const DEFAULT_EXPORT_PADDING = 10;
@@ -358,6 +349,7 @@ export declare enum UserIdleState {
358
349
  */
359
350
  export declare const LINE_POLYGON_POINT_MERGE_DISTANCE = 20;
360
351
  export declare const DOUBLE_TAP_POSITION_THRESHOLD = 35;
352
+ export declare const BIND_MODE_TIMEOUT = 700;
361
353
  export declare const MOBILE_ACTION_BUTTON_BG: {
362
354
  readonly background: "var(--mobile-action-button-bg)";
363
355
  };
@@ -0,0 +1,34 @@
1
+ export type StylesPanelMode = "compact" | "full" | "mobile";
2
+ export type EditorInterface = Readonly<{
3
+ formFactor: "phone" | "tablet" | "desktop";
4
+ desktopUIMode: "compact" | "full";
5
+ userAgent: Readonly<{
6
+ isMobileDevice: boolean;
7
+ platform: "ios" | "android" | "other" | "unknown";
8
+ }>;
9
+ isTouchScreen: boolean;
10
+ canFitSidebar: boolean;
11
+ isLandscape: boolean;
12
+ }>;
13
+ export declare const MQ_MAX_MOBILE = 599;
14
+ export declare const MQ_MAX_WIDTH_LANDSCAPE = 1000;
15
+ export declare const MQ_MAX_HEIGHT_LANDSCAPE = 500;
16
+ export declare const MQ_MIN_TABLET: number;
17
+ export declare const MQ_MAX_TABLET = 1180;
18
+ export declare const MQ_MIN_WIDTH_DESKTOP = 1440;
19
+ export declare const MQ_RIGHT_SIDEBAR_MIN_WIDTH = 1229;
20
+ export declare const isDarwin: boolean;
21
+ export declare const isWindows: boolean;
22
+ export declare const isAndroid: boolean;
23
+ export declare const isFirefox: boolean;
24
+ export declare const isChrome: boolean;
25
+ export declare const isSafari: boolean;
26
+ export declare const isIOS: boolean;
27
+ export declare const isBrave: () => boolean;
28
+ export declare const isMobileBreakpoint: (width: number, height: number) => boolean;
29
+ export declare const isTabletBreakpoint: (editorWidth: number, editorHeight: number) => boolean;
30
+ export declare const getFormFactor: (editorWidth: number, editorHeight: number) => EditorInterface["formFactor"];
31
+ export declare const deriveStylesPanelMode: (editorInterface: EditorInterface) => StylesPanelMode;
32
+ export declare const createUserAgentDescriptor: (userAgentString: string) => EditorInterface["userAgent"];
33
+ export declare const loadDesktopUIModePreference: () => "compact" | "full" | null;
34
+ export declare const setDesktopUIMode: (mode: EditorInterface["desktopUIMode"]) => "compact" | "full" | undefined;
@@ -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,3 +11,5 @@ export * from "./random";
10
11
  export * from "./url";
11
12
  export * from "./utils";
12
13
  export * from "./emitter";
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 { ExcalidrawBindableElement, FontFamilyValues, FontString } from "@excalidraw/element/types";
1
+ import type { GlobalCoord } from "@excalidraw/math";
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,17 +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;
88
+ export declare const isSelectionLikeTool: (type: ToolType | "custom") => type is "selection" | "lasso";
85
89
  export declare const updateActiveTool: (appState: Pick<AppState, "activeTool">, data: (({
86
90
  type: ToolType;
87
91
  } | {
@@ -96,7 +100,6 @@ export declare const updateActiveTool: (appState: Pick<AppState, "activeTool">,
96
100
  export declare const isFullScreen: () => boolean;
97
101
  export declare const allowFullScreen: () => Promise<void>;
98
102
  export declare const exitFullScreen: () => Promise<void>;
99
- export declare const getShortcutKey: (shortcut: string) => string;
100
103
  export declare const viewportCoordsToSceneCoords: ({ clientX, clientY }: {
101
104
  clientX: number;
102
105
  clientY: number;
@@ -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,9 +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;
145
- export declare const isBindingFallthroughEnabled: (el: ExcalidrawBindableElement) => boolean;
143
+ export declare const mapFind: <T, K>(collection: readonly T[], iteratee: (value: T, index: number) => K | undefined | null) => K | undefined;
146
144
  export type ResolvablePromise<T> = Promise<T> & {
147
145
  resolve: [T] extends [undefined] ? (value?: MaybePromise<Awaited<T>>) => void : (value: MaybePromise<Awaited<T>>) => void;
148
146
  reject: (error: Error) => void;
@@ -160,16 +158,16 @@ export declare const getUpdatedTimestamp: () => number;
160
158
  * Transforms array of objects containing `id` attribute,
161
159
  * or array of ids (strings), into a Map, keyd by `id`.
162
160
  */
163
- export declare const arrayToMap: <T extends string | {
161
+ export declare const arrayToMap: <T extends {
164
162
  id: string;
165
- }>(items: Map<string, T> | readonly T[]) => Map<string, T>;
163
+ } | string>(items: readonly T[] | Map<string, T>) => Map<string, T>;
166
164
  export declare const arrayToMapWithIndex: <T extends {
167
165
  id: string;
168
166
  }>(elements: readonly T[]) => Map<string, [element: T, index: number]>;
169
167
  /**
170
168
  * Transform array into an object, use only when array order is irrelevant.
171
169
  */
172
- 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) => {
173
171
  [key: string]: T;
174
172
  };
175
173
  /** Doubly linked node */
@@ -185,11 +183,11 @@ export declare const arrayToList: <T>(array: readonly T[]) => Node<T>[];
185
183
  * Converts a readonly array or map into an iterable.
186
184
  * Useful for avoiding entry allocations when iterating object / map on each iteration.
187
185
  */
188
- 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>;
189
187
  /**
190
188
  * Converts a readonly array or map into an array.
191
189
  */
192
- 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[];
193
191
  export declare const isTestEnv: () => boolean;
194
192
  export declare const isDevEnv: () => boolean;
195
193
  export declare const isProdEnv: () => boolean;
@@ -201,18 +199,18 @@ export declare const updateObject: <T extends Record<string, any>>(obj: T, updat
201
199
  export declare const isPrimitive: (val: any) => boolean;
202
200
  export declare const getFrame: () => "top" | "iframe";
203
201
  export declare const isRunningInIframe: () => boolean;
204
- export declare const isPromiseLike: (value: any) => value is Promise<any>;
202
+ export declare const isPromiseLike: (value: any) => value is Promise<ResolutionType<typeof value>>;
205
203
  export declare const queryFocusableElements: (container: HTMLElement | null) => HTMLElement[];
206
204
  /**
207
205
  * Returns whether object/array is shallow equal.
208
206
  * Considers empty object/arrays as equal (whether top-level or second-level).
209
207
  */
210
- 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 : {
211
209
  _error: "keys are either missing or include keys not in compared obj";
212
210
  } : {
213
211
  _error: "keys are either missing or include keys not in compared obj";
214
- }) | undefined, debug?: boolean) => boolean;
215
- 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 }?: {
216
214
  checkForDefaultPrevented?: boolean | undefined;
217
215
  }) => (event: E) => void;
218
216
  /**
@@ -224,11 +222,15 @@ export declare function invariant(condition: any, message: string): asserts cond
224
222
  /**
225
223
  * Memoizes on values of `opts` object (strict equality).
226
224
  */
227
- 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 & {
228
226
  clear: () => void;
229
227
  };
230
228
  /** Checks if value is inside given collection. Useful for type-safety. */
231
- 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;
232
234
  export declare const cloneJSON: <T>(obj: T) => T;
233
235
  export declare const updateStable: <T extends any[] | Record<string, any>>(prevValue: T, nextValue: T) => T;
234
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;
@@ -239,21 +241,25 @@ export declare function addEventListener<K extends keyof FontFaceSetEventMap>(ta
239
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;
240
242
  export declare function getSvgPathFromStroke(points: number[][], closed?: boolean): string;
241
243
  export declare const normalizeEOL: (str: string) => string;
242
- type HasBrand<T> = {
243
- [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;
244
246
  }[keyof T];
245
247
  type RemoveAllBrands<T> = HasBrand<T> extends true ? {
246
- [K in keyof T as K extends `~brand~${infer _}` ? never : K]: T[K];
247
- } : never;
248
- 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[];
249
254
  /**
250
255
  * Makes type into a branded type, ensuring that value is assignable to
251
- * the base ubranded type. Optionally you can explicitly supply current value
256
+ * the base unbranded type. Optionally you can explicitly supply current value
252
257
  * type to combine both (useful for composite branded types. Make sure you
253
258
  * compose branded types which are not composite themselves.)
254
259
  */
255
- export declare const toBrandedType: <BrandedType, CurrentType = BrandedType>(value: Unbrand<BrandedType>) => CurrentType & BrandedType;
256
- 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>;
257
263
  export declare const isAnyTrue: (...args: boolean[]) => boolean;
258
264
  export declare const safelyParseJSON: (json: string) => Record<string, any> | null;
259
265
  /**
@@ -265,6 +271,11 @@ export declare const castArray: <T>(value: T | T[]) => T[];
265
271
  /** hack for Array.isArray type guard not working with readonly value[] */
266
272
  export declare const isReadonlyArray: (value?: any) => value is readonly any[];
267
273
  export declare const sizeOf: (value: readonly unknown[] | Readonly<Map<string, unknown>> | Readonly<Record<string, unknown>> | ReadonlySet<unknown>) => number;
268
- export declare const reduceToCommonValue: <T, R = T>(collection: ReadonlySet<T> | readonly T[], getValue?: ((item: T) => R) | undefined) => R | null;
269
- export declare const isMobileOrTablet: () => boolean;
274
+ export declare const reduceToCommonValue: <T, R = T>(collection: readonly T[] | ReadonlySet<T>, getValue?: (item: T) => R) => R | null;
275
+ type FEATURE_FLAGS = {
276
+ COMPLEX_BINDINGS: boolean;
277
+ };
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;
270
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?: {
@@ -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;