@excalidraw/excalidraw 0.17.1-d9bbf1e → 0.17.1-e63dd02

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 (416) hide show
  1. package/CHANGELOG.md +4 -0
  2. package/dist/browser/dev/excalidraw-assets-dev/CascadiaCode-Regular-TMZI7IJ5.woff2 +0 -0
  3. package/dist/browser/dev/excalidraw-assets-dev/ComicShanns-Regular-6TOETDFT.woff2 +0 -0
  4. package/dist/browser/dev/excalidraw-assets-dev/Excalifont-Regular-CPKEUDVM.woff2 +0 -0
  5. package/dist/browser/dev/excalidraw-assets-dev/LiberationSans-Regular-ZQD73GJM.woff2 +0 -0
  6. package/dist/browser/dev/excalidraw-assets-dev/Virgil-Regular-YHAB2VGJ.woff2 +0 -0
  7. package/dist/browser/dev/excalidraw-assets-dev/{chunk-XOM7LNOU.js → chunk-IT7T3AIK.js} +49 -8
  8. package/dist/browser/dev/excalidraw-assets-dev/chunk-IT7T3AIK.js.map +7 -0
  9. package/dist/browser/dev/excalidraw-assets-dev/{chunk-BLEB3M62.js → chunk-RNHSD5AR.js} +7668 -2142
  10. package/dist/browser/dev/excalidraw-assets-dev/chunk-RNHSD5AR.js.map +7 -0
  11. package/dist/browser/dev/excalidraw-assets-dev/{dist-ITJNUBZF.js → dist-DNSPZDOZ.js} +66 -32
  12. package/dist/browser/dev/excalidraw-assets-dev/dist-DNSPZDOZ.js.map +7 -0
  13. package/dist/browser/dev/excalidraw-assets-dev/{en-TR4QLF5E.js → en-XV7OZCPP.js} +8 -2
  14. package/dist/browser/dev/excalidraw-assets-dev/{image-ZGDDRBEN.js → image-77HZYGLG.js} +2 -2
  15. package/dist/browser/dev/excalidraw-assets-dev/{image-O66MQ7WQ.css → image-WDHYGKKP.css} +1 -1
  16. package/dist/browser/dev/excalidraw-assets-dev/{image-O66MQ7WQ.css.map → image-WDHYGKKP.css.map} +2 -2
  17. package/dist/browser/dev/index.css +610 -180
  18. package/dist/browser/dev/index.css.map +3 -3
  19. package/dist/browser/dev/index.js +13306 -8006
  20. package/dist/browser/dev/index.js.map +4 -4
  21. package/dist/browser/prod/excalidraw-assets/CascadiaCode-Regular-TMZI7IJ5.woff2 +0 -0
  22. package/dist/browser/prod/excalidraw-assets/ComicShanns-Regular-6TOETDFT.woff2 +0 -0
  23. package/dist/browser/prod/excalidraw-assets/Excalifont-Regular-CPKEUDVM.woff2 +0 -0
  24. package/dist/browser/prod/excalidraw-assets/LiberationSans-Regular-ZQD73GJM.woff2 +0 -0
  25. package/dist/browser/prod/excalidraw-assets/Virgil-Regular-YHAB2VGJ.woff2 +0 -0
  26. package/dist/browser/prod/excalidraw-assets/chunk-OYEADJSR.js +63 -0
  27. package/dist/browser/prod/excalidraw-assets/{chunk-5SYIAZGL.js → chunk-PDYFZJMS.js} +5 -5
  28. package/dist/browser/prod/excalidraw-assets/dist-NLUQPPQQ.js +7 -0
  29. package/dist/browser/prod/excalidraw-assets/en-YVAVVILW.js +1 -0
  30. package/dist/browser/prod/excalidraw-assets/image-X3GFZHNN.js +1 -0
  31. package/dist/browser/prod/index.css +1 -1
  32. package/dist/browser/prod/index.js +70 -51
  33. package/dist/dev/CascadiaCode-Regular-TMZI7IJ5.woff2 +0 -0
  34. package/dist/dev/ComicShanns-Regular-6TOETDFT.woff2 +0 -0
  35. package/dist/dev/Excalifont-Regular-CPKEUDVM.woff2 +0 -0
  36. package/dist/dev/LiberationSans-Regular-ZQD73GJM.woff2 +0 -0
  37. package/dist/dev/Virgil-Regular-YHAB2VGJ.woff2 +0 -0
  38. package/dist/dev/{en-XW4JO6VX.json → en-YNVBSAIL.json} +42 -7
  39. package/dist/dev/index.css +610 -180
  40. package/dist/dev/index.css.map +3 -3
  41. package/dist/dev/index.js +22165 -16833
  42. package/dist/dev/index.js.map +4 -4
  43. package/dist/excalidraw/actions/actionAddToLibrary.d.ts +24 -9
  44. package/dist/excalidraw/actions/actionAlign.d.ts +8 -8
  45. package/dist/excalidraw/actions/actionBoundText.d.ts +20 -10
  46. package/dist/excalidraw/actions/actionBoundText.js +3 -1
  47. package/dist/excalidraw/actions/actionCanvas.d.ts +100 -40
  48. package/dist/excalidraw/actions/actionCanvas.js +1 -1
  49. package/dist/excalidraw/actions/actionClipboard.d.ts +62 -26
  50. package/dist/excalidraw/actions/actionDeleteSelected.d.ts +28 -12
  51. package/dist/excalidraw/actions/actionDeleteSelected.js +24 -5
  52. package/dist/excalidraw/actions/actionDistribute.d.ts +4 -4
  53. package/dist/excalidraw/actions/actionDuplicateSelection.d.ts +3 -3
  54. package/dist/excalidraw/actions/actionDuplicateSelection.js +1 -2
  55. package/dist/excalidraw/actions/actionElementLock.d.ts +17 -7
  56. package/dist/excalidraw/actions/actionExport.d.ts +75 -30
  57. package/dist/excalidraw/actions/actionFinalize.d.ts +17 -7
  58. package/dist/excalidraw/actions/actionFinalize.js +2 -2
  59. package/dist/excalidraw/actions/actionFlip.d.ts +4 -4
  60. package/dist/excalidraw/actions/actionFlip.js +2 -2
  61. package/dist/excalidraw/actions/actionFrame.d.ts +338 -10
  62. package/dist/excalidraw/actions/actionGroup.d.ts +324 -4
  63. package/dist/excalidraw/actions/actionHistory.d.ts +3 -3
  64. package/dist/excalidraw/actions/actionHistory.js +8 -8
  65. package/dist/excalidraw/actions/actionLinearEditor.d.ts +12 -5
  66. package/dist/excalidraw/actions/actionLinearEditor.js +21 -5
  67. package/dist/excalidraw/actions/actionLink.d.ts +8 -3
  68. package/dist/excalidraw/actions/actionMenu.d.ts +24 -9
  69. package/dist/excalidraw/actions/actionNavigate.d.ts +17 -7
  70. package/dist/excalidraw/actions/actionProperties.d.ts +476 -82
  71. package/dist/excalidraw/actions/actionProperties.js +384 -59
  72. package/dist/excalidraw/actions/actionSelectAll.d.ts +9 -4
  73. package/dist/excalidraw/actions/actionStyles.d.ts +12 -4
  74. package/dist/excalidraw/actions/actionStyles.js +3 -2
  75. package/dist/excalidraw/actions/actionTextAutoResize.d.ts +17 -0
  76. package/dist/excalidraw/actions/actionTextAutoResize.js +38 -0
  77. package/dist/excalidraw/actions/actionToggleGridMode.d.ts +9 -4
  78. package/dist/excalidraw/actions/actionToggleObjectsSnapMode.d.ts +8 -3
  79. package/dist/excalidraw/actions/actionToggleStats.d.ts +9 -3
  80. package/dist/excalidraw/actions/actionToggleStats.js +4 -3
  81. package/dist/excalidraw/actions/actionToggleViewMode.d.ts +8 -3
  82. package/dist/excalidraw/actions/actionToggleZenMode.d.ts +8 -3
  83. package/dist/excalidraw/actions/actionZindex.d.ts +8 -4
  84. package/dist/excalidraw/actions/actionZindex.js +4 -0
  85. package/dist/excalidraw/actions/manager.d.ts +3 -3
  86. package/dist/excalidraw/actions/register.d.ts +1 -1
  87. package/dist/excalidraw/actions/shortcuts.d.ts +2 -2
  88. package/dist/excalidraw/actions/types.d.ts +6 -6
  89. package/dist/excalidraw/align.d.ts +1 -1
  90. package/dist/excalidraw/analytics.js +9 -7
  91. package/dist/excalidraw/animated-trail.d.ts +2 -2
  92. package/dist/excalidraw/appState.d.ts +6 -2
  93. package/dist/excalidraw/appState.js +14 -3
  94. package/dist/excalidraw/binaryheap.d.ts +12 -0
  95. package/dist/excalidraw/binaryheap.js +93 -0
  96. package/dist/excalidraw/change.d.ts +6 -5
  97. package/dist/excalidraw/change.js +20 -11
  98. package/dist/excalidraw/charts.d.ts +1 -1
  99. package/dist/excalidraw/charts.js +0 -10
  100. package/dist/excalidraw/clients.d.ts +2 -2
  101. package/dist/excalidraw/clients.js +1 -1
  102. package/dist/excalidraw/clipboard.d.ts +3 -3
  103. package/dist/excalidraw/colors.d.ts +1 -1
  104. package/dist/excalidraw/components/Actions.d.ts +3 -3
  105. package/dist/excalidraw/components/Actions.js +14 -9
  106. package/dist/excalidraw/components/App.d.ts +14 -17
  107. package/dist/excalidraw/components/App.js +356 -217
  108. package/dist/excalidraw/components/ButtonIcon.d.ts +15 -0
  109. package/dist/excalidraw/components/ButtonIcon.js +8 -0
  110. package/dist/excalidraw/components/ButtonIconSelect.js +2 -3
  111. package/dist/excalidraw/components/ButtonSeparator.d.ts +2 -0
  112. package/dist/excalidraw/components/ButtonSeparator.js +7 -0
  113. package/dist/excalidraw/components/CheckboxItem.js +1 -1
  114. package/dist/excalidraw/components/ColorPicker/ColorInput.d.ts +1 -1
  115. package/dist/excalidraw/components/ColorPicker/ColorInput.js +1 -1
  116. package/dist/excalidraw/components/ColorPicker/ColorPicker.d.ts +4 -4
  117. package/dist/excalidraw/components/ColorPicker/ColorPicker.js +48 -80
  118. package/dist/excalidraw/components/ColorPicker/Picker.d.ts +3 -3
  119. package/dist/excalidraw/components/ColorPicker/Picker.js +1 -1
  120. package/dist/excalidraw/components/ColorPicker/PickerColorList.d.ts +1 -1
  121. package/dist/excalidraw/components/ColorPicker/PickerHeading.d.ts +1 -1
  122. package/dist/excalidraw/components/ColorPicker/ShadeList.d.ts +1 -1
  123. package/dist/excalidraw/components/ColorPicker/TopPicks.d.ts +1 -1
  124. package/dist/excalidraw/components/ColorPicker/colorPickerUtils.d.ts +2 -2
  125. package/dist/excalidraw/components/ColorPicker/colorPickerUtils.js +1 -1
  126. package/dist/excalidraw/components/ColorPicker/keyboardNavHandlers.d.ts +2 -2
  127. package/dist/excalidraw/components/ColorPicker/keyboardNavHandlers.js +1 -1
  128. package/dist/excalidraw/components/CommandPalette/CommandPalette.d.ts +1 -1
  129. package/dist/excalidraw/components/CommandPalette/CommandPalette.js +5 -5
  130. package/dist/excalidraw/components/CommandPalette/defaultCommandPaletteItems.d.ts +1 -1
  131. package/dist/excalidraw/components/CommandPalette/types.d.ts +3 -3
  132. package/dist/excalidraw/components/ConfirmDialog.d.ts +1 -1
  133. package/dist/excalidraw/components/ContextMenu.d.ts +2 -2
  134. package/dist/excalidraw/components/ContextMenu.js +2 -2
  135. package/dist/excalidraw/components/DarkModeToggle.d.ts +1 -1
  136. package/dist/excalidraw/components/DefaultSidebar.d.ts +2 -2
  137. package/dist/excalidraw/components/Dialog.js +1 -1
  138. package/dist/excalidraw/components/DialogActionButton.d.ts +1 -1
  139. package/dist/excalidraw/components/EyeDropper.d.ts +2 -2
  140. package/dist/excalidraw/components/FollowMode/FollowMode.d.ts +1 -1
  141. package/dist/excalidraw/components/FollowMode/FollowMode.js +1 -1
  142. package/dist/excalidraw/components/FontPicker/FontPicker.d.ts +21 -0
  143. package/dist/excalidraw/components/FontPicker/FontPicker.js +49 -0
  144. package/dist/excalidraw/components/FontPicker/FontPickerList.d.ts +25 -0
  145. package/dist/excalidraw/components/FontPicker/FontPickerList.js +119 -0
  146. package/dist/excalidraw/components/FontPicker/FontPickerTrigger.d.ts +7 -0
  147. package/dist/excalidraw/components/FontPicker/FontPickerTrigger.js +13 -0
  148. package/dist/excalidraw/components/FontPicker/keyboardNavHandlers.d.ts +14 -0
  149. package/dist/excalidraw/components/FontPicker/keyboardNavHandlers.js +38 -0
  150. package/dist/excalidraw/components/HelpDialog.js +2 -2
  151. package/dist/excalidraw/components/HintViewer.d.ts +1 -1
  152. package/dist/excalidraw/components/HintViewer.js +6 -3
  153. package/dist/excalidraw/components/IconPicker.js +2 -2
  154. package/dist/excalidraw/components/ImageExportDialog.d.ts +1 -1
  155. package/dist/excalidraw/components/InitializeApp.d.ts +2 -2
  156. package/dist/excalidraw/components/JSONExportDialog.d.ts +3 -3
  157. package/dist/excalidraw/components/LayerUI.d.ts +4 -4
  158. package/dist/excalidraw/components/LayerUI.js +10 -7
  159. package/dist/excalidraw/components/LibraryMenu.d.ts +2 -2
  160. package/dist/excalidraw/components/LibraryMenuBrowseButton.d.ts +1 -1
  161. package/dist/excalidraw/components/LibraryMenuControlButtons.d.ts +1 -1
  162. package/dist/excalidraw/components/LibraryMenuHeaderContent.d.ts +2 -2
  163. package/dist/excalidraw/components/LibraryMenuItems.d.ts +1 -1
  164. package/dist/excalidraw/components/LibraryMenuSection.d.ts +5 -4
  165. package/dist/excalidraw/components/LibraryUnit.d.ts +2 -2
  166. package/dist/excalidraw/components/LoadingMessage.d.ts +1 -1
  167. package/dist/excalidraw/components/MagicSettings.js +2 -2
  168. package/dist/excalidraw/components/MobileMenu.d.ts +3 -3
  169. package/dist/excalidraw/components/MobileMenu.js +2 -6
  170. package/dist/excalidraw/components/Modal.d.ts +1 -1
  171. package/dist/excalidraw/components/OverwriteConfirm/OverwriteConfirmState.d.ts +1 -1
  172. package/dist/excalidraw/components/PasteChartDialog.d.ts +1 -1
  173. package/dist/excalidraw/components/PasteChartDialog.js +1 -1
  174. package/dist/excalidraw/components/PropertiesPopover.d.ts +15 -0
  175. package/dist/excalidraw/components/PropertiesPopover.js +31 -0
  176. package/dist/excalidraw/components/PublishLibrary.d.ts +1 -1
  177. package/dist/excalidraw/components/QuickSearch.d.ts +9 -0
  178. package/dist/excalidraw/components/QuickSearch.js +8 -0
  179. package/dist/excalidraw/components/SVGLayer.d.ts +1 -1
  180. package/dist/excalidraw/components/ScrollableList.d.ts +9 -0
  181. package/dist/excalidraw/components/ScrollableList.js +8 -0
  182. package/dist/excalidraw/components/Sidebar/Sidebar.js +1 -1
  183. package/dist/excalidraw/components/Sidebar/SidebarTab.d.ts +1 -1
  184. package/dist/excalidraw/components/Sidebar/SidebarTabTrigger.d.ts +1 -1
  185. package/dist/excalidraw/components/Sidebar/SidebarTrigger.d.ts +1 -1
  186. package/dist/excalidraw/components/Sidebar/common.d.ts +1 -1
  187. package/dist/excalidraw/components/Stats/Angle.d.ts +12 -0
  188. package/dist/excalidraw/components/Stats/Angle.js +53 -0
  189. package/dist/excalidraw/components/Stats/Collapsible.d.ts +9 -0
  190. package/dist/excalidraw/components/Stats/Collapsible.js +12 -0
  191. package/dist/excalidraw/components/Stats/Dimension.d.ts +12 -0
  192. package/dist/excalidraw/components/Stats/Dimension.js +68 -0
  193. package/dist/excalidraw/components/Stats/DragInput.d.ts +32 -0
  194. package/dist/excalidraw/components/Stats/DragInput.js +174 -0
  195. package/dist/excalidraw/components/Stats/FontSize.d.ts +12 -0
  196. package/dist/excalidraw/components/Stats/FontSize.js +50 -0
  197. package/dist/excalidraw/components/Stats/MultiAngle.d.ts +12 -0
  198. package/dist/excalidraw/components/Stats/MultiAngle.js +66 -0
  199. package/dist/excalidraw/components/Stats/MultiDimension.d.ts +15 -0
  200. package/dist/excalidraw/components/Stats/MultiDimension.js +199 -0
  201. package/dist/excalidraw/components/Stats/MultiFontSize.d.ts +13 -0
  202. package/dist/excalidraw/components/Stats/MultiFontSize.js +72 -0
  203. package/dist/excalidraw/components/Stats/MultiPosition.d.ts +15 -0
  204. package/dist/excalidraw/components/Stats/MultiPosition.js +101 -0
  205. package/dist/excalidraw/components/Stats/Position.d.ts +13 -0
  206. package/dist/excalidraw/components/Stats/Position.js +40 -0
  207. package/dist/excalidraw/components/Stats/index.d.ts +16 -0
  208. package/dist/excalidraw/components/Stats/index.js +79 -0
  209. package/dist/excalidraw/components/Stats/utils.d.ts +26 -0
  210. package/dist/excalidraw/components/Stats/utils.js +162 -0
  211. package/dist/excalidraw/components/TTDDialog/MermaidToExcalidraw.d.ts +1 -1
  212. package/dist/excalidraw/components/TTDDialog/TTDDialog.js +2 -2
  213. package/dist/excalidraw/components/TTDDialog/TTDDialogInput.d.ts +1 -1
  214. package/dist/excalidraw/components/TTDDialog/TTDDialogPanel.d.ts +1 -1
  215. package/dist/excalidraw/components/TTDDialog/TTDDialogPanels.d.ts +1 -1
  216. package/dist/excalidraw/components/TTDDialog/TTDDialogTabs.d.ts +1 -1
  217. package/dist/excalidraw/components/TTDDialog/TTDDialogTrigger.d.ts +1 -1
  218. package/dist/excalidraw/components/TTDDialog/common.d.ts +5 -5
  219. package/dist/excalidraw/components/TTDDialog/common.js +3 -7
  220. package/dist/excalidraw/components/TextField.d.ts +1 -1
  221. package/dist/excalidraw/components/Toast.d.ts +1 -1
  222. package/dist/excalidraw/components/ToolButton.d.ts +3 -2
  223. package/dist/excalidraw/components/Trans.d.ts +1 -1
  224. package/dist/excalidraw/components/UserList.d.ts +1 -1
  225. package/dist/excalidraw/components/UserList.js +22 -22
  226. package/dist/excalidraw/components/canvases/InteractiveCanvas.d.ts +3 -2
  227. package/dist/excalidraw/components/canvases/InteractiveCanvas.js +4 -2
  228. package/dist/excalidraw/components/canvases/StaticCanvas.d.ts +2 -2
  229. package/dist/excalidraw/components/canvases/StaticCanvas.js +3 -2
  230. package/dist/excalidraw/components/dropdownMenu/DropdownMenu.d.ts +12 -3
  231. package/dist/excalidraw/components/dropdownMenu/DropdownMenuItem.d.ts +24 -4
  232. package/dist/excalidraw/components/dropdownMenu/DropdownMenuItem.js +55 -14
  233. package/dist/excalidraw/components/dropdownMenu/DropdownMenuItemContent.d.ts +2 -1
  234. package/dist/excalidraw/components/dropdownMenu/DropdownMenuItemContent.js +2 -2
  235. package/dist/excalidraw/components/dropdownMenu/common.d.ts +1 -1
  236. package/dist/excalidraw/components/dropdownMenu/common.js +3 -2
  237. package/dist/excalidraw/components/footer/Footer.d.ts +2 -2
  238. package/dist/excalidraw/components/hyperlink/Hyperlink.d.ts +2 -2
  239. package/dist/excalidraw/components/hyperlink/helpers.d.ts +3 -3
  240. package/dist/excalidraw/components/icons.d.ts +10 -2
  241. package/dist/excalidraw/components/icons.js +29 -6
  242. package/dist/excalidraw/components/main-menu/MainMenu.d.ts +12 -3
  243. package/dist/excalidraw/components/welcome-screen/WelcomeScreen.Center.js +2 -2
  244. package/dist/excalidraw/components/welcome-screen/WelcomeScreen.Hints.js +3 -3
  245. package/dist/excalidraw/constants.d.ts +24 -3
  246. package/dist/excalidraw/constants.js +28 -4
  247. package/dist/excalidraw/context/ui-appState.d.ts +1 -1
  248. package/dist/excalidraw/cursor.d.ts +1 -1
  249. package/dist/excalidraw/data/EditorLocalStorage.d.ts +2 -2
  250. package/dist/excalidraw/data/blob.d.ts +5 -5
  251. package/dist/excalidraw/data/filesystem.d.ts +2 -1
  252. package/dist/excalidraw/data/index.d.ts +4 -4
  253. package/dist/excalidraw/data/json.d.ts +3 -3
  254. package/dist/excalidraw/data/library.d.ts +3 -3
  255. package/dist/excalidraw/data/magic.d.ts +3 -3
  256. package/dist/excalidraw/data/reconcile.d.ts +3 -3
  257. package/dist/excalidraw/data/reconcile.js +18 -1
  258. package/dist/excalidraw/data/resave.d.ts +2 -2
  259. package/dist/excalidraw/data/restore.d.ts +3 -3
  260. package/dist/excalidraw/data/restore.js +58 -9
  261. package/dist/excalidraw/data/transform.d.ts +3 -3
  262. package/dist/excalidraw/data/transform.js +8 -5
  263. package/dist/excalidraw/data/types.d.ts +3 -3
  264. package/dist/excalidraw/element/ElementCanvasButtons.d.ts +1 -1
  265. package/dist/excalidraw/element/binding.d.ts +29 -10
  266. package/dist/excalidraw/element/binding.js +303 -71
  267. package/dist/excalidraw/element/bounds.d.ts +3 -3
  268. package/dist/excalidraw/element/collision.d.ts +4 -4
  269. package/dist/excalidraw/element/collision.js +5 -2
  270. package/dist/excalidraw/element/containerCache.d.ts +1 -1
  271. package/dist/excalidraw/element/dragElements.d.ts +6 -6
  272. package/dist/excalidraw/element/dragElements.js +39 -5
  273. package/dist/excalidraw/element/embeddable.d.ts +11 -6
  274. package/dist/excalidraw/element/heading.d.ts +11 -0
  275. package/dist/excalidraw/element/heading.js +81 -0
  276. package/dist/excalidraw/element/image.d.ts +2 -2
  277. package/dist/excalidraw/element/index.d.ts +2 -2
  278. package/dist/excalidraw/element/index.js +1 -1
  279. package/dist/excalidraw/element/linearElementEditor.d.ts +27 -16
  280. package/dist/excalidraw/element/linearElementEditor.js +133 -56
  281. package/dist/excalidraw/element/mutateElement.d.ts +3 -3
  282. package/dist/excalidraw/element/mutateElement.js +5 -3
  283. package/dist/excalidraw/element/newElement.d.ts +12 -10
  284. package/dist/excalidraw/element/newElement.js +31 -16
  285. package/dist/excalidraw/element/resizeElements.d.ts +15 -6
  286. package/dist/excalidraw/element/resizeElements.js +122 -46
  287. package/dist/excalidraw/element/resizeTest.d.ts +4 -4
  288. package/dist/excalidraw/element/resizeTest.js +2 -4
  289. package/dist/excalidraw/element/routing.d.ts +13 -0
  290. package/dist/excalidraw/element/routing.js +641 -0
  291. package/dist/excalidraw/element/showSelectedShapeActions.d.ts +2 -2
  292. package/dist/excalidraw/element/sizeHelpers.d.ts +2 -2
  293. package/dist/excalidraw/element/sortElements.d.ts +1 -1
  294. package/dist/excalidraw/element/textElement.d.ts +6 -28
  295. package/dist/excalidraw/element/textElement.js +64 -112
  296. package/dist/excalidraw/element/textWysiwyg.d.ts +12 -6
  297. package/dist/excalidraw/element/textWysiwyg.js +75 -62
  298. package/dist/excalidraw/element/transformHandles.d.ts +3 -3
  299. package/dist/excalidraw/element/transformHandles.js +7 -12
  300. package/dist/excalidraw/element/typeChecks.d.ts +7 -4
  301. package/dist/excalidraw/element/typeChecks.js +17 -0
  302. package/dist/excalidraw/element/types.d.ts +22 -4
  303. package/dist/excalidraw/emitter.d.ts +1 -1
  304. package/dist/excalidraw/fonts/ExcalidrawFont.d.ts +21 -0
  305. package/dist/excalidraw/fonts/ExcalidrawFont.js +112 -0
  306. package/dist/excalidraw/fonts/index.d.ts +58 -0
  307. package/dist/excalidraw/fonts/index.js +240 -0
  308. package/dist/excalidraw/fonts/metadata.d.ts +36 -0
  309. package/dist/excalidraw/fonts/metadata.js +91 -0
  310. package/dist/excalidraw/fractionalIndex.d.ts +12 -5
  311. package/dist/excalidraw/fractionalIndex.js +40 -10
  312. package/dist/excalidraw/frame.d.ts +4 -4
  313. package/dist/excalidraw/frame.js +3 -3
  314. package/dist/excalidraw/gatransforms.d.ts +1 -1
  315. package/dist/excalidraw/gesture.d.ts +1 -1
  316. package/dist/excalidraw/groups.d.ts +4 -4
  317. package/dist/excalidraw/history.d.ts +8 -7
  318. package/dist/excalidraw/history.js +8 -8
  319. package/dist/excalidraw/hooks/useEmitter.d.ts +1 -1
  320. package/dist/excalidraw/hooks/useLibraryItemSvg.d.ts +1 -1
  321. package/dist/excalidraw/i18n.d.ts +1 -1
  322. package/dist/excalidraw/index.d.ts +2 -2
  323. package/dist/excalidraw/index.js +3 -3
  324. package/dist/excalidraw/jotai.d.ts +1 -1
  325. package/dist/excalidraw/laser-trails.d.ts +3 -2
  326. package/dist/excalidraw/locales/en.json +42 -7
  327. package/dist/excalidraw/math.d.ts +47 -2
  328. package/dist/excalidraw/math.js +116 -0
  329. package/dist/excalidraw/mermaid.d.ts +2 -0
  330. package/dist/excalidraw/mermaid.js +29 -0
  331. package/dist/excalidraw/points.d.ts +1 -1
  332. package/dist/excalidraw/queue.d.ts +1 -1
  333. package/dist/excalidraw/renderer/helpers.d.ts +2 -2
  334. package/dist/excalidraw/renderer/interactiveScene.d.ts +2 -2
  335. package/dist/excalidraw/renderer/interactiveScene.js +64 -22
  336. package/dist/excalidraw/renderer/renderElement.d.ts +6 -4
  337. package/dist/excalidraw/renderer/renderElement.js +78 -58
  338. package/dist/excalidraw/renderer/renderSnaps.d.ts +1 -1
  339. package/dist/excalidraw/renderer/staticScene.d.ts +1 -1
  340. package/dist/excalidraw/renderer/staticSvgScene.d.ts +4 -4
  341. package/dist/excalidraw/renderer/staticSvgScene.js +2 -1
  342. package/dist/excalidraw/scene/Renderer.d.ts +4 -4
  343. package/dist/excalidraw/scene/Renderer.js +2 -3
  344. package/dist/excalidraw/scene/Scene.d.ts +16 -7
  345. package/dist/excalidraw/scene/Scene.js +26 -11
  346. package/dist/excalidraw/scene/Shape.d.ts +1 -1
  347. package/dist/excalidraw/scene/Shape.js +56 -5
  348. package/dist/excalidraw/scene/ShapeCache.d.ts +4 -4
  349. package/dist/excalidraw/scene/comparisons.d.ts +3 -2
  350. package/dist/excalidraw/scene/comparisons.js +1 -1
  351. package/dist/excalidraw/scene/export.d.ts +4 -3
  352. package/dist/excalidraw/scene/export.js +34 -36
  353. package/dist/excalidraw/scene/scroll.d.ts +2 -2
  354. package/dist/excalidraw/scene/scrollbars.d.ts +3 -3
  355. package/dist/excalidraw/scene/selection.d.ts +2 -2
  356. package/dist/excalidraw/scene/types.d.ts +6 -8
  357. package/dist/excalidraw/scene/zoom.d.ts +1 -1
  358. package/dist/excalidraw/shapes.d.ts +8 -0
  359. package/dist/excalidraw/shapes.js +57 -0
  360. package/dist/excalidraw/snapping.d.ts +4 -4
  361. package/dist/excalidraw/snapping.js +2 -1
  362. package/dist/excalidraw/store.d.ts +34 -4
  363. package/dist/excalidraw/store.js +27 -0
  364. package/dist/excalidraw/types.d.ts +32 -21
  365. package/dist/excalidraw/utils.d.ts +15 -5
  366. package/dist/excalidraw/utils.js +22 -0
  367. package/dist/excalidraw/zindex.d.ts +2 -2
  368. package/dist/prod/CascadiaCode-Regular-TMZI7IJ5.woff2 +0 -0
  369. package/dist/prod/ComicShanns-Regular-6TOETDFT.woff2 +0 -0
  370. package/dist/prod/Excalifont-Regular-CPKEUDVM.woff2 +0 -0
  371. package/dist/prod/LiberationSans-Regular-ZQD73GJM.woff2 +0 -0
  372. package/dist/prod/Virgil-Regular-YHAB2VGJ.woff2 +0 -0
  373. package/dist/prod/{en-XW4JO6VX.json → en-YNVBSAIL.json} +42 -7
  374. package/dist/prod/index.css +1 -1
  375. package/dist/prod/index.js +49 -53
  376. package/dist/utils/bbox.d.ts +2 -2
  377. package/dist/utils/collision.d.ts +1 -1
  378. package/dist/utils/export.d.ts +4 -3
  379. package/dist/utils/export.js +2 -1
  380. package/dist/utils/geometry/geometry.d.ts +3 -2
  381. package/dist/utils/geometry/geometry.js +5 -1
  382. package/dist/utils/geometry/shape.d.ts +1 -1
  383. package/dist/utils/index.d.ts +1 -0
  384. package/dist/utils/index.js +1 -0
  385. package/dist/utils/withinBounds.d.ts +1 -1
  386. package/history.ts +13 -6
  387. package/package.json +2 -2
  388. package/dist/browser/dev/Cascadia-CYPE3OJC.woff2 +0 -0
  389. package/dist/browser/dev/Virgil-UZN6MUT6.woff2 +0 -0
  390. package/dist/browser/dev/excalidraw-assets-dev/chunk-BLEB3M62.js.map +0 -7
  391. package/dist/browser/dev/excalidraw-assets-dev/chunk-XOM7LNOU.js.map +0 -7
  392. package/dist/browser/dev/excalidraw-assets-dev/dist-ITJNUBZF.js.map +0 -7
  393. package/dist/browser/prod/Cascadia-CYPE3OJC.woff2 +0 -0
  394. package/dist/browser/prod/Virgil-UZN6MUT6.woff2 +0 -0
  395. package/dist/browser/prod/excalidraw-assets/chunk-UWBW5SR2.js +0 -55
  396. package/dist/browser/prod/excalidraw-assets/dist-54276HPL.js +0 -6
  397. package/dist/browser/prod/excalidraw-assets/en-7GPZE2Y2.js +0 -1
  398. package/dist/browser/prod/excalidraw-assets/image-35KQQ5EN.js +0 -1
  399. package/dist/dev/Cascadia-CYPE3OJC.woff2 +0 -0
  400. package/dist/dev/Virgil-UZN6MUT6.woff2 +0 -0
  401. package/dist/excalidraw/components/Stats.d.ts +0 -11
  402. package/dist/excalidraw/components/Stats.js +0 -13
  403. package/dist/excalidraw/scene/Fonts.d.ts +0 -21
  404. package/dist/excalidraw/scene/Fonts.js +0 -72
  405. package/dist/prod/Cascadia-CYPE3OJC.woff2 +0 -0
  406. package/dist/prod/Virgil-UZN6MUT6.woff2 +0 -0
  407. /package/dist/browser/dev/{Assistant-Bold-ZDZZ6JHA.woff2 → excalidraw-assets-dev/Assistant-Bold-ZDZZ6JHA.woff2} +0 -0
  408. /package/dist/browser/dev/{Assistant-Medium-DZ25RZU3.woff2 → excalidraw-assets-dev/Assistant-Medium-DZ25RZU3.woff2} +0 -0
  409. /package/dist/browser/dev/{Assistant-Regular-PLF2XOGW.woff2 → excalidraw-assets-dev/Assistant-Regular-PLF2XOGW.woff2} +0 -0
  410. /package/dist/browser/dev/{Assistant-SemiBold-CZ5MX6FK.woff2 → excalidraw-assets-dev/Assistant-SemiBold-CZ5MX6FK.woff2} +0 -0
  411. /package/dist/browser/dev/excalidraw-assets-dev/{en-TR4QLF5E.js.map → en-XV7OZCPP.js.map} +0 -0
  412. /package/dist/browser/dev/excalidraw-assets-dev/{image-ZGDDRBEN.js.map → image-77HZYGLG.js.map} +0 -0
  413. /package/dist/browser/prod/{Assistant-Bold-ZDZZ6JHA.woff2 → excalidraw-assets/Assistant-Bold-ZDZZ6JHA.woff2} +0 -0
  414. /package/dist/browser/prod/{Assistant-Medium-DZ25RZU3.woff2 → excalidraw-assets/Assistant-Medium-DZ25RZU3.woff2} +0 -0
  415. /package/dist/browser/prod/{Assistant-Regular-PLF2XOGW.woff2 → excalidraw-assets/Assistant-Regular-PLF2XOGW.woff2} +0 -0
  416. /package/dist/browser/prod/{Assistant-SemiBold-CZ5MX6FK.woff2 → excalidraw-assets/Assistant-SemiBold-CZ5MX6FK.woff2} +0 -0
@@ -0,0 +1,31 @@
1
+ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
2
+ import React from "react";
3
+ import clsx from "clsx";
4
+ import * as Popover from "@radix-ui/react-popover";
5
+ import { useDevice } from "./App";
6
+ import { Island } from "./Island";
7
+ import { isInteractive } from "../utils";
8
+ export const PropertiesPopover = React.forwardRef(({ className, container, children, style, onClose, onKeyDown, onFocusOutside, onPointerLeave, onPointerDownOutside, }, ref) => {
9
+ const device = useDevice();
10
+ return (_jsx(Popover.Portal, { container: container, children: _jsxs(Popover.Content, { ref: ref, className: clsx("focus-visible-none", className), "data-prevent-outside-click": true, side: device.editor.isMobile && !device.viewport.isLandscape
11
+ ? "bottom"
12
+ : "right", align: device.editor.isMobile && !device.viewport.isLandscape
13
+ ? "center"
14
+ : "start", alignOffset: -16, sideOffset: 20, style: {
15
+ zIndex: "var(--zIndex-popup)",
16
+ }, onPointerLeave: onPointerLeave, onKeyDown: onKeyDown, onFocusOutside: onFocusOutside, onPointerDownOutside: onPointerDownOutside, onCloseAutoFocus: (e) => {
17
+ e.stopPropagation();
18
+ // prevents focusing the trigger
19
+ e.preventDefault();
20
+ // return focus to excalidraw container unless
21
+ // user focuses an interactive element, such as a button, or
22
+ // enters the text editor by clicking on canvas with the text tool
23
+ if (container && !isInteractive(document.activeElement)) {
24
+ container.focus();
25
+ }
26
+ onClose();
27
+ }, children: [_jsx(Island, { padding: 3, style: style, children: children }), _jsx(Popover.Arrow, { width: 20, height: 10, style: {
28
+ fill: "var(--popup-bg-color)",
29
+ filter: "drop-shadow(rgba(0, 0, 0, 0.05) 0px 3px 2px)",
30
+ } })] }) }));
31
+ });
@@ -1,5 +1,5 @@
1
1
  /// <reference types="react" />
2
- import { LibraryItems, UIAppState } from "../types";
2
+ import type { LibraryItems, UIAppState } from "../types";
3
3
  import "./PublishLibrary.scss";
4
4
  declare const PublishLibrary: ({ onClose, libraryItems, appState, onSuccess, onError, updateItemsInStorage, onRemove, }: {
5
5
  onClose: () => void;
@@ -0,0 +1,9 @@
1
+ import React from "react";
2
+ import "./QuickSearch.scss";
3
+ interface QuickSearchProps {
4
+ className?: string;
5
+ placeholder: string;
6
+ onChange: (term: string) => void;
7
+ }
8
+ export declare const QuickSearch: React.ForwardRefExoticComponent<QuickSearchProps & React.RefAttributes<HTMLInputElement>>;
9
+ export {};
@@ -0,0 +1,8 @@
1
+ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
2
+ import clsx from "clsx";
3
+ import React from "react";
4
+ import { searchIcon } from "./icons";
5
+ import "./QuickSearch.scss";
6
+ export const QuickSearch = React.forwardRef(({ className, placeholder, onChange }, ref) => {
7
+ return (_jsxs("div", { className: clsx("QuickSearch__wrapper", className), children: [searchIcon, _jsx("input", { ref: ref, className: "QuickSearch__input", type: "text", placeholder: placeholder, onChange: (e) => onChange(e.target.value.trim().toLowerCase()) })] }));
8
+ });
@@ -1,5 +1,5 @@
1
1
  /// <reference types="react" />
2
- import { Trail } from "../animated-trail";
2
+ import type { Trail } from "../animated-trail";
3
3
  import "./SVGLayer.scss";
4
4
  type SVGLayerProps = {
5
5
  trails: Trail[];
@@ -0,0 +1,9 @@
1
+ /// <reference types="react" />
2
+ import "./ScrollableList.scss";
3
+ interface ScrollableListProps {
4
+ className?: string;
5
+ placeholder: string;
6
+ children: React.ReactNode;
7
+ }
8
+ export declare const ScrollableList: ({ className, placeholder, children, }: ScrollableListProps) => JSX.Element;
9
+ export {};
@@ -0,0 +1,8 @@
1
+ import { jsx as _jsx } from "react/jsx-runtime";
2
+ import clsx from "clsx";
3
+ import { Children } from "react";
4
+ import "./ScrollableList.scss";
5
+ export const ScrollableList = ({ className, placeholder, children, }) => {
6
+ const isEmpty = !Children.count(children);
7
+ return (_jsx("div", { className: clsx("ScrollableList__wrapper", className), role: "menu", children: isEmpty ? _jsx("div", { className: "empty", children: placeholder }) : children }));
8
+ };
@@ -4,7 +4,7 @@ import { useEffect, useLayoutEffect, useRef, useState, forwardRef, useImperative
4
4
  import { Island } from "../Island";
5
5
  import { atom, useSetAtom } from "jotai";
6
6
  import { jotaiScope } from "../../jotai";
7
- import { SidebarPropsContext, } from "./common";
7
+ import { SidebarPropsContext } from "./common";
8
8
  import { SidebarHeader } from "./SidebarHeader";
9
9
  import clsx from "clsx";
10
10
  import { useDevice, useExcalidrawSetAppState } from "../App";
@@ -1,5 +1,5 @@
1
1
  /// <reference types="react" />
2
- import { SidebarTabName } from "../../types";
2
+ import type { SidebarTabName } from "../../types";
3
3
  export declare const SidebarTab: {
4
4
  ({ tab, children, ...rest }: {
5
5
  tab: SidebarTabName;
@@ -1,5 +1,5 @@
1
1
  /// <reference types="react" />
2
- import { SidebarTabName } from "../../types";
2
+ import type { SidebarTabName } from "../../types";
3
3
  export declare const SidebarTabTrigger: {
4
4
  ({ children, tab, onSelect, ...rest }: {
5
5
  children: React.ReactNode;
@@ -1,5 +1,5 @@
1
1
  /// <reference types="react" />
2
- import { SidebarTriggerProps } from "./common";
2
+ import type { SidebarTriggerProps } from "./common";
3
3
  import "./SidebarTrigger.scss";
4
4
  export declare const SidebarTrigger: {
5
5
  ({ name, tab, icon, title, children, onToggle, className, style, }: SidebarTriggerProps): JSX.Element;
@@ -1,5 +1,5 @@
1
1
  import React from "react";
2
- import { AppState, SidebarName, SidebarTabName } from "../../types";
2
+ import type { AppState, SidebarName, SidebarTabName } from "../../types";
3
3
  export type SidebarTriggerProps = {
4
4
  name: SidebarName;
5
5
  tab?: SidebarTabName;
@@ -0,0 +1,12 @@
1
+ /// <reference types="react" />
2
+ import type { ExcalidrawElement } from "../../element/types";
3
+ import type Scene from "../../scene/Scene";
4
+ import type { AppState } from "../../types";
5
+ interface AngleProps {
6
+ element: ExcalidrawElement;
7
+ scene: Scene;
8
+ appState: AppState;
9
+ property: "angle";
10
+ }
11
+ declare const Angle: ({ element, scene, appState, property }: AngleProps) => JSX.Element;
12
+ export default Angle;
@@ -0,0 +1,53 @@
1
+ import { jsx as _jsx } from "react/jsx-runtime";
2
+ import { mutateElement } from "../../element/mutateElement";
3
+ import { getBoundTextElement } from "../../element/textElement";
4
+ import { isArrowElement, isElbowArrow } from "../../element/typeChecks";
5
+ import { degreeToRadian, radianToDegree } from "../../math";
6
+ import { angleIcon } from "../icons";
7
+ import DragInput from "./DragInput";
8
+ import { getStepSizedValue, isPropertyEditable, updateBindings } from "./utils";
9
+ const STEP_SIZE = 15;
10
+ const handleDegreeChange = ({ accumulatedChange, originalElements, shouldChangeByStepSize, nextValue, scene, }) => {
11
+ const elementsMap = scene.getNonDeletedElementsMap();
12
+ const elements = scene.getNonDeletedElements();
13
+ const origElement = originalElements[0];
14
+ if (origElement && !isElbowArrow(origElement)) {
15
+ const latestElement = elementsMap.get(origElement.id);
16
+ if (!latestElement) {
17
+ return;
18
+ }
19
+ if (nextValue !== undefined) {
20
+ const nextAngle = degreeToRadian(nextValue);
21
+ mutateElement(latestElement, {
22
+ angle: nextAngle,
23
+ });
24
+ updateBindings(latestElement, elementsMap, elements, scene);
25
+ const boundTextElement = getBoundTextElement(latestElement, elementsMap);
26
+ if (boundTextElement && !isArrowElement(latestElement)) {
27
+ mutateElement(boundTextElement, { angle: nextAngle });
28
+ }
29
+ return;
30
+ }
31
+ const originalAngleInDegrees = Math.round(radianToDegree(origElement.angle) * 100) / 100;
32
+ const changeInDegrees = Math.round(accumulatedChange);
33
+ let nextAngleInDegrees = (originalAngleInDegrees + changeInDegrees) % 360;
34
+ if (shouldChangeByStepSize) {
35
+ nextAngleInDegrees = getStepSizedValue(nextAngleInDegrees, STEP_SIZE);
36
+ }
37
+ nextAngleInDegrees =
38
+ nextAngleInDegrees < 0 ? nextAngleInDegrees + 360 : nextAngleInDegrees;
39
+ const nextAngle = degreeToRadian(nextAngleInDegrees);
40
+ mutateElement(latestElement, {
41
+ angle: nextAngle,
42
+ });
43
+ updateBindings(latestElement, elementsMap, elements, scene);
44
+ const boundTextElement = getBoundTextElement(latestElement, elementsMap);
45
+ if (boundTextElement && !isArrowElement(latestElement)) {
46
+ mutateElement(boundTextElement, { angle: nextAngle });
47
+ }
48
+ }
49
+ };
50
+ const Angle = ({ element, scene, appState, property }) => {
51
+ return (_jsx(DragInput, { label: "A", icon: angleIcon, value: Math.round((radianToDegree(element.angle) % 360) * 100) / 100, elements: [element], dragInputCallback: handleDegreeChange, editable: isPropertyEditable(element, "angle"), scene: scene, appState: appState, property: property }));
52
+ };
53
+ export default Angle;
@@ -0,0 +1,9 @@
1
+ /// <reference types="react" />
2
+ interface CollapsibleProps {
3
+ label: React.ReactNode;
4
+ open: boolean;
5
+ openTrigger: () => void;
6
+ children: React.ReactNode;
7
+ }
8
+ declare const Collapsible: ({ label, open, openTrigger, children, }: CollapsibleProps) => JSX.Element;
9
+ export default Collapsible;
@@ -0,0 +1,12 @@
1
+ import { jsx as _jsx, jsxs as _jsxs, Fragment as _Fragment } from "react/jsx-runtime";
2
+ import { InlineIcon } from "../InlineIcon";
3
+ import { collapseDownIcon, collapseUpIcon } from "../icons";
4
+ const Collapsible = ({ label, open, openTrigger, children, }) => {
5
+ return (_jsxs(_Fragment, { children: [_jsxs("div", { style: {
6
+ cursor: "pointer",
7
+ display: "flex",
8
+ justifyContent: "space-between",
9
+ alignItems: "center",
10
+ }, onClick: openTrigger, children: [label, _jsx(InlineIcon, { icon: open ? collapseUpIcon : collapseDownIcon })] }), open && _jsx(_Fragment, { children: children })] }));
11
+ };
12
+ export default Collapsible;
@@ -0,0 +1,12 @@
1
+ /// <reference types="react" />
2
+ import type { ExcalidrawElement } from "../../element/types";
3
+ import type Scene from "../../scene/Scene";
4
+ import type { AppState } from "../../types";
5
+ interface DimensionDragInputProps {
6
+ property: "width" | "height";
7
+ element: ExcalidrawElement;
8
+ scene: Scene;
9
+ appState: AppState;
10
+ }
11
+ declare const DimensionDragInput: ({ property, element, scene, appState, }: DimensionDragInputProps) => JSX.Element;
12
+ export default DimensionDragInput;
@@ -0,0 +1,68 @@
1
+ import { jsx as _jsx } from "react/jsx-runtime";
2
+ import DragInput from "./DragInput";
3
+ import { getStepSizedValue, isPropertyEditable, resizeElement } from "./utils";
4
+ import { MIN_WIDTH_OR_HEIGHT } from "../../constants";
5
+ const STEP_SIZE = 10;
6
+ const _shouldKeepAspectRatio = (element) => {
7
+ return element.type === "image";
8
+ };
9
+ const handleDimensionChange = ({ accumulatedChange, originalElements, originalElementsMap, shouldKeepAspectRatio, shouldChangeByStepSize, nextValue, property, scene, }) => {
10
+ const elementsMap = scene.getNonDeletedElementsMap();
11
+ const elements = scene.getNonDeletedElements();
12
+ const origElement = originalElements[0];
13
+ if (origElement) {
14
+ const keepAspectRatio = shouldKeepAspectRatio || _shouldKeepAspectRatio(origElement);
15
+ const aspectRatio = origElement.width / origElement.height;
16
+ if (nextValue !== undefined) {
17
+ const nextWidth = Math.max(property === "width"
18
+ ? nextValue
19
+ : keepAspectRatio
20
+ ? nextValue * aspectRatio
21
+ : origElement.width, MIN_WIDTH_OR_HEIGHT);
22
+ const nextHeight = Math.max(property === "height"
23
+ ? nextValue
24
+ : keepAspectRatio
25
+ ? nextValue / aspectRatio
26
+ : origElement.height, MIN_WIDTH_OR_HEIGHT);
27
+ resizeElement(nextWidth, nextHeight, keepAspectRatio, origElement, elementsMap, elements, scene);
28
+ return;
29
+ }
30
+ const changeInWidth = property === "width" ? accumulatedChange : 0;
31
+ const changeInHeight = property === "height" ? accumulatedChange : 0;
32
+ let nextWidth = Math.max(0, origElement.width + changeInWidth);
33
+ if (property === "width") {
34
+ if (shouldChangeByStepSize) {
35
+ nextWidth = getStepSizedValue(nextWidth, STEP_SIZE);
36
+ }
37
+ else {
38
+ nextWidth = Math.round(nextWidth);
39
+ }
40
+ }
41
+ let nextHeight = Math.max(0, origElement.height + changeInHeight);
42
+ if (property === "height") {
43
+ if (shouldChangeByStepSize) {
44
+ nextHeight = getStepSizedValue(nextHeight, STEP_SIZE);
45
+ }
46
+ else {
47
+ nextHeight = Math.round(nextHeight);
48
+ }
49
+ }
50
+ if (keepAspectRatio) {
51
+ if (property === "width") {
52
+ nextHeight = Math.round((nextWidth / aspectRatio) * 100) / 100;
53
+ }
54
+ else {
55
+ nextWidth = Math.round(nextHeight * aspectRatio * 100) / 100;
56
+ }
57
+ }
58
+ nextHeight = Math.max(MIN_WIDTH_OR_HEIGHT, nextHeight);
59
+ nextWidth = Math.max(MIN_WIDTH_OR_HEIGHT, nextWidth);
60
+ resizeElement(nextWidth, nextHeight, keepAspectRatio, origElement, elementsMap, elements, scene);
61
+ }
62
+ };
63
+ const DimensionDragInput = ({ property, element, scene, appState, }) => {
64
+ const value = Math.round((property === "width" ? element.width : element.height) * 100) /
65
+ 100;
66
+ return (_jsx(DragInput, { label: property === "width" ? "W" : "H", elements: [element], dragInputCallback: handleDimensionChange, value: value, editable: isPropertyEditable(element, property), scene: scene, appState: appState, property: property }));
67
+ };
68
+ export default DimensionDragInput;
@@ -0,0 +1,32 @@
1
+ /// <reference types="react" />
2
+ import type { ElementsMap, ExcalidrawElement } from "../../element/types";
3
+ import type { StatsInputProperty } from "./utils";
4
+ import type Scene from "../../scene/Scene";
5
+ import "./DragInput.scss";
6
+ import type { AppState } from "../../types";
7
+ export type DragInputCallbackType<P extends StatsInputProperty, E = ExcalidrawElement> = (props: {
8
+ accumulatedChange: number;
9
+ instantChange: number;
10
+ originalElements: readonly E[];
11
+ originalElementsMap: ElementsMap;
12
+ shouldKeepAspectRatio: boolean;
13
+ shouldChangeByStepSize: boolean;
14
+ scene: Scene;
15
+ nextValue?: number;
16
+ property: P;
17
+ originalAppState: AppState;
18
+ }) => void;
19
+ interface StatsDragInputProps<T extends StatsInputProperty, E = ExcalidrawElement> {
20
+ label: string | React.ReactNode;
21
+ icon?: React.ReactNode;
22
+ value: number | "Mixed";
23
+ elements: readonly E[];
24
+ editable?: boolean;
25
+ shouldKeepAspectRatio?: boolean;
26
+ dragInputCallback: DragInputCallbackType<T, E>;
27
+ property: T;
28
+ scene: Scene;
29
+ appState: AppState;
30
+ }
31
+ declare const StatsDragInput: <T extends StatsInputProperty, E extends ExcalidrawElement = ExcalidrawElement>({ label, icon, dragInputCallback, value, elements, editable, shouldKeepAspectRatio, property, scene, appState, }: StatsDragInputProps<T, E>) => JSX.Element | null;
32
+ export default StatsDragInput;
@@ -0,0 +1,174 @@
1
+ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
2
+ import { useEffect, useRef, useState } from "react";
3
+ import { EVENT } from "../../constants";
4
+ import { KEYS } from "../../keys";
5
+ import { deepCopyElement } from "../../element/newElement";
6
+ import clsx from "clsx";
7
+ import { useApp } from "../App";
8
+ import { InlineIcon } from "../InlineIcon";
9
+ import { SMALLEST_DELTA } from "./utils";
10
+ import { StoreAction } from "../../store";
11
+ import "./DragInput.scss";
12
+ import { cloneJSON } from "../../utils";
13
+ const StatsDragInput = ({ label, icon, dragInputCallback, value, elements, editable = true, shouldKeepAspectRatio, property, scene, appState, }) => {
14
+ const app = useApp();
15
+ const inputRef = useRef(null);
16
+ const labelRef = useRef(null);
17
+ const [inputValue, setInputValue] = useState(value.toString());
18
+ const stateRef = useRef(null);
19
+ if (!stateRef.current) {
20
+ stateRef.current = {
21
+ originalAppState: cloneJSON(appState),
22
+ originalElements: elements,
23
+ lastUpdatedValue: inputValue,
24
+ updatePending: false,
25
+ };
26
+ }
27
+ useEffect(() => {
28
+ const inputValue = value.toString();
29
+ setInputValue(inputValue);
30
+ stateRef.current.lastUpdatedValue = inputValue;
31
+ }, [value]);
32
+ const handleInputValue = (updatedValue, elements, appState) => {
33
+ if (!stateRef.current.updatePending) {
34
+ return false;
35
+ }
36
+ stateRef.current.updatePending = false;
37
+ const parsed = Number(updatedValue);
38
+ if (isNaN(parsed)) {
39
+ setInputValue(value.toString());
40
+ return;
41
+ }
42
+ const rounded = Number(parsed.toFixed(2));
43
+ const original = Number(value);
44
+ // only update when
45
+ // 1. original was "Mixed" and we have a new value
46
+ // 2. original was not "Mixed" and the difference between a new value and previous value is greater
47
+ // than the smallest delta allowed, which is 0.01
48
+ // reason: idempotent to avoid unnecessary
49
+ if (isNaN(original) || Math.abs(rounded - original) >= SMALLEST_DELTA) {
50
+ stateRef.current.lastUpdatedValue = updatedValue;
51
+ dragInputCallback({
52
+ accumulatedChange: 0,
53
+ instantChange: 0,
54
+ originalElements: elements,
55
+ originalElementsMap: app.scene.getNonDeletedElementsMap(),
56
+ shouldKeepAspectRatio: shouldKeepAspectRatio,
57
+ shouldChangeByStepSize: false,
58
+ scene,
59
+ nextValue: rounded,
60
+ property,
61
+ originalAppState: appState,
62
+ });
63
+ app.syncActionResult({ storeAction: StoreAction.CAPTURE });
64
+ }
65
+ };
66
+ const handleInputValueRef = useRef(handleInputValue);
67
+ handleInputValueRef.current = handleInputValue;
68
+ // make sure that clicking on canvas (which umounts the component)
69
+ // updates current input value (blur isn't triggered)
70
+ useEffect(() => {
71
+ const input = inputRef.current;
72
+ return () => {
73
+ const nextValue = input?.value;
74
+ if (nextValue) {
75
+ handleInputValueRef.current(nextValue, stateRef.current.originalElements, stateRef.current.originalAppState);
76
+ }
77
+ };
78
+ }, [
79
+ // we need to track change of `editable` state as mount/unmount
80
+ // because react doesn't trigger `blur` when a an input is blurred due
81
+ // to being disabled (https://github.com/facebook/react/issues/9142).
82
+ // As such, if we keep rendering disabled inputs, then change in selection
83
+ // to an element that has a given property as non-editable would not trigger
84
+ // blur/unmount and wouldn't update the value.
85
+ editable,
86
+ ]);
87
+ if (!editable) {
88
+ return null;
89
+ }
90
+ return (_jsxs("div", { className: clsx("drag-input-container", !editable && "disabled"), "data-testid": label, children: [_jsx("div", { className: "drag-input-label", ref: labelRef, onPointerDown: (event) => {
91
+ if (inputRef.current && editable) {
92
+ let startValue = Number(inputRef.current.value);
93
+ if (isNaN(startValue)) {
94
+ startValue = 0;
95
+ }
96
+ let lastPointer = null;
97
+ let originalElementsMap = app.scene
98
+ .getNonDeletedElements()
99
+ .reduce((acc, element) => {
100
+ acc.set(element.id, deepCopyElement(element));
101
+ return acc;
102
+ }, new Map());
103
+ let originalElements = elements.map((element) => originalElementsMap.get(element.id));
104
+ const originalAppState = cloneJSON(appState);
105
+ let accumulatedChange = null;
106
+ document.body.classList.add("excalidraw-cursor-resize");
107
+ const onPointerMove = (event) => {
108
+ if (!accumulatedChange) {
109
+ accumulatedChange = 0;
110
+ }
111
+ if (lastPointer &&
112
+ originalElementsMap !== null &&
113
+ originalElements !== null &&
114
+ accumulatedChange !== null) {
115
+ const instantChange = event.clientX - lastPointer.x;
116
+ accumulatedChange += instantChange;
117
+ dragInputCallback({
118
+ accumulatedChange,
119
+ instantChange,
120
+ originalElements,
121
+ originalElementsMap,
122
+ shouldKeepAspectRatio: shouldKeepAspectRatio,
123
+ shouldChangeByStepSize: event.shiftKey,
124
+ property,
125
+ scene,
126
+ originalAppState,
127
+ });
128
+ }
129
+ lastPointer = {
130
+ x: event.clientX,
131
+ y: event.clientY,
132
+ };
133
+ };
134
+ window.addEventListener(EVENT.POINTER_MOVE, onPointerMove, false);
135
+ window.addEventListener(EVENT.POINTER_UP, () => {
136
+ window.removeEventListener(EVENT.POINTER_MOVE, onPointerMove, false);
137
+ app.syncActionResult({ storeAction: StoreAction.CAPTURE });
138
+ lastPointer = null;
139
+ accumulatedChange = null;
140
+ originalElements = null;
141
+ originalElementsMap = null;
142
+ document.body.classList.remove("excalidraw-cursor-resize");
143
+ }, false);
144
+ }
145
+ }, onPointerEnter: () => {
146
+ if (labelRef.current) {
147
+ labelRef.current.style.cursor = "ew-resize";
148
+ }
149
+ }, children: icon ? _jsx(InlineIcon, { icon: icon }) : label }), _jsx("input", { className: "drag-input", autoComplete: "off", spellCheck: "false", onKeyDown: (event) => {
150
+ if (editable) {
151
+ const eventTarget = event.target;
152
+ if (eventTarget instanceof HTMLInputElement &&
153
+ event.key === KEYS.ENTER) {
154
+ handleInputValue(eventTarget.value, elements, appState);
155
+ app.focusContainer();
156
+ }
157
+ }
158
+ }, ref: inputRef, value: inputValue, onChange: (event) => {
159
+ stateRef.current.updatePending = true;
160
+ setInputValue(event.target.value);
161
+ }, onFocus: (event) => {
162
+ event.target.select();
163
+ stateRef.current.originalElements = elements;
164
+ stateRef.current.originalAppState = cloneJSON(appState);
165
+ }, onBlur: (event) => {
166
+ if (!inputValue) {
167
+ setInputValue(value.toString());
168
+ }
169
+ else if (editable) {
170
+ handleInputValue(event.target.value, stateRef.current.originalElements, stateRef.current.originalAppState);
171
+ }
172
+ }, disabled: !editable })] }));
173
+ };
174
+ export default StatsDragInput;
@@ -0,0 +1,12 @@
1
+ /// <reference types="react" />
2
+ import type { ExcalidrawElement } from "../../element/types";
3
+ import type Scene from "../../scene/Scene";
4
+ import type { AppState } from "../../types";
5
+ interface FontSizeProps {
6
+ element: ExcalidrawElement;
7
+ scene: Scene;
8
+ appState: AppState;
9
+ property: "fontSize";
10
+ }
11
+ declare const FontSize: ({ element, scene, appState, property }: FontSizeProps) => JSX.Element | null;
12
+ export default FontSize;
@@ -0,0 +1,50 @@
1
+ import { jsx as _jsx } from "react/jsx-runtime";
2
+ import StatsDragInput from "./DragInput";
3
+ import { mutateElement } from "../../element/mutateElement";
4
+ import { getStepSizedValue } from "./utils";
5
+ import { fontSizeIcon } from "../icons";
6
+ import { isTextElement, redrawTextBoundingBox } from "../../element";
7
+ import { hasBoundTextElement } from "../../element/typeChecks";
8
+ import { getBoundTextElement } from "../../element/textElement";
9
+ const MIN_FONT_SIZE = 4;
10
+ const STEP_SIZE = 4;
11
+ const handleFontSizeChange = ({ accumulatedChange, originalElements, shouldChangeByStepSize, nextValue, scene, }) => {
12
+ const elementsMap = scene.getNonDeletedElementsMap();
13
+ const origElement = originalElements[0];
14
+ if (origElement) {
15
+ const latestElement = elementsMap.get(origElement.id);
16
+ if (!latestElement || !isTextElement(latestElement)) {
17
+ return;
18
+ }
19
+ let nextFontSize;
20
+ if (nextValue !== undefined) {
21
+ nextFontSize = Math.max(Math.round(nextValue), MIN_FONT_SIZE);
22
+ }
23
+ else if (origElement.type === "text") {
24
+ const originalFontSize = Math.round(origElement.fontSize);
25
+ const changeInFontSize = Math.round(accumulatedChange);
26
+ nextFontSize = Math.max(originalFontSize + changeInFontSize, MIN_FONT_SIZE);
27
+ if (shouldChangeByStepSize) {
28
+ nextFontSize = getStepSizedValue(nextFontSize, STEP_SIZE);
29
+ }
30
+ }
31
+ if (nextFontSize) {
32
+ mutateElement(latestElement, {
33
+ fontSize: nextFontSize,
34
+ });
35
+ redrawTextBoundingBox(latestElement, scene.getContainerElement(latestElement), scene.getNonDeletedElementsMap());
36
+ }
37
+ }
38
+ };
39
+ const FontSize = ({ element, scene, appState, property }) => {
40
+ const _element = isTextElement(element)
41
+ ? element
42
+ : hasBoundTextElement(element)
43
+ ? getBoundTextElement(element, scene.getNonDeletedElementsMap())
44
+ : null;
45
+ if (!_element) {
46
+ return null;
47
+ }
48
+ return (_jsx(StatsDragInput, { label: "F", value: Math.round(_element.fontSize * 10) / 10, elements: [_element], dragInputCallback: handleFontSizeChange, icon: fontSizeIcon, appState: appState, scene: scene, property: property }));
49
+ };
50
+ export default FontSize;
@@ -0,0 +1,12 @@
1
+ /// <reference types="react" />
2
+ import type { ExcalidrawElement } from "../../element/types";
3
+ import type Scene from "../../scene/Scene";
4
+ import type { AppState } from "../../types";
5
+ interface MultiAngleProps {
6
+ elements: readonly ExcalidrawElement[];
7
+ scene: Scene;
8
+ appState: AppState;
9
+ property: "angle";
10
+ }
11
+ declare const MultiAngle: ({ elements, scene, appState, property, }: MultiAngleProps) => JSX.Element;
12
+ export default MultiAngle;