@excalidraw/excalidraw 0.18.0-b9d27d3 → 0.18.0-c158187

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (518) hide show
  1. package/dist/dev/{chunk-WWDIUJ2Q.js → chunk-5A4X24JB.js} +277 -456
  2. package/dist/dev/chunk-5A4X24JB.js.map +7 -0
  3. package/dist/dev/{chunk-FB2NA5UG.js → chunk-6JJSWC4C.js} +1 -1
  4. package/dist/dev/{chunk-FB2NA5UG.js.map → chunk-6JJSWC4C.js.map} +2 -2
  5. package/dist/dev/chunk-DJHLEOOZ.js +69 -0
  6. package/dist/dev/chunk-DJHLEOOZ.js.map +7 -0
  7. package/dist/dev/{chunk-QF5FRM6O.js → chunk-OCFTI2BU.js} +49 -26
  8. package/dist/dev/chunk-OCFTI2BU.js.map +7 -0
  9. package/dist/dev/data/{image-VTYIFRQE.js → image-Q6JHR7OE.js} +2 -2
  10. package/dist/dev/index.css +1042 -602
  11. package/dist/dev/index.css.map +3 -3
  12. package/dist/dev/index.js +10053 -7628
  13. package/dist/dev/index.js.map +4 -4
  14. package/dist/dev/locales/{ar-SA-XORAP2EK.js → ar-SA-JK5MQ7TT.js} +300 -142
  15. package/dist/dev/locales/ar-SA-JK5MQ7TT.js.map +7 -0
  16. package/dist/dev/locales/{az-AZ-NAUU3Z4Y.js → az-AZ-2PAD62G4.js} +241 -83
  17. package/dist/dev/locales/az-AZ-2PAD62G4.js.map +7 -0
  18. package/dist/dev/locales/{bg-BG-AAABLFCY.js → bg-BG-HUKVYCRK.js} +229 -71
  19. package/dist/dev/locales/bg-BG-HUKVYCRK.js.map +7 -0
  20. package/dist/dev/locales/{bn-BD-PM4AC5WG.js → bn-BD-V2CQI46P.js} +209 -51
  21. package/dist/dev/locales/bn-BD-V2CQI46P.js.map +7 -0
  22. package/dist/dev/locales/bn-IN-MBEO4C3J.js +744 -0
  23. package/dist/dev/locales/bn-IN-MBEO4C3J.js.map +7 -0
  24. package/dist/dev/locales/{ca-ES-YNNMFRQX.js → ca-ES-KWEKW4C3.js} +275 -117
  25. package/dist/dev/locales/ca-ES-KWEKW4C3.js.map +7 -0
  26. package/dist/dev/locales/{cs-CZ-DGZA5IKG.js → cs-CZ-W5AHZB5H.js} +229 -71
  27. package/dist/dev/locales/cs-CZ-W5AHZB5H.js.map +7 -0
  28. package/dist/dev/locales/{da-DK-N76F4QAJ.js → da-DK-ITTM6YM4.js} +298 -140
  29. package/dist/dev/locales/da-DK-ITTM6YM4.js.map +7 -0
  30. package/dist/dev/locales/de-CH-OAWPDQFJ.js +744 -0
  31. package/dist/dev/locales/de-CH-OAWPDQFJ.js.map +7 -0
  32. package/dist/dev/locales/{de-DE-DMRXZ2SZ.js → de-DE-ZRDYEPMS.js} +199 -41
  33. package/dist/dev/locales/de-DE-ZRDYEPMS.js.map +7 -0
  34. package/dist/dev/locales/{el-GR-HIKPLEXI.js → el-GR-QXASZLPE.js} +274 -116
  35. package/dist/dev/locales/el-GR-QXASZLPE.js.map +7 -0
  36. package/dist/dev/locales/{en-SMAPCEOQ.js → en-MLZIHOCR.js} +4 -2
  37. package/dist/dev/locales/{es-ES-AQYVXC32.js → es-ES-VLQBB7FJ.js} +212 -54
  38. package/dist/dev/locales/es-ES-VLQBB7FJ.js.map +7 -0
  39. package/dist/dev/locales/{eu-ES-3TOEU5DE.js → eu-ES-TF2DGTZU.js} +210 -52
  40. package/dist/dev/locales/eu-ES-TF2DGTZU.js.map +7 -0
  41. package/dist/dev/locales/{fa-IR-527GAKUP.js → fa-IR-ITKFQ7QV.js} +286 -128
  42. package/dist/dev/locales/fa-IR-ITKFQ7QV.js.map +7 -0
  43. package/dist/dev/locales/{fi-FI-M3WLVDFP.js → fi-FI-UWZRVXFI.js} +240 -82
  44. package/dist/dev/locales/fi-FI-UWZRVXFI.js.map +7 -0
  45. package/dist/dev/locales/{fr-FR-YE4VDJFI.js → fr-FR-A72LKGCO.js} +203 -45
  46. package/dist/dev/locales/fr-FR-A72LKGCO.js.map +7 -0
  47. package/dist/dev/locales/{gl-ES-KMXUYGUN.js → gl-ES-2QCVIBFP.js} +212 -54
  48. package/dist/dev/locales/gl-ES-2QCVIBFP.js.map +7 -0
  49. package/dist/dev/locales/he-IL-WJNUHU26.js +744 -0
  50. package/dist/dev/locales/he-IL-WJNUHU26.js.map +7 -0
  51. package/dist/dev/locales/hi-IN-XGMO235V.js +744 -0
  52. package/dist/dev/locales/hi-IN-XGMO235V.js.map +7 -0
  53. package/dist/dev/locales/{hu-HU-VIYZI3X4.js → hu-HU-37FDQFIS.js} +238 -80
  54. package/dist/dev/locales/hu-HU-37FDQFIS.js.map +7 -0
  55. package/dist/dev/locales/{id-ID-22TWZNLA.js → id-ID-EJIDCO4E.js} +245 -87
  56. package/dist/dev/locales/id-ID-EJIDCO4E.js.map +7 -0
  57. package/dist/dev/locales/{it-IT-MDEQ2SG3.js → it-IT-X34PIOJ2.js} +202 -44
  58. package/dist/dev/locales/it-IT-X34PIOJ2.js.map +7 -0
  59. package/dist/dev/locales/{ja-JP-K2DI4W6B.js → ja-JP-37FC23PR.js} +247 -89
  60. package/dist/dev/locales/ja-JP-37FC23PR.js.map +7 -0
  61. package/dist/dev/locales/{kaa-6BPSNM3R.js → kaa-7ZYDFVKA.js} +202 -44
  62. package/dist/dev/locales/kaa-7ZYDFVKA.js.map +7 -0
  63. package/dist/dev/locales/{kab-KAB-2S7ZURK7.js → kab-KAB-MILWXBA6.js} +210 -52
  64. package/dist/dev/locales/kab-KAB-MILWXBA6.js.map +7 -0
  65. package/dist/dev/locales/{kk-KZ-UJPYGRQQ.js → kk-KZ-7BWTPIAV.js} +175 -17
  66. package/dist/dev/locales/kk-KZ-7BWTPIAV.js.map +7 -0
  67. package/dist/dev/locales/{km-KH-M5T5JKUE.js → km-KH-BV4P2KSZ.js} +198 -40
  68. package/dist/dev/locales/km-KH-BV4P2KSZ.js.map +7 -0
  69. package/dist/dev/locales/{ko-KR-RQX37SNF.js → ko-KR-TSXE5P7B.js} +218 -60
  70. package/dist/dev/locales/ko-KR-TSXE5P7B.js.map +7 -0
  71. package/dist/dev/locales/{ku-TR-5XJDIERL.js → ku-TR-ASSXNN3U.js} +198 -40
  72. package/dist/dev/locales/ku-TR-ASSXNN3U.js.map +7 -0
  73. package/dist/dev/locales/{lt-LT-MGUBX6CA.js → lt-LT-G7RZYQQU.js} +179 -21
  74. package/dist/dev/locales/lt-LT-G7RZYQQU.js.map +7 -0
  75. package/dist/dev/locales/{lv-LV-MD7N5VHD.js → lv-LV-DXNPBJZU.js} +196 -38
  76. package/dist/dev/locales/lv-LV-DXNPBJZU.js.map +7 -0
  77. package/dist/dev/locales/{mr-IN-4XWMNGQC.js → mr-IN-7F2ZCTCF.js} +204 -46
  78. package/dist/dev/locales/mr-IN-7F2ZCTCF.js.map +7 -0
  79. package/dist/dev/locales/{my-MM-O4Z74GN5.js → my-MM-NBI3KQGW.js} +181 -23
  80. package/dist/dev/locales/my-MM-NBI3KQGW.js.map +7 -0
  81. package/dist/dev/locales/{nb-NO-BMB73KRH.js → nb-NO-4DCTQT6L.js} +220 -62
  82. package/dist/dev/locales/nb-NO-4DCTQT6L.js.map +7 -0
  83. package/dist/dev/locales/{nl-NL-F2257BLQ.js → nl-NL-XGZJ7V2V.js} +297 -139
  84. package/dist/dev/locales/nl-NL-XGZJ7V2V.js.map +7 -0
  85. package/dist/dev/locales/{nn-NO-NCORG7TS.js → nn-NO-FR534JV5.js} +201 -43
  86. package/dist/dev/locales/nn-NO-FR534JV5.js.map +7 -0
  87. package/dist/dev/locales/{oc-FR-ATFBDMF6.js → oc-FR-YQCIKZIK.js} +220 -62
  88. package/dist/dev/locales/oc-FR-YQCIKZIK.js.map +7 -0
  89. package/dist/dev/locales/{pa-IN-D2I375G4.js → pa-IN-UM43JGD2.js} +190 -32
  90. package/dist/dev/locales/pa-IN-UM43JGD2.js.map +7 -0
  91. package/dist/dev/locales/{percentages-YKFLWNK2.js → percentages-OGWD7R2K.js} +2 -2
  92. package/dist/dev/locales/{pl-PL-YJHOWAAW.js → pl-PL-2UGKA6HK.js} +214 -56
  93. package/dist/dev/locales/pl-PL-2UGKA6HK.js.map +7 -0
  94. package/dist/dev/locales/{pt-BR-APOPYZJ7.js → pt-BR-H23QFYE3.js} +237 -79
  95. package/dist/dev/locales/pt-BR-H23QFYE3.js.map +7 -0
  96. package/dist/dev/locales/pt-PT-RHKJH5I5.js +744 -0
  97. package/dist/dev/locales/pt-PT-RHKJH5I5.js.map +7 -0
  98. package/dist/dev/locales/{ro-RO-L575VRQA.js → ro-RO-IIFONL3T.js} +203 -45
  99. package/dist/dev/locales/ro-RO-IIFONL3T.js.map +7 -0
  100. package/dist/dev/locales/{ru-RU-BLG6HZG5.js → ru-RU-QEP6D7GK.js} +253 -95
  101. package/dist/dev/locales/ru-RU-QEP6D7GK.js.map +7 -0
  102. package/dist/dev/locales/si-LK-LZYJQLHF.js +744 -0
  103. package/dist/dev/locales/si-LK-LZYJQLHF.js.map +7 -0
  104. package/dist/dev/locales/{sk-SK-DY6IPO5U.js → sk-SK-RWC6UWGY.js} +200 -42
  105. package/dist/dev/locales/sk-SK-RWC6UWGY.js.map +7 -0
  106. package/dist/dev/locales/{sl-SI-5DZSRA47.js → sl-SI-QJT2CAUO.js} +197 -39
  107. package/dist/dev/locales/sl-SI-QJT2CAUO.js.map +7 -0
  108. package/dist/dev/locales/{sv-SE-V32YHALQ.js → sv-SE-3MAT3NDX.js} +202 -44
  109. package/dist/dev/locales/sv-SE-3MAT3NDX.js.map +7 -0
  110. package/dist/dev/locales/{ta-IN-5JRAGQAO.js → ta-IN-J7XOYF2T.js} +257 -99
  111. package/dist/dev/locales/ta-IN-J7XOYF2T.js.map +7 -0
  112. package/dist/dev/locales/{th-TH-55ACRHDJ.js → th-TH-2OI52EOQ.js} +289 -131
  113. package/dist/dev/locales/th-TH-2OI52EOQ.js.map +7 -0
  114. package/dist/dev/locales/{tr-TR-7QYBXDBO.js → tr-TR-G7TAUHUI.js} +257 -99
  115. package/dist/dev/locales/tr-TR-G7TAUHUI.js.map +7 -0
  116. package/dist/dev/locales/{uk-UA-TJS2TMRH.js → uk-UA-IVSVBJIG.js} +229 -71
  117. package/dist/dev/locales/uk-UA-IVSVBJIG.js.map +7 -0
  118. package/dist/dev/locales/{si-LK-KT7GGO6D.js → uz-UZ-KCVDUVDE.js} +212 -54
  119. package/dist/dev/locales/uz-UZ-KCVDUVDE.js.map +7 -0
  120. package/dist/dev/locales/vi-VN-KBZAVWP5.js +744 -0
  121. package/dist/dev/locales/vi-VN-KBZAVWP5.js.map +7 -0
  122. package/dist/dev/locales/{zh-CN-4MXUOFTH.js → zh-CN-IS26RG2D.js} +199 -41
  123. package/dist/dev/locales/zh-CN-IS26RG2D.js.map +7 -0
  124. package/dist/dev/locales/{zh-HK-RBTGIU3U.js → zh-HK-KBWQ6SJC.js} +175 -17
  125. package/dist/dev/locales/zh-HK-KBWQ6SJC.js.map +7 -0
  126. package/dist/dev/locales/{zh-TW-U5VF4CCU.js → zh-TW-JKJWJQ4J.js} +204 -46
  127. package/dist/dev/locales/zh-TW-JKJWJQ4J.js.map +7 -0
  128. package/dist/dev/subset-shared.chunk.js +1 -1
  129. package/dist/dev/subset-worker.chunk.js +1 -1
  130. package/dist/prod/chunk-AJI3LATG.js +1 -0
  131. package/dist/prod/chunk-QNG5NH6R.js +12 -0
  132. package/dist/prod/chunk-TIFXQFVB.js +4 -0
  133. package/dist/prod/{chunk-LS7FJGPW.js → chunk-Z5NKEFVG.js} +8 -8
  134. package/dist/prod/data/{image-YQ6UXXDA.js → image-OPZV5J37.js} +1 -1
  135. package/dist/prod/index.css +1 -1
  136. package/dist/prod/index.js +26 -26
  137. package/dist/prod/locales/ar-SA-IYHKZRSE.js +8 -0
  138. package/dist/prod/locales/az-AZ-WL5GYRHK.js +1 -0
  139. package/dist/prod/locales/bg-BG-FXZYTRPD.js +5 -0
  140. package/dist/prod/locales/bn-BD-KO6YL5G2.js +3 -0
  141. package/dist/prod/locales/bn-IN-PC6JHKYB.js +3 -0
  142. package/dist/prod/locales/ca-ES-AREX5NEO.js +8 -0
  143. package/dist/prod/locales/cs-CZ-HXAZMFYH.js +7 -0
  144. package/dist/prod/locales/da-DK-5X7ZLFU3.js +2 -0
  145. package/dist/prod/locales/de-CH-76ZNVSOF.js +7 -0
  146. package/dist/prod/locales/de-DE-G3JVZ4MQ.js +7 -0
  147. package/dist/prod/locales/el-GR-4AZTZGY6.js +7 -0
  148. package/dist/prod/locales/en-BARVNJLJ.js +1 -0
  149. package/dist/prod/locales/es-ES-ART7BI3G.js +7 -0
  150. package/dist/prod/locales/eu-ES-BIF4XBMT.js +7 -0
  151. package/dist/prod/locales/fa-IR-D4HHKAAI.js +9 -0
  152. package/dist/prod/locales/fi-FI-O35ZY7UI.js +6 -0
  153. package/dist/prod/locales/fr-FR-XEFNCM4I.js +12 -0
  154. package/dist/prod/locales/gl-ES-U4NYM3X5.js +6 -0
  155. package/dist/prod/locales/he-IL-656ABAVQ.js +8 -0
  156. package/dist/prod/locales/hi-IN-Z55GAFFR.js +3 -0
  157. package/dist/prod/locales/hu-HU-UJ62DVIW.js +3 -0
  158. package/dist/prod/locales/id-ID-FLZFU3OO.js +8 -0
  159. package/dist/prod/locales/it-IT-GIGIGIBJ.js +12 -0
  160. package/dist/prod/locales/ja-JP-43VXGDWI.js +7 -0
  161. package/dist/prod/locales/kaa-L3IMSDYL.js +1 -0
  162. package/dist/prod/locales/kab-KAB-XKPWJLNL.js +4 -0
  163. package/dist/prod/locales/kk-KZ-SXPDDY2H.js +1 -0
  164. package/dist/prod/locales/km-KH-DOS4CPGC.js +7 -0
  165. package/dist/prod/locales/ko-KR-BGC6VCY4.js +5 -0
  166. package/dist/prod/locales/ku-TR-J7IUITIA.js +6 -0
  167. package/dist/prod/locales/lt-LT-AC3LV5KG.js +3 -0
  168. package/dist/prod/locales/lv-LV-I6AY7QG2.js +4 -0
  169. package/dist/prod/locales/mr-IN-5SP4HV5B.js +9 -0
  170. package/dist/prod/locales/my-MM-S7ECRBYZ.js +1 -0
  171. package/dist/prod/locales/nb-NO-6PNHTF4R.js +8 -0
  172. package/dist/prod/locales/nl-NL-R4C4SUIG.js +13 -0
  173. package/dist/prod/locales/nn-NO-3TFXTM7Y.js +4 -0
  174. package/dist/prod/locales/oc-FR-IK6GIE7H.js +4 -0
  175. package/dist/prod/locales/pa-IN-YAKHYJET.js +4 -0
  176. package/dist/prod/locales/percentages-OL6W367U.js +1 -0
  177. package/dist/prod/locales/pl-PL-BIY22ZWU.js +12 -0
  178. package/dist/prod/locales/pt-BR-Q23NUPD6.js +6 -0
  179. package/dist/prod/locales/pt-PT-LOPEJLPJ.js +8 -0
  180. package/dist/prod/locales/ro-RO-W3D2ZATV.js +12 -0
  181. package/dist/prod/locales/ru-RU-DCTW7QSH.js +10 -0
  182. package/dist/prod/locales/si-LK-FYRRHO3C.js +1 -0
  183. package/dist/prod/locales/sk-SK-MC7UOHQO.js +7 -0
  184. package/dist/prod/locales/sl-SI-L6B6HFY5.js +6 -0
  185. package/dist/prod/locales/sv-SE-KMY6L2BA.js +8 -0
  186. package/dist/prod/locales/ta-IN-ZQCYE2JK.js +6 -0
  187. package/dist/prod/locales/th-TH-WS7ECBAV.js +1 -0
  188. package/dist/prod/locales/tr-TR-S5FI7JRW.js +4 -0
  189. package/dist/prod/locales/uk-UA-4EZUWUSQ.js +6 -0
  190. package/dist/prod/locales/uz-UZ-OKHL6AFA.js +1 -0
  191. package/dist/prod/locales/vi-VN-K34TWHF7.js +7 -0
  192. package/dist/prod/locales/zh-CN-JE4UZWNO.js +11 -0
  193. package/dist/prod/locales/zh-HK-RM35YDXX.js +1 -0
  194. package/dist/prod/locales/zh-TW-ONGLV6Y5.js +9 -0
  195. package/dist/prod/subset-shared.chunk.js +1 -1
  196. package/dist/prod/subset-worker.chunk.js +1 -1
  197. package/dist/types/common/src/bounds.d.ts +10 -0
  198. package/dist/types/common/src/colors.d.ts +5 -2
  199. package/dist/types/common/src/constants.d.ts +22 -24
  200. package/dist/types/common/src/editorInterface.d.ts +34 -0
  201. package/dist/types/common/src/font-metadata.d.ts +1 -3
  202. package/dist/types/common/src/index.d.ts +3 -0
  203. package/dist/types/common/src/keys.d.ts +1 -1
  204. package/dist/types/common/src/utility-types.d.ts +0 -1
  205. package/dist/types/common/src/utils.d.ts +49 -33
  206. package/dist/types/common/src/visualdebug.d.ts +41 -0
  207. package/dist/types/element/src/Scene.d.ts +3 -3
  208. package/dist/types/element/src/binding.d.ts +58 -44
  209. package/dist/types/element/src/bounds.d.ts +2 -10
  210. package/dist/types/element/src/collision.d.ts +6 -2
  211. package/dist/types/element/src/comparisons.d.ts +7 -7
  212. package/dist/types/element/src/dragElements.d.ts +3 -3
  213. package/dist/types/element/src/duplicate.d.ts +3 -3
  214. package/dist/types/element/src/fractionalIndex.d.ts +2 -2
  215. package/dist/types/element/src/frame.d.ts +5 -1
  216. package/dist/types/element/src/heading.d.ts +2 -1
  217. package/dist/types/element/src/image.d.ts +1 -11
  218. package/dist/types/element/src/index.d.ts +1 -3
  219. package/dist/types/element/src/linearElementEditor.d.ts +16 -20
  220. package/dist/types/element/src/mutateElement.d.ts +3 -1
  221. package/dist/types/element/src/newElement.d.ts +6 -6
  222. package/dist/types/element/src/renderElement.d.ts +4 -7
  223. package/dist/types/element/src/resizeElements.d.ts +10 -10
  224. package/dist/types/element/src/resizeTest.d.ts +6 -5
  225. package/dist/types/element/src/selection.d.ts +3 -7
  226. package/dist/types/element/src/shape.d.ts +8 -7
  227. package/dist/types/element/src/textMeasurements.d.ts +1 -3
  228. package/dist/types/{excalidraw/data → element/src}/transform.d.ts +3 -3
  229. package/dist/types/element/src/transformHandles.d.ts +8 -27
  230. package/dist/types/element/src/typeChecks.d.ts +4 -7
  231. package/dist/types/element/src/types.d.ts +7 -11
  232. package/dist/types/element/src/utils.d.ts +5 -2
  233. package/dist/types/element/src/zindex.d.ts +7 -1
  234. package/dist/types/excalidraw/actions/actionAddToLibrary.d.ts +93 -136
  235. package/dist/types/excalidraw/actions/actionAlign.d.ts +6 -7
  236. package/dist/types/excalidraw/actions/actionBoundText.d.ts +67 -96
  237. package/dist/types/excalidraw/actions/actionCanvas.d.ts +401 -771
  238. package/dist/types/excalidraw/actions/actionClipboard.d.ts +86 -856
  239. package/dist/types/excalidraw/actions/actionCropEditor.d.ts +32 -47
  240. package/dist/types/excalidraw/actions/actionDeleteSelected.d.ts +107 -156
  241. package/dist/types/excalidraw/actions/actionDistribute.d.ts +2 -3
  242. package/dist/types/excalidraw/actions/actionDuplicateSelection.d.ts +2 -3
  243. package/dist/types/excalidraw/actions/actionElementLink.d.ts +28 -45
  244. package/dist/types/excalidraw/actions/actionElementLock.d.ts +66 -95
  245. package/dist/types/excalidraw/actions/actionEmbeddable.d.ts +33 -48
  246. package/dist/types/excalidraw/actions/actionExport.d.ts +144 -1104
  247. package/dist/types/excalidraw/actions/actionFinalize.d.ts +10 -394
  248. package/dist/types/excalidraw/actions/actionFlip.d.ts +2 -3
  249. package/dist/types/excalidraw/actions/actionFrame.d.ts +213 -308
  250. package/dist/types/excalidraw/actions/actionGroup.d.ts +70 -107
  251. package/dist/types/excalidraw/actions/actionLinearEditor.d.ts +123 -178
  252. package/dist/types/excalidraw/actions/actionLink.d.ts +30 -45
  253. package/dist/types/excalidraw/actions/actionMenu.d.ts +27 -410
  254. package/dist/types/excalidraw/actions/actionNavigate.d.ts +18 -359
  255. package/dist/types/excalidraw/actions/actionProperties.d.ts +129 -2488
  256. package/dist/types/excalidraw/actions/actionSelectAll.d.ts +35 -54
  257. package/dist/types/excalidraw/actions/actionStyles.d.ts +32 -47
  258. package/dist/types/excalidraw/actions/actionTextAutoResize.d.ts +1 -1
  259. package/dist/types/excalidraw/actions/actionToggleGridMode.d.ts +32 -47
  260. package/dist/types/excalidraw/actions/actionToggleObjectsSnapMode.d.ts +32 -47
  261. package/dist/types/excalidraw/actions/actionToggleSearchMenu.d.ts +25 -42
  262. package/dist/types/excalidraw/actions/actionToggleShapeSwitch.d.ts +1 -1
  263. package/dist/types/excalidraw/actions/actionToggleStats.d.ts +32 -47
  264. package/dist/types/excalidraw/actions/actionToggleViewMode.d.ts +32 -47
  265. package/dist/types/excalidraw/actions/actionToggleZenMode.d.ts +33 -48
  266. package/dist/types/excalidraw/actions/actionZindex.d.ts +2 -3
  267. package/dist/types/excalidraw/actions/index.d.ts +2 -2
  268. package/dist/types/excalidraw/actions/register.d.ts +2 -2
  269. package/dist/types/excalidraw/actions/types.d.ts +4 -4
  270. package/dist/types/excalidraw/appState.d.ts +12 -7
  271. package/dist/types/excalidraw/clipboard.d.ts +7 -29
  272. package/dist/types/excalidraw/components/Actions.d.ts +22 -5
  273. package/dist/types/excalidraw/components/App.d.ts +58 -59
  274. package/dist/types/excalidraw/components/ButtonIconCycle.d.ts +1 -1
  275. package/dist/types/excalidraw/components/Card.d.ts +0 -1
  276. package/dist/types/excalidraw/components/ColorPicker/ColorInput.d.ts +7 -4
  277. package/dist/types/excalidraw/components/ColorPicker/ColorPicker.d.ts +0 -1
  278. package/dist/types/excalidraw/components/ColorPicker/Picker.d.ts +2 -0
  279. package/dist/types/excalidraw/components/ColorPicker/PickerColorList.d.ts +2 -1
  280. package/dist/types/excalidraw/components/ColorPicker/ShadeList.d.ts +2 -1
  281. package/dist/types/excalidraw/components/ColorPicker/keyboardNavHandlers.d.ts +0 -1
  282. package/dist/types/excalidraw/components/CommandPalette/CommandPalette.d.ts +1 -0
  283. package/dist/types/excalidraw/components/CommandPalette/types.d.ts +1 -3
  284. package/dist/types/excalidraw/components/ConvertElementTypePopup.d.ts +2 -2
  285. package/dist/types/excalidraw/components/DarkModeToggle.d.ts +1 -1
  286. package/dist/types/excalidraw/components/DefaultSidebar.d.ts +9 -13
  287. package/dist/types/excalidraw/components/ElementLinkDialog.d.ts +1 -1
  288. package/dist/types/excalidraw/components/Ellipsify.d.ts +1 -2
  289. package/dist/types/excalidraw/components/ErrorDialog.d.ts +1 -1
  290. package/dist/types/excalidraw/components/ExcalidrawLogo.d.ts +1 -2
  291. package/dist/types/excalidraw/components/EyeDropper.d.ts +0 -1
  292. package/dist/types/excalidraw/components/FilledButton.d.ts +1 -1
  293. package/dist/types/excalidraw/components/FontPicker/FontPicker.d.ts +2 -1
  294. package/dist/types/excalidraw/components/FontPicker/FontPickerTrigger.d.ts +3 -1
  295. package/dist/types/excalidraw/components/FontPicker/keyboardNavHandlers.d.ts +0 -1
  296. package/dist/types/excalidraw/components/HelpDialog.d.ts +1 -1
  297. package/dist/types/excalidraw/components/HintViewer.d.ts +4 -3
  298. package/dist/types/excalidraw/components/InlineIcon.d.ts +3 -1
  299. package/dist/types/excalidraw/components/LayerUI.d.ts +2 -1
  300. package/dist/types/excalidraw/components/LibraryMenuControlButtons.d.ts +1 -1
  301. package/dist/types/excalidraw/components/LibraryMenuHeaderContent.d.ts +1 -2
  302. package/dist/types/excalidraw/components/LibraryMenuSection.d.ts +1 -1
  303. package/dist/types/excalidraw/components/LibraryUnit.d.ts +2 -3
  304. package/dist/types/excalidraw/components/LinkButton.d.ts +4 -0
  305. package/dist/types/excalidraw/components/LoadingMessage.d.ts +0 -1
  306. package/dist/types/excalidraw/components/MobileMenu.d.ts +3 -5
  307. package/dist/types/excalidraw/components/MobileToolBar.d.ts +10 -0
  308. package/dist/types/excalidraw/components/Modal.d.ts +0 -1
  309. package/dist/types/excalidraw/components/OverwriteConfirm/OverwriteConfirm.d.ts +1 -1
  310. package/dist/types/excalidraw/components/Popover.d.ts +2 -1
  311. package/dist/types/excalidraw/components/PropertiesPopover.d.ts +1 -0
  312. package/dist/types/excalidraw/components/RadioGroup.d.ts +0 -1
  313. package/dist/types/excalidraw/components/RadioSelection.d.ts +4 -4
  314. package/dist/types/excalidraw/components/ScrollableList.d.ts +0 -1
  315. package/dist/types/excalidraw/components/Sidebar/Sidebar.d.ts +15 -21
  316. package/dist/types/excalidraw/components/Sidebar/SidebarHeader.d.ts +1 -1
  317. package/dist/types/excalidraw/components/Sidebar/SidebarTab.d.ts +1 -2
  318. package/dist/types/excalidraw/components/Sidebar/SidebarTabTrigger.d.ts +1 -2
  319. package/dist/types/excalidraw/components/Sidebar/SidebarTabTriggers.d.ts +1 -2
  320. package/dist/types/excalidraw/components/Sidebar/SidebarTabs.d.ts +1 -2
  321. package/dist/types/excalidraw/components/Spinner.d.ts +4 -4
  322. package/dist/types/excalidraw/components/Stats/CanvasGrid.d.ts +0 -1
  323. package/dist/types/excalidraw/components/Stats/Collapsible.d.ts +0 -1
  324. package/dist/types/excalidraw/components/Stats/DragInput.d.ts +0 -1
  325. package/dist/types/excalidraw/components/Stats/index.d.ts +7 -8
  326. package/dist/types/excalidraw/components/Stats/utils.d.ts +1 -1
  327. package/dist/types/excalidraw/components/TTDDialog/TTDDialog.d.ts +1 -2
  328. package/dist/types/excalidraw/components/TTDDialog/TTDDialogOutput.d.ts +0 -1
  329. package/dist/types/excalidraw/components/TTDDialog/TTDDialogTab.d.ts +1 -2
  330. package/dist/types/excalidraw/components/TTDDialog/TTDDialogTabTrigger.d.ts +1 -2
  331. package/dist/types/excalidraw/components/TTDDialog/TTDDialogTabTriggers.d.ts +1 -2
  332. package/dist/types/excalidraw/components/TTDDialog/TTDDialogTrigger.d.ts +2 -3
  333. package/dist/types/excalidraw/components/TTDDialog/common.d.ts +2 -3
  334. package/dist/types/excalidraw/components/TextField.d.ts +1 -0
  335. package/dist/types/excalidraw/components/Toast.d.ts +3 -3
  336. package/dist/types/excalidraw/components/ToolPopover.d.ts +25 -0
  337. package/dist/types/excalidraw/components/Trans.d.ts +2 -2
  338. package/dist/types/excalidraw/components/canvases/InteractiveCanvas.d.ts +6 -3
  339. package/dist/types/excalidraw/components/dropdownMenu/DropdownMenu.d.ts +30 -32
  340. package/dist/types/excalidraw/components/dropdownMenu/DropdownMenuContent.d.ts +6 -5
  341. package/dist/types/excalidraw/components/dropdownMenu/DropdownMenuGroup.d.ts +3 -3
  342. package/dist/types/excalidraw/components/dropdownMenu/DropdownMenuItem.d.ts +10 -18
  343. package/dist/types/excalidraw/components/dropdownMenu/DropdownMenuItemContent.d.ts +3 -3
  344. package/dist/types/excalidraw/components/dropdownMenu/DropdownMenuItemContentRadio.d.ts +0 -1
  345. package/dist/types/excalidraw/components/dropdownMenu/DropdownMenuItemCustom.d.ts +2 -2
  346. package/dist/types/excalidraw/components/dropdownMenu/DropdownMenuItemLink.d.ts +6 -6
  347. package/dist/types/excalidraw/components/dropdownMenu/DropdownMenuTrigger.d.ts +3 -4
  348. package/dist/types/excalidraw/components/dropdownMenu/common.d.ts +1 -1
  349. package/dist/types/excalidraw/components/hoc/withInternalFallback.d.ts +1 -1
  350. package/dist/types/excalidraw/components/hyperlink/helpers.d.ts +1 -1
  351. package/dist/types/excalidraw/components/icons.d.ts +21 -11
  352. package/dist/types/excalidraw/components/live-collaboration/LiveCollaborationTrigger.d.ts +4 -3
  353. package/dist/types/excalidraw/components/main-menu/DefaultItems.d.ts +2 -2
  354. package/dist/types/excalidraw/components/main-menu/MainMenu.d.ts +25 -30
  355. package/dist/types/excalidraw/components/welcome-screen/WelcomeScreen.Center.d.ts +6 -6
  356. package/dist/types/excalidraw/components/welcome-screen/WelcomeScreen.d.ts +15 -16
  357. package/dist/types/excalidraw/data/blob.d.ts +323 -5
  358. package/dist/types/excalidraw/data/encode.d.ts +4 -4
  359. package/dist/types/excalidraw/data/encryption.d.ts +5 -5
  360. package/dist/types/excalidraw/data/filesystem.d.ts +2 -2
  361. package/dist/types/excalidraw/data/index.d.ts +3 -3
  362. package/dist/types/excalidraw/data/json.d.ts +159 -2
  363. package/dist/types/excalidraw/data/library.d.ts +24 -9
  364. package/dist/types/excalidraw/data/restore.d.ts +25 -10
  365. package/dist/types/excalidraw/data/types.d.ts +4 -1
  366. package/dist/types/excalidraw/editor-jotai.d.ts +11 -11
  367. package/dist/types/excalidraw/hooks/useLibraryItemSvg.d.ts +1 -1
  368. package/dist/types/excalidraw/hooks/useOutsideClick.d.ts +4 -3
  369. package/dist/types/excalidraw/hooks/useScrollPosition.d.ts +1 -2
  370. package/dist/types/excalidraw/hooks/useTextEditorFocus.d.ts +14 -0
  371. package/dist/types/excalidraw/i18n.d.ts +2 -2
  372. package/dist/types/excalidraw/index.d.ts +4 -7
  373. package/dist/types/excalidraw/renderer/animation.d.ts +12 -0
  374. package/dist/types/excalidraw/renderer/helpers.d.ts +6 -8
  375. package/dist/types/excalidraw/renderer/interactiveScene.d.ts +8 -14
  376. package/dist/types/excalidraw/scene/Renderer.d.ts +5 -2
  377. package/dist/types/excalidraw/scene/export.d.ts +2 -2
  378. package/dist/types/excalidraw/scene/scroll.d.ts +1 -6
  379. package/dist/types/excalidraw/scene/types.d.ts +22 -5
  380. package/dist/types/excalidraw/shortcut.d.ts +1 -0
  381. package/dist/types/excalidraw/snapping.d.ts +5 -5
  382. package/dist/types/excalidraw/subset/harfbuzz/harfbuzz-bindings.d.ts +1 -1
  383. package/dist/types/excalidraw/subset/harfbuzz/harfbuzz-loader.d.ts +1 -1
  384. package/dist/types/excalidraw/subset/harfbuzz/harfbuzz-wasm.d.ts +1 -1
  385. package/dist/types/excalidraw/subset/woff2/woff2-loader.d.ts +2 -2
  386. package/dist/types/excalidraw/subset/woff2/woff2-wasm.d.ts +1 -1
  387. package/dist/types/excalidraw/types.d.ts +31 -21
  388. package/dist/types/excalidraw/wysiwyg/textWysiwyg.d.ts +2 -2
  389. package/dist/types/math/src/polygon.d.ts +2 -2
  390. package/dist/types/math/src/range.d.ts +1 -3
  391. package/dist/types/math/src/segment.d.ts +4 -3
  392. package/dist/types/utils/src/bbox.d.ts +1 -1
  393. package/dist/types/utils/src/export.d.ts +5 -5
  394. package/dist/types/utils/src/shape.d.ts +6 -6
  395. package/dist/types/utils/src/withinBounds.d.ts +2 -2
  396. package/package.json +6 -6
  397. package/dist/dev/chunk-MFAYKRVR.js +0 -66
  398. package/dist/dev/chunk-MFAYKRVR.js.map +0 -7
  399. package/dist/dev/chunk-QF5FRM6O.js.map +0 -7
  400. package/dist/dev/chunk-WWDIUJ2Q.js.map +0 -7
  401. package/dist/dev/locales/ar-SA-XORAP2EK.js.map +0 -7
  402. package/dist/dev/locales/az-AZ-NAUU3Z4Y.js.map +0 -7
  403. package/dist/dev/locales/bg-BG-AAABLFCY.js.map +0 -7
  404. package/dist/dev/locales/bn-BD-PM4AC5WG.js.map +0 -7
  405. package/dist/dev/locales/ca-ES-YNNMFRQX.js.map +0 -7
  406. package/dist/dev/locales/cs-CZ-DGZA5IKG.js.map +0 -7
  407. package/dist/dev/locales/da-DK-N76F4QAJ.js.map +0 -7
  408. package/dist/dev/locales/de-DE-DMRXZ2SZ.js.map +0 -7
  409. package/dist/dev/locales/el-GR-HIKPLEXI.js.map +0 -7
  410. package/dist/dev/locales/es-ES-AQYVXC32.js.map +0 -7
  411. package/dist/dev/locales/eu-ES-3TOEU5DE.js.map +0 -7
  412. package/dist/dev/locales/fa-IR-527GAKUP.js.map +0 -7
  413. package/dist/dev/locales/fi-FI-M3WLVDFP.js.map +0 -7
  414. package/dist/dev/locales/fr-FR-YE4VDJFI.js.map +0 -7
  415. package/dist/dev/locales/gl-ES-KMXUYGUN.js.map +0 -7
  416. package/dist/dev/locales/he-IL-4MU5N22B.js +0 -586
  417. package/dist/dev/locales/he-IL-4MU5N22B.js.map +0 -7
  418. package/dist/dev/locales/hi-IN-ZHZNZWFC.js +0 -586
  419. package/dist/dev/locales/hi-IN-ZHZNZWFC.js.map +0 -7
  420. package/dist/dev/locales/hu-HU-VIYZI3X4.js.map +0 -7
  421. package/dist/dev/locales/id-ID-22TWZNLA.js.map +0 -7
  422. package/dist/dev/locales/it-IT-MDEQ2SG3.js.map +0 -7
  423. package/dist/dev/locales/ja-JP-K2DI4W6B.js.map +0 -7
  424. package/dist/dev/locales/kaa-6BPSNM3R.js.map +0 -7
  425. package/dist/dev/locales/kab-KAB-2S7ZURK7.js.map +0 -7
  426. package/dist/dev/locales/kk-KZ-UJPYGRQQ.js.map +0 -7
  427. package/dist/dev/locales/km-KH-M5T5JKUE.js.map +0 -7
  428. package/dist/dev/locales/ko-KR-RQX37SNF.js.map +0 -7
  429. package/dist/dev/locales/ku-TR-5XJDIERL.js.map +0 -7
  430. package/dist/dev/locales/lt-LT-MGUBX6CA.js.map +0 -7
  431. package/dist/dev/locales/lv-LV-MD7N5VHD.js.map +0 -7
  432. package/dist/dev/locales/mr-IN-4XWMNGQC.js.map +0 -7
  433. package/dist/dev/locales/my-MM-O4Z74GN5.js.map +0 -7
  434. package/dist/dev/locales/nb-NO-BMB73KRH.js.map +0 -7
  435. package/dist/dev/locales/nl-NL-F2257BLQ.js.map +0 -7
  436. package/dist/dev/locales/nn-NO-NCORG7TS.js.map +0 -7
  437. package/dist/dev/locales/oc-FR-ATFBDMF6.js.map +0 -7
  438. package/dist/dev/locales/pa-IN-D2I375G4.js.map +0 -7
  439. package/dist/dev/locales/pl-PL-YJHOWAAW.js.map +0 -7
  440. package/dist/dev/locales/pt-BR-APOPYZJ7.js.map +0 -7
  441. package/dist/dev/locales/pt-PT-W56WCN7P.js +0 -586
  442. package/dist/dev/locales/pt-PT-W56WCN7P.js.map +0 -7
  443. package/dist/dev/locales/ro-RO-L575VRQA.js.map +0 -7
  444. package/dist/dev/locales/ru-RU-BLG6HZG5.js.map +0 -7
  445. package/dist/dev/locales/si-LK-KT7GGO6D.js.map +0 -7
  446. package/dist/dev/locales/sk-SK-DY6IPO5U.js.map +0 -7
  447. package/dist/dev/locales/sl-SI-5DZSRA47.js.map +0 -7
  448. package/dist/dev/locales/sv-SE-V32YHALQ.js.map +0 -7
  449. package/dist/dev/locales/ta-IN-5JRAGQAO.js.map +0 -7
  450. package/dist/dev/locales/th-TH-55ACRHDJ.js.map +0 -7
  451. package/dist/dev/locales/tr-TR-7QYBXDBO.js.map +0 -7
  452. package/dist/dev/locales/uk-UA-TJS2TMRH.js.map +0 -7
  453. package/dist/dev/locales/vi-VN-Y5CQ2EKQ.js +0 -586
  454. package/dist/dev/locales/vi-VN-Y5CQ2EKQ.js.map +0 -7
  455. package/dist/dev/locales/zh-CN-4MXUOFTH.js.map +0 -7
  456. package/dist/dev/locales/zh-HK-RBTGIU3U.js.map +0 -7
  457. package/dist/dev/locales/zh-TW-U5VF4CCU.js.map +0 -7
  458. package/dist/prod/chunk-I4UNSFV6.js +0 -12
  459. package/dist/prod/chunk-VTWWEYSQ.js +0 -4
  460. package/dist/prod/chunk-Z3N5DIM6.js +0 -1
  461. package/dist/prod/locales/ar-SA-G6X2FPQ2.js +0 -10
  462. package/dist/prod/locales/az-AZ-76LH7QW2.js +0 -1
  463. package/dist/prod/locales/bg-BG-XCXSNQG7.js +0 -5
  464. package/dist/prod/locales/bn-BD-2XOGV67Q.js +0 -5
  465. package/dist/prod/locales/ca-ES-6MX7JW3Y.js +0 -8
  466. package/dist/prod/locales/cs-CZ-2BRQDIVT.js +0 -11
  467. package/dist/prod/locales/da-DK-5WZEPLOC.js +0 -5
  468. package/dist/prod/locales/de-DE-XR44H4JA.js +0 -8
  469. package/dist/prod/locales/el-GR-BZB4AONW.js +0 -10
  470. package/dist/prod/locales/en-TYY6KWIJ.js +0 -1
  471. package/dist/prod/locales/es-ES-U4NZUMDT.js +0 -9
  472. package/dist/prod/locales/eu-ES-A7QVB2H4.js +0 -11
  473. package/dist/prod/locales/fa-IR-HGAKTJCU.js +0 -8
  474. package/dist/prod/locales/fi-FI-Z5N7JZ37.js +0 -6
  475. package/dist/prod/locales/fr-FR-RHASNOE6.js +0 -9
  476. package/dist/prod/locales/gl-ES-HMX3MZ6V.js +0 -10
  477. package/dist/prod/locales/he-IL-6SHJWFNN.js +0 -10
  478. package/dist/prod/locales/hi-IN-IWLTKZ5I.js +0 -4
  479. package/dist/prod/locales/hu-HU-A5ZG7DT2.js +0 -7
  480. package/dist/prod/locales/id-ID-SAP4L64H.js +0 -10
  481. package/dist/prod/locales/it-IT-JPQ66NNP.js +0 -11
  482. package/dist/prod/locales/ja-JP-DBVTYXUO.js +0 -8
  483. package/dist/prod/locales/kaa-6HZHGXH3.js +0 -1
  484. package/dist/prod/locales/kab-KAB-ZGHBKWFO.js +0 -8
  485. package/dist/prod/locales/kk-KZ-P5N5QNE5.js +0 -1
  486. package/dist/prod/locales/km-KH-HSX4SM5Z.js +0 -11
  487. package/dist/prod/locales/ko-KR-MTYHY66A.js +0 -9
  488. package/dist/prod/locales/ku-TR-6OUDTVRD.js +0 -9
  489. package/dist/prod/locales/lt-LT-XHIRWOB4.js +0 -3
  490. package/dist/prod/locales/lv-LV-5QDEKY6T.js +0 -7
  491. package/dist/prod/locales/mr-IN-CRQNXWMA.js +0 -13
  492. package/dist/prod/locales/my-MM-5M5IBNSE.js +0 -1
  493. package/dist/prod/locales/nb-NO-T6EIAALU.js +0 -10
  494. package/dist/prod/locales/nl-NL-IS3SIHDZ.js +0 -8
  495. package/dist/prod/locales/nn-NO-6E72VCQL.js +0 -8
  496. package/dist/prod/locales/oc-FR-POXYY2M6.js +0 -8
  497. package/dist/prod/locales/pa-IN-N4M65BXN.js +0 -4
  498. package/dist/prod/locales/percentages-BXMCSKIN.js +0 -1
  499. package/dist/prod/locales/pl-PL-T2D74RX3.js +0 -9
  500. package/dist/prod/locales/pt-BR-5N22H2LF.js +0 -9
  501. package/dist/prod/locales/pt-PT-UZXXM6DQ.js +0 -9
  502. package/dist/prod/locales/ro-RO-JPDTUUEW.js +0 -11
  503. package/dist/prod/locales/ru-RU-B4JR7IUQ.js +0 -9
  504. package/dist/prod/locales/si-LK-N5RQ5JYF.js +0 -1
  505. package/dist/prod/locales/sk-SK-C5VTKIMK.js +0 -6
  506. package/dist/prod/locales/sl-SI-NN7IZMDC.js +0 -6
  507. package/dist/prod/locales/sv-SE-XGPEYMSR.js +0 -10
  508. package/dist/prod/locales/ta-IN-2NMHFXQM.js +0 -9
  509. package/dist/prod/locales/th-TH-HPSO5L25.js +0 -2
  510. package/dist/prod/locales/tr-TR-DEFEU3FU.js +0 -7
  511. package/dist/prod/locales/uk-UA-QMV73CPH.js +0 -6
  512. package/dist/prod/locales/vi-VN-M7AON7JQ.js +0 -5
  513. package/dist/prod/locales/zh-CN-LNUGB5OW.js +0 -10
  514. package/dist/prod/locales/zh-HK-E62DVLB3.js +0 -1
  515. package/dist/prod/locales/zh-TW-RAJ6MFWO.js +0 -9
  516. /package/dist/dev/data/{image-VTYIFRQE.js.map → image-Q6JHR7OE.js.map} +0 -0
  517. /package/dist/dev/locales/{en-SMAPCEOQ.js.map → en-MLZIHOCR.js.map} +0 -0
  518. /package/dist/dev/locales/{percentages-YKFLWNK2.js.map → percentages-OGWD7R2K.js.map} +0 -0
@@ -1,68 +1,81 @@
1
1
  import { type GlobalPoint } from "@excalidraw/math";
2
- import type { LocalPoint } from "@excalidraw/math";
2
+ import type { LineSegment, LocalPoint } from "@excalidraw/math";
3
3
  import type { AppState } from "@excalidraw/excalidraw/types";
4
+ import type { Bounds } from "@excalidraw/common";
4
5
  import { type Heading } from "./heading";
5
6
  import type { Scene } from "./Scene";
6
- import type { Bounds } from "./bounds";
7
7
  import type { ElementUpdate } from "./mutateElement";
8
- import type { ExcalidrawBindableElement, ExcalidrawElement, NonDeleted, ExcalidrawLinearElement, NonDeletedExcalidrawElement, ElementsMap, NonDeletedSceneElementsMap, ExcalidrawElbowArrowElement, FixedPoint } from "./types";
9
- export type SuggestedBinding = NonDeleted<ExcalidrawBindableElement> | SuggestedPointBinding;
10
- export type SuggestedPointBinding = [
11
- NonDeleted<ExcalidrawLinearElement>,
12
- "start" | "end" | "both",
13
- NonDeleted<ExcalidrawBindableElement>
14
- ];
8
+ import type { BindMode, ElementsMap, ExcalidrawArrowElement, ExcalidrawBindableElement, ExcalidrawElbowArrowElement, ExcalidrawElement, FixedPoint, FixedPointBinding, NonDeleted, NonDeletedExcalidrawElement, NonDeletedSceneElementsMap, Ordered, PointsPositionUpdates } from "./types";
9
+ export type BindingStrategy = {
10
+ mode: BindMode;
11
+ element: NonDeleted<ExcalidrawBindableElement>;
12
+ focusPoint: GlobalPoint;
13
+ } | {
14
+ mode: null;
15
+ element?: undefined;
16
+ focusPoint?: undefined;
17
+ } | {
18
+ mode: undefined;
19
+ element?: undefined;
20
+ focusPoint?: undefined;
21
+ };
22
+ /**
23
+ * gaps exclude element strokeWidth
24
+ *
25
+ * IMPORTANT: currently must be > 0 (this also applies to the computed gap)
26
+ */
27
+ export declare const BASE_BINDING_GAP = 10;
28
+ export declare const BASE_BINDING_GAP_ELBOW = 5;
29
+ export declare const getBindingGap: (bindTarget: ExcalidrawBindableElement, opts: Pick<ExcalidrawArrowElement, "elbowed">) => number;
30
+ export declare const maxBindingDistance_simple: (zoom?: AppState["zoom"]) => number;
15
31
  export declare const shouldEnableBindingForPointerEvent: (event: React.PointerEvent<HTMLElement>) => boolean;
16
32
  export declare const isBindingEnabled: (appState: AppState) => boolean;
17
- export declare const FIXED_BINDING_DISTANCE = 5;
18
- export declare const BINDING_HIGHLIGHT_THICKNESS = 10;
19
- export declare const bindOrUnbindLinearElement: (linearElement: NonDeleted<ExcalidrawLinearElement>, startBindingElement: ExcalidrawBindableElement | null | "keep", endBindingElement: ExcalidrawBindableElement | null | "keep", scene: Scene) => void;
20
- export declare const bindOrUnbindLinearElements: (selectedElements: NonDeleted<ExcalidrawLinearElement>[], isBindingEnabled: boolean, draggingPoints: readonly number[] | null, scene: Scene, zoom?: AppState["zoom"]) => void;
21
- export declare const getSuggestedBindingsForArrows: (selectedElements: NonDeleted<ExcalidrawElement>[], elementsMap: NonDeletedSceneElementsMap, zoom: AppState["zoom"]) => SuggestedBinding[];
22
- export declare const maybeSuggestBindingsForLinearElementAtCoords: (linearElement: NonDeleted<ExcalidrawLinearElement>, pointerCoords: {
23
- x: number;
24
- y: number;
25
- }[], scene: Scene, zoom: AppState["zoom"], oppositeBindingBoundElement?: ExcalidrawBindableElement | null) => ExcalidrawBindableElement[];
26
- export declare const maybeBindLinearElement: (linearElement: NonDeleted<ExcalidrawLinearElement>, appState: AppState, pointerCoords: {
27
- x: number;
28
- y: number;
29
- }, scene: Scene) => void;
30
- export declare const bindLinearElement: (linearElement: NonDeleted<ExcalidrawLinearElement>, hoveredElement: ExcalidrawBindableElement, startOrEnd: "start" | "end", scene: Scene) => void;
31
- export declare const isLinearElementSimpleAndAlreadyBound: (linearElement: NonDeleted<ExcalidrawLinearElement>, alreadyBoundToId: ExcalidrawBindableElement["id"] | undefined, bindableElement: ExcalidrawBindableElement) => boolean;
32
- export declare const getHoveredElementForBinding: (pointerCoords: {
33
- x: number;
34
- y: number;
35
- }, elements: readonly NonDeletedExcalidrawElement[], elementsMap: NonDeletedSceneElementsMap, zoom?: AppState["zoom"], fullShape?: boolean, considerAllElements?: boolean) => NonDeleted<ExcalidrawBindableElement> | null;
33
+ export declare const bindOrUnbindBindingElement: (arrow: NonDeleted<ExcalidrawArrowElement>, draggingPoints: PointsPositionUpdates, scenePointerX: number, scenePointerY: number, scene: Scene, appState: AppState, opts?: {
34
+ newArrow?: boolean;
35
+ altKey?: boolean;
36
+ angleLocked?: boolean;
37
+ initialBinding?: boolean;
38
+ }) => {
39
+ start: BindingStrategy;
40
+ end: BindingStrategy;
41
+ };
42
+ export declare const getBindingStrategyForDraggingBindingElementEndpoints: (arrow: NonDeleted<ExcalidrawArrowElement>, draggingPoints: PointsPositionUpdates, screenPointerX: number, screenPointerY: number, elementsMap: NonDeletedSceneElementsMap, elements: readonly Ordered<NonDeletedExcalidrawElement>[], appState: AppState, opts?: {
43
+ newArrow?: boolean;
44
+ angleLocked?: boolean;
45
+ altKey?: boolean;
46
+ finalize?: boolean;
47
+ initialBinding?: boolean;
48
+ zoom?: AppState["zoom"];
49
+ }) => {
50
+ start: BindingStrategy;
51
+ end: BindingStrategy;
52
+ };
53
+ export declare const bindOrUnbindBindingElements: (selectedArrows: NonDeleted<ExcalidrawArrowElement>[], scene: Scene, appState: AppState) => void;
54
+ export declare const bindBindingElement: (arrow: NonDeleted<ExcalidrawArrowElement>, hoveredElement: ExcalidrawBindableElement, mode: BindMode, startOrEnd: "start" | "end", scene: Scene, focusPoint?: GlobalPoint) => void;
55
+ export declare const unbindBindingElement: (arrow: NonDeleted<ExcalidrawArrowElement>, startOrEnd: "start" | "end", scene: Scene) => ExcalidrawBindableElement["id"] | null;
36
56
  export declare const updateBoundElements: (changedElement: NonDeletedExcalidrawElement, scene: Scene, options?: {
37
57
  simultaneouslyUpdated?: readonly ExcalidrawElement[];
38
- newSize?: {
39
- width: number;
40
- height: number;
41
- };
42
58
  changedElements?: Map<string, ExcalidrawElement>;
43
59
  }) => void;
44
- export declare const updateBindings: (latestElement: ExcalidrawElement, scene: Scene, options?: {
60
+ export declare const updateBindings: (latestElement: ExcalidrawElement, scene: Scene, appState: AppState, options?: {
45
61
  simultaneouslyUpdated?: readonly ExcalidrawElement[];
46
62
  newSize?: {
47
63
  width: number;
48
64
  height: number;
49
65
  };
50
- zoom?: AppState["zoom"];
51
66
  }) => void;
52
67
  export declare const getHeadingForElbowArrowSnap: (p: Readonly<GlobalPoint>, otherPoint: Readonly<GlobalPoint>, bindableElement: ExcalidrawBindableElement | undefined | null, aabb: Bounds | undefined | null, origPoint: GlobalPoint, elementsMap: ElementsMap, zoom?: AppState["zoom"]) => Heading;
53
- export declare const bindPointToSnapToElementOutline: (arrow: ExcalidrawElbowArrowElement, bindableElement: ExcalidrawBindableElement, startOrEnd: "start" | "end", elementsMap: ElementsMap) => GlobalPoint;
54
- export declare const avoidRectangularCorner: (element: ExcalidrawBindableElement, elementsMap: ElementsMap, p: GlobalPoint) => GlobalPoint;
55
- export declare const snapToMid: (element: ExcalidrawBindableElement, elementsMap: ElementsMap, p: GlobalPoint, tolerance?: number) => GlobalPoint;
68
+ export declare const bindPointToSnapToElementOutline: (arrowElement: ExcalidrawArrowElement, bindableElement: ExcalidrawBindableElement, startOrEnd: "start" | "end", elementsMap: ElementsMap, customIntersector?: LineSegment<GlobalPoint>) => GlobalPoint;
69
+ export declare const avoidRectangularCorner: (arrowElement: ExcalidrawArrowElement, bindTarget: ExcalidrawBindableElement, elementsMap: ElementsMap, p: GlobalPoint) => GlobalPoint;
70
+ export declare const updateBoundPoint: (arrow: NonDeleted<ExcalidrawArrowElement>, startOrEnd: "startBinding" | "endBinding", binding: FixedPointBinding | null | undefined, bindableElement: ExcalidrawBindableElement, elementsMap: ElementsMap, customIntersector?: LineSegment<GlobalPoint>) => LocalPoint | null;
56
71
  export declare const calculateFixedPointForElbowArrowBinding: (linearElement: NonDeleted<ExcalidrawElbowArrowElement>, hoveredElement: ExcalidrawBindableElement, startOrEnd: "start" | "end", elementsMap: ElementsMap) => {
57
72
  fixedPoint: FixedPoint;
58
73
  };
74
+ export declare const calculateFixedPointForNonElbowArrowBinding: (linearElement: NonDeleted<ExcalidrawArrowElement>, hoveredElement: ExcalidrawBindableElement, startOrEnd: "start" | "end", elementsMap: ElementsMap, focusPoint?: GlobalPoint) => {
75
+ fixedPoint: FixedPoint;
76
+ };
59
77
  export declare const fixDuplicatedBindingsAfterDuplication: (duplicatedElements: ExcalidrawElement[], origIdToDuplicateId: Map<ExcalidrawElement["id"], ExcalidrawElement["id"]>, duplicateElementsMap: NonDeletedSceneElementsMap) => void;
60
78
  export declare const fixBindingsAfterDeletion: (sceneElements: readonly ExcalidrawElement[], deletedElements: readonly ExcalidrawElement[]) => void;
61
- export declare const bindingBorderTest: (element: NonDeleted<ExcalidrawBindableElement>, { x, y }: {
62
- x: number;
63
- y: number;
64
- }, elementsMap: NonDeletedSceneElementsMap, zoom?: AppState["zoom"], fullShape?: boolean) => boolean;
65
- export declare const maxBindingGap: (element: ExcalidrawElement, elementWidth: number, elementHeight: number, zoom?: AppState["zoom"]) => number;
66
79
  export declare const bindingProperties: Set<BindableProp | BindingProp>;
67
80
  export type BindableProp = "boundElements";
68
81
  export type BindingProp = "frameId" | "containerId" | "startBinding" | "endBinding";
@@ -104,7 +117,8 @@ export declare class BindableElement {
104
117
  */
105
118
  static rebindAffected: (elements: ElementsMap, bindableElement: ExcalidrawElement | undefined, updateElementWith: (affected: ExcalidrawElement, updates: ElementUpdate<ExcalidrawElement>) => void) => void;
106
119
  }
107
- export declare const getGlobalFixedPointForBindableElement: (fixedPointRatio: [number, number], element: ExcalidrawBindableElement, elementsMap: ElementsMap) => GlobalPoint;
108
- export declare const getGlobalFixedPoints: (arrow: ExcalidrawElbowArrowElement, elementsMap: ElementsMap) => [GlobalPoint, GlobalPoint];
120
+ export declare const getGlobalFixedPointForBindableElement: (fixedPointRatio: FixedPoint, element: ExcalidrawBindableElement, elementsMap: ElementsMap) => GlobalPoint;
121
+ export declare const getGlobalFixedPoints: (arrow: ExcalidrawArrowElement, elementsMap: ElementsMap) => [GlobalPoint, GlobalPoint];
109
122
  export declare const getArrowLocalFixedPoints: (arrow: ExcalidrawElbowArrowElement, elementsMap: ElementsMap) => LocalPoint[];
110
123
  export declare const normalizeFixedPoint: <T extends FixedPoint | null>(fixedPoint: T) => T extends null ? null : FixedPoint;
124
+ export declare const getBindingSideMidPoint: (binding: FixedPointBinding, elementsMap: ElementsMap) => GlobalPoint | LocalPoint | null;
@@ -1,3 +1,4 @@
1
+ import { type Bounds } from "@excalidraw/common";
1
2
  import type { Degrees, GlobalPoint, LineSegment, LocalPoint } from "@excalidraw/math";
2
3
  import type { AppState } from "@excalidraw/excalidraw/types";
3
4
  import type { Drawable, Op } from "roughjs/bin/core";
@@ -9,15 +10,6 @@ export type RectangleBox = {
9
10
  height: number;
10
11
  angle: number;
11
12
  };
12
- /**
13
- * x and y position of top left corner, x and y position of bottom right corner
14
- */
15
- export type Bounds = readonly [
16
- minX: number,
17
- minY: number,
18
- maxX: number,
19
- maxY: number
20
- ];
21
13
  export type SceneBounds = readonly [
22
14
  sceneX: number,
23
15
  sceneY: number,
@@ -45,7 +37,7 @@ export declare const getElementLineSegments: (element: ExcalidrawElement, elemen
45
37
  export declare const getRectangleBoxAbsoluteCoords: (boxSceneCoords: RectangleBox) => number[];
46
38
  export declare const getDiamondPoints: (element: ExcalidrawElement) => number[];
47
39
  export declare const getCubicBezierCurveBound: (p0: GlobalPoint, p1: GlobalPoint, p2: GlobalPoint, p3: GlobalPoint) => Bounds;
48
- export declare const getMinMaxXYFromCurvePathOps: (ops: Op[], transformXY?: ((p: GlobalPoint) => GlobalPoint) | undefined) => Bounds;
40
+ export declare const getMinMaxXYFromCurvePathOps: (ops: Op[], transformXY?: (p: GlobalPoint) => GlobalPoint) => Bounds;
49
41
  export declare const getBoundsFromPoints: (points: ExcalidrawFreeDrawElement["points"]) => Bounds;
50
42
  /** @returns number in pixels */
51
43
  export declare const getArrowheadSize: (arrowhead: Arrowhead) => number;
@@ -1,6 +1,6 @@
1
1
  import type { GlobalPoint, LineSegment } from "@excalidraw/math";
2
2
  import type { FrameNameBounds } from "@excalidraw/excalidraw/types";
3
- import type { ElementsMap, ExcalidrawElement } from "./types";
3
+ import type { ElementsMap, ExcalidrawBindableElement, ExcalidrawElement, NonDeleted, NonDeletedExcalidrawElement, NonDeletedSceneElementsMap, Ordered } from "./types";
4
4
  export declare const shouldTestInside: (element: ExcalidrawElement) => boolean;
5
5
  export type HitTestArgs = {
6
6
  point: GlobalPoint;
@@ -8,11 +8,14 @@ export type HitTestArgs = {
8
8
  threshold: number;
9
9
  elementsMap: ElementsMap;
10
10
  frameNameBound?: FrameNameBounds | null;
11
+ overrideShouldTestInside?: boolean;
11
12
  };
12
- export declare const hitElementItself: ({ point, element, threshold, elementsMap, frameNameBound, }: HitTestArgs) => boolean;
13
+ export declare const hitElementItself: ({ point, element, threshold, elementsMap, frameNameBound, overrideShouldTestInside, }: HitTestArgs) => boolean;
13
14
  export declare const hitElementBoundingBox: (point: GlobalPoint, element: ExcalidrawElement, elementsMap: ElementsMap, tolerance?: number) => boolean;
14
15
  export declare const hitElementBoundingBoxOnly: (hitArgs: HitTestArgs, elementsMap: ElementsMap) => boolean;
15
16
  export declare const hitElementBoundText: (point: GlobalPoint, element: ExcalidrawElement, elementsMap: ElementsMap) => boolean;
17
+ export declare const getAllHoveredElementAtPoint: (point: Readonly<GlobalPoint>, elements: readonly Ordered<NonDeletedExcalidrawElement>[], elementsMap: NonDeletedSceneElementsMap, toleranceFn?: (element: ExcalidrawBindableElement) => number) => NonDeleted<ExcalidrawBindableElement>[];
18
+ export declare const getHoveredElementForBinding: (point: Readonly<GlobalPoint>, elements: readonly Ordered<NonDeletedExcalidrawElement>[], elementsMap: NonDeletedSceneElementsMap, toleranceFn?: (element: ExcalidrawBindableElement) => number) => NonDeleted<ExcalidrawBindableElement> | null;
16
19
  /**
17
20
  * Intersect a line with an element for binding test
18
21
  *
@@ -30,3 +33,4 @@ export declare const intersectElementWithLineSegment: (element: ExcalidrawElemen
30
33
  * @returns
31
34
  */
32
35
  export declare const isPointInElement: (point: GlobalPoint, element: ExcalidrawElement, elementsMap: ElementsMap) => boolean;
36
+ export declare const isBindableElementInsideOtherBindable: (innerElement: ExcalidrawBindableElement, outerElement: ExcalidrawBindableElement, elementsMap: ElementsMap) => boolean;
@@ -1,8 +1,8 @@
1
1
  import type { ElementOrToolType } from "@excalidraw/excalidraw/types";
2
- export declare const hasBackground: (type: ElementOrToolType) => boolean;
3
- export declare const hasStrokeColor: (type: ElementOrToolType) => boolean;
4
- export declare const hasStrokeWidth: (type: ElementOrToolType) => boolean;
5
- export declare const hasStrokeStyle: (type: ElementOrToolType) => boolean;
6
- export declare const canChangeRoundness: (type: ElementOrToolType) => boolean;
7
- export declare const toolIsArrow: (type: ElementOrToolType) => boolean;
8
- export declare const canHaveArrowheads: (type: ElementOrToolType) => boolean;
2
+ export declare const hasBackground: (type: ElementOrToolType) => type is "line" | "rectangle" | "diamond" | "ellipse" | "embeddable" | "iframe" | "freedraw";
3
+ export declare const hasStrokeColor: (type: ElementOrToolType) => type is "line" | "arrow" | "text" | "rectangle" | "diamond" | "ellipse" | "embeddable" | "freedraw";
4
+ export declare const hasStrokeWidth: (type: ElementOrToolType) => type is "line" | "arrow" | "rectangle" | "diamond" | "ellipse" | "embeddable" | "iframe" | "freedraw";
5
+ export declare const hasStrokeStyle: (type: ElementOrToolType) => type is "line" | "arrow" | "rectangle" | "diamond" | "ellipse" | "embeddable" | "iframe";
6
+ export declare const canChangeRoundness: (type: ElementOrToolType) => type is "line" | "rectangle" | "diamond" | "embeddable" | "iframe" | "image";
7
+ export declare const toolIsArrow: (type: ElementOrToolType) => type is "arrow";
8
+ export declare const canHaveArrowheads: (type: ElementOrToolType) => type is "arrow";
@@ -24,10 +24,10 @@ export declare const dragNewElement: ({ newElement, elementType, originX, origin
24
24
  scene: Scene;
25
25
  /** whether to keep given aspect ratio when `isResizeWithSidesSameLength` is
26
26
  true */
27
- widthAspectRatio?: number | null | undefined;
27
+ widthAspectRatio?: number | null;
28
28
  originOffset?: {
29
29
  x: number;
30
30
  y: number;
31
- } | null | undefined;
32
- informMutation?: boolean | undefined;
31
+ } | null;
32
+ informMutation?: boolean;
33
33
  }) => void;
@@ -17,12 +17,12 @@ import type { ExcalidrawElement, GroupId } from "./types";
17
17
  export declare const duplicateElement: <TElement extends ExcalidrawElement>(editingGroupId: AppState["editingGroupId"], groupIdMapForOperation: Map<GroupId, GroupId>, element: TElement, randomizeSeed?: boolean) => Readonly<TElement>;
18
18
  export declare const duplicateElements: (opts: {
19
19
  elements: readonly ExcalidrawElement[];
20
- randomizeSeed?: boolean | undefined;
21
- overrides?: ((data: {
20
+ randomizeSeed?: boolean;
21
+ overrides?: (data: {
22
22
  duplicateElement: ExcalidrawElement;
23
23
  origElement: ExcalidrawElement;
24
24
  origIdToDuplicateId: Map<ExcalidrawElement["id"], ExcalidrawElement["id"]>;
25
- }) => Partial<ExcalidrawElement>) | undefined;
25
+ }) => Partial<ExcalidrawElement>;
26
26
  } & ({
27
27
  /**
28
28
  * Duplicates all elements in array.
@@ -26,11 +26,11 @@ export declare class InvalidFractionalIndexError extends Error {
26
26
  export declare const validateFractionalIndices: (elements: readonly ExcalidrawElement[], { shouldThrow, includeBoundTextValidation, ignoreLogs, reconciliationContext, }: {
27
27
  shouldThrow: boolean;
28
28
  includeBoundTextValidation: boolean;
29
- ignoreLogs?: true | undefined;
29
+ ignoreLogs?: true;
30
30
  reconciliationContext?: {
31
31
  localElements: ReadonlyArray<ExcalidrawElement>;
32
32
  remoteElements: ReadonlyArray<ExcalidrawElement>;
33
- } | undefined;
33
+ };
34
34
  }) => void;
35
35
  /**
36
36
  * Order the elements based on the fractional indices.
@@ -53,7 +53,11 @@ export declare const updateFrameMembershipOfSelectedElements: <T extends Element
53
53
  * filters out elements that are inside groups that contain a frame element
54
54
  * anywhere in the group tree
55
55
  */
56
- export declare const omitGroupsContainingFrameLikes: (allElements: ElementsMapOrArray, selectedElements?: readonly ExcalidrawElement[]) => ExcalidrawElement[];
56
+ export declare const omitGroupsContainingFrameLikes: (allElements: ElementsMapOrArray,
57
+ /** subset of elements you want to filter. Optional perf optimization so we
58
+ * don't have to filter all elements unnecessarily
59
+ */
60
+ selectedElements?: readonly ExcalidrawElement[]) => ExcalidrawElement[];
57
61
  /**
58
62
  * depending on the appState, return target frame, which is the frame the given element
59
63
  * is going to be added to or remove from
@@ -1,3 +1,4 @@
1
+ import { type Bounds } from "@excalidraw/common";
1
2
  import type { LocalPoint, GlobalPoint, Vector } from "@excalidraw/math";
2
3
  import type { ExcalidrawBindableElement } from "./types";
3
4
  export declare const HEADING_RIGHT: Heading;
@@ -11,5 +12,5 @@ export declare const headingForPointIsHorizontal: <P extends GlobalPoint | Local
11
12
  export declare const compareHeading: (a: Heading, b: Heading) => boolean;
12
13
  export declare const headingIsHorizontal: (a: Heading) => boolean;
13
14
  export declare const headingIsVertical: (a: Heading) => boolean;
14
- export declare const headingForPointFromElement: <Point extends GlobalPoint>(element: Readonly<ExcalidrawBindableElement>, aabb: readonly [minX: number, minY: number, maxX: number, maxY: number], p: Readonly<Point>) => Heading;
15
+ export declare const headingForPointFromElement: <Point extends GlobalPoint>(element: Readonly<ExcalidrawBindableElement>, aabb: Readonly<Bounds>, p: Readonly<Point>) => Heading;
15
16
  export declare const flipHeading: (h: Heading) => Heading;
@@ -10,17 +10,7 @@ export declare const updateImageCache: ({ fileIds, files, imageCache, }: {
10
10
  }) => Promise<{
11
11
  imageCache: Map<FileId, {
12
12
  image: HTMLImageElement | Promise<HTMLImageElement>;
13
- mimeType: import("../../common/src/utility-types").ValueOf<{
14
- readonly svg: "image/svg+xml";
15
- readonly png: "image/png";
16
- readonly jpg: "image/jpeg";
17
- readonly gif: "image/gif";
18
- readonly webp: "image/webp";
19
- readonly bmp: "image/bmp";
20
- readonly ico: "image/x-icon";
21
- readonly avif: "image/avif";
22
- readonly jfif: "image/jfif";
23
- }>;
13
+ mimeType: import("@excalidraw/common/utility-types").ValueOf<typeof import("@excalidraw/common").IMAGE_MIME_TYPES>;
24
14
  }>;
25
15
  /** includes errored files because they cache was updated nonetheless */
26
16
  updatedFiles: Map<FileId, true>;
@@ -11,9 +11,6 @@ export declare const hashString: (s: string) => number;
11
11
  export declare const getVisibleElements: (elements: readonly ExcalidrawElement[]) => readonly NonDeletedExcalidrawElement[];
12
12
  export declare const getNonDeletedElements: <T extends ExcalidrawElement>(elements: readonly T[]) => readonly NonDeleted<T>[];
13
13
  export declare const isNonDeletedElement: <T extends ExcalidrawElement>(element: T) => element is NonDeleted<T>;
14
- export declare const clearElementsForDatabase: (elements: readonly ExcalidrawElement[]) => ExcalidrawElement[];
15
- export declare const clearElementsForExport: (elements: readonly ExcalidrawElement[]) => ExcalidrawElement[];
16
- export declare const clearElementsForLocalStorage: (elements: readonly ExcalidrawElement[]) => ExcalidrawElement[];
17
14
  export * from "./align";
18
15
  export * from "./binding";
19
16
  export * from "./bounds";
@@ -52,6 +49,7 @@ export * from "./store";
52
49
  export * from "./textElement";
53
50
  export * from "./textMeasurements";
54
51
  export * from "./textWrapping";
52
+ export * from "./transform";
55
53
  export * from "./transformHandles";
56
54
  export * from "./typeChecks";
57
55
  export * from "./utils";
@@ -1,45 +1,42 @@
1
- /// <reference types="react" />
2
1
  import { type GlobalPoint, type LocalPoint } from "@excalidraw/math";
3
2
  import { type Store } from "@excalidraw/element";
4
3
  import type { AppState, PointerCoords, InteractiveCanvasAppState, AppClassProperties, NullableGridSize, Zoom } from "@excalidraw/excalidraw/types";
4
+ import type { Bounds } from "@excalidraw/common";
5
5
  import type { Scene } from "./Scene";
6
- import type { Bounds } from "./bounds";
7
- import type { NonDeleted, ExcalidrawLinearElement, ExcalidrawElement, PointBinding, ExcalidrawBindableElement, ExcalidrawTextElementWithContainer, ElementsMap, NonDeletedSceneElementsMap, ExcalidrawElbowArrowElement, PointsPositionUpdates } from "./types";
6
+ import type { NonDeleted, ExcalidrawLinearElement, ExcalidrawElement, ExcalidrawTextElementWithContainer, ElementsMap, NonDeletedSceneElementsMap, FixedPointBinding, ExcalidrawElbowArrowElement, PointsPositionUpdates } from "./types";
8
7
  export declare class LinearElementEditor {
9
8
  readonly elementId: ExcalidrawElement["id"] & {
10
9
  _brand: "excalidrawLinearElementId";
11
10
  };
12
11
  /** indices */
13
12
  readonly selectedPointsIndices: readonly number[] | null;
14
- readonly pointerDownState: Readonly<{
13
+ readonly initialState: Readonly<{
15
14
  prevSelectedPointsIndices: readonly number[] | null;
16
15
  /** index */
17
16
  lastClickedPoint: number;
18
- lastClickedIsEndPoint: boolean;
19
- origin: Readonly<{
20
- x: number;
21
- y: number;
22
- }> | null;
17
+ origin: Readonly<GlobalPoint> | null;
23
18
  segmentMidpoint: {
24
19
  value: GlobalPoint | null;
25
20
  index: number | null;
26
21
  added: boolean;
27
22
  };
23
+ arrowStartIsInside: boolean;
24
+ altFocusPoint: Readonly<GlobalPoint> | null;
28
25
  }>;
29
26
  /** whether you're dragging a point */
30
27
  readonly isDragging: boolean;
31
28
  readonly lastUncommittedPoint: LocalPoint | null;
29
+ readonly lastCommittedPoint: LocalPoint | null;
32
30
  readonly pointerOffset: Readonly<{
33
31
  x: number;
34
32
  y: number;
35
33
  }>;
36
- readonly startBindingElement: ExcalidrawBindableElement | null | "keep";
37
- readonly endBindingElement: ExcalidrawBindableElement | null | "keep";
38
34
  readonly hoverPointIndex: number;
39
35
  readonly segmentMidPointHoveredCoords: GlobalPoint | null;
40
36
  readonly elbowed: boolean;
41
37
  readonly customLineAngle: number | null;
42
38
  readonly isEditing: boolean;
39
+ readonly pointerDownState: never;
43
40
  constructor(element: NonDeleted<ExcalidrawLinearElement>, elementsMap: ElementsMap, isEditing?: boolean);
44
41
  static POINT_HANDLE_SIZE: number;
45
42
  /**
@@ -48,10 +45,8 @@ export declare class LinearElementEditor {
48
45
  */
49
46
  static getElement<T extends ExcalidrawLinearElement>(id: InstanceType<typeof LinearElementEditor>["elementId"], elementsMap: ElementsMap): T | null;
50
47
  static handleBoxSelection(event: PointerEvent, appState: AppState, setState: React.Component<any, AppState>["setState"], elementsMap: NonDeletedSceneElementsMap): false | undefined;
51
- /**
52
- * @returns whether point was dragged
53
- */
54
- static handlePointDragging(event: PointerEvent, app: AppClassProperties, scenePointerX: number, scenePointerY: number, linearElementEditor: LinearElementEditor): Pick<AppState, keyof AppState> | null;
48
+ static handlePointerMove(event: PointerEvent, app: AppClassProperties, scenePointerX: number, scenePointerY: number, linearElementEditor: LinearElementEditor): Pick<AppState, "suggestedBinding" | "selectedLinearElement"> | null;
49
+ static handlePointDragging(event: PointerEvent, app: AppClassProperties, scenePointerX: number, scenePointerY: number, linearElementEditor: LinearElementEditor): Pick<AppState, "suggestedBinding" | "selectedLinearElement"> | null;
55
50
  static handlePointerUp(event: PointerEvent, editingLinearElement: LinearElementEditor, appState: AppState, scene: Scene): LinearElementEditor;
56
51
  static getEditorMidPoints: (element: NonDeleted<ExcalidrawLinearElement>, elementsMap: ElementsMap, appState: InteractiveCanvasAppState) => (GlobalPoint | null)[];
57
52
  static getSegmentMidpointHitCoords: (linearElementEditor: LinearElementEditor, scenePointer: {
@@ -70,7 +65,7 @@ export declare class LinearElementEditor {
70
65
  linearElementEditor: LinearElementEditor | null;
71
66
  };
72
67
  static arePointsEqual<Point extends LocalPoint | GlobalPoint>(point1: Point | null, point2: Point | null): boolean;
73
- static handlePointerMove(event: React.PointerEvent<HTMLCanvasElement>, scenePointerX: number, scenePointerY: number, app: AppClassProperties): LinearElementEditor | null;
68
+ static handlePointerMoveInEditMode(event: React.PointerEvent<HTMLCanvasElement>, scenePointerX: number, scenePointerY: number, app: AppClassProperties): LinearElementEditor | null;
74
69
  /** scene coords */
75
70
  static getPointGlobalCoordinates(element: NonDeleted<ExcalidrawLinearElement>, p: LocalPoint, elementsMap: ElementsMap): GlobalPoint;
76
71
  /** scene coords */
@@ -96,12 +91,13 @@ export declare class LinearElementEditor {
96
91
  static deletePoints(element: NonDeleted<ExcalidrawLinearElement>, app: AppClassProperties, pointIndices: readonly number[]): void;
97
92
  static addPoints(element: NonDeleted<ExcalidrawLinearElement>, scene: Scene, addedPoints: LocalPoint[]): void;
98
93
  static movePoints(element: NonDeleted<ExcalidrawLinearElement>, scene: Scene, pointUpdates: PointsPositionUpdates, otherUpdates?: {
99
- startBinding?: PointBinding | null;
100
- endBinding?: PointBinding | null;
94
+ startBinding?: FixedPointBinding | null;
95
+ endBinding?: FixedPointBinding | null;
96
+ moveMidPointsWithElement?: boolean | null;
101
97
  }): void;
102
98
  static shouldAddMidpoint(linearElementEditor: LinearElementEditor, pointerCoords: PointerCoords, appState: AppState, elementsMap: ElementsMap): boolean;
103
99
  static addMidpoint(linearElementEditor: LinearElementEditor, pointerCoords: PointerCoords, app: AppClassProperties, snapToGrid: boolean, scene: Scene): {
104
- pointerDownState: LinearElementEditor["pointerDownState"];
100
+ pointerDownState: LinearElementEditor["initialState"];
105
101
  selectedPointsIndices: LinearElementEditor["selectedPointsIndices"];
106
102
  } | undefined;
107
103
  private static _updatePoints;
@@ -112,6 +108,6 @@ export declare class LinearElementEditor {
112
108
  };
113
109
  static getMinMaxXYWithBoundText: (element: ExcalidrawLinearElement, elementsMap: ElementsMap, elementBounds: Bounds, boundTextElement: ExcalidrawTextElementWithContainer) => [number, number, number, number, number, number];
114
110
  static getElementAbsoluteCoords: (element: ExcalidrawLinearElement, elementsMap: ElementsMap, includeBoundText?: boolean) => [number, number, number, number, number, number];
115
- static moveFixedSegment(linearElement: LinearElementEditor, index: number, x: number, y: number, scene: Scene): LinearElementEditor;
111
+ static moveFixedSegment(linearElement: LinearElementEditor, index: number, x: number, y: number, scene: Scene): Pick<LinearElementEditor, "segmentMidPointHoveredCoords" | "initialState">;
116
112
  static deleteFixedSegment(element: ExcalidrawElbowArrowElement, scene: Scene, index: number): void;
117
113
  }
@@ -12,7 +12,9 @@ export type ElementUpdate<TElement extends ExcalidrawElement> = Omit<Partial<TEl
12
12
  export declare const mutateElement: <TElement extends Mutable<ExcalidrawElement>>(element: TElement, elementsMap: ElementsMap, updates: ElementUpdate<TElement>, options?: {
13
13
  isDragging?: boolean;
14
14
  }) => TElement;
15
- export declare const newElementWith: <TElement extends ExcalidrawElement>(element: TElement, updates: ElementUpdate<TElement>, force?: boolean) => TElement;
15
+ export declare const newElementWith: <TElement extends ExcalidrawElement>(element: TElement, updates: ElementUpdate<TElement>,
16
+ /** pass `true` to always regenerate */
17
+ force?: boolean) => TElement;
16
18
  /**
17
19
  * Mutates element, bumping `version`, `versionNonce`, and `updated`.
18
20
  *
@@ -47,12 +47,12 @@ export declare const newLinearElement: (opts: {
47
47
  } & ElementConstructorOpts) => NonDeleted<ExcalidrawLinearElement>;
48
48
  export declare const newArrowElement: <T extends boolean>(opts: {
49
49
  type: ExcalidrawArrowElement["type"];
50
- startArrowhead?: Arrowhead | null | undefined;
51
- endArrowhead?: Arrowhead | null | undefined;
52
- points?: readonly import("@excalidraw/math").LocalPoint[] | undefined;
53
- elbowed?: T | undefined;
54
- fixedSegments?: readonly import("./types").FixedSegment[] | null | undefined;
55
- } & Omit<Omit<ExcalidrawGenericElement, "id" | "isDeleted" | "updated" | "type">, "link" | "strokeColor" | "backgroundColor" | "fillStyle" | "strokeWidth" | "strokeStyle" | "roundness" | "roughness" | "opacity" | "width" | "height" | "angle" | "seed" | "version" | "versionNonce" | "index" | "groupIds" | "frameId" | "boundElements" | "locked" | "customData"> & Partial<Pick<Omit<ExcalidrawGenericElement, "id" | "isDeleted" | "updated" | "type">, "link" | "strokeColor" | "backgroundColor" | "fillStyle" | "strokeWidth" | "strokeStyle" | "roundness" | "roughness" | "opacity" | "width" | "height" | "angle" | "seed" | "version" | "versionNonce" | "index" | "groupIds" | "frameId" | "boundElements" | "locked" | "customData">>) => T extends true ? NonDeleted<ExcalidrawElbowArrowElement> : NonDeleted<ExcalidrawArrowElement>;
50
+ startArrowhead?: Arrowhead | null;
51
+ endArrowhead?: Arrowhead | null;
52
+ points?: ExcalidrawArrowElement["points"];
53
+ elbowed?: T;
54
+ fixedSegments?: ExcalidrawElbowArrowElement["fixedSegments"] | null;
55
+ } & ElementConstructorOpts) => T extends true ? NonDeleted<ExcalidrawElbowArrowElement> : NonDeleted<ExcalidrawArrowElement>;
56
56
  export declare const newImageElement: (opts: {
57
57
  type: ExcalidrawImageElement["type"];
58
58
  status?: ExcalidrawImageElement["status"];
@@ -1,8 +1,8 @@
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
- export declare const IMAGE_INVERT_FILTER = "invert(100%) hue-rotate(180deg) saturate(1.25)";
6
6
  export declare const getRenderOpacity: (element: ExcalidrawElement, containingFrame: ExcalidrawFrameLikeElement | null, elementsPendingErasure: ElementsPendingErasure, pendingNodes: Readonly<PendingExcalidrawElements> | null, globalAlpha?: number) => number;
7
7
  export interface ExcalidrawElementWithCanvas {
8
8
  element: ExcalidrawElement | ExcalidrawTextElement;
@@ -21,8 +21,5 @@ export interface ExcalidrawElementWithCanvas {
21
21
  export declare const DEFAULT_LINK_SIZE = 14;
22
22
  export declare const elementWithCanvasCache: WeakMap<ExcalidrawElement, ExcalidrawElementWithCanvas>;
23
23
  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 pathsCache: WeakMap<ExcalidrawFreeDrawElement, Path2D>;
26
- export declare function generateFreeDrawShape(element: ExcalidrawFreeDrawElement): Path2D;
27
- export declare function getFreeDrawPath2D(element: ExcalidrawFreeDrawElement): Path2D | undefined;
28
- export declare function getFreeDrawSvgPath(element: ExcalidrawFreeDrawElement): string;
24
+ export declare const renderElement: (element: NonDeletedExcalidrawElement, elementsMap: RenderableElementsMap, allElementsMap: NonDeletedSceneElementsMap, rc: RoughCanvas, context: CanvasRenderingContext2D, renderConfig: StaticCanvasRenderConfig, appState: StaticCanvasAppState | InteractiveCanvasAppState) => void;
25
+ export declare function getFreedrawOutlineAsSegments(element: ExcalidrawFreeDrawElement, points: [number, number][], elementsMap: ElementsMap): import("@excalidraw/math").LineSegment<GlobalPoint>[];
@@ -17,16 +17,16 @@ export declare const resizeSingleTextElement: (origElement: NonDeleted<Excalidra
17
17
  export declare const getResizeOffsetXY: (transformHandleType: MaybeTransformHandleType, selectedElements: NonDeletedExcalidrawElement[], elementsMap: ElementsMap, x: number, y: number) => [number, number];
18
18
  export declare const getResizeArrowDirection: (transformHandleType: MaybeTransformHandleType, element: NonDeleted<ExcalidrawLinearElement>) => "origin" | "end";
19
19
  export declare const resizeSingleElement: (nextWidth: number, nextHeight: number, latestElement: ExcalidrawElement, origElement: ExcalidrawElement, originalElementsMap: ElementsMap, scene: Scene, handleDirection: TransformHandleDirection, { shouldInformMutation, shouldMaintainAspectRatio, shouldResizeFromCenter, }?: {
20
- shouldMaintainAspectRatio?: boolean | undefined;
21
- shouldResizeFromCenter?: boolean | undefined;
22
- shouldInformMutation?: boolean | undefined;
20
+ shouldMaintainAspectRatio?: boolean;
21
+ shouldResizeFromCenter?: boolean;
22
+ shouldInformMutation?: boolean;
23
23
  }) => void;
24
24
  export declare const resizeMultipleElements: (selectedElements: readonly NonDeletedExcalidrawElement[], elementsMap: ElementsMap, handleDirection: TransformHandleDirection, scene: Scene, originalElementsMap: ElementsMap, { shouldMaintainAspectRatio, shouldResizeFromCenter, flipByX, flipByY, nextHeight, nextWidth, originalBoundingBox, }?: {
25
- nextWidth?: number | undefined;
26
- nextHeight?: number | undefined;
27
- shouldMaintainAspectRatio?: boolean | undefined;
28
- shouldResizeFromCenter?: boolean | undefined;
29
- flipByX?: boolean | undefined;
30
- flipByY?: boolean | undefined;
31
- originalBoundingBox?: BoundingBox | undefined;
25
+ nextWidth?: number;
26
+ nextHeight?: number;
27
+ shouldMaintainAspectRatio?: boolean;
28
+ shouldResizeFromCenter?: boolean;
29
+ flipByX?: boolean;
30
+ flipByY?: boolean;
31
+ originalBoundingBox?: BoundingBox;
32
32
  }) => void;
@@ -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 { Bounds } from "./bounds";
3
+ import type { AppState, Zoom } from "@excalidraw/excalidraw/types";
4
+ import type { Bounds } from "@excalidraw/common";
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;
@@ -27,12 +27,8 @@ export declare const makeNextSelectedElementIds: (nextSelectedElementIds: AppSta
27
27
  [id: string]: true;
28
28
  }>;
29
29
  export declare const getSelectionStateForElements: (targetElements: readonly ExcalidrawElement[], allElements: readonly NonDeletedExcalidrawElement[], appState: AppState) => {
30
- editingGroupId: string | null;
31
- selectedElementIds: Readonly<{
32
- [id: string]: true;
33
- }>;
34
- selectedGroupIds: {
35
- [groupId: string]: boolean;
36
- };
30
+ editingGroupId: AppState["editingGroupId"];
31
+ selectedElementIds: AppState["selectedElementIds"];
32
+ selectedGroupIds: AppState["selectedGroupIds"];
37
33
  selectedLinearElement: LinearElementEditor | null;
38
34
  };
@@ -3,7 +3,7 @@ import { type LocalPoint } from "@excalidraw/math";
3
3
  import type { GlobalPoint } from "@excalidraw/math";
4
4
  import type { AppState, EmbedsValidationStatus } from "@excalidraw/excalidraw/types";
5
5
  import type { ElementShape, ElementShapes } from "@excalidraw/excalidraw/scene/types";
6
- import type { ExcalidrawElement, ExcalidrawLinearElement, ExcalidrawFreeDrawElement, ElementsMap, ExcalidrawLineElement } from "./types";
6
+ import type { ExcalidrawElement, ExcalidrawSelectionElement, ExcalidrawLinearElement, ExcalidrawFreeDrawElement, ElementsMap, ExcalidrawLineElement } from "./types";
7
7
  import type { Drawable, Options } from "roughjs/bin/core";
8
8
  export declare class ShapeCache {
9
9
  private static rg;
@@ -12,21 +12,21 @@ export declare class ShapeCache {
12
12
  * Retrieves shape from cache if available. Use this only if shape
13
13
  * is optional and you have a fallback in case it's not cached.
14
14
  */
15
- static get: <T extends ExcalidrawElement>(element: T) => T["type"] extends keyof ElementShapes ? ElementShapes[T["type"]] | undefined : ElementShape | undefined;
16
- static set: <T extends ExcalidrawElement>(element: T, shape: T["type"] extends keyof ElementShapes ? ElementShapes[T["type"]] : Drawable) => WeakMap<ExcalidrawElement, ElementShape>;
17
- static delete: (element: ExcalidrawElement) => boolean;
15
+ static get: <T extends ExcalidrawElement>(element: T, theme: AppState["theme"] | null) => (T["type"] extends keyof ElementShapes ? ElementShapes[T["type"]] | undefined : ElementShape | undefined) | undefined;
16
+ static delete: (element: ExcalidrawElement) => void;
18
17
  static destroy: () => void;
19
18
  /**
20
19
  * Generates & caches shape for element if not already cached, otherwise
21
20
  * returns cached shape.
22
21
  */
23
- static generateElementShape: <T extends ExcalidrawLinearElement | import("./types").ExcalidrawRectangleElement | import("./types").ExcalidrawDiamondElement | import("./types").ExcalidrawEllipseElement | import("./types").ExcalidrawEmbeddableElement | import("./types").ExcalidrawIframeElement | import("./types").ExcalidrawImageElement | import("./types").ExcalidrawFrameElement | import("./types").ExcalidrawMagicFrameElement | import("./types").ExcalidrawTextElement | ExcalidrawFreeDrawElement | import("./types").ExcalidrawArrowElement>(element: T, renderConfig: {
22
+ static generateElementShape: <T extends Exclude<ExcalidrawElement, ExcalidrawSelectionElement>>(element: T, renderConfig: {
24
23
  isExporting: boolean;
25
24
  canvasBackgroundColor: AppState["viewBackgroundColor"];
26
25
  embedsValidationStatus: EmbedsValidationStatus;
27
- } | null) => ((T["type"] extends keyof ElementShapes ? ElementShapes[T["type"]] | undefined : ElementShape | undefined) & ({} | null)) | (T["type"] extends keyof ElementShapes ? ElementShapes[T["type"]] : Drawable | null);
26
+ theme: AppState["theme"];
27
+ } | null) => ((T["type"] extends keyof ElementShapes ? ElementShapes[T["type"]] | undefined : ElementShape | undefined) & {}) | (T["type"] extends keyof ElementShapes ? ElementShapes[T["type"]] : Drawable | null);
28
28
  }
29
- export declare const generateRoughOptions: (element: ExcalidrawElement, continuousPath?: boolean) => Options;
29
+ export declare const generateRoughOptions: (element: ExcalidrawElement, continuousPath?: boolean, isDarkMode?: boolean) => Options;
30
30
  export declare const generateLinearCollisionShape: (element: ExcalidrawLinearElement | ExcalidrawFreeDrawElement) => {
31
31
  op: string;
32
32
  data: number[];
@@ -40,3 +40,4 @@ export declare const toggleLinePolygonState: (element: ExcalidrawLineElement, ne
40
40
  polygon: ExcalidrawLineElement["polygon"];
41
41
  points: ExcalidrawLineElement["points"];
42
42
  } | null;
43
+ export declare const getFreedrawOutlinePoints: (element: ExcalidrawFreeDrawElement) => [number, number][];