@zsviczian/excalidraw 0.17.1-obsidian-37 → 0.17.1-obsidian-39

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 (337) hide show
  1. package/dist/excalidraw.development.js +92 -81
  2. package/dist/excalidraw.production.min.js +1 -1
  3. package/dist/styles.development.css +70 -83
  4. package/dist/styles.production.css +3 -2
  5. package/main.js +2 -1
  6. package/package.json +1 -1
  7. package/types/excalidraw/actions/actionAddToLibrary.d.ts +584 -584
  8. package/types/excalidraw/actions/actionAlign.d.ts +108 -108
  9. package/types/excalidraw/actions/actionBoundText.d.ts +426 -426
  10. package/types/excalidraw/actions/actionCanvas.d.ts +2844 -2844
  11. package/types/excalidraw/actions/actionClipboard.d.ts +1457 -1457
  12. package/types/excalidraw/actions/actionDeleteSelected.d.ts +618 -618
  13. package/types/excalidraw/actions/actionDistribute.d.ts +34 -34
  14. package/types/excalidraw/actions/actionDuplicateSelection.d.ts +21 -21
  15. package/types/excalidraw/actions/actionElementLock.d.ts +414 -414
  16. package/types/excalidraw/actions/actionExport.d.ts +1817 -1817
  17. package/types/excalidraw/actions/actionFinalize.d.ts +395 -395
  18. package/types/excalidraw/actions/actionFlip.d.ts +34 -34
  19. package/types/excalidraw/actions/actionFrame.d.ts +827 -827
  20. package/types/excalidraw/actions/actionGroup.d.ts +424 -424
  21. package/types/excalidraw/actions/actionHistory.d.ts +7 -7
  22. package/types/excalidraw/actions/actionLinearEditor.d.ts +208 -208
  23. package/types/excalidraw/actions/actionLink.d.ts +208 -208
  24. package/types/excalidraw/actions/actionMenu.d.ts +603 -603
  25. package/types/excalidraw/actions/actionNavigate.d.ts +400 -400
  26. package/types/excalidraw/actions/actionProperties.d.ts +3051 -3051
  27. package/types/excalidraw/actions/actionSelectAll.d.ts +207 -207
  28. package/types/excalidraw/actions/actionStyles.d.ts +221 -221
  29. package/types/excalidraw/actions/actionTextAutoResize.d.ts +17 -17
  30. package/types/excalidraw/actions/actionToggleGridMode.d.ts +210 -210
  31. package/types/excalidraw/actions/actionToggleObjectsSnapMode.d.ts +208 -208
  32. package/types/excalidraw/actions/actionToggleStats.d.ts +208 -208
  33. package/types/excalidraw/actions/actionToggleViewMode.d.ts +209 -209
  34. package/types/excalidraw/actions/actionToggleZenMode.d.ts +209 -209
  35. package/types/excalidraw/actions/actionZindex.d.ts +74 -74
  36. package/types/excalidraw/actions/index.d.ts +25 -25
  37. package/types/excalidraw/actions/manager.d.ts +21 -21
  38. package/types/excalidraw/actions/register.d.ts +5 -5
  39. package/types/excalidraw/actions/shortcuts.d.ts +4 -4
  40. package/types/excalidraw/actions/types.d.ts +47 -47
  41. package/types/excalidraw/align.d.ts +6 -6
  42. package/types/excalidraw/analytics.d.ts +1 -1
  43. package/types/excalidraw/animated-trail.d.ts +33 -33
  44. package/types/excalidraw/animation-frame-handler.d.ts +16 -16
  45. package/types/excalidraw/appState.d.ts +83 -83
  46. package/types/excalidraw/binaryheap.d.ts +12 -12
  47. package/types/excalidraw/change.d.ts +191 -191
  48. package/types/excalidraw/charts.d.ts +27 -27
  49. package/types/excalidraw/clients.d.ts +14 -14
  50. package/types/excalidraw/clipboard.d.ts +44 -44
  51. package/types/excalidraw/colors.d.ts +61 -61
  52. package/types/excalidraw/components/Actions.d.ts +34 -34
  53. package/types/excalidraw/components/ActiveConfirmDialog.d.ts +4 -4
  54. package/types/excalidraw/components/App.d.ts +521 -520
  55. package/types/excalidraw/components/Avatar.d.ts +11 -11
  56. package/types/excalidraw/components/BraveMeasureTextError.d.ts +2 -2
  57. package/types/excalidraw/components/Button.d.ts +17 -17
  58. package/types/excalidraw/components/ButtonIcon.d.ts +14 -14
  59. package/types/excalidraw/components/ButtonIconCycle.d.ts +10 -10
  60. package/types/excalidraw/components/ButtonIconSelect.d.ts +19 -19
  61. package/types/excalidraw/components/ButtonSelect.d.ts +9 -9
  62. package/types/excalidraw/components/ButtonSeparator.d.ts +1 -1
  63. package/types/excalidraw/components/Card.d.ts +6 -6
  64. package/types/excalidraw/components/CheckboxItem.d.ts +8 -8
  65. package/types/excalidraw/components/ColorPicker/ColorInput.d.ts +9 -9
  66. package/types/excalidraw/components/ColorPicker/ColorPicker.d.ts +19 -19
  67. package/types/excalidraw/components/ColorPicker/CustomColorList.d.ts +8 -8
  68. package/types/excalidraw/components/ColorPicker/HotkeyLabel.d.ts +8 -8
  69. package/types/excalidraw/components/ColorPicker/Picker.d.ts +18 -18
  70. package/types/excalidraw/components/ColorPicker/PickerColorList.d.ts +10 -10
  71. package/types/excalidraw/components/ColorPicker/PickerHeading.d.ts +5 -5
  72. package/types/excalidraw/components/ColorPicker/ShadeList.d.ts +8 -8
  73. package/types/excalidraw/components/ColorPicker/TopPicks.d.ts +9 -9
  74. package/types/excalidraw/components/ColorPicker/colorPickerUtils.d.ts +21 -21
  75. package/types/excalidraw/components/ColorPicker/keyboardNavHandlers.d.ts +20 -20
  76. package/types/excalidraw/components/CommandPalette/CommandPalette.d.ts +18 -18
  77. package/types/excalidraw/components/CommandPalette/defaultCommandPaletteItems.d.ts +2 -2
  78. package/types/excalidraw/components/CommandPalette/types.d.ts +25 -25
  79. package/types/excalidraw/components/ConfirmDialog.d.ts +10 -10
  80. package/types/excalidraw/components/ContextMenu.d.ts +16 -16
  81. package/types/excalidraw/components/DarkModeToggle.d.ts +7 -7
  82. package/types/excalidraw/components/DefaultSidebar.d.ts +29 -29
  83. package/types/excalidraw/components/Dialog.d.ts +13 -13
  84. package/types/excalidraw/components/DialogActionButton.d.ts +10 -10
  85. package/types/excalidraw/components/ErrorDialog.d.ts +5 -5
  86. package/types/excalidraw/components/ExcalidrawLogo.d.ts +15 -15
  87. package/types/excalidraw/components/EyeDropper.d.ts +27 -27
  88. package/types/excalidraw/components/FilledButton.d.ts +17 -17
  89. package/types/excalidraw/components/FixedSideContainer.d.ts +9 -9
  90. package/types/excalidraw/components/FollowMode/FollowMode.d.ts +10 -10
  91. package/types/excalidraw/components/FontPicker/FontPicker.d.ts +21 -21
  92. package/types/excalidraw/components/FontPicker/FontPickerList.d.ts +25 -25
  93. package/types/excalidraw/components/FontPicker/FontPickerTrigger.d.ts +6 -6
  94. package/types/excalidraw/components/FontPicker/keyboardNavHandlers.d.ts +13 -13
  95. package/types/excalidraw/components/HandButton.d.ts +10 -10
  96. package/types/excalidraw/components/HelpButton.d.ts +7 -7
  97. package/types/excalidraw/components/HelpDialog.d.ts +4 -4
  98. package/types/excalidraw/components/HintViewer.d.ts +10 -10
  99. package/types/excalidraw/components/IconPicker.d.ts +14 -14
  100. package/types/excalidraw/components/ImageExportDialog.d.ts +14 -14
  101. package/types/excalidraw/components/InitializeApp.d.ts +10 -10
  102. package/types/excalidraw/components/InlineIcon.d.ts +3 -3
  103. package/types/excalidraw/components/Island.d.ts +10 -10
  104. package/types/excalidraw/components/JSONExportDialog.d.ts +15 -15
  105. package/types/excalidraw/components/LaserPointerButton.d.ts +10 -10
  106. package/types/excalidraw/components/LayerUI.d.ts +34 -34
  107. package/types/excalidraw/components/LibraryMenu.d.ts +24 -24
  108. package/types/excalidraw/components/LibraryMenuBrowseButton.d.ts +7 -7
  109. package/types/excalidraw/components/LibraryMenuControlButtons.d.ts +9 -9
  110. package/types/excalidraw/components/LibraryMenuHeaderContent.d.ts +17 -17
  111. package/types/excalidraw/components/LibraryMenuItems.d.ts +14 -14
  112. package/types/excalidraw/components/LibraryMenuSection.d.ts +23 -23
  113. package/types/excalidraw/components/LibraryUnit.d.ts +14 -14
  114. package/types/excalidraw/components/LoadingMessage.d.ts +5 -5
  115. package/types/excalidraw/components/LockButton.d.ts +10 -10
  116. package/types/excalidraw/components/MagicButton.d.ts +9 -9
  117. package/types/excalidraw/components/MagicSettings.d.ts +8 -8
  118. package/types/excalidraw/components/MobileMenu.d.ts +24 -24
  119. package/types/excalidraw/components/Modal.d.ts +14 -14
  120. package/types/excalidraw/components/OverwriteConfirm/OverwriteConfirm.d.ts +17 -17
  121. package/types/excalidraw/components/OverwriteConfirm/OverwriteConfirmActions.d.ts +17 -17
  122. package/types/excalidraw/components/OverwriteConfirm/OverwriteConfirmState.d.ts +22 -22
  123. package/types/excalidraw/components/Paragraph.d.ts +4 -4
  124. package/types/excalidraw/components/PasteChartDialog.d.ts +8 -8
  125. package/types/excalidraw/components/PenModeButton.d.ts +12 -12
  126. package/types/excalidraw/components/Popover.d.ts +15 -15
  127. package/types/excalidraw/components/ProjectName.d.ts +10 -10
  128. package/types/excalidraw/components/PropertiesPopover.d.ts +15 -15
  129. package/types/excalidraw/components/PublishLibrary.d.ts +16 -16
  130. package/types/excalidraw/components/QuickSearch.d.ts +9 -9
  131. package/types/excalidraw/components/RadioGroup.d.ts +13 -13
  132. package/types/excalidraw/components/SVGLayer.d.ts +7 -7
  133. package/types/excalidraw/components/ScrollableList.d.ts +8 -8
  134. package/types/excalidraw/components/Section.d.ts +6 -6
  135. package/types/excalidraw/components/ShareableLinkDialog.d.ts +7 -7
  136. package/types/excalidraw/components/Sidebar/Sidebar.d.ts +76 -76
  137. package/types/excalidraw/components/Sidebar/SidebarHeader.d.ts +7 -7
  138. package/types/excalidraw/components/Sidebar/SidebarTab.d.ts +8 -8
  139. package/types/excalidraw/components/Sidebar/SidebarTabTrigger.d.ts +9 -9
  140. package/types/excalidraw/components/Sidebar/SidebarTabTriggers.d.ts +6 -6
  141. package/types/excalidraw/components/Sidebar/SidebarTabs.d.ts +6 -6
  142. package/types/excalidraw/components/Sidebar/SidebarTrigger.d.ts +6 -6
  143. package/types/excalidraw/components/Sidebar/common.d.ts +33 -33
  144. package/types/excalidraw/components/Spinner.d.ts +7 -7
  145. package/types/excalidraw/components/Stack.d.ts +16 -16
  146. package/types/excalidraw/components/Stats/Angle.d.ts +11 -11
  147. package/types/excalidraw/components/Stats/Collapsible.d.ts +8 -8
  148. package/types/excalidraw/components/Stats/Dimension.d.ts +11 -11
  149. package/types/excalidraw/components/Stats/DragInput.d.ts +31 -31
  150. package/types/excalidraw/components/Stats/FontSize.d.ts +11 -11
  151. package/types/excalidraw/components/Stats/MultiAngle.d.ts +11 -11
  152. package/types/excalidraw/components/Stats/MultiDimension.d.ts +14 -14
  153. package/types/excalidraw/components/Stats/MultiFontSize.d.ts +12 -12
  154. package/types/excalidraw/components/Stats/MultiPosition.d.ts +14 -14
  155. package/types/excalidraw/components/Stats/Position.d.ts +12 -12
  156. package/types/excalidraw/components/Stats/index.d.ts +35 -15
  157. package/types/excalidraw/components/Stats/utils.d.ts +26 -26
  158. package/types/excalidraw/components/Stats.d.ts +11 -11
  159. package/types/excalidraw/components/Switch.d.ts +9 -9
  160. package/types/excalidraw/components/TTDDialog/MermaidToExcalidraw.d.ts +14 -14
  161. package/types/excalidraw/components/TTDDialog/TTDDialog.d.ts +29 -29
  162. package/types/excalidraw/components/TTDDialog/TTDDialogInput.d.ts +9 -9
  163. package/types/excalidraw/components/TTDDialog/TTDDialogOutput.d.ts +7 -7
  164. package/types/excalidraw/components/TTDDialog/TTDDialogPanel.d.ts +17 -17
  165. package/types/excalidraw/components/TTDDialog/TTDDialogPanels.d.ts +4 -4
  166. package/types/excalidraw/components/TTDDialog/TTDDialogSubmitShortcut.d.ts +1 -1
  167. package/types/excalidraw/components/TTDDialog/TTDDialogTab.d.ts +7 -7
  168. package/types/excalidraw/components/TTDDialog/TTDDialogTabTrigger.d.ts +8 -8
  169. package/types/excalidraw/components/TTDDialog/TTDDialogTabTriggers.d.ts +6 -6
  170. package/types/excalidraw/components/TTDDialog/TTDDialogTabs.d.ts +14 -14
  171. package/types/excalidraw/components/TTDDialog/TTDDialogTrigger.d.ts +8 -8
  172. package/types/excalidraw/components/TTDDialog/common.d.ts +32 -32
  173. package/types/excalidraw/components/TextField.d.ts +19 -19
  174. package/types/excalidraw/components/Toast.d.ts +9 -9
  175. package/types/excalidraw/components/ToolButton.d.ts +49 -49
  176. package/types/excalidraw/components/Tooltip.d.ts +18 -18
  177. package/types/excalidraw/components/Trans.d.ts +9 -9
  178. package/types/excalidraw/components/UserList.d.ts +18 -18
  179. package/types/excalidraw/components/canvases/InteractiveCanvas.d.ts +29 -29
  180. package/types/excalidraw/components/canvases/StaticCanvas.d.ts +19 -19
  181. package/types/excalidraw/components/canvases/index.d.ts +3 -3
  182. package/types/excalidraw/components/dropdownMenu/DropdownMenu.d.ts +85 -85
  183. package/types/excalidraw/components/dropdownMenu/DropdownMenuContent.d.ts +15 -15
  184. package/types/excalidraw/components/dropdownMenu/DropdownMenuGroup.d.ts +11 -11
  185. package/types/excalidraw/components/dropdownMenu/DropdownMenuItem.d.ts +45 -45
  186. package/types/excalidraw/components/dropdownMenu/DropdownMenuItemContent.d.ts +7 -7
  187. package/types/excalidraw/components/dropdownMenu/DropdownMenuItemContentRadio.d.ts +17 -17
  188. package/types/excalidraw/components/dropdownMenu/DropdownMenuItemCustom.d.ts +7 -7
  189. package/types/excalidraw/components/dropdownMenu/DropdownMenuItemLink.d.ts +14 -14
  190. package/types/excalidraw/components/dropdownMenu/DropdownMenuSeparator.d.ts +5 -5
  191. package/types/excalidraw/components/dropdownMenu/DropdownMenuTrigger.d.ts +10 -10
  192. package/types/excalidraw/components/dropdownMenu/common.d.ts +6 -6
  193. package/types/excalidraw/components/dropdownMenu/dropdownMenuUtils.d.ts +3 -3
  194. package/types/excalidraw/components/footer/Footer.d.ts +12 -12
  195. package/types/excalidraw/components/footer/FooterCenter.d.ts +8 -8
  196. package/types/excalidraw/components/hoc/withInternalFallback.d.ts +4 -4
  197. package/types/excalidraw/components/hyperlink/Hyperlink.d.ts +18 -18
  198. package/types/excalidraw/components/hyperlink/helpers.d.ts +7 -7
  199. package/types/excalidraw/components/icons.d.ts +211 -211
  200. package/types/excalidraw/components/live-collaboration/LiveCollaborationTrigger.d.ts +9 -9
  201. package/types/excalidraw/components/main-menu/DefaultItems.d.ts +58 -58
  202. package/types/excalidraw/components/main-menu/MainMenu.d.ts +79 -79
  203. package/types/excalidraw/components/welcome-screen/WelcomeScreen.Center.d.ts +59 -59
  204. package/types/excalidraw/components/welcome-screen/WelcomeScreen.Hints.d.ts +19 -19
  205. package/types/excalidraw/components/welcome-screen/WelcomeScreen.d.ts +86 -86
  206. package/types/excalidraw/constants.d.ts +312 -312
  207. package/types/excalidraw/context/tunnels.d.ts +20 -20
  208. package/types/excalidraw/context/ui-appState.d.ts +4 -4
  209. package/types/excalidraw/cursor.d.ts +6 -6
  210. package/types/excalidraw/data/EditorLocalStorage.d.ts +8 -8
  211. package/types/excalidraw/data/ai/types.d.ts +242 -242
  212. package/types/excalidraw/data/blob.d.ts +49 -49
  213. package/types/excalidraw/data/encode.d.ts +53 -53
  214. package/types/excalidraw/data/encryption.d.ts +9 -9
  215. package/types/excalidraw/data/filesystem.d.ts +20 -20
  216. package/types/excalidraw/data/image.d.ts +15 -15
  217. package/types/excalidraw/data/index.d.ts +22 -22
  218. package/types/excalidraw/data/json.d.ts +16 -16
  219. package/types/excalidraw/data/library.d.ts +106 -106
  220. package/types/excalidraw/data/magic.d.ts +23 -23
  221. package/types/excalidraw/data/reconcile.d.ts +6 -6
  222. package/types/excalidraw/data/resave.d.ts +5 -5
  223. package/types/excalidraw/data/restore.d.ts +21 -21
  224. package/types/excalidraw/data/transform.d.ts +81 -81
  225. package/types/excalidraw/data/types.d.ts +45 -45
  226. package/types/excalidraw/data/url.d.ts +8 -8
  227. package/types/excalidraw/deburr.d.ts +1 -1
  228. package/types/excalidraw/dist/excalidraw.development.d.ts +2 -2
  229. package/types/excalidraw/dist/excalidraw.production.min.d.ts +1 -1
  230. package/types/excalidraw/distribute.d.ts +6 -6
  231. package/types/excalidraw/element/ElementCanvasButtons.d.ts +7 -7
  232. package/types/excalidraw/element/Hyperlink.d.ts +220 -0
  233. package/types/excalidraw/element/binding.d.ts +97 -97
  234. package/types/excalidraw/element/bounds.d.ts +74 -74
  235. package/types/excalidraw/element/collision.d.ts +16 -16
  236. package/types/excalidraw/element/containerCache.d.ts +11 -11
  237. package/types/excalidraw/element/dragElements.d.ts +15 -15
  238. package/types/excalidraw/element/embeddable.d.ts +214 -214
  239. package/types/excalidraw/element/flowchart.d.ts +25 -25
  240. package/types/excalidraw/element/heading.d.ts +11 -11
  241. package/types/excalidraw/element/image.d.ts +32 -32
  242. package/types/excalidraw/element/index.d.ts +26 -26
  243. package/types/excalidraw/element/linearElementEditor.d.ts +347 -347
  244. package/types/excalidraw/element/mutateElement.d.ts +11 -11
  245. package/types/excalidraw/element/newElement.d.ts +105 -105
  246. package/types/excalidraw/element/resizeElements.d.ts +17 -17
  247. package/types/excalidraw/element/resizeTest.d.ts +14 -14
  248. package/types/excalidraw/element/routing.d.ts +10 -10
  249. package/types/excalidraw/element/showSelectedShapeActions.d.ts +3 -3
  250. package/types/excalidraw/element/sizeHelpers.d.ts +40 -35
  251. package/types/excalidraw/element/sortElements.d.ts +2 -2
  252. package/types/excalidraw/element/textElement.d.ts +68 -68
  253. package/types/excalidraw/element/textWysiwyg.d.ts +22 -22
  254. package/types/excalidraw/element/transformHandles.d.ts +54 -54
  255. package/types/excalidraw/element/typeChecks.d.ts +37 -36
  256. package/types/excalidraw/element/types.d.ts +244 -244
  257. package/types/excalidraw/emitter.d.ts +16 -16
  258. package/types/excalidraw/entry.d.ts +1 -1
  259. package/types/excalidraw/env.d.cts +1 -1
  260. package/types/excalidraw/env.d.ts +1 -1
  261. package/types/excalidraw/errors.d.ts +16 -16
  262. package/types/excalidraw/fonts/ExcalidrawFont.d.ts +21 -21
  263. package/types/excalidraw/fonts/index.d.ts +83 -83
  264. package/types/excalidraw/fonts/metadata.d.ts +35 -35
  265. package/types/excalidraw/fractionalIndex.d.ts +48 -48
  266. package/types/excalidraw/frame.d.ts +63 -63
  267. package/types/excalidraw/ga.d.ts +63 -63
  268. package/types/excalidraw/gadirections.d.ts +8 -8
  269. package/types/excalidraw/galines.d.ts +22 -22
  270. package/types/excalidraw/gapoints.d.ts +7 -7
  271. package/types/excalidraw/gatransforms.d.ts +10 -10
  272. package/types/excalidraw/gesture.d.ts +6 -6
  273. package/types/excalidraw/groups.d.ts +33 -33
  274. package/types/excalidraw/history.d.ts +40 -40
  275. package/types/excalidraw/hooks/useCallbackRefState.d.ts +1 -1
  276. package/types/excalidraw/hooks/useCreatePortalContainer.d.ts +7 -7
  277. package/types/excalidraw/hooks/useEmitter.d.ts +2 -2
  278. package/types/excalidraw/hooks/useLibraryItemSvg.d.ts +11 -11
  279. package/types/excalidraw/hooks/useOutsideClick.d.ts +19 -19
  280. package/types/excalidraw/hooks/useScrollPosition.d.ts +1 -1
  281. package/types/excalidraw/hooks/useStable.d.ts +1 -1
  282. package/types/excalidraw/hooks/useStableCallback.d.ts +4 -4
  283. package/types/excalidraw/hooks/useTransition.d.ts +2 -2
  284. package/types/excalidraw/i18n.d.ts +24 -24
  285. package/types/excalidraw/index-node.d.ts +1 -1
  286. package/types/excalidraw/index.d.ts +59 -58
  287. package/types/excalidraw/jotai.d.ts +34 -34
  288. package/types/excalidraw/keys.d.ts +82 -82
  289. package/types/excalidraw/laser-trails.d.ts +20 -20
  290. package/types/excalidraw/main.d.ts +2 -2
  291. package/types/excalidraw/math.d.ts +78 -78
  292. package/types/excalidraw/mermaid.d.ts +2 -2
  293. package/types/excalidraw/obsidianUtils.d.ts +16 -16
  294. package/types/excalidraw/points.d.ts +7 -7
  295. package/types/excalidraw/polyfill.d.ts +2 -2
  296. package/types/excalidraw/publicPath.d.ts +1 -1
  297. package/types/excalidraw/queue.d.ts +9 -9
  298. package/types/excalidraw/random.d.ts +4 -4
  299. package/types/excalidraw/reactUtils.d.ts +14 -14
  300. package/types/excalidraw/renderer/easingFunctions.d.ts +6 -6
  301. package/types/excalidraw/renderer/helpers.d.ts +13 -13
  302. package/types/excalidraw/renderer/interactiveScene.d.ts +20 -20
  303. package/types/excalidraw/renderer/renderElement.d.ts +27 -27
  304. package/types/excalidraw/renderer/renderScene.d.ts +23 -0
  305. package/types/excalidraw/renderer/renderSnaps.d.ts +2 -2
  306. package/types/excalidraw/renderer/roundRect.d.ts +11 -11
  307. package/types/excalidraw/renderer/staticScene.d.ts +11 -11
  308. package/types/excalidraw/renderer/staticSvgScene.d.ts +5 -5
  309. package/types/excalidraw/scene/Fonts.d.ts +21 -19
  310. package/types/excalidraw/scene/Renderer.d.ts +25 -25
  311. package/types/excalidraw/scene/Scene.d.ts +78 -78
  312. package/types/excalidraw/scene/Shape.d.ts +17 -17
  313. package/types/excalidraw/scene/ShapeCache.d.ts +25 -25
  314. package/types/excalidraw/scene/comparisons.d.ts +11 -11
  315. package/types/excalidraw/scene/export.d.ts +29 -29
  316. package/types/excalidraw/scene/index.d.ts +4 -4
  317. package/types/excalidraw/scene/scroll.d.ts +17 -17
  318. package/types/excalidraw/scene/scrollbars.d.ts +12 -12
  319. package/types/excalidraw/scene/selection.d.ts +32 -32
  320. package/types/excalidraw/scene/types.d.ts +101 -101
  321. package/types/excalidraw/scene/zoom.d.ts +13 -13
  322. package/types/excalidraw/shapes.d.ts +70 -70
  323. package/types/excalidraw/snapping.d.ts +108 -108
  324. package/types/excalidraw/store.d.ts +129 -129
  325. package/types/excalidraw/types.d.ts +692 -692
  326. package/types/excalidraw/utility-types.d.ts +31 -31
  327. package/types/excalidraw/utils.d.ts +242 -242
  328. package/types/excalidraw/webpack.dev.config.d.ts +81 -81
  329. package/types/excalidraw/webpack.prod.config.d.ts +97 -97
  330. package/types/excalidraw/zindex.d.ts +6 -6
  331. package/types/utils/bbox.d.ts +11 -11
  332. package/types/utils/collision.d.ts +4 -4
  333. package/types/utils/export.d.ts +44 -44
  334. package/types/utils/geometry/geometry.d.ts +89 -72
  335. package/types/utils/geometry/shape.d.ts +56 -56
  336. package/types/utils/index.d.ts +4 -4
  337. package/types/utils/withinBounds.d.ts +19 -19
@@ -1,83 +1,83 @@
1
- import type Scene from "../scene/Scene";
2
- import type { ValueOf } from "../utility-types";
3
- import type { ExcalidrawElement, ExcalidrawTextElement, FontFamilyValues } from "../element/types";
4
- import { FONT_FAMILY } from "../constants";
5
- import { type FontMetadata } from "./metadata";
6
- import { type Font } from "./ExcalidrawFont";
7
- export declare class Fonts {
8
- static readonly loadedFontsCache: Set<string>;
9
- private static _registered;
10
- private static _initialized;
11
- static get registered(): Map<number, {
12
- metadata: FontMetadata;
13
- fonts: Font[];
14
- }>;
15
- get registered(): Map<number, {
16
- metadata: FontMetadata;
17
- fonts: Font[];
18
- }>;
19
- private readonly scene;
20
- constructor({ scene }: {
21
- scene: Scene;
22
- });
23
- /**
24
- * if we load a (new) font, it's likely that text elements using it have
25
- * already been rendered using a fallback font. Thus, we want invalidate
26
- * their shapes and rerender. See #637.
27
- *
28
- * Invalidates text elements and rerenders scene, provided that at least one
29
- * of the supplied fontFaces has not already been processed.
30
- */
31
- onLoaded: (fontFaces: readonly FontFace[]) => false | undefined;
32
- /**
33
- * Load font faces for a given scene and trigger scene update.
34
- */
35
- loadSceneFonts: () => Promise<FontFace[]>;
36
- /**
37
- * Gets all the font families for the given scene.
38
- */
39
- getSceneFontFamilies: () => number[];
40
- /**
41
- * Load font faces for passed elements - use when the scene is unavailable (i.e. export).
42
- */
43
- static loadFontsForElements: (elements: readonly ExcalidrawElement[]) => Promise<FontFace[]>;
44
- private static loadFontFaces;
45
- /**
46
- * WARN: should be called just once on init, even across multiple instances.
47
- */
48
- private static init;
49
- private static getFontFamilies;
50
- }
51
- /**
52
- * Register a new font.
53
- *
54
- * @param family font family
55
- * @param metadata font metadata
56
- * @param params array of the rest of the FontFace parameters [uri: string, descriptors: FontFaceDescriptors?] ,
57
- */
58
- export declare function register(//zsviczian (changed from private to export)
59
- this: Fonts | {
60
- registered: Map<ValueOf<typeof FONT_FAMILY>, {
61
- metadata: FontMetadata;
62
- fonts: Font[];
63
- }>;
64
- }, family: string, metadata: FontMetadata, ...params: Array<{
65
- uri: string;
66
- descriptors?: FontFaceDescriptors;
67
- }>): Map<number, {
68
- metadata: FontMetadata;
69
- fonts: Font[];
70
- }> | Map<number, {
71
- metadata: FontMetadata;
72
- fonts: Font[];
73
- }>;
74
- /**
75
- * Calculates vertical offset for a text with alphabetic baseline.
76
- */
77
- export declare const getVerticalOffset: (fontFamily: ExcalidrawTextElement["fontFamily"], fontSize: ExcalidrawTextElement["fontSize"], lineHeightPx: number) => number;
78
- /**
79
- * Gets line height forr a selected family.
80
- */
81
- export declare const getLineHeight: (fontFamily: FontFamilyValues) => number & {
82
- _brand: "unitlessLineHeight";
83
- };
1
+ import type Scene from "../scene/Scene";
2
+ import type { ValueOf } from "../utility-types";
3
+ import type { ExcalidrawElement, ExcalidrawTextElement, FontFamilyValues } from "../element/types";
4
+ import { FONT_FAMILY } from "../constants";
5
+ import { type FontMetadata } from "./metadata";
6
+ import { type Font } from "./ExcalidrawFont";
7
+ export declare class Fonts {
8
+ static readonly loadedFontsCache: Set<string>;
9
+ private static _registered;
10
+ private static _initialized;
11
+ static get registered(): Map<number, {
12
+ metadata: FontMetadata;
13
+ fonts: Font[];
14
+ }>;
15
+ get registered(): Map<number, {
16
+ metadata: FontMetadata;
17
+ fonts: Font[];
18
+ }>;
19
+ private readonly scene;
20
+ constructor({ scene }: {
21
+ scene: Scene;
22
+ });
23
+ /**
24
+ * if we load a (new) font, it's likely that text elements using it have
25
+ * already been rendered using a fallback font. Thus, we want invalidate
26
+ * their shapes and rerender. See #637.
27
+ *
28
+ * Invalidates text elements and rerenders scene, provided that at least one
29
+ * of the supplied fontFaces has not already been processed.
30
+ */
31
+ onLoaded: (fontFaces: readonly FontFace[]) => false | undefined;
32
+ /**
33
+ * Load font faces for a given scene and trigger scene update.
34
+ */
35
+ loadSceneFonts: () => Promise<FontFace[]>;
36
+ /**
37
+ * Gets all the font families for the given scene.
38
+ */
39
+ getSceneFontFamilies: () => number[];
40
+ /**
41
+ * Load font faces for passed elements - use when the scene is unavailable (i.e. export).
42
+ */
43
+ static loadFontsForElements: (elements: readonly ExcalidrawElement[]) => Promise<FontFace[]>;
44
+ private static loadFontFaces;
45
+ /**
46
+ * WARN: should be called just once on init, even across multiple instances.
47
+ */
48
+ private static init;
49
+ private static getFontFamilies;
50
+ }
51
+ /**
52
+ * Register a new font.
53
+ *
54
+ * @param family font family
55
+ * @param metadata font metadata
56
+ * @param params array of the rest of the FontFace parameters [uri: string, descriptors: FontFaceDescriptors?] ,
57
+ */
58
+ export declare function register(//zsviczian (changed from private to export)
59
+ this: Fonts | {
60
+ registered: Map<ValueOf<typeof FONT_FAMILY>, {
61
+ metadata: FontMetadata;
62
+ fonts: Font[];
63
+ }>;
64
+ }, family: string, metadata: FontMetadata, ...params: Array<{
65
+ uri: string;
66
+ descriptors?: FontFaceDescriptors;
67
+ }>): Map<number, {
68
+ metadata: FontMetadata;
69
+ fonts: Font[];
70
+ }> | Map<number, {
71
+ metadata: FontMetadata;
72
+ fonts: Font[];
73
+ }>;
74
+ /**
75
+ * Calculates vertical offset for a text with alphabetic baseline.
76
+ */
77
+ export declare const getVerticalOffset: (fontFamily: ExcalidrawTextElement["fontFamily"], fontSize: ExcalidrawTextElement["fontSize"], lineHeightPx: number) => number;
78
+ /**
79
+ * Gets line height forr a selected family.
80
+ */
81
+ export declare const getLineHeight: (fontFamily: FontFamilyValues) => number & {
82
+ _brand: "unitlessLineHeight";
83
+ };
@@ -1,35 +1,35 @@
1
- /**
2
- * Encapsulates font metrics with additional font metadata.
3
- * */
4
- export interface FontMetadata {
5
- /** for head & hhea metrics read the woff2 with https://fontdrop.info/ */
6
- metrics: {
7
- /** head.unitsPerEm metric */
8
- unitsPerEm: 1000 | 1024 | 2048;
9
- /** hhea.ascender metric */
10
- ascender: number;
11
- /** hhea.descender metric */
12
- descender: number;
13
- /** harcoded unitless line-height, https://github.com/excalidraw/excalidraw/pull/6360#issuecomment-1477635971 */
14
- lineHeight: number;
15
- };
16
- /** element to be displayed as an icon */
17
- icon: JSX.Element;
18
- /** flag to indicate a deprecated font */
19
- deprecated?: true;
20
- /** flag to indicate a server-side only font */
21
- serverSide?: true;
22
- /** flag to indiccate a local-only font */
23
- local?: true;
24
- }
25
- export declare const FONT_METADATA: Record<number, FontMetadata>;
26
- /** Unicode ranges */
27
- export declare const RANGES: {
28
- LATIN: string;
29
- LATIN_EXT: string;
30
- CYRILIC_EXT: string;
31
- CYRILIC: string;
32
- VIETNAMESE: string;
33
- };
34
- /** local protocol to skip the local font from registering or inlining */
35
- export declare const LOCAL_FONT_PROTOCOL = "local:";
1
+ /**
2
+ * Encapsulates font metrics with additional font metadata.
3
+ * */
4
+ export interface FontMetadata {
5
+ /** for head & hhea metrics read the woff2 with https://fontdrop.info/ */
6
+ metrics: {
7
+ /** head.unitsPerEm metric */
8
+ unitsPerEm: 1000 | 1024 | 2048;
9
+ /** hhea.ascender metric */
10
+ ascender: number;
11
+ /** hhea.descender metric */
12
+ descender: number;
13
+ /** harcoded unitless line-height, https://github.com/excalidraw/excalidraw/pull/6360#issuecomment-1477635971 */
14
+ lineHeight: number;
15
+ };
16
+ /** element to be displayed as an icon */
17
+ icon: JSX.Element;
18
+ /** flag to indicate a deprecated font */
19
+ deprecated?: true;
20
+ /** flag to indicate a server-side only font */
21
+ serverSide?: true;
22
+ /** flag to indiccate a local-only font */
23
+ local?: true;
24
+ }
25
+ export declare const FONT_METADATA: Record<number, FontMetadata>;
26
+ /** Unicode ranges */
27
+ export declare const RANGES: {
28
+ LATIN: string;
29
+ LATIN_EXT: string;
30
+ CYRILIC_EXT: string;
31
+ CYRILIC: string;
32
+ VIETNAMESE: string;
33
+ };
34
+ /** local protocol to skip the local font from registering or inlining */
35
+ export declare const LOCAL_FONT_PROTOCOL = "local:";
@@ -1,48 +1,48 @@
1
- import type { ExcalidrawElement, OrderedExcalidrawElement } from "./element/types";
2
- /**
3
- * Envisioned relation between array order and fractional indices:
4
- *
5
- * 1) Array (or array-like ordered data structure) should be used as a cache of elements order, hiding the internal fractional indices implementation.
6
- * - it's undesirable to perform reorder for each related operation, therefore it's necessary to cache the order defined by fractional indices into an ordered data structure
7
- * - it's easy enough to define the order of the elements from the outside (boundaries), without worrying about the underlying structure of fractional indices (especially for the host apps)
8
- * - it's necessary to always keep the array support for backwards compatibility (restore) - old scenes, old libraries, supporting multiple excalidraw versions etc.
9
- * - it's necessary to always keep the fractional indices in sync with the array order
10
- * - elements with invalid indices should be detected and synced, without altering the already valid indices
11
- *
12
- * 2) Fractional indices should be used to reorder the elements, whenever the cached order is expected to be invalidated.
13
- * - as the fractional indices are encoded as part of the elements, it opens up possibilities for incremental-like APIs
14
- * - re-order based on fractional indices should be part of (multiplayer) operations such as reconciliation & undo/redo
15
- * - technically all the z-index actions could perform also re-order based on fractional indices,but in current state it would not bring much benefits,
16
- * as it's faster & more efficient to perform re-order based on array manipulation and later synchronisation of moved indices with the array order
17
- */
18
- /**
19
- * Ensure that all elements have valid fractional indices.
20
- *
21
- * @throws `InvalidFractionalIndexError` if invalid index is detected.
22
- */
23
- export declare const validateFractionalIndices: (elements: readonly ExcalidrawElement[], { shouldThrow, includeBoundTextValidation, ignoreLogs, reconciliationContext, }: {
24
- shouldThrow: boolean;
25
- includeBoundTextValidation: boolean;
26
- ignoreLogs?: true | undefined;
27
- reconciliationContext?: {
28
- localElements: ReadonlyArray<ExcalidrawElement>;
29
- remoteElements: ReadonlyArray<ExcalidrawElement>;
30
- } | undefined;
31
- }) => void;
32
- /**
33
- * Order the elements based on the fractional indices.
34
- * - when fractional indices are identical, break the tie based on the element id
35
- * - when there is no fractional index in one of the elements, respect the order of the array
36
- */
37
- export declare const orderByFractionalIndex: (elements: OrderedExcalidrawElement[]) => OrderedExcalidrawElement[];
38
- /**
39
- * Synchronizes invalid fractional indices of moved elements with the array order by mutating passed elements.
40
- * If the synchronization fails or the result is invalid, it fallbacks to `syncInvalidIndices`.
41
- */
42
- export declare const syncMovedIndices: (elements: readonly ExcalidrawElement[], movedElements: Map<string, ExcalidrawElement>) => OrderedExcalidrawElement[];
43
- /**
44
- * Synchronizes all invalid fractional indices with the array order by mutating passed elements.
45
- *
46
- * WARN: in edge cases it could modify the elements which were not moved, as it's impossible to guess the actually moved elements from the elements array itself.
47
- */
48
- export declare const syncInvalidIndices: (elements: readonly ExcalidrawElement[]) => OrderedExcalidrawElement[];
1
+ import type { ExcalidrawElement, OrderedExcalidrawElement } from "./element/types";
2
+ /**
3
+ * Envisioned relation between array order and fractional indices:
4
+ *
5
+ * 1) Array (or array-like ordered data structure) should be used as a cache of elements order, hiding the internal fractional indices implementation.
6
+ * - it's undesirable to perform reorder for each related operation, therefore it's necessary to cache the order defined by fractional indices into an ordered data structure
7
+ * - it's easy enough to define the order of the elements from the outside (boundaries), without worrying about the underlying structure of fractional indices (especially for the host apps)
8
+ * - it's necessary to always keep the array support for backwards compatibility (restore) - old scenes, old libraries, supporting multiple excalidraw versions etc.
9
+ * - it's necessary to always keep the fractional indices in sync with the array order
10
+ * - elements with invalid indices should be detected and synced, without altering the already valid indices
11
+ *
12
+ * 2) Fractional indices should be used to reorder the elements, whenever the cached order is expected to be invalidated.
13
+ * - as the fractional indices are encoded as part of the elements, it opens up possibilities for incremental-like APIs
14
+ * - re-order based on fractional indices should be part of (multiplayer) operations such as reconciliation & undo/redo
15
+ * - technically all the z-index actions could perform also re-order based on fractional indices,but in current state it would not bring much benefits,
16
+ * as it's faster & more efficient to perform re-order based on array manipulation and later synchronisation of moved indices with the array order
17
+ */
18
+ /**
19
+ * Ensure that all elements have valid fractional indices.
20
+ *
21
+ * @throws `InvalidFractionalIndexError` if invalid index is detected.
22
+ */
23
+ export declare const validateFractionalIndices: (elements: readonly ExcalidrawElement[], { shouldThrow, includeBoundTextValidation, ignoreLogs, reconciliationContext, }: {
24
+ shouldThrow: boolean;
25
+ includeBoundTextValidation: boolean;
26
+ ignoreLogs?: true | undefined;
27
+ reconciliationContext?: {
28
+ localElements: ReadonlyArray<ExcalidrawElement>;
29
+ remoteElements: ReadonlyArray<ExcalidrawElement>;
30
+ } | undefined;
31
+ }) => void;
32
+ /**
33
+ * Order the elements based on the fractional indices.
34
+ * - when fractional indices are identical, break the tie based on the element id
35
+ * - when there is no fractional index in one of the elements, respect the order of the array
36
+ */
37
+ export declare const orderByFractionalIndex: (elements: OrderedExcalidrawElement[]) => OrderedExcalidrawElement[];
38
+ /**
39
+ * Synchronizes invalid fractional indices of moved elements with the array order by mutating passed elements.
40
+ * If the synchronization fails or the result is invalid, it fallbacks to `syncInvalidIndices`.
41
+ */
42
+ export declare const syncMovedIndices: (elements: readonly ExcalidrawElement[], movedElements: Map<string, ExcalidrawElement>) => OrderedExcalidrawElement[];
43
+ /**
44
+ * Synchronizes all invalid fractional indices with the array order by mutating passed elements.
45
+ *
46
+ * WARN: in edge cases it could modify the elements which were not moved, as it's impossible to guess the actually moved elements from the elements array itself.
47
+ */
48
+ export declare const syncInvalidIndices: (elements: readonly ExcalidrawElement[]) => OrderedExcalidrawElement[];
@@ -1,63 +1,63 @@
1
- import type { ElementsMap, ElementsMapOrArray, ExcalidrawElement, ExcalidrawFrameLikeElement, NonDeleted, NonDeletedExcalidrawElement } from "./element/types";
2
- import type { AppClassProperties, AppState, StaticCanvasAppState } from "./types";
3
- import type { ExcalidrawElementsIncludingDeleted } from "./scene/Scene";
4
- import type { ReadonlySetLike } from "./utility-types";
5
- export declare const bindElementsToFramesAfterDuplication: (nextElements: readonly ExcalidrawElement[], oldElements: readonly ExcalidrawElement[], oldIdToDuplicatedId: Map<ExcalidrawElement["id"], ExcalidrawElement["id"]>) => void;
6
- export declare function isElementIntersectingFrame(element: ExcalidrawElement, frame: ExcalidrawFrameLikeElement, elementsMap: ElementsMap): boolean;
7
- export declare const getElementsCompletelyInFrame: (elements: readonly ExcalidrawElement[], frame: ExcalidrawFrameLikeElement, elementsMap: ElementsMap) => ExcalidrawElement[];
8
- export declare const isElementContainingFrame: (elements: readonly ExcalidrawElement[], element: ExcalidrawElement, frame: ExcalidrawFrameLikeElement, elementsMap: ElementsMap) => boolean;
9
- export declare const getElementsIntersectingFrame: (elements: readonly ExcalidrawElement[], frame: ExcalidrawFrameLikeElement) => ExcalidrawElement[];
10
- export declare const elementsAreInFrameBounds: (elements: readonly ExcalidrawElement[], frame: ExcalidrawFrameLikeElement, elementsMap: ElementsMap) => boolean;
11
- export declare const elementOverlapsWithFrame: (element: ExcalidrawElement, frame: ExcalidrawFrameLikeElement, elementsMap: ElementsMap) => boolean;
12
- export declare const isCursorInFrame: (cursorCoords: {
13
- x: number;
14
- y: number;
15
- }, frame: NonDeleted<ExcalidrawFrameLikeElement>, elementsMap: ElementsMap) => boolean;
16
- export declare const groupsAreAtLeastIntersectingTheFrame: (elements: readonly NonDeletedExcalidrawElement[], groupIds: readonly string[], frame: ExcalidrawFrameLikeElement) => boolean;
17
- export declare const groupsAreCompletelyOutOfFrame: (elements: readonly NonDeletedExcalidrawElement[], groupIds: readonly string[], frame: ExcalidrawFrameLikeElement) => boolean;
18
- /**
19
- * Returns a map of frameId to frame elements. Includes empty frames.
20
- */
21
- export declare const groupByFrameLikes: (elements: readonly ExcalidrawElement[]) => Map<string, ExcalidrawElement[]>;
22
- export declare const getFrameChildren: (allElements: ElementsMapOrArray, frameId: string) => ExcalidrawElement[];
23
- export declare const getFrameLikeElements: (allElements: ExcalidrawElementsIncludingDeleted) => ExcalidrawFrameLikeElement[];
24
- /**
25
- * Returns ExcalidrawFrameElements and non-frame-children elements.
26
- *
27
- * Considers children as root elements if they point to a frame parent
28
- * non-existing in the elements set.
29
- *
30
- * Considers non-frame bound elements (container or arrow labels) as root.
31
- */
32
- export declare const getRootElements: (allElements: ExcalidrawElementsIncludingDeleted) => ExcalidrawElement[];
33
- export declare const getElementsInResizingFrame: (allElements: ExcalidrawElementsIncludingDeleted, frame: ExcalidrawFrameLikeElement, appState: AppState, elementsMap: ElementsMap) => ExcalidrawElement[];
34
- export declare const getElementsInNewFrame: (elements: ExcalidrawElementsIncludingDeleted, frame: ExcalidrawFrameLikeElement, elementsMap: ElementsMap) => ExcalidrawElement[];
35
- export declare const getContainingFrame: (element: ExcalidrawElement, elementsMap: ElementsMap) => ExcalidrawFrameLikeElement | null;
36
- /** */
37
- export declare const filterElementsEligibleAsFrameChildren: (elements: readonly ExcalidrawElement[], frame: ExcalidrawFrameLikeElement) => ExcalidrawElement[];
38
- /**
39
- * Retains (or repairs for target frame) the ordering invriant where children
40
- * elements come right before the parent frame:
41
- * [el, el, child, child, frame, el]
42
- *
43
- * @returns mutated allElements (same data structure)
44
- */
45
- export declare const addElementsToFrame: <T extends ElementsMapOrArray>(allElements: T, elementsToAdd: NonDeletedExcalidrawElement[], frame: ExcalidrawFrameLikeElement) => T;
46
- export declare const removeElementsFromFrame: (elementsToRemove: ReadonlySetLike<NonDeletedExcalidrawElement>, elementsMap: ElementsMap) => void;
47
- export declare const removeAllElementsFromFrame: <T extends ExcalidrawElement>(allElements: readonly T[], frame: ExcalidrawFrameLikeElement) => readonly T[];
48
- export declare const replaceAllElementsInFrame: <T extends ExcalidrawElement>(allElements: readonly T[], nextElementsInFrame: ExcalidrawElement[], frame: ExcalidrawFrameLikeElement, app: AppClassProperties) => T[];
49
- /** does not mutate elements, but returns new ones */
50
- export declare const updateFrameMembershipOfSelectedElements: <T extends ElementsMapOrArray>(allElements: T, appState: AppState, app: AppClassProperties) => T;
51
- /**
52
- * filters out elements that are inside groups that contain a frame element
53
- * anywhere in the group tree
54
- */
55
- export declare const omitGroupsContainingFrameLikes: (allElements: ElementsMapOrArray, selectedElements?: readonly ExcalidrawElement[]) => ExcalidrawElement[];
56
- /**
57
- * depending on the appState, return target frame, which is the frame the given element
58
- * is going to be added to or remove from
59
- */
60
- export declare const getTargetFrame: (element: ExcalidrawElement, elementsMap: ElementsMap, appState: StaticCanvasAppState) => import("./element/types").ExcalidrawFrameElement | import("./element/types").ExcalidrawMagicFrameElement | null;
61
- export declare const isElementInFrame: (element: ExcalidrawElement, allElementsMap: ElementsMap, appState: StaticCanvasAppState) => boolean;
62
- export declare const getFrameLikeTitle: (element: ExcalidrawFrameLikeElement) => string;
63
- export declare const getElementsOverlappingFrame: (elements: readonly ExcalidrawElement[], frame: ExcalidrawFrameLikeElement) => NonDeletedExcalidrawElement[];
1
+ import type { ElementsMap, ElementsMapOrArray, ExcalidrawElement, ExcalidrawFrameLikeElement, NonDeleted, NonDeletedExcalidrawElement } from "./element/types";
2
+ import type { AppClassProperties, AppState, StaticCanvasAppState } from "./types";
3
+ import type { ExcalidrawElementsIncludingDeleted } from "./scene/Scene";
4
+ import type { ReadonlySetLike } from "./utility-types";
5
+ export declare const bindElementsToFramesAfterDuplication: (nextElements: readonly ExcalidrawElement[], oldElements: readonly ExcalidrawElement[], oldIdToDuplicatedId: Map<ExcalidrawElement["id"], ExcalidrawElement["id"]>) => void;
6
+ export declare function isElementIntersectingFrame(element: ExcalidrawElement, frame: ExcalidrawFrameLikeElement, elementsMap: ElementsMap): boolean;
7
+ export declare const getElementsCompletelyInFrame: (elements: readonly ExcalidrawElement[], frame: ExcalidrawFrameLikeElement, elementsMap: ElementsMap) => ExcalidrawElement[];
8
+ export declare const isElementContainingFrame: (elements: readonly ExcalidrawElement[], element: ExcalidrawElement, frame: ExcalidrawFrameLikeElement, elementsMap: ElementsMap) => boolean;
9
+ export declare const getElementsIntersectingFrame: (elements: readonly ExcalidrawElement[], frame: ExcalidrawFrameLikeElement) => ExcalidrawElement[];
10
+ export declare const elementsAreInFrameBounds: (elements: readonly ExcalidrawElement[], frame: ExcalidrawFrameLikeElement, elementsMap: ElementsMap) => boolean;
11
+ export declare const elementOverlapsWithFrame: (element: ExcalidrawElement, frame: ExcalidrawFrameLikeElement, elementsMap: ElementsMap) => boolean;
12
+ export declare const isCursorInFrame: (cursorCoords: {
13
+ x: number;
14
+ y: number;
15
+ }, frame: NonDeleted<ExcalidrawFrameLikeElement>, elementsMap: ElementsMap) => boolean;
16
+ export declare const groupsAreAtLeastIntersectingTheFrame: (elements: readonly NonDeletedExcalidrawElement[], groupIds: readonly string[], frame: ExcalidrawFrameLikeElement) => boolean;
17
+ export declare const groupsAreCompletelyOutOfFrame: (elements: readonly NonDeletedExcalidrawElement[], groupIds: readonly string[], frame: ExcalidrawFrameLikeElement) => boolean;
18
+ /**
19
+ * Returns a map of frameId to frame elements. Includes empty frames.
20
+ */
21
+ export declare const groupByFrameLikes: (elements: readonly ExcalidrawElement[]) => Map<string, ExcalidrawElement[]>;
22
+ export declare const getFrameChildren: (allElements: ElementsMapOrArray, frameId: string) => ExcalidrawElement[];
23
+ export declare const getFrameLikeElements: (allElements: ExcalidrawElementsIncludingDeleted) => ExcalidrawFrameLikeElement[];
24
+ /**
25
+ * Returns ExcalidrawFrameElements and non-frame-children elements.
26
+ *
27
+ * Considers children as root elements if they point to a frame parent
28
+ * non-existing in the elements set.
29
+ *
30
+ * Considers non-frame bound elements (container or arrow labels) as root.
31
+ */
32
+ export declare const getRootElements: (allElements: ExcalidrawElementsIncludingDeleted) => ExcalidrawElement[];
33
+ export declare const getElementsInResizingFrame: (allElements: ExcalidrawElementsIncludingDeleted, frame: ExcalidrawFrameLikeElement, appState: AppState, elementsMap: ElementsMap) => ExcalidrawElement[];
34
+ export declare const getElementsInNewFrame: (elements: ExcalidrawElementsIncludingDeleted, frame: ExcalidrawFrameLikeElement, elementsMap: ElementsMap) => ExcalidrawElement[];
35
+ export declare const getContainingFrame: (element: ExcalidrawElement, elementsMap: ElementsMap) => ExcalidrawFrameLikeElement | null;
36
+ /** */
37
+ export declare const filterElementsEligibleAsFrameChildren: (elements: readonly ExcalidrawElement[], frame: ExcalidrawFrameLikeElement) => ExcalidrawElement[];
38
+ /**
39
+ * Retains (or repairs for target frame) the ordering invriant where children
40
+ * elements come right before the parent frame:
41
+ * [el, el, child, child, frame, el]
42
+ *
43
+ * @returns mutated allElements (same data structure)
44
+ */
45
+ export declare const addElementsToFrame: <T extends ElementsMapOrArray>(allElements: T, elementsToAdd: NonDeletedExcalidrawElement[], frame: ExcalidrawFrameLikeElement) => T;
46
+ export declare const removeElementsFromFrame: (elementsToRemove: ReadonlySetLike<NonDeletedExcalidrawElement>, elementsMap: ElementsMap) => void;
47
+ export declare const removeAllElementsFromFrame: <T extends ExcalidrawElement>(allElements: readonly T[], frame: ExcalidrawFrameLikeElement) => readonly T[];
48
+ export declare const replaceAllElementsInFrame: <T extends ExcalidrawElement>(allElements: readonly T[], nextElementsInFrame: ExcalidrawElement[], frame: ExcalidrawFrameLikeElement, app: AppClassProperties) => T[];
49
+ /** does not mutate elements, but returns new ones */
50
+ export declare const updateFrameMembershipOfSelectedElements: <T extends ElementsMapOrArray>(allElements: T, appState: AppState, app: AppClassProperties) => T;
51
+ /**
52
+ * filters out elements that are inside groups that contain a frame element
53
+ * anywhere in the group tree
54
+ */
55
+ export declare const omitGroupsContainingFrameLikes: (allElements: ElementsMapOrArray, selectedElements?: readonly ExcalidrawElement[]) => ExcalidrawElement[];
56
+ /**
57
+ * depending on the appState, return target frame, which is the frame the given element
58
+ * is going to be added to or remove from
59
+ */
60
+ export declare const getTargetFrame: (element: ExcalidrawElement, elementsMap: ElementsMap, appState: StaticCanvasAppState) => import("./element/types").ExcalidrawFrameElement | import("./element/types").ExcalidrawMagicFrameElement | null;
61
+ export declare const isElementInFrame: (element: ExcalidrawElement, allElementsMap: ElementsMap, appState: StaticCanvasAppState) => boolean;
62
+ export declare const getFrameLikeTitle: (element: ExcalidrawFrameLikeElement) => string;
63
+ export declare const getElementsOverlappingFrame: (elements: readonly ExcalidrawElement[], frame: ExcalidrawFrameLikeElement) => NonDeletedExcalidrawElement[];
@@ -1,63 +1,63 @@
1
- /**
2
- * This is a 2D Projective Geometric Algebra implementation.
3
- *
4
- * For wider context on geometric algebra visit see https://bivector.net.
5
- *
6
- * For this specific algebra see cheatsheet https://bivector.net/2DPGA.pdf.
7
- *
8
- * Converted from generator written by enki, with a ton of added on top.
9
- *
10
- * This library uses 8-vectors to represent points, directions and lines
11
- * in 2D space.
12
- *
13
- * An array `[a, b, c, d, e, f, g, h]` represents a n(8)vector:
14
- * a + b*e0 + c*e1 + d*e2 + e*e01 + f*e20 + g*e12 + h*e012
15
- *
16
- * See GAPoint, GALine, GADirection and GATransform modules for common
17
- * operations.
18
- */
19
- export type Point = NVector;
20
- export type Direction = NVector;
21
- export type Line = NVector;
22
- export type Transform = NVector;
23
- export declare const point: (x: number, y: number) => NVector;
24
- export declare const origin: () => NVector;
25
- export declare const direction: (x: number, y: number) => NVector;
26
- export declare const offset: (x: number, y: number) => NVector;
27
- type NVector = readonly [
28
- number,
29
- number,
30
- number,
31
- number,
32
- number,
33
- number,
34
- number,
35
- number
36
- ];
37
- export declare const nvector: (value?: number, index?: number) => NVector;
38
- export declare const toString: (nvector: NVector) => string;
39
- export declare const reverse: (nvector: NVector) => NVector;
40
- export declare const dual: (nvector: NVector) => NVector;
41
- export declare const conjugate: (nvector: NVector) => NVector;
42
- export declare const involute: (nvector: NVector) => NVector;
43
- export declare const add: (a: NVector, b: NVector | number) => NVector;
44
- export declare const sub: (a: NVector, b: NVector | number) => NVector;
45
- export declare const mul: (a: NVector, b: NVector | number) => NVector;
46
- export declare const mulScalar: (a: NVector, b: NVector) => number;
47
- export declare const meet: (a: NVector, b: NVector) => NVector;
48
- export declare const join: (a: NVector, b: NVector) => NVector;
49
- export declare const joinScalar: (a: NVector, b: NVector) => number;
50
- export declare const dot: (a: NVector, b: NVector) => NVector;
51
- export declare const norm: (a: NVector) => number;
52
- export declare const inorm: (a: NVector) => number;
53
- export declare const normalized: (a: NVector) => NVector;
54
- export declare const inormalized: (a: NVector) => NVector;
55
- export declare const E0: NVector;
56
- export declare const E1: NVector;
57
- export declare const E2: NVector;
58
- export declare const E01: NVector;
59
- export declare const E20: NVector;
60
- export declare const E12: NVector;
61
- export declare const E012: NVector;
62
- export declare const I: NVector;
63
- export {};
1
+ /**
2
+ * This is a 2D Projective Geometric Algebra implementation.
3
+ *
4
+ * For wider context on geometric algebra visit see https://bivector.net.
5
+ *
6
+ * For this specific algebra see cheatsheet https://bivector.net/2DPGA.pdf.
7
+ *
8
+ * Converted from generator written by enki, with a ton of added on top.
9
+ *
10
+ * This library uses 8-vectors to represent points, directions and lines
11
+ * in 2D space.
12
+ *
13
+ * An array `[a, b, c, d, e, f, g, h]` represents a n(8)vector:
14
+ * a + b*e0 + c*e1 + d*e2 + e*e01 + f*e20 + g*e12 + h*e012
15
+ *
16
+ * See GAPoint, GALine, GADirection and GATransform modules for common
17
+ * operations.
18
+ */
19
+ export type Point = NVector;
20
+ export type Direction = NVector;
21
+ export type Line = NVector;
22
+ export type Transform = NVector;
23
+ export declare const point: (x: number, y: number) => NVector;
24
+ export declare const origin: () => NVector;
25
+ export declare const direction: (x: number, y: number) => NVector;
26
+ export declare const offset: (x: number, y: number) => NVector;
27
+ type NVector = readonly [
28
+ number,
29
+ number,
30
+ number,
31
+ number,
32
+ number,
33
+ number,
34
+ number,
35
+ number
36
+ ];
37
+ export declare const nvector: (value?: number, index?: number) => NVector;
38
+ export declare const toString: (nvector: NVector) => string;
39
+ export declare const reverse: (nvector: NVector) => NVector;
40
+ export declare const dual: (nvector: NVector) => NVector;
41
+ export declare const conjugate: (nvector: NVector) => NVector;
42
+ export declare const involute: (nvector: NVector) => NVector;
43
+ export declare const add: (a: NVector, b: NVector | number) => NVector;
44
+ export declare const sub: (a: NVector, b: NVector | number) => NVector;
45
+ export declare const mul: (a: NVector, b: NVector | number) => NVector;
46
+ export declare const mulScalar: (a: NVector, b: NVector) => number;
47
+ export declare const meet: (a: NVector, b: NVector) => NVector;
48
+ export declare const join: (a: NVector, b: NVector) => NVector;
49
+ export declare const joinScalar: (a: NVector, b: NVector) => number;
50
+ export declare const dot: (a: NVector, b: NVector) => NVector;
51
+ export declare const norm: (a: NVector) => number;
52
+ export declare const inorm: (a: NVector) => number;
53
+ export declare const normalized: (a: NVector) => NVector;
54
+ export declare const inormalized: (a: NVector) => NVector;
55
+ export declare const E0: NVector;
56
+ export declare const E1: NVector;
57
+ export declare const E2: NVector;
58
+ export declare const E01: NVector;
59
+ export declare const E20: NVector;
60
+ export declare const E12: NVector;
61
+ export declare const E012: NVector;
62
+ export declare const I: NVector;
63
+ export {};
@@ -1,8 +1,8 @@
1
- /**
2
- * A direction is stored as an array `[0, 0, 0, 0, y, x, 0, 0]` representing
3
- * vector `(x, y)`.
4
- */
5
- export declare const from: (point: readonly [number, number, number, number, number, number, number, number]) => readonly [number, number, number, number, number, number, number, number];
6
- export declare const fromTo: (from: readonly [number, number, number, number, number, number, number, number], to: readonly [number, number, number, number, number, number, number, number]) => readonly [number, number, number, number, number, number, number, number];
7
- export declare const orthogonal: (direction: readonly [number, number, number, number, number, number, number, number]) => readonly [number, number, number, number, number, number, number, number];
8
- export declare const orthogonalToLine: (line: readonly [number, number, number, number, number, number, number, number]) => readonly [number, number, number, number, number, number, number, number];
1
+ /**
2
+ * A direction is stored as an array `[0, 0, 0, 0, y, x, 0, 0]` representing
3
+ * vector `(x, y)`.
4
+ */
5
+ export declare const from: (point: readonly [number, number, number, number, number, number, number, number]) => readonly [number, number, number, number, number, number, number, number];
6
+ export declare const fromTo: (from: readonly [number, number, number, number, number, number, number, number], to: readonly [number, number, number, number, number, number, number, number]) => readonly [number, number, number, number, number, number, number, number];
7
+ export declare const orthogonal: (direction: readonly [number, number, number, number, number, number, number, number]) => readonly [number, number, number, number, number, number, number, number];
8
+ export declare const orthogonalToLine: (line: readonly [number, number, number, number, number, number, number, number]) => readonly [number, number, number, number, number, number, number, number];