@dwelle/excalidraw 0.5.0-da1c822 → 0.5.0-e8bcd96

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 (462) hide show
  1. package/CHANGELOG.md +13 -2
  2. package/dist/browser/dev/excalidraw-assets-dev/{blockDiagram-91b80b7a-RHODGCTM.js → blockDiagram-91b80b7a-SWMOP5PL.js} +6 -6
  3. package/dist/browser/dev/excalidraw-assets-dev/{c4Diagram-b2a90758-W7NCR7LR.js → c4Diagram-b2a90758-N33A4OZ7.js} +4 -4
  4. package/dist/browser/dev/excalidraw-assets-dev/{chunk-TKRIVTWP.js → chunk-3XV32LTV.js} +3 -3
  5. package/dist/browser/dev/excalidraw-assets-dev/{chunk-B2MHJWXZ.js → chunk-CLMTS5EY.js} +2 -2
  6. package/dist/browser/dev/excalidraw-assets-dev/{chunk-QFS4M5OJ.js → chunk-DIDQ2KEW.js} +3 -3
  7. package/dist/browser/dev/excalidraw-assets-dev/{chunk-5747M6KP.js → chunk-G3PHSEXY.js} +3 -3
  8. package/dist/browser/dev/excalidraw-assets-dev/{chunk-PPHFJLL7.js → chunk-HCMMCBMX.js} +4 -4
  9. package/dist/browser/dev/excalidraw-assets-dev/{chunk-DQOPSCYA.js → chunk-K5QPOXOQ.js} +3 -3
  10. package/dist/browser/dev/excalidraw-assets-dev/{chunk-52OGG53V.js → chunk-KMSH7QAI.js} +3 -3
  11. package/dist/browser/dev/excalidraw-assets-dev/{chunk-SLLUETBM.js → chunk-TVSGJBCZ.js} +7 -7
  12. package/dist/browser/dev/excalidraw-assets-dev/{chunk-GPOYIZPX.js → chunk-UEFQKRSO.js} +28 -28
  13. package/dist/browser/dev/excalidraw-assets-dev/chunk-UEFQKRSO.js.map +7 -0
  14. package/dist/browser/dev/excalidraw-assets-dev/{chunk-BESQLMCW.js → chunk-UONPRRXT.js} +5 -5
  15. package/dist/browser/dev/excalidraw-assets-dev/{chunk-UETNA2WX.js → chunk-V6ITT7XZ.js} +7397 -5320
  16. package/dist/browser/dev/excalidraw-assets-dev/chunk-V6ITT7XZ.js.map +7 -0
  17. package/dist/browser/dev/excalidraw-assets-dev/{chunk-USLWOHUZ.js → chunk-VU32GUMX.js} +4 -4
  18. package/dist/browser/dev/excalidraw-assets-dev/{chunk-GF7VCOUM.js → chunk-WQNNVZHO.js} +3 -3
  19. package/dist/browser/dev/excalidraw-assets-dev/{chunk-GCA4S2OA.js → chunk-WXRCMPEJ.js} +3 -3
  20. package/dist/browser/dev/excalidraw-assets-dev/{chunk-J5HRUYQR.js → chunk-YGAE3YWH.js} +6 -4
  21. package/dist/browser/dev/excalidraw-assets-dev/chunk-YGAE3YWH.js.map +7 -0
  22. package/dist/browser/dev/excalidraw-assets-dev/{classDiagram-30eddba6-GJGBT4TV.js → classDiagram-30eddba6-HGXEWQY2.js} +6 -6
  23. package/dist/browser/dev/excalidraw-assets-dev/{classDiagram-v2-f2df5561-LYWTIPJA.js → classDiagram-v2-f2df5561-ANW5DGKP.js} +9 -9
  24. package/dist/browser/dev/excalidraw-assets-dev/{directory-open-01563666-UREMLRIT.js → directory-open-01563666-67XPRP2W.js} +2 -2
  25. package/dist/browser/dev/excalidraw-assets-dev/{directory-open-4ed118d0-UN3BUDZZ.js → directory-open-4ed118d0-TZOVUMX3.js} +2 -2
  26. package/dist/browser/dev/excalidraw-assets-dev/dist-JWLY7ZTC.js +10 -0
  27. package/dist/browser/dev/excalidraw-assets-dev/{en-UW5C5KGW.js → en-RSUSLGPV.js} +2 -2
  28. package/dist/browser/dev/excalidraw-assets-dev/{erDiagram-47591fe2-Z7U2XW2Y.js → erDiagram-47591fe2-HB4S6KST.js} +5 -5
  29. package/dist/browser/dev/excalidraw-assets-dev/{file-open-002ab408-4QG336MG.js → file-open-002ab408-ODQEDP24.js} +2 -2
  30. package/dist/browser/dev/excalidraw-assets-dev/{file-open-7c801643-3QI4ICCL.js → file-open-7c801643-RPLD6WZI.js} +2 -2
  31. package/dist/browser/dev/excalidraw-assets-dev/{file-save-3189631c-TNNERCWV.js → file-save-3189631c-63VHNBWZ.js} +2 -2
  32. package/dist/browser/dev/excalidraw-assets-dev/{file-save-745eba88-JFMH565P.js → file-save-745eba88-SJSX6XSD.js} +2 -2
  33. package/dist/browser/dev/excalidraw-assets-dev/{flowDiagram-5540d9b9-PARVG263.js → flowDiagram-5540d9b9-4QMRNUIV.js} +10 -10
  34. package/dist/browser/dev/excalidraw-assets-dev/{flowDiagram-v2-3b53844e-ZJOPVRMB.js → flowDiagram-v2-3b53844e-EH5O3NBM.js} +10 -10
  35. package/dist/browser/dev/excalidraw-assets-dev/{flowchart-elk-definition-5fe447d6-ULPNBSZX.js → flowchart-elk-definition-5fe447d6-7HGYBXUA.js} +6 -6
  36. package/dist/browser/dev/excalidraw-assets-dev/{ganttDiagram-9a3bba1f-ESSYVTJ4.js → ganttDiagram-9a3bba1f-V5WA3IP4.js} +3 -3
  37. package/dist/browser/dev/excalidraw-assets-dev/{gitGraphDiagram-96e6b4ee-6V6VVNNP.js → gitGraphDiagram-96e6b4ee-6JA3Z4O2.js} +3 -3
  38. package/dist/browser/dev/excalidraw-assets-dev/{image-3LTGFHLF.js → image-GHNRJPTS.js} +6 -6
  39. package/dist/browser/dev/excalidraw-assets-dev/{image-ZNQQXS62.css → image-JYKIJPJC.css} +49 -29
  40. package/dist/browser/dev/excalidraw-assets-dev/image-JYKIJPJC.css.map +7 -0
  41. package/dist/browser/dev/excalidraw-assets-dev/{image-blob-reduce.esm-KTX27DAY.js → image-blob-reduce.esm-QYPUYIZK.js} +2 -2
  42. package/dist/browser/dev/excalidraw-assets-dev/{infoDiagram-bcd20f53-I22FLFX3.js → infoDiagram-bcd20f53-24MBINO2.js} +3 -3
  43. package/dist/browser/dev/excalidraw-assets-dev/{journeyDiagram-4fe6b3dc-WAO6F52C.js → journeyDiagram-4fe6b3dc-KJ4YYJII.js} +4 -4
  44. package/dist/browser/dev/excalidraw-assets-dev/{katex-NWA2YFOP.js → katex-INYZI6LE.js} +2 -2
  45. package/dist/browser/dev/excalidraw-assets-dev/{mindmap-definition-f354de21-K74IKX4Y.js → mindmap-definition-f354de21-VZEH45PD.js} +4 -4
  46. package/dist/browser/dev/excalidraw-assets-dev/{pica-3TH2EGXR.js → pica-YQGHCBVI.js} +2 -2
  47. package/dist/browser/dev/excalidraw-assets-dev/{pieDiagram-79897490-DOB2LVE5.js → pieDiagram-79897490-Z2LCRKGQ.js} +3 -3
  48. package/dist/browser/dev/excalidraw-assets-dev/{quadrantDiagram-62f64e94-MJV2X7WI.js → quadrantDiagram-62f64e94-J3AFAFGX.js} +3 -3
  49. package/dist/browser/dev/excalidraw-assets-dev/{requirementDiagram-05bf5f74-H4YM3XN7.js → requirementDiagram-05bf5f74-M474HB6I.js} +5 -5
  50. package/dist/browser/dev/excalidraw-assets-dev/{roundRect-4S3QV2NZ.js → roundRect-ZCXXTYZ4.js} +2 -2
  51. package/dist/browser/dev/excalidraw-assets-dev/{sankeyDiagram-97764748-7X74ABAN.js → sankeyDiagram-97764748-TNQP5HMX.js} +3 -3
  52. package/dist/browser/dev/excalidraw-assets-dev/{sequenceDiagram-acc0e65c-PPDIJFQP.js → sequenceDiagram-acc0e65c-3NIA26ZM.js} +4 -4
  53. package/dist/browser/dev/excalidraw-assets-dev/{stateDiagram-0ff1cf1a-JVBR7N35.js → stateDiagram-0ff1cf1a-V6UXRWCT.js} +6 -6
  54. package/dist/browser/dev/excalidraw-assets-dev/{stateDiagram-v2-9a9d610d-QYAJLQJH.js → stateDiagram-v2-9a9d610d-7LTZXINB.js} +9 -9
  55. package/dist/browser/dev/excalidraw-assets-dev/{timeline-definition-fea2a41d-GL7U3WDB.js → timeline-definition-fea2a41d-X4VGA6IX.js} +3 -3
  56. package/dist/browser/dev/excalidraw-assets-dev/{xychartDiagram-ab372869-4U4JE4TW.js → xychartDiagram-ab372869-UQCQVK6J.js} +4 -4
  57. package/dist/browser/dev/index.css +48 -28
  58. package/dist/browser/dev/index.css.map +2 -2
  59. package/dist/browser/dev/index.js +9 -5
  60. package/dist/browser/prod/excalidraw-assets/{blockDiagram-91b80b7a-BO7MW3VX.js → blockDiagram-91b80b7a-2ADOK2UH.js} +1 -1
  61. package/dist/browser/prod/excalidraw-assets/{c4Diagram-b2a90758-VCUPBVHR.js → c4Diagram-b2a90758-XJ3HR543.js} +1 -1
  62. package/dist/browser/prod/excalidraw-assets/{chunk-VXFFPRP2.js → chunk-4X2EVGJW.js} +1 -1
  63. package/dist/browser/prod/excalidraw-assets/{chunk-5PWM36DG.js → chunk-5ARJLPSL.js} +1 -1
  64. package/dist/browser/prod/excalidraw-assets/{chunk-B7CDQVNY.js → chunk-6RDIDVV6.js} +21 -21
  65. package/dist/browser/prod/excalidraw-assets/chunk-AWDUHWKA.js +269 -0
  66. package/dist/browser/prod/excalidraw-assets/{chunk-V7HUISEN.js → chunk-COMJOADH.js} +1 -1
  67. package/dist/browser/prod/excalidraw-assets/{chunk-NM5B2RBP.js → chunk-DHU3NMWJ.js} +1 -1
  68. package/dist/browser/prod/excalidraw-assets/{chunk-4JYQ3563.js → chunk-FKEWZS6G.js} +1 -1
  69. package/dist/browser/prod/excalidraw-assets/{chunk-3VCRCP5J.js → chunk-GID7HY42.js} +1 -1
  70. package/dist/browser/prod/excalidraw-assets/{chunk-7UJZVYSR.js → chunk-H4K7WCAG.js} +1 -1
  71. package/dist/browser/prod/excalidraw-assets/{chunk-3HZHH3PT.js → chunk-PDA7IERE.js} +1 -1
  72. package/dist/browser/prod/excalidraw-assets/{chunk-O77Z7CWL.js → chunk-SCYMUHNO.js} +1 -1
  73. package/dist/browser/prod/excalidraw-assets/{chunk-QLNFR4AJ.js → chunk-SCZE4QLN.js} +2 -2
  74. package/dist/browser/prod/excalidraw-assets/{chunk-HPA5W5VE.js → chunk-Y4AVKYKK.js} +1 -1
  75. package/dist/browser/prod/excalidraw-assets/{chunk-CVEF66PS.js → chunk-YFHFEESB.js} +1 -1
  76. package/dist/browser/prod/excalidraw-assets/{chunk-22FVL4I7.js → chunk-Z4B7QXT2.js} +1 -1
  77. package/dist/browser/prod/excalidraw-assets/{classDiagram-30eddba6-VXGNM3LI.js → classDiagram-30eddba6-RQ6VHNNF.js} +1 -1
  78. package/dist/browser/prod/excalidraw-assets/{classDiagram-v2-f2df5561-YALTASVE.js → classDiagram-v2-f2df5561-TL3XYHL6.js} +1 -1
  79. package/dist/browser/prod/excalidraw-assets/{directory-open-01563666-JWXY2QSC.js → directory-open-01563666-ORBUXLUB.js} +1 -1
  80. package/dist/browser/prod/excalidraw-assets/{directory-open-4ed118d0-6AL5X37W.js → directory-open-4ed118d0-HRBZ4CD4.js} +1 -1
  81. package/dist/browser/prod/excalidraw-assets/dist-IRBESAGJ.js +1 -0
  82. package/dist/browser/prod/excalidraw-assets/{en-CPU3UVKT.js → en-SOC7FEW5.js} +1 -1
  83. package/dist/browser/prod/excalidraw-assets/{erDiagram-47591fe2-GKYANCN7.js → erDiagram-47591fe2-PBCROW3M.js} +1 -1
  84. package/dist/browser/prod/excalidraw-assets/{file-open-002ab408-3EPJOH45.js → file-open-002ab408-SRGK55ER.js} +1 -1
  85. package/dist/browser/prod/excalidraw-assets/{file-open-7c801643-QIP6HK4D.js → file-open-7c801643-IAPRROWG.js} +1 -1
  86. package/dist/browser/prod/excalidraw-assets/{file-save-3189631c-4TQJBQCS.js → file-save-3189631c-LO2KPJNL.js} +1 -1
  87. package/dist/browser/prod/excalidraw-assets/{file-save-745eba88-C4L3ZGCC.js → file-save-745eba88-2DRIRHNX.js} +1 -1
  88. package/dist/browser/prod/excalidraw-assets/{flowDiagram-5540d9b9-QBRW5SLP.js → flowDiagram-5540d9b9-6MWFBLXS.js} +1 -1
  89. package/dist/browser/prod/excalidraw-assets/flowDiagram-v2-3b53844e-CD6XHMHV.js +1 -0
  90. package/dist/browser/prod/excalidraw-assets/{flowchart-elk-definition-5fe447d6-YYO2EYKS.js → flowchart-elk-definition-5fe447d6-4UPGJKHJ.js} +1 -1
  91. package/dist/browser/prod/excalidraw-assets/{ganttDiagram-9a3bba1f-3B2DUUUQ.js → ganttDiagram-9a3bba1f-PDRTJQZH.js} +1 -1
  92. package/dist/browser/prod/excalidraw-assets/{gitGraphDiagram-96e6b4ee-G6CKXXWQ.js → gitGraphDiagram-96e6b4ee-3J3YSPOQ.js} +1 -1
  93. package/dist/browser/prod/excalidraw-assets/image-U235TWVW.css +1 -0
  94. package/dist/browser/prod/excalidraw-assets/image-ZYZR4L6P.js +1 -0
  95. package/dist/browser/prod/excalidraw-assets/{image-blob-reduce.esm-5DTGAOOI.js → image-blob-reduce.esm-XVCS6NNL.js} +1 -1
  96. package/dist/browser/prod/excalidraw-assets/{infoDiagram-bcd20f53-WJTZJERL.js → infoDiagram-bcd20f53-DVJQEG4I.js} +1 -1
  97. package/dist/browser/prod/excalidraw-assets/{journeyDiagram-4fe6b3dc-JF22KXXQ.js → journeyDiagram-4fe6b3dc-ASSTFADN.js} +1 -1
  98. package/dist/browser/prod/excalidraw-assets/{katex-N6R5DPQX.js → katex-RDNZD65H.js} +1 -1
  99. package/dist/browser/prod/excalidraw-assets/{mindmap-definition-f354de21-7SH5STU3.js → mindmap-definition-f354de21-4Y6OYM5B.js} +1 -1
  100. package/dist/browser/prod/excalidraw-assets/{pica-KWHN2PJ6.js → pica-P43LGTW6.js} +1 -1
  101. package/dist/browser/prod/excalidraw-assets/{pieDiagram-79897490-5O5EBEQB.js → pieDiagram-79897490-XJXBVFLX.js} +1 -1
  102. package/dist/browser/prod/excalidraw-assets/{quadrantDiagram-62f64e94-JTY6WOKB.js → quadrantDiagram-62f64e94-PC5DTCKV.js} +1 -1
  103. package/dist/browser/prod/excalidraw-assets/{requirementDiagram-05bf5f74-TSFQFY5X.js → requirementDiagram-05bf5f74-ILVOGHRN.js} +1 -1
  104. package/dist/browser/prod/excalidraw-assets/{roundRect-PUCZURYS.js → roundRect-HU3IUMCJ.js} +1 -1
  105. package/dist/browser/prod/excalidraw-assets/{sankeyDiagram-97764748-7G2R6W67.js → sankeyDiagram-97764748-SC5VBCT5.js} +1 -1
  106. package/dist/browser/prod/excalidraw-assets/{sequenceDiagram-acc0e65c-CTANNZCO.js → sequenceDiagram-acc0e65c-MFG2JCTS.js} +1 -1
  107. package/dist/browser/prod/excalidraw-assets/{stateDiagram-0ff1cf1a-I5COLKZ4.js → stateDiagram-0ff1cf1a-2HXG5RCM.js} +1 -1
  108. package/dist/browser/prod/excalidraw-assets/{stateDiagram-v2-9a9d610d-IIHI3AJN.js → stateDiagram-v2-9a9d610d-PKXRQ3RV.js} +1 -1
  109. package/dist/browser/prod/excalidraw-assets/{timeline-definition-fea2a41d-CXTGKWI4.js → timeline-definition-fea2a41d-LOYYYOFB.js} +1 -1
  110. package/dist/browser/prod/excalidraw-assets/{xychartDiagram-ab372869-QZGPPHJP.js → xychartDiagram-ab372869-LYHM7ECI.js} +1 -1
  111. package/dist/browser/prod/index.css +1 -1
  112. package/dist/browser/prod/index.js +1 -1
  113. package/dist/dev/{en-R7FEFJGC.json → en-GM5O55AO.json} +5 -3
  114. package/dist/dev/index.css +48 -28
  115. package/dist/dev/index.css.map +2 -2
  116. package/dist/dev/index.js +5324 -3292
  117. package/dist/dev/index.js.map +4 -4
  118. package/dist/excalidraw/actions/actionAddToLibrary.d.ts +4 -4
  119. package/dist/excalidraw/actions/actionAddToLibrary.js +4 -3
  120. package/dist/excalidraw/actions/actionAlign.d.ts +22 -22
  121. package/dist/excalidraw/actions/actionAlign.js +7 -6
  122. package/dist/excalidraw/actions/actionBoundText.d.ts +10 -10
  123. package/dist/excalidraw/actions/actionBoundText.js +11 -5
  124. package/dist/excalidraw/actions/actionCanvas.d.ts +52 -52
  125. package/dist/excalidraw/actions/actionCanvas.js +16 -13
  126. package/dist/excalidraw/actions/actionClipboard.d.ts +24 -24
  127. package/dist/excalidraw/actions/actionClipboard.js +14 -13
  128. package/dist/excalidraw/actions/actionDeleteSelected.d.ts +10 -10
  129. package/dist/excalidraw/actions/actionDeleteSelected.js +6 -3
  130. package/dist/excalidraw/actions/actionDistribute.d.ts +10 -10
  131. package/dist/excalidraw/actions/actionDistribute.js +3 -2
  132. package/dist/excalidraw/actions/actionDuplicateSelection.d.ts +7 -8
  133. package/dist/excalidraw/actions/actionDuplicateSelection.js +7 -3
  134. package/dist/excalidraw/actions/actionElementLock.d.ts +9 -9
  135. package/dist/excalidraw/actions/actionElementLock.js +3 -2
  136. package/dist/excalidraw/actions/actionExport.d.ts +37 -37
  137. package/dist/excalidraw/actions/actionExport.js +15 -11
  138. package/dist/excalidraw/actions/actionFinalize.d.ts +9 -9
  139. package/dist/excalidraw/actions/actionFinalize.js +9 -5
  140. package/dist/excalidraw/actions/actionFlip.d.ts +10 -10
  141. package/dist/excalidraw/actions/actionFlip.js +12 -12
  142. package/dist/excalidraw/actions/actionFrame.d.ts +16 -171
  143. package/dist/excalidraw/actions/actionFrame.js +7 -6
  144. package/dist/excalidraw/actions/actionGroup.d.ts +12 -322
  145. package/dist/excalidraw/actions/actionGroup.js +9 -11
  146. package/dist/excalidraw/actions/actionHistory.d.ts +4 -3
  147. package/dist/excalidraw/actions/actionHistory.js +27 -28
  148. package/dist/excalidraw/actions/actionLinearEditor.d.ts +6 -4
  149. package/dist/excalidraw/actions/actionLinearEditor.js +21 -5
  150. package/dist/excalidraw/actions/actionLink.d.ts +5 -5
  151. package/dist/excalidraw/actions/actionLink.js +2 -1
  152. package/dist/excalidraw/actions/actionMenu.d.ts +8 -8
  153. package/dist/excalidraw/actions/actionMenu.js +4 -3
  154. package/dist/excalidraw/actions/actionNavigate.d.ts +4 -4
  155. package/dist/excalidraw/actions/actionNavigate.js +3 -2
  156. package/dist/excalidraw/actions/actionProperties.d.ts +34 -34
  157. package/dist/excalidraw/actions/actionProperties.js +19 -14
  158. package/dist/excalidraw/actions/actionSelectAll.d.ts +5 -5
  159. package/dist/excalidraw/actions/actionSelectAll.js +2 -1
  160. package/dist/excalidraw/actions/actionStyles.d.ts +9 -12
  161. package/dist/excalidraw/actions/actionStyles.js +4 -3
  162. package/dist/excalidraw/actions/actionTextAutoResize.d.ts +17 -0
  163. package/dist/excalidraw/actions/actionTextAutoResize.js +38 -0
  164. package/dist/excalidraw/actions/actionToggleGridMode.d.ts +7 -5
  165. package/dist/excalidraw/actions/actionToggleGridMode.js +6 -2
  166. package/dist/excalidraw/actions/actionToggleObjectsSnapMode.d.ts +4 -4
  167. package/dist/excalidraw/actions/actionToggleObjectsSnapMode.js +2 -1
  168. package/dist/excalidraw/actions/actionToggleStats.d.ts +4 -4
  169. package/dist/excalidraw/actions/actionToggleStats.js +2 -1
  170. package/dist/excalidraw/actions/actionToggleViewMode.d.ts +4 -4
  171. package/dist/excalidraw/actions/actionToggleViewMode.js +2 -1
  172. package/dist/excalidraw/actions/actionToggleZenMode.d.ts +4 -4
  173. package/dist/excalidraw/actions/actionToggleZenMode.js +2 -1
  174. package/dist/excalidraw/actions/actionZindex.d.ts +23 -19
  175. package/dist/excalidraw/actions/actionZindex.js +9 -4
  176. package/dist/excalidraw/actions/manager.d.ts +5 -5
  177. package/dist/excalidraw/actions/register.d.ts +1 -1
  178. package/dist/excalidraw/actions/shortcuts.d.ts +2 -2
  179. package/dist/excalidraw/actions/types.d.ts +8 -8
  180. package/dist/excalidraw/align.d.ts +1 -1
  181. package/dist/excalidraw/animated-trail.d.ts +2 -2
  182. package/dist/excalidraw/appState.d.ts +6 -6
  183. package/dist/excalidraw/change.d.ts +191 -0
  184. package/dist/excalidraw/change.js +894 -0
  185. package/dist/excalidraw/charts.d.ts +1 -1
  186. package/dist/excalidraw/clients.d.ts +2 -2
  187. package/dist/excalidraw/clients.js +1 -1
  188. package/dist/excalidraw/clipboard.d.ts +3 -3
  189. package/dist/excalidraw/colors.d.ts +1 -1
  190. package/dist/excalidraw/components/Actions.d.ts +3 -3
  191. package/dist/excalidraw/components/Actions.js +8 -5
  192. package/dist/excalidraw/components/App.d.ts +28 -14
  193. package/dist/excalidraw/components/App.js +385 -177
  194. package/dist/excalidraw/components/ColorPicker/ColorInput.d.ts +1 -1
  195. package/dist/excalidraw/components/ColorPicker/ColorInput.js +1 -1
  196. package/dist/excalidraw/components/ColorPicker/ColorPicker.d.ts +4 -4
  197. package/dist/excalidraw/components/ColorPicker/ColorPicker.js +1 -1
  198. package/dist/excalidraw/components/ColorPicker/Picker.d.ts +3 -3
  199. package/dist/excalidraw/components/ColorPicker/PickerColorList.d.ts +1 -1
  200. package/dist/excalidraw/components/ColorPicker/PickerHeading.d.ts +1 -1
  201. package/dist/excalidraw/components/ColorPicker/ShadeList.d.ts +1 -1
  202. package/dist/excalidraw/components/ColorPicker/TopPicks.d.ts +1 -1
  203. package/dist/excalidraw/components/ColorPicker/colorPickerUtils.d.ts +2 -2
  204. package/dist/excalidraw/components/ColorPicker/colorPickerUtils.js +1 -1
  205. package/dist/excalidraw/components/ColorPicker/keyboardNavHandlers.d.ts +2 -2
  206. package/dist/excalidraw/components/ColorPicker/keyboardNavHandlers.js +1 -1
  207. package/dist/excalidraw/components/CommandPalette/CommandPalette.d.ts +1 -1
  208. package/dist/excalidraw/components/CommandPalette/CommandPalette.js +6 -5
  209. package/dist/excalidraw/components/CommandPalette/defaultCommandPaletteItems.d.ts +1 -1
  210. package/dist/excalidraw/components/CommandPalette/types.d.ts +3 -3
  211. package/dist/excalidraw/components/ConfirmDialog.d.ts +1 -1
  212. package/dist/excalidraw/components/ContextMenu.d.ts +2 -2
  213. package/dist/excalidraw/components/ContextMenu.js +1 -1
  214. package/dist/excalidraw/components/DarkModeToggle.d.ts +1 -1
  215. package/dist/excalidraw/components/DefaultSidebar.d.ts +2 -2
  216. package/dist/excalidraw/components/DialogActionButton.d.ts +1 -1
  217. package/dist/excalidraw/components/EyeDropper.d.ts +2 -2
  218. package/dist/excalidraw/components/FollowMode/FollowMode.d.ts +1 -1
  219. package/dist/excalidraw/components/HelpDialog.js +1 -1
  220. package/dist/excalidraw/components/HintViewer.d.ts +1 -1
  221. package/dist/excalidraw/components/ImageExportDialog.d.ts +1 -1
  222. package/dist/excalidraw/components/InitializeApp.d.ts +2 -2
  223. package/dist/excalidraw/components/JSONExportDialog.d.ts +3 -3
  224. package/dist/excalidraw/components/LayerUI.d.ts +4 -4
  225. package/dist/excalidraw/components/LayerUI.js +1 -1
  226. package/dist/excalidraw/components/LibraryMenu.d.ts +2 -2
  227. package/dist/excalidraw/components/LibraryMenuBrowseButton.d.ts +1 -1
  228. package/dist/excalidraw/components/LibraryMenuControlButtons.d.ts +1 -1
  229. package/dist/excalidraw/components/LibraryMenuHeaderContent.d.ts +2 -2
  230. package/dist/excalidraw/components/LibraryMenuItems.d.ts +1 -1
  231. package/dist/excalidraw/components/LibraryMenuSection.d.ts +5 -4
  232. package/dist/excalidraw/components/LibraryUnit.d.ts +2 -2
  233. package/dist/excalidraw/components/LoadingMessage.d.ts +1 -1
  234. package/dist/excalidraw/components/MagicSettings.js +2 -2
  235. package/dist/excalidraw/components/MobileMenu.d.ts +3 -3
  236. package/dist/excalidraw/components/Modal.d.ts +1 -1
  237. package/dist/excalidraw/components/OverwriteConfirm/OverwriteConfirmState.d.ts +1 -1
  238. package/dist/excalidraw/components/PasteChartDialog.d.ts +1 -1
  239. package/dist/excalidraw/components/PublishLibrary.d.ts +1 -1
  240. package/dist/excalidraw/components/SVGLayer.d.ts +1 -1
  241. package/dist/excalidraw/components/Sidebar/Sidebar.d.ts +2 -2
  242. package/dist/excalidraw/components/Sidebar/Sidebar.js +1 -1
  243. package/dist/excalidraw/components/Sidebar/SidebarTab.d.ts +1 -1
  244. package/dist/excalidraw/components/Sidebar/SidebarTabTrigger.d.ts +1 -1
  245. package/dist/excalidraw/components/Sidebar/SidebarTrigger.d.ts +1 -1
  246. package/dist/excalidraw/components/Sidebar/common.d.ts +1 -1
  247. package/dist/excalidraw/components/Stack.d.ts +2 -2
  248. package/dist/excalidraw/components/Stats.d.ts +2 -2
  249. package/dist/excalidraw/components/TTDDialog/MermaidToExcalidraw.d.ts +1 -1
  250. package/dist/excalidraw/components/TTDDialog/TTDDialog.js +2 -2
  251. package/dist/excalidraw/components/TTDDialog/TTDDialogInput.d.ts +1 -1
  252. package/dist/excalidraw/components/TTDDialog/TTDDialogPanel.d.ts +1 -1
  253. package/dist/excalidraw/components/TTDDialog/TTDDialogPanels.d.ts +1 -1
  254. package/dist/excalidraw/components/TTDDialog/TTDDialogTabs.d.ts +1 -1
  255. package/dist/excalidraw/components/TTDDialog/TTDDialogTrigger.d.ts +1 -1
  256. package/dist/excalidraw/components/TTDDialog/common.d.ts +4 -4
  257. package/dist/excalidraw/components/TextField.d.ts +1 -1
  258. package/dist/excalidraw/components/Toast.d.ts +1 -1
  259. package/dist/excalidraw/components/ToolButton.d.ts +4 -2
  260. package/dist/excalidraw/components/ToolButton.js +1 -1
  261. package/dist/excalidraw/components/Trans.d.ts +1 -1
  262. package/dist/excalidraw/components/UserList.d.ts +1 -1
  263. package/dist/excalidraw/components/canvases/InteractiveCanvas.d.ts +3 -2
  264. package/dist/excalidraw/components/canvases/InteractiveCanvas.js +3 -2
  265. package/dist/excalidraw/components/canvases/StaticCanvas.d.ts +2 -2
  266. package/dist/excalidraw/components/canvases/StaticCanvas.js +2 -2
  267. package/dist/excalidraw/components/dropdownMenu/DropdownMenuItem.js +2 -2
  268. package/dist/excalidraw/components/footer/Footer.d.ts +2 -2
  269. package/dist/excalidraw/components/hyperlink/Hyperlink.d.ts +2 -2
  270. package/dist/excalidraw/components/hyperlink/Hyperlink.js +3 -3
  271. package/dist/excalidraw/components/hyperlink/helpers.d.ts +3 -3
  272. package/dist/excalidraw/components/hyperlink/helpers.js +2 -3
  273. package/dist/excalidraw/components/icons.d.ts +4 -2
  274. package/dist/excalidraw/components/icons.js +20 -6
  275. package/dist/excalidraw/components/main-menu/DefaultItems.d.ts +1 -1
  276. package/dist/excalidraw/constants.d.ts +5 -5
  277. package/dist/excalidraw/constants.js +6 -3
  278. package/dist/excalidraw/context/ui-appState.d.ts +1 -1
  279. package/dist/excalidraw/cursor.d.ts +1 -1
  280. package/dist/excalidraw/data/EditorLocalStorage.d.ts +2 -2
  281. package/dist/excalidraw/data/blob.d.ts +5 -5
  282. package/dist/excalidraw/data/filesystem.d.ts +2 -1
  283. package/dist/excalidraw/data/index.d.ts +4 -4
  284. package/dist/excalidraw/data/json.d.ts +3 -3
  285. package/dist/excalidraw/data/library.d.ts +3 -3
  286. package/dist/excalidraw/data/magic.d.ts +3 -3
  287. package/dist/excalidraw/data/reconcile.d.ts +6 -0
  288. package/dist/excalidraw/data/reconcile.js +49 -0
  289. package/dist/excalidraw/data/resave.d.ts +2 -2
  290. package/dist/excalidraw/data/resave.js +1 -1
  291. package/dist/excalidraw/data/restore.d.ts +5 -5
  292. package/dist/excalidraw/data/restore.js +7 -7
  293. package/dist/excalidraw/data/transform.d.ts +4 -4
  294. package/dist/excalidraw/data/transform.js +4 -3
  295. package/dist/excalidraw/data/types.d.ts +3 -3
  296. package/dist/excalidraw/data/url.d.ts +1 -0
  297. package/dist/excalidraw/data/url.js +4 -1
  298. package/dist/excalidraw/element/ElementCanvasButtons.d.ts +1 -1
  299. package/dist/excalidraw/element/binding.d.ts +50 -9
  300. package/dist/excalidraw/element/binding.js +712 -155
  301. package/dist/excalidraw/element/bounds.d.ts +3 -4
  302. package/dist/excalidraw/element/bounds.js +0 -3
  303. package/dist/excalidraw/element/collision.d.ts +14 -19
  304. package/dist/excalidraw/element/collision.js +36 -713
  305. package/dist/excalidraw/element/containerCache.d.ts +1 -1
  306. package/dist/excalidraw/element/dragElements.d.ts +3 -3
  307. package/dist/excalidraw/element/embeddable.d.ts +9 -6
  308. package/dist/excalidraw/element/embeddable.js +88 -27
  309. package/dist/excalidraw/element/image.d.ts +2 -2
  310. package/dist/excalidraw/element/index.d.ts +2 -3
  311. package/dist/excalidraw/element/index.js +1 -2
  312. package/dist/excalidraw/element/linearElementEditor.d.ts +12 -12
  313. package/dist/excalidraw/element/linearElementEditor.js +7 -5
  314. package/dist/excalidraw/element/mutateElement.d.ts +4 -5
  315. package/dist/excalidraw/element/mutateElement.js +5 -3
  316. package/dist/excalidraw/element/newElement.d.ts +4 -9
  317. package/dist/excalidraw/element/newElement.js +17 -14
  318. package/dist/excalidraw/element/resizeElements.d.ts +4 -4
  319. package/dist/excalidraw/element/resizeElements.js +170 -97
  320. package/dist/excalidraw/element/resizeTest.d.ts +7 -7
  321. package/dist/excalidraw/element/resizeTest.js +53 -8
  322. package/dist/excalidraw/element/showSelectedShapeActions.d.ts +2 -2
  323. package/dist/excalidraw/element/sizeHelpers.d.ts +2 -2
  324. package/dist/excalidraw/element/sizeHelpers.js +3 -0
  325. package/dist/excalidraw/element/sortElements.d.ts +1 -1
  326. package/dist/excalidraw/element/textElement.d.ts +5 -6
  327. package/dist/excalidraw/element/textElement.js +13 -37
  328. package/dist/excalidraw/element/textWysiwyg.d.ts +10 -5
  329. package/dist/excalidraw/element/textWysiwyg.js +6 -8
  330. package/dist/excalidraw/element/transformHandles.d.ts +24 -6
  331. package/dist/excalidraw/element/transformHandles.js +22 -11
  332. package/dist/excalidraw/element/typeChecks.d.ts +4 -4
  333. package/dist/excalidraw/element/types.d.ts +30 -10
  334. package/dist/excalidraw/emitter.d.ts +1 -1
  335. package/dist/excalidraw/errors.d.ts +3 -0
  336. package/dist/excalidraw/errors.js +3 -0
  337. package/dist/excalidraw/fractionalIndex.d.ts +40 -0
  338. package/dist/excalidraw/fractionalIndex.js +241 -0
  339. package/dist/excalidraw/frame.d.ts +4 -4
  340. package/dist/excalidraw/gatransforms.d.ts +1 -1
  341. package/dist/excalidraw/gesture.d.ts +1 -1
  342. package/dist/excalidraw/groups.d.ts +5 -3
  343. package/dist/excalidraw/groups.js +17 -0
  344. package/dist/excalidraw/history.d.ts +35 -47
  345. package/dist/excalidraw/history.js +100 -167
  346. package/dist/excalidraw/hooks/useEmitter.d.ts +2 -0
  347. package/dist/excalidraw/hooks/useEmitter.js +13 -0
  348. package/dist/excalidraw/hooks/useLibraryItemSvg.d.ts +1 -1
  349. package/dist/excalidraw/i18n.d.ts +1 -1
  350. package/dist/excalidraw/index.d.ts +3 -1
  351. package/dist/excalidraw/index.js +2 -0
  352. package/dist/excalidraw/jotai.d.ts +1 -1
  353. package/dist/excalidraw/laser-trails.d.ts +3 -2
  354. package/dist/excalidraw/locales/en.json +5 -3
  355. package/dist/excalidraw/math.d.ts +2 -2
  356. package/dist/excalidraw/points.d.ts +1 -1
  357. package/dist/excalidraw/queue.d.ts +1 -1
  358. package/dist/excalidraw/renderer/helpers.d.ts +2 -2
  359. package/dist/excalidraw/renderer/interactiveScene.d.ts +2 -2
  360. package/dist/excalidraw/renderer/interactiveScene.js +8 -7
  361. package/dist/excalidraw/renderer/renderElement.d.ts +3 -3
  362. package/dist/excalidraw/renderer/renderElement.js +2 -2
  363. package/dist/excalidraw/renderer/renderSnaps.d.ts +1 -1
  364. package/dist/excalidraw/renderer/staticScene.d.ts +1 -1
  365. package/dist/excalidraw/renderer/staticScene.js +14 -3
  366. package/dist/excalidraw/renderer/staticSvgScene.d.ts +4 -4
  367. package/dist/excalidraw/renderer/staticSvgScene.js +10 -0
  368. package/dist/excalidraw/scene/Fonts.d.ts +2 -4
  369. package/dist/excalidraw/scene/Fonts.js +6 -12
  370. package/dist/excalidraw/scene/Renderer.d.ts +4 -4
  371. package/dist/excalidraw/scene/Renderer.js +2 -3
  372. package/dist/excalidraw/scene/Scene.d.ts +19 -12
  373. package/dist/excalidraw/scene/Scene.js +44 -23
  374. package/dist/excalidraw/scene/Shape.d.ts +1 -1
  375. package/dist/excalidraw/scene/ShapeCache.d.ts +5 -4
  376. package/dist/excalidraw/scene/comparisons.d.ts +2 -2
  377. package/dist/excalidraw/scene/export.d.ts +3 -3
  378. package/dist/excalidraw/scene/export.js +4 -3
  379. package/dist/excalidraw/scene/scroll.d.ts +2 -2
  380. package/dist/excalidraw/scene/scrollbars.d.ts +3 -3
  381. package/dist/excalidraw/scene/selection.d.ts +2 -2
  382. package/dist/excalidraw/scene/types.d.ts +5 -4
  383. package/dist/excalidraw/scene/zoom.d.ts +1 -1
  384. package/dist/excalidraw/snapping.d.ts +4 -4
  385. package/dist/excalidraw/store.d.ts +99 -0
  386. package/dist/excalidraw/store.js +269 -0
  387. package/dist/excalidraw/types.d.ts +33 -19
  388. package/dist/excalidraw/utils.d.ts +10 -4
  389. package/dist/excalidraw/utils.js +7 -0
  390. package/dist/excalidraw/zindex.d.ts +4 -4
  391. package/dist/excalidraw/zindex.js +9 -13
  392. package/dist/prod/{en-R7FEFJGC.json → en-GM5O55AO.json} +5 -3
  393. package/dist/prod/index.css +1 -1
  394. package/dist/prod/index.js +44 -44
  395. package/dist/utils/bbox.d.ts +2 -2
  396. package/dist/utils/collision.d.ts +4 -0
  397. package/dist/utils/collision.js +48 -0
  398. package/dist/utils/export.d.ts +1 -1
  399. package/dist/utils/geometry/geometry.d.ts +71 -0
  400. package/dist/utils/geometry/geometry.js +674 -0
  401. package/dist/utils/geometry/shape.d.ts +56 -0
  402. package/dist/utils/geometry/shape.js +168 -0
  403. package/dist/utils/withinBounds.d.ts +1 -1
  404. package/history.ts +163 -218
  405. package/package.json +2 -1
  406. package/dist/browser/dev/excalidraw-assets-dev/chunk-GPOYIZPX.js.map +0 -7
  407. package/dist/browser/dev/excalidraw-assets-dev/chunk-J5HRUYQR.js.map +0 -7
  408. package/dist/browser/dev/excalidraw-assets-dev/chunk-UETNA2WX.js.map +0 -7
  409. package/dist/browser/dev/excalidraw-assets-dev/dist-Y7S5GOTG.js +0 -10
  410. package/dist/browser/dev/excalidraw-assets-dev/image-ZNQQXS62.css.map +0 -7
  411. package/dist/browser/prod/excalidraw-assets/chunk-EEN6AFMH.js +0 -269
  412. package/dist/browser/prod/excalidraw-assets/dist-7FHVDAZ2.js +0 -1
  413. package/dist/browser/prod/excalidraw-assets/flowDiagram-v2-3b53844e-CRHRHP7H.js +0 -1
  414. package/dist/browser/prod/excalidraw-assets/image-VXYNPVOG.js +0 -1
  415. package/dist/browser/prod/excalidraw-assets/image-WE6NA2G6.css +0 -1
  416. /package/dist/browser/dev/excalidraw-assets-dev/{blockDiagram-91b80b7a-RHODGCTM.js.map → blockDiagram-91b80b7a-SWMOP5PL.js.map} +0 -0
  417. /package/dist/browser/dev/excalidraw-assets-dev/{c4Diagram-b2a90758-W7NCR7LR.js.map → c4Diagram-b2a90758-N33A4OZ7.js.map} +0 -0
  418. /package/dist/browser/dev/excalidraw-assets-dev/{chunk-TKRIVTWP.js.map → chunk-3XV32LTV.js.map} +0 -0
  419. /package/dist/browser/dev/excalidraw-assets-dev/{chunk-B2MHJWXZ.js.map → chunk-CLMTS5EY.js.map} +0 -0
  420. /package/dist/browser/dev/excalidraw-assets-dev/{chunk-QFS4M5OJ.js.map → chunk-DIDQ2KEW.js.map} +0 -0
  421. /package/dist/browser/dev/excalidraw-assets-dev/{chunk-5747M6KP.js.map → chunk-G3PHSEXY.js.map} +0 -0
  422. /package/dist/browser/dev/excalidraw-assets-dev/{chunk-PPHFJLL7.js.map → chunk-HCMMCBMX.js.map} +0 -0
  423. /package/dist/browser/dev/excalidraw-assets-dev/{chunk-DQOPSCYA.js.map → chunk-K5QPOXOQ.js.map} +0 -0
  424. /package/dist/browser/dev/excalidraw-assets-dev/{chunk-52OGG53V.js.map → chunk-KMSH7QAI.js.map} +0 -0
  425. /package/dist/browser/dev/excalidraw-assets-dev/{chunk-SLLUETBM.js.map → chunk-TVSGJBCZ.js.map} +0 -0
  426. /package/dist/browser/dev/excalidraw-assets-dev/{chunk-BESQLMCW.js.map → chunk-UONPRRXT.js.map} +0 -0
  427. /package/dist/browser/dev/excalidraw-assets-dev/{chunk-USLWOHUZ.js.map → chunk-VU32GUMX.js.map} +0 -0
  428. /package/dist/browser/dev/excalidraw-assets-dev/{chunk-GF7VCOUM.js.map → chunk-WQNNVZHO.js.map} +0 -0
  429. /package/dist/browser/dev/excalidraw-assets-dev/{chunk-GCA4S2OA.js.map → chunk-WXRCMPEJ.js.map} +0 -0
  430. /package/dist/browser/dev/excalidraw-assets-dev/{classDiagram-30eddba6-GJGBT4TV.js.map → classDiagram-30eddba6-HGXEWQY2.js.map} +0 -0
  431. /package/dist/browser/dev/excalidraw-assets-dev/{classDiagram-v2-f2df5561-LYWTIPJA.js.map → classDiagram-v2-f2df5561-ANW5DGKP.js.map} +0 -0
  432. /package/dist/browser/dev/excalidraw-assets-dev/{directory-open-01563666-UREMLRIT.js.map → directory-open-01563666-67XPRP2W.js.map} +0 -0
  433. /package/dist/browser/dev/excalidraw-assets-dev/{directory-open-4ed118d0-UN3BUDZZ.js.map → directory-open-4ed118d0-TZOVUMX3.js.map} +0 -0
  434. /package/dist/browser/dev/excalidraw-assets-dev/{dist-Y7S5GOTG.js.map → dist-JWLY7ZTC.js.map} +0 -0
  435. /package/dist/browser/dev/excalidraw-assets-dev/{en-UW5C5KGW.js.map → en-RSUSLGPV.js.map} +0 -0
  436. /package/dist/browser/dev/excalidraw-assets-dev/{erDiagram-47591fe2-Z7U2XW2Y.js.map → erDiagram-47591fe2-HB4S6KST.js.map} +0 -0
  437. /package/dist/browser/dev/excalidraw-assets-dev/{file-open-002ab408-4QG336MG.js.map → file-open-002ab408-ODQEDP24.js.map} +0 -0
  438. /package/dist/browser/dev/excalidraw-assets-dev/{file-open-7c801643-3QI4ICCL.js.map → file-open-7c801643-RPLD6WZI.js.map} +0 -0
  439. /package/dist/browser/dev/excalidraw-assets-dev/{file-save-3189631c-TNNERCWV.js.map → file-save-3189631c-63VHNBWZ.js.map} +0 -0
  440. /package/dist/browser/dev/excalidraw-assets-dev/{file-save-745eba88-JFMH565P.js.map → file-save-745eba88-SJSX6XSD.js.map} +0 -0
  441. /package/dist/browser/dev/excalidraw-assets-dev/{flowDiagram-5540d9b9-PARVG263.js.map → flowDiagram-5540d9b9-4QMRNUIV.js.map} +0 -0
  442. /package/dist/browser/dev/excalidraw-assets-dev/{flowDiagram-v2-3b53844e-ZJOPVRMB.js.map → flowDiagram-v2-3b53844e-EH5O3NBM.js.map} +0 -0
  443. /package/dist/browser/dev/excalidraw-assets-dev/{flowchart-elk-definition-5fe447d6-ULPNBSZX.js.map → flowchart-elk-definition-5fe447d6-7HGYBXUA.js.map} +0 -0
  444. /package/dist/browser/dev/excalidraw-assets-dev/{ganttDiagram-9a3bba1f-ESSYVTJ4.js.map → ganttDiagram-9a3bba1f-V5WA3IP4.js.map} +0 -0
  445. /package/dist/browser/dev/excalidraw-assets-dev/{gitGraphDiagram-96e6b4ee-6V6VVNNP.js.map → gitGraphDiagram-96e6b4ee-6JA3Z4O2.js.map} +0 -0
  446. /package/dist/browser/dev/excalidraw-assets-dev/{image-3LTGFHLF.js.map → image-GHNRJPTS.js.map} +0 -0
  447. /package/dist/browser/dev/excalidraw-assets-dev/{image-blob-reduce.esm-KTX27DAY.js.map → image-blob-reduce.esm-QYPUYIZK.js.map} +0 -0
  448. /package/dist/browser/dev/excalidraw-assets-dev/{infoDiagram-bcd20f53-I22FLFX3.js.map → infoDiagram-bcd20f53-24MBINO2.js.map} +0 -0
  449. /package/dist/browser/dev/excalidraw-assets-dev/{journeyDiagram-4fe6b3dc-WAO6F52C.js.map → journeyDiagram-4fe6b3dc-KJ4YYJII.js.map} +0 -0
  450. /package/dist/browser/dev/excalidraw-assets-dev/{katex-NWA2YFOP.js.map → katex-INYZI6LE.js.map} +0 -0
  451. /package/dist/browser/dev/excalidraw-assets-dev/{mindmap-definition-f354de21-K74IKX4Y.js.map → mindmap-definition-f354de21-VZEH45PD.js.map} +0 -0
  452. /package/dist/browser/dev/excalidraw-assets-dev/{pica-3TH2EGXR.js.map → pica-YQGHCBVI.js.map} +0 -0
  453. /package/dist/browser/dev/excalidraw-assets-dev/{pieDiagram-79897490-DOB2LVE5.js.map → pieDiagram-79897490-Z2LCRKGQ.js.map} +0 -0
  454. /package/dist/browser/dev/excalidraw-assets-dev/{quadrantDiagram-62f64e94-MJV2X7WI.js.map → quadrantDiagram-62f64e94-J3AFAFGX.js.map} +0 -0
  455. /package/dist/browser/dev/excalidraw-assets-dev/{requirementDiagram-05bf5f74-H4YM3XN7.js.map → requirementDiagram-05bf5f74-M474HB6I.js.map} +0 -0
  456. /package/dist/browser/dev/excalidraw-assets-dev/{roundRect-4S3QV2NZ.js.map → roundRect-ZCXXTYZ4.js.map} +0 -0
  457. /package/dist/browser/dev/excalidraw-assets-dev/{sankeyDiagram-97764748-7X74ABAN.js.map → sankeyDiagram-97764748-TNQP5HMX.js.map} +0 -0
  458. /package/dist/browser/dev/excalidraw-assets-dev/{sequenceDiagram-acc0e65c-PPDIJFQP.js.map → sequenceDiagram-acc0e65c-3NIA26ZM.js.map} +0 -0
  459. /package/dist/browser/dev/excalidraw-assets-dev/{stateDiagram-0ff1cf1a-JVBR7N35.js.map → stateDiagram-0ff1cf1a-V6UXRWCT.js.map} +0 -0
  460. /package/dist/browser/dev/excalidraw-assets-dev/{stateDiagram-v2-9a9d610d-QYAJLQJH.js.map → stateDiagram-v2-9a9d610d-7LTZXINB.js.map} +0 -0
  461. /package/dist/browser/dev/excalidraw-assets-dev/{timeline-definition-fea2a41d-GL7U3WDB.js.map → timeline-definition-fea2a41d-X4VGA6IX.js.map} +0 -0
  462. /package/dist/browser/dev/excalidraw-assets-dev/{xychartDiagram-ab372869-4U4JE4TW.js.map → xychartDiagram-ab372869-UQCQVK6J.js.map} +0 -0
@@ -1,4 +1,4 @@
1
- import { ExcalidrawTextContainer } from "./types";
1
+ import type { ExcalidrawTextContainer } from "./types";
2
2
  export declare const originalContainerCache: {
3
3
  [id: ExcalidrawTextContainer["id"]]: {
4
4
  height: ExcalidrawTextContainer["height"];
@@ -1,6 +1,6 @@
1
- import { NonDeletedExcalidrawElement } from "./types";
2
- import { AppState, PointerDownState } from "../types";
3
- import Scene from "../scene/Scene";
1
+ import type { NonDeletedExcalidrawElement } from "./types";
2
+ import type { AppState, PointerDownState } from "../types";
3
+ import type Scene from "../scene/Scene";
4
4
  export declare const dragSelectedElements: (pointerDownState: PointerDownState, selectedElements: NonDeletedExcalidrawElement[], offset: {
5
5
  x: number;
6
6
  y: number;
@@ -1,8 +1,10 @@
1
1
  /// <reference types="react" />
2
- import { ExcalidrawProps } from "../types";
3
- import { ExcalidrawElement, ExcalidrawIframeLikeElement, IframeData } from "./types";
2
+ import type { ExcalidrawProps } from "../types";
3
+ import type { ExcalidrawElement, ExcalidrawIframeLikeElement, IframeData } from "./types";
4
+ import type { MarkRequired } from "../utility-types";
5
+ type IframeDataWithSandbox = MarkRequired<IframeData, "sandbox">;
4
6
  export declare const createSrcDoc: (body: string) => string;
5
- export declare const getEmbedLink: (link: string | null | undefined) => IframeData | null;
7
+ export declare const getEmbedLink: (link: string | null | undefined) => IframeDataWithSandbox | null;
6
8
  export declare const createPlaceholderEmbeddableLabel: (element: ExcalidrawIframeLikeElement) => ExcalidrawElement;
7
9
  export declare const actionSetEmbeddableAsActiveTool: {
8
10
  name: "setEmbeddableAsActiveTool";
@@ -11,8 +13,8 @@ export declare const actionSetEmbeddableAsActiveTool: {
11
13
  };
12
14
  target: string;
13
15
  label: string;
14
- perform: (elements: readonly ExcalidrawElement[], appState: Readonly<import("../types").AppState>, _: any, app: import("../types").AppClassProperties) => {
15
- elements: readonly ExcalidrawElement[];
16
+ perform: (elements: readonly import("./types").OrderedExcalidrawElement[], appState: Readonly<import("../types").AppState>, _: any, app: import("../types").AppClassProperties) => {
17
+ elements: readonly import("./types").OrderedExcalidrawElement[];
16
18
  appState: {
17
19
  activeTool: {
18
20
  lastActiveTool: import("../types").ActiveTool | null;
@@ -165,10 +167,11 @@ export declare const actionSetEmbeddableAsActiveTool: {
165
167
  userToFollow: import("../types").UserToFollow | null;
166
168
  followedBy: Set<import("../types").SocketId>;
167
169
  };
168
- commitToHistory: false;
170
+ storeAction: import("../store").StoreActionType;
169
171
  };
170
172
  } & {
171
173
  keyTest?: undefined;
172
174
  };
173
175
  export declare const maybeParseEmbedSrc: (str: string) => string;
174
176
  export declare const embeddableURLValidator: (url: string | null | undefined, validateEmbeddable: ExcalidrawProps["validateEmbeddable"]) => boolean;
177
+ export {};
@@ -5,14 +5,16 @@ import { setCursorForShape } from "../cursor";
5
5
  import { newTextElement } from "./newElement";
6
6
  import { wrapText } from "./textElement";
7
7
  import { isIframeElement } from "./typeChecks";
8
+ import { sanitizeHTMLAttribute } from "../data/url";
9
+ import { StoreAction } from "../store";
8
10
  const embeddedLinkCache = new Map();
9
11
  const RE_YOUTUBE = /^(?:http(?:s)?:\/\/)?(?:www\.)?youtu(?:be\.com|\.be)\/(embed\/|watch\?v=|shorts\/|playlist\?list=|embed\/videoseries\?list=)?([a-zA-Z0-9_-]+)(?:\?t=|&t=|\?start=|&start=)?([a-zA-Z0-9_-]+)?[^\s]*$/;
10
12
  const RE_VIMEO = /^(?:http(?:s)?:\/\/)?(?:(?:w){3}\.)?(?:player\.)?vimeo\.com\/(?:video\/)?([^?\s]+)(?:\?.*)?$/;
11
13
  const RE_FIGMA = /^https:\/\/(?:www\.)?figma\.com/;
12
- const RE_GH_GIST = /^https:\/\/gist\.github\.com/;
13
- const RE_GH_GIST_EMBED = /https?:\/\/gist\.github\.com\/([\w_-]+)\/([\w_-]+)\.js["']/i;
14
+ const RE_GH_GIST = /^https:\/\/gist\.github\.com\/([\w_-]+)\/([\w_-]+)/;
15
+ const RE_GH_GIST_EMBED = /^<script[\s\S]*?\ssrc=["'](https:\/\/gist\.github\.com\/.*?)\.js["']/i;
14
16
  // not anchored to start to allow <blockquote> twitter embeds
15
- const RE_TWITTER = /(?:https?:\/\/)?(?:(?:w){3}\.)?(?:twitter|x)\.com/;
17
+ const RE_TWITTER = /(?:https?:\/\/)?(?:(?:w){3}\.)?(?:twitter|x)\.com\/[^/]+\/status\/(\d+)/;
16
18
  const RE_TWITTER_EMBED = /^<blockquote[\s\S]*?\shref=["'](https?:\/\/(?:twitter|x)\.com\/[^"']*)/i;
17
19
  const RE_VALTOWN = /^https:\/\/(?:www\.)?val\.town\/(v|embed)\/[a-zA-Z_$][0-9a-zA-Z_$]+\.[a-zA-Z_$][0-9a-zA-Z_$]+/;
18
20
  const RE_GENERIC_EMBED = /^<(?:iframe|blockquote)[\s\S]*?\s(?:src|href)=["']([^"']*)["'][\s\S]*?>$/i;
@@ -31,7 +33,17 @@ const ALLOWED_DOMAINS = new Set([
31
33
  "stackblitz.com",
32
34
  "val.town",
33
35
  "giphy.com",
34
- "dddice.com",
36
+ ]);
37
+ const ALLOW_SAME_ORIGIN = new Set([
38
+ "youtube.com",
39
+ "youtu.be",
40
+ "vimeo.com",
41
+ "player.vimeo.com",
42
+ "figma.com",
43
+ "twitter.com",
44
+ "x.com",
45
+ "*.simplepdf.eu",
46
+ "stackblitz.com",
35
47
  ]);
36
48
  export const createSrcDoc = (body) => {
37
49
  return `<html><body>${body}</body></html>`;
@@ -44,6 +56,7 @@ export const getEmbedLink = (link) => {
44
56
  return embeddedLinkCache.get(link);
45
57
  }
46
58
  const originalLink = link;
59
+ const allowSameOrigin = ALLOW_SAME_ORIGIN.has(matchHostname(link, ALLOW_SAME_ORIGIN) || "");
47
60
  let type = "generic";
48
61
  let aspectRatio = { w: 560, h: 840 };
49
62
  const ytLink = link.match(RE_YOUTUBE);
@@ -70,8 +83,14 @@ export const getEmbedLink = (link) => {
70
83
  link,
71
84
  intrinsicSize: aspectRatio,
72
85
  type,
86
+ sandbox: { allowSameOrigin },
73
87
  });
74
- return { link, intrinsicSize: aspectRatio, type };
88
+ return {
89
+ link,
90
+ intrinsicSize: aspectRatio,
91
+ type,
92
+ sandbox: { allowSameOrigin },
93
+ };
75
94
  }
76
95
  const vimeoLink = link.match(RE_VIMEO);
77
96
  if (vimeoLink?.[1]) {
@@ -88,8 +107,15 @@ export const getEmbedLink = (link) => {
88
107
  link,
89
108
  intrinsicSize: aspectRatio,
90
109
  type,
110
+ sandbox: { allowSameOrigin },
91
111
  });
92
- return { link, intrinsicSize: aspectRatio, type, error };
112
+ return {
113
+ link,
114
+ intrinsicSize: aspectRatio,
115
+ type,
116
+ error,
117
+ sandbox: { allowSameOrigin },
118
+ };
93
119
  }
94
120
  const figmaLink = link.match(RE_FIGMA);
95
121
  if (figmaLink) {
@@ -100,8 +126,14 @@ export const getEmbedLink = (link) => {
100
126
  link,
101
127
  intrinsicSize: aspectRatio,
102
128
  type,
129
+ sandbox: { allowSameOrigin },
103
130
  });
104
- return { link, intrinsicSize: aspectRatio, type };
131
+ return {
132
+ link,
133
+ intrinsicSize: aspectRatio,
134
+ type,
135
+ sandbox: { allowSameOrigin },
136
+ };
105
137
  }
106
138
  const valLink = link.match(RE_VALTOWN);
107
139
  if (valLink) {
@@ -111,26 +143,38 @@ export const getEmbedLink = (link) => {
111
143
  link,
112
144
  intrinsicSize: aspectRatio,
113
145
  type,
146
+ sandbox: { allowSameOrigin },
114
147
  });
115
- return { link, intrinsicSize: aspectRatio, type };
148
+ return {
149
+ link,
150
+ intrinsicSize: aspectRatio,
151
+ type,
152
+ sandbox: { allowSameOrigin },
153
+ };
116
154
  }
117
155
  if (RE_TWITTER.test(link)) {
118
- // the embed srcdoc still supports twitter.com domain only
119
- link = link.replace(/\bx.com\b/, "twitter.com");
156
+ const postId = link.match(RE_TWITTER)[1];
157
+ // the embed srcdoc still supports twitter.com domain only.
158
+ // Note that we don't attempt to parse the username as it can consist of
159
+ // non-latin1 characters, and the username in the url can be set to anything
160
+ // without affecting the embed.
161
+ const safeURL = sanitizeHTMLAttribute(`https://twitter.com/x/status/${postId}`);
120
162
  const ret = {
121
163
  type: "document",
122
- srcdoc: (theme) => createSrcDoc(`<blockquote class="twitter-tweet" data-dnt="true" data-theme="${theme}"><a href="${link}"></a></blockquote> <script async src="https://platform.twitter.com/widgets.js" charset="utf-8"></script>`),
164
+ srcdoc: (theme) => createSrcDoc(`<blockquote class="twitter-tweet" data-dnt="true" data-theme="${theme}"><a href="${safeURL}"></a></blockquote> <script async src="https://platform.twitter.com/widgets.js" charset="utf-8"></script>`),
123
165
  intrinsicSize: { w: 480, h: 480 },
124
- sandbox: { allowSameOrigin: true },
166
+ sandbox: { allowSameOrigin },
125
167
  };
126
168
  embeddedLinkCache.set(originalLink, ret);
127
169
  return ret;
128
170
  }
129
171
  if (RE_GH_GIST.test(link)) {
172
+ const [, user, gistId] = link.match(RE_GH_GIST);
173
+ const safeURL = sanitizeHTMLAttribute(`https://gist.github.com/${user}/${gistId}`);
130
174
  const ret = {
131
175
  type: "document",
132
176
  srcdoc: () => createSrcDoc(`
133
- <script src="${link}.js"></script>
177
+ <script src="${safeURL}.js"></script>
134
178
  <style type="text/css">
135
179
  * { margin: 0px; }
136
180
  table, .gist { height: 100%; }
@@ -138,12 +182,23 @@ export const getEmbedLink = (link) => {
138
182
  </style>
139
183
  `),
140
184
  intrinsicSize: { w: 550, h: 720 },
185
+ sandbox: { allowSameOrigin },
141
186
  };
142
187
  embeddedLinkCache.set(link, ret);
143
188
  return ret;
144
189
  }
145
- embeddedLinkCache.set(link, { link, intrinsicSize: aspectRatio, type });
146
- return { link, intrinsicSize: aspectRatio, type };
190
+ embeddedLinkCache.set(link, {
191
+ link,
192
+ intrinsicSize: aspectRatio,
193
+ type,
194
+ sandbox: { allowSameOrigin },
195
+ });
196
+ return {
197
+ link,
198
+ intrinsicSize: aspectRatio,
199
+ type,
200
+ sandbox: { allowSameOrigin },
201
+ };
147
202
  };
148
203
  export const createPlaceholderEmbeddableLabel = (element) => {
149
204
  let text;
@@ -194,29 +249,35 @@ export const actionSetEmbeddableAsActiveTool = register({
194
249
  type: "embeddable",
195
250
  }),
196
251
  },
197
- commitToHistory: false,
252
+ storeAction: StoreAction.NONE,
198
253
  };
199
254
  },
200
255
  });
201
- const validateHostname = (url,
256
+ const matchHostname = (url,
202
257
  /** using a Set assumes it already contains normalized bare domains */
203
258
  allowedHostnames) => {
204
259
  try {
205
260
  const { hostname } = new URL(url);
206
261
  const bareDomain = hostname.replace(/^www\./, "");
207
- const bareDomainWithFirstSubdomainWildcarded = bareDomain.replace(/^([^.]+)/, "*");
208
262
  if (allowedHostnames instanceof Set) {
209
- return (ALLOWED_DOMAINS.has(bareDomain) ||
210
- ALLOWED_DOMAINS.has(bareDomainWithFirstSubdomainWildcarded));
263
+ if (ALLOWED_DOMAINS.has(bareDomain)) {
264
+ return bareDomain;
265
+ }
266
+ const bareDomainWithFirstSubdomainWildcarded = bareDomain.replace(/^([^.]+)/, "*");
267
+ if (ALLOWED_DOMAINS.has(bareDomainWithFirstSubdomainWildcarded)) {
268
+ return bareDomainWithFirstSubdomainWildcarded;
269
+ }
270
+ return null;
211
271
  }
212
- if (bareDomain === allowedHostnames.replace(/^www\./, "")) {
213
- return true;
272
+ const bareAllowedHostname = allowedHostnames.replace(/^www\./, "");
273
+ if (bareDomain === bareAllowedHostname) {
274
+ return bareAllowedHostname;
214
275
  }
215
276
  }
216
277
  catch (error) {
217
278
  // ignore
218
279
  }
219
- return false;
280
+ return null;
220
281
  };
221
282
  export const maybeParseEmbedSrc = (str) => {
222
283
  const twitterMatch = str.match(RE_TWITTER_EMBED);
@@ -224,8 +285,8 @@ export const maybeParseEmbedSrc = (str) => {
224
285
  return twitterMatch[1];
225
286
  }
226
287
  const gistMatch = str.match(RE_GH_GIST_EMBED);
227
- if (gistMatch && gistMatch.length === 3) {
228
- return `https://gist.github.com/${gistMatch[1]}/${gistMatch[2]}`;
288
+ if (gistMatch && gistMatch.length === 2) {
289
+ return gistMatch[1];
229
290
  }
230
291
  if (RE_GIPHY.test(str)) {
231
292
  return `https://giphy.com/embed/${RE_GIPHY.exec(str)[1]}`;
@@ -261,12 +322,12 @@ export const embeddableURLValidator = (url, validateEmbeddable) => {
261
322
  return true;
262
323
  }
263
324
  }
264
- else if (validateHostname(url, domain)) {
325
+ else if (matchHostname(url, domain)) {
265
326
  return true;
266
327
  }
267
328
  }
268
329
  return false;
269
330
  }
270
331
  }
271
- return validateHostname(url, ALLOWED_DOMAINS);
332
+ return !!matchHostname(url, ALLOWED_DOMAINS);
272
333
  };
@@ -1,5 +1,5 @@
1
- import { AppClassProperties, DataURL, BinaryFiles } from "../types";
2
- import { ExcalidrawElement, FileId, InitializedExcalidrawImageElement } from "./types";
1
+ import type { AppClassProperties, DataURL, BinaryFiles } from "../types";
2
+ import type { ExcalidrawElement, FileId, InitializedExcalidrawImageElement } from "./types";
3
3
  export declare const loadHTMLImageElement: (dataURL: DataURL) => Promise<HTMLImageElement>;
4
4
  /** NOTE: updates cache even if already populated with given image. Thus,
5
5
  * you should filter out the images upstream if you want to optimize this. */
@@ -1,8 +1,7 @@
1
- import { ExcalidrawElement, NonDeletedExcalidrawElement, NonDeleted } from "./types";
2
- export { newElement, newTextElement, updateTextElement, refreshTextDimensions, newLinearElement, newImageElement, duplicateElement, } from "./newElement";
1
+ import type { ExcalidrawElement, NonDeletedExcalidrawElement, NonDeleted } from "./types";
2
+ export { newElement, newTextElement, refreshTextDimensions, newLinearElement, newImageElement, duplicateElement, } from "./newElement";
3
3
  export { getElementAbsoluteCoords, getElementBounds, getCommonBounds, getDiamondPoints, getArrowheadPoints, getClosestElementBounds, } from "./bounds";
4
4
  export { OMIT_SIDES_FOR_MULTIPLE_ELEMENTS, getTransformHandlesFromCoords, getTransformHandles, } from "./transformHandles";
5
- export { hitTest, isHittingElementBoundingBoxWithoutHittingElement, } from "./collision";
6
5
  export { resizeTest, getCursorForResizingElement, getElementWithTransformHandleType, getTransformHandleTypeFromCoords, } from "./resizeTest";
7
6
  export { transformElements, getResizeOffsetXY, getResizeArrowDirection, } from "./resizeElements";
8
7
  export { dragSelectedElements, getDragOffsetXY, dragNewElement, } from "./dragElements";
@@ -1,9 +1,8 @@
1
1
  import { isInvisiblySmallElement } from "./sizeHelpers";
2
2
  import { isLinearElementType } from "./typeChecks";
3
- export { newElement, newTextElement, updateTextElement, refreshTextDimensions, newLinearElement, newImageElement, duplicateElement, } from "./newElement";
3
+ export { newElement, newTextElement, refreshTextDimensions, newLinearElement, newImageElement, duplicateElement, } from "./newElement";
4
4
  export { getElementAbsoluteCoords, getElementBounds, getCommonBounds, getDiamondPoints, getArrowheadPoints, getClosestElementBounds, } from "./bounds";
5
5
  export { OMIT_SIDES_FOR_MULTIPLE_ELEMENTS, getTransformHandlesFromCoords, getTransformHandles, } from "./transformHandles";
6
- export { hitTest, isHittingElementBoundingBoxWithoutHittingElement, } from "./collision";
7
6
  export { resizeTest, getCursorForResizingElement, getElementWithTransformHandleType, getTransformHandleTypeFromCoords, } from "./resizeTest";
8
7
  export { transformElements, getResizeOffsetXY, getResizeArrowDirection, } from "./resizeElements";
9
8
  export { dragSelectedElements, getDragOffsetXY, dragNewElement, } from "./dragElements";
@@ -1,8 +1,8 @@
1
1
  /// <reference types="react" />
2
- import { NonDeleted, ExcalidrawLinearElement, ExcalidrawElement, PointBinding, ExcalidrawBindableElement, ExcalidrawTextElementWithContainer, ElementsMap, NonDeletedExcalidrawElement, NonDeletedSceneElementsMap } from "./types";
3
- import { Bounds } from "./bounds";
4
- import { Point, AppState, PointerCoords, InteractiveCanvasAppState } from "../types";
5
- import History from "../history";
2
+ import type { NonDeleted, ExcalidrawLinearElement, ExcalidrawElement, PointBinding, ExcalidrawBindableElement, ExcalidrawTextElementWithContainer, ElementsMap, NonDeletedSceneElementsMap } from "./types";
3
+ import type { Bounds } from "./bounds";
4
+ import type { Point, AppState, PointerCoords, InteractiveCanvasAppState, AppClassProperties } from "../types";
5
+ import type { Store } from "../store";
6
6
  declare const editorMidPointsCache: {
7
7
  version: number | null;
8
8
  points: (Point | null)[];
@@ -52,7 +52,7 @@ export declare class LinearElementEditor {
52
52
  x: number;
53
53
  y: number;
54
54
  }[]) => void, linearElementEditor: LinearElementEditor, elementsMap: NonDeletedSceneElementsMap): boolean;
55
- static handlePointerUp(event: PointerEvent, editingLinearElement: LinearElementEditor, appState: AppState, elements: readonly NonDeletedExcalidrawElement[], elementsMap: NonDeletedSceneElementsMap): LinearElementEditor;
55
+ static handlePointerUp(event: PointerEvent, editingLinearElement: LinearElementEditor, appState: AppState, app: AppClassProperties): LinearElementEditor;
56
56
  static getEditorMidPoints: (element: NonDeleted<ExcalidrawLinearElement>, elementsMap: ElementsMap, appState: InteractiveCanvasAppState) => (typeof editorMidPointsCache)["points"];
57
57
  static updateEditorMidPointsCache: (element: NonDeleted<ExcalidrawLinearElement>, elementsMap: ElementsMap, appState: InteractiveCanvasAppState) => void;
58
58
  static getSegmentMidpointHitCoords: (linearElementEditor: LinearElementEditor, scenePointer: {
@@ -62,10 +62,10 @@ export declare class LinearElementEditor {
62
62
  static isSegmentTooShort(element: NonDeleted<ExcalidrawLinearElement>, startPoint: Point, endPoint: Point, zoom: AppState["zoom"]): boolean;
63
63
  static getSegmentMidPoint(element: NonDeleted<ExcalidrawLinearElement>, startPoint: Point, endPoint: Point, endPointIndex: number, elementsMap: ElementsMap): readonly [number, number];
64
64
  static getSegmentMidPointIndex(linearElementEditor: LinearElementEditor, appState: AppState, midPoint: Point, elementsMap: ElementsMap): number;
65
- static handlePointerDown(event: React.PointerEvent<HTMLElement>, appState: AppState, history: History, scenePointer: {
65
+ static handlePointerDown(event: React.PointerEvent<HTMLElement>, appState: AppState, store: Store, scenePointer: {
66
66
  x: number;
67
67
  y: number;
68
- }, linearElementEditor: LinearElementEditor, elements: readonly NonDeletedExcalidrawElement[], elementsMap: NonDeletedSceneElementsMap): {
68
+ }, linearElementEditor: LinearElementEditor, app: AppClassProperties): {
69
69
  didAddPoint: boolean;
70
70
  hitElement: NonDeleted<ExcalidrawElement> | null;
71
71
  linearElementEditor: LinearElementEditor | null;
@@ -133,13 +133,13 @@ export declare class LinearElementEditor {
133
133
  isLoading: boolean;
134
134
  errorMessage: import("react").ReactNode;
135
135
  activeEmbeddable: {
136
- element: NonDeletedExcalidrawElement;
136
+ element: import("./types").NonDeletedExcalidrawElement;
137
137
  state: "hover" | "active";
138
138
  } | null;
139
- draggingElement: NonDeletedExcalidrawElement | null;
140
- resizingElement: NonDeletedExcalidrawElement | null;
139
+ draggingElement: import("./types").NonDeletedExcalidrawElement | null;
140
+ resizingElement: import("./types").NonDeletedExcalidrawElement | null;
141
141
  multiElement: NonDeleted<ExcalidrawLinearElement> | null;
142
- selectionElement: NonDeletedExcalidrawElement | null;
142
+ selectionElement: import("./types").NonDeletedExcalidrawElement | null;
143
143
  isBindingEnabled: boolean;
144
144
  startBoundElement: NonDeleted<ExcalidrawBindableElement> | null;
145
145
  suggestedBindings: import("./binding").SuggestedBinding[];
@@ -152,7 +152,7 @@ export declare class LinearElementEditor {
152
152
  };
153
153
  editingFrame: string | null;
154
154
  elementsToHighlight: NonDeleted<ExcalidrawElement>[] | null;
155
- editingElement: NonDeletedExcalidrawElement | null;
155
+ editingElement: import("./types").NonDeletedExcalidrawElement | null;
156
156
  activeTool: {
157
157
  lastActiveTool: import("../types").ActiveTool | null;
158
158
  locked: boolean;
@@ -163,7 +163,8 @@ export class LinearElementEditor {
163
163
  }
164
164
  return false;
165
165
  }
166
- static handlePointerUp(event, editingLinearElement, appState, elements, elementsMap) {
166
+ static handlePointerUp(event, editingLinearElement, appState, app) {
167
+ const elementsMap = app.scene.getNonDeletedElementsMap();
167
168
  const { elementId, selectedPointsIndices, isDragging, pointerDownState } = editingLinearElement;
168
169
  const element = LinearElementEditor.getElement(elementId, elementsMap);
169
170
  if (!element) {
@@ -185,7 +186,7 @@ export class LinearElementEditor {
185
186
  ]);
186
187
  }
187
188
  const bindingElement = isBindingEnabled(appState)
188
- ? getHoveredElementForBinding(tupleToCoors(LinearElementEditor.getPointAtIndexGlobalCoordinates(element, selectedPoint, elementsMap)), elements, elementsMap)
189
+ ? getHoveredElementForBinding(tupleToCoors(LinearElementEditor.getPointAtIndexGlobalCoordinates(element, selectedPoint, elementsMap)), app)
189
190
  : null;
190
191
  bindings[selectedPoint === 0 ? "startBindingElement" : "endBindingElement"] = bindingElement;
191
192
  }
@@ -313,7 +314,8 @@ export class LinearElementEditor {
313
314
  }
314
315
  return -1;
315
316
  }
316
- static handlePointerDown(event, appState, history, scenePointer, linearElementEditor, elements, elementsMap) {
317
+ static handlePointerDown(event, appState, store, scenePointer, linearElementEditor, app) {
318
+ const elementsMap = app.scene.getNonDeletedElementsMap();
317
319
  const ret = {
318
320
  didAddPoint: false,
319
321
  hitElement: null,
@@ -342,7 +344,7 @@ export class LinearElementEditor {
342
344
  });
343
345
  ret.didAddPoint = true;
344
346
  }
345
- history.resumeRecording();
347
+ store.shouldCaptureIncrement();
346
348
  ret.linearElementEditor = {
347
349
  ...linearElementEditor,
348
350
  pointerDownState: {
@@ -357,7 +359,7 @@ export class LinearElementEditor {
357
359
  },
358
360
  selectedPointsIndices: [element.points.length - 1],
359
361
  lastUncommittedPoint: null,
360
- endBindingElement: getHoveredElementForBinding(scenePointer, elements, elementsMap),
362
+ endBindingElement: getHoveredElementForBinding(scenePointer, app),
361
363
  };
362
364
  ret.didAddPoint = true;
363
365
  return ret;
@@ -1,12 +1,11 @@
1
- import { ExcalidrawElement } from "./types";
2
- import { Mutable } from "../utility-types";
3
- type ElementUpdate<TElement extends ExcalidrawElement> = Omit<Partial<TElement>, "id" | "version" | "versionNonce">;
1
+ import type { ExcalidrawElement } from "./types";
2
+ import type { Mutable } from "../utility-types";
3
+ export type ElementUpdate<TElement extends ExcalidrawElement> = Omit<Partial<TElement>, "id" | "version" | "versionNonce" | "updated">;
4
4
  export declare const mutateElement: <TElement extends Mutable<ExcalidrawElement>>(element: TElement, updates: ElementUpdate<TElement>, informMutation?: boolean) => TElement;
5
- export declare const newElementWith: <TElement extends ExcalidrawElement>(element: TElement, updates: ElementUpdate<TElement>) => TElement;
5
+ export declare const newElementWith: <TElement extends ExcalidrawElement>(element: TElement, updates: ElementUpdate<TElement>, force?: boolean) => TElement;
6
6
  /**
7
7
  * Mutates element, bumping `version`, `versionNonce`, and `updated`.
8
8
  *
9
9
  * NOTE: does not trigger re-render.
10
10
  */
11
11
  export declare const bumpVersion: <T extends Mutable<ExcalidrawElement>>(element: T, version?: ExcalidrawElement["version"]) => T;
12
- export {};
@@ -71,11 +71,13 @@ export const mutateElement = (element, updates, informMutation = true) => {
71
71
  element.versionNonce = randomInteger();
72
72
  element.updated = getUpdatedTimestamp();
73
73
  if (informMutation) {
74
- Scene.getScene(element)?.informMutation();
74
+ Scene.getScene(element)?.triggerUpdate();
75
75
  }
76
76
  return element;
77
77
  };
78
- export const newElementWith = (element, updates) => {
78
+ export const newElementWith = (element, updates,
79
+ /** pass `true` to always regenerate */
80
+ force = false) => {
79
81
  let didChange = false;
80
82
  for (const key in updates) {
81
83
  const value = updates[key];
@@ -88,7 +90,7 @@ export const newElementWith = (element, updates) => {
88
90
  didChange = true;
89
91
  }
90
92
  }
91
- if (!didChange) {
93
+ if (!didChange && !force) {
92
94
  return element;
93
95
  }
94
96
  return {
@@ -1,7 +1,7 @@
1
- import { ExcalidrawElement, ExcalidrawImageElement, ExcalidrawTextElement, ExcalidrawLinearElement, ExcalidrawGenericElement, NonDeleted, TextAlign, GroupId, VerticalAlign, Arrowhead, ExcalidrawFreeDrawElement, FontFamilyValues, ExcalidrawTextContainer, ExcalidrawFrameElement, ExcalidrawEmbeddableElement, ExcalidrawMagicFrameElement, ExcalidrawIframeElement, ElementsMap } from "./types";
2
- import { AppState } from "../types";
3
- import { MarkOptional, Mutable } from "../utility-types";
4
- export type ElementConstructorOpts = MarkOptional<Omit<ExcalidrawGenericElement, "id" | "type" | "isDeleted" | "updated">, "width" | "height" | "angle" | "groupIds" | "frameId" | "boundElements" | "seed" | "version" | "versionNonce" | "link" | "strokeStyle" | "fillStyle" | "strokeColor" | "backgroundColor" | "roughness" | "strokeWidth" | "roundness" | "locked" | "opacity" | "customData">;
1
+ import type { ExcalidrawElement, ExcalidrawImageElement, ExcalidrawTextElement, ExcalidrawLinearElement, ExcalidrawGenericElement, NonDeleted, TextAlign, GroupId, VerticalAlign, Arrowhead, ExcalidrawFreeDrawElement, FontFamilyValues, ExcalidrawTextContainer, ExcalidrawFrameElement, ExcalidrawEmbeddableElement, ExcalidrawMagicFrameElement, ExcalidrawIframeElement, ElementsMap } from "./types";
2
+ import type { AppState } from "../types";
3
+ import type { MarkOptional, Mutable } from "../utility-types";
4
+ export type ElementConstructorOpts = MarkOptional<Omit<ExcalidrawGenericElement, "id" | "type" | "isDeleted" | "updated">, "width" | "height" | "angle" | "groupIds" | "frameId" | "index" | "boundElements" | "seed" | "version" | "versionNonce" | "link" | "strokeStyle" | "fillStyle" | "strokeColor" | "backgroundColor" | "roughness" | "strokeWidth" | "roundness" | "locked" | "opacity" | "customData">;
5
5
  export declare const newElement: (opts: {
6
6
  type: ExcalidrawGenericElement["type"];
7
7
  } & ElementConstructorOpts) => NonDeleted<ExcalidrawGenericElement>;
@@ -34,11 +34,6 @@ export declare const refreshTextDimensions: (textElement: ExcalidrawTextElement,
34
34
  height: number;
35
35
  text: string;
36
36
  } | undefined;
37
- export declare const updateTextElement: (textElement: ExcalidrawTextElement, container: ExcalidrawTextContainer | null, elementsMap: ElementsMap, { text, isDeleted, originalText, }: {
38
- text: string;
39
- isDeleted?: boolean | undefined;
40
- originalText: string;
41
- }) => ExcalidrawTextElement;
42
37
  export declare const newFreeDrawElement: (opts: {
43
38
  type: "freedraw";
44
39
  points?: ExcalidrawFreeDrawElement["points"];
@@ -7,7 +7,7 @@ import { adjustXYWithRotation } from "../math";
7
7
  import { getResizedElementAbsoluteCoords } from "./bounds";
8
8
  import { measureText, normalizeText, wrapText, getBoundTextMaxWidth, getDefaultLineHeight, } from "./textElement";
9
9
  import { DEFAULT_ELEMENT_PROPS, DEFAULT_FONT_FAMILY, DEFAULT_FONT_SIZE, DEFAULT_TEXT_ALIGN, DEFAULT_VERTICAL_ALIGN, VERTICAL_ALIGN, } from "../constants";
10
- const _newElementBase = (type, { x, y, strokeColor = DEFAULT_ELEMENT_PROPS.strokeColor, backgroundColor = DEFAULT_ELEMENT_PROPS.backgroundColor, fillStyle = DEFAULT_ELEMENT_PROPS.fillStyle, strokeWidth = DEFAULT_ELEMENT_PROPS.strokeWidth, strokeStyle = DEFAULT_ELEMENT_PROPS.strokeStyle, roughness = DEFAULT_ELEMENT_PROPS.roughness, opacity = DEFAULT_ELEMENT_PROPS.opacity, width = 0, height = 0, angle = 0, groupIds = [], frameId = null, roundness = null, boundElements = null, link = null, locked = DEFAULT_ELEMENT_PROPS.locked, ...rest }) => {
10
+ const _newElementBase = (type, { x, y, strokeColor = DEFAULT_ELEMENT_PROPS.strokeColor, backgroundColor = DEFAULT_ELEMENT_PROPS.backgroundColor, fillStyle = DEFAULT_ELEMENT_PROPS.fillStyle, strokeWidth = DEFAULT_ELEMENT_PROPS.strokeWidth, strokeStyle = DEFAULT_ELEMENT_PROPS.strokeStyle, roughness = DEFAULT_ELEMENT_PROPS.roughness, opacity = DEFAULT_ELEMENT_PROPS.opacity, width = 0, height = 0, angle = 0, groupIds = [], frameId = null, index = null, roundness = null, boundElements = null, link = null, locked = DEFAULT_ELEMENT_PROPS.locked, ...rest }) => {
11
11
  // assign type to guard against excess properties
12
12
  const element = {
13
13
  id: rest.id || randomId(),
@@ -26,6 +26,7 @@ const _newElementBase = (type, { x, y, strokeColor = DEFAULT_ELEMENT_PROPS.strok
26
26
  opacity,
27
27
  groupIds,
28
28
  frameId,
29
+ index,
29
30
  roundness,
30
31
  seed: rest.seed ?? randomInteger(),
31
32
  version: rest.version || 1,
@@ -84,7 +85,7 @@ export const newTextElement = (opts) => {
84
85
  const textAlign = opts.textAlign || DEFAULT_TEXT_ALIGN;
85
86
  const verticalAlign = opts.verticalAlign || DEFAULT_VERTICAL_ALIGN;
86
87
  const offsets = getTextElementPositionOffsets({ textAlign, verticalAlign }, metrics);
87
- const textElement = newElementWith({
88
+ const textElementProps = {
88
89
  ..._newElementBase("text", opts),
89
90
  text,
90
91
  fontSize,
@@ -97,18 +98,25 @@ export const newTextElement = (opts) => {
97
98
  height: metrics.height,
98
99
  containerId: opts.containerId || null,
99
100
  originalText: text,
101
+ autoResize: true,
100
102
  lineHeight,
101
- }, {});
103
+ };
104
+ const textElement = newElementWith(textElementProps, {});
102
105
  return textElement;
103
106
  };
104
107
  const getAdjustedDimensions = (element, elementsMap, nextText) => {
105
- const { width: nextWidth, height: nextHeight } = measureText(nextText, getFontString(element), element.lineHeight);
108
+ let { width: nextWidth, height: nextHeight } = measureText(nextText, getFontString(element), element.lineHeight);
109
+ // wrapped text
110
+ if (!element.autoResize) {
111
+ nextWidth = element.width;
112
+ }
106
113
  const { textAlign, verticalAlign } = element;
107
114
  let x;
108
115
  let y;
109
116
  if (textAlign === "center" &&
110
117
  verticalAlign === VERTICAL_ALIGN.MIDDLE &&
111
- !element.containerId) {
118
+ !element.containerId &&
119
+ element.autoResize) {
112
120
  const prevMetrics = measureText(element.text, getFontString(element), element.lineHeight);
113
121
  const offsets = getTextElementPositionOffsets(element, {
114
122
  width: nextWidth - prevMetrics.width,
@@ -141,19 +149,14 @@ export const refreshTextDimensions = (textElement, container, elementsMap, text
141
149
  if (textElement.isDeleted) {
142
150
  return;
143
151
  }
144
- if (container) {
145
- text = wrapText(text, getFontString(textElement), getBoundTextMaxWidth(container, textElement));
152
+ if (container || !textElement.autoResize) {
153
+ text = wrapText(text, getFontString(textElement), container
154
+ ? getBoundTextMaxWidth(container, textElement)
155
+ : textElement.width);
146
156
  }
147
157
  const dimensions = getAdjustedDimensions(textElement, elementsMap, text);
148
158
  return { text, ...dimensions };
149
159
  };
150
- export const updateTextElement = (textElement, container, elementsMap, { text, isDeleted, originalText, }) => {
151
- return newElementWith(textElement, {
152
- originalText,
153
- isDeleted: isDeleted ?? textElement.isDeleted,
154
- ...refreshTextDimensions(textElement, container, elementsMap, originalText),
155
- });
156
- };
157
160
  export const newFreeDrawElement = (opts) => {
158
161
  return {
159
162
  ..._newElementBase(opts.type, opts),
@@ -1,9 +1,9 @@
1
- import { ExcalidrawLinearElement, NonDeletedExcalidrawElement, NonDeleted, ElementsMap } from "./types";
2
- import { MaybeTransformHandleType, TransformHandleDirection } from "./transformHandles";
3
- import { PointerDownState } from "../types";
1
+ import type { ExcalidrawLinearElement, NonDeletedExcalidrawElement, NonDeleted, ElementsMap } from "./types";
2
+ import type { MaybeTransformHandleType, TransformHandleDirection } from "./transformHandles";
3
+ import type { PointerDownState } from "../types";
4
4
  export declare const normalizeAngle: (angle: number) => number;
5
5
  export declare const transformElements: (originalElements: PointerDownState["originalElements"], transformHandleType: MaybeTransformHandleType, selectedElements: readonly NonDeletedExcalidrawElement[], elementsMap: ElementsMap, shouldRotateWithDiscreteAngle: boolean, shouldResizeFromCenter: boolean, shouldMaintainAspectRatio: boolean, pointerX: number, pointerY: number, centerX: number, centerY: number) => boolean;
6
6
  export declare const resizeSingleElement: (originalElements: PointerDownState["originalElements"], shouldMaintainAspectRatio: boolean, element: NonDeletedExcalidrawElement, elementsMap: ElementsMap, transformHandleDirection: TransformHandleDirection, shouldResizeFromCenter: boolean, pointerX: number, pointerY: number) => void;
7
- export declare const resizeMultipleElements: (originalElements: PointerDownState["originalElements"], selectedElements: readonly NonDeletedExcalidrawElement[], elementsMap: ElementsMap, transformHandleType: "nw" | "ne" | "sw" | "se", shouldResizeFromCenter: boolean, pointerX: number, pointerY: number) => void;
7
+ export declare const resizeMultipleElements: (originalElements: PointerDownState["originalElements"], selectedElements: readonly NonDeletedExcalidrawElement[], elementsMap: ElementsMap, transformHandleType: TransformHandleDirection, shouldResizeFromCenter: boolean, shouldMaintainAspectRatio: boolean, pointerX: number, pointerY: number) => void;
8
8
  export declare const getResizeOffsetXY: (transformHandleType: MaybeTransformHandleType, selectedElements: NonDeletedExcalidrawElement[], elementsMap: ElementsMap, x: number, y: number) => [number, number];
9
9
  export declare const getResizeArrowDirection: (transformHandleType: MaybeTransformHandleType, element: NonDeleted<ExcalidrawLinearElement>) => "origin" | "end";