@excalidraw/common 0.18.0-b9d27d3 → 0.18.0-c158187

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (202) hide show
  1. package/dist/dev/index.js +1390 -59
  2. package/dist/dev/index.js.map +4 -4
  3. package/dist/prod/index.js +3 -3
  4. package/dist/types/common/src/bounds.d.ts +10 -0
  5. package/dist/types/common/src/colors.d.ts +5 -2
  6. package/dist/types/common/src/constants.d.ts +23 -25
  7. package/dist/types/common/src/editorInterface.d.ts +34 -0
  8. package/dist/types/common/src/font-metadata.d.ts +1 -3
  9. package/dist/types/common/src/index.d.ts +3 -0
  10. package/dist/types/common/src/keys.d.ts +1 -1
  11. package/dist/types/common/src/utility-types.d.ts +0 -1
  12. package/dist/types/common/src/utils.d.ts +50 -34
  13. package/dist/types/common/src/visualdebug.d.ts +41 -0
  14. package/dist/types/element/src/Scene.d.ts +4 -4
  15. package/dist/types/element/src/binding.d.ts +58 -44
  16. package/dist/types/element/src/bounds.d.ts +2 -10
  17. package/dist/types/element/src/collision.d.ts +6 -2
  18. package/dist/types/element/src/comparisons.d.ts +7 -7
  19. package/dist/types/element/src/dragElements.d.ts +3 -3
  20. package/dist/types/element/src/duplicate.d.ts +3 -3
  21. package/dist/types/element/src/fractionalIndex.d.ts +2 -2
  22. package/dist/types/element/src/frame.d.ts +7 -3
  23. package/dist/types/element/src/heading.d.ts +2 -1
  24. package/dist/types/element/src/image.d.ts +1 -11
  25. package/dist/types/element/src/index.d.ts +1 -3
  26. package/dist/types/element/src/linearElementEditor.d.ts +16 -20
  27. package/dist/types/element/src/mutateElement.d.ts +3 -1
  28. package/dist/types/element/src/newElement.d.ts +6 -6
  29. package/dist/types/element/src/renderElement.d.ts +4 -7
  30. package/dist/types/element/src/resizeElements.d.ts +10 -10
  31. package/dist/types/element/src/resizeTest.d.ts +6 -5
  32. package/dist/types/element/src/selection.d.ts +3 -7
  33. package/dist/types/element/src/shape.d.ts +8 -7
  34. package/dist/types/element/src/textMeasurements.d.ts +1 -3
  35. package/dist/types/{excalidraw/data → element/src}/transform.d.ts +3 -3
  36. package/dist/types/element/src/transformHandles.d.ts +8 -27
  37. package/dist/types/element/src/typeChecks.d.ts +4 -7
  38. package/dist/types/element/src/types.d.ts +7 -11
  39. package/dist/types/element/src/utils.d.ts +5 -2
  40. package/dist/types/element/src/zindex.d.ts +7 -1
  41. package/dist/types/excalidraw/actions/actionAddToLibrary.d.ts +138 -181
  42. package/dist/types/excalidraw/actions/actionAlign.d.ts +6 -7
  43. package/dist/types/excalidraw/actions/actionBoundText.d.ts +67 -96
  44. package/dist/types/excalidraw/actions/actionCanvas.d.ts +401 -771
  45. package/dist/types/excalidraw/actions/actionClipboard.d.ts +103 -873
  46. package/dist/types/excalidraw/actions/actionCropEditor.d.ts +32 -47
  47. package/dist/types/excalidraw/actions/actionDeleteSelected.d.ts +110 -159
  48. package/dist/types/excalidraw/actions/actionDistribute.d.ts +2 -3
  49. package/dist/types/excalidraw/actions/actionDuplicateSelection.d.ts +3 -4
  50. package/dist/types/excalidraw/actions/actionElementLink.d.ts +47 -64
  51. package/dist/types/excalidraw/actions/actionElementLock.d.ts +66 -95
  52. package/dist/types/excalidraw/actions/actionEmbeddable.d.ts +49 -64
  53. package/dist/types/excalidraw/actions/actionExport.d.ts +144 -1104
  54. package/dist/types/excalidraw/actions/actionFinalize.d.ts +10 -394
  55. package/dist/types/excalidraw/actions/actionFlip.d.ts +2 -3
  56. package/dist/types/excalidraw/actions/actionFrame.d.ts +252 -347
  57. package/dist/types/excalidraw/actions/actionGroup.d.ts +70 -107
  58. package/dist/types/excalidraw/actions/actionLinearEditor.d.ts +165 -220
  59. package/dist/types/excalidraw/actions/actionLink.d.ts +49 -64
  60. package/dist/types/excalidraw/actions/actionMenu.d.ts +42 -425
  61. package/dist/types/excalidraw/actions/actionNavigate.d.ts +18 -359
  62. package/dist/types/excalidraw/actions/actionProperties.d.ts +129 -2488
  63. package/dist/types/excalidraw/actions/actionSelectAll.d.ts +35 -54
  64. package/dist/types/excalidraw/actions/actionStyles.d.ts +32 -47
  65. package/dist/types/excalidraw/actions/actionTextAutoResize.d.ts +3 -3
  66. package/dist/types/excalidraw/actions/actionToggleGridMode.d.ts +49 -64
  67. package/dist/types/excalidraw/actions/actionToggleObjectsSnapMode.d.ts +49 -64
  68. package/dist/types/excalidraw/actions/actionToggleSearchMenu.d.ts +41 -58
  69. package/dist/types/excalidraw/actions/actionToggleShapeSwitch.d.ts +1 -1
  70. package/dist/types/excalidraw/actions/actionToggleStats.d.ts +48 -63
  71. package/dist/types/excalidraw/actions/actionToggleViewMode.d.ts +49 -64
  72. package/dist/types/excalidraw/actions/actionToggleZenMode.d.ts +49 -64
  73. package/dist/types/excalidraw/actions/actionZindex.d.ts +8 -9
  74. package/dist/types/excalidraw/actions/index.d.ts +2 -2
  75. package/dist/types/excalidraw/actions/register.d.ts +2 -2
  76. package/dist/types/excalidraw/actions/types.d.ts +4 -4
  77. package/dist/types/excalidraw/appState.d.ts +20 -15
  78. package/dist/types/excalidraw/clipboard.d.ts +7 -29
  79. package/dist/types/excalidraw/components/Actions.d.ts +22 -5
  80. package/dist/types/excalidraw/components/App.d.ts +58 -59
  81. package/dist/types/excalidraw/components/Card.d.ts +0 -1
  82. package/dist/types/excalidraw/components/ColorPicker/ColorInput.d.ts +7 -4
  83. package/dist/types/excalidraw/components/ColorPicker/ColorPicker.d.ts +0 -1
  84. package/dist/types/excalidraw/components/ColorPicker/Picker.d.ts +2 -0
  85. package/dist/types/excalidraw/components/ColorPicker/PickerColorList.d.ts +2 -1
  86. package/dist/types/excalidraw/components/ColorPicker/ShadeList.d.ts +2 -1
  87. package/dist/types/excalidraw/components/ColorPicker/keyboardNavHandlers.d.ts +0 -1
  88. package/dist/types/excalidraw/components/CommandPalette/CommandPalette.d.ts +1 -0
  89. package/dist/types/excalidraw/components/CommandPalette/types.d.ts +1 -3
  90. package/dist/types/excalidraw/components/ConvertElementTypePopup.d.ts +2 -2
  91. package/dist/types/excalidraw/components/DarkModeToggle.d.ts +1 -1
  92. package/dist/types/excalidraw/components/DefaultSidebar.d.ts +9 -13
  93. package/dist/types/excalidraw/components/ElementLinkDialog.d.ts +1 -1
  94. package/dist/types/excalidraw/components/Ellipsify.d.ts +1 -2
  95. package/dist/types/excalidraw/components/ErrorDialog.d.ts +1 -1
  96. package/dist/types/excalidraw/components/ExcalidrawLogo.d.ts +1 -2
  97. package/dist/types/excalidraw/components/EyeDropper.d.ts +0 -1
  98. package/dist/types/excalidraw/components/FilledButton.d.ts +1 -1
  99. package/dist/types/excalidraw/components/FontPicker/FontPicker.d.ts +2 -1
  100. package/dist/types/excalidraw/components/FontPicker/FontPickerTrigger.d.ts +3 -1
  101. package/dist/types/excalidraw/components/FontPicker/keyboardNavHandlers.d.ts +0 -1
  102. package/dist/types/excalidraw/components/HelpDialog.d.ts +1 -1
  103. package/dist/types/excalidraw/components/HintViewer.d.ts +4 -3
  104. package/dist/types/excalidraw/components/InlineIcon.d.ts +3 -1
  105. package/dist/types/excalidraw/components/LayerUI.d.ts +2 -1
  106. package/dist/types/excalidraw/components/LibraryMenuControlButtons.d.ts +1 -1
  107. package/dist/types/excalidraw/components/LibraryMenuHeaderContent.d.ts +1 -2
  108. package/dist/types/excalidraw/components/LibraryMenuSection.d.ts +1 -1
  109. package/dist/types/excalidraw/components/LibraryUnit.d.ts +2 -3
  110. package/dist/types/excalidraw/components/LoadingMessage.d.ts +0 -1
  111. package/dist/types/excalidraw/components/MobileMenu.d.ts +3 -5
  112. package/dist/types/excalidraw/components/MobileToolBar.d.ts +10 -0
  113. package/dist/types/excalidraw/components/Modal.d.ts +0 -1
  114. package/dist/types/excalidraw/components/OverwriteConfirm/OverwriteConfirm.d.ts +1 -1
  115. package/dist/types/excalidraw/components/Popover.d.ts +2 -1
  116. package/dist/types/excalidraw/components/PropertiesPopover.d.ts +1 -0
  117. package/dist/types/excalidraw/components/RadioGroup.d.ts +0 -1
  118. package/dist/types/excalidraw/components/RadioSelection.d.ts +4 -4
  119. package/dist/types/excalidraw/components/ScrollableList.d.ts +0 -1
  120. package/dist/types/excalidraw/components/Sidebar/Sidebar.d.ts +15 -21
  121. package/dist/types/excalidraw/components/Sidebar/SidebarHeader.d.ts +1 -1
  122. package/dist/types/excalidraw/components/Sidebar/SidebarTab.d.ts +1 -2
  123. package/dist/types/excalidraw/components/Sidebar/SidebarTabTrigger.d.ts +1 -2
  124. package/dist/types/excalidraw/components/Sidebar/SidebarTabTriggers.d.ts +1 -2
  125. package/dist/types/excalidraw/components/Sidebar/SidebarTabs.d.ts +1 -2
  126. package/dist/types/excalidraw/components/Spinner.d.ts +4 -4
  127. package/dist/types/excalidraw/components/Stats/CanvasGrid.d.ts +0 -1
  128. package/dist/types/excalidraw/components/Stats/Collapsible.d.ts +0 -1
  129. package/dist/types/excalidraw/components/Stats/DragInput.d.ts +0 -1
  130. package/dist/types/excalidraw/components/Stats/index.d.ts +7 -8
  131. package/dist/types/excalidraw/components/Stats/utils.d.ts +1 -1
  132. package/dist/types/excalidraw/components/TTDDialog/TTDDialog.d.ts +1 -2
  133. package/dist/types/excalidraw/components/TTDDialog/TTDDialogOutput.d.ts +0 -1
  134. package/dist/types/excalidraw/components/TTDDialog/TTDDialogTab.d.ts +1 -2
  135. package/dist/types/excalidraw/components/TTDDialog/TTDDialogTabTrigger.d.ts +1 -2
  136. package/dist/types/excalidraw/components/TTDDialog/TTDDialogTabTriggers.d.ts +1 -2
  137. package/dist/types/excalidraw/components/TTDDialog/TTDDialogTrigger.d.ts +2 -3
  138. package/dist/types/excalidraw/components/TTDDialog/common.d.ts +2 -3
  139. package/dist/types/excalidraw/components/TextField.d.ts +1 -0
  140. package/dist/types/excalidraw/components/Toast.d.ts +3 -3
  141. package/dist/types/excalidraw/components/ToolPopover.d.ts +25 -0
  142. package/dist/types/excalidraw/components/Trans.d.ts +2 -2
  143. package/dist/types/excalidraw/components/canvases/InteractiveCanvas.d.ts +6 -3
  144. package/dist/types/excalidraw/components/dropdownMenu/DropdownMenu.d.ts +30 -32
  145. package/dist/types/excalidraw/components/dropdownMenu/DropdownMenuContent.d.ts +6 -5
  146. package/dist/types/excalidraw/components/dropdownMenu/DropdownMenuGroup.d.ts +3 -3
  147. package/dist/types/excalidraw/components/dropdownMenu/DropdownMenuItem.d.ts +10 -18
  148. package/dist/types/excalidraw/components/dropdownMenu/DropdownMenuItemContent.d.ts +3 -3
  149. package/dist/types/excalidraw/components/dropdownMenu/DropdownMenuItemContentRadio.d.ts +0 -1
  150. package/dist/types/excalidraw/components/dropdownMenu/DropdownMenuItemCustom.d.ts +2 -2
  151. package/dist/types/excalidraw/components/dropdownMenu/DropdownMenuItemLink.d.ts +6 -6
  152. package/dist/types/excalidraw/components/dropdownMenu/DropdownMenuTrigger.d.ts +3 -4
  153. package/dist/types/excalidraw/components/dropdownMenu/common.d.ts +1 -1
  154. package/dist/types/excalidraw/components/hoc/withInternalFallback.d.ts +1 -1
  155. package/dist/types/excalidraw/components/hyperlink/helpers.d.ts +1 -1
  156. package/dist/types/excalidraw/components/icons.d.ts +21 -11
  157. package/dist/types/excalidraw/components/live-collaboration/LiveCollaborationTrigger.d.ts +4 -3
  158. package/dist/types/excalidraw/components/main-menu/DefaultItems.d.ts +2 -2
  159. package/dist/types/excalidraw/components/main-menu/MainMenu.d.ts +25 -30
  160. package/dist/types/excalidraw/components/shapes.d.ts +1 -1
  161. package/dist/types/excalidraw/components/welcome-screen/WelcomeScreen.Center.d.ts +6 -6
  162. package/dist/types/excalidraw/components/welcome-screen/WelcomeScreen.d.ts +15 -16
  163. package/dist/types/excalidraw/data/blob.d.ts +323 -5
  164. package/dist/types/excalidraw/data/encode.d.ts +4 -4
  165. package/dist/types/excalidraw/data/encryption.d.ts +5 -5
  166. package/dist/types/excalidraw/data/filesystem.d.ts +2 -2
  167. package/dist/types/excalidraw/data/index.d.ts +3 -3
  168. package/dist/types/excalidraw/data/json.d.ts +159 -2
  169. package/dist/types/excalidraw/data/library.d.ts +24 -9
  170. package/dist/types/excalidraw/data/restore.d.ts +25 -10
  171. package/dist/types/excalidraw/data/types.d.ts +4 -1
  172. package/dist/types/excalidraw/editor-jotai.d.ts +11 -11
  173. package/dist/types/excalidraw/hooks/useLibraryItemSvg.d.ts +1 -1
  174. package/dist/types/excalidraw/hooks/useOutsideClick.d.ts +4 -3
  175. package/dist/types/excalidraw/hooks/useScrollPosition.d.ts +1 -2
  176. package/dist/types/excalidraw/hooks/useTextEditorFocus.d.ts +14 -0
  177. package/dist/types/excalidraw/i18n.d.ts +2 -2
  178. package/dist/types/excalidraw/index.d.ts +4 -7
  179. package/dist/types/excalidraw/renderer/animation.d.ts +12 -0
  180. package/dist/types/excalidraw/renderer/helpers.d.ts +6 -8
  181. package/dist/types/excalidraw/renderer/interactiveScene.d.ts +8 -14
  182. package/dist/types/excalidraw/scene/Renderer.d.ts +5 -2
  183. package/dist/types/excalidraw/scene/export.d.ts +2 -2
  184. package/dist/types/excalidraw/scene/scroll.d.ts +1 -6
  185. package/dist/types/excalidraw/scene/types.d.ts +22 -5
  186. package/dist/types/excalidraw/shortcut.d.ts +1 -0
  187. package/dist/types/excalidraw/snapping.d.ts +5 -5
  188. package/dist/types/excalidraw/subset/harfbuzz/harfbuzz-bindings.d.ts +1 -1
  189. package/dist/types/excalidraw/subset/harfbuzz/harfbuzz-loader.d.ts +1 -1
  190. package/dist/types/excalidraw/subset/harfbuzz/harfbuzz-wasm.d.ts +1 -1
  191. package/dist/types/excalidraw/subset/woff2/woff2-loader.d.ts +2 -2
  192. package/dist/types/excalidraw/subset/woff2/woff2-wasm.d.ts +1 -1
  193. package/dist/types/excalidraw/types.d.ts +31 -21
  194. package/dist/types/excalidraw/wysiwyg/textWysiwyg.d.ts +2 -2
  195. package/dist/types/math/src/polygon.d.ts +2 -2
  196. package/dist/types/math/src/range.d.ts +1 -3
  197. package/dist/types/math/src/segment.d.ts +4 -3
  198. package/dist/types/utils/src/bbox.d.ts +1 -1
  199. package/dist/types/utils/src/export.d.ts +5 -5
  200. package/dist/types/utils/src/shape.d.ts +6 -6
  201. package/dist/types/utils/src/withinBounds.d.ts +2 -2
  202. package/package.json +7 -1
@@ -1,8 +1,7 @@
1
- import type { IMAGE_MIME_TYPES, UserIdleState, throttleRAF, MIME_TYPES } from "@excalidraw/common";
2
- import type { SuggestedBinding } from "@excalidraw/element";
1
+ import type { IMAGE_MIME_TYPES, UserIdleState, throttleRAF, MIME_TYPES, EditorInterface } from "@excalidraw/common";
3
2
  import type { LinearElementEditor } from "@excalidraw/element";
4
3
  import type { MaybeTransformHandleType } from "@excalidraw/element";
5
- import type { PointerType, ExcalidrawLinearElement, NonDeletedExcalidrawElement, NonDeleted, TextAlign, ExcalidrawElement, GroupId, ExcalidrawBindableElement, Arrowhead, ChartType, FontFamilyValues, FileId, Theme, StrokeRoundness, ExcalidrawEmbeddableElement, ExcalidrawMagicFrameElement, ExcalidrawFrameLikeElement, ExcalidrawElementType, ExcalidrawIframeLikeElement, OrderedExcalidrawElement, ExcalidrawNonSelectionElement } from "@excalidraw/element/types";
4
+ import type { PointerType, ExcalidrawLinearElement, NonDeletedExcalidrawElement, NonDeleted, TextAlign, ExcalidrawElement, GroupId, ExcalidrawBindableElement, Arrowhead, ChartType, FontFamilyValues, FileId, Theme, StrokeRoundness, ExcalidrawEmbeddableElement, ExcalidrawMagicFrameElement, ExcalidrawFrameLikeElement, ExcalidrawElementType, ExcalidrawIframeLikeElement, OrderedExcalidrawElement, ExcalidrawNonSelectionElement, BindMode } from "@excalidraw/element/types";
6
5
  import type { Merge, MaybePromise, ValueOf, MakeBrand } from "@excalidraw/common/utility-types";
7
6
  import type { CaptureUpdateActionType, DurableIncrement, EphemeralIncrement } from "@excalidraw/element";
8
7
  import type { Action } from "./actions/types";
@@ -125,6 +124,7 @@ export type StaticCanvasAppState = Readonly<_CommonCanvasAppState & {
125
124
  frameRendering: AppState["frameRendering"];
126
125
  currentHoveredFontFamily: AppState["currentHoveredFontFamily"];
127
126
  hoveredElementIds: AppState["hoveredElementIds"];
127
+ suggestedBinding: AppState["suggestedBinding"];
128
128
  croppingElementId: AppState["croppingElementId"];
129
129
  }>;
130
130
  export type InteractiveCanvasAppState = Readonly<_CommonCanvasAppState & {
@@ -133,8 +133,9 @@ export type InteractiveCanvasAppState = Readonly<_CommonCanvasAppState & {
133
133
  selectedGroupIds: AppState["selectedGroupIds"];
134
134
  selectedLinearElement: AppState["selectedLinearElement"];
135
135
  multiElement: AppState["multiElement"];
136
+ newElement: AppState["newElement"];
136
137
  isBindingEnabled: AppState["isBindingEnabled"];
137
- suggestedBindings: AppState["suggestedBindings"];
138
+ suggestedBinding: AppState["suggestedBinding"];
138
139
  isRotating: AppState["isRotating"];
139
140
  elementsToHighlight: AppState["elementsToHighlight"];
140
141
  collaborators: AppState["collaborators"];
@@ -145,6 +146,10 @@ export type InteractiveCanvasAppState = Readonly<_CommonCanvasAppState & {
145
146
  croppingElementId: AppState["croppingElementId"];
146
147
  searchMatches: AppState["searchMatches"];
147
148
  activeLockedId: AppState["activeLockedId"];
149
+ hoveredElementIds: AppState["hoveredElementIds"];
150
+ frameRendering: AppState["frameRendering"];
151
+ shouldCacheIgnoreZoom: AppState["shouldCacheIgnoreZoom"];
152
+ exportScale: AppState["exportScale"];
148
153
  }>;
149
154
  export type ObservedAppState = ObservedStandaloneAppState & ObservedElementsAppState;
150
155
  export type ObservedStandaloneAppState = {
@@ -198,7 +203,7 @@ export interface AppState {
198
203
  selectionElement: NonDeletedExcalidrawElement | null;
199
204
  isBindingEnabled: boolean;
200
205
  startBoundElement: NonDeleted<ExcalidrawBindableElement> | null;
201
- suggestedBindings: SuggestedBinding[];
206
+ suggestedBinding: NonDeleted<ExcalidrawBindableElement> | null;
202
207
  frameToHighlight: NonDeleted<ExcalidrawFrameLikeElement> | null;
203
208
  frameRendering: {
204
209
  enabled: boolean;
@@ -221,6 +226,10 @@ export interface AppState {
221
226
  locked: boolean;
222
227
  fromSelection: boolean;
223
228
  } & ActiveTool;
229
+ preferredSelectionTool: {
230
+ type: "selection" | "lasso";
231
+ initialized: boolean;
232
+ };
224
233
  penMode: boolean;
225
234
  penDetected: boolean;
226
235
  exportBackground: boolean;
@@ -251,8 +260,8 @@ export interface AppState {
251
260
  isResizing: boolean;
252
261
  isRotating: boolean;
253
262
  zoom: Zoom;
254
- openMenu: "canvas" | "shape" | null;
255
- openPopup: "canvasBackground" | "elementBackground" | "elementStroke" | "fontFamily" | null;
263
+ openMenu: "canvas" | null;
264
+ openPopup: "canvasBackground" | "elementBackground" | "elementStroke" | "fontFamily" | "compactTextProperties" | "compactStrokeStyles" | "compactOtherProperties" | "compactArrowProperties" | null;
256
265
  openSidebar: {
257
266
  name: SidebarName;
258
267
  tab?: SidebarTabName;
@@ -264,6 +273,8 @@ export interface AppState {
264
273
  tab: "text-to-diagram" | "mermaid";
265
274
  } | {
266
275
  name: "commandPalette";
276
+ } | {
277
+ name: "settings";
267
278
  } | {
268
279
  name: "elementLinkSelector";
269
280
  sourceElementId: ExcalidrawElement["id"];
@@ -351,6 +362,7 @@ export interface AppState {
351
362
  lockedMultiSelections: {
352
363
  [groupId: string]: true;
353
364
  };
365
+ bindMode: BindMode;
354
366
  }
355
367
  export type SearchMatch = {
356
368
  id: string;
@@ -363,7 +375,7 @@ export type SearchMatch = {
363
375
  showOnCanvas: boolean;
364
376
  }[];
365
377
  };
366
- export type UIAppState = Omit<AppState, "suggestedBindings" | "startBoundElement" | "cursorButton" | "scrollX" | "scrollY">;
378
+ export type UIAppState = Omit<AppState, "startBoundElement" | "cursorButton" | "scrollX" | "scrollY">;
367
379
  export type NormalizedZoomValue = number & {
368
380
  _brand: "normalizedZoom";
369
381
  };
@@ -441,6 +453,7 @@ export interface ExcalidrawProps {
441
453
  onDuplicate?: (nextElements: readonly ExcalidrawElement[],
442
454
  /** excludes the duplicated elements */
443
455
  prevElements: readonly ExcalidrawElement[]) => ExcalidrawElement[] | void;
456
+ renderTopLeftUI?: (isMobile: boolean, appState: UIAppState) => JSX.Element | null;
444
457
  renderTopRightUI?: (isMobile: boolean, appState: UIAppState) => JSX.Element | null;
445
458
  langCode?: Language["code"];
446
459
  viewModeEnabled?: boolean;
@@ -498,6 +511,12 @@ export type UIOptions = Partial<{
498
511
  tools: {
499
512
  image: boolean;
500
513
  };
514
+ /**
515
+ * Optionally control the editor form factor and desktop UI mode from the host app.
516
+ * If not provided, we will take care of it internally.
517
+ */
518
+ formFactor?: EditorInterface["formFactor"];
519
+ desktopUIMode?: EditorInterface["desktopUIMode"];
501
520
  /** @deprecated does nothing. Will be removed in 0.15 */
502
521
  welcomeScreen?: boolean;
503
522
  }>;
@@ -528,7 +547,7 @@ export type AppClassProperties = {
528
547
  mimeType: ValueOf<typeof IMAGE_MIME_TYPES>;
529
548
  }>;
530
549
  files: BinaryFiles;
531
- device: App["device"];
550
+ editorInterface: App["editorInterface"];
532
551
  scene: App["scene"];
533
552
  syncActionResult: App["syncActionResult"];
534
553
  fonts: App["fonts"];
@@ -557,7 +576,8 @@ export type AppClassProperties = {
557
576
  excalidrawContainerValue: App["excalidrawContainerValue"];
558
577
  onPointerUpEmitter: App["onPointerUpEmitter"];
559
578
  updateEditorAtom: App["updateEditorAtom"];
560
- defaultSelectionTool: "selection" | "lasso";
579
+ onPointerDownEmitter: App["onPointerDownEmitter"];
580
+ bindModeHandler: App["bindModeHandler"];
561
581
  };
562
582
  export type PointerDownState = Readonly<{
563
583
  origin: Readonly<{
@@ -643,6 +663,7 @@ export interface ExcalidrawImperativeAPI {
643
663
  setCursor: InstanceType<typeof App>["setCursor"];
644
664
  resetCursor: InstanceType<typeof App>["resetCursor"];
645
665
  toggleSidebar: InstanceType<typeof App>["toggleSidebar"];
666
+ getEditorInterface: () => EditorInterface;
646
667
  /**
647
668
  * Disables rendering of frames (including element clipping), but currently
648
669
  * the frames are still interactive in edit mode. As such, this API should be
@@ -656,17 +677,6 @@ export interface ExcalidrawImperativeAPI {
656
677
  onScrollChange: (callback: (scrollX: number, scrollY: number, zoom: Zoom) => void) => UnsubscribeCallback;
657
678
  onUserFollow: (callback: (payload: OnUserFollowedPayload) => void) => UnsubscribeCallback;
658
679
  }
659
- export type Device = Readonly<{
660
- viewport: {
661
- isMobile: boolean;
662
- isLandscape: boolean;
663
- };
664
- editor: {
665
- isMobile: boolean;
666
- canFitSidebar: boolean;
667
- };
668
- isTouchScreen: boolean;
669
- }>;
670
680
  export type FrameNameBounds = {
671
681
  x: number;
672
682
  y: number;
@@ -9,7 +9,7 @@ export declare const textWysiwyg: ({ id, onChange, onSubmit, getViewportCoords,
9
9
  * Note: `text`, which can be wrapped and therefore different from `originalText`,
10
10
  * is derived from `originalText`
11
11
  */
12
- onChange?: ((nextOriginalText: string) => void) | undefined;
12
+ onChange?: (nextOriginalText: string) => void;
13
13
  onSubmit: (data: {
14
14
  viaKeyboard: boolean;
15
15
  nextOriginalText: string;
@@ -19,6 +19,6 @@ export declare const textWysiwyg: ({ id, onChange, onSubmit, getViewportCoords,
19
19
  canvas: HTMLCanvasElement;
20
20
  excalidrawContainer: HTMLDivElement | null;
21
21
  app: App;
22
- autoSelect?: boolean | undefined;
22
+ autoSelect?: boolean;
23
23
  }) => SubmitHandler;
24
24
  export {};
@@ -1,6 +1,6 @@
1
1
  import type { GlobalPoint, LocalPoint, Polygon } from "./types";
2
2
  export declare function polygon<Point extends GlobalPoint | LocalPoint>(...points: Point[]): Polygon<Point>;
3
3
  export declare function polygonFromPoints<Point extends GlobalPoint | LocalPoint>(points: Point[]): Polygon<Point>;
4
- export declare const polygonIncludesPoint: <Point extends GlobalPoint | LocalPoint>(point: Point, polygon: Polygon<Point>) => boolean;
4
+ export declare const polygonIncludesPoint: <Point extends LocalPoint | GlobalPoint>(point: Point, polygon: Polygon<Point>) => boolean;
5
5
  export declare const polygonIncludesPointNonZero: <Point extends [number, number]>(point: Point, polygon: Point[]) => boolean;
6
- export declare const pointOnPolygon: <Point extends GlobalPoint | LocalPoint>(p: Point, poly: Polygon<Point>, threshold?: number) => boolean;
6
+ export declare const pointOnPolygon: <Point extends LocalPoint | GlobalPoint>(p: Point, poly: Polygon<Point>, threshold?: number) => boolean;
@@ -13,9 +13,7 @@ export declare function rangeInclusive(start: number, end: number): InclusiveRan
13
13
  * @param pair The number pair to convert to an inclusive range
14
14
  * @returns The new inclusive range
15
15
  */
16
- export declare function rangeInclusiveFromPair(pair: [start: number, end: number]): [number, number] & {
17
- _brand: "excalimath_degree";
18
- };
16
+ export declare function rangeInclusiveFromPair(pair: [start: number, end: number]): InclusiveRange;
19
17
  /**
20
18
  * Given two ranges, return if the two ranges overlap with each other e.g.
21
19
  * [1, 3] overlaps with [2, 4] while [1, 3] does not overlap with [4, 5].
@@ -21,14 +21,14 @@ export declare const isLineSegment: <Point extends GlobalPoint | LocalPoint>(seg
21
21
  * @param origin
22
22
  * @returns
23
23
  */
24
- export declare const lineSegmentRotate: <Point extends GlobalPoint | LocalPoint>(l: LineSegment<Point>, angle: Radians, origin?: Point | undefined) => LineSegment<Point>;
24
+ export declare const lineSegmentRotate: <Point extends LocalPoint | GlobalPoint>(l: LineSegment<Point>, angle: Radians, origin?: Point) => LineSegment<Point>;
25
25
  /**
26
26
  * Calculates the point two line segments with a definite start and end point
27
27
  * intersect at.
28
28
  */
29
29
  export declare const segmentsIntersectAt: <Point extends GlobalPoint | LocalPoint>(a: Readonly<LineSegment<Point>>, b: Readonly<LineSegment<Point>>) => Point | null;
30
- export declare const pointOnLineSegment: <Point extends GlobalPoint | LocalPoint>(point: Point, line: LineSegment<Point>, threshold?: number) => boolean;
31
- export declare const distanceToLineSegment: <Point extends GlobalPoint | LocalPoint>(point: Point, line: LineSegment<Point>) => number;
30
+ export declare const pointOnLineSegment: <Point extends LocalPoint | GlobalPoint>(point: Point, line: LineSegment<Point>, threshold?: number) => boolean;
31
+ export declare const distanceToLineSegment: <Point extends LocalPoint | GlobalPoint>(point: Point, line: LineSegment<Point>) => number;
32
32
  /**
33
33
  * Returns the intersection point of a segment and a line
34
34
  *
@@ -37,3 +37,4 @@ export declare const distanceToLineSegment: <Point extends GlobalPoint | LocalPo
37
37
  * @returns
38
38
  */
39
39
  export declare function lineSegmentIntersectionPoints<Point extends GlobalPoint | LocalPoint>(l: LineSegment<Point>, s: LineSegment<Point>, threshold?: number): Point | null;
40
+ export declare function lineSegmentsDistance<Point extends GlobalPoint | LocalPoint>(s1: LineSegment<Point>, s2: LineSegment<Point>): number;
@@ -1,5 +1,5 @@
1
1
  import { type GlobalPoint, type LocalPoint } from "@excalidraw/math";
2
- import type { Bounds } from "@excalidraw/element";
2
+ import type { Bounds } from "@excalidraw/common";
3
3
  export type LineSegment<P extends LocalPoint | GlobalPoint> = [P, P];
4
4
  export declare function getBBox<P extends LocalPoint | GlobalPoint>(line: LineSegment<P>): Bounds;
5
5
  export declare function doBBoxesIntersect(a: Bounds, b: Bounds): boolean;
@@ -15,7 +15,7 @@ type ExportOpts = {
15
15
  };
16
16
  };
17
17
  export declare const exportToCanvas: ({ elements, appState, files, maxWidthOrHeight, getDimensions, exportPadding, exportingFrame, }: ExportOpts & {
18
- exportPadding?: number | undefined;
18
+ exportPadding?: number;
19
19
  }) => Promise<HTMLCanvasElement>;
20
20
  export declare const exportToBlob: (opts: ExportOpts & {
21
21
  mimeType?: string;
@@ -23,10 +23,10 @@ export declare const exportToBlob: (opts: ExportOpts & {
23
23
  exportPadding?: number;
24
24
  }) => Promise<Blob>;
25
25
  export declare const exportToSvg: ({ elements, appState, files, exportPadding, renderEmbeddables, exportingFrame, skipInliningFonts, reuseImages, }: Omit<ExportOpts, "getDimensions"> & {
26
- exportPadding?: number | undefined;
27
- renderEmbeddables?: boolean | undefined;
28
- skipInliningFonts?: true | undefined;
29
- reuseImages?: boolean | undefined;
26
+ exportPadding?: number;
27
+ renderEmbeddables?: boolean;
28
+ skipInliningFonts?: true;
29
+ reuseImages?: boolean;
30
30
  }) => Promise<SVGSVGElement>;
31
31
  export declare const exportToClipboard: (opts: ExportOpts & {
32
32
  mimeType?: string;
@@ -46,13 +46,13 @@ export declare const getClosedCurveShape: <Point extends GlobalPoint | LocalPoin
46
46
  * @param gap Optional value to inflate the shape before testing
47
47
  * @returns An array of intersections
48
48
  */
49
- export declare const segmentIntersectRectangleElement: <Point extends GlobalPoint | LocalPoint>(element: ExcalidrawBindableElement, segment: LineSegment<Point>, gap?: number) => Point[];
50
- export declare const pointOnEllipse: <Point extends GlobalPoint | LocalPoint>(point: Point, ellipse: Ellipse<Point>, threshold?: number) => boolean;
51
- export declare const pointInEllipse: <Point extends GlobalPoint | LocalPoint>(p: Point, ellipse: Ellipse<Point>) => boolean;
52
- export declare const ellipseAxes: <Point extends GlobalPoint | LocalPoint>(ellipse: Ellipse<Point>) => {
49
+ export declare const segmentIntersectRectangleElement: <Point extends LocalPoint | GlobalPoint>(element: ExcalidrawBindableElement, segment: LineSegment<Point>, gap?: number) => Point[];
50
+ export declare const pointOnEllipse: <Point extends LocalPoint | GlobalPoint>(point: Point, ellipse: Ellipse<Point>, threshold?: number) => boolean;
51
+ export declare const pointInEllipse: <Point extends LocalPoint | GlobalPoint>(p: Point, ellipse: Ellipse<Point>) => boolean;
52
+ export declare const ellipseAxes: <Point extends LocalPoint | GlobalPoint>(ellipse: Ellipse<Point>) => {
53
53
  majorAxis: number;
54
54
  minorAxis: number;
55
55
  };
56
- export declare const ellipseFocusToCenter: <Point extends GlobalPoint | LocalPoint>(ellipse: Ellipse<Point>) => number;
57
- export declare const ellipseExtremes: <Point extends GlobalPoint | LocalPoint>(ellipse: Ellipse<Point>) => import("@excalidraw/math").Vector[];
56
+ export declare const ellipseFocusToCenter: <Point extends LocalPoint | GlobalPoint>(ellipse: Ellipse<Point>) => number;
57
+ export declare const ellipseExtremes: <Point extends LocalPoint | GlobalPoint>(ellipse: Ellipse<Point>) => import("@excalidraw/math").Vector[];
58
58
  export {};
@@ -1,4 +1,4 @@
1
- import type { Bounds } from "@excalidraw/element";
1
+ import { type Bounds } from "@excalidraw/common";
2
2
  import type { ExcalidrawElement, NonDeletedExcalidrawElement } from "@excalidraw/element/types";
3
3
  type Element = NonDeletedExcalidrawElement;
4
4
  type Elements = readonly NonDeletedExcalidrawElement[];
@@ -8,7 +8,7 @@ export declare const elementsOverlappingBBox: ({ elements, bounds, type, errorMa
8
8
  elements: Elements;
9
9
  bounds: Bounds | ExcalidrawElement;
10
10
  /** safety offset. Defaults to 0. */
11
- errorMargin?: number | undefined;
11
+ errorMargin?: number;
12
12
  /**
13
13
  * - overlap: elements overlapping or inside bounds
14
14
  * - contain: elements inside bounds or bounds inside elements
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@excalidraw/common",
3
- "version": "0.18.0-b9d27d3",
3
+ "version": "0.18.0-c158187",
4
4
  "type": "module",
5
5
  "types": "./dist/types/common/src/index.d.ts",
6
6
  "main": "./dist/prod/index.js",
@@ -55,5 +55,11 @@
55
55
  "scripts": {
56
56
  "gen:types": "rimraf types && tsc",
57
57
  "build:esm": "rimraf dist && node ../../scripts/buildBase.js && yarn gen:types"
58
+ },
59
+ "dependencies": {
60
+ "tinycolor2": "1.6.0"
61
+ },
62
+ "devDependencies": {
63
+ "@types/tinycolor2": "1.4.6"
58
64
  }
59
65
  }