@excalidraw/excalidraw 0.18.0-b7aac689a → 0.18.0-c141960

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 (425) hide show
  1. package/dist/dev/{chunk-QF5FRM6O.js → chunk-AWYOLLYX.js} +49 -26
  2. package/dist/dev/chunk-AWYOLLYX.js.map +7 -0
  3. package/dist/dev/chunk-PMQWN2AA.js +69 -0
  4. package/dist/dev/chunk-PMQWN2AA.js.map +7 -0
  5. package/dist/dev/{chunk-CBGOW5JB.js → chunk-SJTAY27F.js} +185 -389
  6. package/dist/dev/chunk-SJTAY27F.js.map +7 -0
  7. package/dist/dev/data/{image-SURZSZNX.js → image-S2GFZH7W.js} +2 -2
  8. package/dist/dev/index.css +944 -498
  9. package/dist/dev/index.css.map +3 -3
  10. package/dist/dev/index.js +10424 -7221
  11. package/dist/dev/index.js.map +4 -4
  12. package/dist/dev/locales/{ar-SA-XORAP2EK.js → ar-SA-USQAA427.js} +299 -142
  13. package/dist/dev/locales/ar-SA-USQAA427.js.map +7 -0
  14. package/dist/dev/locales/{az-AZ-NAUU3Z4Y.js → az-AZ-CVQRXULV.js} +240 -83
  15. package/dist/dev/locales/az-AZ-CVQRXULV.js.map +7 -0
  16. package/dist/dev/locales/{bg-BG-AAABLFCY.js → bg-BG-E4I2JVOQ.js} +228 -71
  17. package/dist/dev/locales/bg-BG-E4I2JVOQ.js.map +7 -0
  18. package/dist/dev/locales/{bn-BD-PM4AC5WG.js → bn-BD-O55ROP2R.js} +208 -51
  19. package/dist/dev/locales/bn-BD-O55ROP2R.js.map +7 -0
  20. package/dist/dev/locales/bn-IN-OL7OUKTP.js +743 -0
  21. package/dist/dev/locales/bn-IN-OL7OUKTP.js.map +7 -0
  22. package/dist/dev/locales/{ca-ES-YNNMFRQX.js → ca-ES-73KY52DM.js} +274 -117
  23. package/dist/dev/locales/ca-ES-73KY52DM.js.map +7 -0
  24. package/dist/dev/locales/{cs-CZ-DGZA5IKG.js → cs-CZ-2YGHPQ24.js} +228 -71
  25. package/dist/dev/locales/cs-CZ-2YGHPQ24.js.map +7 -0
  26. package/dist/dev/locales/{da-DK-N76F4QAJ.js → da-DK-OEIZIPJU.js} +297 -140
  27. package/dist/dev/locales/da-DK-OEIZIPJU.js.map +7 -0
  28. package/dist/dev/locales/de-CH-4GJTW23D.js +743 -0
  29. package/dist/dev/locales/de-CH-4GJTW23D.js.map +7 -0
  30. package/dist/dev/locales/{de-DE-DMRXZ2SZ.js → de-DE-YRH6WMM5.js} +198 -41
  31. package/dist/dev/locales/de-DE-YRH6WMM5.js.map +7 -0
  32. package/dist/dev/locales/{el-GR-HIKPLEXI.js → el-GR-W7S64QNM.js} +273 -116
  33. package/dist/dev/locales/el-GR-W7S64QNM.js.map +7 -0
  34. package/dist/dev/locales/{en-SMAPCEOQ.js → en-ZO6QSABV.js} +4 -2
  35. package/dist/dev/locales/{es-ES-AQYVXC32.js → es-ES-7JEN5PTZ.js} +211 -54
  36. package/dist/dev/locales/es-ES-7JEN5PTZ.js.map +7 -0
  37. package/dist/dev/locales/{eu-ES-3TOEU5DE.js → eu-ES-HQNHU6VR.js} +209 -52
  38. package/dist/dev/locales/eu-ES-HQNHU6VR.js.map +7 -0
  39. package/dist/dev/locales/{fa-IR-527GAKUP.js → fa-IR-IN6XOPA6.js} +285 -128
  40. package/dist/dev/locales/fa-IR-IN6XOPA6.js.map +7 -0
  41. package/dist/dev/locales/{fi-FI-M3WLVDFP.js → fi-FI-5BAAYJDZ.js} +239 -82
  42. package/dist/dev/locales/fi-FI-5BAAYJDZ.js.map +7 -0
  43. package/dist/dev/locales/{fr-FR-YE4VDJFI.js → fr-FR-KCXBY2R4.js} +202 -45
  44. package/dist/dev/locales/fr-FR-KCXBY2R4.js.map +7 -0
  45. package/dist/dev/locales/{gl-ES-KMXUYGUN.js → gl-ES-5OPGWS6N.js} +211 -54
  46. package/dist/dev/locales/gl-ES-5OPGWS6N.js.map +7 -0
  47. package/dist/dev/locales/he-IL-3A6ZWK6L.js +743 -0
  48. package/dist/dev/locales/he-IL-3A6ZWK6L.js.map +7 -0
  49. package/dist/dev/locales/hi-IN-HZTBH6EG.js +743 -0
  50. package/dist/dev/locales/hi-IN-HZTBH6EG.js.map +7 -0
  51. package/dist/dev/locales/{hu-HU-VIYZI3X4.js → hu-HU-52IRZEAZ.js} +237 -80
  52. package/dist/dev/locales/hu-HU-52IRZEAZ.js.map +7 -0
  53. package/dist/dev/locales/{id-ID-22TWZNLA.js → id-ID-W6HBGXTS.js} +244 -87
  54. package/dist/dev/locales/id-ID-W6HBGXTS.js.map +7 -0
  55. package/dist/dev/locales/{it-IT-MDEQ2SG3.js → it-IT-AV75ICYT.js} +201 -44
  56. package/dist/dev/locales/it-IT-AV75ICYT.js.map +7 -0
  57. package/dist/dev/locales/{ja-JP-K2DI4W6B.js → ja-JP-SS4G3ZXF.js} +246 -89
  58. package/dist/dev/locales/ja-JP-SS4G3ZXF.js.map +7 -0
  59. package/dist/dev/locales/{kaa-6BPSNM3R.js → kaa-Y5BBB3IW.js} +201 -44
  60. package/dist/dev/locales/kaa-Y5BBB3IW.js.map +7 -0
  61. package/dist/dev/locales/{kab-KAB-2S7ZURK7.js → kab-KAB-KDVZQXBT.js} +209 -52
  62. package/dist/dev/locales/kab-KAB-KDVZQXBT.js.map +7 -0
  63. package/dist/dev/locales/{kk-KZ-UJPYGRQQ.js → kk-KZ-762YODLJ.js} +174 -17
  64. package/dist/dev/locales/kk-KZ-762YODLJ.js.map +7 -0
  65. package/dist/dev/locales/{km-KH-M5T5JKUE.js → km-KH-K2TE5MIK.js} +197 -40
  66. package/dist/dev/locales/km-KH-K2TE5MIK.js.map +7 -0
  67. package/dist/dev/locales/{ko-KR-RQX37SNF.js → ko-KR-75RUMBCO.js} +217 -60
  68. package/dist/dev/locales/ko-KR-75RUMBCO.js.map +7 -0
  69. package/dist/dev/locales/{ku-TR-5XJDIERL.js → ku-TR-E6DJ6LYM.js} +197 -40
  70. package/dist/dev/locales/ku-TR-E6DJ6LYM.js.map +7 -0
  71. package/dist/dev/locales/{lt-LT-MGUBX6CA.js → lt-LT-BYS5DA45.js} +178 -21
  72. package/dist/dev/locales/lt-LT-BYS5DA45.js.map +7 -0
  73. package/dist/dev/locales/{lv-LV-MD7N5VHD.js → lv-LV-SPQ2VWX3.js} +195 -38
  74. package/dist/dev/locales/lv-LV-SPQ2VWX3.js.map +7 -0
  75. package/dist/dev/locales/{mr-IN-4XWMNGQC.js → mr-IN-2HLK6LUA.js} +203 -46
  76. package/dist/dev/locales/mr-IN-2HLK6LUA.js.map +7 -0
  77. package/dist/dev/locales/{my-MM-O4Z74GN5.js → my-MM-P2LR44WR.js} +180 -23
  78. package/dist/dev/locales/my-MM-P2LR44WR.js.map +7 -0
  79. package/dist/dev/locales/{nb-NO-BMB73KRH.js → nb-NO-7YZHFFVS.js} +219 -62
  80. package/dist/dev/locales/nb-NO-7YZHFFVS.js.map +7 -0
  81. package/dist/dev/locales/{nl-NL-F2257BLQ.js → nl-NL-TF2OVIKN.js} +217 -60
  82. package/dist/dev/locales/nl-NL-TF2OVIKN.js.map +7 -0
  83. package/dist/dev/locales/{nn-NO-NCORG7TS.js → nn-NO-2BWEL2IS.js} +200 -43
  84. package/dist/dev/locales/nn-NO-2BWEL2IS.js.map +7 -0
  85. package/dist/dev/locales/{oc-FR-ATFBDMF6.js → oc-FR-5JYIFGLE.js} +212 -55
  86. package/dist/dev/locales/oc-FR-5JYIFGLE.js.map +7 -0
  87. package/dist/dev/locales/{pa-IN-D2I375G4.js → pa-IN-KBBGER76.js} +189 -32
  88. package/dist/dev/locales/pa-IN-KBBGER76.js.map +7 -0
  89. package/dist/dev/locales/{percentages-YKFLWNK2.js → percentages-2RAYDWNS.js} +2 -2
  90. package/dist/dev/locales/{pl-PL-YJHOWAAW.js → pl-PL-BWZ2X734.js} +213 -56
  91. package/dist/dev/locales/pl-PL-BWZ2X734.js.map +7 -0
  92. package/dist/dev/locales/{pt-BR-APOPYZJ7.js → pt-BR-ERVIQI63.js} +236 -79
  93. package/dist/dev/locales/pt-BR-ERVIQI63.js.map +7 -0
  94. package/dist/dev/locales/pt-PT-ZNJ5NB5S.js +743 -0
  95. package/dist/dev/locales/pt-PT-ZNJ5NB5S.js.map +7 -0
  96. package/dist/dev/locales/{ro-RO-L575VRQA.js → ro-RO-UYNXGUB7.js} +202 -45
  97. package/dist/dev/locales/ro-RO-UYNXGUB7.js.map +7 -0
  98. package/dist/dev/locales/{ru-RU-BLG6HZG5.js → ru-RU-F7LPIMGQ.js} +252 -95
  99. package/dist/dev/locales/ru-RU-F7LPIMGQ.js.map +7 -0
  100. package/dist/dev/locales/si-LK-5GF2DJUH.js +743 -0
  101. package/dist/dev/locales/si-LK-5GF2DJUH.js.map +7 -0
  102. package/dist/dev/locales/{sk-SK-DY6IPO5U.js → sk-SK-H6WE7IJX.js} +199 -42
  103. package/dist/dev/locales/sk-SK-H6WE7IJX.js.map +7 -0
  104. package/dist/dev/locales/{sl-SI-5DZSRA47.js → sl-SI-4PJ6LBI7.js} +196 -39
  105. package/dist/dev/locales/sl-SI-4PJ6LBI7.js.map +7 -0
  106. package/dist/dev/locales/{sv-SE-V32YHALQ.js → sv-SE-E5VQLCRE.js} +201 -44
  107. package/dist/dev/locales/sv-SE-E5VQLCRE.js.map +7 -0
  108. package/dist/dev/locales/{ta-IN-5JRAGQAO.js → ta-IN-2YWIVLKF.js} +256 -99
  109. package/dist/dev/locales/ta-IN-2YWIVLKF.js.map +7 -0
  110. package/dist/dev/locales/{th-TH-55ACRHDJ.js → th-TH-IV7RUTDK.js} +288 -131
  111. package/dist/dev/locales/th-TH-IV7RUTDK.js.map +7 -0
  112. package/dist/dev/locales/{tr-TR-7QYBXDBO.js → tr-TR-LEQWIQH7.js} +256 -99
  113. package/dist/dev/locales/tr-TR-LEQWIQH7.js.map +7 -0
  114. package/dist/dev/locales/{uk-UA-TJS2TMRH.js → uk-UA-DWVOQPTB.js} +228 -71
  115. package/dist/dev/locales/uk-UA-DWVOQPTB.js.map +7 -0
  116. package/dist/dev/locales/{si-LK-KT7GGO6D.js → uz-UZ-CKXQ3QKG.js} +211 -54
  117. package/dist/dev/locales/uz-UZ-CKXQ3QKG.js.map +7 -0
  118. package/dist/dev/locales/vi-VN-3P6DZOGS.js +743 -0
  119. package/dist/dev/locales/vi-VN-3P6DZOGS.js.map +7 -0
  120. package/dist/dev/locales/{zh-CN-4MXUOFTH.js → zh-CN-XXVG53TQ.js} +198 -41
  121. package/dist/dev/locales/zh-CN-XXVG53TQ.js.map +7 -0
  122. package/dist/dev/locales/{zh-HK-RBTGIU3U.js → zh-HK-JCHGKEUE.js} +174 -17
  123. package/dist/dev/locales/zh-HK-JCHGKEUE.js.map +7 -0
  124. package/dist/dev/locales/{zh-TW-U5VF4CCU.js → zh-TW-ARVT7RZU.js} +203 -46
  125. package/dist/dev/locales/zh-TW-ARVT7RZU.js.map +7 -0
  126. package/dist/prod/chunk-KRJFZ5JQ.js +1 -0
  127. package/dist/prod/chunk-N7QNUCIG.js +12 -0
  128. package/dist/prod/chunk-XJNFOLHK.js +4 -0
  129. package/dist/prod/data/{image-HXEZYJPQ.js → image-SMWA6JLH.js} +1 -1
  130. package/dist/prod/index.css +1 -1
  131. package/dist/prod/index.js +23 -23
  132. package/dist/prod/locales/ar-SA-F62BVQMB.js +8 -0
  133. package/dist/prod/locales/az-AZ-7PGSKYOB.js +1 -0
  134. package/dist/prod/locales/bg-BG-AAEXMUQ4.js +5 -0
  135. package/dist/prod/locales/bn-BD-ONOFQYIQ.js +3 -0
  136. package/dist/prod/locales/bn-IN-YT3I2M3F.js +3 -0
  137. package/dist/prod/locales/ca-ES-GG4YH2FN.js +8 -0
  138. package/dist/prod/locales/cs-CZ-IS5VTBOP.js +7 -0
  139. package/dist/prod/locales/da-DK-VPQ2KWAY.js +2 -0
  140. package/dist/prod/locales/de-CH-G4Y2G6IS.js +7 -0
  141. package/dist/prod/locales/de-DE-RAT2LIDI.js +7 -0
  142. package/dist/prod/locales/el-GR-DNJB2AZO.js +7 -0
  143. package/dist/prod/locales/en-FOCNVEEU.js +1 -0
  144. package/dist/prod/locales/es-ES-IMTENLBU.js +7 -0
  145. package/dist/prod/locales/eu-ES-XLOS36YS.js +7 -0
  146. package/dist/prod/locales/fa-IR-J6Z2YOGX.js +9 -0
  147. package/dist/prod/locales/fi-FI-B2IQ7SBP.js +6 -0
  148. package/dist/prod/locales/fr-FR-N5BRDCMI.js +12 -0
  149. package/dist/prod/locales/gl-ES-BOYALFRN.js +6 -0
  150. package/dist/prod/locales/he-IL-H7M7HGY5.js +8 -0
  151. package/dist/prod/locales/hi-IN-7AB5CA2Q.js +3 -0
  152. package/dist/prod/locales/hu-HU-ZZM7UJLP.js +3 -0
  153. package/dist/prod/locales/id-ID-RZ7JNCXA.js +8 -0
  154. package/dist/prod/locales/it-IT-ZX7HN56D.js +8 -0
  155. package/dist/prod/locales/ja-JP-NBNBUHIR.js +7 -0
  156. package/dist/prod/locales/kaa-QWYSGEM7.js +1 -0
  157. package/dist/prod/locales/kab-KAB-Q3HBKQ5I.js +4 -0
  158. package/dist/prod/locales/kk-KZ-HF2NTCRX.js +1 -0
  159. package/dist/prod/locales/km-KH-CN6HHF5U.js +7 -0
  160. package/dist/prod/locales/ko-KR-SJQMUXM7.js +5 -0
  161. package/dist/prod/locales/ku-TR-VM4BHTPC.js +6 -0
  162. package/dist/prod/locales/lt-LT-QIWZQ7AG.js +3 -0
  163. package/dist/prod/locales/lv-LV-YQFCB4WZ.js +4 -0
  164. package/dist/prod/locales/mr-IN-GR2ZJPSQ.js +9 -0
  165. package/dist/prod/locales/my-MM-M5XJDJQ2.js +1 -0
  166. package/dist/prod/locales/nb-NO-2RU2YF7H.js +8 -0
  167. package/dist/prod/locales/nl-NL-MUHXDQFK.js +7 -0
  168. package/dist/prod/locales/nn-NO-72RCA552.js +4 -0
  169. package/dist/prod/locales/oc-FR-65ITQYQ2.js +4 -0
  170. package/dist/prod/locales/pa-IN-WESENMFH.js +4 -0
  171. package/dist/prod/locales/percentages-OEPNEGCM.js +1 -0
  172. package/dist/prod/locales/pl-PL-7C4NGVUA.js +12 -0
  173. package/dist/prod/locales/pt-BR-QH23C2IX.js +6 -0
  174. package/dist/prod/locales/pt-PT-O5XBATXI.js +8 -0
  175. package/dist/prod/locales/ro-RO-QHCHEGM5.js +12 -0
  176. package/dist/prod/locales/ru-RU-FUMQ2LLB.js +6 -0
  177. package/dist/prod/locales/si-LK-JYUINGNN.js +1 -0
  178. package/dist/prod/locales/sk-SK-R25O52BS.js +7 -0
  179. package/dist/prod/locales/sl-SI-5KPVX4FS.js +6 -0
  180. package/dist/prod/locales/sv-SE-MVMXV6O4.js +8 -0
  181. package/dist/prod/locales/ta-IN-A32FQB4D.js +6 -0
  182. package/dist/prod/locales/th-TH-CXMWNVBY.js +1 -0
  183. package/dist/prod/locales/tr-TR-YHFI3W2D.js +4 -0
  184. package/dist/prod/locales/uk-UA-UTJIIKT5.js +6 -0
  185. package/dist/prod/locales/uz-UZ-H4EGTR7D.js +1 -0
  186. package/dist/prod/locales/vi-VN-XBV2ESZM.js +7 -0
  187. package/dist/prod/locales/zh-CN-CKCJ4HAO.js +11 -0
  188. package/dist/prod/locales/zh-HK-ISASRRMF.js +1 -0
  189. package/dist/prod/locales/zh-TW-KYRW5V3R.js +9 -0
  190. package/dist/types/common/src/constants.d.ts +21 -15
  191. package/dist/types/common/src/editorInterface.d.ts +34 -0
  192. package/dist/types/common/src/index.d.ts +2 -0
  193. package/dist/types/common/src/utils.d.ts +9 -3
  194. package/dist/types/common/src/visualdebug.d.ts +41 -0
  195. package/dist/types/element/src/Scene.d.ts +6 -2
  196. package/dist/types/element/src/align.d.ts +2 -1
  197. package/dist/types/element/src/binding.d.ts +55 -43
  198. package/dist/types/element/src/bounds.d.ts +1 -1
  199. package/dist/types/element/src/collision.d.ts +6 -2
  200. package/dist/types/element/src/delta.d.ts +16 -4
  201. package/dist/types/element/src/distribute.d.ts +2 -1
  202. package/dist/types/element/src/groups.d.ts +1 -0
  203. package/dist/types/element/src/index.d.ts +1 -3
  204. package/dist/types/element/src/linearElementEditor.d.ts +17 -19
  205. package/dist/types/element/src/positionElementsOnGrid.d.ts +2 -0
  206. package/dist/types/element/src/renderElement.d.ts +5 -2
  207. package/dist/types/element/src/resizeTest.d.ts +5 -4
  208. package/dist/types/element/src/store.d.ts +6 -1
  209. package/dist/types/element/src/textElement.d.ts +1 -1
  210. package/dist/types/element/src/transformHandles.d.ts +5 -4
  211. package/dist/types/element/src/typeChecks.d.ts +2 -3
  212. package/dist/types/element/src/types.d.ts +7 -11
  213. package/dist/types/element/src/utils.d.ts +2 -1
  214. package/dist/types/element/src/zindex.d.ts +7 -1
  215. package/dist/types/excalidraw/actions/actionAddToLibrary.d.ts +34 -16
  216. package/dist/types/excalidraw/actions/actionAlign.d.ts +6 -6
  217. package/dist/types/excalidraw/actions/actionBoundText.d.ts +25 -13
  218. package/dist/types/excalidraw/actions/actionCanvas.d.ts +153 -275
  219. package/dist/types/excalidraw/actions/actionClipboard.d.ts +45 -777
  220. package/dist/types/excalidraw/actions/actionCropEditor.d.ts +12 -6
  221. package/dist/types/excalidraw/actions/actionDeleteSelected.d.ts +45 -29
  222. package/dist/types/excalidraw/actions/actionDistribute.d.ts +2 -2
  223. package/dist/types/excalidraw/actions/actionDuplicateSelection.d.ts +2 -2
  224. package/dist/types/excalidraw/actions/actionElementLink.d.ts +11 -7
  225. package/dist/types/excalidraw/actions/actionElementLock.d.ts +23 -11
  226. package/dist/types/excalidraw/actions/actionEmbeddable.d.ts +12 -6
  227. package/dist/types/excalidraw/actions/actionExport.d.ts +68 -952
  228. package/dist/types/excalidraw/actions/actionFinalize.d.ts +10 -394
  229. package/dist/types/excalidraw/actions/actionFlip.d.ts +2 -2
  230. package/dist/types/excalidraw/actions/actionFrame.d.ts +50 -28
  231. package/dist/types/excalidraw/actions/actionGroup.d.ts +24 -12
  232. package/dist/types/excalidraw/actions/actionLinearEditor.d.ts +47 -14
  233. package/dist/types/excalidraw/actions/actionLink.d.ts +9 -3
  234. package/dist/types/excalidraw/actions/actionMenu.d.ts +10 -374
  235. package/dist/types/excalidraw/actions/actionNavigate.d.ts +21 -361
  236. package/dist/types/excalidraw/actions/actionProperties.d.ts +87 -2418
  237. package/dist/types/excalidraw/actions/actionSelectAll.d.ts +12 -6
  238. package/dist/types/excalidraw/actions/actionStyles.d.ts +13 -7
  239. package/dist/types/excalidraw/actions/actionTextAutoResize.d.ts +1 -1
  240. package/dist/types/excalidraw/actions/actionToggleGridMode.d.ts +11 -5
  241. package/dist/types/excalidraw/actions/actionToggleObjectsSnapMode.d.ts +11 -5
  242. package/dist/types/excalidraw/actions/actionToggleSearchMenu.d.ts +10 -6
  243. package/dist/types/excalidraw/actions/actionToggleShapeSwitch.d.ts +1 -1
  244. package/dist/types/excalidraw/actions/actionToggleStats.d.ts +11 -5
  245. package/dist/types/excalidraw/actions/actionToggleViewMode.d.ts +11 -5
  246. package/dist/types/excalidraw/actions/actionToggleZenMode.d.ts +12 -6
  247. package/dist/types/excalidraw/actions/actionZindex.d.ts +2 -2
  248. package/dist/types/excalidraw/actions/index.d.ts +2 -2
  249. package/dist/types/excalidraw/actions/manager.d.ts +1 -1
  250. package/dist/types/excalidraw/actions/register.d.ts +1 -1
  251. package/dist/types/excalidraw/actions/types.d.ts +4 -4
  252. package/dist/types/excalidraw/appState.d.ts +9 -4
  253. package/dist/types/excalidraw/clipboard.d.ts +64 -1
  254. package/dist/types/excalidraw/components/Actions.d.ts +20 -7
  255. package/dist/types/excalidraw/components/App.d.ts +35 -25
  256. package/dist/types/excalidraw/components/ColorPicker/Picker.d.ts +2 -0
  257. package/dist/types/excalidraw/components/ColorPicker/PickerColorList.d.ts +2 -1
  258. package/dist/types/excalidraw/components/ColorPicker/ShadeList.d.ts +2 -1
  259. package/dist/types/excalidraw/components/CommandPalette/CommandPalette.d.ts +1 -0
  260. package/dist/types/excalidraw/components/CommandPalette/types.d.ts +1 -2
  261. package/dist/types/excalidraw/components/Ellipsify.d.ts +4 -0
  262. package/dist/types/excalidraw/components/ExcalidrawLogo.d.ts +1 -1
  263. package/dist/types/excalidraw/components/FilledButton.d.ts +1 -1
  264. package/dist/types/excalidraw/components/FontPicker/FontPicker.d.ts +2 -1
  265. package/dist/types/excalidraw/components/FontPicker/FontPickerTrigger.d.ts +3 -1
  266. package/dist/types/excalidraw/components/HintViewer.d.ts +4 -3
  267. package/dist/types/excalidraw/components/InlineIcon.d.ts +3 -1
  268. package/dist/types/excalidraw/components/LayerUI.d.ts +2 -1
  269. package/dist/types/excalidraw/components/LibraryMenuSection.d.ts +1 -1
  270. package/dist/types/excalidraw/components/LinkButton.d.ts +4 -0
  271. package/dist/types/excalidraw/components/MobileMenu.d.ts +3 -5
  272. package/dist/types/excalidraw/components/MobileToolBar.d.ts +11 -0
  273. package/dist/types/excalidraw/components/Popover.d.ts +2 -1
  274. package/dist/types/excalidraw/components/PropertiesPopover.d.ts +1 -0
  275. package/dist/types/excalidraw/components/Stats/utils.d.ts +1 -1
  276. package/dist/types/excalidraw/components/TTDDialog/TTDDialogTrigger.d.ts +1 -2
  277. package/dist/types/excalidraw/components/TextField.d.ts +1 -0
  278. package/dist/types/excalidraw/components/ToolPopover.d.ts +25 -0
  279. package/dist/types/excalidraw/components/canvases/InteractiveCanvas.d.ts +6 -3
  280. package/dist/types/excalidraw/components/dropdownMenu/DropdownMenu.d.ts +4 -2
  281. package/dist/types/excalidraw/components/dropdownMenu/DropdownMenuContent.d.ts +2 -1
  282. package/dist/types/excalidraw/components/icons.d.ts +10 -0
  283. package/dist/types/excalidraw/components/live-collaboration/LiveCollaborationTrigger.d.ts +13 -1
  284. package/dist/types/excalidraw/components/main-menu/MainMenu.d.ts +0 -3
  285. package/dist/types/excalidraw/components/shapes.d.ts +129 -1
  286. package/dist/types/excalidraw/data/blob.d.ts +3 -7
  287. package/dist/types/excalidraw/data/reconcile.d.ts +1 -0
  288. package/dist/types/excalidraw/data/restore.d.ts +7 -2
  289. package/dist/types/excalidraw/data/types.d.ts +4 -1
  290. package/dist/types/excalidraw/hooks/useLibraryItemSvg.d.ts +1 -1
  291. package/dist/types/excalidraw/hooks/useOutsideClick.d.ts +3 -1
  292. package/dist/types/excalidraw/hooks/useTextEditorFocus.d.ts +14 -0
  293. package/dist/types/excalidraw/index.d.ts +4 -4
  294. package/dist/types/excalidraw/renderer/animation.d.ts +12 -0
  295. package/dist/types/excalidraw/renderer/helpers.d.ts +1 -5
  296. package/dist/types/excalidraw/renderer/interactiveScene.d.ts +5 -13
  297. package/dist/types/excalidraw/renderer/staticScene.d.ts +4 -1
  298. package/dist/types/excalidraw/scene/types.d.ts +15 -3
  299. package/dist/types/excalidraw/shortcut.d.ts +1 -0
  300. package/dist/types/excalidraw/types.d.ts +37 -24
  301. package/dist/types/math/src/segment.d.ts +1 -0
  302. package/history.ts +1 -1
  303. package/package.json +6 -6
  304. package/dist/dev/chunk-CBGOW5JB.js.map +0 -7
  305. package/dist/dev/chunk-MFAYKRVR.js +0 -66
  306. package/dist/dev/chunk-MFAYKRVR.js.map +0 -7
  307. package/dist/dev/chunk-QF5FRM6O.js.map +0 -7
  308. package/dist/dev/locales/ar-SA-XORAP2EK.js.map +0 -7
  309. package/dist/dev/locales/az-AZ-NAUU3Z4Y.js.map +0 -7
  310. package/dist/dev/locales/bg-BG-AAABLFCY.js.map +0 -7
  311. package/dist/dev/locales/bn-BD-PM4AC5WG.js.map +0 -7
  312. package/dist/dev/locales/ca-ES-YNNMFRQX.js.map +0 -7
  313. package/dist/dev/locales/cs-CZ-DGZA5IKG.js.map +0 -7
  314. package/dist/dev/locales/da-DK-N76F4QAJ.js.map +0 -7
  315. package/dist/dev/locales/de-DE-DMRXZ2SZ.js.map +0 -7
  316. package/dist/dev/locales/el-GR-HIKPLEXI.js.map +0 -7
  317. package/dist/dev/locales/es-ES-AQYVXC32.js.map +0 -7
  318. package/dist/dev/locales/eu-ES-3TOEU5DE.js.map +0 -7
  319. package/dist/dev/locales/fa-IR-527GAKUP.js.map +0 -7
  320. package/dist/dev/locales/fi-FI-M3WLVDFP.js.map +0 -7
  321. package/dist/dev/locales/fr-FR-YE4VDJFI.js.map +0 -7
  322. package/dist/dev/locales/gl-ES-KMXUYGUN.js.map +0 -7
  323. package/dist/dev/locales/he-IL-4MU5N22B.js +0 -586
  324. package/dist/dev/locales/he-IL-4MU5N22B.js.map +0 -7
  325. package/dist/dev/locales/hi-IN-ZHZNZWFC.js +0 -586
  326. package/dist/dev/locales/hi-IN-ZHZNZWFC.js.map +0 -7
  327. package/dist/dev/locales/hu-HU-VIYZI3X4.js.map +0 -7
  328. package/dist/dev/locales/id-ID-22TWZNLA.js.map +0 -7
  329. package/dist/dev/locales/it-IT-MDEQ2SG3.js.map +0 -7
  330. package/dist/dev/locales/ja-JP-K2DI4W6B.js.map +0 -7
  331. package/dist/dev/locales/kaa-6BPSNM3R.js.map +0 -7
  332. package/dist/dev/locales/kab-KAB-2S7ZURK7.js.map +0 -7
  333. package/dist/dev/locales/kk-KZ-UJPYGRQQ.js.map +0 -7
  334. package/dist/dev/locales/km-KH-M5T5JKUE.js.map +0 -7
  335. package/dist/dev/locales/ko-KR-RQX37SNF.js.map +0 -7
  336. package/dist/dev/locales/ku-TR-5XJDIERL.js.map +0 -7
  337. package/dist/dev/locales/lt-LT-MGUBX6CA.js.map +0 -7
  338. package/dist/dev/locales/lv-LV-MD7N5VHD.js.map +0 -7
  339. package/dist/dev/locales/mr-IN-4XWMNGQC.js.map +0 -7
  340. package/dist/dev/locales/my-MM-O4Z74GN5.js.map +0 -7
  341. package/dist/dev/locales/nb-NO-BMB73KRH.js.map +0 -7
  342. package/dist/dev/locales/nl-NL-F2257BLQ.js.map +0 -7
  343. package/dist/dev/locales/nn-NO-NCORG7TS.js.map +0 -7
  344. package/dist/dev/locales/oc-FR-ATFBDMF6.js.map +0 -7
  345. package/dist/dev/locales/pa-IN-D2I375G4.js.map +0 -7
  346. package/dist/dev/locales/pl-PL-YJHOWAAW.js.map +0 -7
  347. package/dist/dev/locales/pt-BR-APOPYZJ7.js.map +0 -7
  348. package/dist/dev/locales/pt-PT-W56WCN7P.js +0 -586
  349. package/dist/dev/locales/pt-PT-W56WCN7P.js.map +0 -7
  350. package/dist/dev/locales/ro-RO-L575VRQA.js.map +0 -7
  351. package/dist/dev/locales/ru-RU-BLG6HZG5.js.map +0 -7
  352. package/dist/dev/locales/si-LK-KT7GGO6D.js.map +0 -7
  353. package/dist/dev/locales/sk-SK-DY6IPO5U.js.map +0 -7
  354. package/dist/dev/locales/sl-SI-5DZSRA47.js.map +0 -7
  355. package/dist/dev/locales/sv-SE-V32YHALQ.js.map +0 -7
  356. package/dist/dev/locales/ta-IN-5JRAGQAO.js.map +0 -7
  357. package/dist/dev/locales/th-TH-55ACRHDJ.js.map +0 -7
  358. package/dist/dev/locales/tr-TR-7QYBXDBO.js.map +0 -7
  359. package/dist/dev/locales/uk-UA-TJS2TMRH.js.map +0 -7
  360. package/dist/dev/locales/vi-VN-Y5CQ2EKQ.js +0 -586
  361. package/dist/dev/locales/vi-VN-Y5CQ2EKQ.js.map +0 -7
  362. package/dist/dev/locales/zh-CN-4MXUOFTH.js.map +0 -7
  363. package/dist/dev/locales/zh-HK-RBTGIU3U.js.map +0 -7
  364. package/dist/dev/locales/zh-TW-U5VF4CCU.js.map +0 -7
  365. package/dist/prod/chunk-I4UNSFV6.js +0 -12
  366. package/dist/prod/chunk-IRHK23LL.js +0 -4
  367. package/dist/prod/chunk-Z3N5DIM6.js +0 -1
  368. package/dist/prod/locales/ar-SA-G6X2FPQ2.js +0 -10
  369. package/dist/prod/locales/az-AZ-76LH7QW2.js +0 -1
  370. package/dist/prod/locales/bg-BG-XCXSNQG7.js +0 -5
  371. package/dist/prod/locales/bn-BD-2XOGV67Q.js +0 -5
  372. package/dist/prod/locales/ca-ES-6MX7JW3Y.js +0 -8
  373. package/dist/prod/locales/cs-CZ-2BRQDIVT.js +0 -11
  374. package/dist/prod/locales/da-DK-5WZEPLOC.js +0 -5
  375. package/dist/prod/locales/de-DE-XR44H4JA.js +0 -8
  376. package/dist/prod/locales/el-GR-BZB4AONW.js +0 -10
  377. package/dist/prod/locales/en-TYY6KWIJ.js +0 -1
  378. package/dist/prod/locales/es-ES-U4NZUMDT.js +0 -9
  379. package/dist/prod/locales/eu-ES-A7QVB2H4.js +0 -11
  380. package/dist/prod/locales/fa-IR-HGAKTJCU.js +0 -8
  381. package/dist/prod/locales/fi-FI-Z5N7JZ37.js +0 -6
  382. package/dist/prod/locales/fr-FR-RHASNOE6.js +0 -9
  383. package/dist/prod/locales/gl-ES-HMX3MZ6V.js +0 -10
  384. package/dist/prod/locales/he-IL-6SHJWFNN.js +0 -10
  385. package/dist/prod/locales/hi-IN-IWLTKZ5I.js +0 -4
  386. package/dist/prod/locales/hu-HU-A5ZG7DT2.js +0 -7
  387. package/dist/prod/locales/id-ID-SAP4L64H.js +0 -10
  388. package/dist/prod/locales/it-IT-JPQ66NNP.js +0 -11
  389. package/dist/prod/locales/ja-JP-DBVTYXUO.js +0 -8
  390. package/dist/prod/locales/kaa-6HZHGXH3.js +0 -1
  391. package/dist/prod/locales/kab-KAB-ZGHBKWFO.js +0 -8
  392. package/dist/prod/locales/kk-KZ-P5N5QNE5.js +0 -1
  393. package/dist/prod/locales/km-KH-HSX4SM5Z.js +0 -11
  394. package/dist/prod/locales/ko-KR-MTYHY66A.js +0 -9
  395. package/dist/prod/locales/ku-TR-6OUDTVRD.js +0 -9
  396. package/dist/prod/locales/lt-LT-XHIRWOB4.js +0 -3
  397. package/dist/prod/locales/lv-LV-5QDEKY6T.js +0 -7
  398. package/dist/prod/locales/mr-IN-CRQNXWMA.js +0 -13
  399. package/dist/prod/locales/my-MM-5M5IBNSE.js +0 -1
  400. package/dist/prod/locales/nb-NO-T6EIAALU.js +0 -10
  401. package/dist/prod/locales/nl-NL-IS3SIHDZ.js +0 -8
  402. package/dist/prod/locales/nn-NO-6E72VCQL.js +0 -8
  403. package/dist/prod/locales/oc-FR-POXYY2M6.js +0 -8
  404. package/dist/prod/locales/pa-IN-N4M65BXN.js +0 -4
  405. package/dist/prod/locales/percentages-BXMCSKIN.js +0 -1
  406. package/dist/prod/locales/pl-PL-T2D74RX3.js +0 -9
  407. package/dist/prod/locales/pt-BR-5N22H2LF.js +0 -9
  408. package/dist/prod/locales/pt-PT-UZXXM6DQ.js +0 -9
  409. package/dist/prod/locales/ro-RO-JPDTUUEW.js +0 -11
  410. package/dist/prod/locales/ru-RU-B4JR7IUQ.js +0 -9
  411. package/dist/prod/locales/si-LK-N5RQ5JYF.js +0 -1
  412. package/dist/prod/locales/sk-SK-C5VTKIMK.js +0 -6
  413. package/dist/prod/locales/sl-SI-NN7IZMDC.js +0 -6
  414. package/dist/prod/locales/sv-SE-XGPEYMSR.js +0 -10
  415. package/dist/prod/locales/ta-IN-2NMHFXQM.js +0 -9
  416. package/dist/prod/locales/th-TH-HPSO5L25.js +0 -2
  417. package/dist/prod/locales/tr-TR-DEFEU3FU.js +0 -7
  418. package/dist/prod/locales/uk-UA-QMV73CPH.js +0 -6
  419. package/dist/prod/locales/vi-VN-M7AON7JQ.js +0 -5
  420. package/dist/prod/locales/zh-CN-LNUGB5OW.js +0 -10
  421. package/dist/prod/locales/zh-HK-E62DVLB3.js +0 -1
  422. package/dist/prod/locales/zh-TW-RAJ6MFWO.js +0 -9
  423. /package/dist/dev/data/{image-SURZSZNX.js.map → image-S2GFZH7W.js.map} +0 -0
  424. /package/dist/dev/locales/{en-SMAPCEOQ.js.map → en-ZO6QSABV.js.map} +0 -0
  425. /package/dist/dev/locales/{percentages-YKFLWNK2.js.map → percentages-2RAYDWNS.js.map} +0 -0
@@ -4,42 +4,41 @@ import { type Store } from "@excalidraw/element";
4
4
  import type { AppState, PointerCoords, InteractiveCanvasAppState, AppClassProperties, NullableGridSize, Zoom } from "@excalidraw/excalidraw/types";
5
5
  import type { Scene } from "./Scene";
6
6
  import type { Bounds } from "./bounds";
7
- import type { NonDeleted, ExcalidrawLinearElement, ExcalidrawElement, PointBinding, ExcalidrawBindableElement, ExcalidrawTextElementWithContainer, ElementsMap, NonDeletedSceneElementsMap, ExcalidrawElbowArrowElement, PointsPositionUpdates } from "./types";
7
+ import type { NonDeleted, ExcalidrawLinearElement, ExcalidrawElement, ExcalidrawTextElementWithContainer, ElementsMap, NonDeletedSceneElementsMap, FixedPointBinding, ExcalidrawElbowArrowElement, PointsPositionUpdates } from "./types";
8
8
  export declare class LinearElementEditor {
9
9
  readonly elementId: ExcalidrawElement["id"] & {
10
10
  _brand: "excalidrawLinearElementId";
11
11
  };
12
12
  /** indices */
13
13
  readonly selectedPointsIndices: readonly number[] | null;
14
- readonly pointerDownState: Readonly<{
14
+ readonly initialState: Readonly<{
15
15
  prevSelectedPointsIndices: readonly number[] | null;
16
16
  /** index */
17
17
  lastClickedPoint: number;
18
- lastClickedIsEndPoint: boolean;
19
- origin: Readonly<{
20
- x: number;
21
- y: number;
22
- }> | null;
18
+ origin: Readonly<GlobalPoint> | null;
23
19
  segmentMidpoint: {
24
20
  value: GlobalPoint | null;
25
21
  index: number | null;
26
22
  added: boolean;
27
23
  };
24
+ arrowStartIsInside: boolean;
25
+ altFocusPoint: Readonly<GlobalPoint> | null;
28
26
  }>;
29
27
  /** whether you're dragging a point */
30
28
  readonly isDragging: boolean;
31
29
  readonly lastUncommittedPoint: LocalPoint | null;
30
+ readonly lastCommittedPoint: LocalPoint | null;
32
31
  readonly pointerOffset: Readonly<{
33
32
  x: number;
34
33
  y: number;
35
34
  }>;
36
- readonly startBindingElement: ExcalidrawBindableElement | null | "keep";
37
- readonly endBindingElement: ExcalidrawBindableElement | null | "keep";
38
35
  readonly hoverPointIndex: number;
39
36
  readonly segmentMidPointHoveredCoords: GlobalPoint | null;
40
37
  readonly elbowed: boolean;
41
38
  readonly customLineAngle: number | null;
42
- constructor(element: NonDeleted<ExcalidrawLinearElement>, elementsMap: ElementsMap);
39
+ readonly isEditing: boolean;
40
+ readonly pointerDownState: never;
41
+ constructor(element: NonDeleted<ExcalidrawLinearElement>, elementsMap: ElementsMap, isEditing?: boolean);
43
42
  static POINT_HANDLE_SIZE: number;
44
43
  /**
45
44
  * @param id the `elementId` from the instance of this class (so that we can
@@ -47,10 +46,8 @@ export declare class LinearElementEditor {
47
46
  */
48
47
  static getElement<T extends ExcalidrawLinearElement>(id: InstanceType<typeof LinearElementEditor>["elementId"], elementsMap: ElementsMap): T | null;
49
48
  static handleBoxSelection(event: PointerEvent, appState: AppState, setState: React.Component<any, AppState>["setState"], elementsMap: NonDeletedSceneElementsMap): false | undefined;
50
- /**
51
- * @returns whether point was dragged
52
- */
53
- static handlePointDragging(event: PointerEvent, app: AppClassProperties, scenePointerX: number, scenePointerY: number, linearElementEditor: LinearElementEditor): Pick<AppState, keyof AppState> | null;
49
+ static handlePointerMove(event: PointerEvent, app: AppClassProperties, scenePointerX: number, scenePointerY: number, linearElementEditor: LinearElementEditor): Pick<AppState, "suggestedBinding" | "selectedLinearElement"> | null;
50
+ static handlePointDragging(event: PointerEvent, app: AppClassProperties, scenePointerX: number, scenePointerY: number, linearElementEditor: LinearElementEditor): Pick<AppState, "suggestedBinding" | "selectedLinearElement"> | null;
54
51
  static handlePointerUp(event: PointerEvent, editingLinearElement: LinearElementEditor, appState: AppState, scene: Scene): LinearElementEditor;
55
52
  static getEditorMidPoints: (element: NonDeleted<ExcalidrawLinearElement>, elementsMap: ElementsMap, appState: InteractiveCanvasAppState) => (GlobalPoint | null)[];
56
53
  static getSegmentMidpointHitCoords: (linearElementEditor: LinearElementEditor, scenePointer: {
@@ -69,7 +66,7 @@ export declare class LinearElementEditor {
69
66
  linearElementEditor: LinearElementEditor | null;
70
67
  };
71
68
  static arePointsEqual<Point extends LocalPoint | GlobalPoint>(point1: Point | null, point2: Point | null): boolean;
72
- static handlePointerMove(event: React.PointerEvent<HTMLCanvasElement>, scenePointerX: number, scenePointerY: number, app: AppClassProperties): LinearElementEditor | null;
69
+ static handlePointerMoveInEditMode(event: React.PointerEvent<HTMLCanvasElement>, scenePointerX: number, scenePointerY: number, app: AppClassProperties): LinearElementEditor | null;
73
70
  /** scene coords */
74
71
  static getPointGlobalCoordinates(element: NonDeleted<ExcalidrawLinearElement>, p: LocalPoint, elementsMap: ElementsMap): GlobalPoint;
75
72
  /** scene coords */
@@ -95,12 +92,13 @@ export declare class LinearElementEditor {
95
92
  static deletePoints(element: NonDeleted<ExcalidrawLinearElement>, app: AppClassProperties, pointIndices: readonly number[]): void;
96
93
  static addPoints(element: NonDeleted<ExcalidrawLinearElement>, scene: Scene, addedPoints: LocalPoint[]): void;
97
94
  static movePoints(element: NonDeleted<ExcalidrawLinearElement>, scene: Scene, pointUpdates: PointsPositionUpdates, otherUpdates?: {
98
- startBinding?: PointBinding | null;
99
- endBinding?: PointBinding | null;
95
+ startBinding?: FixedPointBinding | null;
96
+ endBinding?: FixedPointBinding | null;
97
+ moveMidPointsWithElement?: boolean | null;
100
98
  }): void;
101
99
  static shouldAddMidpoint(linearElementEditor: LinearElementEditor, pointerCoords: PointerCoords, appState: AppState, elementsMap: ElementsMap): boolean;
102
100
  static addMidpoint(linearElementEditor: LinearElementEditor, pointerCoords: PointerCoords, app: AppClassProperties, snapToGrid: boolean, scene: Scene): {
103
- pointerDownState: LinearElementEditor["pointerDownState"];
101
+ pointerDownState: LinearElementEditor["initialState"];
104
102
  selectedPointsIndices: LinearElementEditor["selectedPointsIndices"];
105
103
  } | undefined;
106
104
  private static _updatePoints;
@@ -111,6 +109,6 @@ export declare class LinearElementEditor {
111
109
  };
112
110
  static getMinMaxXYWithBoundText: (element: ExcalidrawLinearElement, elementsMap: ElementsMap, elementBounds: Bounds, boundTextElement: ExcalidrawTextElementWithContainer) => [number, number, number, number, number, number];
113
111
  static getElementAbsoluteCoords: (element: ExcalidrawLinearElement, elementsMap: ElementsMap, includeBoundText?: boolean) => [number, number, number, number, number, number];
114
- static moveFixedSegment(linearElement: LinearElementEditor, index: number, x: number, y: number, scene: Scene): LinearElementEditor;
112
+ static moveFixedSegment(linearElement: LinearElementEditor, index: number, x: number, y: number, scene: Scene): Pick<LinearElementEditor, "segmentMidPointHoveredCoords" | "initialState">;
115
113
  static deleteFixedSegment(element: ExcalidrawElbowArrowElement, scene: Scene, index: number): void;
116
114
  }
@@ -0,0 +1,2 @@
1
+ import type { ExcalidrawElement } from "./types";
2
+ export declare const positionElementsOnGrid: <TElement extends ExcalidrawElement>(elements: TElement[] | TElement[][], centerX: number, centerY: number, padding?: number) => TElement[];
@@ -1,6 +1,7 @@
1
+ import { type GlobalPoint } from "@excalidraw/math";
1
2
  import type { AppState, StaticCanvasAppState, InteractiveCanvasAppState, ElementsPendingErasure, PendingExcalidrawElements } from "@excalidraw/excalidraw/types";
2
3
  import type { StaticCanvasRenderConfig, RenderableElementsMap, InteractiveCanvasRenderConfig } from "@excalidraw/excalidraw/scene/types";
3
- import type { ExcalidrawElement, ExcalidrawTextElement, NonDeletedExcalidrawElement, ExcalidrawFreeDrawElement, ExcalidrawImageElement, ExcalidrawFrameLikeElement, NonDeletedSceneElementsMap } from "./types";
4
+ import type { ExcalidrawElement, ExcalidrawTextElement, NonDeletedExcalidrawElement, ExcalidrawFreeDrawElement, ExcalidrawImageElement, ExcalidrawFrameLikeElement, NonDeletedSceneElementsMap, ElementsMap } from "./types";
4
5
  import type { RoughCanvas } from "roughjs/bin/canvas";
5
6
  export declare const IMAGE_INVERT_FILTER = "invert(100%) hue-rotate(180deg) saturate(1.25)";
6
7
  export declare const getRenderOpacity: (element: ExcalidrawElement, containingFrame: ExcalidrawFrameLikeElement | null, elementsPendingErasure: ElementsPendingErasure, pendingNodes: Readonly<PendingExcalidrawElements> | null, globalAlpha?: number) => number;
@@ -21,8 +22,10 @@ export interface ExcalidrawElementWithCanvas {
21
22
  export declare const DEFAULT_LINK_SIZE = 14;
22
23
  export declare const elementWithCanvasCache: WeakMap<ExcalidrawElement, ExcalidrawElementWithCanvas>;
23
24
  export declare const renderSelectionElement: (element: NonDeletedExcalidrawElement, context: CanvasRenderingContext2D, appState: InteractiveCanvasAppState, selectionColor: InteractiveCanvasRenderConfig["selectionColor"]) => void;
24
- export declare const renderElement: (element: NonDeletedExcalidrawElement, elementsMap: RenderableElementsMap, allElementsMap: NonDeletedSceneElementsMap, rc: RoughCanvas, context: CanvasRenderingContext2D, renderConfig: StaticCanvasRenderConfig, appState: StaticCanvasAppState) => void;
25
+ export declare const renderElement: (element: NonDeletedExcalidrawElement, elementsMap: RenderableElementsMap, allElementsMap: NonDeletedSceneElementsMap, rc: RoughCanvas, context: CanvasRenderingContext2D, renderConfig: StaticCanvasRenderConfig, appState: StaticCanvasAppState | InteractiveCanvasAppState) => void;
25
26
  export declare const pathsCache: WeakMap<ExcalidrawFreeDrawElement, Path2D>;
26
27
  export declare function generateFreeDrawShape(element: ExcalidrawFreeDrawElement): Path2D;
27
28
  export declare function getFreeDrawPath2D(element: ExcalidrawFreeDrawElement): Path2D | undefined;
28
29
  export declare function getFreeDrawSvgPath(element: ExcalidrawFreeDrawElement): string;
30
+ export declare function getFreedrawOutlineAsSegments(element: ExcalidrawFreeDrawElement, points: [number, number][], elementsMap: ElementsMap): import("@excalidraw/math").LineSegment<GlobalPoint>[];
31
+ export declare function getFreedrawOutlinePoints(element: ExcalidrawFreeDrawElement): [number, number][];
@@ -1,14 +1,15 @@
1
+ import { type EditorInterface } from "@excalidraw/common";
1
2
  import type { GlobalPoint, LocalPoint } from "@excalidraw/math";
2
- import type { AppState, Device, Zoom } from "@excalidraw/excalidraw/types";
3
+ import type { AppState, Zoom } from "@excalidraw/excalidraw/types";
3
4
  import type { Bounds } from "./bounds";
4
5
  import type { MaybeTransformHandleType } from "./transformHandles";
5
6
  import type { ExcalidrawElement, PointerType, NonDeletedExcalidrawElement, ElementsMap } from "./types";
6
- export declare const resizeTest: <Point extends GlobalPoint | LocalPoint>(element: NonDeletedExcalidrawElement, elementsMap: ElementsMap, appState: AppState, x: number, y: number, zoom: Zoom, pointerType: PointerType, device: Device) => MaybeTransformHandleType;
7
- export declare const getElementWithTransformHandleType: (elements: readonly NonDeletedExcalidrawElement[], appState: AppState, scenePointerX: number, scenePointerY: number, zoom: Zoom, pointerType: PointerType, elementsMap: ElementsMap, device: Device) => {
7
+ export declare const resizeTest: <Point extends GlobalPoint | LocalPoint>(element: NonDeletedExcalidrawElement, elementsMap: ElementsMap, appState: AppState, x: number, y: number, zoom: Zoom, pointerType: PointerType, editorInterface: EditorInterface) => MaybeTransformHandleType;
8
+ export declare const getElementWithTransformHandleType: (elements: readonly NonDeletedExcalidrawElement[], appState: AppState, scenePointerX: number, scenePointerY: number, zoom: Zoom, pointerType: PointerType, elementsMap: ElementsMap, editorInterface: EditorInterface) => {
8
9
  element: NonDeletedExcalidrawElement;
9
10
  transformHandleType: MaybeTransformHandleType;
10
11
  } | null;
11
- export declare const getTransformHandleTypeFromCoords: <Point extends GlobalPoint | LocalPoint>([x1, y1, x2, y2]: Bounds, scenePointerX: number, scenePointerY: number, zoom: Zoom, pointerType: PointerType, device: Device) => MaybeTransformHandleType;
12
+ export declare const getTransformHandleTypeFromCoords: <Point extends GlobalPoint | LocalPoint>([x1, y1, x2, y2]: Bounds, scenePointerX: number, scenePointerY: number, zoom: Zoom, pointerType: PointerType, editorInterface: EditorInterface) => MaybeTransformHandleType;
12
13
  export declare const getCursorForResizingElement: (resizingElement: {
13
14
  element?: ExcalidrawElement;
14
15
  transformHandleType: MaybeTransformHandleType;
@@ -169,7 +169,11 @@ export declare class StoreDelta {
169
169
  /**
170
170
  * Parse and load the delta from the remote payload.
171
171
  */
172
- static load({ id, elements: { added, removed, updated }, }: DTO<StoreDelta>): StoreDelta;
172
+ static load({ id, elements: { added, removed, updated }, appState: { delta: appStateDelta }, }: DTO<StoreDelta>): StoreDelta;
173
+ /**
174
+ * Squash the passed deltas into the aggregated delta instance.
175
+ */
176
+ static squash(...deltas: StoreDelta[]): StoreDelta;
173
177
  /**
174
178
  * Inverse store delta, creates new instance of `StoreDelta`.
175
179
  */
@@ -182,6 +186,7 @@ export declare class StoreDelta {
182
186
  * Apply latest (remote) changes to the delta, creates new instance of `StoreDelta`.
183
187
  */
184
188
  static applyLatestChanges(delta: StoreDelta, prevElements: SceneElementsMap, nextElements: SceneElementsMap, modifierOptions?: "deleted" | "inserted"): StoreDelta;
189
+ static empty(): StoreDelta;
185
190
  isEmpty(): boolean;
186
191
  }
187
192
  /**
@@ -1,6 +1,6 @@
1
+ import { type Radians } from "@excalidraw/math";
1
2
  import type { AppState } from "@excalidraw/excalidraw/types";
2
3
  import type { ExtractSetType } from "@excalidraw/common/utility-types";
3
- import type { Radians } from "@excalidraw/math";
4
4
  import type { Scene } from "./Scene";
5
5
  import type { MaybeTransformHandleType } from "./transformHandles";
6
6
  import type { ElementsMap, ExcalidrawElement, ExcalidrawElementType, ExcalidrawTextContainer, ExcalidrawTextElement, ExcalidrawTextElementWithContainer, NonDeletedExcalidrawElement } from "./types";
@@ -1,5 +1,6 @@
1
+ import { type EditorInterface } from "@excalidraw/common";
1
2
  import type { Radians } from "@excalidraw/math";
2
- import type { Device, InteractiveCanvasAppState, Zoom } from "@excalidraw/excalidraw/types";
3
+ import type { InteractiveCanvasAppState, Zoom } from "@excalidraw/excalidraw/types";
3
4
  import type { Bounds } from "./bounds";
4
5
  import type { ElementsMap, ExcalidrawElement, NonDeletedExcalidrawElement, PointerType } from "./types";
5
6
  export type TransformHandleDirection = "n" | "s" | "w" | "e" | "nw" | "ne" | "sw" | "se";
@@ -28,8 +29,8 @@ export declare const OMIT_SIDES_FOR_FRAME: {
28
29
  w: boolean;
29
30
  rotation: boolean;
30
31
  };
31
- export declare const canResizeFromSides: (device: Device) => boolean;
32
- export declare const getOmitSidesForDevice: (device: Device) => {};
32
+ export declare const canResizeFromSides: (editorInterface: EditorInterface) => boolean;
33
+ export declare const getOmitSidesForEditorInterface: (editorInterface: EditorInterface) => {};
33
34
  export declare const getTransformHandlesFromCoords: ([x1, y1, x2, y2, cx, cy]: [number, number, number, number, number, number], angle: Radians, zoom: Zoom, pointerType: PointerType, omitSides?: {
34
35
  s?: boolean | undefined;
35
36
  n?: boolean | undefined;
@@ -52,4 +53,4 @@ export declare const getTransformHandles: (element: ExcalidrawElement, zoom: Zoo
52
53
  se?: boolean | undefined;
53
54
  rotation?: boolean | undefined;
54
55
  }) => TransformHandles;
55
- export declare const shouldShowBoundingBox: (elements: readonly NonDeletedExcalidrawElement[], appState: InteractiveCanvasAppState) => boolean;
56
+ export declare const hasBoundingBox: (elements: readonly NonDeletedExcalidrawElement[], appState: InteractiveCanvasAppState, editorInterface: EditorInterface) => boolean;
@@ -1,7 +1,7 @@
1
1
  import type { ElementOrToolType } from "@excalidraw/excalidraw/types";
2
2
  import type { MarkNonNullable } from "@excalidraw/common/utility-types";
3
3
  import type { Bounds } from "./bounds";
4
- import type { ExcalidrawElement, ExcalidrawTextElement, ExcalidrawEmbeddableElement, ExcalidrawLinearElement, ExcalidrawBindableElement, ExcalidrawFreeDrawElement, InitializedExcalidrawImageElement, ExcalidrawImageElement, ExcalidrawTextElementWithContainer, ExcalidrawTextContainer, ExcalidrawFrameElement, RoundnessType, ExcalidrawFrameLikeElement, ExcalidrawElementType, ExcalidrawIframeElement, ExcalidrawIframeLikeElement, ExcalidrawMagicFrameElement, ExcalidrawArrowElement, ExcalidrawElbowArrowElement, ExcalidrawLineElement, PointBinding, FixedPointBinding, ExcalidrawFlowchartNodeElement, ExcalidrawLinearElementSubType } from "./types";
4
+ import type { ExcalidrawElement, ExcalidrawTextElement, ExcalidrawEmbeddableElement, ExcalidrawLinearElement, ExcalidrawBindableElement, ExcalidrawFreeDrawElement, InitializedExcalidrawImageElement, ExcalidrawImageElement, ExcalidrawTextElementWithContainer, ExcalidrawTextContainer, ExcalidrawFrameElement, RoundnessType, ExcalidrawFrameLikeElement, ExcalidrawElementType, ExcalidrawIframeElement, ExcalidrawIframeLikeElement, ExcalidrawMagicFrameElement, ExcalidrawArrowElement, ExcalidrawElbowArrowElement, ExcalidrawLineElement, ExcalidrawFlowchartNodeElement, ExcalidrawLinearElementSubType } from "./types";
5
5
  export declare const isInitializedImageElement: (element: ExcalidrawElement | null) => element is InitializedExcalidrawImageElement;
6
6
  export declare const isImageElement: (element: ExcalidrawElement | null) => element is ExcalidrawImageElement;
7
7
  export declare const isEmbeddableElement: (element: ExcalidrawElement | null | undefined) => element is ExcalidrawEmbeddableElement;
@@ -24,7 +24,7 @@ export declare const isSimpleArrow: (element?: ExcalidrawElement) => element is
24
24
  export declare const isSharpArrow: (element?: ExcalidrawElement) => element is ExcalidrawArrowElement;
25
25
  export declare const isCurvedArrow: (element?: ExcalidrawElement) => element is ExcalidrawArrowElement;
26
26
  export declare const isLinearElementType: (elementType: ElementOrToolType) => boolean;
27
- export declare const isBindingElement: (element?: ExcalidrawElement | null, includeLocked?: boolean) => element is ExcalidrawLinearElement;
27
+ export declare const isBindingElement: (element?: ExcalidrawElement | null, includeLocked?: boolean) => element is ExcalidrawArrowElement;
28
28
  export declare const isBindingElementType: (elementType: ElementOrToolType) => boolean;
29
29
  export declare const isBindableElement: (element: ExcalidrawElement | null | undefined, includeLocked?: boolean) => element is ExcalidrawBindableElement;
30
30
  export declare const isRectanguloidElement: (element?: ExcalidrawElement | null) => element is ExcalidrawBindableElement;
@@ -43,7 +43,6 @@ export declare const getDefaultRoundnessTypeForElement: (element: ExcalidrawElem
43
43
  } | {
44
44
  type: 3;
45
45
  } | null;
46
- export declare const isFixedPointBinding: (binding: PointBinding | FixedPointBinding) => binding is FixedPointBinding;
47
46
  export declare const isBounds: (box: unknown) => box is Bounds;
48
47
  export declare const getLinearElementSubType: (element: ExcalidrawLinearElement) => ExcalidrawLinearElementSubType;
49
48
  /**
@@ -197,14 +197,12 @@ export type ExcalidrawTextElementWithContainer = {
197
197
  containerId: ExcalidrawTextContainer["id"];
198
198
  } & ExcalidrawTextElement;
199
199
  export type FixedPoint = [number, number];
200
- export type PointBinding = {
200
+ export type BindMode = "inside" | "orbit" | "skip";
201
+ export type FixedPointBinding = {
201
202
  elementId: ExcalidrawBindableElement["id"];
202
- focus: number;
203
- gap: number;
204
- };
205
- export type FixedPointBinding = Merge<PointBinding, {
206
203
  fixedPoint: FixedPoint;
207
- }>;
204
+ mode: BindMode;
205
+ };
208
206
  type Index = number;
209
207
  export type PointsPositionUpdates = Map<Index, {
210
208
  point: LocalPoint;
@@ -214,9 +212,8 @@ export type Arrowhead = "arrow" | "bar" | "dot" | "circle" | "circle_outline" |
214
212
  export type ExcalidrawLinearElement = _ExcalidrawElementBase & Readonly<{
215
213
  type: "line" | "arrow";
216
214
  points: readonly LocalPoint[];
217
- lastCommittedPoint: LocalPoint | null;
218
- startBinding: PointBinding | null;
219
- endBinding: PointBinding | null;
215
+ startBinding: FixedPointBinding | null;
216
+ endBinding: FixedPointBinding | null;
220
217
  startArrowhead: Arrowhead | null;
221
218
  endArrowhead: Arrowhead | null;
222
219
  }>;
@@ -235,9 +232,9 @@ export type ExcalidrawArrowElement = ExcalidrawLinearElement & Readonly<{
235
232
  }>;
236
233
  export type ExcalidrawElbowArrowElement = Merge<ExcalidrawArrowElement, {
237
234
  elbowed: true;
235
+ fixedSegments: readonly FixedSegment[] | null;
238
236
  startBinding: FixedPointBinding | null;
239
237
  endBinding: FixedPointBinding | null;
240
- fixedSegments: readonly FixedSegment[] | null;
241
238
  /**
242
239
  * Marks that the 3rd point should be used as the 2nd point of the arrow in
243
240
  * order to temporarily hide the first segment of the arrow without losing
@@ -260,7 +257,6 @@ export type ExcalidrawFreeDrawElement = _ExcalidrawElementBase & Readonly<{
260
257
  points: readonly LocalPoint[];
261
258
  pressures: readonly number[];
262
259
  simulatePressure: boolean;
263
- lastCommittedPoint: LocalPoint | null;
264
260
  }>;
265
261
  export type FileId = string & {
266
262
  _brand: "FileId";
@@ -1,7 +1,7 @@
1
1
  import { type GlobalPoint } from "@excalidraw/math";
2
2
  import type { Curve, LineSegment } from "@excalidraw/math";
3
3
  import type { Zoom } from "@excalidraw/excalidraw/types";
4
- import type { ExcalidrawDiamondElement, ExcalidrawElement, ExcalidrawFreeDrawElement, ExcalidrawLinearElement, ExcalidrawRectanguloidElement } from "./types";
4
+ import type { ElementsMap, ExcalidrawArrowElement, ExcalidrawDiamondElement, ExcalidrawElement, ExcalidrawFreeDrawElement, ExcalidrawLinearElement, ExcalidrawRectanguloidElement } from "./types";
5
5
  /**
6
6
  * Returns the **rotated** components of freedraw, line or arrow elements.
7
7
  *
@@ -29,3 +29,4 @@ export declare function deconstructRectanguloidElement(element: ExcalidrawRectan
29
29
  export declare function deconstructDiamondElement(element: ExcalidrawDiamondElement, offset?: number): [LineSegment<GlobalPoint>[], Curve<GlobalPoint>[]];
30
30
  export declare const isPathALoop: (points: ExcalidrawLinearElement["points"], zoomValue?: Zoom["value"]) => boolean;
31
31
  export declare const getCornerRadius: (x: number, element: ExcalidrawElement) => number;
32
+ export declare const projectFixedPointOntoDiagonal: (arrow: ExcalidrawArrowElement, point: GlobalPoint, element: ExcalidrawElement, startOrEnd: "start" | "end", elementsMap: ElementsMap) => GlobalPoint | null;
@@ -1,6 +1,12 @@
1
1
  import type { AppState } from "@excalidraw/excalidraw/types";
2
+ import type { GlobalPoint } from "@excalidraw/math";
2
3
  import type { Scene } from "./Scene";
3
- import type { ExcalidrawElement } from "./types";
4
+ import type { ExcalidrawArrowElement, ExcalidrawElement, NonDeletedExcalidrawElement, NonDeletedSceneElementsMap, Ordered, OrderedExcalidrawElement } from "./types";
5
+ /**
6
+ * Moves the arrow element above any bindable elements it intersects with or
7
+ * hovers over.
8
+ */
9
+ export declare const moveArrowAboveBindable: (point: GlobalPoint, arrow: ExcalidrawArrowElement, elements: readonly Ordered<NonDeletedExcalidrawElement>[], elementsMap: NonDeletedSceneElementsMap, scene: Scene) => readonly OrderedExcalidrawElement[];
4
10
  export declare const moveOneLeft: (allElements: readonly ExcalidrawElement[], appState: AppState, scene: Scene) => readonly ExcalidrawElement[];
5
11
  export declare const moveOneRight: (allElements: readonly ExcalidrawElement[], appState: AppState, scene: Scene) => readonly ExcalidrawElement[];
6
12
  export declare const moveAllLeft: (allElements: readonly ExcalidrawElement[], appState: AppState) => readonly ExcalidrawElement[] | ExcalidrawElement[];
@@ -4,7 +4,7 @@ export declare const actionAddToLibrary: {
4
4
  trackEvent: {
5
5
  category: "element";
6
6
  };
7
- perform: (elements: readonly import("@excalidraw/element/types").OrderedExcalidrawElement[], appState: Readonly<import("../types").AppState>, _: any, app: import("../types").AppClassProperties) => Promise<{
7
+ perform: (elements: readonly import("@excalidraw/element/types").OrderedExcalidrawElement[], appState: Readonly<import("../types").AppState>, _: unknown, app: import("../types").AppClassProperties) => Promise<{
8
8
  captureUpdate: "EVENTUALLY";
9
9
  appState: {
10
10
  toast: {
@@ -28,7 +28,7 @@ export declare const actionAddToLibrary: {
28
28
  selectionElement: import("@excalidraw/element/types").NonDeletedExcalidrawElement | null;
29
29
  isBindingEnabled: boolean;
30
30
  startBoundElement: import("@excalidraw/element/types").NonDeleted<import("@excalidraw/element/types").ExcalidrawBindableElement> | null;
31
- suggestedBindings: import("@excalidraw/element").SuggestedBinding[];
31
+ suggestedBinding: import("@excalidraw/element/types").NonDeleted<import("@excalidraw/element/types").ExcalidrawBindableElement> | null;
32
32
  frameToHighlight: import("@excalidraw/element/types").NonDeleted<import("@excalidraw/element/types").ExcalidrawFrameLikeElement> | null;
33
33
  frameRendering: {
34
34
  enabled: boolean;
@@ -39,12 +39,15 @@ export declare const actionAddToLibrary: {
39
39
  editingFrame: string | null;
40
40
  elementsToHighlight: import("@excalidraw/element/types").NonDeleted<import("@excalidraw/element/types").ExcalidrawElement>[] | null;
41
41
  editingTextElement: import("@excalidraw/element/types").NonDeletedExcalidrawElement | null;
42
- editingLinearElement: import("@excalidraw/element").LinearElementEditor | null;
43
42
  activeTool: {
44
43
  lastActiveTool: import("../types").ActiveTool | null;
45
44
  locked: boolean;
46
45
  fromSelection: boolean;
47
46
  } & import("../types").ActiveTool;
47
+ preferredSelectionTool: {
48
+ type: "selection" | "lasso";
49
+ initialized: boolean;
50
+ };
48
51
  penMode: boolean;
49
52
  penDetected: boolean;
50
53
  exportBackground: boolean;
@@ -77,8 +80,8 @@ export declare const actionAddToLibrary: {
77
80
  zoom: Readonly<{
78
81
  value: import("../types").NormalizedZoomValue;
79
82
  }>;
80
- openMenu: "canvas" | "shape" | null;
81
- openPopup: "fontFamily" | "canvasBackground" | "elementBackground" | "elementStroke" | null;
83
+ openMenu: "canvas" | null;
84
+ openPopup: "fontFamily" | "canvasBackground" | "elementBackground" | "elementStroke" | "compactTextProperties" | "compactStrokeStyles" | "compactOtherProperties" | "compactArrowProperties" | null;
82
85
  openSidebar: {
83
86
  name: string;
84
87
  tab?: string | undefined;
@@ -90,6 +93,8 @@ export declare const actionAddToLibrary: {
90
93
  tab: "mermaid" | "text-to-diagram";
91
94
  } | {
92
95
  name: "commandPalette";
96
+ } | {
97
+ name: "settings";
93
98
  } | {
94
99
  name: "elementLinkSelector";
95
100
  sourceElementId: string;
@@ -154,7 +159,7 @@ export declare const actionAddToLibrary: {
154
159
  shown: true;
155
160
  data: import("../charts").Spreadsheet;
156
161
  };
157
- showHyperlinkPopup: false | "editor" | "info";
162
+ showHyperlinkPopup: false | "info" | "editor";
158
163
  selectedLinearElement: import("@excalidraw/element").LinearElementEditor | null;
159
164
  snapLines: readonly import("../snapping").SnapLine[];
160
165
  originSnapOffset: {
@@ -174,6 +179,7 @@ export declare const actionAddToLibrary: {
174
179
  lockedMultiSelections: {
175
180
  [groupId: string]: true;
176
181
  };
182
+ bindMode: import("@excalidraw/element/types").BindMode;
177
183
  };
178
184
  } | {
179
185
  captureUpdate: "EVENTUALLY";
@@ -196,7 +202,7 @@ export declare const actionAddToLibrary: {
196
202
  selectionElement: import("@excalidraw/element/types").NonDeletedExcalidrawElement | null;
197
203
  isBindingEnabled: boolean;
198
204
  startBoundElement: import("@excalidraw/element/types").NonDeleted<import("@excalidraw/element/types").ExcalidrawBindableElement> | null;
199
- suggestedBindings: import("@excalidraw/element").SuggestedBinding[];
205
+ suggestedBinding: import("@excalidraw/element/types").NonDeleted<import("@excalidraw/element/types").ExcalidrawBindableElement> | null;
200
206
  frameToHighlight: import("@excalidraw/element/types").NonDeleted<import("@excalidraw/element/types").ExcalidrawFrameLikeElement> | null;
201
207
  frameRendering: {
202
208
  enabled: boolean;
@@ -207,12 +213,15 @@ export declare const actionAddToLibrary: {
207
213
  editingFrame: string | null;
208
214
  elementsToHighlight: import("@excalidraw/element/types").NonDeleted<import("@excalidraw/element/types").ExcalidrawElement>[] | null;
209
215
  editingTextElement: import("@excalidraw/element/types").NonDeletedExcalidrawElement | null;
210
- editingLinearElement: import("@excalidraw/element").LinearElementEditor | null;
211
216
  activeTool: {
212
217
  lastActiveTool: import("../types").ActiveTool | null;
213
218
  locked: boolean;
214
219
  fromSelection: boolean;
215
220
  } & import("../types").ActiveTool;
221
+ preferredSelectionTool: {
222
+ type: "selection" | "lasso";
223
+ initialized: boolean;
224
+ };
216
225
  penMode: boolean;
217
226
  penDetected: boolean;
218
227
  exportBackground: boolean;
@@ -245,8 +254,8 @@ export declare const actionAddToLibrary: {
245
254
  zoom: Readonly<{
246
255
  value: import("../types").NormalizedZoomValue;
247
256
  }>;
248
- openMenu: "canvas" | "shape" | null;
249
- openPopup: "fontFamily" | "canvasBackground" | "elementBackground" | "elementStroke" | null;
257
+ openMenu: "canvas" | null;
258
+ openPopup: "fontFamily" | "canvasBackground" | "elementBackground" | "elementStroke" | "compactTextProperties" | "compactStrokeStyles" | "compactOtherProperties" | "compactArrowProperties" | null;
250
259
  openSidebar: {
251
260
  name: string;
252
261
  tab?: string | undefined;
@@ -258,6 +267,8 @@ export declare const actionAddToLibrary: {
258
267
  tab: "mermaid" | "text-to-diagram";
259
268
  } | {
260
269
  name: "commandPalette";
270
+ } | {
271
+ name: "settings";
261
272
  } | {
262
273
  name: "elementLinkSelector";
263
274
  sourceElementId: string;
@@ -327,7 +338,7 @@ export declare const actionAddToLibrary: {
327
338
  shown: true;
328
339
  data: import("../charts").Spreadsheet;
329
340
  };
330
- showHyperlinkPopup: false | "editor" | "info";
341
+ showHyperlinkPopup: false | "info" | "editor";
331
342
  selectedLinearElement: import("@excalidraw/element").LinearElementEditor | null;
332
343
  snapLines: readonly import("../snapping").SnapLine[];
333
344
  originSnapOffset: {
@@ -347,6 +358,7 @@ export declare const actionAddToLibrary: {
347
358
  lockedMultiSelections: {
348
359
  [groupId: string]: true;
349
360
  };
361
+ bindMode: import("@excalidraw/element/types").BindMode;
350
362
  };
351
363
  }> | {
352
364
  captureUpdate: "EVENTUALLY";
@@ -369,7 +381,7 @@ export declare const actionAddToLibrary: {
369
381
  selectionElement: import("@excalidraw/element/types").NonDeletedExcalidrawElement | null;
370
382
  isBindingEnabled: boolean;
371
383
  startBoundElement: import("@excalidraw/element/types").NonDeleted<import("@excalidraw/element/types").ExcalidrawBindableElement> | null;
372
- suggestedBindings: import("@excalidraw/element").SuggestedBinding[];
384
+ suggestedBinding: import("@excalidraw/element/types").NonDeleted<import("@excalidraw/element/types").ExcalidrawBindableElement> | null;
373
385
  frameToHighlight: import("@excalidraw/element/types").NonDeleted<import("@excalidraw/element/types").ExcalidrawFrameLikeElement> | null;
374
386
  frameRendering: {
375
387
  enabled: boolean;
@@ -380,12 +392,15 @@ export declare const actionAddToLibrary: {
380
392
  editingFrame: string | null;
381
393
  elementsToHighlight: import("@excalidraw/element/types").NonDeleted<import("@excalidraw/element/types").ExcalidrawElement>[] | null;
382
394
  editingTextElement: import("@excalidraw/element/types").NonDeletedExcalidrawElement | null;
383
- editingLinearElement: import("@excalidraw/element").LinearElementEditor | null;
384
395
  activeTool: {
385
396
  lastActiveTool: import("../types").ActiveTool | null;
386
397
  locked: boolean;
387
398
  fromSelection: boolean;
388
399
  } & import("../types").ActiveTool;
400
+ preferredSelectionTool: {
401
+ type: "selection" | "lasso";
402
+ initialized: boolean;
403
+ };
389
404
  penMode: boolean;
390
405
  penDetected: boolean;
391
406
  exportBackground: boolean;
@@ -418,8 +433,8 @@ export declare const actionAddToLibrary: {
418
433
  zoom: Readonly<{
419
434
  value: import("../types").NormalizedZoomValue;
420
435
  }>;
421
- openMenu: "canvas" | "shape" | null;
422
- openPopup: "fontFamily" | "canvasBackground" | "elementBackground" | "elementStroke" | null;
436
+ openMenu: "canvas" | null;
437
+ openPopup: "fontFamily" | "canvasBackground" | "elementBackground" | "elementStroke" | "compactTextProperties" | "compactStrokeStyles" | "compactOtherProperties" | "compactArrowProperties" | null;
423
438
  openSidebar: {
424
439
  name: string;
425
440
  tab?: string | undefined;
@@ -431,6 +446,8 @@ export declare const actionAddToLibrary: {
431
446
  tab: "mermaid" | "text-to-diagram";
432
447
  } | {
433
448
  name: "commandPalette";
449
+ } | {
450
+ name: "settings";
434
451
  } | {
435
452
  name: "elementLinkSelector";
436
453
  sourceElementId: string;
@@ -500,7 +517,7 @@ export declare const actionAddToLibrary: {
500
517
  shown: true;
501
518
  data: import("../charts").Spreadsheet;
502
519
  };
503
- showHyperlinkPopup: false | "editor" | "info";
520
+ showHyperlinkPopup: false | "info" | "editor";
504
521
  selectedLinearElement: import("@excalidraw/element").LinearElementEditor | null;
505
522
  snapLines: readonly import("../snapping").SnapLine[];
506
523
  originSnapOffset: {
@@ -520,6 +537,7 @@ export declare const actionAddToLibrary: {
520
537
  lockedMultiSelections: {
521
538
  [groupId: string]: true;
522
539
  };
540
+ bindMode: import("@excalidraw/element/types").BindMode;
523
541
  };
524
542
  };
525
543
  label: string;
@@ -10,7 +10,7 @@ export declare const actionAlignTop: {
10
10
  category: "element";
11
11
  };
12
12
  predicate: (elements: readonly ExcalidrawElement[], appState: AppState, appProps: import("../types").ExcalidrawProps, app: AppClassProperties) => boolean;
13
- perform: (elements: readonly import("@excalidraw/element/types").OrderedExcalidrawElement[], appState: Readonly<AppState>, _: any, app: AppClassProperties) => {
13
+ perform: (elements: readonly import("@excalidraw/element/types").OrderedExcalidrawElement[], appState: Readonly<AppState>, _: unknown, app: AppClassProperties) => {
14
14
  appState: Readonly<AppState>;
15
15
  elements: ExcalidrawElement[];
16
16
  captureUpdate: "IMMEDIATELY";
@@ -28,7 +28,7 @@ export declare const actionAlignBottom: {
28
28
  category: "element";
29
29
  };
30
30
  predicate: (elements: readonly ExcalidrawElement[], appState: AppState, appProps: import("../types").ExcalidrawProps, app: AppClassProperties) => boolean;
31
- perform: (elements: readonly import("@excalidraw/element/types").OrderedExcalidrawElement[], appState: Readonly<AppState>, _: any, app: AppClassProperties) => {
31
+ perform: (elements: readonly import("@excalidraw/element/types").OrderedExcalidrawElement[], appState: Readonly<AppState>, _: unknown, app: AppClassProperties) => {
32
32
  appState: Readonly<AppState>;
33
33
  elements: ExcalidrawElement[];
34
34
  captureUpdate: "IMMEDIATELY";
@@ -46,7 +46,7 @@ export declare const actionAlignLeft: {
46
46
  category: "element";
47
47
  };
48
48
  predicate: (elements: readonly ExcalidrawElement[], appState: AppState, appProps: import("../types").ExcalidrawProps, app: AppClassProperties) => boolean;
49
- perform: (elements: readonly import("@excalidraw/element/types").OrderedExcalidrawElement[], appState: Readonly<AppState>, _: any, app: AppClassProperties) => {
49
+ perform: (elements: readonly import("@excalidraw/element/types").OrderedExcalidrawElement[], appState: Readonly<AppState>, _: unknown, app: AppClassProperties) => {
50
50
  appState: Readonly<AppState>;
51
51
  elements: ExcalidrawElement[];
52
52
  captureUpdate: "IMMEDIATELY";
@@ -64,7 +64,7 @@ export declare const actionAlignRight: {
64
64
  category: "element";
65
65
  };
66
66
  predicate: (elements: readonly ExcalidrawElement[], appState: AppState, appProps: import("../types").ExcalidrawProps, app: AppClassProperties) => boolean;
67
- perform: (elements: readonly import("@excalidraw/element/types").OrderedExcalidrawElement[], appState: Readonly<AppState>, _: any, app: AppClassProperties) => {
67
+ perform: (elements: readonly import("@excalidraw/element/types").OrderedExcalidrawElement[], appState: Readonly<AppState>, _: unknown, app: AppClassProperties) => {
68
68
  appState: Readonly<AppState>;
69
69
  elements: ExcalidrawElement[];
70
70
  captureUpdate: "IMMEDIATELY";
@@ -82,7 +82,7 @@ export declare const actionAlignVerticallyCentered: {
82
82
  category: "element";
83
83
  };
84
84
  predicate: (elements: readonly ExcalidrawElement[], appState: AppState, appProps: import("../types").ExcalidrawProps, app: AppClassProperties) => boolean;
85
- perform: (elements: readonly import("@excalidraw/element/types").OrderedExcalidrawElement[], appState: Readonly<AppState>, _: any, app: AppClassProperties) => {
85
+ perform: (elements: readonly import("@excalidraw/element/types").OrderedExcalidrawElement[], appState: Readonly<AppState>, _: unknown, app: AppClassProperties) => {
86
86
  appState: Readonly<AppState>;
87
87
  elements: ExcalidrawElement[];
88
88
  captureUpdate: "IMMEDIATELY";
@@ -99,7 +99,7 @@ export declare const actionAlignHorizontallyCentered: {
99
99
  category: "element";
100
100
  };
101
101
  predicate: (elements: readonly ExcalidrawElement[], appState: AppState, appProps: import("../types").ExcalidrawProps, app: AppClassProperties) => boolean;
102
- perform: (elements: readonly import("@excalidraw/element/types").OrderedExcalidrawElement[], appState: Readonly<AppState>, _: any, app: AppClassProperties) => {
102
+ perform: (elements: readonly import("@excalidraw/element/types").OrderedExcalidrawElement[], appState: Readonly<AppState>, _: unknown, app: AppClassProperties) => {
103
103
  appState: Readonly<AppState>;
104
104
  elements: ExcalidrawElement[];
105
105
  captureUpdate: "IMMEDIATELY";