@dwelle/excalidraw 0.5.0-da1c822 → 0.5.0-e56eec7

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 (382) hide show
  1. package/CHANGELOG.md +13 -2
  2. package/dist/browser/dev/excalidraw-assets-dev/{blockDiagram-91b80b7a-RHODGCTM.js → blockDiagram-91b80b7a-NRABZKZA.js} +6 -6
  3. package/dist/browser/dev/excalidraw-assets-dev/{c4Diagram-b2a90758-W7NCR7LR.js → c4Diagram-b2a90758-56M32CJD.js} +4 -4
  4. package/dist/browser/dev/excalidraw-assets-dev/{chunk-TKRIVTWP.js → chunk-5EDB2FTV.js} +3 -3
  5. package/dist/browser/dev/excalidraw-assets-dev/{chunk-52OGG53V.js → chunk-6VTJEXQH.js} +3 -3
  6. package/dist/browser/dev/excalidraw-assets-dev/{chunk-J5HRUYQR.js → chunk-AKQDHN2W.js} +2 -2
  7. package/dist/browser/dev/excalidraw-assets-dev/chunk-AKQDHN2W.js.map +7 -0
  8. package/dist/browser/dev/excalidraw-assets-dev/{chunk-GF7VCOUM.js → chunk-C4OL7SRI.js} +3 -3
  9. package/dist/browser/dev/excalidraw-assets-dev/{chunk-BESQLMCW.js → chunk-E47I6Q7O.js} +5 -5
  10. package/dist/browser/dev/excalidraw-assets-dev/{chunk-UETNA2WX.js → chunk-KDIPICHB.js} +6377 -4340
  11. package/dist/browser/dev/excalidraw-assets-dev/chunk-KDIPICHB.js.map +7 -0
  12. package/dist/browser/dev/excalidraw-assets-dev/{chunk-5747M6KP.js → chunk-OH2YDYHX.js} +3 -3
  13. package/dist/browser/dev/excalidraw-assets-dev/{chunk-GPOYIZPX.js → chunk-PXBR5CBM.js} +28 -28
  14. package/dist/browser/dev/excalidraw-assets-dev/chunk-PXBR5CBM.js.map +7 -0
  15. package/dist/browser/dev/excalidraw-assets-dev/{chunk-GCA4S2OA.js → chunk-RTA6DTUV.js} +3 -3
  16. package/dist/browser/dev/excalidraw-assets-dev/{chunk-DQOPSCYA.js → chunk-TTH3BTHQ.js} +3 -3
  17. package/dist/browser/dev/excalidraw-assets-dev/{chunk-B2MHJWXZ.js → chunk-U4N7TEPH.js} +2 -2
  18. package/dist/browser/dev/excalidraw-assets-dev/{chunk-QFS4M5OJ.js → chunk-V3PA4IDR.js} +3 -3
  19. package/dist/browser/dev/excalidraw-assets-dev/{chunk-SLLUETBM.js → chunk-WFT6ZJE6.js} +7 -7
  20. package/dist/browser/dev/excalidraw-assets-dev/{chunk-PPHFJLL7.js → chunk-XZKEYTKS.js} +4 -4
  21. package/dist/browser/dev/excalidraw-assets-dev/{chunk-USLWOHUZ.js → chunk-YC6VTXEO.js} +4 -4
  22. package/dist/browser/dev/excalidraw-assets-dev/{classDiagram-30eddba6-GJGBT4TV.js → classDiagram-30eddba6-EZJVINS6.js} +6 -6
  23. package/dist/browser/dev/excalidraw-assets-dev/{classDiagram-v2-f2df5561-LYWTIPJA.js → classDiagram-v2-f2df5561-XSUIN44A.js} +9 -9
  24. package/dist/browser/dev/excalidraw-assets-dev/{directory-open-01563666-UREMLRIT.js → directory-open-01563666-KOK2HSB6.js} +2 -2
  25. package/dist/browser/dev/excalidraw-assets-dev/{directory-open-4ed118d0-UN3BUDZZ.js → directory-open-4ed118d0-P3Q3CLF3.js} +2 -2
  26. package/dist/browser/dev/excalidraw-assets-dev/dist-O6HOTHQF.js +10 -0
  27. package/dist/browser/dev/excalidraw-assets-dev/{en-UW5C5KGW.js → en-PSBMWL4S.js} +2 -2
  28. package/dist/browser/dev/excalidraw-assets-dev/{erDiagram-47591fe2-Z7U2XW2Y.js → erDiagram-47591fe2-U7FLWOG3.js} +5 -5
  29. package/dist/browser/dev/excalidraw-assets-dev/{file-open-002ab408-4QG336MG.js → file-open-002ab408-EQEHGU2J.js} +2 -2
  30. package/dist/browser/dev/excalidraw-assets-dev/{file-open-7c801643-3QI4ICCL.js → file-open-7c801643-QQT6O7P5.js} +2 -2
  31. package/dist/browser/dev/excalidraw-assets-dev/{file-save-3189631c-TNNERCWV.js → file-save-3189631c-YXX2C7C6.js} +2 -2
  32. package/dist/browser/dev/excalidraw-assets-dev/{file-save-745eba88-JFMH565P.js → file-save-745eba88-7G554KTZ.js} +2 -2
  33. package/dist/browser/dev/excalidraw-assets-dev/{flowDiagram-5540d9b9-PARVG263.js → flowDiagram-5540d9b9-F2VP4JAA.js} +10 -10
  34. package/dist/browser/dev/excalidraw-assets-dev/{flowDiagram-v2-3b53844e-ZJOPVRMB.js → flowDiagram-v2-3b53844e-2WQZZRND.js} +10 -10
  35. package/dist/browser/dev/excalidraw-assets-dev/{flowchart-elk-definition-5fe447d6-ULPNBSZX.js → flowchart-elk-definition-5fe447d6-IW6O2F6C.js} +6 -6
  36. package/dist/browser/dev/excalidraw-assets-dev/{ganttDiagram-9a3bba1f-ESSYVTJ4.js → ganttDiagram-9a3bba1f-B5RH7ZAO.js} +3 -3
  37. package/dist/browser/dev/excalidraw-assets-dev/{gitGraphDiagram-96e6b4ee-6V6VVNNP.js → gitGraphDiagram-96e6b4ee-INGQRNLZ.js} +3 -3
  38. package/dist/browser/dev/excalidraw-assets-dev/{image-ZNQQXS62.css → image-FDQLNM24.css} +39 -16
  39. package/dist/browser/dev/excalidraw-assets-dev/image-FDQLNM24.css.map +7 -0
  40. package/dist/browser/dev/excalidraw-assets-dev/{image-3LTGFHLF.js → image-GMAHLVER.js} +6 -6
  41. package/dist/browser/dev/excalidraw-assets-dev/{image-blob-reduce.esm-KTX27DAY.js → image-blob-reduce.esm-OX75MRP3.js} +2 -2
  42. package/dist/browser/dev/excalidraw-assets-dev/{infoDiagram-bcd20f53-I22FLFX3.js → infoDiagram-bcd20f53-43FMAUOR.js} +3 -3
  43. package/dist/browser/dev/excalidraw-assets-dev/{journeyDiagram-4fe6b3dc-WAO6F52C.js → journeyDiagram-4fe6b3dc-KFVOUX4I.js} +4 -4
  44. package/dist/browser/dev/excalidraw-assets-dev/{katex-NWA2YFOP.js → katex-A3GRORPB.js} +2 -2
  45. package/dist/browser/dev/excalidraw-assets-dev/{mindmap-definition-f354de21-K74IKX4Y.js → mindmap-definition-f354de21-D7S3CRQ4.js} +4 -4
  46. package/dist/browser/dev/excalidraw-assets-dev/{pica-3TH2EGXR.js → pica-ZAD7MTGA.js} +2 -2
  47. package/dist/browser/dev/excalidraw-assets-dev/{pieDiagram-79897490-DOB2LVE5.js → pieDiagram-79897490-OON2CRZ5.js} +3 -3
  48. package/dist/browser/dev/excalidraw-assets-dev/{quadrantDiagram-62f64e94-MJV2X7WI.js → quadrantDiagram-62f64e94-5APTNVVS.js} +3 -3
  49. package/dist/browser/dev/excalidraw-assets-dev/{requirementDiagram-05bf5f74-H4YM3XN7.js → requirementDiagram-05bf5f74-FM7WZVKU.js} +5 -5
  50. package/dist/browser/dev/excalidraw-assets-dev/{roundRect-4S3QV2NZ.js → roundRect-AYYHVX5X.js} +2 -2
  51. package/dist/browser/dev/excalidraw-assets-dev/{sankeyDiagram-97764748-7X74ABAN.js → sankeyDiagram-97764748-5HLEFFGY.js} +3 -3
  52. package/dist/browser/dev/excalidraw-assets-dev/{sequenceDiagram-acc0e65c-PPDIJFQP.js → sequenceDiagram-acc0e65c-4ZRSNGPV.js} +4 -4
  53. package/dist/browser/dev/excalidraw-assets-dev/{stateDiagram-0ff1cf1a-JVBR7N35.js → stateDiagram-0ff1cf1a-OLTPYRPP.js} +6 -6
  54. package/dist/browser/dev/excalidraw-assets-dev/{stateDiagram-v2-9a9d610d-QYAJLQJH.js → stateDiagram-v2-9a9d610d-N3XOTAEE.js} +9 -9
  55. package/dist/browser/dev/excalidraw-assets-dev/{timeline-definition-fea2a41d-GL7U3WDB.js → timeline-definition-fea2a41d-5PDFIYJQ.js} +3 -3
  56. package/dist/browser/dev/excalidraw-assets-dev/{xychartDiagram-ab372869-4U4JE4TW.js → xychartDiagram-ab372869-VIWBP45Y.js} +4 -4
  57. package/dist/browser/dev/index.css +38 -15
  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/ar-SA-JA6F2FMJ-MVAFRXH2.js +10 -0
  61. package/dist/browser/prod/excalidraw-assets/az-AZ-GVIENQVH-DULWV7IG.js +1 -0
  62. package/dist/browser/prod/excalidraw-assets/bg-BG-YFNNHCEP-TOMMDX7A.js +5 -0
  63. package/dist/browser/prod/excalidraw-assets/{blockDiagram-91b80b7a-BO7MW3VX.js → blockDiagram-91b80b7a-ZBW6LBXS.js} +1 -1
  64. package/dist/browser/prod/excalidraw-assets/bn-BD-LMEIWSRD-U6EPN6XJ.js +5 -0
  65. package/dist/browser/prod/excalidraw-assets/{c4Diagram-b2a90758-VCUPBVHR.js → c4Diagram-b2a90758-GET6IFET.js} +1 -1
  66. package/dist/browser/prod/excalidraw-assets/ca-ES-C2WGCLOT-4Q2376G3.js +8 -0
  67. package/dist/browser/prod/excalidraw-assets/{chunk-O77Z7CWL.js → chunk-2UGPV7X3.js} +1 -1
  68. package/dist/browser/prod/excalidraw-assets/{chunk-B7CDQVNY.js → chunk-364WSJPQ.js} +21 -21
  69. package/dist/browser/prod/excalidraw-assets/{chunk-NM5B2RBP.js → chunk-4FM7RPKW.js} +1 -1
  70. package/dist/browser/prod/excalidraw-assets/{chunk-CVEF66PS.js → chunk-4SHJFNCN.js} +1 -1
  71. package/dist/browser/prod/excalidraw-assets/{chunk-22FVL4I7.js → chunk-6TNDONBF.js} +1 -1
  72. package/dist/browser/prod/excalidraw-assets/{chunk-QLNFR4AJ.js → chunk-BJTCWAK5.js} +1 -1
  73. package/dist/browser/prod/excalidraw-assets/chunk-CKRG5LOX.js +335 -0
  74. package/dist/browser/prod/excalidraw-assets/{chunk-3HZHH3PT.js → chunk-IW42BK4V.js} +1 -1
  75. package/dist/browser/prod/excalidraw-assets/{chunk-4JYQ3563.js → chunk-MRQWXP64.js} +1 -1
  76. package/dist/browser/prod/excalidraw-assets/{chunk-VXFFPRP2.js → chunk-OG2UUKMT.js} +1 -1
  77. package/dist/browser/prod/excalidraw-assets/chunk-Q6QP4TRB.js +11 -0
  78. package/dist/browser/prod/excalidraw-assets/{chunk-V7HUISEN.js → chunk-QBYA3CCP.js} +1 -1
  79. package/dist/browser/prod/excalidraw-assets/{chunk-5PWM36DG.js → chunk-S3O7MXSU.js} +1 -1
  80. package/dist/browser/prod/excalidraw-assets/chunk-SJBOQTFA.js +1 -0
  81. package/dist/browser/prod/excalidraw-assets/{chunk-3VCRCP5J.js → chunk-T7MBBIYG.js} +1 -1
  82. package/dist/browser/prod/excalidraw-assets/{chunk-HPA5W5VE.js → chunk-X7R4RA7C.js} +1 -1
  83. package/dist/browser/prod/excalidraw-assets/{chunk-7UJZVYSR.js → chunk-Y3NNVSMP.js} +1 -1
  84. package/dist/browser/prod/excalidraw-assets/{classDiagram-30eddba6-VXGNM3LI.js → classDiagram-30eddba6-MJ5GZSCE.js} +1 -1
  85. package/dist/browser/prod/excalidraw-assets/{classDiagram-v2-f2df5561-YALTASVE.js → classDiagram-v2-f2df5561-FU5PRXDD.js} +1 -1
  86. package/dist/browser/prod/excalidraw-assets/cs-CZ-F2NDIQMB-4NMYRMO2.js +11 -0
  87. package/dist/browser/prod/excalidraw-assets/da-DK-WBEQB3CJ-6YAF4DNI.js +5 -0
  88. package/dist/browser/prod/excalidraw-assets/de-DE-VEIMCP7R-NSRLPHDI.js +8 -0
  89. package/dist/browser/prod/excalidraw-assets/{directory-open-01563666-JWXY2QSC.js → directory-open-01563666-UG2J4T6L.js} +1 -1
  90. package/dist/browser/prod/excalidraw-assets/{directory-open-4ed118d0-6AL5X37W.js → directory-open-4ed118d0-FGQD6TMW.js} +1 -1
  91. package/dist/browser/prod/excalidraw-assets/dist-LI3DBBWR.js +1 -0
  92. package/dist/browser/prod/excalidraw-assets/el-GR-TKRKG5GQ-6N4GY2DI.js +10 -0
  93. package/dist/browser/prod/excalidraw-assets/{en-CPU3UVKT.js → en-MPFDZHEH.js} +1 -1
  94. package/dist/browser/prod/excalidraw-assets/en-Q552WR7L-QAV42NF3.js +1 -0
  95. package/dist/browser/prod/excalidraw-assets/{erDiagram-47591fe2-GKYANCN7.js → erDiagram-47591fe2-YGAMNOK6.js} +1 -1
  96. package/dist/browser/prod/excalidraw-assets/es-ES-TOLWEZNW-ODY4LX7F.js +9 -0
  97. package/dist/browser/prod/excalidraw-assets/eu-ES-7CDRJQWJ-KF3KSB2X.js +11 -0
  98. package/dist/browser/prod/excalidraw-assets/fa-IR-527E2XGU-WLLGMWYR.js +8 -0
  99. package/dist/browser/prod/excalidraw-assets/fi-FI-NLQ7RQGZ-EZLGQEWF.js +6 -0
  100. package/dist/browser/prod/excalidraw-assets/{file-open-002ab408-3EPJOH45.js → file-open-002ab408-WLX7QPS6.js} +1 -1
  101. package/dist/browser/prod/excalidraw-assets/{file-open-7c801643-QIP6HK4D.js → file-open-7c801643-YB6IH3XI.js} +1 -1
  102. package/dist/browser/prod/excalidraw-assets/{file-save-3189631c-4TQJBQCS.js → file-save-3189631c-MRYCXU63.js} +1 -1
  103. package/dist/browser/prod/excalidraw-assets/{file-save-745eba88-C4L3ZGCC.js → file-save-745eba88-UZEDMFLR.js} +1 -1
  104. package/dist/browser/prod/excalidraw-assets/{flowDiagram-5540d9b9-QBRW5SLP.js → flowDiagram-5540d9b9-V23UQWYJ.js} +1 -1
  105. package/dist/browser/prod/excalidraw-assets/flowDiagram-v2-3b53844e-UDC2ZAFT.js +1 -0
  106. package/dist/browser/prod/excalidraw-assets/{flowchart-elk-definition-5fe447d6-YYO2EYKS.js → flowchart-elk-definition-5fe447d6-N3ISH6AG.js} +1 -1
  107. package/dist/browser/prod/excalidraw-assets/fr-FR-KUHO4FLU-2OW7FE5V.js +9 -0
  108. package/dist/browser/prod/excalidraw-assets/{ganttDiagram-9a3bba1f-3B2DUUUQ.js → ganttDiagram-9a3bba1f-7SAN2TXA.js} +1 -1
  109. package/dist/browser/prod/excalidraw-assets/{gitGraphDiagram-96e6b4ee-G6CKXXWQ.js → gitGraphDiagram-96e6b4ee-EXV6PWXL.js} +1 -1
  110. package/dist/browser/prod/excalidraw-assets/gl-ES-NEXX3VBB-TESFDR6O.js +10 -0
  111. package/dist/browser/prod/excalidraw-assets/he-IL-MED2VGBZ-N4VYRCHF.js +10 -0
  112. package/dist/browser/prod/excalidraw-assets/hi-IN-5V633W7V-4VXVQ6GE.js +4 -0
  113. package/dist/browser/prod/excalidraw-assets/hu-HU-2FOZGVGR-7CHHZRPD.js +7 -0
  114. package/dist/browser/prod/excalidraw-assets/id-ID-I6BOLXTF-ULJRGCTU.js +10 -0
  115. package/dist/browser/prod/excalidraw-assets/image-ZKACJTPS.js +1 -0
  116. package/dist/browser/prod/excalidraw-assets/{image-blob-reduce.esm-5DTGAOOI.js → image-blob-reduce.esm-GOFU5DPX.js} +1 -1
  117. package/dist/browser/prod/excalidraw-assets/{infoDiagram-bcd20f53-WJTZJERL.js → infoDiagram-bcd20f53-LJZ36XP5.js} +1 -1
  118. package/dist/browser/prod/excalidraw-assets/it-IT-WKPQOK4P-C3FTW2QG.js +11 -0
  119. package/dist/browser/prod/excalidraw-assets/ja-JP-VKA4ISRU-EBXFDMUP.js +8 -0
  120. package/dist/browser/prod/excalidraw-assets/{journeyDiagram-4fe6b3dc-JF22KXXQ.js → journeyDiagram-4fe6b3dc-TFRSU2KH.js} +1 -1
  121. package/dist/browser/prod/excalidraw-assets/kaa-IKPRSBNY-URJPWZZH.js +1 -0
  122. package/dist/browser/prod/excalidraw-assets/kab-KAB-IE4PHQTZ-OMISFOMM.js +8 -0
  123. package/dist/browser/prod/excalidraw-assets/{katex-N6R5DPQX.js → katex-HAQKNIIQ.js} +1 -1
  124. package/dist/browser/prod/excalidraw-assets/kk-KZ-MNJT6XSV-56OVE4EH.js +1 -0
  125. package/dist/browser/prod/excalidraw-assets/km-KH-LADGDFXV-KI7V2Z5A.js +11 -0
  126. package/dist/browser/prod/excalidraw-assets/ko-KR-XD7AVF2F-EFYGITKM.js +9 -0
  127. package/dist/browser/prod/excalidraw-assets/ku-TR-4XBHKDQA-U25XLPMW.js +9 -0
  128. package/dist/browser/prod/excalidraw-assets/lt-LT-QC35R4YH-6TDSRONI.js +3 -0
  129. package/dist/browser/prod/excalidraw-assets/lv-LV-GSD5D3BA-KMXM2FQ7.js +7 -0
  130. package/dist/browser/prod/excalidraw-assets/{mindmap-definition-f354de21-7SH5STU3.js → mindmap-definition-f354de21-J3C2WSJB.js} +1 -1
  131. package/dist/browser/prod/excalidraw-assets/mr-IN-KOLSWM7Y-NVYC6JCO.js +13 -0
  132. package/dist/browser/prod/excalidraw-assets/my-MM-M53KMUET-A2ORJJ2D.js +1 -0
  133. package/dist/browser/prod/excalidraw-assets/nb-NO-XXC6U37A-L4O4DGCC.js +10 -0
  134. package/dist/browser/prod/excalidraw-assets/nl-NL-HCCJQEUO-7Q2LV5NM.js +8 -0
  135. package/dist/browser/prod/excalidraw-assets/nn-NO-6P7Z2PI2-TUT2PFEE.js +8 -0
  136. package/dist/browser/prod/excalidraw-assets/oc-FR-JRJKPLNT-SBQHJH7X.js +8 -0
  137. package/dist/browser/prod/excalidraw-assets/pa-IN-LZWLEPIB-7NKOXI65.js +4 -0
  138. package/dist/browser/prod/excalidraw-assets/percentages-UCQDHIQF-Q4IM6ZEB.js +1 -0
  139. package/dist/browser/prod/excalidraw-assets/{pica-KWHN2PJ6.js → pica-ABPXE5C5.js} +1 -1
  140. package/dist/browser/prod/excalidraw-assets/{pieDiagram-79897490-5O5EBEQB.js → pieDiagram-79897490-FMJ3ZAF7.js} +1 -1
  141. package/dist/browser/prod/excalidraw-assets/pl-PL-3WBLCXI2-E2SMTIVM.js +9 -0
  142. package/dist/browser/prod/excalidraw-assets/pt-BR-O3ZPTUNW-RS7M7EKX.js +9 -0
  143. package/dist/browser/prod/excalidraw-assets/pt-PT-7AQTSAFO-AEANJ2UN.js +9 -0
  144. package/dist/browser/prod/excalidraw-assets/{quadrantDiagram-62f64e94-JTY6WOKB.js → quadrantDiagram-62f64e94-YI32TPUI.js} +1 -1
  145. package/dist/browser/prod/excalidraw-assets/{requirementDiagram-05bf5f74-TSFQFY5X.js → requirementDiagram-05bf5f74-UO2ATL3U.js} +1 -1
  146. package/dist/browser/prod/excalidraw-assets/ro-RO-HJ65JYWV-35XNZ4QJ.js +11 -0
  147. package/dist/browser/prod/excalidraw-assets/{roundRect-PUCZURYS.js → roundRect-UKQBLFKQ.js} +1 -1
  148. package/dist/browser/prod/excalidraw-assets/ru-RU-P7ROIYNC-ERPG3GJT.js +9 -0
  149. package/dist/browser/prod/excalidraw-assets/{sankeyDiagram-97764748-7G2R6W67.js → sankeyDiagram-97764748-3RR36435.js} +1 -1
  150. package/dist/browser/prod/excalidraw-assets/{sequenceDiagram-acc0e65c-CTANNZCO.js → sequenceDiagram-acc0e65c-G2Q6J4UN.js} +1 -1
  151. package/dist/browser/prod/excalidraw-assets/si-LK-7ZSWVION-YHKN25MU.js +1 -0
  152. package/dist/browser/prod/excalidraw-assets/sk-SK-NXVBGLYY-IKQZT26E.js +6 -0
  153. package/dist/browser/prod/excalidraw-assets/sl-SI-VFTWOYNP-UPLNMI3E.js +6 -0
  154. package/dist/browser/prod/excalidraw-assets/{stateDiagram-0ff1cf1a-I5COLKZ4.js → stateDiagram-0ff1cf1a-QEYVXCSB.js} +1 -1
  155. package/dist/browser/prod/excalidraw-assets/{stateDiagram-v2-9a9d610d-IIHI3AJN.js → stateDiagram-v2-9a9d610d-3VKD7UYK.js} +1 -1
  156. package/dist/browser/prod/excalidraw-assets/sv-SE-YONBLQNW-ZG4TE7PV.js +10 -0
  157. package/dist/browser/prod/excalidraw-assets/ta-IN-BSETPMLX-FC54FMQJ.js +9 -0
  158. package/dist/browser/prod/excalidraw-assets/th-TH-URTRDITB-K6QQ2PRO.js +2 -0
  159. package/dist/browser/prod/excalidraw-assets/{timeline-definition-fea2a41d-CXTGKWI4.js → timeline-definition-fea2a41d-H4D6IYVJ.js} +1 -1
  160. package/dist/browser/prod/excalidraw-assets/tr-TR-N5SCAVTB-HMUEG6DN.js +7 -0
  161. package/dist/browser/prod/excalidraw-assets/uk-UA-LBCYVSQZ-DEJZCNRZ.js +6 -0
  162. package/dist/browser/prod/excalidraw-assets/vi-VN-POZWLIUU-EY6QFLQV.js +5 -0
  163. package/dist/browser/prod/excalidraw-assets/{xychartDiagram-ab372869-QZGPPHJP.js → xychartDiagram-ab372869-SUXFHV53.js} +1 -1
  164. package/dist/browser/prod/excalidraw-assets/zh-CN-FUF5V3SC-5UIL2T3T.js +10 -0
  165. package/dist/browser/prod/excalidraw-assets/zh-HK-OB4VW42C-3ID2CCZJ.js +1 -0
  166. package/dist/browser/prod/excalidraw-assets/zh-TW-5JPVKOM7-VUPJBABS.js +9 -0
  167. package/dist/browser/prod/index.css +1 -1
  168. package/dist/browser/prod/index.js +128 -1
  169. package/dist/dev/{en-R7FEFJGC.json → en-Q552WR7L.json} +1 -1
  170. package/dist/dev/index.css +38 -15
  171. package/dist/dev/index.css.map +2 -2
  172. package/dist/dev/index.js +4575 -2598
  173. package/dist/dev/index.js.map +4 -4
  174. package/dist/excalidraw/actions/actionAddToLibrary.d.ts +4 -4
  175. package/dist/excalidraw/actions/actionAddToLibrary.js +4 -3
  176. package/dist/excalidraw/actions/actionAlign.d.ts +20 -20
  177. package/dist/excalidraw/actions/actionAlign.js +7 -6
  178. package/dist/excalidraw/actions/actionBoundText.d.ts +7 -7
  179. package/dist/excalidraw/actions/actionBoundText.js +8 -4
  180. package/dist/excalidraw/actions/actionCanvas.d.ts +49 -49
  181. package/dist/excalidraw/actions/actionCanvas.js +16 -13
  182. package/dist/excalidraw/actions/actionClipboard.d.ts +24 -24
  183. package/dist/excalidraw/actions/actionClipboard.js +14 -13
  184. package/dist/excalidraw/actions/actionDeleteSelected.d.ts +8 -8
  185. package/dist/excalidraw/actions/actionDeleteSelected.js +6 -3
  186. package/dist/excalidraw/actions/actionDistribute.d.ts +8 -8
  187. package/dist/excalidraw/actions/actionDistribute.js +3 -2
  188. package/dist/excalidraw/actions/actionDuplicateSelection.d.ts +5 -6
  189. package/dist/excalidraw/actions/actionDuplicateSelection.js +7 -3
  190. package/dist/excalidraw/actions/actionElementLock.d.ts +8 -8
  191. package/dist/excalidraw/actions/actionElementLock.js +3 -2
  192. package/dist/excalidraw/actions/actionExport.d.ts +36 -36
  193. package/dist/excalidraw/actions/actionExport.js +15 -11
  194. package/dist/excalidraw/actions/actionFinalize.d.ts +8 -8
  195. package/dist/excalidraw/actions/actionFinalize.js +9 -5
  196. package/dist/excalidraw/actions/actionFlip.d.ts +9 -9
  197. package/dist/excalidraw/actions/actionFlip.js +10 -9
  198. package/dist/excalidraw/actions/actionFrame.d.ts +14 -169
  199. package/dist/excalidraw/actions/actionFrame.js +7 -6
  200. package/dist/excalidraw/actions/actionGroup.d.ts +11 -321
  201. package/dist/excalidraw/actions/actionGroup.js +9 -11
  202. package/dist/excalidraw/actions/actionHistory.d.ts +3 -2
  203. package/dist/excalidraw/actions/actionHistory.js +27 -28
  204. package/dist/excalidraw/actions/actionLinearEditor.d.ts +2 -2
  205. package/dist/excalidraw/actions/actionLinearEditor.js +2 -1
  206. package/dist/excalidraw/actions/actionLink.d.ts +5 -5
  207. package/dist/excalidraw/actions/actionLink.js +2 -1
  208. package/dist/excalidraw/actions/actionMenu.d.ts +8 -8
  209. package/dist/excalidraw/actions/actionMenu.js +4 -3
  210. package/dist/excalidraw/actions/actionNavigate.d.ts +3 -3
  211. package/dist/excalidraw/actions/actionNavigate.js +3 -2
  212. package/dist/excalidraw/actions/actionProperties.d.ts +32 -32
  213. package/dist/excalidraw/actions/actionProperties.js +18 -13
  214. package/dist/excalidraw/actions/actionSelectAll.d.ts +4 -4
  215. package/dist/excalidraw/actions/actionSelectAll.js +2 -1
  216. package/dist/excalidraw/actions/actionStyles.d.ts +9 -12
  217. package/dist/excalidraw/actions/actionStyles.js +4 -3
  218. package/dist/excalidraw/actions/actionToggleGridMode.d.ts +6 -4
  219. package/dist/excalidraw/actions/actionToggleGridMode.js +6 -2
  220. package/dist/excalidraw/actions/actionToggleObjectsSnapMode.d.ts +4 -4
  221. package/dist/excalidraw/actions/actionToggleObjectsSnapMode.js +2 -1
  222. package/dist/excalidraw/actions/actionToggleStats.d.ts +4 -4
  223. package/dist/excalidraw/actions/actionToggleStats.js +2 -1
  224. package/dist/excalidraw/actions/actionToggleViewMode.d.ts +4 -4
  225. package/dist/excalidraw/actions/actionToggleViewMode.js +2 -1
  226. package/dist/excalidraw/actions/actionToggleZenMode.d.ts +4 -4
  227. package/dist/excalidraw/actions/actionToggleZenMode.js +2 -1
  228. package/dist/excalidraw/actions/actionZindex.d.ts +19 -19
  229. package/dist/excalidraw/actions/actionZindex.js +5 -4
  230. package/dist/excalidraw/actions/manager.d.ts +3 -3
  231. package/dist/excalidraw/actions/types.d.ts +4 -4
  232. package/dist/excalidraw/appState.d.ts +5 -5
  233. package/dist/excalidraw/change.d.ts +191 -0
  234. package/dist/excalidraw/change.js +894 -0
  235. package/dist/excalidraw/components/App.d.ts +22 -7
  236. package/dist/excalidraw/components/App.js +340 -130
  237. package/dist/excalidraw/components/CommandPalette/CommandPalette.js +1 -0
  238. package/dist/excalidraw/components/HelpDialog.js +1 -1
  239. package/dist/excalidraw/components/Sidebar/Sidebar.d.ts +2 -2
  240. package/dist/excalidraw/components/Stack.d.ts +2 -2
  241. package/dist/excalidraw/components/ToolButton.d.ts +1 -0
  242. package/dist/excalidraw/components/ToolButton.js +1 -1
  243. package/dist/excalidraw/components/canvases/InteractiveCanvas.d.ts +2 -1
  244. package/dist/excalidraw/components/canvases/InteractiveCanvas.js +1 -0
  245. package/dist/excalidraw/components/hyperlink/Hyperlink.js +3 -3
  246. package/dist/excalidraw/components/hyperlink/helpers.js +2 -3
  247. package/dist/excalidraw/components/icons.d.ts +1 -0
  248. package/dist/excalidraw/components/icons.js +1 -0
  249. package/dist/excalidraw/components/main-menu/DefaultItems.d.ts +1 -1
  250. package/dist/excalidraw/constants.d.ts +3 -3
  251. package/dist/excalidraw/constants.js +6 -3
  252. package/dist/excalidraw/data/reconcile.d.ts +6 -0
  253. package/dist/excalidraw/data/reconcile.js +49 -0
  254. package/dist/excalidraw/data/restore.d.ts +3 -3
  255. package/dist/excalidraw/data/restore.js +6 -7
  256. package/dist/excalidraw/data/transform.d.ts +1 -1
  257. package/dist/excalidraw/data/transform.js +4 -3
  258. package/dist/excalidraw/data/url.d.ts +1 -0
  259. package/dist/excalidraw/data/url.js +4 -1
  260. package/dist/excalidraw/element/binding.d.ts +64 -9
  261. package/dist/excalidraw/element/binding.js +634 -96
  262. package/dist/excalidraw/element/bounds.d.ts +0 -1
  263. package/dist/excalidraw/element/bounds.js +0 -3
  264. package/dist/excalidraw/element/collision.d.ts +14 -19
  265. package/dist/excalidraw/element/collision.js +36 -713
  266. package/dist/excalidraw/element/embeddable.d.ts +7 -4
  267. package/dist/excalidraw/element/embeddable.js +88 -27
  268. package/dist/excalidraw/element/index.d.ts +0 -1
  269. package/dist/excalidraw/element/index.js +0 -1
  270. package/dist/excalidraw/element/linearElementEditor.d.ts +11 -11
  271. package/dist/excalidraw/element/linearElementEditor.js +7 -5
  272. package/dist/excalidraw/element/mutateElement.d.ts +1 -2
  273. package/dist/excalidraw/element/newElement.d.ts +1 -1
  274. package/dist/excalidraw/element/newElement.js +2 -1
  275. package/dist/excalidraw/element/resizeElements.d.ts +1 -1
  276. package/dist/excalidraw/element/resizeElements.js +110 -86
  277. package/dist/excalidraw/element/resizeTest.d.ts +4 -4
  278. package/dist/excalidraw/element/resizeTest.js +55 -8
  279. package/dist/excalidraw/element/sizeHelpers.js +3 -0
  280. package/dist/excalidraw/element/textElement.d.ts +1 -2
  281. package/dist/excalidraw/element/textElement.js +5 -34
  282. package/dist/excalidraw/element/transformHandles.d.ts +22 -4
  283. package/dist/excalidraw/element/transformHandles.js +24 -3
  284. package/dist/excalidraw/element/typeChecks.d.ts +2 -2
  285. package/dist/excalidraw/element/types.d.ts +19 -6
  286. package/dist/excalidraw/errors.d.ts +3 -0
  287. package/dist/excalidraw/errors.js +3 -0
  288. package/dist/excalidraw/fractionalIndex.d.ts +40 -0
  289. package/dist/excalidraw/fractionalIndex.js +241 -0
  290. package/dist/excalidraw/frame.d.ts +1 -1
  291. package/dist/excalidraw/groups.d.ts +2 -0
  292. package/dist/excalidraw/groups.js +17 -0
  293. package/dist/excalidraw/history.d.ts +34 -46
  294. package/dist/excalidraw/history.js +100 -167
  295. package/dist/excalidraw/hooks/useEmitter.d.ts +2 -0
  296. package/dist/excalidraw/hooks/useEmitter.js +13 -0
  297. package/dist/excalidraw/index.d.ts +2 -0
  298. package/dist/excalidraw/index.js +2 -0
  299. package/dist/excalidraw/locales/en.json +1 -1
  300. package/dist/excalidraw/renderer/interactiveScene.d.ts +1 -1
  301. package/dist/excalidraw/renderer/interactiveScene.js +8 -7
  302. package/dist/excalidraw/renderer/staticScene.js +14 -3
  303. package/dist/excalidraw/renderer/staticSvgScene.js +10 -0
  304. package/dist/excalidraw/scene/Scene.d.ts +7 -6
  305. package/dist/excalidraw/scene/Scene.js +31 -16
  306. package/dist/excalidraw/scene/export.js +2 -1
  307. package/dist/excalidraw/scene/types.d.ts +2 -1
  308. package/dist/excalidraw/store.d.ts +99 -0
  309. package/dist/excalidraw/store.js +269 -0
  310. package/dist/excalidraw/types.d.ts +18 -4
  311. package/dist/excalidraw/utils.d.ts +6 -0
  312. package/dist/excalidraw/utils.js +7 -0
  313. package/dist/excalidraw/zindex.d.ts +2 -2
  314. package/dist/excalidraw/zindex.js +9 -13
  315. package/dist/prod/{en-R7FEFJGC.json → en-Q552WR7L.json} +1 -1
  316. package/dist/prod/index.css +1 -1
  317. package/dist/prod/index.js +44 -44
  318. package/dist/utils/collision.d.ts +4 -0
  319. package/dist/utils/collision.js +48 -0
  320. package/dist/utils/geometry/geometry.d.ts +71 -0
  321. package/dist/utils/geometry/geometry.js +674 -0
  322. package/dist/utils/geometry/shape.d.ts +56 -0
  323. package/dist/utils/geometry/shape.js +168 -0
  324. package/history.ts +161 -216
  325. package/package.json +2 -1
  326. package/dist/browser/dev/excalidraw-assets-dev/chunk-GPOYIZPX.js.map +0 -7
  327. package/dist/browser/dev/excalidraw-assets-dev/chunk-J5HRUYQR.js.map +0 -7
  328. package/dist/browser/dev/excalidraw-assets-dev/chunk-UETNA2WX.js.map +0 -7
  329. package/dist/browser/dev/excalidraw-assets-dev/dist-Y7S5GOTG.js +0 -10
  330. package/dist/browser/dev/excalidraw-assets-dev/image-ZNQQXS62.css.map +0 -7
  331. package/dist/browser/prod/excalidraw-assets/chunk-EEN6AFMH.js +0 -269
  332. package/dist/browser/prod/excalidraw-assets/dist-7FHVDAZ2.js +0 -1
  333. package/dist/browser/prod/excalidraw-assets/flowDiagram-v2-3b53844e-CRHRHP7H.js +0 -1
  334. package/dist/browser/prod/excalidraw-assets/image-VXYNPVOG.js +0 -1
  335. package/dist/browser/prod/excalidraw-assets/image-WE6NA2G6.css +0 -1
  336. /package/dist/browser/dev/excalidraw-assets-dev/{blockDiagram-91b80b7a-RHODGCTM.js.map → blockDiagram-91b80b7a-NRABZKZA.js.map} +0 -0
  337. /package/dist/browser/dev/excalidraw-assets-dev/{c4Diagram-b2a90758-W7NCR7LR.js.map → c4Diagram-b2a90758-56M32CJD.js.map} +0 -0
  338. /package/dist/browser/dev/excalidraw-assets-dev/{chunk-TKRIVTWP.js.map → chunk-5EDB2FTV.js.map} +0 -0
  339. /package/dist/browser/dev/excalidraw-assets-dev/{chunk-52OGG53V.js.map → chunk-6VTJEXQH.js.map} +0 -0
  340. /package/dist/browser/dev/excalidraw-assets-dev/{chunk-GF7VCOUM.js.map → chunk-C4OL7SRI.js.map} +0 -0
  341. /package/dist/browser/dev/excalidraw-assets-dev/{chunk-BESQLMCW.js.map → chunk-E47I6Q7O.js.map} +0 -0
  342. /package/dist/browser/dev/excalidraw-assets-dev/{chunk-5747M6KP.js.map → chunk-OH2YDYHX.js.map} +0 -0
  343. /package/dist/browser/dev/excalidraw-assets-dev/{chunk-GCA4S2OA.js.map → chunk-RTA6DTUV.js.map} +0 -0
  344. /package/dist/browser/dev/excalidraw-assets-dev/{chunk-DQOPSCYA.js.map → chunk-TTH3BTHQ.js.map} +0 -0
  345. /package/dist/browser/dev/excalidraw-assets-dev/{chunk-B2MHJWXZ.js.map → chunk-U4N7TEPH.js.map} +0 -0
  346. /package/dist/browser/dev/excalidraw-assets-dev/{chunk-QFS4M5OJ.js.map → chunk-V3PA4IDR.js.map} +0 -0
  347. /package/dist/browser/dev/excalidraw-assets-dev/{chunk-SLLUETBM.js.map → chunk-WFT6ZJE6.js.map} +0 -0
  348. /package/dist/browser/dev/excalidraw-assets-dev/{chunk-PPHFJLL7.js.map → chunk-XZKEYTKS.js.map} +0 -0
  349. /package/dist/browser/dev/excalidraw-assets-dev/{chunk-USLWOHUZ.js.map → chunk-YC6VTXEO.js.map} +0 -0
  350. /package/dist/browser/dev/excalidraw-assets-dev/{classDiagram-30eddba6-GJGBT4TV.js.map → classDiagram-30eddba6-EZJVINS6.js.map} +0 -0
  351. /package/dist/browser/dev/excalidraw-assets-dev/{classDiagram-v2-f2df5561-LYWTIPJA.js.map → classDiagram-v2-f2df5561-XSUIN44A.js.map} +0 -0
  352. /package/dist/browser/dev/excalidraw-assets-dev/{directory-open-01563666-UREMLRIT.js.map → directory-open-01563666-KOK2HSB6.js.map} +0 -0
  353. /package/dist/browser/dev/excalidraw-assets-dev/{directory-open-4ed118d0-UN3BUDZZ.js.map → directory-open-4ed118d0-P3Q3CLF3.js.map} +0 -0
  354. /package/dist/browser/dev/excalidraw-assets-dev/{dist-Y7S5GOTG.js.map → dist-O6HOTHQF.js.map} +0 -0
  355. /package/dist/browser/dev/excalidraw-assets-dev/{en-UW5C5KGW.js.map → en-PSBMWL4S.js.map} +0 -0
  356. /package/dist/browser/dev/excalidraw-assets-dev/{erDiagram-47591fe2-Z7U2XW2Y.js.map → erDiagram-47591fe2-U7FLWOG3.js.map} +0 -0
  357. /package/dist/browser/dev/excalidraw-assets-dev/{file-open-002ab408-4QG336MG.js.map → file-open-002ab408-EQEHGU2J.js.map} +0 -0
  358. /package/dist/browser/dev/excalidraw-assets-dev/{file-open-7c801643-3QI4ICCL.js.map → file-open-7c801643-QQT6O7P5.js.map} +0 -0
  359. /package/dist/browser/dev/excalidraw-assets-dev/{file-save-3189631c-TNNERCWV.js.map → file-save-3189631c-YXX2C7C6.js.map} +0 -0
  360. /package/dist/browser/dev/excalidraw-assets-dev/{file-save-745eba88-JFMH565P.js.map → file-save-745eba88-7G554KTZ.js.map} +0 -0
  361. /package/dist/browser/dev/excalidraw-assets-dev/{flowDiagram-5540d9b9-PARVG263.js.map → flowDiagram-5540d9b9-F2VP4JAA.js.map} +0 -0
  362. /package/dist/browser/dev/excalidraw-assets-dev/{flowDiagram-v2-3b53844e-ZJOPVRMB.js.map → flowDiagram-v2-3b53844e-2WQZZRND.js.map} +0 -0
  363. /package/dist/browser/dev/excalidraw-assets-dev/{flowchart-elk-definition-5fe447d6-ULPNBSZX.js.map → flowchart-elk-definition-5fe447d6-IW6O2F6C.js.map} +0 -0
  364. /package/dist/browser/dev/excalidraw-assets-dev/{ganttDiagram-9a3bba1f-ESSYVTJ4.js.map → ganttDiagram-9a3bba1f-B5RH7ZAO.js.map} +0 -0
  365. /package/dist/browser/dev/excalidraw-assets-dev/{gitGraphDiagram-96e6b4ee-6V6VVNNP.js.map → gitGraphDiagram-96e6b4ee-INGQRNLZ.js.map} +0 -0
  366. /package/dist/browser/dev/excalidraw-assets-dev/{image-3LTGFHLF.js.map → image-GMAHLVER.js.map} +0 -0
  367. /package/dist/browser/dev/excalidraw-assets-dev/{image-blob-reduce.esm-KTX27DAY.js.map → image-blob-reduce.esm-OX75MRP3.js.map} +0 -0
  368. /package/dist/browser/dev/excalidraw-assets-dev/{infoDiagram-bcd20f53-I22FLFX3.js.map → infoDiagram-bcd20f53-43FMAUOR.js.map} +0 -0
  369. /package/dist/browser/dev/excalidraw-assets-dev/{journeyDiagram-4fe6b3dc-WAO6F52C.js.map → journeyDiagram-4fe6b3dc-KFVOUX4I.js.map} +0 -0
  370. /package/dist/browser/dev/excalidraw-assets-dev/{katex-NWA2YFOP.js.map → katex-A3GRORPB.js.map} +0 -0
  371. /package/dist/browser/dev/excalidraw-assets-dev/{mindmap-definition-f354de21-K74IKX4Y.js.map → mindmap-definition-f354de21-D7S3CRQ4.js.map} +0 -0
  372. /package/dist/browser/dev/excalidraw-assets-dev/{pica-3TH2EGXR.js.map → pica-ZAD7MTGA.js.map} +0 -0
  373. /package/dist/browser/dev/excalidraw-assets-dev/{pieDiagram-79897490-DOB2LVE5.js.map → pieDiagram-79897490-OON2CRZ5.js.map} +0 -0
  374. /package/dist/browser/dev/excalidraw-assets-dev/{quadrantDiagram-62f64e94-MJV2X7WI.js.map → quadrantDiagram-62f64e94-5APTNVVS.js.map} +0 -0
  375. /package/dist/browser/dev/excalidraw-assets-dev/{requirementDiagram-05bf5f74-H4YM3XN7.js.map → requirementDiagram-05bf5f74-FM7WZVKU.js.map} +0 -0
  376. /package/dist/browser/dev/excalidraw-assets-dev/{roundRect-4S3QV2NZ.js.map → roundRect-AYYHVX5X.js.map} +0 -0
  377. /package/dist/browser/dev/excalidraw-assets-dev/{sankeyDiagram-97764748-7X74ABAN.js.map → sankeyDiagram-97764748-5HLEFFGY.js.map} +0 -0
  378. /package/dist/browser/dev/excalidraw-assets-dev/{sequenceDiagram-acc0e65c-PPDIJFQP.js.map → sequenceDiagram-acc0e65c-4ZRSNGPV.js.map} +0 -0
  379. /package/dist/browser/dev/excalidraw-assets-dev/{stateDiagram-0ff1cf1a-JVBR7N35.js.map → stateDiagram-0ff1cf1a-OLTPYRPP.js.map} +0 -0
  380. /package/dist/browser/dev/excalidraw-assets-dev/{stateDiagram-v2-9a9d610d-QYAJLQJH.js.map → stateDiagram-v2-9a9d610d-N3XOTAEE.js.map} +0 -0
  381. /package/dist/browser/dev/excalidraw-assets-dev/{timeline-definition-fea2a41d-GL7U3WDB.js.map → timeline-definition-fea2a41d-5PDFIYJQ.js.map} +0 -0
  382. /package/dist/browser/dev/excalidraw-assets-dev/{xychartDiagram-ab372869-4U4JE4TW.js.map → xychartDiagram-ab372869-VIWBP45Y.js.map} +0 -0
@@ -1,18 +1,18 @@
1
- var yk=Object.defineProperty;var H0=e=>t=>{var o=e[t];if(o)return o();throw new Error("Module not found in bundle: "+t)};var v=(e,t)=>()=>(e&&(t=e(e=0)),t);var Os=(e,t)=>{for(var o in t)yk(e,o,{get:t[o],enumerable:!0})};var C,f=v(()=>{C={NODE_ENV:"production",VITE_APP_BACKEND_V2_GET_URL:"https://json.excalidraw.com/api/v2/",VITE_APP_BACKEND_V2_POST_URL:"https://json.excalidraw.com/api/v2/post/",VITE_APP_LIBRARY_URL:"https://libraries.excalidraw.com",VITE_APP_LIBRARY_BACKEND:"https://us-central1-excalidraw-room-persistence.cloudfunctions.net/libraries",VITE_APP_PLUS_LP:"https://plus.excalidraw.com",VITE_APP_PLUS_APP:"https://app.excalidraw.com",VITE_APP_AI_BACKEND:"https://oss-ai.excalidraw.com",VITE_APP_WS_SERVER_URL:"https://oss-collab.excalidraw.com",VITE_APP_FIREBASE_CONFIG:'{"apiKey":"AIzaSyAd15pYlMci_xIp9ko6wkEsDzAAA0Dn0RU","authDomain":"excalidraw-room-persistence.firebaseapp.com","databaseURL":"https://excalidraw-room-persistence.firebaseio.com","projectId":"excalidraw-room-persistence","storageBucket":"excalidraw-room-persistence.appspot.com","messagingSenderId":"654800341332","appId":"1:654800341332:web:4a692de832b55bd57ce0c1"}',VITE_APP_DISABLE_TRACKING:"",VITE_PKG_NAME:"@excalidraw/excalidraw",VITE_PKG_VERSION:"0.5.0-da1c822",VITE_IS_EXCALIDRAW_NPM_PACKAGE:!0,PROD:!0}});import{unstable_createStore as vk,useAtom as sN}from"jotai";import{useLayoutEffect as dN}from"react";var He,Zt,Tt=v(()=>{"use strict";f();He=Symbol(),Zt=vk()});var Tk,sh=v(()=>{Tk=H0({"./locales/ar-SA.json":()=>import("./ar-SA-JA6F2FMJ.json"),"./locales/az-AZ.json":()=>import("./az-AZ-GVIENQVH.json"),"./locales/bg-BG.json":()=>import("./bg-BG-YFNNHCEP.json"),"./locales/bn-BD.json":()=>import("./bn-BD-LMEIWSRD.json"),"./locales/ca-ES.json":()=>import("./ca-ES-C2WGCLOT.json"),"./locales/cs-CZ.json":()=>import("./cs-CZ-F2NDIQMB.json"),"./locales/da-DK.json":()=>import("./da-DK-WBEQB3CJ.json"),"./locales/de-DE.json":()=>import("./de-DE-VEIMCP7R.json"),"./locales/el-GR.json":()=>import("./el-GR-TKRKG5GQ.json"),"./locales/en.json":()=>import("./en-R7FEFJGC.json"),"./locales/es-ES.json":()=>import("./es-ES-TOLWEZNW.json"),"./locales/eu-ES.json":()=>import("./eu-ES-7CDRJQWJ.json"),"./locales/fa-IR.json":()=>import("./fa-IR-527E2XGU.json"),"./locales/fi-FI.json":()=>import("./fi-FI-NLQ7RQGZ.json"),"./locales/fr-FR.json":()=>import("./fr-FR-KUHO4FLU.json"),"./locales/gl-ES.json":()=>import("./gl-ES-NEXX3VBB.json"),"./locales/he-IL.json":()=>import("./he-IL-MED2VGBZ.json"),"./locales/hi-IN.json":()=>import("./hi-IN-5V633W7V.json"),"./locales/hu-HU.json":()=>import("./hu-HU-2FOZGVGR.json"),"./locales/id-ID.json":()=>import("./id-ID-I6BOLXTF.json"),"./locales/it-IT.json":()=>import("./it-IT-WKPQOK4P.json"),"./locales/ja-JP.json":()=>import("./ja-JP-VKA4ISRU.json"),"./locales/kaa.json":()=>import("./kaa-IKPRSBNY.json"),"./locales/kab-KAB.json":()=>import("./kab-KAB-IE4PHQTZ.json"),"./locales/kk-KZ.json":()=>import("./kk-KZ-MNJT6XSV.json"),"./locales/km-KH.json":()=>import("./km-KH-LADGDFXV.json"),"./locales/ko-KR.json":()=>import("./ko-KR-XD7AVF2F.json"),"./locales/ku-TR.json":()=>import("./ku-TR-4XBHKDQA.json"),"./locales/lt-LT.json":()=>import("./lt-LT-QC35R4YH.json"),"./locales/lv-LV.json":()=>import("./lv-LV-GSD5D3BA.json"),"./locales/mr-IN.json":()=>import("./mr-IN-KOLSWM7Y.json"),"./locales/my-MM.json":()=>import("./my-MM-M53KMUET.json"),"./locales/nb-NO.json":()=>import("./nb-NO-XXC6U37A.json"),"./locales/nl-NL.json":()=>import("./nl-NL-HCCJQEUO.json"),"./locales/nn-NO.json":()=>import("./nn-NO-6P7Z2PI2.json"),"./locales/oc-FR.json":()=>import("./oc-FR-JRJKPLNT.json"),"./locales/pa-IN.json":()=>import("./pa-IN-LZWLEPIB.json"),"./locales/percentages.json":()=>import("./percentages-UCQDHIQF.json"),"./locales/pl-PL.json":()=>import("./pl-PL-3WBLCXI2.json"),"./locales/pt-BR.json":()=>import("./pt-BR-O3ZPTUNW.json"),"./locales/pt-PT.json":()=>import("./pt-PT-7AQTSAFO.json"),"./locales/ro-RO.json":()=>import("./ro-RO-HJ65JYWV.json"),"./locales/ru-RU.json":()=>import("./ru-RU-P7ROIYNC.json"),"./locales/si-LK.json":()=>import("./si-LK-7ZSWVION.json"),"./locales/sk-SK.json":()=>import("./sk-SK-NXVBGLYY.json"),"./locales/sl-SI.json":()=>import("./sl-SI-VFTWOYNP.json"),"./locales/sv-SE.json":()=>import("./sv-SE-YONBLQNW.json"),"./locales/ta-IN.json":()=>import("./ta-IN-BSETPMLX.json"),"./locales/th-TH.json":()=>import("./th-TH-URTRDITB.json"),"./locales/tr-TR.json":()=>import("./tr-TR-N5SCAVTB.json"),"./locales/uk-UA.json":()=>import("./uk-UA-LBCYVSQZ.json"),"./locales/vi-VN.json":()=>import("./vi-VN-POZWLIUU.json"),"./locales/zh-CN.json":()=>import("./zh-CN-FUF5V3SC.json"),"./locales/zh-HK.json":()=>import("./zh-HK-OB4VW42C.json"),"./locales/zh-TW.json":()=>import("./zh-TW-5JPVKOM7.json")})});import G0 from"./en-R7FEFJGC.json";import Ck from"./percentages-UCQDHIQF.json";import{atom as Ik,useAtomValue as Sk}from"jotai";var kk,Vr,sl,Jd,ll,qd,Qd,Cn,z0,b,U0,Ct,X=v(()=>{"use strict";f();Tt();sh();kk=85,Vr={code:"en",label:"English"},sl=[Vr,...[{code:"ar-SA",label:"\u0627\u0644\u0639\u0631\u0628\u064A\u0629",rtl:!0},{code:"bg-BG",label:"\u0411\u044A\u043B\u0433\u0430\u0440\u0441\u043A\u0438"},{code:"ca-ES",label:"Catal\xE0"},{code:"cs-CZ",label:"\u010Cesky"},{code:"de-DE",label:"Deutsch"},{code:"el-GR",label:"\u0395\u03BB\u03BB\u03B7\u03BD\u03B9\u03BA\u03AC"},{code:"es-ES",label:"Espa\xF1ol"},{code:"eu-ES",label:"Euskara"},{code:"fa-IR",label:"\u0641\u0627\u0631\u0633\u06CC",rtl:!0},{code:"fi-FI",label:"Suomi"},{code:"fr-FR",label:"Fran\xE7ais"},{code:"gl-ES",label:"Galego"},{code:"he-IL",label:"\u05E2\u05D1\u05E8\u05D9\u05EA",rtl:!0},{code:"hi-IN",label:"\u0939\u093F\u0928\u094D\u0926\u0940"},{code:"hu-HU",label:"Magyar"},{code:"id-ID",label:"Bahasa Indonesia"},{code:"it-IT",label:"Italiano"},{code:"ja-JP",label:"\u65E5\u672C\u8A9E"},{code:"kab-KAB",label:"Taqbaylit"},{code:"kk-KZ",label:"\u049A\u0430\u0437\u0430\u049B \u0442\u0456\u043B\u0456"},{code:"ko-KR",label:"\uD55C\uAD6D\uC5B4"},{code:"ku-TR",label:"Kurd\xEE"},{code:"lt-LT",label:"Lietuvi\u0173"},{code:"lv-LV",label:"Latvie\u0161u"},{code:"my-MM",label:"Burmese"},{code:"nb-NO",label:"Norsk bokm\xE5l"},{code:"nl-NL",label:"Nederlands"},{code:"nn-NO",label:"Norsk nynorsk"},{code:"oc-FR",label:"Occitan"},{code:"pa-IN",label:"\u0A2A\u0A70\u0A1C\u0A3E\u0A2C\u0A40"},{code:"pl-PL",label:"Polski"},{code:"pt-BR",label:"Portugu\xEAs Brasileiro"},{code:"pt-PT",label:"Portugu\xEAs"},{code:"ro-RO",label:"Rom\xE2n\u0103"},{code:"ru-RU",label:"\u0420\u0443\u0441\u0441\u043A\u0438\u0439"},{code:"sk-SK",label:"Sloven\u010Dina"},{code:"sv-SE",label:"Svenska"},{code:"sl-SI",label:"Sloven\u0161\u010Dina"},{code:"tr-TR",label:"T\xFCrk\xE7e"},{code:"uk-UA",label:"\u0423\u043A\u0440\u0430\u0457\u043D\u0441\u044C\u043A\u0430"},{code:"zh-CN",label:"\u7B80\u4F53\u4E2D\u6587"},{code:"zh-TW",label:"\u7E41\u9AD4\u4E2D\u6587"},{code:"vi-VN",label:"Ti\u1EBFng Vi\u1EC7t"},{code:"mr-IN",label:"\u092E\u0930\u093E\u0920\u0940"}].filter(e=>Ck[e.code]>=kk).sort((e,t)=>e.label>t.label?1:-1)],Jd="__test__";C.DEV&&sl.unshift({code:Jd,label:"test language"},{code:`${Jd}.rtl`,label:"\u202Atest language (rtl)\u202C",rtl:!0});ll=Vr,qd={},Qd=async e=>{if(ll=e,document.documentElement.dir=ll.rtl?"rtl":"ltr",document.documentElement.lang=ll.code,e.code.startsWith(Jd))qd={};else try{qd=await Tk(`./locales/${ll.code}.json`)}catch(t){console.error(`Failed to load language ${e.code}:`,t.message),qd=G0}Zt.set(U0,e.code)},Cn=()=>ll,z0=(e,t)=>{for(let o=0;o<t.length;++o){let r=t[o];if(e[r]===void 0)return;e=e[r]}if(typeof e=="string")return e},b=(e,t,o)=>{if(ll.code.startsWith(Jd))return`\u202A[[${t?`${e}(${JSON.stringify(t).slice(1,-1)})`:e}]]\u202C`;let r=e.split("."),n=z0(qd,r)||z0(G0,r)||o;if(n===void 0){let i=`Can't find translation for ${e}`;if(C.PROD)return console.warn(i),"";throw new Error(i)}if(t)for(let i in t)n=n.replace(`{{${i}}}`,String(t[i]));return n},U0=Ik(Vr.code),Ct=()=>{let e=Sk(U0,He);return{t:b,langCode:e}}});var W0=v(()=>{});import Ak from"react";import{jsx as ch}from"react/jsx-runtime";var Mk,jt,In=v(()=>{"use strict";f();W0();Mk=({size:e="1em",circleWidth:t=8,synchronized:o=!1})=>{let n=-(Ak.useRef(Date.now()).current%1600);return ch("div",{className:"Spinner",children:ch("svg",{viewBox:"0 0 100 100",style:{width:e,height:e,"--spinner-delay":o?`${n}ms`:0},children:ch("circle",{cx:"50",cy:"50",r:50-t/2,strokeWidth:t,fill:"none",strokeMiterlimit:"10"})})})},jt=Mk});var so,em,MN,Sn,Lk,LN,V0,Y0,Bs,Fs,kn,cl,K0,dh,$0,Yr,mh,Pe,ai,na,Hs,ph,tm,dt,ie,Je,uh,om,Rt,qt,li,ia,aa,rm,Ht,si,zs,X0,An,Gs,Z0,J,nm,ro,Us,j0,q0,J0,Q0,la,im,ey,dl,am,lm,gh,ty,oy,ry,ny,iy,ml,pl,Kr,ay,hh,Ue,sa,xt,ly,sy,yt,ci,cy,sm,dy,at,cm,fh,dm,rt,Ws,Do,mm,wt,or,pm,U=v(()=>{"use strict";f();so=/Mac|iPod|iPhone|iPad/.test(navigator.platform),em=/^Win/.test(navigator.platform),MN=/\b(android)\b/i.test(navigator.userAgent),Sn="netscape"in window&&navigator.userAgent.indexOf("rv:")>1&&navigator.userAgent.indexOf("Gecko")>1,Lk=navigator.userAgent.indexOf("Chrome")!==-1,LN=!Lk&&navigator.userAgent.indexOf("Safari")!==-1,V0=/iPad|iPhone/.test(navigator.platform)||navigator.userAgent.includes("Mac")&&"ontouchend"in document,Y0=()=>navigator.brave?.isBrave?.name==="isBrave",Bs=typeof window<"u"&&"ResizeObserver"in window,Fs="Excalidraw",kn=10,cl=8,K0=5,dh=1,$0=30,Yr=Math.PI/12,mh="red",Pe={TEXT:"text",CROSSHAIR:"crosshair",GRABBING:"grabbing",GRAB:"grab",POINTER:"pointer",MOVE:"move",AUTO:""},ai={MAIN:0,WHEEL:1,SECONDARY:2,TOUCH:-1,ERASER:5},na={enabled:"all",disabled:"none",inheritFromUI:"var(--ui-pointerEvents)"},Hs={UNSTARTED:-1,ENDED:0,PLAYING:1,PAUSED:2,BUFFERING:3,CUED:5},ph={TEST:"test"},tm={SHAPE_ACTIONS_MENU:"App-menu__left"},dt={Virgil:1,Helvetica:2,Cascadia:3,Assistant:4},ie={LIGHT:"light",DARK:"dark"},Je={strokeColor:"#bbb",strokeWidth:2,strokeStyle:"solid",fillStyle:"solid",roughness:0,roundness:null,backgroundColor:"transparent",radius:8,nameOffsetY:3,nameColorLightTheme:"#999999",nameColorDarkTheme:"#7a7a7a",nameFontSize:14,nameLineHeight:1.25},uh="Segoe UI Emoji",om=1,Rt=20,qt=dt.Virgil,li="left",ia="top",aa=2,rm=1,Ht="#ffffff",si="#1e1e1e",zs="transparent",X0="#a2f1a6",An=20,Gs={svg:"image/svg+xml",png:"image/png",jpg:"image/jpeg",gif:"image/gif",webp:"image/webp",bmp:"image/bmp",ico:"image/x-icon",avif:"image/avif",jfif:"image/jfif"},Z0=["text/plain","text/html"],J={json:"application/json",excalidraw:"application/vnd.excalidraw+json",excalidrawlib:"application/vnd.excalidrawlib+json","excalidraw.svg":"image/svg+xml","excalidraw.png":"image/png",binary:"application/octet-stream",...Gs},nm={png:"png",svg:"svg",clipboard:"clipboard"},ro={excalidraw:"excalidraw",excalidrawClipboard:"excalidraw/clipboard",excalidrawLibrary:"excalidrawlib",excalidrawClipboardWithAPI:"excalidraw-api/clipboard"},Us=window.EXCALIDRAW_EXPORT_SOURCE||window.location.origin,j0=500,q0=300,J0=500,Q0=100,la=.1,im=.1,ey=300,dl="invert(93%) hue-rotate(180deg)",am={addLibrary:"addLibrary"},lm={addLibrary:"addLibrary"},gh={canvasActions:{changeViewBackgroundColor:!0,clearCanvas:!0,export:{saveFileToDisk:!0},loadScene:!0,saveToActiveFile:!0,toggleTheme:null,saveAsImage:!0},tools:{image:!0}},ty=800,oy=1e3,ry=500,ny=1229,iy=302,ml=2,pl=[1,2,3],Kr=10,ay=1440,hh=2*1024*1024,Ue="http://www.w3.org/2000/svg",sa={excalidraw:2,excalidrawLibrary:2},xt=5,ly=.7,sy=11,yt={TOP:"top",MIDDLE:"middle",BOTTOM:"bottom"},ci={LEFT:"left",CENTER:"center",RIGHT:"right"},cy=20,sm=.25,dy=32,at={LEGACY:1,PROPORTIONAL_RADIUS:2,ADAPTIVE_RADIUS:3},cm="__precedingElement__",fh={architect:0,artist:1,cartoonist:2},dm={thin:1,bold:2,extraBold:4},rt={strokeColor:si,backgroundColor:zs,fillStyle:"solid",strokeWidth:2,strokeStyle:"solid",roughness:fh.artist,opacity:100,locked:!1},Ws="library",Do={name:"default",defaultTab:Ws},mm=new Set(["iframe","embeddable","image"]),wt={selection:"selection",rectangle:"rectangle",diamond:"diamond",ellipse:"ellipse",arrow:"arrow",line:"line",freedraw:"freedraw",text:"text",image:"image",eraser:"eraser",hand:"hand",frame:"frame",magicframe:"magicframe",embeddable:"embeddable",laser:"laser"},or={OAI_API_KEY:"excalidraw-oai-api-key",MERMAID_TO_EXCALIDRAW:"mermaid-to-excalidraw",PUBLISH_LIBRARY:"publish-library-data"},pm="Untitled"});import{useState as _k,useEffect as Pk}from"react";import Dk from"clsx";import{jsx as bh,jsxs as Rk}from"react/jsx-runtime";var um,xh=v(()=>{"use strict";f();X();In();U();um=({delay:e,theme:t})=>{let[o,r]=_k(!!e);return Pk(()=>{if(!e)return;let n=setTimeout(()=>{r(!1)},e);return()=>clearTimeout(n)},[e]),o?null:Rk("div",{className:Dk("LoadingMessage",{"LoadingMessage--dark":t===ie.DARK}),children:[bh("div",{children:bh(jt,{})}),bh("div",{className:"LoadingMessage-text",children:b("labels.loadingScene")})]})}});import{useEffect as Nk,useState as Ok}from"react";import{jsx as Bk}from"react/jsx-runtime";var my,py=v(()=>{"use strict";f();xh();X();my=e=>{let[t,o]=Ok(!0);return Nk(()=>{let r=async()=>{await Qd(n),o(!1)},n=sl.find(i=>i.code===e.langCode)||Vr;r()},[e.langCode]),t?Bk(um,{theme:e.theme}):e.children}});function ft(e,t,o,r){return e?(e?.addEventListener?.(t,o,r),()=>{e?.removeEventListener?.(t,o,r)}):()=>{}}function Ay(e,t=!0){let o=e.length;if(o<4)return"";let r=e[0],n=e[1],i=e[2],a=`M${r[0].toFixed(2)},${r[1].toFixed(2)} Q${n[0].toFixed(2)},${n[1].toFixed(2)} ${gm(n[0],i[0]).toFixed(2)},${gm(n[1],i[1]).toFixed(2)} T`;for(let l=2,s=o-1;l<s;l++)r=e[l],n=e[l+1],a+=`${gm(r[0],n[0]).toFixed(2)},${gm(r[1],n[1]).toFixed(2)} `;return t&&(a+="Z"),a}var uy,Eh,$r,fy,yh,by,rr,ul,Ke,ca,gl,Mn,gy,xy,Ey,Nt,Qe,N,$e,zt,Vs,Fk,Hk,zk,hm,Cr,fm,wh,vh,co,bm,yy,wy,vy,Ty,Ln,re,Cy,Ro,Iy,xm,hl,Sy,Xr,Ys,hy,It,di,mi,ky,Ks,Zr,Th,Em,gm,ym,Ir,$s,My,G=v(()=>{"use strict";f();U();uy=null,Eh=()=>{if(uy)return uy;let e=new Date,t=e.getFullYear(),o=`${e.getMonth()+1}`.padStart(2,"0"),r=`${e.getDate()}`.padStart(2,"0"),n=`${e.getHours()}`.padStart(2,"0"),i=`${e.getMinutes()}`.padStart(2,"0");return`${t}-${o}-${r}-${n}${i}`},$r=e=>e.charAt(0).toUpperCase()+e.slice(1),fy=e=>e instanceof HTMLElement&&e.className.includes("ToolIcon"),yh=e=>e instanceof HTMLElement&&e.dataset.type==="wysiwyg"||e instanceof HTMLBRElement||e instanceof HTMLInputElement||e instanceof HTMLTextAreaElement||e instanceof HTMLSelectElement,by=e=>yh(e)||e instanceof Element&&!!e.closest("label, button"),rr=e=>e instanceof HTMLElement&&e.dataset.type==="wysiwyg"||e instanceof HTMLBRElement||e instanceof HTMLTextAreaElement||e instanceof HTMLInputElement&&(e.type==="text"||e.type==="number"||e.type==="password"),ul=({fontFamily:e})=>{for(let[t,o]of Object.entries(dt))if(o===e)return`${t}, ${uh}`;return uh},Ke=({fontSize:e,fontFamily:t})=>`${e}px ${ul({fontFamily:t})}`,ca=(e,t)=>{let o=0,r=null,n=(...i)=>{r=i,clearTimeout(o),o=window.setTimeout(()=>{r=null,e(...i)},t)};return n.flush=()=>{if(clearTimeout(o),r){let i=r;r=null,e(...i)}},n.cancel=()=>{r=null,clearTimeout(o)},n},gl=(e,t)=>{let o=null,r=null,n=null,i=l=>{o=window.requestAnimationFrame(()=>{o=null,e(...l),r=null,n&&(r=n,n=null,i(r))})},a=(...l)=>{if(C.MODE==="test"){e(...l);return}r=l,o===null?i(r):t?.trailing&&(n=l)};return a.flush=()=>{o!==null&&(cancelAnimationFrame(o),o=null),r&&(e(...n||r),r=n=null)},a.cancel=()=>{r=n=null,o!==null&&(cancelAnimationFrame(o),o=null)},a},Mn=e=>1-Math.pow(1-e,4),gy=(e,t,o)=>(t-e)*Mn(o)+e,xy=({fromValues:e,toValues:t,onStep:o,duration:r=250,interpolateValue:n,onStart:i,onEnd:a,onCancel:l})=>{let s=!1,c=0,d;function m(p){if(s)return;d===void 0&&(d=p,i?.());let u=Math.min(p-d,r),g=Mn(u/r),x={};if(Object.keys(e).forEach(E=>{let y=E,T=(t[y]-e[y])*g+e[y];x[y]=T}),o(x),u<r){let E=u/r,y={};Object.keys(e).forEach(T=>{let w=T,S=e[w],M=t[w],k;k=n?n(S,M,E,w):gy(S,M,E),k==null&&(k=gy(S,M,E)),y[w]=k}),o(y),c=window.requestAnimationFrame(m)}else o(t),a?.()}return c=window.requestAnimationFrame(m),()=>{l?.(),s=!0,window.cancelAnimationFrame(c)}},Ey=(e,t)=>{if(!e.length||t<1)return[];let o=0,r=0,n=Array(Math.ceil(e.length/t));for(;o<e.length;)n[r++]=e.slice(o,o+=t);return n},Nt=(e,t)=>Math.abs(e-t),Qe=(e,t)=>t.type==="custom"?{...e.activeTool,type:"custom",customType:t.customType,locked:t.locked??e.activeTool.locked}:{...e.activeTool,lastActiveTool:t.lastActiveToolBeforeEraser===void 0?e.activeTool.lastActiveTool:t.lastActiveToolBeforeEraser,type:t.type,customType:null,locked:t.locked??e.activeTool.locked},N=e=>(e=e.replace(/\bAlt\b/i,"Alt").replace(/\bShift\b/i,"Shift").replace(/\b(Enter|Return)\b/i,"Enter"),so?e.replace(/\bCtrlOrCmd\b/gi,"Cmd").replace(/\bAlt\b/i,"Option"):e.replace(/\bCtrlOrCmd\b/gi,"Ctrl")),$e=({clientX:e,clientY:t},{zoom:o,offsetLeft:r,offsetTop:n,scrollX:i,scrollY:a})=>{let l=(e-r)/o.value-i,s=(t-n)/o.value-a;return{x:l,y:s}},zt=({sceneX:e,sceneY:t},{zoom:o,offsetLeft:r,offsetTop:n,scrollX:i,scrollY:a})=>{let l=(e+i)*o.value+r,s=(t+a)*o.value+n;return{x:l,y:s}},Vs=e=>getComputedStyle(document.documentElement).getPropertyValue(`--${e}`),Fk="A-Za-z\xC0-\xD6\xD8-\xF6\xF8-\u02B8\u0300-\u0590\u0800-\u1FFF\u2C00-\uFB1C\uFDFE-\uFE6F\uFEFD-\uFFFF",Hk="\u0591-\u07FF\uFB1D-\uFDFD\uFE70-\uFEFC",zk=new RegExp(`^[^${Fk}]*[${Hk}]`),hm=e=>zk.test(e),Cr=e=>{let[t,o]=e;return{x:t,y:o}},fm=e=>{if(e?.name==="AbortError"){console.warn(e);return}throw e},wh=(e,t,o=0)=>{o<0&&(o=e.length+o),o=Math.min(e.length,Math.max(o,0));let r=o-1;for(;++r<e.length;)if(t(e[r],r,e))return r;return-1},vh=(e,t,o=e.length-1)=>{o<0&&(o=e.length+o),o=Math.min(e.length-1,Math.max(o,0));let r=o+1;for(;--r>-1;)if(t(e[r],r,e))return r;return-1},co=e=>{let t=e.length===5&&e.substr(4,1)==="0",o=e.length===9&&e.substr(7,2)==="00";return t||o||e===zs},bm=()=>{let e,t,o=new Promise((r,n)=>{e=r,t=n});return o.resolve=e,o.reject=t,o},yy=e=>{let t=e.parentElement;for(;t;){if(t===document.body)return document;let{overflowY:o}=window.getComputedStyle(t);if(t.scrollHeight>t.clientHeight&&(o==="auto"||o==="scroll"||o==="overlay"))return t;t=t.parentElement}return document},wy=e=>{let t=e.parentElement;for(;t;){if(t.tabIndex>-1){t.focus();return}t=t.parentElement}},vy=e=>{e.preventDefault(),e.returnValue=""},Ty=e=>Array.from(e).map(t=>`0${t.toString(16)}`.slice(-2)).join(""),Ln=()=>Ro()?1:Date.now(),re=e=>e instanceof Map?e:e.reduce((t,o)=>(t.set(typeof o=="string"?o:o.id,o),t),new Map),Cy=e=>e.reduce((t,o,r)=>(t.set(o.id,[o,r]),t),new Map),Ro=()=>C.MODE==="test",Iy=()=>C.MODE==="development",xm=(e,t)=>new CustomEvent(e,{detail:{nativeEvent:t},cancelable:!0}),hl=(e,t)=>{let o=!1;for(let r in t){let n=t[r];if(typeof n<"u"){if(e[r]===n&&(typeof n!="object"||n===null))continue;o=!0}}return o?{...e,...t}:e},Sy=()=>{try{return window.self===window.top?"top":"iframe"}catch{return"iframe"}},Xr=e=>!!e&&typeof e=="object"&&"then"in e&&"catch"in e&&"finally"in e,Ys=e=>{let t=e?.querySelectorAll("button, a, input, select, textarea, div[tabindex], label[tabindex]");return t?Array.from(t).filter(o=>o.tabIndex>-1&&!o.disabled):[]},hy=(e,t)=>Array.isArray(e)&&Array.isArray(t)&&e.length===0&&t.length===0?!0:e===t,It=(e,t,o,r=!1)=>{let n=Object.keys(e),i=Object.keys(t);if(n.length!==i.length)return r&&console.warn("%cisShallowEqual: objects don't have same properties ->","color: #8B4000",e,t),!1;if(o&&Array.isArray(o)){for(let a of o)if(!(e[a]===t[a]||hy(e[a],t[a])))return r&&console.warn(`%cisShallowEqual: ${a} not equal ->`,"color: #8B4000",e[a],t[a]),!1;return!0}return n.every(a=>{let l=o?.[a],s=l?l(e[a],t[a]):e[a]===t[a]||hy(e[a],t[a]);return!s&&r&&console.warn(`%cisShallowEqual: ${a} not equal ->`,"color: #8B4000",e[a],t[a]),s})},di=(e,t,{checkForDefaultPrevented:o=!0}={})=>function(n){if(e?.(n),!o||!n?.defaultPrevented)return t?.(n)},mi=(e,t,o)=>{if(!t)return e;if(o)return console.error(t),e;throw new Error(t)},ky=e=>{let t,o,r=function(n){let i=Object.entries(n);if(t){let l=!0;for(let[s,c]of i)if(t.get(s)!==c){l=!1;break}if(l)return o}let a=e(n);return t=new Map(i),o=a,a};return r.clear=()=>{t=void 0,o=void 0},r},Ks=(e,t)=>e instanceof Set||e instanceof Map?e.has(t):"includes"in e?e.includes(t):e.hasOwnProperty(t),Zr=e=>JSON.parse(JSON.stringify(e)),Th=e=>typeof e=="number"&&Number.isFinite(e),Em=(e,t)=>It(e,t)?e:t;gm=(e,t)=>(e+t)/2;ym=e=>e.replace(/\r?\n|\r/g,`
2
- `),Ir=e=>e,$s=async(e,...t)=>new Promise(o=>{o(e(...t))}),My=(e,t)=>t.reduce((o,r)=>(r in e&&(o[r]=e[r]),o),{})});var mo,nr,St,ir,Jt,W,pi,da,Q,Ot,Gk,ne,ke,Xs,kt,Ch,fl,jr,Zs,Eo,ze,qr,Ly,_y,Py,se=v(()=>{"use strict";f();U();G();mo=e=>!!e&&e.type==="image"&&!!e.fileId,nr=e=>!!e&&e.type==="image",St=e=>!!e&&e.type==="embeddable",ir=e=>!!e&&e.type==="iframe",Jt=e=>!!e&&(e.type==="iframe"||e.type==="embeddable"),W=e=>e!=null&&e.type==="text",pi=e=>e!=null&&e.type==="frame",da=e=>e!=null&&e.type==="magicframe",Q=e=>e!=null&&(e.type==="frame"||e.type==="magicframe"),Ot=e=>e!=null&&Gk(e.type),Gk=e=>e==="freedraw",ne=e=>e!=null&&Xs(e.type),ke=e=>e!=null&&e.type==="arrow",Xs=e=>e==="arrow"||e==="line",kt=(e,t=!0)=>e!=null&&(!e.locked||t===!0)&&Ch(e.type),Ch=e=>e==="arrow",fl=(e,t=!0)=>e!=null&&(!e.locked||t===!0)&&(e.type==="rectangle"||e.type==="diamond"||e.type==="ellipse"||e.type==="image"||e.type==="iframe"||e.type==="embeddable"||e.type==="frame"||e.type==="magicframe"||e.type==="text"&&!e.containerId),jr=(e,t=!0)=>e!=null&&(!e.locked||t===!0)&&(e.type==="rectangle"||e.type==="diamond"||e.type==="ellipse"||ke(e)),Zs=e=>{let t=e?.type;if(!t)return!1;switch(t){case"text":case"diamond":case"rectangle":case"iframe":case"embeddable":case"ellipse":case"arrow":case"freedraw":case"line":case"frame":case"magicframe":case"image":case"selection":return!0;default:return mi(t,null),!1}},Eo=e=>jr(e)&&!!e.boundElements?.some(({type:t})=>t==="text"),ze=e=>e!==null&&"containerId"in e&&e.containerId!==null&&W(e),qr=e=>e==="rectangle"||e==="embeddable"||e==="iframe"||e==="image",Ly=e=>e==="line"||e==="arrow"||e==="diamond",_y=(e,t)=>!!((e===at.ADAPTIVE_RADIUS||e===at.LEGACY)&&qr(t.type)||e===at.PROPORTIONAL_RADIUS&&Ly(t.type)),Py=e=>Ly(e.type)?{type:at.PROPORTIONAL_RADIUS}:qr(e.type)?{type:at.ADAPTIVE_RADIUS}:null});import{Random as Uk}from"roughjs/bin/math";import{nanoid as Wk}from"nanoid";var Vk,Yk,ar,Bt,Sr=v(()=>{"use strict";f();G();Vk=new Uk(Date.now()),Yk=0,ar=()=>Math.floor(Vk.next()*2**31),Bt=()=>Ro()?`id${Yk++}`:Wk()});var Dy,Kk,Ry,Ih,lt,_n=v(()=>{"use strict";f();he();se();ui();Sr();G();Dy=e=>{let t=new Map,o=[];for(let r of e)r.isDeleted||(o.push(r),t.set(r.id,r));return{elementsMap:t,elements:o}},Kk=e=>{let t=["includeBoundTextElement","includeElementsInFrames"],o="";for(let r of t)o+=`${r}:${e[r]?"1":"0"}`;return o},Ry=e=>typeof e=="string",Ih=class e{static sceneMapByElement=new WeakMap;static sceneMapById=new Map;static mapElementToScene(t,o){Ry(t)?this.sceneMapById.set(t,o):(this.sceneMapByElement.set(t,o),this.sceneMapById.set(t.id,o))}static getScene(t){return Ry(t)?this.sceneMapById.get(t)||null:this.sceneMapByElement.get(t)||null}callbacks=new Set;nonDeletedElements=[];nonDeletedElementsMap=Ir(new Map);elements=[];nonDeletedFramesLikes=[];frames=[];elementsMap=Ir(new Map);selectedElementsCache={selectedElementIds:null,elements:null,cache:new Map};versionNonce;getElementsMapIncludingDeleted(){return this.elementsMap}getNonDeletedElementsMap(){return this.nonDeletedElementsMap}getElementsIncludingDeleted(){return this.elements}getNonDeletedElements(){return this.nonDeletedElements}getFramesIncludingDeleted(){return this.frames}getSelectedElements(t){let o=Kk(t),r=t?.elements||this.nonDeletedElements;if(this.selectedElementsCache.elements===r&&this.selectedElementsCache.selectedElementIds===t.selectedElementIds){let i=this.selectedElementsCache.cache.get(o);if(i)return i}else t?.elements==null&&this.selectedElementsCache.cache.clear();let n=de(r,{selectedElementIds:t.selectedElementIds},t);return t?.elements==null&&(this.selectedElementsCache.selectedElementIds=t.selectedElementIds,this.selectedElementsCache.elements=this.nonDeletedElements,this.selectedElementsCache.cache.set(o,n)),n}getNonDeletedFramesLikes(){return this.nonDeletedFramesLikes}getElement(t){return this.elementsMap.get(t)||null}getVersionNonce(){return this.versionNonce}getNonDeletedElement(t){let o=this.getElement(t);return o&&js(o)?o:null}mapElements(t){let o=!1,r=this.elements.map(n=>{let i=t(n);return i!==n&&(o=!0),i});return o&&this.replaceAllElements(r),o}replaceAllElements(t){this.elements=t instanceof Array?t:Array.from(t.values());let o=[];this.elementsMap.clear(),this.elements.forEach(n=>{Q(n)&&o.push(n),this.elementsMap.set(n.id,n),e.mapElementToScene(n,this)});let r=Dy(this.elements);this.nonDeletedElements=r.elements,this.nonDeletedElementsMap=r.elementsMap,this.frames=o,this.nonDeletedFramesLikes=Dy(this.frames).elements,this.informMutation()}informMutation(){this.versionNonce=ar();for(let t of Array.from(this.callbacks))t()}addCallback(t){if(this.callbacks.has(t))throw new Error;return this.callbacks.add(t),()=>{if(!this.callbacks.has(t))throw new Error;this.callbacks.delete(t)}}destroy(){this.nonDeletedElements=[],this.elements=[],this.nonDeletedFramesLikes=[],this.frames=[],this.elementsMap.clear(),this.selectedElementsCache.selectedElementIds=null,this.selectedElementsCache.elements=null,this.selectedElementsCache.cache.clear(),e.sceneMapById.forEach((t,o)=>{t===this&&e.sceneMapById.delete(o)}),this.callbacks.clear()}insertElementAtIndex(t,o){if(!Number.isFinite(o)||o<0)throw new Error("insertElementAtIndex can only be called with index >= 0");let r=[...this.elements.slice(0,o),t,...this.elements.slice(o)];this.replaceAllElements(r)}insertElementsAtIndex(t,o){if(!Number.isFinite(o)||o<0)throw new Error("insertElementAtIndex can only be called with index >= 0");let r=[...this.elements.slice(0,o),...t,...this.elements.slice(o)];this.replaceAllElements(r)}addNewElement=t=>{t.frameId?this.insertElementAtIndex(t,this.getElementIndex(t.frameId)):this.replaceAllElements([...this.elements,t])};getElementIndex(t){return this.elements.findIndex(o=>o.id===t)}getContainerElement=t=>t&&t.containerId&&this.getElement(t.containerId)||null},lt=Ih});var wm,gi,qs=v(()=>{"use strict";f();wm=e=>{let t=e.map(r=>r[0]),o=e.map(r=>r[1]);return{width:Math.max(...t)-Math.min(...t),height:Math.max(...o)-Math.min(...o)}},gi=(e,t,o,r)=>{let n=o.map(u=>u[e]),i=Math.max(...n),a=Math.min(...n),l=i-a,s=l===0?1:t/l,c=1/0,d=o.map(u=>{let g=u[e]*s,x=[...u];return x[e]=g,g<c&&(c=g),x});if(!r||d.length===2)return d;let m=a-c;return d.map(u=>u.map((g,x)=>x===e?g+m:g))}});var Ee,Xe,vm,mt,Qs,yo,Sh,ma,Js,$k,At,kr,kh,Ah,Xk,Ny,Oy,By,Mh,Fy,ec,tc,oc,Qt=v(()=>{"use strict";f();U();bt();Mr();Ee=(e,t,o,r,n)=>[(e-o)*Math.cos(n)-(t-r)*Math.sin(n)+o,(e-o)*Math.sin(n)+(t-r)*Math.cos(n)+r],Xe=(e,t,o)=>Ee(e[0],e[1],t[0],t[1],o),vm=(e,t,o,r,n,i,a,l)=>{let s=Math.cos(r),c=Math.sin(r);return e.e&&e.w?t+=n+a:e.e?(t+=n*(1+s),o+=n*c,t+=a*(1-s),o+=a*-c):e.w&&(t+=n*(1-s),o+=n*-c,t+=a*(1+s),o+=a*c),e.n&&e.s?o+=i+l:e.n?(t+=i*c,o+=i*(1-s),t+=l*-c,o+=l*(1+s)):e.s&&(t+=i*-c,o+=i*(1+s),t+=l*c,o+=l*(1-s)),[t,o]},mt=(e,t,o,r)=>{let n=o-e,i=r-t;return Math.hypot(n,i)},Qs=(e,t)=>[(e[0]+t[0])/2,(e[1]+t[1])/2],yo=(e,t=1)=>{if(e.length>=3){let[o,r]=[e[0],e[e.length-1]];return mt(o[0],o[1],r[0],r[1])<=cl/t}return!1},Sh=(e,t,o)=>{let r=e.length;if(r<3)return!1;let n=[Number.MAX_SAFE_INTEGER,o],i=[t,o],a=0;for(let l=0;l<r;l++){let s=e[l],c=e[(l+1)%r];if($k(s,c,i,n)){if(Js(s,i,c)===0)return ma(s,i,c);a++}}return a%2===1},ma=(e,t,o)=>t[0]<=Math.max(e[0],o[0])&&t[0]>=Math.min(e[0],o[0])&&t[1]<=Math.max(e[1],o[1])&&t[1]>=Math.min(e[1],o[1]),Js=(e,t,o)=>{let r=(t[1]-e[1])*(o[0]-t[0])-(t[0]-e[0])*(o[1]-t[1]);return r===0?0:r>0?1:2},$k=(e,t,o,r)=>{let n=Js(e,t,o),i=Js(e,t,r),a=Js(o,r,e),l=Js(o,r,t);return!!(n!==i&&a!==l||n===0&&ma(e,o,t)||i===0&&ma(e,r,t)||a===0&&ma(o,e,r)||l===0&&ma(o,t,r))},At=(e,t,o)=>o?[Math.round(e/o)*o,Math.round(t/o)*o]:[e,t],kr=(e,t)=>{if(t.roundness?.type===at.PROPORTIONAL_RADIUS||t.roundness?.type===at.LEGACY)return e*sm;if(t.roundness?.type===at.ADAPTIVE_RADIUS){let o=t.roundness?.value??dy,r=o/sm;return e<=r?e*sm:o}return 0},kh=(e,t)=>{let o=Me.generateElementShape(e,null);if(!o)return null;let r=Ar(o[0]),n=[0,0],i=0,a=1/0,l=null;for(;i<r.length;){let{op:s,data:c}=r[i];if(s==="move"&&(n=c),s==="bcurveTo"){let d=n,m=[c[0],c[1]],p=[c[2],c[3]],u=[c[4],c[5]],g=mt(u[0],u[1],t[0],t[1]);g<a&&(a=g,l=[d,m,p,u]),n=u}i++}return l},Ah=(e,t,o,r,n)=>{let i=(s,c)=>Math.pow(1-s,3)*r[c]+3*s*Math.pow(1-s,2)*o[c]+3*Math.pow(s,2)*(1-s)*t[c]+e[c]*Math.pow(s,3),a=i(n,0),l=i(n,1);return[a,l]},Xk=(e,t)=>{let o=kh(e,t);if(!o)return[];let r=[],n=1;for(;n>0;){let i=Ah(o[0],o[1],o[2],o[3],n);r.push([i[0],i[1]]),n-=.05}return r.length&&Mh(r.at(-1),t)&&r.push([t[0],t[1]]),r},Ny=(e,t)=>{let o=[];o[0]=0;let r=Xk(e,t),n=0,i=0;for(;n<r.length-1;){let a=mt(r[n][0],r[n][1],r[n+1][0],r[n+1][1]);i+=a,o.push(i),n++}return o},Oy=(e,t)=>Ny(e,t).at(-1),By=(e,t,o)=>{let r=Ny(e,t),n=r.length-1,i=r.at(-1),a=o*i,l=0,s=n,c=0;for(;l<s;)c=Math.floor(l+(s-l)/2),r[c]<a?l=c+1:s=c;return r[c]>a&&c--,r[c]===a?c/n:1-(c+(a-r[c])/(r[c+1]-r[c]))/n},Mh=(e,t)=>e[0]===t[0]&&e[1]===t[1],Fy=e=>Math.round(e/Math.PI*1e4)%5e3===0,ec=([e,t],[o,r])=>e<=o?t>=o:e>=o?r>=e:!1,tc=(e,t)=>{let o=Math.max(e[0],t[0]),r=Math.min(e[1],t[1]);return o<=r?[o,r]:null},oc=(e,t,o)=>e>=t&&e<=o});var Pn,rc,Tm,Cm,bl,pa,Lh,_h,nc=v(()=>{"use strict";f();se();Pn=e=>e==="rectangle"||e==="iframe"||e==="embeddable"||e==="ellipse"||e==="diamond"||e==="line"||e==="freedraw",rc=e=>e!=="image"&&e!=="frame"&&e!=="magicframe",Tm=e=>e==="rectangle"||e==="iframe"||e==="embeddable"||e==="ellipse"||e==="diamond"||e==="freedraw"||e==="arrow"||e==="line",Cm=e=>e==="rectangle"||e==="iframe"||e==="embeddable"||e==="ellipse"||e==="diamond"||e==="arrow"||e==="line",bl=e=>e==="rectangle"||e==="iframe"||e==="embeddable"||e==="arrow"||e==="line"||e==="diamond"||e==="image",pa=e=>e==="arrow",Lh=(e,t)=>{let o=null;for(let r=e.length-1;r>=0;--r){let n=e[r];if(!n.isDeleted&&t(n)){o=n;break}}return o},_h=(e,t)=>{let o=[];return e.filter(n=>!n.isDeleted&&t(n)?ir(n)?(o.push(n),!1):!0:!1).concat(o)}});import{simplify as Zk}from"points-on-curve";function qk(e){let t=e.roughness,o=Math.max(e.width,e.height),r=Math.min(e.width,e.height);return r>=20&&o>=50||r>=15&&e.roundness&&bl(e.type)||ne(e)&&o>=50?t:Math.min(t/(o<10?3:2),2.5)}var jk,Gy,No,Hy,zy,Uy,Ph=v(()=>{"use strict";f();he();Qt();Jr();G();U();se();nc();jk=e=>[8,8+e],Gy=e=>[1.5,6+e];No=(e,t=!1)=>{let o={seed:e.seed,strokeLineDash:e.strokeStyle==="dashed"?jk(e.strokeWidth):e.strokeStyle==="dotted"?Gy(e.strokeWidth):void 0,disableMultiStroke:e.strokeStyle!=="solid",strokeWidth:e.strokeStyle!=="solid"?e.strokeWidth+.5:e.strokeWidth,fillWeight:e.strokeWidth/2,hachureGap:e.strokeWidth*4,roughness:qk(e),stroke:e.strokeColor,preserveVertices:t||e.roughness<fh.cartoonist};switch(e.type){case"rectangle":case"iframe":case"embeddable":case"diamond":case"ellipse":return o.fillStyle=e.fillStyle,o.fill=co(e.backgroundColor)?void 0:e.backgroundColor,e.type==="ellipse"&&(o.curveFitting=1),o;case"line":case"freedraw":return yo(e.points)&&(o.fillStyle=e.fillStyle,o.fill=e.backgroundColor==="transparent"?void 0:e.backgroundColor),o;case"arrow":return o;default:throw new Error(`Unimplemented type ${e.type}`)}},Hy=(e,t,o)=>Jt(e)&&(t||St(e)&&o?.get(e.id)!==!0)&&co(e.backgroundColor)&&co(e.strokeColor)?{...e,roughness:0,backgroundColor:"#d3d3d3",fillStyle:"solid"}:ir(e)?{...e,strokeColor:co(e.strokeColor)?"#000000":e.strokeColor,backgroundColor:co(e.backgroundColor)?"#f4f4f6":e.backgroundColor}:e,zy=(e,t,o,r,n,i,a)=>{a=a||"transparent";let l=Rh(e,t,o,r);if(l===null)return[];switch(r){case"dot":case"circle":case"circle_outline":{let[s,c,d]=l;return delete i.strokeLineDash,[n.circle(s,c,d,{...i,fill:r==="circle_outline"?a:e.strokeColor,fillStyle:"solid",stroke:e.strokeColor,roughness:Math.min(.5,i.roughness||0)})]}case"triangle":case"triangle_outline":{let[s,c,d,m,p,u]=l;return delete i.strokeLineDash,[n.polygon([[s,c],[d,m],[p,u],[s,c]],{...i,fill:r==="triangle_outline"?a:e.strokeColor,fillStyle:"solid",roughness:Math.min(1,i.roughness||0)})]}case"diamond":case"diamond_outline":{let[s,c,d,m,p,u,g,x]=l;return delete i.strokeLineDash,[n.polygon([[s,c],[d,m],[p,u],[g,x],[s,c]],{...i,fill:r==="diamond_outline"?a:e.strokeColor,fillStyle:"solid",roughness:Math.min(1,i.roughness||0)})]}case"bar":case"arrow":default:{let[s,c,d,m,p,u]=l;if(e.strokeStyle==="dotted"){let g=Gy(e.strokeWidth-1);i.strokeLineDash=[g[0],g[1]-1]}else delete i.strokeLineDash;return i.roughness=Math.min(1,i.roughness||0),[n.line(d,m,s,c,i),n.line(p,u,s,c,i)]}}},Uy=(e,t,{isExporting:o,canvasBackgroundColor:r,embedsValidationStatus:n})=>{switch(e.type){case"rectangle":case"iframe":case"embeddable":{let i;if(e.roundness){let a=e.width,l=e.height,s=kr(Math.min(a,l),e);i=t.path(`M ${s} 0 L ${a-s} 0 Q ${a} 0, ${a} ${s} L ${a} ${l-s} Q ${a} ${l}, ${a-s} ${l} L ${s} ${l} Q 0 ${l}, 0 ${l-s} L 0 ${s} Q 0 0, ${s} 0`,No(Hy(e,o,n),!0))}else i=t.rectangle(0,0,e.width,e.height,No(Hy(e,o,n),!1));return i}case"diamond":{let i,[a,l,s,c,d,m,p,u]=Dh(e);if(e.roundness){let g=kr(Math.abs(a-p),e),x=kr(Math.abs(c-l),e);i=t.path(`M ${a+g} ${l+x} L ${s-g} ${c-x}
3
- C ${s} ${c}, ${s} ${c}, ${s-g} ${c+x}
4
- L ${d+g} ${m-x}
5
- C ${d} ${m}, ${d} ${m}, ${d-g} ${m-x}
6
- L ${p+g} ${u+x}
7
- C ${p} ${u}, ${p} ${u}, ${p+g} ${u-x}
8
- L ${a-g} ${l+x}
9
- C ${a} ${l}, ${a} ${l}, ${a+g} ${l+x}`,No(e,!0))}else i=t.polygon([[a,l],[s,c],[d,m],[p,u]],No(e));return i}case"ellipse":return t.ellipse(e.width/2,e.height/2,e.width,e.height,No(e));case"line":case"arrow":{let i,a=No(e),l=e.points.length?e.points:[[0,0]];if(e.roundness?i=[t.curve(l,a)]:a.fill?i=[t.polygon(l,a)]:i=[t.linearPath(l,a)],e.type==="arrow"){let{startArrowhead:s=null,endArrowhead:c="arrow"}=e;if(s!==null){let d=zy(e,i,"start",s,t,a,r);i.push(...d)}if(c!==null){let d=zy(e,i,"end",c,t,a,r);i.push(...d)}}return i}case"freedraw":{let i;if(Wy(e),yo(e.points)){let a=Zk(e.points,.75);i=t.curve(a,{...No(e),stroke:"none"})}else i=null;return i}case"frame":case"magicframe":case"text":case"image":return null;default:return mi(e,`generateElementShape(): Unimplemented type ${e?.type}`),null}}});var no,Nh,ua,xl,Vy,ic,hi,Jk,Oh,Im,Bh,Yy,Fh,Ky,ga,$y,Hh,OO,BO,FO,HO,zO,GO,UO,ha=v(()=>{"use strict";f();no=(e,t)=>[0,0,0,0,t,e,1,0],Nh=(e,t)=>[0,0,0,0,t,e,0,0],ua=(e=0,t=0)=>{let o=[0,0,0,0,0,0,0,0];if(t<0||t>7)throw new Error(`Expected \`index\` between 0 and 7, got \`${t}\``);return e!==0&&(o[t]=e),o},xl=e=>[e[0],e[1],e[2],e[3],-e[4],-e[5],-e[6],-e[7]],Vy=(e,t)=>Hh(t)?[e[0]+t,e[1],e[2],e[3],e[4],e[5],e[6],e[7]]:[e[0]+t[0],e[1]+t[1],e[2]+t[2],e[3]+t[3],e[4]+t[4],e[5]+t[5],e[6]+t[6],e[7]+t[7]],ic=(e,t)=>Hh(t)?[e[0]-t,e[1],e[2],e[3],e[4],e[5],e[6],e[7]]:[e[0]-t[0],e[1]-t[1],e[2]-t[2],e[3]-t[3],e[4]-t[4],e[5]-t[5],e[6]-t[6],e[7]-t[7]],hi=(e,t)=>Hh(t)?[e[0]*t,e[1]*t,e[2]*t,e[3]*t,e[4]*t,e[5]*t,e[6]*t,e[7]*t]:[Jk(e,t),t[1]*e[0]+t[0]*e[1]-t[4]*e[2]+t[5]*e[3]+t[2]*e[4]-t[3]*e[5]-t[7]*e[6]-t[6]*e[7],t[2]*e[0]+t[0]*e[2]-t[6]*e[3]+t[3]*e[6],t[3]*e[0]+t[6]*e[2]+t[0]*e[3]-t[2]*e[6],t[4]*e[0]+t[2]*e[1]-t[1]*e[2]+t[7]*e[3]+t[0]*e[4]+t[6]*e[5]-t[5]*e[6]+t[3]*e[7],t[5]*e[0]-t[3]*e[1]+t[7]*e[2]+t[1]*e[3]-t[6]*e[4]+t[0]*e[5]+t[4]*e[6]+t[2]*e[7],t[6]*e[0]+t[3]*e[2]-t[2]*e[3]+t[0]*e[6],t[7]*e[0]+t[6]*e[1]+t[5]*e[2]+t[4]*e[3]+t[3]*e[4]+t[2]*e[5]+t[1]*e[6]+t[0]*e[7]],Jk=(e,t)=>t[0]*e[0]+t[2]*e[2]+t[3]*e[3]-t[6]*e[6],Oh=(e,t)=>[t[0]*e[0],t[1]*e[0]+t[0]*e[1],t[2]*e[0]+t[0]*e[2],t[3]*e[0]+t[0]*e[3],t[4]*e[0]+t[2]*e[1]-t[1]*e[2]+t[0]*e[4],t[5]*e[0]-t[3]*e[1]+t[1]*e[3]+t[0]*e[5],t[6]*e[0]+t[3]*e[2]-t[2]*e[3]+t[0]*e[6],t[7]*e[0]+t[6]*e[1]+t[5]*e[2]+t[4]*e[3]+t[3]*e[4]+t[2]*e[5]+t[1]*e[6]],Im=(e,t)=>[Bh(e,t),e[1]*t[7]+e[4]*t[5]-e[5]*t[4]+e[7]*t[1],e[2]*t[7]-e[4]*t[6]+e[6]*t[4]+e[7]*t[2],e[3]*t[7]+e[5]*t[6]-e[6]*t[5]+e[7]*t[3],e[4]*t[7]+e[7]*t[4],e[5]*t[7]+e[7]*t[5],e[6]*t[7]+e[7]*t[6],e[7]*t[7]],Bh=(e,t)=>e[0]*t[7]+e[1]*t[6]+e[2]*t[5]+e[3]*t[4]+e[4]*t[3]+e[5]*t[2]+e[6]*t[1]+e[7]*t[0],Yy=(e,t)=>[t[0]*e[0]+t[2]*e[2]+t[3]*e[3]-t[6]*e[6],t[1]*e[0]+t[0]*e[1]-t[4]*e[2]+t[5]*e[3]+t[2]*e[4]-t[3]*e[5]-t[7]*e[6]-t[6]*e[7],t[2]*e[0]+t[0]*e[2]-t[6]*e[3]+t[3]*e[6],t[3]*e[0]+t[6]*e[2]+t[0]*e[3]-t[2]*e[6],t[4]*e[0]+t[7]*e[3]+t[0]*e[4]+t[3]*e[7],t[5]*e[0]+t[7]*e[2]+t[0]*e[5]+t[2]*e[7],t[6]*e[0]+t[0]*e[6],t[7]*e[0]+t[0]*e[7]],Fh=e=>Math.sqrt(Math.abs(e[0]*e[0]-e[2]*e[2]-e[3]*e[3]+e[6]*e[6])),Ky=e=>Math.sqrt(Math.abs(e[7]*e[7]-e[5]*e[5]-e[4]*e[4]+e[1]*e[1])),ga=e=>{let t=Fh(e);if(t===0||t===1)return e;let o=e[6]<0?-1:1;return hi(e,o/t)},$y=e=>{let t=Ky(e);return t===0||t===1?e:hi(e,1/t)},Hh=e=>typeof e=="number",OO=ua(1,1),BO=ua(1,2),FO=ua(1,3),HO=ua(1,4),zO=ua(1,5),GO=ua(1,6),UO=ua(1,7)});var fi,El,Xy,Zy,jy,zh=v(()=>{"use strict";f();ha();fi=(e,t,o)=>ga([0,o,e,t,0,0,0,0]),El=(e,t)=>ga(Im(t,e)),Xy=(e,t)=>Yy(e,t),Zy=(e,t)=>Xy(El(e,t),t),jy=e=>Math.sign(e[1])});var bi,xi,Gh,Jy,Uh,lr,Qy=v(()=>{"use strict";f();ha();zh();ha();bi=([e,t])=>[0,0,0,0,t,e,1,0],xi=e=>[e[5],e[4]],Gh=e=>[0,0,0,0,Math.abs(e[4]),Math.abs(e[5]),1,0],Jy=(e,t)=>ga(Oh(e,t)),Uh=(e,t)=>Fh(Im(e,t)),lr=(e,t)=>Bh(e,t)});var Sm,e2,Wh=v(()=>{"use strict";f();ha();Sm=e=>[0,0,0,0,e[4],e[5],0,0],e2=(e,t)=>$y([0,0,0,0,t[4]-e[4],t[5]-e[5],0,0])});var km,o2,r2,n2,sr,i2=v(()=>{"use strict";f();ha();Wh();km=(e,t)=>Vy(hi(e,Math.sin(t/2)),Math.cos(t/2)),o2=e=>[1,0,0,0,-(.5*e[5]),.5*e[4],0,0],r2=(e,t)=>{let o=.5*t;return[1,0,0,0,o*e[4],o*e[5],0,0]},n2=(e,t)=>hi(t,e),sr=(e,t)=>ga(hi(hi(e,t),xl(e)))});var a2,tA,lc,s2,oA,l2,Vh,Dn,yl,sc,wl,vl=v(()=>{"use strict";f();bt();Qt();he();se();U();a2={mouse:8,pen:16,touch:28},tA=16,lc={e:!0,s:!0,n:!0,w:!0},s2={e:!0,s:!0,n:!0,w:!0,rotation:!0},oA={e:!0,s:!0,n:!0,w:!0},l2={e:!0,s:!0,n:!0,w:!0,nw:!0,se:!0},Vh={e:!0,s:!0,n:!0,w:!0},Dn=(e,t,o,r,n,i,a)=>{let[l,s]=Ee(e+o/2,t+r/2,n,i,a);return[l-o/2,s-r/2,o,r]},yl=([e,t,o,r,n,i],a,l,s,c={},d=4)=>{let m=a2[s],p=m/l.value,u=m/l.value,g=m/l.value,x=m/l.value,E=o-e,y=r-t,T=d/l.value,w=(m-aa*2)/(2*l.value),S={nw:c.nw?void 0:Dn(e-T-g+w,t-T-x+w,p,u,n,i,a),ne:c.ne?void 0:Dn(o+T-w,t-T-x+w,p,u,n,i,a),sw:c.sw?void 0:Dn(e-T-g+w,r+T-w,p,u,n,i,a),se:c.se?void 0:Dn(o+T-w,r+T-w,p,u,n,i,a),rotation:c.rotation?void 0:Dn(e+E/2-p/2,t-T-x+w-tA/l.value,p,u,n,i,a)},M=5*a2.mouse/l.value;return Math.abs(E)>M&&(c.n||(S.n=Dn(e+E/2-p/2,t-T-x+w,p,u,n,i,a)),c.s||(S.s=Dn(e+E/2-p/2,r+T-w,p,u,n,i,a))),Math.abs(y)>M&&(c.w||(S.w=Dn(e-T-g+w,t+y/2-u/2,p,u,n,i,a)),c.e||(S.e=Dn(o+T-w,t+y/2-u/2,p,u,n,i,a))),S},sc=(e,t,o,r="mouse")=>{if(e.locked)return{};let n={};if(e.type==="freedraw"||ne(e)){if(e.points.length===2){let[,a]=e.points;a[0]===0||a[1]===0?n=Vh:a[0]>0&&a[1]<0?n=l2:a[0]>0&&a[1]>0?n=Vh:a[0]<0&&a[1]>0?n=l2:a[0]<0&&a[1]<0&&(n=Vh)}}else W(e)?n=oA:Q(e)&&(n={rotation:!0});let i=ne(e)?aa+8:aa;return yl(te(e,o,!0),e.angle,t,r,n,i)},wl=(e,t)=>{if(t.editingLinearElement)return!1;if(e.length>1)return!0;let o=e[0];return ne(o)?o.points.length>2:!0}});import{pointsOnBezierCurves as rA}from"points-on-curve";var nA,Tl,dc,fa,iA,Cl,Yh,Il,Kh,Am,aA,cc,lA,sA,c2,cA,dA,mA,pA,uA,gA,Mm,hA,$h,Lm,d2,m2,p2,fA,u2,bA,xA,EA,yA,wA,vA,TA,Xh,g2,Ei=v(()=>{"use strict";f();ha();Qy();Wh();zh();i2();Qt();bt();se();he();G();vl();pt();Mr();nA=e=>{if(e.type==="arrow")return!1;if(e.type==="freedraw")return!0;let t=!co(e.backgroundColor)||Eo(e)||Jt(e);return e.type==="line"?t&&yo(e.points):t||nr(e)},Tl=(e,t,o,r,n,i)=>{let a=10/t.zoom.value,l=[r,n];if(iA(t,e)&&wl([e],t))return Cl(e,i,l,a,o);let s=me(e,i);return s&&Tl(s,t,o,r,n,i)?!0:fa(e,t,o,l,i)},dc=(e,t,o,r,n,i)=>{let a=10/t.zoom.value,l=me(e,i);return l&&Tl(l,t,o,r,n,i)?!1:!fa(e,t,o,[r,n],i)&&Cl(e,i,[r,n],a,o)},fa=(e,t,o,r,n)=>{let i=10/t.zoom.value,a=W(e)?aA:nA(e)?cc:lA;return Kh({element:e,elementsMap:n,point:r,threshold:i,check:a,frameNameBoundsCache:o})},iA=(e,t)=>e.selectedElementIds[t.id],Cl=(e,t,[o,r],n,i)=>{if(Q(e))return Kh({element:e,elementsMap:t,point:[o,r],threshold:n,check:cc,frameNameBoundsCache:i});let[a,l,s,c]=te(e,t),d=(a+s)/2,m=(l+c)/2,[p,u]=Ee(o,r,d,m,-e.angle);return p>a-n&&p<s+n&&u>l-n&&u<c+n},Yh=(e,{x:t,y:o},r)=>{let n=Il(e,e.width,e.height);return Kh({element:e,elementsMap:r,point:[t,o],threshold:n,check:sA,frameNameBoundsCache:null})},Il=(e,t,o)=>{let n=(e.type==="diamond"?1/Math.sqrt(2):1)*Math.min(t,o);return Math.max(16,Math.min(.25*n,32))},Kh=e=>{switch(e.element.type){case"rectangle":case"iframe":case"embeddable":case"image":case"text":case"diamond":case"ellipse":let t=Am(e.element,e.point,e.elementsMap);return e.check(t,e.threshold);case"freedraw":return e.check(c2(e.element,e.point,e.elementsMap),e.threshold)?uA(e.element,e.point,e.threshold,e.elementsMap):!1;case"arrow":case"line":return gA(e);case"selection":return console.warn("This should not happen, we need to investigate why it does."),!1;case"frame":case"magicframe":{if(e.check(Am(e.element,e.point,e.elementsMap),e.threshold))return!0;let o=e.frameNameBoundsCache?.get(e.element);return o?e.check(cA(o,e.point),e.threshold):!1}}},Am=(e,t,o)=>{switch(e.type){case"rectangle":case"image":case"text":case"iframe":case"embeddable":case"frame":case"magicframe":return c2(e,t,o);case"diamond":return dA(e,t,o);case"ellipse":return mA(e,t,o)}},aA=(e,t)=>e<0,cc=(e,t)=>e<t,lA=(e,t)=>Math.abs(e)<t,sA=(e,t)=>0<=e&&e<t,c2=(e,t,o)=>{let[,r,n,i]=Mm(e,t,o);return Math.max(lr(r,fi(0,1,-i)),lr(r,fi(1,0,-n)))},cA=(e,t)=>{let[,o,r,n]=hA(t,e);return Math.max(lr(o,fi(0,1,-n)),lr(o,fi(1,0,-r)))},dA=(e,t,o)=>{let[,r,n,i]=Mm(e,t,o),a=fi(i,n,-i*n);return lr(r,a)},mA=(e,t,o)=>{let[r,n]=pA(e,t,o);return-jy(n)*lr(r,n)},pA=(e,t,o)=>{let[,r,n,i]=Mm(e,t,o),[a,l]=xi(r),s=.707,c=.707,d=n,m=i;[0,1,2,3].forEach(g=>{let x=d*s,E=m*c,y=(d*d-m*m)*s**3/d,T=(m*m-d*d)*c**3/m,w=x-y,S=E-T,M=a-y,k=l-T,R=Math.hypot(S,w),P=Math.hypot(k,M);s=Math.min(1,Math.max(0,(M*R/P+y)/d)),c=Math.min(1,Math.max(0,(k*R/P+T)/m));let F=Math.hypot(c,s);s/=F,c/=F});let p=no(d*s,m*c),u=Zy(r,p);return[r,u]},uA=(e,t,o,r)=>{let n,i;if(e.angle===0)n=t[0]-e.x,i=t[1]-e.y;else{let[d,m,p,u]=te(e,r),g=Xe(t,[d+(p-d)/2,m+(u-m)/2],-e.angle);n=g[0]-e.x,i=g[1]-e.y}let[a,l]=e.points,s;if(mt(a[0],a[1],n,i)<o||mt(l[0],l[1],n,i)<o)return!0;for(let d=0;d<e.points.length;d++){let m=[l[0]-a[0],l[1]-a[1]],p=Math.hypot(m[1],m[0]),u=[m[0]/p,m[1]/p],g=[n-a[0],i-a[1]],x=(g[0]*u[0]+g[1]*u[1])/Math.hypot(u[1],u[0]);s=[a[0]+u[0]*x,a[1]+u[1]*x];let E=mt(s[0],s[1],a[0],a[1]),y=mt(s[0],s[1],l[0],l[1]);if(s=y<E&&E>p?l:E<y&&y>p?a:s,Math.hypot(i-s[1],n-s[0])<o)return!0;a=l,l=e.points[d+1]}let c=Me.get(e);return c&&c.sets.length?e.fillStyle==="solid"?Xh(c,n,i,"round"):g2(c,n,i,o):!1},gA=e=>{let{element:t,threshold:o}=e;if(!Me.get(t))return!1;let[r,n,i,a]=Mm(e.element,e.point,e.elementsMap),l=fi(0,1,-a),s=fi(1,0,-i);if(!cc(lr(n,l),o)||!cc(lr(n,s),o))return!1;let[c,d]=xi(r),m=Me.get(t);return m?e.check===cc&&m.some(u=>Xh(u,c,d,t.roundness?"round":"sharp"))?!0:m.some(p=>g2(p,c,d,o)):!1},Mm=(e,t,o)=>{let r=bi(t),[n,i,a,l]=te(e,o),s=Lm(n,i,a,l),c=km(s,e.angle),d=sr(c,r),m=ic(d,Sm(s)),p=Gh(m),u=Nh(e.x,e.y),g=ic(d,u),x=(a-n)/2,E=(l-i)/2;return[g,p,x,E]},hA=(e,t)=>{let o=bi(e),[r,n,i,a]=h2(t),l=Lm(r,n,i,a),s=km(l,t.angle),c=sr(s,o),d=ic(c,Sm(l)),m=Gh(d),p=Nh(t.x,t.y),u=ic(c,p),g=(i-r)/2,x=(a-n)/2;return[u,m,g,x]},$h=(e,t)=>{let[o,r,n,i]=te(e,t),a=Lm(o,r,n,i),l=km(a,e.angle),s=xl(o2(Sm(a)));return n2(l,s)},Lm=(e,t,o,r)=>no((e+o)/2,(t+r)/2),d2=(e,t,o,r)=>{let n=$h(e,r),i=sr(n,bi(t)),a=sr(n,bi(o)),l=El(i,a),s=e.height/e.width,c=e.width/2,d=e.height/2,m=l[2],p=l[3],u=l[1],g=Math.abs(p),x=Math.abs(m),E;switch(e.type){case"rectangle":case"image":case"text":case"iframe":case"embeddable":case"frame":case"magicframe":E=u/(c*(x+s*g));break;case"diamond":E=g<x?u/(x*c):u/(g*d);break;case"ellipse":E=u/(c*Math.sqrt(m**2+s**2*p**2));break}return E||0},m2=(e,t,o,r)=>{if(t===0){let[s,c,d,m]=te(e,r),p=Lm(s,c,d,m);return xi(p)}let n=$h(e,r),i=sr(n,bi(o)),a=xl(n),l;switch(e.type){case"rectangle":case"image":case"text":case"diamond":case"iframe":case"embeddable":case"frame":case"magicframe":l=vA(e,t,i);break;case"ellipse":l=wA(e,t,i);break}return xi(sr(a,l))},p2=(e,t,o,r=0,n)=>{let i=$h(e,n),a=sr(i,bi(t)),l=sr(i,bi(o)),s=El(a,l),c=xl(i);return fA(e,s,a,r).map(m=>xi(sr(c,m)))},fA=(e,t,o,r=0)=>{let n;switch(e.type){case"rectangle":case"image":case"text":case"diamond":case"iframe":case"embeddable":case"frame":case"magicframe":let a=u2(e);n=a.flatMap((l,s)=>{let c=[l,a[(s+1)%4]];return bA(t,xA(c,r))}).concat(a.flatMap(l=>yA(l,r,t)));break;case"ellipse":n=EA(e,r,t);break}if(n.length<2)return[];let i=n.sort((a,l)=>Uh(a,o)-Uh(l,o));return[i[0],i[i.length-1]]},u2=(e,t=1)=>{let o=t*e.width/2,r=t*e.height/2;switch(e.type){case"rectangle":case"image":case"text":case"iframe":case"embeddable":case"frame":case"magicframe":return[no(o,r),no(o,-r),no(-o,-r),no(-o,r)];case"diamond":return[no(0,r),no(o,0),no(0,-r),no(-o,0)]}},bA=(e,t)=>{let[o,r]=t,n=lr(o,e),i=lr(r,e);return n*i>=0?[]:[Jy(e,El(o,r))]},xA=(e,t)=>{let[o,r]=e,n=r2(e2(o,r),t);return[sr(n,o),sr(n,r)]},EA=(e,t,o)=>{let r=e.width/2+t,n=e.height/2+t,i=o[2],a=o[3],l=o[1],s=r*r*i*i+n*n*a*a,c=s-l*l;if(s===0||c<=0)return[];let d=Math.sqrt(c),m=-r*r*i*l,p=-n*n*a*l;return[no((m+r*n*a*d)/s,(p-r*n*i*d)/s),no((m-r*n*a*d)/s,(p+r*n*i*d)/s)]},yA=(e,t,o)=>{if(t===0)return lr(o,e)===0?[e]:[];let r=o[2],n=o[3],i=o[1],[a,l]=xi(e),s=t,c=r*r+n*n,d=s*s*c-(r*a+n*l+i)**2;if(c===0||d<=0)return[];let m=Math.sqrt(d),p=a*n*n-l*r*n-r*i,u=l*r*r-a*r*n-n*i;return[no((p+n*m)/c,(u-r*m)/c),no((p-n*m)/c,(u+r*m)/c)]},wA=(e,t,o)=>{let r=Math.abs(t),n=e.width*r/2,i=e.height*r/2,a=Math.sign(t),[l,s]=xi(o),c=s===0?1e-4:s,d=l**2*i**2+c**2*n**2,m=(-l*i**2+a*c*Math.sqrt(Math.max(0,d-n**2*i**2)))/d,p=(-m*l-1)/c;p===0&&(p=(Object.is(p,-0)?-1:1)*.01);let u=-(n**2*m)/(p**2*i**2+m**2*n**2);return no(u,(-m*u-1)/p)},vA=(e,t,o)=>{let r=Math.abs(t),n=Math.sign(t),i=u2(e,r),a=0,l=null;return i.forEach(s=>{let c=n*El(o,s)[1];c>a&&(a=c,l=s)}),l},TA=(e,t,o,r,[n,i],a)=>{let l=(c,d)=>Math.pow(1-c,3)*r[d]+3*c*Math.pow(1-c,2)*o[d]+3*Math.pow(c,2)*(1-c)*t[d]+e[d]*Math.pow(c,3),s=0;for(;s<=1;){let c=l(s,0),d=l(s,1);if(Math.sqrt(Math.pow(c-n,2)+Math.pow(d-i,2))<a)return!0;s+=.01}return!1},Xh=(e,t,o,r)=>{let n=Ar(e),i=[],a=!1;for(let l of n)l.op==="move"?(a=!a,a&&i.push([l.data[0],l.data[1]])):l.op==="bcurveTo"?a&&(i.push([l.data[0],l.data[1]]),i.push([l.data[2],l.data[3]]),i.push([l.data[4],l.data[5]])):l.op==="lineTo"&&a&&i.push([l.data[0],l.data[1]]);if(i.length>=4){if(r==="sharp")return Sh(i,t,o);let l=rA(i,10,5);return Sh(l,t,o)}return!1},g2=(e,t,o,r)=>{let n=Ar(e),i=[0,0];return n.some(({op:a,data:l},s)=>{if(a==="move")i=l;else if(a==="bcurveTo"){let c=[l[0],l[1]],d=[l[2],l[3]],m=[l[4],l[5]],p=i;return i=m,TA(p,c,d,m,[t,o],r)}else{if(a==="lineTo")return Xh(e,t,o,"sharp");a==="qcurveTo"&&console.warn("qcurveTo is not implemented yet")}return!1})}});var fe,I,Sl,_m,kl,ba,ue=v(()=>{"use strict";f();U();fe={EQUAL:"Equal",MINUS:"Minus",NUM_ADD:"NumpadAdd",NUM_SUBTRACT:"NumpadSubtract",NUM_ZERO:"Numpad0",BRACKET_RIGHT:"BracketRight",BRACKET_LEFT:"BracketLeft",ONE:"Digit1",TWO:"Digit2",THREE:"Digit3",NINE:"Digit9",QUOTE:"Quote",ZERO:"Digit0",SLASH:"Slash",C:"KeyC",D:"KeyD",H:"KeyH",V:"KeyV",Z:"KeyZ",R:"KeyR",S:"KeyS"},I={ARROW_DOWN:"ArrowDown",ARROW_LEFT:"ArrowLeft",ARROW_RIGHT:"ArrowRight",ARROW_UP:"ArrowUp",PAGE_UP:"PageUp",PAGE_DOWN:"PageDown",BACKSPACE:"Backspace",ALT:"Alt",CTRL_OR_CMD:so?"metaKey":"ctrlKey",DELETE:"Delete",ENTER:"Enter",ESCAPE:"Escape",QUESTION_MARK:"?",SPACE:" ",TAB:"Tab",CHEVRON_LEFT:"<",CHEVRON_RIGHT:">",PERIOD:".",COMMA:",",SUBTRACT:"-",SLASH:"/",A:"a",C:"c",D:"d",E:"e",F:"f",G:"g",H:"h",I:"i",L:"l",O:"o",P:"p",Q:"q",R:"r",S:"s",T:"t",V:"v",X:"x",Y:"y",Z:"z",K:"k",W:"w",0:"0",1:"1",2:"2",3:"3",4:"4",5:"5",6:"6",7:"7",8:"8",9:"9"},Sl=e=>e===I.ARROW_LEFT||e===I.ARROW_RIGHT||e===I.ARROW_DOWN||e===I.ARROW_UP,_m=e=>e.altKey,kl=e=>e.shiftKey,ba=e=>e.shiftKey});var v2,Qr,T2,Rn,f2,mc,CA,pc,Al,Zh,jh,uc,IA,en,SA,Lr,kA,AA,b2,x2,C2,MA,Pm,I2,S2,E2,Dm,y2,Ml,w2,LA,_r=v(()=>{"use strict";f();We();se();Ei();Ze();_n();io();G();ue();pt();v2=e=>!e[I.CTRL_OR_CMD],Qr=e=>e.isBindingEnabled,T2=(e,t)=>{let o=[];return t.forEach(r=>{let n=e.getNonDeletedElement(r);n!=null&&o.push(n)}),o},Rn=(e,t,o,r)=>{let n=new Set,i=new Set;f2(e,t,o,"start",n,i,r),f2(e,o,t,"end",n,i,r);let a=Array.from(i).filter(l=>!n.has(l));T2(lt.getScene(e),a).forEach(l=>{z(l,{boundElements:l.boundElements?.filter(s=>s.type!=="arrow"||s.id!==e.id)})})},f2=(e,t,o,r,n,i,a)=>{if(t!=="keep")if(t!=null)(o==null||(o==="keep"?!Zh(e,t,r):r==="start"||o.id!==t.id))&&(Al(e,t,r,a),n.add(t.id));else{let l=IA(e,r);l!=null&&i.add(l)}},mc=(e,t,o)=>{e.forEach(r=>{kt(r)?Rn(r,Pm(r,"start",t,o),Pm(r,"end",t,o),o):fl(r)&&CA(r,o)})},CA=(e,t)=>{S2(e,t).forEach(([o,r])=>Rn(o,r==="end"?"keep":e,r==="start"?"keep":e,t))},pc=(e,t,o,r,n)=>{t.startBoundElement!=null&&Al(e,t.startBoundElement,"start",n);let i=en(r,o.getNonDeletedElements(),n);i!=null&&!Zh(e,i,"end")&&Al(e,i,"end",n)},Al=(e,t,o,r)=>{z(e,{[o==="start"?"startBinding":"endBinding"]:{elementId:t.id,...SA(e,t,o,r)}}),re(t.boundElements||[]).has(e.id)||z(t,{boundElements:(t.boundElements||[]).concat({id:e.id,type:"arrow"})})},Zh=(e,t,o)=>{let r=e[o==="start"?"endBinding":"startBinding"];return jh(e,r?.elementId,t)},jh=(e,t,o)=>t===o.id&&e.points.length<3,uc=(e,t)=>{e.forEach(o=>{kt(o)&&Rn(o,null,null,t)})},IA=(e,t)=>{let o=t==="start"?"startBinding":"endBinding",r=e[o];return r==null?null:(z(e,{[o]:null}),r.elementId)},en=(e,t,o)=>Lh(t,n=>fl(n,!1)&&Yh(n,e,o)),SA=(e,t,o,r)=>{let n=o==="start"?-1:1,i=n===-1?0:e.points.length-1,a=i-n,l=$.getPointAtIndexGlobalCoordinates(e,i,r),s=$.getPointAtIndexGlobalCoordinates(e,a,r);return{focus:d2(t,s,l,r),gap:Math.max(1,Am(t,l,r))}},Lr=(e,t,o)=>{let r=(e.boundElements??[]).filter(s=>s.type==="arrow");if(r.length===0)return;let{newSize:n,simultaneouslyUpdated:i}=o??{},a=AA(i),l=lt.getScene(e);T2(l,r.map(s=>s.id)).forEach(s=>{if(!ne(s))return;let c=e;if(!kA(s,c))return;let d=x2(c,s.startBinding,n),m=x2(c,s.endBinding,n);if(a.has(s.id)){z(s,{startBinding:d,endBinding:m});return}b2(s,"start",d,e,t),b2(s,"end",m,e,t),me(s,l.getNonDeletedElementsMap())&&xa(s,l.getNonDeletedElementsMap(),!1)})},kA=(e,t)=>e.startBinding?.elementId===t.id||e.endBinding?.elementId===t.id,AA=e=>new Set((e||[]).map(t=>t.id)),b2=(e,t,o,r,n)=>{if(o==null||o.elementId!==r.id&&e.points.length>2)return;let i=lt.getScene(e).getElement(o.elementId);if(i==null)return;let a=t==="start"?-1:1,l=a===-1?0:e.points.length-1,s=l-a,c=$.getPointAtIndexGlobalCoordinates(e,s,n),d=m2(i,o.focus,c,n),m;if(o.gap===0)m=d;else{let p=p2(i,c,d,o.gap,n);p.length===0?m=d:m=p[0]}$.movePoints(e,[{index:l,point:$.pointFromAbsoluteCoords(e,m,n)}],{[t==="start"?"startBinding":"endBinding"]:o})},x2=(e,t,o)=>{if(t==null||o==null)return t;let{gap:r,focus:n,elementId:i}=t,{width:a,height:l}=o,{width:s,height:c}=e,d=Math.max(1,Math.min(Il(e,a,l),r*(a<l?a/s:l/c)));return{elementId:i,gap:d,focus:n}},C2=(e,t,o)=>{let r=new Set(e.map(({id:n})=>n));return e.flatMap(n=>kt(n,!1)?MA(n,t,o).filter(i=>!r.has(i.id)):fl(n,!1)?S2(n,o).filter(i=>!r.has(i[0].id)):[])},MA=(e,t,o)=>[Pm(e,"start",t,o),Pm(e,"end",t,o)].filter(r=>r!=null),Pm=(e,t,o,r)=>en(I2(e,t,r),o,r),I2=(e,t,o)=>{let r=t==="start"?0:-1;return Cr($.getPointAtIndexGlobalCoordinates(e,r,o))},S2=(e,t)=>lt.getScene(e).getNonDeletedElements().map(r=>{if(!kt(r,!1))return null;let n=E2(r,"start",e,t),i=E2(r,"end",e,t);return!n&&!i?null:[r,n&&i?"both":n?"start":"end",e]}).filter(r=>r!=null),E2=(e,t,o,r)=>e[t==="start"?"startBinding":"endBinding"]==null&&!Zh(e,o,t)&&Yh(o,I2(e,t,r),r),Dm=(e,t,o,r)=>{let n=new Set,i=new Set,a=r==="duplicatesServeAsOld";t.forEach(l=>{let{boundElements:s}=l;if(s!=null&&s.length>0&&(s.forEach(c=>{a&&!o.has(c.id)&&n.add(c.id)}),i.add(o.get(l.id))),kt(l)){if(l.startBinding!=null){let{elementId:c}=l.startBinding;a&&!o.has(c)&&i.add(c)}if(l.endBinding!=null){let{elementId:c}=l.endBinding;a&&!o.has(c)&&i.add(c)}(l.startBinding!=null||l.endBinding!=null)&&n.add(o.get(l.id))}}),e.filter(({id:l})=>n.has(l)).forEach(l=>{let{startBinding:s,endBinding:c}=l;z(l,{startBinding:y2(s,o),endBinding:y2(c,o)})}),e.filter(({id:l})=>i.has(l)).forEach(l=>{let{boundElements:s}=l;s!=null&&s.length>0&&z(l,{boundElements:s.map(c=>o.has(c.id)?{id:o.get(c.id),type:c.type}:c)})})},y2=(e,t)=>{if(e==null)return null;let{elementId:o,focus:r,gap:n}=e;return{focus:r,gap:n,elementId:t.get(o)??o}},Ml=(e,t)=>{let o=new Set(t.map(n=>n.id)),r=new Set;t.forEach(n=>{fl(n)?n.boundElements?.forEach(i=>{o.has(i.id)||r.add(i.id)}):kt(n)&&(n.startBinding&&r.add(n.startBinding.elementId),n.endBinding&&r.add(n.endBinding.elementId))}),e.filter(({id:n})=>r.has(n)).forEach(n=>{fl(n)?z(n,{boundElements:LA(n.boundElements,o)}):kt(n)&&z(n,{startBinding:w2(n.startBinding,o),endBinding:w2(n.endBinding,o)})})},w2=(e,t)=>e==null||t.has(e.elementId)?null:e,LA=(e,t)=>e?e.filter(o=>!t.has(o.id)):null});var Nn,$,_A,io=v(()=>{"use strict";f();Qt();he();bt();Ze();_r();G();se();ue();pt();U();Mr();Nn={version:null,points:[],zoom:null},$=class e{elementId;selectedPointsIndices;pointerDownState;isDragging;lastUncommittedPoint;pointerOffset;startBindingElement;endBindingElement;hoverPointIndex;segmentMidPointHoveredCoords;constructor(t){this.elementId=t.id,e.normalizePoints(t),this.selectedPointsIndices=null,this.lastUncommittedPoint=null,this.isDragging=!1,this.pointerOffset={x:0,y:0},this.startBindingElement="keep",this.endBindingElement="keep",this.pointerDownState={prevSelectedPointsIndices:null,lastClickedPoint:-1,origin:null,segmentMidpoint:{value:null,index:null,added:!1}},this.hoverPointIndex=-1,this.segmentMidPointHoveredCoords=null}static POINT_HANDLE_SIZE=10;static getElement(t,o){let r=o.get(t);return r||null}static handleBoxSelection(t,o,r,n){if(!o.editingLinearElement||o.draggingElement?.type!=="selection")return!1;let{editingLinearElement:i}=o,{selectedPointsIndices:a,elementId:l}=i,s=e.getElement(l,n);if(!s)return!1;let[c,d,m,p]=te(o.draggingElement,n),g=e.getPointsGlobalCoordinates(s,n).reduce((x,E,y)=>((E[0]>=c&&E[0]<=m&&E[1]>=d&&E[1]<=p||t.shiftKey&&a?.includes(y))&&x.push(y),x),[]);r({editingLinearElement:{...i,selectedPointsIndices:g.length?g:null}})}static handlePointDragging(t,o,r,n,i,a,l){if(!a)return!1;let{selectedPointsIndices:s,elementId:c}=a,d=e.getElement(c,l);if(!d)return!1;let m=d.points[a.pointerDownState.lastClickedPoint];if(s&&m){if(ba(t)&&s.length===1&&d.points.length>1){let u=s[0],g=d.points[u===0?1:u-1],[x,E]=e._getShiftLockedDelta(d,l,g,[r,n],t[I.CTRL_OR_CMD]?null:o.gridSize);e.movePoints(d,[{index:u,point:[x+g[0],E+g[1]],isDragging:u===a.pointerDownState.lastClickedPoint}])}else{let u=e.createPointAt(d,l,r-a.pointerOffset.x,n-a.pointerOffset.y,t[I.CTRL_OR_CMD]?null:o.gridSize),g=u[0]-m[0],x=u[1]-m[1];e.movePoints(d,s.map(E=>{let y=E===a.pointerDownState.lastClickedPoint?e.createPointAt(d,l,r-a.pointerOffset.x,n-a.pointerOffset.y,t[I.CTRL_OR_CMD]?null:o.gridSize):[d.points[E][0]+g,d.points[E][1]+x];return{index:E,point:y,isDragging:E===a.pointerDownState.lastClickedPoint}}))}if(me(d,l)&&xa(d,l,!1),kt(d,!1)){let u=[];s[0]===0&&u.push(Cr(e.getPointGlobalCoordinates(d,d.points[0],l)));let x=s[s.length-1];x===d.points.length-1&&u.push(Cr(e.getPointGlobalCoordinates(d,d.points[x],l))),u.length&&i(d,u)}return!0}return!1}static handlePointerUp(t,o,r,n,i){let{elementId:a,selectedPointsIndices:l,isDragging:s,pointerDownState:c}=o,d=e.getElement(a,i);if(!d)return o;let m={};if(s&&l){for(let p of l)if(p===0||p===d.points.length-1){yo(d.points,r.zoom.value)&&e.movePoints(d,[{index:p,point:p===0?d.points[d.points.length-1]:d.points[0]}]);let u=Qr(r)?en(Cr(e.getPointAtIndexGlobalCoordinates(d,p,i)),n,i):null;m[p===0?"startBindingElement":"endBindingElement"]=u}}return{...o,...m,selectedPointsIndices:s||t.shiftKey?!s&&t.shiftKey&&c.prevSelectedPointsIndices?.includes(c.lastClickedPoint)?l&&l.filter(p=>p!==c.lastClickedPoint):l:l?.includes(c.lastClickedPoint)?[c.lastClickedPoint]:l,isDragging:!1,pointerOffset:{x:0,y:0}}}static getEditorMidPoints=(t,o,r)=>{let n=me(t,o);return!r.editingLinearElement&&t.points.length>2&&!n?[]:(Nn.version===t.version&&Nn.zoom===r.zoom.value||e.updateEditorMidPointsCache(t,o,r),Nn.points)};static updateEditorMidPointsCache=(t,o,r)=>{let n=e.getPointsGlobalCoordinates(t,o),i=0,a=[];for(;i<n.length-1;){if(e.isSegmentTooShort(t,t.points[i],t.points[i+1],r.zoom)){a.push(null),i++;continue}let l=e.getSegmentMidPoint(t,n[i],n[i+1],i+1,o);a.push(l),i++}Nn.points=a,Nn.version=t.version,Nn.zoom=r.zoom.value};static getSegmentMidpointHitCoords=(t,o,r,n)=>{let{elementId:i}=t,a=e.getElement(i,n);if(!a||e.getPointIndexUnderCursor(a,n,r.zoom,o.x,o.y)>=0||e.getPointsGlobalCoordinates(a,n).length>=3&&!r.editingLinearElement)return null;let c=e.POINT_HANDLE_SIZE/r.zoom.value,d=t.segmentMidPointHoveredCoords;if(d&&mt(d[0],d[1],o.x,o.y)<=c)return d;let m=0,p=e.getEditorMidPoints(a,n,r);for(;m<p.length;){if(p[m]!==null&&mt(p[m][0],p[m][1],o.x,o.y)<=c)return p[m];m++}return null};static isSegmentTooShort(t,o,r,n){let i=mt(o[0],o[1],r[0],r[1]);return t.points.length>2&&t.roundness&&(i=Oy(t,r)),i*n.value<e.POINT_HANDLE_SIZE*4}static getSegmentMidPoint(t,o,r,n,i){let a=Qs(o,r);if(t.points.length>2&&t.roundness){let l=kh(t,t.points[n]);if(l){let s=By(t,t.points[n],.5),[c,d]=Ah(l[0],l[1],l[2],l[3],s);a=e.getPointGlobalCoordinates(t,[c,d],i)}}return a}static getSegmentMidPointIndex(t,o,r,n){let i=e.getElement(t.elementId,n);if(!i)return-1;let a=e.getEditorMidPoints(i,n,o),l=0;for(;l<a.length;){if(e.arePointsEqual(r,a[l]))return l+1;l++}return-1}static handlePointerDown(t,o,r,n,i,a,l){let s={didAddPoint:!1,hitElement:null,linearElementEditor:null};if(!i)return s;let{elementId:c}=i,d=e.getElement(c,l);if(!d)return s;let m=e.getSegmentMidpointHitCoords(i,n,o,l),p=null;if(m&&(p=e.getSegmentMidPointIndex(i,o,m,l)),t.altKey&&o.editingLinearElement)return i.lastUncommittedPoint==null&&(z(d,{points:[...d.points,e.createPointAt(d,l,n.x,n.y,t[I.CTRL_OR_CMD]?null:o.gridSize)]}),s.didAddPoint=!0),r.resumeRecording(),s.linearElementEditor={...i,pointerDownState:{prevSelectedPointsIndices:i.selectedPointsIndices,lastClickedPoint:-1,origin:{x:n.x,y:n.y},segmentMidpoint:{value:m,index:p,added:!1}},selectedPointsIndices:[d.points.length-1],lastUncommittedPoint:null,endBindingElement:en(n,a,l)},s.didAddPoint=!0,s;let u=e.getPointIndexUnderCursor(d,l,o.zoom,n.x,n.y);if(u>=0||m)s.hitElement=d;else{let{startBindingElement:k,endBindingElement:R}=i;Qr(o)&&kt(d)&&Rn(d,k,R,l)}let[g,x,E,y]=te(d,l),T=(g+E)/2,w=(x+y)/2,S=u>-1&&Ee(d.x+d.points[u][0],d.y+d.points[u][1],T,w,d.angle),M=u>-1||t.shiftKey?t.shiftKey||i.selectedPointsIndices?.includes(u)?_A([...i.selectedPointsIndices||[],u]):[u]:null;return s.linearElementEditor={...i,pointerDownState:{prevSelectedPointsIndices:i.selectedPointsIndices,lastClickedPoint:u,origin:{x:n.x,y:n.y},segmentMidpoint:{value:m,index:p,added:!1}},selectedPointsIndices:M,pointerOffset:S?{x:n.x-S[0],y:n.y-S[1]}:{x:0,y:0}},s}static arePointsEqual(t,o){return!t&&!o?!0:!t||!o?!1:Mh(t,o)}static handlePointerMove(t,o,r,n,i){if(!n.editingLinearElement)return null;let{elementId:a,lastUncommittedPoint:l}=n.editingLinearElement,s=e.getElement(a,i);if(!s)return n.editingLinearElement;let{points:c}=s,d=c[c.length-1];if(!t.altKey)return d===l&&e.deletePoints(s,[c.length-1]),{...n.editingLinearElement,lastUncommittedPoint:null};let m;if(ba(t)&&c.length>=2){let p=c[c.length-2],[u,g]=e._getShiftLockedDelta(s,i,p,[o,r],t[I.CTRL_OR_CMD]?null:n.gridSize);m=[u+p[0],g+p[1]]}else m=e.createPointAt(s,i,o-n.editingLinearElement.pointerOffset.x,r-n.editingLinearElement.pointerOffset.y,t[I.CTRL_OR_CMD]?null:n.gridSize);return d===l?e.movePoints(s,[{index:s.points.length-1,point:m}]):e.addPoints(s,n,[{point:m}]),{...n.editingLinearElement,lastUncommittedPoint:s.points[s.points.length-1]}}static getPointGlobalCoordinates(t,o,r){let[n,i,a,l]=te(t,r),s=(n+a)/2,c=(i+l)/2,{x:d,y:m}=t;return[d,m]=Ee(d+o[0],m+o[1],s,c,t.angle),[d,m]}static getPointsGlobalCoordinates(t,o){let[r,n,i,a]=te(t,o),l=(r+i)/2,s=(n+a)/2;return t.points.map(c=>{let{x:d,y:m}=t;return[d,m]=Ee(d+c[0],m+c[1],l,s,t.angle),[d,m]})}static getPointAtIndexGlobalCoordinates(t,o,r){let n=o<0?t.points.length+o:o,[i,a,l,s]=te(t,r),c=(i+l)/2,d=(a+s)/2,m=t.points[n],{x:p,y:u}=t;return m?Ee(p+m[0],u+m[1],c,d,t.angle):Ee(p,u,c,d,t.angle)}static pointFromAbsoluteCoords(t,o,r){let[n,i,a,l]=te(t,r),s=(n+a)/2,c=(i+l)/2,[d,m]=Ee(o[0],o[1],s,c,-t.angle);return[d-t.x,m-t.y]}static getPointIndexUnderCursor(t,o,r,n,i){let a=e.getPointsGlobalCoordinates(t,o),l=a.length;for(;--l>-1;){let s=a[l];if(mt(n,i,s[0],s[1])*r.value<e.POINT_HANDLE_SIZE+1)return l}return-1}static createPointAt(t,o,r,n,i){let a=At(r,n,i),[l,s,c,d]=te(t,o),m=(l+c)/2,p=(s+d)/2,[u,g]=Ee(a[0],a[1],m,p,-t.angle);return[u-t.x,g-t.y]}static getNormalizedPoints(t){let{points:o}=t,r=o[0][0],n=o[0][1];return{points:o.map((i,a)=>[i[0]-r,i[1]-n]),x:t.x+r,y:t.y+n}}static normalizePoints(t){z(t,e.getNormalizedPoints(t))}static duplicateSelectedPoints(t,o){if(!t.editingLinearElement)return!1;let{selectedPointsIndices:r,elementId:n}=t.editingLinearElement,i=e.getElement(n,o);if(!i||r===null)return!1;let{points:a}=i,l=[],s=!1,c=-1,d=a.reduce((m,p,u)=>{if(++c,m.push(p),r.includes(u)){let x=a[u+1];x||(s=!0),m.push(x?[(p[0]+x[0])/2,(p[1]+x[1])/2]:[p[0],p[1]]),l.push(c+1),++c}return m},[]);if(z(i,{points:d}),s){let m=i.points[i.points.length-1];e.movePoints(i,[{index:i.points.length-1,point:[m[0]+30,m[1]+30]}])}return{appState:{...t,editingLinearElement:{...t.editingLinearElement,selectedPointsIndices:l}}}}static deletePoints(t,o){let r=0,n=0;if(o.includes(0)){let l=t.points.find((s,c)=>!o.includes(c));l&&(r=l[0],n=l[1])}let a=t.points.reduce((l,s,c)=>(o.includes(c)||l.push(l.length?[s[0]-r,s[1]-n]:[0,0]),l),[]);e._updatePoints(t,a,r,n)}static addPoints(t,o,r){let a=[...t.points,...r.map(l=>l.point)];e._updatePoints(t,a,0,0)}static movePoints(t,o,r){let{points:n}=t,i=0,a=0,l=o.find(({index:c})=>c===0);l&&(i=l.point[0]+n[l.index][0],a=l.point[1]+n[l.index][1]);let s=n.map((c,d)=>{let m=o.find(p=>p.index===d);if(m){if(l)return c;let p=m.point[0]-n[m.index][0],u=m.point[1]-n[m.index][1];return[c[0]+p,c[1]+u]}return i||a?[c[0]-i,c[1]-a]:c});e._updatePoints(t,s,i,a,r)}static shouldAddMidpoint(t,o,r,n){if(!e.getElement(t.elementId,n))return!1;let{segmentMidpoint:a}=t.pointerDownState;if(a.added||a.value===null||a.index===null||t.pointerDownState.origin===null)return!1;let l=t.pointerDownState.origin,s=mt(l.x,l.y,o.x,o.y);return!(!r.editingLinearElement&&s<kn/r.zoom.value)}static addMidpoint(t,o,r,n,i){let a=e.getElement(t.elementId,i);if(!a)return;let{segmentMidpoint:l}=t.pointerDownState,s={pointerDownState:t.pointerDownState,selectedPointsIndices:t.selectedPointsIndices},c=e.createPointAt(a,i,o.x,o.y,n?r.gridSize:null),d=[...a.points.slice(0,l.index),c,...a.points.slice(l.index)];return z(a,{points:d}),s.pointerDownState={...t.pointerDownState,segmentMidpoint:{...t.pointerDownState.segmentMidpoint,added:!0},lastClickedPoint:l.index},s.selectedPointsIndices=[l.index],s}static _updatePoints(t,o,r,n,i){let a=Ll(t,o),l=Ll(t,t.points),s=(a[0]+a[2])/2,c=(a[1]+a[3])/2,d=(l[0]+l[2])/2,m=(l[1]+l[3])/2,p=d-s,u=m-c,g=Ee(r,n,p,u,t.angle);z(t,{...i,points:o,x:t.x+g[0],y:t.y+g[1]})}static _getShiftLockedDelta(t,o,r,n,i){let a=e.getPointGlobalCoordinates(t,r,o),[l,s]=At(n[0],n[1],i),{width:c,height:d}=_l(a[0],a[1],l,s);return Xe([c,d],[0,0],-t.angle)}static getBoundTextElementPosition=(t,o,r)=>{let n=e.getPointsGlobalCoordinates(t,r);n.length<2&&z(o,{isDeleted:!0});let i=0,a=0;if(t.points.length%2===1){let l=Math.floor(t.points.length/2),s=e.getPointGlobalCoordinates(t,t.points[l],r);i=s[0]-o.width/2,a=s[1]-o.height/2}else{let l=t.points.length/2-1,s=Nn.points[l];t.points.length===2&&(s=Qs(n[0],n[1])),(!s||Nn.version!==t.version)&&(s=e.getSegmentMidPoint(t,n[l],n[l+1],l+1,r)),i=s[0]-o.width/2,a=s[1]-o.height/2}return{x:i,y:a}};static getMinMaxXYWithBoundText=(t,o,r,n)=>{let[i,a,l,s]=r,c=(i+l)/2,d=(a+s)/2,{x:m,y:p}=e.getBoundTextElementPosition(t,n,o),u=m+n.width,g=p+n.height,x=Xe([i,a],[c,d],t.angle),E=Xe([l,a],[c,d],t.angle),y=Xe([m,p],[c,d],-t.angle),T=Xe([u,p],[c,d],-t.angle),w=Xe([m,g],[c,d],-t.angle),S=Xe([u,g],[c,d],-t.angle);return x[0]<E[0]&&x[1]>=E[1]?(i=Math.min(i,w[0]),l=Math.max(l,Math.max(T[0],S[0])),a=Math.min(a,y[1]),s=Math.max(s,S[1])):x[0]>=E[0]&&x[1]>E[1]?(i=Math.min(i,S[0]),l=Math.max(l,Math.max(y[0],T[0])),a=Math.min(a,w[1]),s=Math.max(s,T[1])):x[0]>=E[0]?(i=Math.min(i,T[0]),l=Math.max(l,w[0]),a=Math.min(a,S[1]),s=Math.max(s,y[1])):x[1]<=E[1]&&(i=Math.min(i,Math.min(T[0],y[0])),l=Math.max(l,S[0]),a=Math.min(a,T[1]),s=Math.max(s,w[1])),[i,a,l,s,c,d]};static getElementAbsoluteCoords=(t,o,r=!1)=>{let n,i,a,l,s;if(t.points.length<2||!Me.get(t)){let{minX:p,minY:u,maxX:g,maxY:x}=t.points.reduce((E,[y,T])=>(E.minY=Math.min(E.minY,T),E.minX=Math.min(E.minX,y),E.maxX=Math.max(E.maxX,y),E.maxY=Math.max(E.maxY,T),E),{minX:1/0,minY:1/0,maxX:-1/0,maxY:-1/0});i=p+t.x,a=u+t.y,l=g+t.x,s=x+t.y}else{let p=Me.generateElementShape(t,null),u=Ar(p[0]),[g,x,E,y]=gc(u);i=g+t.x,a=x+t.y,l=E+t.x,s=y+t.y}let c=(i+l)/2,d=(a+s)/2;if(n=[i,a,l,s,c,d],!r)return n;let m=me(t,o);return m&&(n=e.getMinMaxXYWithBoundText(t,o,[i,a,l,s],m)),n}},_A=e=>{let t=[...new Set(e.filter(o=>o!==null&&o!==-1))];return t=t.sort((o,r)=>o-r),t.length?t:null}});var Ea,ya,Rm,k2,Nm=v(()=>{"use strict";f();Ea={},ya=(e,t)=>{let o=Ea[e]||(Ea[e]={height:t});return o.height=t,o},Rm=e=>{Ea[e]&&delete Ea[e]},k2=e=>Ea[e]?.height??null});var yi,Qh,eo,Om,xa,Pl,Pr,M2,wi,Bm,Fm,qh,hc,fc,PA,DA,vi,L2,_2,Hm,RA,Bn,me,ut,zm,ef,P2,D2,R2,tf,NA,N2,On,wo,wa,O2,Jh,A2,Oo,pt=v(()=>{"use strict";f();G();Ze();U();he();se();io();se();he();We();Ei();Nm();yi=e=>ym(e).replace(/\t/g," "),Qh=e=>yi(e).split(`
10
- `),eo=(e,t,o)=>{let r,n={x:e.x,y:e.y,text:e.text,width:e.width,height:e.height};n.text=e.text,t&&(r=wo(t,e),n.text=vi(e.originalText,Ke(e),r));let i=Pr(n.text,Ke(e),e.lineHeight);if(n.width=i.width,n.height=i.height,t){let a=wa(t,e),l=wo(t,e);if(!ke(t)&&i.height>a){let m=On(i.height,t.type);z(t,{height:m}),ya(t.id,m)}if(i.width>l){let m=On(i.width,t.type);z(t,{width:m})}let s={...e,...n},{x:c,y:d}=Pl(t,s,o);n.x=c,n.y=d}z(e,n)},Om=(e,t,o)=>{let r=re(e);t.forEach(n=>{let i=o.get(n.id),a=Bn(n);if(a){let l=o.get(a);if(l){let s=r.get(i);s&&z(s,{boundElements:(n.boundElements||[]).filter(d=>d.id!==l&&d.id!==a).concat({type:"text",id:l})});let c=r.get(l);c&&W(c)&&z(c,{containerId:s?i:null})}}})},xa=(e,t,o,r=!1)=>{if(!Bn(e))return;Rm(e.id);let i=me(e,t);if(i&&i.text){if(!e)return;let a=i.text,l=i.height,s=i.width,c=wo(e,i),d=wa(e,i),m=e.height;if(r||o!=="n"&&o!=="s"){a&&(a=vi(i.originalText,Ke(i),c));let p=Pr(a,Ke(i),i.lineHeight);l=p.height,s=p.width}if(l>d){m=On(l,e.type);let p=m-e.height,u=!ke(e)&&(o==="ne"||o==="nw"||o==="n")?e.y-p:e.y;z(e,{height:m,y:u})}z(i,{text:a,width:s,height:l}),ke(e)||z(i,Pl(e,i,t))}},Pl=(e,t,o)=>{if(ke(e))return $.getBoundTextElementPosition(e,t,o);let r=ef(e),n=wa(e,t),i=wo(e,t),a,l;return t.verticalAlign===yt.TOP?l=r.y:t.verticalAlign===yt.BOTTOM?l=r.y+(n-t.height):l=r.y+(n/2-t.height/2),t.textAlign===ci.LEFT?a=r.x:t.textAlign===ci.RIGHT?a=r.x+(i-t.width):a=r.x+(i/2-t.width/2),{x:a,y:l}},Pr=(e,t,o)=>{e=e.split(`
1
+ var yk=Object.defineProperty;var xy=e=>t=>{var r=e[t];if(r)return r();throw new Error("Module not found in bundle: "+t)};var y=(e,t)=>()=>(e&&(t=e(e=0)),t);var Xs=(e,t)=>{for(var r in t)yk(e,r,{get:t[r],enumerable:!0})};var S,f=y(()=>{S={NODE_ENV:"production",VITE_APP_BACKEND_V2_GET_URL:"https://json.excalidraw.com/api/v2/",VITE_APP_BACKEND_V2_POST_URL:"https://json.excalidraw.com/api/v2/post/",VITE_APP_LIBRARY_URL:"https://libraries.excalidraw.com",VITE_APP_LIBRARY_BACKEND:"https://us-central1-excalidraw-room-persistence.cloudfunctions.net/libraries",VITE_APP_PLUS_LP:"https://plus.excalidraw.com",VITE_APP_PLUS_APP:"https://app.excalidraw.com",VITE_APP_AI_BACKEND:"https://oss-ai.excalidraw.com",VITE_APP_WS_SERVER_URL:"https://oss-collab.excalidraw.com",VITE_APP_FIREBASE_CONFIG:'{"apiKey":"AIzaSyAd15pYlMci_xIp9ko6wkEsDzAAA0Dn0RU","authDomain":"excalidraw-room-persistence.firebaseapp.com","databaseURL":"https://excalidraw-room-persistence.firebaseio.com","projectId":"excalidraw-room-persistence","storageBucket":"excalidraw-room-persistence.appspot.com","messagingSenderId":"654800341332","appId":"1:654800341332:web:4a692de832b55bd57ce0c1"}',VITE_APP_DISABLE_TRACKING:"",VITE_PKG_NAME:"@excalidraw/excalidraw",VITE_PKG_VERSION:"0.5.0-e56eec7",VITE_IS_EXCALIDRAW_NPM_PACKAGE:!0,PROD:!0}});import{unstable_createStore as vk,useAtom as EO}from"jotai";import{useLayoutEffect as yO}from"react";var Ge,Qt,kt=y(()=>{"use strict";f();Ge=Symbol(),Qt=vk()});var Tk,Og=y(()=>{Tk=xy({"./locales/ar-SA.json":()=>import("./ar-SA-JA6F2FMJ.json"),"./locales/az-AZ.json":()=>import("./az-AZ-GVIENQVH.json"),"./locales/bg-BG.json":()=>import("./bg-BG-YFNNHCEP.json"),"./locales/bn-BD.json":()=>import("./bn-BD-LMEIWSRD.json"),"./locales/ca-ES.json":()=>import("./ca-ES-C2WGCLOT.json"),"./locales/cs-CZ.json":()=>import("./cs-CZ-F2NDIQMB.json"),"./locales/da-DK.json":()=>import("./da-DK-WBEQB3CJ.json"),"./locales/de-DE.json":()=>import("./de-DE-VEIMCP7R.json"),"./locales/el-GR.json":()=>import("./el-GR-TKRKG5GQ.json"),"./locales/en.json":()=>import("./en-Q552WR7L.json"),"./locales/es-ES.json":()=>import("./es-ES-TOLWEZNW.json"),"./locales/eu-ES.json":()=>import("./eu-ES-7CDRJQWJ.json"),"./locales/fa-IR.json":()=>import("./fa-IR-527E2XGU.json"),"./locales/fi-FI.json":()=>import("./fi-FI-NLQ7RQGZ.json"),"./locales/fr-FR.json":()=>import("./fr-FR-KUHO4FLU.json"),"./locales/gl-ES.json":()=>import("./gl-ES-NEXX3VBB.json"),"./locales/he-IL.json":()=>import("./he-IL-MED2VGBZ.json"),"./locales/hi-IN.json":()=>import("./hi-IN-5V633W7V.json"),"./locales/hu-HU.json":()=>import("./hu-HU-2FOZGVGR.json"),"./locales/id-ID.json":()=>import("./id-ID-I6BOLXTF.json"),"./locales/it-IT.json":()=>import("./it-IT-WKPQOK4P.json"),"./locales/ja-JP.json":()=>import("./ja-JP-VKA4ISRU.json"),"./locales/kaa.json":()=>import("./kaa-IKPRSBNY.json"),"./locales/kab-KAB.json":()=>import("./kab-KAB-IE4PHQTZ.json"),"./locales/kk-KZ.json":()=>import("./kk-KZ-MNJT6XSV.json"),"./locales/km-KH.json":()=>import("./km-KH-LADGDFXV.json"),"./locales/ko-KR.json":()=>import("./ko-KR-XD7AVF2F.json"),"./locales/ku-TR.json":()=>import("./ku-TR-4XBHKDQA.json"),"./locales/lt-LT.json":()=>import("./lt-LT-QC35R4YH.json"),"./locales/lv-LV.json":()=>import("./lv-LV-GSD5D3BA.json"),"./locales/mr-IN.json":()=>import("./mr-IN-KOLSWM7Y.json"),"./locales/my-MM.json":()=>import("./my-MM-M53KMUET.json"),"./locales/nb-NO.json":()=>import("./nb-NO-XXC6U37A.json"),"./locales/nl-NL.json":()=>import("./nl-NL-HCCJQEUO.json"),"./locales/nn-NO.json":()=>import("./nn-NO-6P7Z2PI2.json"),"./locales/oc-FR.json":()=>import("./oc-FR-JRJKPLNT.json"),"./locales/pa-IN.json":()=>import("./pa-IN-LZWLEPIB.json"),"./locales/percentages.json":()=>import("./percentages-UCQDHIQF.json"),"./locales/pl-PL.json":()=>import("./pl-PL-3WBLCXI2.json"),"./locales/pt-BR.json":()=>import("./pt-BR-O3ZPTUNW.json"),"./locales/pt-PT.json":()=>import("./pt-PT-7AQTSAFO.json"),"./locales/ro-RO.json":()=>import("./ro-RO-HJ65JYWV.json"),"./locales/ru-RU.json":()=>import("./ru-RU-P7ROIYNC.json"),"./locales/si-LK.json":()=>import("./si-LK-7ZSWVION.json"),"./locales/sk-SK.json":()=>import("./sk-SK-NXVBGLYY.json"),"./locales/sl-SI.json":()=>import("./sl-SI-VFTWOYNP.json"),"./locales/sv-SE.json":()=>import("./sv-SE-YONBLQNW.json"),"./locales/ta-IN.json":()=>import("./ta-IN-BSETPMLX.json"),"./locales/th-TH.json":()=>import("./th-TH-URTRDITB.json"),"./locales/tr-TR.json":()=>import("./tr-TR-N5SCAVTB.json"),"./locales/uk-UA.json":()=>import("./uk-UA-LBCYVSQZ.json"),"./locales/vi-VN.json":()=>import("./vi-VN-POZWLIUU.json"),"./locales/zh-CN.json":()=>import("./zh-CN-FUF5V3SC.json"),"./locales/zh-HK.json":()=>import("./zh-HK-OB4VW42C.json"),"./locales/zh-TW.json":()=>import("./zh-TW-5JPVKOM7.json")})});import wy from"./en-Q552WR7L.json";import Sk from"./percentages-UCQDHIQF.json";import{atom as Ck,useAtomValue as Ik}from"jotai";var Ak,jo,vl,hm,wl,um,gm,Dn,yy,b,vy,Mt,q=y(()=>{"use strict";f();kt();Og();Ak=85,jo={code:"en",label:"English"},vl=[jo,...[{code:"ar-SA",label:"\u0627\u0644\u0639\u0631\u0628\u064A\u0629",rtl:!0},{code:"bg-BG",label:"\u0411\u044A\u043B\u0433\u0430\u0440\u0441\u043A\u0438"},{code:"ca-ES",label:"Catal\xE0"},{code:"cs-CZ",label:"\u010Cesky"},{code:"de-DE",label:"Deutsch"},{code:"el-GR",label:"\u0395\u03BB\u03BB\u03B7\u03BD\u03B9\u03BA\u03AC"},{code:"es-ES",label:"Espa\xF1ol"},{code:"eu-ES",label:"Euskara"},{code:"fa-IR",label:"\u0641\u0627\u0631\u0633\u06CC",rtl:!0},{code:"fi-FI",label:"Suomi"},{code:"fr-FR",label:"Fran\xE7ais"},{code:"gl-ES",label:"Galego"},{code:"he-IL",label:"\u05E2\u05D1\u05E8\u05D9\u05EA",rtl:!0},{code:"hi-IN",label:"\u0939\u093F\u0928\u094D\u0926\u0940"},{code:"hu-HU",label:"Magyar"},{code:"id-ID",label:"Bahasa Indonesia"},{code:"it-IT",label:"Italiano"},{code:"ja-JP",label:"\u65E5\u672C\u8A9E"},{code:"kab-KAB",label:"Taqbaylit"},{code:"kk-KZ",label:"\u049A\u0430\u0437\u0430\u049B \u0442\u0456\u043B\u0456"},{code:"ko-KR",label:"\uD55C\uAD6D\uC5B4"},{code:"ku-TR",label:"Kurd\xEE"},{code:"lt-LT",label:"Lietuvi\u0173"},{code:"lv-LV",label:"Latvie\u0161u"},{code:"my-MM",label:"Burmese"},{code:"nb-NO",label:"Norsk bokm\xE5l"},{code:"nl-NL",label:"Nederlands"},{code:"nn-NO",label:"Norsk nynorsk"},{code:"oc-FR",label:"Occitan"},{code:"pa-IN",label:"\u0A2A\u0A70\u0A1C\u0A3E\u0A2C\u0A40"},{code:"pl-PL",label:"Polski"},{code:"pt-BR",label:"Portugu\xEAs Brasileiro"},{code:"pt-PT",label:"Portugu\xEAs"},{code:"ro-RO",label:"Rom\xE2n\u0103"},{code:"ru-RU",label:"\u0420\u0443\u0441\u0441\u043A\u0438\u0439"},{code:"sk-SK",label:"Sloven\u010Dina"},{code:"sv-SE",label:"Svenska"},{code:"sl-SI",label:"Sloven\u0161\u010Dina"},{code:"tr-TR",label:"T\xFCrk\xE7e"},{code:"uk-UA",label:"\u0423\u043A\u0440\u0430\u0457\u043D\u0441\u044C\u043A\u0430"},{code:"zh-CN",label:"\u7B80\u4F53\u4E2D\u6587"},{code:"zh-TW",label:"\u7E41\u9AD4\u4E2D\u6587"},{code:"vi-VN",label:"Ti\u1EBFng Vi\u1EC7t"},{code:"mr-IN",label:"\u092E\u0930\u093E\u0920\u0940"}].filter(e=>Sk[e.code]>=Ak).sort((e,t)=>e.label>t.label?1:-1)],hm="__test__";S.DEV&&vl.unshift({code:hm,label:"test language"},{code:`${hm}.rtl`,label:"\u202Atest language (rtl)\u202C",rtl:!0});wl=jo,um={},gm=async e=>{if(wl=e,document.documentElement.dir=wl.rtl?"rtl":"ltr",document.documentElement.lang=wl.code,e.code.startsWith(hm))um={};else try{um=await Tk(`./locales/${wl.code}.json`)}catch(t){console.error(`Failed to load language ${e.code}:`,t.message),um=wy}Qt.set(vy,e.code)},Dn=()=>wl,yy=(e,t)=>{for(let r=0;r<t.length;++r){let o=t[r];if(e[o]===void 0)return;e=e[o]}if(typeof e=="string")return e},b=(e,t,r)=>{if(wl.code.startsWith(hm))return`\u202A[[${t?`${e}(${JSON.stringify(t).slice(1,-1)})`:e}]]\u202C`;let o=e.split("."),n=yy(um,o)||yy(wy,o)||r;if(n===void 0){let i=`Can't find translation for ${e}`;if(S.PROD)return console.warn(i),"";throw new Error(i)}if(t)for(let i in t)n=n.replace(`{{${i}}}`,String(t[i]));return n},vy=Ck(jo.code),Mt=()=>{let e=Ik(vy,Ge);return{t:b,langCode:e}}});var Ty=y(()=>{});import kk from"react";import{jsx as Bg}from"react/jsx-runtime";var Mk,er,_n=y(()=>{"use strict";f();Ty();Mk=({size:e="1em",circleWidth:t=8,synchronized:r=!1})=>{let n=-(kk.useRef(Date.now()).current%1600);return Bg("div",{className:"Spinner",children:Bg("svg",{viewBox:"0 0 100 100",style:{width:e,height:e,"--spinner-delay":r?`${n}ms`:0},children:Bg("circle",{cx:"50",cy:"50",r:50-t/2,strokeWidth:t,fill:"none",strokeMiterlimit:"10"})})})},er=Mk});var ur,fm,Sy,Rn,Lk,zO,bm,Cy,Zs,js,Nn,Tl,Iy,Fg,Ay,qo,zg,Re,hi,ga,qs,kr,Em,ht,se,et,Hg,xm,Ot,tr,gi,fa,fi,ym,Gt,bi,Js,wm,Pk,ky,My,On,Qs,Ly,te,vm,ar,ec,Py,Dy,_y,Ry,ba,Sl,Ug,Ny,Cl,Tm,Sm,Gg,Oy,By,Fy,zy,Hy,Il,Al,Jo,Uy,Vg,We,Ea,yt,Gy,Vy,Tt,Ei,Wy,Cm,Yy,ct,Wg,Im,at,tc,Vr,Am,St,po,km,W=y(()=>{"use strict";f();ur=/Mac|iPod|iPhone|iPad/.test(navigator.platform),fm=/^Win/.test(navigator.platform),Sy=/\b(android)\b/i.test(navigator.userAgent),Rn="netscape"in window&&navigator.userAgent.indexOf("rv:")>1&&navigator.userAgent.indexOf("Gecko")>1,Lk=navigator.userAgent.indexOf("Chrome")!==-1,zO=!Lk&&navigator.userAgent.indexOf("Safari")!==-1,bm=/iPad|iPhone/.test(navigator.platform)||navigator.userAgent.includes("Mac")&&"ontouchend"in document,Cy=()=>navigator.brave?.isBrave?.name==="isBrave",Zs=typeof window<"u"&&"ResizeObserver"in window,js="Excalidraw",Nn=10,Tl=8,Iy=5,Fg=1,Ay=30,qo=Math.PI/12,zg="red",Re={TEXT:"text",CROSSHAIR:"crosshair",GRABBING:"grabbing",GRAB:"grab",POINTER:"pointer",MOVE:"move",AUTO:""},hi={MAIN:0,WHEEL:1,SECONDARY:2,TOUCH:-1,ERASER:5},ga={enabled:"all",disabled:"none",inheritFromUI:"var(--ui-pointerEvents)"},qs={UNSTARTED:-1,ENDED:0,PLAYING:1,PAUSED:2,BUFFERING:3,CUED:5},kr={TEST:"test"},Em={SHAPE_ACTIONS_MENU:"App-menu__left"},ht={Virgil:1,Helvetica:2,Cascadia:3,Assistant:4},se={LIGHT:"light",DARK:"dark"},et={strokeColor:"#bbb",strokeWidth:2,strokeStyle:"solid",fillStyle:"solid",roughness:0,roundness:null,backgroundColor:"transparent",radius:8,nameOffsetY:3,nameColorLightTheme:"#999999",nameColorDarkTheme:"#7a7a7a",nameFontSize:14,nameLineHeight:1.25},Hg="Segoe UI Emoji",xm=1,Ot=20,tr=ht.Virgil,gi="left",fa="top",fi=2,ym=1,Gt="#ffffff",bi="#1e1e1e",Js="transparent",wm=2*fi,Pk=1e-5,ky=2*wm-Pk,My="#a2f1a6",On=20,Qs={svg:"image/svg+xml",png:"image/png",jpg:"image/jpeg",gif:"image/gif",webp:"image/webp",bmp:"image/bmp",ico:"image/x-icon",avif:"image/avif",jfif:"image/jfif"},Ly=["text/plain","text/html"],te={json:"application/json",excalidraw:"application/vnd.excalidraw+json",excalidrawlib:"application/vnd.excalidrawlib+json","excalidraw.svg":"image/svg+xml","excalidraw.png":"image/png",binary:"application/octet-stream",...Qs},vm={png:"png",svg:"svg",clipboard:"clipboard"},ar={excalidraw:"excalidraw",excalidrawClipboard:"excalidraw/clipboard",excalidrawLibrary:"excalidrawlib",excalidrawClipboardWithAPI:"excalidraw-api/clipboard"},ec=window.EXCALIDRAW_EXPORT_SOURCE||window.location.origin,Py=500,Dy=300,_y=500,Ry=100,ba=.1,Sl=.1,Ug=30,Ny=300,Cl="invert(93%) hue-rotate(180deg)",Tm={addLibrary:"addLibrary"},Sm={addLibrary:"addLibrary"},Gg={canvasActions:{changeViewBackgroundColor:!0,clearCanvas:!0,export:{saveFileToDisk:!0},loadScene:!0,saveToActiveFile:!0,toggleTheme:null,saveAsImage:!0},tools:{image:!0}},Oy=800,By=1e3,Fy=500,zy=1229,Hy=302,Il=2,Al=[1,2,3],Jo=10,Uy=1440,Vg=2*1024*1024,We="http://www.w3.org/2000/svg",Ea={excalidraw:2,excalidrawLibrary:2},yt=5,Gy=.7,Vy=11,Tt={TOP:"top",MIDDLE:"middle",BOTTOM:"bottom"},Ei={LEFT:"left",CENTER:"center",RIGHT:"right"},Wy=20,Cm=.25,Yy=32,ct={LEGACY:1,PROPORTIONAL_RADIUS:2,ADAPTIVE_RADIUS:3},Wg={architect:0,artist:1,cartoonist:2},Im={thin:1,bold:2,extraBold:4},at={strokeColor:bi,backgroundColor:Js,fillStyle:"solid",strokeWidth:2,strokeStyle:"solid",roughness:Wg.artist,opacity:100,locked:!1},tc="library",Vr={name:"default",defaultTab:tc},Am=new Set(["iframe","embeddable","image"]),St={selection:"selection",rectangle:"rectangle",diamond:"diamond",ellipse:"ellipse",arrow:"arrow",line:"line",freedraw:"freedraw",text:"text",image:"image",eraser:"eraser",hand:"hand",frame:"frame",magicframe:"magicframe",embeddable:"embeddable",laser:"laser"},po={OAI_API_KEY:"excalidraw-oai-api-key",MERMAID_TO_EXCALIDRAW:"mermaid-to-excalidraw",PUBLISH_LIBRARY:"publish-library-data"},km="Untitled"});import{useState as Dk,useEffect as _k}from"react";import Rk from"clsx";import{jsx as Yg,jsxs as Nk}from"react/jsx-runtime";var Mm,Kg=y(()=>{"use strict";f();q();_n();W();Mm=({delay:e,theme:t})=>{let[r,o]=Dk(!!e);return _k(()=>{if(!e)return;let n=setTimeout(()=>{o(!1)},e);return()=>clearTimeout(n)},[e]),r?null:Nk("div",{className:Rk("LoadingMessage",{"LoadingMessage--dark":t===se.DARK}),children:[Yg("div",{children:Yg(er,{})}),Yg("div",{className:"LoadingMessage-text",children:b("labels.loadingScene")})]})}});import{useEffect as Ok,useState as Bk}from"react";import{jsx as Fk}from"react/jsx-runtime";var Ky,$y=y(()=>{"use strict";f();Kg();q();Ky=e=>{let[t,r]=Bk(!0);return Ok(()=>{let o=async()=>{await gm(n),r(!1)},n=vl.find(i=>i.code===e.langCode)||jo;o()},[e.langCode]),t?Fk(Mm,{theme:e.theme}):e.children}});function Et(e,t,r,o){return e?(e?.addEventListener?.(t,r,o),()=>{e?.removeEventListener?.(t,r,o)}):()=>{}}function cw(e,t=!0){let r=e.length;if(r<4)return"";let o=e[0],n=e[1],i=e[2],a=`M${o[0].toFixed(2)},${o[1].toFixed(2)} Q${n[0].toFixed(2)},${n[1].toFixed(2)} ${Lm(n[0],i[0]).toFixed(2)},${Lm(n[1],i[1]).toFixed(2)} T`;for(let l=2,s=r-1;l<s;l++)o=e[l],n=e[l+1],a+=`${Lm(o[0],n[0]).toFixed(2)},${Lm(o[1],n[1]).toFixed(2)} `;return t&&(a+="Z"),a}var Xy,$g,Qo,qy,Xg,Jy,uo,kl,Ze,xa,Ml,Bn,Zy,Qy,ew,Bt,tt,N,je,Vt,rc,zk,Hk,Uk,Pm,Ro,Dm,Zg,jg,hr,_m,tw,rw,ow,nw,Fn,X,iw,en,Wr,aw,Rm,Ll,lw,tn,oc,jy,rt,xi,No,sw,nc,rn,qg,Nm,Lm,Om,Yr,ic,dw,G=y(()=>{"use strict";f();W();Xy=null,$g=()=>{if(Xy)return Xy;let e=new Date,t=e.getFullYear(),r=`${e.getMonth()+1}`.padStart(2,"0"),o=`${e.getDate()}`.padStart(2,"0"),n=`${e.getHours()}`.padStart(2,"0"),i=`${e.getMinutes()}`.padStart(2,"0");return`${t}-${r}-${o}-${n}${i}`},Qo=e=>e.charAt(0).toUpperCase()+e.slice(1),qy=e=>e instanceof HTMLElement&&e.className.includes("ToolIcon"),Xg=e=>e instanceof HTMLElement&&e.dataset.type==="wysiwyg"||e instanceof HTMLBRElement||e instanceof HTMLInputElement||e instanceof HTMLTextAreaElement||e instanceof HTMLSelectElement,Jy=e=>Xg(e)||e instanceof Element&&!!e.closest("label, button"),uo=e=>e instanceof HTMLElement&&e.dataset.type==="wysiwyg"||e instanceof HTMLBRElement||e instanceof HTMLTextAreaElement||e instanceof HTMLInputElement&&(e.type==="text"||e.type==="number"||e.type==="password"),kl=({fontFamily:e})=>{for(let[t,r]of Object.entries(ht))if(r===e)return`${t}, ${Hg}`;return Hg},Ze=({fontSize:e,fontFamily:t})=>`${e}px ${kl({fontFamily:t})}`,xa=(e,t)=>{let r=0,o=null,n=(...i)=>{o=i,clearTimeout(r),r=window.setTimeout(()=>{o=null,e(...i)},t)};return n.flush=()=>{if(clearTimeout(r),o){let i=o;o=null,e(...i)}},n.cancel=()=>{o=null,clearTimeout(r)},n},Ml=(e,t)=>{let r=null,o=null,n=null,i=l=>{r=window.requestAnimationFrame(()=>{r=null,e(...l),o=null,n&&(o=n,n=null,i(o))})},a=(...l)=>{if(S.MODE==="test"){e(...l);return}o=l,r===null?i(o):t?.trailing&&(n=l)};return a.flush=()=>{r!==null&&(cancelAnimationFrame(r),r=null),o&&(e(...n||o),o=n=null)},a.cancel=()=>{o=n=null,r!==null&&(cancelAnimationFrame(r),r=null)},a},Bn=e=>1-Math.pow(1-e,4),Zy=(e,t,r)=>(t-e)*Bn(r)+e,Qy=({fromValues:e,toValues:t,onStep:r,duration:o=250,interpolateValue:n,onStart:i,onEnd:a,onCancel:l})=>{let s=!1,c=0,d;function m(p){if(s)return;d===void 0&&(d=p,i?.());let u=Math.min(p-d,o),h=Bn(u/o),E={};if(Object.keys(e).forEach(x=>{let T=x,v=(t[T]-e[T])*h+e[T];E[T]=v}),r(E),u<o){let x=u/o,T={};Object.keys(e).forEach(v=>{let w=v,I=e[w],L=t[w],A;A=n?n(I,L,x,w):Zy(I,L,x),A==null&&(A=Zy(I,L,x)),T[w]=A}),r(T),c=window.requestAnimationFrame(m)}else r(t),a?.()}return c=window.requestAnimationFrame(m),()=>{l?.(),s=!0,window.cancelAnimationFrame(c)}},ew=(e,t)=>{if(!e.length||t<1)return[];let r=0,o=0,n=Array(Math.ceil(e.length/t));for(;r<e.length;)n[o++]=e.slice(r,r+=t);return n},Bt=(e,t)=>Math.abs(e-t),tt=(e,t)=>t.type==="custom"?{...e.activeTool,type:"custom",customType:t.customType,locked:t.locked??e.activeTool.locked}:{...e.activeTool,lastActiveTool:t.lastActiveToolBeforeEraser===void 0?e.activeTool.lastActiveTool:t.lastActiveToolBeforeEraser,type:t.type,customType:null,locked:t.locked??e.activeTool.locked},N=e=>(e=e.replace(/\bAlt\b/i,"Alt").replace(/\bShift\b/i,"Shift").replace(/\b(Enter|Return)\b/i,"Enter"),ur?e.replace(/\bCtrlOrCmd\b/gi,"Cmd").replace(/\bAlt\b/i,"Option"):e.replace(/\bCtrlOrCmd\b/gi,"Ctrl")),je=({clientX:e,clientY:t},{zoom:r,offsetLeft:o,offsetTop:n,scrollX:i,scrollY:a})=>{let l=(e-o)/r.value-i,s=(t-n)/r.value-a;return{x:l,y:s}},Vt=({sceneX:e,sceneY:t},{zoom:r,offsetLeft:o,offsetTop:n,scrollX:i,scrollY:a})=>{let l=(e+i)*r.value+o,s=(t+a)*r.value+n;return{x:l,y:s}},rc=e=>getComputedStyle(document.documentElement).getPropertyValue(`--${e}`),zk="A-Za-z\xC0-\xD6\xD8-\xF6\xF8-\u02B8\u0300-\u0590\u0800-\u1FFF\u2C00-\uFB1C\uFDFE-\uFE6F\uFEFD-\uFFFF",Hk="\u0591-\u07FF\uFB1D-\uFDFD\uFE70-\uFEFC",Uk=new RegExp(`^[^${zk}]*[${Hk}]`),Pm=e=>Uk.test(e),Ro=e=>{let[t,r]=e;return{x:t,y:r}},Dm=e=>{if(e?.name==="AbortError"){console.warn(e);return}throw e},Zg=(e,t,r=0)=>{r<0&&(r=e.length+r),r=Math.min(e.length,Math.max(r,0));let o=r-1;for(;++o<e.length;)if(t(e[o],o,e))return o;return-1},jg=(e,t,r=e.length-1)=>{r<0&&(r=e.length+r),r=Math.min(e.length-1,Math.max(r,0));let o=r+1;for(;--o>-1;)if(t(e[o],o,e))return o;return-1},hr=e=>{let t=e.length===5&&e.substr(4,1)==="0",r=e.length===9&&e.substr(7,2)==="00";return t||r||e===Js},_m=()=>{let e,t,r=new Promise((o,n)=>{e=o,t=n});return r.resolve=e,r.reject=t,r},tw=e=>{let t=e.parentElement;for(;t;){if(t===document.body)return document;let{overflowY:r}=window.getComputedStyle(t);if(t.scrollHeight>t.clientHeight&&(r==="auto"||r==="scroll"||r==="overlay"))return t;t=t.parentElement}return document},rw=e=>{let t=e.parentElement;for(;t;){if(t.tabIndex>-1){t.focus();return}t=t.parentElement}},ow=e=>{e.preventDefault(),e.returnValue=""},nw=e=>Array.from(e).map(t=>`0${t.toString(16)}`.slice(-2)).join(""),Fn=()=>Wr()?1:Date.now(),X=e=>e instanceof Map?e:e.reduce((t,r)=>(t.set(typeof r=="string"?r:r.id,r),t),new Map),iw=e=>e.reduce((t,r,o)=>(t.set(r.id,[r,o]),t),new Map),en=(e,t)=>e.reduce((r,o)=>(r[t?t(o):String(o)]=o,r),{}),Wr=()=>S.MODE==="test",aw=()=>S.MODE==="development",Rm=(e,t)=>new CustomEvent(e,{detail:{nativeEvent:t},cancelable:!0}),Ll=(e,t)=>{let r=!1;for(let o in t){let n=t[o];if(typeof n<"u"){if(e[o]===n&&(typeof n!="object"||n===null))continue;r=!0}}return r?{...e,...t}:e},lw=()=>{try{return window.self===window.top?"top":"iframe"}catch{return"iframe"}},tn=e=>!!e&&typeof e=="object"&&"then"in e&&"catch"in e&&"finally"in e,oc=e=>{let t=e?.querySelectorAll("button, a, input, select, textarea, div[tabindex], label[tabindex]");return t?Array.from(t).filter(r=>r.tabIndex>-1&&!r.disabled):[]},jy=(e,t)=>Array.isArray(e)&&Array.isArray(t)&&e.length===0&&t.length===0?!0:e===t,rt=(e,t,r,o=!1)=>{let n=Object.keys(e),i=Object.keys(t);if(n.length!==i.length)return o&&console.warn("%cisShallowEqual: objects don't have same properties ->","color: #8B4000",e,t),!1;if(r&&Array.isArray(r)){for(let a of r)if(!(e[a]===t[a]||jy(e[a],t[a])))return o&&console.warn(`%cisShallowEqual: ${a} not equal ->`,"color: #8B4000",e[a],t[a]),!1;return!0}return n.every(a=>{let l=r?.[a],s=l?l(e[a],t[a]):e[a]===t[a]||jy(e[a],t[a]);return!s&&o&&console.warn(`%cisShallowEqual: ${a} not equal ->`,"color: #8B4000",e[a],t[a]),s})},xi=(e,t,{checkForDefaultPrevented:r=!0}={})=>function(n){if(e?.(n),!r||!n?.defaultPrevented)return t?.(n)},No=(e,t,r)=>{if(!t)return e;if(r)return console.error(t),e;throw new Error(t)},sw=e=>{let t,r,o=function(n){let i=Object.entries(n);if(t){let l=!0;for(let[s,c]of i)if(t.get(s)!==c){l=!1;break}if(l)return r}let a=e(n);return t=new Map(i),r=a,a};return o.clear=()=>{t=void 0,r=void 0},o},nc=(e,t)=>e instanceof Set||e instanceof Map?e.has(t):"includes"in e?e.includes(t):e.hasOwnProperty(t),rn=e=>JSON.parse(JSON.stringify(e)),qg=e=>typeof e=="number"&&Number.isFinite(e),Nm=(e,t)=>rt(e,t)?e:t;Lm=(e,t)=>(e+t)/2;Om=e=>e.replace(/\r?\n|\r/g,`
2
+ `),Yr=e=>e,ic=async(e,...t)=>new Promise(r=>{r(e(...t))}),dw=(e,t)=>t.reduce((r,o)=>(o in e&&(r[o]=e[o]),r),{})});var gr,ho,Lt,go,rr,V,yi,ya,re,Ft,Gk,ce,Ce,ac,Wt,Jg,zn,on,lc,lr,Pe,nn,mw,pw,uw,me=y(()=>{"use strict";f();W();G();gr=e=>!!e&&e.type==="image"&&!!e.fileId,ho=e=>!!e&&e.type==="image",Lt=e=>!!e&&e.type==="embeddable",go=e=>!!e&&e.type==="iframe",rr=e=>!!e&&(e.type==="iframe"||e.type==="embeddable"),V=e=>e!=null&&e.type==="text",yi=e=>e!=null&&e.type==="frame",ya=e=>e!=null&&e.type==="magicframe",re=e=>e!=null&&(e.type==="frame"||e.type==="magicframe"),Ft=e=>e!=null&&Gk(e.type),Gk=e=>e==="freedraw",ce=e=>e!=null&&ac(e.type),Ce=e=>e!=null&&e.type==="arrow",ac=e=>e==="arrow"||e==="line",Wt=(e,t=!0)=>e!=null&&(!e.locked||t===!0)&&Jg(e.type),Jg=e=>e==="arrow",zn=(e,t=!0)=>e!=null&&(!e.locked||t===!0)&&(e.type==="rectangle"||e.type==="diamond"||e.type==="ellipse"||e.type==="image"||e.type==="iframe"||e.type==="embeddable"||e.type==="frame"||e.type==="magicframe"||e.type==="text"&&!e.containerId),on=(e,t=!0)=>e!=null&&(!e.locked||t===!0)&&(e.type==="rectangle"||e.type==="diamond"||e.type==="ellipse"||Ce(e)),lc=e=>{let t=e?.type;if(!t)return!1;switch(t){case"text":case"diamond":case"rectangle":case"iframe":case"embeddable":case"ellipse":case"arrow":case"freedraw":case"line":case"frame":case"magicframe":case"image":case"selection":return!0;default:return No(t,null),!1}},lr=e=>on(e)&&!!e.boundElements?.some(({type:t})=>t==="text"),Pe=e=>e!==null&&"containerId"in e&&e.containerId!==null&&V(e),nn=e=>e==="rectangle"||e==="embeddable"||e==="iframe"||e==="image",mw=e=>e==="line"||e==="arrow"||e==="diamond",pw=(e,t)=>!!((e===ct.ADAPTIVE_RADIUS||e===ct.LEGACY)&&nn(t.type)||e===ct.PROPORTIONAL_RADIUS&&mw(t.type)),uw=e=>mw(e.type)?{type:ct.PROPORTIONAL_RADIUS}:nn(e.type)?{type:ct.ADAPTIVE_RADIUS}:null});import{Random as Vk}from"roughjs/bin/math";import{nanoid as Wk}from"nanoid";var Yk,Kk,fo,zt,Oo=y(()=>{"use strict";f();G();Yk=new Vk(Date.now()),Kk=0,fo=()=>Math.floor(Yk.next()*2**31),zt=()=>Wr()?`id${Kk++}`:Wk()});var Bm,an,Bo,Fm,wi=y(()=>{"use strict";f();Bm=class extends Error{constructor(t="Couldn't export canvas.",r="CANVAS_ERROR"){super(),this.name=r,this.message=t}},an=class extends DOMException{constructor(t="Request Aborted"){super(t,"AbortError")}},Bo=class extends Error{code;constructor(t="Image Scene Data Error",r="IMAGE_SCENE_DATA_ERROR"){super(t),this.name="EncodingError",this.code=r}},Fm=class extends Error{code="ELEMENT_HAS_INVALID_INDEX"}});import{generateNKeysBetween as $k}from"fractional-indexing";var Qg,zm,Yt,fr,Xk,Zk,sc,gw,hw,bo=y(()=>{"use strict";f();Ye();wi();Qg=e=>{for(let[t,r]of e.entries()){let o=e[t-1],n=e[t+1];if(!sc(r,o,n))throw new Fm(`Fractional indices invariant for element has been compromised - ["${o}", "${r}", "${n}"] [predecessor, current, successor]`)}},zm=e=>e.sort((t,r)=>hw(t)&&hw(r)?t.index<r.index?-1:t.index>r.index?1:t.id<r.id?-1:1:1),Yt=(e,t)=>{try{let r=Xk(e,t),o=gw(e,r);Qg(e.map(n=>o.get(n)?.index||n.index));for(let[n,i]of o)H(n,i,!1)}catch{fr(e)}return e},fr=e=>{let t=Zk(e),r=gw(e,t);for(let[o,n]of r)H(o,n,!1);return e},Xk=(e,t)=>{let r=[],o=0;for(;o<e.length;)if(t.has(e[o].id)&&!sc(e[o]?.index,e[o-1]?.index,e[o+1]?.index)){let n=[o-1,o];for(;++o<e.length&&(t.has(e[o].id)&&!sc(e[o]?.index,e[o-1]?.index,e[o+1]?.index));)n.push(o);n.push(o),r.push(n)}else o++;return r},Zk=e=>{let t=[],r,o,n=-1,i=0,a=c=>{let d=e[n]?e[n].index:void 0,m=e[c-1]?.index;return!d&&m||d&&m&&m>d?[m,c-1]:[d,n]},l=c=>{let d=e[i]?e[i].index:void 0;if(d&&c<i)return[d,i];let m=i;for(;++m<e.length;){let p=e[m]?.index;if(!d&&p||d&&p&&p>d)return[p,m]}return[void 0,m]},s=0;for(;s<e.length;){let c=e[s].index;if([r,n]=a(s),[o,i]=l(s),sc(c,r,o))s++;else{let d=[n,s];for(;++s<e.length;){let m=e[s].index,[p,u]=a(s),[h,E]=l(s);if(sc(m,p,h))break;[r,n]=[p,u],[o,i]=[h,E],d.push(s)}d.push(i),t.push(d)}}return t},sc=(e,t,r)=>e?t&&r?t<e&&e<r:!t&&r?e<r:t&&!r?t<e:!!e:!1,gw=(e,t)=>{let r=new Map;for(let o of t){let n=o.shift(),i=o.pop(),a=$k(e[n]?.index,e[i]?.index,o.length);for(let l=0;l<o.length;l++){let s=e[o[l]];r.set(s,{index:a[l]})}}return r},hw=e=>!!e.index});var fw,jk,bw,ef,Ct,vi=y(()=>{"use strict";f();xe();me();Ti();Oo();bo();G();G();W();fw=e=>{let t=new Map,r=[];for(let o of e)o.isDeleted||(r.push(o),t.set(o.id,o));return{elementsMap:t,elements:r}},jk=e=>{let t=["includeBoundTextElement","includeElementsInFrames"],r="";for(let o of t)r+=`${o}:${e[o]?"1":"0"}`;return r},bw=e=>typeof e=="string",ef=class e{static sceneMapByElement=new WeakMap;static sceneMapById=new Map;static mapElementToScene(t,r){bw(t)?this.sceneMapById.set(t,r):(this.sceneMapByElement.set(t,r),this.sceneMapById.set(t.id,r))}static getScene(t){return bw(t)?this.sceneMapById.get(t)||null:this.sceneMapByElement.get(t)||null}callbacks=new Set;nonDeletedElements=[];nonDeletedElementsMap=Yr(new Map);elements=[];nonDeletedFramesLikes=[];frames=[];elementsMap=Yr(new Map);selectedElementsCache={selectedElementIds:null,elements:null,cache:new Map};versionNonce;getNonDeletedElementsMap(){return this.nonDeletedElementsMap}getElementsIncludingDeleted(){return this.elements}getElementsMapIncludingDeleted(){return this.elementsMap}getNonDeletedElements(){return this.nonDeletedElements}getFramesIncludingDeleted(){return this.frames}getSelectedElements(t){let r=jk(t),o=t?.elements||this.nonDeletedElements;if(this.selectedElementsCache.elements===o&&this.selectedElementsCache.selectedElementIds===t.selectedElementIds){let i=this.selectedElementsCache.cache.get(r);if(i)return i}else t?.elements==null&&this.selectedElementsCache.cache.clear();let n=ge(o,{selectedElementIds:t.selectedElementIds},t);return t?.elements==null&&(this.selectedElementsCache.selectedElementIds=t.selectedElementIds,this.selectedElementsCache.elements=this.nonDeletedElements,this.selectedElementsCache.cache.set(r,n)),n}getNonDeletedFramesLikes(){return this.nonDeletedFramesLikes}getElement(t){return this.elementsMap.get(t)||null}getVersionNonce(){return this.versionNonce}getNonDeletedElement(t){let r=this.getElement(t);return r&&cc(r)?r:null}mapElements(t){let r=!1,o=this.elements.map(n=>{let i=t(n);return i!==n&&(r=!0),i});return r&&this.replaceAllElements(o),r}replaceAllElements(t){let r=t instanceof Array?t:Array.from(t.values()),o=[];(S.DEV||S.MODE===kr.TEST)&&Qg(r.map(i=>i.index)),this.elements=fr(r),this.elementsMap.clear(),this.elements.forEach(i=>{re(i)&&o.push(i),this.elementsMap.set(i.id,i),e.mapElementToScene(i,this)});let n=fw(this.elements);this.nonDeletedElements=n.elements,this.nonDeletedElementsMap=n.elementsMap,this.frames=o,this.nonDeletedFramesLikes=fw(this.frames).elements,this.informMutation()}informMutation(){this.versionNonce=fo();for(let t of Array.from(this.callbacks))t()}addCallback(t){if(this.callbacks.has(t))throw new Error;return this.callbacks.add(t),()=>{if(!this.callbacks.has(t))throw new Error;this.callbacks.delete(t)}}destroy(){this.elements=[],this.nonDeletedElements=[],this.nonDeletedFramesLikes=[],this.frames=[],this.elementsMap.clear(),this.selectedElementsCache.selectedElementIds=null,this.selectedElementsCache.elements=null,this.selectedElementsCache.cache.clear(),e.sceneMapById.forEach((t,r)=>{t===this&&e.sceneMapById.delete(r)}),this.callbacks.clear()}insertElementAtIndex(t,r){if(!Number.isFinite(r)||r<0)throw new Error("insertElementAtIndex can only be called with index >= 0");let o=[...this.elements.slice(0,r),t,...this.elements.slice(r)];Yt(o,X([t])),this.replaceAllElements(o)}insertElementsAtIndex(t,r){if(!Number.isFinite(r)||r<0)throw new Error("insertElementAtIndex can only be called with index >= 0");let o=[...this.elements.slice(0,r),...t,...this.elements.slice(r)];Yt(o,X(t)),this.replaceAllElements(o)}insertElement=t=>{let r=t.frameId?this.getElementIndex(t.frameId):this.elements.length;this.insertElementAtIndex(t,r)};insertElements=t=>{let r=t[0].frameId?this.getElementIndex(t[0].frameId):this.elements.length;this.insertElementsAtIndex(t,r)};getElementIndex(t){return this.elements.findIndex(r=>r.id===t)}getContainerElement=t=>t&&t.containerId&&this.getElement(t.containerId)||null},Ct=ef});var Hm,Si,dc=y(()=>{"use strict";f();Hm=e=>{let t=e.map(o=>o[0]),r=e.map(o=>o[1]);return{width:Math.max(...t)-Math.min(...t),height:Math.max(...r)-Math.min(...r)}},Si=(e,t,r,o)=>{let n=r.map(u=>u[e]),i=Math.max(...n),a=Math.min(...n),l=i-a,s=l===0?1:t/l,c=1/0,d=r.map(u=>{let h=u[e]*s,E=[...u];return E[e]=h,h<c&&(c=h),E});if(!o||d.length===2)return d;let m=a-c;return d.map(u=>u.map((h,E)=>E===e?h+m:h))}});var Se,Ke,Ew,It,mc,br,Um,Pt,Fo,tf,rf,qk,xw,yw,ww,of,vw,pc,uc,hc,Kt=y(()=>{"use strict";f();W();dt();ln();Se=(e,t,r,o,n)=>[(e-r)*Math.cos(n)-(t-o)*Math.sin(n)+r,(e-r)*Math.sin(n)+(t-o)*Math.cos(n)+o],Ke=(e,t,r)=>Se(e[0],e[1],t[0],t[1],r),Ew=(e,t,r,o,n,i,a,l)=>{let s=Math.cos(o),c=Math.sin(o);return e.e&&e.w?t+=n+a:e.e?(t+=n*(1+s),r+=n*c,t+=a*(1-s),r+=a*-c):e.w&&(t+=n*(1-s),r+=n*-c,t+=a*(1+s),r+=a*c),e.n&&e.s?r+=i+l:e.n?(t+=i*c,r+=i*(1-s),t+=l*-c,r+=l*(1+s)):e.s&&(t+=i*-c,r+=i*(1+s),t+=l*c,r+=l*(1-s)),[t,r]},It=(e,t,r,o)=>{let n=r-e,i=o-t;return Math.hypot(n,i)},mc=(e,t)=>[(e[0]+t[0])/2,(e[1]+t[1])/2],br=(e,t=1)=>{if(e.length>=3){let[r,o]=[e[0],e[e.length-1]];return It(r[0],r[1],o[0],o[1])<=Tl/t}return!1},Um=(e,t,r)=>t[0]<=Math.max(e[0],r[0])&&t[0]>=Math.min(e[0],r[0])&&t[1]<=Math.max(e[1],r[1])&&t[1]>=Math.min(e[1],r[1]),Pt=(e,t,r)=>r?[Math.round(e/r)*r,Math.round(t/r)*r]:[e,t],Fo=(e,t)=>{if(t.roundness?.type===ct.PROPORTIONAL_RADIUS||t.roundness?.type===ct.LEGACY)return e*Cm;if(t.roundness?.type===ct.ADAPTIVE_RADIUS){let r=t.roundness?.value??Yy,o=r/Cm;return e<=o?e*Cm:r}return 0},tf=(e,t)=>{let r=Ne.generateElementShape(e,null);if(!r)return null;let o=Ci(r[0]),n=[0,0],i=0,a=1/0,l=null;for(;i<o.length;){let{op:s,data:c}=o[i];if(s==="move"&&(n=c),s==="bcurveTo"){let d=n,m=[c[0],c[1]],p=[c[2],c[3]],u=[c[4],c[5]],h=It(u[0],u[1],t[0],t[1]);h<a&&(a=h,l=[d,m,p,u]),n=u}i++}return l},rf=(e,t,r,o,n)=>{let i=(s,c)=>Math.pow(1-s,3)*o[c]+3*s*Math.pow(1-s,2)*r[c]+3*Math.pow(s,2)*(1-s)*t[c]+e[c]*Math.pow(s,3),a=i(n,0),l=i(n,1);return[a,l]},qk=(e,t)=>{let r=tf(e,t);if(!r)return[];let o=[],n=1;for(;n>0;){let i=rf(r[0],r[1],r[2],r[3],n);o.push([i[0],i[1]]),n-=.05}return o.length&&of(o.at(-1),t)&&o.push([t[0],t[1]]),o},xw=(e,t)=>{let r=[];r[0]=0;let o=qk(e,t),n=0,i=0;for(;n<o.length-1;){let a=It(o[n][0],o[n][1],o[n+1][0],o[n+1][1]);i+=a,r.push(i),n++}return r},yw=(e,t)=>xw(e,t).at(-1),ww=(e,t,r)=>{let o=xw(e,t),n=o.length-1,i=o.at(-1),a=r*i,l=0,s=n,c=0;for(;l<s;)c=Math.floor(l+(s-l)/2),o[c]<a?l=c+1:s=c;return o[c]>a&&c--,o[c]===a?c/n:1-(c+(a-o[c])/(o[c+1]-o[c]))/n},of=(e,t)=>e[0]===t[0]&&e[1]===t[1],vw=e=>Math.round(e/Math.PI*1e4)%5e3===0,pc=([e,t],[r,o])=>e<=r?t>=r:e>=r?o>=e:!1,uc=(e,t)=>{let r=Math.max(e[0],t[0]),o=Math.min(e[1],t[1]);return r<=o?[r,o]:null},hc=(e,t,r)=>e>=t&&e<=r});var Hn,gc,Gm,Vm,Pl,wa,nf,fc=y(()=>{"use strict";f();me();Hn=e=>e==="rectangle"||e==="iframe"||e==="embeddable"||e==="ellipse"||e==="diamond"||e==="line"||e==="freedraw",gc=e=>e!=="image"&&e!=="frame"&&e!=="magicframe",Gm=e=>e==="rectangle"||e==="iframe"||e==="embeddable"||e==="ellipse"||e==="diamond"||e==="freedraw"||e==="arrow"||e==="line",Vm=e=>e==="rectangle"||e==="iframe"||e==="embeddable"||e==="ellipse"||e==="diamond"||e==="arrow"||e==="line",Pl=e=>e==="rectangle"||e==="iframe"||e==="embeddable"||e==="arrow"||e==="line"||e==="diamond"||e==="image",wa=e=>e==="arrow",nf=(e,t)=>{let r=null;for(let o=e.length-1;o>=0;--o){let n=e[o];if(!n.isDeleted&&t(n)){r=n;break}}return r}});import{simplify as Jk}from"points-on-curve";function eM(e){let t=e.roughness,r=Math.max(e.width,e.height),o=Math.min(e.width,e.height);return o>=20&&r>=50||o>=15&&e.roundness&&Pl(e.type)||ce(e)&&r>=50?t:Math.min(t/(r<10?3:2),2.5)}var Qk,Cw,Kr,Tw,Sw,Iw,af=y(()=>{"use strict";f();xe();Kt();sn();G();W();me();fc();Qk=e=>[8,8+e],Cw=e=>[1.5,6+e];Kr=(e,t=!1)=>{let r={seed:e.seed,strokeLineDash:e.strokeStyle==="dashed"?Qk(e.strokeWidth):e.strokeStyle==="dotted"?Cw(e.strokeWidth):void 0,disableMultiStroke:e.strokeStyle!=="solid",strokeWidth:e.strokeStyle!=="solid"?e.strokeWidth+.5:e.strokeWidth,fillWeight:e.strokeWidth/2,hachureGap:e.strokeWidth*4,roughness:eM(e),stroke:e.strokeColor,preserveVertices:t||e.roughness<Wg.cartoonist};switch(e.type){case"rectangle":case"iframe":case"embeddable":case"diamond":case"ellipse":return r.fillStyle=e.fillStyle,r.fill=hr(e.backgroundColor)?void 0:e.backgroundColor,e.type==="ellipse"&&(r.curveFitting=1),r;case"line":case"freedraw":return br(e.points)&&(r.fillStyle=e.fillStyle,r.fill=e.backgroundColor==="transparent"?void 0:e.backgroundColor),r;case"arrow":return r;default:throw new Error(`Unimplemented type ${e.type}`)}},Tw=(e,t,r)=>rr(e)&&(t||Lt(e)&&r?.get(e.id)!==!0)&&hr(e.backgroundColor)&&hr(e.strokeColor)?{...e,roughness:0,backgroundColor:"#d3d3d3",fillStyle:"solid"}:go(e)?{...e,strokeColor:hr(e.strokeColor)?"#000000":e.strokeColor,backgroundColor:hr(e.backgroundColor)?"#f4f4f6":e.backgroundColor}:e,Sw=(e,t,r,o,n,i,a)=>{a=a||"transparent";let l=sf(e,t,r,o);if(l===null)return[];switch(o){case"dot":case"circle":case"circle_outline":{let[s,c,d]=l;return delete i.strokeLineDash,[n.circle(s,c,d,{...i,fill:o==="circle_outline"?a:e.strokeColor,fillStyle:"solid",stroke:e.strokeColor,roughness:Math.min(.5,i.roughness||0)})]}case"triangle":case"triangle_outline":{let[s,c,d,m,p,u]=l;return delete i.strokeLineDash,[n.polygon([[s,c],[d,m],[p,u],[s,c]],{...i,fill:o==="triangle_outline"?a:e.strokeColor,fillStyle:"solid",roughness:Math.min(1,i.roughness||0)})]}case"diamond":case"diamond_outline":{let[s,c,d,m,p,u,h,E]=l;return delete i.strokeLineDash,[n.polygon([[s,c],[d,m],[p,u],[h,E],[s,c]],{...i,fill:o==="diamond_outline"?a:e.strokeColor,fillStyle:"solid",roughness:Math.min(1,i.roughness||0)})]}case"bar":case"arrow":default:{let[s,c,d,m,p,u]=l;if(e.strokeStyle==="dotted"){let h=Cw(e.strokeWidth-1);i.strokeLineDash=[h[0],h[1]-1]}else delete i.strokeLineDash;return i.roughness=Math.min(1,i.roughness||0),[n.line(d,m,s,c,i),n.line(p,u,s,c,i)]}}},Iw=(e,t,{isExporting:r,canvasBackgroundColor:o,embedsValidationStatus:n})=>{switch(e.type){case"rectangle":case"iframe":case"embeddable":{let i;if(e.roundness){let a=e.width,l=e.height,s=Fo(Math.min(a,l),e);i=t.path(`M ${s} 0 L ${a-s} 0 Q ${a} 0, ${a} ${s} L ${a} ${l-s} Q ${a} ${l}, ${a-s} ${l} L ${s} ${l} Q 0 ${l}, 0 ${l-s} L 0 ${s} Q 0 0, ${s} 0`,Kr(Tw(e,r,n),!0))}else i=t.rectangle(0,0,e.width,e.height,Kr(Tw(e,r,n),!1));return i}case"diamond":{let i,[a,l,s,c,d,m,p,u]=lf(e);if(e.roundness){let h=Fo(Math.abs(a-p),e),E=Fo(Math.abs(c-l),e);i=t.path(`M ${a+h} ${l+E} L ${s-h} ${c-E}
3
+ C ${s} ${c}, ${s} ${c}, ${s-h} ${c+E}
4
+ L ${d+h} ${m-E}
5
+ C ${d} ${m}, ${d} ${m}, ${d-h} ${m-E}
6
+ L ${p+h} ${u+E}
7
+ C ${p} ${u}, ${p} ${u}, ${p+h} ${u-E}
8
+ L ${a-h} ${l+E}
9
+ C ${a} ${l}, ${a} ${l}, ${a+h} ${l+E}`,Kr(e,!0))}else i=t.polygon([[a,l],[s,c],[d,m],[p,u]],Kr(e));return i}case"ellipse":return t.ellipse(e.width/2,e.height/2,e.width,e.height,Kr(e));case"line":case"arrow":{let i,a=Kr(e),l=e.points.length?e.points:[[0,0]];if(e.roundness?i=[t.curve(l,a)]:a.fill?i=[t.polygon(l,a)]:i=[t.linearPath(l,a)],e.type==="arrow"){let{startArrowhead:s=null,endArrowhead:c="arrow"}=e;if(s!==null){let d=Sw(e,i,"start",s,t,a,o);i.push(...d)}if(c!==null){let d=Sw(e,i,"end",c,t,a,o);i.push(...d)}}return i}case"freedraw":{let i;if(Aw(e),br(e.points)){let a=Jk(e.points,.75);i=t.curve(a,{...Kr(e),stroke:"none"})}else i=null;return i}case"frame":case"magicframe":case"text":case"image":return null;default:return No(e,`generateElementShape(): Unimplemented type ${e?.type}`),null}}});var sr,kw,va,Dl,Mw,cf,Ii,tM,df,Wm,mf,Lw,pf,Pw,Ta,Dw,uf,tF,rF,oF,nF,iF,aF,lF,Sa=y(()=>{"use strict";f();sr=(e,t)=>[0,0,0,0,t,e,1,0],kw=(e,t)=>[0,0,0,0,t,e,0,0],va=(e=0,t=0)=>{let r=[0,0,0,0,0,0,0,0];if(t<0||t>7)throw new Error(`Expected \`index\` between 0 and 7, got \`${t}\``);return e!==0&&(r[t]=e),r},Dl=e=>[e[0],e[1],e[2],e[3],-e[4],-e[5],-e[6],-e[7]],Mw=(e,t)=>uf(t)?[e[0]+t,e[1],e[2],e[3],e[4],e[5],e[6],e[7]]:[e[0]+t[0],e[1]+t[1],e[2]+t[2],e[3]+t[3],e[4]+t[4],e[5]+t[5],e[6]+t[6],e[7]+t[7]],cf=(e,t)=>uf(t)?[e[0]-t,e[1],e[2],e[3],e[4],e[5],e[6],e[7]]:[e[0]-t[0],e[1]-t[1],e[2]-t[2],e[3]-t[3],e[4]-t[4],e[5]-t[5],e[6]-t[6],e[7]-t[7]],Ii=(e,t)=>uf(t)?[e[0]*t,e[1]*t,e[2]*t,e[3]*t,e[4]*t,e[5]*t,e[6]*t,e[7]*t]:[tM(e,t),t[1]*e[0]+t[0]*e[1]-t[4]*e[2]+t[5]*e[3]+t[2]*e[4]-t[3]*e[5]-t[7]*e[6]-t[6]*e[7],t[2]*e[0]+t[0]*e[2]-t[6]*e[3]+t[3]*e[6],t[3]*e[0]+t[6]*e[2]+t[0]*e[3]-t[2]*e[6],t[4]*e[0]+t[2]*e[1]-t[1]*e[2]+t[7]*e[3]+t[0]*e[4]+t[6]*e[5]-t[5]*e[6]+t[3]*e[7],t[5]*e[0]-t[3]*e[1]+t[7]*e[2]+t[1]*e[3]-t[6]*e[4]+t[0]*e[5]+t[4]*e[6]+t[2]*e[7],t[6]*e[0]+t[3]*e[2]-t[2]*e[3]+t[0]*e[6],t[7]*e[0]+t[6]*e[1]+t[5]*e[2]+t[4]*e[3]+t[3]*e[4]+t[2]*e[5]+t[1]*e[6]+t[0]*e[7]],tM=(e,t)=>t[0]*e[0]+t[2]*e[2]+t[3]*e[3]-t[6]*e[6],df=(e,t)=>[t[0]*e[0],t[1]*e[0]+t[0]*e[1],t[2]*e[0]+t[0]*e[2],t[3]*e[0]+t[0]*e[3],t[4]*e[0]+t[2]*e[1]-t[1]*e[2]+t[0]*e[4],t[5]*e[0]-t[3]*e[1]+t[1]*e[3]+t[0]*e[5],t[6]*e[0]+t[3]*e[2]-t[2]*e[3]+t[0]*e[6],t[7]*e[0]+t[6]*e[1]+t[5]*e[2]+t[4]*e[3]+t[3]*e[4]+t[2]*e[5]+t[1]*e[6]],Wm=(e,t)=>[mf(e,t),e[1]*t[7]+e[4]*t[5]-e[5]*t[4]+e[7]*t[1],e[2]*t[7]-e[4]*t[6]+e[6]*t[4]+e[7]*t[2],e[3]*t[7]+e[5]*t[6]-e[6]*t[5]+e[7]*t[3],e[4]*t[7]+e[7]*t[4],e[5]*t[7]+e[7]*t[5],e[6]*t[7]+e[7]*t[6],e[7]*t[7]],mf=(e,t)=>e[0]*t[7]+e[1]*t[6]+e[2]*t[5]+e[3]*t[4]+e[4]*t[3]+e[5]*t[2]+e[6]*t[1]+e[7]*t[0],Lw=(e,t)=>[t[0]*e[0]+t[2]*e[2]+t[3]*e[3]-t[6]*e[6],t[1]*e[0]+t[0]*e[1]-t[4]*e[2]+t[5]*e[3]+t[2]*e[4]-t[3]*e[5]-t[7]*e[6]-t[6]*e[7],t[2]*e[0]+t[0]*e[2]-t[6]*e[3]+t[3]*e[6],t[3]*e[0]+t[6]*e[2]+t[0]*e[3]-t[2]*e[6],t[4]*e[0]+t[7]*e[3]+t[0]*e[4]+t[3]*e[7],t[5]*e[0]+t[7]*e[2]+t[0]*e[5]+t[2]*e[7],t[6]*e[0]+t[0]*e[6],t[7]*e[0]+t[0]*e[7]],pf=e=>Math.sqrt(Math.abs(e[0]*e[0]-e[2]*e[2]-e[3]*e[3]+e[6]*e[6])),Pw=e=>Math.sqrt(Math.abs(e[7]*e[7]-e[5]*e[5]-e[4]*e[4]+e[1]*e[1])),Ta=e=>{let t=pf(e);if(t===0||t===1)return e;let r=e[6]<0?-1:1;return Ii(e,r/t)},Dw=e=>{let t=Pw(e);return t===0||t===1?e:Ii(e,1/t)},uf=e=>typeof e=="number",tF=va(1,1),rF=va(1,2),oF=va(1,3),nF=va(1,4),iF=va(1,5),aF=va(1,6),lF=va(1,7)});var Ym,_l,_w,Rw,Nw,hf=y(()=>{"use strict";f();Sa();Ym=(e,t,r)=>Ta([0,r,e,t,0,0,0,0]),_l=(e,t)=>Ta(Wm(t,e)),_w=(e,t)=>Lw(e,t),Rw=(e,t)=>_w(_l(e,t),t),Nw=e=>Math.sign(e[1])});var Ca,Ia,Bw,Fw,gf,Ai,zw=y(()=>{"use strict";f();Sa();hf();Sa();Ca=([e,t])=>[0,0,0,0,t,e,1,0],Ia=e=>[e[5],e[4]],Bw=e=>[0,0,0,0,Math.abs(e[4]),Math.abs(e[5]),1,0],Fw=(e,t)=>Ta(df(e,t)),gf=(e,t)=>pf(Wm(e,t)),Ai=(e,t)=>mf(e,t)});var ff,Hw,bf=y(()=>{"use strict";f();Sa();ff=e=>[0,0,0,0,e[4],e[5],0,0],Hw=(e,t)=>Dw([0,0,0,0,t[4]-e[4],t[5]-e[5],0,0])});var Ef,Gw,Vw,Ww,zo,Yw=y(()=>{"use strict";f();Sa();bf();Ef=(e,t)=>Mw(Ii(e,Math.sin(t/2)),Math.cos(t/2)),Gw=e=>[1,0,0,0,-(.5*e[5]),.5*e[4],0,0],Vw=(e,t)=>{let r=.5*t;return[1,0,0,0,r*e[4],r*e[5],0,0]},Ww=(e,t)=>Ii(t,e),zo=(e,t)=>Ta(Ii(Ii(e,t),Dl(e)))});var Rl,nM,Nl,cn,iM,Kw,aM,wt,lM,xf,sM,$w,cM,Aa,yf,dM,mM,wf,Xw,vf,Zw,pM,jw,qw,Km=y(()=>{"use strict";f();Kt();Rl=1e-4,nM=e=>{let t=e[0],r=e[e.length-1];return t[0]===r[0]&&t[1]===r[1]},Nl=e=>nM(e)?e:[...e,e[0]],cn=e=>e*180/Math.PI,iM=e=>e/180*Math.PI,Kw=(e,t)=>[e[0]*Math.cos(t)-e[1]*Math.sin(t),e[0]*Math.sin(t)+e[1]*Math.cos(t)],aM=e=>e[0]===0&&e[1]===0,wt=(e,t,r)=>{let o=iM(t);return!r||aM(r)?Kw(e,o):Kw(e.map((n,i)=>n-r[i]),o).map((n,i)=>n+r[i])},lM=e=>[-e[0],-e[1]],xf=(e,t)=>[e[0]+t[0],e[1]+t[1]],sM=(e,t)=>It(...e,...t),$w=(e,t,r)=>{let o=xf(e,lM(t));return wt(o,-cn(r))},cM=(e,t)=>{let[r,o]=e,[[n,i],[a,l]]=t,s=r-n,c=o-i,d=a-n,m=l-i,p=s*d+c*m,u=d*d+m*m,h=-1;u!==0&&(h=p/u);let E,x;h<0?(E=n,x=i):h>1?(E=a,x=l):(E=n+h*d,x=i+h*m);let T=r-E,v=o-x;return Math.sqrt(T*T+v*v)},Aa=(e,t,r=Rl)=>{let o=cM(e,t);return o===0?!0:o<r},yf=(e,t,r=Rl)=>t.some(o=>Aa(e,o,r)),dM=e=>{let[t,r,o,n]=e;return(i,a)=>Math.pow(1-i,3)*n[a]+3*i*Math.pow(1-i,2)*o[a]+3*Math.pow(i,2)*(1-i)*r[a]+t[a]*Math.pow(i,3)},mM=(e,t=10)=>{let r=dM(e),o=[r(0,0),r(0,1)],n=[],i=0,a=1/t;for(let l=0;l<t;l++)if(i+=a,i<=1){let s=[r(i,0),r(i,1)];n.push([o,s]),o=s}return n},wf=(e,t,r=Rl)=>yf(e,mM(t),r),Xw=(e,t,r=Rl)=>t.some(o=>wf(e,o,r)),vf=(e,t)=>{let r=e[0],o=e[1],n=!1;for(let i=0,a=t.length-1;i<t.length;a=i++){let l=t[i][0],s=t[i][1],c=t[a][0],d=t[a][1];(s>o&&d<=o||s<=o&&d>o)&&r<(c-l)*(o-s)/(d-s)+l&&(n=!n)}return n},Zw=(e,t,r=Rl)=>{let o=!1,n=Nl(t);for(let i=0,a=n.length-1;i<a;i++)if(Aa(e,[n[i],n[i+1]],r)){o=!0;break}return o},pM=(e,t)=>{let{angle:r,halfWidth:o,halfHeight:n,center:i}=t,a=o,l=n,[s,c]=$w(e,i,r),d=Math.abs(s),m=Math.abs(c),p=.707,u=.707;for(let x=0;x<3;x++){let T=a*p,v=l*u,w=(a*a-l*l)*p**3/a,I=(l*l-a*a)*u**3/l,L=T-w,A=v-I,M=d-w,D=m-I,O=Math.hypot(A,L),R=Math.hypot(D,M);p=Math.min(1,Math.max(0,(M*O/R+w)/a)),u=Math.min(1,Math.max(0,(D*O/R+I)/l));let B=Math.hypot(u,p);p/=B,u/=B}let[h,E]=[a*p*Math.sign(s),l*u*Math.sign(c)];return sM([s,c],[h,E])},jw=(e,t,r=Rl)=>pM(e,t)<=r,qw=(e,t)=>{let{center:r,angle:o,halfWidth:n,halfHeight:i}=t,[a,l]=$w(e,r,o);return a/n*(a/n)+l/i*(l/i)<=1}});var Ec,Ol,$m=y(()=>{"use strict";f();Km();Ec=(e,t,r=0)=>{switch(t.type){case"polygon":return Zw(e,t.data,r);case"ellipse":return jw(e,t.data,r);case"line":return Aa(e,t.data,r);case"polyline":return yf(e,t.data,r);case"curve":return wf(e,t.data,r);case"polycurve":return Xw(e,t.data,r);default:throw Error(`shape ${t} is not implemented`)}},Ol=(e,t)=>{switch(t.type){case"polygon":return vf(e,t.data);case"line":return!1;case"curve":return!1;case"ellipse":return qw(e,t.data);case"polyline":{let r=Nl(t.data.flat());return vf(e,r)}case"polycurve":return!1;default:throw Error(`shape ${t} is not implemented`)}}});var Ee,C,Bl,Xm,Fl,ka,be=y(()=>{"use strict";f();W();Ee={EQUAL:"Equal",MINUS:"Minus",NUM_ADD:"NumpadAdd",NUM_SUBTRACT:"NumpadSubtract",NUM_ZERO:"Numpad0",BRACKET_RIGHT:"BracketRight",BRACKET_LEFT:"BracketLeft",ONE:"Digit1",TWO:"Digit2",THREE:"Digit3",NINE:"Digit9",QUOTE:"Quote",ZERO:"Digit0",SLASH:"Slash",C:"KeyC",D:"KeyD",H:"KeyH",V:"KeyV",Z:"KeyZ",R:"KeyR",S:"KeyS"},C={ARROW_DOWN:"ArrowDown",ARROW_LEFT:"ArrowLeft",ARROW_RIGHT:"ArrowRight",ARROW_UP:"ArrowUp",PAGE_UP:"PageUp",PAGE_DOWN:"PageDown",BACKSPACE:"Backspace",ALT:"Alt",CTRL_OR_CMD:ur?"metaKey":"ctrlKey",DELETE:"Delete",ENTER:"Enter",ESCAPE:"Escape",QUESTION_MARK:"?",SPACE:" ",TAB:"Tab",CHEVRON_LEFT:"<",CHEVRON_RIGHT:">",PERIOD:".",COMMA:",",SUBTRACT:"-",SLASH:"/",A:"a",C:"c",D:"d",E:"e",F:"f",G:"g",H:"h",I:"i",L:"l",O:"o",P:"p",Q:"q",R:"r",S:"s",T:"t",V:"v",X:"x",Y:"y",Z:"z",K:"k",W:"w",0:"0",1:"1",2:"2",3:"3",4:"4",5:"5",6:"6",7:"7",8:"8",9:"9"},Bl=e=>e===C.ARROW_LEFT||e===C.ARROW_RIGHT||e===C.ARROW_DOWN||e===C.ARROW_UP,Xm=e=>e.altKey,Fl=e=>e.shiftKey,ka=e=>e.shiftKey});var r2,mn,uM,dn,Jw,yc,hM,wc,zl,Tf,Sf,vc,gM,pn,fM,$r,bM,EM,xM,Qw,o2,yM,Zm,n2,i2,e2,Jm,t2,Qm,xc,a2,Tc,wM,vM,TM,SM,CM,Cf,If,Af,IM,AM,kM,MM,l2,LM,PM,DM,_M,RM,NM,s2,jm,qm,ki,Mi,Eo=y(()=>{"use strict";f();Sa();zw();bf();hf();Yw();dt();$m();qe();me();Ye();vi();or();G();be();mt();r2=e=>!e[C.CTRL_OR_CMD],mn=e=>e.isBindingEnabled,uM=(e,t)=>{let r=[];return t.forEach(o=>{let n=e.getNonDeletedElement(o);n!=null&&r.push(n)}),r},dn=(e,t,r,o)=>{let n=new Set,i=new Set;Jw(e,t,r,"start",n,i,o),Jw(e,r,t,"end",n,i,o);let a=Array.from(i).filter(l=>!n.has(l));uM(Ct.getScene(e),a).forEach(l=>{H(l,{boundElements:l.boundElements?.filter(s=>s.type!=="arrow"||s.id!==e.id)})})},Jw=(e,t,r,o,n,i,a)=>{if(t!=="keep")if(t!=null)(r==null||(r==="keep"?!Tf(e,t,o):o==="start"||r.id!==t.id))&&(zl(e,t,o,a),n.add(t.id));else{let l=gM(e,o);l!=null&&i.add(l)}},yc=(e,t)=>{e.forEach(r=>{Wt(r)?dn(r,Zm(r,"start",t),Zm(r,"end",t),t.scene.getNonDeletedElementsMap()):zn(r)&&hM(r,t.scene.getNonDeletedElementsMap(),t)})},hM=(e,t,r)=>{i2(e,r).forEach(([o,n])=>dn(o,n==="end"?"keep":e,n==="start"?"keep":e,t))},wc=(e,t,r,o)=>{t.startBoundElement!=null&&zl(e,t.startBoundElement,"start",o.scene.getNonDeletedElementsMap());let n=pn(r,o);n!=null&&!Tf(e,n,"end")&&zl(e,n,"end",o.scene.getNonDeletedElementsMap())},zl=(e,t,r,o)=>{H(e,{[r==="start"?"startBinding":"endBinding"]:{elementId:t.id,...fM(e,t,r,o)}}),X(t.boundElements||[]).has(e.id)||H(t,{boundElements:(t.boundElements||[]).concat({id:e.id,type:"arrow"})})},Tf=(e,t,r)=>{let o=e[r==="start"?"endBinding":"startBinding"];return Sf(e,o?.elementId,t)},Sf=(e,t,r)=>t===r.id&&e.points.length<3,vc=(e,t)=>{e.forEach(r=>{Wt(r)&&(r.startBinding!==null&&r.endBinding!==null?dn(r,null,null,t):dn(r,r.startBinding?"keep":null,r.endBinding?"keep":null,t))})},gM=(e,t)=>{let r=t==="start"?"startBinding":"endBinding",o=e[r];return o==null?null:(H(e,{[r]:null}),o.elementId)},pn=(e,t)=>nf(t.scene.getNonDeletedElements(),o=>zn(o,!1)&&a2(o,e,t)),fM=(e,t,r,o)=>{let n=r==="start"?-1:1,i=n===-1?0:e.points.length-1,a=i-n,l=Z.getPointAtIndexGlobalCoordinates(e,i,o),s=Z.getPointAtIndexGlobalCoordinates(e,a,o);return{focus:IM(t,s,l,o),gap:Math.max(1,wM(t,l,o))}},$r=(e,t,r)=>{let{newSize:o,simultaneouslyUpdated:n}=r??{},i=EM(n);zn(e)&&jm(t,e,a=>{if(!ce(a)||a.isDeleted||!bM(a,e))return;let l={startBinding:Qw(e,a.startBinding,o),endBinding:Qw(e,a.endBinding,o)};if(i.has(a.id)){H(a,l);return}qm(t,a,(c,d)=>{c&&zn(c)&&(d==="startBinding"||d==="endBinding")&&xM(a,d,l[d],c,t)});let s=ue(a,t);s&&!s.isDeleted&&Ma(a,t,!1)})},bM=(e,t)=>e.startBinding?.elementId===t.id||e.endBinding?.elementId===t.id,EM=e=>new Set((e||[]).map(t=>t.id)),xM=(e,t,r,o,n)=>{if(r==null||r.elementId!==o.id&&e.points.length>2)return;let i=t==="startBinding"?-1:1,a=i===-1?0:e.points.length-1,l=a-i,s=Z.getPointAtIndexGlobalCoordinates(e,l,n),c=AM(o,r.focus,s,n),d;if(r.gap===0)d=c;else{let m=kM(o,s,c,r.gap,n);m.length===0?d=c:d=m[0]}Z.movePoints(e,[{index:a,point:Z.pointFromAbsoluteCoords(e,d,n)}],{[t]:r})},Qw=(e,t,r)=>{if(t==null||r==null)return t;let{gap:o,focus:n,elementId:i}=t,{width:a,height:l}=r,{width:s,height:c}=e,d=Math.max(1,Math.min(Tc(e,a,l),o*(a<l?a/s:l/c)));return{elementId:i,gap:d,focus:n}},o2=(e,t)=>{let r=new Set(e.map(({id:o})=>o));return e.flatMap(o=>Wt(o,!1)?yM(o,t).filter(n=>!r.has(n.id)):zn(o,!1)?i2(o,t).filter(n=>!r.has(n[0].id)):[])},yM=(e,t)=>[Zm(e,"start",t),Zm(e,"end",t)].filter(r=>r!=null),Zm=(e,t,r)=>pn(n2(e,t,r.scene.getNonDeletedElementsMap()),r),n2=(e,t,r)=>{let o=t==="start"?0:-1;return Ro(Z.getPointAtIndexGlobalCoordinates(e,o,r))},i2=(e,t)=>{let r=Ct.getScene(e);return r.getNonDeletedElements().map(o=>{if(!Wt(o,!1))return null;let n=e2(o,"start",e,r.getNonDeletedElementsMap(),t),i=e2(o,"end",e,r.getNonDeletedElementsMap(),t);return!n&&!i?null:[o,n&&i?"both":n?"start":"end",e]}).filter(o=>o!=null)},e2=(e,t,r,o,n)=>e[t==="start"?"startBinding":"endBinding"]==null&&!Tf(e,r,t)&&a2(r,n2(e,t,o),n),Jm=(e,t,r,o)=>{let n=new Set,i=new Set,a=o==="duplicatesServeAsOld";t.forEach(l=>{let{boundElements:s}=l;if(s!=null&&s.length>0&&(s.forEach(c=>{a&&!r.has(c.id)&&n.add(c.id)}),i.add(r.get(l.id))),Wt(l)){if(l.startBinding!=null){let{elementId:c}=l.startBinding;a&&!r.has(c)&&i.add(c)}if(l.endBinding!=null){let{elementId:c}=l.endBinding;a&&!r.has(c)&&i.add(c)}(l.startBinding!=null||l.endBinding!=null)&&n.add(r.get(l.id))}}),e.filter(({id:l})=>n.has(l)).forEach(l=>{let{startBinding:s,endBinding:c}=l;H(l,{startBinding:t2(s,r),endBinding:t2(c,r)})}),e.filter(({id:l})=>i.has(l)).forEach(l=>{let{boundElements:s}=l;s!=null&&s.length>0&&H(l,{boundElements:s.map(c=>r.has(c.id)?{id:r.get(c.id),type:c.type}:c)})})},t2=(e,t)=>{if(e==null)return null;let{elementId:r,focus:o,gap:n}=e;return{focus:o,gap:n,elementId:t.get(r)??r}},Qm=(e,t)=>{let r=X(e);for(let o of t)ki.unbindAffected(r,o,H),Mi.unbindAffected(r,o,H)},xc=(e,t,r=[])=>{if(!e)return null;let o=e.filter(n=>!t.has(n.id));return o.push(...r.map(n=>({id:n.id,type:n.type}))),o},a2=(e,{x:t,y:r},o)=>{let n=Tc(e,e.width,e.height),i=o.getElementShape(e);return Ec([t,r],i,n)},Tc=(e,t,r)=>{let n=(e.type==="diamond"?1/Math.sqrt(2):1)*Math.min(t,r);return Math.max(16,Math.min(.25*n,32))},wM=(e,t,r)=>{switch(e.type){case"rectangle":case"image":case"text":case"iframe":case"embeddable":case"frame":case"magicframe":return vM(e,t,r);case"diamond":return TM(e,t,r);case"ellipse":return SM(e,t,r)}},vM=(e,t,r)=>{let[,o,n,i]=Cf(e,t,r);return Math.max(Ai(o,Ym(0,1,-i)),Ai(o,Ym(1,0,-n)))},TM=(e,t,r)=>{let[,o,n,i]=Cf(e,t,r),a=Ym(i,n,-i*n);return Ai(o,a)},SM=(e,t,r)=>{let[o,n]=CM(e,t,r);return-Nw(n)*Ai(o,n)},CM=(e,t,r)=>{let[,o,n,i]=Cf(e,t,r),[a,l]=Ia(o),s=.707,c=.707,d=n,m=i;[0,1,2,3].forEach(h=>{let E=d*s,x=m*c,T=(d*d-m*m)*s**3/d,v=(m*m-d*d)*c**3/m,w=E-T,I=x-v,L=a-T,A=l-v,M=Math.hypot(I,w),D=Math.hypot(A,L);s=Math.min(1,Math.max(0,(L*M/D+T)/d)),c=Math.min(1,Math.max(0,(A*M/D+v)/m));let O=Math.hypot(c,s);s/=O,c/=O});let p=sr(d*s,m*c),u=Rw(o,p);return[o,u]},Cf=(e,t,r)=>{let o=Ca(t),[n,i,a,l]=oe(e,r),s=Af(n,i,a,l),c=Ef(s,e.angle),d=zo(c,o),m=cf(d,ff(s)),p=Bw(m),u=kw(e.x,e.y),h=cf(d,u),E=(a-n)/2,x=(l-i)/2;return[h,p,E,x]},If=(e,t)=>{let[r,o,n,i]=oe(e,t),a=Af(r,o,n,i),l=Ef(a,e.angle),s=Dl(Gw(ff(a)));return Ww(l,s)},Af=(e,t,r,o)=>sr((e+r)/2,(t+o)/2),IM=(e,t,r,o)=>{let n=If(e,o),i=zo(n,Ca(t)),a=zo(n,Ca(r)),l=_l(i,a),s=e.height/e.width,c=e.width/2,d=e.height/2,m=l[2],p=l[3],u=l[1],h=Math.abs(p),E=Math.abs(m),x;switch(e.type){case"rectangle":case"image":case"text":case"iframe":case"embeddable":case"frame":case"magicframe":x=u/(c*(E+s*h));break;case"diamond":x=h<E?u/(E*c):u/(h*d);break;case"ellipse":x=u/(c*Math.sqrt(m**2+s**2*p**2));break}return x||0},AM=(e,t,r,o)=>{if(t===0){let[s,c,d,m]=oe(e,o),p=Af(s,c,d,m);return Ia(p)}let n=If(e,o),i=zo(n,Ca(r)),a=Dl(n),l;switch(e.type){case"rectangle":case"image":case"text":case"diamond":case"iframe":case"embeddable":case"frame":case"magicframe":l=NM(e,t,i);break;case"ellipse":l=RM(e,t,i);break}return Ia(zo(a,l))},kM=(e,t,r,o=0,n)=>{let i=If(e,n),a=zo(i,Ca(t)),l=zo(i,Ca(r)),s=_l(a,l),c=Dl(i);return MM(e,s,a,o).map(m=>Ia(zo(c,m)))},MM=(e,t,r,o=0)=>{let n;switch(e.type){case"rectangle":case"image":case"text":case"diamond":case"iframe":case"embeddable":case"frame":case"magicframe":let a=l2(e);n=a.flatMap((l,s)=>{let c=[l,a[(s+1)%4]];return LM(t,PM(c,o))}).concat(a.flatMap(l=>_M(l,o,t)));break;case"ellipse":n=DM(e,o,t);break}if(n.length<2)return[];let i=n.sort((a,l)=>gf(a,r)-gf(l,r));return[i[0],i[i.length-1]]},l2=(e,t=1)=>{let r=t*e.width/2,o=t*e.height/2;switch(e.type){case"rectangle":case"image":case"text":case"iframe":case"embeddable":case"frame":case"magicframe":return[sr(r,o),sr(r,-o),sr(-r,-o),sr(-r,o)];case"diamond":return[sr(0,o),sr(r,0),sr(0,-o),sr(-r,0)]}},LM=(e,t)=>{let[r,o]=t,n=Ai(r,e),i=Ai(o,e);return n*i>=0?[]:[Fw(e,_l(r,o))]},PM=(e,t)=>{let[r,o]=e,n=Vw(Hw(r,o),t);return[zo(n,r),zo(n,o)]},DM=(e,t,r)=>{let o=e.width/2+t,n=e.height/2+t,i=r[2],a=r[3],l=r[1],s=o*o*i*i+n*n*a*a,c=s-l*l;if(s===0||c<=0)return[];let d=Math.sqrt(c),m=-o*o*i*l,p=-n*n*a*l;return[sr((m+o*n*a*d)/s,(p-o*n*i*d)/s),sr((m-o*n*a*d)/s,(p+o*n*i*d)/s)]},_M=(e,t,r)=>{if(t===0)return Ai(r,e)===0?[e]:[];let o=r[2],n=r[3],i=r[1],[a,l]=Ia(e),s=t,c=o*o+n*n,d=s*s*c-(o*a+n*l+i)**2;if(c===0||d<=0)return[];let m=Math.sqrt(d),p=a*n*n-l*o*n-o*i,u=l*o*o-a*o*n-n*i;return[sr((p+n*m)/c,(u-o*m)/c),sr((p-n*m)/c,(u+o*m)/c)]},RM=(e,t,r)=>{let o=Math.abs(t),n=e.width*o/2,i=e.height*o/2,a=Math.sign(t),[l,s]=Ia(r),c=s===0?1e-4:s,d=l**2*i**2+c**2*n**2,m=(-l*i**2+a*c*Math.sqrt(Math.max(0,d-n**2*i**2)))/d,p=(-m*l-1)/c;p===0&&(p=(Object.is(p,-0)?-1:1)*.01);let u=-(n**2*m)/(p**2*i**2+m**2*n**2);return sr(u,(-m*u-1)/p)},NM=(e,t,r)=>{let o=Math.abs(t),n=Math.sign(t),i=l2(e,o),a=0,l=null;return i.forEach(s=>{let c=n*_l(r,s)[1];c>a&&(a=c,l=s)}),l},s2=new Set(["boundElements","frameId","containerId","startBinding","endBinding"]),jm=(e,t,r)=>{zn(t)&&(t.boundElements?.slice()??[]).forEach(({id:n})=>{r(e.get(n),"boundElements",n)})},qm=(e,t,r)=>{if(t.frameId){let o=t.frameId;r(e.get(o),"frameId",o)}if(Pe(t)){let o=t.containerId;r(e.get(o),"containerId",o)}if(Ce(t)){if(t.startBinding){let o=t.startBinding.elementId;r(e.get(o),"startBinding",o)}if(t.endBinding){let o=t.endBinding.elementId;r(e.get(o),"endBinding",o)}}},ki=class{static unbindAffected(t,r,o){r&&qm(t,r,n=>{!n||n.isDeleted||jm(t,n,(i,a,l)=>{l===r.id&&o(n,{boundElements:xc(n.boundElements,new Set([l]))})})})}static rebindAffected=(t,r,o)=>{!r||r.isDeleted||qm(t,r,(n,i)=>{if(!n||n.isDeleted){o(r,{[i]:null});return}i!=="frameId"&&(n.boundElements?.find(a=>a.id===r.id)||(Ce(r)&&o(n,{boundElements:xc(n.boundElements,new Set,new Array(r))}),V(r)&&(n.boundElements?.find(a=>a.type==="text")?o(r,{[i]:null}):o(n,{boundElements:xc(n.boundElements,new Set,new Array(r))}))))})}},Mi=class{static unbindAffected(t,r,o){r&&jm(t,r,n=>{!n||n.isDeleted||qm(t,n,(i,a,l)=>{l===r.id&&o(n,{[a]:null})})})}static rebindAffected=(t,r,o)=>{!r||r.isDeleted||jm(t,r,(n,i,a)=>{if(!n||n.isDeleted){o(r,{boundElements:xc(r.boundElements,new Set([a]))});return}V(n)&&((r.boundElements?.slice()??[]).reverse().find(s=>s.type==="text")?.id===n.id?n.containerId!==r.id&&o(n,{containerId:r.id}):(n.containerId!==null&&o(n,{containerId:null}),o(r,{boundElements:xc(r.boundElements,new Set([n.id]))})))})}}});var Un,Z,OM,or=y(()=>{"use strict";f();Kt();xe();dt();Ye();Eo();G();me();be();mt();W();ln();Un={version:null,points:[],zoom:null},Z=class e{elementId;selectedPointsIndices;pointerDownState;isDragging;lastUncommittedPoint;pointerOffset;startBindingElement;endBindingElement;hoverPointIndex;segmentMidPointHoveredCoords;constructor(t){this.elementId=t.id,e.normalizePoints(t),this.selectedPointsIndices=null,this.lastUncommittedPoint=null,this.isDragging=!1,this.pointerOffset={x:0,y:0},this.startBindingElement="keep",this.endBindingElement="keep",this.pointerDownState={prevSelectedPointsIndices:null,lastClickedPoint:-1,origin:null,segmentMidpoint:{value:null,index:null,added:!1}},this.hoverPointIndex=-1,this.segmentMidPointHoveredCoords=null}static POINT_HANDLE_SIZE=10;static getElement(t,r){let o=r.get(t);return o||null}static handleBoxSelection(t,r,o,n){if(!r.editingLinearElement||r.draggingElement?.type!=="selection")return!1;let{editingLinearElement:i}=r,{selectedPointsIndices:a,elementId:l}=i,s=e.getElement(l,n);if(!s)return!1;let[c,d,m,p]=oe(r.draggingElement,n),h=e.getPointsGlobalCoordinates(s,n).reduce((E,x,T)=>((x[0]>=c&&x[0]<=m&&x[1]>=d&&x[1]<=p||t.shiftKey&&a?.includes(T))&&E.push(T),E),[]);o({editingLinearElement:{...i,selectedPointsIndices:h.length?h:null}})}static handlePointDragging(t,r,o,n,i,a,l){if(!a)return!1;let{selectedPointsIndices:s,elementId:c}=a,d=e.getElement(c,l);if(!d)return!1;let m=d.points[a.pointerDownState.lastClickedPoint];if(s&&m){if(ka(t)&&s.length===1&&d.points.length>1){let u=s[0],h=d.points[u===0?1:u-1],[E,x]=e._getShiftLockedDelta(d,l,h,[o,n],t[C.CTRL_OR_CMD]?null:r.gridSize);e.movePoints(d,[{index:u,point:[E+h[0],x+h[1]],isDragging:u===a.pointerDownState.lastClickedPoint}])}else{let u=e.createPointAt(d,l,o-a.pointerOffset.x,n-a.pointerOffset.y,t[C.CTRL_OR_CMD]?null:r.gridSize),h=u[0]-m[0],E=u[1]-m[1];e.movePoints(d,s.map(x=>{let T=x===a.pointerDownState.lastClickedPoint?e.createPointAt(d,l,o-a.pointerOffset.x,n-a.pointerOffset.y,t[C.CTRL_OR_CMD]?null:r.gridSize):[d.points[x][0]+h,d.points[x][1]+E];return{index:x,point:T,isDragging:x===a.pointerDownState.lastClickedPoint}}))}if(ue(d,l)&&Ma(d,l,!1),Wt(d,!1)){let u=[];s[0]===0&&u.push(Ro(e.getPointGlobalCoordinates(d,d.points[0],l)));let E=s[s.length-1];E===d.points.length-1&&u.push(Ro(e.getPointGlobalCoordinates(d,d.points[E],l))),u.length&&i(d,u)}return!0}return!1}static handlePointerUp(t,r,o,n){let i=n.scene.getNonDeletedElementsMap(),{elementId:a,selectedPointsIndices:l,isDragging:s,pointerDownState:c}=r,d=e.getElement(a,i);if(!d)return r;let m={};if(s&&l){for(let p of l)if(p===0||p===d.points.length-1){br(d.points,o.zoom.value)&&e.movePoints(d,[{index:p,point:p===0?d.points[d.points.length-1]:d.points[0]}]);let u=mn(o)?pn(Ro(e.getPointAtIndexGlobalCoordinates(d,p,i)),n):null;m[p===0?"startBindingElement":"endBindingElement"]=u}}return{...r,...m,selectedPointsIndices:s||t.shiftKey?!s&&t.shiftKey&&c.prevSelectedPointsIndices?.includes(c.lastClickedPoint)?l&&l.filter(p=>p!==c.lastClickedPoint):l:l?.includes(c.lastClickedPoint)?[c.lastClickedPoint]:l,isDragging:!1,pointerOffset:{x:0,y:0}}}static getEditorMidPoints=(t,r,o)=>{let n=ue(t,r);return!o.editingLinearElement&&t.points.length>2&&!n?[]:(Un.version===t.version&&Un.zoom===o.zoom.value||e.updateEditorMidPointsCache(t,r,o),Un.points)};static updateEditorMidPointsCache=(t,r,o)=>{let n=e.getPointsGlobalCoordinates(t,r),i=0,a=[];for(;i<n.length-1;){if(e.isSegmentTooShort(t,t.points[i],t.points[i+1],o.zoom)){a.push(null),i++;continue}let l=e.getSegmentMidPoint(t,n[i],n[i+1],i+1,r);a.push(l),i++}Un.points=a,Un.version=t.version,Un.zoom=o.zoom.value};static getSegmentMidpointHitCoords=(t,r,o,n)=>{let{elementId:i}=t,a=e.getElement(i,n);if(!a||e.getPointIndexUnderCursor(a,n,o.zoom,r.x,r.y)>=0||e.getPointsGlobalCoordinates(a,n).length>=3&&!o.editingLinearElement)return null;let c=e.POINT_HANDLE_SIZE/o.zoom.value,d=t.segmentMidPointHoveredCoords;if(d&&It(d[0],d[1],r.x,r.y)<=c)return d;let m=0,p=e.getEditorMidPoints(a,n,o);for(;m<p.length;){if(p[m]!==null&&It(p[m][0],p[m][1],r.x,r.y)<=c)return p[m];m++}return null};static isSegmentTooShort(t,r,o,n){let i=It(r[0],r[1],o[0],o[1]);return t.points.length>2&&t.roundness&&(i=yw(t,o)),i*n.value<e.POINT_HANDLE_SIZE*4}static getSegmentMidPoint(t,r,o,n,i){let a=mc(r,o);if(t.points.length>2&&t.roundness){let l=tf(t,t.points[n]);if(l){let s=ww(t,t.points[n],.5),[c,d]=rf(l[0],l[1],l[2],l[3],s);a=e.getPointGlobalCoordinates(t,[c,d],i)}}return a}static getSegmentMidPointIndex(t,r,o,n){let i=e.getElement(t.elementId,n);if(!i)return-1;let a=e.getEditorMidPoints(i,n,r),l=0;for(;l<a.length;){if(e.arePointsEqual(o,a[l]))return l+1;l++}return-1}static handlePointerDown(t,r,o,n,i,a){let l=a.scene.getNonDeletedElementsMap(),s={didAddPoint:!1,hitElement:null,linearElementEditor:null};if(!i)return s;let{elementId:c}=i,d=e.getElement(c,l);if(!d)return s;let m=e.getSegmentMidpointHitCoords(i,n,r,l),p=null;if(m&&(p=e.getSegmentMidPointIndex(i,r,m,l)),t.altKey&&r.editingLinearElement)return i.lastUncommittedPoint==null&&(H(d,{points:[...d.points,e.createPointAt(d,l,n.x,n.y,t[C.CTRL_OR_CMD]?null:r.gridSize)]}),s.didAddPoint=!0),o.shouldCaptureIncrement(),s.linearElementEditor={...i,pointerDownState:{prevSelectedPointsIndices:i.selectedPointsIndices,lastClickedPoint:-1,origin:{x:n.x,y:n.y},segmentMidpoint:{value:m,index:p,added:!1}},selectedPointsIndices:[d.points.length-1],lastUncommittedPoint:null,endBindingElement:pn(n,a)},s.didAddPoint=!0,s;let u=e.getPointIndexUnderCursor(d,l,r.zoom,n.x,n.y);if(u>=0||m)s.hitElement=d;else{let{startBindingElement:A,endBindingElement:M}=i;mn(r)&&Wt(d)&&dn(d,A,M,l)}let[h,E,x,T]=oe(d,l),v=(h+x)/2,w=(E+T)/2,I=u>-1&&Se(d.x+d.points[u][0],d.y+d.points[u][1],v,w,d.angle),L=u>-1||t.shiftKey?t.shiftKey||i.selectedPointsIndices?.includes(u)?OM([...i.selectedPointsIndices||[],u]):[u]:null;return s.linearElementEditor={...i,pointerDownState:{prevSelectedPointsIndices:i.selectedPointsIndices,lastClickedPoint:u,origin:{x:n.x,y:n.y},segmentMidpoint:{value:m,index:p,added:!1}},selectedPointsIndices:L,pointerOffset:I?{x:n.x-I[0],y:n.y-I[1]}:{x:0,y:0}},s}static arePointsEqual(t,r){return!t&&!r?!0:!t||!r?!1:of(t,r)}static handlePointerMove(t,r,o,n,i){if(!n.editingLinearElement)return null;let{elementId:a,lastUncommittedPoint:l}=n.editingLinearElement,s=e.getElement(a,i);if(!s)return n.editingLinearElement;let{points:c}=s,d=c[c.length-1];if(!t.altKey)return d===l&&e.deletePoints(s,[c.length-1]),{...n.editingLinearElement,lastUncommittedPoint:null};let m;if(ka(t)&&c.length>=2){let p=c[c.length-2],[u,h]=e._getShiftLockedDelta(s,i,p,[r,o],t[C.CTRL_OR_CMD]?null:n.gridSize);m=[u+p[0],h+p[1]]}else m=e.createPointAt(s,i,r-n.editingLinearElement.pointerOffset.x,o-n.editingLinearElement.pointerOffset.y,t[C.CTRL_OR_CMD]?null:n.gridSize);return d===l?e.movePoints(s,[{index:s.points.length-1,point:m}]):e.addPoints(s,n,[{point:m}]),{...n.editingLinearElement,lastUncommittedPoint:s.points[s.points.length-1]}}static getPointGlobalCoordinates(t,r,o){let[n,i,a,l]=oe(t,o),s=(n+a)/2,c=(i+l)/2,{x:d,y:m}=t;return[d,m]=Se(d+r[0],m+r[1],s,c,t.angle),[d,m]}static getPointsGlobalCoordinates(t,r){let[o,n,i,a]=oe(t,r),l=(o+i)/2,s=(n+a)/2;return t.points.map(c=>{let{x:d,y:m}=t;return[d,m]=Se(d+c[0],m+c[1],l,s,t.angle),[d,m]})}static getPointAtIndexGlobalCoordinates(t,r,o){let n=r<0?t.points.length+r:r,[i,a,l,s]=oe(t,o),c=(i+l)/2,d=(a+s)/2,m=t.points[n],{x:p,y:u}=t;return m?Se(p+m[0],u+m[1],c,d,t.angle):Se(p,u,c,d,t.angle)}static pointFromAbsoluteCoords(t,r,o){let[n,i,a,l]=oe(t,o),s=(n+a)/2,c=(i+l)/2,[d,m]=Se(r[0],r[1],s,c,-t.angle);return[d-t.x,m-t.y]}static getPointIndexUnderCursor(t,r,o,n,i){let a=e.getPointsGlobalCoordinates(t,r),l=a.length;for(;--l>-1;){let s=a[l];if(It(n,i,s[0],s[1])*o.value<e.POINT_HANDLE_SIZE+1)return l}return-1}static createPointAt(t,r,o,n,i){let a=Pt(o,n,i),[l,s,c,d]=oe(t,r),m=(l+c)/2,p=(s+d)/2,[u,h]=Se(a[0],a[1],m,p,-t.angle);return[u-t.x,h-t.y]}static getNormalizedPoints(t){let{points:r}=t,o=r[0][0],n=r[0][1];return{points:r.map((i,a)=>[i[0]-o,i[1]-n]),x:t.x+o,y:t.y+n}}static normalizePoints(t){H(t,e.getNormalizedPoints(t))}static duplicateSelectedPoints(t,r){if(!t.editingLinearElement)return!1;let{selectedPointsIndices:o,elementId:n}=t.editingLinearElement,i=e.getElement(n,r);if(!i||o===null)return!1;let{points:a}=i,l=[],s=!1,c=-1,d=a.reduce((m,p,u)=>{if(++c,m.push(p),o.includes(u)){let E=a[u+1];E||(s=!0),m.push(E?[(p[0]+E[0])/2,(p[1]+E[1])/2]:[p[0],p[1]]),l.push(c+1),++c}return m},[]);if(H(i,{points:d}),s){let m=i.points[i.points.length-1];e.movePoints(i,[{index:i.points.length-1,point:[m[0]+30,m[1]+30]}])}return{appState:{...t,editingLinearElement:{...t.editingLinearElement,selectedPointsIndices:l}}}}static deletePoints(t,r){let o=0,n=0;if(r.includes(0)){let l=t.points.find((s,c)=>!r.includes(c));l&&(o=l[0],n=l[1])}let a=t.points.reduce((l,s,c)=>(r.includes(c)||l.push(l.length?[s[0]-o,s[1]-n]:[0,0]),l),[]);e._updatePoints(t,a,o,n)}static addPoints(t,r,o){let a=[...t.points,...o.map(l=>l.point)];e._updatePoints(t,a,0,0)}static movePoints(t,r,o){let{points:n}=t,i=0,a=0,l=r.find(({index:c})=>c===0);l&&(i=l.point[0]+n[l.index][0],a=l.point[1]+n[l.index][1]);let s=n.map((c,d)=>{let m=r.find(p=>p.index===d);if(m){if(l)return c;let p=m.point[0]-n[m.index][0],u=m.point[1]-n[m.index][1];return[c[0]+p,c[1]+u]}return i||a?[c[0]-i,c[1]-a]:c});e._updatePoints(t,s,i,a,o)}static shouldAddMidpoint(t,r,o,n){if(!e.getElement(t.elementId,n))return!1;let{segmentMidpoint:a}=t.pointerDownState;if(a.added||a.value===null||a.index===null||t.pointerDownState.origin===null)return!1;let l=t.pointerDownState.origin,s=It(l.x,l.y,r.x,r.y);return!(!o.editingLinearElement&&s<Nn/o.zoom.value)}static addMidpoint(t,r,o,n,i){let a=e.getElement(t.elementId,i);if(!a)return;let{segmentMidpoint:l}=t.pointerDownState,s={pointerDownState:t.pointerDownState,selectedPointsIndices:t.selectedPointsIndices},c=e.createPointAt(a,i,r.x,r.y,n?o.gridSize:null),d=[...a.points.slice(0,l.index),c,...a.points.slice(l.index)];return H(a,{points:d}),s.pointerDownState={...t.pointerDownState,segmentMidpoint:{...t.pointerDownState.segmentMidpoint,added:!0},lastClickedPoint:l.index},s.selectedPointsIndices=[l.index],s}static _updatePoints(t,r,o,n,i){let a=kf(t,r),l=kf(t,t.points),s=(a[0]+a[2])/2,c=(a[1]+a[3])/2,d=(l[0]+l[2])/2,m=(l[1]+l[3])/2,p=d-s,u=m-c,h=Se(o,n,p,u,t.angle);H(t,{...i,points:r,x:t.x+h[0],y:t.y+h[1]})}static _getShiftLockedDelta(t,r,o,n,i){let a=e.getPointGlobalCoordinates(t,o,r),[l,s]=Pt(n[0],n[1],i),{width:c,height:d}=Hl(a[0],a[1],l,s);return Ke([c,d],[0,0],-t.angle)}static getBoundTextElementPosition=(t,r,o)=>{let n=e.getPointsGlobalCoordinates(t,o);n.length<2&&H(r,{isDeleted:!0});let i=0,a=0;if(t.points.length%2===1){let l=Math.floor(t.points.length/2),s=e.getPointGlobalCoordinates(t,t.points[l],o);i=s[0]-r.width/2,a=s[1]-r.height/2}else{let l=t.points.length/2-1,s=Un.points[l];t.points.length===2&&(s=mc(n[0],n[1])),(!s||Un.version!==t.version)&&(s=e.getSegmentMidPoint(t,n[l],n[l+1],l+1,o)),i=s[0]-r.width/2,a=s[1]-r.height/2}return{x:i,y:a}};static getMinMaxXYWithBoundText=(t,r,o,n)=>{let[i,a,l,s]=o,c=(i+l)/2,d=(a+s)/2,{x:m,y:p}=e.getBoundTextElementPosition(t,n,r),u=m+n.width,h=p+n.height,E=Ke([i,a],[c,d],t.angle),x=Ke([l,a],[c,d],t.angle),T=Ke([m,p],[c,d],-t.angle),v=Ke([u,p],[c,d],-t.angle),w=Ke([m,h],[c,d],-t.angle),I=Ke([u,h],[c,d],-t.angle);return E[0]<x[0]&&E[1]>=x[1]?(i=Math.min(i,w[0]),l=Math.max(l,Math.max(v[0],I[0])),a=Math.min(a,T[1]),s=Math.max(s,I[1])):E[0]>=x[0]&&E[1]>x[1]?(i=Math.min(i,I[0]),l=Math.max(l,Math.max(T[0],v[0])),a=Math.min(a,w[1]),s=Math.max(s,v[1])):E[0]>=x[0]?(i=Math.min(i,v[0]),l=Math.max(l,w[0]),a=Math.min(a,I[1]),s=Math.max(s,T[1])):E[1]<=x[1]&&(i=Math.min(i,Math.min(v[0],T[0])),l=Math.max(l,I[0]),a=Math.min(a,v[1]),s=Math.max(s,w[1])),[i,a,l,s,c,d]};static getElementAbsoluteCoords=(t,r,o=!1)=>{let n,i,a,l,s;if(t.points.length<2||!Ne.get(t)){let{minX:p,minY:u,maxX:h,maxY:E}=t.points.reduce((x,[T,v])=>(x.minY=Math.min(x.minY,v),x.minX=Math.min(x.minX,T),x.maxX=Math.max(x.maxX,T),x.maxY=Math.max(x.maxY,v),x),{minX:1/0,minY:1/0,maxX:-1/0,maxY:-1/0});i=p+t.x,a=u+t.y,l=h+t.x,s=E+t.y}else{let p=Ne.generateElementShape(t,null),u=Ci(p[0]),[h,E,x,T]=Sc(u);i=h+t.x,a=E+t.y,l=x+t.x,s=T+t.y}let c=(i+l)/2,d=(a+s)/2;if(n=[i,a,l,s,c,d],!o)return n;let m=ue(t,r);return m&&(n=e.getMinMaxXYWithBoundText(t,r,[i,a,l,s],m)),n}},OM=e=>{let t=[...new Set(e.filter(r=>r!==null&&r!==-1))];return t=t.sort((r,o)=>r-o),t.length?t:null}});var La,Pa,ep,c2,tp=y(()=>{"use strict";f();La={},Pa=(e,t)=>{let r=La[e]||(La[e]={height:t});return r.height=t,r},ep=e=>{La[e]&&delete La[e]},c2=e=>La[e]?.height??null});var Li,Pf,Ht,rp,Ma,Ul,Ho,m2,Pi,op,np,Mf,Cc,Ic,BM,FM,Di,p2,u2,ip,zM,Uo,ue,gt,ap,Df,h2,g2,f2,HM,b2,Gn,Mr,Da,E2,Lf,d2,Xr,mt=y(()=>{"use strict";f();G();Ye();W();xe();me();or();tp();Li=e=>Om(e).replace(/\t/g," "),Pf=e=>Li(e).split(`
10
+ `),Ht=(e,t,r,o=!0)=>{let n,i={x:e.x,y:e.y,text:e.text,width:e.width,height:e.height,angle:t?.angle??e.angle};i.text=e.text,t&&(n=Mr(t,e),i.text=Di(e.originalText,Ze(e),n));let a=Ho(i.text,Ze(e),e.lineHeight);if(i.width=a.width,i.height=a.height,t){let l=Da(t,e),s=Mr(t,e);if(!Ce(t)&&a.height>l){let p=Gn(a.height,t.type);H(t,{height:p},o),Pa(t.id,p)}if(a.width>s){let p=Gn(a.width,t.type);H(t,{width:p},o)}let c={...e,...i},{x:d,y:m}=Ul(t,c,r);i.x=d,i.y=m}H(e,i,o)},rp=(e,t,r)=>{let o=X(e);t.forEach(n=>{let i=r.get(n.id),a=Uo(n);if(a){let l=r.get(a);if(l){let s=o.get(i);s&&H(s,{boundElements:(n.boundElements||[]).filter(d=>d.id!==l&&d.id!==a).concat({type:"text",id:l})});let c=o.get(l);c&&V(c)&&H(c,{containerId:s?i:null})}}})},Ma=(e,t,r,o=!1)=>{if(!Uo(e))return;ep(e.id);let i=ue(e,t);if(i&&i.text){if(!e)return;let a=i.text,l=i.height,s=i.width,c=Mr(e,i),d=Da(e,i),m=e.height;if(o||r!=="n"&&r!=="s"){a&&(a=Di(i.originalText,Ze(i),c));let p=Ho(a,Ze(i),i.lineHeight);l=p.height,s=p.width}if(l>d){m=Gn(l,e.type);let p=m-e.height,u=!Ce(e)&&(r==="ne"||r==="nw"||r==="n")?e.y-p:e.y;H(e,{height:m,y:u})}H(i,{text:a,width:s,height:l}),Ce(e)||H(i,Ul(e,i,t))}},Ul=(e,t,r)=>{if(Ce(e))return Z.getBoundTextElementPosition(e,t,r);let o=Df(e),n=Da(e,t),i=Mr(e,t),a,l;return t.verticalAlign===Tt.TOP?l=o.y:t.verticalAlign===Tt.BOTTOM?l=o.y+(n-t.height):l=o.y+(n/2-t.height/2),t.textAlign===Ei.LEFT?a=o.x:t.textAlign===Ei.RIGHT?a=o.x+(i-t.width):a=o.x+(i/2-t.width/2),{x:a,y:l}},Ho=(e,t,r)=>{e=e.split(`
11
11
  `).map(a=>a||" ").join(`
12
- `);let r=parseFloat(t),n=PA(e,r,o);return{width:fc(e,t),height:n}},M2=e=>{let t=Qh(e.text).length;return e.height/t/e.fontSize},wi=(e,t)=>e*t,Bm=(e,t,o)=>{let{unitsPerEm:r,ascender:n,descender:i}=A2[e]||A2[dt.Helvetica],a=t/r,l=o-a*n+a*i;return a*n+l},Fm=(e,t)=>wi(e,t)+xt*2,hc=(e,t)=>{qh||(qh=document.createElement("canvas"));let o=qh.getContext("2d");o.font=t;let r=o.measureText(e).width;return Ro()?r*10:r},fc=(e,t)=>{let o=Qh(e),r=0;return o.forEach(n=>{r=Math.max(r,hc(n,t))}),r},PA=(e,t,o)=>{let r=Qh(e).length;return wi(t,o)*r},DA=e=>{let t=e.split("-");return t.length>1&&t.forEach((o,r)=>{r!==t.length-1&&(t[r]=o+="-")}),t.join(" ").split(" ")},vi=(e,t,o)=>{if(!Number.isFinite(o)||o<0)return e;let r=[],n=e.split(`
13
- `),i=hc(" ",t),a="",l=0,s=d=>{d.trim()&&r.push(d)},c=()=>{a="",l=0};return n.forEach(d=>{if(fc(d,t)<=o){r.push(d);return}let p=DA(d);c();let u=0;for(;u<p.length;){let g=hc(p[u],t);if(g===o)s(p[u]),u++;else if(g>o){for(s(a),c();p[u].length>0;){let x=String.fromCodePoint(p[u].codePointAt(0)),E=L2.calculate(x,t);l+=E,p[u]=p[u].slice(x.length),l>=o?(s(a),a=x,l=E):a+=x}l+i>=o?(s(a),c()):a.endsWith("-")||(a+=" ",l+=i),u++}else for(;l<o&&u<p.length;){let x=p[u];if(l=hc(a+x,t),l>o){s(a),c();break}u++;let E=!x.endsWith("-");if(a+=x,E&&(a+=" "),l+i>=o){E?r.push(a.slice(0,-1)):r.push(a),c();break}}}a.slice(-1)===" "&&(a=a.slice(0,-1),s(a))}),r.join(`
14
- `)},L2=(()=>{let e={};return{calculate:(r,n)=>{let i=r.charCodeAt(0);if(e[n]||(e[n]=[]),!e[n][i]){let a=hc(r,n);e[n][i]=a}return e[n][i]},getCache:r=>e[r]}})(),_2="ABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789".toLocaleUpperCase(),Hm=(e,t)=>{let o=RA(e);return o===0?Pr(_2.split("").join(`
15
- `),e,t).width+xt*2:o+xt*2},RA=e=>{let t=L2.getCache(e);if(!t)return 0;let o=t.filter(r=>r!==void 0);return Math.max(...o)},Bn=e=>e?.boundElements?.length&&e?.boundElements?.filter(t=>t.type==="text")[0]?.id||null,me=(e,t)=>{if(!e)return null;let o=Bn(e);return o&&t.get(o)||null},ut=(e,t)=>e&&e.containerId&&t.get(e.containerId)||null,zm=(e,t,o)=>{if(!ke(e))return{x:e.x+e.width/2,y:e.y+e.height/2};let r=$.getPointsGlobalCoordinates(e,o);if(r.length%2===1){let a=Math.floor(e.points.length/2),l=$.getPointGlobalCoordinates(e,e.points[a],o);return{x:l[0],y:l[1]}}let n=e.points.length/2-1,i=$.getEditorMidPoints(e,o,t)[n];return i||(i=$.getSegmentMidPoint(e,r[n],r[n+1],n+1,o)),{x:i[0],y:i[1]}},ef=e=>{let t=xt,o=xt;return e.type==="ellipse"&&(t+=e.width/2*(1-Math.sqrt(2)/2),o+=e.height/2*(1-Math.sqrt(2)/2)),e.type==="diamond"&&(t+=e.width/4,o+=e.height/4),{x:e.x+t,y:e.y+o}},P2=(e,t)=>!t||ke(t)?e.angle:t.angle,D2=(e,t)=>e.some(o=>{if(ze(o)){let r=ut(o,t);return!ke(r)}return!1}),R2=(e,t)=>e.some(o=>{if(ze(o)){let r=ut(o,t);return!ke(r)}return W(o)}),tf=(e,t,o,r,n)=>{let i=de(e,t);if(i.length===1)return jr(i[0],!1)?i[0]:null;let a=null;for(let l=e.length-1;l>=0;--l){if(e[l].isDeleted)continue;let[s,c,d,m]=te(e[l],n);if(ke(e[l])&&fa(e[l],t,null,[o,r],n)){a=e[l];break}else if(s<o&&o<d&&c<r&&r<m){a=e[l];break}}return jr(a,!1)?a:null},NA=new Set(["rectangle","ellipse","diamond","arrow"]),N2=e=>NA.has(e.type),On=(e,t)=>{e=Math.ceil(e);let o=xt*2;return t==="ellipse"?Math.round((e+o)/Math.sqrt(2)*2):t==="arrow"?e+o*8:t==="diamond"?2*(e+o):e+o},wo=(e,t)=>{let{width:o}=e;if(ke(e)){let r=(t?.fontSize??Rt)*sy;return Math.max(ly*o,r)}return e.type==="ellipse"?Math.round(o/2*Math.sqrt(2))-xt*2:e.type==="diamond"?Math.round(o/2)-xt*2:o-xt*2},wa=(e,t)=>{let{height:o}=e;return ke(e)?o-xt*8*2<=0?t.height:o:e.type==="ellipse"?Math.round(o/2*Math.sqrt(2))-xt*2:e.type==="diamond"?Math.round(o/2)-xt*2:o-xt*2},O2=()=>fc(_2,Ke({fontSize:Rt,fontFamily:qt}))>0,Jh={[dt.Virgil]:1.25,[dt.Helvetica]:1.15,[dt.Cascadia]:1.2},A2={[dt.Virgil]:{unitsPerEm:1e3,ascender:886,descender:-374},[dt.Helvetica]:{unitsPerEm:2048,ascender:1577,descender:-471},[dt.Cascadia]:{unitsPerEm:2048,ascender:1977,descender:-480},[dt.Assistant]:{unitsPerEm:1e3,ascender:1021,descender:-287}},Oo=e=>e in Jh?Jh[e]:Jh[qt]});import rf from"roughjs/bin/rough";var of,te,nf,h2,Dh,Ar,B2,F2,OA,gc,af,BA,FA,HA,Rh,zA,GA,Dr,Se,Gm,va,Ll,lf,vo,UA,bt=v(()=>{"use strict";f();Qt();Ph();se();qs();pt();io();Mr();G();of=class e{static boundsCache=new WeakMap;static getBounds(t,o){let r=e.boundsCache.get(t);if(r?.version&&r.version===t.version&&!ze(t))return r.bounds;let n=e.calculateBounds(t,o);return e.boundsCache.set(t,{version:t.version,bounds:n}),n}static calculateBounds(t,o){let r,[n,i,a,l,s,c]=te(t,o);if(Ot(t)){let[d,m,p,u]=af(t.points.map(([g,x])=>Ee(g,x,s-t.x,c-t.y,t.angle)));return[d+t.x,m+t.y,p+t.x,u+t.y]}else if(ne(t))r=GA(t,s,c,o);else if(t.type==="diamond"){let[d,m]=Ee(s,i,s,c,t.angle),[p,u]=Ee(s,l,s,c,t.angle),[g,x]=Ee(n,c,s,c,t.angle),[E,y]=Ee(a,c,s,c,t.angle),T=Math.min(d,p,g,E),w=Math.min(m,u,x,y),S=Math.max(d,p,g,E),M=Math.max(m,u,x,y);r=[T,w,S,M]}else if(t.type==="ellipse"){let d=(a-n)/2,m=(l-i)/2,p=Math.cos(t.angle),u=Math.sin(t.angle),g=Math.hypot(d*p,m*u),x=Math.hypot(m*p,d*u);r=[s-g,c-x,s+g,c+x]}else{let[d,m]=Ee(n,i,s,c,t.angle),[p,u]=Ee(n,l,s,c,t.angle),[g,x]=Ee(a,l,s,c,t.angle),[E,y]=Ee(a,i,s,c,t.angle),T=Math.min(d,p,g,E),w=Math.min(m,u,x,y),S=Math.max(d,p,g,E),M=Math.max(m,u,x,y);r=[T,w,S,M]}return r}},te=(e,t,o=!1)=>{if(Ot(e))return BA(e);if(ne(e))return $.getElementAbsoluteCoords(e,t,o);if(W(e)){let r=t?ut(e,t):null;if(ke(r)){let n=$.getBoundTextElementPosition(r,e,t);return[n.x,n.y,n.x+e.width,n.y+e.height,n.x+e.width/2,n.y+e.height/2]}}return[e.x,e.y,e.x+e.width,e.y+e.height,e.x+e.width/2,e.y+e.height/2]},nf=(e,t)=>{let[o,r,n,i,a,l]=te(e,t),s=[a,l];if(ne(e)||Ot(e)){let y=[],T=0;for(;T<e.points.length-1;)y.push([Xe([e.points[T][0]+e.x,e.points[T][1]+e.y],s,e.angle),Xe([e.points[T+1][0]+e.x,e.points[T+1][1]+e.y],s,e.angle)]),T++;return y}let[c,d,m,p,u,g,x,E]=[[o,r],[n,r],[o,i],[n,i],[a,r],[a,i],[o,l],[n,l]].map(y=>Xe(y,s,e.angle));return e.type==="diamond"?[[u,x],[u,E],[g,x],[g,E]]:e.type==="ellipse"?[[u,x],[u,E],[g,x],[g,E],[u,x],[u,E],[g,x],[g,E]]:[[c,d],[m,p],[c,m],[d,p],[c,E],[m,E],[d,x],[p,x]]},h2=e=>[e.x,e.y,e.x+e.width,e.y+e.height,e.x+e.width/2,e.y+e.height/2],Dh=e=>{let t=Math.floor(e.width/2)+1,o=0,r=e.width,n=Math.floor(e.height/2)+1,i=t,a=e.height;return[t,o,r,n,i,a,0,n]},Ar=e=>{for(let t of e.sets)if(t.type==="path")return t.ops;return e.sets[0].ops},B2=(e,t,o,r,n)=>{let i=1-e;return Math.pow(i,3)*t+3*Math.pow(i,2)*e*o+3*i*Math.pow(e,2)*r+Math.pow(e,3)*n},F2=(e,t,o,r)=>{let n=t-e,i=o-t,a=r-o,l=3*n-6*i+3*a,s=6*i-6*n,c=3*n,d=s*s-4*l*c;if(!(d>=0))return!1;let p=null,u=null,g=1/0,x=1/0;return l===0?g=x=-c/s:(g=(-s+Math.sqrt(d))/(2*l),x=(-s-Math.sqrt(d))/(2*l)),g>=0&&g<=1&&(p=B2(g,e,t,o,r)),x>=0&&x<=1&&(u=B2(x,e,t,o,r)),[p,u]},OA=(e,t,o,r)=>{let n=F2(e[0],t[0],o[0],r[0]),i=F2(e[1],t[1],o[1],r[1]),a=Math.min(e[0],r[0]),l=Math.max(e[0],r[0]);if(n){let d=n.filter(m=>m!==null);a=Math.min(a,...d),l=Math.max(l,...d)}let s=Math.min(e[1],r[1]),c=Math.max(e[1],r[1]);if(i){let d=i.filter(m=>m!==null);s=Math.min(s,...d),c=Math.max(c,...d)}return[a,s,l,c]},gc=(e,t)=>{let o=[0,0],{minX:r,minY:n,maxX:i,maxY:a}=e.reduce((l,{op:s,data:c})=>{if(s==="move")o=c;else if(s==="bcurveTo"){let d=[c[0],c[1]],m=[c[2],c[3]],p=[c[4],c[5]],u=t?t(...d):d,g=t?t(...m):m,x=t?t(...p):p,E=t?t(...o):o;o=p;let[y,T,w,S]=OA(E,u,g,x);l.minX=Math.min(l.minX,y),l.minY=Math.min(l.minY,T),l.maxX=Math.max(l.maxX,w),l.maxY=Math.max(l.maxY,S)}return l},{minX:1/0,minY:1/0,maxX:-1/0,maxY:-1/0});return[r,n,i,a]},af=e=>{let t=1/0,o=1/0,r=-1/0,n=-1/0;for(let[i,a]of e)t=Math.min(t,i),o=Math.min(o,a),r=Math.max(r,i),n=Math.max(n,a);return[t,o,r,n]},BA=e=>{let[t,o,r,n]=af(e.points),i=t+e.x,a=o+e.y,l=r+e.x,s=n+e.y;return[i,a,l,s,(i+l)/2,(a+s)/2]},FA=e=>{switch(e){case"arrow":return 25;case"diamond":case"diamond_outline":return 12;default:return 15}},HA=e=>{switch(e){case"bar":return 90;case"arrow":return 20;default:return 25}},Rh=(e,t,o,r)=>{let n=Ar(t[0]);if(n.length<1)return null;let i=o==="start"?1:n.length-1,a=n[i].data,l=[a[4],a[5]],s=[a[2],a[3]],c=[a[0],a[1]],d=n[i-1],m=[0,0];d.op==="move"?m=d.data:d.op==="bcurveTo"&&(m=[d.data[4],d.data[5]]);let p=(Y,oe)=>Math.pow(1-Y,3)*l[oe]+3*Y*Math.pow(1-Y,2)*s[oe]+3*Math.pow(Y,2)*(1-Y)*c[oe]+m[oe]*Math.pow(Y,3),[u,g]=o==="start"?m:l,[x,E]=[p(.3,0),p(.3,1)],y=Math.hypot(u-x,g-E),T=(u-x)/y,w=(g-E)/y,S=FA(r),M=0;{let[Y,oe]=o==="end"?e.points[e.points.length-1]:e.points[0],[Ce,Te]=e.points.length>1?o==="end"?e.points[e.points.length-2]:e.points[1]:[0,0];M=Math.hypot(Y-Ce,oe-Te)}let R=Math.min(S,M*(r==="diamond"||r==="diamond_outline"?.25:.5)),P=u-T*R,F=g-w*R;if(r==="dot"||r==="circle"||r==="circle_outline"){let Y=Math.hypot(F-g,P-u)+e.strokeWidth-2;return[u,g,Y]}let D=HA(r),[L,A]=Ee(P,F,u,g,-D*Math.PI/180),[B,j]=Ee(P,F,u,g,D*Math.PI/180);if(r==="diamond"||r==="diamond_outline"){let Y,oe;if(o==="start"){let[Ce,Te]=e.points.length>1?e.points[1]:[0,0];[Y,oe]=Ee(u+R*2,g,u,g,Math.atan2(Te-g,Ce-u))}else{let[Ce,Te]=e.points.length>1?e.points[e.points.length-2]:[0,0];[Y,oe]=Ee(u-R*2,g,u,g,Math.atan2(g-Te,u-Ce))}return[u,g,L,A,Y,oe,B,j]}return[u,g,L,A,B,j]},zA=e=>{let t=rf.generator(),o=No(e),r=e.roundness?"curve":o.fill?"polygon":"linearPath";return t[r](e.points,o)},GA=(e,t,o,r)=>{let n=me(e,r);if(e.points.length<2){let[m,p]=e.points[0],[u,g]=Ee(e.x+m,e.y+p,t,o,e.angle),x=[u,g,u,g];if(n){let E=$.getMinMaxXYWithBoundText(e,r,[u,g,u,g],n);x=[E[0],E[1],E[2],E[3]]}return x}let a=Me.get(e)?.[0]??zA(e),l=Ar(a),c=gc(l,(m,p)=>Ee(e.x+m,e.y+p,t,o,e.angle)),d=[c[0],c[1],c[2],c[3]];if(n){let m=$.getMinMaxXYWithBoundText(e,r,d,n);d=[m[0],m[1],m[2],m[3]]}return d},Dr=(e,t)=>of.getBounds(e,t),Se=e=>{if(!e.length)return[0,0,0,0];let t=1/0,o=-1/0,r=1/0,n=-1/0,i=re(e);return e.forEach(a=>{let[l,s,c,d]=Dr(a,i);t=Math.min(t,l),r=Math.min(r,s),o=Math.max(o,c),n=Math.max(n,d)}),[t,r,o,n]},Gm=(e,t)=>{let[o,r,n,i]=Se(e);return[o+t.x,r+t.y,n+t.x,i+t.y]},va=(e,t,o,r)=>{if(!(ne(e)||Ot(e)))return[e.x,e.y,e.x+t,e.y+o];let n=gi(0,t,gi(1,o,e.points,r),r),i;if(Ot(e))i=af(n);else{let d=rf.generator(),m=e.roundness?d.curve(n,No(e)):d.linearPath(n,No(e)),p=Ar(m);i=gc(p)}let[a,l,s,c]=i;return[a+e.x,l+e.y,s+e.x,c+e.y]},Ll=(e,t)=>{let o=rf.generator(),r=e.roundness==null?o.linearPath(t,No(e)):o.curve(t,No(e)),n=Ar(r),[i,a,l,s]=gc(n);return[i+e.x,a+e.y,l+e.x,s+e.y]},lf=(e,t)=>{if(!e.length)return[0,0,0,0];let o=1/0,r=e[0],n=re(e);return e.forEach(i=>{let[a,l,s,c]=Dr(i,n),d=mt((a+s)/2,(l+c)/2,t.x,t.y);d<o&&(o=d,r=i)}),Dr(r,n)},vo=e=>{let[t,o,r,n]=Se(e);return{minX:t,minY:o,maxX:r,maxY:n,width:r-t,height:n-o,midX:(t+r)/2,midY:(o+n)/2}},UA=({scrollX:e,scrollY:t,width:o,height:r,zoom:n})=>[-e,-t,-e+o/n.value,-t+r/n.value]});var WA,Bo,VA,sf,YA,bc,H2,To,Rr,Fo=v(()=>{"use strict";f();U();WA=pl.includes(devicePixelRatio)?devicePixelRatio:1,Bo=()=>({showWelcomeScreen:!1,theme:ie.LIGHT,collaborators:new Map,currentChartType:"bar",currentItemBackgroundColor:rt.backgroundColor,currentItemEndArrowhead:"arrow",currentItemFillStyle:rt.fillStyle,currentItemFontFamily:qt,currentItemFontSize:Rt,currentItemOpacity:rt.opacity,currentItemRoughness:rt.roughness,currentItemStartArrowhead:null,currentItemStrokeColor:rt.strokeColor,currentItemRoundness:"round",currentItemStrokeStyle:rt.strokeStyle,currentItemStrokeWidth:rt.strokeWidth,currentItemTextAlign:li,cursorButton:"up",activeEmbeddable:null,draggingElement:null,editingElement:null,editingGroupId:null,editingLinearElement:null,activeTool:{type:"selection",customType:null,locked:rt.locked,lastActiveTool:null},penMode:!1,penDetected:!1,errorMessage:null,exportBackground:!0,exportScale:WA,exportEmbedScene:!1,exportWithDarkMode:!1,fileHandle:null,gridSize:null,isBindingEnabled:!0,defaultSidebarDockedPreference:!1,isLoading:!1,isResizing:!1,isRotating:!1,lastPointerDownWith:"mouse",multiElement:null,name:null,contextMenu:null,openMenu:null,openPopup:null,openSidebar:null,openDialog:null,pasteDialog:{shown:!1,data:null},previousSelectedElementIds:{},resizingElement:null,scrolledOutside:!1,scrollX:0,scrollY:0,selectedElementIds:{},selectedGroupIds:{},selectedElementsAreBeingDragged:!1,selectionElement:null,shouldCacheIgnoreZoom:!1,showStats:!1,startBoundElement:null,suggestedBindings:[],frameRendering:{enabled:!0,clip:!0,name:!0,outline:!0},frameToHighlight:null,editingFrame:null,elementsToHighlight:null,toast:null,viewBackgroundColor:Ht,zenModeEnabled:!1,zoom:{value:rm},viewModeEnabled:!1,pendingImageElementId:null,showHyperlinkPopup:!1,selectedLinearElement:null,snapLines:[],originSnapOffset:{x:0,y:0},objectsSnapModeEnabled:!1,userToFollow:null,followedBy:new Set}),VA=(e=>e)({showWelcomeScreen:{browser:!0,export:!1,server:!1},theme:{browser:!0,export:!1,server:!1},collaborators:{browser:!1,export:!1,server:!1},currentChartType:{browser:!0,export:!1,server:!1},currentItemBackgroundColor:{browser:!0,export:!1,server:!1},currentItemEndArrowhead:{browser:!0,export:!1,server:!1},currentItemFillStyle:{browser:!0,export:!1,server:!1},currentItemFontFamily:{browser:!0,export:!1,server:!1},currentItemFontSize:{browser:!0,export:!1,server:!1},currentItemRoundness:{browser:!0,export:!1,server:!1},currentItemOpacity:{browser:!0,export:!1,server:!1},currentItemRoughness:{browser:!0,export:!1,server:!1},currentItemStartArrowhead:{browser:!0,export:!1,server:!1},currentItemStrokeColor:{browser:!0,export:!1,server:!1},currentItemStrokeStyle:{browser:!0,export:!1,server:!1},currentItemStrokeWidth:{browser:!0,export:!1,server:!1},currentItemTextAlign:{browser:!0,export:!1,server:!1},cursorButton:{browser:!0,export:!1,server:!1},activeEmbeddable:{browser:!1,export:!1,server:!1},draggingElement:{browser:!1,export:!1,server:!1},editingElement:{browser:!1,export:!1,server:!1},editingGroupId:{browser:!0,export:!1,server:!1},editingLinearElement:{browser:!1,export:!1,server:!1},activeTool:{browser:!0,export:!1,server:!1},penMode:{browser:!0,export:!1,server:!1},penDetected:{browser:!0,export:!1,server:!1},errorMessage:{browser:!1,export:!1,server:!1},exportBackground:{browser:!0,export:!1,server:!1},exportEmbedScene:{browser:!0,export:!1,server:!1},exportScale:{browser:!0,export:!1,server:!1},exportWithDarkMode:{browser:!0,export:!1,server:!1},fileHandle:{browser:!1,export:!1,server:!1},gridSize:{browser:!0,export:!0,server:!0},height:{browser:!1,export:!1,server:!1},isBindingEnabled:{browser:!1,export:!1,server:!1},defaultSidebarDockedPreference:{browser:!0,export:!1,server:!1},isLoading:{browser:!1,export:!1,server:!1},isResizing:{browser:!1,export:!1,server:!1},isRotating:{browser:!1,export:!1,server:!1},lastPointerDownWith:{browser:!0,export:!1,server:!1},multiElement:{browser:!1,export:!1,server:!1},name:{browser:!0,export:!1,server:!1},offsetLeft:{browser:!1,export:!1,server:!1},offsetTop:{browser:!1,export:!1,server:!1},contextMenu:{browser:!1,export:!1,server:!1},openMenu:{browser:!0,export:!1,server:!1},openPopup:{browser:!1,export:!1,server:!1},openSidebar:{browser:!0,export:!1,server:!1},openDialog:{browser:!1,export:!1,server:!1},pasteDialog:{browser:!1,export:!1,server:!1},previousSelectedElementIds:{browser:!0,export:!1,server:!1},resizingElement:{browser:!1,export:!1,server:!1},scrolledOutside:{browser:!0,export:!1,server:!1},scrollX:{browser:!0,export:!1,server:!1},scrollY:{browser:!0,export:!1,server:!1},selectedElementIds:{browser:!0,export:!1,server:!1},selectedGroupIds:{browser:!0,export:!1,server:!1},selectedElementsAreBeingDragged:{browser:!1,export:!1,server:!1},selectionElement:{browser:!1,export:!1,server:!1},shouldCacheIgnoreZoom:{browser:!0,export:!1,server:!1},showStats:{browser:!0,export:!1,server:!1},startBoundElement:{browser:!1,export:!1,server:!1},suggestedBindings:{browser:!1,export:!1,server:!1},frameRendering:{browser:!1,export:!1,server:!1},frameToHighlight:{browser:!1,export:!1,server:!1},editingFrame:{browser:!1,export:!1,server:!1},elementsToHighlight:{browser:!1,export:!1,server:!1},toast:{browser:!1,export:!1,server:!1},viewBackgroundColor:{browser:!0,export:!0,server:!0},width:{browser:!1,export:!1,server:!1},zenModeEnabled:{browser:!0,export:!1,server:!1},zoom:{browser:!0,export:!1,server:!1},viewModeEnabled:{browser:!1,export:!1,server:!1},pendingImageElementId:{browser:!1,export:!1,server:!1},showHyperlinkPopup:{browser:!1,export:!1,server:!1},selectedLinearElement:{browser:!0,export:!1,server:!1},snapLines:{browser:!1,export:!1,server:!1},originSnapOffset:{browser:!1,export:!1,server:!1},objectsSnapModeEnabled:{browser:!0,export:!1,server:!1},userToFollow:{browser:!1,export:!1,server:!1},followedBy:{browser:!1,export:!1,server:!1}}),sf=(e,t)=>{let o={};for(let r of Object.keys(e))if(VA[r]?.[t]){let i=e[r];o[r]=i}return o},YA=e=>sf(e,"browser"),bc=e=>sf(e,"export"),H2=e=>sf(e,"server"),To=({activeTool:e})=>e.type==="eraser",Rr=({activeTool:e})=>e.type==="hand"});var cf,to,Um,df,Fn,Wm,z2,Ta,ot,G2,U2,W2,V2,Ca,Ho=v(()=>{"use strict";f();We();pt();ui();cf=(e,t,o)=>{let r=o.reduce((n,i)=>(i.groupIds.includes(e)&&(n[i.id]=!0),n),{});return Object.keys(r).length<2?t.selectedGroupIds[e]||t.editingGroupId===e?{selectedElementIds:t.selectedElementIds,selectedGroupIds:{...t.selectedGroupIds,[e]:!1},editingGroupId:null}:t:{editingGroupId:t.editingGroupId,selectedGroupIds:{...t.selectedGroupIds,[e]:!0},selectedElementIds:{...t.selectedElementIds,...r}}},to=function(){let e=null,t=null,o=null,r=(i,a,l,s)=>{if(o!==void 0&&a===t&&i===e&&l.editingGroupId===o?.editingGroupId)return o;let c={};for(let p of i){let u=p.groupIds;if(l.editingGroupId){let g=u.indexOf(l.editingGroupId);g>-1&&(u=u.slice(0,g))}if(u.length>0){let g=u[u.length-1];c[g]=!0}}let d={},m=a.reduce((p,u)=>{let g=u.groupIds.find(x=>c[x]);return g&&(p[u.id]=!0,Array.isArray(d[g])?d[g].push(u.id):d[g]=[u.id]),p},{});for(let p of Object.keys(d))d[p].length<2&&c[p]&&(c[p]=!1);return t=a,e=i,o={editingGroupId:l.editingGroupId,selectedGroupIds:c,selectedElementIds:Oe({...l.selectedElementIds,...m},s)},o},n=(i,a,l,s)=>{let c=s?s.scene.getSelectedElements({selectedElementIds:i.selectedElementIds,elements:a}):de(a,i);return c.length?r(c,a,i,l):{selectedGroupIds:{},editingGroupId:null,selectedElementIds:Oe(i.selectedElementIds,l)}};return n.clearCache=()=>{t=null,e=null,o=null},n}(),Um=(e,t)=>df(e,t)!=null,df=(e,t)=>t.groupIds.filter(o=>o!==e.editingGroupId).find(o=>e.selectedGroupIds[o]),Fn=e=>Object.entries(e.selectedGroupIds).filter(([t,o])=>o).map(([t,o])=>t),Wm=(e,t)=>{let o={...t,selectedGroupIds:{}};for(let r of e){let n=r.groupIds;if(t.editingGroupId){let i=n.indexOf(t.editingGroupId);i>-1&&(n=n.slice(0,i))}if(n.length>0){let i=n[n.length-1];o={...o,...cf(i,o,e)}}}return o.selectedGroupIds},z2=(e,t)=>({...e,editingGroupId:t.groupIds.length?t.groupIds[0]:null,selectedGroupIds:{},selectedElementIds:{[t.id]:!0}}),Ta=(e,t)=>e.groupIds.includes(t),ot=(e,t)=>{let o=[];for(let r of e.values())Ta(r,t)&&o.push(r);return o},G2=(e,t)=>e.groupIds.find(o=>t[o]),U2=(e,t,o)=>{let r=[...e],n=t?e.indexOf(t):-1,i=n>-1?n:e.length;for(let a=0;a<i;a++)r[a]=o(r[a]);return r},W2=(e,t,o)=>{let r=[...e],n=o?r.indexOf(o):-1,i=n>-1?n:r.length;return r.splice(i,0,t),r},V2=(e,t)=>e.filter(o=>!t[o]),Ca=(e,t)=>{let o=new Map;return e.forEach(r=>{let n=r.groupIds.length===0?r.id:r.groupIds[r.groupIds.length-1],i=o.get(n)||[],a=me(r,t);a&&i.push(a),o.set(n,[...i,r])}),Array.from(o.values())}});import{sanitizeUrl as KA}from"@braintree/sanitize-url";var po,Vm,Ym,Dl=v(()=>{"use strict";f();po=e=>(e=e.trim(),e&&KA(e)),Vm=e=>!!(e?.includes(location.origin)||e?.startsWith("/")),Ym=e=>{if(e=po(e),e.startsWith("/"))return`${location.origin}${e}`;try{new URL(e)}catch{return"about:blank"}return e}});var Km,H,je=v(()=>{"use strict";f();Km=[],H=e=>(Km=Km.concat(e),e)});import $m from"open-color";var K2,$A,$2,XA,ZA,zo,Ve,tn,Y2,mf,Go,Rl=v(()=>{"use strict";f();U();Fo();K2='<svg viewBox="0 0 24 24" stroke-width="1" width="28" height="28" xmlns="http://www.w3.org/2000/svg">',$A='<path d="M6.164 11.755a5.314 5.314 0 0 1-4.932-5.298 5.314 5.314 0 0 1 5.311-5.311 5.314 5.314 0 0 1 5.307 5.113l8.773 8.773a3.322 3.322 0 0 1 0 4.696l-.895.895a3.322 3.322 0 0 1-4.696 0l-8.868-8.868Z" style="fill:#fff"/>',$2='<path stroke="#1b1b1f" fill="#fff" d="m7.868 11.113 7.773 7.774a2.359 2.359 0 0 0 1.667.691 2.368 2.368 0 0 0 2.357-2.358c0-.625-.248-1.225-.69-1.667L11.201 7.78 9.558 9.469l-1.69 1.643v.001Zm10.273 3.606-3.333 3.333m-3.25-6.583 2 2m-7-7 3 3M3.664 3.625l1 1M2.529 6.922l1.407-.144m5.735-2.932-1.118.866M4.285 9.823l.758-1.194m1.863-6.207-.13 1.408"/>',XA=`data:${J.svg},${encodeURIComponent(`${K2}${$2}</svg>`)}`,ZA=`data:${J.svg},${encodeURIComponent(`${K2}${$A}${$2}</svg>`)}`,zo=e=>{e&&(e.style.cursor="")},Ve=(e,t)=>{e&&(e.style.cursor=t)},mf=(e,t)=>{let r=()=>{let n=t===ie.DARK;tn=document.createElement("canvas"),tn.theme=t,tn.height=20,tn.width=20;let i=tn.getContext("2d");i.lineWidth=1,i.beginPath(),i.arc(tn.width/2,tn.height/2,5,0,2*Math.PI),i.fillStyle=n?$m.black:$m.white,i.fill(),i.strokeStyle=n?$m.white:$m.black,i.stroke(),Y2=tn.toDataURL(J.svg)};(!tn||tn.theme!==t)&&r(),Ve(e,`url(${Y2}) ${20/2} ${20/2}, auto`)},Go=(e,t)=>{if(e)if(t.activeTool.type==="selection")zo(e);else if(Rr(t))e.style.cursor=Pe.GRAB;else if(To(t))mf(e,t.theme);else if(t.activeTool.type==="laser"){let o=t.theme===ie.LIGHT?XA:ZA;e.style.cursor=`url(${o}), auto`}else if(!["image","custom"].includes(t.activeTool.type))e.style.cursor=Pe.CROSSHAIR;else if(t.activeTool.type==="custom"&&t.activeTool.customType==="comment"){let o=`data:${J.svg},${encodeURIComponent(`
12
+ `);let o=parseFloat(t),n=BM(e,o,r);return{width:Ic(e,t),height:n}},m2=e=>{let t=Pf(e.text).length;return e.height/t/e.fontSize},Pi=(e,t)=>e*t,op=(e,t,r)=>{let{unitsPerEm:o,ascender:n,descender:i}=d2[e]||d2[ht.Helvetica],a=t/o,l=r-a*n+a*i;return a*n+l},np=(e,t)=>Pi(e,t)+yt*2,Cc=(e,t)=>{Mf||(Mf=document.createElement("canvas"));let r=Mf.getContext("2d");r.font=t;let o=r.measureText(e).width;return Wr()?o*10:o},Ic=(e,t)=>{let r=Pf(e),o=0;return r.forEach(n=>{o=Math.max(o,Cc(n,t))}),o},BM=(e,t,r)=>{let o=Pf(e).length;return Pi(t,r)*o},FM=e=>{let t=e.split("-");return t.length>1&&t.forEach((r,o)=>{o!==t.length-1&&(t[o]=r+="-")}),t.join(" ").split(" ")},Di=(e,t,r)=>{if(!Number.isFinite(r)||r<0)return e;let o=[],n=e.split(`
13
+ `),i=Cc(" ",t),a="",l=0,s=d=>{d.trim()&&o.push(d)},c=()=>{a="",l=0};return n.forEach(d=>{if(Ic(d,t)<=r){o.push(d);return}let p=FM(d);c();let u=0;for(;u<p.length;){let h=Cc(p[u],t);if(h===r)s(p[u]),u++;else if(h>r){for(s(a),c();p[u].length>0;){let E=String.fromCodePoint(p[u].codePointAt(0)),x=p2.calculate(E,t);l+=x,p[u]=p[u].slice(E.length),l>=r?(s(a),a=E,l=x):a+=E}l+i>=r?(s(a),c()):a.endsWith("-")||(a+=" ",l+=i),u++}else for(;l<r&&u<p.length;){let E=p[u];if(l=Cc(a+E,t),l>r){s(a),c();break}u++;let x=!E.endsWith("-");if(a+=E,x&&(a+=" "),l+i>=r){x?o.push(a.slice(0,-1)):o.push(a),c();break}}}a.slice(-1)===" "&&(a=a.slice(0,-1),s(a))}),o.join(`
14
+ `)},p2=(()=>{let e={};return{calculate:(o,n)=>{let i=o.charCodeAt(0);if(e[n]||(e[n]=[]),!e[n][i]){let a=Cc(o,n);e[n][i]=a}return e[n][i]},getCache:o=>e[o]}})(),u2="ABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789".toLocaleUpperCase(),ip=(e,t)=>{let r=zM(e);return r===0?Ho(u2.split("").join(`
15
+ `),e,t).width+yt*2:r+yt*2},zM=e=>{let t=p2.getCache(e);if(!t)return 0;let r=t.filter(o=>o!==void 0);return Math.max(...r)},Uo=e=>e?.boundElements?.length&&e?.boundElements?.filter(t=>t.type==="text")[0]?.id||null,ue=(e,t)=>{if(!e)return null;let r=Uo(e);return r&&t.get(r)||null},gt=(e,t)=>e&&e.containerId&&t.get(e.containerId)||null,ap=(e,t,r)=>{if(!Ce(e))return{x:e.x+e.width/2,y:e.y+e.height/2};let o=Z.getPointsGlobalCoordinates(e,r);if(o.length%2===1){let a=Math.floor(e.points.length/2),l=Z.getPointGlobalCoordinates(e,e.points[a],r);return{x:l[0],y:l[1]}}let n=e.points.length/2-1,i=Z.getEditorMidPoints(e,r,t)[n];return i||(i=Z.getSegmentMidPoint(e,o[n],o[n+1],n+1,r)),{x:i[0],y:i[1]}},Df=e=>{let t=yt,r=yt;return e.type==="ellipse"&&(t+=e.width/2*(1-Math.sqrt(2)/2),r+=e.height/2*(1-Math.sqrt(2)/2)),e.type==="diamond"&&(t+=e.width/4,r+=e.height/4),{x:e.x+t,y:e.y+r}},h2=(e,t)=>!t||Ce(t)?e.angle:t.angle,g2=(e,t)=>e.some(r=>{if(Pe(r)){let o=gt(r,t);return!Ce(o)}return!1}),f2=(e,t)=>e.some(r=>{if(Pe(r)){let o=gt(r,t);return!Ce(o)}return V(r)}),HM=new Set(["rectangle","ellipse","diamond","arrow"]),b2=e=>HM.has(e.type),Gn=(e,t)=>{e=Math.ceil(e);let r=yt*2;return t==="ellipse"?Math.round((e+r)/Math.sqrt(2)*2):t==="arrow"?e+r*8:t==="diamond"?2*(e+r):e+r},Mr=(e,t)=>{let{width:r}=e;if(Ce(e)){let o=(t?.fontSize??Ot)*Vy;return Math.max(Gy*r,o)}return e.type==="ellipse"?Math.round(r/2*Math.sqrt(2))-yt*2:e.type==="diamond"?Math.round(r/2)-yt*2:r-yt*2},Da=(e,t)=>{let{height:r}=e;return Ce(e)?r-yt*8*2<=0?t.height:r:e.type==="ellipse"?Math.round(r/2*Math.sqrt(2))-yt*2:e.type==="diamond"?Math.round(r/2)-yt*2:r-yt*2},E2=()=>Ic(u2,Ze({fontSize:Ot,fontFamily:tr}))>0,Lf={[ht.Virgil]:1.25,[ht.Helvetica]:1.15,[ht.Cascadia]:1.2},d2={[ht.Virgil]:{unitsPerEm:1e3,ascender:886,descender:-374},[ht.Helvetica]:{unitsPerEm:2048,ascender:1577,descender:-471},[ht.Cascadia]:{unitsPerEm:2048,ascender:1977,descender:-480},[ht.Assistant]:{unitsPerEm:1e3,ascender:1021,descender:-287}},Xr=e=>e in Lf?Lf[e]:Lf[tr]});import Rf from"roughjs/bin/rough";var _f,oe,Nf,lf,Ci,x2,y2,UM,Sc,Of,GM,VM,WM,sf,YM,KM,Zr,Ae,lp,Gl,kf,Bf,Lr,$M,dt=y(()=>{"use strict";f();Kt();af();me();dc();mt();or();ln();G();_f=class e{static boundsCache=new WeakMap;static getBounds(t,r){let o=e.boundsCache.get(t);if(o?.version&&o.version===t.version&&!Pe(t))return o.bounds;let n=e.calculateBounds(t,r);return e.boundsCache.set(t,{version:t.version,bounds:n}),n}static calculateBounds(t,r){let o,[n,i,a,l,s,c]=oe(t,r);if(Ft(t)){let[d,m,p,u]=Of(t.points.map(([h,E])=>Se(h,E,s-t.x,c-t.y,t.angle)));return[d+t.x,m+t.y,p+t.x,u+t.y]}else if(ce(t))o=KM(t,s,c,r);else if(t.type==="diamond"){let[d,m]=Se(s,i,s,c,t.angle),[p,u]=Se(s,l,s,c,t.angle),[h,E]=Se(n,c,s,c,t.angle),[x,T]=Se(a,c,s,c,t.angle),v=Math.min(d,p,h,x),w=Math.min(m,u,E,T),I=Math.max(d,p,h,x),L=Math.max(m,u,E,T);o=[v,w,I,L]}else if(t.type==="ellipse"){let d=(a-n)/2,m=(l-i)/2,p=Math.cos(t.angle),u=Math.sin(t.angle),h=Math.hypot(d*p,m*u),E=Math.hypot(m*p,d*u);o=[s-h,c-E,s+h,c+E]}else{let[d,m]=Se(n,i,s,c,t.angle),[p,u]=Se(n,l,s,c,t.angle),[h,E]=Se(a,l,s,c,t.angle),[x,T]=Se(a,i,s,c,t.angle),v=Math.min(d,p,h,x),w=Math.min(m,u,E,T),I=Math.max(d,p,h,x),L=Math.max(m,u,E,T);o=[v,w,I,L]}return o}},oe=(e,t,r=!1)=>{if(Ft(e))return GM(e);if(ce(e))return Z.getElementAbsoluteCoords(e,t,r);if(V(e)){let o=t?gt(e,t):null;if(Ce(o)){let n=Z.getBoundTextElementPosition(o,e,t);return[n.x,n.y,n.x+e.width,n.y+e.height,n.x+e.width/2,n.y+e.height/2]}}return[e.x,e.y,e.x+e.width,e.y+e.height,e.x+e.width/2,e.y+e.height/2]},Nf=(e,t)=>{let[r,o,n,i,a,l]=oe(e,t),s=[a,l];if(ce(e)||Ft(e)){let T=[],v=0;for(;v<e.points.length-1;)T.push([Ke([e.points[v][0]+e.x,e.points[v][1]+e.y],s,e.angle),Ke([e.points[v+1][0]+e.x,e.points[v+1][1]+e.y],s,e.angle)]),v++;return T}let[c,d,m,p,u,h,E,x]=[[r,o],[n,o],[r,i],[n,i],[a,o],[a,i],[r,l],[n,l]].map(T=>Ke(T,s,e.angle));return e.type==="diamond"?[[u,E],[u,x],[h,E],[h,x]]:e.type==="ellipse"?[[u,E],[u,x],[h,E],[h,x],[u,E],[u,x],[h,E],[h,x]]:[[c,d],[m,p],[c,m],[d,p],[c,x],[m,x],[d,E],[p,E]]},lf=e=>{let t=Math.floor(e.width/2)+1,r=0,o=e.width,n=Math.floor(e.height/2)+1,i=t,a=e.height;return[t,r,o,n,i,a,0,n]},Ci=e=>{for(let t of e.sets)if(t.type==="path")return t.ops;return e.sets[0].ops},x2=(e,t,r,o,n)=>{let i=1-e;return Math.pow(i,3)*t+3*Math.pow(i,2)*e*r+3*i*Math.pow(e,2)*o+Math.pow(e,3)*n},y2=(e,t,r,o)=>{let n=t-e,i=r-t,a=o-r,l=3*n-6*i+3*a,s=6*i-6*n,c=3*n,d=s*s-4*l*c;if(!(d>=0))return!1;let p=null,u=null,h=1/0,E=1/0;return l===0?h=E=-c/s:(h=(-s+Math.sqrt(d))/(2*l),E=(-s-Math.sqrt(d))/(2*l)),h>=0&&h<=1&&(p=x2(h,e,t,r,o)),E>=0&&E<=1&&(u=x2(E,e,t,r,o)),[p,u]},UM=(e,t,r,o)=>{let n=y2(e[0],t[0],r[0],o[0]),i=y2(e[1],t[1],r[1],o[1]),a=Math.min(e[0],o[0]),l=Math.max(e[0],o[0]);if(n){let d=n.filter(m=>m!==null);a=Math.min(a,...d),l=Math.max(l,...d)}let s=Math.min(e[1],o[1]),c=Math.max(e[1],o[1]);if(i){let d=i.filter(m=>m!==null);s=Math.min(s,...d),c=Math.max(c,...d)}return[a,s,l,c]},Sc=(e,t)=>{let r=[0,0],{minX:o,minY:n,maxX:i,maxY:a}=e.reduce((l,{op:s,data:c})=>{if(s==="move")r=c;else if(s==="bcurveTo"){let d=[c[0],c[1]],m=[c[2],c[3]],p=[c[4],c[5]],u=t?t(...d):d,h=t?t(...m):m,E=t?t(...p):p,x=t?t(...r):r;r=p;let[T,v,w,I]=UM(x,u,h,E);l.minX=Math.min(l.minX,T),l.minY=Math.min(l.minY,v),l.maxX=Math.max(l.maxX,w),l.maxY=Math.max(l.maxY,I)}return l},{minX:1/0,minY:1/0,maxX:-1/0,maxY:-1/0});return[o,n,i,a]},Of=e=>{let t=1/0,r=1/0,o=-1/0,n=-1/0;for(let[i,a]of e)t=Math.min(t,i),r=Math.min(r,a),o=Math.max(o,i),n=Math.max(n,a);return[t,r,o,n]},GM=e=>{let[t,r,o,n]=Of(e.points),i=t+e.x,a=r+e.y,l=o+e.x,s=n+e.y;return[i,a,l,s,(i+l)/2,(a+s)/2]},VM=e=>{switch(e){case"arrow":return 25;case"diamond":case"diamond_outline":return 12;default:return 15}},WM=e=>{switch(e){case"bar":return 90;case"arrow":return 20;default:return 25}},sf=(e,t,r,o)=>{let n=Ci(t[0]);if(n.length<1)return null;let i=r==="start"?1:n.length-1,a=n[i].data,l=[a[4],a[5]],s=[a[2],a[3]],c=[a[0],a[1]],d=n[i-1],m=[0,0];d.op==="move"?m=d.data:d.op==="bcurveTo"&&(m=[d.data[4],d.data[5]]);let p=(j,ie)=>Math.pow(1-j,3)*l[ie]+3*j*Math.pow(1-j,2)*s[ie]+3*Math.pow(j,2)*(1-j)*c[ie]+m[ie]*Math.pow(j,3),[u,h]=r==="start"?m:l,[E,x]=[p(.3,0),p(.3,1)],T=Math.hypot(u-E,h-x),v=(u-E)/T,w=(h-x)/T,I=VM(o),L=0;{let[j,ie]=r==="end"?e.points[e.points.length-1]:e.points[0],[ke,$]=e.points.length>1?r==="end"?e.points[e.points.length-2]:e.points[1]:[0,0];L=Math.hypot(j-ke,ie-$)}let M=Math.min(I,L*(o==="diamond"||o==="diamond_outline"?.25:.5)),D=u-v*M,O=h-w*M;if(o==="dot"||o==="circle"||o==="circle_outline"){let j=Math.hypot(O-h,D-u)+e.strokeWidth-2;return[u,h,j]}let R=WM(o),[B,k]=Se(D,O,u,h,-R*Math.PI/180),[z,ee]=Se(D,O,u,h,R*Math.PI/180);if(o==="diamond"||o==="diamond_outline"){let j,ie;if(r==="start"){let[ke,$]=e.points.length>1?e.points[1]:[0,0];[j,ie]=Se(u+M*2,h,u,h,Math.atan2($-h,ke-u))}else{let[ke,$]=e.points.length>1?e.points[e.points.length-2]:[0,0];[j,ie]=Se(u-M*2,h,u,h,Math.atan2(h-$,u-ke))}return[u,h,B,k,j,ie,z,ee]}return[u,h,B,k,z,ee]},YM=e=>{let t=Rf.generator(),r=Kr(e),o=e.roundness?"curve":r.fill?"polygon":"linearPath";return t[o](e.points,r)},KM=(e,t,r,o)=>{let n=ue(e,o);if(e.points.length<2){let[m,p]=e.points[0],[u,h]=Se(e.x+m,e.y+p,t,r,e.angle),E=[u,h,u,h];if(n){let x=Z.getMinMaxXYWithBoundText(e,o,[u,h,u,h],n);E=[x[0],x[1],x[2],x[3]]}return E}let a=Ne.get(e)?.[0]??YM(e),l=Ci(a),c=Sc(l,(m,p)=>Se(e.x+m,e.y+p,t,r,e.angle)),d=[c[0],c[1],c[2],c[3]];if(n){let m=Z.getMinMaxXYWithBoundText(e,o,d,n);d=[m[0],m[1],m[2],m[3]]}return d},Zr=(e,t)=>_f.getBounds(e,t),Ae=e=>{if(!e.length)return[0,0,0,0];let t=1/0,r=-1/0,o=1/0,n=-1/0,i=X(e);return e.forEach(a=>{let[l,s,c,d]=Zr(a,i);t=Math.min(t,l),o=Math.min(o,s),r=Math.max(r,c),n=Math.max(n,d)}),[t,o,r,n]},lp=(e,t)=>{let[r,o,n,i]=Ae(e);return[r+t.x,o+t.y,n+t.x,i+t.y]},Gl=(e,t,r,o)=>{if(!(ce(e)||Ft(e)))return[e.x,e.y,e.x+t,e.y+r];let n=Si(0,t,Si(1,r,e.points,o),o),i;if(Ft(e))i=Of(n);else{let d=Rf.generator(),m=e.roundness?d.curve(n,Kr(e)):d.linearPath(n,Kr(e)),p=Ci(m);i=Sc(p)}let[a,l,s,c]=i;return[a+e.x,l+e.y,s+e.x,c+e.y]},kf=(e,t)=>{let r=Rf.generator(),o=e.roundness==null?r.linearPath(t,Kr(e)):r.curve(t,Kr(e)),n=Ci(o),[i,a,l,s]=Sc(n);return[i+e.x,a+e.y,l+e.x,s+e.y]},Bf=(e,t)=>{if(!e.length)return[0,0,0,0];let r=1/0,o=e[0],n=X(e);return e.forEach(i=>{let[a,l,s,c]=Zr(i,n),d=It((a+s)/2,(l+c)/2,t.x,t.y);d<r&&(r=d,o=i)}),Zr(o,n)},Lr=e=>{let[t,r,o,n]=Ae(e);return{minX:t,minY:r,maxX:o,maxY:n,width:o-t,height:n-r,midX:(t+o)/2,midY:(r+n)/2}},$M=({scrollX:e,scrollY:t,width:r,height:o,zoom:n})=>[-e,-t,-e+r/n.value,-t+o/n.value]});var XM,Er,ZM,Ff,jM,Ac,w2,Pr,Go,Dr=y(()=>{"use strict";f();W();XM=Al.includes(devicePixelRatio)?devicePixelRatio:1,Er=()=>({showWelcomeScreen:!1,theme:se.LIGHT,collaborators:new Map,currentChartType:"bar",currentItemBackgroundColor:at.backgroundColor,currentItemEndArrowhead:"arrow",currentItemFillStyle:at.fillStyle,currentItemFontFamily:tr,currentItemFontSize:Ot,currentItemOpacity:at.opacity,currentItemRoughness:at.roughness,currentItemStartArrowhead:null,currentItemStrokeColor:at.strokeColor,currentItemRoundness:"round",currentItemStrokeStyle:at.strokeStyle,currentItemStrokeWidth:at.strokeWidth,currentItemTextAlign:gi,cursorButton:"up",activeEmbeddable:null,draggingElement:null,editingElement:null,editingGroupId:null,editingLinearElement:null,activeTool:{type:"selection",customType:null,locked:at.locked,lastActiveTool:null},penMode:!1,penDetected:!1,errorMessage:null,exportBackground:!0,exportScale:XM,exportEmbedScene:!1,exportWithDarkMode:!1,fileHandle:null,gridSize:null,isBindingEnabled:!0,defaultSidebarDockedPreference:!1,isLoading:!1,isResizing:!1,isRotating:!1,lastPointerDownWith:"mouse",multiElement:null,name:null,contextMenu:null,openMenu:null,openPopup:null,openSidebar:null,openDialog:null,pasteDialog:{shown:!1,data:null},previousSelectedElementIds:{},resizingElement:null,scrolledOutside:!1,scrollX:0,scrollY:0,selectedElementIds:{},selectedGroupIds:{},selectedElementsAreBeingDragged:!1,selectionElement:null,shouldCacheIgnoreZoom:!1,showStats:!1,startBoundElement:null,suggestedBindings:[],frameRendering:{enabled:!0,clip:!0,name:!0,outline:!0},frameToHighlight:null,editingFrame:null,elementsToHighlight:null,toast:null,viewBackgroundColor:Gt,zenModeEnabled:!1,zoom:{value:ym},viewModeEnabled:!1,pendingImageElementId:null,showHyperlinkPopup:!1,selectedLinearElement:null,snapLines:[],originSnapOffset:{x:0,y:0},objectsSnapModeEnabled:!1,userToFollow:null,followedBy:new Set}),ZM=(e=>e)({showWelcomeScreen:{browser:!0,export:!1,server:!1},theme:{browser:!0,export:!1,server:!1},collaborators:{browser:!1,export:!1,server:!1},currentChartType:{browser:!0,export:!1,server:!1},currentItemBackgroundColor:{browser:!0,export:!1,server:!1},currentItemEndArrowhead:{browser:!0,export:!1,server:!1},currentItemFillStyle:{browser:!0,export:!1,server:!1},currentItemFontFamily:{browser:!0,export:!1,server:!1},currentItemFontSize:{browser:!0,export:!1,server:!1},currentItemRoundness:{browser:!0,export:!1,server:!1},currentItemOpacity:{browser:!0,export:!1,server:!1},currentItemRoughness:{browser:!0,export:!1,server:!1},currentItemStartArrowhead:{browser:!0,export:!1,server:!1},currentItemStrokeColor:{browser:!0,export:!1,server:!1},currentItemStrokeStyle:{browser:!0,export:!1,server:!1},currentItemStrokeWidth:{browser:!0,export:!1,server:!1},currentItemTextAlign:{browser:!0,export:!1,server:!1},cursorButton:{browser:!0,export:!1,server:!1},activeEmbeddable:{browser:!1,export:!1,server:!1},draggingElement:{browser:!1,export:!1,server:!1},editingElement:{browser:!1,export:!1,server:!1},editingGroupId:{browser:!0,export:!1,server:!1},editingLinearElement:{browser:!1,export:!1,server:!1},activeTool:{browser:!0,export:!1,server:!1},penMode:{browser:!0,export:!1,server:!1},penDetected:{browser:!0,export:!1,server:!1},errorMessage:{browser:!1,export:!1,server:!1},exportBackground:{browser:!0,export:!1,server:!1},exportEmbedScene:{browser:!0,export:!1,server:!1},exportScale:{browser:!0,export:!1,server:!1},exportWithDarkMode:{browser:!0,export:!1,server:!1},fileHandle:{browser:!1,export:!1,server:!1},gridSize:{browser:!0,export:!0,server:!0},height:{browser:!1,export:!1,server:!1},isBindingEnabled:{browser:!1,export:!1,server:!1},defaultSidebarDockedPreference:{browser:!0,export:!1,server:!1},isLoading:{browser:!1,export:!1,server:!1},isResizing:{browser:!1,export:!1,server:!1},isRotating:{browser:!1,export:!1,server:!1},lastPointerDownWith:{browser:!0,export:!1,server:!1},multiElement:{browser:!1,export:!1,server:!1},name:{browser:!0,export:!1,server:!1},offsetLeft:{browser:!1,export:!1,server:!1},offsetTop:{browser:!1,export:!1,server:!1},contextMenu:{browser:!1,export:!1,server:!1},openMenu:{browser:!0,export:!1,server:!1},openPopup:{browser:!1,export:!1,server:!1},openSidebar:{browser:!0,export:!1,server:!1},openDialog:{browser:!1,export:!1,server:!1},pasteDialog:{browser:!1,export:!1,server:!1},previousSelectedElementIds:{browser:!0,export:!1,server:!1},resizingElement:{browser:!1,export:!1,server:!1},scrolledOutside:{browser:!0,export:!1,server:!1},scrollX:{browser:!0,export:!1,server:!1},scrollY:{browser:!0,export:!1,server:!1},selectedElementIds:{browser:!0,export:!1,server:!1},selectedGroupIds:{browser:!0,export:!1,server:!1},selectedElementsAreBeingDragged:{browser:!1,export:!1,server:!1},selectionElement:{browser:!1,export:!1,server:!1},shouldCacheIgnoreZoom:{browser:!0,export:!1,server:!1},showStats:{browser:!0,export:!1,server:!1},startBoundElement:{browser:!1,export:!1,server:!1},suggestedBindings:{browser:!1,export:!1,server:!1},frameRendering:{browser:!1,export:!1,server:!1},frameToHighlight:{browser:!1,export:!1,server:!1},editingFrame:{browser:!1,export:!1,server:!1},elementsToHighlight:{browser:!1,export:!1,server:!1},toast:{browser:!1,export:!1,server:!1},viewBackgroundColor:{browser:!0,export:!0,server:!0},width:{browser:!1,export:!1,server:!1},zenModeEnabled:{browser:!0,export:!1,server:!1},zoom:{browser:!0,export:!1,server:!1},viewModeEnabled:{browser:!1,export:!1,server:!1},pendingImageElementId:{browser:!1,export:!1,server:!1},showHyperlinkPopup:{browser:!1,export:!1,server:!1},selectedLinearElement:{browser:!0,export:!1,server:!1},snapLines:{browser:!1,export:!1,server:!1},originSnapOffset:{browser:!1,export:!1,server:!1},objectsSnapModeEnabled:{browser:!0,export:!1,server:!1},userToFollow:{browser:!1,export:!1,server:!1},followedBy:{browser:!1,export:!1,server:!1}}),Ff=(e,t)=>{let r={};for(let o of Object.keys(e))if(ZM[o]?.[t]){let i=e[o];r[o]=i}return r},jM=e=>Ff(e,"browser"),Ac=e=>Ff(e,"export"),w2=e=>Ff(e,"server"),Pr=({activeTool:e})=>e.type==="eraser",Go=({activeTool:e})=>e.type==="hand"});var zf,nr,sp,Hf,Vn,cp,v2,_a,it,T2,S2,C2,I2,Ra,A2,k2,xr=y(()=>{"use strict";f();qe();mt();Ti();zf=(e,t,r)=>{let o=r.reduce((n,i)=>(i.groupIds.includes(e)&&(n[i.id]=!0),n),{});return Object.keys(o).length<2?t.selectedGroupIds[e]||t.editingGroupId===e?{selectedElementIds:t.selectedElementIds,selectedGroupIds:{...t.selectedGroupIds,[e]:!1},editingGroupId:null}:t:{editingGroupId:t.editingGroupId,selectedGroupIds:{...t.selectedGroupIds,[e]:!0},selectedElementIds:{...t.selectedElementIds,...o}}},nr=function(){let e=null,t=null,r=null,o=(i,a,l,s)=>{if(r!==void 0&&a===t&&i===e&&l.editingGroupId===r?.editingGroupId)return r;let c={};for(let p of i){let u=p.groupIds;if(l.editingGroupId){let h=u.indexOf(l.editingGroupId);h>-1&&(u=u.slice(0,h))}if(u.length>0){let h=u[u.length-1];c[h]=!0}}let d={},m=a.reduce((p,u)=>{let h=u.groupIds.find(E=>c[E]);return h&&(p[u.id]=!0,Array.isArray(d[h])?d[h].push(u.id):d[h]=[u.id]),p},{});for(let p of Object.keys(d))d[p].length<2&&c[p]&&(c[p]=!1);return t=a,e=i,r={editingGroupId:l.editingGroupId,selectedGroupIds:c,selectedElementIds:Fe({...l.selectedElementIds,...m},s)},r},n=(i,a,l,s)=>{let c=s?s.scene.getSelectedElements({selectedElementIds:i.selectedElementIds,elements:a}):ge(a,i);return c.length?o(c,a,i,l):{selectedGroupIds:{},editingGroupId:null,selectedElementIds:Fe(i.selectedElementIds,l)}};return n.clearCache=()=>{t=null,e=null,r=null},n}(),sp=(e,t)=>Hf(e,t)!=null,Hf=(e,t)=>t.groupIds.filter(r=>r!==e.editingGroupId).find(r=>e.selectedGroupIds[r]),Vn=e=>Object.entries(e.selectedGroupIds).filter(([t,r])=>r).map(([t,r])=>t),cp=(e,t)=>{let r={...t,selectedGroupIds:{}};for(let o of e){let n=o.groupIds;if(t.editingGroupId){let i=n.indexOf(t.editingGroupId);i>-1&&(n=n.slice(0,i))}if(n.length>0){let i=n[n.length-1];r={...r,...zf(i,r,e)}}}return r.selectedGroupIds},v2=(e,t)=>({...e,editingGroupId:t.groupIds.length?t.groupIds[0]:null,selectedGroupIds:{},selectedElementIds:{[t.id]:!0}}),_a=(e,t)=>e.groupIds.includes(t),it=(e,t)=>{let r=[];for(let o of e.values())_a(o,t)&&r.push(o);return r},T2=(e,t)=>e.groupIds.find(r=>t[r]),S2=(e,t,r)=>{let o=[...e],n=t?e.indexOf(t):-1,i=n>-1?n:e.length;for(let a=0;a<i;a++)o[a]=r(o[a]);return o},C2=(e,t,r)=>{let o=[...e],n=r?o.indexOf(r):-1,i=n>-1?n:o.length;return o.splice(i,0,t),o},I2=(e,t)=>e.filter(r=>!t[r]),Ra=(e,t)=>{let r=new Map;return e.forEach(o=>{let n=o.groupIds.length===0?o.id:o.groupIds[o.groupIds.length-1],i=r.get(n)||[],a=ue(o,t);a&&i.push(a),r.set(n,[...i,o])}),Array.from(r.values())},A2=e=>{let t=new Set;for(let[,r]of e)if(!r.isDeleted)for(let o of r.groupIds??[])t.add(o);return t},k2=e=>e.groupIds.length>0});import{sanitizeUrl as qM}from"@braintree/sanitize-url";var dp,yr,mp,pp,Na=y(()=>{"use strict";f();dp=e=>e.replace(/"/g,"&quot;"),yr=e=>(e=e.trim(),e&&qM(dp(e))),mp=e=>!!(e?.includes(location.origin)||e?.startsWith("/")),pp=e=>{if(e=yr(e),e.startsWith("/"))return`${location.origin}${e}`;try{new URL(e)}catch{return"about:blank"}return e}});var up,U,Je=y(()=>{"use strict";f();up=[],U=e=>(up=up.concat(e),e)});import hp from"open-color";var L2,JM,P2,QM,eL,jr,$e,un,M2,Uf,qr,Vl=y(()=>{"use strict";f();W();Dr();L2='<svg viewBox="0 0 24 24" stroke-width="1" width="28" height="28" xmlns="http://www.w3.org/2000/svg">',JM='<path d="M6.164 11.755a5.314 5.314 0 0 1-4.932-5.298 5.314 5.314 0 0 1 5.311-5.311 5.314 5.314 0 0 1 5.307 5.113l8.773 8.773a3.322 3.322 0 0 1 0 4.696l-.895.895a3.322 3.322 0 0 1-4.696 0l-8.868-8.868Z" style="fill:#fff"/>',P2='<path stroke="#1b1b1f" fill="#fff" d="m7.868 11.113 7.773 7.774a2.359 2.359 0 0 0 1.667.691 2.368 2.368 0 0 0 2.357-2.358c0-.625-.248-1.225-.69-1.667L11.201 7.78 9.558 9.469l-1.69 1.643v.001Zm10.273 3.606-3.333 3.333m-3.25-6.583 2 2m-7-7 3 3M3.664 3.625l1 1M2.529 6.922l1.407-.144m5.735-2.932-1.118.866M4.285 9.823l.758-1.194m1.863-6.207-.13 1.408"/>',QM=`data:${te.svg},${encodeURIComponent(`${L2}${P2}</svg>`)}`,eL=`data:${te.svg},${encodeURIComponent(`${L2}${JM}${P2}</svg>`)}`,jr=e=>{e&&(e.style.cursor="")},$e=(e,t)=>{e&&(e.style.cursor=t)},Uf=(e,t)=>{let o=()=>{let n=t===se.DARK;un=document.createElement("canvas"),un.theme=t,un.height=20,un.width=20;let i=un.getContext("2d");i.lineWidth=1,i.beginPath(),i.arc(un.width/2,un.height/2,5,0,2*Math.PI),i.fillStyle=n?hp.black:hp.white,i.fill(),i.strokeStyle=n?hp.white:hp.black,i.stroke(),M2=un.toDataURL(te.svg)};(!un||un.theme!==t)&&o(),$e(e,`url(${M2}) ${20/2} ${20/2}, auto`)},qr=(e,t)=>{if(e)if(t.activeTool.type==="selection")jr(e);else if(Go(t))e.style.cursor=Re.GRAB;else if(Pr(t))Uf(e,t.theme);else if(t.activeTool.type==="laser"){let r=t.theme===se.LIGHT?QM:eL;e.style.cursor=`url(${r}), auto`}else if(!["image","custom"].includes(t.activeTool.type))e.style.cursor=Re.CROSSHAIR;else if(t.activeTool.type==="custom"&&t.activeTool.customType==="comment"){let r=`data:${te.svg},${encodeURIComponent(`
16
16
  <svg
17
17
  width="24"
18
18
  height="24"
@@ -21,26 +21,26 @@ var yk=Object.defineProperty;var H0=e=>t=>{var o=e[t];if(o)return o();throw new
21
21
  >
22
22
  <path
23
23
  d="M5.25 18A3.25 3.25 0 0 1 2 14.75v-8.5A3.25 3.25 0 0 1 5.25 3h13.5A3.25 3.25 0 0 1 22 6.25v8.5A3.25 3.25 0 0 1 18.75 18h-5.738L8 21.75a1.25 1.25 0 0 1-1.999-1V18h-.75Zm7.264-1.5h6.236a1.75 1.75 0 0 0 1.75-1.75v-8.5a1.75 1.75 0 0 0-1.75-1.75H5.25A1.75 1.75 0 0 0 3.5 6.25v8.5c0 .966.784 1.75 1.75 1.75h2.249v3.75l5.015-3.75Z"
24
- fill="${t.theme===ie.LIGHT?"#000":"#fff"}"
24
+ fill="${t.theme===se.LIGHT?"#000":"#fff"}"
25
25
  />
26
26
  </svg>
27
- `)}`;e.style.cursor=`url(${o}) 5 20, auto`}else t.activeTool.type!=="image"&&(e.style.cursor=Pe.AUTO)}});var Hn,Uo,pf,X2,jm,xc,Z2,Gt,jA,Nl,uf,j2,cr,Ec,Xm,zn,Zm,Ol,yc,on=v(()=>{"use strict";f();G();Sr();Ze();Ho();he();Qt();bt();pt();U();Hn=(e,{x:t,y:o,strokeColor:r=rt.strokeColor,backgroundColor:n=rt.backgroundColor,fillStyle:i=rt.fillStyle,strokeWidth:a=rt.strokeWidth,strokeStyle:l=rt.strokeStyle,roughness:s=rt.roughness,opacity:c=rt.opacity,width:d=0,height:m=0,angle:p=0,groupIds:u=[],frameId:g=null,roundness:x=null,boundElements:E=null,link:y=null,locked:T=rt.locked,...w})=>({id:w.id||Bt(),type:e,x:t,y:o,width:d,height:m,angle:p,strokeColor:r,backgroundColor:n,fillStyle:i,strokeWidth:a,strokeStyle:l,roughness:s,opacity:c,groupIds:u,frameId:g,roundness:x,seed:w.seed??ar(),version:w.version||1,versionNonce:w.versionNonce??0,isDeleted:!1,boundElements:E,updated:Ln(),link:y,locked:T,customData:w.customData}),Uo=e=>Hn(e.type,e),pf=e=>Hn("embeddable",e),X2=e=>({...Hn("iframe",e)}),jm=e=>ae({...Hn("frame",e),type:"frame",name:e?.name||null},{}),xc=e=>ae({...Hn("magicframe",e),type:"magicframe",name:e?.name||null},{}),Z2=(e,t)=>({x:e.textAlign==="center"?t.width/2:e.textAlign==="right"?t.width:0,y:e.verticalAlign==="middle"?t.height/2:0}),Gt=e=>{let t=e.fontFamily||qt,o=e.fontSize||Rt,r=e.lineHeight||Oo(t),n=yi(e.text),i=Pr(n,Ke({fontFamily:t,fontSize:o}),r),a=e.textAlign||li,l=e.verticalAlign||ia,s=Z2({textAlign:a,verticalAlign:l},i);return ae({...Hn("text",e),text:n,fontSize:o,fontFamily:t,textAlign:a,verticalAlign:l,x:e.x-s.x,y:e.y-s.y,width:i.width,height:i.height,containerId:e.containerId||null,originalText:n,lineHeight:r},{})},jA=(e,t,o)=>{let{width:r,height:n}=Pr(o,Ke(e),e.lineHeight),{textAlign:i,verticalAlign:a}=e,l,s;if(i==="center"&&a===yt.MIDDLE&&!e.containerId){let c=Pr(e.text,Ke(e),e.lineHeight),d=Z2(e,{width:r-c.width,height:n-c.height});l=e.x-d.x,s=e.y-d.y}else{let[c,d,m,p]=te(e,t),[u,g,x,E]=va(e,r,n,!1),y=(c-u)/2,T=(d-g)/2,w=(m-x)/2,S=(p-E)/2;[l,s]=vm({s:!0,e:i==="center"||i==="left",w:i==="center"||i==="right"},e.x,e.y,e.angle,y,T,w,S)}return{width:r,height:n,x:Number.isFinite(l)?l:e.x,y:Number.isFinite(s)?s:e.y}},Nl=(e,t,o,r=e.text)=>{if(e.isDeleted)return;t&&(r=vi(r,Ke(e),wo(t,e)));let n=jA(e,o,r);return{text:r,...n}},uf=(e,t,o,{text:r,isDeleted:n,originalText:i})=>ae(e,{originalText:i,isDeleted:n??e.isDeleted,...Nl(e,t,o,i)}),j2=e=>({...Hn(e.type,e),points:e.points||[],pressures:[],simulatePressure:e.simulatePressure,lastCommittedPoint:null}),cr=e=>({...Hn(e.type,e),points:e.points||[],lastCommittedPoint:null,startBinding:null,endBinding:null,startArrowhead:e.startArrowhead||null,endArrowhead:e.endArrowhead||null}),Ec=e=>({...Hn("image",e),strokeColor:"transparent",status:e.status??"pending",fileId:e.fileId??null,scale:e.scale??[1,1]}),Xm=(e,t=0)=>{if(e==null||typeof e!="object")return e;let o=Object.prototype.toString.call(e);if(o==="[object Object]"){let r=typeof e.constructor=="function"?Object.create(Object.getPrototypeOf(e)):{};for(let n in e)if(e.hasOwnProperty(n)){if(t===0&&(n==="shape"||n==="canvas"))continue;r[n]=Xm(e[n],t+1)}return r}if(Array.isArray(e)){let r=e.length,n=new Array(r);for(;r--;)n[r]=Xm(e[r],t+1);return n}return C.DEV&&o!=="[object Object]"&&o!=="[object Array]"&&o.startsWith("[object ")&&console.warn(`_deepCloneElement: unexpected object type ${o}. This value will not be cloned!`),e},zn=e=>Xm(e),Zm=e=>{if(Ro()&&e){let t=`${e}_copy`;return window.h?.app?.getSceneElementsIncludingDeleted().find(o=>o.id===t)&&(t+="_copy"),t}return Bt()},Ol=(e,t,o,r)=>{let n=zn(o);return n.id=Zm(n.id),n.boundElements=null,n.updated=Ln(),n.seed=ar(),n.groupIds=U2(n.groupIds,e,i=>(t.has(i)||t.set(i,Zm(i)),t.get(i))),r&&(n=Object.assign(n,r)),n},yc=(e,t)=>{let o=[],r=re(e),n=new Map,i=l=>{if(n.has(l))return n.get(l);if(r.has(l)){let s=Zm(l);return n.set(l,s),s}return null},a=new Map;for(let l of e){let s=Xm(l);if(s.id=i(l.id),t?.randomizeSeed&&(s.seed=ar(),Nr(s)),s.groupIds&&(s.groupIds=s.groupIds.map(c=>(a.has(c)||a.set(c,Zm(c)),a.get(c)))),"containerId"in s&&s.containerId){let c=i(s.containerId);s.containerId=c}if("boundElements"in s&&s.boundElements&&(s.boundElements=s.boundElements.reduce((c,d)=>{let m=i(d.id);return m&&c.push({...d,id:m}),c},[])),"endBinding"in s&&s.endBinding){let c=i(s.endBinding.elementId);s.endBinding=c?{...s.endBinding,elementId:c}:null}if("startBinding"in s&&s.startBinding){let c=i(s.startBinding.elementId);s.startBinding=c?{...s.startBinding,elementId:c}:null}s.frameId&&(s.frameId=i(s.frameId)),o.push(s)}return o}});var Gn,qA,JA,QA,eM,tM,oM,rM,nM,iM,q2,gf,wc,Un,qm,tH,J2,Q2,Bl,vc=v(()=>{"use strict";f();je();U();G();Rl();on();pt();se();Gn=new Map,qA=/^(?: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]*$/,JA=/^(?:http(?:s)?:\/\/)?(?:(?:w){3}\.)?(?:player\.)?vimeo\.com\/(?:video\/)?([^?\s]+)(?:\?.*)?$/,QA=/^https:\/\/(?:www\.)?figma\.com/,eM=/^https:\/\/gist\.github\.com/,tM=/https?:\/\/gist\.github\.com\/([\w_-]+)\/([\w_-]+)\.js["']/i,oM=/(?:https?:\/\/)?(?:(?:w){3}\.)?(?:twitter|x)\.com/,rM=/^<blockquote[\s\S]*?\shref=["'](https?:\/\/(?:twitter|x)\.com\/[^"']*)/i,nM=/^https:\/\/(?:www\.)?val\.town\/(v|embed)\/[a-zA-Z_$][0-9a-zA-Z_$]+\.[a-zA-Z_$][0-9a-zA-Z_$]+/,iM=/^<(?:iframe|blockquote)[\s\S]*?\s(?:src|href)=["']([^"']*)["'][\s\S]*?>$/i,q2=/giphy.com\/(?:clips|embed|gifs)\/[a-zA-Z0-9]*?-?([a-zA-Z0-9]+)(?:[^a-zA-Z0-9]|$)/,gf=new Set(["youtube.com","youtu.be","vimeo.com","player.vimeo.com","figma.com","link.excalidraw.com","gist.github.com","twitter.com","x.com","*.simplepdf.eu","stackblitz.com","val.town","giphy.com","dddice.com"]),wc=e=>`<html><body>${e}</body></html>`,Un=e=>{if(!e)return null;if(Gn.has(e))return Gn.get(e);let t=e,o="generic",r={w:560,h:840},n=e.match(qA);if(n?.[2]){let s=n[3]?`&start=${n[3]}`:"",c=e.includes("shorts");switch(o="video",n[1]){case"embed/":case"watch?v=":case"shorts/":e=`https://www.youtube.com/embed/${n[2]}?enablejsapi=1${s}`;break;case"playlist?list=":case"embed/videoseries?list=":e=`https://www.youtube.com/embed/videoseries?list=${n[2]}&enablejsapi=1${s}`;break;default:e=`https://www.youtube.com/embed/${n[2]}?enablejsapi=1${s}`;break}return r=c?{w:315,h:560}:{w:560,h:315},Gn.set(t,{link:e,intrinsicSize:r,type:o}),{link:e,intrinsicSize:r,type:o}}let i=e.match(JA);if(i?.[1]){let s=i?.[1],c=/^\d+$/.test(s)?void 0:new URIError("Invalid embed link format");return o="video",e=`https://player.vimeo.com/video/${s}?api=1`,r={w:560,h:315},Gn.set(t,{link:e,intrinsicSize:r,type:o}),{link:e,intrinsicSize:r,type:o,error:c}}if(e.match(QA))return o="generic",e=`https://www.figma.com/embed?embed_host=share&url=${encodeURIComponent(e)}`,r={w:550,h:550},Gn.set(t,{link:e,intrinsicSize:r,type:o}),{link:e,intrinsicSize:r,type:o};let l=e.match(nM);if(l)return e=l[1]==="embed"?l[0]:l[0].replace("/v","/embed"),Gn.set(t,{link:e,intrinsicSize:r,type:o}),{link:e,intrinsicSize:r,type:o};if(oM.test(e)){e=e.replace(/\bx.com\b/,"twitter.com");let s={type:"document",srcdoc:c=>wc(`<blockquote class="twitter-tweet" data-dnt="true" data-theme="${c}"><a href="${e}"></a></blockquote> <script async src="https://platform.twitter.com/widgets.js" charset="utf-8"><\/script>`),intrinsicSize:{w:480,h:480},sandbox:{allowSameOrigin:!0}};return Gn.set(t,s),s}if(eM.test(e)){let s={type:"document",srcdoc:()=>wc(`
28
- <script src="${e}.js"><\/script>
27
+ `)}`;e.style.cursor=`url(${r}) 5 20, auto`}else t.activeTool.type!=="image"&&(e.style.cursor=Re.AUTO)}});var Wn,Jr,Gf,D2,bp,kc,_2,$t,tL,Wl,Vf,R2,xo,Mc,gp,Yn,fp,Yl,Lc,hn=y(()=>{"use strict";f();G();Oo();Ye();xr();xe();Kt();dt();mt();W();Wn=(e,{x:t,y:r,strokeColor:o=at.strokeColor,backgroundColor:n=at.backgroundColor,fillStyle:i=at.fillStyle,strokeWidth:a=at.strokeWidth,strokeStyle:l=at.strokeStyle,roughness:s=at.roughness,opacity:c=at.opacity,width:d=0,height:m=0,angle:p=0,groupIds:u=[],frameId:h=null,index:E=null,roundness:x=null,boundElements:T=null,link:v=null,locked:w=at.locked,...I})=>({id:I.id||zt(),type:e,x:t,y:r,width:d,height:m,angle:p,strokeColor:o,backgroundColor:n,fillStyle:i,strokeWidth:a,strokeStyle:l,roughness:s,opacity:c,groupIds:u,frameId:h,index:E,roundness:x,seed:I.seed??fo(),version:I.version||1,versionNonce:I.versionNonce??0,isDeleted:!1,boundElements:T,updated:Fn(),link:v,locked:w,customData:I.customData}),Jr=e=>Wn(e.type,e),Gf=e=>Wn("embeddable",e),D2=e=>({...Wn("iframe",e)}),bp=e=>le({...Wn("frame",e),type:"frame",name:e?.name||null},{}),kc=e=>le({...Wn("magicframe",e),type:"magicframe",name:e?.name||null},{}),_2=(e,t)=>({x:e.textAlign==="center"?t.width/2:e.textAlign==="right"?t.width:0,y:e.verticalAlign==="middle"?t.height/2:0}),$t=e=>{let t=e.fontFamily||tr,r=e.fontSize||Ot,o=e.lineHeight||Xr(t),n=Li(e.text),i=Ho(n,Ze({fontFamily:t,fontSize:r}),o),a=e.textAlign||gi,l=e.verticalAlign||fa,s=_2({textAlign:a,verticalAlign:l},i);return le({...Wn("text",e),text:n,fontSize:r,fontFamily:t,textAlign:a,verticalAlign:l,x:e.x-s.x,y:e.y-s.y,width:i.width,height:i.height,containerId:e.containerId||null,originalText:n,lineHeight:o},{})},tL=(e,t,r)=>{let{width:o,height:n}=Ho(r,Ze(e),e.lineHeight),{textAlign:i,verticalAlign:a}=e,l,s;if(i==="center"&&a===Tt.MIDDLE&&!e.containerId){let c=Ho(e.text,Ze(e),e.lineHeight),d=_2(e,{width:o-c.width,height:n-c.height});l=e.x-d.x,s=e.y-d.y}else{let[c,d,m,p]=oe(e,t),[u,h,E,x]=Gl(e,o,n,!1),T=(c-u)/2,v=(d-h)/2,w=(m-E)/2,I=(p-x)/2;[l,s]=Ew({s:!0,e:i==="center"||i==="left",w:i==="center"||i==="right"},e.x,e.y,e.angle,T,v,w,I)}return{width:o,height:n,x:Number.isFinite(l)?l:e.x,y:Number.isFinite(s)?s:e.y}},Wl=(e,t,r,o=e.text)=>{if(e.isDeleted)return;t&&(o=Di(o,Ze(e),Mr(t,e)));let n=tL(e,r,o);return{text:o,...n}},Vf=(e,t,r,{text:o,isDeleted:n,originalText:i})=>le(e,{originalText:i,isDeleted:n??e.isDeleted,...Wl(e,t,r,i)}),R2=e=>({...Wn(e.type,e),points:e.points||[],pressures:[],simulatePressure:e.simulatePressure,lastCommittedPoint:null}),xo=e=>({...Wn(e.type,e),points:e.points||[],lastCommittedPoint:null,startBinding:null,endBinding:null,startArrowhead:e.startArrowhead||null,endArrowhead:e.endArrowhead||null}),Mc=e=>({...Wn("image",e),strokeColor:"transparent",status:e.status??"pending",fileId:e.fileId??null,scale:e.scale??[1,1]}),gp=(e,t=0)=>{if(e==null||typeof e!="object")return e;let r=Object.prototype.toString.call(e);if(r==="[object Object]"){let o=typeof e.constructor=="function"?Object.create(Object.getPrototypeOf(e)):{};for(let n in e)if(e.hasOwnProperty(n)){if(t===0&&(n==="shape"||n==="canvas"))continue;o[n]=gp(e[n],t+1)}return o}if(Array.isArray(e)){let o=e.length,n=new Array(o);for(;o--;)n[o]=gp(e[o],t+1);return n}return S.DEV&&r!=="[object Object]"&&r!=="[object Array]"&&r.startsWith("[object ")&&console.warn(`_deepCloneElement: unexpected object type ${r}. This value will not be cloned!`),e},Yn=e=>gp(e),fp=e=>{if(Wr()&&e){let t=`${e}_copy`;return window.h?.app?.getSceneElementsIncludingDeleted().find(r=>r.id===t)&&(t+="_copy"),t}return zt()},Yl=(e,t,r,o)=>{let n=Yn(r);return n.id=fp(n.id),n.boundElements=null,n.updated=Fn(),n.seed=fo(),n.groupIds=S2(n.groupIds,e,i=>(t.has(i)||t.set(i,fp(i)),t.get(i))),o&&(n=Object.assign(n,o)),n},Lc=(e,t)=>{let r=[],o=X(e),n=new Map,i=l=>{if(n.has(l))return n.get(l);if(o.has(l)){let s=fp(l);return n.set(l,s),s}return null},a=new Map;for(let l of e){let s=gp(l);if(s.id=i(l.id),t?.randomizeSeed&&(s.seed=fo(),_i(s)),s.groupIds&&(s.groupIds=s.groupIds.map(c=>(a.has(c)||a.set(c,fp(c)),a.get(c)))),"containerId"in s&&s.containerId){let c=i(s.containerId);s.containerId=c}if("boundElements"in s&&s.boundElements&&(s.boundElements=s.boundElements.reduce((c,d)=>{let m=i(d.id);return m&&c.push({...d,id:m}),c},[])),"endBinding"in s&&s.endBinding){let c=i(s.endBinding.elementId);s.endBinding=c?{...s.endBinding,elementId:c}:null}if("startBinding"in s&&s.startBinding){let c=i(s.startBinding.elementId);s.startBinding=c?{...s.startBinding,elementId:c}:null}s.frameId&&(s.frameId=i(s.frameId)),r.push(s)}return r}});var xt,Pc,Dc,N2=y(()=>{"use strict";f();W();Eo();or();Ye();mt();me();bo();xr();ze();G();xt=class e{constructor(t,r){this.deleted=t;this.inserted=r}static create(t,r,o,n){let i=o&&n!=="inserted"?o(t):t,a=o&&n!=="deleted"?o(r):r;return new e(i,a)}static calculate(t,r,o,n){if(t===r)return e.empty();let i={},a={};for(let c of this.distinctKeysIterator("full",t,r))i[c]=t[c],a[c]=r[c];let[l,s]=n?n(i,a):[i,a];return e.create(l,s,o)}static empty(){return new e({},{})}static isEmpty(t){return!Object.keys(t.deleted).length&&!Object.keys(t.inserted).length}static mergeObjects(t,r,o){let n={...t};for(let i of Object.keys(o))delete n[i];return{...n,...r}}static mergeArrays(t,r,o,n){return Object.values(e.mergeObjects(en(t??[],n),en(r??[],n),en(o??[],n)))}static diffObjects(t,r,o,n){if(!(!t[o]&&!r[o])&&(typeof t[o]=="object"||typeof r[o]=="object")){let i=t[o]??{},a=r[o]??{},l=e.getLeftDifferences(i,a).reduce((c,d)=>(c[d]=n(i[d]),c),{}),s=e.getRightDifferences(i,a).reduce((c,d)=>(c[d]=n(a[d]),c),{});Object.keys(l).length||Object.keys(s).length?(Reflect.set(t,o,l),Reflect.set(r,o,s)):(Reflect.deleteProperty(t,o),Reflect.deleteProperty(r,o))}}static diffArrays(t,r,o,n){if(!(!t[o]&&!r[o])&&(Array.isArray(t[o])||Array.isArray(r[o]))){let i=Array.isArray(t[o])?t[o]:[],a=Array.isArray(r[o])?r[o]:[],l=en(e.getLeftDifferences(en(i,n),en(a,n))),s=en(e.getRightDifferences(en(i,n),en(a,n)));if(Object.keys(l).length||Object.keys(s).length){let c=i.filter(m=>l[n?n(m):String(m)]),d=a.filter(m=>s[n?n(m):String(m)]);Reflect.set(t,o,c),Reflect.set(r,o,d)}else Reflect.deleteProperty(t,o),Reflect.deleteProperty(r,o)}}static isLeftDifferent(t,r,o=!1){return!!this.distinctKeysIterator("left",t,r,o).next().value}static isRightDifferent(t,r,o=!1){return!!this.distinctKeysIterator("right",t,r,o).next().value}static getLeftDifferences(t,r,o=!1){return Array.from(this.distinctKeysIterator("left",t,r,o))}static getRightDifferences(t,r,o=!1){return Array.from(this.distinctKeysIterator("right",t,r,o))}static*distinctKeysIterator(t,r,o,n=!1){if(r===o)return;let i=[];t==="left"?i=Object.keys(r):t==="right"?i=Object.keys(o):t==="full"?i=Array.from(new Set([...Object.keys(r),...Object.keys(o)])):No(t,`Unknown distinctKeysIterator's join param "${t}"`,!0);for(let a of i){let l=r[a],s=o[a];if(l!==s){if(!n&&typeof l=="object"&&typeof s=="object"&&l!==null&&s!==null&&rt(l,s))continue;yield a}}}},Pc=class e{constructor(t){this.delta=t}static calculate(t,r){let o=xt.calculate(t,r,void 0,e.postProcess);return new e(o)}static empty(){return new e(xt.create({},{}))}inverse(){let t=xt.create(this.delta.inserted,this.delta.deleted);return new e(t)}applyTo(t,r){try{let{selectedElementIds:o={},selectedGroupIds:n={}}=this.delta.deleted,{selectedElementIds:i={},selectedGroupIds:a={},selectedLinearElementId:l,editingLinearElementId:s,...c}=this.delta.inserted,d=xt.mergeObjects(t.selectedElementIds,i,o),m=xt.mergeObjects(t.selectedGroupIds,a,n),p=l&&r.has(l)?new Z(r.get(l)):null,u=s&&r.has(s)?new Z(r.get(s)):null,h={...t,...c,selectedElementIds:d,selectedGroupIds:m,selectedLinearElement:typeof l<"u"?p:t.selectedLinearElement,editingLinearElement:typeof s<"u"?u:t.editingLinearElement},E=this.filterInvisibleChanges(t,h,r);return[h,E]}catch(o){if(console.error("Couldn't apply appstate change",o),S.DEV||S.MODE===kr.TEST)throw o;return[t,!1]}}isEmpty(){return xt.isEmpty(this.delta)}static postProcess(t,r){try{xt.diffObjects(t,r,"selectedElementIds",o=>!0),xt.diffObjects(t,r,"selectedGroupIds",o=>o??!1)}catch(o){if(console.error("Couldn't postprocess appstate change deltas."),S.DEV||S.MODE===kr.TEST)throw o}finally{return[t,r]}}filterInvisibleChanges(t,r,o){let n=_c(t),i=_c(r),a=xt.isRightDifferent(e.stripElementsProps(n),e.stripElementsProps(i)),l=xt.isRightDifferent(e.stripStandaloneProps(n),e.stripStandaloneProps(i));if(!a&&!l)return!1;let s={value:a};if(l){let c=xt.getRightDifferences(e.stripStandaloneProps(n),e.stripStandaloneProps(i)),d=new Set;(c.includes("editingGroupId")||c.includes("selectedGroupIds"))&&(d=A2(o));for(let m of c)switch(m){case"selectedElementIds":r[m]=e.filterSelectedElements(r[m],o,s);break;case"selectedGroupIds":r[m]=e.filterSelectedGroups(r[m],d,s);break;case"editingGroupId":let p=r[m];p?d.has(p)?s.value=!0:r[m]=null:s.value=!0;break;case"selectedLinearElementId":case"editingLinearElementId":let u=e.convertToAppStateKey(m),h=r[u];if(!h)s.value=!0;else{let E=o.get(h.elementId);E&&!E.isDeleted?s.value=!0:r[u]=null}break;default:No(m,`Unknown ObservedElementsAppState's key "${m}"`,!0)}}return s.value}static convertToAppStateKey(t){switch(t){case"selectedLinearElementId":return"selectedLinearElement";case"editingLinearElementId":return"editingLinearElement"}}static filterSelectedElements(t,r,o){let n=Object.keys(t);if(!n.length)return o.value=!0,t;let i={...t};for(let a of n){let l=r.get(a);l&&!l.isDeleted?o.value=!0:delete i[a]}return i}static filterSelectedGroups(t,r,o){if(!Object.keys(t).length)return o.value=!0,t;let i={...t};for(let a of Object.keys(i))r.has(a)?o.value=!0:delete i[a];return i}static stripElementsProps(t){let{editingGroupId:r,selectedGroupIds:o,selectedElementIds:n,editingLinearElementId:i,selectedLinearElementId:a,...l}=t;return l}static stripStandaloneProps(t){let{name:r,viewBackgroundColor:o,...n}=t;return n}},Dc=class e{constructor(t,r,o){this.added=t;this.removed=r;this.updated=o}static create(t,r,o,n={shouldRedistribute:!1}){let i;if(n.shouldRedistribute){let a=new Map,l=new Map,s=new Map,c=[...t,...r,...o];for(let[d,m]of c)this.satisfiesAddition(m)?a.set(d,m):this.satisfiesRemoval(m)?l.set(d,m):s.set(d,m);i=new e(a,l,s)}else i=new e(t,r,o);return(S.DEV||S.MODE===kr.TEST)&&(e.validate(i,"added",this.satisfiesAddition),e.validate(i,"removed",this.satisfiesRemoval),e.validate(i,"updated",this.satisfiesUpdate)),i}static satisfiesAddition=({deleted:t,inserted:r})=>t.isDeleted===!0&&!r.isDeleted;static satisfiesRemoval=({deleted:t,inserted:r})=>!t.isDeleted&&r.isDeleted===!0;static satisfiesUpdate=({deleted:t,inserted:r})=>!!t.isDeleted==!!r.isDeleted;static validate(t,r,o){for(let[n,i]of t[r].entries())if(!o(i))throw console.error(`Broken invariant for "${r}" delta, element "${n}", delta:`,i),new Error(`ElementsChange invariant broken for element "${n}".`)}static calculate(t,r){if(t===r)return e.empty();let o=new Map,n=new Map,i=new Map;for(let a of t.values())if(!r.get(a.id)){let s={...a,isDeleted:!1},c={isDeleted:!0},d=xt.create(s,c,e.stripIrrelevantProps);n.set(a.id,d)}for(let a of r.values()){let l=t.get(a.id);if(!l){let s={isDeleted:!0},c={...a,isDeleted:!1},d=xt.create(s,c,e.stripIrrelevantProps);o.set(a.id,d);continue}if(l.versionNonce!==a.versionNonce){let s=xt.calculate(l,a,e.stripIrrelevantProps,e.postProcess);if(typeof l.isDeleted=="boolean"&&typeof a.isDeleted=="boolean"&&l.isDeleted!==a.isDeleted){l.isDeleted&&!a.isDeleted?o.set(a.id,s):n.set(a.id,s);continue}xt.isEmpty(s)||i.set(a.id,s)}}return e.create(o,n,i)}static empty(){return e.create(new Map,new Map,new Map)}inverse(){let t=i=>{let a=new Map;for(let[l,s]of i.entries())a.set(l,xt.create(s.inserted,s.deleted));return a},r=t(this.added),o=t(this.removed),n=t(this.updated);return e.create(o,r,n)}isEmpty(){return this.added.size===0&&this.removed.size===0&&this.updated.size===0}applyLatestChanges(t){let r=l=>s=>{let c={};for(let d of Object.keys(s))switch(d){case"boundElements":c[d]=s[d];break;default:c[d]=l[d]}return c},o=l=>{let s=new Map;for(let[c,d]of l.entries()){let m=t.get(c);if(m){let p=xt.create(d.deleted,d.inserted,r(m),"inserted");s.set(c,p)}else s.set(c,d)}return s},n=o(this.added),i=o(this.removed),a=o(this.updated);return e.create(n,i,a,{shouldRedistribute:!0})}applyTo(t,r){let o=Yr(new Map(t)),n,i={containsVisibleDifference:!1,containsZindexDifference:!1};try{let a=e.createApplier(o,r,i),l=a(this.added),s=a(this.removed),c=a(this.updated),d=this.resolveConflicts(t,o);n=new Map([...l,...s,...c,...d])}catch(a){if(console.error("Couldn't apply elements change",a),S.DEV||S.MODE===kr.TEST)throw a;return[t,!0]}try{e.redrawTextBoundingBoxes(o,n),e.redrawBoundArrows(o,n),o=e.reorderElements(o,n,i)}catch(a){if(console.error("Couldn't mutate elements after applying elements change",a),S.DEV||S.MODE===kr.TEST)throw a}finally{return[o,i.containsVisibleDifference]}}static createApplier=(t,r,o)=>{let n=e.createGetter(t,r,o);return i=>Array.from(i.entries()).reduce((a,[l,s])=>{let c=n(l,s.inserted);if(c){let d=e.applyDelta(c,s,o);t.set(d.id,d),a.set(d.id,d)}return a},new Map)};static createGetter=(t,r,o)=>(n,i)=>{let a=t.get(n);return a||(a=r.get(n),a&&(o.containsZindexDifference=!0,(i.isDeleted===!1||i.isDeleted!==!0&&a.isDeleted===!1)&&(o.containsVisibleDifference=!0))),a};static applyDelta(t,r,o={containsVisibleDifference:!0,containsZindexDifference:!0}){let{boundElements:n,...i}=r.inserted;if(r.deleted.boundElements?.length||r.inserted.boundElements?.length){let a=xt.mergeArrays(t.boundElements,r.inserted.boundElements,r.deleted.boundElements,l=>l.id);Object.assign(i,{boundElements:a})}if(!o.containsVisibleDifference){let{index:a,...l}=i,s=e.checkForVisibleDifference(t,l);o.containsVisibleDifference=s}return o.containsZindexDifference||(o.containsZindexDifference=r.deleted.index!==r.inserted.index),le(t,i)}static checkForVisibleDifference(t,r){return t.isDeleted&&r.isDeleted!==!1?!1:t.isDeleted&&r.isDeleted===!1||t.isDeleted===!1&&r.isDeleted?!0:xt.isRightDifferent(t,r)}resolveConflicts(t,r){let o=new Map,n=(c,d)=>{let m=r.get(c.id);if(!m)return;let p;t.get(c.id)===m?p=le(m,d):p=H(m,d),o.set(p.id,p),r.set(p.id,p)};for(let[c]of this.removed)e.unbindAffected(t,r,c,n);for(let[c]of this.added)e.rebindAffected(t,r,c,n);for(let[c]of Array.from(this.updated).filter(([d,m])=>Object.keys({...m.deleted,...m.inserted}).find(p=>s2.has(p)))){let d=r.get(c);!d||d.isDeleted||e.rebindAffected(t,r,c,n)}let i=new Map(Array.from(t).filter(([c])=>o.has(c))),{added:a,removed:l,updated:s}=e.calculate(i,o);for(let[c,d]of a)this.added.set(c,d);for(let[c,d]of l)this.removed.set(c,d);for(let[c,d]of s)this.updated.set(c,d);return o}static unbindAffected(t,r,o,n){let i=()=>t.get(o),a=()=>r.get(o);ki.unbindAffected(r,i(),n),ki.unbindAffected(r,a(),n),Mi.unbindAffected(r,i(),n),Mi.unbindAffected(r,a(),n)}static rebindAffected(t,r,o,n){let i=()=>t.get(o),a=()=>r.get(o);ki.unbindAffected(r,i(),n),ki.rebindAffected(r,a(),n),Mi.unbindAffected(r,i(),(l,s)=>{V(l)&&n(l,s)}),Mi.rebindAffected(r,a(),n)}static redrawTextBoundingBoxes(t,r){let o=new Map;for(let n of r.values()){if(Pe(n)){let{containerId:i}=n,a=i?t.get(i):void 0;a&&o.set(a.id,{container:a,boundText:n})}if(lr(n)){let i=Uo(n),a=i?t.get(i):void 0;a&&o.set(n.id,{container:n,boundText:a})}}for(let{container:n,boundText:i}of o.values())n.isDeleted||i.isDeleted||Ht(i,n,t,!1)}static redrawBoundArrows(t,r){for(let o of r.values())!o.isDeleted&&zn(o)&&$r(o,t)}static reorderElements(t,r,o){if(!o.containsZindexDifference)return t;let n=Array.from(t.values()),i=zm([...n]);return!o.containsVisibleDifference&&xt.isRightDifferent(n,i,!0)&&(o.containsVisibleDifference=!0),X(Yt(i,r))}static postProcess(t,r){try{xt.diffArrays(t,r,"boundElements",o=>o.id)}catch(o){if(console.error("Couldn't postprocess elements change deltas."),S.DEV||S.MODE===kr.TEST)throw o}finally{return[t,r]}}static stripIrrelevantProps(t){let{id:r,updated:o,version:n,versionNonce:i,seed:a,...l}=t;return l}}});var cr,Rc=y(()=>{"use strict";f();cr=class{subscribers=[];on(...t){let r=t.flat().filter(o=>typeof o=="function");return this.subscribers.push(...r),()=>this.off(r)}once(...t){let r=t.flat().filter(n=>typeof n=="function");r.push(()=>o());let o=this.on(...r);return o}off(...t){let r=t.flat();this.subscribers=this.subscribers.filter(o=>!r.includes(o))}trigger(...t){for(let r of this.subscribers)r(...t);return this}clear(){this.subscribers=[]}}});var O2,_c,rL,_,Wf,Ep,xp,ze=y(()=>{"use strict";f();Dr();N2();W();Ye();hn();Rc();G();O2="__observedAppState",_c=e=>{let t={name:e.name,editingGroupId:e.editingGroupId,viewBackgroundColor:e.viewBackgroundColor,selectedElementIds:e.selectedElementIds,selectedGroupIds:e.selectedGroupIds,editingLinearElementId:e.editingLinearElement?.elementId||null,selectedLinearElementId:e.selectedLinearElement?.elementId||null};return Reflect.defineProperty(t,O2,{value:!0,enumerable:!1}),t},rL=e=>!!Reflect.get(e,O2),_={CAPTURE:"capture",UPDATE:"update",NONE:"none"},Wf=class{constructor(t,r){this.elementsChange=t;this.appStateChange=r}},Ep=class{onStoreIncrementEmitter=new cr;scheduledActions=new Set;_snapshot=xp.empty();get snapshot(){return this._snapshot}set snapshot(t){this._snapshot=t}shouldCaptureIncrement=()=>{this.scheduleAction(_.CAPTURE)};shouldUpdateSnapshot=()=>{this.scheduleAction(_.UPDATE)};scheduleAction=t=>{this.scheduledActions.add(t),this.satisfiesScheduledActionsInvariant()};commit=(t,r)=>{try{this.scheduledActions.has(_.CAPTURE)?this.captureIncrement(t,r):this.scheduledActions.has(_.UPDATE)&&this.updateSnapshot(t,r)}finally{this.satisfiesScheduledActionsInvariant(),this.scheduledActions=new Set}};captureIncrement=(t,r)=>{let o=this.snapshot,n=this.snapshot.maybeClone(t,r);if(o!==n){let i=n.meta.didElementsChange?Dc.calculate(o.elements,n.elements):Dc.empty(),a=n.meta.didAppStateChange?Pc.calculate(o.appState,n.appState):Pc.empty();(!i.isEmpty()||!a.isEmpty())&&this.onStoreIncrementEmitter.trigger(new Wf(i,a)),this.snapshot=n}};updateSnapshot=(t,r)=>{let o=this.snapshot.maybeClone(t,r);this.snapshot!==o&&(this.snapshot=o)};filterUncomittedElements=(t,r)=>{for(let[o,n]of t.entries()){if(!r.get(o))continue;let a=this.snapshot.elements.get(o);a?a.version<n.version&&r.set(o,a):r.delete(o)}return r};clear=()=>{this.snapshot=xp.empty(),this.scheduledActions=new Set};satisfiesScheduledActionsInvariant=()=>{if(!(this.scheduledActions.size>=0&&this.scheduledActions.size<=3)){let t=`There can be at most three store actions scheduled at the same time, but there are "${this.scheduledActions.size}".`;if(console.error(t,this.scheduledActions.values()),S.DEV||S.MODE===kr.TEST)throw new Error(t)}}},xp=class e{constructor(t,r,o={didElementsChange:!1,didAppStateChange:!1,isEmpty:!1}){this.elements=t;this.appState=r;this.meta=o}static empty(){return new e(new Map,_c(Er()),{didElementsChange:!1,didAppStateChange:!1,isEmpty:!0})}isEmpty(){return this.meta.isEmpty}maybeClone(t,r){let o=this.maybeCreateElementsSnapshot(t),n=this.maybeCreateAppStateSnapshot(r),i=!1,a=!1;return this.elements!==o&&(i=!0),this.appState!==n&&(a=!0),!i&&!a?this:new e(o,n,{didElementsChange:i,didAppStateChange:a})}maybeCreateAppStateSnapshot(t){if(!t)return this.appState;let r=rL(t)?t:_c(t);return this.detectChangedAppState(r)?r:this.appState}detectChangedAppState(t){return!rt(this.appState,t,{selectedElementIds:rt,selectedGroupIds:rt})}maybeCreateElementsSnapshot(t){return t?this.detectChangedElements(t)?this.createElementsSnapshot(t):this.elements:this.elements}detectChangedElements(t){if(this.elements===t)return!1;if(this.elements.size!==t.size)return!0;let r=Array.from(t.keys());for(let o=r.length-1;o>=0;o--){let n=this.elements.get(r[o]),i=t.get(r[o]);if(!n||!i||n.id!==i.id||n.versionNonce!==i.versionNonce)return!0}return!1}createElementsSnapshot(t){let r=new Map;for(let[o,n]of this.elements.entries())t.get(o)?r.set(o,n):r.set(o,le(n,{isDeleted:!0}));for(let[o,n]of t.entries()){let i=r.get(o);(!i||i&&i.versionNonce!==n.versionNonce)&&r.set(o,Yn(n))}return r}}});var Kn,oL,nL,iL,B2,aL,F2,lL,sL,cL,z2,Yf,H2,Nc,$n,yp,DH,Kf,U2,Kl,Oc=y(()=>{"use strict";f();Je();W();G();Vl();hn();mt();me();Na();ze();Kn=new Map,oL=/^(?: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]*$/,nL=/^(?:http(?:s)?:\/\/)?(?:(?:w){3}\.)?(?:player\.)?vimeo\.com\/(?:video\/)?([^?\s]+)(?:\?.*)?$/,iL=/^https:\/\/(?:www\.)?figma\.com/,B2=/^https:\/\/gist\.github\.com\/([\w_-]+)\/([\w_-]+)/,aL=/^<script[\s\S]*?\ssrc=["'](https:\/\/gist\.github\.com\/.*?)\.js["']/i,F2=/(?:https?:\/\/)?(?:(?:w){3}\.)?(?:twitter|x)\.com\/[^/]+\/status\/(\d+)/,lL=/^<blockquote[\s\S]*?\shref=["'](https?:\/\/(?:twitter|x)\.com\/[^"']*)/i,sL=/^https:\/\/(?:www\.)?val\.town\/(v|embed)\/[a-zA-Z_$][0-9a-zA-Z_$]+\.[a-zA-Z_$][0-9a-zA-Z_$]+/,cL=/^<(?:iframe|blockquote)[\s\S]*?\s(?:src|href)=["']([^"']*)["'][\s\S]*?>$/i,z2=/giphy.com\/(?:clips|embed|gifs)\/[a-zA-Z0-9]*?-?([a-zA-Z0-9]+)(?:[^a-zA-Z0-9]|$)/,Yf=new Set(["youtube.com","youtu.be","vimeo.com","player.vimeo.com","figma.com","link.excalidraw.com","gist.github.com","twitter.com","x.com","*.simplepdf.eu","stackblitz.com","val.town","giphy.com"]),H2=new Set(["youtube.com","youtu.be","vimeo.com","player.vimeo.com","figma.com","twitter.com","x.com","*.simplepdf.eu","stackblitz.com"]),Nc=e=>`<html><body>${e}</body></html>`,$n=e=>{if(!e)return null;if(Kn.has(e))return Kn.get(e);let t=e,r=H2.has(Kf(e,H2)||""),o="generic",n={w:560,h:840},i=e.match(oL);if(i?.[2]){let c=i[3]?`&start=${i[3]}`:"",d=e.includes("shorts");switch(o="video",i[1]){case"embed/":case"watch?v=":case"shorts/":e=`https://www.youtube.com/embed/${i[2]}?enablejsapi=1${c}`;break;case"playlist?list=":case"embed/videoseries?list=":e=`https://www.youtube.com/embed/videoseries?list=${i[2]}&enablejsapi=1${c}`;break;default:e=`https://www.youtube.com/embed/${i[2]}?enablejsapi=1${c}`;break}return n=d?{w:315,h:560}:{w:560,h:315},Kn.set(t,{link:e,intrinsicSize:n,type:o,sandbox:{allowSameOrigin:r}}),{link:e,intrinsicSize:n,type:o,sandbox:{allowSameOrigin:r}}}let a=e.match(nL);if(a?.[1]){let c=a?.[1],d=/^\d+$/.test(c)?void 0:new URIError("Invalid embed link format");return o="video",e=`https://player.vimeo.com/video/${c}?api=1`,n={w:560,h:315},Kn.set(t,{link:e,intrinsicSize:n,type:o,sandbox:{allowSameOrigin:r}}),{link:e,intrinsicSize:n,type:o,error:d,sandbox:{allowSameOrigin:r}}}if(e.match(iL))return o="generic",e=`https://www.figma.com/embed?embed_host=share&url=${encodeURIComponent(e)}`,n={w:550,h:550},Kn.set(t,{link:e,intrinsicSize:n,type:o,sandbox:{allowSameOrigin:r}}),{link:e,intrinsicSize:n,type:o,sandbox:{allowSameOrigin:r}};let s=e.match(sL);if(s)return e=s[1]==="embed"?s[0]:s[0].replace("/v","/embed"),Kn.set(t,{link:e,intrinsicSize:n,type:o,sandbox:{allowSameOrigin:r}}),{link:e,intrinsicSize:n,type:o,sandbox:{allowSameOrigin:r}};if(F2.test(e)){let c=e.match(F2)[1],d=dp(`https://twitter.com/x/status/${c}`),m={type:"document",srcdoc:p=>Nc(`<blockquote class="twitter-tweet" data-dnt="true" data-theme="${p}"><a href="${d}"></a></blockquote> <script async src="https://platform.twitter.com/widgets.js" charset="utf-8"><\/script>`),intrinsicSize:{w:480,h:480},sandbox:{allowSameOrigin:r}};return Kn.set(t,m),m}if(B2.test(e)){let[,c,d]=e.match(B2),m=dp(`https://gist.github.com/${c}/${d}`),p={type:"document",srcdoc:()=>Nc(`
28
+ <script src="${m}.js"><\/script>
29
29
  <style type="text/css">
30
30
  * { margin: 0px; }
31
31
  table, .gist { height: 100%; }
32
32
  .gist .gist-file { height: calc(100vh - 2px); padding: 0px; display: grid; grid-template-rows: 1fr auto; }
33
33
  </style>
34
- `),intrinsicSize:{w:550,h:720}};return Gn.set(e,s),s}return Gn.set(e,{link:e,intrinsicSize:r,type:o}),{link:e,intrinsicSize:r,type:o}},qm=e=>{let t;ir(e)?t="IFrame element":t=!e.link||e?.link===""?"Empty Web-Embed":e.link;let o=Math.max(Math.min(e.width/2,e.width/t.length),e.width/30),r=dt.Helvetica,n=Ke({fontSize:o,fontFamily:r});return Gt({x:e.x+e.width/2,y:e.y+e.height/2,strokeColor:e.strokeColor!=="transparent"?e.strokeColor:"black",backgroundColor:"transparent",fontFamily:r,fontSize:o,text:vi(t,n,e.width-20),textAlign:"center",verticalAlign:yt.MIDDLE,angle:e.angle??0})},tH=H({name:"setEmbeddableAsActiveTool",trackEvent:{category:"toolbar"},target:"Tool",label:"toolBar.embeddable",perform:(e,t,o,r)=>{let n=Qe(t,{type:"embeddable"});return Go(r.canvas,{...t,activeTool:n}),{elements:e,appState:{...t,activeTool:Qe(t,{type:"embeddable"})},commitToHistory:!1}}}),J2=(e,t)=>{try{let{hostname:o}=new URL(e),r=o.replace(/^www\./,""),n=r.replace(/^([^.]+)/,"*");if(t instanceof Set)return gf.has(r)||gf.has(n);if(r===t.replace(/^www\./,""))return!0}catch{}return!1},Q2=e=>{let t=e.match(rM);if(t&&t.length===2)return t[1];let o=e.match(tM);if(o&&o.length===3)return`https://gist.github.com/${o[1]}/${o[2]}`;if(q2.test(e))return`https://giphy.com/embed/${q2.exec(e)[1]}`;let r=e.match(iM);return r&&r.length===2?r[1]:e},Bl=(e,t)=>{if(!e)return!1;if(t!=null)if(typeof t=="function"){let o=t(e);if(typeof o=="boolean")return o}else{if(typeof t=="boolean")return t;if(t instanceof RegExp)return t.test(e);if(Array.isArray(t)){for(let o of t)if(o instanceof RegExp){if(e.match(o))return!0}else if(J2(e,o))return!0;return!1}}return J2(e,gf)}});var Tc,Cc,hf,ew,tw=v(()=>{"use strict";f();U();Dl();he();vc();io();pt();se();ao();Qt();Mr();G();Jr();Tc=(e,t,o)=>{if(typeof o>"u")return e.draw(t);let r={sets:t.sets,shape:t.shape,options:{...t.options,fixedDecimalPlaceDigits:o}};return e.draw(r)},Cc=(e,t,o,r,n)=>{if(!r.enabled||!r.clip)return null;let i=Ut(e,n);if(i){let a=t.ownerDocument.createElementNS(Ue,"g");return a.setAttributeNS(Ue,"clip-path",`url(#${i.id})`),o.forEach(l=>a.appendChild(l)),a}return null},hf=(e,t,o,r,n,i,a,l)=>{let s={x:i,y:a},[c,d,m,p]=te(e,t),u=(m-c)/2-(e.x-c),g=(p-d)/2-(e.y-d);if(W(e)){let w=ut(e,t);if(ke(w)){let[S,M,k,R]=te(w,t),P=$.getBoundTextElementPosition(w,e,t);u=(k-S)/2-(P.x-S),g=(R-M)/2-(P.y-M),i=i+P.x-e.x,a=a+P.y-e.y}}let x=180*e.angle/Math.PI,E=r;if(e.link){let w=r.ownerDocument.createElementNS(Ue,"a");w.setAttribute("href",po(e.link)),E.appendChild(w),E=w}let y=(w,S)=>{Ro()&&w.setAttribute("data-id",S.id),E.appendChild(w)},T=(Ut(e,t)?.opacity??100)*e.opacity/1e4;switch(e.type){case"selection":throw new Error("Selection rendering is not supported for SVG");case"rectangle":case"diamond":case"ellipse":{let w=Me.generateElementShape(e,null),S=Tc(o,w,ml);T!==1&&(S.setAttribute("stroke-opacity",`${T}`),S.setAttribute("fill-opacity",`${T}`)),S.setAttribute("stroke-linecap","round"),S.setAttribute("transform",`translate(${i||0} ${a||0}) rotate(${x} ${u} ${g})`);let M=Cc(e,E,[S],l.frameRendering,t);y(M||S,e);break}case"iframe":case"embeddable":{let w=Me.generateElementShape(e,l),S=Tc(o,w,ml),M=e.opacity/100;M!==1&&(S.setAttribute("stroke-opacity",`${M}`),S.setAttribute("fill-opacity",`${M}`)),S.setAttribute("stroke-linecap","round"),S.setAttribute("transform",`translate(${i||0} ${a||0}) rotate(${x} ${u} ${g})`),y(S,e);let k=qm(e);hf(k,t,o,E,n,k.x+s.x-e.x,k.y+s.y-e.y,l);let R=Tc(o,w,ml);for(R.setAttribute("stroke-linecap","round"),R.setAttribute("transform",`translate(${i||0} ${a||0}) rotate(${x} ${u} ${g})`);R.firstChild;)R.removeChild(R.firstChild);let P=kr(Math.min(e.width,e.height),e),F=Un(Ym(e.link||""));if(l.renderEmbeddables===!1||F?.type==="document"){let D=r.ownerDocument.createElementNS(Ue,"a");D.setAttribute("href",po(e.link||"")),D.setAttribute("target","_blank"),D.setAttribute("rel","noopener noreferrer"),D.style.borderRadius=`${P}px`,R.appendChild(D)}else{let D=r.ownerDocument.createElementNS(Ue,"foreignObject");D.style.width=`${e.width}px`,D.style.height=`${e.height}px`,D.style.border="none";let L=D.ownerDocument.createElementNS(Ue,"div");L.setAttribute("xmlns","http://www.w3.org/1999/xhtml"),L.style.width="100%",L.style.height="100%";let A=L.ownerDocument.createElement("iframe");A.src=F?.link??"",A.style.width="100%",A.style.height="100%",A.style.border="none",A.style.borderRadius=`${P}px`,A.style.top="0",A.style.left="0",A.allowFullscreen=!0,L.appendChild(A),D.appendChild(L),R.appendChild(D)}y(R,e);break}case"line":case"arrow":{let w=me(e,t),S=r.ownerDocument.createElementNS(Ue,"mask");if(w){S.setAttribute("id",`mask-${e.id}`);let P=r.ownerDocument.createElementNS(Ue,"rect");i=i||0,a=a||0,P.setAttribute("x","0"),P.setAttribute("y","0"),P.setAttribute("fill","#fff"),P.setAttribute("width",`${e.width+100+i}`),P.setAttribute("height",`${e.height+100+a}`),S.appendChild(P);let F=r.ownerDocument.createElementNS(Ue,"rect"),D=$.getBoundTextElementPosition(e,w,t),L=i+D.x-e.x,A=a+D.y-e.y;F.setAttribute("x",L.toString()),F.setAttribute("y",A.toString()),F.setAttribute("fill","#000"),F.setAttribute("width",`${w.width}`),F.setAttribute("height",`${w.height}`),F.setAttribute("opacity","1"),S.appendChild(F)}let M=r.ownerDocument.createElementNS(Ue,"g");w&&M.setAttribute("mask",`url(#mask-${e.id})`),M.setAttribute("stroke-linecap","round"),Me.generateElementShape(e,l).forEach(P=>{let F=Tc(o,P,ml);T!==1&&(F.setAttribute("stroke-opacity",`${T}`),F.setAttribute("fill-opacity",`${T}`)),F.setAttribute("transform",`translate(${i||0} ${a||0}) rotate(${x} ${u} ${g})`),e.type==="line"&&yo(e.points)&&e.backgroundColor!=="transparent"&&F.setAttribute("fill-rule","evenodd"),M.appendChild(F)});let R=Cc(e,E,[M,S],l.frameRendering,t);R?(y(R,e),E.appendChild(R)):(y(M,e),E.append(S));break}case"freedraw":{let w=Me.generateElementShape(e,l),S=w?Tc(o,w,ml):r.ownerDocument.createElementNS(Ue,"g");T!==1&&(S.setAttribute("stroke-opacity",`${T}`),S.setAttribute("fill-opacity",`${T}`)),S.setAttribute("transform",`translate(${i||0} ${a||0}) rotate(${x} ${u} ${g})`),S.setAttribute("stroke","none");let M=r.ownerDocument.createElementNS(Ue,"path");M.setAttribute("fill",e.strokeColor),M.setAttribute("d",Jm(e)),S.appendChild(M);let k=Cc(e,E,[S],l.frameRendering,t);y(k||S,e);break}case"image":{let w=Math.round(e.width),S=Math.round(e.height),M=mo(e)&&n[e.fileId];if(M){let k=`image-${M.id}`,R=r.querySelector(`#${k}`);if(!R){R=r.ownerDocument.createElementNS(Ue,"symbol"),R.id=k;let L=r.ownerDocument.createElementNS(Ue,"image");L.setAttribute("width","100%"),L.setAttribute("height","100%"),L.setAttribute("href",M.dataURL),R.appendChild(L),E.prepend(R)}let P=r.ownerDocument.createElementNS(Ue,"use");if(P.setAttribute("href",`#${k}`),l.exportWithDarkMode&&M.mimeType!==J.svg&&P.setAttribute("filter",ff),P.setAttribute("width",`${w}`),P.setAttribute("height",`${S}`),P.setAttribute("opacity",`${T}`),e.scale[0]!==1||e.scale[1]!==1){let L=e.scale[0]!==1?-w:0,A=e.scale[1]!==1?-S:0;P.setAttribute("transform",`scale(${e.scale[0]}, ${e.scale[1]}) translate(${L} ${A})`)}let F=r.ownerDocument.createElementNS(Ue,"g");if(F.appendChild(P),F.setAttribute("transform",`translate(${i||0} ${a||0}) rotate(${x} ${u} ${g})`),e.roundness){let L=r.ownerDocument.createElementNS(Ue,"clipPath");L.id=`image-clipPath-${e.id}`;let A=r.ownerDocument.createElementNS(Ue,"rect"),B=kr(Math.min(e.width,e.height),e);A.setAttribute("width",`${e.width}`),A.setAttribute("height",`${e.height}`),A.setAttribute("rx",`${B}`),A.setAttribute("ry",`${B}`),L.appendChild(A),y(L,e),F.setAttributeNS(Ue,"clip-path",`url(#${L.id})`)}let D=Cc(e,E,[F],l.frameRendering,t);y(D||F,e)}break}case"frame":case"magicframe":{if(l.frameRendering.enabled&&l.frameRendering.outline){let w=document.createElementNS(Ue,"rect");w.setAttribute("transform",`translate(${i||0} ${a||0}) rotate(${x} ${u} ${g})`),w.setAttribute("width",`${e.width}px`),w.setAttribute("height",`${e.height}px`),w.setAttribute("rx",Je.radius.toString()),w.setAttribute("ry",Je.radius.toString()),w.setAttribute("fill","none"),w.setAttribute("stroke",Je.strokeColor),w.setAttribute("stroke-width",Je.strokeWidth.toString()),y(w,e)}break}default:if(W(e)){let w=r.ownerDocument.createElementNS(Ue,"g");T!==1&&(w.setAttribute("stroke-opacity",`${T}`),w.setAttribute("fill-opacity",`${T}`)),w.setAttribute("transform",`translate(${i||0} ${a||0}) rotate(${x} ${u} ${g})`);let S=e.text.replace(/\r\n?/g,`
34
+ `),intrinsicSize:{w:550,h:720},sandbox:{allowSameOrigin:r}};return Kn.set(e,p),p}return Kn.set(e,{link:e,intrinsicSize:n,type:o,sandbox:{allowSameOrigin:r}}),{link:e,intrinsicSize:n,type:o,sandbox:{allowSameOrigin:r}}},yp=e=>{let t;go(e)?t="IFrame element":t=!e.link||e?.link===""?"Empty Web-Embed":e.link;let r=Math.max(Math.min(e.width/2,e.width/t.length),e.width/30),o=ht.Helvetica,n=Ze({fontSize:r,fontFamily:o});return $t({x:e.x+e.width/2,y:e.y+e.height/2,strokeColor:e.strokeColor!=="transparent"?e.strokeColor:"black",backgroundColor:"transparent",fontFamily:o,fontSize:r,text:Di(t,n,e.width-20),textAlign:"center",verticalAlign:Tt.MIDDLE,angle:e.angle??0})},DH=U({name:"setEmbeddableAsActiveTool",trackEvent:{category:"toolbar"},target:"Tool",label:"toolBar.embeddable",perform:(e,t,r,o)=>{let n=tt(t,{type:"embeddable"});return qr(o.canvas,{...t,activeTool:n}),{elements:e,appState:{...t,activeTool:tt(t,{type:"embeddable"})},storeAction:_.NONE}}}),Kf=(e,t)=>{try{let{hostname:r}=new URL(e),o=r.replace(/^www\./,"");if(t instanceof Set){if(Yf.has(o))return o;let i=o.replace(/^([^.]+)/,"*");return Yf.has(i)?i:null}let n=t.replace(/^www\./,"");if(o===n)return n}catch{}return null},U2=e=>{let t=e.match(lL);if(t&&t.length===2)return t[1];let r=e.match(aL);if(r&&r.length===2)return r[1];if(z2.test(e))return`https://giphy.com/embed/${z2.exec(e)[1]}`;let o=e.match(cL);return o&&o.length===2?o[1]:e},Kl=(e,t)=>{if(!e)return!1;if(t!=null)if(typeof t=="function"){let r=t(e);if(typeof r=="boolean")return r}else{if(typeof t=="boolean")return t;if(t instanceof RegExp)return t.test(e);if(Array.isArray(t)){for(let r of t)if(r instanceof RegExp){if(e.match(r))return!0}else if(Kf(e,r))return!0;return!1}}return!!Kf(e,Yf)}});var Bc,Fc,wp,G2,V2=y(()=>{"use strict";f();W();Na();xe();Oc();or();mt();me();dr();Kt();ln();G();sn();Bc=(e,t,r)=>{if(typeof r>"u")return e.draw(t);let o={sets:t.sets,shape:t.shape,options:{...t.options,fixedDecimalPlaceDigits:r}};return e.draw(o)},Fc=(e,t,r,o,n)=>{if(!o.enabled||!o.clip)return null;let i=Xt(e,n);if(i){let a=t.ownerDocument.createElementNS(We,"g");return a.setAttributeNS(We,"clip-path",`url(#${i.id})`),r.forEach(l=>a.appendChild(l)),a}return null},wp=(e,t,r,o,n,i,a,l)=>{let s={x:i,y:a},[c,d,m,p]=oe(e,t),u=(m-c)/2-(e.x-c),h=(p-d)/2-(e.y-d);if(V(e)){let w=gt(e,t);if(Ce(w)){let[I,L,A,M]=oe(w,t),D=Z.getBoundTextElementPosition(w,e,t);u=(A-I)/2-(D.x-I),h=(M-L)/2-(D.y-L),i=i+D.x-e.x,a=a+D.y-e.y}}let E=180*e.angle/Math.PI,x=o;if(e.link){let w=o.ownerDocument.createElementNS(We,"a");w.setAttribute("href",yr(e.link)),x.appendChild(w),x=w}let T=(w,I)=>{Wr()&&w.setAttribute("data-id",I.id),x.appendChild(w)},v=(Xt(e,t)?.opacity??100)*e.opacity/1e4;switch(e.type){case"selection":throw new Error("Selection rendering is not supported for SVG");case"rectangle":case"diamond":case"ellipse":{let w=Ne.generateElementShape(e,null),I=Bc(r,w,Il);v!==1&&(I.setAttribute("stroke-opacity",`${v}`),I.setAttribute("fill-opacity",`${v}`)),I.setAttribute("stroke-linecap","round"),I.setAttribute("transform",`translate(${i||0} ${a||0}) rotate(${E} ${u} ${h})`);let L=Fc(e,x,[I],l.frameRendering,t);T(L||I,e);break}case"iframe":case"embeddable":{let w=Ne.generateElementShape(e,l),I=Bc(r,w,Il),L=e.opacity/100;L!==1&&(I.setAttribute("stroke-opacity",`${L}`),I.setAttribute("fill-opacity",`${L}`)),I.setAttribute("stroke-linecap","round"),I.setAttribute("transform",`translate(${i||0} ${a||0}) rotate(${E} ${u} ${h})`),T(I,e);let A=yp(e);wp(A,t,r,x,n,A.x+s.x-e.x,A.y+s.y-e.y,l);let M=Bc(r,w,Il);for(M.setAttribute("stroke-linecap","round"),M.setAttribute("transform",`translate(${i||0} ${a||0}) rotate(${E} ${u} ${h})`);M.firstChild;)M.removeChild(M.firstChild);let D=Fo(Math.min(e.width,e.height),e),O=$n(pp(e.link||""));if(l.renderEmbeddables===!1||O?.type==="document"){let R=o.ownerDocument.createElementNS(We,"a");R.setAttribute("href",yr(e.link||"")),R.setAttribute("target","_blank"),R.setAttribute("rel","noopener noreferrer"),R.style.borderRadius=`${D}px`,M.appendChild(R)}else{let R=o.ownerDocument.createElementNS(We,"foreignObject");R.style.width=`${e.width}px`,R.style.height=`${e.height}px`,R.style.border="none";let B=R.ownerDocument.createElementNS(We,"div");B.setAttribute("xmlns","http://www.w3.org/1999/xhtml"),B.style.width="100%",B.style.height="100%";let k=B.ownerDocument.createElement("iframe");k.src=O?.link??"",k.style.width="100%",k.style.height="100%",k.style.border="none",k.style.borderRadius=`${D}px`,k.style.top="0",k.style.left="0",k.allowFullscreen=!0,B.appendChild(k),R.appendChild(B),M.appendChild(R)}T(M,e);break}case"line":case"arrow":{let w=ue(e,t),I=o.ownerDocument.createElementNS(We,"mask");if(w){I.setAttribute("id",`mask-${e.id}`);let D=o.ownerDocument.createElementNS(We,"rect");i=i||0,a=a||0,D.setAttribute("x","0"),D.setAttribute("y","0"),D.setAttribute("fill","#fff"),D.setAttribute("width",`${e.width+100+i}`),D.setAttribute("height",`${e.height+100+a}`),I.appendChild(D);let O=o.ownerDocument.createElementNS(We,"rect"),R=Z.getBoundTextElementPosition(e,w,t),B=i+R.x-e.x,k=a+R.y-e.y;O.setAttribute("x",B.toString()),O.setAttribute("y",k.toString()),O.setAttribute("fill","#000"),O.setAttribute("width",`${w.width}`),O.setAttribute("height",`${w.height}`),O.setAttribute("opacity","1"),I.appendChild(O)}let L=o.ownerDocument.createElementNS(We,"g");w&&L.setAttribute("mask",`url(#mask-${e.id})`),L.setAttribute("stroke-linecap","round"),Ne.generateElementShape(e,l).forEach(D=>{let O=Bc(r,D,Il);v!==1&&(O.setAttribute("stroke-opacity",`${v}`),O.setAttribute("fill-opacity",`${v}`)),O.setAttribute("transform",`translate(${i||0} ${a||0}) rotate(${E} ${u} ${h})`),e.type==="line"&&br(e.points)&&e.backgroundColor!=="transparent"&&O.setAttribute("fill-rule","evenodd"),L.appendChild(O)});let M=Fc(e,x,[L,I],l.frameRendering,t);M?(T(M,e),x.appendChild(M)):(T(L,e),x.append(I));break}case"freedraw":{let w=Ne.generateElementShape(e,l),I=w?Bc(r,w,Il):o.ownerDocument.createElementNS(We,"g");v!==1&&(I.setAttribute("stroke-opacity",`${v}`),I.setAttribute("fill-opacity",`${v}`)),I.setAttribute("transform",`translate(${i||0} ${a||0}) rotate(${E} ${u} ${h})`),I.setAttribute("stroke","none");let L=o.ownerDocument.createElementNS(We,"path");L.setAttribute("fill",e.strokeColor),L.setAttribute("d",vp(e)),I.appendChild(L);let A=Fc(e,x,[I],l.frameRendering,t);T(A||I,e);break}case"image":{let w=Math.round(e.width),I=Math.round(e.height),L=gr(e)&&n[e.fileId];if(L){let A=`image-${L.id}`,M=o.querySelector(`#${A}`);if(!M){M=o.ownerDocument.createElementNS(We,"symbol"),M.id=A;let B=o.ownerDocument.createElementNS(We,"image");B.setAttribute("width","100%"),B.setAttribute("height","100%"),B.setAttribute("href",L.dataURL),M.appendChild(B),x.prepend(M)}let D=o.ownerDocument.createElementNS(We,"use");if(D.setAttribute("href",`#${A}`),l.exportWithDarkMode&&L.mimeType!==te.svg&&D.setAttribute("filter",$f),D.setAttribute("width",`${w}`),D.setAttribute("height",`${I}`),D.setAttribute("opacity",`${v}`),e.scale[0]!==1||e.scale[1]!==1){let B=e.scale[0]!==1?-w:0,k=e.scale[1]!==1?-I:0;D.setAttribute("transform",`scale(${e.scale[0]}, ${e.scale[1]}) translate(${B} ${k})`)}let O=o.ownerDocument.createElementNS(We,"g");if(O.appendChild(D),O.setAttribute("transform",`translate(${i||0} ${a||0}) rotate(${E} ${u} ${h})`),e.roundness){let B=o.ownerDocument.createElementNS(We,"clipPath");B.id=`image-clipPath-${e.id}`;let k=o.ownerDocument.createElementNS(We,"rect"),z=Fo(Math.min(e.width,e.height),e);k.setAttribute("width",`${e.width}`),k.setAttribute("height",`${e.height}`),k.setAttribute("rx",`${z}`),k.setAttribute("ry",`${z}`),B.appendChild(k),T(B,e),O.setAttributeNS(We,"clip-path",`url(#${B.id})`)}let R=Fc(e,x,[O],l.frameRendering,t);T(R||O,e)}break}case"frame":case"magicframe":{if(l.frameRendering.enabled&&l.frameRendering.outline){let w=document.createElementNS(We,"rect");w.setAttribute("transform",`translate(${i||0} ${a||0}) rotate(${E} ${u} ${h})`),w.setAttribute("width",`${e.width}px`),w.setAttribute("height",`${e.height}px`),w.setAttribute("rx",et.radius.toString()),w.setAttribute("ry",et.radius.toString()),w.setAttribute("fill","none"),w.setAttribute("stroke",et.strokeColor),w.setAttribute("stroke-width",et.strokeWidth.toString()),T(w,e)}break}default:if(V(e)){let w=o.ownerDocument.createElementNS(We,"g");v!==1&&(w.setAttribute("stroke-opacity",`${v}`),w.setAttribute("fill-opacity",`${v}`)),w.setAttribute("transform",`translate(${i||0} ${a||0}) rotate(${E} ${u} ${h})`);let I=e.text.replace(/\r\n?/g,`
35
35
  `).split(`
36
- `),M=wi(e.fontSize,e.lineHeight),k=e.textAlign==="center"?e.width/2:e.textAlign==="right"?e.width:0,R=Bm(e.fontFamily,e.fontSize,M),P=hm(e.text)?"rtl":"ltr",F=e.textAlign==="center"?"middle":e.textAlign==="right"||P==="rtl"?"end":"start";for(let L=0;L<S.length;L++){let A=r.ownerDocument.createElementNS(Ue,"text");A.textContent=S[L],A.setAttribute("x",`${k}`),A.setAttribute("y",`${L*M+R}`),A.setAttribute("font-family",ul(e)),A.setAttribute("font-size",`${e.fontSize}px`),A.setAttribute("fill",e.strokeColor),A.setAttribute("text-anchor",F),A.setAttribute("style","white-space: pre;"),A.setAttribute("direction",P),A.setAttribute("dominant-baseline","alphabetic"),w.appendChild(A)}let D=Cc(e,E,[w],l.frameRendering,t);y(D||w,e)}else throw new Error(`Unimplemented type ${e.type}`)}},ew=(e,t,o,r,n,i)=>{r&&(e.filter(a=>!Jt(a)).forEach(a=>{if(!a.isDeleted)try{hf(a,t,o,r,n,a.x+i.offsetX,a.y+i.offsetY,i)}catch(l){console.error(l)}}),e.filter(a=>Jt(a)).forEach(a=>{if(!a.isDeleted)try{hf(a,t,o,r,n,a.x+i.offsetX,a.y+i.offsetY,i)}catch(l){console.error(l)}}))}});var Qm,rn,Or,Ia=v(()=>{"use strict";f();Qm=class extends Error{constructor(t="Couldn't export canvas.",o="CANVAS_ERROR"){super(),this.name=o,this.message=t}},rn=class extends DOMException{constructor(t="Request Aborted"){super(t,"AbortError")}},Or=class extends Error{code;constructor(t="Image Scene Data Error",o="IMAGE_SCENE_DATA_ERROR"){super(t),this.name="EncodingError",this.code=o}}});import{fileOpen as aM,fileSave as lM,supported as Ti}from"browser-fs-access";var ow,Fl,Hl,Wn=v(()=>{"use strict";f();U();Ia();G();ow=500,Fl=e=>{let t=e.extensions?.reduce((r,n)=>(r.push(J[n]),r),[]),o=e.extensions?.reduce((r,n)=>n==="jpg"?r.concat(".jpg",".jpeg"):r.concat(`.${n}`),[]);return aM({description:e.description,extensions:o,mimeTypes:t,multiple:e.multiple??!1,legacySetup:(r,n,i)=>{let a=ca(n,ow),l=()=>{s(),document.addEventListener("keyup",a),document.addEventListener("pointerup",a),a()},s=()=>{if(i.files?.length){let d=e.multiple?[...i.files]:i.files[0];r(d)}};requestAnimationFrame(()=>{window.addEventListener("focus",l)});let c=window.setInterval(()=>{s()},ow);return d=>{clearInterval(c),a.cancel(),window.removeEventListener("focus",l),document.removeEventListener("keyup",a),document.removeEventListener("pointerup",a),d&&(console.warn("Opening the file was canceled (legacy-fs)."),d(new rn))}}})},Hl=(e,t)=>lM(e,{fileName:`${t.name}.${t.extension}`,description:t.description,extensions:[`.${t.extension}`]},t.fileHandle)});var sM,cM,rw,zl,dM,mM,pM,uM,Ic,gM,nw,ep,Sa,iw,ka,Aa=v(()=>{"use strict";f();he();se();Sr();U();Fo();io();Ze();G();G();pt();Dl();sM={selection:!0,text:!0,rectangle:!0,diamond:!0,ellipse:!0,line:!0,image:!0,arrow:!0,freedraw:!0,eraser:!1,custom:!0,frame:!0,embeddable:!0,hand:!0,laser:!1,magicframe:!1},cM=e=>Object.keys(dt).includes(e)?dt[e]:qt,rw=e=>e?{...e,focus:e.focus||0}:null,zl=(e,t)=>{let o={type:t.type||e.type,version:e.version||1,versionNonce:e.versionNonce??0,isDeleted:e.isDeleted??!1,id:e.id||Bt(),fillStyle:e.fillStyle||rt.fillStyle,strokeWidth:e.strokeWidth||rt.strokeWidth,strokeStyle:e.strokeStyle??rt.strokeStyle,roughness:e.roughness??rt.roughness,opacity:e.opacity==null?rt.opacity:e.opacity,angle:e.angle||0,x:t.x??e.x??0,y:t.y??e.y??0,strokeColor:e.strokeColor||rt.strokeColor,backgroundColor:e.backgroundColor||rt.backgroundColor,width:e.width||0,height:e.height||0,seed:e.seed??1,groupIds:e.groupIds??[],frameId:e.frameId??null,roundness:e.roundness?e.roundness:e.strokeSharpness==="round"?{type:qr(e.type)?at.LEGACY:at.PROPORTIONAL_RADIUS}:null,boundElements:e.boundElementIds?e.boundElementIds.map(r=>({type:"arrow",id:r})):e.boundElements??[],updated:e.updated??Ln(),link:e.link?po(e.link):null,locked:e.locked??!1};return("customData"in e||"customData"in t)&&(o.customData="customData"in t?t.customData:e.customData),cm in e&&(o[cm]=e[cm]),{...o,...Sc(o),...t}},dM=e=>{switch(e.type){case"text":let t=e.fontSize,o=e.fontFamily;if("font"in e){let[i,a]=e.font.split(" ");t=parseFloat(i),o=cM(a)}let r=typeof e.text=="string"&&e.text||"",n=e.lineHeight||(e.height?M2(e):Oo(e.fontFamily));return e=zl(e,{fontSize:t,fontFamily:o,text:r,textAlign:e.textAlign||li,verticalAlign:e.verticalAlign||ia,containerId:e.containerId??null,originalText:e.originalText||r,lineHeight:n}),!r&&!e.isDeleted&&(e={...e,originalText:r,isDeleted:!0},e=Nr(e)),e;case"freedraw":return zl(e,{points:e.points,lastCommittedPoint:null,simulatePressure:e.simulatePressure,pressures:e.pressures});case"image":return zl(e,{status:e.status||"pending",fileId:e.fileId,scale:e.scale||[1,1]});case"line":case"draw":case"arrow":{let{startArrowhead:i=null,endArrowhead:a=e.type==="arrow"?"arrow":null}=e,l=e.x,s=e.y,c=!Array.isArray(e.points)||e.points.length<2?[[0,0],[e.width,e.height]]:e.points;return(c[0][0]!==0||c[0][1]!==0)&&({points:c,x:l,y:s}=$.getNormalizedPoints(e)),zl(e,{type:e.type==="draw"?"line":e.type,startBinding:rw(e.startBinding),endBinding:rw(e.endBinding),lastCommittedPoint:null,startArrowhead:i,endArrowhead:a,points:c,x:l,y:s})}case"ellipse":case"rectangle":case"diamond":case"iframe":case"embeddable":return zl(e,{});case"magicframe":case"frame":return zl(e,{name:e.name??null})}return null},mM=(e,t)=>{if(e.boundElements){let o=e.boundElements.slice(),r=new Set;e.boundElements=o.reduce((n,i)=>{let a=t.get(i.id);if(a&&!r.has(i.id)){if(r.add(i.id),a.isDeleted)return n;n.push(i),W(a)&&!a.containerId&&(a.containerId=e.id)}return n},[])}},pM=(e,t)=>{let o=e.containerId?t.get(e.containerId):null;if(!o){e.containerId=null;return}if(!e.isDeleted&&o.boundElements&&!o.boundElements.find(r=>r.id===e.id)){let r=(o.boundElements||(o.boundElements=[])).slice();r.push({type:"text",id:e.id}),o.boundElements=r}},uM=(e,t)=>{e.frameId&&(t.get(e.frameId)||(e.frameId=null))},Ic=(e,t,o)=>{let r=new Set,n=t?re(t):null,i=(e||[]).reduce((l,s)=>{if(s.type!=="selection"&&!dr(s)){let c=dM(s);if(c){let d=n?.get(s.id);d&&d.version>c.version&&(c=Nr(c,d.version)),r.has(c.id)&&(c={...c,id:Bt()}),r.add(c.id),l.push(c)}}return l},[]);if(!o?.repairBindings)return i;let a=re(i);for(let l of i)l.frameId&&uM(l,a),W(l)&&l.containerId?pM(l,a):l.boundElements&&mM(l,a),o.refreshDimensions&&W(l)&&Object.assign(l,Nl(l,ut(l,a),a));return i},gM=(e,t,o)=>{let r=t[e];return r!==void 0?r:o[e]},nw={isSidebarDocked:(e,t)=>["defaultSidebarDockedPreference",e.isSidebarDocked??gM("defaultSidebarDockedPreference",e,t)]},ep=(e,t)=>{e=e||{};let o=Bo(),r={};for(let n of Object.keys(nw))if(n in e){let[i,a]=nw[n](e,o);r[i]=a}for(let[n,i]of Object.entries(o)){let a=e[n],l=t?t[n]:void 0;r[n]=a!==void 0?a:l!==void 0?l:i}return{...r,cursorButton:t?.cursorButton||"up",penDetected:t?.penDetected??(e.penMode?e.penDetected??!1:!1),activeTool:{...Qe(o,r.activeTool.type&&sM[r.activeTool.type]?r.activeTool:{type:"selection"}),lastActiveTool:null,locked:r.activeTool.locked??!1},zoom:typeof e.zoom=="number"?{value:e.zoom}:e.zoom?.value?e.zoom:o.zoom,openSidebar:typeof e.openSidebar=="string"?{name:Do.name}:r.openSidebar}},Sa=(e,t,o,r)=>({elements:Ic(e?.elements,o,r),appState:ep(e?.appState,t||null),files:e?.files||{}}),iw=e=>{let t=Ic(be(e.elements),null);return t.length?{...e,elements:t}:null},ka=(e=[],t)=>{let o=[];for(let r of e)if(Array.isArray(r)){let n=iw({status:t,elements:r,id:Bt(),created:Date.now()});n&&o.push(n)}else{let n=r,i=iw({...n,id:n.id||Bt(),status:n.status||t,created:n.created||Date.now()});i&&o.push(i)}return o}});var aw=v(()=>{"use strict";f();U();Co()});import{deflate as hM,inflate as fM}from"pako";var bf,lw,sw,cw,dw,xf,Ef,mw=v(()=>{"use strict";f();aw();bf=e=>new Promise((t,o)=>{let r=typeof e=="string"?new Blob([new TextEncoder().encode(e)]):new Blob([e instanceof Uint8Array?e:new Uint8Array(e)]),n=new FileReader;n.onload=i=>{if(!i.target||typeof i.target.result!="string")return o(new Error("couldn't convert to byte string"));t(i.target.result)},n.readAsBinaryString(r)}),lw=e=>{let t=new ArrayBuffer(e.length),o=new Uint8Array(t);for(let r=0,n=e.length;r<n;r++)o[r]=e.charCodeAt(r);return t},sw=e=>new TextDecoder("utf-8").decode(lw(e)),cw=async(e,t=!1)=>t?window.btoa(e):window.btoa(await bf(e)),dw=async(e,t=!1)=>t?window.atob(e):sw(window.atob(e)),xf=async({text:e,compress:t})=>{let o;if(t!==!1)try{o=await bf(hM(e))}catch(r){console.error("encode: cannot deflate",r)}return{version:"1",encoding:"bstring",compressed:!!o,encoded:o||await bf(e)}},Ef=async e=>{let t;switch(e.encoding){case"bstring":t=e.compressed?e.encoded:await sw(e.encoded);break;default:throw new Error(`decode: unknown encoding "${e.encoding}"`)}return e.compressed?fM(new Uint8Array(lw(t)),{to:"string"}):t}});var kc={};Os(kc,{decodePngMetadata:()=>xM,decodeSvgMetadata:()=>yM,encodePngMetadata:()=>yf,encodeSvgMetadata:()=>EM,getTEXtChunk:()=>gw});import pw from"png-chunks-extract";import uw from"png-chunk-text";import bM from"png-chunks-encode";var gw,yf,xM,EM,yM,Gl=v(()=>{"use strict";f();mw();U();Co();gw=async e=>{let o=pw(new Uint8Array(await Vn(e))).find(r=>r.name==="tEXt");return o?uw.decode(o.data):null},yf=async({blob:e,metadata:t})=>{let o=pw(new Uint8Array(await Vn(e))),r=uw.encode(J.excalidraw,JSON.stringify(await xf({text:t,compress:!0})));return o.splice(-1,0,r),new Blob([bM(o)],{type:J.png})},xM=async e=>{let t=await gw(e);if(t?.keyword===J.excalidraw)try{let o=JSON.parse(t.text);if(!("encoded"in o)){if("type"in o&&o.type===ro.excalidraw)return t.text;throw new Error("FAILED")}return await Ef(o)}catch(o){throw console.error(o),new Error("FAILED")}throw new Error("INVALID")},EM=async({text:e})=>{let t=await cw(JSON.stringify(await xf({text:e})),!0),o="";return o+=`<!-- payload-type:${J.excalidraw} -->`,o+="<!-- payload-version:2 -->",o+="<!-- payload-start -->",o+=t,o+="<!-- payload-end -->",o},yM=async({svg:e})=>{if(e.includes(`payload-type:${J.excalidraw}`)){let t=e.match(/<!-- payload-start -->\s*(.+?)\s*<!-- payload-end -->/);if(!t)throw new Error("INVALID");let n=(e.match(/<!-- payload-version:(\d+) -->/)?.[1]||"1")!=="1";try{let i=await dw(t[1],n),a=JSON.parse(i);if(!("encoded"in a)){if("type"in a&&a.type===ro.excalidraw)return i;throw new Error("FAILED")}return await Ef(a)}catch(i){throw console.error(i),new Error("FAILED")}}throw new Error("INVALID")}});import{nanoid as wM}from"nanoid";var fw,wf,bw,Ul,Ci,op,Wl,vf,Tf,Yn,xw,rp,Ew,Ac,Cf,yw,ww,vM,hw,tp,Mc,Vn,Co=v(()=>{"use strict";f();Fo();U();he();Ia();We();G();Wn();Kn();Aa();fw=async e=>{let t;if(e.type===J.png)try{return await(await Promise.resolve().then(()=>(Gl(),kc))).decodePngMetadata(e)}catch(o){throw o.message==="INVALID"?new Or("Image doesn't contain scene","IMAGE_NOT_CONTAINS_SCENE_DATA"):new Or("Error: cannot restore image")}else if("text"in Blob?t=await e.text():t=await new Promise(o=>{let r=new FileReader;r.readAsText(e,"utf8"),r.onloadend=()=>{r.readyState===FileReader.DONE&&o(r.result)}}),e.type===J.svg)try{return await(await Promise.resolve().then(()=>(Gl(),kc))).decodeSvgMetadata({svg:t})}catch(o){throw o.message==="INVALID"?new Or("Image doesn't contain scene","IMAGE_NOT_CONTAINS_SCENE_DATA"):new Or("Error: cannot restore image")}return t},wf=e=>e&&e.name.match(/\.(json|excalidraw|png|svg)$/)?.[1]||null,bw=e=>e==="png"||e==="svg",Ul=e=>{let t=wf(e);return t==="png"||t==="svg"},Ci=e=>{let{type:t}=e||{};return!!t&&Object.values(Gs).includes(t)},op=async(e,t,o,r)=>{let n=await fw(e),i;try{try{i=JSON.parse(n)}catch(a){throw Ci(e)?new Or("Image doesn't contain scene","IMAGE_NOT_CONTAINS_SCENE_DATA"):a}if(vw(i))return{type:J.excalidraw,data:Sa({elements:np(i.elements||[]),appState:{theme:t?.theme,fileHandle:r||e.handle||null,...bc(i.appState||{}),...t?nn(i.elements||[],t):{}},files:i.files},t,o,{repairBindings:!0,refreshDimensions:!1})};if(If(i))return{type:J.excalidrawlib,data:i};throw new Error("Error: invalid file")}catch(a){throw a instanceof Or?a:new Error("Error: invalid file")}},Wl=async(e,t,o,r)=>{let n=await op(e,t,o,r);if(n.type!==J.excalidraw)throw new Error("Error: invalid file");return n.data},vf=(e,t="unpublished")=>{let o=JSON.parse(e);if(!If(o))throw new Error("Invalid library");let r=o.libraryItems||o.library;return ka(r,t)},Tf=async(e,t="unpublished")=>vf(await fw(e),t),Yn=async e=>new Promise(async(t,o)=>{try{Xr(e)&&(e=await e),e.toBlob(r=>{if(!r)return o(new Qm("Error: Canvas too big","CANVAS_POSSIBLY_TOO_BIG"));t(r)})}catch(r){o(r)}}),xw=async e=>{try{let t=await window.crypto.subtle.digest("SHA-1",await Vn(e));return Ty(new Uint8Array(t))}catch(t){return console.error(t),wM(40)}},rp=async e=>new Promise((t,o)=>{let r=new FileReader;r.onload=()=>{let n=r.result;t(n)},r.onerror=n=>o(n),r.readAsDataURL(e)}),Ew=(e,t="")=>{let o=e.indexOf(","),r=atob(e.slice(o+1)),n=e.slice(0,o).split(":")[1].split(";")[0],i=new ArrayBuffer(r.length),a=new Uint8Array(i);for(let l=0;l<r.length;l++)a[l]=r.charCodeAt(l);return new File([i],t,{type:n})},Ac=async(e,t)=>{if(e.type===J.svg)return e;let[o,r]=await Promise.all([import("pica").then(i=>i.default),import("image-blob-reduce").then(i=>i.default)]),n=r({pica:o({features:["js","wasm"]})});if(t.outputType){let{outputType:i}=t;n._create_blob=function(a){return this.pica.toBlob(a.out_canvas,i,.8).then(l=>(a.out_blob=l,a))}}if(!Ci(e))throw new Error("Error: unsupported file type",{cause:"UNSUPPORTED"});return new File([await n.toBlob(e,{max:t.maxWidthOrHeight})],e.name,{type:t.outputType||e.type})},Cf=(e,t="")=>new File([new TextEncoder().encode(e)],t,{type:J.svg}),yw=async(e,t="")=>{let o;try{o=await fetch(e)}catch{throw new Error("Error: failed to fetch image",{cause:"FETCH_ERROR"})}if(!o.ok)throw new Error("Error: failed to fetch image",{cause:"FETCH_ERROR"});let r=await o.blob();if(r.type&&Ci(r)){let n=t||r.name||"";return new File([r],n,{type:r.type})}throw new Error("Error: unsupported file type",{cause:"UNSUPPORTED"})},ww=async e=>{let t=e.dataTransfer.files.item(0),o=await vM(e);return{file:t?await Mc(t):null,fileHandle:o}},vM=async e=>{if(Ti)try{return await e.dataTransfer.items[0].getAsFileSystemHandle()||null}catch(t){return console.warn(t.name,t.message),null}return null},hw=e=>{let t=null,o=`${[...new Uint8Array(e).slice(0,8)].join(" ")} `,r={png:"137 80 78 71 13 10 26 10 ",jpg:"255 216 255 ",gif:"71 73 70 56 57 97 "};return o===r.png?t=J.png:o.startsWith(r.jpg)?t=J.jpg:o.startsWith(r.gif)&&(t=J.gif),t},tp=(e,t,o)=>new File([e],o||"",{type:t}),Mc=async e=>{if(e.type){if(Ci(e)){let t=await Vn(e),o=hw(t);o&&o!==e.type&&(e=tp(t,o,e.name))}}else if(e?.name?.endsWith(".excalidrawlib"))e=tp(await Vn(e),J.excalidrawlib,e.name);else if(e?.name?.endsWith(".excalidraw"))e=tp(await Vn(e),J.excalidraw,e.name);else{let t=await Vn(e),o=hw(t);o&&(e=tp(t,o,e.name))}return e},Vn=e=>"arrayBuffer"in e?e.arrayBuffer():new Promise((t,o)=>{let r=new FileReader;r.onload=n=>{if(!n.target?.result)return o(new Error("Couldn't convert blob to ArrayBuffer"));t(n.target.result)},r.readAsArrayBuffer(e)})});var TM,Ii,ip,Sf,vw,If,ap,Tw,Kn=v(()=>{"use strict";f();Wn();Fo();U();he();Co();TM=(e,t)=>{let o={};for(let r of e)!r.isDeleted&&"fileId"in r&&r.fileId&&t[r.fileId]&&(o[r.fileId]=t[r.fileId]);return o},Ii=(e,t,o,r)=>{let n={type:ro.excalidraw,version:sa.excalidraw,source:Us,elements:r==="local"?np(e):Cw(e),appState:r==="local"?bc(t):H2(t),files:r==="local"?TM(e,o):void 0};return JSON.stringify(n,null,2)},ip=async(e,t,o,r=t.name||pm)=>{let n=Ii(e,t,o,"local"),i=new Blob([n],{type:J.excalidraw});return{fileHandle:await Hl(i,{name:r,extension:"excalidraw",description:"Excalidraw file",fileHandle:Ul(t.fileHandle)?null:t.fileHandle})}},Sf=async(e,t)=>{let o=await Fl({description:"Excalidraw files"});return Wl(await Mc(o),e,t,o.handle)},vw=e=>e?.type===ro.excalidraw&&(!e.elements||Array.isArray(e.elements)&&(!e.appState||typeof e.appState=="object")),If=e=>typeof e=="object"&&e&&e.type===ro.excalidrawLibrary&&(e.version===1||e.version===2),ap=e=>{let t={type:ro.excalidrawLibrary,version:sa.excalidrawLibrary,source:Us,libraryItems:e};return JSON.stringify(t,null,2)},Tw=async e=>{let t=ap(e);await Hl(new Blob([t],{type:J.excalidrawlib}),{name:"library",extension:"excalidrawlib",description:"Excalidraw library file"})}});var kf,lp,sp,CM,Iw,Af=v(()=>{"use strict";f();U();se();kf=e=>new Promise((t,o)=>{let r=new Image;r.onload=()=>{t(r)},r.onerror=n=>{o(n)},r.src=e}),lp=async({fileIds:e,files:t,imageCache:o})=>{let r=new Map,n=new Map;return await Promise.all(e.reduce((i,a)=>{let l=t[a];return l&&!r.has(a)?(r.set(a,!0),i.concat((async()=>{try{if(l.mimeType===J.binary)throw new Error("Only images can be added to ImageCache");let s=kf(l.dataURL),c={image:s,mimeType:l.mimeType};o.set(a,c);let d=await s;o.set(a,{...c,image:d})}catch{n.set(a,!0)}})())):i},[])),{imageCache:o,updatedFiles:r,erroredFiles:n}},sp=e=>e.filter(t=>mo(t)),CM=e=>e?.nodeName.toLowerCase()==="svg",Iw=async e=>{let t=new DOMParser().parseFromString(e,J.svg),o=t.querySelector("svg");if(t.querySelector("parsererror")||!CM(o))throw new Error("Invalid SVG");if(o.hasAttribute("xmlns")||o.setAttribute("xmlns",Ue),!o.hasAttribute("width")||!o.hasAttribute("height")){let n=o.getAttribute("viewBox"),i=o.getAttribute("width")||"50",a=o.getAttribute("height")||"50";if(n){let l=n.match(/\d+ +\d+ +(\d+) +(\d+)/);l&&([,i,a]=l)}o.setAttribute("width",i),o.setAttribute("height",a)}return o.outerHTML}});var Mf,Lc,Lf,cp,dp=v(()=>{"use strict";f();U();bt();Ei();Qt();Jr();Mf=document.createElement("img");Mf.src=`data:${J.svg}, ${encodeURIComponent('<svg xmlns="http://www.w3.org/2000/svg" width="16" height="16" viewBox="0 0 24 24" fill="none" stroke="#1971c2" stroke-width="2" stroke-linecap="round" stroke-linejoin="round" class="feather feather-external-link"><path d="M18 13v6a2 2 0 0 1-2 2H5a2 2 0 0 1-2-2V8a2 2 0 0 1 2-2h6"></path><polyline points="15 3 21 3 21 9"></polyline><line x1="10" y1="14" x2="21" y2="3"></line></svg>')}`;Lc=([e,t,o,r],n,i)=>{let a=Sw,l=a/i.zoom.value,s=a/i.zoom.value,c=a/i.zoom.value,d=(e+o)/2,m=(t+r)/2,p=(a-8)/(2*i.zoom.value),u=4/i.zoom.value,g=o+u-p,x=t-u-c+p,[E,y]=Ee(g+l/2,x+s/2,d,m,n);return[E-l/2,y-s/2,l,s]},Lf=(e,t,o,[r,n])=>{let i=4/o.zoom.value,[a,l,s,c]=te(e,t),[d,m,p,u]=Lc([a,l,s,c],e.angle,o);return r>d-i&&r<d+i+p&&n>m-i&&n<m+u+i},cp=(e,t,o,[r,n],i)=>{if(!e.link||o.selectedElementIds[e.id])return!1;let a=4/o.zoom.value;return!i&&o.viewModeEnabled&&Cl(e,t,[r,n],a,null)?!0:Lf(e,t,o,[r,n])}});var _c,mp,pp,_f=v(()=>{"use strict";f();U();_c=(e,t,o,r,n=!0)=>{e.beginPath(),e.arc(t,o,r,0,Math.PI*2),e.fill(),n&&e.stroke()},mp=(e,t)=>[e.width/t,e.height/t],pp=({canvas:e,scale:t,normalizedWidth:o,normalizedHeight:r,theme:n,isExporting:i,canvasBackgroundColor:a})=>{let l=e.getContext("2d");return l.setTransform(1,0,0,1,0,0),l.scale(t,t),i&&n===ie.DARK&&(l.filter=dl),typeof a=="string"?((a==="transparent"||a.length===5||a.length===9||/(hsla|rgba)\(/.test(a))&&l.clearRect(0,0,o,r),l.save(),l.fillStyle=a,l.fillRect(0,0,o,r),l.restore()):l.clearRect(0,0,o,r),l}});var IM,kw,$n,Aw,Mw,Pf,gp,hp=v(()=>{"use strict";f();U();he();ao();se();Jr();vc();dp();_f();G();IM=(e,t,o,r,n,i,a)=>{let s={Bold:"#cccccc",Regular:"#e5e5e5"},c=-Math.round(n.value/t)*t+o%t,d=-Math.round(n.value/t)*t+r%t,m=Math.min(1/n.value,1),p=1/n.value,u=[m*3,p+(m+p)];e.save(),e.lineWidth=m;for(let g=c;g<c+i+t*2;g+=t){let x=Math.round(g-o)%(5*t)===0;e.beginPath(),e.setLineDash(x?[]:u),e.strokeStyle=x?s.Bold:s.Regular,e.moveTo(g,d-t),e.lineTo(g,d+a+t*2),e.stroke()}for(let g=d;g<d+a+t*2;g+=t){let x=Math.round(g-r)%(5*t)===0;e.beginPath(),e.setLineDash(x?[]:u),e.strokeStyle=x?s.Bold:s.Regular,e.moveTo(c-t,g),e.lineTo(c+i+t*2,g),e.stroke()}e.restore()},kw=(e,t,o,r)=>{t.translate(e.x+r.scrollX,e.y+r.scrollY),t.beginPath(),t.roundRect?t.roundRect(0,0,e.width,e.height,Je.radius/r.zoom.value):t.rect(0,0,e.width,e.height),t.clip(),t.translate(-(e.x+r.scrollX),-(e.y+r.scrollY))},Aw=(e,t,o,r)=>{if(e.link&&!o.selectedElementIds[e.id]){let[n,i,a,l]=te(e,r),[s,c,d,m]=Lc([n,i,a,l],e.angle,o),p=s+d/2,u=c+m/2;if(t.save(),t.translate(o.scrollX+p,o.scrollY+u),t.rotate(e.angle),!$n||$n.zoom!==o.zoom.value){$n=document.createElement("canvas"),$n.zoom=o.zoom.value,$n.width=d*window.devicePixelRatio*o.zoom.value,$n.height=m*window.devicePixelRatio*o.zoom.value;let g=$n.getContext("2d");g.scale(window.devicePixelRatio*o.zoom.value,window.devicePixelRatio*o.zoom.value),g.fillStyle="#fff",g.fillRect(0,0,d,m),g.drawImage(Mf,0,0,d,m),g.restore(),t.drawImage($n,s-p,c-u,d,m)}else t.drawImage($n,s-p,c-u,d,m);t.restore()}},Mw=({canvas:e,rc:t,elementsMap:o,allElementsMap:r,visibleElements:n,scale:i,appState:a,renderConfig:l})=>{if(e===null)return;let{renderGrid:s=!0,isExporting:c}=l,[d,m]=mp(e,i),p=pp({canvas:e,scale:i,normalizedWidth:d,normalizedHeight:m,theme:a.theme,isExporting:c,canvasBackgroundColor:l.canvasBackgroundColor});p.scale(a.zoom.value,a.zoom.value),s&&a.gridSize&&IM(p,a.gridSize,a.scrollX,a.scrollY,a.zoom,d/a.zoom.value,m/a.zoom.value);let u=new Set;n.forEach(g=>{g.groupIds.length>0&&a.frameToHighlight&&a.selectedElementIds[g.id]&&(an(g,a.frameToHighlight,o)||g.groupIds.find(x=>u.has(x)))&&g.groupIds.forEach(x=>u.add(x))}),n.filter(g=>!Jt(g)).forEach(g=>{try{if((g.frameId||a.frameToHighlight?.id)&&a.frameRendering.enabled&&a.frameRendering.clip){p.save();let E=up(g,o,a);E&&Ma(g,o,a)&&kw(E,p,l,a),Pc(g,o,r,t,p,l,a),p.restore()}else Pc(g,o,r,t,p,l,a);c||Aw(g,p,a,o)}catch(x){console.error(x)}}),n.filter(g=>Jt(g)).forEach(g=>{try{let x=()=>{if(Pc(g,o,r,t,p,l,a),Jt(g)&&(c||St(g)&&l.embedsValidationStatus.get(g.id)!==!0)&&g.width&&g.height){let y=qm(g);Pc(y,o,r,t,p,l,a)}c||Aw(g,p,a,o)};if((g.frameId||a.frameToHighlight?.id)&&a.frameRendering.enabled&&a.frameRendering.clip){p.save();let y=up(g,o,a);y&&Ma(g,o,a)&&kw(y,p,l,a),x(),p.restore()}else x()}catch(x){console.error(x)}})},Pf=gl(e=>{Mw(e)},{trailing:!0}),gp=(e,t)=>{if(t){Pf(e);return}Mw(e)}});import Lw from"roughjs/bin/rough";var SM,kM,AM,_w,Pw,Si,Vl,fp,Yl=v(()=>{"use strict";f();bt();tw();G();U();Fo();Kn();Af();Aa();ao();he();Ze();se();hp();SM="<!-- svg-source:excalidraw -->",kM=(e,t)=>{if(e.width<=t)return e;let r=document.createElement("canvas").getContext("2d");r.font=Ke({fontFamily:e.fontFamily,fontSize:e.fontSize});let n=e.text;if(r.measureText(n).width>t)for(let a=n.length;a>0;a--){let l=`${n.slice(0,a)}...`;if(r.measureText(l).width<=t){n=l;break}}return ae(e,{text:n,width:t})},AM=(e,t)=>{let o=[],r=0,n=0;for(let i of e){if(Q(i)){pi(i)?r++:n++;let a=Gt({x:i.x,y:i.y-Je.nameOffsetY,fontFamily:dt.Assistant,fontSize:Je.nameFontSize,lineHeight:Je.nameLineHeight,strokeColor:t.exportWithDarkMode?Je.nameColorDarkTheme:Je.nameColorLightTheme,text:bp(i,pi(i)?r:n)});a.y-=a.height,a=kM(a,i.width),o.push(a)}o.push(i)}return o},_w=(e,t)=>(t=t||Bo().frameRendering,{enabled:e?!0:t.enabled,outline:e?!1:t.outline,name:e?!1:t.name,clip:e?!0:t.clip}),Pw=({elements:e,exportingFrame:t,frameRendering:o,exportWithDarkMode:r})=>{let n;return t?n=Kl(e,t):o.enabled&&o.name?n=AM(e,{exportWithDarkMode:r}):n=e,n},Si=async({data:e,config:t})=>{let o=Object.assign({},t),{files:r}=e,{exportingFrame:n}=o,i=e.elements,a=ep(e.appState,null),l=_w(n??null,a.frameRendering??null),s=Pw({elements:i,exportingFrame:n,exportWithDarkMode:a.exportWithDarkMode,frameRendering:l});n&&(o.padding=0),o.fit=o.fit??(o.width!=null||o.height!=null||o.maxWidthOrHeight!=null||o.widthOrHeight!=null?"contain":"none");let c=o.fit==="contain";(o.x!=null||o.x!=null)&&(o.fit="none"),o.fit==="cover"&&(o.padding&&!C.PROD&&console.warn("`padding` is ignored when `fit` is set to `cover`"),o.padding=0),o.padding=o.padding??0,o.scale=o.scale??1,o.origin=o.origin??"canvas",o.position=o.position??"center",o.maxWidthOrHeight!=null&&o.widthOrHeight!=null&&(C.PROD||console.warn("`maxWidthOrHeight` is ignored when `widthOrHeight` is set"),o.maxWidthOrHeight=void 0),(o.maxWidthOrHeight!=null||o.width!=null||o.height!=null)&&o.getDimensions&&(C.PROD||console.warn("`getDimensions` is ignored when `width`, `height`, or `maxWidthOrHeight` is set"),o.getDimensions=void 0);let d=1,m=fp(n?[n]:Df(s)),[p,u,g,x]=m,[E,y,T,w]=m;if(o.width!=null?(T=o.width,o.padding&&c&&(T-=o.padding*2),o.height?(w=o.height,o.padding&&c&&(w-=o.padding*2)):w*=T/g):o.height!=null&&(w=o.height,o.padding&&c&&(w-=o.padding*2),T*=w/x),o.maxWidthOrHeight!=null||o.widthOrHeight!=null){c&&o.padding&&(o.maxWidthOrHeight!=null?o.maxWidthOrHeight-=o.padding*2:o.widthOrHeight!=null&&(o.widthOrHeight-=o.padding*2));let R=Math.max(T,w);o.widthOrHeight!=null?d=o.widthOrHeight/R:o.maxWidthOrHeight!=null&&(d=o.maxWidthOrHeight<R?o.maxWidthOrHeight/R:1),T*=d,w*=d}else if(o.getDimensions){let R=o.getDimensions(T,w);T=R.width,w=R.height,o.scale=R.scale??o.scale}else if(c&&o.padding&&o.width==null&&o.height==null){let R=T/w;T-=o.padding*2,w-=o.padding*2/R}if(o.fit==="contain"&&!o.maxWidthOrHeight||c&&o.padding)if(o.fit==="contain"){let R=T/g,P=w/x;d=Math.min(R,P)}else{let R=(T-o.padding*2)/T,P=(w-o.padding*2)/w;d=Math.min(R,P)}else if(o.fit==="cover"){let R=T/g,P=w/x;d=Math.max(R,P)}E=o.x??p,y=o.y??u,o.origin==="content"&&(o.x!=null&&(E+=p),o.y!=null&&(y+=u)),o.position==="center"&&(E-=T/d/2-(o.x==null?g:T+o.padding*2)/2,y-=w/d/2-(o.y==null?x:w+o.padding*2)/2);let S=o.createCanvas?o.createCanvas():document.createElement("canvas"),M=o.padding/d;d*=o.scale,T*=o.scale,w*=o.scale,S.width=T+o.padding*2*o.scale,S.height=w+o.padding*2*o.scale;let{imageCache:k}=await lp({imageCache:new Map,fileIds:sp(s).map(R=>R.fileId),files:r||{}});return gp({canvas:S,rc:Lw.canvas(S),elementsMap:Ir(re(s)),allElementsMap:Ir(re(i)),visibleElements:s,appState:{...a,frameRendering:l,width:T,height:w,offsetLeft:0,offsetTop:0,scrollX:-E+M,scrollY:-y+M,zoom:{value:rm},shouldCacheIgnoreZoom:!1,theme:o.theme||ie.LIGHT},scale:d,renderConfig:{canvasBackgroundColor:o.canvasBackgroundColor===!1?null:o.canvasBackgroundColor||a.viewBackgroundColor||Ht,imageCache:k,renderGrid:!1,isExporting:!0,embedsValidationStatus:new Map,elementsPendingErasure:new Set}}),S},Vl=async({data:e,config:t})=>{let o=Object.assign({},t);o.exportingFrame=o.exportingFrame??null;let r=e.elements,n=_w(o?.exportingFrame??null,e.appState.frameRendering??null),{exportPadding:i=Kr,exportWithDarkMode:a=!1,viewBackgroundColor:l,exportScale:s=1,exportEmbedScene:c}=e.appState,d=Pw({elements:r,exportingFrame:o.exportingFrame,exportWithDarkMode:a,frameRendering:n});o.exportingFrame&&(i=0);let m="";if(c)try{m=await(await Promise.resolve().then(()=>(Gl(),kc))).encodeSvgMetadata({text:Ii(r,e.appState,e.files||{},"local")})}catch(F){console.error(F)}let[p,u,g,x]=fp(o.exportingFrame?[o.exportingFrame]:Df(d));g+=i*2,x+=i*2;let E=document.createElementNS(Ue,"svg");E.setAttribute("version","1.1"),E.setAttribute("xmlns",Ue),E.setAttribute("viewBox",`0 0 ${g} ${x}`),E.setAttribute("width",`${g*s}`),E.setAttribute("height",`${x*s}`),a&&E.setAttribute("filter",dl);let y="https://excalidraw.com/";C.VITE_IS_EXCALIDRAW_NPM_PACKAGE&&(y=window.EXCALIDRAW_ASSET_PATH||`https://unpkg.com/${C.VITE_PKG_NAME}@${C.PKG_VERSION}`,y?.startsWith("/")&&(y=y.replace("/",`${window.location.origin}/`)),y=`${y}/dist/excalidraw-assets/`);let T=-p+i,w=-u+i,S=Dc(r),M="",k=re(r);for(let F of S){let[D,L,A,B]=te(F,k),j=(A-D)/2-(F.x-D),Y=(B-L)/2-(F.y-L);M+=`<clipPath id=${F.id}>
37
- <rect transform="translate(${F.x+T} ${F.y+w}) rotate(${F.angle} ${j} ${Y})"
38
- width="${F.width}"
39
- height="${F.height}"
36
+ `),L=Pi(e.fontSize,e.lineHeight),A=e.textAlign==="center"?e.width/2:e.textAlign==="right"?e.width:0,M=op(e.fontFamily,e.fontSize,L),D=Pm(e.text)?"rtl":"ltr",O=e.textAlign==="center"?"middle":e.textAlign==="right"||D==="rtl"?"end":"start";for(let B=0;B<I.length;B++){let k=o.ownerDocument.createElementNS(We,"text");k.textContent=I[B],k.setAttribute("x",`${A}`),k.setAttribute("y",`${B*L+M}`),k.setAttribute("font-family",kl(e)),k.setAttribute("font-size",`${e.fontSize}px`),k.setAttribute("fill",e.strokeColor),k.setAttribute("text-anchor",O),k.setAttribute("style","white-space: pre;"),k.setAttribute("direction",D),k.setAttribute("dominant-baseline","alphabetic"),w.appendChild(k)}let R=Fc(e,x,[w],l.frameRendering,t);T(R||w,e)}else throw new Error(`Unimplemented type ${e.type}`)}},G2=(e,t,r,o,n,i)=>{o&&(e.filter(a=>!rr(a)).forEach(a=>{if(!a.isDeleted){if(V(a)&&a.containerId&&t.has(a.containerId))return;try{wp(a,t,r,o,n,a.x+i.offsetX,a.y+i.offsetY,i);let l=ue(a,t);l&&wp(l,t,r,o,n,l.x+i.offsetX,l.y+i.offsetY,i)}catch(l){console.error(l)}}}),e.filter(a=>rr(a)).forEach(a=>{if(!a.isDeleted)try{wp(a,t,r,o,n,a.x+i.offsetX,a.y+i.offsetY,i)}catch(l){console.error(l)}}))}});import{fileOpen as dL,fileSave as mL,supported as Ri}from"browser-fs-access";var W2,$l,Xl,Xn=y(()=>{"use strict";f();W();wi();G();W2=500,$l=e=>{let t=e.extensions?.reduce((o,n)=>(o.push(te[n]),o),[]),r=e.extensions?.reduce((o,n)=>n==="jpg"?o.concat(".jpg",".jpeg"):o.concat(`.${n}`),[]);return dL({description:e.description,extensions:r,mimeTypes:t,multiple:e.multiple??!1,legacySetup:(o,n,i)=>{let a=xa(n,W2),l=()=>{s(),document.addEventListener("keyup",a),document.addEventListener("pointerup",a),a()},s=()=>{if(i.files?.length){let d=e.multiple?[...i.files]:i.files[0];o(d)}};requestAnimationFrame(()=>{window.addEventListener("focus",l)});let c=window.setInterval(()=>{s()},W2);return d=>{clearInterval(c),a.cancel(),window.removeEventListener("focus",l),document.removeEventListener("keyup",a),document.removeEventListener("pointerup",a),d&&(console.warn("Opening the file was canceled (legacy-fs)."),d(new an))}}})},Xl=(e,t)=>mL(e,{fileName:`${t.name}.${t.extension}`,description:t.description,extensions:[`.${t.extension}`]},t.fileHandle)});var pL,uL,Y2,Zl,hL,gL,fL,bL,zc,EL,K2,Tp,Oa,$2,Ba,Fa=y(()=>{"use strict";f();xe();me();Oo();W();Dr();or();Ye();G();G();mt();Na();bo();pL={selection:!0,text:!0,rectangle:!0,diamond:!0,ellipse:!0,line:!0,image:!0,arrow:!0,freedraw:!0,eraser:!1,custom:!0,frame:!0,embeddable:!0,hand:!0,laser:!1,magicframe:!1},uL=e=>Object.keys(ht).includes(e)?ht[e]:tr,Y2=e=>e?{...e,focus:e.focus||0}:null,Zl=(e,t)=>{let r={type:t.type||e.type,version:e.version||1,versionNonce:e.versionNonce??0,index:e.index??null,isDeleted:e.isDeleted??!1,id:e.id||zt(),fillStyle:e.fillStyle||at.fillStyle,strokeWidth:e.strokeWidth||at.strokeWidth,strokeStyle:e.strokeStyle??at.strokeStyle,roughness:e.roughness??at.roughness,opacity:e.opacity==null?at.opacity:e.opacity,angle:e.angle||0,x:t.x??e.x??0,y:t.y??e.y??0,strokeColor:e.strokeColor||at.strokeColor,backgroundColor:e.backgroundColor||at.backgroundColor,width:e.width||0,height:e.height||0,seed:e.seed??1,groupIds:e.groupIds??[],frameId:e.frameId??null,roundness:e.roundness?e.roundness:e.strokeSharpness==="round"?{type:nn(e.type)?ct.LEGACY:ct.PROPORTIONAL_RADIUS}:null,boundElements:e.boundElementIds?e.boundElementIds.map(o=>({type:"arrow",id:o})):e.boundElements??[],updated:e.updated??Fn(),link:e.link?yr(e.link):null,locked:e.locked??!1};return("customData"in e||"customData"in t)&&(r.customData="customData"in t?t.customData:e.customData),{...r,...Hc(r),...t}},hL=e=>{switch(e.type){case"text":let t=e.fontSize,r=e.fontFamily;if("font"in e){let[i,a]=e.font.split(" ");t=parseFloat(i),r=uL(a)}let o=typeof e.text=="string"&&e.text||"",n=e.lineHeight||(e.height?m2(e):Xr(e.fontFamily));return e=Zl(e,{fontSize:t,fontFamily:r,text:o,textAlign:e.textAlign||gi,verticalAlign:e.verticalAlign||fa,containerId:e.containerId??null,originalText:e.originalText||o,lineHeight:n}),!o&&!e.isDeleted&&(e={...e,originalText:o,isDeleted:!0},e=_i(e)),e;case"freedraw":return Zl(e,{points:e.points,lastCommittedPoint:null,simulatePressure:e.simulatePressure,pressures:e.pressures});case"image":return Zl(e,{status:e.status||"pending",fileId:e.fileId,scale:e.scale||[1,1]});case"line":case"draw":case"arrow":{let{startArrowhead:i=null,endArrowhead:a=e.type==="arrow"?"arrow":null}=e,l=e.x,s=e.y,c=!Array.isArray(e.points)||e.points.length<2?[[0,0],[e.width,e.height]]:e.points;return(c[0][0]!==0||c[0][1]!==0)&&({points:c,x:l,y:s}=Z.getNormalizedPoints(e)),Zl(e,{type:e.type==="draw"?"line":e.type,startBinding:Y2(e.startBinding),endBinding:Y2(e.endBinding),lastCommittedPoint:null,startArrowhead:i,endArrowhead:a,points:c,x:l,y:s})}case"ellipse":case"rectangle":case"diamond":case"iframe":case"embeddable":return Zl(e,{});case"magicframe":case"frame":return Zl(e,{name:e.name??null})}return null},gL=(e,t)=>{if(e.boundElements){let r=e.boundElements.slice(),o=new Set;e.boundElements=r.reduce((n,i)=>{let a=t.get(i.id);if(a&&!o.has(i.id)){if(o.add(i.id),a.isDeleted)return n;n.push(i),V(a)&&!a.containerId&&(a.containerId=e.id)}return n},[])}},fL=(e,t)=>{let r=e.containerId?t.get(e.containerId):null;if(!r){e.containerId=null;return}if(!e.isDeleted&&r.boundElements&&!r.boundElements.find(o=>o.id===e.id)){let o=(r.boundElements||(r.boundElements=[])).slice();o.push({type:"text",id:e.id}),r.boundElements=o}},bL=(e,t)=>{e.frameId&&(t.get(e.frameId)||(e.frameId=null))},zc=(e,t,r)=>{let o=new Set,n=t?X(t):null,i=fr((e||[]).reduce((l,s)=>{if(s.type!=="selection"&&!yo(s)){let c=hL(s);if(c){let d=n?.get(s.id);d&&d.version>c.version&&(c=_i(c,d.version)),o.has(c.id)&&(c={...c,id:zt()}),o.add(c.id),l.push(c)}}return l},[]));if(!r?.repairBindings)return i;let a=X(i);for(let l of i)l.frameId&&bL(l,a),V(l)&&l.containerId?fL(l,a):l.boundElements&&gL(l,a),r.refreshDimensions&&V(l)&&Object.assign(l,Wl(l,gt(l,a),a));return i},EL=(e,t,r)=>{let o=t[e];return o!==void 0?o:r[e]},K2={isSidebarDocked:(e,t)=>["defaultSidebarDockedPreference",e.isSidebarDocked??EL("defaultSidebarDockedPreference",e,t)]},Tp=(e,t)=>{e=e||{};let r=Er(),o={};for(let n of Object.keys(K2))if(n in e){let[i,a]=K2[n](e,r);o[i]=a}for(let[n,i]of Object.entries(r)){let a=e[n],l=t?t[n]:void 0;o[n]=a!==void 0?a:l!==void 0?l:i}return{...o,cursorButton:t?.cursorButton||"up",penDetected:t?.penDetected??(e.penMode?e.penDetected??!1:!1),activeTool:{...tt(r,o.activeTool.type&&pL[o.activeTool.type]?o.activeTool:{type:"selection"}),lastActiveTool:null,locked:o.activeTool.locked??!1},zoom:typeof e.zoom=="number"?{value:e.zoom}:e.zoom?.value?e.zoom:r.zoom,openSidebar:typeof e.openSidebar=="string"?{name:Vr.name}:o.openSidebar}},Oa=(e,t,r,o)=>({elements:zc(e?.elements,r,o),appState:Tp(e?.appState,t||null),files:e?.files||{}}),$2=e=>{let t=zc(ye(e.elements),null);return t.length?{...e,elements:t}:null},Ba=(e=[],t)=>{let r=[];for(let o of e)if(Array.isArray(o)){let n=$2({status:t,elements:o,id:zt(),created:Date.now()});n&&r.push(n)}else{let n=o,i=$2({...n,id:n.id||zt(),status:n.status||t,created:n.created||Date.now()});i&&r.push(i)}return r}});var X2=y(()=>{"use strict";f();W();_r()});import{deflate as xL,inflate as yL}from"pako";var Xf,Z2,j2,q2,J2,Zf,jf,Q2=y(()=>{"use strict";f();X2();Xf=e=>new Promise((t,r)=>{let o=typeof e=="string"?new Blob([new TextEncoder().encode(e)]):new Blob([e instanceof Uint8Array?e:new Uint8Array(e)]),n=new FileReader;n.onload=i=>{if(!i.target||typeof i.target.result!="string")return r(new Error("couldn't convert to byte string"));t(i.target.result)},n.readAsBinaryString(o)}),Z2=e=>{let t=new ArrayBuffer(e.length),r=new Uint8Array(t);for(let o=0,n=e.length;o<n;o++)r[o]=e.charCodeAt(o);return t},j2=e=>new TextDecoder("utf-8").decode(Z2(e)),q2=async(e,t=!1)=>t?window.btoa(e):window.btoa(await Xf(e)),J2=async(e,t=!1)=>t?window.atob(e):j2(window.atob(e)),Zf=async({text:e,compress:t})=>{let r;if(t!==!1)try{r=await Xf(xL(e))}catch(o){console.error("encode: cannot deflate",o)}return{version:"1",encoding:"bstring",compressed:!!r,encoded:r||await Xf(e)}},jf=async e=>{let t;switch(e.encoding){case"bstring":t=e.compressed?e.encoded:await j2(e.encoded);break;default:throw new Error(`decode: unknown encoding "${e.encoding}"`)}return e.compressed?yL(new Uint8Array(Z2(t)),{to:"string"}):t}});var Uc={};Xs(Uc,{decodePngMetadata:()=>vL,decodeSvgMetadata:()=>SL,encodePngMetadata:()=>qf,encodeSvgMetadata:()=>TL,getTEXtChunk:()=>rv});import ev from"png-chunks-extract";import tv from"png-chunk-text";import wL from"png-chunks-encode";var rv,qf,vL,TL,SL,jl=y(()=>{"use strict";f();Q2();W();_r();rv=async e=>{let r=ev(new Uint8Array(await Zn(e))).find(o=>o.name==="tEXt");return r?tv.decode(r.data):null},qf=async({blob:e,metadata:t})=>{let r=ev(new Uint8Array(await Zn(e))),o=tv.encode(te.excalidraw,JSON.stringify(await Zf({text:t,compress:!0})));return r.splice(-1,0,o),new Blob([wL(r)],{type:te.png})},vL=async e=>{let t=await rv(e);if(t?.keyword===te.excalidraw)try{let r=JSON.parse(t.text);if(!("encoded"in r)){if("type"in r&&r.type===ar.excalidraw)return t.text;throw new Error("FAILED")}return await jf(r)}catch(r){throw console.error(r),new Error("FAILED")}throw new Error("INVALID")},TL=async({text:e})=>{let t=await q2(JSON.stringify(await Zf({text:e})),!0),r="";return r+=`<!-- payload-type:${te.excalidraw} -->`,r+="<!-- payload-version:2 -->",r+="<!-- payload-start -->",r+=t,r+="<!-- payload-end -->",r},SL=async({svg:e})=>{if(e.includes(`payload-type:${te.excalidraw}`)){let t=e.match(/<!-- payload-start -->\s*(.+?)\s*<!-- payload-end -->/);if(!t)throw new Error("INVALID");let n=(e.match(/<!-- payload-version:(\d+) -->/)?.[1]||"1")!=="1";try{let i=await J2(t[1],n),a=JSON.parse(i);if(!("encoded"in a)){if("type"in a&&a.type===ar.excalidraw)return i;throw new Error("FAILED")}return await jf(a)}catch(i){throw console.error(i),new Error("FAILED")}}throw new Error("INVALID")}});import{nanoid as CL}from"nanoid";var nv,Jf,iv,ql,Ni,Cp,Jl,Qf,e1,jn,av,Ip,lv,Gc,t1,sv,cv,IL,ov,Sp,Vc,Zn,_r=y(()=>{"use strict";f();Dr();W();xe();wi();qe();G();Xn();qn();Fa();nv=async e=>{let t;if(e.type===te.png)try{return await(await Promise.resolve().then(()=>(jl(),Uc))).decodePngMetadata(e)}catch(r){throw r.message==="INVALID"?new Bo("Image doesn't contain scene","IMAGE_NOT_CONTAINS_SCENE_DATA"):new Bo("Error: cannot restore image")}else if("text"in Blob?t=await e.text():t=await new Promise(r=>{let o=new FileReader;o.readAsText(e,"utf8"),o.onloadend=()=>{o.readyState===FileReader.DONE&&r(o.result)}}),e.type===te.svg)try{return await(await Promise.resolve().then(()=>(jl(),Uc))).decodeSvgMetadata({svg:t})}catch(r){throw r.message==="INVALID"?new Bo("Image doesn't contain scene","IMAGE_NOT_CONTAINS_SCENE_DATA"):new Bo("Error: cannot restore image")}return t},Jf=e=>e&&e.name.match(/\.(json|excalidraw|png|svg)$/)?.[1]||null,iv=e=>e==="png"||e==="svg",ql=e=>{let t=Jf(e);return t==="png"||t==="svg"},Ni=e=>{let{type:t}=e||{};return!!t&&Object.values(Qs).includes(t)},Cp=async(e,t,r,o)=>{let n=await nv(e),i;try{try{i=JSON.parse(n)}catch(a){throw Ni(e)?new Bo("Image doesn't contain scene","IMAGE_NOT_CONTAINS_SCENE_DATA"):a}if(dv(i))return{type:te.excalidraw,data:Oa({elements:Ap(i.elements||[]),appState:{theme:t?.theme,fileHandle:o||e.handle||null,...Ac(i.appState||{}),...t?gn(i.elements||[],t):{}},files:i.files},t,r,{repairBindings:!0,refreshDimensions:!1})};if(r1(i))return{type:te.excalidrawlib,data:i};throw new Error("Error: invalid file")}catch(a){throw a instanceof Bo?a:new Error("Error: invalid file")}},Jl=async(e,t,r,o)=>{let n=await Cp(e,t,r,o);if(n.type!==te.excalidraw)throw new Error("Error: invalid file");return n.data},Qf=(e,t="unpublished")=>{let r=JSON.parse(e);if(!r1(r))throw new Error("Invalid library");let o=r.libraryItems||r.library;return Ba(o,t)},e1=async(e,t="unpublished")=>Qf(await nv(e),t),jn=async e=>new Promise(async(t,r)=>{try{tn(e)&&(e=await e),e.toBlob(o=>{if(!o)return r(new Bm("Error: Canvas too big","CANVAS_POSSIBLY_TOO_BIG"));t(o)})}catch(o){r(o)}}),av=async e=>{try{let t=await window.crypto.subtle.digest("SHA-1",await Zn(e));return nw(new Uint8Array(t))}catch(t){return console.error(t),CL(40)}},Ip=async e=>new Promise((t,r)=>{let o=new FileReader;o.onload=()=>{let n=o.result;t(n)},o.onerror=n=>r(n),o.readAsDataURL(e)}),lv=(e,t="")=>{let r=e.indexOf(","),o=atob(e.slice(r+1)),n=e.slice(0,r).split(":")[1].split(";")[0],i=new ArrayBuffer(o.length),a=new Uint8Array(i);for(let l=0;l<o.length;l++)a[l]=o.charCodeAt(l);return new File([i],t,{type:n})},Gc=async(e,t)=>{if(e.type===te.svg)return e;let[r,o]=await Promise.all([import("pica").then(i=>i.default),import("image-blob-reduce").then(i=>i.default)]),n=o({pica:r({features:["js","wasm"]})});if(t.outputType){let{outputType:i}=t;n._create_blob=function(a){return this.pica.toBlob(a.out_canvas,i,.8).then(l=>(a.out_blob=l,a))}}if(!Ni(e))throw new Error("Error: unsupported file type",{cause:"UNSUPPORTED"});return new File([await n.toBlob(e,{max:t.maxWidthOrHeight})],e.name,{type:t.outputType||e.type})},t1=(e,t="")=>new File([new TextEncoder().encode(e)],t,{type:te.svg}),sv=async(e,t="")=>{let r;try{r=await fetch(e)}catch{throw new Error("Error: failed to fetch image",{cause:"FETCH_ERROR"})}if(!r.ok)throw new Error("Error: failed to fetch image",{cause:"FETCH_ERROR"});let o=await r.blob();if(o.type&&Ni(o)){let n=t||o.name||"";return new File([o],n,{type:o.type})}throw new Error("Error: unsupported file type",{cause:"UNSUPPORTED"})},cv=async e=>{let t=e.dataTransfer.files.item(0),r=await IL(e);return{file:t?await Vc(t):null,fileHandle:r}},IL=async e=>{if(Ri)try{return await e.dataTransfer.items[0].getAsFileSystemHandle()||null}catch(t){return console.warn(t.name,t.message),null}return null},ov=e=>{let t=null,r=`${[...new Uint8Array(e).slice(0,8)].join(" ")} `,o={png:"137 80 78 71 13 10 26 10 ",jpg:"255 216 255 ",gif:"71 73 70 56 57 97 "};return r===o.png?t=te.png:r.startsWith(o.jpg)?t=te.jpg:r.startsWith(o.gif)&&(t=te.gif),t},Sp=(e,t,r)=>new File([e],r||"",{type:t}),Vc=async e=>{if(e.type){if(Ni(e)){let t=await Zn(e),r=ov(t);r&&r!==e.type&&(e=Sp(t,r,e.name))}}else if(e?.name?.endsWith(".excalidrawlib"))e=Sp(await Zn(e),te.excalidrawlib,e.name);else if(e?.name?.endsWith(".excalidraw"))e=Sp(await Zn(e),te.excalidraw,e.name);else{let t=await Zn(e),r=ov(t);r&&(e=Sp(t,r,e.name))}return e},Zn=e=>"arrayBuffer"in e?e.arrayBuffer():new Promise((t,r)=>{let o=new FileReader;o.onload=n=>{if(!n.target?.result)return r(new Error("Couldn't convert blob to ArrayBuffer"));t(n.target.result)},o.readAsArrayBuffer(e)})});var AL,Oi,kp,o1,dv,r1,Mp,mv,qn=y(()=>{"use strict";f();Xn();Dr();W();xe();_r();AL=(e,t)=>{let r={};for(let o of e)!o.isDeleted&&"fileId"in o&&o.fileId&&t[o.fileId]&&(r[o.fileId]=t[o.fileId]);return r},Oi=(e,t,r,o)=>{let n={type:ar.excalidraw,version:Ea.excalidraw,source:ec,elements:o==="local"?Ap(e):pv(e),appState:o==="local"?Ac(t):w2(t),files:o==="local"?AL(e,r):void 0};return JSON.stringify(n,null,2)},kp=async(e,t,r,o=t.name||km)=>{let n=Oi(e,t,r,"local"),i=new Blob([n],{type:te.excalidraw});return{fileHandle:await Xl(i,{name:o,extension:"excalidraw",description:"Excalidraw file",fileHandle:ql(t.fileHandle)?null:t.fileHandle})}},o1=async(e,t)=>{let r=await $l({description:"Excalidraw files"});return Jl(await Vc(r),e,t,r.handle)},dv=e=>e?.type===ar.excalidraw&&(!e.elements||Array.isArray(e.elements)&&(!e.appState||typeof e.appState=="object")),r1=e=>typeof e=="object"&&e&&e.type===ar.excalidrawLibrary&&(e.version===1||e.version===2),Mp=e=>{let t={type:ar.excalidrawLibrary,version:Ea.excalidrawLibrary,source:ec,libraryItems:e};return JSON.stringify(t,null,2)},mv=async e=>{let t=Mp(e);await Xl(new Blob([t],{type:te.excalidrawlib}),{name:"library",extension:"excalidrawlib",description:"Excalidraw library file"})}});var n1,Lp,Pp,kL,uv,i1=y(()=>{"use strict";f();W();me();n1=e=>new Promise((t,r)=>{let o=new Image;o.onload=()=>{t(o)},o.onerror=n=>{r(n)},o.src=e}),Lp=async({fileIds:e,files:t,imageCache:r})=>{let o=new Map,n=new Map;return await Promise.all(e.reduce((i,a)=>{let l=t[a];return l&&!o.has(a)?(o.set(a,!0),i.concat((async()=>{try{if(l.mimeType===te.binary)throw new Error("Only images can be added to ImageCache");let s=n1(l.dataURL),c={image:s,mimeType:l.mimeType};r.set(a,c);let d=await s;r.set(a,{...c,image:d})}catch{n.set(a,!0)}})())):i},[])),{imageCache:r,updatedFiles:o,erroredFiles:n}},Pp=e=>e.filter(t=>gr(t)),kL=e=>e?.nodeName.toLowerCase()==="svg",uv=async e=>{let t=new DOMParser().parseFromString(e,te.svg),r=t.querySelector("svg");if(t.querySelector("parsererror")||!kL(r))throw new Error("Invalid SVG");if(r.hasAttribute("xmlns")||r.setAttribute("xmlns",We),!r.hasAttribute("width")||!r.hasAttribute("height")){let n=r.getAttribute("viewBox"),i=r.getAttribute("width")||"50",a=r.getAttribute("height")||"50";if(n){let l=n.match(/\d+ +\d+ +(\d+) +(\d+)/);l&&([,i,a]=l)}r.setAttribute("width",i),r.setAttribute("height",a)}return r.outerHTML}});import{pointsOnBezierCurves as ML}from"points-on-curve";var Dp,hv,gv,fv,bv,LL,Ev,xv,a1=y(()=>{"use strict";f();xe();Km();Dp=e=>{let{angle:t,width:r,height:o,x:n,y:i}=e,a=cn(t),l=n+r/2,s=i+o/2,c=[l,s],d=[];return e.type==="diamond"?d=[wt([l,i],a,c),wt([n+r,s],a,c),wt([l,i+o],a,c),wt([n,s],a,c)]:d=[wt([n,i],a,c),wt([n+r,i],a,c),wt([n+r,i+o],a,c),wt([n,i+o],a,c)],{type:"polygon",data:d}},hv=(e,t,r=10)=>{let[o,n,i,a,l,s]=oe(e,t,!0);o-=r,i+=r,n-=r,a+=r;let c=cn(e.angle),d=[l,s],m=wt([o,n],c,d),p=wt([i,n],c,d),u=wt([o,a],c,d),h=wt([i,a],c,d);return{type:"polygon",data:[m,p,h,u]}},gv=e=>{let{width:t,height:r,angle:o,x:n,y:i}=e;return{type:"ellipse",data:{center:[n+t/2,i+r/2],angle:o,halfWidth:t/2,halfHeight:r/2}}},fv=e=>{for(let t of e.sets)if(t.type==="path")return t.ops;return e.sets[0].ops},bv=(e,t=[0,0],r,o)=>{let n=s=>wt([s[0]+t[0],s[1]+t[1]],cn(r),o),i=fv(e),a=[],l=[0,0];for(let s of i)if(s.op==="move"&&(l=n(s.data)),s.op==="bcurveTo"){let c=n([s.data[0],s.data[1]]),d=n([s.data[2],s.data[3]]),m=n([s.data[4],s.data[5]]);a.push([l,c,d,m]),l=m}return{type:"polycurve",data:a}},LL=e=>{let t=e[0],r=[];for(let o=1;o<e.length;o++){let n=e[o];r.push([t,n]),t=n}return r},Ev=(e,t,r=!1)=>{let o=cn(e.angle),n=a=>wt(xf(a,[e.x,e.y]),o,t),i=LL(e.points.map(a=>n(a)));return r?{type:"polygon",data:Nl(i.flat())}:{type:"polyline",data:i}},xv=(e,t,r=[0,0],o,n)=>{let i=d=>wt([d[0]+r[0],d[1]+r[1]],cn(o),n);if(e.roundness===null)return{type:"polygon",data:Nl(e.points.map(d=>i(d)))};let a=fv(t),l=[],s=!1;for(let d of a)d.op==="move"?(s=!s,s&&l.push([d.data[0],d.data[1]])):d.op==="bcurveTo"?s&&(l.push([d.data[0],d.data[1]]),l.push([d.data[2],d.data[3]]),l.push([d.data[4],d.data[5]])):d.op==="lineTo"&&s&&l.push([d.data[0],d.data[1]]);return{type:"polygon",data:ML(l,10,5).map(d=>i(d))}}});var _p,za,Wc,yv,wv,Rp=y(()=>{"use strict";f();Kt();dt();a1();$m();G();me();_p=e=>{if(e.type==="arrow")return!1;let t=!hr(e.backgroundColor)||lr(e)||rr(e)||V(e);return e.type==="line"?t&&br(e.points):e.type==="freedraw"?t&&br(e.points):t||ho(e)},za=({x:e,y:t,element:r,shape:o,threshold:n=10,frameNameBound:i=null})=>{let a=_p(r)?Ol([e,t],o)||Ec([e,t],o,n):Ec([e,t],o,n);return!a&&i&&(a=Ol([e,t],{type:"polygon",data:Dp(i).data})),a},Wc=(e,t,r,o,n=0)=>{let[i,a,l,s]=Zr(r,o);return i-=n,a-=n,l+=n,s+=n,Um([i,a],[e,t],[l,s])},yv=(e,t)=>!za(e)&&Wc(e.x,e.y,e.element,t),wv=(e,t,r)=>r&&Ol([e,t],r)});var l1,Yc,s1,Np,Op=y(()=>{"use strict";f();W();dt();Rp();Kt();sn();l1=document.createElement("img");l1.src=`data:${te.svg}, ${encodeURIComponent('<svg xmlns="http://www.w3.org/2000/svg" width="16" height="16" viewBox="0 0 24 24" fill="none" stroke="#1971c2" stroke-width="2" stroke-linecap="round" stroke-linejoin="round" class="feather feather-external-link"><path d="M18 13v6a2 2 0 0 1-2 2H5a2 2 0 0 1-2-2V8a2 2 0 0 1 2-2h6"></path><polyline points="15 3 21 3 21 9"></polyline><line x1="10" y1="14" x2="21" y2="3"></line></svg>')}`;Yc=([e,t,r,o],n,i)=>{let a=vv,l=a/i.zoom.value,s=a/i.zoom.value,c=a/i.zoom.value,d=(e+r)/2,m=(t+o)/2,p=(a-8)/(2*i.zoom.value),u=4/i.zoom.value,h=r+u-p,E=t-u-c+p,[x,T]=Se(h+l/2,E+s/2,d,m,n);return[x-l/2,T-s/2,l,s]},s1=(e,t,r,[o,n])=>{let i=4/r.zoom.value,[a,l,s,c]=oe(e,t),[d,m,p,u]=Yc([a,l,s,c],e.angle,r);return o>d-i&&o<d+i+p&&n>m-i&&n<m+u+i},Np=(e,t,r,[o,n],i)=>!e.link||r.selectedElementIds[e.id]?!1:!i&&r.viewModeEnabled&&Wc(o,n,e,t)?!0:s1(e,t,r,[o,n])});var Kc,Bp,Fp,c1=y(()=>{"use strict";f();W();Kc=(e,t,r,o,n=!0)=>{e.beginPath(),e.arc(t,r,o,0,Math.PI*2),e.fill(),n&&e.stroke()},Bp=(e,t)=>[e.width/t,e.height/t],Fp=({canvas:e,scale:t,normalizedWidth:r,normalizedHeight:o,theme:n,isExporting:i,canvasBackgroundColor:a})=>{let l=e.getContext("2d");return l.setTransform(1,0,0,1,0,0),l.scale(t,t),i&&n===se.DARK&&(l.filter=Cl),typeof a=="string"?((a==="transparent"||a.length===5||a.length===9||/(hsla|rgba)\(/.test(a))&&l.clearRect(0,0,r,o),l.save(),l.fillStyle=a,l.fillRect(0,0,r,o),l.restore()):l.clearRect(0,0,r,o),l}});var PL,Tv,Jn,Sv,Cv,d1,Hp,Up=y(()=>{"use strict";f();W();xe();dr();me();sn();Oc();Op();c1();G();mt();PL=(e,t,r,o,n,i,a)=>{let s={Bold:"#cccccc",Regular:"#e5e5e5"},c=-Math.round(n.value/t)*t+r%t,d=-Math.round(n.value/t)*t+o%t,m=Math.min(1/n.value,1),p=1/n.value,u=[m*3,p+(m+p)];e.save(),e.lineWidth=m;for(let h=c;h<c+i+t*2;h+=t){let E=Math.round(h-r)%(5*t)===0;e.beginPath(),e.setLineDash(E?[]:u),e.strokeStyle=E?s.Bold:s.Regular,e.moveTo(h,d-t),e.lineTo(h,d+a+t*2),e.stroke()}for(let h=d;h<d+a+t*2;h+=t){let E=Math.round(h-o)%(5*t)===0;e.beginPath(),e.setLineDash(E?[]:u),e.strokeStyle=E?s.Bold:s.Regular,e.moveTo(c-t,h),e.lineTo(c+i+t*2,h),e.stroke()}e.restore()},Tv=(e,t,r,o)=>{t.translate(e.x+o.scrollX,e.y+o.scrollY),t.beginPath(),t.roundRect?t.roundRect(0,0,e.width,e.height,et.radius/o.zoom.value):t.rect(0,0,e.width,e.height),t.clip(),t.translate(-(e.x+o.scrollX),-(e.y+o.scrollY))},Sv=(e,t,r,o)=>{if(e.link&&!r.selectedElementIds[e.id]){let[n,i,a,l]=oe(e,o),[s,c,d,m]=Yc([n,i,a,l],e.angle,r),p=s+d/2,u=c+m/2;if(t.save(),t.translate(r.scrollX+p,r.scrollY+u),t.rotate(e.angle),!Jn||Jn.zoom!==r.zoom.value){Jn=document.createElement("canvas"),Jn.zoom=r.zoom.value,Jn.width=d*window.devicePixelRatio*r.zoom.value,Jn.height=m*window.devicePixelRatio*r.zoom.value;let h=Jn.getContext("2d");h.scale(window.devicePixelRatio*r.zoom.value,window.devicePixelRatio*r.zoom.value),h.fillStyle="#fff",h.fillRect(0,0,d,m),h.drawImage(l1,0,0,d,m),h.restore(),t.drawImage(Jn,s-p,c-u,d,m)}else t.drawImage(Jn,s-p,c-u,d,m);t.restore()}},Cv=({canvas:e,rc:t,elementsMap:r,allElementsMap:o,visibleElements:n,scale:i,appState:a,renderConfig:l})=>{if(e===null)return;let{renderGrid:s=!0,isExporting:c}=l,[d,m]=Bp(e,i),p=Fp({canvas:e,scale:i,normalizedWidth:d,normalizedHeight:m,theme:a.theme,isExporting:c,canvasBackgroundColor:l.canvasBackgroundColor});p.scale(a.zoom.value,a.zoom.value),s&&a.gridSize&&PL(p,a.gridSize,a.scrollX,a.scrollY,a.zoom,d/a.zoom.value,m/a.zoom.value);let u=new Set;n.forEach(h=>{h.groupIds.length>0&&a.frameToHighlight&&a.selectedElementIds[h.id]&&(fn(h,a.frameToHighlight,r)||h.groupIds.find(E=>u.has(E)))&&h.groupIds.forEach(E=>u.add(E))}),n.filter(h=>!rr(h)).forEach(h=>{try{let E=h.frameId||a.frameToHighlight?.id;if(V(h)&&h.containerId&&r.has(h.containerId))return;if(p.save(),E&&a.frameRendering.enabled&&a.frameRendering.clip){let T=zp(h,r,a);T&&Ha(h,r,a)&&Tv(T,p,l,a),Ql(h,r,o,t,p,l,a)}else Ql(h,r,o,t,p,l,a);let x=ue(h,r);x&&Ql(x,r,o,t,p,l,a),p.restore(),c||Sv(h,p,a,r)}catch(E){console.error(E)}}),n.filter(h=>rr(h)).forEach(h=>{try{let E=()=>{if(Ql(h,r,o,t,p,l,a),rr(h)&&(c||Lt(h)&&l.embedsValidationStatus.get(h.id)!==!0)&&h.width&&h.height){let T=yp(h);Ql(T,r,o,t,p,l,a)}c||Sv(h,p,a,r)};if((h.frameId||a.frameToHighlight?.id)&&a.frameRendering.enabled&&a.frameRendering.clip){p.save();let T=zp(h,r,a);T&&Ha(h,r,a)&&Tv(T,p,l,a),E(),p.restore()}else E()}catch(E){console.error(E)}})},d1=Ml(e=>{Cv(e)},{trailing:!0}),Hp=(e,t)=>{if(t){d1(e);return}Cv(e)}});import Iv from"roughjs/bin/rough";var DL,_L,RL,Av,kv,Bi,es,Gp,ts=y(()=>{"use strict";f();dt();V2();G();W();Dr();qn();i1();Fa();dr();xe();Ye();me();bo();Up();DL="<!-- svg-source:excalidraw -->",_L=(e,t)=>{if(e.width<=t)return e;let o=document.createElement("canvas").getContext("2d");o.font=Ze({fontFamily:e.fontFamily,fontSize:e.fontSize});let n=e.text;if(o.measureText(n).width>t)for(let a=n.length;a>0;a--){let l=`${n.slice(0,a)}...`;if(o.measureText(l).width<=t){n=l;break}}return le(e,{text:n,width:t})},RL=(e,t)=>{let r=[],o=0,n=0;for(let i of e){if(re(i)){yi(i)?o++:n++;let a=$t({x:i.x,y:i.y-et.nameOffsetY,fontFamily:ht.Assistant,fontSize:et.nameFontSize,lineHeight:et.nameLineHeight,strokeColor:t.exportWithDarkMode?et.nameColorDarkTheme:et.nameColorLightTheme,text:Vp(i,yi(i)?o:n)});a.y-=a.height,a=_L(a,i.width),r.push(a)}r.push(i)}return r},Av=(e,t)=>(t=t||Er().frameRendering,{enabled:e?!0:t.enabled,outline:e?!1:t.outline,name:e?!1:t.name,clip:e?!0:t.clip}),kv=({elements:e,exportingFrame:t,frameRendering:r,exportWithDarkMode:o})=>{let n;return t?n=rs(e,t):r.enabled&&r.name?n=RL(e,{exportWithDarkMode:o}):n=e,n},Bi=async({data:e,config:t})=>{let r=Object.assign({},t),{files:o}=e,{exportingFrame:n}=r,i=e.elements,a=Tp(e.appState,null),l=Av(n??null,a.frameRendering??null),s=kv({elements:i,exportingFrame:n,exportWithDarkMode:a.exportWithDarkMode,frameRendering:l});n&&(r.padding=0),r.fit=r.fit??(r.width!=null||r.height!=null||r.maxWidthOrHeight!=null||r.widthOrHeight!=null?"contain":"none");let c=r.fit==="contain";(r.x!=null||r.x!=null)&&(r.fit="none"),r.fit==="cover"&&(r.padding&&!S.PROD&&console.warn("`padding` is ignored when `fit` is set to `cover`"),r.padding=0),r.padding=r.padding??0,r.scale=r.scale??1,r.origin=r.origin??"canvas",r.position=r.position??"center",r.maxWidthOrHeight!=null&&r.widthOrHeight!=null&&(S.PROD||console.warn("`maxWidthOrHeight` is ignored when `widthOrHeight` is set"),r.maxWidthOrHeight=void 0),(r.maxWidthOrHeight!=null||r.width!=null||r.height!=null)&&r.getDimensions&&(S.PROD||console.warn("`getDimensions` is ignored when `width`, `height`, or `maxWidthOrHeight` is set"),r.getDimensions=void 0);let d=1,m=Gp(n?[n]:m1(s)),[p,u,h,E]=m,[x,T,v,w]=m;if(r.width!=null?(v=r.width,r.padding&&c&&(v-=r.padding*2),r.height?(w=r.height,r.padding&&c&&(w-=r.padding*2)):w*=v/h):r.height!=null&&(w=r.height,r.padding&&c&&(w-=r.padding*2),v*=w/E),r.maxWidthOrHeight!=null||r.widthOrHeight!=null){c&&r.padding&&(r.maxWidthOrHeight!=null?r.maxWidthOrHeight-=r.padding*2:r.widthOrHeight!=null&&(r.widthOrHeight-=r.padding*2));let M=Math.max(v,w);r.widthOrHeight!=null?d=r.widthOrHeight/M:r.maxWidthOrHeight!=null&&(d=r.maxWidthOrHeight<M?r.maxWidthOrHeight/M:1),v*=d,w*=d}else if(r.getDimensions){let M=r.getDimensions(v,w);v=M.width,w=M.height,r.scale=M.scale??r.scale}else if(c&&r.padding&&r.width==null&&r.height==null){let M=v/w;v-=r.padding*2,w-=r.padding*2/M}if(r.fit==="contain"&&!r.maxWidthOrHeight||c&&r.padding)if(r.fit==="contain"){let M=v/h,D=w/E;d=Math.min(M,D)}else{let M=(v-r.padding*2)/v,D=(w-r.padding*2)/w;d=Math.min(M,D)}else if(r.fit==="cover"){let M=v/h,D=w/E;d=Math.max(M,D)}x=r.x??p,T=r.y??u,r.origin==="content"&&(r.x!=null&&(x+=p),r.y!=null&&(T+=u)),r.position==="center"&&(x-=v/d/2-(r.x==null?h:v+r.padding*2)/2,T-=w/d/2-(r.y==null?E:w+r.padding*2)/2);let I=r.createCanvas?r.createCanvas():document.createElement("canvas"),L=r.padding/d;d*=r.scale,v*=r.scale,w*=r.scale,I.width=v+r.padding*2*r.scale,I.height=w+r.padding*2*r.scale;let{imageCache:A}=await Lp({imageCache:new Map,fileIds:Pp(s).map(M=>M.fileId),files:o||{}});return Hp({canvas:I,rc:Iv.canvas(I),elementsMap:Yr(X(s)),allElementsMap:Yr(X(fr(i))),visibleElements:s,appState:{...a,frameRendering:l,width:v,height:w,offsetLeft:0,offsetTop:0,scrollX:-x+L,scrollY:-T+L,zoom:{value:ym},shouldCacheIgnoreZoom:!1,theme:r.theme||se.LIGHT},scale:d,renderConfig:{canvasBackgroundColor:r.canvasBackgroundColor===!1?null:r.canvasBackgroundColor||a.viewBackgroundColor||Gt,imageCache:A,renderGrid:!1,isExporting:!0,embedsValidationStatus:new Map,elementsPendingErasure:new Set}}),I},es=async({data:e,config:t})=>{let r=Object.assign({},t);r.exportingFrame=r.exportingFrame??null;let o=e.elements,n=Av(r?.exportingFrame??null,e.appState.frameRendering??null),{exportPadding:i=Jo,exportWithDarkMode:a=!1,viewBackgroundColor:l,exportScale:s=1,exportEmbedScene:c}=e.appState,d=kv({elements:o,exportingFrame:r.exportingFrame,exportWithDarkMode:a,frameRendering:n});r.exportingFrame&&(i=0);let m="";if(c)try{m=await(await Promise.resolve().then(()=>(jl(),Uc))).encodeSvgMetadata({text:Oi(o,e.appState,e.files||{},"local")})}catch(O){console.error(O)}let[p,u,h,E]=Gp(r.exportingFrame?[r.exportingFrame]:m1(d));h+=i*2,E+=i*2;let x=document.createElementNS(We,"svg");x.setAttribute("version","1.1"),x.setAttribute("xmlns",We),x.setAttribute("viewBox",`0 0 ${h} ${E}`),x.setAttribute("width",`${h*s}`),x.setAttribute("height",`${E*s}`),a&&x.setAttribute("filter",Cl);let T="https://excalidraw.com/";S.VITE_IS_EXCALIDRAW_NPM_PACKAGE&&(T=window.EXCALIDRAW_ASSET_PATH||`https://unpkg.com/${S.VITE_PKG_NAME}@${S.PKG_VERSION}`,T?.startsWith("/")&&(T=T.replace("/",`${window.location.origin}/`)),T=`${T}/dist/excalidraw-assets/`);let v=-p+i,w=-u+i,I=$c(o),L="",A=X(o);for(let O of I){let[R,B,k,z]=oe(O,A),ee=(k-R)/2-(O.x-R),j=(z-B)/2-(O.y-B);L+=`<clipPath id=${O.id}>
37
+ <rect transform="translate(${O.x+v} ${O.y+w}) rotate(${O.angle} ${ee} ${j})"
38
+ width="${O.width}"
39
+ height="${O.height}"
40
40
  >
41
41
  </rect>
42
- </clipPath>`}if(E.innerHTML=`
43
- ${SM}
42
+ </clipPath>`}if(x.innerHTML=`
43
+ ${DL}
44
44
  ${m}
45
45
  <defs>
46
46
  <style class="style-fonts">
@@ -54,27 +54,27 @@ var yk=Object.defineProperty;var H0=e=>t=>{var o=e[t];if(o)return o();throw new
54
54
  }
55
55
  @font-face {
56
56
  font-family: "Assistant";
57
- src: url("${y}Assistant-Regular.woff2");
57
+ src: url("${T}Assistant-Regular.woff2");
58
58
  }
59
59
  </style>
60
- ${M}
60
+ ${L}
61
61
  </defs>
62
- `,e.appState.exportBackground&&l){let F=E.ownerDocument.createElementNS(Ue,"rect");F.setAttribute("x","0"),F.setAttribute("y","0"),F.setAttribute("width",`${g}`),F.setAttribute("height",`${x}`),F.setAttribute("fill",l),E.appendChild(F)}let R=Lw.svg(E),P=o.renderEmbeddables??!1;return ew(d,Ir(re(d)),R,E,e.files||{},{offsetX:T,offsetY:w,isExporting:!0,exportWithDarkMode:a,renderEmbeddables:P,frameRendering:n,canvasBackgroundColor:l,embedsValidationStatus:P?new Map(d.filter(F=>Q(F)).map(F=>[F.id,!0])):new Map}),E},fp=e=>{let[t,o,r,n]=Se(e),i=Nt(t,r),a=Nt(o,n);return[t,o,i,a]}});import MM from"open-color";var Dw,La,Rw,$l,Xl,Fr,Hr,ve,Nw,xp,Ep,yp,Ow,Bw,Fw,Hw,Wo=v(()=>{"use strict";f();U();G();Dw=5,La=5,Rw=4,$l=4,Xl=1,Fr=[0,2,4,6,8],Hr=(e,t)=>t.map(o=>MM[e][o]),ve={transparent:zs,charcoal:si,white:Ht,gray:Hr("gray",Fr),red:Hr("red",Fr),pink:Hr("pink",Fr),grape:Hr("grape",Fr),violet:Hr("violet",Fr),blue:Hr("blue",Fr),cyan:Hr("cyan",Fr),teal:Hr("teal",Fr),green:Hr("green",Fr),yellow:Hr("yellow",Fr),orange:Hr("orange",Fr),bronze:["#f8f1ee","#eaddd7","#d2bab0","#a18072","#846358"]},Nw=My(ve,["cyan","blue","violet","grape","pink","green","teal","yellow","orange","red"]),xp=[ve.charcoal,ve.red[$l],ve.green[$l],ve.blue[$l],ve.yellow[$l]],Ep=[ve.transparent,ve.red[Xl],ve.green[Xl],ve.blue[Xl],ve.yellow[Xl]],yp=[ve.white,"#f8f9fa","#f5faff","#fffce8","#fdf8f6"],Ow={transparent:ve.transparent,white:ve.white,gray:ve.gray,charcoal:ve.charcoal,bronze:ve.bronze,...Nw},Bw={transparent:ve.transparent,white:ve.white,gray:ve.gray,charcoal:ve.charcoal,bronze:ve.bronze,...Nw},Fw=e=>[ve.cyan[e],ve.blue[e],ve.violet[e],ve.grape[e],ve.pink[e],ve.green[e],ve.teal[e],ve.yellow[e],ve.orange[e],ve.red[e]],Hw=(e,t,o)=>`#${((1<<24)+(e<<16)+(t<<8)+o).toString(16).slice(1)}`});var zr,et,ki,Gw,_a,Zl,Rc,Rf,zw,LM,Uw,wp,mr,Ww,_M,PM,DM,Vw,RM,NM,Yw,Nf=v(()=>{"use strict";f();Wo();U();he();Sr();zr=32,et=12,ki=256,Gw=50,_a="NOT_SPREADSHEET",Zl="VALID_SPREADSHEET",Rc=e=>{let t=/^([-+]?)[$€£¥₩]?([-+]?)([\d.,]+)[%]?$/.exec(e);return t?parseFloat(`${(t[1]||t[2])+t[3]}`.replace(/,/g,"")):null},Rf=(e,t)=>e.slice(1).every(o=>Rc(o[t])!==null),zw=e=>{let t=e[0].length;if(t>2)return{type:_a,reason:"More than 2 columns"};if(t===1){if(!Rf(e,0))return{type:_a,reason:"Value is not numeric"};let s=Rc(e[0][0])===null,c=(s?e.slice(1):e).map(d=>Rc(d[0]));return c.length<2?{type:_a,reason:"Less than two rows"}:{type:Zl,spreadsheet:{title:s?e[0][0]:null,labels:null,values:c}}}let o=Rf(e,0),r=Rf(e,1);if(!o&&!r)return{type:_a,reason:"Value is not numeric"};let[n,i]=r?[0,1]:[1,0],a=Rc(e[0][i])===null,l=a?e.slice(1):e;return l.length<2?{type:_a,reason:"Less than 2 rows"}:{type:Zl,spreadsheet:{title:a?e[0][i]:null,labels:l.map(s=>s[n]),values:l.map(s=>Rc(s[i]))}}},LM=e=>{let t=[];for(let o=0;o<e[0].length;o++){let r=[];for(let n=0;n<e.length;n++)r.push(e[n][o]);t.push(r)}return t},Uw=e=>{let t=e.trim().split(`
62
+ `,e.appState.exportBackground&&l){let O=x.ownerDocument.createElementNS(We,"rect");O.setAttribute("x","0"),O.setAttribute("y","0"),O.setAttribute("width",`${h}`),O.setAttribute("height",`${E}`),O.setAttribute("fill",l),x.appendChild(O)}let M=Iv.svg(x),D=r.renderEmbeddables??!1;return G2(d,Yr(X(d)),M,x,e.files||{},{offsetX:v,offsetY:w,isExporting:!0,exportWithDarkMode:a,renderEmbeddables:D,frameRendering:n,canvasBackgroundColor:l,embedsValidationStatus:D?new Map(d.filter(O=>re(O)).map(O=>[O.id,!0])):new Map}),x},Gp=e=>{let[t,r,o,n]=Ae(e),i=Bt(t,o),a=Bt(r,n);return[t,r,i,a]}});import NL from"open-color";var Mv,Ua,Lv,os,ns,Wo,Yo,Te,Pv,Wp,Yp,Kp,Dv,_v,Rv,Nv,Qr=y(()=>{"use strict";f();W();G();Mv=5,Ua=5,Lv=4,os=4,ns=1,Wo=[0,2,4,6,8],Yo=(e,t)=>t.map(r=>NL[e][r]),Te={transparent:Js,charcoal:bi,white:Gt,gray:Yo("gray",Wo),red:Yo("red",Wo),pink:Yo("pink",Wo),grape:Yo("grape",Wo),violet:Yo("violet",Wo),blue:Yo("blue",Wo),cyan:Yo("cyan",Wo),teal:Yo("teal",Wo),green:Yo("green",Wo),yellow:Yo("yellow",Wo),orange:Yo("orange",Wo),bronze:["#f8f1ee","#eaddd7","#d2bab0","#a18072","#846358"]},Pv=dw(Te,["cyan","blue","violet","grape","pink","green","teal","yellow","orange","red"]),Wp=[Te.charcoal,Te.red[os],Te.green[os],Te.blue[os],Te.yellow[os]],Yp=[Te.transparent,Te.red[ns],Te.green[ns],Te.blue[ns],Te.yellow[ns]],Kp=[Te.white,"#f8f9fa","#f5faff","#fffce8","#fdf8f6"],Dv={transparent:Te.transparent,white:Te.white,gray:Te.gray,charcoal:Te.charcoal,bronze:Te.bronze,...Pv},_v={transparent:Te.transparent,white:Te.white,gray:Te.gray,charcoal:Te.charcoal,bronze:Te.bronze,...Pv},Rv=e=>[Te.cyan[e],Te.blue[e],Te.violet[e],Te.grape[e],Te.pink[e],Te.green[e],Te.teal[e],Te.yellow[e],Te.orange[e],Te.red[e]],Nv=(e,t,r)=>`#${((1<<24)+(e<<16)+(t<<8)+r).toString(16).slice(1)}`});var Ko,ot,Fi,Bv,Ga,is,Xc,p1,Ov,OL,Fv,$p,wo,zv,BL,FL,zL,Hv,HL,UL,Uv,u1=y(()=>{"use strict";f();Qr();W();xe();Oo();Ko=32,ot=12,Fi=256,Bv=50,Ga="NOT_SPREADSHEET",is="VALID_SPREADSHEET",Xc=e=>{let t=/^([-+]?)[$€£¥₩]?([-+]?)([\d.,]+)[%]?$/.exec(e);return t?parseFloat(`${(t[1]||t[2])+t[3]}`.replace(/,/g,"")):null},p1=(e,t)=>e.slice(1).every(r=>Xc(r[t])!==null),Ov=e=>{let t=e[0].length;if(t>2)return{type:Ga,reason:"More than 2 columns"};if(t===1){if(!p1(e,0))return{type:Ga,reason:"Value is not numeric"};let s=Xc(e[0][0])===null,c=(s?e.slice(1):e).map(d=>Xc(d[0]));return c.length<2?{type:Ga,reason:"Less than two rows"}:{type:is,spreadsheet:{title:s?e[0][0]:null,labels:null,values:c}}}let r=p1(e,0),o=p1(e,1);if(!r&&!o)return{type:Ga,reason:"Value is not numeric"};let[n,i]=o?[0,1]:[1,0],a=Xc(e[0][i])===null,l=a?e.slice(1):e;return l.length<2?{type:Ga,reason:"Less than 2 rows"}:{type:is,spreadsheet:{title:a?e[0][i]:null,labels:l.map(s=>s[n]),values:l.map(s=>Xc(s[i]))}}},OL=e=>{let t=[];for(let r=0;r<e[0].length;r++){let o=[];for(let n=0;n<e.length;n++)o.push(e[n][r]);t.push(o)}return t},Fv=e=>{let t=e.trim().split(`
63
63
  `).map(i=>i.trim().split(" "));if(t.length&&t[0].length!==2&&(t=e.trim().split(`
64
- `).map(i=>i.trim().split(","))),t.length===0)return{type:_a,reason:"No values"};let o=t[0].length;if(!t.every(i=>i.length===o))return{type:_a,reason:"All rows don't have same number of columns"};let n=zw(t);if(n.type!==Zl){let i=zw(LM(t));if(i.type===Zl)return i}return n},wp=Fw(Rw),mr={fillStyle:"hachure",fontFamily:qt,fontSize:Rt,opacity:100,roughness:1,strokeColor:si,roundness:null,strokeStyle:"solid",strokeWidth:1,verticalAlign:yt.MIDDLE,locked:!1},Ww=e=>{let t=(zr+et)*e.values.length+et,o=ki+et*2;return{chartWidth:t,chartHeight:o}},_M=(e,t,o,r,n)=>e.labels?.map((i,a)=>Gt({groupIds:[r],backgroundColor:n,...mr,text:i.length>8?`${i.slice(0,5)}...`:i,x:t+a*(zr+et)+et*2,y:o+et/2,width:zr,angle:5.87,fontSize:16,textAlign:"center",verticalAlign:"top"}))||[],PM=(e,t,o,r,n)=>{let i=Gt({groupIds:[r],backgroundColor:n,...mr,x:t-et,y:o-et,text:"0",textAlign:"right"}),a=Gt({groupIds:[r],backgroundColor:n,...mr,x:t-et,y:o-ki-i.height/2,text:Math.max(...e.values).toLocaleString(),textAlign:"right"});return[i,a]},DM=(e,t,o,r,n)=>{let{chartWidth:i,chartHeight:a}=Ww(e),l=cr({backgroundColor:n,groupIds:[r],...mr,type:"line",x:t,y:o,startArrowhead:null,endArrowhead:null,width:i,points:[[0,0],[i,0]]}),s=cr({backgroundColor:n,groupIds:[r],...mr,type:"line",x:t,y:o,startArrowhead:null,endArrowhead:null,height:a,points:[[0,0],[0,-a]]}),c=cr({backgroundColor:n,groupIds:[r],...mr,type:"line",x:t,y:o-ki-et,startArrowhead:null,endArrowhead:null,strokeStyle:"dotted",width:i,opacity:Gw,points:[[0,0],[i,0]]});return[l,s,c]},Vw=(e,t,o,r,n,i)=>{let{chartWidth:a,chartHeight:l}=Ww(e),s=e.title?Gt({backgroundColor:n,groupIds:[r],...mr,text:e.title,x:t+a/2,y:o-ki-et*2-Rt,roundness:null,textAlign:"center"}):null,c=i?Uo({backgroundColor:n,groupIds:[r],...mr,type:"rectangle",x:t,y:o-l,width:a,height:l,strokeColor:si,fillStyle:"solid",opacity:6}):null;return[...c?[c]:[],...s?[s]:[],..._M(e,t,o,r,n),...PM(e,t,o,r,n),...DM(e,t,o,r,n)]},RM=(e,t,o)=>{let r=Math.max(...e.values),n=Bt(),i=wp[Math.floor(Math.random()*wp.length)];return[...e.values.map((l,s)=>{let c=l/r*ki;return Uo({backgroundColor:i,groupIds:[n],...mr,type:"rectangle",x:t+s*(zr+et)+et,y:o-c-et,width:zr,height:c})}),...Vw(e,t,o,n,i,C.DEV)]},NM=(e,t,o)=>{let r=Math.max(...e.values),n=Bt(),i=wp[Math.floor(Math.random()*wp.length)],a=0,l=[];for(let x of e.values){let E=a*(zr+et),y=-(x/r)*ki;l.push([E,y]),a++}let s=Math.max(...l.map(x=>x[0])),c=Math.max(...l.map(x=>x[1])),d=Math.min(...l.map(x=>x[0])),m=Math.min(...l.map(x=>x[1])),p=cr({backgroundColor:i,groupIds:[n],...mr,type:"line",x:t+et+zr/2,y:o-et,startArrowhead:null,endArrowhead:null,height:c-m,width:s-d,strokeWidth:2,points:l}),u=e.values.map((x,E)=>{let y=E*(zr+et)+et/2,T=-(x/r)*ki+et/2;return Uo({backgroundColor:i,groupIds:[n],...mr,fillStyle:"solid",strokeWidth:2,type:"ellipse",x:t+y+zr/2,y:o+T-et*2,width:et,height:et})}),g=e.values.map((x,E)=>{let y=E*(zr+et)+et/2,T=x/r*ki+et/2+et;return cr({backgroundColor:i,groupIds:[n],...mr,type:"line",x:t+y+zr/2+et/2,y:o-T,startArrowhead:null,endArrowhead:null,height:T,strokeStyle:"dotted",opacity:Gw,points:[[0,0],[0,T]]})});return[...Vw(e,t,o,n,i,C.DEV),p,...g,...u]},Yw=(e,t,o,r)=>e==="line"?NM(t,o,r):RM(t,o,r)});function $w(e){let t=[];for(let o of e.childNodes)if(o.nodeType===3){let r=o.textContent?.trim();r&&t.push({type:"text",value:r})}else if(o instanceof HTMLImageElement){let r=o.getAttribute("src");r&&r.startsWith("http")&&t.push({type:"imageUrl",value:r})}else t=t.concat($w(o));return t}var PG,vp,jl,OM,Kw,BM,Tp,FM,HM,Xw,zM,Cp,Ip,Xn,GM,Ai=v(()=>{"use strict";f();Nf();U();se();on();Ze();ao();G();PG="clipboard"in navigator&&"readText"in navigator.clipboard,vp="clipboard"in navigator&&"writeText"in navigator.clipboard,jl="clipboard"in navigator&&"write"in navigator.clipboard&&"ClipboardItem"in window&&"toBlob"in HTMLCanvasElement.prototype,OM=e=>!!([ro.excalidraw,ro.excalidrawClipboard,ro.excalidrawClipboardWithAPI].includes(e?.type)&&Array.isArray(e.elements)),Kw=({types:e,files:t})=>{!e&&!t&&console.warn("createPasteEvent: no types or files provided");let o=new ClipboardEvent("paste",{clipboardData:new DataTransfer});if(e)for(let[r,n]of Object.entries(e))try{if(o.clipboardData?.setData(r,n),o.clipboardData?.getData(r)!==n)throw new Error(`Failed to set "${r}" as clipboardData item`)}catch(i){throw new Error(i.message)}if(t){let r=-1;for(let n of t){r++;try{if(o.clipboardData?.items.add(n),o.clipboardData?.files[r]!==n)throw new Error(`Failed to set file "${n.name}" as clipboardData item`)}catch(i){throw new Error(i.message)}}}return o},BM=({elements:e,files:t})=>{let o=re(e),r=new Set(e.filter(l=>Q(l))),n=!1,i=e.reduce((l,s)=>(mo(s)&&(n=!0,t&&t[s.fileId]&&(l[s.fileId]=t[s.fileId])),l),{});n&&!t&&console.warn("copyToClipboard: attempting to file element(s) without providing associated `files` object.");let a={type:ro.excalidrawClipboard,elements:e.map(l=>{if(Ut(l,o)&&!r.has(Ut(l,o))){let s=zn(l);return z(s,{frameId:null}),s}return l}),files:t?i:void 0};return JSON.stringify(a)},Tp=async(e,t,o)=>{await Xn(BM({elements:e,files:t}),o)},FM=e=>{let t=Uw(e);return t.type===Zl?{spreadsheet:t.spreadsheet}:null};HM=e=>{let t=e.clipboardData?.getData("text/html");if(!t)return null;try{let o=new DOMParser().parseFromString(t,"text/html"),r=$w(o.body);if(r.length)return{type:"mixedContent",value:r}}catch(o){console.error(`error in parseHTMLFromPaste: ${o.message}`)}return null},Xw=async()=>{let e={};try{if(navigator.clipboard?.readText)return{"text/plain":await navigator.clipboard?.readText()}}catch(o){if(navigator.clipboard?.read)console.warn(`navigator.clipboard.readText() failed (${o.message}). Failling back to navigator.clipboard.read()`);else throw o}let t;try{t=await navigator.clipboard?.read()}catch(o){if(o.name==="DataError")return console.warn(`navigator.clipboard.read() error, clipboard is probably empty: ${o.message}`),e;throw o}for(let o of t)for(let r of o.types)if(Ks(Z0,r))try{e[r]=await(await o.getType(r)).text()}catch(n){console.warn(`Cannot retrieve ${r} from clipboardItem: ${n.message}`)}return Object.keys(e).length===0&&console.warn("No clipboard data found from clipboard.read()."),e},zM=async(e,t=!1)=>{try{let o=!t&&e&&HM(e);return o?o.value.every(n=>n.type==="text")?{type:"text",value:e.clipboardData?.getData("text/plain")||o.value.map(n=>n.value).join(`
65
- `).trim()}:o:{type:"text",value:(e.clipboardData?.getData("text/plain")||"").trim()}}catch{return{type:"text",value:""}}},Cp=async(e,t=!1)=>{let o=await zM(e,t);if(o.type==="mixedContent")return{mixedContent:o.value};try{let r=!t&&FM(o.value);if(r)return r}catch(r){console.error(r)}try{let r=JSON.parse(o.value),n=r.type===ro.excalidrawClipboardWithAPI;if(OM(r))return{elements:r.elements,files:r.files,text:t?JSON.stringify(r.elements,null,2):void 0,programmaticAPI:n}}catch{}return{text:o.value}},Ip=async e=>{try{await navigator.clipboard.write([new window.ClipboardItem({[J.png]:e})])}catch(t){if(Xr(e))await navigator.clipboard.write([new window.ClipboardItem({[J.png]:await e})]);else throw t}},Xn=async(e,t)=>{if(vp)try{await navigator.clipboard.writeText(e||"");return}catch(o){console.error(o)}try{if(t){if(t.clipboardData?.setData("text/plain",e||""),t.clipboardData?.getData("text/plain")!==e)throw new Error("Failed to setData on clipboardEvent");return}}catch(o){console.error(o)}if(!GM(e))throw new Error("Error copying to clipboard.")},GM=e=>{e||(e=" ");let t=document.documentElement.getAttribute("dir")==="rtl",o=document.createElement("textarea");o.style.border="0",o.style.padding="0",o.style.margin="0",o.style.position="absolute",o.style[t?"right":"left"]="-9999px";let r=window.pageYOffset||document.documentElement.scrollTop;o.style.top=`${r}px`,o.style.fontSize="12pt",o.setAttribute("readonly",""),o.value=e,document.body.appendChild(o);let n=!1;try{o.select(),o.setSelectionRange(0,o.value.length),n=document.execCommand("copy")}catch(i){console.error(i)}return o.remove(),n}});var Sp,kp,ql,UM,Pa=v(()=>{"use strict";f();Yl();Aa();U();Gl();Kn();Ai();Of();Sp=async({data:e,config:t})=>Si({data:e,config:t}),kp=async({data:e,config:t})=>{let{mimeType:o=J.png,quality:r}=t||{};o===J.png&&typeof r=="number"&&console.warn(`"quality" will be ignored for "${J.png}" mimeType`),o==="image/jpg"&&(o=J.jpg),o===J.jpg&&t?.canvasBackgroundColor&&(console.warn(`Defaulting "exportBackground" to "true" for "${J.jpg}" mimeType`),t={...t,canvasBackgroundColor:e.appState?.viewBackgroundColor||Ht});let n=await Si({data:e,config:t});return r=r||(/image\/jpe?g/.test(o)?.92:.8),new Promise((i,a)=>{n.toBlob(async l=>{if(!l)return a(new Error("couldn't export to blob"));l&&o===J.png&&e.appState?.exportEmbedScene&&(l=await yf({blob:l,metadata:Ii(e.elements,e.appState,e.files||{},"local")})),i(l)},o,r)})},ql=async({data:e,config:t})=>{let{elements:o,appState:r}=Sa({...e,files:e.files||{}},null,null),n={...r,exportPadding:t?.padding},i=be(o),a=e.files||{};return Vl({data:{elements:i,appState:n,files:a},config:{exportingFrame:t?.exportingFrame,renderEmbeddables:t?.renderEmbeddables}})},UM=async({type:e,data:t,config:o})=>{if(e==="svg"){let r=await ql({data:t,config:o});await Xn(r.outerHTML)}else if(e==="png")await Ip(kp({data:t,config:o}));else if(e==="json")await Tp(t.elements,t.files);else throw new Error("Invalid export type")}});var WM,VM,Zw,jw,Bf,qw,Ff,Hf=v(()=>{"use strict";f();se();Qt();bt();G();WM=e=>e.type==="diamond"?[[e.width/2,0],[e.width,e.height/2],[e.width/2,e.height],[0,e.height/2]]:[[0,0],[0+e.width,0],[0+e.width,e.height],[0,e.height]],VM=e=>ne(e)||Ot(e)?e.points:WM(e),Zw=e=>{let t=e.reduce((o,[r,n])=>(o.minY=Math.min(o.minY,n),o.minX=Math.min(o.minX,r),o.maxX=Math.max(o.maxX,r),o.maxY=Math.max(o.maxY,n),o),{minX:1/0,minY:1/0,maxX:-1/0,maxY:-1/0,cx:0,cy:0});return t.cx=(t.maxX+t.minX)/2,t.cy=(t.maxY+t.minY)/2,t},jw=e=>{let t=VM(e),{cx:o,cy:r}=Zw(t),n=[o,r],i=t.map(d=>Xe([d[0],d[1]],n,e.angle)),{minX:a,minY:l,maxX:s,maxY:c}=Zw(i);return[a+e.x,l+e.y,s+e.x,c+e.y]},Bf=(e,t,o=!1)=>{let r=jw(e),n=t[0]<=r[0]&&t[2]>=r[2]&&t[1]<=r[1]&&t[3]>=r[3];return o?n?!0:r[0]<=t[0]&&r[2]>=t[2]&&r[1]<=t[1]&&r[3]>=t[3]:n},qw=(e,t)=>{let o=jw(e);return(oc(o[0],t[0],t[2])||oc(t[0],o[0],o[2]))&&(oc(o[1],t[1],t[3])||oc(t[1],o[1],o[3]))},Ff=({elements:e,bounds:t,type:o,errorMargin:r=0})=>{Zs(t)&&(t=Dr(t,re(e)));let n=[t[0]-r,t[1]-r,t[2]+r,t[3]+r],i=new Set;for(let a of e){if(i.has(a.id))continue;if(o==="overlap"?qw(a,n):o==="inside"?Bf(a,n):Bf(a,n,!0)){if(i.add(a.id),a.boundElements)for(let s of a.boundElements)i.add(s.id);W(a)&&a.containerId&&i.add(a.containerId),ke(a)&&(a.startBinding&&i.add(a.startBinding.elementId),a.endBinding&&i.add(a.endBinding?.elementId))}}return e.filter(a=>i.has(a.id))}});function Jw(e){return[Math.min(e[0][0],e[1][0]),Math.min(e[0][1],e[1][1]),Math.max(e[0][0],e[1][0]),Math.max(e[0][1],e[1][1])]}function tv(e,t){return e[0]*t[1]-t[0]*e[1]}function YM(e,t){return e[0]<=t[2]&&e[2]>=t[0]&&e[1]<=t[3]&&e[3]>=t[1]}function Ap(e,t){return[e[0]-t[0],e[1]-t[1]]}function Qw(e,t){let o=Ap(e[1],e[0]),r=Ap(t,e[0]),n=tv(o,r);return Math.abs(n)<KM}function zf(e,t){let o=Ap(e[1],e[0]),r=Ap(t,e[0]);return tv(o,r)<0}function ev(e,t){return Qw(e,t[0])||Qw(e,t[1])||(zf(e,t[0])?!zf(e,t[1]):zf(e,t[1]))}function ov(e,t){return YM(Jw(e),Jw(t))&&ev(e,t)&&ev(t,e)}var KM,rv=v(()=>{"use strict";f();KM=1e-6});var nv=v(()=>{"use strict";f();Pa();Hf();rv()});function iv(e,t,o){let r=nf(t,o),n=nf(e,o);return r.some(a=>n.some(l=>ov(a,l)))}var Mp,av,lv,sv,an,Gf,cv,Vo,Dc,Df,Jl,dv,Ut,mv,Nc,Ql,Uf,Lp,ln,_p,up,Ma,bp,Kl,ao=v(()=>{"use strict";f();he();Qt();pt();G();Ze();We();Ho();bt();nv();se();Mp=(e,t,o)=>{let r=re(e);for(let n of t)if(n.frameId){let i=o.get(n.id),a=o.get(n.frameId);if(i){let l=r.get(i);l&&z(l,{frameId:a??n.frameId},!1)}}};av=(e,t,o)=>_p(es(e,t,o,!1)).filter(r=>!Q(r)&&!r.frameId||r.frameId===t.id),lv=(e,t,o,r)=>es(e,t,r).some(n=>n.id===o.id),sv=(e,t,o)=>{let[r,n,i,a]=te(t,o),[l,s,c,d]=Se(e);return r<=l&&n<=s&&i>=c&&a>=d},an=(e,t,o)=>sv([e],t,o)||iv(e,t,o)||lv([t],e,t,o),Gf=(e,t,o)=>{let[r,n,i,a]=te(t,o);return ma([r,n],[e.x,e.y],[i,a])},cv=e=>{let t=new Map;for(let o of e){let r=Q(o)?o.id:o.frameId;r&&!t.has(r)&&t.set(r,Vo(e,r))}return t},Vo=(e,t)=>{let o=[];for(let r of e.values())r.frameId===t&&o.push(r);return o},Dc=e=>e.filter(t=>Q(t)),Df=e=>{let t=re(Dc(e));return e.filter(o=>t.has(o.id)||!o.frameId||!t.has(o.frameId))},Jl=(e,t,o,r)=>{let n=Vo(e,t.id),i=new Set(n),a=new Set([...av(e,t,r),...n.filter(p=>lv(e,p,t,r))]),l=n.filter(p=>!a.has(p)),s=new Set(Array.from(a).flatMap(p=>p.groupIds));for(let p of l)if(!iv(p,t,r))p.groupIds.length===0&&i.delete(p);else if(p.groupIds.length>0)for(let u of p.groupIds)s.add(u);for(let p of l)if(p.groupIds.length>0){let u=!0;for(let g of p.groupIds)s.has(g)&&(u=!1);u&&i.delete(p)}let c=Array.from(a).filter(p=>p.groupIds.length===0);for(let p of c)i.add(p);let d=Array.from(a).filter(p=>p.groupIds.length>0),m=Wm(d,o);for(let[p,u]of Object.entries(m))if(u){let g=ot(e,p);if(sv(g,t,r))for(let x of g)i.add(x)}return[...i].filter(p=>!(W(p)&&p.containerId))},dv=(e,t,o)=>_p(e,av(e,t,o)),Ut=(e,t)=>e.frameId&&t.get(e.frameId)||null,mv=(e,t)=>{let o=new Set,r=re(e);e=_p(e);for(let a of e)Q(a)&&a.id!==t.id&&o.add(a.id);let n=new Set,i=[];for(let a of e)if(!(Q(a)||a.frameId&&o.has(a.frameId)))if(a.groupIds.length){let l=a.groupIds.at(-1);if(!n.has(l)){n.add(l);let s=ot(e,l);if(s.some(c=>an(c,t,r)))for(let c of s)i.push(c)}}else an(a,t,r)&&i.push(a);return i},Nc=(e,t,o)=>{let r=re(e),n=new Map;for(let s of e.values())s.frameId===o.id&&n.set(s.id,!0);let i=new Set(t.map(s=>s.id)),a=[],l=new Set;for(let s of t)Q(s)&&s.id!==o.id&&l.add(s.id);for(let s of _p(e,t)){if(Q(s)||s.frameId&&l.has(s.frameId))continue;n.has(s.id)||a.push(s);let c=me(s,r);c&&!i.has(c.id)&&!n.has(c.id)&&a.push(c)}for(let s of a)z(s,{frameId:o.id},!1);return e},Ql=(e,t)=>{let o=new Map,r=new Map;for(let n of e)if(n.frameId){o.set(n.id,n);let i=r.get(n.frameId)||[];i.push(n);let a=me(n,t);a&&(o.set(a.id,a),i.push(a)),r.set(n.frameId,i)}for(let[,n]of o)z(n,{frameId:null},!1)},Uf=(e,t)=>{let o=Vo(e,t.id);return Ql(o,re(e)),e},Lp=(e,t,o,r)=>Nc(Uf(e,o),t,o).slice(),ln=(e,t,o)=>{let r=o.scene.getSelectedElements({selectedElementIds:t.selectedElementIds,elements:e}),n=new Set(r);if(t.editingGroupId)for(let l of r)l.groupIds.length===0?n.add(l):l.groupIds.flatMap(s=>ot(e,s)).forEach(s=>n.add(s));let i=new Set,a=re(e);return n.forEach(l=>{l.frameId&&!Q(l)&&!Ma(l,a,t)&&i.add(l)}),i.size>0&&Ql(i,a),e},_p=(e,t)=>{let o=new Set,r=t||e;for(let a of r.values()){let l=a.groupIds[a.groupIds.length-1];l&&o.add(l)}let n=new Set;for(let a of o)ot(e,a).some(l=>Q(l))&&n.add(a);let i=[];for(let a of r.values())n.has(a.groupIds[a.groupIds.length-1])||i.push(a);return i},up=(e,t,o)=>{let r=W(e)&&ut(e,t)||e;return o.selectedElementIds[r.id]&&o.selectedElementsAreBeingDragged?o.frameToHighlight:Ut(r,t)},Ma=(e,t,o)=>{let r=up(e,t,o),n=W(e)&&ut(e,t)||e;if(r){if(!o.selectedElementIds[e.id]||!o.selectedElementsAreBeingDragged)return!0;if(n.groupIds.length===0)return an(n,r,t);let i=new Set(n.groupIds.flatMap(a=>ot(t,a)));if(o.editingGroupId&&o.selectedElementsAreBeingDragged){let a=new Set(de(t,o));if(o.frameToHighlight!==null)return!0;a.forEach(s=>{i.delete(s)})}for(let a of i)if(Q(a))return!1;for(let a of i)if(an(a,r,t))return!0}return!1},bp=(e,t)=>e.name===null?pi(e)?`Frame ${t}`:`AI Frame $${t}`:e.name,Kl=(e,t)=>Ff({elements:e,bounds:t,type:"overlap"}).filter(o=>!o.frameId||o.frameId===t.id)});import hv from"roughjs/bin/rough";import{getStroke as $M}from"perfect-freehand";function Wy(e){let t=Jm(e),o=new Path2D(t);return Vf.set(e,o),o}function JM(e){return Vf.get(e)}function Jm(e){let t=e.simulatePressure?e.points:e.points.length?e.points.map(([r,n],i)=>[r,n,e.pressures[i]]):[[0,0,.5]],o={simulatePressure:e.simulatePressure,size:e.strokeWidth*4.25,thinning:.6,smoothing:.5,streamline:.5,easing:r=>Math.sin(r*Math.PI/2),last:!!e.lastCommittedPoint};return eL($M(t,o))}function gv(e,t){return[(e[0]+t[0])/2,(e[1]+t[1])/2]}function eL(e){if(!e.length)return"";let t=e.length-1;return e.reduce((o,r,n,i)=>(n===t?o.push(r,gv(r,i[0]),"L",i[0],"Z"):o.push(r,gv(r,i[n+1])),o),["M",e[0],"Q"]).join(" ").replace(QM,"$1")}var ff,XM,fv,bv,Dp,Wf,ZM,jM,Sw,xv,Ev,qM,Pp,Oc,yv,pv,uv,wv,Pc,Vf,QM,Jr=v(()=>{"use strict";f();se();bt();G();Qt();Fo();U();pt();io();ao();Mr();ff="invert(100%) hue-rotate(180deg) saturate(1.25)",XM=Bo(),fv=(e,t)=>mo(e)&&!t.imageCache.has(e.fileId),bv=(e,t,o)=>o.theme===ie.DARK&&mo(e)&&!fv(e,t)&&t.imageCache.get(e.fileId)?.mimeType!==J.svg,Dp=e=>e.type==="freedraw"?e.strokeWidth*12:20,Wf=(e,t,o)=>{let r=(t?.opacity??100)*e.opacity/1e4;return(o.has(e.id)||t&&o.has(t.id))&&(r*=cy/100),r},ZM=(e,t,o)=>{let i=Dp(e),[a,l,s,c]=te(e,t),d=ne(e)||Ot(e)?Nt(a,s):e.width,m=ne(e)||Ot(e)?Nt(l,c):e.height,p=d*window.devicePixelRatio+i*2,u=m*window.devicePixelRatio+i*2,g=o.value;return(p*g>32767||u*g>32767)&&(g=Math.min(32767/p,32767/u)),p*u*g*g>16777216&&(g=Math.sqrt(16777216/(p*u))),p=Math.floor(p*g),u=Math.floor(u*g),{width:p,height:u,scale:g}},jM=(e,t,o,r,n)=>{let i=document.createElement("canvas"),a=i.getContext("2d"),l=Dp(e),{width:s,height:c,scale:d}=ZM(e,t,o);i.width=s,i.height=c;let m=0,p=0;if(ne(e)||Ot(e)){let[g,x]=te(e,t);m=e.x>g?Nt(e.x,g)*window.devicePixelRatio*d:0,p=e.y>x?Nt(e.y,x)*window.devicePixelRatio*d:0,a.translate(m,p)}a.save(),a.translate(l*d,l*d),a.scale(window.devicePixelRatio*d,window.devicePixelRatio*d);let u=hv.canvas(i);return bv(e,r,n)&&(a.filter=ff),Pp(e,u,a,r,n),a.restore(),{element:e,canvas:i,theme:n.theme,scale:d,zoomValue:o.value,canvasOffsetX:m,canvasOffsetY:p,boundTextElementVersion:me(e,t)?.version||null,containingFrameOpacity:Ut(e,t)?.opacity||100}},Sw=14,xv=document.createElement("img");xv.src=`data:${J.svg},${encodeURIComponent('<svg aria-hidden="true" focusable="false" data-prefix="fas" data-icon="image" class="svg-inline--fa fa-image fa-w-16" role="img" xmlns="http://www.w3.org/2000/svg" viewBox="0 0 512 512"><path fill="#888" d="M464 448H48c-26.51 0-48-21.49-48-48V112c0-26.51 21.49-48 48-48h416c26.51 0 48 21.49 48 48v288c0 26.51-21.49 48-48 48zM112 120c-30.928 0-56 25.072-56 56s25.072 56 56 56 56-25.072 56-56-25.072-56-56-56zM64 384h384V272l-87.515-87.515c-4.686-4.686-12.284-4.686-16.971 0L208 320l-55.515-55.515c-4.686-4.686-12.284-4.686-16.971 0L64 336v48z"></path></svg>')}`;Ev=document.createElement("img");Ev.src=`data:${J.svg},${encodeURIComponent('<svg viewBox="0 0 668 668" xmlns="http://www.w3.org/2000/svg" xml:space="preserve" style="fill-rule:evenodd;clip-rule:evenodd;stroke-linejoin:round;stroke-miterlimit:2"><path d="M464 448H48c-26.51 0-48-21.49-48-48V112c0-26.51 21.49-48 48-48h416c26.51 0 48 21.49 48 48v288c0 26.51-21.49 48-48 48ZM112 120c-30.928 0-56 25.072-56 56s25.072 56 56 56 56-25.072 56-56-25.072-56-56-56ZM64 384h384V272l-87.515-87.515c-4.686-4.686-12.284-4.686-16.971 0L208 320l-55.515-55.515c-4.686-4.686-12.284-4.686-16.971 0L64 336v48Z" style="fill:#888;fill-rule:nonzero" transform="matrix(.81709 0 0 .81709 124.825 145.825)"/><path d="M256 8C119.034 8 8 119.033 8 256c0 136.967 111.034 248 248 248s248-111.034 248-248S392.967 8 256 8Zm130.108 117.892c65.448 65.448 70 165.481 20.677 235.637L150.47 105.216c70.204-49.356 170.226-44.735 235.638 20.676ZM125.892 386.108c-65.448-65.448-70-165.481-20.677-235.637L361.53 406.784c-70.203 49.356-170.226 44.736-235.638-20.676Z" style="fill:#888;fill-rule:nonzero" transform="matrix(.30366 0 0 .30366 506.822 60.065)"/></svg>')}`;qM=(e,t,o)=>{t.fillStyle="#E7E7E7",t.fillRect(0,0,e.width,e.height);let r=Math.min(e.width,e.height),n=Math.min(r,Math.min(r*.4,100));t.drawImage(e.status==="error"?Ev:xv,e.width/2-n/2,e.height/2-n/2,n,n)},Pp=(e,t,o,r,n)=>{switch(e.type){case"rectangle":case"iframe":case"embeddable":case"diamond":case"ellipse":{o.lineJoin="round",o.lineCap="round",t.draw(Me.get(e));break}case"arrow":case"line":{o.lineJoin="round",o.lineCap="round",Me.get(e).forEach(i=>{t.draw(i)});break}case"freedraw":{o.save(),o.fillStyle=e.strokeColor;let i=JM(e),a=Me.get(e);a&&t.draw(a),o.fillStyle=e.strokeColor,o.fill(i),o.restore();break}case"image":{let i=mo(e)?r.imageCache.get(e.fileId)?.image:void 0;i!=null&&!(i instanceof Promise)?(e.roundness&&o.roundRect&&(o.beginPath(),o.roundRect(0,0,e.width,e.height,kr(Math.min(e.width,e.height),e)),o.clip()),o.drawImage(i,0,0,e.width,e.height)):qM(e,o,n.zoom.value);break}default:if(W(e)){let i=hm(e.text),a=i&&!o.canvas.isConnected;a&&document.body.appendChild(o.canvas),o.canvas.setAttribute("dir",i?"rtl":"ltr"),o.save(),o.font=Ke(e),o.fillStyle=e.strokeColor,o.textAlign=e.textAlign;let l=e.text.replace(/\r\n?/g,`
64
+ `).map(i=>i.trim().split(","))),t.length===0)return{type:Ga,reason:"No values"};let r=t[0].length;if(!t.every(i=>i.length===r))return{type:Ga,reason:"All rows don't have same number of columns"};let n=Ov(t);if(n.type!==is){let i=Ov(OL(t));if(i.type===is)return i}return n},$p=Rv(Lv),wo={fillStyle:"hachure",fontFamily:tr,fontSize:Ot,opacity:100,roughness:1,strokeColor:bi,roundness:null,strokeStyle:"solid",strokeWidth:1,verticalAlign:Tt.MIDDLE,locked:!1},zv=e=>{let t=(Ko+ot)*e.values.length+ot,r=Fi+ot*2;return{chartWidth:t,chartHeight:r}},BL=(e,t,r,o,n)=>e.labels?.map((i,a)=>$t({groupIds:[o],backgroundColor:n,...wo,text:i.length>8?`${i.slice(0,5)}...`:i,x:t+a*(Ko+ot)+ot*2,y:r+ot/2,width:Ko,angle:5.87,fontSize:16,textAlign:"center",verticalAlign:"top"}))||[],FL=(e,t,r,o,n)=>{let i=$t({groupIds:[o],backgroundColor:n,...wo,x:t-ot,y:r-ot,text:"0",textAlign:"right"}),a=$t({groupIds:[o],backgroundColor:n,...wo,x:t-ot,y:r-Fi-i.height/2,text:Math.max(...e.values).toLocaleString(),textAlign:"right"});return[i,a]},zL=(e,t,r,o,n)=>{let{chartWidth:i,chartHeight:a}=zv(e),l=xo({backgroundColor:n,groupIds:[o],...wo,type:"line",x:t,y:r,startArrowhead:null,endArrowhead:null,width:i,points:[[0,0],[i,0]]}),s=xo({backgroundColor:n,groupIds:[o],...wo,type:"line",x:t,y:r,startArrowhead:null,endArrowhead:null,height:a,points:[[0,0],[0,-a]]}),c=xo({backgroundColor:n,groupIds:[o],...wo,type:"line",x:t,y:r-Fi-ot,startArrowhead:null,endArrowhead:null,strokeStyle:"dotted",width:i,opacity:Bv,points:[[0,0],[i,0]]});return[l,s,c]},Hv=(e,t,r,o,n,i)=>{let{chartWidth:a,chartHeight:l}=zv(e),s=e.title?$t({backgroundColor:n,groupIds:[o],...wo,text:e.title,x:t+a/2,y:r-Fi-ot*2-Ot,roundness:null,textAlign:"center"}):null,c=i?Jr({backgroundColor:n,groupIds:[o],...wo,type:"rectangle",x:t,y:r-l,width:a,height:l,strokeColor:bi,fillStyle:"solid",opacity:6}):null;return[...c?[c]:[],...s?[s]:[],...BL(e,t,r,o,n),...FL(e,t,r,o,n),...zL(e,t,r,o,n)]},HL=(e,t,r)=>{let o=Math.max(...e.values),n=zt(),i=$p[Math.floor(Math.random()*$p.length)];return[...e.values.map((l,s)=>{let c=l/o*Fi;return Jr({backgroundColor:i,groupIds:[n],...wo,type:"rectangle",x:t+s*(Ko+ot)+ot,y:r-c-ot,width:Ko,height:c})}),...Hv(e,t,r,n,i,S.DEV)]},UL=(e,t,r)=>{let o=Math.max(...e.values),n=zt(),i=$p[Math.floor(Math.random()*$p.length)],a=0,l=[];for(let E of e.values){let x=a*(Ko+ot),T=-(E/o)*Fi;l.push([x,T]),a++}let s=Math.max(...l.map(E=>E[0])),c=Math.max(...l.map(E=>E[1])),d=Math.min(...l.map(E=>E[0])),m=Math.min(...l.map(E=>E[1])),p=xo({backgroundColor:i,groupIds:[n],...wo,type:"line",x:t+ot+Ko/2,y:r-ot,startArrowhead:null,endArrowhead:null,height:c-m,width:s-d,strokeWidth:2,points:l}),u=e.values.map((E,x)=>{let T=x*(Ko+ot)+ot/2,v=-(E/o)*Fi+ot/2;return Jr({backgroundColor:i,groupIds:[n],...wo,fillStyle:"solid",strokeWidth:2,type:"ellipse",x:t+T+Ko/2,y:r+v-ot*2,width:ot,height:ot})}),h=e.values.map((E,x)=>{let T=x*(Ko+ot)+ot/2,v=E/o*Fi+ot/2+ot;return xo({backgroundColor:i,groupIds:[n],...wo,type:"line",x:t+T+Ko/2+ot/2,y:r-v,startArrowhead:null,endArrowhead:null,height:v,strokeStyle:"dotted",opacity:Bv,points:[[0,0],[0,v]]})});return[...Hv(e,t,r,n,i,S.DEV),p,...h,...u]},Uv=(e,t,r,o)=>e==="line"?UL(t,r,o):HL(t,r,o)});function Vv(e){let t=[];for(let r of e.childNodes)if(r.nodeType===3){let o=r.textContent?.trim();o&&t.push({type:"text",value:o})}else if(r instanceof HTMLImageElement){let o=r.getAttribute("src");o&&o.startsWith("http")&&t.push({type:"imageUrl",value:o})}else t=t.concat(Vv(r));return t}var CV,Xp,as,GL,Gv,VL,Zp,WL,YL,Wv,KL,jp,qp,Qn,$L,zi=y(()=>{"use strict";f();u1();W();me();hn();Ye();dr();G();CV="clipboard"in navigator&&"readText"in navigator.clipboard,Xp="clipboard"in navigator&&"writeText"in navigator.clipboard,as="clipboard"in navigator&&"write"in navigator.clipboard&&"ClipboardItem"in window&&"toBlob"in HTMLCanvasElement.prototype,GL=e=>!!([ar.excalidraw,ar.excalidrawClipboard,ar.excalidrawClipboardWithAPI].includes(e?.type)&&Array.isArray(e.elements)),Gv=({types:e,files:t})=>{!e&&!t&&console.warn("createPasteEvent: no types or files provided");let r=new ClipboardEvent("paste",{clipboardData:new DataTransfer});if(e)for(let[o,n]of Object.entries(e))try{if(r.clipboardData?.setData(o,n),r.clipboardData?.getData(o)!==n)throw new Error(`Failed to set "${o}" as clipboardData item`)}catch(i){throw new Error(i.message)}if(t){let o=-1;for(let n of t){o++;try{if(r.clipboardData?.items.add(n),r.clipboardData?.files[o]!==n)throw new Error(`Failed to set file "${n.name}" as clipboardData item`)}catch(i){throw new Error(i.message)}}}return r},VL=({elements:e,files:t})=>{let r=X(e),o=new Set(e.filter(l=>re(l))),n=!1,i=e.reduce((l,s)=>(gr(s)&&(n=!0,t&&t[s.fileId]&&(l[s.fileId]=t[s.fileId])),l),{});n&&!t&&console.warn("copyToClipboard: attempting to file element(s) without providing associated `files` object.");let a={type:ar.excalidrawClipboard,elements:e.map(l=>{if(Xt(l,r)&&!o.has(Xt(l,r))){let s=Yn(l);return H(s,{frameId:null}),s}return l}),files:t?i:void 0};return JSON.stringify(a)},Zp=async(e,t,r)=>{await Qn(VL({elements:e,files:t}),r)},WL=e=>{let t=Fv(e);return t.type===is?{spreadsheet:t.spreadsheet}:null};YL=e=>{let t=e.clipboardData?.getData("text/html");if(!t)return null;try{let r=new DOMParser().parseFromString(t,"text/html"),o=Vv(r.body);if(o.length)return{type:"mixedContent",value:o}}catch(r){console.error(`error in parseHTMLFromPaste: ${r.message}`)}return null},Wv=async()=>{let e={};try{if(navigator.clipboard?.readText)return{"text/plain":await navigator.clipboard?.readText()}}catch(r){if(navigator.clipboard?.read)console.warn(`navigator.clipboard.readText() failed (${r.message}). Failling back to navigator.clipboard.read()`);else throw r}let t;try{t=await navigator.clipboard?.read()}catch(r){if(r.name==="DataError")return console.warn(`navigator.clipboard.read() error, clipboard is probably empty: ${r.message}`),e;throw r}for(let r of t)for(let o of r.types)if(nc(Ly,o))try{e[o]=await(await r.getType(o)).text()}catch(n){console.warn(`Cannot retrieve ${o} from clipboardItem: ${n.message}`)}return Object.keys(e).length===0&&console.warn("No clipboard data found from clipboard.read()."),e},KL=async(e,t=!1)=>{try{let r=!t&&e&&YL(e);return r?r.value.every(n=>n.type==="text")?{type:"text",value:e.clipboardData?.getData("text/plain")||r.value.map(n=>n.value).join(`
65
+ `).trim()}:r:{type:"text",value:(e.clipboardData?.getData("text/plain")||"").trim()}}catch{return{type:"text",value:""}}},jp=async(e,t=!1)=>{let r=await KL(e,t);if(r.type==="mixedContent")return{mixedContent:r.value};try{let o=!t&&WL(r.value);if(o)return o}catch(o){console.error(o)}try{let o=JSON.parse(r.value),n=o.type===ar.excalidrawClipboardWithAPI;if(GL(o))return{elements:o.elements,files:o.files,text:t?JSON.stringify(o.elements,null,2):void 0,programmaticAPI:n}}catch{}return{text:r.value}},qp=async e=>{try{await navigator.clipboard.write([new window.ClipboardItem({[te.png]:e})])}catch(t){if(tn(e))await navigator.clipboard.write([new window.ClipboardItem({[te.png]:await e})]);else throw t}},Qn=async(e,t)=>{if(Xp)try{await navigator.clipboard.writeText(e||"");return}catch(r){console.error(r)}try{if(t){if(t.clipboardData?.setData("text/plain",e||""),t.clipboardData?.getData("text/plain")!==e)throw new Error("Failed to setData on clipboardEvent");return}}catch(r){console.error(r)}if(!$L(e))throw new Error("Error copying to clipboard.")},$L=e=>{e||(e=" ");let t=document.documentElement.getAttribute("dir")==="rtl",r=document.createElement("textarea");r.style.border="0",r.style.padding="0",r.style.margin="0",r.style.position="absolute",r.style[t?"right":"left"]="-9999px";let o=window.pageYOffset||document.documentElement.scrollTop;r.style.top=`${o}px`,r.style.fontSize="12pt",r.setAttribute("readonly",""),r.value=e,document.body.appendChild(r);let n=!1;try{r.select(),r.setSelectionRange(0,r.value.length),n=document.execCommand("copy")}catch(i){console.error(i)}return r.remove(),n}});var Jp,Qp,ls,XL,Va=y(()=>{"use strict";f();ts();Fa();W();jl();qn();zi();h1();Jp=async({data:e,config:t})=>Bi({data:e,config:t}),Qp=async({data:e,config:t})=>{let{mimeType:r=te.png,quality:o}=t||{};r===te.png&&typeof o=="number"&&console.warn(`"quality" will be ignored for "${te.png}" mimeType`),r==="image/jpg"&&(r=te.jpg),r===te.jpg&&t?.canvasBackgroundColor&&(console.warn(`Defaulting "exportBackground" to "true" for "${te.jpg}" mimeType`),t={...t,canvasBackgroundColor:e.appState?.viewBackgroundColor||Gt});let n=await Bi({data:e,config:t});return o=o||(/image\/jpe?g/.test(r)?.92:.8),new Promise((i,a)=>{n.toBlob(async l=>{if(!l)return a(new Error("couldn't export to blob"));l&&r===te.png&&e.appState?.exportEmbedScene&&(l=await qf({blob:l,metadata:Oi(e.elements,e.appState,e.files||{},"local")})),i(l)},r,o)})},ls=async({data:e,config:t})=>{let{elements:r,appState:o}=Oa({...e,files:e.files||{}},null,null),n={...o,exportPadding:t?.padding},i=ye(r),a=e.files||{};return es({data:{elements:i,appState:n,files:a},config:{exportingFrame:t?.exportingFrame,renderEmbeddables:t?.renderEmbeddables}})},XL=async({type:e,data:t,config:r})=>{if(e==="svg"){let o=await ls({data:t,config:r});await Qn(o.outerHTML)}else if(e==="png")await qp(Qp({data:t,config:r}));else if(e==="json")await Zp(t.elements,t.files);else throw new Error("Invalid export type")}});var ZL,jL,Yv,Kv,g1,$v,f1,b1=y(()=>{"use strict";f();me();Kt();dt();G();ZL=e=>e.type==="diamond"?[[e.width/2,0],[e.width,e.height/2],[e.width/2,e.height],[0,e.height/2]]:[[0,0],[0+e.width,0],[0+e.width,e.height],[0,e.height]],jL=e=>ce(e)||Ft(e)?e.points:ZL(e),Yv=e=>{let t=e.reduce((r,[o,n])=>(r.minY=Math.min(r.minY,n),r.minX=Math.min(r.minX,o),r.maxX=Math.max(r.maxX,o),r.maxY=Math.max(r.maxY,n),r),{minX:1/0,minY:1/0,maxX:-1/0,maxY:-1/0,cx:0,cy:0});return t.cx=(t.maxX+t.minX)/2,t.cy=(t.maxY+t.minY)/2,t},Kv=e=>{let t=jL(e),{cx:r,cy:o}=Yv(t),n=[r,o],i=t.map(d=>Ke([d[0],d[1]],n,e.angle)),{minX:a,minY:l,maxX:s,maxY:c}=Yv(i);return[a+e.x,l+e.y,s+e.x,c+e.y]},g1=(e,t,r=!1)=>{let o=Kv(e),n=t[0]<=o[0]&&t[2]>=o[2]&&t[1]<=o[1]&&t[3]>=o[3];return r?n?!0:o[0]<=t[0]&&o[2]>=t[2]&&o[1]<=t[1]&&o[3]>=t[3]:n},$v=(e,t)=>{let r=Kv(e);return(hc(r[0],t[0],t[2])||hc(t[0],r[0],r[2]))&&(hc(r[1],t[1],t[3])||hc(t[1],r[1],r[3]))},f1=({elements:e,bounds:t,type:r,errorMargin:o=0})=>{lc(t)&&(t=Zr(t,X(e)));let n=[t[0]-o,t[1]-o,t[2]+o,t[3]+o],i=new Set;for(let a of e){if(i.has(a.id))continue;if(r==="overlap"?$v(a,n):r==="inside"?g1(a,n):g1(a,n,!0)){if(i.add(a.id),a.boundElements)for(let s of a.boundElements)i.add(s.id);V(a)&&a.containerId&&i.add(a.containerId),Ce(a)&&(a.startBinding&&i.add(a.startBinding.elementId),a.endBinding&&i.add(a.endBinding?.elementId))}}return e.filter(a=>i.has(a.id))}});function Xv(e){return[Math.min(e[0][0],e[1][0]),Math.min(e[0][1],e[1][1]),Math.max(e[0][0],e[1][0]),Math.max(e[0][1],e[1][1])]}function qv(e,t){return e[0]*t[1]-t[0]*e[1]}function qL(e,t){return e[0]<=t[2]&&e[2]>=t[0]&&e[1]<=t[3]&&e[3]>=t[1]}function eu(e,t){return[e[0]-t[0],e[1]-t[1]]}function Zv(e,t){let r=eu(e[1],e[0]),o=eu(t,e[0]),n=qv(r,o);return Math.abs(n)<JL}function E1(e,t){let r=eu(e[1],e[0]),o=eu(t,e[0]);return qv(r,o)<0}function jv(e,t){return Zv(e,t[0])||Zv(e,t[1])||(E1(e,t[0])?!E1(e,t[1]):E1(e,t[1]))}function Jv(e,t){return qL(Xv(e),Xv(t))&&jv(e,t)&&jv(t,e)}var JL,Qv=y(()=>{"use strict";f();JL=1e-6});var eT=y(()=>{"use strict";f();Va();b1();Qv()});function tT(e,t,r){let o=Nf(t,r),n=Nf(e,r);return o.some(a=>n.some(l=>Jv(a,l)))}var tu,rT,oT,nT,fn,x1,iT,eo,$c,m1,ss,aT,Xt,lT,Zc,cs,y1,ru,bn,ou,zp,Ha,Vp,rs,dr=y(()=>{"use strict";f();xe();Kt();mt();G();Ye();qe();xr();dt();eT();me();tu=(e,t,r)=>{let o=X(e);for(let n of t)if(n.frameId){let i=r.get(n.id),a=r.get(n.frameId);if(i){let l=o.get(i);l&&H(l,{frameId:a??n.frameId},!1)}}};rT=(e,t,r)=>ou(ds(e,t,r,!1)).filter(o=>!re(o)&&!o.frameId||o.frameId===t.id),oT=(e,t,r,o)=>ds(e,t,o).some(n=>n.id===r.id),nT=(e,t,r)=>{let[o,n,i,a]=oe(t,r),[l,s,c,d]=Ae(e);return o<=l&&n<=s&&i>=c&&a>=d},fn=(e,t,r)=>nT([e],t,r)||tT(e,t,r)||oT([t],e,t,r),x1=(e,t,r)=>{let[o,n,i,a]=oe(t,r);return Um([o,n],[e.x,e.y],[i,a])},iT=e=>{let t=new Map;for(let r of e){let o=re(r)?r.id:r.frameId;o&&!t.has(o)&&t.set(o,eo(e,o))}return t},eo=(e,t)=>{let r=[];for(let o of e.values())o.frameId===t&&r.push(o);return r},$c=e=>e.filter(t=>re(t)),m1=e=>{let t=X($c(e));return e.filter(r=>t.has(r.id)||!r.frameId||!t.has(r.frameId))},ss=(e,t,r,o)=>{let n=eo(e,t.id),i=new Set(n),a=new Set([...rT(e,t,o),...n.filter(p=>oT(e,p,t,o))]),l=n.filter(p=>!a.has(p)),s=new Set(Array.from(a).flatMap(p=>p.groupIds));for(let p of l)if(!tT(p,t,o))p.groupIds.length===0&&i.delete(p);else if(p.groupIds.length>0)for(let u of p.groupIds)s.add(u);for(let p of l)if(p.groupIds.length>0){let u=!0;for(let h of p.groupIds)s.has(h)&&(u=!1);u&&i.delete(p)}let c=Array.from(a).filter(p=>p.groupIds.length===0);for(let p of c)i.add(p);let d=Array.from(a).filter(p=>p.groupIds.length>0),m=cp(d,r);for(let[p,u]of Object.entries(m))if(u){let h=it(e,p);if(nT(h,t,o))for(let E of h)i.add(E)}return[...i].filter(p=>!(V(p)&&p.containerId))},aT=(e,t,r)=>ou(e,rT(e,t,r)),Xt=(e,t)=>e.frameId&&t.get(e.frameId)||null,lT=(e,t)=>{let r=new Set,o=X(e);e=ou(e);for(let a of e)re(a)&&a.id!==t.id&&r.add(a.id);let n=new Set,i=[];for(let a of e)if(!(re(a)||a.frameId&&r.has(a.frameId)))if(a.groupIds.length){let l=a.groupIds.at(-1);if(!n.has(l)){n.add(l);let s=it(e,l);if(s.some(c=>fn(c,t,o)))for(let c of s)i.push(c)}}else fn(a,t,o)&&i.push(a);return i},Zc=(e,t,r)=>{let o=X(e),n=new Map;for(let s of e.values())s.frameId===r.id&&n.set(s.id,!0);let i=new Set(t.map(s=>s.id)),a=[],l=new Set;for(let s of t)re(s)&&s.id!==r.id&&l.add(s.id);for(let s of ou(e,t)){if(re(s)||s.frameId&&l.has(s.frameId))continue;n.has(s.id)||a.push(s);let c=ue(s,o);c&&!i.has(c.id)&&!n.has(c.id)&&a.push(c)}for(let s of a)H(s,{frameId:r.id},!1);return e},cs=(e,t)=>{let r=new Map,o=new Map;for(let n of e)if(n.frameId){r.set(n.id,n);let i=o.get(n.frameId)||[];i.push(n);let a=ue(n,t);a&&(r.set(a.id,a),i.push(a)),o.set(n.frameId,i)}for(let[,n]of r)H(n,{frameId:null},!1)},y1=(e,t)=>{let r=eo(e,t.id);return cs(r,X(e)),e},ru=(e,t,r,o)=>Zc(y1(e,r),t,r).slice(),bn=(e,t,r)=>{let o=r.scene.getSelectedElements({selectedElementIds:t.selectedElementIds,elements:e}),n=new Set(o);if(t.editingGroupId)for(let l of o)l.groupIds.length===0?n.add(l):l.groupIds.flatMap(s=>it(e,s)).forEach(s=>n.add(s));let i=new Set,a=X(e);return n.forEach(l=>{l.frameId&&!re(l)&&!Ha(l,a,t)&&i.add(l)}),i.size>0&&cs(i,a),e},ou=(e,t)=>{let r=new Set,o=t||e;for(let a of o.values()){let l=a.groupIds[a.groupIds.length-1];l&&r.add(l)}let n=new Set;for(let a of r)it(e,a).some(l=>re(l))&&n.add(a);let i=[];for(let a of o.values())n.has(a.groupIds[a.groupIds.length-1])||i.push(a);return i},zp=(e,t,r)=>{let o=V(e)&&gt(e,t)||e;return r.selectedElementIds[o.id]&&r.selectedElementsAreBeingDragged?r.frameToHighlight:Xt(o,t)},Ha=(e,t,r)=>{let o=zp(e,t,r),n=V(e)&&gt(e,t)||e;if(o){if(!r.selectedElementIds[e.id]||!r.selectedElementsAreBeingDragged)return!0;if(n.groupIds.length===0)return fn(n,o,t);let i=new Set(n.groupIds.flatMap(a=>it(t,a)));if(r.editingGroupId&&r.selectedElementsAreBeingDragged){let a=new Set(ge(t,r));if(r.frameToHighlight!==null)return!0;a.forEach(s=>{i.delete(s)})}for(let a of i)if(re(a))return!1;for(let a of i)if(fn(a,o,t))return!0}return!1},Vp=(e,t)=>e.name===null?yi(e)?`Frame ${t}`:`AI Frame $${t}`:e.name,rs=(e,t)=>f1({elements:e,bounds:t,type:"overlap"}).filter(r=>!r.frameId||r.frameId===t.id)});import mT from"roughjs/bin/rough";import{getStroke as QL}from"perfect-freehand";function Aw(e){let t=vp(e),r=new Path2D(t);return v1.set(e,r),r}function nP(e){return v1.get(e)}function vp(e){let t=e.simulatePressure?e.points:e.points.length?e.points.map(([o,n],i)=>[o,n,e.pressures[i]]):[[0,0,.5]],r={simulatePressure:e.simulatePressure,size:e.strokeWidth*4.25,thinning:.6,smoothing:.5,streamline:.5,easing:o=>Math.sin(o*Math.PI/2),last:!!e.lastCommittedPoint};return aP(QL(t,r))}function dT(e,t){return[(e[0]+t[0])/2,(e[1]+t[1])/2]}function aP(e){if(!e.length)return"";let t=e.length-1;return e.reduce((r,o,n,i)=>(n===t?r.push(o,dT(o,i[0]),"L",i[0],"Z"):r.push(o,dT(o,i[n+1])),r),["M",e[0],"Q"]).join(" ").replace(iP,"$1")}var $f,eP,pT,uT,iu,w1,tP,rP,vv,hT,gT,oP,nu,jc,fT,sT,cT,bT,Ql,v1,iP,sn=y(()=>{"use strict";f();me();dt();G();Kt();Dr();W();mt();or();dr();ln();$f="invert(100%) hue-rotate(180deg) saturate(1.25)",eP=Er(),pT=(e,t)=>gr(e)&&!t.imageCache.has(e.fileId),uT=(e,t,r)=>r.theme===se.DARK&&gr(e)&&!pT(e,t)&&t.imageCache.get(e.fileId)?.mimeType!==te.svg,iu=e=>e.type==="freedraw"?e.strokeWidth*12:20,w1=(e,t,r)=>{let o=(t?.opacity??100)*e.opacity/1e4;return(r.has(e.id)||t&&r.has(t.id))&&(o*=Wy/100),o},tP=(e,t,r)=>{let i=iu(e),[a,l,s,c]=oe(e,t),d=ce(e)||Ft(e)?Bt(a,s):e.width,m=ce(e)||Ft(e)?Bt(l,c):e.height,p=d*window.devicePixelRatio+i*2,u=m*window.devicePixelRatio+i*2,h=r.value;return(p*h>32767||u*h>32767)&&(h=Math.min(32767/p,32767/u)),p*u*h*h>16777216&&(h=Math.sqrt(16777216/(p*u))),p=Math.floor(p*h),u=Math.floor(u*h),{width:p,height:u,scale:h}},rP=(e,t,r,o,n)=>{let i=document.createElement("canvas"),a=i.getContext("2d"),l=iu(e),{width:s,height:c,scale:d}=tP(e,t,r);i.width=s,i.height=c;let m=0,p=0;if(ce(e)||Ft(e)){let[h,E]=oe(e,t);m=e.x>h?Bt(e.x,h)*window.devicePixelRatio*d:0,p=e.y>E?Bt(e.y,E)*window.devicePixelRatio*d:0,a.translate(m,p)}a.save(),a.translate(l*d,l*d),a.scale(window.devicePixelRatio*d,window.devicePixelRatio*d);let u=mT.canvas(i);return uT(e,o,n)&&(a.filter=$f),nu(e,u,a,o,n),a.restore(),{element:e,canvas:i,theme:n.theme,scale:d,zoomValue:r.value,canvasOffsetX:m,canvasOffsetY:p,boundTextElementVersion:ue(e,t)?.version||null,containingFrameOpacity:Xt(e,t)?.opacity||100}},vv=14,hT=document.createElement("img");hT.src=`data:${te.svg},${encodeURIComponent('<svg aria-hidden="true" focusable="false" data-prefix="fas" data-icon="image" class="svg-inline--fa fa-image fa-w-16" role="img" xmlns="http://www.w3.org/2000/svg" viewBox="0 0 512 512"><path fill="#888" d="M464 448H48c-26.51 0-48-21.49-48-48V112c0-26.51 21.49-48 48-48h416c26.51 0 48 21.49 48 48v288c0 26.51-21.49 48-48 48zM112 120c-30.928 0-56 25.072-56 56s25.072 56 56 56 56-25.072 56-56-25.072-56-56-56zM64 384h384V272l-87.515-87.515c-4.686-4.686-12.284-4.686-16.971 0L208 320l-55.515-55.515c-4.686-4.686-12.284-4.686-16.971 0L64 336v48z"></path></svg>')}`;gT=document.createElement("img");gT.src=`data:${te.svg},${encodeURIComponent('<svg viewBox="0 0 668 668" xmlns="http://www.w3.org/2000/svg" xml:space="preserve" style="fill-rule:evenodd;clip-rule:evenodd;stroke-linejoin:round;stroke-miterlimit:2"><path d="M464 448H48c-26.51 0-48-21.49-48-48V112c0-26.51 21.49-48 48-48h416c26.51 0 48 21.49 48 48v288c0 26.51-21.49 48-48 48ZM112 120c-30.928 0-56 25.072-56 56s25.072 56 56 56 56-25.072 56-56-25.072-56-56-56ZM64 384h384V272l-87.515-87.515c-4.686-4.686-12.284-4.686-16.971 0L208 320l-55.515-55.515c-4.686-4.686-12.284-4.686-16.971 0L64 336v48Z" style="fill:#888;fill-rule:nonzero" transform="matrix(.81709 0 0 .81709 124.825 145.825)"/><path d="M256 8C119.034 8 8 119.033 8 256c0 136.967 111.034 248 248 248s248-111.034 248-248S392.967 8 256 8Zm130.108 117.892c65.448 65.448 70 165.481 20.677 235.637L150.47 105.216c70.204-49.356 170.226-44.735 235.638 20.676ZM125.892 386.108c-65.448-65.448-70-165.481-20.677-235.637L361.53 406.784c-70.203 49.356-170.226 44.736-235.638-20.676Z" style="fill:#888;fill-rule:nonzero" transform="matrix(.30366 0 0 .30366 506.822 60.065)"/></svg>')}`;oP=(e,t,r)=>{t.fillStyle="#E7E7E7",t.fillRect(0,0,e.width,e.height);let o=Math.min(e.width,e.height),n=Math.min(o,Math.min(o*.4,100));t.drawImage(e.status==="error"?gT:hT,e.width/2-n/2,e.height/2-n/2,n,n)},nu=(e,t,r,o,n)=>{switch(e.type){case"rectangle":case"iframe":case"embeddable":case"diamond":case"ellipse":{r.lineJoin="round",r.lineCap="round",t.draw(Ne.get(e));break}case"arrow":case"line":{r.lineJoin="round",r.lineCap="round",Ne.get(e).forEach(i=>{t.draw(i)});break}case"freedraw":{r.save(),r.fillStyle=e.strokeColor;let i=nP(e),a=Ne.get(e);a&&t.draw(a),r.fillStyle=e.strokeColor,r.fill(i),r.restore();break}case"image":{let i=gr(e)?o.imageCache.get(e.fileId)?.image:void 0;i!=null&&!(i instanceof Promise)?(e.roundness&&r.roundRect&&(r.beginPath(),r.roundRect(0,0,e.width,e.height,Fo(Math.min(e.width,e.height),e)),r.clip()),r.drawImage(i,0,0,e.width,e.height)):oP(e,r,n.zoom.value);break}default:if(V(e)){let i=Pm(e.text),a=i&&!r.canvas.isConnected;a&&document.body.appendChild(r.canvas),r.canvas.setAttribute("dir",i?"rtl":"ltr"),r.save(),r.font=Ze(e),r.fillStyle=e.strokeColor,r.textAlign=e.textAlign;let l=e.text.replace(/\r\n?/g,`
66
66
  `).split(`
67
- `),s=e.textAlign==="center"?e.width/2:e.textAlign==="right"?e.width:0,c=wi(e.fontSize,e.lineHeight),d=Bm(e.fontFamily,e.fontSize,c);for(let m=0;m<l.length;m++)o.fillText(l[m],s,m*c+d);o.restore(),a&&o.canvas.remove()}else throw new Error(`Unimplemented type ${e.type}`)}},Oc=new WeakMap,yv=()=>{Oc=new WeakMap,Vf=new WeakMap},pv=(e,t,o,r)=>{let n=o?r.zoom:XM.zoom,i=Oc.get(e),a=i&&i.zoomValue!==n.value&&!r?.shouldCacheIgnoreZoom,l=me(e,t)?.version||null,s=Ut(e,t)?.opacity||100;if(!i||a||i.theme!==r.theme||i.boundTextElementVersion!==l||i.containingFrameOpacity!==s){let c=jM(e,t,n,o,r);return Oc.set(e,c),c}return i},uv=(e,t,o,r,n)=>{let i=e.element,a=Dp(i),l=e.scale,[s,c,d,m]=te(i,n);Ot(i)&&(s=Math.floor(s),d=Math.ceil(d),c=Math.floor(c),m=Math.ceil(m));let p=((s+d)/2+r.scrollX)*window.devicePixelRatio,u=((c+m)/2+r.scrollY)*window.devicePixelRatio;t.save(),t.scale(1/window.devicePixelRatio,1/window.devicePixelRatio);let g=me(i,n);if(ke(i)&&g){let x=document.createElement("canvas"),E=x.getContext("2d"),y=Math.max(Nt(s,d),Nt(c,m));x.width=y*window.devicePixelRatio*l+a*e.scale*10,x.height=y*window.devicePixelRatio*l+a*e.scale*10;let T=(x.width-e.canvas.width)/2,w=(x.height-e.canvas.height)/2;E.translate(x.width/2,x.height/2),E.rotate(i.angle),E.drawImage(e.canvas,-e.canvas.width/2,-e.canvas.height/2,e.canvas.width,e.canvas.height);let[,,,,S,M]=te(g,n);E.rotate(-i.angle);let k=x.width/2-(S-s)*window.devicePixelRatio*l-T-a*l,R=x.height/2-(M-c)*window.devicePixelRatio*l-w-a*l;E.translate(-k,-R),E.clearRect(-(g.width/2+xt)*window.devicePixelRatio*l,-(g.height/2+xt)*window.devicePixelRatio*l,(g.width+xt*2)*window.devicePixelRatio*l,(g.height+xt*2)*window.devicePixelRatio*l),t.translate(p,u),t.drawImage(x,-(d-s)/2*window.devicePixelRatio-T/l-a,-(m-c)/2*window.devicePixelRatio-w/l-a,x.width/l,x.height/l)}else if(t.translate(p,u),t.rotate(i.angle),"scale"in e.element&&!fv(i,o)&&t.scale(e.element.scale[0],e.element.scale[1]),t.translate(-p,-u),t.drawImage(e.canvas,(s+r.scrollX)*window.devicePixelRatio-a*e.scale/e.scale,(c+r.scrollY)*window.devicePixelRatio-a*e.scale/e.scale,e.canvas.width/e.scale,e.canvas.height/e.scale),C.VITE_APP_DEBUG_ENABLE_TEXT_CONTAINER_BOUNDING_BOX==="true"&&Eo(i)){let x=me(i,n),E=ef(i);t.strokeStyle="#c92a2a",t.lineWidth=3,t.strokeRect((E.x+r.scrollX)*window.devicePixelRatio,(E.y+r.scrollY)*window.devicePixelRatio,wo(i,x)*window.devicePixelRatio,wa(i,x)*window.devicePixelRatio)}t.restore()},wv=(e,t,o)=>{t.save(),t.translate(e.x+o.scrollX,e.y+o.scrollY),t.fillStyle="rgba(0, 0, 200, 0.04)";let r=.5/o.zoom.value;t.fillRect(r,r,e.width,e.height),t.lineWidth=1/o.zoom.value,t.strokeStyle=" rgb(105, 101, 219)",t.strokeRect(r,r,e.width,e.height),t.restore()},Pc=(e,t,o,r,n,i,a)=>{switch(n.globalAlpha=Wf(e,Ut(e,t),i.elementsPendingErasure),e.type){case"magicframe":case"frame":{a.frameRendering.enabled&&a.frameRendering.outline&&(n.save(),n.translate(e.x+a.scrollX,e.y+a.scrollY),n.fillStyle="rgba(0, 0, 200, 0.04)",n.lineWidth=Je.strokeWidth/a.zoom.value,n.strokeStyle=Je.strokeColor,da(e)&&(n.strokeStyle=a.theme===ie.LIGHT?"#7affd7":"#1d8264"),Je.radius&&n.roundRect?(n.beginPath(),n.roundRect(0,0,e.width,e.height,Je.radius/a.zoom.value),n.stroke(),n.closePath()):n.strokeRect(0,0,e.width,e.height),n.restore());break}case"freedraw":{if(Me.generateElementShape(e,null),i.isExporting){let[l,s,c,d]=te(e,t),m=(l+c)/2+a.scrollX,p=(s+d)/2+a.scrollY,u=(c-l)/2-(e.x-l),g=(d-s)/2-(e.y-s);n.save(),n.translate(m,p),n.rotate(e.angle),n.translate(-u,-g),Pp(e,r,n,i,a),n.restore()}else{let l=pv(e,t,i,a);uv(l,n,i,a,o)}break}case"rectangle":case"diamond":case"ellipse":case"line":case"arrow":case"image":case"text":case"iframe":case"embeddable":{if(Me.generateElementShape(e,i),i.isExporting){let[l,s,c,d]=te(e,t),m=(l+c)/2+a.scrollX,p=(s+d)/2+a.scrollY,u=(c-l)/2-(e.x-l),g=(d-s)/2-(e.y-s);if(W(e)){let E=ut(e,t);if(ke(E)){let y=$.getBoundTextElementPosition(E,e,t);u=(c-l)/2-(y.x-l),g=(d-s)/2-(y.y-s)}}n.save(),n.translate(m,p),bv(e,i,a)&&(n.filter="none");let x=me(e,t);if(ke(e)&&x){let E=document.createElement("canvas"),y=E.getContext("2d"),T=Math.max(Nt(l,c),Nt(s,d)),w=Dp(e);E.width=T*a.exportScale+w*10*a.exportScale,E.height=T*a.exportScale+w*10*a.exportScale,y.translate(E.width/2,E.height/2),y.scale(a.exportScale,a.exportScale),u=e.width/2-(e.x-l),g=e.height/2-(e.y-s),y.rotate(e.angle);let S=hv.canvas(E);y.translate(-u,-g),Pp(e,S,y,i,a),y.translate(u,g),y.rotate(-e.angle);let[,,,,M,k]=te(x,t),R=(l+c)/2-M,P=(s+d)/2-k;y.translate(-R,-P),y.clearRect(-x.width/2,-x.height/2,x.width,x.height),n.scale(1/a.exportScale,1/a.exportScale),n.drawImage(E,-E.width/2,-E.height/2,E.width,E.height)}else n.rotate(e.angle),e.type==="image"&&n.scale(e.scale[0],e.scale[1]),n.translate(-u,-g),Pp(e,r,n,i,a);n.restore()}else{let l=pv(e,t,i,a),s=n.imageSmoothingEnabled;!a?.shouldCacheIgnoreZoom&&(!e.angle||Fy(e.angle))&&(n.imageSmoothingEnabled=!1),uv(l,n,i,a,o),n.imageSmoothingEnabled=s}break}default:throw new Error(`Unimplemented type ${e.type}`)}n.globalAlpha=1},Vf=new WeakMap([]);QM=/(\s?[A-Z]?,?-?[0-9]*\.[0-9]{0,2})(([0-9]|e|-)*)/g});import{RoughGenerator as tL}from"roughjs/bin/generator";var Me,Mr=v(()=>{"use strict";f();Jr();Ph();Wo();Me=class e{static rg=new tL;static cache=new WeakMap;static get=t=>e.cache.get(t);static set=(t,o)=>e.cache.set(t,o);static delete=t=>e.cache.delete(t);static destroy=()=>{e.cache=new WeakMap};static generateElementShape=(t,o)=>{let r=o?.isExporting?void 0:e.get(t);if(r!==void 0)return r;Oc.delete(t);let n=Uy(t,e.rg,o||{isExporting:!1,canvasBackgroundColor:ve.white,embedsValidationStatus:null});return e.cache.set(t,n),n}}});var z,ae,Nr,Ze=v(()=>{"use strict";f();_n();qs();Sr();G();Mr();z=(e,t,o=!0)=>{let r=!1,{points:n,fileId:i}=t;typeof n<"u"&&(t={...wm(n),...t});for(let a in t){let l=t[a];if(typeof l<"u"){if(e[a]===l&&(typeof l!="object"||l===null||a==="groupIds"||a==="scale"))continue;if(a==="scale"){let s=e[a],c=l;if(s[0]===c[0]&&s[1]===c[1])continue}else if(a==="points"){let s=e[a],c=l;if(s.length===c.length){let d=!1,m=s.length;for(;--m;){let p=s[m],u=c[m];if(p[0]!==u[0]||p[1]!==u[1]){d=!0;break}}if(!d)continue}}e[a]=l,r=!0}}return r&&((typeof t.height<"u"||typeof t.width<"u"||typeof i<"u"||typeof n<"u")&&Me.delete(e),e.version++,e.versionNonce=ar(),e.updated=Ln(),o&&lt.getScene(e)?.informMutation()),e},ae=(e,t)=>{let o=!1;for(let r in t){let n=t[r];if(typeof n<"u"){if(e[r]===n&&(typeof n!="object"||n===null))continue;o=!0}}return o?{...e,...t,updated:Ln(),version:e.version+1,versionNonce:ar()}:e},Nr=(e,t)=>(e.version=(t??e.version)+1,e.versionNonce=ar(),e.updated=Ln(),e)});var dr,Da,Rp,_l,Sc,Ra=v(()=>{"use strict";f();Ze();se();U();bt();G();dr=e=>ne(e)||Ot(e)?e.points.length<2:e.width===0&&e.height===0,Da=(e,t,o,r,n)=>{let[i,a,l,s]=Dr(e,n),c=$e({clientX:r.offsetLeft,clientY:r.offsetTop},r),d=$e({clientX:r.offsetLeft+t,clientY:r.offsetTop+o},r);return c.x<=l&&c.y<=s&&d.x>=i&&d.y>=a},Rp=(e,t,o)=>{let r=Math.abs(t),n=Math.abs(o);if(e==="line"||e==="arrow"||e==="freedraw"){let i=Math.round(Math.atan(n/r)/Yr)*Yr;i===0?o=0:i===Math.PI/2?t=0:o=r*Math.tan(i)*Math.sign(o)||o}else e!=="selection"&&(o=r*Math.sign(o));return{width:t,height:o}},_l=(e,t,o,r)=>{let n=o-e,i=r-t,a=Math.round(Math.atan(i/n)/Yr)*Yr;if(a===0)i=0;else if(a===Math.PI/2)n=0;else{let l=Math.tan(a),s=-1,c=t-l*e,d=-1/l,m=-1,p=r-d*o,u=(s*p-m*c)/(l*m-d*s),g=(c*d-p*l)/(l*m-d*s);n=u-e,i=g-t}return{width:n,height:i}},Sc=e=>{let t={width:e.width,height:e.height,x:e.x,y:e.y};if(e.width<0){let o=Math.abs(e.width);t.width=o,t.x=e.x-o}if(e.height<0){let o=Math.abs(e.height);t.height=o,t.y=e.y-o}return t}});var Kf,vv,Np,Op,Yf,oL,Bp,Tv=v(()=>{"use strict";f();vl();Kf=(e,t,o)=>t>=e[0]&&t<=e[0]+e[2]&&o>=e[1]&&o<=e[1]+e[3],vv=(e,t,o,r,n,i,a)=>{if(!o.selectedElementIds[e.id])return!1;let{rotation:l,...s}=sc(e,i,t,a);if(l&&Kf(l,r,n))return"rotation";let c=Object.keys(s).filter(d=>{let m=s[d];return m?Kf(m,r,n):!1});return c.length>0?c[0]:!1},Np=(e,t,o,r,n,i,a)=>e.reduce((l,s)=>{if(l)return l;let c=vv(s,a,t,o,r,n,i);return c?{element:s,transformHandleType:c}:null},null),Op=([e,t,o,r],n,i,a,l)=>{let s=yl([e,t,o,r,(e+o)/2,(t+r)/2],0,a,l,lc);return Object.keys(s).find(d=>{let m=s[d];return m&&Kf(m,n,i)})||!1},Yf=["ns","nesw","ew","nwse"],oL=(e,t)=>{let o=Yf.indexOf(e);if(o>=0){let r=Math.round(t/(Math.PI/4));e=Yf[(o+r)%Yf.length]}return e},Bp=e=>{let{element:t,transformHandleType:o}=e,r=t&&Math.sign(t.height)*Math.sign(t.width)===-1,n=null;switch(o){case"n":case"s":n="ns";break;case"w":case"e":n="ew";break;case"nw":case"se":r?n="nesw":n="nwse";break;case"ne":case"sw":r?n="nwse":n="nesw";break;case"rotation":return"grab"}return n&&t&&(n=oL(n,t.angle)),n?`${n}-resize`:""}});var Fp,$f,rL,nL,Xf,iL,aL,lL,Zf,sL,jf,qf,Jf=v(()=>{"use strict";f();U();qs();Qt();bt();se();Ze();G();_r();_n();pt();io();Fp=e=>e<0?e+2*Math.PI:e>=2*Math.PI?e-2*Math.PI:e,$f=(e,t,o,r,n,i,a,l,s,c,d)=>{if(o.length===1){let[m]=o;return t==="rotation"?(rL(m,r,l,s,n),Lr(m,r)):W(m)&&(t==="nw"||t==="ne"||t==="sw"||t==="se")?(aL(m,r,t,i,l,s),Lr(m,r)):t&&lL(e,a,m,r,t,i,l,s),!0}else if(o.length>1){if(t==="rotation")return sL(e,o,r,l,s,n,c,d),!0;if(t==="nw"||t==="ne"||t==="sw"||t==="se")return Zf(e,o,r,t,i,l,s),!0}return!1},rL=(e,t,o,r,n)=>{let[i,a,l,s]=te(e,t),c=(i+l)/2,d=(a+s)/2,m;Q(e)?m=0:(m=5*Math.PI/2+Math.atan2(r-d,o-c),n&&(m+=Yr/2,m-=m%Yr),m=Fp(m));let p=Bn(e);if(z(e,{angle:m}),p){let u=lt.getScene(e)?.getElement(p);u&&!ke(e)&&z(u,{angle:m})}},nL=(e,t,o,r)=>ne(e)||Ot(e)?{points:gi(0,t,gi(1,o,e.points,r),r)}:{},Xf=(e,t,o)=>{let r=e.width;if(ze(e)){let a=ut(e,t);a&&(r=wo(a,e))}let i=e.fontSize*(o/r);return i<om?null:{size:i}},iL=(e,t)=>({n:/^(n|ne|nw)$/.test(e)||t&&/^(s|se|sw)$/.test(e),s:/^(s|se|sw)$/.test(e)||t&&/^(n|ne|nw)$/.test(e),w:/^(w|nw|sw)$/.test(e)||t&&/^(e|ne|se)$/.test(e),e:/^(e|ne|se)$/.test(e)||t&&/^(w|nw|sw)$/.test(e)}),aL=(e,t,o,r,n,i)=>{let[a,l,s,c]=te(e,t),d=(a+s)/2,m=(l+c)/2,[p,u]=Ee(n,i,d,m,-e.angle),g;switch(o){case"se":g=Math.max((p-a)/(s-a),(u-l)/(c-l));break;case"nw":g=Math.max((s-p)/(s-a),(c-u)/(c-l));break;case"ne":g=Math.max((p-a)/(s-a),(c-u)/(c-l));break;case"sw":g=Math.max((s-p)/(s-a),(u-l)/(c-l));break}if(g>0){let x=e.width*g,E=e.height*g,y=Xf(e,t,x);if(y===null)return;let[T,w,S,M]=va(e,x,E,!1),k=(a-T)/2,R=(l-w)/2,P=(s-S)/2,F=(c-M)/2,[D,L]=vm(iL(o,r),e.x,e.y,e.angle,k,R,P,F);z(e,{fontSize:y.size,width:x,height:E,x:D,y:L})}},lL=(e,t,o,r,n,i,a,l)=>{let s=e.get(o.id),[c,d,m,p]=va(s,s.width,s.height,!0),u=[c,d],g=[m,p],x=Qs(u,g),E=Xe([a,l],x,-s.angle),[y,T,w,S]=va(o,o.width,o.height,!0),M=w-y,k=S-T,R=g[0]-u[0],P=g[1]-u[1],F=R/M,D=P/k,L={},A=me(o,r);n.includes("e")&&(F=(E[0]-u[0])/M),n.includes("s")&&(D=(E[1]-u[1])/k),n.includes("w")&&(F=(g[0]-E[0])/M),n.includes("n")&&(D=(g[1]-E[1])/k);let B=s.width,j=s.height,Y=o.width*F,oe=o.height*D;if(i&&(Y=2*Y-B,oe=2*oe-j),t){let xo=Math.abs(Y)/B,al=Math.abs(oe)/j;if(n.length===1&&(oe*=xo,Y*=al),n.length===2){let ra=Math.max(xo,al);Y=B*ra*Math.sign(Y),oe=j*ra*Math.sign(oe)}}if(A){let xo=e.get(A.id);if(xo&&(L={fontSize:xo.fontSize}),t){let al={...o,width:Y,height:oe},ra=Xf(A,r,wo(al,A));if(ra===null)return;L={fontSize:ra.size}}else{let al=Hm(Ke(A),A.lineHeight),ra=Fm(A.fontSize,A.lineHeight);Y=Math.max(Y,al),oe=Math.max(oe,ra)}}let[Ce,Te,K,ge]=va(s,Y,oe,!0),xe=K-Ce,Ne=ge-Te,Le=[...u];if(["n","w","nw"].includes(n)&&(Le=[g[0]-Math.abs(xe),g[1]-Math.abs(Ne)]),n==="ne"){let xo=[u[0],g[1]];Le=[xo[0],xo[1]-Math.abs(Ne)]}if(n==="sw"){let xo=[g[0],u[1]];Le=[xo[0]-Math.abs(xe),xo[1]]}t&&(["s","n"].includes(n)&&(Le[0]=x[0]-xe/2),["e","w"].includes(n)&&(Le[1]=x[1]-Ne/2));let $t=Y<0,wn=oe<0;$t&&(n.includes("e")&&(Le[0]-=Math.abs(xe)),n.includes("w")&&(Le[0]+=Math.abs(xe))),wn&&(n.includes("s")&&(Le[1]-=Math.abs(Ne)),n.includes("n")&&(Le[1]+=Math.abs(Ne))),i&&(Le[0]=x[0]-Math.abs(xe)/2,Le[1]=x[1]-Math.abs(Ne)/2);let Xt=s.angle,Wr=Xe(Le,x,Xt),vn=[Le[0]+Math.abs(xe)/2,Le[1]+Math.abs(Ne)/2],oa=Xe(vn,x,Xt);Le=Xe(Wr,oa,-Xt);let tr=[...Le],Tn=s.x-Ce,Dt=s.y-Te;tr[0]+=Tn,tr[1]+=Dt;let xk=tr[0],Ek=tr[1],B0,F0;(ne(o)||Ot(o))&&(B0=gi(1,oe,s.points,!0),F0=gi(0,Y,B0,!0));let ii={width:Math.abs(Y),height:Math.abs(oe),x:xk,y:Ek,points:F0};if("scale"in o&&"scale"in s&&z(o,{scale:[(Math.sign(K-s.x)||s.scale[0])*s.scale[0],(Math.sign(ge-s.y)||s.scale[1])*s.scale[1]]}),ke(o)&&A&&t){let xo=ii.width/o.width*A.fontSize;if(xo<om)return;L.fontSize=xo}ii.width!==0&&ii.height!==0&&Number.isFinite(ii.x)&&Number.isFinite(ii.y)&&(z(o,ii),Lr(o,r,{newSize:{width:ii.width,height:ii.height}}),A&&L!=null&&z(A,{fontSize:L.fontSize}),xa(o,r,n,t))},Zf=(e,t,o,r,n,i,a)=>{let l=t.reduce((L,A)=>{let B=e.get(A.id);return B&&L.push({orig:B,latest:A}),L},[]),s=l.reduce((L,{orig:A})=>{if(!ne(A))return L;let B=Bn(A);if(!B)return L;let j=e.get(B)??null;if(!ze(j))return L;let Y=$.getBoundTextElementPosition(A,j,o);return[...L,{...j,...Y}]},[]),{minX:c,minY:d,maxX:m,maxY:p,midX:u,midY:g}=vo(l.map(({orig:L})=>L).concat(s)),x=r,E={ne:[c,p],se:[c,d],sw:[m,d],nw:[m,p]},[y,T]=n?[u,g]:E[x],w=Math.max(Math.abs(i-y)/(m-c)||0,Math.abs(a-T)/(p-d)||0)*(n?2:1);if(w===0)return;let S={ne:[i>=y,a<=T],se:[i>=y,a>=T],sw:[i<=y,a>=T],nw:[i<=y,a<=T]},[M,k]=S[x].map(L=>L?1:-1),R=M<0,P=k<0,F=[];for(let{orig:L,latest:A}of l){if(W(L)&&ze(L))continue;let B=L.width*w,j=L.height*w,Y=Fp(L.angle*M*k),oe=ne(L)||Ot(L),Ce=L.x-y,Te=L.y-T,K=R&&!oe?B:0,ge=P&&!oe?j:0,xe=y+M*(Ce*w+K),Ne=T+k*(Te*w+ge),Le=nL(L,B*M,j*k,!1),$t={x:xe,y:Ne,width:B,height:j,angle:Y,...Le};if(nr(L)&&l.length===1&&($t.scale=[L.scale[0]*M,L.scale[1]*k]),ne(L)&&(R||P)){let Xt=Ll(L,L.points),Wr=Ll({...L,x:xe,y:Ne},Le.points),vn=[L.x,L.y],oa=[xe,Ne],tr=Tn=>{let Dt=Tn==="x"?0:1;return(Wr[Dt+2]-oa[Dt]-(vn[Dt]-Xt[Dt])*w+(Xt[Dt+2]-vn[Dt])*w-(oa[Dt]-Wr[Dt]))/2};R&&($t.x-=tr("x")),P&&($t.y-=tr("y"))}if(W(L)){let Xt=Xf(L,o,B);if(!Xt)return;$t.fontSize=Xt.size}let wn=e.get(Bn(L)??"");if(wn){let Xt=wn.fontSize*w;if(Xt<om)return;$t.boundTextFontSize=Xt}F.push({element:A,update:$t})}let D=F.map(({element:L})=>L);for(let{element:L,update:{boundTextFontSize:A,...B}}of F){let{width:j,height:Y,angle:oe}=B;z(L,B,!1),Lr(L,o,{simultaneouslyUpdated:D,newSize:{width:j,height:Y}});let Ce=me(L,o);Ce&&A&&(z(Ce,{fontSize:A,angle:ne(L)?void 0:oe},!1),xa(L,o,r,!0))}lt.getScene(F[0].element)?.informMutation()},sL=(e,t,o,r,n,i,a,l)=>{let s=5*Math.PI/2+Math.atan2(n-l,r-a);i&&(s+=Yr/2,s-=s%Yr),t.filter(c=>!Q(c)).forEach(c=>{let[d,m,p,u]=te(c,o),g=(d+p)/2,x=(m+u)/2,E=e.get(c.id)?.angle??c.angle,[y,T]=Ee(g,x,a,l,s+E-c.angle);z(c,{x:c.x+(y-g),y:c.y+(T-x),angle:Fp(s+E)},!1),Lr(c,o,{simultaneouslyUpdated:t});let w=me(c,o);w&&!ke(c)&&z(w,{x:w.x+(y-g),y:w.y+(T-x),angle:Fp(s+E)},!1)}),lt.getScene(t[0])?.informMutation()},jf=(e,t,o,r,n)=>{let[i,a,l,s]=t.length===1?te(t[0],o):Se(t),c=(i+l)/2,d=(a+s)/2,m=t.length===1?t[0].angle:0;switch([r,n]=Ee(r,n,c,d,-m),e){case"n":return Ee(r-(i+l)/2,n-a,0,0,m);case"s":return Ee(r-(i+l)/2,n-s,0,0,m);case"w":return Ee(r-i,n-(a+s)/2,0,0,m);case"e":return Ee(r-l,n-(a+s)/2,0,0,m);case"nw":return Ee(r-i,n-a,0,0,m);case"ne":return Ee(r-l,n-a,0,0,m);case"sw":return Ee(r-i,n-s,0,0,m);case"se":return Ee(r-l,n-s,0,0,m);default:return[0,0]}},qf=(e,t)=>{let[,[o,r]]=t.points;return e==="nw"&&(o<0||r<0)||e==="ne"&&o>=0||e==="sw"&&o<=0||e==="se"&&(o>0||r>0)?"end":"origin"}});var Qf,cL,Cv,e1,Hp,Iv=v(()=>{"use strict";f();_r();bt();Ze();Ra();pt();Qt();se();Qf=(e,t,o,r,n,i,a)=>{let l=new Set(t),s=t.filter(m=>Q(m)).map(m=>m.id);if(s.length>0)for(let m of n.getNonDeletedElements())m.frameId!==null&&s.includes(m.frameId)&&l.add(m);let c=Se(Array.from(l).map(m=>e.originalElements.get(m.id)??m)),d=cL(c,o,i,a);l.forEach(m=>{if(Cv(e,m,d),!ke(m)){let p=me(m,n.getNonDeletedElementsMap());p&&Cv(e,p,d)}Lr(m,n.getElementsMapIncludingDeleted(),{simultaneouslyUpdated:Array.from(l)})})},cL=(e,t,o,r)=>{let[n,i]=e,a=n+t.x+o.x,l=i+t.y+o.y;if(o.x===0||o.y===0){let[s,c]=At(n+t.x,i+t.y,r);o.x===0&&(a=s),o.y===0&&(l=c)}return{x:a-n,y:l-i}},Cv=(e,t,o)=>{let r=e.originalElements.get(t.id)??t,n=r.x+o.x,i=r.y+o.y;z(t,{x:n,y:i})},e1=(e,t,o)=>{let[r,n]=Se(e);return[t-r,o-n]},Hp=(e,t,o,r,n,i,a,l,s,c,d,m=null)=>{s&&e.type!=="selection"&&(d?l=a/d:(Math.abs(i-r)>Math.abs(n-o)?{width:a,height:l}=Rp(t,l,n<o?-a:a):{width:a,height:l}=Rp(t,a,i<r?-l:l),l<0&&(l=-l)));let p=n<o?o-a:o,u=i<r?r-l:r;c&&(a+=a,l+=l,p=o-a/2,u=r-l/2),a!==0&&l!==0&&z(e,{x:p+(m?.x??0),y:u+(m?.y??0),width:a,height:l})}});var Na,Sv=v(()=>{"use strict";f();We();Na=(e,t)=>!!(!e.viewModeEnabled&&(e.activeTool.type!=="custom"&&(e.editingElement||e.activeTool.type!=="selection"&&e.activeTool.type!=="eraser"&&e.activeTool.type!=="hand"&&e.activeTool.type!=="laser")||de(t,e).length))});var dL,t1,o1,kv,be,js,Av,Cw,np,he=v(()=>{"use strict";f();Ra();se();on();bt();vl();Ei();Tv();Jf();Iv();se();pt();Ra();Sv();dL=e=>e.reduce((t,o)=>t+o.version,0),t1=e=>{let t=5381;for(let o=0;o<e.length;o++)t=(t<<5)+t+e[o].versionNonce;return t>>>0},o1=e=>{let t=5381;for(let o=0;o<e.length;o++){let r=e.charCodeAt(o);t=(t<<5)+t+r}return t>>>0},kv=e=>e.filter(t=>!t.isDeleted&&!dr(t)),be=e=>e.filter(t=>!t.isDeleted),js=e=>!e.isDeleted,Av=e=>be(e).map(t=>Xs(t.type)?{...t,lastCommittedPoint:null}:t),Cw=e=>Av(e),np=e=>Av(e)});var Oa,es,r1,Ye,n1,de,Ba,Oe,ui=v(()=>{"use strict";f();he();se();ao();G();Ra();Oa=e=>{let t=new Set;return e.forEach(o=>{Q(o)&&t.add(o.id)}),e.filter(o=>!(o.frameId&&t.has(o.frameId)))},es=(e,t,o,r=!0)=>{let[n,i,a,l]=te(t,o),s=e.filter(c=>{let[d,m,p,u]=Dr(c,o),g=Ut(c,o);if(g){let[x,E,y,T]=Dr(g,o);d=Math.max(x,d),m=Math.max(E,m),p=Math.min(y,p),u=Math.min(T,u)}return c.locked===!1&&c.type!=="selection"&&!ze(c)&&n<=d&&i<=m&&a>=p&&l>=u});return s=r?Oa(s):s,s=s.filter(c=>{let d=Ut(c,o);return d?an(c,d,o):!0}),s},r1=(e,t,o,r)=>{let n=new Set(t.map(i=>i.id));return e.filter(i=>{let a=Da(i,o.width,o.height,o,r);return!n.has(i.id)&&a})},Ye=function(){let e=null,t=null,o=null,r=(n,i)=>(o!=null&&n===e&&i.selectedElementIds===t||(o=n.some(a=>i.selectedElementIds[a.id]),e=n,t=i.selectedElementIds),o);return r.clearCache=()=>{e=null,t=null,o=null},r}(),n1=(e,t,o)=>{let r=Array.from(new Set(de(e,t).map(n=>o(n))));return r.length===1?r[0]:null},de=(e,t,o)=>{let r=[];for(let n of e.values()){if(t.selectedElementIds[n.id]){r.push(n);continue}if(o?.includeBoundTextElement&&ze(n)&&t.selectedElementIds[n?.containerId]){r.push(n);continue}}if(o?.includeElementsInFrames){let n=[];return r.forEach(i=>{Q(i)&&Vo(e,i.id).forEach(a=>n.push(a)),n.push(i)}),n}return r},Ba=(e,t)=>t.editingElement?[t.editingElement]:de(e,t,{includeBoundTextElement:!0}),Oe=(e,t)=>It(t.selectedElementIds,e)?t.selectedElementIds:e});var mL,i1,nn,a1=v(()=>{"use strict";f();he();G();mL=(e,t)=>{let[o,r,n,i]=t,{x:a,y:l}=zt({sceneX:o,sceneY:r},e),{x:s,y:c}=zt({sceneX:n,sceneY:i},e);return s-a>e.width||c-l>e.height},i1=({scenePoint:e,viewportDimensions:t,zoom:o})=>({scrollX:t.width/2/o.value-e.x,scrollY:t.height/2/o.value-e.y}),nn=(e,t)=>{if(e=kv(e),!e.length)return{scrollX:0,scrollY:0};let[o,r,n,i]=Se(e);mL(t,[o,r,n,i])&&([o,r,n,i]=lf(e,$e({clientX:t.scrollX,clientY:t.scrollY},t)));let a=(o+n)/2,l=(r+i)/2;return i1({scenePoint:{x:a,y:l},viewportDimensions:{width:t.width,height:t.height},zoom:t.zoom})}});var sn,Zn,zp=v(()=>{"use strict";f();U();sn=e=>Math.max(im,Math.min(e,30)),Zn=({viewportX:e,viewportY:t,nextZoom:o},r)=>{let n=e-r.offsetLeft,i=t-r.offsetTop,a=r.zoom.value,l=r.scrollX+(n-n/a),s=r.scrollY+(i-i/a),c=-(n-n/o),d=-(i-i/o);return{scrollX:l+c,scrollY:s+d,zoom:{value:o}}}});var We=v(()=>{"use strict";f();ui();a1();nc();zp()});var jn=v(()=>{});import l1,{useEffect as pL,useRef as Mv,useState as uL}from"react";import Lv from"clsx";import{jsx as Bc,jsxs as Fc}from"react/jsx-runtime";var ce,Mt=v(()=>{"use strict";f();jn();ye();Ia();In();G();ce=l1.forwardRef((e,t)=>{let{id:o}=Wt(),r=l1.useRef(null);l1.useImperativeHandle(t,()=>r.current);let n=`ToolIcon_size_${e.size}`,[i,a]=uL(!1),l=Mv(!0),s=async d=>{let m="onClick"in e&&e.onClick?.(d);if(Xr(m))try{a(!0),await m}catch(p){if(p instanceof rn)console.warn(p);else throw p}finally{l.current&&a(!1)}};pL(()=>(l.current=!0,()=>{l.current=!1}),[]);let c=Mv(null);if(e.type==="button"||e.type==="icon"||e.type==="submit"){let d=e.type==="icon"?"button":e.type;return Fc("button",{className:Lv("ToolIcon_type_button",n,e.className,e.visible&&!e.hidden?"ToolIcon_type_button--show":"ToolIcon_type_button--hide",{ToolIcon:!e.hidden,"ToolIcon--selected":e.selected,"ToolIcon--plain":e.type==="icon"}),style:e.style,"data-testid":e["data-testid"],hidden:e.hidden,title:e.title,"aria-label":e["aria-label"],type:d,onClick:s,ref:r,disabled:i||e.isLoading,children:[(e.icon||e.label)&&Fc("div",{className:"ToolIcon__icon","aria-hidden":"true",children:[e.icon||e.label,e.keyBindingLabel&&Bc("span",{className:"ToolIcon__keybinding",children:e.keyBindingLabel}),e.isLoading&&Bc(jt,{})]}),e.showAriaLabel&&Fc("div",{className:"ToolIcon__label",children:[e["aria-label"]," ",i&&Bc(jt,{})]}),e.children]})}return Fc("label",{className:Lv("ToolIcon",e.className),title:e.title,onPointerDown:d=>{c.current=d.pointerType||null,e.onPointerDown?.({pointerType:d.pointerType||null})},onPointerUp:()=>{requestAnimationFrame(()=>{c.current=null})},children:[Bc("input",{className:`ToolIcon_type_radio ${n}`,type:"radio",name:e.name,"aria-label":e["aria-label"],"aria-keyshortcuts":e["aria-keyshortcuts"],"data-testid":e["data-testid"],id:`${o}-${e.id}`,onChange:()=>{e.onChange?.({pointerType:c.current})},checked:e.checked,ref:r}),Fc("div",{className:"ToolIcon__icon",children:[e.icon,e.keyBindingLabel&&Bc("span",{className:"ToolIcon__keybinding",children:e.keyBindingLabel})]})]})});ce.defaultProps={visible:!0,className:"",size:"medium"};ce.displayName="ToolButton"});var Pv={};Os(Pv,{AlignBottomIcon:()=>qp,AlignLeftIcon:()=>Jp,AlignRightIcon:()=>Qp,AlignTopIcon:()=>jp,ArrowIcon:()=>E1,ArrowRightIcon:()=>Ua,ArrowheadArrowIcon:()=>eb,ArrowheadBarIcon:()=>ob,ArrowheadCircleIcon:()=>iu,ArrowheadCircleOutlineIcon:()=>tb,ArrowheadDiamondIcon:()=>ib,ArrowheadDiamondOutlineIcon:()=>ab,ArrowheadNoneIcon:()=>Q1,ArrowheadTriangleIcon:()=>rb,ArrowheadTriangleOutlineIcon:()=>nb,BringForwardIcon:()=>Kp,BringToFrontIcon:()=>Xp,CenterHorizontallyIcon:()=>tu,CenterVerticallyIcon:()=>eu,CloseIcon:()=>Yo,DeviceDesktopIcon:()=>zb,DiamondIcon:()=>b1,DiscordIcon:()=>A1,DistributeHorizontallyIcon:()=>F1,DistributeVerticallyIcon:()=>H1,DotsIcon:()=>d1,DuplicateIcon:()=>ts,EdgeRoundIcon:()=>J1,EdgeSharpIcon:()=>q1,EllipseIcon:()=>x1,EmbedIcon:()=>S1,EraserIcon:()=>C1,ExcalLogo:()=>fL,ExportIcon:()=>Li,ExportImageIcon:()=>Wc,ExternalLinkIcon:()=>Wp,FillCrossHatchIcon:()=>U1,FillHachureIcon:()=>G1,FillSolidIcon:()=>W1,FillZigZagIcon:()=>z1,FontFamilyCodeIcon:()=>pb,FontFamilyNormalIcon:()=>mb,FontSizeExtraLargeIcon:()=>db,FontSizeLargeIcon:()=>cb,FontSizeMediumIcon:()=>sb,FontSizeSmallIcon:()=>lb,FreedrawIcon:()=>Ha,GithubIcon:()=>Gc,GroupIcon:()=>ou,HamburgerMenuIcon:()=>zc,HelpIcon:()=>za,HelpIconThin:()=>k1,HomeIcon:()=>s1,ImageIcon:()=>T1,LibraryIcon:()=>Hc,LineIcon:()=>y1,LinkIcon:()=>ns,LoadIcon:()=>Ga,LockedIcon:()=>Fa,MagicIcon:()=>Wa,MagicIconThin:()=>OL,MoonIcon:()=>os,OpenAIIcon:()=>is,PenModeIcon:()=>w1,PinIcon:()=>m1,PlusIcon:()=>c1,RectangleIcon:()=>f1,RedoIcon:()=>Yp,SelectionIcon:()=>h1,SendBackwardIcon:()=>$p,SendToBackIcon:()=>Zp,SloppinessArchitectIcon:()=>X1,SloppinessArtistIcon:()=>Z1,SloppinessCartoonistIcon:()=>j1,StrokeStyleDashedIcon:()=>K1,StrokeStyleDottedIcon:()=>$1,StrokeStyleSolidIcon:()=>_L,StrokeWidthBaseIcon:()=>nu,StrokeWidthBoldIcon:()=>V1,StrokeWidthExtraBoldIcon:()=>Y1,SunIcon:()=>rs,TextAlignBottomIcon:()=>bb,TextAlignCenterIcon:()=>gb,TextAlignLeftIcon:()=>ub,TextAlignMiddleIcon:()=>xb,TextAlignRightIcon:()=>hb,TextAlignTopIcon:()=>fb,TextIcon:()=>v1,TrashIcon:()=>ur,UndoIcon:()=>Vp,UngroupIcon:()=>ru,UnlockedIcon:()=>Mi,WelcomeScreenHelpArrow:()=>u1,WelcomeScreenMenuArrow:()=>p1,WelcomeScreenTopToolbarArrow:()=>g1,XBrandIcon:()=>M1,ZoomInIcon:()=>Gp,ZoomOutIcon:()=>Up,ZoomResetIcon:()=>I1,abacusIcon:()=>Db,alertTriangleIcon:()=>vb,arrowBarToLeftIcon:()=>BL,boltIcon:()=>qc,brainIcon:()=>kb,brainIconThin:()=>Ab,bucketFillIcon:()=>Uc,checkIcon:()=>L1,clipboard:()=>bL,clockIcon:()=>Mb,clone:()=>AL,coffeeIcon:()=>Hb,copyIcon:()=>Kc,createIcon:()=>_,cutIcon:()=>yb,done:()=>N1,downloadIcon:()=>lu,eraser:()=>PL,exportToFileIcon:()=>R1,exportToPlus:()=>TL,extraToolsIcon:()=>Cb,eyeClosedIcon:()=>Sb,eyeDropperIcon:()=>Tb,eyeIcon:()=>Va,file:()=>LL,flipHorizontal:()=>Nb,flipVertical:()=>Rb,fontSizeIcon:()=>au,frameToolIcon:()=>$c,fullscreenIcon:()=>Ib,handIcon:()=>Yc,helpIcon:()=>wb,iconFillColor:()=>pr,laserPointerToolIcon:()=>Zc,magnetIcon:()=>Fb,menu:()=>yL,mermaidLogoIcon:()=>Xc,microphoneIcon:()=>Lb,microphoneMutedIcon:()=>_b,paintIcon:()=>su,palette:()=>D1,playerPlayIcon:()=>DL,playerStopFilledIcon:()=>RL,pngIcon:()=>Bb,publishIcon:()=>Eb,questionCircle:()=>O1,resetZoom:()=>IL,save:()=>_1,saveAs:()=>P1,searchIcon:()=>jc,selectAllIcon:()=>Pb,share:()=>B1,shareIOS:()=>vL,shareWindows:()=>CL,shield:()=>ML,start:()=>SL,stop:()=>kL,svgIcon:()=>Ob,tablerCheckIcon:()=>NL,usersIcon:()=>Vc,warning:()=>wL,youtubeIcon:()=>Gb,zoomAreaIcon:()=>Jc,zoomIn:()=>xL,zoomOut:()=>EL});import Io from"react";import gL from"open-color";import hL from"clsx";import{Fragment as De,jsx as h,jsxs as O}from"react/jsx-runtime";var pr,_v,_,q,pe,s1,Hc,c1,d1,m1,Mi,Fa,p1,u1,g1,fL,h1,f1,b1,x1,E1,y1,w1,Ha,v1,T1,C1,Gp,Up,I1,ur,S1,ts,os,rs,zc,Li,za,k1,Wp,Gc,A1,M1,L1,ns,_1,P1,Ga,bL,D1,Uc,Wc,R1,xL,EL,N1,yL,Vp,Yp,O1,B1,wL,vL,TL,CL,IL,Kp,$p,Xp,Zp,jp,qp,Jp,Qp,F1,H1,eu,tu,Vc,SL,kL,Yo,AL,ML,LL,ou,ru,z1,G1,U1,W1,nu,V1,Y1,_L,K1,$1,X1,Z1,j1,q1,J1,Q1,eb,iu,tb,ob,rb,nb,ib,ab,lb,sb,cb,db,au,mb,pb,ub,gb,hb,fb,bb,xb,Eb,PL,Yc,lu,Kc,yb,wb,DL,RL,NL,vb,Tb,Cb,$c,Xc,Ua,Zc,Wa,OL,is,Ib,Va,Sb,kb,Ab,jc,Mb,Lb,_b,qc,Pb,Db,Rb,Nb,su,Jc,Ob,Bb,Fb,Hb,zb,BL,Gb,ee=v(()=>{"use strict";f();U();pr=e=>"var(--icon-fill-color)",_v=e=>e===ie.LIGHT?gL.white:"#1e1e1e",_=(e,t=512)=>{let{width:o=512,height:r=o,mirror:n,style:i,...a}=typeof t=="number"?{width:t}:t;return h("svg",{"aria-hidden":"true",focusable:"false",role:"img",viewBox:`0 0 ${o} ${r}`,className:hL({"rtl-mirror":n}),style:i,...a,children:typeof e=="string"?h("path",{fill:"currentColor",d:e}):e})},q={width:24,height:24,fill:"none",strokeWidth:2,stroke:"currentColor",strokeLinecap:"round",strokeLinejoin:"round"},pe={width:20,height:20,fill:"none",stroke:"currentColor",strokeLinecap:"round",strokeLinejoin:"round"},s1=_(O("g",{strokeWidth:1.5,children:[h("path",{stroke:"none",d:"M0 0h24v24H0z",fill:"none"}),h("polyline",{points:"5 12 3 12 12 3 21 12 19 12"}),h("path",{d:"M5 12v7a2 2 0 0 0 2 2h10a2 2 0 0 0 2 -2v-7"}),h("path",{d:"M9 21v-6a2 2 0 0 1 2 -2h2a2 2 0 0 1 2 2v6"})]}),q),Hc=_(O("g",{strokeWidth:"1.25",children:[h("path",{stroke:"none",d:"M0 0h24v24H0z",fill:"none"}),h("path",{d:"M3 19a9 9 0 0 1 9 0a9 9 0 0 1 9 0"}),h("path",{d:"M3 6a9 9 0 0 1 9 0a9 9 0 0 1 9 0"}),h("line",{x1:"3",y1:"6",x2:"3",y2:"19"}),h("line",{x1:"12",y1:"6",x2:"12",y2:"19"}),h("line",{x1:"21",y1:"6",x2:"21",y2:"19"})]}),q),c1=_(O("svg",{strokeWidth:"1.5",children:[h("path",{stroke:"none",d:"M0 0h24v24H0z",fill:"none"}),h("line",{x1:"12",y1:"5",x2:"12",y2:"19"}),h("line",{x1:"5",y1:"12",x2:"19",y2:"12"})]}),q),d1=_(O("g",{strokeWidth:"1.5",children:[h("path",{stroke:"none",d:"M0 0h24v24H0z",fill:"none"}),h("circle",{cx:"12",cy:"12",r:"1"}),h("circle",{cx:"12",cy:"19",r:"1"}),h("circle",{cx:"12",cy:"5",r:"1"})]}),q),m1=_(O("svg",{strokeWidth:"1.5",children:[h("path",{stroke:"none",d:"M0 0h24v24H0z",fill:"none"}),h("path",{d:"M9 4v6l-2 4v2h10v-2l-2 -4v-6"}),h("line",{x1:"12",y1:"16",x2:"12",y2:"21"}),h("line",{x1:"8",y1:"4",x2:"16",y2:"4"})]}),q),Mi=_(O("g",{children:[h("path",{d:"M13.542 8.542H6.458a2.5 2.5 0 0 0-2.5 2.5v3.75a2.5 2.5 0 0 0 2.5 2.5h7.084a2.5 2.5 0 0 0 2.5-2.5v-3.75a2.5 2.5 0 0 0-2.5-2.5Z",stroke:"currentColor",strokeWidth:"1.25"}),h("path",{d:"M10 13.958a1.042 1.042 0 1 0 0-2.083 1.042 1.042 0 0 0 0 2.083Z",stroke:"currentColor",strokeWidth:"1.25"}),h("mask",{id:"UnlockedIcon",style:{maskType:"alpha"},maskUnits:"userSpaceOnUse",x:6,y:1,width:9,height:9,children:h("path",{stroke:"none",d:"M6.399 9.561V5.175c0-.93.401-1.823 1.116-2.48a3.981 3.981 0 0 1 2.693-1.028c1.01 0 1.98.37 2.694 1.027.715.658 1.116 1.55 1.116 2.481",fill:"#fff"})}),h("g",{mask:"url(#UnlockedIcon)",children:h("path",{stroke:"none",d:"M5.149 9.561v1.25h2.5v-1.25h-2.5Zm5.06-7.894V.417v1.25Zm2.559 3.508v1.25h2.5v-1.25h-2.5ZM7.648 8.51V5.175h-2.5V8.51h2.5Zm0-3.334c0-.564.243-1.128.713-1.561L6.668 1.775c-.959.883-1.52 2.104-1.52 3.4h2.5Zm.713-1.561a2.732 2.732 0 0 1 1.847-.697v-2.5c-1.31 0-2.585.478-3.54 1.358L8.36 3.614Zm1.847-.697c.71 0 1.374.26 1.847.697l1.694-1.839a5.231 5.231 0 0 0-3.54-1.358v2.5Zm1.847.697c.47.433.713.997.713 1.561h2.5c0-1.296-.56-2.517-1.52-3.4l-1.693 1.839Z",fill:"currentColor"})})]}),pe),Fa=_(O("g",{strokeWidth:"1.25",children:[h("path",{d:"M13.542 8.542H6.458a2.5 2.5 0 0 0-2.5 2.5v3.75a2.5 2.5 0 0 0 2.5 2.5h7.084a2.5 2.5 0 0 0 2.5-2.5v-3.75a2.5 2.5 0 0 0-2.5-2.5Z"}),h("path",{d:"M10 13.958a1.042 1.042 0 1 0 0-2.083 1.042 1.042 0 0 0 0 2.083Z"}),h("path",{d:"M6.667 8.333V5.417C6.667 3.806 8.159 2.5 10 2.5c1.841 0 3.333 1.306 3.333 2.917v2.916"})]}),pe),p1=_(O(De,{children:[h("path",{d:"M38.5 83.5c-14-2-17.833-10.473-21-22.5C14.333 48.984 12 22 12 12.5",stroke:"currentColor",strokeWidth:2,strokeLinecap:"round"}),h("path",{fillRule:"evenodd",clipRule:"evenodd",d:"m12.005 10.478 7.905 14.423L6 25.75l6.005-15.273Z",fill:"currentColor"}),h("path",{d:"M12.005 10.478c1.92 3.495 3.838 7 7.905 14.423m-7.905-14.423c3.11 5.683 6.23 11.368 7.905 14.423m0 0c-3.68.226-7.35.455-13.91.85m13.91-.85c-5.279.33-10.566.647-13.91.85m0 0c1.936-4.931 3.882-9.86 6.005-15.273M6 25.75c2.069-5.257 4.135-10.505 6.005-15.272",stroke:"currentColor",strokeWidth:2,strokeLinecap:"round"})]}),{width:41,height:94,fill:"none"}),u1=_(O(De,{children:[h("path",{d:"M18.026 1.232c-5.268 13.125-5.548 33.555 3.285 42.311 8.823 8.75 33.31 12.304 42.422 13.523",stroke:"currentColor",strokeWidth:2,strokeLinecap:"round"}),h("path",{fillRule:"evenodd",clipRule:"evenodd",d:"m72.181 59.247-13.058-10-2.948 13.62 16.006-3.62Z",fill:"currentColor"}),h("path",{d:"M72.181 59.247c-3.163-2.429-6.337-4.856-13.058-10m13.058 10c-5.145-3.936-10.292-7.882-13.058-10m0 0c-.78 3.603-1.563 7.196-2.948 13.62m2.948-13.62c-1.126 5.168-2.24 10.346-2.948 13.62m0 0c5.168-1.166 10.334-2.343 16.006-3.62m-16.006 3.62c5.51-1.248 11.01-2.495 16.006-3.62",stroke:"currentColor",strokeWidth:2,strokeLinecap:"round"})]}),{width:85,height:71,fill:"none"}),g1=_(O(De,{children:[h("path",{d:"M1 77c14-2 31.833-11.973 35-24 3.167-12.016-6-35-9.5-43.5",stroke:"currentColor",strokeWidth:2,strokeLinecap:"round"}),h("path",{fillRule:"evenodd",clipRule:"evenodd",d:"m24.165 1.093-2.132 16.309 13.27-4.258-11.138-12.05Z",fill:"currentColor"}),h("path",{d:"M24.165 1.093c-.522 3.953-1.037 7.916-2.132 16.309m2.131-16.309c-.835 6.424-1.68 12.854-2.13 16.308m0 0c3.51-1.125 7.013-2.243 13.27-4.257m-13.27 4.257c5.038-1.608 10.08-3.232 13.27-4.257m0 0c-3.595-3.892-7.197-7.777-11.14-12.05m11.14 12.05c-3.837-4.148-7.667-8.287-11.14-12.05",stroke:"currentColor",strokeWidth:2,strokeLinecap:"round"})]}),{width:38,height:78,fill:"none"}),fL=_(h("g",{fill:"currentColor",children:h("path",{d:"M39.9 32.889a.326.326 0 0 0-.279-.056c-2.094-3.083-4.774-6-7.343-8.833l-.419-.472a.212.212 0 0 0-.056-.139.586.586 0 0 0-.167-.111l-.084-.083-.056-.056c-.084-.167-.28-.278-.475-.167-.782.39-1.507.973-2.206 1.528-.92.722-1.842 1.445-2.708 2.25a8.405 8.405 0 0 0-.977 1.028c-.14.194-.028.361.14.444-.615.611-1.23 1.223-1.843 1.861a.315.315 0 0 0-.084.223c0 .083.056.166.111.194l1.09.833v.028c1.535 1.528 4.244 3.611 7.12 5.861.418.334.865.667 1.284 1 .195.223.39.473.558.695.084.11.28.139.391.055.056.056.14.111.196.167a.398.398 0 0 0 .167.056.255.255 0 0 0 .224-.111.394.394 0 0 0 .055-.167c.029 0 .028.028.056.028a.318.318 0 0 0 .224-.084l5.082-5.528a.309.309 0 0 0 0-.444Zm-14.63-1.917a.485.485 0 0 0 .111.14c.586.5 1.2 1 1.843 1.555l-2.569-1.945-.251-.166c-.056-.028-.112-.084-.168-.111l-.195-.167.056-.056.055-.055.112-.111c.866-.861 2.346-2.306 3.1-3.028-.81.805-2.43 3.167-2.095 3.944Zm8.767 6.89-2.122-1.612a44.713 44.713 0 0 0-2.625-2.5c1.145.861 2.122 1.611 2.262 1.75 1.117.972 1.06.806 1.815 1.445l.921.666a1.06 1.06 0 0 1-.251.25Zm.558.416-.056-.028c.084-.055.168-.111.252-.194l-.196.222ZM1.089 5.75c.055.361.14.722.195 1.056.335 1.833.67 3.5 1.284 4.75l.252.944c.084.361.223.806.363.917 1.424 1.25 3.602 3.11 5.947 4.889a.295.295 0 0 0 .363 0s0 .027.028.027a.254.254 0 0 0 .196.084.318.318 0 0 0 .223-.084c2.988-3.305 5.221-6.027 6.813-8.305.112-.111.14-.278.14-.417.111-.111.195-.25.307-.333.111-.111.111-.306 0-.39l-.028-.027c0-.055-.028-.139-.084-.167-.698-.666-1.2-1.138-1.731-1.638-.922-.862-1.871-1.75-3.881-3.75l-.028-.028c-.028-.028-.056-.056-.112-.056-.558-.194-1.703-.389-3.127-.639C6.087 2.223 3.21 1.723.614.944c0 0-.168 0-.196.028l-.083.084c-.028.027-.056.055-.224.11h.056-.056c.028.167.028.278.084.473 0 .055.112.5.112.555l.782 3.556Zm15.496 3.278-.335-.334c.084.112.196.195.335.334Zm-3.546 4.666-.056.056c0-.028.028-.056.056-.056Zm-2.038-10c.168.167.866.834 1.033.973-.726-.334-2.54-1.167-3.379-1.445.838.167 1.983.334 2.346.472ZM1.424 2.306c.419.722.754 3.222 1.089 5.666-.196-.778-.335-1.555-.503-2.278-.251-1.277-.503-2.416-.838-3.416.056 0 .14 0 .252.028Zm-.168-.584c-.112 0-.223-.028-.307-.028 0-.027 0-.055-.028-.055.14 0 .223.028.335.083Zm-1.089.222c0-.027 0-.027 0 0ZM39.453 1.333c.028-.11-.558-.61-.363-.639.42-.027.42-.666 0-.666-.558.028-1.144.166-1.675.25-.977.194-1.982.389-2.96.61-2.205.473-4.383.973-6.561 1.557-.67.194-1.424.333-2.066.666-.224.111-.196.333-.084.472-.056.028-.084.028-.14.056-.195.028-.363.056-.558.083-.168.028-.252.167-.224.334 0 .027.028.083.028.11-1.173 1.556-2.485 3.195-3.909 4.945-1.396 1.611-2.876 3.306-4.356 5.056-4.719 5.5-10.052 11.75-15.943 17.25a.268.268 0 0 0 0 .389c.028.027.056.055.084.055-.084.084-.168.14-.252.222-.056.056-.084.111-.084.167a.605.605 0 0 0-.111.139c-.112.111-.112.305.028.389.111.11.307.11.39-.028.029-.028.029-.056.056-.056a.44.44 0 0 1 .615 0c.335.362.67.723.977 1.028l-.698-.583c-.112-.111-.307-.083-.39.028-.113.11-.085.305.027.389l7.427 6.194c.056.056.112.056.196.056s.14-.028.195-.084l.168-.166c.028.027.083.027.111.027.084 0 .14-.027.196-.083 10.052-10.055 18.15-17.639 27.42-24.417.083-.055.111-.166.111-.25.112 0 .196-.083.251-.194 1.704-5.194 2.039-9.806 2.15-12.083v-.028c0-.028.028-.056.028-.083.028-.056.028-.084.028-.084a1.626 1.626 0 0 0-.111-1.028ZM21.472 9.5c.446-.5.893-1.028 1.34-1.5-2.876 3.778-7.65 9.583-14.408 16.5 4.607-5.083 9.242-10.333 13.068-15ZM5.193 35.778h.084-.084Zm3.462 3.194c-.027-.028-.027-.028 0-.028v.028Zm4.16-3.583c.224-.25.448-.472.699-.722 0 0 0 .027.028.027-.252.223-.475.445-.726.695Zm1.146-1.111c.14-.14.279-.334.446-.5l.028-.028c1.648-1.694 3.351-3.389 5.082-5.111l.028-.028c.419-.333.921-.694 1.368-1.028a379.003 379.003 0 0 0-6.952 6.695ZM24.794 6.472c-.921 1.195-1.954 2.778-2.82 4.028-2.736 3.944-11.532 13.583-11.727 13.75a1976.983 1976.983 0 0 1-8.042 7.639l-.167.167c-.14-.167-.14-.417.028-.556C14.49 19.861 22.03 10.167 25.074 5.917c-.084.194-.14.36-.28.555Zm4.83 5.695c-1.116-.64-1.646-1.64-1.34-2.611l.084-.334c.028-.083.084-.194.14-.277.307-.5.754-.917 1.257-1.167.027 0 .055 0 .083-.028-.028-.056-.028-.139-.028-.222.028-.167.14-.278.335-.278.335 0 1.369.306 1.76.639.111.083.223.194.335.305.14.167.363.445.474.667.056.028.112.306.196.445.056.222.111.472.084.694-.028.028 0 .194-.028.194a2.668 2.668 0 0 1-.363 1.028c-.028.028-.028.056-.056.084l-.028.027c-.14.223-.335.417-.53.556-.643.444-1.369.583-2.095.389 0 0-.195-.084-.28-.111Zm8.154-.834a39.098 39.098 0 0 1-.893 3.167c0 .028-.028.083 0 .111-.056 0-.084.028-.14.056-2.206 1.61-4.356 3.305-6.506 5.028 1.843-1.64 3.686-3.306 5.613-4.945.558-.5.949-1.139 1.06-1.861l.28-1.667v-.055c.14-.334.67-.195.586.166Z",fill:"currentColor"})}),{width:40,height:40,fill:"none"}),h1=_(O("g",{stroke:"currentColor",strokeLinecap:"round",strokeLinejoin:"round",children:[h("path",{stroke:"none",d:"M0 0h24v24H0z",fill:"none"}),h("path",{d:"M6 6l4.153 11.793a0.365 .365 0 0 0 .331 .207a0.366 .366 0 0 0 .332 -.207l2.184 -4.793l4.787 -1.994a0.355 .355 0 0 0 .213 -.323a0.355 .355 0 0 0 -.213 -.323l-11.787 -4.36z"}),h("path",{d:"M13.5 13.5l4.5 4.5"})]}),{fill:"none",width:22,height:22,strokeWidth:1.25}),f1=_(O("g",{strokeWidth:"1.5",children:[h("path",{stroke:"none",d:"M0 0h24v24H0z",fill:"none"}),h("rect",{x:"4",y:"4",width:"16",height:"16",rx:"2"})]}),q),b1=_(O("g",{strokeWidth:"1.5",children:[h("path",{stroke:"none",d:"M0 0h24v24H0z",fill:"none"}),h("path",{d:"M10.5 20.4l-6.9 -6.9c-.781 -.781 -.781 -2.219 0 -3l6.9 -6.9c.781 -.781 2.219 -.781 3 0l6.9 6.9c.781 .781 .781 2.219 0 3l-6.9 6.9c-.781 .781 -2.219 .781 -3 0z"})]}),q),x1=_(O("g",{strokeWidth:"1.5",children:[h("path",{stroke:"none",d:"M0 0h24v24H0z",fill:"none"}),h("circle",{cx:"12",cy:"12",r:"9"})]}),q),E1=_(O("g",{strokeWidth:"1.5",children:[h("path",{stroke:"none",d:"M0 0h24v24H0z",fill:"none"}),h("line",{x1:"5",y1:"12",x2:"19",y2:"12"}),h("line",{x1:"15",y1:"16",x2:"19",y2:"12"}),h("line",{x1:"15",y1:"8",x2:"19",y2:"12"})]}),q),y1=_(h("path",{d:"M4.167 10h11.666",strokeWidth:"1.5"}),pe),w1=_(O("g",{strokeWidth:"1.25",children:[h("path",{stroke:"none",d:"M0 0h24v24H0z",fill:"none"}),h("path",{d:"M20 17v-12c0 -1.121 -.879 -2 -2 -2s-2 .879 -2 2v12l2 2l2 -2z"}),h("path",{d:"M16 7h4"}),h("path",{d:"M18 19h-13a2 2 0 1 1 0 -4h4a2 2 0 1 0 0 -4h-3"})]}),q),Ha=_(O("g",{strokeWidth:"1.25",children:[h("path",{clipRule:"evenodd",d:"m7.643 15.69 7.774-7.773a2.357 2.357 0 1 0-3.334-3.334L4.31 12.357a3.333 3.333 0 0 0-.977 2.357v1.953h1.953c.884 0 1.732-.352 2.357-.977Z"}),h("path",{d:"m11.25 5.417 3.333 3.333"})]}),pe),v1=_(O("g",{strokeWidth:"1.5",children:[h("path",{stroke:"none",d:"M0 0h24v24H0z",fill:"none"}),h("line",{x1:"4",y1:"20",x2:"7",y2:"20"}),h("line",{x1:"14",y1:"20",x2:"21",y2:"20"}),h("line",{x1:"6.9",y1:"15",x2:"13.8",y2:"15"}),h("line",{x1:"10.2",y1:"6.3",x2:"16",y2:"20"}),h("polyline",{points:"5 20 11 4 13 4 20 20"})]}),q),T1=_(O("g",{strokeWidth:"1.25",children:[h("path",{d:"M12.5 6.667h.01"}),h("path",{d:"M4.91 2.625h10.18a2.284 2.284 0 0 1 2.285 2.284v10.182a2.284 2.284 0 0 1-2.284 2.284H4.909a2.284 2.284 0 0 1-2.284-2.284V4.909a2.284 2.284 0 0 1 2.284-2.284Z"}),h("path",{d:"m3.333 12.5 3.334-3.333c.773-.745 1.726-.745 2.5 0l4.166 4.166"}),h("path",{d:"m11.667 11.667.833-.834c.774-.744 1.726-.744 2.5 0l1.667 1.667"})]}),pe),C1=_(O("g",{strokeWidth:"1.5",children:[h("path",{stroke:"none",d:"M0 0h24v24H0z",fill:"none"}),h("path",{d:"M19 20h-10.5l-4.21 -4.3a1 1 0 0 1 0 -1.41l10 -10a1 1 0 0 1 1.41 0l5 5a1 1 0 0 1 0 1.41l-9.2 9.3"}),h("path",{d:"M18 13.3l-6.3 -6.3"})]}),q),Gp=_(h("path",{strokeWidth:"1.25",d:"M10 4.167v11.666M4.167 10h11.666"}),pe),Up=_(h("path",{d:"M5 10h10",strokeWidth:"1.25"}),pe),I1=_(O("g",{strokeWidth:1.25,children:[h("path",{stroke:"none",d:"M0 0h24v24H0z",fill:"none"}),h("path",{d:"M21 21l-6 -6"}),h("path",{d:"M3.268 12.043a7.017 7.017 0 0 0 6.634 4.957a7.012 7.012 0 0 0 7.043 -6.131a7 7 0 0 0 -5.314 -7.672a7.021 7.021 0 0 0 -8.241 4.403"}),h("path",{d:"M3 4v4h4"})]}),q),ur=_(h("path",{strokeWidth:"1.25",d:"M3.333 5.833h13.334M8.333 9.167v5M11.667 9.167v5M4.167 5.833l.833 10c0 .92.746 1.667 1.667 1.667h6.666c.92 0 1.667-.746 1.667-1.667l.833-10M7.5 5.833v-2.5c0-.46.373-.833.833-.833h3.334c.46 0 .833.373.833.833v2.5"}),pe),S1=_(O("g",{strokeWidth:"1.25",children:[h("polyline",{points:"12 16 18 10 12 4"}),h("polyline",{points:"8 4 2 10 8 16"})]}),pe),ts=_(O("g",{strokeWidth:"1.25",children:[h("path",{d:"M14.375 6.458H8.958a2.5 2.5 0 0 0-2.5 2.5v5.417a2.5 2.5 0 0 0 2.5 2.5h5.417a2.5 2.5 0 0 0 2.5-2.5V8.958a2.5 2.5 0 0 0-2.5-2.5Z"}),h("path",{clipRule:"evenodd",d:"M11.667 3.125c.517 0 .986.21 1.325.55.34.338.55.807.55 1.325v1.458H8.333c-.485 0-.927.185-1.26.487-.343.312-.57.75-.609 1.24l-.005 5.357H5a1.87 1.87 0 0 1-1.326-.55 1.87 1.87 0 0 1-.549-1.325V5c0-.518.21-.987.55-1.326.338-.34.807-.549 1.325-.549h6.667Z"})]}),pe),os=_(h("path",{clipRule:"evenodd",d:"M10 2.5h.328a6.25 6.25 0 0 0 6.6 10.372A7.5 7.5 0 1 1 10 2.493V2.5Z",stroke:"currentColor"}),pe),rs=_(h("g",{stroke:"currentColor",strokeLinejoin:"round",children:h("path",{d:"M10 12.5a2.5 2.5 0 1 0 0-5 2.5 2.5 0 0 0 0 5ZM10 4.167V2.5M14.167 5.833l1.166-1.166M15.833 10H17.5M14.167 14.167l1.166 1.166M10 15.833V17.5M5.833 14.167l-1.166 1.166M5 10H3.333M5.833 5.833 4.667 4.667"})}),{...pe,strokeWidth:1.5}),zc=_(O("g",{strokeWidth:"1.5",children:[h("path",{stroke:"none",d:"M0 0h24v24H0z",fill:"none"}),h("line",{x1:"4",y1:"6",x2:"20",y2:"6"}),h("line",{x1:"4",y1:"12",x2:"20",y2:"12"}),h("line",{x1:"4",y1:"18",x2:"20",y2:"18"})]}),q),Li=_(h("path",{strokeWidth:"1.25",d:"M3.333 14.167v1.666c0 .92.747 1.667 1.667 1.667h10c.92 0 1.667-.746 1.667-1.667v-1.666M5.833 9.167 10 13.333l4.167-4.166M10 3.333v10"}),pe),za=_(O("g",{strokeWidth:"1.5",children:[h("path",{stroke:"none",d:"M0 0h24v24H0z",fill:"none"}),h("circle",{cx:"12",cy:"12",r:"9"}),h("line",{x1:"12",y1:"17",x2:"12",y2:"17.01"}),h("path",{d:"M12 13.5a1.5 1.5 0 0 1 1 -1.5a2.6 2.6 0 1 0 -3 -4"})]}),q),k1=_(O("g",{strokeWidth:"1.25",children:[h("path",{stroke:"none",d:"M0 0h24v24H0z",fill:"none"}),h("circle",{cx:"12",cy:"12",r:"9"}),h("line",{x1:"12",y1:"17",x2:"12",y2:"17.01"}),h("path",{d:"M12 13.5a1.5 1.5 0 0 1 1 -1.5a2.6 2.6 0 1 0 -3 -4"})]}),q),Wp=_(h("path",{strokeWidth:"1.25",d:"M9.167 5.833H5.833c-1.254 0-2.5 1.282-2.5 2.5v5.834c0 1.283 1.252 2.5 2.5 2.5h5.834c1.251 0 2.5-1.25 2.5-2.5v-3.334M8.333 11.667l8.334-8.334M12.5 3.333h4.167V7.5"}),pe),Gc=_(h("path",{d:"M7.5 15.833c-3.583 1.167-3.583-2.083-5-2.5m10 4.167v-2.917c0-.833.083-1.166-.417-1.666 2.334-.25 4.584-1.167 4.584-5a3.833 3.833 0 0 0-1.084-2.667 3.5 3.5 0 0 0-.083-2.667s-.917-.25-2.917 1.084a10.25 10.25 0 0 0-5.166 0C5.417 2.333 4.5 2.583 4.5 2.583a3.5 3.5 0 0 0-.083 2.667 3.833 3.833 0 0 0-1.084 2.667c0 3.833 2.25 4.75 4.584 5-.5.5-.5 1-.417 1.666V17.5",strokeWidth:"1.25"}),pe),A1=_(O("g",{strokeWidth:"1.25",children:[h("path",{d:"M7.5 10.833a.833.833 0 1 0 0-1.666.833.833 0 0 0 0 1.666ZM12.5 10.833a.833.833 0 1 0 0-1.666.833.833 0 0 0 0 1.666ZM6.25 6.25c2.917-.833 4.583-.833 7.5 0M5.833 13.75c2.917.833 5.417.833 8.334 0"}),h("path",{d:"M12.917 14.167c0 .833 1.25 2.5 1.666 2.5 1.25 0 2.361-1.39 2.917-2.5.556-1.39.417-4.861-1.25-9.584-1.214-.846-2.5-1.116-3.75-1.25l-.833 2.084M7.083 14.167c0 .833-1.13 2.5-1.526 2.5-1.191 0-2.249-1.39-2.778-2.5-.529-1.39-.397-4.861 1.19-9.584 1.157-.846 2.318-1.116 3.531-1.25l.833 2.084"})]}),pe),M1=_(O("g",{strokeWidth:"1.25",children:[h("path",{stroke:"none",d:"M0 0h24v24H0z",fill:"none"}),h("path",{d:"M4 4l11.733 16h4.267l-11.733 -16z"}),h("path",{d:"M4 20l6.768 -6.768m2.46 -2.46l6.772 -6.772"})]}),q),L1=_(h("polyline",{fill:"none",stroke:"currentColor",points:"20 6 9 17 4 12"}),{width:24,height:24}),ns=_(O("g",{strokeWidth:"1.25",children:[h("path",{d:"M8.333 11.667a2.917 2.917 0 0 0 4.167 0l3.333-3.334a2.946 2.946 0 1 0-4.166-4.166l-.417.416"}),h("path",{d:"M11.667 8.333a2.917 2.917 0 0 0-4.167 0l-3.333 3.334a2.946 2.946 0 0 0 4.166 4.166l.417-.416"})]}),pe),_1=_("M433.941 129.941l-83.882-83.882A48 48 0 0 0 316.118 32H48C21.49 32 0 53.49 0 80v352c0 26.51 21.49 48 48 48h352c26.51 0 48-21.49 48-48V163.882a48 48 0 0 0-14.059-33.941zM224 416c-35.346 0-64-28.654-64-64 0-35.346 28.654-64 64-64s64 28.654 64 64c0 35.346-28.654 64-64 64zm96-304.52V212c0 6.627-5.373 12-12 12H76c-6.627 0-12-5.373-12-12V108c0-6.627 5.373-12 12-12h228.52c3.183 0 6.235 1.264 8.485 3.515l3.48 3.48A11.996 11.996 0 0 1 320 111.48z",{width:448,height:512}),P1=_("M252 54L203 8a28 27 0 00-20-8H28C12 0 0 12 0 27v195c0 15 12 26 28 26h204c15 0 28-11 28-26V73a28 27 0 00-8-19zM130 213c-21 0-37-16-37-36 0-19 16-35 37-35 20 0 37 16 37 35 0 20-17 36-37 36zm56-169v56c0 4-4 6-7 6H44c-4 0-7-2-7-6V42c0-4 3-7 7-7h133l4 2 3 2a7 7 0 012 5z M296 201l87 95-188 205-78 9c-10 1-19-8-18-20l9-84zm141-14l-41-44a31 31 0 00-46 0l-38 41 87 95 38-42c13-14 13-36 0-50z",{width:448,height:512}),Ga=_(h("path",{d:"m9.257 6.351.183.183H15.819c.34 0 .727.182 1.051.506.323.323.505.708.505 1.05v5.819c0 .316-.183.7-.52 1.035-.337.338-.723.522-1.037.522H4.182c-.352 0-.74-.181-1.058-.5-.318-.318-.499-.705-.499-1.057V5.182c0-.351.181-.736.5-1.054.32-.321.71-.503 1.057-.503H6.53l2.726 2.726Z",strokeWidth:"1.25"}),pe),bL=_("M384 112v352c0 26.51-21.49 48-48 48H48c-26.51 0-48-21.49-48-48V112c0-26.51 21.49-48 48-48h80c0-35.29 28.71-64 64-64s64 28.71 64 64h80c26.51 0 48 21.49 48 48zM192 40c-13.255 0-24 10.745-24 24s10.745 24 24 24 24-10.745 24-24-10.745-24-24-24m96 114v-20a6 6 0 0 0-6-6H102a6 6 0 0 0-6 6v20a6 6 0 0 0 6 6h180a6 6 0 0 0 6-6z",{width:384,height:512}),D1=_("M204.3 5C104.9 24.4 24.8 104.3 5.2 203.4c-37 187 131.7 326.4 258.8 306.7 41.2-6.4 61.4-54.6 42.5-91.7-23.1-45.4 9.9-98.4 60.9-98.4h79.7c35.8 0 64.8-29.6 64.9-65.3C511.5 97.1 368.1-26.9 204.3 5zM96 320c-17.7 0-32-14.3-32-32s14.3-32 32-32 32 14.3 32 32-14.3 32-32 32zm32-128c-17.7 0-32-14.3-32-32s14.3-32 32-32 32 14.3 32 32-14.3 32-32 32zm128-64c-17.7 0-32-14.3-32-32s14.3-32 32-32 32 14.3 32 32-14.3 32-32 32zm128 64c-17.7 0-32-14.3-32-32s14.3-32 32-32 32 14.3 32 32-14.3 32-32 32z"),Uc=_(O("g",{strokeWidth:1.25,children:[h("path",{stroke:"none",d:"M0 0h24v24H0z",fill:"none"}),h("path",{d:"M5 16l1.465 1.638a2 2 0 1 1 -3.015 .099l1.55 -1.737z"}),h("path",{d:"M13.737 9.737c2.299 -2.3 3.23 -5.095 2.081 -6.245c-1.15 -1.15 -3.945 -.217 -6.244 2.082c-2.3 2.299 -3.231 5.095 -2.082 6.244c1.15 1.15 3.946 .218 6.245 -2.081z"}),h("path",{d:"M7.492 11.818c.362 .362 .768 .676 1.208 .934l6.895 4.047c1.078 .557 2.255 -.075 3.692 -1.512c1.437 -1.437 2.07 -2.614 1.512 -3.692c-.372 -.718 -1.72 -3.017 -4.047 -6.895a6.015 6.015 0 0 0 -.934 -1.208"})]}),q),Wc=_(O("g",{strokeWidth:"1.25",children:[h("path",{stroke:"none",d:"M0 0h24v24H0z",fill:"none"}),h("path",{d:"M15 8h.01"}),h("path",{d:"M12 20h-5a3 3 0 0 1 -3 -3v-10a3 3 0 0 1 3 -3h10a3 3 0 0 1 3 3v5"}),h("path",{d:"M4 15l4 -4c.928 -.893 2.072 -.893 3 0l4 4"}),h("path",{d:"M14 14l1 -1c.617 -.593 1.328 -.793 2.009 -.598"}),h("path",{d:"M19 16v6"}),h("path",{d:"M22 19l-3 3l-3 -3"})]}),q),R1=_("M216 0h80c13.3 0 24 10.7 24 24v168h87.7c17.8 0 26.7 21.5 14.1 34.1L269.7 378.3c-7.5 7.5-19.8 7.5-27.3 0L90.1 226.1c-12.6-12.6-3.7-34.1 14.1-34.1H192V24c0-13.3 10.7-24 24-24zm296 376v112c0 13.3-10.7 24-24 24H24c-13.3 0-24-10.7-24-24V376c0-13.3 10.7-24 24-24h146.7l49 49c20.1 20.1 52.5 20.1 72.6 0l49-49H488c13.3 0 24 10.7 24 24zm-124 88c0-11-9-20-20-20s-20 9-20 20 9 20 20 20 20-9 20-20zm64 0c0-11-9-20-20-20s-20 9-20 20 9 20 20 20 20-9 20-20z",{width:512,height:512}),xL=_("M416 208H272V64c0-17.67-14.33-32-32-32h-32c-17.67 0-32 14.33-32 32v144H32c-17.67 0-32 14.33-32 32v32c0 17.67 14.33 32 32 32h144v144c0 17.67 14.33 32 32 32h32c17.67 0 32-14.33 32-32V304h144c17.67 0 32-14.33 32-32v-32c0-17.67-14.33-32-32-32z",{width:448,height:512}),EL=_("M416 208H32c-17.67 0-32 14.33-32 32v32c0 17.67 14.33 32 32 32h384c17.67 0 32-14.33 32-32v-32c0-17.67-14.33-32-32-32z",{width:448,height:512}),N1=_("M173.898 439.404l-166.4-166.4c-9.997-9.997-9.997-26.206 0-36.204l36.203-36.204c9.997-9.998 26.207-9.998 36.204 0L192 312.69 432.095 72.596c9.997-9.997 26.207-9.997 36.204 0l36.203 36.204c9.997 9.997 9.997 26.206 0 36.204l-294.4 294.401c-9.998 9.997-26.207 9.997-36.204-.001z"),yL=_("M16 132h416c8.837 0 16-7.163 16-16V76c0-8.837-7.163-16-16-16H16C7.163 60 0 67.163 0 76v40c0 8.837 7.163 16 16 16zm0 160h416c8.837 0 16-7.163 16-16v-40c0-8.837-7.163-16-16-16H16c-8.837 0-16 7.163-16 16v40c0 8.837 7.163 16 16 16zm0 160h416c8.837 0 16-7.163 16-16v-40c0-8.837-7.163-16-16-16H16c-8.837 0-16 7.163-16 16v40c0 8.837 7.163 16 16 16z"),Vp=_(h("path",{d:"M7.5 10.833 4.167 7.5 7.5 4.167M4.167 7.5h9.166a3.333 3.333 0 0 1 0 6.667H12.5",strokeWidth:"1.25"}),pe),Yp=_(h("path",{d:"M12.5 10.833 15.833 7.5 12.5 4.167M15.833 7.5H6.667a3.333 3.333 0 1 0 0 6.667H7.5",strokeWidth:"1.25"}),pe),O1=_("M504 256c0 136.997-111.043 248-248 248S8 392.997 8 256C8 119.083 119.043 8 256 8s248 111.083 248 248zM262.655 90c-54.497 0-89.255 22.957-116.549 63.758-3.536 5.286-2.353 12.415 2.715 16.258l34.699 26.31c5.205 3.947 12.621 3.008 16.665-2.122 17.864-22.658 30.113-35.797 57.303-35.797 20.429 0 45.698 13.148 45.698 32.958 0 14.976-12.363 22.667-32.534 33.976C247.128 238.528 216 254.941 216 296v4c0 6.627 5.373 12 12 12h56c6.627 0 12-5.373 12-12v-1.333c0-28.462 83.186-29.647 83.186-106.667 0-58.002-60.165-102-116.531-102zM256 338c-25.365 0-46 20.635-46 46 0 25.364 20.635 46 46 46s46-20.636 46-46c0-25.365-20.635-46-46-46z",{mirror:!0}),B1=_(h("path",{d:"M5 12.5a2.5 2.5 0 1 0 0-5 2.5 2.5 0 0 0 0 5ZM15 7.5a2.5 2.5 0 1 0 0-5 2.5 2.5 0 0 0 0 5ZM15 17.5a2.5 2.5 0 1 0 0-5 2.5 2.5 0 0 0 0 5ZM7.25 8.917l5.5-2.834M7.25 11.083l5.5 2.834",strokeWidth:"1.5"}),pe),wL=_("M256 32c14.2 0 27.3 7.5 34.5 19.8l216 368c7.3 12.4 7.3 27.7 .2 40.1S486.3 480 472 480H40c-14.3 0-27.6-7.7-34.7-20.1s-7-27.8 .2-40.1l216-368C228.7 39.5 241.8 32 256 32zm0 128c-13.3 0-24 10.7-24 24V296c0 13.3 10.7 24 24 24s24-10.7 24-24V184c0-13.3-10.7-24-24-24zm32 224a32 32 0 1 0 -64 0 32 32 0 1 0 64 0z"),vL=_("M16 5l-1.42 1.42-1.59-1.59V16h-1.98V4.83L9.42 6.42 8 5l4-4 4 4zm4 5v11c0 1.1-.9 2-2 2H6c-1.11 0-2-.9-2-2V10c0-1.11.89-2 2-2h3v2H6v11h12V10h-3V8h3c1.1 0 2 .89 2 2z",{width:24,height:24}),TL=_(O("g",{strokeWidth:1.25,children:[h("path",{stroke:"none",d:"M0 0h24v24H0z",fill:"none"}),h("path",{d:"M8 9h-1a2 2 0 0 0 -2 2v8a2 2 0 0 0 2 2h10a2 2 0 0 0 2 -2v-8a2 2 0 0 0 -2 -2h-1"}),h("path",{d:"M12 14v-11"}),h("path",{d:"M9 6l3 -3l3 3"})]}),q),CL=_(O(De,{children:[h("path",{fill:"currentColor",d:"M40 5.6v6.1l-4.1.7c-8.9 1.4-16.5 6.9-20.6 15C13 32 10.9 43 12.4 43c.4 0 2.4-1.3 4.4-3 5-3.9 12.1-7 18.2-7.7l5-.6v12.8l11.2-11.3L62.5 22 51.2 10.8 40-.5v6.1zm10.2 22.6L44 34.5v-6.8l-6.9.6c-3.9.3-9.8 1.7-13.2 3.1-3.5 1.4-6.5 2.4-6.7 2.2-.9-1 3-7.5 6.4-10.8C28 18.6 34.4 16 40.1 16c3.7 0 3.9-.1 3.9-3.2V9.5l6.2 6.3 6.3 6.2-6.3 6.2z"}),h("path",{stroke:"currentColor",fill:"currentColor",d:"M0 36v20h48v-6.2c0-6 0-6.1-2-4.3-1.1 1-2 2.9-2 4.2V52H4V34c0-17.3-.1-18-2-18s-2 .7-2 20z"})]}),{width:64,height:64}),IL=_(h("path",{stroke:"currentColor",strokeWidth:"40",fill:"currentColor",d:"M148 560a318 318 0 0 0 522 110 316 316 0 0 0 0-450 316 316 0 0 0-450 0c-11 11-21 22-30 34v4h47c25 0 46 21 46 46s-21 45-46 45H90c-13 0-25-6-33-14-9-9-14-20-14-33V156c0-25 20-45 45-45s45 20 45 45v32l1 1a401 401 0 0 1 623 509l212 212a42 42 0 0 1-59 59L698 757A401 401 0 0 1 65 570a42 42 0 0 1 83-10z"}),{width:1024}),Kp=_(O(De,{children:[O("g",{clipPath:"url(#a)",stroke:"currentColor",strokeWidth:"1.25",strokeLinecap:"round",strokeLinejoin:"round",children:[h("path",{d:"M13.889 4.167H8.333c-.767 0-1.389.622-1.389 1.389v5.555c0 .767.622 1.389 1.39 1.389h5.555c.767 0 1.389-.622 1.389-1.389V5.556c0-.767-.622-1.39-1.39-1.39Z",fill:"currentColor"}),h("path",{d:"M12.5 12.5v1.389a1.389 1.389 0 0 1-1.389 1.389H5.556a1.389 1.389 0 0 1-1.39-1.39V8.334a1.389 1.389 0 0 1 1.39-1.389h1.388"})]}),h("defs",{children:h("clipPath",{id:"a",children:h("path",{fill:"#fff",d:"M0 0h20v20H0z"})})})]}),pe),$p=_(O(De,{children:[O("g",{clipPath:"url(#a)",stroke:"currentColor",strokeWidth:"1.25",strokeLinecap:"round",strokeLinejoin:"round",children:[h("path",{fillRule:"evenodd",clipRule:"evenodd",d:"M6.944 12.5H12.5v1.389a1.389 1.389 0 0 1-1.389 1.389H5.556a1.389 1.389 0 0 1-1.39-1.39V8.334a1.389 1.389 0 0 1 1.39-1.389h1.388",fill:"currentColor"}),h("path",{d:"M13.889 4.167H8.333c-.767 0-1.389.621-1.389 1.389v5.555c0 .767.622 1.389 1.39 1.389h5.555c.767 0 1.389-.622 1.389-1.389V5.556c0-.768-.622-1.39-1.39-1.39Z"})]}),h("defs",{children:h("clipPath",{id:"a",children:h("path",{fill:"#fff",d:"M0 0h20v20H0z"})})})]}),pe),Xp=_(O(De,{children:[O("g",{clipPath:"url(#a)",stroke:"currentColor",strokeWidth:"1.25",children:[h("path",{d:"M8.775 6.458h2.45a2.316 2.316 0 0 1 2.317 2.316v2.452a2.316 2.316 0 0 1-2.316 2.316H8.774a2.316 2.316 0 0 1-2.317-2.316V8.774a2.316 2.316 0 0 1 2.317-2.316Z",fill:"currentColor"}),h("path",{d:"M5.441 9.792h2.451a2.316 2.316 0 0 1 2.316 2.316v2.45a2.316 2.316 0 0 1-2.316 2.317h-2.45a2.316 2.316 0 0 1-2.317-2.316v-2.451a2.316 2.316 0 0 1 2.316-2.316ZM12.108 3.125h2.45a2.316 2.316 0 0 1 2.317 2.316v2.451a2.316 2.316 0 0 1-2.316 2.316h-2.451a2.316 2.316 0 0 1-2.316-2.316v-2.45a2.316 2.316 0 0 1 2.316-2.317Z"})]}),h("defs",{children:h("clipPath",{id:"a",children:h("path",{fill:"#fff",d:"M0 0h20v20H0z"})})})]}),pe),Zp=_(O(De,{children:[O("g",{clipPath:"url(#a)",children:[h("path",{d:"M5.441 9.792h2.451a2.316 2.316 0 0 1 2.316 2.316v2.45a2.316 2.316 0 0 1-2.316 2.317h-2.45a2.316 2.316 0 0 1-2.317-2.316v-2.451a2.316 2.316 0 0 1 2.316-2.316Z",stroke:"currentColor",strokeWidth:"1.25"}),h("path",{d:"M5.441 9.792h2.451a2.316 2.316 0 0 1 2.316 2.316v2.45a2.316 2.316 0 0 1-2.316 2.317h-2.45a2.316 2.316 0 0 1-2.317-2.316v-2.451a2.316 2.316 0 0 1 2.316-2.316Z",stroke:"currentColor",strokeWidth:"1.25"}),h("mask",{id:"SendToBackIcon",fill:"#fff",children:h("path",{fillRule:"evenodd",clipRule:"evenodd",d:"M9.167 5.833v2.06a2.941 2.941 0 0 0 2.94 2.94h2.06v.393a2.941 2.941 0 0 1-2.941 2.94h-.393v-2.058a2.941 2.941 0 0 0-2.94-2.941h-2.06v-.393a2.941 2.941 0 0 1 2.942-2.94h.392Z"})}),h("path",{fillRule:"evenodd",clipRule:"evenodd",d:"M9.167 5.833v2.06a2.941 2.941 0 0 0 2.94 2.94h2.06v.393a2.941 2.941 0 0 1-2.941 2.94h-.393v-2.058a2.941 2.941 0 0 0-2.94-2.941h-2.06v-.393a2.941 2.941 0 0 1 2.942-2.94h.392Z",fill:"currentColor"}),h("path",{d:"M9.167 5.833h1.25v-1.25h-1.25v1.25Zm5 5h1.25v-1.25h-1.25v1.25Zm-3.334 3.334h-1.25v1.25h1.25v-1.25Zm-5-5h-1.25v1.25h1.25v-1.25Zm2.084-3.334v2.06h2.5v-2.06h-2.5Zm0 2.06a4.191 4.191 0 0 0 4.19 4.19v-2.5a1.691 1.691 0 0 1-1.69-1.69h-2.5Zm4.19 4.19h2.06v-2.5h-2.06v2.5Zm.81-1.25v.393h2.5v-.393h-2.5Zm0 .393c0 .933-.758 1.69-1.691 1.69v2.5a4.191 4.191 0 0 0 4.19-4.19h-2.5Zm-1.691 1.69h-.393v2.5h.393v-2.5Zm.857 1.25v-2.058h-2.5v2.059h2.5Zm0-2.058a4.191 4.191 0 0 0-4.19-4.191v2.5c.933 0 1.69.757 1.69 1.69h2.5Zm-4.19-4.191h-2.06v2.5h2.06v-2.5Zm-.81 1.25v-.393h-2.5v.393h2.5Zm0-.393c0-.934.758-1.69 1.692-1.69v-2.5a4.191 4.191 0 0 0-4.192 4.19h2.5Zm1.692-1.69h.392v-2.5h-.392v2.5Z",fill:"currentColor",mask:"url(#SendToBackIcon)"}),h("path",{d:"M12.108 3.125h2.45a2.316 2.316 0 0 1 2.317 2.316v2.451a2.316 2.316 0 0 1-2.316 2.316h-2.451a2.316 2.316 0 0 1-2.316-2.316v-2.45a2.316 2.316 0 0 1 2.316-2.317Z",stroke:"currentColor",strokeWidth:"1.25"})]}),h("defs",{children:h("clipPath",{id:"a",children:h("path",{fill:"#fff",d:"M0 0h20v20H0z"})})})]}),pe),jp=_(O(De,{children:[O("g",{clipPath:"url(#a)",stroke:"currentColor",strokeWidth:"1.25",children:[h("path",{d:"M3.333 3.333h13.334",strokeLinecap:"round",strokeLinejoin:"round"}),h("path",{d:"M13.542 6.458h-.417c-.92 0-1.667.747-1.667 1.667v7.083c0 .92.746 1.667 1.667 1.667h.417c.92 0 1.666-.746 1.666-1.667V8.125c0-.92-.746-1.667-1.666-1.667ZM6.875 6.458h-.417c-.92 0-1.666.747-1.666 1.667v3.75c0 .92.746 1.667 1.666 1.667h.417c.92 0 1.667-.746 1.667-1.667v-3.75c0-.92-.747-1.667-1.667-1.667Z"})]}),h("defs",{children:h("clipPath",{id:"a",children:h("path",{fill:"#fff",d:"M0 0h20v20H0z"})})})]}),pe),qp=_(O(De,{children:[O("g",{clipPath:"url(#a)",stroke:"currentColor",strokeWidth:"1.25",children:[h("path",{d:"M3.333 16.667h13.334",strokeLinecap:"round",strokeLinejoin:"round"}),h("path",{d:"M6.875 3.125h-.417c-.92 0-1.666.746-1.666 1.667v7.083c0 .92.746 1.667 1.666 1.667h.417c.92 0 1.667-.746 1.667-1.667V4.792c0-.92-.747-1.667-1.667-1.667ZM13.542 5.817h-.417c-.92 0-1.667.747-1.667 1.667v4.391c0 .92.746 1.667 1.667 1.667h.417c.92 0 1.666-.746 1.666-1.667V7.484c0-.92-.746-1.667-1.666-1.667Z"})]}),h("defs",{children:h("clipPath",{id:"a",children:h("path",{fill:"#fff",d:"M0 0h20v20H0z"})})})]}),pe),Jp=_(O(De,{children:[O("g",{clipPath:"url(#a)",stroke:"currentColor",strokeWidth:"1.25",children:[h("path",{d:"M3.333 3.333v13.334",strokeLinecap:"round",strokeLinejoin:"round"}),h("path",{d:"M15.208 4.792H8.125c-.92 0-1.667.746-1.667 1.666v.417c0 .92.747 1.667 1.667 1.667h7.083c.92 0 1.667-.747 1.667-1.667v-.417c0-.92-.746-1.666-1.667-1.666ZM12.516 11.458H8.125c-.92 0-1.667.746-1.667 1.667v.417c0 .92.747 1.666 1.667 1.666h4.391c.92 0 1.667-.746 1.667-1.666v-.417c0-.92-.746-1.667-1.667-1.667Z"})]}),h("defs",{children:h("clipPath",{id:"a",children:h("path",{fill:"#fff",d:"M0 0h20v20H0z"})})})]}),pe),Qp=_(O(De,{children:[O("g",{clipPath:"url(#a)",stroke:"currentColor",strokeWidth:"1.25",children:[h("path",{d:"M16.667 3.333v13.334",strokeLinecap:"round",strokeLinejoin:"round"}),h("path",{d:"M11.875 4.792H4.792c-.92 0-1.667.746-1.667 1.666v.417c0 .92.746 1.667 1.667 1.667h7.083c.92 0 1.667-.747 1.667-1.667v-.417c0-.92-.746-1.666-1.667-1.666ZM11.683 11.458H7.292c-.92 0-1.667.746-1.667 1.667v.417c0 .92.746 1.666 1.667 1.666h4.39c.921 0 1.667-.746 1.667-1.666v-.417c0-.92-.746-1.667-1.666-1.667Z"})]}),h("defs",{children:h("clipPath",{id:"a",children:h("path",{fill:"#fff",d:"M0 0h20v20H0z"})})})]}),pe),F1=_(O(De,{children:[O("g",{clipPath:"url(#a)",stroke:"currentColor",strokeWidth:"1.25",children:[h("path",{d:"M16.667 3.333v13.334M3.333 3.333v13.334",strokeLinecap:"round",strokeLinejoin:"round"}),h("path",{d:"M14.375 10.208v-.416c0-.92-.746-1.667-1.667-1.667H7.292c-.92 0-1.667.746-1.667 1.667v.416c0 .92.746 1.667 1.667 1.667h5.416c.92 0 1.667-.746 1.667-1.667Z"})]}),h("defs",{children:h("clipPath",{id:"a",children:h("path",{fill:"#fff",d:"M0 0h20v20H0z"})})})]}),pe),H1=_(O(De,{children:[O("g",{clipPath:"url(#a)",stroke:"currentColor",strokeWidth:"1.25",children:[h("path",{d:"M3.333 3.333h13.334M3.333 16.667h13.334",strokeLinecap:"round",strokeLinejoin:"round"}),h("path",{d:"M10.208 5.625h-.416c-.92 0-1.667.746-1.667 1.667v5.416c0 .92.746 1.667 1.667 1.667h.416c.92 0 1.667-.746 1.667-1.667V7.292c0-.92-.746-1.667-1.667-1.667Z"})]}),h("defs",{children:h("clipPath",{id:"a",children:h("path",{fill:"#fff",d:"M0 0h20v20H0z"})})})]}),pe),eu=_(O("g",{stroke:"currentColor",strokeWidth:"1.25",children:[h("path",{d:"M1.667 10h2.916",strokeLinecap:"round",strokeLinejoin:"round"}),h("path",{d:"M8.333 10h3.334",strokeLinejoin:"round"}),h("path",{d:"M15.417 10h2.916",strokeLinecap:"round",strokeLinejoin:"round"}),h("path",{d:"M6.875 4.792h-.417c-.92 0-1.666.746-1.666 1.666v7.084c0 .92.746 1.666 1.666 1.666h.417c.92 0 1.667-.746 1.667-1.666V6.458c0-.92-.747-1.666-1.667-1.666ZM13.542 6.458h-.417c-.92 0-1.667.747-1.667 1.667v3.75c0 .92.746 1.667 1.667 1.667h.417c.92 0 1.666-.746 1.666-1.667v-3.75c0-.92-.746-1.667-1.666-1.667Z"})]}),pe),tu=_(O("g",{stroke:"currentColor",strokeWidth:"1.25",children:[h("path",{d:"M10 18.333v-2.916",strokeLinecap:"round",strokeLinejoin:"round"}),h("path",{d:"M10 11.667V8.333",strokeLinejoin:"round"}),h("path",{d:"M10 4.583V1.667",strokeLinecap:"round",strokeLinejoin:"round"}),h("path",{d:"M4.792 13.125v.417c0 .92.746 1.666 1.666 1.666h7.084c.92 0 1.666-.746 1.666-1.666v-.417c0-.92-.746-1.667-1.666-1.667H6.458c-.92 0-1.666.746-1.666 1.667ZM6.458 6.458v.417c0 .92.747 1.667 1.667 1.667h3.75c.92 0 1.667-.747 1.667-1.667v-.417c0-.92-.746-1.666-1.667-1.666h-3.75c-.92 0-1.667.746-1.667 1.666Z"})]}),pe),Vc=_(O("g",{strokeWidth:"1.5",children:[h("path",{stroke:"none",d:"M0 0h24v24H0z",fill:"none"}),h("circle",{cx:"9",cy:"7",r:"4"}),h("path",{d:"M3 21v-2a4 4 0 0 1 4 -4h4a4 4 0 0 1 4 4v2"}),h("path",{d:"M16 3.13a4 4 0 0 1 0 7.75"}),h("path",{d:"M21 21v-2a4 4 0 0 0 -3 -3.85"})]}),q),SL=_("M256 8C119 8 8 119 8 256s111 248 248 248 248-111 248-248S393 8 256 8zm115.7 272l-176 101c-15.8 8.8-35.7-2.5-35.7-21V152c0-18.4 19.8-29.8 35.7-21l176 107c16.4 9.2 16.4 32.9 0 42z"),kL=_("M256 8C119 8 8 119 8 256s111 248 248 248 248-111 248-248S393 8 256 8zm96 328c0 8.8-7.2 16-16 16H176c-8.8 0-16-7.2-16-16V176c0-8.8 7.2-16 16-16h160c8.8 0 16 7.2 16 16v160z"),Yo=_(O(De,{children:[h("g",{clipPath:"url(#a)",stroke:"currentColor",strokeWidth:"1.25",strokeLinecap:"round",strokeLinejoin:"round",children:h("path",{d:"M15 5 5 15M5 5l10 10"})}),h("defs",{children:h("clipPath",{id:"a",children:h("path",{fill:"#fff",d:"M0 0h20v20H0z"})})})]}),pe),AL=_("M464 0c26.51 0 48 21.49 48 48v288c0 26.51-21.49 48-48 48H176c-26.51 0-48-21.49-48-48V48c0-26.51 21.49-48 48-48h288M176 416c-44.112 0-80-35.888-80-80V128H48c-26.51 0-48 21.49-48 48v288c0 26.51 21.49 48 48 48h288c26.51 0 48-21.49 48-48v-48H176z",{mirror:!0}),ML=_("M11.553 22.894a.998.998 0 00.894 0s3.037-1.516 5.465-4.097C19.616 16.987 21 14.663 21 12V5a1 1 0 00-.649-.936l-8-3a.998.998 0 00-.702 0l-8 3A1 1 0 003 5v7c0 2.663 1.384 4.987 3.088 6.797 2.428 2.581 5.465 4.097 5.465 4.097zm-1.303-8.481l6.644-6.644a.856.856 0 111.212 1.212l-7.25 7.25a.856.856 0 01-1.212 0l-3.75-3.75a.856.856 0 111.212-1.212l3.144 3.144z",{width:24}),LL=_("M369.9 97.9L286 14C277 5 264.8-.1 252.1-.1H48C21.5 0 0 21.5 0 48v416c0 26.5 21.5 48 48 48h288c26.5 0 48-21.5 48-48V131.9c0-12.7-5.1-25-14.1-34zM332.1 128H256V51.9l76.1 76.1zM48 464V48h160v104c0 13.3 10.7 24 24 24h104v288H48zm32-48h224V288l-23.5-23.5c-4.7-4.7-12.3-4.7-17 0L176 352l-39.5-39.5c-4.7-4.7-12.3-4.7-17 0L80 352v64zm48-240c-26.5 0-48 21.5-48 48s21.5 48 48 48 48-21.5 48-48-21.5-48-48-48z",{width:384,height:512}),ou=Io.memo(({theme:e})=>_(O(De,{children:[h("path",{d:"M25 26H111V111H25",fill:pr(e)}),h("path",{d:"M25 111C25 80.2068 25 49.4135 25 26M25 26C48.6174 26 72.2348 26 111 26H25ZM25 26C53.3671 26 81.7343 26 111 26H25ZM111 26C111 52.303 111 78.606 111 111V26ZM111 26C111 51.2947 111 76.5893 111 111V26ZM111 111C87.0792 111 63.1585 111 25 111H111ZM111 111C87.4646 111 63.9293 111 25 111H111ZM25 111C25 81.1514 25 51.3028 25 26V111Z",stroke:pr(e),strokeWidth:"2"}),h("path",{d:"M100 100H160V160H100",fill:pr(e)}),h("path",{d:"M100 160C100 144.106 100 128.211 100 100M100 100C117.706 100 135.412 100 160 100H100ZM100 100C114.214 100 128.428 100 160 100H100ZM160 100C160 120.184 160 140.369 160 160V100ZM160 100C160 113.219 160 126.437 160 160V100ZM160 160C145.534 160 131.068 160 100 160H160ZM160 160C143.467 160 126.934 160 100 160H160ZM100 160C100 143.661 100 127.321 100 100V160Z",stroke:pr(e),strokeWidth:"2"}),O("g",{fill:_v(e),stroke:pr(e),strokeWidth:"6",children:[h("rect",{x:"2.5",y:"2.5",width:"30",height:"30"}),h("rect",{x:"2.5",y:"149.5",width:"30",height:"30"}),h("rect",{x:"147.5",y:"149.5",width:"30",height:"30"}),h("rect",{x:"147.5",y:"2.5",width:"30",height:"30"})]})]}),{width:182,height:182,mirror:!0})),ru=Io.memo(({theme:e})=>_(O(De,{children:[h("path",{d:"M25 26H111V111H25",fill:pr(e)}),h("path",{d:"M25 111C25 80.2068 25 49.4135 25 26M25 26C48.6174 26 72.2348 26 111 26H25ZM25 26C53.3671 26 81.7343 26 111 26H25ZM111 26C111 52.303 111 78.606 111 111V26ZM111 26C111 51.2947 111 76.5893 111 111V26ZM111 111C87.0792 111 63.1585 111 25 111H111ZM111 111C87.4646 111 63.9293 111 25 111H111ZM25 111C25 81.1514 25 51.3028 25 26V111Z",stroke:pr(e),strokeWidth:"2"}),h("path",{d:"M100 100H160V160H100",fill:pr(e)}),h("path",{d:"M100 160C100 144.106 100 128.211 100 100M100 100C117.706 100 135.412 100 160 100H100ZM100 100C114.214 100 128.428 100 160 100H100ZM160 100C160 120.184 160 140.369 160 160V100ZM160 100C160 113.219 160 126.437 160 160V100ZM160 160C145.534 160 131.068 160 100 160H160ZM160 160C143.467 160 126.934 160 100 160H160ZM100 160C100 143.661 100 127.321 100 100V160Z",stroke:pr(e),strokeWidth:"2"}),O("g",{fill:_v(e),stroke:pr(e),strokeWidth:"6",children:[h("rect",{x:"2.5",y:"2.5",width:"30",height:"30"}),h("rect",{x:"78.5",y:"149.5",width:"30",height:"30"}),h("rect",{x:"147.5",y:"149.5",width:"30",height:"30"}),h("rect",{x:"147.5",y:"78.5",width:"30",height:"30"}),h("rect",{x:"105.5",y:"2.5",width:"30",height:"30"}),h("rect",{x:"2.5",y:"102.5",width:"30",height:"30"})]})]}),{width:182,height:182,mirror:!0})),z1=_(h("g",{strokeWidth:1.25,children:h("path",{d:"M5.879 2.625h8.242a3.27 3.27 0 0 1 3.254 3.254v8.242a3.27 3.27 0 0 1-3.254 3.254H5.88a3.27 3.27 0 0 1-3.254-3.254V5.88A3.27 3.27 0 0 1 5.88 2.626l-.001-.001ZM4.518 16.118l7.608-12.83m.198 13.934 5.051-9.897M2.778 9.675l9.348-6.387m-7.608 12.83 12.857-8.793"})}),pe),G1=_(O(De,{children:[h("path",{d:"M5.879 2.625h8.242a3.254 3.254 0 0 1 3.254 3.254v8.242a3.254 3.254 0 0 1-3.254 3.254H5.88a3.254 3.254 0 0 1-3.254-3.254V5.88a3.254 3.254 0 0 1 3.254-3.254Z",stroke:"currentColor",strokeWidth:"1.25"}),h("mask",{id:"FillHachureIcon",style:{maskType:"alpha"},maskUnits:"userSpaceOnUse",x:2,y:2,width:16,height:16,children:h("path",{d:"M5.879 2.625h8.242a3.254 3.254 0 0 1 3.254 3.254v8.242a3.254 3.254 0 0 1-3.254 3.254H5.88a3.254 3.254 0 0 1-3.254-3.254V5.88a3.254 3.254 0 0 1 3.254-3.254Z",fill:"currentColor",stroke:"currentColor",strokeWidth:"1.25"})}),h("g",{mask:"url(#FillHachureIcon)",children:h("path",{d:"M2.258 15.156 15.156 2.258M7.324 20.222 20.222 7.325m-20.444 5.35L12.675-.222m-8.157 18.34L17.416 5.22",stroke:"currentColor",strokeWidth:"1.25",strokeLinecap:"round",strokeLinejoin:"round"})})]}),pe),U1=_(O(De,{children:[O("g",{clipPath:"url(#a)",children:[h("path",{d:"M5.879 2.625h8.242a3.254 3.254 0 0 1 3.254 3.254v8.242a3.254 3.254 0 0 1-3.254 3.254H5.88a3.254 3.254 0 0 1-3.254-3.254V5.88a3.254 3.254 0 0 1 3.254-3.254Z",stroke:"currentColor",strokeWidth:"1.25"}),h("mask",{id:"FillCrossHatchIcon",style:{maskType:"alpha"},maskUnits:"userSpaceOnUse",x:-1,y:-1,width:22,height:22,children:h("path",{d:"M2.426 15.044 15.044 2.426M7.383 20 20 7.383M0 12.617 12.617 0m-7.98 17.941L17.256 5.324m-2.211 12.25L2.426 4.956M20 12.617 7.383 0m5.234 20L0 7.383m17.941 7.98L5.324 2.745",stroke:"currentColor",strokeWidth:"1.25",strokeLinecap:"round",strokeLinejoin:"round"})}),h("g",{mask:"url(#FillCrossHatchIcon)",children:h("path",{d:"M14.121 2H5.88A3.879 3.879 0 0 0 2 5.879v8.242A3.879 3.879 0 0 0 5.879 18h8.242A3.879 3.879 0 0 0 18 14.121V5.88A3.879 3.879 0 0 0 14.121 2Z",fill:"currentColor"})})]}),h("defs",{children:h("clipPath",{id:"a",children:h("path",{fill:"#fff",d:"M0 0h20v20H0z"})})})]}),pe),W1=_(O(De,{children:[h("g",{clipPath:"url(#a)",children:h("path",{d:"M4.91 2.625h10.18a2.284 2.284 0 0 1 2.285 2.284v10.182a2.284 2.284 0 0 1-2.284 2.284H4.909a2.284 2.284 0 0 1-2.284-2.284V4.909a2.284 2.284 0 0 1 2.284-2.284Z",stroke:"currentColor",strokeWidth:"1.25"})}),h("defs",{children:h("clipPath",{id:"a",children:h("path",{fill:"#fff",d:"M0 0h20v20H0z"})})})]}),{...pe,fill:"currentColor"}),nu=_(h(De,{children:h("path",{d:"M4.167 10h11.666",stroke:"currentColor",strokeWidth:"1.25",strokeLinecap:"round",strokeLinejoin:"round"})}),pe),V1=_(h("path",{d:"M5 10h10",stroke:"currentColor",strokeWidth:"2.5",strokeLinecap:"round",strokeLinejoin:"round"}),pe),Y1=_(h("path",{d:"M5 10h10",stroke:"currentColor",strokeWidth:"3.75",strokeLinecap:"round",strokeLinejoin:"round"}),pe),_L=Io.memo(({theme:e})=>_(h("path",{d:"M6 10H34",stroke:pr(e),strokeWidth:2,fill:"none",strokeLinecap:"round"}),{width:40,height:20})),K1=_(O("g",{strokeWidth:"2",children:[h("path",{stroke:"none",d:"M0 0h24v24H0z",fill:"none"}),h("path",{d:"M5 12h2"}),h("path",{d:"M17 12h2"}),h("path",{d:"M11 12h2"})]}),q),$1=_(O("g",{strokeWidth:"2",children:[h("path",{stroke:"none",d:"M0 0h24v24H0z",fill:"none"}),h("path",{d:"M4 12v.01"}),h("path",{d:"M8 12v.01"}),h("path",{d:"M12 12v.01"}),h("path",{d:"M16 12v.01"}),h("path",{d:"M20 12v.01"})]}),q),X1=_(h("path",{d:"M2.5 12.038c1.655-.885 5.9-3.292 8.568-4.354 2.668-1.063.101 2.821 1.32 3.104 1.218.283 5.112-1.814 5.112-1.814",strokeWidth:"1.25"}),pe),Z1=_(h("path",{d:"M2.5 12.563c1.655-.886 5.9-3.293 8.568-4.355 2.668-1.062.101 2.822 1.32 3.105 1.218.283 5.112-1.814 5.112-1.814m-13.469 2.23c2.963-1.586 6.13-5.62 7.468-4.998 1.338.623-1.153 4.11-.132 5.595 1.02 1.487 6.133-1.43 6.133-1.43",strokeWidth:"1.25"}),pe),j1=_(h("path",{d:"M2.5 11.936c1.737-.879 8.627-5.346 10.42-5.268 1.795.078-.418 5.138.345 5.736.763.598 3.53-1.789 4.235-2.147M2.929 9.788c1.164-.519 5.47-3.28 6.987-3.114 1.519.165 1 3.827 2.121 4.109 1.122.281 3.839-2.016 4.606-2.42",strokeWidth:"1.25"}),pe),q1=_(O("svg",{strokeWidth:"1.5",children:[h("path",{d:"M3.33334 9.99998V6.66665C3.33334 6.04326 3.33403 4.9332 3.33539 3.33646C4.95233 3.33436 6.06276 3.33331 6.66668 3.33331H10"}),h("path",{d:"M13.3333 3.33331V3.34331"}),h("path",{d:"M16.6667 3.33331V3.34331"}),h("path",{d:"M16.6667 6.66669V6.67669"}),h("path",{d:"M16.6667 10V10.01"}),h("path",{d:"M3.33334 13.3333V13.3433"}),h("path",{d:"M16.6667 13.3333V13.3433"}),h("path",{d:"M3.33334 16.6667V16.6767"}),h("path",{d:"M6.66666 16.6667V16.6767"}),h("path",{d:"M10 16.6667V16.6767"}),h("path",{d:"M13.3333 16.6667V16.6767"}),h("path",{d:"M16.6667 16.6667V16.6767"})]}),pe),J1=_(O("g",{strokeWidth:"1.5",stroke:"currentColor",strokeLinecap:"round",strokeLinejoin:"round",children:[h("path",{stroke:"none",d:"M0 0h24v24H0z",fill:"none"}),h("path",{d:"M4 12v-4a4 4 0 0 1 4 -4h4"}),h("line",{x1:"16",y1:"4",x2:"16",y2:"4.01"}),h("line",{x1:"20",y1:"4",x2:"20",y2:"4.01"}),h("line",{x1:"20",y1:"8",x2:"20",y2:"8.01"}),h("line",{x1:"20",y1:"12",x2:"20",y2:"12.01"}),h("line",{x1:"4",y1:"16",x2:"4",y2:"16.01"}),h("line",{x1:"20",y1:"16",x2:"20",y2:"16.01"}),h("line",{x1:"4",y1:"20",x2:"4",y2:"20.01"}),h("line",{x1:"8",y1:"20",x2:"8",y2:"20.01"}),h("line",{x1:"12",y1:"20",x2:"12",y2:"20.01"}),h("line",{x1:"16",y1:"20",x2:"16",y2:"20.01"}),h("line",{x1:"20",y1:"20",x2:"20",y2:"20.01"})]}),q),Q1=_(h("path",{d:"M6 10H34",stroke:"currentColor",strokeWidth:2,fill:"none"}),{width:40,height:20}),eb=Io.memo(({flip:e=!1})=>_(O("g",{transform:e?"translate(40, 0) scale(-1, 1)":"",stroke:"currentColor",strokeWidth:2,fill:"none",children:[h("path",{d:"M34 10H6M34 10L27 5M34 10L27 15"}),h("path",{d:"M27.5 5L34.5 10L27.5 15"})]}),{width:40,height:20})),iu=Io.memo(({flip:e=!1})=>_(O("g",{stroke:"currentColor",fill:"currentColor",transform:e?"translate(40, 0) scale(-1, 1)":"",children:[h("path",{d:"M32 10L6 10",strokeWidth:2}),h("circle",{r:"4",transform:"matrix(-1 0 0 1 30 10)"})]}),{width:40,height:20})),tb=Io.memo(({flip:e=!1})=>_(O("g",{stroke:"currentColor",fill:"none",transform:e?"translate(40, 0) scale(-1, 1)":"",strokeWidth:2,children:[h("path",{d:"M26 10L6 10"}),h("circle",{r:"4",transform:"matrix(-1 0 0 1 30 10)"})]}),{width:40,height:20})),ob=Io.memo(({flip:e=!1})=>_(h("g",{transform:e?"translate(40, 0) scale(-1, 1)":"",children:h("path",{d:"M34 10H5.99996M34 10L34 5M34 10L34 15",stroke:"currentColor",strokeWidth:2,fill:"none"})}),{width:40,height:20})),rb=Io.memo(({flip:e=!1})=>_(O("g",{stroke:"currentColor",fill:"currentColor",transform:e?"translate(40, 0) scale(-1, 1)":"",children:[h("path",{d:"M32 10L6 10",strokeWidth:2}),h("path",{d:"M27.5 5.5L34.5 10L27.5 14.5L27.5 5.5"})]}),{width:40,height:20})),nb=Io.memo(({flip:e=!1})=>_(O("g",{stroke:"currentColor",fill:"none",transform:e?"translate(40, 0) scale(-1, 1)":"",strokeWidth:2,strokeLinejoin:"round",children:[h("path",{d:"M6,9.5H27"}),h("path",{d:"M27,5L34,10L27,14Z",fill:"none"})]}),{width:40,height:20})),ib=Io.memo(({flip:e=!1})=>_(O("g",{stroke:"currentColor",fill:"currentColor",transform:e?"translate(40, 0) scale(-1, 1)":"",strokeLinejoin:"round",strokeWidth:2,children:[h("path",{d:"M6,9.5H20"}),h("path",{d:"M27,5L34,10L27,14L20,9.5Z"})]}),{width:40,height:20})),ab=Io.memo(({flip:e=!1})=>_(O("g",{stroke:"currentColor",fill:"none",transform:e?"translate(40, 0) scale(-1, 1)":"",strokeLinejoin:"round",strokeWidth:2,children:[h("path",{d:"M6,9.5H20"}),h("path",{d:"M27,5L34,10L27,14L20,9.5Z"})]}),{width:40,height:20})),lb=_(O(De,{children:[h("g",{clipPath:"url(#a)",children:h("path",{d:"M14.167 6.667a3.333 3.333 0 0 0-3.334-3.334H9.167a3.333 3.333 0 0 0 0 6.667h1.666a3.333 3.333 0 0 1 0 6.667H9.167a3.333 3.333 0 0 1-3.334-3.334",stroke:"currentColor",strokeWidth:"1.25",strokeLinecap:"round",strokeLinejoin:"round"})}),h("defs",{children:h("clipPath",{id:"a",children:h("path",{fill:"#fff",d:"M0 0h20v20H0z"})})})]}),pe),sb=_(O(De,{children:[h("g",{clipPath:"url(#a)",children:h("path",{d:"M5 16.667V3.333L10 15l5-11.667v13.334",stroke:"currentColor",strokeWidth:"1.25",strokeLinecap:"round",strokeLinejoin:"round"})}),h("defs",{children:h("clipPath",{id:"a",children:h("path",{fill:"#fff",d:"M0 0h20v20H0z"})})})]}),pe),cb=_(O(De,{children:[h("g",{clipPath:"url(#a)",children:h("path",{d:"M5.833 3.333v13.334h8.334",stroke:"currentColor",strokeWidth:"1.25",strokeLinecap:"round",strokeLinejoin:"round"})}),h("defs",{children:h("clipPath",{id:"a",children:h("path",{fill:"#fff",d:"M0 0h20v20H0z"})})})]}),pe),db=_(h(De,{children:h("path",{d:"m1.667 3.333 6.666 13.334M8.333 3.333 1.667 16.667M11.667 3.333v13.334h6.666",stroke:"currentColor",strokeWidth:"1.25",strokeLinecap:"round",strokeLinejoin:"round"})}),pe),au=_(O("g",{strokeWidth:1.25,children:[h("path",{stroke:"none",d:"M0 0h24v24H0z",fill:"none"}),h("path",{d:"M3 7v-2h13v2"}),h("path",{d:"M10 5v14"}),h("path",{d:"M12 19h-4"}),h("path",{d:"M15 13v-1h6v1"}),h("path",{d:"M18 12v7"}),h("path",{d:"M17 19h2"})]}),q),mb=_(h(De,{children:h("g",{stroke:"currentColor",strokeWidth:"1.25",strokeLinecap:"round",strokeLinejoin:"round",children:h("path",{d:"M5.833 16.667v-10a3.333 3.333 0 0 1 3.334-3.334h1.666a3.333 3.333 0 0 1 3.334 3.334v10M5.833 10.833h8.334"})})}),pe),pb=_(O(De,{children:[h("g",{clipPath:"url(#a)",stroke:"currentColor",strokeWidth:"1.25",strokeLinecap:"round",strokeLinejoin:"round",children:h("path",{d:"M5.833 6.667 2.5 10l3.333 3.333M14.167 6.667 17.5 10l-3.333 3.333M11.667 3.333 8.333 16.667"})}),h("defs",{children:h("clipPath",{id:"a",children:h("path",{fill:"#fff",d:"M0 0h20v20H0z"})})})]}),pe),ub=_(O("g",{stroke:"currentColor",fill:"none",strokeLinecap:"round",strokeLinejoin:"round",strokeWidth:2,children:[h("path",{stroke:"none",d:"M0 0h24v24H0z",fill:"none"}),h("line",{x1:"4",y1:"8",x2:"20",y2:"8"}),h("line",{x1:"4",y1:"12",x2:"12",y2:"12"}),h("line",{x1:"4",y1:"16",x2:"16",y2:"16"})]}),q),gb=_(O("g",{stroke:"currentColor",fill:"none",strokeLinecap:"round",strokeLinejoin:"round",children:[h("path",{stroke:"none",d:"M0 0h24v24H0z",fill:"none"}),h("line",{x1:"4",y1:"8",x2:"20",y2:"8"}),h("line",{x1:"8",y1:"12",x2:"16",y2:"12"}),h("line",{x1:"6",y1:"16",x2:"18",y2:"16"})]}),q),hb=_(O("g",{stroke:"currentColor",fill:"none",strokeLinecap:"round",strokeLinejoin:"round",children:[h("path",{stroke:"none",d:"M0 0h24v24H0z",fill:"none"}),h("line",{x1:"4",y1:"8",x2:"20",y2:"8"}),h("line",{x1:"10",y1:"12",x2:"20",y2:"12"}),h("line",{x1:"8",y1:"16",x2:"20",y2:"16"})]}),q),fb=Io.memo(({theme:e})=>_(O("g",{strokeWidth:"1.5",stroke:"currentColor",fill:"none",strokeLinecap:"round",strokeLinejoin:"round",children:[h("path",{stroke:"none",d:"M0 0h24v24H0z",fill:"none"}),h("line",{x1:"4",y1:"4",x2:"20",y2:"4"}),h("rect",{x:"9",y:"8",width:"6",height:"12",rx:"2"})]}),q)),bb=Io.memo(({theme:e})=>_(O("g",{strokeWidth:"2",stroke:"currentColor",fill:"none",strokeLinecap:"round",strokeLinejoin:"round",children:[h("path",{stroke:"none",d:"M0 0h24v24H0z",fill:"none"}),h("line",{x1:"4",y1:"20",x2:"20",y2:"20"}),h("rect",{x:"9",y:"4",width:"6",height:"12",rx:"2"})]}),q)),xb=Io.memo(({theme:e})=>_(O("g",{strokeWidth:"1.5",stroke:"currentColor",fill:"none",strokeLinecap:"round",strokeLinejoin:"round",children:[h("path",{stroke:"none",d:"M0 0h24v24H0z",fill:"none"}),h("line",{x1:"4",y1:"12",x2:"9",y2:"12"}),h("line",{x1:"15",y1:"12",x2:"20",y2:"12"}),h("rect",{x:"9",y:"6",width:"6",height:"12",rx:"2"})]}),q)),Eb=_(h("path",{d:"M537.6 226.6c4.1-10.7 6.4-22.4 6.4-34.6 0-53-43-96-96-96-19.7 0-38.1 6-53.3 16.2C367 64.2 315.3 32 256 32c-88.4 0-160 71.6-160 160 0 2.7.1 5.4.2 8.1C40.2 219.8 0 273.2 0 336c0 79.5 64.5 144 144 144h368c70.7 0 128-57.3 128-128 0-61.9-44-113.6-102.4-125.4zM393.4 288H328v112c0 8.8-7.2 16-16 16h-48c-8.8 0-16-7.2-16-16V288h-65.4c-14.3 0-21.4-17.2-11.3-27.3l105.4-105.4c6.2-6.2 16.4-6.2 22.6 0l105.4 105.4c10.1 10.1 2.9 27.3-11.3 27.3z",fill:"currentColor"}),{width:640,height:512}),PL=_(h("path",{d:"M480 416C497.7 416 512 430.3 512 448C512 465.7 497.7 480 480 480H150.6C133.7 480 117.4 473.3 105.4 461.3L25.37 381.3C.3786 356.3 .3786 315.7 25.37 290.7L258.7 57.37C283.7 32.38 324.3 32.38 349.3 57.37L486.6 194.7C511.6 219.7 511.6 260.3 486.6 285.3L355.9 416H480zM265.4 416L332.7 348.7L195.3 211.3L70.63 336L150.6 416L265.4 416z"})),Yc=_(O("g",{strokeWidth:1.25,children:[h("path",{stroke:"none",d:"M0 0h24v24H0z",fill:"none"}),h("path",{d:"M8 13v-7.5a1.5 1.5 0 0 1 3 0v6.5"}),h("path",{d:"M11 5.5v-2a1.5 1.5 0 1 1 3 0v8.5"}),h("path",{d:"M14 5.5a1.5 1.5 0 0 1 3 0v6.5"}),h("path",{d:"M17 7.5a1.5 1.5 0 0 1 3 0v8.5a6 6 0 0 1 -6 6h-2h.208a6 6 0 0 1 -5.012 -2.7a69.74 69.74 0 0 1 -.196 -.3c-.312 -.479 -1.407 -2.388 -3.286 -5.728a1.5 1.5 0 0 1 .536 -2.022a1.867 1.867 0 0 1 2.28 .28l1.47 1.47"})]}),q),lu=_(O(De,{children:[h("path",{stroke:"none",d:"M0 0h24v24H0z",fill:"none"}),h("path",{d:"M4 17v2a2 2 0 0 0 2 2h12a2 2 0 0 0 2 -2v-2"}),h("path",{d:"M7 11l5 5l5 -5"}),h("path",{d:"M12 4l0 12"})]}),q),Kc=_(O(De,{children:[h("path",{stroke:"none",d:"M0 0h24v24H0z",fill:"none"}),h("path",{d:"M8 8m0 2a2 2 0 0 1 2 -2h8a2 2 0 0 1 2 2v8a2 2 0 0 1 -2 2h-8a2 2 0 0 1 -2 -2z"}),h("path",{d:"M16 8v-2a2 2 0 0 0 -2 -2h-8a2 2 0 0 0 -2 2v8a2 2 0 0 0 2 2h2"})]}),q),yb=_(O("g",{strokeWidth:1.25,children:[h("path",{stroke:"none",d:"M0 0h24v24H0z",fill:"none"}),h("path",{d:"M7 17m-3 0a3 3 0 1 0 6 0a3 3 0 1 0 -6 0"}),h("path",{d:"M17 17m-3 0a3 3 0 1 0 6 0a3 3 0 1 0 -6 0"}),h("path",{d:"M9.15 14.85l8.85 -10.85"}),h("path",{d:"M6 4l8.85 10.85"})]}),q),wb=_(O(De,{children:[h("path",{stroke:"none",d:"M0 0h24v24H0z",fill:"none"}),h("path",{d:"M12 12m-9 0a9 9 0 1 0 18 0a9 9 0 1 0 -18 0"}),h("path",{d:"M12 17l0 .01"}),h("path",{d:"M12 13.5a1.5 1.5 0 0 1 1 -1.5a2.6 2.6 0 1 0 -3 -4"})]}),q),DL=_(O(De,{children:[h("path",{stroke:"none",d:"M0 0h24v24H0z",fill:"none"}),h("path",{d:"M7 4v16l13 -8z"})]}),q),RL=_(O(De,{children:[h("path",{stroke:"none",d:"M0 0h24v24H0z",fill:"none"}),h("path",{d:"M17 4h-10a3 3 0 0 0 -3 3v10a3 3 0 0 0 3 3h10a3 3 0 0 0 3 -3v-10a3 3 0 0 0 -3 -3z",strokeWidth:"0",fill:"currentColor"})]}),q),NL=_(O(De,{children:[h("path",{stroke:"none",d:"M0 0h24v24H0z",fill:"none"}),h("path",{d:"M5 12l5 5l10 -10"})]}),q),vb=_(O(De,{children:[h("path",{stroke:"none",d:"M0 0h24v24H0z",fill:"none"}),h("path",{d:"M10.24 3.957l-8.422 14.06a1.989 1.989 0 0 0 1.7 2.983h16.845a1.989 1.989 0 0 0 1.7 -2.983l-8.423 -14.06a1.989 1.989 0 0 0 -3.4 0z"}),h("path",{d:"M12 9v4"}),h("path",{d:"M12 17h.01"})]}),q),Tb=_(O("g",{strokeWidth:1.25,children:[h("path",{stroke:"none",d:"M0 0h24v24H0z",fill:"none"}),h("path",{d:"M11 7l6 6"}),h("path",{d:"M4 16l11.7 -11.7a1 1 0 0 1 1.4 0l2.6 2.6a1 1 0 0 1 0 1.4l-11.7 11.7h-4v-4z"})]}),q),Cb=_(O("g",{strokeWidth:1.5,children:[h("path",{stroke:"none",d:"M0 0h24v24H0z",fill:"none"}),h("path",{d:"M12 3l-4 7h8z"}),h("path",{d:"M17 17m-3 0a3 3 0 1 0 6 0a3 3 0 1 0 -6 0"}),h("path",{d:"M4 14m0 1a1 1 0 0 1 1 -1h4a1 1 0 0 1 1 1v4a1 1 0 0 1 -1 1h-4a1 1 0 0 1 -1 -1z"})]}),q),$c=_(O("g",{strokeWidth:1.5,children:[h("path",{stroke:"none",d:"M0 0h24v24H0z",fill:"none"}),h("path",{d:"M4 7l16 0"}),h("path",{d:"M4 17l16 0"}),h("path",{d:"M7 4l0 16"}),h("path",{d:"M17 4l0 16"})]}),q),Xc=_(h("path",{fill:"currentColor",d:"M407.48,111.18C335.587,108.103 269.573,152.338 245.08,220C220.587,152.338 154.573,108.103 82.68,111.18C80.285,168.229 107.577,222.632 154.74,254.82C178.908,271.419 193.35,298.951 193.27,328.27L193.27,379.13L296.9,379.13L296.9,328.27C296.816,298.953 311.255,271.42 335.42,254.82C382.596,222.644 409.892,168.233 407.48,111.18Z"})),Ua=_(O("g",{strokeWidth:"1.25",children:[h("path",{d:"M4.16602 10H15.8327"}),h("path",{d:"M12.5 13.3333L15.8333 10"}),h("path",{d:"M12.5 6.66666L15.8333 9.99999"})]}),pe),Zc=_(O("g",{fill:"none",stroke:"currentColor",strokeWidth:"1.25",strokeLinecap:"round",strokeLinejoin:"round",transform:"rotate(90 10 10)",children:[h("path",{clipRule:"evenodd",d:"m9.644 13.69 7.774-7.773a2.357 2.357 0 0 0-3.334-3.334l-7.773 7.774L8 12l1.643 1.69Z"}),h("path",{d:"m13.25 3.417 3.333 3.333M10 10l2-2M5 15l3-3M2.156 17.894l1-1M5.453 19.029l-.144-1.407M2.377 11.887l.866 1.118M8.354 17.273l-1.194-.758M.953 14.652l1.408.13"})]}),20),Wa=_(O("g",{stroke:"currentColor",fill:"none",children:[h("path",{stroke:"none",d:"M0 0h24v24H0z"}),h("path",{d:"M6 21l15 -15l-3 -3l-15 15l3 3"}),h("path",{d:"M15 6l3 3"}),h("path",{d:"M9 3a2 2 0 0 0 2 2a2 2 0 0 0 -2 2a2 2 0 0 0 -2 -2a2 2 0 0 0 2 -2"}),h("path",{d:"M19 13a2 2 0 0 0 2 2a2 2 0 0 0 -2 2a2 2 0 0 0 -2 -2a2 2 0 0 0 2 -2"})]}),q),OL=_(O("g",{strokeWidth:1.25,children:[h("path",{stroke:"none",d:"M0 0h24v24H0z"}),h("path",{d:"M6 21l15 -15l-3 -3l-15 15l3 3"}),h("path",{d:"M15 6l3 3"}),h("path",{d:"M9 3a2 2 0 0 0 2 2a2 2 0 0 0 -2 2a2 2 0 0 0 -2 -2a2 2 0 0 0 2 -2"}),h("path",{d:"M19 13a2 2 0 0 0 2 2a2 2 0 0 0 -2 2a2 2 0 0 0 -2 -2a2 2 0 0 0 2 -2"})]}),q),is=_(O("g",{stroke:"currentColor",fill:"none",children:[h("path",{stroke:"none",d:"M0 0h24v24H0z",fill:"none"}),h("path",{d:"M11.217 19.384a3.501 3.501 0 0 0 6.783 -1.217v-5.167l-6 -3.35"}),h("path",{d:"M5.214 15.014a3.501 3.501 0 0 0 4.446 5.266l4.34 -2.534v-6.946"}),h("path",{d:"M6 7.63c-1.391 -.236 -2.787 .395 -3.534 1.689a3.474 3.474 0 0 0 1.271 4.745l4.263 2.514l6 -3.348"}),h("path",{d:"M12.783 4.616a3.501 3.501 0 0 0 -6.783 1.217v5.067l6 3.45"}),h("path",{d:"M18.786 8.986a3.501 3.501 0 0 0 -4.446 -5.266l-4.34 2.534v6.946"}),h("path",{d:"M18 16.302c1.391 .236 2.787 -.395 3.534 -1.689a3.474 3.474 0 0 0 -1.271 -4.745l-4.308 -2.514l-5.955 3.42"})]}),q),Ib=_(O("g",{stroke:"currentColor",fill:"none",children:[h("path",{stroke:"none",d:"M0 0h24v24H0z",fill:"none"}),h("path",{d:"M4 8v-2a2 2 0 0 1 2 -2h2"}),h("path",{d:"M4 16v2a2 2 0 0 0 2 2h2"}),h("path",{d:"M16 4h2a2 2 0 0 1 2 2v2"}),h("path",{d:"M16 20h2a2 2 0 0 0 2 -2v-2"})]}),q),Va=_(O("g",{stroke:"currentColor",fill:"none",strokeWidth:1.5,children:[h("path",{stroke:"none",d:"M0 0h24v24H0z",fill:"none"}),h("path",{d:"M10 12a2 2 0 1 0 4 0a2 2 0 0 0 -4 0"}),h("path",{d:"M21 12c-2.4 4 -5.4 6 -9 6c-3.6 0 -6.6 -2 -9 -6c2.4 -4 5.4 -6 9 -6c3.6 0 6.6 2 9 6"})]}),q),Sb=_(O("g",{stroke:"currentColor",fill:"none",children:[h("path",{stroke:"none",d:"M0 0h24v24H0z",fill:"none"}),h("path",{d:"M10.585 10.587a2 2 0 0 0 2.829 2.828"}),h("path",{d:"M16.681 16.673a8.717 8.717 0 0 1 -4.681 1.327c-3.6 0 -6.6 -2 -9 -6c1.272 -2.12 2.712 -3.678 4.32 -4.674m2.86 -1.146a9.055 9.055 0 0 1 1.82 -.18c3.6 0 6.6 2 9 6c-.666 1.11 -1.379 2.067 -2.138 2.87"}),h("path",{d:"M3 3l18 18"})]}),q),kb=_(O("g",{stroke:"currentColor",fill:"none",children:[h("path",{stroke:"none",d:"M0 0h24v24H0z",fill:"none"}),h("path",{d:"M15.5 13a3.5 3.5 0 0 0 -3.5 3.5v1a3.5 3.5 0 0 0 7 0v-1.8"}),h("path",{d:"M8.5 13a3.5 3.5 0 0 1 3.5 3.5v1a3.5 3.5 0 0 1 -7 0v-1.8"}),h("path",{d:"M17.5 16a3.5 3.5 0 0 0 0 -7h-.5"}),h("path",{d:"M19 9.3v-2.8a3.5 3.5 0 0 0 -7 0"}),h("path",{d:"M6.5 16a3.5 3.5 0 0 1 0 -7h.5"}),h("path",{d:"M5 9.3v-2.8a3.5 3.5 0 0 1 7 0v10"})]}),q),Ab=_(O("g",{strokeWidth:1.25,children:[h("path",{stroke:"none",d:"M0 0h24v24H0z",fill:"none"}),h("path",{d:"M15.5 13a3.5 3.5 0 0 0 -3.5 3.5v1a3.5 3.5 0 0 0 7 0v-1.8"}),h("path",{d:"M8.5 13a3.5 3.5 0 0 1 3.5 3.5v1a3.5 3.5 0 0 1 -7 0v-1.8"}),h("path",{d:"M17.5 16a3.5 3.5 0 0 0 0 -7h-.5"}),h("path",{d:"M19 9.3v-2.8a3.5 3.5 0 0 0 -7 0"}),h("path",{d:"M6.5 16a3.5 3.5 0 0 1 0 -7h.5"}),h("path",{d:"M5 9.3v-2.8a3.5 3.5 0 0 1 7 0v10"})]}),q),jc=_(O("g",{strokeWidth:1.5,children:[h("path",{stroke:"none",d:"M0 0h24v24H0z",fill:"none"}),h("path",{d:"M10 10m-7 0a7 7 0 1 0 14 0a7 7 0 1 0 -14 0"}),h("path",{d:"M21 21l-6 -6"})]}),q),Mb=_(O("g",{strokeWidth:1.5,children:[h("path",{stroke:"none",d:"M0 0h24v24H0z",fill:"none"}),h("path",{d:"M20.984 12.53a9 9 0 1 0 -7.552 8.355"}),h("path",{d:"M12 7v5l3 3"}),h("path",{d:"M19 16l-2 3h4l-2 3"})]}),q),Lb=_(O("g",{strokeWidth:1.5,children:[h("path",{stroke:"none",d:"M0 0h24v24H0z",fill:"none"}),h("path",{d:"M9 2m0 3a3 3 0 0 1 3 -3h0a3 3 0 0 1 3 3v5a3 3 0 0 1 -3 3h0a3 3 0 0 1 -3 -3z"}),h("path",{d:"M5 10a7 7 0 0 0 14 0"}),h("path",{d:"M8 21l8 0"}),h("path",{d:"M12 17l0 4"})]}),q),_b=_(O("g",{strokeWidth:1.5,children:[h("path",{stroke:"none",d:"M0 0h24v24H0z",fill:"none"}),h("path",{d:"M3 3l18 18"}),h("path",{d:"M9 5a3 3 0 0 1 6 0v5a3 3 0 0 1 -.13 .874m-2 2a3 3 0 0 1 -3.87 -2.872v-1"}),h("path",{d:"M5 10a7 7 0 0 0 10.846 5.85m2 -2a6.967 6.967 0 0 0 1.152 -3.85"}),h("path",{d:"M8 21l8 0"}),h("path",{d:"M12 17l0 4"})]}),q),qc=_(O("g",{strokeWidth:1.25,children:[h("path",{stroke:"none",d:"M0 0h24v24H0z",fill:"none"}),h("path",{d:"M13 3l0 7l6 0l-8 11l0 -7l-6 0l8 -11"})]}),q),Pb=_(O("g",{children:[h("path",{stroke:"none",d:"M0 0h24v24H0z",fill:"none"}),h("path",{d:"M8 8m0 1a1 1 0 0 1 1 -1h6a1 1 0 0 1 1 1v6a1 1 0 0 1 -1 1h-6a1 1 0 0 1 -1 -1z"}),h("path",{d:"M12 20v.01"}),h("path",{d:"M16 20v.01"}),h("path",{d:"M8 20v.01"}),h("path",{d:"M4 20v.01"}),h("path",{d:"M4 16v.01"}),h("path",{d:"M4 12v.01"}),h("path",{d:"M4 8v.01"}),h("path",{d:"M4 4v.01"}),h("path",{d:"M8 4v.01"}),h("path",{d:"M12 4v.01"}),h("path",{d:"M16 4v.01"}),h("path",{d:"M20 4v.01"}),h("path",{d:"M20 8v.01"}),h("path",{d:"M20 12v.01"}),h("path",{d:"M20 16v.01"}),h("path",{d:"M20 20v.01"})]}),q),Db=_(O("g",{strokeWidth:1.25,children:[h("path",{stroke:"none",d:"M0 0h24v24H0z",fill:"none"}),h("path",{d:"M5 3v18"}),h("path",{d:"M19 21v-18"}),h("path",{d:"M5 7h14"}),h("path",{d:"M5 15h14"}),h("path",{d:"M8 13v4"}),h("path",{d:"M11 13v4"}),h("path",{d:"M16 13v4"}),h("path",{d:"M14 5v4"}),h("path",{d:"M11 5v4"}),h("path",{d:"M8 5v4"}),h("path",{d:"M3 21h18"})]}),q),Rb=_(O("g",{strokeWidth:1.25,children:[h("path",{stroke:"none",d:"M0 0h24v24H0z",fill:"none"}),h("path",{d:"M3 12l18 0"}),h("path",{d:"M7 16l10 0l-10 5l0 -5"}),h("path",{d:"M7 8l10 0l-10 -5l0 5"})]}),q),Nb=_(O("g",{strokeWidth:1.25,children:[h("path",{stroke:"none",d:"M0 0h24v24H0z",fill:"none"}),h("path",{d:"M12 3l0 18"}),h("path",{d:"M16 7l0 10l5 0l-5 -10"}),h("path",{d:"M8 7l0 10l-5 0l5 -10"})]}),q),su=_(O("g",{strokeWidth:1.25,children:[h("path",{stroke:"none",d:"M0 0h24v24H0z",fill:"none"}),h("path",{d:"M5 3m0 2a2 2 0 0 1 2 -2h10a2 2 0 0 1 2 2v2a2 2 0 0 1 -2 2h-10a2 2 0 0 1 -2 -2z"}),h("path",{d:"M19 6h1a2 2 0 0 1 2 2a5 5 0 0 1 -5 5l-5 0v2"}),h("path",{d:"M10 15m0 1a1 1 0 0 1 1 -1h2a1 1 0 0 1 1 1v4a1 1 0 0 1 -1 1h-2a1 1 0 0 1 -1 -1z"})]}),q),Jc=_(O("g",{strokeWidth:1.25,children:[h("path",{stroke:"none",d:"M0 0h24v24H0z",fill:"none"}),h("path",{d:"M15 15m-5 0a5 5 0 1 0 10 0a5 5 0 1 0 -10 0"}),h("path",{d:"M22 22l-3 -3"}),h("path",{d:"M6 18h-1a2 2 0 0 1 -2 -2v-1"}),h("path",{d:"M3 11v-1"}),h("path",{d:"M3 6v-1a2 2 0 0 1 2 -2h1"}),h("path",{d:"M10 3h1"}),h("path",{d:"M15 3h1a2 2 0 0 1 2 2v1"})]}),q),Ob=_(O("g",{strokeWidth:1.25,children:[h("path",{stroke:"none",d:"M0 0h24v24H0z",fill:"none"}),h("path",{d:"M14 3v4a1 1 0 0 0 1 1h4"}),h("path",{d:"M5 12v-7a2 2 0 0 1 2 -2h7l5 5v4"}),h("path",{d:"M4 20.25c0 .414 .336 .75 .75 .75h1.25a1 1 0 0 0 1 -1v-1a1 1 0 0 0 -1 -1h-1a1 1 0 0 1 -1 -1v-1a1 1 0 0 1 1 -1h1.25a.75 .75 0 0 1 .75 .75"}),h("path",{d:"M10 15l2 6l2 -6"}),h("path",{d:"M20 15h-1a2 2 0 0 0 -2 2v2a2 2 0 0 0 2 2h1v-3"})]}),q),Bb=_(O("g",{strokeWidth:1.25,children:[h("path",{stroke:"none",d:"M0 0h24v24H0z",fill:"none"}),h("path",{d:"M14 3v4a1 1 0 0 0 1 1h4"}),h("path",{d:"M5 12v-7a2 2 0 0 1 2 -2h7l5 5v4"}),h("path",{d:"M20 15h-1a2 2 0 0 0 -2 2v2a2 2 0 0 0 2 2h1v-3"}),h("path",{d:"M5 18h1.5a1.5 1.5 0 0 0 0 -3h-1.5v6"}),h("path",{d:"M11 21v-6l3 6v-6"})]}),q),Fb=_(O("g",{strokeWidth:1.25,children:[h("path",{stroke:"none",d:"M0 0h24v24H0z",fill:"none"}),h("path",{d:"M4 13v-8a2 2 0 0 1 2 -2h1a2 2 0 0 1 2 2v8a2 2 0 0 0 6 0v-8a2 2 0 0 1 2 -2h1a2 2 0 0 1 2 2v8a8 8 0 0 1 -16 0"}),h("path",{d:"M4 8l5 0"}),h("path",{d:"M15 8l4 0"})]}),q),Hb=_(O("g",{strokeWidth:1.25,children:[h("path",{stroke:"none",d:"M0 0h24v24H0z",fill:"none"}),h("path",{d:"M3 14c.83 .642 2.077 1.017 3.5 1c1.423 .017 2.67 -.358 3.5 -1c.83 -.642 2.077 -1.017 3.5 -1c1.423 -.017 2.67 .358 3.5 1"}),h("path",{d:"M8 3a2.4 2.4 0 0 0 -1 2a2.4 2.4 0 0 0 1 2"}),h("path",{d:"M12 3a2.4 2.4 0 0 0 -1 2a2.4 2.4 0 0 0 1 2"}),h("path",{d:"M3 10h14v5a6 6 0 0 1 -6 6h-2a6 6 0 0 1 -6 -6v-5z"}),h("path",{d:"M16.746 16.726a3 3 0 1 0 .252 -5.555"})]}),q),zb=_(O("g",{stroke:"currentColor",children:[h("path",{stroke:"none",d:"M0 0h24v24H0z",fill:"none"}),h("path",{d:"M3 5a1 1 0 0 1 1-1h16a1 1 0 0 1 1 1v10a1 1 0 0 1-1 1h-16a1 1 0 0 1-1-1v-10zM7 20h10M9 16v4M15 16v4"})]}),{...q,strokeWidth:1.5}),BL=_(O("g",{children:[h("path",{stroke:"none",d:"M0 0h24v24H0z",fill:"none"}),h("path",{d:"M10 12l10 0"}),h("path",{d:"M10 12l4 4"}),h("path",{d:"M10 12l4 -4"}),h("path",{d:"M4 4l0 16"})]}),q),Gb=_(O("g",{children:[h("path",{stroke:"none",d:"M0 0h24v24H0z",fill:"none"}),h("path",{d:"M2 8a4 4 0 0 1 4 -4h12a4 4 0 0 1 4 4v8a4 4 0 0 1 -4 4h-12a4 4 0 0 1 -4 -4v-8z"}),h("path",{d:"M10 9l5 3l-5 3z"})]}),q)});import{jsx as HL}from"react/jsx-runtime";var FL,Dv,as,Ub=v(()=>{"use strict";f();We();ue();Mt();X();je();he();Ze();Ho();io();_r();se();G();ee();FL=(e,t)=>{let o=new Set(de(e.filter(r=>Q(r)),t).map(r=>r.id));return{elements:e.map(r=>t.selectedElementIds[r.id]?ae(r,{isDeleted:!0}):r.frameId&&o.has(r.frameId)?ae(r,{isDeleted:!0}):ze(r)&&t.selectedElementIds[r.containerId]?ae(r,{isDeleted:!0}):r),appState:{...t,selectedElementIds:{},selectedGroupIds:{}}}},Dv=(e,t)=>{if(e.editingGroupId){let o=ot(be(t),e.editingGroupId);if(o.length)return{...e,selectedElementIds:{[o[0].id]:!0}}}return e},as=H({name:"deleteSelectedElements",label:"labels.delete",icon:ur,trackEvent:{category:"element",action:"delete"},perform:(e,t,o,r)=>{if(t.editingLinearElement){let{elementId:a,selectedPointsIndices:l,startBindingElement:s,endBindingElement:c}=t.editingLinearElement,d=r.scene.getNonDeletedElementsMap(),m=$.getElement(a,d);if(!m||l==null)return!1;if(m.points.length<2){let u=e.map(x=>x.id===m.id?ae(x,{isDeleted:!0}):x),g=Dv(t,u);return{elements:u,appState:{...g,editingLinearElement:null},commitToHistory:!1}}let p={startBindingElement:l?.includes(0)?null:s,endBindingElement:l?.includes(m.points.length-1)?null:c};return $.deletePoints(m,l),{elements:e,appState:{...t,editingLinearElement:{...t.editingLinearElement,...p,selectedPointsIndices:l?.[0]>0?[l[0]-1]:[0]}},commitToHistory:!0}}let{elements:n,appState:i}=FL(e,t);return Ml(n,e.filter(({id:a})=>t.selectedElementIds[a])),i=Dv(i,n),{elements:n,appState:{...i,activeTool:Qe(t,{type:"selection"}),multiElement:null,activeEmbeddable:null},commitToHistory:Ye(be(e),t)}},keyTest:(e,t,o)=>(e.key===I.BACKSPACE||e.key===I.DELETE)&&!e[I.CTRL_OR_CMD],PanelComponent:({elements:e,appState:t,updateData:o})=>HL(ce,{type:"button",icon:ur,title:b("labels.delete"),"aria-label":b("labels.delete"),onClick:()=>o(null),visible:Ye(be(e),t)})})});function Hv(e,t,o,r){let n=re(de(e,t,{includeBoundTextElement:!0,includeElementsInFrames:!0})),i={regularElements:[],frameChildren:new Map},a=new Set;for(let c of e)n.has(c.id)&&Q(c)&&a.add(c.id);for(let c of e)if(n.has(c.id))if(Q(c)||c.frameId&&a.has(c.frameId))i.regularElements.push(c);else if(!c.frameId)i.regularElements.push(c);else{let d=i.frameChildren.get(c.frameId)||[];d.push(c),i.frameChildren.set(c.frameId,d)}let l=e,s=Array.from(i.frameChildren.entries());for(let[c,d]of s)l=r(e,t,o,c,d);return r(l,t,o,null,i.regularElements)}var Wb,Nv,zL,Rv,GL,UL,Ov,Bv,Fv,zv,Gv,Uv,Wv,Vv=v(()=>{"use strict";f();Ze();se();Ho();We();_n();G();Wb=(e,t)=>e.frameId===t||e.id===t,Nv=(e,t,o)=>{let r=[],n=[],i=null,a=-1,l=re(o||de(e,t,{includeBoundTextElement:!0,includeElementsInFrames:!0}));for(;++a<e.length;){let s=e[a];l.get(s.id)?(n.length&&(r=r.concat(n),n=[]),r.push(a),i=a+1):s.isDeleted&&i===a?(i=a+1,n.push(a)):n=[]}return r},zL=e=>{let t=0;return e.reduce((o,r,n)=>(n>0&&e[n-1]!==r-1&&(t=++t),(o[t]||(o[t]=[])).push(r),o),[])},Rv=(e,t,o)=>{if("containerId"in e&&e.containerId)if(o==="left"){let r=lt.getScene(e).getElement(e.containerId);if(r)return t.indexOf(r)}else return t.indexOf(e);else{let r=e.boundElements?.find(n=>n.type!=="arrow")?.id;if(r){if(o==="left")return t.indexOf(e);let n=lt.getScene(e).getElement(r);if(n)return t.indexOf(n)}}},GL=(e,t)=>{let o=-1,r=-1;return e.forEach((n,i)=>{Wb(n,t)&&(o===-1&&(o=i),r=i)}),o===-1?[]:e.slice(o,r+1)},UL=(e,t,o,r,n)=>{let i=t[o],a=m=>m.isDeleted?!1:n?m.frameId===n:e.editingGroupId?m.groupIds.includes(e.editingGroupId):!0,l=r==="left"?vh(t,m=>a(m),Math.max(0,o-1)):wh(t,m=>a(m),o+1),s=t[l];if(!s)return-1;if(e.editingGroupId){if(i?.groupIds.join("")===s?.groupIds.join(""))return Rv(s,t,r)??l;if(!s?.groupIds.includes(e.editingGroupId))return-1}if(!n&&(s.frameId||Q(s))){let m=GL(t,s.frameId||s.id);return r==="left"?t.indexOf(m[0]):t.indexOf(m[m.length-1])}if(!s.groupIds.length)return Rv(s,t,r)??l;let c=e.editingGroupId?s.groupIds[s.groupIds.indexOf(e.editingGroupId)-1]:s.groupIds[s.groupIds.length-1],d=ot(t,c);return d.length?r==="left"?t.indexOf(d[0]):t.indexOf(d[d.length-1]):l},Ov=(e,t)=>t.reduce((o,r)=>{let n=e[r];return o[n.id]=n,o},{}),Bv=(e,t,o)=>{let r=Nv(e,t),n=Ov(e,r),i=zL(r);o==="right"&&(i=i.reverse());let a=new Set(r.filter(l=>Q(e[l])).map(l=>e[l].id));return i.forEach((l,s)=>{let c=l[0],d=l[l.length-1],m=o==="left"?c:d,p=l.some(T=>{let w=e[T];return w.frameId&&a.has(w.frameId)})?null:e[m]?.frameId,u=UL(t,e,m,o,p);if(u===-1||m===u)return;let g=o==="left"?e.slice(0,u):e.slice(0,c),x=e.slice(c,d+1),E=o==="left"?e.slice(u,c):e.slice(d+1,u+1),y=o==="left"?e.slice(d+1):e.slice(u+1);e=o==="left"?[...g,...x,...E,...y]:[...g,...E,...x,...y]}),e.map(l=>n[l.id]?Nr(l):l)},Fv=(e,t,o,r,n)=>{let i=Nv(e,t,n),a=Ov(e,i),l=[],s,c;if(o==="left"){if(r)s=wh(e,u=>Wb(u,r));else if(t.editingGroupId){let u=ot(e,t.editingGroupId);if(!u.length)return e;s=e.indexOf(u[0])}else s=0;c=i[i.length-1]}else{if(r)c=vh(e,u=>Wb(u,r));else if(t.editingGroupId){let u=ot(e,t.editingGroupId);if(!u.length)return e;c=e.indexOf(u[u.length-1])}else c=e.length-1;s=i[0]}s===-1&&(s=0);for(let u=s;u<c+1;u++)i.includes(u)||l.push(e[u]);let d=Object.values(a).map(u=>Nr(u)),m=e.slice(0,s),p=e.slice(c+1);return o==="left"?[...m,...d,...l,...p]:[...m,...l,...d,...p]};zv=(e,t)=>Bv(e,t,"left"),Gv=(e,t)=>Bv(e,t,"right"),Uv=(e,t)=>Hv(e,t,"left",Fv),Wv=(e,t)=>Hv(e,t,"right",Fv)});import{jsx as uu}from"react/jsx-runtime";var cu,du,mu,pu,Yv=v(()=>{"use strict";f();Vv();ue();X();G();je();ee();U();cu=H({name:"sendBackward",label:"labels.sendBackward",icon:$p,trackEvent:{category:"element"},perform:(e,t)=>({elements:zv(e,t),appState:t,commitToHistory:!0}),keyPriority:40,keyTest:e=>e[I.CTRL_OR_CMD]&&!e.shiftKey&&e.code===fe.BRACKET_LEFT,PanelComponent:({updateData:e,appState:t})=>uu("button",{type:"button",className:"zIndexButton",onClick:()=>e(null),title:`${b("labels.sendBackward")} \u2014 ${N("CtrlOrCmd+[")}`,children:$p})}),du=H({name:"bringForward",label:"labels.bringForward",icon:Kp,trackEvent:{category:"element"},perform:(e,t)=>({elements:Gv(e,t),appState:t,commitToHistory:!0}),keyPriority:40,keyTest:e=>e[I.CTRL_OR_CMD]&&!e.shiftKey&&e.code===fe.BRACKET_RIGHT,PanelComponent:({updateData:e,appState:t})=>uu("button",{type:"button",className:"zIndexButton",onClick:()=>e(null),title:`${b("labels.bringForward")} \u2014 ${N("CtrlOrCmd+]")}`,children:Kp})}),mu=H({name:"sendToBack",label:"labels.sendToBack",icon:Zp,trackEvent:{category:"element"},perform:(e,t)=>({elements:Uv(e,t),appState:t,commitToHistory:!0}),keyTest:e=>so?e[I.CTRL_OR_CMD]&&e.altKey&&e.code===fe.BRACKET_LEFT:e[I.CTRL_OR_CMD]&&e.shiftKey&&e.code===fe.BRACKET_LEFT,PanelComponent:({updateData:e,appState:t})=>uu("button",{type:"button",className:"zIndexButton",onClick:()=>e(null),title:`${b("labels.sendToBack")} \u2014 ${so?N("CtrlOrCmd+Alt+["):N("CtrlOrCmd+Shift+[")}`,children:Zp})}),pu=H({name:"bringToFront",label:"labels.bringToFront",icon:Xp,trackEvent:{category:"element"},perform:(e,t)=>({elements:Wv(e,t),appState:t,commitToHistory:!0}),keyTest:e=>so?e[I.CTRL_OR_CMD]&&e.altKey&&e.code===fe.BRACKET_RIGHT:e[I.CTRL_OR_CMD]&&e.shiftKey&&e.code===fe.BRACKET_RIGHT,PanelComponent:({updateData:e,appState:t})=>uu("button",{type:"button",className:"zIndexButton",onClick:o=>e(null),title:`${b("labels.bringToFront")} \u2014 ${so?N("CtrlOrCmd+Alt+]"):N("CtrlOrCmd+Shift+]")}`,children:Xp})})});var gu,Kv=v(()=>{"use strict";f();ue();je();Ho();he();se();io();ui();ee();gu=H({name:"selectAll",label:"labels.selectAll",icon:Pb,trackEvent:{category:"canvas"},viewMode:!1,perform:(e,t,o,r)=>{if(t.editingLinearElement)return!1;let n=Oa(e.filter(i=>!i.isDeleted&&!(W(i)&&i.containerId)&&!i.locked)).reduce((i,a)=>(i[a.id]=!0,i),{});return{appState:{...t,...to({editingGroupId:null,selectedElementIds:n},be(e),t,r),selectedLinearElement:Object.keys(n).length===1&&ne(e[0])?new $(e[0]):null},commitToHistory:!0}},keyTest:e=>e[I.CTRL_OR_CMD]&&e.key===I.A})});var WL,VL,$v,Xv=v(()=>{"use strict";f();G();WL=e=>{let t=e.slice(),o=new Set,r=i=>{let a=i[0]?.groupIds?.join(""),l=[i[0]],s=[];for(let c of i.slice(1))c.groupIds?.join("")===a?l.push(c):s.push(c);return s.length?[...l,...r(s)]:l},n=new Map;return t.forEach((i,a)=>{if(!n.has(i.id))if(i.groupIds?.length){let l=i.groupIds[i.groupIds.length-1],s=t.slice(a).filter(c=>{let d=c?.groupIds?.some(m=>m===l);return d&&n.set(c.id,!0),d});for(let c of r(s))o.add(c)}else o.add(i)}),o.size!==e.length?(console.error("normalizeGroupElementOrder: lost some elements... bailing!"),e):[...o]},VL=e=>{let t=Cy(e),o=e.slice(),r=new Set;return o.forEach((n,i)=>{n&&(n.boundElements?.length?(r.add(n),o[i]=null,n.boundElements.forEach(a=>{let l=t.get(a.id);l&&a.type==="text"&&(r.add(l[0]),o[l[1]]=null)})):n.type==="text"&&n.containerId&&t.get(n.containerId)?.[0].boundElements?.find(l=>l.id===n.id)||(r.add(n),o[i]=null))}),r.size!==e.length?(console.error("normalizeBoundElementsOrder: lost some elements... bailing!"),e):[...r]},$v=e=>VL(WL(e))});import{jsx as KL}from"react/jsx-runtime";var hu,YL,Zv=v(()=>{"use strict";f();ue();je();he();We();Mt();X();G();io();Ho();_r();U();pt();se();Xv();ee();ao();ui();hu=H({name:"duplicateSelection",label:"labels.duplicateSelection",icon:ts,trackEvent:{category:"element"},perform:(e,t,o,r)=>{let n=r.scene.getNonDeletedElementsMap();if(t.editingLinearElement){let i=$.duplicateSelectedPoints(t,n);return i?{elements:e,appState:i.appState,commitToHistory:!0}:!1}return{...YL(e,t),commitToHistory:!0}},keyTest:e=>e[I.CTRL_OR_CMD]&&e.key===I.D,PanelComponent:({elements:e,appState:t,updateData:o})=>KL(ce,{type:"button",icon:ts,title:`${b("labels.duplicateSelection")} \u2014 ${N("CtrlOrCmd+D")}`,"aria-label":b("labels.duplicateSelection"),onClick:()=>o(null),visible:Ye(be(e),t)})}),YL=(e,t)=>{let o=$v(e),r=new Map,n=[],i=[],a=new Map,l=y=>{let T=Ol(t.editingGroupId,r,y,{x:y.x+An/2,y:y.y+An/2});return a.set(y.id,T.id),i.push(y),n.push(T),T},s=re(de(o,t,{includeBoundTextElement:!0,includeElementsInFrames:!0})),c=new Map,d=y=>{for(let T of y)c.set(T.id,!0);return y},m=[],p=-1;for(;++p<o.length;){let y=o[p];if(c.get(y.id))continue;let T=me(y,re(e)),w=Q(y);if(s.get(y.id)){if(y.groupIds.length||T||w){let S=df(t,y);if(S){let M=ot(o,S).flatMap(k=>Q(k)?[...Vo(e,k.id),k]:[k]);m.push(...d([...M,...M.map(k=>l(k))]));continue}if(T){m.push(...d([y,T,l(y),l(T)]));continue}if(w){let M=Vo(o,y.id);m.push(...d([...M,y,...M.map(k=>l(k)),l(y)]));continue}}(!y.frameId||!s.has(y.frameId))&&m.push(...d([y,l(y)]))}else m.push(...d([y]))}let u=[],g=new Map;for(p=m.length;--p>=0;){let y=m[p];g.get(y.id)||(g.set(y.id,!0),u.push(y))}let x=u.reverse();Om(m,i,a),Dm(m,i,a),Mp(x,i,a);let E=Oa(n);return{elements:x,appState:{...t,...to({editingGroupId:t.editingGroupId,selectedElementIds:E.reduce((y,T)=>(ze(T)||(y[T.id]=!0),y),{})},be(x),t,null)}}}});var $L,we,So=v(()=>{"use strict";f();$L=["ai","command_palette"],we=(e,t,o,r)=>{try{if(typeof window>"u"||C.VITE_WORKER_ID||C.PROD||!$L.includes(e))return;C.PROD||console.info("trackEvent",{category:e,action:t,label:o,value:r}),window.sa_event&&window.sa_event(t,{category:e,label:o,value:r})}catch(n){console.error("error during analytics",n)}}});import jv from"clsx";import{jsx as Vb,jsxs as XL}from"react/jsx-runtime";var cn,qv=v(()=>{"use strict";f();cn=e=>Vb("div",{className:"buttonList buttonListIcon",children:e.options.map(t=>e.type==="button"?Vb("button",{onClick:o=>e.onClick(t.value,o),className:jv({active:t.active??e.value===t.value}),"data-testid":t.testId,title:t.text,children:t.icon},t.text):XL("label",{className:jv({active:e.value===t.value}),title:t.text,children:[Vb("input",{type:"radio",name:e.group,onChange:()=>e.onChange(t.value),checked:e.value===t.value,"data-testid":t.testId}),t.icon]},t.text))})});import ZL from"clsx";import{jsx as Yb}from"react/jsx-runtime";var Jv,Qv=v(()=>{"use strict";f();Wo();Jv=({onChange:e,type:t,activeColor:o,topPicks:r})=>{let n;return t==="elementStroke"&&(n=xp),t==="elementBackground"&&(n=Ep),t==="canvasBackground"&&(n=yp),r&&(n=r),n?Yb("div",{className:"color-picker__top-picks",children:n.map(i=>Yb("button",{className:ZL("color-picker__button",{active:i===o,"is-transparent":i==="transparent"||!i}),style:{"--swatch-color":i},type:"button",title:i,onClick:()=>e(i),"data-testid":`color-top-pick-${i}`,children:Yb("div",{className:"color-picker__button-outline"})},i))}):(console.error("Invalid type for TopPicks"),null)}});import{atom as jL}from"jotai";var _i,Qc,Kb,t3,gr,e3,o3,qn=v(()=>{"use strict";f();Wo();_i=({palette:e,color:t})=>{for(let[o,r]of Object.entries(e))if(Array.isArray(r)){let n=r.indexOf(t);if(n>-1)return{colorName:o,shade:n}}else if(r===t)return{colorName:o,shade:null};return null},Qc=[["q","w","e","r","t"],["a","s","d","f","g"],["z","x","c","v","b"]].flat(),Kb=({color:e,palette:t})=>!Object.values(t).flat().includes(e),t3=(e,t,o)=>{let r={elementBackground:"backgroundColor",elementStroke:"strokeColor"},n=e.filter(a=>{if(a.isDeleted)return!1;let l=a[r[t]];return Kb({color:l,palette:o})}),i=new Map;return n.forEach(a=>{let l=a[r[t]];i.has(l)?i.set(l,i.get(l)+1):i.set(l,1)}),[...i.entries()].sort((a,l)=>l[1]-a[1]).map(a=>a[0]).slice(0,Dw)},gr=jL(null),e3=(e,t,o)=>(e*299+t*587+o*114)/1e3>=160?"black":"white",o3=(e,t)=>{if(t){let i=new Option().style;if(i.color=e,i.color){let a=i.color.replace(/^(rgb|rgba)\(/,"").replace(/\)$/,"").replace(/\s/g,"").split(","),l=parseInt(a[0]),s=parseInt(a[1]),c=parseInt(a[2]);return e3(l,s,c)}}if(e==="transparent")return"black";let o=parseInt(e.substring(1,3),16),r=parseInt(e.substring(3,5),16),n=parseInt(e.substring(5,7),16);return e3(o,r,n)}});import{jsxs as JL}from"react/jsx-runtime";var qL,ls,fu=v(()=>{"use strict";f();qn();qL=({color:e,keyLabel:t,isCustomColor:o=!1,isShade:r=!1})=>JL("div",{className:"color-picker__button__hotkey-label",style:{color:o3(e,o)},children:[r&&"\u21E7",t]}),ls=qL});import QL from"clsx";import{useAtom as e8}from"jotai";import{useEffect as t8,useRef as o8}from"react";import{jsx as ed,jsxs as r3}from"react/jsx-runtime";var n3,i3=v(()=>{"use strict";f();qn();fu();X();n3=({hex:e,onChange:t,palette:o})=>{let r=_i({color:e||"transparent",palette:o}),[n,i]=e8(gr),a=o8(null);if(t8(()=>{a.current&&n==="shades"&&a.current.focus()},[r,n]),r){let{colorName:l,shade:s}=r,c=o[l];if(Array.isArray(c))return ed("div",{className:"color-picker-content--default shades",children:c.map((d,m)=>r3("button",{ref:m===s&&n==="shades"?a:void 0,tabIndex:-1,type:"button",className:QL("color-picker__button color-picker__button--large",{active:m===s}),"aria-label":"Shade",title:`${l} - ${m+1}`,style:d?{"--swatch-color":d}:void 0,onClick:()=>{t(d),i("shades")},children:[ed("div",{className:"color-picker__button-outline"}),ed(ls,{color:d,keyLabel:m+1,isShade:!0})]},m))})}return r3("div",{className:"color-picker-content--default",style:{position:"relative"},tabIndex:-1,children:[ed("button",{type:"button",tabIndex:-1,className:"color-picker__button color-picker__button--large color-picker__button--no-focus-visible"}),ed("div",{tabIndex:-1,style:{position:"absolute",top:0,left:0,right:0,bottom:0,display:"flex",alignItems:"center",justifyContent:"center",textAlign:"center",fontSize:"0.75rem"},children:b("colorPicker.noShades")})]})}});import r8 from"clsx";import{useAtom as n8}from"jotai";import{useEffect as i8,useRef as a8}from"react";import{jsx as $b,jsxs as s8}from"react/jsx-runtime";var l8,a3,l3=v(()=>{"use strict";f();qn();fu();X();l8=({palette:e,color:t,onChange:o,label:r,activeShade:n})=>{let i=_i({color:t||"transparent",palette:e}),[a,l]=n8(gr),s=a8(null);return i8(()=>{s.current&&a==="baseColors"&&s.current.focus()},[i?.colorName,a]),$b("div",{className:"color-picker-content--default",children:Object.entries(e).map(([c,d],m)=>{let p=(Array.isArray(d)?d[n]:d)||"transparent",u=Qc[m],g=b(`colors.${c.replace(/\d+/,"")}`,null,"");return s8("button",{ref:i?.colorName===c?s:void 0,tabIndex:-1,type:"button",className:r8("color-picker__button color-picker__button--large",{active:i?.colorName===c,"is-transparent":p==="transparent"||!p}),onClick:()=>{o(p),l("baseColors")},title:`${g}${p.startsWith("#")?` ${p}`:""} \u2014 ${u}`,"aria-label":`${g} \u2014 ${u}`,style:p?{"--swatch-color":p}:void 0,"data-testid":`color-${c}`,children:[$b("div",{className:"color-picker__button-outline"}),$b(ls,{color:p,keyLabel:u})]},c)})})},a3=l8});import c8 from"clsx";import{useAtom as d8}from"jotai";import{useEffect as m8,useRef as p8}from"react";import{jsx as Xb,jsxs as u8}from"react/jsx-runtime";var s3,c3=v(()=>{"use strict";f();qn();fu();s3=({colors:e,color:t,onChange:o,label:r})=>{let[n,i]=d8(gr),a=p8(null);return m8(()=>{a.current&&a.current.focus()},[t,n]),Xb("div",{className:"color-picker-content--default",children:e.map((l,s)=>u8("button",{ref:t===l?a:void 0,tabIndex:-1,type:"button",className:c8("color-picker__button color-picker__button--large",{active:t===l,"is-transparent":l==="transparent"||!l}),onClick:()=>{o(l),i("custom")},title:l,"aria-label":r,style:{"--swatch-color":l},children:[Xb("div",{className:"color-picker__button-outline"}),Xb(ls,{color:l,keyLabel:s+1,isCustomColor:!0})]},s))})}});var Zb,g8,d3,m3=v(()=>{"use strict";f();ue();Wo();qn();Zb=(e,t,o)=>{let r=Math.ceil(o/La);switch(t=t??-1,e){case"ArrowLeft":{let n=t-1;return n<0?o-1:n}case"ArrowRight":return(t+1)%o;case"ArrowDown":{let n=t+La;return n>=o?t%La:n}case"ArrowUp":{let n=t-La,i=n<0?La*r+n:n;return i>=o?void 0:i}}},g8=({e,colorObj:t,onChange:o,palette:r,customColors:n,setActiveColorPickerSection:i,activeShade:a})=>{if(t?.shade!=null&&["Digit1","Digit2","Digit3","Digit4","Digit5"].includes(e.code)&&e.shiftKey){let l=Number(e.code.slice(-1))-1;return o(r[t.colorName][l]),i("shades"),!0}if(["1","2","3","4","5"].includes(e.key)&&n[Number(e.key)-1])return o(n[Number(e.key)-1]),i("custom"),!0;if(Qc.includes(e.key)){let l=Qc.indexOf(e.key),s=Object.keys(r)[l],c=r[s],d=Array.isArray(c)?c[a]:c;return o(d),i("baseColors"),!0}return!1},d3=({event:e,activeColorPickerSection:t,palette:o,color:r,onChange:n,customColors:i,setActiveColorPickerSection:a,updateData:l,activeShade:s,onEyeDropperToggle:c,onEscape:d})=>{if(e[I.CTRL_OR_CMD])return!1;if(e.key===I.ESCAPE)return d(e),!0;if(e.key===I.ALT)return c(!0),!0;if(e.key===I.I)return c(),!0;let m=_i({color:r,palette:o});if(e.key===I.TAB){let p={custom:!!i.length,baseColors:!0,shades:m?.shade!=null,hex:!0},u=Object.entries(p).reduce((T,[w,S])=>(S&&T.push(w),T),[]),g=u.indexOf(t),x=e.shiftKey?-1:1,E=g+x>u.length-1?0:g+x<0?u.length-1:g+x,y=u[E];return y&&a(y),y==="custom"?n(i[0]):y==="baseColors"&&(Object.entries(o).find(([w,S])=>Array.isArray(S)?S.includes(r):S===r?w:null)||n(ve.charcoal)),e.preventDefault(),e.stopPropagation(),!0}if(g8({e,colorObj:m,onChange:n,palette:o,customColors:i,setActiveColorPickerSection:a,activeShade:s}))return!0;if(t==="shades"&&m){let{shade:p}=m,u=Zb(e.key,p,La);if(u!==void 0)return n(o[m.colorName][u]),!0}if(t==="baseColors"&&m){let{colorName:p}=m,u=Object.keys(o),g=u.indexOf(p),x=Zb(e.key,g,u.length);if(x!==void 0){let E=u[x],y=o[E];return n(Array.isArray(y)?y[s]:y),!0}}if(t==="custom"){let p=i.indexOf(r),u=Zb(e.key,p,i.length);if(u!==void 0){let g=i[u];return n(g),!0}}return!1}});import{jsx as f8}from"react/jsx-runtime";var h8,ss,jb=v(()=>{"use strict";f();h8=({children:e})=>f8("div",{className:"color-picker__heading",children:e}),ss=h8});import p3,{useEffect as u3,useState as b8}from"react";import{useAtom as x8}from"jotai";import{jsx as Ya,jsxs as bu}from"react/jsx-runtime";var g3,h3=v(()=>{"use strict";f();X();i3();l3();c3();m3();jb();qn();Wo();ue();U();g3=({color:e,onChange:t,label:o,type:r,elements:n,palette:i,updateData:a,children:l,onEyeDropperToggle:s,onEscape:c})=>{let[d]=p3.useState(()=>r==="canvasBackground"?[]:t3(n,r,i)),[m,p]=x8(gr),u=_i({color:e,palette:i});u3(()=>{if(!m){let y=Kb({color:e,palette:i}),T=y&&!d.includes(e);p(T?"hex":y?"custom":u?.shade!=null?"shades":"baseColors")}},[m,e,i,p,u,d]);let[g,x]=b8(u?.shade??(r==="elementBackground"?Xl:$l));u3(()=>{u?.shade!=null&&x(u.shade);let y=T=>{T.key===I.ALT&&s(!1)};return document.addEventListener("keyup",y,{capture:!0}),()=>{document.removeEventListener("keyup",y,{capture:!0})}},[u,s]);let E=p3.useRef(null);return Ya("div",{role:"dialog","aria-modal":"true","aria-label":b("labels.colorPicker"),children:bu("div",{ref:E,onKeyDown:y=>{d3({event:y,activeColorPickerSection:m,palette:i,color:e,onChange:t,onEyeDropperToggle:s,customColors:d,setActiveColorPickerSection:p,updateData:a,activeShade:g,onEscape:c})&&(y.preventDefault(),y.stopPropagation())},className:"color-picker-content",tabIndex:-1,children:[!!d.length&&bu("div",{children:[Ya(ss,{children:b("colorPicker.mostUsedCustomColors")}),Ya(s3,{colors:d,color:e,label:b("colorPicker.mostUsedCustomColors"),onChange:t})]}),bu("div",{children:[Ya(ss,{children:b("colorPicker.colors")}),Ya(a3,{color:e,label:o,palette:i,onChange:t,activeShade:g})]}),bu("div",{children:[Ya(ss,{children:b("colorPicker.shades")}),Ya(n3,{hex:e,onChange:t,palette:i})]}),l]})})}});import f3 from"react";var qb,Re,Vt=v(()=>{"use strict";f();qb=f3.createContext(null),Re=()=>f3.useContext(qb)});import{useState as E8,useLayoutEffect as b3}from"react";var xu,Jb=v(()=>{"use strict";f();ye();U();Vt();xu=e=>{let[t,o]=E8(null),r=_e(),{theme:n}=Re(),{container:i}=Wt();return b3(()=>{t&&(t.className="",t.classList.add("excalidraw",...e?.className?.split(/\s+/)||[]),t.classList.toggle("excalidraw--mobile",r.editor.isMobile),t.classList.toggle("theme--dark",n===ie.DARK))},[t,n,r.editor.isMobile,e?.className]),b3(()=>{let a=e?.parentSelector?i?.querySelector(e.parentSelector):document.body;if(!a)return;let l=document.createElement("div");return a.appendChild(l),o(l),()=>{a.removeChild(l)}},[i,e?.parentSelector]),t}});import{useEffect as y8}from"react";function cs(e,t,o){y8(()=>{function r(n){let i=n;if(!e.current)return;let a=o?.(i,e.current);if(a===!0)return;if(a===!1)return t(i);e.current.contains(i.target)||!document.documentElement.contains(i.target)||i.target.closest("[data-radix-portal]")||i.target===document.documentElement&&document.body.style.pointerEvents==="none"||i.target.closest("[data-prevent-outside-click]")||t(i)}return document.addEventListener("pointerdown",r),document.addEventListener("touchstart",r),()=>{document.removeEventListener("pointerdown",r),document.removeEventListener("touchstart",r)}},[e,t,o])}var Eu=v(()=>{"use strict";f();U()});import{useRef as w8}from"react";var ds,yu=v(()=>{"use strict";f();ds=e=>{let t=w8(e);return Object.assign(t.current,e),t.current}});var x3=v(()=>{});import{atom as v8}from"jotai";import{useEffect as T8,useRef as C8}from"react";import{createPortal as I8}from"react-dom";import{jsx as S8}from"react/jsx-runtime";var Pi,E3,td=v(()=>{"use strict";f();Wo();U();Vt();Jb();Eu();ue();We();ye();yu();x3();Pi=v8(null),E3=({onCancel:e,onChange:t,onSelect:o,colorPickerType:r})=>{let n=xu({className:"excalidraw-eye-dropper-backdrop",parentSelector:".excalidraw-eye-dropper-container"}),i=Re(),a=Di(),l=ko(),s=de(a,i),c=ds({app:l,onCancel:e,onChange:t,onSelect:o,selectedElements:s}),{container:d}=Wt();T8(()=>{let p=m.current;if(!p||!l.canvas||!n)return;let u=!1,g=l.canvas.getContext("2d"),x=({clientX:k,clientY:R})=>{let P=g.getImageData((k-i.offsetLeft)*window.devicePixelRatio,(R-i.offsetTop)*window.devicePixelRatio,1,1).data;return Hw(P[0],P[1],P[2])},E=({clientX:k,clientY:R,altKey:P})=>{p.style.top=`${R+20}px`,p.style.left=`${k+20}px`;let F=x({clientX:k,clientY:R});u&&c.onChange(r,F,c.selectedElements,{altKey:P}),p.style.background=F},y=()=>{c.onCancel()},T=(k,R)=>{c.onSelect(k,R)},w=k=>{u=!0,k.stopImmediatePropagation()},S=k=>{u=!1,d?.focus(),k.stopImmediatePropagation(),k.preventDefault(),T(x(k),k)},M=k=>{k.key===I.ESCAPE&&(k.preventDefault(),k.stopImmediatePropagation(),y())};return n.tabIndex=-1,n.focus(),E({clientX:c.app.lastViewportPosition.x,clientY:c.app.lastViewportPosition.y,altKey:!1}),n.addEventListener("keydown",M),n.addEventListener("pointerdown",w),n.addEventListener("pointerup",S),window.addEventListener("pointermove",E,{passive:!0}),window.addEventListener("blur",y),()=>{u=!1,n.removeEventListener("keydown",M),n.removeEventListener("pointerdown",w),n.removeEventListener("pointerup",S),window.removeEventListener("pointermove",E),window.removeEventListener("blur",y)}},[c,l.canvas,n,r,d,i.offsetLeft,i.offsetTop]);let m=C8(null);return cs(m,()=>{e()},p=>!!p.target.closest(".excalidraw-eye-dropper-trigger, .excalidraw-eye-dropper-backdrop")),n?I8(S8("div",{ref:m,className:"excalidraw-eye-dropper-preview"}),n):null}});import{useCallback as k8,useEffect as Qb,useRef as y3,useState as A8}from"react";import{useAtom as w3}from"jotai";import M8 from"clsx";import{Fragment as L8,jsx as wu,jsxs as v3}from"react/jsx-runtime";var T3,C3=v(()=>{"use strict";f();vu();qn();ee();Tt();ue();td();X();ye();G();T3=({color:e,onChange:t,label:o,colorPickerType:r})=>{let n=_e(),[i,a]=A8(e),[l,s]=w3(gr);Qb(()=>{a(e)},[e]);let c=k8(g=>{let x=g.toLowerCase(),E=I3(x);E&&t(E),a(x)},[t]),d=y3(null),m=y3(null);Qb(()=>{d.current&&d.current.focus()},[l]);let[p,u]=w3(Pi,He);return Qb(()=>()=>{u(null)},[u]),v3("div",{className:"color-picker__input-label",children:[wu("div",{className:"color-picker__input-hash",children:"#"}),wu("input",{ref:l==="hex"?d:void 0,style:{border:0,padding:0},spellCheck:!1,className:"color-picker-input","aria-label":o,onChange:g=>{c(g.target.value)},value:(i||"").replace(/^#/,""),onBlur:()=>{a(e)},tabIndex:-1,onFocus:()=>s("hex"),onKeyDown:g=>{g.key!==I.TAB&&(g.key===I.ESCAPE&&m.current?.focus(),g.stopPropagation())}}),!n.editor.isMobile&&v3(L8,{children:[wu("div",{style:{width:"1px",height:"1.25rem",backgroundColor:"var(--default-border-color)"}}),wu("div",{ref:m,className:M8("excalidraw-eye-dropper-trigger",{selected:p}),onClick:()=>u(g=>g?null:{keepOpenOnAlt:!1,onSelect:x=>t(x),colorPickerType:r}),title:`${b("labels.eyeDropper")} \u2014 ${I.I.toLocaleUpperCase()} or ${N("Alt")} `,children:Tb})]})]})}});var S3=v(()=>{});import*as dn from"@radix-ui/react-popover";import{useAtom as k3}from"jotai";import _8 from"clsx";import{useRef as P8}from"react";import{jsx as hr,jsxs as Tu}from"react/jsx-runtime";var A3,I3,D8,R8,od,vu=v(()=>{"use strict";f();G();Qv();h3();qn();ye();Wo();jb();X();Tt();C3();td();S3();A3=e=>{let t=new Option().style;return t.color=e,!!t.color},I3=e=>co(e)?e:A3(`#${e}`)?`#${e}`:A3(e)?e:null,D8=({type:e,color:t,onChange:o,label:r,elements:n,palette:i=ve,updateData:a})=>{let[,l]=k3(gr),[s,c]=k3(Pi,He),{container:d}=Wt(),m=_e(),p=Tu("div",{children:[hr(ss,{children:b("colorPicker.hexCode")}),hr(T3,{color:t,label:r,onChange:x=>{o(x)},colorPickerType:e})]}),u=P8(null),g=()=>{u.current?.querySelector(".color-picker-content")?.focus()};return hr(dn.Portal,{container:d,children:Tu(dn.Content,{ref:u,className:"focus-visible-none","data-prevent-outside-click":!0,onFocusOutside:x=>{g(),x.preventDefault()},onPointerDownOutside:x=>{s&&x.preventDefault()},onCloseAutoFocus:x=>{x.stopPropagation(),x.preventDefault(),d&&!by(document.activeElement)&&d.focus(),a({openPopup:null}),l(null)},side:m.editor.isMobile&&!m.viewport.isLandscape?"bottom":"right",align:m.editor.isMobile&&!m.viewport.isLandscape?"center":"start",alignOffset:-16,sideOffset:20,style:{zIndex:"var(--zIndex-layerUI)",backgroundColor:"var(--popup-bg-color)",maxWidth:"208px",maxHeight:window.innerHeight,padding:"12px",borderRadius:"8px",boxSizing:"border-box",overflowY:"auto",boxShadow:"0px 7px 14px rgba(0, 0, 0, 0.05), 0px 0px 3.12708px rgba(0, 0, 0, 0.0798), 0px 0px 0.931014px rgba(0, 0, 0, 0.1702)"},children:[i?hr(g3,{palette:i,color:t,onChange:x=>{o(x)},onEyeDropperToggle:x=>{c(E=>x?(E=E||{keepOpenOnAlt:!0,onSelect:o,colorPickerType:e},E.keepOpenOnAlt=!0,E):x===!1||E?null:{keepOpenOnAlt:!1,onSelect:o,colorPickerType:e})},onEscape:x=>{s?c(null):rr(x.target)?g():a({openPopup:null})},label:r,type:e,elements:n,updateData:a,children:p}):p,hr(dn.Arrow,{width:20,height:10,style:{fill:"var(--popup-bg-color)",filter:"drop-shadow(rgba(0, 0, 0, 0.05) 0px 3px 2px)"}})]})})},R8=({label:e,color:t,type:o})=>hr(dn.Trigger,{type:"button",className:_8("color-picker__button active-color",{"is-transparent":t==="transparent"||!t}),"aria-label":e,style:t?{"--swatch-color":t}:void 0,title:o==="elementStroke"?b("labels.showStroke"):b("labels.showBackground"),children:hr("div",{className:"color-picker__button-outline"})}),od=({type:e,color:t,onChange:o,label:r,elements:n,palette:i=ve,topPicks:a,updateData:l,appState:s})=>hr("div",{children:Tu("div",{role:"dialog","aria-modal":"true",className:"color-picker-container",children:[hr(Jv,{activeColor:t,onChange:o,type:e,topPicks:a}),hr("div",{style:{width:1,height:"100%",backgroundColor:"var(--default-border-color)",margin:"0 auto"}}),Tu(dn.Root,{open:s.openPopup===e,onOpenChange:c=>{l({openPopup:c?e:null})},children:[hr(R8,{color:t,label:r,type:e}),s.openPopup===e&&hr(D8,{type:e,color:t,onChange:o,label:r,elements:n,palette:i,updateData:l})]})]})})});var M3=v(()=>{});import{useLayoutEffect as N8,useRef as L3,useEffect as _3}from"react";import{unstable_batchedUpdates as O8}from"react-dom";import{jsx as B8}from"react/jsx-runtime";var Cu,ex=v(()=>{"use strict";f();M3();G();ue();Cu=({children:e,left:t,top:o,onCloseRequest:r,fitInViewport:n=!1,offsetLeft:i=0,offsetTop:a=0,viewportWidth:l=window.innerWidth,viewportHeight:s=window.innerHeight})=>{let c=L3(null);_3(()=>{let m=c.current;if(!m)return;m.contains(document.activeElement)||m.focus();let p=u=>{if(u.key===I.TAB){let g=Ys(m),{activeElement:x}=document,E=g.findIndex(y=>y===x);x===m?(u.shiftKey?g[g.length-1]?.focus():g[0].focus(),u.preventDefault(),u.stopImmediatePropagation()):E===0&&u.shiftKey?(g[g.length-1]?.focus(),u.preventDefault(),u.stopImmediatePropagation()):E===g.length-1&&!u.shiftKey&&(g[0]?.focus(),u.preventDefault(),u.stopImmediatePropagation())}};return m.addEventListener("keydown",p),()=>m.removeEventListener("keydown",p)},[]);let d=L3(null);return N8(()=>{if(n&&c.current&&o!=null&&t!=null){let m=c.current,{width:p,height:u}=m.getBoundingClientRect();if(d.current?.top===o&&d.current?.left===t)return;d.current={top:o,left:t},p>=l?(m.style.width=`${l}px`,m.style.left="0px",m.style.overflowX="scroll"):t+p-i>l?m.style.left=`${l-p-10}px`:m.style.left=`${t}px`,u>=s?(m.style.height=`${s-20}px`,m.style.top="10px",m.style.overflowY="scroll"):o+u-a>s?m.style.top=`${s-u}px`:m.style.top=`${o}px`}},[o,t,n,l,s,i,a]),_3(()=>{if(r){let m=p=>{c.current?.contains(p.target)||O8(()=>r(p))};return document.addEventListener("pointerdown",m,!1),()=>document.removeEventListener("pointerdown",m,!1)}},[r]),B8("div",{className:"popover",ref:c,tabIndex:-1,children:e})}});var P3=v(()=>{});import Ka from"react";import F8 from"clsx";import{Fragment as z8,jsx as Ri,jsxs as tx}from"react/jsx-runtime";function H8({options:e,value:t,label:o,onChange:r,onClose:n}){let i=Ka.useRef(),a=Ka.useRef(),l=Ka.useRef(null);return Ka.useEffect(()=>{a.current?a.current.focus():l.current&&l.current.focus()},[]),Ri("div",{className:"picker",role:"dialog","aria-modal":"true","aria-label":o,onKeyDown:c=>{let d=e.find(m=>m.keyBinding===c.key.toLowerCase());if(!(c.metaKey||c.altKey||c.ctrlKey)&&d){let m=e.indexOf(d);l.current.children[m].focus(),c.preventDefault()}else if(c.key===I.TAB)setTimeout(()=>{let m=a.current,p=document.activeElement;m!==p&&n()},0);else if(Sl(c.key)){let{activeElement:m}=document,p=Cn().rtl,u=Array.prototype.indexOf.call(l.current.children,m);if(u!==-1){let g=e.length,x=u;switch(c.key){case(p?I.ARROW_LEFT:I.ARROW_RIGHT):case I.ARROW_DOWN:{x=(u+1)%g;break}case(p?I.ARROW_RIGHT:I.ARROW_LEFT):case I.ARROW_UP:{x=(g+u-1)%g;break}}l.current.children[x].focus()}c.preventDefault()}else(c.key===I.ESCAPE||c.key===I.ENTER)&&(c.preventDefault(),n());c.nativeEvent.stopImmediatePropagation(),c.stopPropagation()},children:Ri("div",{className:"picker-content",ref:l,children:e.map((c,d)=>tx("button",{className:F8("picker-option",{active:t===c.value}),onClick:m=>{m.currentTarget.focus(),r(c.value)},title:`${c.text} ${c.keyBinding&&`\u2014 ${c.keyBinding.toUpperCase()}`}`,"aria-label":c.text||"none","aria-keyshortcuts":c.keyBinding||void 0,ref:m=>{m&&d===0&&(i.current=m),m&&c.value===t&&(a.current=m)},onFocus:()=>{r(c.value)},children:[c.icon,c.keyBinding&&Ri("span",{className:"picker-keybinding",children:c.keyBinding})]},c.text))})})}function ox({value:e,label:t,options:o,onChange:r,group:n=""}){let[i,a]=Ka.useState(!1),l=Ka.useRef(null),s=Cn().rtl;return tx("div",{children:[Ri("button",{name:n,className:i?"active":"","aria-label":t,onClick:()=>a(!i),ref:l,children:o.find(c=>c.value===e)?.icon}),Ri(Ka.Suspense,{fallback:"",children:i?tx(z8,{children:[Ri(Cu,{onCloseRequest:c=>c.target!==l.current&&a(!1),...s?{right:5.5}:{left:-5.5},children:Ri(H8,{options:o.filter(c=>c.showInPicker!==!1),value:e,label:t,onChange:r,onClose:()=>{a(!1),l.current?.focus()}})}),Ri("div",{className:"picker-triangle"})]}):null})]})}var D3=v(()=>{"use strict";f();ex();P3();ue();X()});import{Fragment as K3,jsx as Ae,jsxs as Ko}from"react/jsx-runtime";var N3,$o,Ao,G8,rx,O3,B3,F3,H3,z3,EZ,G3,U3,nx,ix,W3,V3,Y3,yZ,R3,wZ,ax=v(()=>{"use strict";f();Wo();So();qv();vu();D3();ee();U();he();Ze();pt();se();X();ue();Sr();We();nc();G();je();N3=.1,$o=(e,t,o,r=!1)=>{let n=re(de(e,t,{includeBoundTextElement:r}));return e.map(i=>n.get(i.id)||i.id===t.editingElement?.id?o(i):i)},Ao=function(e,t,o,r,n){let i=t.editingElement,a=be(e),l=null;return i&&(l=o(i)),l||(Ye(a,t)?l=n1(r===!0?a:a.filter(c=>r(c)),t,o)??(typeof n=="function"?n(!0):n):l=typeof n=="function"?n(!1):n),l},G8=(e,t)=>ze(t)?t:z(t,{x:e.textAlign==="left"?e.x:e.x+(e.width-t.width)/(e.textAlign==="center"?2:1),y:e.y+(e.height-t.height)/2},!1),rx=(e,t,o,r,n)=>{let i=new Set;return{elements:$o(e,t,a=>{if(W(a)){let l=r(a);i.add(l);let s=ae(a,{fontSize:l});return eo(s,o.scene.getContainerElement(a),o.scene.getNonDeletedElementsMap()),s=G8(a,s),s}return a},!0),appState:{...t,currentItemFontSize:i.size===1?[...i][0]:n??t.currentItemFontSize},commitToHistory:!0}},O3=H({name:"changeStrokeColor",label:"labels.stroke",trackEvent:!1,perform:(e,t,o)=>({...o.currentItemStrokeColor&&{elements:$o(e,t,r=>rc(r.type)?ae(r,{strokeColor:o.currentItemStrokeColor}):r,!0)},appState:{...t,...o},commitToHistory:!!o.currentItemStrokeColor}),PanelComponent:({elements:e,appState:t,updateData:o,appProps:r})=>Ko(K3,{children:[Ae("h3",{"aria-hidden":"true",children:b("labels.stroke")}),Ae(od,{topPicks:xp,palette:Ow,type:"elementStroke",label:b("labels.stroke"),color:Ao(e,t,n=>n.strokeColor,!0,t.currentItemStrokeColor),onChange:n=>o({currentItemStrokeColor:n}),elements:e,appState:t,updateData:o})]})}),B3=H({name:"changeBackgroundColor",label:"labels.changeBackground",trackEvent:!1,perform:(e,t,o)=>({...o.currentItemBackgroundColor&&{elements:$o(e,t,r=>ae(r,{backgroundColor:o.currentItemBackgroundColor}))},appState:{...t,...o},commitToHistory:!!o.currentItemBackgroundColor}),PanelComponent:({elements:e,appState:t,updateData:o,appProps:r})=>Ko(K3,{children:[Ae("h3",{"aria-hidden":"true",children:b("labels.background")}),Ae(od,{topPicks:Ep,palette:Bw,type:"elementBackground",label:b("labels.background"),color:Ao(e,t,n=>n.backgroundColor,!0,t.currentItemBackgroundColor),onChange:n=>o({currentItemBackgroundColor:n}),elements:e,appState:t,updateData:o})]})}),F3=H({name:"changeFillStyle",label:"labels.fill",trackEvent:!1,perform:(e,t,o,r)=>(we("element","changeFillStyle",`${o} (${r.device.editor.isMobile?"mobile":"desktop"})`),{elements:$o(e,t,n=>ae(n,{fillStyle:o})),appState:{...t,currentItemFillStyle:o},commitToHistory:!0}),PanelComponent:({elements:e,appState:t,updateData:o})=>{let r=de(e,t),n=r.length>0&&r.every(i=>i.fillStyle==="zigzag");return Ko("fieldset",{children:[Ae("legend",{children:b("labels.fill")}),Ae(cn,{type:"button",options:[{value:"hachure",text:`${n?b("labels.zigzag"):b("labels.hachure")} (${N("Alt-Click")})`,icon:n?z1:G1,active:n?!0:void 0,testId:"fill-hachure"},{value:"cross-hatch",text:b("labels.crossHatch"),icon:U1,testId:"fill-cross-hatch"},{value:"solid",text:b("labels.solid"),icon:W1,testId:"fill-solid"}],value:Ao(e,t,i=>i.fillStyle,i=>i.hasOwnProperty("fillStyle"),i=>i?null:t.currentItemFillStyle),onClick:(i,a)=>{let l=a.altKey&&i==="hachure"&&r.every(s=>s.fillStyle==="hachure")?"zigzag":i;o(l)}})]})}}),H3=H({name:"changeStrokeWidth",label:"labels.strokeWidth",trackEvent:!1,perform:(e,t,o)=>({elements:$o(e,t,r=>ae(r,{strokeWidth:o})),appState:{...t,currentItemStrokeWidth:o},commitToHistory:!0}),PanelComponent:({elements:e,appState:t,updateData:o})=>Ko("fieldset",{children:[Ae("legend",{children:b("labels.strokeWidth")}),Ae(cn,{group:"stroke-width",options:[{value:dm.thin,text:b("labels.thin"),icon:nu,testId:"strokeWidth-thin"},{value:dm.bold,text:b("labels.bold"),icon:V1,testId:"strokeWidth-bold"},{value:dm.extraBold,text:b("labels.extraBold"),icon:Y1,testId:"strokeWidth-extraBold"}],value:Ao(e,t,r=>r.strokeWidth,r=>r.hasOwnProperty("strokeWidth"),r=>r?null:t.currentItemStrokeWidth),onChange:r=>o(r)})]})}),z3=H({name:"changeSloppiness",label:"labels.sloppiness",trackEvent:!1,perform:(e,t,o)=>({elements:$o(e,t,r=>ae(r,{seed:ar(),roughness:o})),appState:{...t,currentItemRoughness:o},commitToHistory:!0}),PanelComponent:({elements:e,appState:t,updateData:o})=>Ko("fieldset",{children:[Ae("legend",{children:b("labels.sloppiness")}),Ae(cn,{group:"sloppiness",options:[{value:0,text:b("labels.architect"),icon:X1},{value:1,text:b("labels.artist"),icon:Z1},{value:2,text:b("labels.cartoonist"),icon:j1}],value:Ao(e,t,r=>r.roughness,r=>r.hasOwnProperty("roughness"),r=>r?null:t.currentItemRoughness),onChange:r=>o(r)})]})}),EZ=H({name:"changeStrokeStyle",label:"labels.strokeStyle",trackEvent:!1,perform:(e,t,o)=>({elements:$o(e,t,r=>ae(r,{strokeStyle:o})),appState:{...t,currentItemStrokeStyle:o},commitToHistory:!0}),PanelComponent:({elements:e,appState:t,updateData:o})=>Ko("fieldset",{children:[Ae("legend",{children:b("labels.strokeStyle")}),Ae(cn,{group:"strokeStyle",options:[{value:"solid",text:b("labels.strokeStyle_solid"),icon:nu},{value:"dashed",text:b("labels.strokeStyle_dashed"),icon:K1},{value:"dotted",text:b("labels.strokeStyle_dotted"),icon:$1}],value:Ao(e,t,r=>r.strokeStyle,r=>r.hasOwnProperty("strokeStyle"),r=>r?null:t.currentItemStrokeStyle),onChange:r=>o(r)})]})}),G3=H({name:"changeOpacity",label:"labels.opacity",trackEvent:!1,perform:(e,t,o)=>({elements:$o(e,t,r=>ae(r,{opacity:o}),!0),appState:{...t,currentItemOpacity:o},commitToHistory:!0}),PanelComponent:({elements:e,appState:t,updateData:o})=>Ko("label",{className:"control-label",children:[b("labels.opacity"),Ae("input",{type:"range",min:"0",max:"100",step:"10",onChange:r=>o(+r.target.value),value:Ao(e,t,r=>r.opacity,!0,t.currentItemOpacity)??void 0})]})}),U3=H({name:"changeFontSize",label:"labels.fontSize",trackEvent:!1,perform:(e,t,o,r)=>rx(e,t,r,()=>o,o),PanelComponent:({elements:e,appState:t,updateData:o,app:r})=>Ko("fieldset",{children:[Ae("legend",{children:b("labels.fontSize")}),Ae(cn,{group:"font-size",options:[{value:16,text:b("labels.small"),icon:lb,testId:"fontSize-small"},{value:20,text:b("labels.medium"),icon:sb,testId:"fontSize-medium"},{value:28,text:b("labels.large"),icon:cb,testId:"fontSize-large"},{value:36,text:b("labels.veryLarge"),icon:db,testId:"fontSize-veryLarge"}],value:Ao(e,t,n=>{if(W(n))return n.fontSize;let i=me(n,r.scene.getNonDeletedElementsMap());return i?i.fontSize:null},n=>W(n)||me(n,r.scene.getNonDeletedElementsMap())!==null,n=>n?null:t.currentItemFontSize||Rt),onChange:n=>o(n)})]})}),nx=H({name:"decreaseFontSize",label:"labels.decreaseFontSize",icon:au,trackEvent:!1,perform:(e,t,o,r)=>rx(e,t,r,n=>Math.round(1/(1+N3)*n.fontSize)),keyTest:e=>e[I.CTRL_OR_CMD]&&e.shiftKey&&(e.key===I.CHEVRON_LEFT||e.key===I.COMMA)}),ix=H({name:"increaseFontSize",label:"labels.increaseFontSize",icon:au,trackEvent:!1,perform:(e,t,o,r)=>rx(e,t,r,n=>Math.round(n.fontSize*(1+N3))),keyTest:e=>e[I.CTRL_OR_CMD]&&e.shiftKey&&(e.key===I.CHEVRON_RIGHT||e.key===I.PERIOD)}),W3=H({name:"changeFontFamily",label:"labels.fontFamily",trackEvent:!1,perform:(e,t,o,r)=>({elements:$o(e,t,n=>{if(W(n)){let i=ae(n,{fontFamily:o,lineHeight:Oo(o)});return eo(i,r.scene.getContainerElement(n),r.scene.getNonDeletedElementsMap()),i}return n},!0),appState:{...t,currentItemFontFamily:o},commitToHistory:!0}),PanelComponent:({elements:e,appState:t,updateData:o,app:r})=>{let n=[{value:dt.Virgil,text:b("labels.handDrawn"),icon:Ha,testId:"font-family-virgil"},{value:dt.Helvetica,text:b("labels.normal"),icon:mb,testId:"font-family-normal"},{value:dt.Cascadia,text:b("labels.code"),icon:pb,testId:"font-family-code"}];return Ko("fieldset",{children:[Ae("legend",{children:b("labels.fontFamily")}),Ae(cn,{group:"font-family",options:n,value:Ao(e,t,i=>{if(W(i))return i.fontFamily;let a=me(i,r.scene.getNonDeletedElementsMap());return a?a.fontFamily:null},i=>W(i)||me(i,r.scene.getNonDeletedElementsMap())!==null,i=>i?null:t.currentItemFontFamily||qt),onChange:i=>o(i)})]})}}),V3=H({name:"changeTextAlign",label:"Change text alignment",trackEvent:!1,perform:(e,t,o,r)=>({elements:$o(e,t,n=>{if(W(n)){let i=ae(n,{textAlign:o});return eo(i,r.scene.getContainerElement(n),r.scene.getNonDeletedElementsMap()),i}return n},!0),appState:{...t,currentItemTextAlign:o},commitToHistory:!0}),PanelComponent:({elements:e,appState:t,updateData:o,app:r})=>{let n=r.scene.getNonDeletedElementsMap();return Ko("fieldset",{children:[Ae("legend",{children:b("labels.textAlign")}),Ae(cn,{group:"text-align",options:[{value:"left",text:b("labels.left"),icon:ub,testId:"align-left"},{value:"center",text:b("labels.center"),icon:gb,testId:"align-horizontal-center"},{value:"right",text:b("labels.right"),icon:hb,testId:"align-right"}],value:Ao(e,t,i=>{if(W(i))return i.textAlign;let a=me(i,n);return a?a.textAlign:null},i=>W(i)||me(i,n)!==null,i=>i?null:t.currentItemTextAlign),onChange:i=>o(i)})]})}}),Y3=H({name:"changeVerticalAlign",label:"Change vertical alignment",trackEvent:{category:"element"},perform:(e,t,o,r)=>({elements:$o(e,t,n=>{if(W(n)){let i=ae(n,{verticalAlign:o});return eo(i,r.scene.getContainerElement(n),r.scene.getNonDeletedElementsMap()),i}return n},!0),appState:{...t},commitToHistory:!0}),PanelComponent:({elements:e,appState:t,updateData:o,app:r})=>Ae("fieldset",{children:Ae(cn,{group:"text-align",options:[{value:yt.TOP,text:b("labels.alignTop"),icon:Ae(fb,{theme:t.theme}),testId:"align-top"},{value:yt.MIDDLE,text:b("labels.centerVertically"),icon:Ae(xb,{theme:t.theme}),testId:"align-middle"},{value:yt.BOTTOM,text:b("labels.alignBottom"),icon:Ae(bb,{theme:t.theme}),testId:"align-bottom"}],value:Ao(e,t,n=>{if(W(n)&&n.containerId)return n.verticalAlign;let i=me(n,r.scene.getNonDeletedElementsMap());return i?i.verticalAlign:null},n=>W(n)||me(n,r.scene.getNonDeletedElementsMap())!==null,n=>n?null:yt.MIDDLE),onChange:n=>o(n)})})}),yZ=H({name:"changeRoundness",label:"Change edge roundness",trackEvent:!1,perform:(e,t,o)=>({elements:$o(e,t,r=>ae(r,{roundness:o==="round"?{type:qr(r.type)?at.ADAPTIVE_RADIUS:at.PROPORTIONAL_RADIUS}:null})),appState:{...t,currentItemRoundness:o},commitToHistory:!0}),PanelComponent:({elements:e,appState:t,updateData:o})=>{let n=Ba(be(e),t).some(i=>i.roundness?.type===at.LEGACY);return Ko("fieldset",{children:[Ae("legend",{children:b("labels.edges")}),Ae(cn,{group:"edges",options:[{value:"sharp",text:b("labels.sharp"),icon:q1},{value:"round",text:b("labels.round"),icon:J1}],value:Ao(e,t,i=>n?null:i.roundness?"round":"sharp",i=>i.hasOwnProperty("roundness"),i=>i?null:t.currentItemRoundness),onChange:i=>o(i)})]})}}),R3=e=>[{value:null,text:b("labels.arrowhead_none"),keyBinding:"q",icon:Q1},{value:"arrow",text:b("labels.arrowhead_arrow"),keyBinding:"w",icon:Ae(eb,{flip:e})},{value:"bar",text:b("labels.arrowhead_bar"),keyBinding:"e",icon:Ae(ob,{flip:e})},{value:"dot",text:b("labels.arrowhead_circle"),keyBinding:null,icon:Ae(iu,{flip:e}),showInPicker:!1},{value:"circle",text:b("labels.arrowhead_circle"),keyBinding:"r",icon:Ae(iu,{flip:e}),showInPicker:!1},{value:"circle_outline",text:b("labels.arrowhead_circle_outline"),keyBinding:null,icon:Ae(tb,{flip:e}),showInPicker:!1},{value:"triangle",text:b("labels.arrowhead_triangle"),icon:Ae(rb,{flip:e}),keyBinding:"t"},{value:"triangle_outline",text:b("labels.arrowhead_triangle_outline"),icon:Ae(nb,{flip:e}),keyBinding:null,showInPicker:!1},{value:"diamond",text:b("labels.arrowhead_diamond"),icon:Ae(ib,{flip:e}),keyBinding:null,showInPicker:!1},{value:"diamond_outline",text:b("labels.arrowhead_diamond_outline"),icon:Ae(ab,{flip:e}),keyBinding:null,showInPicker:!1}],wZ=H({name:"changeArrowhead",label:"Change arrowheads",trackEvent:!1,perform:(e,t,o)=>({elements:$o(e,t,r=>{if(ne(r)){let{position:n,type:i}=o;if(n==="start")return ae(r,{startArrowhead:i});if(n==="end")return ae(r,{endArrowhead:i})}return r}),appState:{...t,[o.position==="start"?"currentItemStartArrowhead":"currentItemEndArrowhead"]:o.type},commitToHistory:!0}),PanelComponent:({elements:e,appState:t,updateData:o})=>{let r=Cn().rtl;return Ko("fieldset",{children:[Ae("legend",{children:b("labels.arrowheads")}),Ko("div",{className:"iconSelectList buttonList",children:[Ae(ox,{label:"arrowhead_start",options:R3(!r),value:Ao(e,t,n=>ne(n)&&pa(n.type)?n.startArrowhead:t.currentItemStartArrowhead,!0,t.currentItemStartArrowhead),onChange:n=>o({position:"start",type:n})}),Ae(ox,{label:"arrowhead_end",group:"arrowheads",options:R3(!!r),value:Ao(e,t,n=>ne(n)&&pa(n.type)?n.endArrowhead:t.currentItemEndArrowhead,!0,t.currentItemEndArrowhead),onChange:n=>o({position:"end",type:n})})]})]})}})});var $3=v(()=>{});import{useEffect as U8}from"react";import{jsx as V8}from"react/jsx-runtime";var ms,lx,W8,Xo,Ni=v(()=>{"use strict";f();$3();ms=()=>{let e=document.querySelector(".excalidraw-tooltip");if(e)return e;let t=document.createElement("div");return document.body.appendChild(t),t.classList.add("excalidraw-tooltip"),t},lx=(e,t,o="bottom")=>{let r=e.getBoundingClientRect(),n=window.innerWidth,i=window.innerHeight,a=5,l=t.left+t.width/2-r.width/2;l<0?l=a:l+r.width>=n&&(l=n-r.width-a);let s;o==="bottom"?(s=t.top+t.height+a,s+r.height>=i&&(s=t.top-r.height-a)):(s=t.top-r.height-a,s<0&&(s=t.top+t.height+a)),Object.assign(e.style,{top:`${s}px`,left:`${l}px`})},W8=(e,t,o,r)=>{t.classList.add("excalidraw-tooltip--visible"),t.style.minWidth=r?"50ch":"10ch",t.style.maxWidth=r?"50ch":"15ch",t.textContent=o;let n=e.getBoundingClientRect();lx(t,n)},Xo=({children:e,label:t,long:o=!1,style:r,disabled:n})=>(U8(()=>()=>ms().classList.remove("excalidraw-tooltip--visible"),[]),n?null:V8("div",{className:"excalidraw-tooltip-wrapper",onPointerEnter:i=>W8(i.currentTarget,ms(),t,o),onPointerLeave:()=>ms().classList.remove("excalidraw-tooltip--visible"),style:r,children:e}))});import{jsx as Iu,jsxs as K8}from"react/jsx-runtime";var X3,mn,rd,nd,Z3,Y8,j3,id,jZ,qZ,q3,Oi,JZ,J3,ad=v(()=>{"use strict";f();vu();ee();Mt();U();he();X();ue();We();a1();zp();G();je();Ni();Ze();Fo();Wo();Rl();X3=H({name:"changeViewBackgroundColor",label:"labels.canvasBackground",paletteName:"Change canvas background color",trackEvent:!1,predicate:(e,t,o,r)=>!!r.props.UIOptions.canvasActions.changeViewBackgroundColor&&!t.viewModeEnabled,perform:(e,t,o)=>({appState:{...t,...o},commitToHistory:!!o.viewBackgroundColor}),PanelComponent:({elements:e,appState:t,updateData:o,appProps:r})=>Iu(od,{palette:null,topPicks:yp,label:b("labels.canvasBackground"),type:"canvasBackground",color:t.viewBackgroundColor,onChange:n=>o({viewBackgroundColor:n}),"data-testid":"canvas-background-picker",elements:e,appState:t,updateData:o})}),mn=H({name:"clearCanvas",label:"labels.clearCanvas",paletteName:"Clear canvas",icon:ur,trackEvent:{category:"canvas"},predicate:(e,t,o,r)=>!!r.props.UIOptions.canvasActions.clearCanvas&&!t.viewModeEnabled,perform:(e,t,o,r)=>(r.imageCache.clear(),{elements:e.map(n=>ae(n,{isDeleted:!0})),appState:{...Bo(),files:{},theme:t.theme,penMode:t.penMode,penDetected:t.penDetected,exportBackground:t.exportBackground,exportEmbedScene:t.exportEmbedScene,gridSize:t.gridSize,showStats:t.showStats,pasteDialog:t.pasteDialog,activeTool:t.activeTool.type==="image"?{...t.activeTool,type:"selection"}:t.activeTool},commitToHistory:!0})}),rd=H({name:"zoomIn",label:"buttons.zoomIn",viewMode:!0,icon:Gp,trackEvent:{category:"canvas"},perform:(e,t,o,r)=>({appState:{...t,...Zn({viewportX:t.width/2+t.offsetLeft,viewportY:t.height/2+t.offsetTop,nextZoom:sn(t.zoom.value+la)},t),userToFollow:null},commitToHistory:!1}),PanelComponent:({updateData:e})=>Iu(ce,{type:"button",className:"zoom-in-button zoom-button",icon:Gp,title:`${b("buttons.zoomIn")} \u2014 ${N("CtrlOrCmd++")}`,"aria-label":b("buttons.zoomIn"),onClick:()=>{e(null)}}),keyTest:e=>(e.code===fe.EQUAL||e.code===fe.NUM_ADD)&&(e[I.CTRL_OR_CMD]||e.shiftKey)}),nd=H({name:"zoomOut",label:"buttons.zoomOut",icon:Up,viewMode:!0,trackEvent:{category:"canvas"},perform:(e,t,o,r)=>({appState:{...t,...Zn({viewportX:t.width/2+t.offsetLeft,viewportY:t.height/2+t.offsetTop,nextZoom:sn(t.zoom.value-la)},t),userToFollow:null},commitToHistory:!1}),PanelComponent:({updateData:e})=>Iu(ce,{type:"button",className:"zoom-out-button zoom-button",icon:Up,title:`${b("buttons.zoomOut")} \u2014 ${N("CtrlOrCmd+-")}`,"aria-label":b("buttons.zoomOut"),onClick:()=>{e(null)}}),keyTest:e=>(e.code===fe.MINUS||e.code===fe.NUM_SUBTRACT)&&(e[I.CTRL_OR_CMD]||e.shiftKey)}),Z3=H({name:"resetZoom",label:"buttons.resetZoom",icon:I1,viewMode:!0,trackEvent:{category:"canvas"},perform:(e,t,o,r)=>({appState:{...t,...Zn({viewportX:t.width/2+t.offsetLeft,viewportY:t.height/2+t.offsetTop,nextZoom:sn(1)},t),userToFollow:null},commitToHistory:!1}),PanelComponent:({updateData:e,appState:t})=>Iu(Xo,{label:b("buttons.resetZoom"),style:{height:"100%"},children:K8(ce,{type:"button",className:"reset-zoom-button zoom-button",title:b("buttons.resetZoom"),"aria-label":b("buttons.resetZoom"),onClick:()=>{e(null)},children:[(t.zoom.value*100).toFixed(0),"%"]})}),keyTest:e=>(e.code===fe.ZERO||e.code===fe.NUM_ZERO)&&(e[I.CTRL_OR_CMD]||e.shiftKey)}),Y8=(e,t)=>{let[o,r,n,i]=e,a=n-o,l=t.width/a,s=i-r,c=t.height/s,d=Math.min(l,c),m=Math.floor(d/la)*la;return Math.min(Math.max(m,im),1)},j3=({bounds:e,appState:t,fitToViewport:o=!1,viewportZoomFactor:r=.7})=>{let[n,i,a,l]=e,s=(n+a)/2,c=(i+l)/2,d,m,p;if(o){let u=a-n,g=l-i;d=Math.min(t.width/u,t.height/g)*Math.min(1,Math.max(r,.1)),d=Math.min(Math.max(d,.1),30);let x=t.width;if(t.openSidebar){let y=document.querySelector(".sidebar")?.offsetWidth??0;x=document.documentElement.getAttribute("dir")==="rtl"?t.width+y:t.width-y}m=x/2*(1/d)-s,p=t.height/2*(1/d)-c}else{d=Y8(e,{width:t.width,height:t.height});let u=i1({scenePoint:{x:s,y:c},viewportDimensions:{width:t.width,height:t.height},zoom:{value:d}});m=u.scrollX,p=u.scrollY}return{appState:{...t,scrollX:m,scrollY:p,zoom:{value:d}},commitToHistory:!1}},id=({targetElements:e,appState:t,fitToViewport:o,viewportZoomFactor:r})=>{let n=Se(be(e));return j3({bounds:n,appState:t,fitToViewport:o,viewportZoomFactor:r})},jZ=H({name:"zoomToFitSelectionInViewport",label:"labels.zoomToFitViewport",icon:Jc,trackEvent:{category:"canvas"},perform:(e,t,o,r)=>{let n=r.scene.getSelectedElements(t);return id({targetElements:n.length?n:e,appState:{...t,userToFollow:null},fitToViewport:!1})},keyTest:e=>e.code===fe.TWO&&e.shiftKey&&!e.altKey&&!e[I.CTRL_OR_CMD]}),qZ=H({name:"zoomToFitSelection",label:"helpDialog.zoomToSelection",icon:Jc,trackEvent:{category:"canvas"},perform:(e,t,o,r)=>{let n=r.scene.getSelectedElements(t);return id({targetElements:n.length?n:e,appState:{...t,userToFollow:null},fitToViewport:!0})},keyTest:e=>e.code===fe.THREE&&e.shiftKey&&!e.altKey&&!e[I.CTRL_OR_CMD]}),q3=H({name:"zoomToFit",label:"helpDialog.zoomToFit",icon:Jc,viewMode:!0,trackEvent:{category:"canvas"},perform:(e,t)=>id({targetElements:e,appState:{...t,userToFollow:null},fitToViewport:!1}),keyTest:e=>e.code===fe.ONE&&e.shiftKey&&!e.altKey&&!e[I.CTRL_OR_CMD]}),Oi=H({name:"toggleTheme",label:(e,t)=>t.theme===ie.DARK?"buttons.lightMode":"buttons.darkMode",keywords:["toggle","dark","light","mode","theme"],icon:e=>e.theme===ie.LIGHT?os:rs,viewMode:!0,trackEvent:{category:"canvas"},perform:(e,t,o)=>({appState:{...t,theme:o||(t.theme===ie.LIGHT?ie.DARK:ie.LIGHT)},commitToHistory:!1}),keyTest:e=>e.altKey&&e.shiftKey&&e.code===fe.D,predicate:(e,t,o,r)=>!!r.props.UIOptions.canvasActions.toggleTheme}),JZ=H({name:"toggleEraserTool",label:"toolBar.eraser",trackEvent:{category:"toolbar"},perform:(e,t)=>{let o;return To(t)?o=Qe(t,{...t.activeTool.lastActiveTool||{type:"selection"},lastActiveToolBeforeEraser:null}):o=Qe(t,{type:"eraser",lastActiveToolBeforeEraser:t.activeTool}),{appState:{...t,selectedElementIds:{},selectedGroupIds:{},activeEmbeddable:null,activeTool:o},commitToHistory:!0}},keyTest:e=>e.key===I.E}),J3=H({name:"toggleHandTool",label:"toolBar.hand",paletteName:"Toggle hand tool",trackEvent:{category:"toolbar"},icon:Yc,viewMode:!1,perform:(e,t,o,r)=>{let n;return Rr(t)?n=Qe(t,{...t.activeTool.lastActiveTool||{type:"selection"},lastActiveToolBeforeEraser:null}):(n=Qe(t,{type:"hand",lastActiveToolBeforeEraser:t.activeTool}),Ve(r.interactiveCanvas,Pe.GRAB)),{appState:{...t,selectedElementIds:{},selectedGroupIds:{},activeEmbeddable:null,activeTool:n},commitToHistory:!0}},keyTest:e=>!e.altKey&&!e[I.CTRL_OR_CMD]&&e.key===I.H})});import{jsx as $8}from"react/jsx-runtime";var Zo,Q3=v(()=>{"use strict";f();ue();he();G();Mt();ee();X();je();Ze();Qt();io();_n();_r();se();Rl();Zo=H({name:"finalize",label:"",trackEvent:!1,perform:(e,t,o,{interactiveCanvas:r,focusContainer:n,scene:i})=>{let a=i.getNonDeletedElementsMap();if(t.editingLinearElement){let{elementId:m,startBindingElement:p,endBindingElement:u}=t.editingLinearElement,g=$.getElement(m,a);if(g)return kt(g)&&Rn(g,p,u,a),{elements:g.points.length<2||dr(g)?e.filter(x=>x.id!==g.id):void 0,appState:{...t,cursorButton:"up",editingLinearElement:null},commitToHistory:!0}}let l=e,s=t.pendingImageElementId&&i.getElement(t.pendingImageElementId);s&&z(s,{isDeleted:!0},!1),window.document.activeElement instanceof HTMLElement&&n();let c=t.multiElement?t.multiElement:t.editingElement?.type==="freedraw"?t.editingElement:null;if(c){if(c.type!=="freedraw"&&t.lastPointerDownWith!=="touch"){let{points:p,lastCommittedPoint:u}=c;(!u||p[p.length-1]!==u)&&z(c,{points:c.points.slice(0,-1)})}dr(c)&&(l=l.filter(p=>p.id!==c.id));let m=yo(c.points,t.zoom.value);if((c.type==="line"||c.type==="freedraw")&&m){let p=c.points,u=p[0];z(c,{points:p.map((g,x)=>x===p.length-1?[u[0],u[1]]:g)})}if(kt(c)&&!m&&c.points.length>1){let[p,u]=$.getPointAtIndexGlobalCoordinates(c,-1,re(e));pc(c,t,lt.getScene(c),{x:p,y:u},a)}}(!t.activeTool.locked&&t.activeTool.type!=="freedraw"||!c)&&zo(r);let d;return t.activeTool.type==="eraser"?d=Qe(t,{...t.activeTool.lastActiveTool||{type:"selection"},lastActiveToolBeforeEraser:null}):d=Qe(t,{type:"selection"}),{elements:l,appState:{...t,cursorButton:"up",activeTool:(t.activeTool.locked||t.activeTool.type==="freedraw")&&c?t.activeTool:d,activeEmbeddable:null,draggingElement:null,multiElement:null,editingElement:null,startBoundElement:null,suggestedBindings:[],selectedElementIds:c&&!t.activeTool.locked&&t.activeTool.type!=="freedraw"?{...t.selectedElementIds,[c.id]:!0}:t.selectedElementIds,selectedLinearElement:c&&ne(c)?new $(c):t.selectedLinearElement,pendingImageElementId:null},commitToHistory:t.activeTool.type==="freedraw"}},keyTest:(e,t)=>e.key===I.ESCAPE&&(t.editingLinearElement!==null||!t.draggingElement&&t.multiElement===null)||(e.key===I.ESCAPE||e.key===I.ENTER)&&t.multiElement!==null,PanelComponent:({appState:e,updateData:t,data:o})=>$8(ce,{type:"button",icon:N1,title:b("buttons.done"),"aria-label":b("buttons.done"),onClick:t,visible:e.multiElement!=null,size:o?.size||"medium"})})});var eT=v(()=>{});var tT=v(()=>{});import{useState as X8}from"react";import{jsx as oT,jsxs as Z8}from"react/jsx-runtime";var rT,nT=v(()=>{"use strict";f();eT();G();tT();ye();ue();rT=e=>{let{id:t}=Wt(),[o,r]=X8(e.value),n=a=>{e.ignoreFocus||wy(a.target);let l=a.target.value;l!==e.value&&e.onChange(l)},i=a=>{if(a.key===I.ENTER){if(a.preventDefault(),a.nativeEvent.isComposing||a.keyCode===229)return;a.currentTarget.blur()}};return Z8("div",{className:"ProjectName",children:[oT("label",{className:"ProjectName-label",htmlFor:"filename",children:`${e.label}:`}),oT("input",{type:"text",className:"TextInput",onBlur:n,onKeyDown:i,id:`${t}-filename`,value:o,onChange:a=>r(a.target.value)})]})}});import{jsx as ld}from"react/jsx-runtime";var aT,iT,lT=v(()=>{"use strict";f();jn();X();Mt();U();aT=e=>{let t=e.title||(e.value===ie.DARK?b("buttons.lightMode"):b("buttons.darkMode"));return ld(ce,{type:"icon",icon:e.value===ie.LIGHT?iT.MOON:iT.SUN,title:t,"aria-label":t,onClick:()=>e.onChange(e.value===ie.DARK?ie.LIGHT:ie.DARK),"data-testid":"toggle-dark-mode"})},iT={SUN:ld("svg",{width:"512",height:"512",className:"rtl-mirror",viewBox:"0 0 512 512",children:ld("path",{fill:"currentColor",d:"M256 160c-52.9 0-96 43.1-96 96s43.1 96 96 96 96-43.1 96-96-43.1-96-96-96zm246.4 80.5l-94.7-47.3 33.5-100.4c4.5-13.6-8.4-26.5-21.9-21.9l-100.4 33.5-47.4-94.8c-6.4-12.8-24.6-12.8-31 0l-47.3 94.7L92.7 70.8c-13.6-4.5-26.5 8.4-21.9 21.9l33.5 100.4-94.7 47.4c-12.8 6.4-12.8 24.6 0 31l94.7 47.3-33.5 100.5c-4.5 13.6 8.4 26.5 21.9 21.9l100.4-33.5 47.3 94.7c6.4 12.8 24.6 12.8 31 0l47.3-94.7 100.4 33.5c13.6 4.5 26.5-8.4 21.9-21.9l-33.5-100.4 94.7-47.3c13-6.5 13-24.7.2-31.1zm-155.9 106c-49.9 49.9-131.1 49.9-181 0-49.9-49.9-49.9-131.1 0-181 49.9-49.9 131.1-49.9 181 0 49.9 49.9 49.9 131.1 0 181z"})}),MOON:ld("svg",{width:"512",height:"512",className:"rtl-mirror",viewBox:"0 0 512 512",children:ld("path",{fill:"currentColor",d:"M283.211 512c78.962 0 151.079-35.925 198.857-94.792 7.068-8.708-.639-21.43-11.562-19.35-124.203 23.654-238.262-71.576-238.262-196.954 0-72.222 38.662-138.635 101.498-174.394 9.686-5.512 7.25-20.197-3.756-22.23A258.156 258.156 0 0 0 283.211 0c-141.309 0-256 114.511-256 256 0 141.309 114.511 256 256 256z"})})}});var $a,Xa,Bi=v(()=>{"use strict";f();Ai();U();he();se();X();We();Yl();G();Co();Wn();Kn();ao();Co();Kn();$a=(e,{selectedElementIds:t},o)=>{e=be(e);let r=o&&Ye(e,{selectedElementIds:t}),n=null,i=r?de(e,{selectedElementIds:t},{includeBoundTextElement:!0}):e;return r&&(i.length===1&&Q(i[0])?(n=i[0],i=Kl(e,n)):i.length>1&&(i=de(e,{selectedElementIds:t},{includeBoundTextElement:!0,includeElementsInFrames:!0}))),{exportingFrame:n,exportedElements:Zr(i)}},Xa=async({type:e,data:t,config:o})=>{let r=Object.assign({},o);if(r.padding=r.padding??Kr,r.fileHandle=r.fileHandle??null,r.exportingFrame=r.exportingFrame??null,r.name=r.name||pm,t.elements.length===0)throw new Error(b("alerts.cannotExportEmptyCanvas"));if(e==="svg"||e==="clipboard-svg"){let i=Vl({data:{elements:t.elements,appState:{exportBackground:r.exportBackground,exportWithDarkMode:t.appState.exportWithDarkMode,viewBackgroundColor:t.appState.viewBackgroundColor,exportPadding:r.padding,exportScale:t.appState.exportScale,exportEmbedScene:t.appState.exportEmbedScene&&e==="svg"},files:t.files},config:{exportingFrame:r.exportingFrame}});if(e==="svg")return Hl(i.then(a=>new Blob([a.outerHTML],{type:J.svg})),{description:"Export to SVG",name:r.name,extension:t.appState.exportEmbedScene?"excalidraw.svg":"svg",fileHandle:r.fileHandle});if(e==="clipboard-svg"){let a=await i.then(l=>l.outerHTML);try{await Xn(a)}catch{throw new Error(b("errors.copyToSystemClipboardFailed"))}return}}let n=Si({data:t,config:{canvasBackgroundColor:r.exportBackground?r.viewBackgroundColor:!1,padding:r.padding,theme:t.appState.exportWithDarkMode?"dark":"light",scale:t.appState.exportScale,fit:"none",exportingFrame:r.exportingFrame}});if(e==="png"){let i=Yn(n);return t.appState.exportEmbedScene&&i.then(a=>Promise.resolve().then(()=>(Gl(),kc)).then(({encodePngMetadata:l})=>l({blob:a,metadata:Ii(t.elements,t.appState,t.files,"local")}))),Hl(i,{description:"Export to PNG",name:r.name,extension:"png",fileHandle:r.fileHandle})}else if(e==="clipboard")try{let i=Yn(n);await Ip(i)}catch(i){throw console.warn(i),i.name==="CANVAS_POSSIBLY_TOO_BIG"?new Error(b("canvasError.canvasTooBig")):Sn&&i.name==="TypeError"?new Error(`${b("alerts.couldNotCopyToClipboard")}
67
+ `),s=e.textAlign==="center"?e.width/2:e.textAlign==="right"?e.width:0,c=Pi(e.fontSize,e.lineHeight),d=op(e.fontFamily,e.fontSize,c);for(let m=0;m<l.length;m++)r.fillText(l[m],s,m*c+d);r.restore(),a&&r.canvas.remove()}else throw new Error(`Unimplemented type ${e.type}`)}},jc=new WeakMap,fT=()=>{jc=new WeakMap,v1=new WeakMap},sT=(e,t,r,o)=>{let n=r?o.zoom:eP.zoom,i=jc.get(e),a=i&&i.zoomValue!==n.value&&!o?.shouldCacheIgnoreZoom,l=ue(e,t)?.version||null,s=Xt(e,t)?.opacity||100;if(!i||a||i.theme!==o.theme||i.boundTextElementVersion!==l||i.containingFrameOpacity!==s){let c=rP(e,t,n,r,o);return jc.set(e,c),c}return i},cT=(e,t,r,o,n)=>{let i=e.element,a=iu(i),l=e.scale,[s,c,d,m]=oe(i,n);Ft(i)&&(s=Math.floor(s),d=Math.ceil(d),c=Math.floor(c),m=Math.ceil(m));let p=((s+d)/2+o.scrollX)*window.devicePixelRatio,u=((c+m)/2+o.scrollY)*window.devicePixelRatio;t.save(),t.scale(1/window.devicePixelRatio,1/window.devicePixelRatio);let h=ue(i,n);if(Ce(i)&&h){let E=document.createElement("canvas"),x=E.getContext("2d"),T=Math.max(Bt(s,d),Bt(c,m));E.width=T*window.devicePixelRatio*l+a*e.scale*10,E.height=T*window.devicePixelRatio*l+a*e.scale*10;let v=(E.width-e.canvas.width)/2,w=(E.height-e.canvas.height)/2;x.translate(E.width/2,E.height/2),x.rotate(i.angle),x.drawImage(e.canvas,-e.canvas.width/2,-e.canvas.height/2,e.canvas.width,e.canvas.height);let[,,,,I,L]=oe(h,n);x.rotate(-i.angle);let A=E.width/2-(I-s)*window.devicePixelRatio*l-v-a*l,M=E.height/2-(L-c)*window.devicePixelRatio*l-w-a*l;x.translate(-A,-M),x.clearRect(-(h.width/2+yt)*window.devicePixelRatio*l,-(h.height/2+yt)*window.devicePixelRatio*l,(h.width+yt*2)*window.devicePixelRatio*l,(h.height+yt*2)*window.devicePixelRatio*l),t.translate(p,u),t.drawImage(E,-(d-s)/2*window.devicePixelRatio-v/l-a,-(m-c)/2*window.devicePixelRatio-w/l-a,E.width/l,E.height/l)}else if(t.translate(p,u),t.rotate(i.angle),"scale"in e.element&&!pT(i,r)&&t.scale(e.element.scale[0],e.element.scale[1]),t.translate(-p,-u),t.drawImage(e.canvas,(s+o.scrollX)*window.devicePixelRatio-a*e.scale/e.scale,(c+o.scrollY)*window.devicePixelRatio-a*e.scale/e.scale,e.canvas.width/e.scale,e.canvas.height/e.scale),S.VITE_APP_DEBUG_ENABLE_TEXT_CONTAINER_BOUNDING_BOX==="true"&&lr(i)){let E=ue(i,n),x=Df(i);t.strokeStyle="#c92a2a",t.lineWidth=3,t.strokeRect((x.x+o.scrollX)*window.devicePixelRatio,(x.y+o.scrollY)*window.devicePixelRatio,Mr(i,E)*window.devicePixelRatio,Da(i,E)*window.devicePixelRatio)}t.restore()},bT=(e,t,r)=>{t.save(),t.translate(e.x+r.scrollX,e.y+r.scrollY),t.fillStyle="rgba(0, 0, 200, 0.04)";let o=.5/r.zoom.value;t.fillRect(o,o,e.width,e.height),t.lineWidth=1/r.zoom.value,t.strokeStyle=" rgb(105, 101, 219)",t.strokeRect(o,o,e.width,e.height),t.restore()},Ql=(e,t,r,o,n,i,a)=>{switch(n.globalAlpha=w1(e,Xt(e,t),i.elementsPendingErasure),e.type){case"magicframe":case"frame":{a.frameRendering.enabled&&a.frameRendering.outline&&(n.save(),n.translate(e.x+a.scrollX,e.y+a.scrollY),n.fillStyle="rgba(0, 0, 200, 0.04)",n.lineWidth=et.strokeWidth/a.zoom.value,n.strokeStyle=et.strokeColor,ya(e)&&(n.strokeStyle=a.theme===se.LIGHT?"#7affd7":"#1d8264"),et.radius&&n.roundRect?(n.beginPath(),n.roundRect(0,0,e.width,e.height,et.radius/a.zoom.value),n.stroke(),n.closePath()):n.strokeRect(0,0,e.width,e.height),n.restore());break}case"freedraw":{if(Ne.generateElementShape(e,null),i.isExporting){let[l,s,c,d]=oe(e,t),m=(l+c)/2+a.scrollX,p=(s+d)/2+a.scrollY,u=(c-l)/2-(e.x-l),h=(d-s)/2-(e.y-s);n.save(),n.translate(m,p),n.rotate(e.angle),n.translate(-u,-h),nu(e,o,n,i,a),n.restore()}else{let l=sT(e,t,i,a);cT(l,n,i,a,r)}break}case"rectangle":case"diamond":case"ellipse":case"line":case"arrow":case"image":case"text":case"iframe":case"embeddable":{if(Ne.generateElementShape(e,i),i.isExporting){let[l,s,c,d]=oe(e,t),m=(l+c)/2+a.scrollX,p=(s+d)/2+a.scrollY,u=(c-l)/2-(e.x-l),h=(d-s)/2-(e.y-s);if(V(e)){let x=gt(e,t);if(Ce(x)){let T=Z.getBoundTextElementPosition(x,e,t);u=(c-l)/2-(T.x-l),h=(d-s)/2-(T.y-s)}}n.save(),n.translate(m,p),uT(e,i,a)&&(n.filter="none");let E=ue(e,t);if(Ce(e)&&E){let x=document.createElement("canvas"),T=x.getContext("2d"),v=Math.max(Bt(l,c),Bt(s,d)),w=iu(e);x.width=v*a.exportScale+w*10*a.exportScale,x.height=v*a.exportScale+w*10*a.exportScale,T.translate(x.width/2,x.height/2),T.scale(a.exportScale,a.exportScale),u=e.width/2-(e.x-l),h=e.height/2-(e.y-s),T.rotate(e.angle);let I=mT.canvas(x);T.translate(-u,-h),nu(e,I,T,i,a),T.translate(u,h),T.rotate(-e.angle);let[,,,,L,A]=oe(E,t),M=(l+c)/2-L,D=(s+d)/2-A;T.translate(-M,-D),T.clearRect(-E.width/2,-E.height/2,E.width,E.height),n.scale(1/a.exportScale,1/a.exportScale),n.drawImage(x,-x.width/2,-x.height/2,x.width,x.height)}else n.rotate(e.angle),e.type==="image"&&n.scale(e.scale[0],e.scale[1]),n.translate(-u,-h),nu(e,o,n,i,a);n.restore()}else{let l=sT(e,t,i,a),s=n.imageSmoothingEnabled;!a?.shouldCacheIgnoreZoom&&(!e.angle||vw(e.angle))&&(n.imageSmoothingEnabled=!1),cT(l,n,i,a,r),n.imageSmoothingEnabled=s}break}default:throw new Error(`Unimplemented type ${e.type}`)}n.globalAlpha=1},v1=new WeakMap([]);iP=/(\s?[A-Z]?,?-?[0-9]*\.[0-9]{0,2})(([0-9]|e|-)*)/g});import{RoughGenerator as lP}from"roughjs/bin/generator";var Ne,ln=y(()=>{"use strict";f();sn();af();Qr();Ne=class e{static rg=new lP;static cache=new WeakMap;static get=t=>e.cache.get(t);static set=(t,r)=>e.cache.set(t,r);static delete=t=>e.cache.delete(t);static destroy=()=>{e.cache=new WeakMap};static generateElementShape=(t,r)=>{let o=r?.isExporting?void 0:e.get(t);if(o!==void 0)return o;jc.delete(t);let n=Iw(t,e.rg,r||{isExporting:!1,canvasBackgroundColor:Te.white,embedsValidationStatus:null});return e.cache.set(t,n),n}}});var H,le,_i,Ye=y(()=>{"use strict";f();vi();dc();Oo();G();ln();H=(e,t,r=!0)=>{let o=!1,{points:n,fileId:i}=t;typeof n<"u"&&(t={...Hm(n),...t});for(let a in t){let l=t[a];if(typeof l<"u"){if(e[a]===l&&(typeof l!="object"||l===null||a==="groupIds"||a==="scale"))continue;if(a==="scale"){let s=e[a],c=l;if(s[0]===c[0]&&s[1]===c[1])continue}else if(a==="points"){let s=e[a],c=l;if(s.length===c.length){let d=!1,m=s.length;for(;--m;){let p=s[m],u=c[m];if(p[0]!==u[0]||p[1]!==u[1]){d=!0;break}}if(!d)continue}}e[a]=l,o=!0}}return o&&((typeof t.height<"u"||typeof t.width<"u"||typeof i<"u"||typeof n<"u")&&Ne.delete(e),e.version++,e.versionNonce=fo(),e.updated=Fn(),r&&Ct.getScene(e)?.informMutation()),e},le=(e,t)=>{let r=!1;for(let o in t){let n=t[o];if(typeof n<"u"){if(e[o]===n&&(typeof n!="object"||n===null))continue;r=!0}}return r?{...e,...t,updated:Fn(),version:e.version+1,versionNonce:fo()}:e},_i=(e,t)=>(e.version=(t??e.version)+1,e.versionNonce=fo(),e.updated=Fn(),e)});var yo,Wa,au,Hl,Hc,Ya=y(()=>{"use strict";f();Ye();me();W();dt();G();yo=e=>ce(e)||Ft(e)?e.points.length<2:e.width===0&&e.height===0,Wa=(e,t,r,o,n)=>{let[i,a,l,s]=Zr(e,n),c=je({clientX:o.offsetLeft,clientY:o.offsetTop},o),d=je({clientX:o.offsetLeft+t,clientY:o.offsetTop+r},o);return c.x<=l&&c.y<=s&&d.x>=i&&d.y>=a},au=(e,t,r)=>{let o=Math.abs(t),n=Math.abs(r);if(e==="line"||e==="arrow"||e==="freedraw"){let i=Math.round(Math.atan(n/o)/qo)*qo;i===0?r=0:i===Math.PI/2?t=0:r=o*Math.tan(i)*Math.sign(r)||r}else e!=="selection"&&(r=o*Math.sign(r));return{width:t,height:r}},Hl=(e,t,r,o)=>{let n=r-e,i=o-t,a=Math.round(Math.atan(i/n)/qo)*qo;if(a===0)i=0;else if(a===Math.PI/2)n=0;else{let l=Math.tan(a),s=-1,c=t-l*e,d=-1/l,m=-1,p=o-d*r,u=(s*p-m*c)/(l*m-d*s),h=(c*d-p*l)/(l*m-d*s);n=u-e,i=h-t}return{width:n,height:i}},Hc=e=>{let t={width:e.width,height:e.height,x:e.x,y:e.y};if(e.width<0){let r=Math.abs(e.width);t.width=r,t.x=e.x-r}if(e.height<0){let r=Math.abs(e.height);t.height=r,t.y=e.y-r}return t}});var ET,sP,yT,cP,xT,T1,ei,lu,Ka,ms,qc,su,Jc=y(()=>{"use strict";f();dt();Kt();xe();me();W();ET={mouse:8,pen:16,touch:28},sP=16,yT={e:!0,s:!0,n:!0,w:!0},cP={e:!0,s:!0,n:!0,w:!0},xT={e:!0,s:!0,n:!0,w:!0,nw:!0,se:!0},T1={e:!0,s:!0,n:!0,w:!0},ei=(e,t,r,o,n,i,a)=>{let[l,s]=Se(e+r/2,t+o/2,n,i,a);return[l-r/2,s-o/2,r,o]},lu=e=>!(e.viewport.isMobile||e.isTouchScreen&&(Sy||bm)),Ka=e=>lu(e)?yT:{},ms=([e,t,r,o,n,i],a,l,s,c={},d=4)=>{let m=ET[s],p=m/l.value,u=m/l.value,h=m/l.value,E=m/l.value,x=r-e,T=o-t,v=d/l.value,w=(m-fi*2)/(2*l.value),I={nw:c.nw?void 0:ei(e-v-h+w,t-v-E+w,p,u,n,i,a),ne:c.ne?void 0:ei(r+v-w,t-v-E+w,p,u,n,i,a),sw:c.sw?void 0:ei(e-v-h+w,o+v-w,p,u,n,i,a),se:c.se?void 0:ei(r+v-w,o+v-w,p,u,n,i,a),rotation:c.rotation?void 0:ei(e+x/2-p/2,t-v-E+w-sP/l.value,p,u,n,i,a)},L=5*ET.mouse/l.value;return Math.abs(x)>L&&(c.n||(I.n=ei(e+x/2-p/2,t-v-E+w,p,u,n,i,a)),c.s||(I.s=ei(e+x/2-p/2,o+v-w,p,u,n,i,a))),Math.abs(T)>L&&(c.w||(I.w=ei(e-v-h+w,t+T/2-u/2,p,u,n,i,a)),c.e||(I.e=ei(r+v-w,t+T/2-u/2,p,u,n,i,a))),I},qc=(e,t,r,o="mouse",n=yT)=>{if(e.locked)return{};if(e.type==="freedraw"||ce(e)){if(e.points.length===2){let[,a]=e.points;a[0]===0||a[1]===0?n=T1:a[0]>0&&a[1]<0?n=xT:a[0]>0&&a[1]>0?n=T1:a[0]<0&&a[1]>0?n=xT:a[0]<0&&a[1]<0&&(n=T1)}}else V(e)?n=cP:re(e)&&(n={...n,rotation:!0});let i=ce(e)?fi+8:fi;return ms(oe(e,r,!0),e.angle,t,o,n,i)},su=(e,t)=>{if(t.editingLinearElement)return!1;if(e.length>1)return!0;let r=e[0];return ce(r)?r.points.length>2:!0}});var C1,wT,cu,du,S1,dP,mu,vT,TT=y(()=>{"use strict";f();Jc();dt();W();Km();me();C1=(e,t,r)=>t>=e[0]&&t<=e[0]+e[2]&&r>=e[1]&&r<=e[1]+e[3],wT=(e,t,r,o,n,i,a,l)=>{if(!r.selectedElementIds[e.id])return!1;let{rotation:s,...c}=qc(e,i,t,a,Ka(l));if(s&&C1(s,o,n))return"rotation";let d=Object.keys(c).filter(m=>{let p=c[m];return p?C1(p,o,n):!1});if(d.length>0)return d[0];if(lu(l)){let[m,p,u,h,E,x]=oe(e,t);if(e.type!=="text"&&!(ce(e)&&e.points.length<=2)){let T=wm/i.value,v=vT([m-T,p-T],[u+T,h+T],[E,x],cn(e.angle));for(let[w,I]of Object.entries(v))if(Aa([o,n],I,T))return w}}return!1},cu=(e,t,r,o,n,i,a,l)=>e.reduce((s,c)=>{if(s)return s;let d=wT(c,a,t,r,o,n,i,l);return d?{element:c,transformHandleType:d}:null},null),du=([e,t,r,o],n,i,a,l,s)=>{let c=ms([e,t,r,o,(e+r)/2,(t+o)/2],0,a,l,Ka(s)),d=Object.keys(c).find(m=>{let p=c[m];return p&&C1(p,n,i)});if(d)return d;if(lu(s)){let m=(e+r)/2,p=(t+o)/2,u=wm/a.value,h=vT([e-u,t-u],[r+u,o+u],[m,p],cn(0));for(let[E,x]of Object.entries(h))if(Aa([n,i],x,u))return E}return!1},S1=["ns","nesw","ew","nwse"],dP=(e,t)=>{let r=S1.indexOf(e);if(r>=0){let o=Math.round(t/(Math.PI/4));e=S1[(r+o)%S1.length]}return e},mu=e=>{let{element:t,transformHandleType:r}=e,o=t&&Math.sign(t.height)*Math.sign(t.width)===-1,n=null;switch(r){case"n":case"s":n="ns";break;case"w":case"e":n="ew";break;case"nw":case"se":o?n="nesw":n="nwse";break;case"ne":case"sw":o?n="nwse":n="nesw";break;case"rotation":return"grab"}return n&&t&&(n=dP(n,t.angle)),n?`${n}-resize`:""},vT=([e,t],[r,o],n,i)=>{let a=wt([e,t],i,n),l=wt([r,t],i,n),s=wt([e,o],i,n),c=wt([r,o],i,n);return{n:[a,l],e:[l,c],s:[c,s],w:[s,a]}}});var pu,I1,mP,pP,A1,uP,hP,k1,gP,M1,L1,P1=y(()=>{"use strict";f();W();dc();Kt();dt();me();Ye();G();Eo();vi();mt();or();xr();pu=e=>e<0?e+2*Math.PI:e>=2*Math.PI?e-2*Math.PI:e,I1=(e,t,r,o,n,i,a,l,s,c,d)=>{if(r.length===1){let[m]=r;return t==="rotation"?(mP(m,o,l,s,n),$r(m,o)):V(m)&&(t==="nw"||t==="ne"||t==="sw"||t==="se")?(uP(m,o,t,i,l,s),$r(m,o)):t&&hP(e,a,m,o,t,i,l,s),!0}else if(r.length>1){if(t==="rotation")return gP(e,r,o,l,s,n,c,d),!0;if(t)return k1(e,r,o,t,i,a,l,s),!0}return!1},mP=(e,t,r,o,n)=>{let[i,a,l,s]=oe(e,t),c=(i+l)/2,d=(a+s)/2,m;re(e)?m=0:(m=5*Math.PI/2+Math.atan2(o-d,r-c),n&&(m+=qo/2,m-=m%qo),m=pu(m));let p=Uo(e);if(H(e,{angle:m}),p){let u=Ct.getScene(e)?.getElement(p);u&&!Ce(e)&&H(u,{angle:m})}},pP=(e,t,r,o)=>ce(e)||Ft(e)?{points:Si(0,t,Si(1,r,e.points,o),o)}:{},A1=(e,t,r)=>{let o=e.width;if(Pe(e)){let a=gt(e,t);a&&(o=Mr(a,e))}let i=e.fontSize*(r/o);return i<xm?null:{size:i}},uP=(e,t,r,o,n,i)=>{let[a,l,s,c,d,m]=oe(e,t),[p,u]=Se(n,i,d,m,-e.angle),h=0,E=0;r.includes("e")&&(h=(p-a)/(s-a)),r.includes("w")&&(h=(s-p)/(s-a)),r.includes("n")&&(E=(c-u)/(c-l)),r.includes("s")&&(E=(u-l)/(c-l));let x=Math.max(h,E);if(x>0){let T=e.width*x,v=e.height*x,w=A1(e,t,T);if(w===null)return;let I=[a,l],L=[s,c],A=[d,m],M=[a,l];if(["n","w","nw"].includes(r)&&(M=[L[0]-Math.abs(T),L[1]-Math.abs(v)]),r==="ne"){let ee=[I[0],L[1]];M=[ee[0],ee[1]-Math.abs(v)]}if(r==="sw"){let ee=[L[0],I[1]];M=[ee[0]-Math.abs(T),ee[1]]}["s","n"].includes(r)&&(M[0]=A[0]-T/2),["e","w"].includes(r)&&(M[1]=A[1]-v/2),o&&(M[0]=A[0]-Math.abs(T)/2,M[1]=A[1]-Math.abs(v)/2);let D=e.angle,O=Ke(M,[d,m],D),R=[M[0]+Math.abs(T)/2,M[1]+Math.abs(v)/2],B=Ke(R,[d,m],D);M=Ke(O,B,-D);let[k,z]=M;H(e,{fontSize:w.size,width:T,height:v,x:k,y:z})}},hP=(e,t,r,o,n,i,a,l)=>{let s=e.get(r.id),[c,d,m,p]=Gl(s,s.width,s.height,!0),u=[c,d],h=[m,p],E=mc(u,h),x=Ke([a,l],E,-s.angle),[T,v,w,I]=Gl(r,r.width,r.height,!0),L=w-T,A=I-v,M=h[0]-u[0],D=h[1]-u[1],O=M/L,R=D/A,B={},k=ue(r,o);n.includes("e")&&(O=(x[0]-u[0])/L),n.includes("s")&&(R=(x[1]-u[1])/A),n.includes("w")&&(O=(h[0]-x[0])/L),n.includes("n")&&(R=(h[1]-x[1])/A);let z=s.width,ee=s.height,j=r.width*O,ie=r.height*R;if(i&&(j=2*j-z,ie=2*ie-ee),t){let Ar=Math.abs(j)/z,yl=Math.abs(ie)/ee;if(n.length===1&&(ie*=Ar,j*=yl),n.length===2){let ha=Math.max(Ar,yl);j=z*ha*Math.sign(j),ie=ee*ha*Math.sign(ie)}}if(k){let Ar=e.get(k.id);if(Ar&&(B={fontSize:Ar.fontSize}),t){let yl={...r,width:j,height:ie},ha=A1(k,o,Mr(yl,k));if(ha===null)return;B={fontSize:ha.size}}else{let yl=ip(Ze(k),k.lineHeight),ha=np(k.fontSize,k.lineHeight);j=Math.max(j,yl),ie=Math.max(ie,ha)}}let[ke,$,Y,ae]=Gl(s,j,ie,!0),fe=Y-ke,De=ae-$,Le=[...u];if(["n","w","nw"].includes(n)&&(Le=[h[0]-Math.abs(fe),h[1]-Math.abs(De)]),n==="ne"){let Ar=[u[0],h[1]];Le=[Ar[0],Ar[1]-Math.abs(De)]}if(n==="sw"){let Ar=[h[0],u[1]];Le=[Ar[0]-Math.abs(fe),Ar[1]]}t&&(["s","n"].includes(n)&&(Le[0]=E[0]-fe/2),["e","w"].includes(n)&&(Le[1]=E[1]-De/2));let pr=j<0,mi=ie<0;pr&&(n.includes("e")&&(Le[0]-=Math.abs(fe)),n.includes("w")&&(Le[0]+=Math.abs(fe))),mi&&(n.includes("s")&&(Le[1]-=Math.abs(De)),n.includes("n")&&(Le[1]+=Math.abs(De))),i&&(Le[0]=E[0]-Math.abs(fe)/2,Le[1]=E[1]-Math.abs(De)/2);let Zo=s.angle,Pn=Ke(Le,E,Zo),pi=[Le[0]+Math.abs(fe)/2,Le[1]+Math.abs(De)/2],xl=Ke(pi,E,Zo);Le=Ke(Pn,xl,-Zo);let _o=[...Le],Gr=s.x-ke,Ir=s.y-$;_o[0]+=Gr,_o[1]+=Ir;let ua=_o[0],xk=_o[1],by,Ey;(ce(r)||Ft(r))&&(by=Si(1,ie,s.points,!0),Ey=Si(0,j,by,!0));let ui={width:Math.abs(j),height:Math.abs(ie),x:ua,y:xk,points:Ey};if("scale"in r&&"scale"in s&&H(r,{scale:[(Math.sign(Y-s.x)||s.scale[0])*s.scale[0],(Math.sign(ae-s.y)||s.scale[1])*s.scale[1]]}),Ce(r)&&k&&t){let Ar=ui.width/r.width*k.fontSize;if(Ar<xm)return;B.fontSize=Ar}ui.width!==0&&ui.height!==0&&Number.isFinite(ui.x)&&Number.isFinite(ui.y)&&(H(r,ui),$r(r,o,{newSize:{width:ui.width,height:ui.height}}),k&&B!=null&&H(k,{fontSize:B.fontSize}),Ma(r,o,n,t))},k1=(e,t,r,o,n,i,a,l)=>{let s=t.reduce(($,Y)=>{let ae=e.get(Y.id);return ae&&$.push({orig:ae,latest:Y}),$},[]),c=s.reduce(($,{orig:Y})=>{if(!ce(Y))return $;let ae=Uo(Y);if(!ae)return $;let fe=e.get(ae)??null;if(!Pe(fe))return $;let De=Z.getBoundTextElementPosition(Y,fe,r);return[...$,{...fe,...De}]},[]),{minX:d,minY:m,maxX:p,maxY:u,midX:h,midY:E}=Lr(s.map(({orig:$})=>$).concat(c)),x=p-d,T=u-m,v=o,w={ne:[d,u],se:[d,m],sw:[p,m],nw:[p,u],e:[d,m+T/2],w:[p,m+T/2],n:[d+x/2,u],s:[d+x/2,m]},[I,L]=n?[h,E]:w[v],A=n?2:1,M=Math.max(Math.abs(a-I)/x||0,Math.abs(l-L)/T||0)*A;if(M===0)return;let D=v.includes("e")||v.includes("w")?Math.abs(a-I)/x*A:1,O=v.includes("n")||v.includes("s")?Math.abs(l-L)/T*A:1,R=i||s.some($=>$.latest.angle!==0||V($.latest)||k2($.latest));R&&(D=M,O=M);let B={ne:[a<I,l>L],se:[a<I,l<L],sw:[a>I,l<L],nw:[a>I,l>L],e:[a<I,!1],w:[a>I,!1],n:[!1,l>L],s:[!1,l<L]},[k,z]=B[v].map($=>$?-1:1),ee=k<0,j=z<0,ie=[];for(let{orig:$,latest:Y}of s){if(V($)&&Pe($))continue;let ae=$.width*D,fe=$.height*O,De=pu($.angle*k*z),Le=ce($)||Ft($),pr=$.x-I,mi=$.y-L,Zo=ee&&!Le?ae:0,Pn=j&&!Le?fe:0,pi=I+k*(pr*D+Zo),xl=L+z*(mi*O+Pn),_o=pP($,ae*k,fe*z,!1),Gr={x:pi,y:xl,width:ae,height:fe,angle:De,..._o};if(ho($)&&(Gr.scale=[$.scale[0]*k,$.scale[1]*z]),V($)){let ua=A1($,r,ae);if(!ua)return;Gr.fontSize=ua.size}let Ir=e.get(Uo($)??"");if(Ir)if(R){let ua=Ir.fontSize*M;if(ua<xm)return;Gr.boundTextFontSize=ua}else Gr.boundTextFontSize=Ir.fontSize;ie.push({element:Y,update:Gr})}let ke=ie.map(({element:$})=>$);for(let{element:$,update:{boundTextFontSize:Y,...ae}}of ie){let{width:fe,height:De,angle:Le}=ae;H($,ae,!1),$r($,r,{simultaneouslyUpdated:ke,newSize:{width:fe,height:De}});let pr=ue($,r);pr&&Y&&(H(pr,{fontSize:Y,angle:ce($)?void 0:Le},!1),Ma($,r,o,!0))}Ct.getScene(ie[0].element)?.informMutation()},gP=(e,t,r,o,n,i,a,l)=>{let s=5*Math.PI/2+Math.atan2(n-l,o-a);i&&(s+=qo/2,s-=s%qo),t.filter(c=>!re(c)).forEach(c=>{let[d,m,p,u]=oe(c,r),h=(d+p)/2,E=(m+u)/2,x=e.get(c.id)?.angle??c.angle,[T,v]=Se(h,E,a,l,s+x-c.angle);H(c,{x:c.x+(T-h),y:c.y+(v-E),angle:pu(s+x)},!1),$r(c,r,{simultaneouslyUpdated:t});let w=ue(c,r);w&&!Ce(c)&&H(w,{x:w.x+(T-h),y:w.y+(v-E),angle:pu(s+x)},!1)}),Ct.getScene(t[0])?.informMutation()},M1=(e,t,r,o,n)=>{let[i,a,l,s]=t.length===1?oe(t[0],r):Ae(t),c=(i+l)/2,d=(a+s)/2,m=t.length===1?t[0].angle:0;switch([o,n]=Se(o,n,c,d,-m),e){case"n":return Se(o-(i+l)/2,n-a,0,0,m);case"s":return Se(o-(i+l)/2,n-s,0,0,m);case"w":return Se(o-i,n-(a+s)/2,0,0,m);case"e":return Se(o-l,n-(a+s)/2,0,0,m);case"nw":return Se(o-i,n-a,0,0,m);case"ne":return Se(o-l,n-a,0,0,m);case"sw":return Se(o-i,n-s,0,0,m);case"se":return Se(o-l,n-s,0,0,m);default:return[0,0]}},L1=(e,t)=>{let[,[r,o]]=t.points;return e==="nw"&&(r<0||o<0)||e==="ne"&&r>=0||e==="sw"&&r<=0||e==="se"&&(r>0||o>0)?"end":"origin"}});var D1,fP,ST,_1,uu,CT=y(()=>{"use strict";f();Eo();dt();Ye();Ya();mt();Kt();me();D1=(e,t,r,o,n,i,a)=>{let l=new Set(t),s=t.filter(m=>re(m)).map(m=>m.id);if(s.length>0)for(let m of n.getNonDeletedElements())m.frameId!==null&&s.includes(m.frameId)&&l.add(m);let c=Ae(Array.from(l).map(m=>e.originalElements.get(m.id)??m)),d=fP(c,r,i,a);l.forEach(m=>{if(ST(e,m,d),!Ce(m)){let p=ue(m,n.getNonDeletedElementsMap());p&&ST(e,p,d)}$r(m,n.getElementsMapIncludingDeleted(),{simultaneouslyUpdated:Array.from(l)})})},fP=(e,t,r,o)=>{let[n,i]=e,a=n+t.x+r.x,l=i+t.y+r.y;if(r.x===0||r.y===0){let[s,c]=Pt(n+t.x,i+t.y,o);r.x===0&&(a=s),r.y===0&&(l=c)}return{x:a-n,y:l-i}},ST=(e,t,r)=>{let o=e.originalElements.get(t.id)??t,n=o.x+r.x,i=o.y+r.y;H(t,{x:n,y:i})},_1=(e,t,r)=>{let[o,n]=Ae(e);return[t-o,r-n]},uu=(e,t,r,o,n,i,a,l,s,c,d,m=null)=>{s&&e.type!=="selection"&&(d?l=a/d:(Math.abs(i-o)>Math.abs(n-r)?{width:a,height:l}=au(t,l,n<r?-a:a):{width:a,height:l}=au(t,a,i<o?-l:l),l<0&&(l=-l)));let p=n<r?r-a:r,u=i<o?o-l:o;c&&(a+=a,l+=l,p=r-a/2,u=o-l/2),a!==0&&l!==0&&H(e,{x:p+(m?.x??0),y:u+(m?.y??0),width:a,height:l})}});var $a,IT=y(()=>{"use strict";f();qe();$a=(e,t)=>!!(!e.viewModeEnabled&&(e.activeTool.type!=="custom"&&(e.editingElement||e.activeTool.type!=="selection"&&e.activeTool.type!=="eraser"&&e.activeTool.type!=="hand"&&e.activeTool.type!=="laser")||ge(t,e).length))});var bP,R1,N1,AT,ye,cc,kT,pv,Ap,xe=y(()=>{"use strict";f();Ya();me();hn();dt();Jc();TT();P1();CT();me();mt();Ya();IT();bP=e=>e.reduce((t,r)=>t+r.version,0),R1=e=>{let t=5381;for(let r=0;r<e.length;r++)t=(t<<5)+t+e[r].versionNonce;return t>>>0},N1=e=>{let t=5381;for(let r=0;r<e.length;r++){let o=e.charCodeAt(r);t=(t<<5)+t+o}return t>>>0},AT=e=>e.filter(t=>!t.isDeleted&&!yo(t)),ye=e=>e.filter(t=>!t.isDeleted),cc=e=>!e.isDeleted,kT=e=>ye(e).map(t=>ac(t.type)?{...t,lastCommittedPoint:null}:t),pv=e=>kT(e),Ap=e=>kT(e)});var Xa,ds,O1,Xe,B1,ge,Za,Fe,Ti=y(()=>{"use strict";f();xe();me();dr();G();Ya();Xa=e=>{let t=new Set;return e.forEach(r=>{re(r)&&t.add(r.id)}),e.filter(r=>!(r.frameId&&t.has(r.frameId)))},ds=(e,t,r,o=!0)=>{let[n,i,a,l]=oe(t,r),s=e.filter(c=>{let[d,m,p,u]=Zr(c,r),h=Xt(c,r);if(h){let[E,x,T,v]=Zr(h,r);d=Math.max(E,d),m=Math.max(x,m),p=Math.min(T,p),u=Math.min(v,u)}return c.locked===!1&&c.type!=="selection"&&!Pe(c)&&n<=d&&i<=m&&a>=p&&l>=u});return s=o?Xa(s):s,s=s.filter(c=>{let d=Xt(c,r);return d?fn(c,d,r):!0}),s},O1=(e,t,r,o)=>{let n=new Set(t.map(i=>i.id));return e.filter(i=>{let a=Wa(i,r.width,r.height,r,o);return!n.has(i.id)&&a})},Xe=function(){let e=null,t=null,r=null,o=(n,i)=>(r!=null&&n===e&&i.selectedElementIds===t||(r=n.some(a=>i.selectedElementIds[a.id]),e=n,t=i.selectedElementIds),r);return o.clearCache=()=>{e=null,t=null,r=null},o}(),B1=(e,t,r)=>{let o=Array.from(new Set(ge(e,t).map(n=>r(n))));return o.length===1?o[0]:null},ge=(e,t,r)=>{let o=[];for(let n of e.values()){if(t.selectedElementIds[n.id]){o.push(n);continue}if(r?.includeBoundTextElement&&Pe(n)&&t.selectedElementIds[n?.containerId]){o.push(n);continue}}if(r?.includeElementsInFrames){let n=[];return o.forEach(i=>{re(i)&&eo(e,i.id).forEach(a=>n.push(a)),n.push(i)}),n}return o},Za=(e,t)=>t.editingElement?[t.editingElement]:ge(e,t,{includeBoundTextElement:!0}),Fe=(e,t)=>rt(t.selectedElementIds,e)?t.selectedElementIds:e});var EP,F1,gn,z1=y(()=>{"use strict";f();xe();G();EP=(e,t)=>{let[r,o,n,i]=t,{x:a,y:l}=Vt({sceneX:r,sceneY:o},e),{x:s,y:c}=Vt({sceneX:n,sceneY:i},e);return s-a>e.width||c-l>e.height},F1=({scenePoint:e,viewportDimensions:t,zoom:r})=>({scrollX:t.width/2/r.value-e.x,scrollY:t.height/2/r.value-e.y}),gn=(e,t)=>{if(e=AT(e),!e.length)return{scrollX:0,scrollY:0};let[r,o,n,i]=Ae(e);EP(t,[r,o,n,i])&&([r,o,n,i]=Bf(e,je({clientX:t.scrollX,clientY:t.scrollY},t)));let a=(r+n)/2,l=(o+i)/2;return F1({scenePoint:{x:a,y:l},viewportDimensions:{width:t.width,height:t.height},zoom:t.zoom})}});var En,ti,hu=y(()=>{"use strict";f();W();En=e=>Math.max(Sl,Math.min(e,30)),ti=({viewportX:e,viewportY:t,nextZoom:r},o)=>{let n=e-o.offsetLeft,i=t-o.offsetTop,a=o.zoom.value,l=o.scrollX+(n-n/a),s=o.scrollY+(i-i/a),c=-(n-n/r),d=-(i-i/r);return{scrollX:l+c,scrollY:s+d,zoom:{value:r}}}});var qe=y(()=>{"use strict";f();Ti();z1();fc();hu()});var ri=y(()=>{});import H1,{useEffect as xP,useRef as MT,useState as yP}from"react";import LT from"clsx";import{jsx as Qc,jsxs as ed}from"react/jsx-runtime";var pe,Dt=y(()=>{"use strict";f();ri();we();wi();_n();G();pe=H1.forwardRef((e,t)=>{let{id:r}=Zt(),o=H1.useRef(null);H1.useImperativeHandle(t,()=>o.current);let n=`ToolIcon_size_${e.size}`,[i,a]=yP(!1),l=MT(!0),s=async d=>{let m="onClick"in e&&e.onClick?.(d);if(tn(m))try{a(!0),await m}catch(p){if(p instanceof an)console.warn(p);else throw p}finally{l.current&&a(!1)}};xP(()=>(l.current=!0,()=>{l.current=!1}),[]);let c=MT(null);if(e.type==="button"||e.type==="icon"||e.type==="submit"){let d=e.type==="icon"?"button":e.type;return ed("button",{className:LT("ToolIcon_type_button",n,e.className,e.visible&&!e.hidden?"ToolIcon_type_button--show":"ToolIcon_type_button--hide",{ToolIcon:!e.hidden,"ToolIcon--selected":e.selected,"ToolIcon--plain":e.type==="icon"}),style:e.style,"data-testid":e["data-testid"],hidden:e.hidden,title:e.title,"aria-label":e["aria-label"],type:d,onClick:s,ref:o,disabled:i||e.isLoading||!!e.disabled,children:[(e.icon||e.label)&&ed("div",{className:"ToolIcon__icon","aria-hidden":"true","aria-disabled":!!e.disabled,children:[e.icon||e.label,e.keyBindingLabel&&Qc("span",{className:"ToolIcon__keybinding",children:e.keyBindingLabel}),e.isLoading&&Qc(er,{})]}),e.showAriaLabel&&ed("div",{className:"ToolIcon__label",children:[e["aria-label"]," ",i&&Qc(er,{})]}),e.children]})}return ed("label",{className:LT("ToolIcon",e.className),title:e.title,onPointerDown:d=>{c.current=d.pointerType||null,e.onPointerDown?.({pointerType:d.pointerType||null})},onPointerUp:()=>{requestAnimationFrame(()=>{c.current=null})},children:[Qc("input",{className:`ToolIcon_type_radio ${n}`,type:"radio",name:e.name,"aria-label":e["aria-label"],"aria-keyshortcuts":e["aria-keyshortcuts"],"data-testid":e["data-testid"],id:`${r}-${e.id}`,onChange:()=>{e.onChange?.({pointerType:c.current})},checked:e.checked,ref:o}),ed("div",{className:"ToolIcon__icon",children:[e.icon,e.keyBindingLabel&&Qc("span",{className:"ToolIcon__keybinding",children:e.keyBindingLabel})]})]})});pe.defaultProps={visible:!0,className:"",size:"medium"};pe.displayName="ToolButton"});var DT={};Xs(DT,{AlignBottomIcon:()=>Cu,AlignLeftIcon:()=>Iu,AlignRightIcon:()=>Au,AlignTopIcon:()=>Su,ArrowIcon:()=>J1,ArrowRightIcon:()=>el,ArrowheadArrowIcon:()=>_b,ArrowheadBarIcon:()=>Nb,ArrowheadCircleIcon:()=>_u,ArrowheadCircleOutlineIcon:()=>Rb,ArrowheadDiamondIcon:()=>Fb,ArrowheadDiamondOutlineIcon:()=>zb,ArrowheadNoneIcon:()=>Db,ArrowheadTriangleIcon:()=>Ob,ArrowheadTriangleOutlineIcon:()=>Bb,BringForwardIcon:()=>yu,BringToFrontIcon:()=>vu,CenterHorizontallyIcon:()=>Mu,CenterVerticallyIcon:()=>ku,CloseIcon:()=>to,DeviceDesktopIcon:()=>xE,DiamondIcon:()=>j1,DiscordIcon:()=>lb,DistributeHorizontallyIcon:()=>bb,DistributeVerticallyIcon:()=>Eb,DotsIcon:()=>V1,DuplicateIcon:()=>ps,EdgeRoundIcon:()=>Pb,EdgeSharpIcon:()=>Lb,EllipseIcon:()=>q1,EmbedIcon:()=>ib,EraserIcon:()=>ob,ExcalLogo:()=>TP,ExportIcon:()=>Ui,ExportImageIcon:()=>id,ExternalLinkIcon:()=>bu,FillCrossHatchIcon:()=>wb,FillHachureIcon:()=>yb,FillSolidIcon:()=>vb,FillZigZagIcon:()=>xb,FontFamilyCodeIcon:()=>Yb,FontFamilyNormalIcon:()=>Wb,FontSizeExtraLargeIcon:()=>Vb,FontSizeLargeIcon:()=>Gb,FontSizeMediumIcon:()=>Ub,FontSizeSmallIcon:()=>Hb,FreedrawIcon:()=>qa,GithubIcon:()=>od,GroupIcon:()=>Lu,HamburgerMenuIcon:()=>rd,HelpIcon:()=>Ja,HelpIconThin:()=>ab,HomeIcon:()=>U1,ImageIcon:()=>rb,LibraryIcon:()=>td,LineIcon:()=>Q1,LinkIcon:()=>gs,LoadIcon:()=>Qa,LockedIcon:()=>ja,MagicIcon:()=>tl,MagicIconThin:()=>VP,MoonIcon:()=>us,OpenAIIcon:()=>fs,PenModeIcon:()=>eb,PinIcon:()=>W1,PlusIcon:()=>G1,RectangleIcon:()=>Z1,RedoIcon:()=>xu,SelectionIcon:()=>X1,SendBackwardIcon:()=>wu,SendToBackIcon:()=>Tu,SloppinessArchitectIcon:()=>Ab,SloppinessArtistIcon:()=>kb,SloppinessCartoonistIcon:()=>Mb,StrokeStyleDashedIcon:()=>Cb,StrokeStyleDottedIcon:()=>Ib,StrokeStyleSolidIcon:()=>FP,StrokeWidthBaseIcon:()=>Du,StrokeWidthBoldIcon:()=>Tb,StrokeWidthExtraBoldIcon:()=>Sb,SunIcon:()=>hs,TextAlignBottomIcon:()=>jb,TextAlignCenterIcon:()=>$b,TextAlignLeftIcon:()=>Kb,TextAlignMiddleIcon:()=>qb,TextAlignRightIcon:()=>Xb,TextAlignTopIcon:()=>Zb,TextIcon:()=>tb,TrashIcon:()=>To,UndoIcon:()=>Eu,UngroupIcon:()=>Pu,UnlockedIcon:()=>Hi,WelcomeScreenHelpArrow:()=>K1,WelcomeScreenMenuArrow:()=>Y1,WelcomeScreenTopToolbarArrow:()=>$1,XBrandIcon:()=>sb,ZoomInIcon:()=>gu,ZoomOutIcon:()=>fu,ZoomResetIcon:()=>nb,abacusIcon:()=>pE,alertTriangleIcon:()=>tE,arrowBarToLeftIcon:()=>WP,boltIcon:()=>ud,brainIcon:()=>aE,brainIconThin:()=>lE,bucketFillIcon:()=>nd,checkIcon:()=>cb,clipboard:()=>SP,clockIcon:()=>sE,clone:()=>NP,coffeeIcon:()=>EE,copyIcon:()=>sd,createIcon:()=>P,cutIcon:()=>Qb,done:()=>hb,downloadIcon:()=>Nu,eraser:()=>zP,exportToFileIcon:()=>ub,exportToPlus:()=>LP,extraToolsIcon:()=>oE,eyeClosedIcon:()=>iE,eyeDropperIcon:()=>rE,eyeIcon:()=>rl,file:()=>BP,flipHorizontal:()=>hE,flipVertical:()=>uE,fontSizeIcon:()=>Ru,frameToolIcon:()=>cd,fullscreenIcon:()=>nE,gridIcon:()=>wE,handIcon:()=>ld,helpIcon:()=>eE,iconFillColor:()=>vo,laserPointerToolIcon:()=>md,magnetIcon:()=>bE,menu:()=>AP,mermaidLogoIcon:()=>dd,microphoneIcon:()=>cE,microphoneMutedIcon:()=>dE,paintIcon:()=>Ou,palette:()=>pb,playerPlayIcon:()=>HP,playerStopFilledIcon:()=>UP,pngIcon:()=>fE,publishIcon:()=>Jb,questionCircle:()=>gb,resetZoom:()=>DP,save:()=>db,saveAs:()=>mb,searchIcon:()=>pd,selectAllIcon:()=>mE,share:()=>fb,shareIOS:()=>MP,shareWindows:()=>PP,shield:()=>OP,start:()=>_P,stop:()=>RP,svgIcon:()=>gE,tablerCheckIcon:()=>GP,usersIcon:()=>ad,warning:()=>kP,youtubeIcon:()=>yE,zoomAreaIcon:()=>hd,zoomIn:()=>CP,zoomOut:()=>IP});import Rr from"react";import wP from"open-color";import vP from"clsx";import{Fragment as Oe,jsx as g,jsxs as F}from"react/jsx-runtime";var vo,PT,P,Q,he,U1,td,G1,V1,W1,Hi,ja,Y1,K1,$1,TP,X1,Z1,j1,q1,J1,Q1,eb,qa,tb,rb,ob,gu,fu,nb,To,ib,ps,us,hs,rd,Ui,Ja,ab,bu,od,lb,sb,cb,gs,db,mb,Qa,SP,pb,nd,id,ub,CP,IP,hb,AP,Eu,xu,gb,fb,kP,MP,LP,PP,DP,yu,wu,vu,Tu,Su,Cu,Iu,Au,bb,Eb,ku,Mu,ad,_P,RP,to,NP,OP,BP,Lu,Pu,xb,yb,wb,vb,Du,Tb,Sb,FP,Cb,Ib,Ab,kb,Mb,Lb,Pb,Db,_b,_u,Rb,Nb,Ob,Bb,Fb,zb,Hb,Ub,Gb,Vb,Ru,Wb,Yb,Kb,$b,Xb,Zb,jb,qb,Jb,zP,ld,Nu,sd,Qb,eE,HP,UP,GP,tE,rE,oE,cd,dd,el,md,tl,VP,fs,nE,rl,iE,aE,lE,pd,sE,cE,dE,ud,mE,pE,uE,hE,Ou,hd,gE,fE,bE,EE,xE,WP,yE,wE,ne=y(()=>{"use strict";f();W();vo=e=>"var(--icon-fill-color)",PT=e=>e===se.LIGHT?wP.white:"#1e1e1e",P=(e,t=512)=>{let{width:r=512,height:o=r,mirror:n,style:i,...a}=typeof t=="number"?{width:t}:t;return g("svg",{"aria-hidden":"true",focusable:"false",role:"img",viewBox:`0 0 ${r} ${o}`,className:vP({"rtl-mirror":n}),style:i,...a,children:typeof e=="string"?g("path",{fill:"currentColor",d:e}):e})},Q={width:24,height:24,fill:"none",strokeWidth:2,stroke:"currentColor",strokeLinecap:"round",strokeLinejoin:"round"},he={width:20,height:20,fill:"none",stroke:"currentColor",strokeLinecap:"round",strokeLinejoin:"round"},U1=P(F("g",{strokeWidth:1.5,children:[g("path",{stroke:"none",d:"M0 0h24v24H0z",fill:"none"}),g("polyline",{points:"5 12 3 12 12 3 21 12 19 12"}),g("path",{d:"M5 12v7a2 2 0 0 0 2 2h10a2 2 0 0 0 2 -2v-7"}),g("path",{d:"M9 21v-6a2 2 0 0 1 2 -2h2a2 2 0 0 1 2 2v6"})]}),Q),td=P(F("g",{strokeWidth:"1.25",children:[g("path",{stroke:"none",d:"M0 0h24v24H0z",fill:"none"}),g("path",{d:"M3 19a9 9 0 0 1 9 0a9 9 0 0 1 9 0"}),g("path",{d:"M3 6a9 9 0 0 1 9 0a9 9 0 0 1 9 0"}),g("line",{x1:"3",y1:"6",x2:"3",y2:"19"}),g("line",{x1:"12",y1:"6",x2:"12",y2:"19"}),g("line",{x1:"21",y1:"6",x2:"21",y2:"19"})]}),Q),G1=P(F("svg",{strokeWidth:"1.5",children:[g("path",{stroke:"none",d:"M0 0h24v24H0z",fill:"none"}),g("line",{x1:"12",y1:"5",x2:"12",y2:"19"}),g("line",{x1:"5",y1:"12",x2:"19",y2:"12"})]}),Q),V1=P(F("g",{strokeWidth:"1.5",children:[g("path",{stroke:"none",d:"M0 0h24v24H0z",fill:"none"}),g("circle",{cx:"12",cy:"12",r:"1"}),g("circle",{cx:"12",cy:"19",r:"1"}),g("circle",{cx:"12",cy:"5",r:"1"})]}),Q),W1=P(F("svg",{strokeWidth:"1.5",children:[g("path",{stroke:"none",d:"M0 0h24v24H0z",fill:"none"}),g("path",{d:"M9 4v6l-2 4v2h10v-2l-2 -4v-6"}),g("line",{x1:"12",y1:"16",x2:"12",y2:"21"}),g("line",{x1:"8",y1:"4",x2:"16",y2:"4"})]}),Q),Hi=P(F("g",{children:[g("path",{d:"M13.542 8.542H6.458a2.5 2.5 0 0 0-2.5 2.5v3.75a2.5 2.5 0 0 0 2.5 2.5h7.084a2.5 2.5 0 0 0 2.5-2.5v-3.75a2.5 2.5 0 0 0-2.5-2.5Z",stroke:"currentColor",strokeWidth:"1.25"}),g("path",{d:"M10 13.958a1.042 1.042 0 1 0 0-2.083 1.042 1.042 0 0 0 0 2.083Z",stroke:"currentColor",strokeWidth:"1.25"}),g("mask",{id:"UnlockedIcon",style:{maskType:"alpha"},maskUnits:"userSpaceOnUse",x:6,y:1,width:9,height:9,children:g("path",{stroke:"none",d:"M6.399 9.561V5.175c0-.93.401-1.823 1.116-2.48a3.981 3.981 0 0 1 2.693-1.028c1.01 0 1.98.37 2.694 1.027.715.658 1.116 1.55 1.116 2.481",fill:"#fff"})}),g("g",{mask:"url(#UnlockedIcon)",children:g("path",{stroke:"none",d:"M5.149 9.561v1.25h2.5v-1.25h-2.5Zm5.06-7.894V.417v1.25Zm2.559 3.508v1.25h2.5v-1.25h-2.5ZM7.648 8.51V5.175h-2.5V8.51h2.5Zm0-3.334c0-.564.243-1.128.713-1.561L6.668 1.775c-.959.883-1.52 2.104-1.52 3.4h2.5Zm.713-1.561a2.732 2.732 0 0 1 1.847-.697v-2.5c-1.31 0-2.585.478-3.54 1.358L8.36 3.614Zm1.847-.697c.71 0 1.374.26 1.847.697l1.694-1.839a5.231 5.231 0 0 0-3.54-1.358v2.5Zm1.847.697c.47.433.713.997.713 1.561h2.5c0-1.296-.56-2.517-1.52-3.4l-1.693 1.839Z",fill:"currentColor"})})]}),he),ja=P(F("g",{strokeWidth:"1.25",children:[g("path",{d:"M13.542 8.542H6.458a2.5 2.5 0 0 0-2.5 2.5v3.75a2.5 2.5 0 0 0 2.5 2.5h7.084a2.5 2.5 0 0 0 2.5-2.5v-3.75a2.5 2.5 0 0 0-2.5-2.5Z"}),g("path",{d:"M10 13.958a1.042 1.042 0 1 0 0-2.083 1.042 1.042 0 0 0 0 2.083Z"}),g("path",{d:"M6.667 8.333V5.417C6.667 3.806 8.159 2.5 10 2.5c1.841 0 3.333 1.306 3.333 2.917v2.916"})]}),he),Y1=P(F(Oe,{children:[g("path",{d:"M38.5 83.5c-14-2-17.833-10.473-21-22.5C14.333 48.984 12 22 12 12.5",stroke:"currentColor",strokeWidth:2,strokeLinecap:"round"}),g("path",{fillRule:"evenodd",clipRule:"evenodd",d:"m12.005 10.478 7.905 14.423L6 25.75l6.005-15.273Z",fill:"currentColor"}),g("path",{d:"M12.005 10.478c1.92 3.495 3.838 7 7.905 14.423m-7.905-14.423c3.11 5.683 6.23 11.368 7.905 14.423m0 0c-3.68.226-7.35.455-13.91.85m13.91-.85c-5.279.33-10.566.647-13.91.85m0 0c1.936-4.931 3.882-9.86 6.005-15.273M6 25.75c2.069-5.257 4.135-10.505 6.005-15.272",stroke:"currentColor",strokeWidth:2,strokeLinecap:"round"})]}),{width:41,height:94,fill:"none"}),K1=P(F(Oe,{children:[g("path",{d:"M18.026 1.232c-5.268 13.125-5.548 33.555 3.285 42.311 8.823 8.75 33.31 12.304 42.422 13.523",stroke:"currentColor",strokeWidth:2,strokeLinecap:"round"}),g("path",{fillRule:"evenodd",clipRule:"evenodd",d:"m72.181 59.247-13.058-10-2.948 13.62 16.006-3.62Z",fill:"currentColor"}),g("path",{d:"M72.181 59.247c-3.163-2.429-6.337-4.856-13.058-10m13.058 10c-5.145-3.936-10.292-7.882-13.058-10m0 0c-.78 3.603-1.563 7.196-2.948 13.62m2.948-13.62c-1.126 5.168-2.24 10.346-2.948 13.62m0 0c5.168-1.166 10.334-2.343 16.006-3.62m-16.006 3.62c5.51-1.248 11.01-2.495 16.006-3.62",stroke:"currentColor",strokeWidth:2,strokeLinecap:"round"})]}),{width:85,height:71,fill:"none"}),$1=P(F(Oe,{children:[g("path",{d:"M1 77c14-2 31.833-11.973 35-24 3.167-12.016-6-35-9.5-43.5",stroke:"currentColor",strokeWidth:2,strokeLinecap:"round"}),g("path",{fillRule:"evenodd",clipRule:"evenodd",d:"m24.165 1.093-2.132 16.309 13.27-4.258-11.138-12.05Z",fill:"currentColor"}),g("path",{d:"M24.165 1.093c-.522 3.953-1.037 7.916-2.132 16.309m2.131-16.309c-.835 6.424-1.68 12.854-2.13 16.308m0 0c3.51-1.125 7.013-2.243 13.27-4.257m-13.27 4.257c5.038-1.608 10.08-3.232 13.27-4.257m0 0c-3.595-3.892-7.197-7.777-11.14-12.05m11.14 12.05c-3.837-4.148-7.667-8.287-11.14-12.05",stroke:"currentColor",strokeWidth:2,strokeLinecap:"round"})]}),{width:38,height:78,fill:"none"}),TP=P(g("g",{fill:"currentColor",children:g("path",{d:"M39.9 32.889a.326.326 0 0 0-.279-.056c-2.094-3.083-4.774-6-7.343-8.833l-.419-.472a.212.212 0 0 0-.056-.139.586.586 0 0 0-.167-.111l-.084-.083-.056-.056c-.084-.167-.28-.278-.475-.167-.782.39-1.507.973-2.206 1.528-.92.722-1.842 1.445-2.708 2.25a8.405 8.405 0 0 0-.977 1.028c-.14.194-.028.361.14.444-.615.611-1.23 1.223-1.843 1.861a.315.315 0 0 0-.084.223c0 .083.056.166.111.194l1.09.833v.028c1.535 1.528 4.244 3.611 7.12 5.861.418.334.865.667 1.284 1 .195.223.39.473.558.695.084.11.28.139.391.055.056.056.14.111.196.167a.398.398 0 0 0 .167.056.255.255 0 0 0 .224-.111.394.394 0 0 0 .055-.167c.029 0 .028.028.056.028a.318.318 0 0 0 .224-.084l5.082-5.528a.309.309 0 0 0 0-.444Zm-14.63-1.917a.485.485 0 0 0 .111.14c.586.5 1.2 1 1.843 1.555l-2.569-1.945-.251-.166c-.056-.028-.112-.084-.168-.111l-.195-.167.056-.056.055-.055.112-.111c.866-.861 2.346-2.306 3.1-3.028-.81.805-2.43 3.167-2.095 3.944Zm8.767 6.89-2.122-1.612a44.713 44.713 0 0 0-2.625-2.5c1.145.861 2.122 1.611 2.262 1.75 1.117.972 1.06.806 1.815 1.445l.921.666a1.06 1.06 0 0 1-.251.25Zm.558.416-.056-.028c.084-.055.168-.111.252-.194l-.196.222ZM1.089 5.75c.055.361.14.722.195 1.056.335 1.833.67 3.5 1.284 4.75l.252.944c.084.361.223.806.363.917 1.424 1.25 3.602 3.11 5.947 4.889a.295.295 0 0 0 .363 0s0 .027.028.027a.254.254 0 0 0 .196.084.318.318 0 0 0 .223-.084c2.988-3.305 5.221-6.027 6.813-8.305.112-.111.14-.278.14-.417.111-.111.195-.25.307-.333.111-.111.111-.306 0-.39l-.028-.027c0-.055-.028-.139-.084-.167-.698-.666-1.2-1.138-1.731-1.638-.922-.862-1.871-1.75-3.881-3.75l-.028-.028c-.028-.028-.056-.056-.112-.056-.558-.194-1.703-.389-3.127-.639C6.087 2.223 3.21 1.723.614.944c0 0-.168 0-.196.028l-.083.084c-.028.027-.056.055-.224.11h.056-.056c.028.167.028.278.084.473 0 .055.112.5.112.555l.782 3.556Zm15.496 3.278-.335-.334c.084.112.196.195.335.334Zm-3.546 4.666-.056.056c0-.028.028-.056.056-.056Zm-2.038-10c.168.167.866.834 1.033.973-.726-.334-2.54-1.167-3.379-1.445.838.167 1.983.334 2.346.472ZM1.424 2.306c.419.722.754 3.222 1.089 5.666-.196-.778-.335-1.555-.503-2.278-.251-1.277-.503-2.416-.838-3.416.056 0 .14 0 .252.028Zm-.168-.584c-.112 0-.223-.028-.307-.028 0-.027 0-.055-.028-.055.14 0 .223.028.335.083Zm-1.089.222c0-.027 0-.027 0 0ZM39.453 1.333c.028-.11-.558-.61-.363-.639.42-.027.42-.666 0-.666-.558.028-1.144.166-1.675.25-.977.194-1.982.389-2.96.61-2.205.473-4.383.973-6.561 1.557-.67.194-1.424.333-2.066.666-.224.111-.196.333-.084.472-.056.028-.084.028-.14.056-.195.028-.363.056-.558.083-.168.028-.252.167-.224.334 0 .027.028.083.028.11-1.173 1.556-2.485 3.195-3.909 4.945-1.396 1.611-2.876 3.306-4.356 5.056-4.719 5.5-10.052 11.75-15.943 17.25a.268.268 0 0 0 0 .389c.028.027.056.055.084.055-.084.084-.168.14-.252.222-.056.056-.084.111-.084.167a.605.605 0 0 0-.111.139c-.112.111-.112.305.028.389.111.11.307.11.39-.028.029-.028.029-.056.056-.056a.44.44 0 0 1 .615 0c.335.362.67.723.977 1.028l-.698-.583c-.112-.111-.307-.083-.39.028-.113.11-.085.305.027.389l7.427 6.194c.056.056.112.056.196.056s.14-.028.195-.084l.168-.166c.028.027.083.027.111.027.084 0 .14-.027.196-.083 10.052-10.055 18.15-17.639 27.42-24.417.083-.055.111-.166.111-.25.112 0 .196-.083.251-.194 1.704-5.194 2.039-9.806 2.15-12.083v-.028c0-.028.028-.056.028-.083.028-.056.028-.084.028-.084a1.626 1.626 0 0 0-.111-1.028ZM21.472 9.5c.446-.5.893-1.028 1.34-1.5-2.876 3.778-7.65 9.583-14.408 16.5 4.607-5.083 9.242-10.333 13.068-15ZM5.193 35.778h.084-.084Zm3.462 3.194c-.027-.028-.027-.028 0-.028v.028Zm4.16-3.583c.224-.25.448-.472.699-.722 0 0 0 .027.028.027-.252.223-.475.445-.726.695Zm1.146-1.111c.14-.14.279-.334.446-.5l.028-.028c1.648-1.694 3.351-3.389 5.082-5.111l.028-.028c.419-.333.921-.694 1.368-1.028a379.003 379.003 0 0 0-6.952 6.695ZM24.794 6.472c-.921 1.195-1.954 2.778-2.82 4.028-2.736 3.944-11.532 13.583-11.727 13.75a1976.983 1976.983 0 0 1-8.042 7.639l-.167.167c-.14-.167-.14-.417.028-.556C14.49 19.861 22.03 10.167 25.074 5.917c-.084.194-.14.36-.28.555Zm4.83 5.695c-1.116-.64-1.646-1.64-1.34-2.611l.084-.334c.028-.083.084-.194.14-.277.307-.5.754-.917 1.257-1.167.027 0 .055 0 .083-.028-.028-.056-.028-.139-.028-.222.028-.167.14-.278.335-.278.335 0 1.369.306 1.76.639.111.083.223.194.335.305.14.167.363.445.474.667.056.028.112.306.196.445.056.222.111.472.084.694-.028.028 0 .194-.028.194a2.668 2.668 0 0 1-.363 1.028c-.028.028-.028.056-.056.084l-.028.027c-.14.223-.335.417-.53.556-.643.444-1.369.583-2.095.389 0 0-.195-.084-.28-.111Zm8.154-.834a39.098 39.098 0 0 1-.893 3.167c0 .028-.028.083 0 .111-.056 0-.084.028-.14.056-2.206 1.61-4.356 3.305-6.506 5.028 1.843-1.64 3.686-3.306 5.613-4.945.558-.5.949-1.139 1.06-1.861l.28-1.667v-.055c.14-.334.67-.195.586.166Z",fill:"currentColor"})}),{width:40,height:40,fill:"none"}),X1=P(F("g",{stroke:"currentColor",strokeLinecap:"round",strokeLinejoin:"round",children:[g("path",{stroke:"none",d:"M0 0h24v24H0z",fill:"none"}),g("path",{d:"M6 6l4.153 11.793a0.365 .365 0 0 0 .331 .207a0.366 .366 0 0 0 .332 -.207l2.184 -4.793l4.787 -1.994a0.355 .355 0 0 0 .213 -.323a0.355 .355 0 0 0 -.213 -.323l-11.787 -4.36z"}),g("path",{d:"M13.5 13.5l4.5 4.5"})]}),{fill:"none",width:22,height:22,strokeWidth:1.25}),Z1=P(F("g",{strokeWidth:"1.5",children:[g("path",{stroke:"none",d:"M0 0h24v24H0z",fill:"none"}),g("rect",{x:"4",y:"4",width:"16",height:"16",rx:"2"})]}),Q),j1=P(F("g",{strokeWidth:"1.5",children:[g("path",{stroke:"none",d:"M0 0h24v24H0z",fill:"none"}),g("path",{d:"M10.5 20.4l-6.9 -6.9c-.781 -.781 -.781 -2.219 0 -3l6.9 -6.9c.781 -.781 2.219 -.781 3 0l6.9 6.9c.781 .781 .781 2.219 0 3l-6.9 6.9c-.781 .781 -2.219 .781 -3 0z"})]}),Q),q1=P(F("g",{strokeWidth:"1.5",children:[g("path",{stroke:"none",d:"M0 0h24v24H0z",fill:"none"}),g("circle",{cx:"12",cy:"12",r:"9"})]}),Q),J1=P(F("g",{strokeWidth:"1.5",children:[g("path",{stroke:"none",d:"M0 0h24v24H0z",fill:"none"}),g("line",{x1:"5",y1:"12",x2:"19",y2:"12"}),g("line",{x1:"15",y1:"16",x2:"19",y2:"12"}),g("line",{x1:"15",y1:"8",x2:"19",y2:"12"})]}),Q),Q1=P(g("path",{d:"M4.167 10h11.666",strokeWidth:"1.5"}),he),eb=P(F("g",{strokeWidth:"1.25",children:[g("path",{stroke:"none",d:"M0 0h24v24H0z",fill:"none"}),g("path",{d:"M20 17v-12c0 -1.121 -.879 -2 -2 -2s-2 .879 -2 2v12l2 2l2 -2z"}),g("path",{d:"M16 7h4"}),g("path",{d:"M18 19h-13a2 2 0 1 1 0 -4h4a2 2 0 1 0 0 -4h-3"})]}),Q),qa=P(F("g",{strokeWidth:"1.25",children:[g("path",{clipRule:"evenodd",d:"m7.643 15.69 7.774-7.773a2.357 2.357 0 1 0-3.334-3.334L4.31 12.357a3.333 3.333 0 0 0-.977 2.357v1.953h1.953c.884 0 1.732-.352 2.357-.977Z"}),g("path",{d:"m11.25 5.417 3.333 3.333"})]}),he),tb=P(F("g",{strokeWidth:"1.5",children:[g("path",{stroke:"none",d:"M0 0h24v24H0z",fill:"none"}),g("line",{x1:"4",y1:"20",x2:"7",y2:"20"}),g("line",{x1:"14",y1:"20",x2:"21",y2:"20"}),g("line",{x1:"6.9",y1:"15",x2:"13.8",y2:"15"}),g("line",{x1:"10.2",y1:"6.3",x2:"16",y2:"20"}),g("polyline",{points:"5 20 11 4 13 4 20 20"})]}),Q),rb=P(F("g",{strokeWidth:"1.25",children:[g("path",{d:"M12.5 6.667h.01"}),g("path",{d:"M4.91 2.625h10.18a2.284 2.284 0 0 1 2.285 2.284v10.182a2.284 2.284 0 0 1-2.284 2.284H4.909a2.284 2.284 0 0 1-2.284-2.284V4.909a2.284 2.284 0 0 1 2.284-2.284Z"}),g("path",{d:"m3.333 12.5 3.334-3.333c.773-.745 1.726-.745 2.5 0l4.166 4.166"}),g("path",{d:"m11.667 11.667.833-.834c.774-.744 1.726-.744 2.5 0l1.667 1.667"})]}),he),ob=P(F("g",{strokeWidth:"1.5",children:[g("path",{stroke:"none",d:"M0 0h24v24H0z",fill:"none"}),g("path",{d:"M19 20h-10.5l-4.21 -4.3a1 1 0 0 1 0 -1.41l10 -10a1 1 0 0 1 1.41 0l5 5a1 1 0 0 1 0 1.41l-9.2 9.3"}),g("path",{d:"M18 13.3l-6.3 -6.3"})]}),Q),gu=P(g("path",{strokeWidth:"1.25",d:"M10 4.167v11.666M4.167 10h11.666"}),he),fu=P(g("path",{d:"M5 10h10",strokeWidth:"1.25"}),he),nb=P(F("g",{strokeWidth:1.25,children:[g("path",{stroke:"none",d:"M0 0h24v24H0z",fill:"none"}),g("path",{d:"M21 21l-6 -6"}),g("path",{d:"M3.268 12.043a7.017 7.017 0 0 0 6.634 4.957a7.012 7.012 0 0 0 7.043 -6.131a7 7 0 0 0 -5.314 -7.672a7.021 7.021 0 0 0 -8.241 4.403"}),g("path",{d:"M3 4v4h4"})]}),Q),To=P(g("path",{strokeWidth:"1.25",d:"M3.333 5.833h13.334M8.333 9.167v5M11.667 9.167v5M4.167 5.833l.833 10c0 .92.746 1.667 1.667 1.667h6.666c.92 0 1.667-.746 1.667-1.667l.833-10M7.5 5.833v-2.5c0-.46.373-.833.833-.833h3.334c.46 0 .833.373.833.833v2.5"}),he),ib=P(F("g",{strokeWidth:"1.25",children:[g("polyline",{points:"12 16 18 10 12 4"}),g("polyline",{points:"8 4 2 10 8 16"})]}),he),ps=P(F("g",{strokeWidth:"1.25",children:[g("path",{d:"M14.375 6.458H8.958a2.5 2.5 0 0 0-2.5 2.5v5.417a2.5 2.5 0 0 0 2.5 2.5h5.417a2.5 2.5 0 0 0 2.5-2.5V8.958a2.5 2.5 0 0 0-2.5-2.5Z"}),g("path",{clipRule:"evenodd",d:"M11.667 3.125c.517 0 .986.21 1.325.55.34.338.55.807.55 1.325v1.458H8.333c-.485 0-.927.185-1.26.487-.343.312-.57.75-.609 1.24l-.005 5.357H5a1.87 1.87 0 0 1-1.326-.55 1.87 1.87 0 0 1-.549-1.325V5c0-.518.21-.987.55-1.326.338-.34.807-.549 1.325-.549h6.667Z"})]}),he),us=P(g("path",{clipRule:"evenodd",d:"M10 2.5h.328a6.25 6.25 0 0 0 6.6 10.372A7.5 7.5 0 1 1 10 2.493V2.5Z",stroke:"currentColor"}),he),hs=P(g("g",{stroke:"currentColor",strokeLinejoin:"round",children:g("path",{d:"M10 12.5a2.5 2.5 0 1 0 0-5 2.5 2.5 0 0 0 0 5ZM10 4.167V2.5M14.167 5.833l1.166-1.166M15.833 10H17.5M14.167 14.167l1.166 1.166M10 15.833V17.5M5.833 14.167l-1.166 1.166M5 10H3.333M5.833 5.833 4.667 4.667"})}),{...he,strokeWidth:1.5}),rd=P(F("g",{strokeWidth:"1.5",children:[g("path",{stroke:"none",d:"M0 0h24v24H0z",fill:"none"}),g("line",{x1:"4",y1:"6",x2:"20",y2:"6"}),g("line",{x1:"4",y1:"12",x2:"20",y2:"12"}),g("line",{x1:"4",y1:"18",x2:"20",y2:"18"})]}),Q),Ui=P(g("path",{strokeWidth:"1.25",d:"M3.333 14.167v1.666c0 .92.747 1.667 1.667 1.667h10c.92 0 1.667-.746 1.667-1.667v-1.666M5.833 9.167 10 13.333l4.167-4.166M10 3.333v10"}),he),Ja=P(F("g",{strokeWidth:"1.5",children:[g("path",{stroke:"none",d:"M0 0h24v24H0z",fill:"none"}),g("circle",{cx:"12",cy:"12",r:"9"}),g("line",{x1:"12",y1:"17",x2:"12",y2:"17.01"}),g("path",{d:"M12 13.5a1.5 1.5 0 0 1 1 -1.5a2.6 2.6 0 1 0 -3 -4"})]}),Q),ab=P(F("g",{strokeWidth:"1.25",children:[g("path",{stroke:"none",d:"M0 0h24v24H0z",fill:"none"}),g("circle",{cx:"12",cy:"12",r:"9"}),g("line",{x1:"12",y1:"17",x2:"12",y2:"17.01"}),g("path",{d:"M12 13.5a1.5 1.5 0 0 1 1 -1.5a2.6 2.6 0 1 0 -3 -4"})]}),Q),bu=P(g("path",{strokeWidth:"1.25",d:"M9.167 5.833H5.833c-1.254 0-2.5 1.282-2.5 2.5v5.834c0 1.283 1.252 2.5 2.5 2.5h5.834c1.251 0 2.5-1.25 2.5-2.5v-3.334M8.333 11.667l8.334-8.334M12.5 3.333h4.167V7.5"}),he),od=P(g("path",{d:"M7.5 15.833c-3.583 1.167-3.583-2.083-5-2.5m10 4.167v-2.917c0-.833.083-1.166-.417-1.666 2.334-.25 4.584-1.167 4.584-5a3.833 3.833 0 0 0-1.084-2.667 3.5 3.5 0 0 0-.083-2.667s-.917-.25-2.917 1.084a10.25 10.25 0 0 0-5.166 0C5.417 2.333 4.5 2.583 4.5 2.583a3.5 3.5 0 0 0-.083 2.667 3.833 3.833 0 0 0-1.084 2.667c0 3.833 2.25 4.75 4.584 5-.5.5-.5 1-.417 1.666V17.5",strokeWidth:"1.25"}),he),lb=P(F("g",{strokeWidth:"1.25",children:[g("path",{d:"M7.5 10.833a.833.833 0 1 0 0-1.666.833.833 0 0 0 0 1.666ZM12.5 10.833a.833.833 0 1 0 0-1.666.833.833 0 0 0 0 1.666ZM6.25 6.25c2.917-.833 4.583-.833 7.5 0M5.833 13.75c2.917.833 5.417.833 8.334 0"}),g("path",{d:"M12.917 14.167c0 .833 1.25 2.5 1.666 2.5 1.25 0 2.361-1.39 2.917-2.5.556-1.39.417-4.861-1.25-9.584-1.214-.846-2.5-1.116-3.75-1.25l-.833 2.084M7.083 14.167c0 .833-1.13 2.5-1.526 2.5-1.191 0-2.249-1.39-2.778-2.5-.529-1.39-.397-4.861 1.19-9.584 1.157-.846 2.318-1.116 3.531-1.25l.833 2.084"})]}),he),sb=P(F("g",{strokeWidth:"1.25",children:[g("path",{stroke:"none",d:"M0 0h24v24H0z",fill:"none"}),g("path",{d:"M4 4l11.733 16h4.267l-11.733 -16z"}),g("path",{d:"M4 20l6.768 -6.768m2.46 -2.46l6.772 -6.772"})]}),Q),cb=P(g("polyline",{fill:"none",stroke:"currentColor",points:"20 6 9 17 4 12"}),{width:24,height:24}),gs=P(F("g",{strokeWidth:"1.25",children:[g("path",{d:"M8.333 11.667a2.917 2.917 0 0 0 4.167 0l3.333-3.334a2.946 2.946 0 1 0-4.166-4.166l-.417.416"}),g("path",{d:"M11.667 8.333a2.917 2.917 0 0 0-4.167 0l-3.333 3.334a2.946 2.946 0 0 0 4.166 4.166l.417-.416"})]}),he),db=P("M433.941 129.941l-83.882-83.882A48 48 0 0 0 316.118 32H48C21.49 32 0 53.49 0 80v352c0 26.51 21.49 48 48 48h352c26.51 0 48-21.49 48-48V163.882a48 48 0 0 0-14.059-33.941zM224 416c-35.346 0-64-28.654-64-64 0-35.346 28.654-64 64-64s64 28.654 64 64c0 35.346-28.654 64-64 64zm96-304.52V212c0 6.627-5.373 12-12 12H76c-6.627 0-12-5.373-12-12V108c0-6.627 5.373-12 12-12h228.52c3.183 0 6.235 1.264 8.485 3.515l3.48 3.48A11.996 11.996 0 0 1 320 111.48z",{width:448,height:512}),mb=P("M252 54L203 8a28 27 0 00-20-8H28C12 0 0 12 0 27v195c0 15 12 26 28 26h204c15 0 28-11 28-26V73a28 27 0 00-8-19zM130 213c-21 0-37-16-37-36 0-19 16-35 37-35 20 0 37 16 37 35 0 20-17 36-37 36zm56-169v56c0 4-4 6-7 6H44c-4 0-7-2-7-6V42c0-4 3-7 7-7h133l4 2 3 2a7 7 0 012 5z M296 201l87 95-188 205-78 9c-10 1-19-8-18-20l9-84zm141-14l-41-44a31 31 0 00-46 0l-38 41 87 95 38-42c13-14 13-36 0-50z",{width:448,height:512}),Qa=P(g("path",{d:"m9.257 6.351.183.183H15.819c.34 0 .727.182 1.051.506.323.323.505.708.505 1.05v5.819c0 .316-.183.7-.52 1.035-.337.338-.723.522-1.037.522H4.182c-.352 0-.74-.181-1.058-.5-.318-.318-.499-.705-.499-1.057V5.182c0-.351.181-.736.5-1.054.32-.321.71-.503 1.057-.503H6.53l2.726 2.726Z",strokeWidth:"1.25"}),he),SP=P("M384 112v352c0 26.51-21.49 48-48 48H48c-26.51 0-48-21.49-48-48V112c0-26.51 21.49-48 48-48h80c0-35.29 28.71-64 64-64s64 28.71 64 64h80c26.51 0 48 21.49 48 48zM192 40c-13.255 0-24 10.745-24 24s10.745 24 24 24 24-10.745 24-24-10.745-24-24-24m96 114v-20a6 6 0 0 0-6-6H102a6 6 0 0 0-6 6v20a6 6 0 0 0 6 6h180a6 6 0 0 0 6-6z",{width:384,height:512}),pb=P("M204.3 5C104.9 24.4 24.8 104.3 5.2 203.4c-37 187 131.7 326.4 258.8 306.7 41.2-6.4 61.4-54.6 42.5-91.7-23.1-45.4 9.9-98.4 60.9-98.4h79.7c35.8 0 64.8-29.6 64.9-65.3C511.5 97.1 368.1-26.9 204.3 5zM96 320c-17.7 0-32-14.3-32-32s14.3-32 32-32 32 14.3 32 32-14.3 32-32 32zm32-128c-17.7 0-32-14.3-32-32s14.3-32 32-32 32 14.3 32 32-14.3 32-32 32zm128-64c-17.7 0-32-14.3-32-32s14.3-32 32-32 32 14.3 32 32-14.3 32-32 32zm128 64c-17.7 0-32-14.3-32-32s14.3-32 32-32 32 14.3 32 32-14.3 32-32 32z"),nd=P(F("g",{strokeWidth:1.25,children:[g("path",{stroke:"none",d:"M0 0h24v24H0z",fill:"none"}),g("path",{d:"M5 16l1.465 1.638a2 2 0 1 1 -3.015 .099l1.55 -1.737z"}),g("path",{d:"M13.737 9.737c2.299 -2.3 3.23 -5.095 2.081 -6.245c-1.15 -1.15 -3.945 -.217 -6.244 2.082c-2.3 2.299 -3.231 5.095 -2.082 6.244c1.15 1.15 3.946 .218 6.245 -2.081z"}),g("path",{d:"M7.492 11.818c.362 .362 .768 .676 1.208 .934l6.895 4.047c1.078 .557 2.255 -.075 3.692 -1.512c1.437 -1.437 2.07 -2.614 1.512 -3.692c-.372 -.718 -1.72 -3.017 -4.047 -6.895a6.015 6.015 0 0 0 -.934 -1.208"})]}),Q),id=P(F("g",{strokeWidth:"1.25",children:[g("path",{stroke:"none",d:"M0 0h24v24H0z",fill:"none"}),g("path",{d:"M15 8h.01"}),g("path",{d:"M12 20h-5a3 3 0 0 1 -3 -3v-10a3 3 0 0 1 3 -3h10a3 3 0 0 1 3 3v5"}),g("path",{d:"M4 15l4 -4c.928 -.893 2.072 -.893 3 0l4 4"}),g("path",{d:"M14 14l1 -1c.617 -.593 1.328 -.793 2.009 -.598"}),g("path",{d:"M19 16v6"}),g("path",{d:"M22 19l-3 3l-3 -3"})]}),Q),ub=P("M216 0h80c13.3 0 24 10.7 24 24v168h87.7c17.8 0 26.7 21.5 14.1 34.1L269.7 378.3c-7.5 7.5-19.8 7.5-27.3 0L90.1 226.1c-12.6-12.6-3.7-34.1 14.1-34.1H192V24c0-13.3 10.7-24 24-24zm296 376v112c0 13.3-10.7 24-24 24H24c-13.3 0-24-10.7-24-24V376c0-13.3 10.7-24 24-24h146.7l49 49c20.1 20.1 52.5 20.1 72.6 0l49-49H488c13.3 0 24 10.7 24 24zm-124 88c0-11-9-20-20-20s-20 9-20 20 9 20 20 20 20-9 20-20zm64 0c0-11-9-20-20-20s-20 9-20 20 9 20 20 20 20-9 20-20z",{width:512,height:512}),CP=P("M416 208H272V64c0-17.67-14.33-32-32-32h-32c-17.67 0-32 14.33-32 32v144H32c-17.67 0-32 14.33-32 32v32c0 17.67 14.33 32 32 32h144v144c0 17.67 14.33 32 32 32h32c17.67 0 32-14.33 32-32V304h144c17.67 0 32-14.33 32-32v-32c0-17.67-14.33-32-32-32z",{width:448,height:512}),IP=P("M416 208H32c-17.67 0-32 14.33-32 32v32c0 17.67 14.33 32 32 32h384c17.67 0 32-14.33 32-32v-32c0-17.67-14.33-32-32-32z",{width:448,height:512}),hb=P("M173.898 439.404l-166.4-166.4c-9.997-9.997-9.997-26.206 0-36.204l36.203-36.204c9.997-9.998 26.207-9.998 36.204 0L192 312.69 432.095 72.596c9.997-9.997 26.207-9.997 36.204 0l36.203 36.204c9.997 9.997 9.997 26.206 0 36.204l-294.4 294.401c-9.998 9.997-26.207 9.997-36.204-.001z"),AP=P("M16 132h416c8.837 0 16-7.163 16-16V76c0-8.837-7.163-16-16-16H16C7.163 60 0 67.163 0 76v40c0 8.837 7.163 16 16 16zm0 160h416c8.837 0 16-7.163 16-16v-40c0-8.837-7.163-16-16-16H16c-8.837 0-16 7.163-16 16v40c0 8.837 7.163 16 16 16zm0 160h416c8.837 0 16-7.163 16-16v-40c0-8.837-7.163-16-16-16H16c-8.837 0-16 7.163-16 16v40c0 8.837 7.163 16 16 16z"),Eu=P(g("path",{d:"M7.5 10.833 4.167 7.5 7.5 4.167M4.167 7.5h9.166a3.333 3.333 0 0 1 0 6.667H12.5",strokeWidth:"1.25"}),he),xu=P(g("path",{d:"M12.5 10.833 15.833 7.5 12.5 4.167M15.833 7.5H6.667a3.333 3.333 0 1 0 0 6.667H7.5",strokeWidth:"1.25"}),he),gb=P("M504 256c0 136.997-111.043 248-248 248S8 392.997 8 256C8 119.083 119.043 8 256 8s248 111.083 248 248zM262.655 90c-54.497 0-89.255 22.957-116.549 63.758-3.536 5.286-2.353 12.415 2.715 16.258l34.699 26.31c5.205 3.947 12.621 3.008 16.665-2.122 17.864-22.658 30.113-35.797 57.303-35.797 20.429 0 45.698 13.148 45.698 32.958 0 14.976-12.363 22.667-32.534 33.976C247.128 238.528 216 254.941 216 296v4c0 6.627 5.373 12 12 12h56c6.627 0 12-5.373 12-12v-1.333c0-28.462 83.186-29.647 83.186-106.667 0-58.002-60.165-102-116.531-102zM256 338c-25.365 0-46 20.635-46 46 0 25.364 20.635 46 46 46s46-20.636 46-46c0-25.365-20.635-46-46-46z",{mirror:!0}),fb=P(g("path",{d:"M5 12.5a2.5 2.5 0 1 0 0-5 2.5 2.5 0 0 0 0 5ZM15 7.5a2.5 2.5 0 1 0 0-5 2.5 2.5 0 0 0 0 5ZM15 17.5a2.5 2.5 0 1 0 0-5 2.5 2.5 0 0 0 0 5ZM7.25 8.917l5.5-2.834M7.25 11.083l5.5 2.834",strokeWidth:"1.5"}),he),kP=P("M256 32c14.2 0 27.3 7.5 34.5 19.8l216 368c7.3 12.4 7.3 27.7 .2 40.1S486.3 480 472 480H40c-14.3 0-27.6-7.7-34.7-20.1s-7-27.8 .2-40.1l216-368C228.7 39.5 241.8 32 256 32zm0 128c-13.3 0-24 10.7-24 24V296c0 13.3 10.7 24 24 24s24-10.7 24-24V184c0-13.3-10.7-24-24-24zm32 224a32 32 0 1 0 -64 0 32 32 0 1 0 64 0z"),MP=P("M16 5l-1.42 1.42-1.59-1.59V16h-1.98V4.83L9.42 6.42 8 5l4-4 4 4zm4 5v11c0 1.1-.9 2-2 2H6c-1.11 0-2-.9-2-2V10c0-1.11.89-2 2-2h3v2H6v11h12V10h-3V8h3c1.1 0 2 .89 2 2z",{width:24,height:24}),LP=P(F("g",{strokeWidth:1.25,children:[g("path",{stroke:"none",d:"M0 0h24v24H0z",fill:"none"}),g("path",{d:"M8 9h-1a2 2 0 0 0 -2 2v8a2 2 0 0 0 2 2h10a2 2 0 0 0 2 -2v-8a2 2 0 0 0 -2 -2h-1"}),g("path",{d:"M12 14v-11"}),g("path",{d:"M9 6l3 -3l3 3"})]}),Q),PP=P(F(Oe,{children:[g("path",{fill:"currentColor",d:"M40 5.6v6.1l-4.1.7c-8.9 1.4-16.5 6.9-20.6 15C13 32 10.9 43 12.4 43c.4 0 2.4-1.3 4.4-3 5-3.9 12.1-7 18.2-7.7l5-.6v12.8l11.2-11.3L62.5 22 51.2 10.8 40-.5v6.1zm10.2 22.6L44 34.5v-6.8l-6.9.6c-3.9.3-9.8 1.7-13.2 3.1-3.5 1.4-6.5 2.4-6.7 2.2-.9-1 3-7.5 6.4-10.8C28 18.6 34.4 16 40.1 16c3.7 0 3.9-.1 3.9-3.2V9.5l6.2 6.3 6.3 6.2-6.3 6.2z"}),g("path",{stroke:"currentColor",fill:"currentColor",d:"M0 36v20h48v-6.2c0-6 0-6.1-2-4.3-1.1 1-2 2.9-2 4.2V52H4V34c0-17.3-.1-18-2-18s-2 .7-2 20z"})]}),{width:64,height:64}),DP=P(g("path",{stroke:"currentColor",strokeWidth:"40",fill:"currentColor",d:"M148 560a318 318 0 0 0 522 110 316 316 0 0 0 0-450 316 316 0 0 0-450 0c-11 11-21 22-30 34v4h47c25 0 46 21 46 46s-21 45-46 45H90c-13 0-25-6-33-14-9-9-14-20-14-33V156c0-25 20-45 45-45s45 20 45 45v32l1 1a401 401 0 0 1 623 509l212 212a42 42 0 0 1-59 59L698 757A401 401 0 0 1 65 570a42 42 0 0 1 83-10z"}),{width:1024}),yu=P(F(Oe,{children:[F("g",{clipPath:"url(#a)",stroke:"currentColor",strokeWidth:"1.25",strokeLinecap:"round",strokeLinejoin:"round",children:[g("path",{d:"M13.889 4.167H8.333c-.767 0-1.389.622-1.389 1.389v5.555c0 .767.622 1.389 1.39 1.389h5.555c.767 0 1.389-.622 1.389-1.389V5.556c0-.767-.622-1.39-1.39-1.39Z",fill:"currentColor"}),g("path",{d:"M12.5 12.5v1.389a1.389 1.389 0 0 1-1.389 1.389H5.556a1.389 1.389 0 0 1-1.39-1.39V8.334a1.389 1.389 0 0 1 1.39-1.389h1.388"})]}),g("defs",{children:g("clipPath",{id:"a",children:g("path",{fill:"#fff",d:"M0 0h20v20H0z"})})})]}),he),wu=P(F(Oe,{children:[F("g",{clipPath:"url(#a)",stroke:"currentColor",strokeWidth:"1.25",strokeLinecap:"round",strokeLinejoin:"round",children:[g("path",{fillRule:"evenodd",clipRule:"evenodd",d:"M6.944 12.5H12.5v1.389a1.389 1.389 0 0 1-1.389 1.389H5.556a1.389 1.389 0 0 1-1.39-1.39V8.334a1.389 1.389 0 0 1 1.39-1.389h1.388",fill:"currentColor"}),g("path",{d:"M13.889 4.167H8.333c-.767 0-1.389.621-1.389 1.389v5.555c0 .767.622 1.389 1.39 1.389h5.555c.767 0 1.389-.622 1.389-1.389V5.556c0-.768-.622-1.39-1.39-1.39Z"})]}),g("defs",{children:g("clipPath",{id:"a",children:g("path",{fill:"#fff",d:"M0 0h20v20H0z"})})})]}),he),vu=P(F(Oe,{children:[F("g",{clipPath:"url(#a)",stroke:"currentColor",strokeWidth:"1.25",children:[g("path",{d:"M8.775 6.458h2.45a2.316 2.316 0 0 1 2.317 2.316v2.452a2.316 2.316 0 0 1-2.316 2.316H8.774a2.316 2.316 0 0 1-2.317-2.316V8.774a2.316 2.316 0 0 1 2.317-2.316Z",fill:"currentColor"}),g("path",{d:"M5.441 9.792h2.451a2.316 2.316 0 0 1 2.316 2.316v2.45a2.316 2.316 0 0 1-2.316 2.317h-2.45a2.316 2.316 0 0 1-2.317-2.316v-2.451a2.316 2.316 0 0 1 2.316-2.316ZM12.108 3.125h2.45a2.316 2.316 0 0 1 2.317 2.316v2.451a2.316 2.316 0 0 1-2.316 2.316h-2.451a2.316 2.316 0 0 1-2.316-2.316v-2.45a2.316 2.316 0 0 1 2.316-2.317Z"})]}),g("defs",{children:g("clipPath",{id:"a",children:g("path",{fill:"#fff",d:"M0 0h20v20H0z"})})})]}),he),Tu=P(F(Oe,{children:[F("g",{clipPath:"url(#a)",children:[g("path",{d:"M5.441 9.792h2.451a2.316 2.316 0 0 1 2.316 2.316v2.45a2.316 2.316 0 0 1-2.316 2.317h-2.45a2.316 2.316 0 0 1-2.317-2.316v-2.451a2.316 2.316 0 0 1 2.316-2.316Z",stroke:"currentColor",strokeWidth:"1.25"}),g("path",{d:"M5.441 9.792h2.451a2.316 2.316 0 0 1 2.316 2.316v2.45a2.316 2.316 0 0 1-2.316 2.317h-2.45a2.316 2.316 0 0 1-2.317-2.316v-2.451a2.316 2.316 0 0 1 2.316-2.316Z",stroke:"currentColor",strokeWidth:"1.25"}),g("mask",{id:"SendToBackIcon",fill:"#fff",children:g("path",{fillRule:"evenodd",clipRule:"evenodd",d:"M9.167 5.833v2.06a2.941 2.941 0 0 0 2.94 2.94h2.06v.393a2.941 2.941 0 0 1-2.941 2.94h-.393v-2.058a2.941 2.941 0 0 0-2.94-2.941h-2.06v-.393a2.941 2.941 0 0 1 2.942-2.94h.392Z"})}),g("path",{fillRule:"evenodd",clipRule:"evenodd",d:"M9.167 5.833v2.06a2.941 2.941 0 0 0 2.94 2.94h2.06v.393a2.941 2.941 0 0 1-2.941 2.94h-.393v-2.058a2.941 2.941 0 0 0-2.94-2.941h-2.06v-.393a2.941 2.941 0 0 1 2.942-2.94h.392Z",fill:"currentColor"}),g("path",{d:"M9.167 5.833h1.25v-1.25h-1.25v1.25Zm5 5h1.25v-1.25h-1.25v1.25Zm-3.334 3.334h-1.25v1.25h1.25v-1.25Zm-5-5h-1.25v1.25h1.25v-1.25Zm2.084-3.334v2.06h2.5v-2.06h-2.5Zm0 2.06a4.191 4.191 0 0 0 4.19 4.19v-2.5a1.691 1.691 0 0 1-1.69-1.69h-2.5Zm4.19 4.19h2.06v-2.5h-2.06v2.5Zm.81-1.25v.393h2.5v-.393h-2.5Zm0 .393c0 .933-.758 1.69-1.691 1.69v2.5a4.191 4.191 0 0 0 4.19-4.19h-2.5Zm-1.691 1.69h-.393v2.5h.393v-2.5Zm.857 1.25v-2.058h-2.5v2.059h2.5Zm0-2.058a4.191 4.191 0 0 0-4.19-4.191v2.5c.933 0 1.69.757 1.69 1.69h2.5Zm-4.19-4.191h-2.06v2.5h2.06v-2.5Zm-.81 1.25v-.393h-2.5v.393h2.5Zm0-.393c0-.934.758-1.69 1.692-1.69v-2.5a4.191 4.191 0 0 0-4.192 4.19h2.5Zm1.692-1.69h.392v-2.5h-.392v2.5Z",fill:"currentColor",mask:"url(#SendToBackIcon)"}),g("path",{d:"M12.108 3.125h2.45a2.316 2.316 0 0 1 2.317 2.316v2.451a2.316 2.316 0 0 1-2.316 2.316h-2.451a2.316 2.316 0 0 1-2.316-2.316v-2.45a2.316 2.316 0 0 1 2.316-2.317Z",stroke:"currentColor",strokeWidth:"1.25"})]}),g("defs",{children:g("clipPath",{id:"a",children:g("path",{fill:"#fff",d:"M0 0h20v20H0z"})})})]}),he),Su=P(F(Oe,{children:[F("g",{clipPath:"url(#a)",stroke:"currentColor",strokeWidth:"1.25",children:[g("path",{d:"M3.333 3.333h13.334",strokeLinecap:"round",strokeLinejoin:"round"}),g("path",{d:"M13.542 6.458h-.417c-.92 0-1.667.747-1.667 1.667v7.083c0 .92.746 1.667 1.667 1.667h.417c.92 0 1.666-.746 1.666-1.667V8.125c0-.92-.746-1.667-1.666-1.667ZM6.875 6.458h-.417c-.92 0-1.666.747-1.666 1.667v3.75c0 .92.746 1.667 1.666 1.667h.417c.92 0 1.667-.746 1.667-1.667v-3.75c0-.92-.747-1.667-1.667-1.667Z"})]}),g("defs",{children:g("clipPath",{id:"a",children:g("path",{fill:"#fff",d:"M0 0h20v20H0z"})})})]}),he),Cu=P(F(Oe,{children:[F("g",{clipPath:"url(#a)",stroke:"currentColor",strokeWidth:"1.25",children:[g("path",{d:"M3.333 16.667h13.334",strokeLinecap:"round",strokeLinejoin:"round"}),g("path",{d:"M6.875 3.125h-.417c-.92 0-1.666.746-1.666 1.667v7.083c0 .92.746 1.667 1.666 1.667h.417c.92 0 1.667-.746 1.667-1.667V4.792c0-.92-.747-1.667-1.667-1.667ZM13.542 5.817h-.417c-.92 0-1.667.747-1.667 1.667v4.391c0 .92.746 1.667 1.667 1.667h.417c.92 0 1.666-.746 1.666-1.667V7.484c0-.92-.746-1.667-1.666-1.667Z"})]}),g("defs",{children:g("clipPath",{id:"a",children:g("path",{fill:"#fff",d:"M0 0h20v20H0z"})})})]}),he),Iu=P(F(Oe,{children:[F("g",{clipPath:"url(#a)",stroke:"currentColor",strokeWidth:"1.25",children:[g("path",{d:"M3.333 3.333v13.334",strokeLinecap:"round",strokeLinejoin:"round"}),g("path",{d:"M15.208 4.792H8.125c-.92 0-1.667.746-1.667 1.666v.417c0 .92.747 1.667 1.667 1.667h7.083c.92 0 1.667-.747 1.667-1.667v-.417c0-.92-.746-1.666-1.667-1.666ZM12.516 11.458H8.125c-.92 0-1.667.746-1.667 1.667v.417c0 .92.747 1.666 1.667 1.666h4.391c.92 0 1.667-.746 1.667-1.666v-.417c0-.92-.746-1.667-1.667-1.667Z"})]}),g("defs",{children:g("clipPath",{id:"a",children:g("path",{fill:"#fff",d:"M0 0h20v20H0z"})})})]}),he),Au=P(F(Oe,{children:[F("g",{clipPath:"url(#a)",stroke:"currentColor",strokeWidth:"1.25",children:[g("path",{d:"M16.667 3.333v13.334",strokeLinecap:"round",strokeLinejoin:"round"}),g("path",{d:"M11.875 4.792H4.792c-.92 0-1.667.746-1.667 1.666v.417c0 .92.746 1.667 1.667 1.667h7.083c.92 0 1.667-.747 1.667-1.667v-.417c0-.92-.746-1.666-1.667-1.666ZM11.683 11.458H7.292c-.92 0-1.667.746-1.667 1.667v.417c0 .92.746 1.666 1.667 1.666h4.39c.921 0 1.667-.746 1.667-1.666v-.417c0-.92-.746-1.667-1.666-1.667Z"})]}),g("defs",{children:g("clipPath",{id:"a",children:g("path",{fill:"#fff",d:"M0 0h20v20H0z"})})})]}),he),bb=P(F(Oe,{children:[F("g",{clipPath:"url(#a)",stroke:"currentColor",strokeWidth:"1.25",children:[g("path",{d:"M16.667 3.333v13.334M3.333 3.333v13.334",strokeLinecap:"round",strokeLinejoin:"round"}),g("path",{d:"M14.375 10.208v-.416c0-.92-.746-1.667-1.667-1.667H7.292c-.92 0-1.667.746-1.667 1.667v.416c0 .92.746 1.667 1.667 1.667h5.416c.92 0 1.667-.746 1.667-1.667Z"})]}),g("defs",{children:g("clipPath",{id:"a",children:g("path",{fill:"#fff",d:"M0 0h20v20H0z"})})})]}),he),Eb=P(F(Oe,{children:[F("g",{clipPath:"url(#a)",stroke:"currentColor",strokeWidth:"1.25",children:[g("path",{d:"M3.333 3.333h13.334M3.333 16.667h13.334",strokeLinecap:"round",strokeLinejoin:"round"}),g("path",{d:"M10.208 5.625h-.416c-.92 0-1.667.746-1.667 1.667v5.416c0 .92.746 1.667 1.667 1.667h.416c.92 0 1.667-.746 1.667-1.667V7.292c0-.92-.746-1.667-1.667-1.667Z"})]}),g("defs",{children:g("clipPath",{id:"a",children:g("path",{fill:"#fff",d:"M0 0h20v20H0z"})})})]}),he),ku=P(F("g",{stroke:"currentColor",strokeWidth:"1.25",children:[g("path",{d:"M1.667 10h2.916",strokeLinecap:"round",strokeLinejoin:"round"}),g("path",{d:"M8.333 10h3.334",strokeLinejoin:"round"}),g("path",{d:"M15.417 10h2.916",strokeLinecap:"round",strokeLinejoin:"round"}),g("path",{d:"M6.875 4.792h-.417c-.92 0-1.666.746-1.666 1.666v7.084c0 .92.746 1.666 1.666 1.666h.417c.92 0 1.667-.746 1.667-1.666V6.458c0-.92-.747-1.666-1.667-1.666ZM13.542 6.458h-.417c-.92 0-1.667.747-1.667 1.667v3.75c0 .92.746 1.667 1.667 1.667h.417c.92 0 1.666-.746 1.666-1.667v-3.75c0-.92-.746-1.667-1.666-1.667Z"})]}),he),Mu=P(F("g",{stroke:"currentColor",strokeWidth:"1.25",children:[g("path",{d:"M10 18.333v-2.916",strokeLinecap:"round",strokeLinejoin:"round"}),g("path",{d:"M10 11.667V8.333",strokeLinejoin:"round"}),g("path",{d:"M10 4.583V1.667",strokeLinecap:"round",strokeLinejoin:"round"}),g("path",{d:"M4.792 13.125v.417c0 .92.746 1.666 1.666 1.666h7.084c.92 0 1.666-.746 1.666-1.666v-.417c0-.92-.746-1.667-1.666-1.667H6.458c-.92 0-1.666.746-1.666 1.667ZM6.458 6.458v.417c0 .92.747 1.667 1.667 1.667h3.75c.92 0 1.667-.747 1.667-1.667v-.417c0-.92-.746-1.666-1.667-1.666h-3.75c-.92 0-1.667.746-1.667 1.666Z"})]}),he),ad=P(F("g",{strokeWidth:"1.5",children:[g("path",{stroke:"none",d:"M0 0h24v24H0z",fill:"none"}),g("circle",{cx:"9",cy:"7",r:"4"}),g("path",{d:"M3 21v-2a4 4 0 0 1 4 -4h4a4 4 0 0 1 4 4v2"}),g("path",{d:"M16 3.13a4 4 0 0 1 0 7.75"}),g("path",{d:"M21 21v-2a4 4 0 0 0 -3 -3.85"})]}),Q),_P=P("M256 8C119 8 8 119 8 256s111 248 248 248 248-111 248-248S393 8 256 8zm115.7 272l-176 101c-15.8 8.8-35.7-2.5-35.7-21V152c0-18.4 19.8-29.8 35.7-21l176 107c16.4 9.2 16.4 32.9 0 42z"),RP=P("M256 8C119 8 8 119 8 256s111 248 248 248 248-111 248-248S393 8 256 8zm96 328c0 8.8-7.2 16-16 16H176c-8.8 0-16-7.2-16-16V176c0-8.8 7.2-16 16-16h160c8.8 0 16 7.2 16 16v160z"),to=P(F(Oe,{children:[g("g",{clipPath:"url(#a)",stroke:"currentColor",strokeWidth:"1.25",strokeLinecap:"round",strokeLinejoin:"round",children:g("path",{d:"M15 5 5 15M5 5l10 10"})}),g("defs",{children:g("clipPath",{id:"a",children:g("path",{fill:"#fff",d:"M0 0h20v20H0z"})})})]}),he),NP=P("M464 0c26.51 0 48 21.49 48 48v288c0 26.51-21.49 48-48 48H176c-26.51 0-48-21.49-48-48V48c0-26.51 21.49-48 48-48h288M176 416c-44.112 0-80-35.888-80-80V128H48c-26.51 0-48 21.49-48 48v288c0 26.51 21.49 48 48 48h288c26.51 0 48-21.49 48-48v-48H176z",{mirror:!0}),OP=P("M11.553 22.894a.998.998 0 00.894 0s3.037-1.516 5.465-4.097C19.616 16.987 21 14.663 21 12V5a1 1 0 00-.649-.936l-8-3a.998.998 0 00-.702 0l-8 3A1 1 0 003 5v7c0 2.663 1.384 4.987 3.088 6.797 2.428 2.581 5.465 4.097 5.465 4.097zm-1.303-8.481l6.644-6.644a.856.856 0 111.212 1.212l-7.25 7.25a.856.856 0 01-1.212 0l-3.75-3.75a.856.856 0 111.212-1.212l3.144 3.144z",{width:24}),BP=P("M369.9 97.9L286 14C277 5 264.8-.1 252.1-.1H48C21.5 0 0 21.5 0 48v416c0 26.5 21.5 48 48 48h288c26.5 0 48-21.5 48-48V131.9c0-12.7-5.1-25-14.1-34zM332.1 128H256V51.9l76.1 76.1zM48 464V48h160v104c0 13.3 10.7 24 24 24h104v288H48zm32-48h224V288l-23.5-23.5c-4.7-4.7-12.3-4.7-17 0L176 352l-39.5-39.5c-4.7-4.7-12.3-4.7-17 0L80 352v64zm48-240c-26.5 0-48 21.5-48 48s21.5 48 48 48 48-21.5 48-48-21.5-48-48-48z",{width:384,height:512}),Lu=Rr.memo(({theme:e})=>P(F(Oe,{children:[g("path",{d:"M25 26H111V111H25",fill:vo(e)}),g("path",{d:"M25 111C25 80.2068 25 49.4135 25 26M25 26C48.6174 26 72.2348 26 111 26H25ZM25 26C53.3671 26 81.7343 26 111 26H25ZM111 26C111 52.303 111 78.606 111 111V26ZM111 26C111 51.2947 111 76.5893 111 111V26ZM111 111C87.0792 111 63.1585 111 25 111H111ZM111 111C87.4646 111 63.9293 111 25 111H111ZM25 111C25 81.1514 25 51.3028 25 26V111Z",stroke:vo(e),strokeWidth:"2"}),g("path",{d:"M100 100H160V160H100",fill:vo(e)}),g("path",{d:"M100 160C100 144.106 100 128.211 100 100M100 100C117.706 100 135.412 100 160 100H100ZM100 100C114.214 100 128.428 100 160 100H100ZM160 100C160 120.184 160 140.369 160 160V100ZM160 100C160 113.219 160 126.437 160 160V100ZM160 160C145.534 160 131.068 160 100 160H160ZM160 160C143.467 160 126.934 160 100 160H160ZM100 160C100 143.661 100 127.321 100 100V160Z",stroke:vo(e),strokeWidth:"2"}),F("g",{fill:PT(e),stroke:vo(e),strokeWidth:"6",children:[g("rect",{x:"2.5",y:"2.5",width:"30",height:"30"}),g("rect",{x:"2.5",y:"149.5",width:"30",height:"30"}),g("rect",{x:"147.5",y:"149.5",width:"30",height:"30"}),g("rect",{x:"147.5",y:"2.5",width:"30",height:"30"})]})]}),{width:182,height:182,mirror:!0})),Pu=Rr.memo(({theme:e})=>P(F(Oe,{children:[g("path",{d:"M25 26H111V111H25",fill:vo(e)}),g("path",{d:"M25 111C25 80.2068 25 49.4135 25 26M25 26C48.6174 26 72.2348 26 111 26H25ZM25 26C53.3671 26 81.7343 26 111 26H25ZM111 26C111 52.303 111 78.606 111 111V26ZM111 26C111 51.2947 111 76.5893 111 111V26ZM111 111C87.0792 111 63.1585 111 25 111H111ZM111 111C87.4646 111 63.9293 111 25 111H111ZM25 111C25 81.1514 25 51.3028 25 26V111Z",stroke:vo(e),strokeWidth:"2"}),g("path",{d:"M100 100H160V160H100",fill:vo(e)}),g("path",{d:"M100 160C100 144.106 100 128.211 100 100M100 100C117.706 100 135.412 100 160 100H100ZM100 100C114.214 100 128.428 100 160 100H100ZM160 100C160 120.184 160 140.369 160 160V100ZM160 100C160 113.219 160 126.437 160 160V100ZM160 160C145.534 160 131.068 160 100 160H160ZM160 160C143.467 160 126.934 160 100 160H160ZM100 160C100 143.661 100 127.321 100 100V160Z",stroke:vo(e),strokeWidth:"2"}),F("g",{fill:PT(e),stroke:vo(e),strokeWidth:"6",children:[g("rect",{x:"2.5",y:"2.5",width:"30",height:"30"}),g("rect",{x:"78.5",y:"149.5",width:"30",height:"30"}),g("rect",{x:"147.5",y:"149.5",width:"30",height:"30"}),g("rect",{x:"147.5",y:"78.5",width:"30",height:"30"}),g("rect",{x:"105.5",y:"2.5",width:"30",height:"30"}),g("rect",{x:"2.5",y:"102.5",width:"30",height:"30"})]})]}),{width:182,height:182,mirror:!0})),xb=P(g("g",{strokeWidth:1.25,children:g("path",{d:"M5.879 2.625h8.242a3.27 3.27 0 0 1 3.254 3.254v8.242a3.27 3.27 0 0 1-3.254 3.254H5.88a3.27 3.27 0 0 1-3.254-3.254V5.88A3.27 3.27 0 0 1 5.88 2.626l-.001-.001ZM4.518 16.118l7.608-12.83m.198 13.934 5.051-9.897M2.778 9.675l9.348-6.387m-7.608 12.83 12.857-8.793"})}),he),yb=P(F(Oe,{children:[g("path",{d:"M5.879 2.625h8.242a3.254 3.254 0 0 1 3.254 3.254v8.242a3.254 3.254 0 0 1-3.254 3.254H5.88a3.254 3.254 0 0 1-3.254-3.254V5.88a3.254 3.254 0 0 1 3.254-3.254Z",stroke:"currentColor",strokeWidth:"1.25"}),g("mask",{id:"FillHachureIcon",style:{maskType:"alpha"},maskUnits:"userSpaceOnUse",x:2,y:2,width:16,height:16,children:g("path",{d:"M5.879 2.625h8.242a3.254 3.254 0 0 1 3.254 3.254v8.242a3.254 3.254 0 0 1-3.254 3.254H5.88a3.254 3.254 0 0 1-3.254-3.254V5.88a3.254 3.254 0 0 1 3.254-3.254Z",fill:"currentColor",stroke:"currentColor",strokeWidth:"1.25"})}),g("g",{mask:"url(#FillHachureIcon)",children:g("path",{d:"M2.258 15.156 15.156 2.258M7.324 20.222 20.222 7.325m-20.444 5.35L12.675-.222m-8.157 18.34L17.416 5.22",stroke:"currentColor",strokeWidth:"1.25",strokeLinecap:"round",strokeLinejoin:"round"})})]}),he),wb=P(F(Oe,{children:[F("g",{clipPath:"url(#a)",children:[g("path",{d:"M5.879 2.625h8.242a3.254 3.254 0 0 1 3.254 3.254v8.242a3.254 3.254 0 0 1-3.254 3.254H5.88a3.254 3.254 0 0 1-3.254-3.254V5.88a3.254 3.254 0 0 1 3.254-3.254Z",stroke:"currentColor",strokeWidth:"1.25"}),g("mask",{id:"FillCrossHatchIcon",style:{maskType:"alpha"},maskUnits:"userSpaceOnUse",x:-1,y:-1,width:22,height:22,children:g("path",{d:"M2.426 15.044 15.044 2.426M7.383 20 20 7.383M0 12.617 12.617 0m-7.98 17.941L17.256 5.324m-2.211 12.25L2.426 4.956M20 12.617 7.383 0m5.234 20L0 7.383m17.941 7.98L5.324 2.745",stroke:"currentColor",strokeWidth:"1.25",strokeLinecap:"round",strokeLinejoin:"round"})}),g("g",{mask:"url(#FillCrossHatchIcon)",children:g("path",{d:"M14.121 2H5.88A3.879 3.879 0 0 0 2 5.879v8.242A3.879 3.879 0 0 0 5.879 18h8.242A3.879 3.879 0 0 0 18 14.121V5.88A3.879 3.879 0 0 0 14.121 2Z",fill:"currentColor"})})]}),g("defs",{children:g("clipPath",{id:"a",children:g("path",{fill:"#fff",d:"M0 0h20v20H0z"})})})]}),he),vb=P(F(Oe,{children:[g("g",{clipPath:"url(#a)",children:g("path",{d:"M4.91 2.625h10.18a2.284 2.284 0 0 1 2.285 2.284v10.182a2.284 2.284 0 0 1-2.284 2.284H4.909a2.284 2.284 0 0 1-2.284-2.284V4.909a2.284 2.284 0 0 1 2.284-2.284Z",stroke:"currentColor",strokeWidth:"1.25"})}),g("defs",{children:g("clipPath",{id:"a",children:g("path",{fill:"#fff",d:"M0 0h20v20H0z"})})})]}),{...he,fill:"currentColor"}),Du=P(g(Oe,{children:g("path",{d:"M4.167 10h11.666",stroke:"currentColor",strokeWidth:"1.25",strokeLinecap:"round",strokeLinejoin:"round"})}),he),Tb=P(g("path",{d:"M5 10h10",stroke:"currentColor",strokeWidth:"2.5",strokeLinecap:"round",strokeLinejoin:"round"}),he),Sb=P(g("path",{d:"M5 10h10",stroke:"currentColor",strokeWidth:"3.75",strokeLinecap:"round",strokeLinejoin:"round"}),he),FP=Rr.memo(({theme:e})=>P(g("path",{d:"M6 10H34",stroke:vo(e),strokeWidth:2,fill:"none",strokeLinecap:"round"}),{width:40,height:20})),Cb=P(F("g",{strokeWidth:"2",children:[g("path",{stroke:"none",d:"M0 0h24v24H0z",fill:"none"}),g("path",{d:"M5 12h2"}),g("path",{d:"M17 12h2"}),g("path",{d:"M11 12h2"})]}),Q),Ib=P(F("g",{strokeWidth:"2",children:[g("path",{stroke:"none",d:"M0 0h24v24H0z",fill:"none"}),g("path",{d:"M4 12v.01"}),g("path",{d:"M8 12v.01"}),g("path",{d:"M12 12v.01"}),g("path",{d:"M16 12v.01"}),g("path",{d:"M20 12v.01"})]}),Q),Ab=P(g("path",{d:"M2.5 12.038c1.655-.885 5.9-3.292 8.568-4.354 2.668-1.063.101 2.821 1.32 3.104 1.218.283 5.112-1.814 5.112-1.814",strokeWidth:"1.25"}),he),kb=P(g("path",{d:"M2.5 12.563c1.655-.886 5.9-3.293 8.568-4.355 2.668-1.062.101 2.822 1.32 3.105 1.218.283 5.112-1.814 5.112-1.814m-13.469 2.23c2.963-1.586 6.13-5.62 7.468-4.998 1.338.623-1.153 4.11-.132 5.595 1.02 1.487 6.133-1.43 6.133-1.43",strokeWidth:"1.25"}),he),Mb=P(g("path",{d:"M2.5 11.936c1.737-.879 8.627-5.346 10.42-5.268 1.795.078-.418 5.138.345 5.736.763.598 3.53-1.789 4.235-2.147M2.929 9.788c1.164-.519 5.47-3.28 6.987-3.114 1.519.165 1 3.827 2.121 4.109 1.122.281 3.839-2.016 4.606-2.42",strokeWidth:"1.25"}),he),Lb=P(F("svg",{strokeWidth:"1.5",children:[g("path",{d:"M3.33334 9.99998V6.66665C3.33334 6.04326 3.33403 4.9332 3.33539 3.33646C4.95233 3.33436 6.06276 3.33331 6.66668 3.33331H10"}),g("path",{d:"M13.3333 3.33331V3.34331"}),g("path",{d:"M16.6667 3.33331V3.34331"}),g("path",{d:"M16.6667 6.66669V6.67669"}),g("path",{d:"M16.6667 10V10.01"}),g("path",{d:"M3.33334 13.3333V13.3433"}),g("path",{d:"M16.6667 13.3333V13.3433"}),g("path",{d:"M3.33334 16.6667V16.6767"}),g("path",{d:"M6.66666 16.6667V16.6767"}),g("path",{d:"M10 16.6667V16.6767"}),g("path",{d:"M13.3333 16.6667V16.6767"}),g("path",{d:"M16.6667 16.6667V16.6767"})]}),he),Pb=P(F("g",{strokeWidth:"1.5",stroke:"currentColor",strokeLinecap:"round",strokeLinejoin:"round",children:[g("path",{stroke:"none",d:"M0 0h24v24H0z",fill:"none"}),g("path",{d:"M4 12v-4a4 4 0 0 1 4 -4h4"}),g("line",{x1:"16",y1:"4",x2:"16",y2:"4.01"}),g("line",{x1:"20",y1:"4",x2:"20",y2:"4.01"}),g("line",{x1:"20",y1:"8",x2:"20",y2:"8.01"}),g("line",{x1:"20",y1:"12",x2:"20",y2:"12.01"}),g("line",{x1:"4",y1:"16",x2:"4",y2:"16.01"}),g("line",{x1:"20",y1:"16",x2:"20",y2:"16.01"}),g("line",{x1:"4",y1:"20",x2:"4",y2:"20.01"}),g("line",{x1:"8",y1:"20",x2:"8",y2:"20.01"}),g("line",{x1:"12",y1:"20",x2:"12",y2:"20.01"}),g("line",{x1:"16",y1:"20",x2:"16",y2:"20.01"}),g("line",{x1:"20",y1:"20",x2:"20",y2:"20.01"})]}),Q),Db=P(g("path",{d:"M6 10H34",stroke:"currentColor",strokeWidth:2,fill:"none"}),{width:40,height:20}),_b=Rr.memo(({flip:e=!1})=>P(F("g",{transform:e?"translate(40, 0) scale(-1, 1)":"",stroke:"currentColor",strokeWidth:2,fill:"none",children:[g("path",{d:"M34 10H6M34 10L27 5M34 10L27 15"}),g("path",{d:"M27.5 5L34.5 10L27.5 15"})]}),{width:40,height:20})),_u=Rr.memo(({flip:e=!1})=>P(F("g",{stroke:"currentColor",fill:"currentColor",transform:e?"translate(40, 0) scale(-1, 1)":"",children:[g("path",{d:"M32 10L6 10",strokeWidth:2}),g("circle",{r:"4",transform:"matrix(-1 0 0 1 30 10)"})]}),{width:40,height:20})),Rb=Rr.memo(({flip:e=!1})=>P(F("g",{stroke:"currentColor",fill:"none",transform:e?"translate(40, 0) scale(-1, 1)":"",strokeWidth:2,children:[g("path",{d:"M26 10L6 10"}),g("circle",{r:"4",transform:"matrix(-1 0 0 1 30 10)"})]}),{width:40,height:20})),Nb=Rr.memo(({flip:e=!1})=>P(g("g",{transform:e?"translate(40, 0) scale(-1, 1)":"",children:g("path",{d:"M34 10H5.99996M34 10L34 5M34 10L34 15",stroke:"currentColor",strokeWidth:2,fill:"none"})}),{width:40,height:20})),Ob=Rr.memo(({flip:e=!1})=>P(F("g",{stroke:"currentColor",fill:"currentColor",transform:e?"translate(40, 0) scale(-1, 1)":"",children:[g("path",{d:"M32 10L6 10",strokeWidth:2}),g("path",{d:"M27.5 5.5L34.5 10L27.5 14.5L27.5 5.5"})]}),{width:40,height:20})),Bb=Rr.memo(({flip:e=!1})=>P(F("g",{stroke:"currentColor",fill:"none",transform:e?"translate(40, 0) scale(-1, 1)":"",strokeWidth:2,strokeLinejoin:"round",children:[g("path",{d:"M6,9.5H27"}),g("path",{d:"M27,5L34,10L27,14Z",fill:"none"})]}),{width:40,height:20})),Fb=Rr.memo(({flip:e=!1})=>P(F("g",{stroke:"currentColor",fill:"currentColor",transform:e?"translate(40, 0) scale(-1, 1)":"",strokeLinejoin:"round",strokeWidth:2,children:[g("path",{d:"M6,9.5H20"}),g("path",{d:"M27,5L34,10L27,14L20,9.5Z"})]}),{width:40,height:20})),zb=Rr.memo(({flip:e=!1})=>P(F("g",{stroke:"currentColor",fill:"none",transform:e?"translate(40, 0) scale(-1, 1)":"",strokeLinejoin:"round",strokeWidth:2,children:[g("path",{d:"M6,9.5H20"}),g("path",{d:"M27,5L34,10L27,14L20,9.5Z"})]}),{width:40,height:20})),Hb=P(F(Oe,{children:[g("g",{clipPath:"url(#a)",children:g("path",{d:"M14.167 6.667a3.333 3.333 0 0 0-3.334-3.334H9.167a3.333 3.333 0 0 0 0 6.667h1.666a3.333 3.333 0 0 1 0 6.667H9.167a3.333 3.333 0 0 1-3.334-3.334",stroke:"currentColor",strokeWidth:"1.25",strokeLinecap:"round",strokeLinejoin:"round"})}),g("defs",{children:g("clipPath",{id:"a",children:g("path",{fill:"#fff",d:"M0 0h20v20H0z"})})})]}),he),Ub=P(F(Oe,{children:[g("g",{clipPath:"url(#a)",children:g("path",{d:"M5 16.667V3.333L10 15l5-11.667v13.334",stroke:"currentColor",strokeWidth:"1.25",strokeLinecap:"round",strokeLinejoin:"round"})}),g("defs",{children:g("clipPath",{id:"a",children:g("path",{fill:"#fff",d:"M0 0h20v20H0z"})})})]}),he),Gb=P(F(Oe,{children:[g("g",{clipPath:"url(#a)",children:g("path",{d:"M5.833 3.333v13.334h8.334",stroke:"currentColor",strokeWidth:"1.25",strokeLinecap:"round",strokeLinejoin:"round"})}),g("defs",{children:g("clipPath",{id:"a",children:g("path",{fill:"#fff",d:"M0 0h20v20H0z"})})})]}),he),Vb=P(g(Oe,{children:g("path",{d:"m1.667 3.333 6.666 13.334M8.333 3.333 1.667 16.667M11.667 3.333v13.334h6.666",stroke:"currentColor",strokeWidth:"1.25",strokeLinecap:"round",strokeLinejoin:"round"})}),he),Ru=P(F("g",{strokeWidth:1.25,children:[g("path",{stroke:"none",d:"M0 0h24v24H0z",fill:"none"}),g("path",{d:"M3 7v-2h13v2"}),g("path",{d:"M10 5v14"}),g("path",{d:"M12 19h-4"}),g("path",{d:"M15 13v-1h6v1"}),g("path",{d:"M18 12v7"}),g("path",{d:"M17 19h2"})]}),Q),Wb=P(g(Oe,{children:g("g",{stroke:"currentColor",strokeWidth:"1.25",strokeLinecap:"round",strokeLinejoin:"round",children:g("path",{d:"M5.833 16.667v-10a3.333 3.333 0 0 1 3.334-3.334h1.666a3.333 3.333 0 0 1 3.334 3.334v10M5.833 10.833h8.334"})})}),he),Yb=P(F(Oe,{children:[g("g",{clipPath:"url(#a)",stroke:"currentColor",strokeWidth:"1.25",strokeLinecap:"round",strokeLinejoin:"round",children:g("path",{d:"M5.833 6.667 2.5 10l3.333 3.333M14.167 6.667 17.5 10l-3.333 3.333M11.667 3.333 8.333 16.667"})}),g("defs",{children:g("clipPath",{id:"a",children:g("path",{fill:"#fff",d:"M0 0h20v20H0z"})})})]}),he),Kb=P(F("g",{stroke:"currentColor",fill:"none",strokeLinecap:"round",strokeLinejoin:"round",strokeWidth:2,children:[g("path",{stroke:"none",d:"M0 0h24v24H0z",fill:"none"}),g("line",{x1:"4",y1:"8",x2:"20",y2:"8"}),g("line",{x1:"4",y1:"12",x2:"12",y2:"12"}),g("line",{x1:"4",y1:"16",x2:"16",y2:"16"})]}),Q),$b=P(F("g",{stroke:"currentColor",fill:"none",strokeLinecap:"round",strokeLinejoin:"round",children:[g("path",{stroke:"none",d:"M0 0h24v24H0z",fill:"none"}),g("line",{x1:"4",y1:"8",x2:"20",y2:"8"}),g("line",{x1:"8",y1:"12",x2:"16",y2:"12"}),g("line",{x1:"6",y1:"16",x2:"18",y2:"16"})]}),Q),Xb=P(F("g",{stroke:"currentColor",fill:"none",strokeLinecap:"round",strokeLinejoin:"round",children:[g("path",{stroke:"none",d:"M0 0h24v24H0z",fill:"none"}),g("line",{x1:"4",y1:"8",x2:"20",y2:"8"}),g("line",{x1:"10",y1:"12",x2:"20",y2:"12"}),g("line",{x1:"8",y1:"16",x2:"20",y2:"16"})]}),Q),Zb=Rr.memo(({theme:e})=>P(F("g",{strokeWidth:"1.5",stroke:"currentColor",fill:"none",strokeLinecap:"round",strokeLinejoin:"round",children:[g("path",{stroke:"none",d:"M0 0h24v24H0z",fill:"none"}),g("line",{x1:"4",y1:"4",x2:"20",y2:"4"}),g("rect",{x:"9",y:"8",width:"6",height:"12",rx:"2"})]}),Q)),jb=Rr.memo(({theme:e})=>P(F("g",{strokeWidth:"2",stroke:"currentColor",fill:"none",strokeLinecap:"round",strokeLinejoin:"round",children:[g("path",{stroke:"none",d:"M0 0h24v24H0z",fill:"none"}),g("line",{x1:"4",y1:"20",x2:"20",y2:"20"}),g("rect",{x:"9",y:"4",width:"6",height:"12",rx:"2"})]}),Q)),qb=Rr.memo(({theme:e})=>P(F("g",{strokeWidth:"1.5",stroke:"currentColor",fill:"none",strokeLinecap:"round",strokeLinejoin:"round",children:[g("path",{stroke:"none",d:"M0 0h24v24H0z",fill:"none"}),g("line",{x1:"4",y1:"12",x2:"9",y2:"12"}),g("line",{x1:"15",y1:"12",x2:"20",y2:"12"}),g("rect",{x:"9",y:"6",width:"6",height:"12",rx:"2"})]}),Q)),Jb=P(g("path",{d:"M537.6 226.6c4.1-10.7 6.4-22.4 6.4-34.6 0-53-43-96-96-96-19.7 0-38.1 6-53.3 16.2C367 64.2 315.3 32 256 32c-88.4 0-160 71.6-160 160 0 2.7.1 5.4.2 8.1C40.2 219.8 0 273.2 0 336c0 79.5 64.5 144 144 144h368c70.7 0 128-57.3 128-128 0-61.9-44-113.6-102.4-125.4zM393.4 288H328v112c0 8.8-7.2 16-16 16h-48c-8.8 0-16-7.2-16-16V288h-65.4c-14.3 0-21.4-17.2-11.3-27.3l105.4-105.4c6.2-6.2 16.4-6.2 22.6 0l105.4 105.4c10.1 10.1 2.9 27.3-11.3 27.3z",fill:"currentColor"}),{width:640,height:512}),zP=P(g("path",{d:"M480 416C497.7 416 512 430.3 512 448C512 465.7 497.7 480 480 480H150.6C133.7 480 117.4 473.3 105.4 461.3L25.37 381.3C.3786 356.3 .3786 315.7 25.37 290.7L258.7 57.37C283.7 32.38 324.3 32.38 349.3 57.37L486.6 194.7C511.6 219.7 511.6 260.3 486.6 285.3L355.9 416H480zM265.4 416L332.7 348.7L195.3 211.3L70.63 336L150.6 416L265.4 416z"})),ld=P(F("g",{strokeWidth:1.25,children:[g("path",{stroke:"none",d:"M0 0h24v24H0z",fill:"none"}),g("path",{d:"M8 13v-7.5a1.5 1.5 0 0 1 3 0v6.5"}),g("path",{d:"M11 5.5v-2a1.5 1.5 0 1 1 3 0v8.5"}),g("path",{d:"M14 5.5a1.5 1.5 0 0 1 3 0v6.5"}),g("path",{d:"M17 7.5a1.5 1.5 0 0 1 3 0v8.5a6 6 0 0 1 -6 6h-2h.208a6 6 0 0 1 -5.012 -2.7a69.74 69.74 0 0 1 -.196 -.3c-.312 -.479 -1.407 -2.388 -3.286 -5.728a1.5 1.5 0 0 1 .536 -2.022a1.867 1.867 0 0 1 2.28 .28l1.47 1.47"})]}),Q),Nu=P(F(Oe,{children:[g("path",{stroke:"none",d:"M0 0h24v24H0z",fill:"none"}),g("path",{d:"M4 17v2a2 2 0 0 0 2 2h12a2 2 0 0 0 2 -2v-2"}),g("path",{d:"M7 11l5 5l5 -5"}),g("path",{d:"M12 4l0 12"})]}),Q),sd=P(F(Oe,{children:[g("path",{stroke:"none",d:"M0 0h24v24H0z",fill:"none"}),g("path",{d:"M8 8m0 2a2 2 0 0 1 2 -2h8a2 2 0 0 1 2 2v8a2 2 0 0 1 -2 2h-8a2 2 0 0 1 -2 -2z"}),g("path",{d:"M16 8v-2a2 2 0 0 0 -2 -2h-8a2 2 0 0 0 -2 2v8a2 2 0 0 0 2 2h2"})]}),Q),Qb=P(F("g",{strokeWidth:1.25,children:[g("path",{stroke:"none",d:"M0 0h24v24H0z",fill:"none"}),g("path",{d:"M7 17m-3 0a3 3 0 1 0 6 0a3 3 0 1 0 -6 0"}),g("path",{d:"M17 17m-3 0a3 3 0 1 0 6 0a3 3 0 1 0 -6 0"}),g("path",{d:"M9.15 14.85l8.85 -10.85"}),g("path",{d:"M6 4l8.85 10.85"})]}),Q),eE=P(F(Oe,{children:[g("path",{stroke:"none",d:"M0 0h24v24H0z",fill:"none"}),g("path",{d:"M12 12m-9 0a9 9 0 1 0 18 0a9 9 0 1 0 -18 0"}),g("path",{d:"M12 17l0 .01"}),g("path",{d:"M12 13.5a1.5 1.5 0 0 1 1 -1.5a2.6 2.6 0 1 0 -3 -4"})]}),Q),HP=P(F(Oe,{children:[g("path",{stroke:"none",d:"M0 0h24v24H0z",fill:"none"}),g("path",{d:"M7 4v16l13 -8z"})]}),Q),UP=P(F(Oe,{children:[g("path",{stroke:"none",d:"M0 0h24v24H0z",fill:"none"}),g("path",{d:"M17 4h-10a3 3 0 0 0 -3 3v10a3 3 0 0 0 3 3h10a3 3 0 0 0 3 -3v-10a3 3 0 0 0 -3 -3z",strokeWidth:"0",fill:"currentColor"})]}),Q),GP=P(F(Oe,{children:[g("path",{stroke:"none",d:"M0 0h24v24H0z",fill:"none"}),g("path",{d:"M5 12l5 5l10 -10"})]}),Q),tE=P(F(Oe,{children:[g("path",{stroke:"none",d:"M0 0h24v24H0z",fill:"none"}),g("path",{d:"M10.24 3.957l-8.422 14.06a1.989 1.989 0 0 0 1.7 2.983h16.845a1.989 1.989 0 0 0 1.7 -2.983l-8.423 -14.06a1.989 1.989 0 0 0 -3.4 0z"}),g("path",{d:"M12 9v4"}),g("path",{d:"M12 17h.01"})]}),Q),rE=P(F("g",{strokeWidth:1.25,children:[g("path",{stroke:"none",d:"M0 0h24v24H0z",fill:"none"}),g("path",{d:"M11 7l6 6"}),g("path",{d:"M4 16l11.7 -11.7a1 1 0 0 1 1.4 0l2.6 2.6a1 1 0 0 1 0 1.4l-11.7 11.7h-4v-4z"})]}),Q),oE=P(F("g",{strokeWidth:1.5,children:[g("path",{stroke:"none",d:"M0 0h24v24H0z",fill:"none"}),g("path",{d:"M12 3l-4 7h8z"}),g("path",{d:"M17 17m-3 0a3 3 0 1 0 6 0a3 3 0 1 0 -6 0"}),g("path",{d:"M4 14m0 1a1 1 0 0 1 1 -1h4a1 1 0 0 1 1 1v4a1 1 0 0 1 -1 1h-4a1 1 0 0 1 -1 -1z"})]}),Q),cd=P(F("g",{strokeWidth:1.5,children:[g("path",{stroke:"none",d:"M0 0h24v24H0z",fill:"none"}),g("path",{d:"M4 7l16 0"}),g("path",{d:"M4 17l16 0"}),g("path",{d:"M7 4l0 16"}),g("path",{d:"M17 4l0 16"})]}),Q),dd=P(g("path",{fill:"currentColor",d:"M407.48,111.18C335.587,108.103 269.573,152.338 245.08,220C220.587,152.338 154.573,108.103 82.68,111.18C80.285,168.229 107.577,222.632 154.74,254.82C178.908,271.419 193.35,298.951 193.27,328.27L193.27,379.13L296.9,379.13L296.9,328.27C296.816,298.953 311.255,271.42 335.42,254.82C382.596,222.644 409.892,168.233 407.48,111.18Z"})),el=P(F("g",{strokeWidth:"1.25",children:[g("path",{d:"M4.16602 10H15.8327"}),g("path",{d:"M12.5 13.3333L15.8333 10"}),g("path",{d:"M12.5 6.66666L15.8333 9.99999"})]}),he),md=P(F("g",{fill:"none",stroke:"currentColor",strokeWidth:"1.25",strokeLinecap:"round",strokeLinejoin:"round",transform:"rotate(90 10 10)",children:[g("path",{clipRule:"evenodd",d:"m9.644 13.69 7.774-7.773a2.357 2.357 0 0 0-3.334-3.334l-7.773 7.774L8 12l1.643 1.69Z"}),g("path",{d:"m13.25 3.417 3.333 3.333M10 10l2-2M5 15l3-3M2.156 17.894l1-1M5.453 19.029l-.144-1.407M2.377 11.887l.866 1.118M8.354 17.273l-1.194-.758M.953 14.652l1.408.13"})]}),20),tl=P(F("g",{stroke:"currentColor",fill:"none",children:[g("path",{stroke:"none",d:"M0 0h24v24H0z"}),g("path",{d:"M6 21l15 -15l-3 -3l-15 15l3 3"}),g("path",{d:"M15 6l3 3"}),g("path",{d:"M9 3a2 2 0 0 0 2 2a2 2 0 0 0 -2 2a2 2 0 0 0 -2 -2a2 2 0 0 0 2 -2"}),g("path",{d:"M19 13a2 2 0 0 0 2 2a2 2 0 0 0 -2 2a2 2 0 0 0 -2 -2a2 2 0 0 0 2 -2"})]}),Q),VP=P(F("g",{strokeWidth:1.25,children:[g("path",{stroke:"none",d:"M0 0h24v24H0z"}),g("path",{d:"M6 21l15 -15l-3 -3l-15 15l3 3"}),g("path",{d:"M15 6l3 3"}),g("path",{d:"M9 3a2 2 0 0 0 2 2a2 2 0 0 0 -2 2a2 2 0 0 0 -2 -2a2 2 0 0 0 2 -2"}),g("path",{d:"M19 13a2 2 0 0 0 2 2a2 2 0 0 0 -2 2a2 2 0 0 0 -2 -2a2 2 0 0 0 2 -2"})]}),Q),fs=P(F("g",{stroke:"currentColor",fill:"none",children:[g("path",{stroke:"none",d:"M0 0h24v24H0z",fill:"none"}),g("path",{d:"M11.217 19.384a3.501 3.501 0 0 0 6.783 -1.217v-5.167l-6 -3.35"}),g("path",{d:"M5.214 15.014a3.501 3.501 0 0 0 4.446 5.266l4.34 -2.534v-6.946"}),g("path",{d:"M6 7.63c-1.391 -.236 -2.787 .395 -3.534 1.689a3.474 3.474 0 0 0 1.271 4.745l4.263 2.514l6 -3.348"}),g("path",{d:"M12.783 4.616a3.501 3.501 0 0 0 -6.783 1.217v5.067l6 3.45"}),g("path",{d:"M18.786 8.986a3.501 3.501 0 0 0 -4.446 -5.266l-4.34 2.534v6.946"}),g("path",{d:"M18 16.302c1.391 .236 2.787 -.395 3.534 -1.689a3.474 3.474 0 0 0 -1.271 -4.745l-4.308 -2.514l-5.955 3.42"})]}),Q),nE=P(F("g",{stroke:"currentColor",fill:"none",children:[g("path",{stroke:"none",d:"M0 0h24v24H0z",fill:"none"}),g("path",{d:"M4 8v-2a2 2 0 0 1 2 -2h2"}),g("path",{d:"M4 16v2a2 2 0 0 0 2 2h2"}),g("path",{d:"M16 4h2a2 2 0 0 1 2 2v2"}),g("path",{d:"M16 20h2a2 2 0 0 0 2 -2v-2"})]}),Q),rl=P(F("g",{stroke:"currentColor",fill:"none",strokeWidth:1.5,children:[g("path",{stroke:"none",d:"M0 0h24v24H0z",fill:"none"}),g("path",{d:"M10 12a2 2 0 1 0 4 0a2 2 0 0 0 -4 0"}),g("path",{d:"M21 12c-2.4 4 -5.4 6 -9 6c-3.6 0 -6.6 -2 -9 -6c2.4 -4 5.4 -6 9 -6c3.6 0 6.6 2 9 6"})]}),Q),iE=P(F("g",{stroke:"currentColor",fill:"none",children:[g("path",{stroke:"none",d:"M0 0h24v24H0z",fill:"none"}),g("path",{d:"M10.585 10.587a2 2 0 0 0 2.829 2.828"}),g("path",{d:"M16.681 16.673a8.717 8.717 0 0 1 -4.681 1.327c-3.6 0 -6.6 -2 -9 -6c1.272 -2.12 2.712 -3.678 4.32 -4.674m2.86 -1.146a9.055 9.055 0 0 1 1.82 -.18c3.6 0 6.6 2 9 6c-.666 1.11 -1.379 2.067 -2.138 2.87"}),g("path",{d:"M3 3l18 18"})]}),Q),aE=P(F("g",{stroke:"currentColor",fill:"none",children:[g("path",{stroke:"none",d:"M0 0h24v24H0z",fill:"none"}),g("path",{d:"M15.5 13a3.5 3.5 0 0 0 -3.5 3.5v1a3.5 3.5 0 0 0 7 0v-1.8"}),g("path",{d:"M8.5 13a3.5 3.5 0 0 1 3.5 3.5v1a3.5 3.5 0 0 1 -7 0v-1.8"}),g("path",{d:"M17.5 16a3.5 3.5 0 0 0 0 -7h-.5"}),g("path",{d:"M19 9.3v-2.8a3.5 3.5 0 0 0 -7 0"}),g("path",{d:"M6.5 16a3.5 3.5 0 0 1 0 -7h.5"}),g("path",{d:"M5 9.3v-2.8a3.5 3.5 0 0 1 7 0v10"})]}),Q),lE=P(F("g",{strokeWidth:1.25,children:[g("path",{stroke:"none",d:"M0 0h24v24H0z",fill:"none"}),g("path",{d:"M15.5 13a3.5 3.5 0 0 0 -3.5 3.5v1a3.5 3.5 0 0 0 7 0v-1.8"}),g("path",{d:"M8.5 13a3.5 3.5 0 0 1 3.5 3.5v1a3.5 3.5 0 0 1 -7 0v-1.8"}),g("path",{d:"M17.5 16a3.5 3.5 0 0 0 0 -7h-.5"}),g("path",{d:"M19 9.3v-2.8a3.5 3.5 0 0 0 -7 0"}),g("path",{d:"M6.5 16a3.5 3.5 0 0 1 0 -7h.5"}),g("path",{d:"M5 9.3v-2.8a3.5 3.5 0 0 1 7 0v10"})]}),Q),pd=P(F("g",{strokeWidth:1.5,children:[g("path",{stroke:"none",d:"M0 0h24v24H0z",fill:"none"}),g("path",{d:"M10 10m-7 0a7 7 0 1 0 14 0a7 7 0 1 0 -14 0"}),g("path",{d:"M21 21l-6 -6"})]}),Q),sE=P(F("g",{strokeWidth:1.5,children:[g("path",{stroke:"none",d:"M0 0h24v24H0z",fill:"none"}),g("path",{d:"M20.984 12.53a9 9 0 1 0 -7.552 8.355"}),g("path",{d:"M12 7v5l3 3"}),g("path",{d:"M19 16l-2 3h4l-2 3"})]}),Q),cE=P(F("g",{strokeWidth:1.5,children:[g("path",{stroke:"none",d:"M0 0h24v24H0z",fill:"none"}),g("path",{d:"M9 2m0 3a3 3 0 0 1 3 -3h0a3 3 0 0 1 3 3v5a3 3 0 0 1 -3 3h0a3 3 0 0 1 -3 -3z"}),g("path",{d:"M5 10a7 7 0 0 0 14 0"}),g("path",{d:"M8 21l8 0"}),g("path",{d:"M12 17l0 4"})]}),Q),dE=P(F("g",{strokeWidth:1.5,children:[g("path",{stroke:"none",d:"M0 0h24v24H0z",fill:"none"}),g("path",{d:"M3 3l18 18"}),g("path",{d:"M9 5a3 3 0 0 1 6 0v5a3 3 0 0 1 -.13 .874m-2 2a3 3 0 0 1 -3.87 -2.872v-1"}),g("path",{d:"M5 10a7 7 0 0 0 10.846 5.85m2 -2a6.967 6.967 0 0 0 1.152 -3.85"}),g("path",{d:"M8 21l8 0"}),g("path",{d:"M12 17l0 4"})]}),Q),ud=P(F("g",{strokeWidth:1.25,children:[g("path",{stroke:"none",d:"M0 0h24v24H0z",fill:"none"}),g("path",{d:"M13 3l0 7l6 0l-8 11l0 -7l-6 0l8 -11"})]}),Q),mE=P(F("g",{children:[g("path",{stroke:"none",d:"M0 0h24v24H0z",fill:"none"}),g("path",{d:"M8 8m0 1a1 1 0 0 1 1 -1h6a1 1 0 0 1 1 1v6a1 1 0 0 1 -1 1h-6a1 1 0 0 1 -1 -1z"}),g("path",{d:"M12 20v.01"}),g("path",{d:"M16 20v.01"}),g("path",{d:"M8 20v.01"}),g("path",{d:"M4 20v.01"}),g("path",{d:"M4 16v.01"}),g("path",{d:"M4 12v.01"}),g("path",{d:"M4 8v.01"}),g("path",{d:"M4 4v.01"}),g("path",{d:"M8 4v.01"}),g("path",{d:"M12 4v.01"}),g("path",{d:"M16 4v.01"}),g("path",{d:"M20 4v.01"}),g("path",{d:"M20 8v.01"}),g("path",{d:"M20 12v.01"}),g("path",{d:"M20 16v.01"}),g("path",{d:"M20 20v.01"})]}),Q),pE=P(F("g",{strokeWidth:1.25,children:[g("path",{stroke:"none",d:"M0 0h24v24H0z",fill:"none"}),g("path",{d:"M5 3v18"}),g("path",{d:"M19 21v-18"}),g("path",{d:"M5 7h14"}),g("path",{d:"M5 15h14"}),g("path",{d:"M8 13v4"}),g("path",{d:"M11 13v4"}),g("path",{d:"M16 13v4"}),g("path",{d:"M14 5v4"}),g("path",{d:"M11 5v4"}),g("path",{d:"M8 5v4"}),g("path",{d:"M3 21h18"})]}),Q),uE=P(F("g",{strokeWidth:1.25,children:[g("path",{stroke:"none",d:"M0 0h24v24H0z",fill:"none"}),g("path",{d:"M3 12l18 0"}),g("path",{d:"M7 16l10 0l-10 5l0 -5"}),g("path",{d:"M7 8l10 0l-10 -5l0 5"})]}),Q),hE=P(F("g",{strokeWidth:1.25,children:[g("path",{stroke:"none",d:"M0 0h24v24H0z",fill:"none"}),g("path",{d:"M12 3l0 18"}),g("path",{d:"M16 7l0 10l5 0l-5 -10"}),g("path",{d:"M8 7l0 10l-5 0l5 -10"})]}),Q),Ou=P(F("g",{strokeWidth:1.25,children:[g("path",{stroke:"none",d:"M0 0h24v24H0z",fill:"none"}),g("path",{d:"M5 3m0 2a2 2 0 0 1 2 -2h10a2 2 0 0 1 2 2v2a2 2 0 0 1 -2 2h-10a2 2 0 0 1 -2 -2z"}),g("path",{d:"M19 6h1a2 2 0 0 1 2 2a5 5 0 0 1 -5 5l-5 0v2"}),g("path",{d:"M10 15m0 1a1 1 0 0 1 1 -1h2a1 1 0 0 1 1 1v4a1 1 0 0 1 -1 1h-2a1 1 0 0 1 -1 -1z"})]}),Q),hd=P(F("g",{strokeWidth:1.25,children:[g("path",{stroke:"none",d:"M0 0h24v24H0z",fill:"none"}),g("path",{d:"M15 15m-5 0a5 5 0 1 0 10 0a5 5 0 1 0 -10 0"}),g("path",{d:"M22 22l-3 -3"}),g("path",{d:"M6 18h-1a2 2 0 0 1 -2 -2v-1"}),g("path",{d:"M3 11v-1"}),g("path",{d:"M3 6v-1a2 2 0 0 1 2 -2h1"}),g("path",{d:"M10 3h1"}),g("path",{d:"M15 3h1a2 2 0 0 1 2 2v1"})]}),Q),gE=P(F("g",{strokeWidth:1.25,children:[g("path",{stroke:"none",d:"M0 0h24v24H0z",fill:"none"}),g("path",{d:"M14 3v4a1 1 0 0 0 1 1h4"}),g("path",{d:"M5 12v-7a2 2 0 0 1 2 -2h7l5 5v4"}),g("path",{d:"M4 20.25c0 .414 .336 .75 .75 .75h1.25a1 1 0 0 0 1 -1v-1a1 1 0 0 0 -1 -1h-1a1 1 0 0 1 -1 -1v-1a1 1 0 0 1 1 -1h1.25a.75 .75 0 0 1 .75 .75"}),g("path",{d:"M10 15l2 6l2 -6"}),g("path",{d:"M20 15h-1a2 2 0 0 0 -2 2v2a2 2 0 0 0 2 2h1v-3"})]}),Q),fE=P(F("g",{strokeWidth:1.25,children:[g("path",{stroke:"none",d:"M0 0h24v24H0z",fill:"none"}),g("path",{d:"M14 3v4a1 1 0 0 0 1 1h4"}),g("path",{d:"M5 12v-7a2 2 0 0 1 2 -2h7l5 5v4"}),g("path",{d:"M20 15h-1a2 2 0 0 0 -2 2v2a2 2 0 0 0 2 2h1v-3"}),g("path",{d:"M5 18h1.5a1.5 1.5 0 0 0 0 -3h-1.5v6"}),g("path",{d:"M11 21v-6l3 6v-6"})]}),Q),bE=P(F("g",{strokeWidth:1.25,children:[g("path",{stroke:"none",d:"M0 0h24v24H0z",fill:"none"}),g("path",{d:"M4 13v-8a2 2 0 0 1 2 -2h1a2 2 0 0 1 2 2v8a2 2 0 0 0 6 0v-8a2 2 0 0 1 2 -2h1a2 2 0 0 1 2 2v8a8 8 0 0 1 -16 0"}),g("path",{d:"M4 8l5 0"}),g("path",{d:"M15 8l4 0"})]}),Q),EE=P(F("g",{strokeWidth:1.25,children:[g("path",{stroke:"none",d:"M0 0h24v24H0z",fill:"none"}),g("path",{d:"M3 14c.83 .642 2.077 1.017 3.5 1c1.423 .017 2.67 -.358 3.5 -1c.83 -.642 2.077 -1.017 3.5 -1c1.423 -.017 2.67 .358 3.5 1"}),g("path",{d:"M8 3a2.4 2.4 0 0 0 -1 2a2.4 2.4 0 0 0 1 2"}),g("path",{d:"M12 3a2.4 2.4 0 0 0 -1 2a2.4 2.4 0 0 0 1 2"}),g("path",{d:"M3 10h14v5a6 6 0 0 1 -6 6h-2a6 6 0 0 1 -6 -6v-5z"}),g("path",{d:"M16.746 16.726a3 3 0 1 0 .252 -5.555"})]}),Q),xE=P(F("g",{stroke:"currentColor",children:[g("path",{stroke:"none",d:"M0 0h24v24H0z",fill:"none"}),g("path",{d:"M3 5a1 1 0 0 1 1-1h16a1 1 0 0 1 1 1v10a1 1 0 0 1-1 1h-16a1 1 0 0 1-1-1v-10zM7 20h10M9 16v4M15 16v4"})]}),{...Q,strokeWidth:1.5}),WP=P(F("g",{children:[g("path",{stroke:"none",d:"M0 0h24v24H0z",fill:"none"}),g("path",{d:"M10 12l10 0"}),g("path",{d:"M10 12l4 4"}),g("path",{d:"M10 12l4 -4"}),g("path",{d:"M4 4l0 16"})]}),Q),yE=P(F("g",{children:[g("path",{stroke:"none",d:"M0 0h24v24H0z",fill:"none"}),g("path",{d:"M2 8a4 4 0 0 1 4 -4h12a4 4 0 0 1 4 4v8a4 4 0 0 1 -4 4h-12a4 4 0 0 1 -4 -4v-8z"}),g("path",{d:"M10 9l5 3l-5 3z"})]}),Q),wE=P(F("g",{strokeWidth:1.5,children:[g("path",{stroke:"none",d:"M0 0h24v24H0z",fill:"none"}),g("path",{d:"M3 6h18"}),g("path",{d:"M3 12h18"}),g("path",{d:"M3 18h18"}),g("path",{d:"M6 3v18"}),g("path",{d:"M12 3v18"}),g("path",{d:"M18 3v18"})]}),Q)});import{jsx as KP}from"react/jsx-runtime";var YP,_T,bs,vE=y(()=>{"use strict";f();qe();be();Dt();q();Je();xe();Ye();xr();or();Eo();me();G();ne();ze();YP=(e,t)=>{let r=new Set(ge(e.filter(o=>re(o)),t).map(o=>o.id));return{elements:e.map(o=>t.selectedElementIds[o.id]?le(o,{isDeleted:!0}):o.frameId&&r.has(o.frameId)?le(o,{isDeleted:!0}):Pe(o)&&t.selectedElementIds[o.containerId]?le(o,{isDeleted:!0}):o),appState:{...t,selectedElementIds:{},selectedGroupIds:{}}}},_T=(e,t)=>{if(e.editingGroupId){let r=it(ye(t),e.editingGroupId);if(r.length)return{...e,selectedElementIds:{[r[0].id]:!0}}}return e},bs=U({name:"deleteSelectedElements",label:"labels.delete",icon:To,trackEvent:{category:"element",action:"delete"},perform:(e,t,r,o)=>{if(t.editingLinearElement){let{elementId:a,selectedPointsIndices:l,startBindingElement:s,endBindingElement:c}=t.editingLinearElement,d=o.scene.getNonDeletedElementsMap(),m=Z.getElement(a,d);if(!m||l==null)return!1;if(m.points.length<2){let u=e.map(E=>E.id===m.id?le(E,{isDeleted:!0}):E),h=_T(t,u);return{elements:u,appState:{...h,editingLinearElement:null},storeAction:_.CAPTURE}}let p={startBindingElement:l?.includes(0)?null:s,endBindingElement:l?.includes(m.points.length-1)?null:c};return Z.deletePoints(m,l),{elements:e,appState:{...t,editingLinearElement:{...t.editingLinearElement,...p,selectedPointsIndices:l?.[0]>0?[l[0]-1]:[0]}},storeAction:_.CAPTURE}}let{elements:n,appState:i}=YP(e,t);return Qm(n,e.filter(({id:a})=>t.selectedElementIds[a])),i=_T(i,n),{elements:n,appState:{...i,activeTool:tt(t,{type:"selection"}),multiElement:null,activeEmbeddable:null},storeAction:Xe(ye(e),t)?_.CAPTURE:_.NONE}},keyTest:(e,t,r)=>(e.key===C.BACKSPACE||e.key===C.DELETE)&&!e[C.CTRL_OR_CMD],PanelComponent:({elements:e,appState:t,updateData:r})=>KP(pe,{type:"button",icon:To,title:b("labels.delete"),"aria-label":b("labels.delete"),onClick:()=>r(null),visible:Xe(ye(e),t)})})});function zT(e,t,r,o){let n=X(ge(e,t,{includeBoundTextElement:!0,includeElementsInFrames:!0})),i={regularElements:[],frameChildren:new Map},a=new Set;for(let c of e)n.has(c.id)&&re(c)&&a.add(c.id);for(let c of e)if(n.has(c.id))if(re(c)||c.frameId&&a.has(c.frameId))i.regularElements.push(c);else if(!c.frameId)i.regularElements.push(c);else{let d=i.frameChildren.get(c.frameId)||[];d.push(c),i.frameChildren.set(c.frameId,d)}let l=e,s=Array.from(i.frameChildren.entries());for(let[c,d]of s)l=o(e,t,r,c,d);return o(l,t,r,null,i.regularElements)}var TE,NT,$P,RT,XP,ZP,OT,BT,FT,HT,UT,GT,VT,WT=y(()=>{"use strict";f();me();bo();xr();qe();vi();G();TE=(e,t)=>e.frameId===t||e.id===t,NT=(e,t,r)=>{let o=[],n=[],i=null,a=-1,l=X(r||ge(e,t,{includeBoundTextElement:!0,includeElementsInFrames:!0}));for(;++a<e.length;){let s=e[a];l.get(s.id)?(n.length&&(o=o.concat(n),n=[]),o.push(a),i=a+1):s.isDeleted&&i===a?(i=a+1,n.push(a)):n=[]}return o},$P=e=>{let t=0;return e.reduce((r,o,n)=>(n>0&&e[n-1]!==o-1&&(t=++t),(r[t]||(r[t]=[])).push(o),r),[])},RT=(e,t,r)=>{if("containerId"in e&&e.containerId)if(r==="left"){let o=Ct.getScene(e).getElement(e.containerId);if(o)return t.indexOf(o)}else return t.indexOf(e);else{let o=e.boundElements?.find(n=>n.type!=="arrow")?.id;if(o){if(r==="left")return t.indexOf(e);let n=Ct.getScene(e).getElement(o);if(n)return t.indexOf(n)}}},XP=(e,t)=>{let r=-1,o=-1;return e.forEach((n,i)=>{TE(n,t)&&(r===-1&&(r=i),o=i)}),r===-1?[]:e.slice(r,o+1)},ZP=(e,t,r,o,n)=>{let i=t[r],a=m=>m.isDeleted?!1:n?m.frameId===n:e.editingGroupId?m.groupIds.includes(e.editingGroupId):!0,l=o==="left"?jg(t,m=>a(m),Math.max(0,r-1)):Zg(t,m=>a(m),r+1),s=t[l];if(!s)return-1;if(e.editingGroupId){if(i?.groupIds.join("")===s?.groupIds.join(""))return RT(s,t,o)??l;if(!s?.groupIds.includes(e.editingGroupId))return-1}if(!n&&(s.frameId||re(s))){let m=XP(t,s.frameId||s.id);return o==="left"?t.indexOf(m[0]):t.indexOf(m[m.length-1])}if(!s.groupIds.length)return RT(s,t,o)??l;let c=e.editingGroupId?s.groupIds[s.groupIds.indexOf(e.editingGroupId)-1]:s.groupIds[s.groupIds.length-1],d=it(t,c);return d.length?o==="left"?t.indexOf(d[0]):t.indexOf(d[d.length-1]):l},OT=(e,t)=>t.reduce((r,o)=>{let n=e[o];return r.set(n.id,n),r},new Map),BT=(e,t,r)=>{let o=NT(e,t),n=OT(e,o),i=$P(o);r==="right"&&(i=i.reverse());let a=new Set(o.filter(l=>re(e[l])).map(l=>e[l].id));return i.forEach((l,s)=>{let c=l[0],d=l[l.length-1],m=r==="left"?c:d,p=l.some(v=>{let w=e[v];return w.frameId&&a.has(w.frameId)})?null:e[m]?.frameId,u=ZP(t,e,m,r,p);if(u===-1||m===u)return;let h=r==="left"?e.slice(0,u):e.slice(0,c),E=e.slice(c,d+1),x=r==="left"?e.slice(u,c):e.slice(d+1,u+1),T=r==="left"?e.slice(d+1):e.slice(u+1);e=r==="left"?[...h,...E,...x,...T]:[...h,...x,...E,...T]}),Yt(e,n),e},FT=(e,t,r,o,n)=>{let i=NT(e,t,n),a=OT(e,i),l=[],s,c;if(r==="left"){if(o)s=Zg(e,h=>TE(h,o));else if(t.editingGroupId){let h=it(e,t.editingGroupId);if(!h.length)return e;s=e.indexOf(h[0])}else s=0;c=i[i.length-1]}else{if(o)c=jg(e,h=>TE(h,o));else if(t.editingGroupId){let h=it(e,t.editingGroupId);if(!h.length)return e;c=e.indexOf(h[h.length-1])}else c=e.length-1;s=i[0]}s===-1&&(s=0);for(let h=s;h<c+1;h++)i.includes(h)||l.push(e[h]);let d=Array.from(a.values()),m=e.slice(0,s),p=e.slice(c+1),u=r==="left"?[...m,...d,...l,...p]:[...m,...l,...d,...p];return Yt(u,a),u};HT=(e,t)=>BT(e,t,"left"),UT=(e,t)=>BT(e,t,"right"),GT=(e,t)=>zT(e,t,"left",FT),VT=(e,t)=>zT(e,t,"right",FT)});import{jsx as Uu}from"react/jsx-runtime";var Bu,Fu,zu,Hu,YT=y(()=>{"use strict";f();WT();be();q();G();Je();ne();W();ze();Bu=U({name:"sendBackward",label:"labels.sendBackward",icon:wu,trackEvent:{category:"element"},perform:(e,t)=>({elements:HT(e,t),appState:t,storeAction:_.CAPTURE}),keyPriority:40,keyTest:e=>e[C.CTRL_OR_CMD]&&!e.shiftKey&&e.code===Ee.BRACKET_LEFT,PanelComponent:({updateData:e,appState:t})=>Uu("button",{type:"button",className:"zIndexButton",onClick:()=>e(null),title:`${b("labels.sendBackward")} \u2014 ${N("CtrlOrCmd+[")}`,children:wu})}),Fu=U({name:"bringForward",label:"labels.bringForward",icon:yu,trackEvent:{category:"element"},perform:(e,t)=>({elements:UT(e,t),appState:t,storeAction:_.CAPTURE}),keyPriority:40,keyTest:e=>e[C.CTRL_OR_CMD]&&!e.shiftKey&&e.code===Ee.BRACKET_RIGHT,PanelComponent:({updateData:e,appState:t})=>Uu("button",{type:"button",className:"zIndexButton",onClick:()=>e(null),title:`${b("labels.bringForward")} \u2014 ${N("CtrlOrCmd+]")}`,children:yu})}),zu=U({name:"sendToBack",label:"labels.sendToBack",icon:Tu,trackEvent:{category:"element"},perform:(e,t)=>({elements:GT(e,t),appState:t,storeAction:_.CAPTURE}),keyTest:e=>ur?e[C.CTRL_OR_CMD]&&e.altKey&&e.code===Ee.BRACKET_LEFT:e[C.CTRL_OR_CMD]&&e.shiftKey&&e.code===Ee.BRACKET_LEFT,PanelComponent:({updateData:e,appState:t})=>Uu("button",{type:"button",className:"zIndexButton",onClick:()=>e(null),title:`${b("labels.sendToBack")} \u2014 ${ur?N("CtrlOrCmd+Alt+["):N("CtrlOrCmd+Shift+[")}`,children:Tu})}),Hu=U({name:"bringToFront",label:"labels.bringToFront",icon:vu,trackEvent:{category:"element"},perform:(e,t)=>({elements:VT(e,t),appState:t,storeAction:_.CAPTURE}),keyTest:e=>ur?e[C.CTRL_OR_CMD]&&e.altKey&&e.code===Ee.BRACKET_RIGHT:e[C.CTRL_OR_CMD]&&e.shiftKey&&e.code===Ee.BRACKET_RIGHT,PanelComponent:({updateData:e,appState:t})=>Uu("button",{type:"button",className:"zIndexButton",onClick:r=>e(null),title:`${b("labels.bringToFront")} \u2014 ${ur?N("CtrlOrCmd+Alt+]"):N("CtrlOrCmd+Shift+]")}`,children:vu})})});var Gu,KT=y(()=>{"use strict";f();be();Je();xr();xe();me();or();Ti();ne();ze();Gu=U({name:"selectAll",label:"labels.selectAll",icon:mE,trackEvent:{category:"canvas"},viewMode:!1,perform:(e,t,r,o)=>{if(t.editingLinearElement)return!1;let n=Xa(e.filter(i=>!i.isDeleted&&!(V(i)&&i.containerId)&&!i.locked)).reduce((i,a)=>(i[a.id]=!0,i),{});return{appState:{...t,...nr({editingGroupId:null,selectedElementIds:n},ye(e),t,o),selectedLinearElement:Object.keys(n).length===1&&ce(e[0])?new Z(e[0]):null},storeAction:_.CAPTURE}},keyTest:e=>e[C.CTRL_OR_CMD]&&e.key===C.A})});var jP,qP,$T,XT=y(()=>{"use strict";f();G();jP=e=>{let t=e.slice(),r=new Set,o=i=>{let a=i[0]?.groupIds?.join(""),l=[i[0]],s=[];for(let c of i.slice(1))c.groupIds?.join("")===a?l.push(c):s.push(c);return s.length?[...l,...o(s)]:l},n=new Map;return t.forEach((i,a)=>{if(!n.has(i.id))if(i.groupIds?.length){let l=i.groupIds[i.groupIds.length-1],s=t.slice(a).filter(c=>{let d=c?.groupIds?.some(m=>m===l);return d&&n.set(c.id,!0),d});for(let c of o(s))r.add(c)}else r.add(i)}),r.size!==e.length?(console.error("normalizeGroupElementOrder: lost some elements... bailing!"),e):[...r]},qP=e=>{let t=iw(e),r=e.slice(),o=new Set;return r.forEach((n,i)=>{n&&(n.boundElements?.length?(o.add(n),r[i]=null,n.boundElements.forEach(a=>{let l=t.get(a.id);l&&a.type==="text"&&(o.add(l[0]),r[l[1]]=null)})):n.type==="text"&&n.containerId&&t.get(n.containerId)?.[0].boundElements?.find(l=>l.id===n.id)||(o.add(n),r[i]=null))}),o.size!==e.length?(console.error("normalizeBoundElementsOrder: lost some elements... bailing!"),e):[...o]},$T=e=>qP(jP(e))});import{jsx as QP}from"react/jsx-runtime";var Vu,JP,ZT=y(()=>{"use strict";f();be();Je();xe();qe();Dt();q();G();or();xr();Eo();W();mt();me();XT();ne();dr();Ti();bo();ze();Vu=U({name:"duplicateSelection",label:"labels.duplicateSelection",icon:ps,trackEvent:{category:"element"},perform:(e,t,r,o)=>{let n=o.scene.getNonDeletedElementsMap();if(t.editingLinearElement){let i=Z.duplicateSelectedPoints(t,n);return i?{elements:e,appState:i.appState,storeAction:_.CAPTURE}:!1}return{...JP(e,t),storeAction:_.CAPTURE}},keyTest:e=>e[C.CTRL_OR_CMD]&&e.key===C.D,PanelComponent:({elements:e,appState:t,updateData:r})=>QP(pe,{type:"button",icon:ps,title:`${b("labels.duplicateSelection")} \u2014 ${N("CtrlOrCmd+D")}`,"aria-label":b("labels.duplicateSelection"),onClick:()=>r(null),visible:Xe(ye(e),t)})}),JP=(e,t)=>{let r=$T(e),o=new Map,n=[],i=[],a=new Map,l=new Map,s=v=>{let w=Yl(t.editingGroupId,o,v,{x:v.x+On/2,y:v.y+On/2});return l.set(w.id,w),a.set(v.id,w.id),i.push(v),n.push(w),w},c=X(ge(r,t,{includeBoundTextElement:!0,includeElementsInFrames:!0})),d=new Map,m=v=>{for(let w of v)d.set(w.id,!0);return v},p=[],u=-1;for(;++u<r.length;){let v=r[u];if(d.get(v.id))continue;let w=ue(v,X(e)),I=re(v);if(c.get(v.id)){if(v.groupIds.length||w||I){let L=Hf(t,v);if(L){let A=it(r,L).flatMap(M=>re(M)?[...eo(e,M.id),M]:[M]);p.push(...m([...A,...A.map(M=>s(M))]));continue}if(w){p.push(...m([v,w,s(v),s(w)]));continue}if(I){let A=eo(r,v.id);p.push(...m([...A,v,...A.map(M=>s(M)),s(v)]));continue}}(!v.frameId||!c.has(v.frameId))&&p.push(...m([v,s(v)]))}else p.push(...m([v]))}let h=[],E=new Map;for(u=p.length;--u>=0;){let v=p[u];E.get(v.id)||(E.set(v.id,!0),h.push(v))}let x=Yt(h.reverse(),X(n));rp(p,i,a),Jm(p,i,a),tu(x,i,a);let T=Xa(n);return{elements:x,appState:{...t,...nr({editingGroupId:t.editingGroupId,selectedElementIds:T.reduce((v,w)=>(Pe(w)||(v[w.id]=!0),v),{})},ye(x),t,null)}}}});var e8,ve,Nr=y(()=>{"use strict";f();e8=["ai","command_palette"],ve=(e,t,r,o)=>{try{if(typeof window>"u"||S.VITE_WORKER_ID||S.PROD||!e8.includes(e))return;S.PROD||console.info("trackEvent",{category:e,action:t,label:r,value:o}),window.sa_event&&window.sa_event(t,{category:e,label:r,value:o})}catch(n){console.error("error during analytics",n)}}});import jT from"clsx";import{jsx as SE,jsxs as t8}from"react/jsx-runtime";var xn,qT=y(()=>{"use strict";f();xn=e=>SE("div",{className:"buttonList buttonListIcon",children:e.options.map(t=>e.type==="button"?SE("button",{onClick:r=>e.onClick(t.value,r),className:jT({active:t.active??e.value===t.value}),"data-testid":t.testId,title:t.text,children:t.icon},t.text):t8("label",{className:jT({active:e.value===t.value}),title:t.text,children:[SE("input",{type:"radio",name:e.group,onChange:()=>e.onChange(t.value),checked:e.value===t.value,"data-testid":t.testId}),t.icon]},t.text))})});import r8 from"clsx";import{jsx as CE}from"react/jsx-runtime";var JT,QT=y(()=>{"use strict";f();Qr();JT=({onChange:e,type:t,activeColor:r,topPicks:o})=>{let n;return t==="elementStroke"&&(n=Wp),t==="elementBackground"&&(n=Yp),t==="canvasBackground"&&(n=Kp),o&&(n=o),n?CE("div",{className:"color-picker__top-picks",children:n.map(i=>CE("button",{className:r8("color-picker__button",{active:i===r,"is-transparent":i==="transparent"||!i}),style:{"--swatch-color":i},type:"button",title:i,onClick:()=>e(i),"data-testid":`color-top-pick-${i}`,children:CE("div",{className:"color-picker__button-outline"})},i))}):(console.error("Invalid type for TopPicks"),null)}});import{atom as o8}from"jotai";var Gi,gd,IE,t3,So,e3,r3,oi=y(()=>{"use strict";f();Qr();Gi=({palette:e,color:t})=>{for(let[r,o]of Object.entries(e))if(Array.isArray(o)){let n=o.indexOf(t);if(n>-1)return{colorName:r,shade:n}}else if(o===t)return{colorName:r,shade:null};return null},gd=[["q","w","e","r","t"],["a","s","d","f","g"],["z","x","c","v","b"]].flat(),IE=({color:e,palette:t})=>!Object.values(t).flat().includes(e),t3=(e,t,r)=>{let o={elementBackground:"backgroundColor",elementStroke:"strokeColor"},n=e.filter(a=>{if(a.isDeleted)return!1;let l=a[o[t]];return IE({color:l,palette:r})}),i=new Map;return n.forEach(a=>{let l=a[o[t]];i.has(l)?i.set(l,i.get(l)+1):i.set(l,1)}),[...i.entries()].sort((a,l)=>l[1]-a[1]).map(a=>a[0]).slice(0,Mv)},So=o8(null),e3=(e,t,r)=>(e*299+t*587+r*114)/1e3>=160?"black":"white",r3=(e,t)=>{if(t){let i=new Option().style;if(i.color=e,i.color){let a=i.color.replace(/^(rgb|rgba)\(/,"").replace(/\)$/,"").replace(/\s/g,"").split(","),l=parseInt(a[0]),s=parseInt(a[1]),c=parseInt(a[2]);return e3(l,s,c)}}if(e==="transparent")return"black";let r=parseInt(e.substring(1,3),16),o=parseInt(e.substring(3,5),16),n=parseInt(e.substring(5,7),16);return e3(r,o,n)}});import{jsxs as i8}from"react/jsx-runtime";var n8,Es,Wu=y(()=>{"use strict";f();oi();n8=({color:e,keyLabel:t,isCustomColor:r=!1,isShade:o=!1})=>i8("div",{className:"color-picker__button__hotkey-label",style:{color:r3(e,r)},children:[o&&"\u21E7",t]}),Es=n8});import a8 from"clsx";import{useAtom as l8}from"jotai";import{useEffect as s8,useRef as c8}from"react";import{jsx as fd,jsxs as o3}from"react/jsx-runtime";var n3,i3=y(()=>{"use strict";f();oi();Wu();q();n3=({hex:e,onChange:t,palette:r})=>{let o=Gi({color:e||"transparent",palette:r}),[n,i]=l8(So),a=c8(null);if(s8(()=>{a.current&&n==="shades"&&a.current.focus()},[o,n]),o){let{colorName:l,shade:s}=o,c=r[l];if(Array.isArray(c))return fd("div",{className:"color-picker-content--default shades",children:c.map((d,m)=>o3("button",{ref:m===s&&n==="shades"?a:void 0,tabIndex:-1,type:"button",className:a8("color-picker__button color-picker__button--large",{active:m===s}),"aria-label":"Shade",title:`${l} - ${m+1}`,style:d?{"--swatch-color":d}:void 0,onClick:()=>{t(d),i("shades")},children:[fd("div",{className:"color-picker__button-outline"}),fd(Es,{color:d,keyLabel:m+1,isShade:!0})]},m))})}return o3("div",{className:"color-picker-content--default",style:{position:"relative"},tabIndex:-1,children:[fd("button",{type:"button",tabIndex:-1,className:"color-picker__button color-picker__button--large color-picker__button--no-focus-visible"}),fd("div",{tabIndex:-1,style:{position:"absolute",top:0,left:0,right:0,bottom:0,display:"flex",alignItems:"center",justifyContent:"center",textAlign:"center",fontSize:"0.75rem"},children:b("colorPicker.noShades")})]})}});import d8 from"clsx";import{useAtom as m8}from"jotai";import{useEffect as p8,useRef as u8}from"react";import{jsx as AE,jsxs as g8}from"react/jsx-runtime";var h8,a3,l3=y(()=>{"use strict";f();oi();Wu();q();h8=({palette:e,color:t,onChange:r,label:o,activeShade:n})=>{let i=Gi({color:t||"transparent",palette:e}),[a,l]=m8(So),s=u8(null);return p8(()=>{s.current&&a==="baseColors"&&s.current.focus()},[i?.colorName,a]),AE("div",{className:"color-picker-content--default",children:Object.entries(e).map(([c,d],m)=>{let p=(Array.isArray(d)?d[n]:d)||"transparent",u=gd[m],h=b(`colors.${c.replace(/\d+/,"")}`,null,"");return g8("button",{ref:i?.colorName===c?s:void 0,tabIndex:-1,type:"button",className:d8("color-picker__button color-picker__button--large",{active:i?.colorName===c,"is-transparent":p==="transparent"||!p}),onClick:()=>{r(p),l("baseColors")},title:`${h}${p.startsWith("#")?` ${p}`:""} \u2014 ${u}`,"aria-label":`${h} \u2014 ${u}`,style:p?{"--swatch-color":p}:void 0,"data-testid":`color-${c}`,children:[AE("div",{className:"color-picker__button-outline"}),AE(Es,{color:p,keyLabel:u})]},c)})})},a3=h8});import f8 from"clsx";import{useAtom as b8}from"jotai";import{useEffect as E8,useRef as x8}from"react";import{jsx as kE,jsxs as y8}from"react/jsx-runtime";var s3,c3=y(()=>{"use strict";f();oi();Wu();s3=({colors:e,color:t,onChange:r,label:o})=>{let[n,i]=b8(So),a=x8(null);return E8(()=>{a.current&&a.current.focus()},[t,n]),kE("div",{className:"color-picker-content--default",children:e.map((l,s)=>y8("button",{ref:t===l?a:void 0,tabIndex:-1,type:"button",className:f8("color-picker__button color-picker__button--large",{active:t===l,"is-transparent":l==="transparent"||!l}),onClick:()=>{r(l),i("custom")},title:l,"aria-label":o,style:{"--swatch-color":l},children:[kE("div",{className:"color-picker__button-outline"}),kE(Es,{color:l,keyLabel:s+1,isCustomColor:!0})]},s))})}});var ME,w8,d3,m3=y(()=>{"use strict";f();be();Qr();oi();ME=(e,t,r)=>{let o=Math.ceil(r/Ua);switch(t=t??-1,e){case"ArrowLeft":{let n=t-1;return n<0?r-1:n}case"ArrowRight":return(t+1)%r;case"ArrowDown":{let n=t+Ua;return n>=r?t%Ua:n}case"ArrowUp":{let n=t-Ua,i=n<0?Ua*o+n:n;return i>=r?void 0:i}}},w8=({e,colorObj:t,onChange:r,palette:o,customColors:n,setActiveColorPickerSection:i,activeShade:a})=>{if(t?.shade!=null&&["Digit1","Digit2","Digit3","Digit4","Digit5"].includes(e.code)&&e.shiftKey){let l=Number(e.code.slice(-1))-1;return r(o[t.colorName][l]),i("shades"),!0}if(["1","2","3","4","5"].includes(e.key)&&n[Number(e.key)-1])return r(n[Number(e.key)-1]),i("custom"),!0;if(gd.includes(e.key)){let l=gd.indexOf(e.key),s=Object.keys(o)[l],c=o[s],d=Array.isArray(c)?c[a]:c;return r(d),i("baseColors"),!0}return!1},d3=({event:e,activeColorPickerSection:t,palette:r,color:o,onChange:n,customColors:i,setActiveColorPickerSection:a,updateData:l,activeShade:s,onEyeDropperToggle:c,onEscape:d})=>{if(e[C.CTRL_OR_CMD])return!1;if(e.key===C.ESCAPE)return d(e),!0;if(e.key===C.ALT)return c(!0),!0;if(e.key===C.I)return c(),!0;let m=Gi({color:o,palette:r});if(e.key===C.TAB){let p={custom:!!i.length,baseColors:!0,shades:m?.shade!=null,hex:!0},u=Object.entries(p).reduce((v,[w,I])=>(I&&v.push(w),v),[]),h=u.indexOf(t),E=e.shiftKey?-1:1,x=h+E>u.length-1?0:h+E<0?u.length-1:h+E,T=u[x];return T&&a(T),T==="custom"?n(i[0]):T==="baseColors"&&(Object.entries(r).find(([w,I])=>Array.isArray(I)?I.includes(o):I===o?w:null)||n(Te.charcoal)),e.preventDefault(),e.stopPropagation(),!0}if(w8({e,colorObj:m,onChange:n,palette:r,customColors:i,setActiveColorPickerSection:a,activeShade:s}))return!0;if(t==="shades"&&m){let{shade:p}=m,u=ME(e.key,p,Ua);if(u!==void 0)return n(r[m.colorName][u]),!0}if(t==="baseColors"&&m){let{colorName:p}=m,u=Object.keys(r),h=u.indexOf(p),E=ME(e.key,h,u.length);if(E!==void 0){let x=u[E],T=r[x];return n(Array.isArray(T)?T[s]:T),!0}}if(t==="custom"){let p=i.indexOf(o),u=ME(e.key,p,i.length);if(u!==void 0){let h=i[u];return n(h),!0}}return!1}});import{jsx as T8}from"react/jsx-runtime";var v8,xs,LE=y(()=>{"use strict";f();v8=({children:e})=>T8("div",{className:"color-picker__heading",children:e}),xs=v8});import p3,{useEffect as u3,useState as S8}from"react";import{useAtom as C8}from"jotai";import{jsx as ol,jsxs as Yu}from"react/jsx-runtime";var h3,g3=y(()=>{"use strict";f();q();i3();l3();c3();m3();LE();oi();Qr();be();W();h3=({color:e,onChange:t,label:r,type:o,elements:n,palette:i,updateData:a,children:l,onEyeDropperToggle:s,onEscape:c})=>{let[d]=p3.useState(()=>o==="canvasBackground"?[]:t3(n,o,i)),[m,p]=C8(So),u=Gi({color:e,palette:i});u3(()=>{if(!m){let T=IE({color:e,palette:i}),v=T&&!d.includes(e);p(v?"hex":T?"custom":u?.shade!=null?"shades":"baseColors")}},[m,e,i,p,u,d]);let[h,E]=S8(u?.shade??(o==="elementBackground"?ns:os));u3(()=>{u?.shade!=null&&E(u.shade);let T=v=>{v.key===C.ALT&&s(!1)};return document.addEventListener("keyup",T,{capture:!0}),()=>{document.removeEventListener("keyup",T,{capture:!0})}},[u,s]);let x=p3.useRef(null);return ol("div",{role:"dialog","aria-modal":"true","aria-label":b("labels.colorPicker"),children:Yu("div",{ref:x,onKeyDown:T=>{d3({event:T,activeColorPickerSection:m,palette:i,color:e,onChange:t,onEyeDropperToggle:s,customColors:d,setActiveColorPickerSection:p,updateData:a,activeShade:h,onEscape:c})&&(T.preventDefault(),T.stopPropagation())},className:"color-picker-content",tabIndex:-1,children:[!!d.length&&Yu("div",{children:[ol(xs,{children:b("colorPicker.mostUsedCustomColors")}),ol(s3,{colors:d,color:e,label:b("colorPicker.mostUsedCustomColors"),onChange:t})]}),Yu("div",{children:[ol(xs,{children:b("colorPicker.colors")}),ol(a3,{color:e,label:r,palette:i,onChange:t,activeShade:h})]}),Yu("div",{children:[ol(xs,{children:b("colorPicker.shades")}),ol(n3,{hex:e,onChange:t,palette:i})]}),l]})})}});import f3 from"react";var PE,Be,jt=y(()=>{"use strict";f();PE=f3.createContext(null),Be=()=>f3.useContext(PE)});import{useState as I8,useLayoutEffect as b3}from"react";var Ku,DE=y(()=>{"use strict";f();we();W();jt();Ku=e=>{let[t,r]=I8(null),o=_e(),{theme:n}=Be(),{container:i}=Zt();return b3(()=>{t&&(t.className="",t.classList.add("excalidraw",...e?.className?.split(/\s+/)||[]),t.classList.toggle("excalidraw--mobile",o.editor.isMobile),t.classList.toggle("theme--dark",n===se.DARK))},[t,n,o.editor.isMobile,e?.className]),b3(()=>{let a=e?.parentSelector?i?.querySelector(e.parentSelector):document.body;if(!a)return;let l=document.createElement("div");return a.appendChild(l),r(l),()=>{a.removeChild(l)}},[i,e?.parentSelector]),t}});import{useEffect as A8}from"react";function ys(e,t,r){A8(()=>{function o(n){let i=n;if(!e.current)return;let a=r?.(i,e.current);if(a===!0)return;if(a===!1)return t(i);e.current.contains(i.target)||!document.documentElement.contains(i.target)||i.target.closest("[data-radix-portal]")||i.target===document.documentElement&&document.body.style.pointerEvents==="none"||i.target.closest("[data-prevent-outside-click]")||t(i)}return document.addEventListener("pointerdown",o),document.addEventListener("touchstart",o),()=>{document.removeEventListener("pointerdown",o),document.removeEventListener("touchstart",o)}},[e,t,r])}var $u=y(()=>{"use strict";f();W()});import{useRef as k8}from"react";var ws,Xu=y(()=>{"use strict";f();ws=e=>{let t=k8(e);return Object.assign(t.current,e),t.current}});var E3=y(()=>{});import{atom as M8}from"jotai";import{useEffect as L8,useRef as P8}from"react";import{createPortal as D8}from"react-dom";import{jsx as _8}from"react/jsx-runtime";var Vi,x3,bd=y(()=>{"use strict";f();Qr();W();jt();DE();$u();be();qe();we();Xu();E3();Vi=M8(null),x3=({onCancel:e,onChange:t,onSelect:r,colorPickerType:o})=>{let n=Ku({className:"excalidraw-eye-dropper-backdrop",parentSelector:".excalidraw-eye-dropper-container"}),i=Be(),a=Wi(),l=Or(),s=ge(a,i),c=ws({app:l,onCancel:e,onChange:t,onSelect:r,selectedElements:s}),{container:d}=Zt();L8(()=>{let p=m.current;if(!p||!l.canvas||!n)return;let u=!1,h=l.canvas.getContext("2d"),E=({clientX:A,clientY:M})=>{let D=h.getImageData((A-i.offsetLeft)*window.devicePixelRatio,(M-i.offsetTop)*window.devicePixelRatio,1,1).data;return Nv(D[0],D[1],D[2])},x=({clientX:A,clientY:M,altKey:D})=>{p.style.top=`${M+20}px`,p.style.left=`${A+20}px`;let O=E({clientX:A,clientY:M});u&&c.onChange(o,O,c.selectedElements,{altKey:D}),p.style.background=O},T=()=>{c.onCancel()},v=(A,M)=>{c.onSelect(A,M)},w=A=>{u=!0,A.stopImmediatePropagation()},I=A=>{u=!1,d?.focus(),A.stopImmediatePropagation(),A.preventDefault(),v(E(A),A)},L=A=>{A.key===C.ESCAPE&&(A.preventDefault(),A.stopImmediatePropagation(),T())};return n.tabIndex=-1,n.focus(),x({clientX:c.app.lastViewportPosition.x,clientY:c.app.lastViewportPosition.y,altKey:!1}),n.addEventListener("keydown",L),n.addEventListener("pointerdown",w),n.addEventListener("pointerup",I),window.addEventListener("pointermove",x,{passive:!0}),window.addEventListener("blur",T),()=>{u=!1,n.removeEventListener("keydown",L),n.removeEventListener("pointerdown",w),n.removeEventListener("pointerup",I),window.removeEventListener("pointermove",x),window.removeEventListener("blur",T)}},[c,l.canvas,n,o,d,i.offsetLeft,i.offsetTop]);let m=P8(null);return ys(m,()=>{e()},p=>!!p.target.closest(".excalidraw-eye-dropper-trigger, .excalidraw-eye-dropper-backdrop")),n?D8(_8("div",{ref:m,className:"excalidraw-eye-dropper-preview"}),n):null}});import{useCallback as R8,useEffect as _E,useRef as y3,useState as N8}from"react";import{useAtom as w3}from"jotai";import O8 from"clsx";import{Fragment as B8,jsx as Zu,jsxs as v3}from"react/jsx-runtime";var T3,S3=y(()=>{"use strict";f();ju();oi();ne();kt();be();bd();q();we();G();T3=({color:e,onChange:t,label:r,colorPickerType:o})=>{let n=_e(),[i,a]=N8(e),[l,s]=w3(So);_E(()=>{a(e)},[e]);let c=R8(h=>{let E=h.toLowerCase(),x=C3(E);x&&t(x),a(E)},[t]),d=y3(null),m=y3(null);_E(()=>{d.current&&d.current.focus()},[l]);let[p,u]=w3(Vi,Ge);return _E(()=>()=>{u(null)},[u]),v3("div",{className:"color-picker__input-label",children:[Zu("div",{className:"color-picker__input-hash",children:"#"}),Zu("input",{ref:l==="hex"?d:void 0,style:{border:0,padding:0},spellCheck:!1,className:"color-picker-input","aria-label":r,onChange:h=>{c(h.target.value)},value:(i||"").replace(/^#/,""),onBlur:()=>{a(e)},tabIndex:-1,onFocus:()=>s("hex"),onKeyDown:h=>{h.key!==C.TAB&&(h.key===C.ESCAPE&&m.current?.focus(),h.stopPropagation())}}),!n.editor.isMobile&&v3(B8,{children:[Zu("div",{style:{width:"1px",height:"1.25rem",backgroundColor:"var(--default-border-color)"}}),Zu("div",{ref:m,className:O8("excalidraw-eye-dropper-trigger",{selected:p}),onClick:()=>u(h=>h?null:{keepOpenOnAlt:!1,onSelect:E=>t(E),colorPickerType:o}),title:`${b("labels.eyeDropper")} \u2014 ${C.I.toLocaleUpperCase()} or ${N("Alt")} `,children:rE})]})]})}});var I3=y(()=>{});import*as yn from"@radix-ui/react-popover";import{useAtom as A3}from"jotai";import F8 from"clsx";import{useRef as z8}from"react";import{jsx as Co,jsxs as qu}from"react/jsx-runtime";var k3,C3,H8,U8,Ed,ju=y(()=>{"use strict";f();G();QT();g3();oi();we();Qr();LE();q();kt();S3();bd();I3();k3=e=>{let t=new Option().style;return t.color=e,!!t.color},C3=e=>hr(e)?e:k3(`#${e}`)?`#${e}`:k3(e)?e:null,H8=({type:e,color:t,onChange:r,label:o,elements:n,palette:i=Te,updateData:a})=>{let[,l]=A3(So),[s,c]=A3(Vi,Ge),{container:d}=Zt(),m=_e(),p=qu("div",{children:[Co(xs,{children:b("colorPicker.hexCode")}),Co(T3,{color:t,label:o,onChange:E=>{r(E)},colorPickerType:e})]}),u=z8(null),h=()=>{u.current?.querySelector(".color-picker-content")?.focus()};return Co(yn.Portal,{container:d,children:qu(yn.Content,{ref:u,className:"focus-visible-none","data-prevent-outside-click":!0,onFocusOutside:E=>{h(),E.preventDefault()},onPointerDownOutside:E=>{s&&E.preventDefault()},onCloseAutoFocus:E=>{E.stopPropagation(),E.preventDefault(),d&&!Jy(document.activeElement)&&d.focus(),a({openPopup:null}),l(null)},side:m.editor.isMobile&&!m.viewport.isLandscape?"bottom":"right",align:m.editor.isMobile&&!m.viewport.isLandscape?"center":"start",alignOffset:-16,sideOffset:20,style:{zIndex:"var(--zIndex-layerUI)",backgroundColor:"var(--popup-bg-color)",maxWidth:"208px",maxHeight:window.innerHeight,padding:"12px",borderRadius:"8px",boxSizing:"border-box",overflowY:"auto",boxShadow:"0px 7px 14px rgba(0, 0, 0, 0.05), 0px 0px 3.12708px rgba(0, 0, 0, 0.0798), 0px 0px 0.931014px rgba(0, 0, 0, 0.1702)"},children:[i?Co(h3,{palette:i,color:t,onChange:E=>{r(E)},onEyeDropperToggle:E=>{c(x=>E?(x=x||{keepOpenOnAlt:!0,onSelect:r,colorPickerType:e},x.keepOpenOnAlt=!0,x):E===!1||x?null:{keepOpenOnAlt:!1,onSelect:r,colorPickerType:e})},onEscape:E=>{s?c(null):uo(E.target)?h():a({openPopup:null})},label:o,type:e,elements:n,updateData:a,children:p}):p,Co(yn.Arrow,{width:20,height:10,style:{fill:"var(--popup-bg-color)",filter:"drop-shadow(rgba(0, 0, 0, 0.05) 0px 3px 2px)"}})]})})},U8=({label:e,color:t,type:r})=>Co(yn.Trigger,{type:"button",className:F8("color-picker__button active-color",{"is-transparent":t==="transparent"||!t}),"aria-label":e,style:t?{"--swatch-color":t}:void 0,title:r==="elementStroke"?b("labels.showStroke"):b("labels.showBackground"),children:Co("div",{className:"color-picker__button-outline"})}),Ed=({type:e,color:t,onChange:r,label:o,elements:n,palette:i=Te,topPicks:a,updateData:l,appState:s})=>Co("div",{children:qu("div",{role:"dialog","aria-modal":"true",className:"color-picker-container",children:[Co(JT,{activeColor:t,onChange:r,type:e,topPicks:a}),Co("div",{style:{width:1,height:"100%",backgroundColor:"var(--default-border-color)",margin:"0 auto"}}),qu(yn.Root,{open:s.openPopup===e,onOpenChange:c=>{l({openPopup:c?e:null})},children:[Co(U8,{color:t,label:o,type:e}),s.openPopup===e&&Co(H8,{type:e,color:t,onChange:r,label:o,elements:n,palette:i,updateData:l})]})]})})});var M3=y(()=>{});import{useLayoutEffect as G8,useRef as L3,useEffect as P3}from"react";import{unstable_batchedUpdates as V8}from"react-dom";import{jsx as W8}from"react/jsx-runtime";var Ju,RE=y(()=>{"use strict";f();M3();G();be();Ju=({children:e,left:t,top:r,onCloseRequest:o,fitInViewport:n=!1,offsetLeft:i=0,offsetTop:a=0,viewportWidth:l=window.innerWidth,viewportHeight:s=window.innerHeight})=>{let c=L3(null);P3(()=>{let m=c.current;if(!m)return;m.contains(document.activeElement)||m.focus();let p=u=>{if(u.key===C.TAB){let h=oc(m),{activeElement:E}=document,x=h.findIndex(T=>T===E);E===m?(u.shiftKey?h[h.length-1]?.focus():h[0].focus(),u.preventDefault(),u.stopImmediatePropagation()):x===0&&u.shiftKey?(h[h.length-1]?.focus(),u.preventDefault(),u.stopImmediatePropagation()):x===h.length-1&&!u.shiftKey&&(h[0]?.focus(),u.preventDefault(),u.stopImmediatePropagation())}};return m.addEventListener("keydown",p),()=>m.removeEventListener("keydown",p)},[]);let d=L3(null);return G8(()=>{if(n&&c.current&&r!=null&&t!=null){let m=c.current,{width:p,height:u}=m.getBoundingClientRect();if(d.current?.top===r&&d.current?.left===t)return;d.current={top:r,left:t},p>=l?(m.style.width=`${l}px`,m.style.left="0px",m.style.overflowX="scroll"):t+p-i>l?m.style.left=`${l-p-10}px`:m.style.left=`${t}px`,u>=s?(m.style.height=`${s-20}px`,m.style.top="10px",m.style.overflowY="scroll"):r+u-a>s?m.style.top=`${s-u}px`:m.style.top=`${r}px`}},[r,t,n,l,s,i,a]),P3(()=>{if(o){let m=p=>{c.current?.contains(p.target)||V8(()=>o(p))};return document.addEventListener("pointerdown",m,!1),()=>document.removeEventListener("pointerdown",m,!1)}},[o]),W8("div",{className:"popover",ref:c,tabIndex:-1,children:e})}});var D3=y(()=>{});import nl from"react";import Y8 from"clsx";import{Fragment as $8,jsx as Yi,jsxs as NE}from"react/jsx-runtime";function K8({options:e,value:t,label:r,onChange:o,onClose:n}){let i=nl.useRef(),a=nl.useRef(),l=nl.useRef(null);return nl.useEffect(()=>{a.current?a.current.focus():l.current&&l.current.focus()},[]),Yi("div",{className:"picker",role:"dialog","aria-modal":"true","aria-label":r,onKeyDown:c=>{let d=e.find(m=>m.keyBinding===c.key.toLowerCase());if(!(c.metaKey||c.altKey||c.ctrlKey)&&d){let m=e.indexOf(d);l.current.children[m].focus(),c.preventDefault()}else if(c.key===C.TAB)setTimeout(()=>{let m=a.current,p=document.activeElement;m!==p&&n()},0);else if(Bl(c.key)){let{activeElement:m}=document,p=Dn().rtl,u=Array.prototype.indexOf.call(l.current.children,m);if(u!==-1){let h=e.length,E=u;switch(c.key){case(p?C.ARROW_LEFT:C.ARROW_RIGHT):case C.ARROW_DOWN:{E=(u+1)%h;break}case(p?C.ARROW_RIGHT:C.ARROW_LEFT):case C.ARROW_UP:{E=(h+u-1)%h;break}}l.current.children[E].focus()}c.preventDefault()}else(c.key===C.ESCAPE||c.key===C.ENTER)&&(c.preventDefault(),n());c.nativeEvent.stopImmediatePropagation(),c.stopPropagation()},children:Yi("div",{className:"picker-content",ref:l,children:e.map((c,d)=>NE("button",{className:Y8("picker-option",{active:t===c.value}),onClick:m=>{m.currentTarget.focus(),o(c.value)},title:`${c.text} ${c.keyBinding&&`\u2014 ${c.keyBinding.toUpperCase()}`}`,"aria-label":c.text||"none","aria-keyshortcuts":c.keyBinding||void 0,ref:m=>{m&&d===0&&(i.current=m),m&&c.value===t&&(a.current=m)},onFocus:()=>{o(c.value)},children:[c.icon,c.keyBinding&&Yi("span",{className:"picker-keybinding",children:c.keyBinding})]},c.text))})})}function OE({value:e,label:t,options:r,onChange:o,group:n=""}){let[i,a]=nl.useState(!1),l=nl.useRef(null),s=Dn().rtl;return NE("div",{children:[Yi("button",{name:n,className:i?"active":"","aria-label":t,onClick:()=>a(!i),ref:l,children:r.find(c=>c.value===e)?.icon}),Yi(nl.Suspense,{fallback:"",children:i?NE($8,{children:[Yi(Ju,{onCloseRequest:c=>c.target!==l.current&&a(!1),...s?{right:5.5}:{left:-5.5},children:Yi(K8,{options:r.filter(c=>c.showInPicker!==!1),value:e,label:t,onChange:o,onClose:()=>{a(!1),l.current?.focus()}})}),Yi("div",{className:"picker-triangle"})]}):null})]})}var _3=y(()=>{"use strict";f();RE();D3();be();q()});import{Fragment as K3,jsx as Me,jsxs as ro}from"react/jsx-runtime";var N3,oo,Br,X8,BE,O3,B3,F3,z3,H3,_q,U3,G3,FE,zE,V3,W3,Y3,Rq,R3,Nq,HE=y(()=>{"use strict";f();Qr();Nr();qT();ju();_3();ne();W();xe();Ye();mt();me();q();be();Oo();qe();fc();G();Je();ze();N3=.1,oo=(e,t,r,o=!1)=>{let n=X(ge(e,t,{includeBoundTextElement:o}));return e.map(i=>n.get(i.id)||i.id===t.editingElement?.id?r(i):i)},Br=function(e,t,r,o,n){let i=t.editingElement,a=ye(e),l=null;return i&&(l=r(i)),l||(Xe(a,t)?l=B1(o===!0?a:a.filter(c=>o(c)),t,r)??(typeof n=="function"?n(!0):n):l=typeof n=="function"?n(!1):n),l},X8=(e,t)=>Pe(t)?t:H(t,{x:e.textAlign==="left"?e.x:e.x+(e.width-t.width)/(e.textAlign==="center"?2:1),y:e.y+(e.height-t.height)/2},!1),BE=(e,t,r,o,n)=>{let i=new Set;return{elements:oo(e,t,a=>{if(V(a)){let l=o(a);i.add(l);let s=le(a,{fontSize:l});return Ht(s,r.scene.getContainerElement(a),r.scene.getNonDeletedElementsMap()),s=X8(a,s),s}return a},!0),appState:{...t,currentItemFontSize:i.size===1?[...i][0]:n??t.currentItemFontSize},storeAction:_.CAPTURE}},O3=U({name:"changeStrokeColor",label:"labels.stroke",trackEvent:!1,perform:(e,t,r)=>({...r.currentItemStrokeColor&&{elements:oo(e,t,o=>gc(o.type)?le(o,{strokeColor:r.currentItemStrokeColor}):o,!0)},appState:{...t,...r},storeAction:r.currentItemStrokeColor?_.CAPTURE:_.NONE}),PanelComponent:({elements:e,appState:t,updateData:r,appProps:o})=>ro(K3,{children:[Me("h3",{"aria-hidden":"true",children:b("labels.stroke")}),Me(Ed,{topPicks:Wp,palette:Dv,type:"elementStroke",label:b("labels.stroke"),color:Br(e,t,n=>n.strokeColor,!0,t.currentItemStrokeColor),onChange:n=>r({currentItemStrokeColor:n}),elements:e,appState:t,updateData:r})]})}),B3=U({name:"changeBackgroundColor",label:"labels.changeBackground",trackEvent:!1,perform:(e,t,r)=>({...r.currentItemBackgroundColor&&{elements:oo(e,t,o=>le(o,{backgroundColor:r.currentItemBackgroundColor}))},appState:{...t,...r},storeAction:r.currentItemBackgroundColor?_.CAPTURE:_.NONE}),PanelComponent:({elements:e,appState:t,updateData:r,appProps:o})=>ro(K3,{children:[Me("h3",{"aria-hidden":"true",children:b("labels.background")}),Me(Ed,{topPicks:Yp,palette:_v,type:"elementBackground",label:b("labels.background"),color:Br(e,t,n=>n.backgroundColor,!0,t.currentItemBackgroundColor),onChange:n=>r({currentItemBackgroundColor:n}),elements:e,appState:t,updateData:r})]})}),F3=U({name:"changeFillStyle",label:"labels.fill",trackEvent:!1,perform:(e,t,r,o)=>(ve("element","changeFillStyle",`${r} (${o.device.editor.isMobile?"mobile":"desktop"})`),{elements:oo(e,t,n=>le(n,{fillStyle:r})),appState:{...t,currentItemFillStyle:r},storeAction:_.CAPTURE}),PanelComponent:({elements:e,appState:t,updateData:r})=>{let o=ge(e,t),n=o.length>0&&o.every(i=>i.fillStyle==="zigzag");return ro("fieldset",{children:[Me("legend",{children:b("labels.fill")}),Me(xn,{type:"button",options:[{value:"hachure",text:`${n?b("labels.zigzag"):b("labels.hachure")} (${N("Alt-Click")})`,icon:n?xb:yb,active:n?!0:void 0,testId:"fill-hachure"},{value:"cross-hatch",text:b("labels.crossHatch"),icon:wb,testId:"fill-cross-hatch"},{value:"solid",text:b("labels.solid"),icon:vb,testId:"fill-solid"}],value:Br(e,t,i=>i.fillStyle,i=>i.hasOwnProperty("fillStyle"),i=>i?null:t.currentItemFillStyle),onClick:(i,a)=>{let l=a.altKey&&i==="hachure"&&o.every(s=>s.fillStyle==="hachure")?"zigzag":i;r(l)}})]})}}),z3=U({name:"changeStrokeWidth",label:"labels.strokeWidth",trackEvent:!1,perform:(e,t,r)=>({elements:oo(e,t,o=>le(o,{strokeWidth:r})),appState:{...t,currentItemStrokeWidth:r},storeAction:_.CAPTURE}),PanelComponent:({elements:e,appState:t,updateData:r})=>ro("fieldset",{children:[Me("legend",{children:b("labels.strokeWidth")}),Me(xn,{group:"stroke-width",options:[{value:Im.thin,text:b("labels.thin"),icon:Du,testId:"strokeWidth-thin"},{value:Im.bold,text:b("labels.bold"),icon:Tb,testId:"strokeWidth-bold"},{value:Im.extraBold,text:b("labels.extraBold"),icon:Sb,testId:"strokeWidth-extraBold"}],value:Br(e,t,o=>o.strokeWidth,o=>o.hasOwnProperty("strokeWidth"),o=>o?null:t.currentItemStrokeWidth),onChange:o=>r(o)})]})}),H3=U({name:"changeSloppiness",label:"labels.sloppiness",trackEvent:!1,perform:(e,t,r)=>({elements:oo(e,t,o=>le(o,{seed:fo(),roughness:r})),appState:{...t,currentItemRoughness:r},storeAction:_.CAPTURE}),PanelComponent:({elements:e,appState:t,updateData:r})=>ro("fieldset",{children:[Me("legend",{children:b("labels.sloppiness")}),Me(xn,{group:"sloppiness",options:[{value:0,text:b("labels.architect"),icon:Ab},{value:1,text:b("labels.artist"),icon:kb},{value:2,text:b("labels.cartoonist"),icon:Mb}],value:Br(e,t,o=>o.roughness,o=>o.hasOwnProperty("roughness"),o=>o?null:t.currentItemRoughness),onChange:o=>r(o)})]})}),_q=U({name:"changeStrokeStyle",label:"labels.strokeStyle",trackEvent:!1,perform:(e,t,r)=>({elements:oo(e,t,o=>le(o,{strokeStyle:r})),appState:{...t,currentItemStrokeStyle:r},storeAction:_.CAPTURE}),PanelComponent:({elements:e,appState:t,updateData:r})=>ro("fieldset",{children:[Me("legend",{children:b("labels.strokeStyle")}),Me(xn,{group:"strokeStyle",options:[{value:"solid",text:b("labels.strokeStyle_solid"),icon:Du},{value:"dashed",text:b("labels.strokeStyle_dashed"),icon:Cb},{value:"dotted",text:b("labels.strokeStyle_dotted"),icon:Ib}],value:Br(e,t,o=>o.strokeStyle,o=>o.hasOwnProperty("strokeStyle"),o=>o?null:t.currentItemStrokeStyle),onChange:o=>r(o)})]})}),U3=U({name:"changeOpacity",label:"labels.opacity",trackEvent:!1,perform:(e,t,r)=>({elements:oo(e,t,o=>le(o,{opacity:r}),!0),appState:{...t,currentItemOpacity:r},storeAction:_.CAPTURE}),PanelComponent:({elements:e,appState:t,updateData:r})=>ro("label",{className:"control-label",children:[b("labels.opacity"),Me("input",{type:"range",min:"0",max:"100",step:"10",onChange:o=>r(+o.target.value),value:Br(e,t,o=>o.opacity,!0,t.currentItemOpacity)??void 0})]})}),G3=U({name:"changeFontSize",label:"labels.fontSize",trackEvent:!1,perform:(e,t,r,o)=>BE(e,t,o,()=>r,r),PanelComponent:({elements:e,appState:t,updateData:r,app:o})=>ro("fieldset",{children:[Me("legend",{children:b("labels.fontSize")}),Me(xn,{group:"font-size",options:[{value:16,text:b("labels.small"),icon:Hb,testId:"fontSize-small"},{value:20,text:b("labels.medium"),icon:Ub,testId:"fontSize-medium"},{value:28,text:b("labels.large"),icon:Gb,testId:"fontSize-large"},{value:36,text:b("labels.veryLarge"),icon:Vb,testId:"fontSize-veryLarge"}],value:Br(e,t,n=>{if(V(n))return n.fontSize;let i=ue(n,o.scene.getNonDeletedElementsMap());return i?i.fontSize:null},n=>V(n)||ue(n,o.scene.getNonDeletedElementsMap())!==null,n=>n?null:t.currentItemFontSize||Ot),onChange:n=>r(n)})]})}),FE=U({name:"decreaseFontSize",label:"labels.decreaseFontSize",icon:Ru,trackEvent:!1,perform:(e,t,r,o)=>BE(e,t,o,n=>Math.round(1/(1+N3)*n.fontSize)),keyTest:e=>e[C.CTRL_OR_CMD]&&e.shiftKey&&(e.key===C.CHEVRON_LEFT||e.key===C.COMMA)}),zE=U({name:"increaseFontSize",label:"labels.increaseFontSize",icon:Ru,trackEvent:!1,perform:(e,t,r,o)=>BE(e,t,o,n=>Math.round(n.fontSize*(1+N3))),keyTest:e=>e[C.CTRL_OR_CMD]&&e.shiftKey&&(e.key===C.CHEVRON_RIGHT||e.key===C.PERIOD)}),V3=U({name:"changeFontFamily",label:"labels.fontFamily",trackEvent:!1,perform:(e,t,r,o)=>({elements:oo(e,t,n=>{if(V(n)){let i=le(n,{fontFamily:r,lineHeight:Xr(r)});return Ht(i,o.scene.getContainerElement(n),o.scene.getNonDeletedElementsMap()),i}return n},!0),appState:{...t,currentItemFontFamily:r},storeAction:_.CAPTURE}),PanelComponent:({elements:e,appState:t,updateData:r,app:o})=>{let n=[{value:ht.Virgil,text:b("labels.handDrawn"),icon:qa,testId:"font-family-virgil"},{value:ht.Helvetica,text:b("labels.normal"),icon:Wb,testId:"font-family-normal"},{value:ht.Cascadia,text:b("labels.code"),icon:Yb,testId:"font-family-code"}];return ro("fieldset",{children:[Me("legend",{children:b("labels.fontFamily")}),Me(xn,{group:"font-family",options:n,value:Br(e,t,i=>{if(V(i))return i.fontFamily;let a=ue(i,o.scene.getNonDeletedElementsMap());return a?a.fontFamily:null},i=>V(i)||ue(i,o.scene.getNonDeletedElementsMap())!==null,i=>i?null:t.currentItemFontFamily||tr),onChange:i=>r(i)})]})}}),W3=U({name:"changeTextAlign",label:"Change text alignment",trackEvent:!1,perform:(e,t,r,o)=>({elements:oo(e,t,n=>{if(V(n)){let i=le(n,{textAlign:r});return Ht(i,o.scene.getContainerElement(n),o.scene.getNonDeletedElementsMap()),i}return n},!0),appState:{...t,currentItemTextAlign:r},storeAction:_.CAPTURE}),PanelComponent:({elements:e,appState:t,updateData:r,app:o})=>{let n=o.scene.getNonDeletedElementsMap();return ro("fieldset",{children:[Me("legend",{children:b("labels.textAlign")}),Me(xn,{group:"text-align",options:[{value:"left",text:b("labels.left"),icon:Kb,testId:"align-left"},{value:"center",text:b("labels.center"),icon:$b,testId:"align-horizontal-center"},{value:"right",text:b("labels.right"),icon:Xb,testId:"align-right"}],value:Br(e,t,i=>{if(V(i))return i.textAlign;let a=ue(i,n);return a?a.textAlign:null},i=>V(i)||ue(i,n)!==null,i=>i?null:t.currentItemTextAlign),onChange:i=>r(i)})]})}}),Y3=U({name:"changeVerticalAlign",label:"Change vertical alignment",trackEvent:{category:"element"},perform:(e,t,r,o)=>({elements:oo(e,t,n=>{if(V(n)){let i=le(n,{verticalAlign:r});return Ht(i,o.scene.getContainerElement(n),o.scene.getNonDeletedElementsMap()),i}return n},!0),appState:{...t},storeAction:_.CAPTURE}),PanelComponent:({elements:e,appState:t,updateData:r,app:o})=>Me("fieldset",{children:Me(xn,{group:"text-align",options:[{value:Tt.TOP,text:b("labels.alignTop"),icon:Me(Zb,{theme:t.theme}),testId:"align-top"},{value:Tt.MIDDLE,text:b("labels.centerVertically"),icon:Me(qb,{theme:t.theme}),testId:"align-middle"},{value:Tt.BOTTOM,text:b("labels.alignBottom"),icon:Me(jb,{theme:t.theme}),testId:"align-bottom"}],value:Br(e,t,n=>{if(V(n)&&n.containerId)return n.verticalAlign;let i=ue(n,o.scene.getNonDeletedElementsMap());return i?i.verticalAlign:null},n=>V(n)||ue(n,o.scene.getNonDeletedElementsMap())!==null,n=>n?null:Tt.MIDDLE),onChange:n=>r(n)})})}),Rq=U({name:"changeRoundness",label:"Change edge roundness",trackEvent:!1,perform:(e,t,r)=>({elements:oo(e,t,o=>le(o,{roundness:r==="round"?{type:nn(o.type)?ct.ADAPTIVE_RADIUS:ct.PROPORTIONAL_RADIUS}:null})),appState:{...t,currentItemRoundness:r},storeAction:_.CAPTURE}),PanelComponent:({elements:e,appState:t,updateData:r})=>{let n=Za(ye(e),t).some(i=>i.roundness?.type===ct.LEGACY);return ro("fieldset",{children:[Me("legend",{children:b("labels.edges")}),Me(xn,{group:"edges",options:[{value:"sharp",text:b("labels.sharp"),icon:Lb},{value:"round",text:b("labels.round"),icon:Pb}],value:Br(e,t,i=>n?null:i.roundness?"round":"sharp",i=>i.hasOwnProperty("roundness"),i=>i?null:t.currentItemRoundness),onChange:i=>r(i)})]})}}),R3=e=>[{value:null,text:b("labels.arrowhead_none"),keyBinding:"q",icon:Db},{value:"arrow",text:b("labels.arrowhead_arrow"),keyBinding:"w",icon:Me(_b,{flip:e})},{value:"bar",text:b("labels.arrowhead_bar"),keyBinding:"e",icon:Me(Nb,{flip:e})},{value:"dot",text:b("labels.arrowhead_circle"),keyBinding:null,icon:Me(_u,{flip:e}),showInPicker:!1},{value:"circle",text:b("labels.arrowhead_circle"),keyBinding:"r",icon:Me(_u,{flip:e}),showInPicker:!1},{value:"circle_outline",text:b("labels.arrowhead_circle_outline"),keyBinding:null,icon:Me(Rb,{flip:e}),showInPicker:!1},{value:"triangle",text:b("labels.arrowhead_triangle"),icon:Me(Ob,{flip:e}),keyBinding:"t"},{value:"triangle_outline",text:b("labels.arrowhead_triangle_outline"),icon:Me(Bb,{flip:e}),keyBinding:null,showInPicker:!1},{value:"diamond",text:b("labels.arrowhead_diamond"),icon:Me(Fb,{flip:e}),keyBinding:null,showInPicker:!1},{value:"diamond_outline",text:b("labels.arrowhead_diamond_outline"),icon:Me(zb,{flip:e}),keyBinding:null,showInPicker:!1}],Nq=U({name:"changeArrowhead",label:"Change arrowheads",trackEvent:!1,perform:(e,t,r)=>({elements:oo(e,t,o=>{if(ce(o)){let{position:n,type:i}=r;if(n==="start")return le(o,{startArrowhead:i});if(n==="end")return le(o,{endArrowhead:i})}return o}),appState:{...t,[r.position==="start"?"currentItemStartArrowhead":"currentItemEndArrowhead"]:r.type},storeAction:_.CAPTURE}),PanelComponent:({elements:e,appState:t,updateData:r})=>{let o=Dn().rtl;return ro("fieldset",{children:[Me("legend",{children:b("labels.arrowheads")}),ro("div",{className:"iconSelectList buttonList",children:[Me(OE,{label:"arrowhead_start",options:R3(!o),value:Br(e,t,n=>ce(n)&&wa(n.type)?n.startArrowhead:t.currentItemStartArrowhead,!0,t.currentItemStartArrowhead),onChange:n=>r({position:"start",type:n})}),Me(OE,{label:"arrowhead_end",group:"arrowheads",options:R3(!!o),value:Br(e,t,n=>ce(n)&&wa(n.type)?n.endArrowhead:t.currentItemEndArrowhead,!0,t.currentItemEndArrowhead),onChange:n=>r({position:"end",type:n})})]})]})}})});var $3=y(()=>{});import{useEffect as Z8}from"react";import{jsx as q8}from"react/jsx-runtime";var vs,UE,j8,no,Ki=y(()=>{"use strict";f();$3();vs=()=>{let e=document.querySelector(".excalidraw-tooltip");if(e)return e;let t=document.createElement("div");return document.body.appendChild(t),t.classList.add("excalidraw-tooltip"),t},UE=(e,t,r="bottom")=>{let o=e.getBoundingClientRect(),n=window.innerWidth,i=window.innerHeight,a=5,l=t.left+t.width/2-o.width/2;l<0?l=a:l+o.width>=n&&(l=n-o.width-a);let s;r==="bottom"?(s=t.top+t.height+a,s+o.height>=i&&(s=t.top-o.height-a)):(s=t.top-o.height-a,s<0&&(s=t.top+t.height+a)),Object.assign(e.style,{top:`${s}px`,left:`${l}px`})},j8=(e,t,r,o)=>{t.classList.add("excalidraw-tooltip--visible"),t.style.minWidth=o?"50ch":"10ch",t.style.maxWidth=o?"50ch":"15ch",t.textContent=r;let n=e.getBoundingClientRect();UE(t,n)},no=({children:e,label:t,long:r=!1,style:o,disabled:n})=>(Z8(()=>()=>vs().classList.remove("excalidraw-tooltip--visible"),[]),n?null:q8("div",{className:"excalidraw-tooltip-wrapper",onPointerEnter:i=>j8(i.currentTarget,vs(),t,r),onPointerLeave:()=>vs().classList.remove("excalidraw-tooltip--visible"),style:o,children:e}))});import{jsx as Qu,jsxs as Q8}from"react/jsx-runtime";var X3,wn,xd,yd,Z3,J8,j3,wd,mJ,pJ,q3,$i,uJ,J3,vd=y(()=>{"use strict";f();ju();ne();Dt();W();xe();q();be();qe();z1();hu();G();Je();Ki();Ye();Dr();Qr();Vl();ze();X3=U({name:"changeViewBackgroundColor",label:"labels.canvasBackground",paletteName:"Change canvas background color",trackEvent:!1,predicate:(e,t,r,o)=>!!o.props.UIOptions.canvasActions.changeViewBackgroundColor&&!t.viewModeEnabled,perform:(e,t,r)=>({appState:{...t,...r},storeAction:r.viewBackgroundColor?_.CAPTURE:_.NONE}),PanelComponent:({elements:e,appState:t,updateData:r,appProps:o})=>Qu(Ed,{palette:null,topPicks:Kp,label:b("labels.canvasBackground"),type:"canvasBackground",color:t.viewBackgroundColor,onChange:n=>r({viewBackgroundColor:n}),"data-testid":"canvas-background-picker",elements:e,appState:t,updateData:r})}),wn=U({name:"clearCanvas",label:"labels.clearCanvas",paletteName:"Clear canvas",icon:To,trackEvent:{category:"canvas"},predicate:(e,t,r,o)=>!!o.props.UIOptions.canvasActions.clearCanvas&&!t.viewModeEnabled,perform:(e,t,r,o)=>(o.imageCache.clear(),{elements:e.map(n=>le(n,{isDeleted:!0})),appState:{...Er(),files:{},theme:t.theme,penMode:t.penMode,penDetected:t.penDetected,exportBackground:t.exportBackground,exportEmbedScene:t.exportEmbedScene,gridSize:t.gridSize,showStats:t.showStats,pasteDialog:t.pasteDialog,activeTool:t.activeTool.type==="image"?{...t.activeTool,type:"selection"}:t.activeTool},storeAction:_.CAPTURE})}),xd=U({name:"zoomIn",label:"buttons.zoomIn",viewMode:!0,icon:gu,trackEvent:{category:"canvas"},perform:(e,t,r,o)=>({appState:{...t,...ti({viewportX:t.width/2+t.offsetLeft,viewportY:t.height/2+t.offsetTop,nextZoom:En(t.zoom.value+ba)},t),userToFollow:null},storeAction:_.NONE}),PanelComponent:({updateData:e,appState:t})=>Qu(pe,{type:"button",className:"zoom-in-button zoom-button",icon:gu,title:`${b("buttons.zoomIn")} \u2014 ${N("CtrlOrCmd++")}`,"aria-label":b("buttons.zoomIn"),disabled:t.zoom.value>=Ug,onClick:()=>{e(null)}}),keyTest:e=>(e.code===Ee.EQUAL||e.code===Ee.NUM_ADD)&&(e[C.CTRL_OR_CMD]||e.shiftKey)}),yd=U({name:"zoomOut",label:"buttons.zoomOut",icon:fu,viewMode:!0,trackEvent:{category:"canvas"},perform:(e,t,r,o)=>({appState:{...t,...ti({viewportX:t.width/2+t.offsetLeft,viewportY:t.height/2+t.offsetTop,nextZoom:En(t.zoom.value-ba)},t),userToFollow:null},storeAction:_.NONE}),PanelComponent:({updateData:e,appState:t})=>Qu(pe,{type:"button",className:"zoom-out-button zoom-button",icon:fu,title:`${b("buttons.zoomOut")} \u2014 ${N("CtrlOrCmd+-")}`,"aria-label":b("buttons.zoomOut"),disabled:t.zoom.value<=Sl,onClick:()=>{e(null)}}),keyTest:e=>(e.code===Ee.MINUS||e.code===Ee.NUM_SUBTRACT)&&(e[C.CTRL_OR_CMD]||e.shiftKey)}),Z3=U({name:"resetZoom",label:"buttons.resetZoom",icon:nb,viewMode:!0,trackEvent:{category:"canvas"},perform:(e,t,r,o)=>({appState:{...t,...ti({viewportX:t.width/2+t.offsetLeft,viewportY:t.height/2+t.offsetTop,nextZoom:En(1)},t),userToFollow:null},storeAction:_.NONE}),PanelComponent:({updateData:e,appState:t})=>Qu(no,{label:b("buttons.resetZoom"),style:{height:"100%"},children:Q8(pe,{type:"button",className:"reset-zoom-button zoom-button",title:b("buttons.resetZoom"),"aria-label":b("buttons.resetZoom"),onClick:()=>{e(null)},children:[(t.zoom.value*100).toFixed(0),"%"]})}),keyTest:e=>(e.code===Ee.ZERO||e.code===Ee.NUM_ZERO)&&(e[C.CTRL_OR_CMD]||e.shiftKey)}),J8=(e,t)=>{let[r,o,n,i]=e,a=n-r,l=t.width/a,s=i-o,c=t.height/s,d=Math.min(l,c),m=Math.floor(d/ba)*ba;return Math.min(Math.max(m,Sl),1)},j3=({bounds:e,appState:t,fitToViewport:r=!1,viewportZoomFactor:o=.7})=>{let[n,i,a,l]=e,s=(n+a)/2,c=(i+l)/2,d,m,p;if(r){let u=a-n,h=l-i;d=Math.min(t.width/u,t.height/h)*Math.min(1,Math.max(o,.1)),d=Math.min(Math.max(d,Sl),Ug);let E=t.width;if(t.openSidebar){let T=document.querySelector(".sidebar")?.offsetWidth??0;E=document.documentElement.getAttribute("dir")==="rtl"?t.width+T:t.width-T}m=E/2*(1/d)-s,p=t.height/2*(1/d)-c}else{d=J8(e,{width:t.width,height:t.height});let u=F1({scenePoint:{x:s,y:c},viewportDimensions:{width:t.width,height:t.height},zoom:{value:d}});m=u.scrollX,p=u.scrollY}return{appState:{...t,scrollX:m,scrollY:p,zoom:{value:d}},storeAction:_.NONE}},wd=({targetElements:e,appState:t,fitToViewport:r,viewportZoomFactor:o})=>{let n=Ae(ye(e));return j3({bounds:n,appState:t,fitToViewport:r,viewportZoomFactor:o})},mJ=U({name:"zoomToFitSelectionInViewport",label:"labels.zoomToFitViewport",icon:hd,trackEvent:{category:"canvas"},perform:(e,t,r,o)=>{let n=o.scene.getSelectedElements(t);return wd({targetElements:n.length?n:e,appState:{...t,userToFollow:null},fitToViewport:!1})},keyTest:e=>e.code===Ee.TWO&&e.shiftKey&&!e.altKey&&!e[C.CTRL_OR_CMD]}),pJ=U({name:"zoomToFitSelection",label:"helpDialog.zoomToSelection",icon:hd,trackEvent:{category:"canvas"},perform:(e,t,r,o)=>{let n=o.scene.getSelectedElements(t);return wd({targetElements:n.length?n:e,appState:{...t,userToFollow:null},fitToViewport:!0})},keyTest:e=>e.code===Ee.THREE&&e.shiftKey&&!e.altKey&&!e[C.CTRL_OR_CMD]}),q3=U({name:"zoomToFit",label:"helpDialog.zoomToFit",icon:hd,viewMode:!0,trackEvent:{category:"canvas"},perform:(e,t)=>wd({targetElements:e,appState:{...t,userToFollow:null},fitToViewport:!1}),keyTest:e=>e.code===Ee.ONE&&e.shiftKey&&!e.altKey&&!e[C.CTRL_OR_CMD]}),$i=U({name:"toggleTheme",label:(e,t)=>t.theme===se.DARK?"buttons.lightMode":"buttons.darkMode",keywords:["toggle","dark","light","mode","theme"],icon:e=>e.theme===se.LIGHT?us:hs,viewMode:!0,trackEvent:{category:"canvas"},perform:(e,t,r)=>({appState:{...t,theme:r||(t.theme===se.LIGHT?se.DARK:se.LIGHT)},storeAction:_.NONE}),keyTest:e=>e.altKey&&e.shiftKey&&e.code===Ee.D,predicate:(e,t,r,o)=>!!o.props.UIOptions.canvasActions.toggleTheme}),uJ=U({name:"toggleEraserTool",label:"toolBar.eraser",trackEvent:{category:"toolbar"},perform:(e,t)=>{let r;return Pr(t)?r=tt(t,{...t.activeTool.lastActiveTool||{type:"selection"},lastActiveToolBeforeEraser:null}):r=tt(t,{type:"eraser",lastActiveToolBeforeEraser:t.activeTool}),{appState:{...t,selectedElementIds:{},selectedGroupIds:{},activeEmbeddable:null,activeTool:r},storeAction:_.CAPTURE}},keyTest:e=>e.key===C.E}),J3=U({name:"toggleHandTool",label:"toolBar.hand",paletteName:"Toggle hand tool",trackEvent:{category:"toolbar"},icon:ld,viewMode:!1,perform:(e,t,r,o)=>{let n;return Go(t)?n=tt(t,{...t.activeTool.lastActiveTool||{type:"selection"},lastActiveToolBeforeEraser:null}):(n=tt(t,{type:"hand",lastActiveToolBeforeEraser:t.activeTool}),$e(o.interactiveCanvas,Re.GRAB)),{appState:{...t,selectedElementIds:{},selectedGroupIds:{},activeEmbeddable:null,activeTool:n},storeAction:_.CAPTURE}},keyTest:e=>!e.altKey&&!e[C.CTRL_OR_CMD]&&e.key===C.H})});import{jsx as e7}from"react/jsx-runtime";var io,Q3=y(()=>{"use strict";f();be();xe();G();Dt();ne();q();Je();Ye();Kt();or();Eo();me();Vl();ze();io=U({name:"finalize",label:"",trackEvent:!1,perform:(e,t,r,o)=>{let{interactiveCanvas:n,focusContainer:i,scene:a}=o,l=a.getNonDeletedElementsMap();if(t.editingLinearElement){let{elementId:p,startBindingElement:u,endBindingElement:h}=t.editingLinearElement,E=Z.getElement(p,l);if(E)return Wt(E)&&dn(E,u,h,l),{elements:E.points.length<2||yo(E)?e.filter(x=>x.id!==E.id):void 0,appState:{...t,cursorButton:"up",editingLinearElement:null,selectedLinearElement:null},storeAction:_.CAPTURE}}let s=e,c=t.pendingImageElementId&&a.getElement(t.pendingImageElementId);c&&H(c,{isDeleted:!0},!1),window.document.activeElement instanceof HTMLElement&&i();let d=t.multiElement?t.multiElement:t.editingElement?.type==="freedraw"?t.editingElement:null;if(d){if(d.type!=="freedraw"&&t.lastPointerDownWith!=="touch"){let{points:u,lastCommittedPoint:h}=d;(!h||u[u.length-1]!==h)&&H(d,{points:d.points.slice(0,-1)})}yo(d)&&(s=s.filter(u=>u.id!==d.id));let p=br(d.points,t.zoom.value);if((d.type==="line"||d.type==="freedraw")&&p){let u=d.points,h=u[0];H(d,{points:u.map((E,x)=>x===u.length-1?[h[0],h[1]]:E)})}if(Wt(d)&&!p&&d.points.length>1){let[u,h]=Z.getPointAtIndexGlobalCoordinates(d,-1,X(e));wc(d,t,{x:u,y:h},o)}}(!t.activeTool.locked&&t.activeTool.type!=="freedraw"||!d)&&jr(n);let m;return t.activeTool.type==="eraser"?m=tt(t,{...t.activeTool.lastActiveTool||{type:"selection"},lastActiveToolBeforeEraser:null}):m=tt(t,{type:"selection"}),{elements:s,appState:{...t,cursorButton:"up",activeTool:(t.activeTool.locked||t.activeTool.type==="freedraw")&&d?t.activeTool:m,activeEmbeddable:null,draggingElement:null,multiElement:null,editingElement:null,startBoundElement:null,suggestedBindings:[],selectedElementIds:d&&!t.activeTool.locked&&t.activeTool.type!=="freedraw"?{...t.selectedElementIds,[d.id]:!0}:t.selectedElementIds,selectedLinearElement:d&&ce(d)?new Z(d):t.selectedLinearElement,pendingImageElementId:null},storeAction:_.CAPTURE}},keyTest:(e,t)=>e.key===C.ESCAPE&&(t.editingLinearElement!==null||!t.draggingElement&&t.multiElement===null)||(e.key===C.ESCAPE||e.key===C.ENTER)&&t.multiElement!==null,PanelComponent:({appState:e,updateData:t,data:r})=>e7(pe,{type:"button",icon:hb,title:b("buttons.done"),"aria-label":b("buttons.done"),onClick:t,visible:e.multiElement!=null,size:r?.size||"medium"})})});var eS=y(()=>{});var tS=y(()=>{});import{useState as t7}from"react";import{jsx as rS,jsxs as r7}from"react/jsx-runtime";var oS,nS=y(()=>{"use strict";f();eS();G();tS();we();be();oS=e=>{let{id:t}=Zt(),[r,o]=t7(e.value),n=a=>{e.ignoreFocus||rw(a.target);let l=a.target.value;l!==e.value&&e.onChange(l)},i=a=>{if(a.key===C.ENTER){if(a.preventDefault(),a.nativeEvent.isComposing||a.keyCode===229)return;a.currentTarget.blur()}};return r7("div",{className:"ProjectName",children:[rS("label",{className:"ProjectName-label",htmlFor:"filename",children:`${e.label}:`}),rS("input",{type:"text",className:"TextInput",onBlur:n,onKeyDown:i,id:`${t}-filename`,value:r,onChange:a=>o(a.target.value)})]})}});import{jsx as Td}from"react/jsx-runtime";var aS,iS,lS=y(()=>{"use strict";f();ri();q();Dt();W();aS=e=>{let t=e.title||(e.value===se.DARK?b("buttons.lightMode"):b("buttons.darkMode"));return Td(pe,{type:"icon",icon:e.value===se.LIGHT?iS.MOON:iS.SUN,title:t,"aria-label":t,onClick:()=>e.onChange(e.value===se.DARK?se.LIGHT:se.DARK),"data-testid":"toggle-dark-mode"})},iS={SUN:Td("svg",{width:"512",height:"512",className:"rtl-mirror",viewBox:"0 0 512 512",children:Td("path",{fill:"currentColor",d:"M256 160c-52.9 0-96 43.1-96 96s43.1 96 96 96 96-43.1 96-96-43.1-96-96-96zm246.4 80.5l-94.7-47.3 33.5-100.4c4.5-13.6-8.4-26.5-21.9-21.9l-100.4 33.5-47.4-94.8c-6.4-12.8-24.6-12.8-31 0l-47.3 94.7L92.7 70.8c-13.6-4.5-26.5 8.4-21.9 21.9l33.5 100.4-94.7 47.4c-12.8 6.4-12.8 24.6 0 31l94.7 47.3-33.5 100.5c-4.5 13.6 8.4 26.5 21.9 21.9l100.4-33.5 47.3 94.7c6.4 12.8 24.6 12.8 31 0l47.3-94.7 100.4 33.5c13.6 4.5 26.5-8.4 21.9-21.9l-33.5-100.4 94.7-47.3c13-6.5 13-24.7.2-31.1zm-155.9 106c-49.9 49.9-131.1 49.9-181 0-49.9-49.9-49.9-131.1 0-181 49.9-49.9 131.1-49.9 181 0 49.9 49.9 49.9 131.1 0 181z"})}),MOON:Td("svg",{width:"512",height:"512",className:"rtl-mirror",viewBox:"0 0 512 512",children:Td("path",{fill:"currentColor",d:"M283.211 512c78.962 0 151.079-35.925 198.857-94.792 7.068-8.708-.639-21.43-11.562-19.35-124.203 23.654-238.262-71.576-238.262-196.954 0-72.222 38.662-138.635 101.498-174.394 9.686-5.512 7.25-20.197-3.756-22.23A258.156 258.156 0 0 0 283.211 0c-141.309 0-256 114.511-256 256 0 141.309 114.511 256 256 256z"})})}});var il,al,Xi=y(()=>{"use strict";f();zi();W();xe();me();q();qe();ts();G();_r();Xn();qn();dr();_r();qn();il=(e,{selectedElementIds:t},r)=>{e=ye(e);let o=r&&Xe(e,{selectedElementIds:t}),n=null,i=o?ge(e,{selectedElementIds:t},{includeBoundTextElement:!0}):e;return o&&(i.length===1&&re(i[0])?(n=i[0],i=rs(e,n)):i.length>1&&(i=ge(e,{selectedElementIds:t},{includeBoundTextElement:!0,includeElementsInFrames:!0}))),{exportingFrame:n,exportedElements:rn(i)}},al=async({type:e,data:t,config:r})=>{let o=Object.assign({},r);if(o.padding=o.padding??Jo,o.fileHandle=o.fileHandle??null,o.exportingFrame=o.exportingFrame??null,o.name=o.name||km,t.elements.length===0)throw new Error(b("alerts.cannotExportEmptyCanvas"));if(e==="svg"||e==="clipboard-svg"){let i=es({data:{elements:t.elements,appState:{exportBackground:o.exportBackground,exportWithDarkMode:t.appState.exportWithDarkMode,viewBackgroundColor:t.appState.viewBackgroundColor,exportPadding:o.padding,exportScale:t.appState.exportScale,exportEmbedScene:t.appState.exportEmbedScene&&e==="svg"},files:t.files},config:{exportingFrame:o.exportingFrame}});if(e==="svg")return Xl(i.then(a=>new Blob([a.outerHTML],{type:te.svg})),{description:"Export to SVG",name:o.name,extension:t.appState.exportEmbedScene?"excalidraw.svg":"svg",fileHandle:o.fileHandle});if(e==="clipboard-svg"){let a=await i.then(l=>l.outerHTML);try{await Qn(a)}catch{throw new Error(b("errors.copyToSystemClipboardFailed"))}return}}let n=Bi({data:t,config:{canvasBackgroundColor:o.exportBackground?o.viewBackgroundColor:!1,padding:o.padding,theme:t.appState.exportWithDarkMode?"dark":"light",scale:t.appState.exportScale,fit:"none",exportingFrame:o.exportingFrame}});if(e==="png"){let i=jn(n);return t.appState.exportEmbedScene&&i.then(a=>Promise.resolve().then(()=>(jl(),Uc)).then(({encodePngMetadata:l})=>l({blob:a,metadata:Oi(t.elements,t.appState,t.files,"local")}))),Xl(i,{description:"Export to PNG",name:o.name,extension:"png",fileHandle:o.fileHandle})}else if(e==="clipboard")try{let i=jn(n);await qp(i)}catch(i){throw console.warn(i),i.name==="CANVAS_POSSIBLY_TOO_BIG"?new Error(b("canvasError.canvasTooBig")):Rn&&i.name==="TypeError"?new Error(`${b("alerts.couldNotCopyToClipboard")}
68
68
 
69
- ${b("hints.firefox_clipboard_write")}`):new Error(b("alerts.couldNotCopyToClipboard"))}else throw new Error("Unsupported export type")}});var sT,cT=v(()=>{"use strict";f();Bi();Bi();Co();sT=async(e,t,o,r)=>{let{exportBackground:n,viewBackgroundColor:i,fileHandle:a}=t,l=wf(a);if(!a||!bw(l))throw new Error("fileHandle should exist and should be of type svg or png when resaving");t={...t,exportEmbedScene:!0};let{exportedElements:s,exportingFrame:c}=$a(e,t,!1);return await Xa({type:l,data:{elements:s,appState:t,files:o},config:{exportBackground:n,viewBackgroundColor:i,name:r,fileHandle:a,exportingFrame:c}}),{fileHandle:a}}});var dT=v(()=>{});import j8 from"clsx";import{jsx as mT,jsxs as q8}from"react/jsx-runtime";var Za,Su=v(()=>{"use strict";f();ee();dT();Za=({children:e,checked:t,onChange:o,className:r})=>q8("div",{className:j8("Checkbox",r,{"is-checked":t}),onClick:n=>{o(!t,n),n.currentTarget.querySelector(".Checkbox-box").focus()},children:[mT("button",{className:"Checkbox-box",role:"checkbox","aria-checked":t,children:L1}),mT("div",{className:"Checkbox-label",children:e})]})});import{Fragment as J8,jsx as Jn,jsxs as Q8}from"react/jsx-runtime";var ku,pT,Au,Mu,sd,ps,ja,uT,cd=v(()=>{"use strict";f();ee();nT();Mt();Ni();lT();Bi();cT();X();ye();ue();je();Su();Yl();U();We();he();Co();Wn();jn();ku=H({name:"changeProjectName",label:"labels.fileTitle",trackEvent:!1,perform:(e,t,o)=>({appState:{...t,name:o},commitToHistory:!1}),PanelComponent:({appState:e,updateData:t,appProps:o,data:r,app:n})=>Jn(rT,{label:b("labels.fileTitle"),value:n.getName(),onChange:i=>t(i),ignoreFocus:r?.ignoreFocus??!1})}),pT=H({name:"changeExportScale",label:"imageExportDialog.scale",trackEvent:{category:"export",action:"scale"},perform:(e,t,o)=>({appState:{...t,exportScale:o},commitToHistory:!1}),PanelComponent:({elements:e,appState:t,updateData:o})=>{let r=be(e),i=Ye(r,t)?de(r,t):r,a=(l,s,c)=>{let[,,d,m]=fp(l).map(p=>Math.trunc(p*c));return[d+s*2,m+s*2]};return Jn(J8,{children:pl.map(l=>{let[s,c]=a(i,Kr,l),d=`${b("imageExportDialog.label.scale")} ${l}x (${s}x${c})`;return Jn(ce,{size:"small",type:"radio",icon:`${l}x`,name:"export-canvas-scale",title:d,"aria-label":d,id:"export-canvas-scale",checked:l===t.exportScale,onChange:()=>o(l)},l)})})}}),Au=H({name:"changeExportBackground",label:"imageExportDialog.label.withBackground",trackEvent:{category:"export",action:"toggleBackground"},perform:(e,t,o)=>({appState:{...t,exportBackground:o},commitToHistory:!1}),PanelComponent:({appState:e,updateData:t})=>Jn(Za,{checked:e.exportBackground,onChange:o=>t(o),children:b("imageExportDialog.label.withBackground")})}),Mu=H({name:"changeExportEmbedScene",label:"imageExportDialog.tooltip.embedScene",trackEvent:{category:"export",action:"embedScene"},perform:(e,t,o)=>({appState:{...t,exportEmbedScene:o},commitToHistory:!1}),PanelComponent:({appState:e,updateData:t})=>Q8(Za,{checked:e.exportEmbedScene,onChange:o=>t(o),children:[b("imageExportDialog.label.embedScene"),Jn(Xo,{label:b("imageExportDialog.tooltip.embedScene"),long:!0,children:Jn("div",{className:"excalidraw-tooltip-icon",children:O1})})]})}),sd=H({name:"saveToActiveFile",label:"buttons.save",icon:Li,trackEvent:{category:"export"},predicate:(e,t,o,r)=>!!r.props.UIOptions.canvasActions.saveToActiveFile&&!!t.fileHandle&&!t.viewModeEnabled,perform:async(e,t,o,r)=>{let n=!!t.fileHandle;try{let{fileHandle:i}=Ul(t.fileHandle)?await sT(e,t,r.files,r.getName()):await ip(e,t,r.files,r.getName());return{commitToHistory:!1,appState:{...t,fileHandle:i,toast:n?{message:i?.name?b("toast.fileSavedToFilename").replace("{filename}",`"${i.name}"`):b("toast.fileSaved")}:null}}}catch(i){return i?.name!=="AbortError"?console.error(i):console.warn(i),{commitToHistory:!1}}},keyTest:e=>e.key===I.S&&e[I.CTRL_OR_CMD]&&!e.shiftKey}),ps=H({name:"saveFileToDisk",label:"exportDialog.disk_title",icon:Li,viewMode:!0,trackEvent:{category:"export"},perform:async(e,t,o,r)=>{try{let{fileHandle:n}=await ip(e,{...t,fileHandle:null},r.files,r.getName());return{commitToHistory:!1,appState:{...t,openDialog:null,fileHandle:n,toast:{message:b("toast.fileSaved")}}}}catch(n){return n?.name!=="AbortError"?console.error(n):console.warn(n),{commitToHistory:!1}}},keyTest:e=>e.key===I.S&&e.shiftKey&&e[I.CTRL_OR_CMD],PanelComponent:({updateData:e})=>Jn(ce,{type:"button",icon:P1,title:b("buttons.saveAs"),"aria-label":b("buttons.saveAs"),showAriaLabel:_e().editor.isMobile,hidden:!Ti,onClick:()=>e(null),"data-testid":"save-as-button"})}),ja=H({name:"loadScene",label:"buttons.load",trackEvent:{category:"export"},predicate:(e,t,o,r)=>!!r.props.UIOptions.canvasActions.loadScene&&!t.viewModeEnabled,perform:async(e,t,o,r)=>{try{let{elements:n,appState:i,files:a}=await Sf(t,e);return{elements:n,appState:i,files:a,commitToHistory:!0}}catch(n){return n?.name==="AbortError"?(console.warn(n),!1):{elements:e,appState:{...t,errorMessage:n.message},files:r.files,commitToHistory:!1}}},keyTest:e=>e[I.CTRL_OR_CMD]&&e.key===I.O}),uT=H({name:"exportWithDarkMode",label:"imageExportDialog.label.darkMode",trackEvent:{category:"export",action:"toggleTheme"},perform:(e,t,o)=>({appState:{...t,exportWithDarkMode:o},commitToHistory:!1}),PanelComponent:({appState:e,updateData:t})=>Jn("div",{style:{display:"flex",justifyContent:"flex-end",marginTop:"-45px",marginBottom:"10px"},children:Jn(aT,{value:e.exportWithDarkMode?ie.DARK:ie.LIGHT,onChange:o=>{t(o===ie.DARK)},title:b("imageExportDialog.label.darkMode")})})})});var gT,Lu,_u,hT=v(()=>{"use strict";f();he();ue();X();je();Ze();U();pt();se();We();ee();gT="{}",Lu=H({name:"copyStyles",label:"labels.copyStyles",icon:su,trackEvent:{category:"element"},perform:(e,t,o,r)=>{let n=[],i=e.find(a=>t.selectedElementIds[a.id]);if(n.push(i),i&&Eo(i)){let a=me(i,r.scene.getNonDeletedElementsMap());n.push(a)}return i&&(gT=JSON.stringify(n)),{appState:{...t,toast:{message:b("toast.copyStyles")}},commitToHistory:!1}},keyTest:e=>e[I.CTRL_OR_CMD]&&e.altKey&&e.code===fe.C}),_u=H({name:"pasteStyles",label:"labels.pasteStyles",icon:su,trackEvent:{category:"element"},perform:(e,t,o,r)=>{let n=JSON.parse(gT),i=n[0],a=n[1];if(!Zs(i))return{elements:e,commitToHistory:!1};let l=de(e,t,{includeBoundTextElement:!0}),s=l.map(c=>c.id);return{elements:e.map(c=>{if(s.includes(c.id)){let d=i;if(W(c)&&c.containerId&&(d=a),!d)return c;let m=ae(c,{backgroundColor:d?.backgroundColor,strokeWidth:d?.strokeWidth,strokeColor:d?.strokeColor,strokeStyle:d?.strokeStyle,fillStyle:d?.fillStyle,opacity:d?.opacity,roughness:d?.roughness,roundness:d.roundness?_y(d.roundness.type,c)?d.roundness:Py(c):null});if(W(m)){let p=d.fontSize||Rt,u=d.fontFamily||qt;m=ae(m,{fontSize:p,fontFamily:u,textAlign:d.textAlign||li,lineHeight:d.lineHeight||Oo(u)});let g=null;m.containerId&&(g=l.find(x=>W(m)&&x.id===m.containerId)||null),eo(m,g,r.scene.getNonDeletedElementsMap())}return m.type==="arrow"&&ke(d)&&(m=ae(m,{startArrowhead:d.startArrowhead,endArrowhead:d.endArrowhead})),Q(c)&&(m=ae(m,{roundness:null,backgroundColor:"transparent"})),m}return c}),commitToHistory:!0}},keyTest:e=>e[I.CTRL_OR_CMD]&&e.altKey&&e.code===fe.V})});import{jsx as xT}from"react/jsx-runtime";var fT,bT,Fi,ET=v(()=>{"use strict";f();ee();Mt();X();he();je();ue();fT=H({name:"toggleCanvasMenu",label:"buttons.menu",trackEvent:{category:"menu"},perform:(e,t)=>({appState:{...t,openMenu:t.openMenu==="canvas"?null:"canvas"},commitToHistory:!1}),PanelComponent:({appState:e,updateData:t})=>xT(ce,{type:"button",icon:zc,"aria-label":b("buttons.menu"),onClick:t,selected:e.openMenu==="canvas"})}),bT=H({name:"toggleEditMenu",label:"buttons.edit",trackEvent:{category:"menu"},perform:(e,t)=>({appState:{...t,openMenu:t.openMenu==="shape"?null:"shape"},commitToHistory:!1}),PanelComponent:({elements:e,appState:t,updateData:o})=>xT(ce,{visible:Na(t,be(e)),type:"button",icon:D1,"aria-label":b("buttons.edit"),onClick:o,selected:t.openMenu==="shape"})}),Fi=H({name:"toggleShortcuts",label:"welcomeScreen.defaults.helpHint",icon:k1,viewMode:!0,trackEvent:{category:"menu",action:"toggleHelpDialog"},perform:(e,t,o,{focusContainer:r})=>(t.openDialog?.name==="help"&&r(),{appState:{...t,openDialog:t.openDialog?.name==="help"?null:{name:"help"}},commitToHistory:!1}),keyTest:e=>e.key===I.QUESTION_MARK})});import{jsx as us}from"react/jsx-runtime";var e7,yT,Pu,Du,wT=v(()=>{"use strict";f();ue();X();G();je();ee();Ze();We();Ho();he();Sr();Mt();se();ao();e7=e=>{if(e.length>=2){let t=e[0].groupIds;for(let o of t)if(e.reduce((r,n)=>r&&Ta(n,o),!0))return!0}return!1},yT=(e,t,o)=>{let r=o.scene.getSelectedElements({selectedElementIds:t.selectedElementIds,includeBoundTextElement:!0});return r.length>=2&&!e7(r)},Pu=H({name:"group",label:"labels.group",icon:e=>us(ou,{theme:e.theme}),trackEvent:{category:"element"},perform:(e,t,o,r)=>{let n=r.scene.getSelectedElements({selectedElementIds:t.selectedElementIds,includeBoundTextElement:!0});if(n.length<2)return{appState:t,elements:e,commitToHistory:!1};let i=Fn(t);if(i.length===1){let x=i[0],E=new Set(ot(e,x).map(w=>w.id)),y=new Set(n.map(w=>w.id));if(new Set([...Array.from(E),...Array.from(y)]).size===E.size)return{appState:t,elements:e,commitToHistory:!1}}let a=[...e];new Set(n.map(x=>x.frameId)).size>1&&cv(n).forEach((E,y)=>{Ql(E,r.scene.getNonDeletedElementsMap())});let s=Bt(),c=re(n);a=a.map(x=>c.get(x.id)?ae(x,{groupIds:W2(x.groupIds,s,t.editingGroupId)}):x);let d=ot(a,s),m=d[d.length-1],p=a.lastIndexOf(m),u=a.slice(p+1);return a=[...a.slice(0,p).filter(x=>!Ta(x,s)),...d,...u],{appState:{...t,...cf(s,{...t,selectedGroupIds:{}},be(a))},elements:a,commitToHistory:!0}},predicate:(e,t,o,r)=>yT(e,t,r),keyTest:e=>!e.shiftKey&&e[I.CTRL_OR_CMD]&&e.key===I.G,PanelComponent:({elements:e,appState:t,updateData:o,app:r})=>us(ce,{hidden:!yT(e,t,r),type:"button",icon:us(ou,{theme:t.theme}),onClick:()=>o(null),title:`${b("labels.group")} \u2014 ${N("CtrlOrCmd+G")}`,"aria-label":b("labels.group"),visible:Ye(be(e),t)})}),Du=H({name:"ungroup",label:"labels.ungroup",icon:e=>us(ru,{theme:e.theme}),trackEvent:{category:"element"},perform:(e,t,o,r)=>{let n=Fn(t),i=re(e);if(n.length===0)return{appState:t,elements:e,commitToHistory:!1};let a=[...e],l=[];a=a.map(p=>{ze(p)&&l.push(p.id);let u=V2(p.groupIds,t.selectedGroupIds);return u.length===p.groupIds.length?p:ae(p,{groupIds:u})});let s=to(t,be(a),t,null),c=r.scene.getSelectedElements(t),d=new Set(c.filter(p=>p.frameId).map(p=>p.frameId));return Dc(e).filter(p=>d.has(p.id)).forEach(p=>{p&&(a=Lp(a,Jl(a,p,t,i),p,r))}),s.selectedElementIds=Object.entries(s.selectedElementIds).reduce((p,[u,g])=>(g&&!l.includes(u)&&(p[u]=!0),p),{}),{appState:{...t,...s},elements:a,commitToHistory:!0}},keyTest:e=>e.shiftKey&&e[I.CTRL_OR_CMD]&&e.key===I.G.toUpperCase(),predicate:(e,t)=>Fn(t).length>0,PanelComponent:({elements:e,appState:t,updateData:o})=>us(ce,{type:"button",hidden:Fn(t).length===0,icon:us(ru,{theme:t.theme}),onClick:()=>o(null),title:`${b("labels.ungroup")} \u2014 ${N("CtrlOrCmd+Shift+G")}`,"aria-label":b("labels.ungroup"),visible:Ye(be(e),t)})})});var Ru,sx=v(()=>{"use strict";f();Ru=(e,t,o,r,n,i,a)=>{e.beginPath(),e.moveTo(t+i,o),e.lineTo(t+r-i,o),e.quadraticCurveTo(t+r,o,t+r,o+i),e.lineTo(t+r,o+n-i),e.quadraticCurveTo(t+r,o+n,t+r-i,o+n),e.lineTo(t+i,o+n),e.quadraticCurveTo(t,o+n,t,o+n-i),e.lineTo(t,o+i),e.quadraticCurveTo(t,o,t+i,o),e.closePath(),e.fill(),a&&(e.strokeStyle=a),e.stroke()}});var vT=v(()=>{"use strict";f()});function t7(e){let t=0;if(e.length===0)return t;for(let o=0;o<e.length;o++){let r=e.charCodeAt(o);t=(t<<5)-t+r}return t}var qa,TT,CT,dd=v(()=>{"use strict";f();U();sx();vT();qa=(e,t)=>`hsl(${Math.abs(t7(t?.id||e))%37*10}, 100%, 83%)`,TT=e=>{let t=e?.trim()?.codePointAt(0);return(t?String.fromCodePoint(t):"?").toUpperCase()},CT=({context:e,renderConfig:t,appState:o,normalizedWidth:r,normalizedHeight:n})=>{for(let[i,a]of t.remotePointerViewportCoords){let{x:l,y:s}=a,c=o.collaborators.get(i);l-=o.offsetLeft,s-=o.offsetTop;let d=11,m=14,p=l<0||l>r-d||s<0||s>n-m;l=Math.max(l,0),l=Math.min(l,r-d),s=Math.max(s,0),s=Math.min(s,n-m);let u=qa(i,c);e.save(),e.strokeStyle=u,e.fillStyle=u;let g=t.remotePointerUserStates.get(i),x=p||g==="idle"||g==="away";x&&(e.globalAlpha=.3),t.remotePointerButton.get(i)==="down"&&(e.beginPath(),e.arc(l,s,15,0,2*Math.PI,!1),e.lineWidth=3,e.strokeStyle="#ffffff88",e.stroke(),e.closePath(),e.beginPath(),e.arc(l,s,15,0,2*Math.PI,!1),e.lineWidth=1,e.strokeStyle=u,e.stroke(),e.closePath());let E=o.theme===ie.DARK?"#2f6330":X0,y=c?.isSpeaking;y&&(e.fillStyle=E,e.strokeStyle=E,e.lineWidth=10,e.lineJoin="round",e.beginPath(),e.moveTo(l,s),e.lineTo(l+0,s+14),e.lineTo(l+4,s+9),e.lineTo(l+11,s+8),e.closePath(),e.stroke(),e.fill()),e.fillStyle=Ht,e.strokeStyle=Ht,e.lineWidth=6,e.lineJoin="round",e.beginPath(),e.moveTo(l,s),e.lineTo(l+0,s+14),e.lineTo(l+4,s+9),e.lineTo(l+11,s+8),e.closePath(),e.stroke(),e.fill(),e.fillStyle=u,e.strokeStyle=u,e.lineWidth=2,e.lineJoin="round",e.beginPath(),x?(e.moveTo(l-1,s-1),e.lineTo(l-1,s+15),e.lineTo(l+5,s+10),e.lineTo(l+12,s+9),e.closePath(),e.fill()):(e.moveTo(l,s),e.lineTo(l+0,s+14),e.lineTo(l+4,s+9),e.lineTo(l+11,s+8),e.closePath(),e.fill(),e.stroke());let T=t.remotePointerUsernames.get(i)||"";if(!p&&T){e.font="600 12px sans-serif";let w=(y?l+0:l)+d/2,S=(y?s+0:s)+m+2,M=5,k=3,R=e.measureText(T),P=R.actualBoundingBoxDescent+R.actualBoundingBoxAscent,F=Math.max(P,12),D=w-1,L=S-1,A=R.width+2+M*2+2,B=F+2+k*2+2;if(e.roundRect?(e.beginPath(),e.roundRect(D,L,A,B,8),e.fillStyle=u,e.fill(),e.strokeStyle=Ht,e.stroke(),y&&(e.beginPath(),e.roundRect(D-2,L-2,A+4,B+4,8),e.strokeStyle=E,e.stroke())):Ru(e,D,L,A,B,8,Ht),e.fillStyle=si,e.fillText(T,w+M+1,S+k+R.actualBoundingBoxAscent+Math.floor((F-P)/2)+2),y){e.fillStyle=E;let j=8,Y=8,oe=5;e.fillRect(D+A+Y,L+(B/2-j/2),2,j),e.fillRect(D+A+Y+oe,L+(B/2-j*2/2),2,j*2),e.fillRect(D+A+Y+oe*2,L+(B/2-j/2),2,j)}}e.restore(),e.closePath()}}});var IT=v(()=>{});import{useState as o7}from"react";import r7 from"clsx";import{jsx as ST}from"react/jsx-runtime";var cx,kT=v(()=>{"use strict";f();IT();dd();cx=({color:e,onClick:t,name:o,src:r,className:n})=>{let i=TT(o),[a,l]=o7(!1),s=!a&&r,c=s?void 0:{background:e};return ST("div",{className:r7("Avatar",n),style:c,onClick:t,children:s?ST("img",{className:"Avatar-img",src:r,alt:i,referrerPolicy:"no-referrer",onError:()=>l(!0)}):i})}});import n7 from"clsx";import{jsx as pn,jsxs as Nu}from"react/jsx-runtime";var AT,MT=v(()=>{"use strict";f();dd();kT();ee();X();je();AT=H({name:"goToCollaborator",label:"Go to a collaborator",viewMode:!0,trackEvent:{category:"collab"},perform:(e,t,o)=>!o.socketId||t.userToFollow?.socketId===o.socketId||o.isCurrentUser?{appState:{...t,userToFollow:null},commitToHistory:!1}:{appState:{...t,userToFollow:{socketId:o.socketId,username:o.username||""},openMenu:t.openMenu==="canvas"?null:t.openMenu},commitToHistory:!1},PanelComponent:({updateData:e,data:t,appState:o})=>{let{socketId:r,collaborator:n,withName:i,isBeingFollowed:a}=t,l=qa(r,n),s=n7({"is-followed":a,"is-current-user":n.isCurrentUser===!0,"is-speaking":n.isSpeaking,"is-in-call":n.isInCall,"is-muted":n.isMuted}),c=n.isInCall?n.isSpeaking?Nu("div",{className:"UserList__collaborator-status-icon-speaking-indicator",title:b("userList.hint.isSpeaking"),children:[pn("div",{}),pn("div",{}),pn("div",{})]}):n.isMuted?pn("div",{className:"UserList__collaborator-status-icon-microphone-muted",title:b("userList.hint.micMuted"),children:_b}):pn("div",{title:b("userList.hint.inCall"),children:Lb}):null;return i?Nu("div",{className:`dropdown-menu-item dropdown-menu-item-base UserList__collaborator ${s}`,style:{"--avatar-size":"1.5rem"},onClick:()=>e(n),children:[pn(cx,{color:l,onClick:()=>{},name:n.username||"",src:n.avatarUrl,className:s}),pn("div",{className:"UserList__collaborator-name",children:n.username}),Nu("div",{className:"UserList__collaborator-status-icons","aria-hidden":!0,children:[a&&pn("div",{className:"UserList__collaborator-status-icon-is-followed",title:b("userList.hint.followStatus"),children:Va}),c]})]}):Nu("div",{className:`UserList__collaborator UserList__collaborator--avatar-only ${s}`,children:[pn(cx,{color:l,onClick:()=>{e(n)},name:n.username||"",src:n.avatarUrl,className:s}),c&&pn("div",{className:"UserList__collaborator-status-icon",children:c})]})}})});var Ou,LT=v(()=>{"use strict";f();je();on();Sr();X();U();Ou=H({name:"addToLibrary",trackEvent:{category:"element"},perform:(e,t,o,r)=>{let n=r.scene.getSelectedElements({selectedElementIds:t.selectedElementIds,includeBoundTextElement:!0,includeElementsInFrames:!0});for(let i of mm)if(n.some(a=>a.type===i))return{commitToHistory:!1,appState:{...t,errorMessage:b(`errors.libraryElementTypeError.${i}`)}};return r.library.getLatestLibrary().then(i=>r.library.setLibrary([{id:Bt(),status:"unpublished",elements:n.map(zn),created:Date.now()},...i])).then(()=>({commitToHistory:!1,appState:{...t,toast:{message:b("toast.addedToLibrary")}}})).catch(i=>({commitToHistory:!1,appState:{...t,errorMessage:i.message}}))},label:"labels.addToLibrary"})});var _T,i7,PT=v(()=>{"use strict";f();Ze();bt();Ho();_T=(e,t,o)=>{let r=Ca(e,t),n=vo(e);return r.flatMap(i=>{let a=i7(i,n,o);return i.map(l=>ae(l,{x:l.x+a.x,y:l.y+a.y}))})},i7=(e,t,{axis:o,position:r})=>{let n=vo(e),[i,a]=o==="x"?["minX","maxX"]:["minY","maxY"],l={x:0,y:0};return r==="start"?{...l,[o]:t[i]-n[i]}:r==="end"?{...l,[o]:t[a]-n[a]}:{...l,[o]:(t[i]+t[a])/2-(n[i]+n[a])/2}}});import{jsx as hs}from"react/jsx-runtime";var fr,gs,DT,RT,NT,OT,BT,FT,HT=v(()=>{"use strict";f();PT();ee();Mt();he();se();ao();X();ue();We();G();je();fr=(e,t,o,r)=>{let n=r.scene.getSelectedElements(t);return n.length>1&&!n.some(i=>Q(i))},gs=(e,t,o,r)=>{let n=o.scene.getSelectedElements(t),i=re(e),a=_T(n,i,r),l=re(a);return ln(e.map(s=>l.get(s.id)||s),t,o)},DT=H({name:"alignTop",label:"labels.alignTop",icon:jp,trackEvent:{category:"element"},predicate:fr,perform:(e,t,o,r)=>({appState:t,elements:gs(e,t,r,{position:"start",axis:"y"}),commitToHistory:!0}),keyTest:e=>e[I.CTRL_OR_CMD]&&e.shiftKey&&e.key===I.ARROW_UP,PanelComponent:({elements:e,appState:t,updateData:o,app:r})=>hs(ce,{hidden:!fr(e,t,null,r),type:"button",icon:jp,onClick:()=>o(null),title:`${b("labels.alignTop")} \u2014 ${N("CtrlOrCmd+Shift+Up")}`,"aria-label":b("labels.alignTop"),visible:Ye(be(e),t)})}),RT=H({name:"alignBottom",label:"labels.alignBottom",icon:qp,trackEvent:{category:"element"},predicate:fr,perform:(e,t,o,r)=>({appState:t,elements:gs(e,t,r,{position:"end",axis:"y"}),commitToHistory:!0}),keyTest:e=>e[I.CTRL_OR_CMD]&&e.shiftKey&&e.key===I.ARROW_DOWN,PanelComponent:({elements:e,appState:t,updateData:o,app:r})=>hs(ce,{hidden:!fr(e,t,null,r),type:"button",icon:qp,onClick:()=>o(null),title:`${b("labels.alignBottom")} \u2014 ${N("CtrlOrCmd+Shift+Down")}`,"aria-label":b("labels.alignBottom"),visible:Ye(be(e),t)})}),NT=H({name:"alignLeft",label:"labels.alignLeft",icon:Jp,trackEvent:{category:"element"},predicate:fr,perform:(e,t,o,r)=>({appState:t,elements:gs(e,t,r,{position:"start",axis:"x"}),commitToHistory:!0}),keyTest:e=>e[I.CTRL_OR_CMD]&&e.shiftKey&&e.key===I.ARROW_LEFT,PanelComponent:({elements:e,appState:t,updateData:o,app:r})=>hs(ce,{hidden:!fr(e,t,null,r),type:"button",icon:Jp,onClick:()=>o(null),title:`${b("labels.alignLeft")} \u2014 ${N("CtrlOrCmd+Shift+Left")}`,"aria-label":b("labels.alignLeft"),visible:Ye(be(e),t)})}),OT=H({name:"alignRight",label:"labels.alignRight",icon:Qp,trackEvent:{category:"element"},predicate:fr,perform:(e,t,o,r)=>({appState:t,elements:gs(e,t,r,{position:"end",axis:"x"}),commitToHistory:!0}),keyTest:e=>e[I.CTRL_OR_CMD]&&e.shiftKey&&e.key===I.ARROW_RIGHT,PanelComponent:({elements:e,appState:t,updateData:o,app:r})=>hs(ce,{hidden:!fr(e,t,null,r),type:"button",icon:Qp,onClick:()=>o(null),title:`${b("labels.alignRight")} \u2014 ${N("CtrlOrCmd+Shift+Right")}`,"aria-label":b("labels.alignRight"),visible:Ye(be(e),t)})}),BT=H({name:"alignVerticallyCentered",label:"labels.centerVertically",icon:eu,trackEvent:{category:"element"},predicate:fr,perform:(e,t,o,r)=>({appState:t,elements:gs(e,t,r,{position:"center",axis:"y"}),commitToHistory:!0}),PanelComponent:({elements:e,appState:t,updateData:o,app:r})=>hs(ce,{hidden:!fr(e,t,null,r),type:"button",icon:eu,onClick:()=>o(null),title:b("labels.centerVertically"),"aria-label":b("labels.centerVertically"),visible:Ye(be(e),t)})}),FT=H({name:"alignHorizontallyCentered",label:"labels.centerHorizontally",icon:tu,trackEvent:{category:"element"},predicate:fr,perform:(e,t,o,r)=>({appState:t,elements:gs(e,t,r,{position:"center",axis:"x"}),commitToHistory:!0}),PanelComponent:({elements:e,appState:t,updateData:o,app:r})=>hs(ce,{hidden:!fr(e,t,null,r),type:"button",icon:tu,onClick:()=>o(null),title:b("labels.centerHorizontally"),"aria-label":b("labels.centerHorizontally"),visible:Ye(be(e),t)})})});var zT,GT=v(()=>{"use strict";f();Ze();Ho();bt();zT=(e,t,o)=>{let[r,n,i,a]=o.axis==="x"?["minX","midX","maxX","width"]:["minY","midY","maxY","height"],l=vo(e),s=Ca(e,t).map(p=>[p,vo(p)]).sort((p,u)=>p[1][n]-u[1][n]),c=0;for(let p of s)c+=p[1][a];let d=(l[a]-c)/(s.length-1);if(d<0){let p=s.findIndex(E=>E[1][r]===l[r]),u=s.findIndex(E=>E[1][i]===l[i]),g=(s[u][1][n]-s[p][1][n])/(s.length-1),x=s[p][1][n];return s.flatMap(([E,y],T)=>{let w={x:0,y:0};return T!==p&&T!==u&&(x+=g,w[o.axis]=x-y[n]),E.map(S=>ae(S,{x:S.x+w.x,y:S.y+w.y}))})}let m=l[r];return s.flatMap(([p,u])=>{let g={x:0,y:0};return g[o.axis]=m-u[r],m+=d,m+=u[a],p.map(x=>ae(x,{x:x.x+g.x,y:x.y+g.y}))})}});import{jsx as KT}from"react/jsx-runtime";var UT,WT,VT,YT,$T=v(()=>{"use strict";f();ee();Mt();GT();he();se();ao();X();ue();We();G();je();UT=(e,t)=>{let o=t.scene.getSelectedElements(e);return o.length>1&&!o.some(r=>Q(r))},WT=(e,t,o,r)=>{let n=o.scene.getSelectedElements(t),i=zT(n,o.scene.getNonDeletedElementsMap(),r),a=re(i);return ln(e.map(l=>a.get(l.id)||l),t,o)},VT=H({name:"distributeHorizontally",label:"labels.distributeHorizontally",trackEvent:{category:"element"},perform:(e,t,o,r)=>({appState:t,elements:WT(e,t,r,{space:"between",axis:"x"}),commitToHistory:!0}),keyTest:e=>!e[I.CTRL_OR_CMD]&&e.altKey&&e.code===fe.H,PanelComponent:({elements:e,appState:t,updateData:o,app:r})=>KT(ce,{hidden:!UT(t,r),type:"button",icon:F1,onClick:()=>o(null),title:`${b("labels.distributeHorizontally")} \u2014 ${N("Alt+H")}`,"aria-label":b("labels.distributeHorizontally"),visible:Ye(be(e),t)})}),YT=H({name:"distributeVertically",label:"labels.distributeVertically",trackEvent:{category:"element"},perform:(e,t,o,r)=>({appState:t,elements:WT(e,t,r,{space:"between",axis:"y"}),commitToHistory:!0}),keyTest:e=>!e[I.CTRL_OR_CMD]&&e.altKey&&e.code===fe.V,PanelComponent:({elements:e,appState:t,updateData:o,app:r})=>KT(ce,{hidden:!UT(t,r),type:"button",icon:H1,onClick:()=>o(null),title:`${b("labels.distributeVertically")} \u2014 ${N("Alt+V")}`,"aria-label":b("labels.distributeVertically"),visible:Ye(be(e),t)})})});var Bu,Fu,XT,a7,ZT=v(()=>{"use strict";f();je();We();he();Jf();G();ue();bt();_r();ao();ee();Bu=H({name:"flipHorizontal",label:"labels.flipHorizontal",icon:Nb,trackEvent:{category:"element"},perform:(e,t,o,r)=>({elements:ln(XT(e,r.scene.getNonDeletedElementsMap(),t,"horizontal"),t,r),appState:t,commitToHistory:!0}),keyTest:e=>e.shiftKey&&e.code===fe.H}),Fu=H({name:"flipVertical",label:"labels.flipVertical",icon:Rb,trackEvent:{category:"element"},perform:(e,t,o,r)=>({elements:ln(XT(e,r.scene.getNonDeletedElementsMap(),t,"vertical"),t,r),appState:t,commitToHistory:!0}),keyTest:e=>e.shiftKey&&e.code===fe.V&&!e[I.CTRL_OR_CMD]}),XT=(e,t,o,r)=>{let n=de(be(e),o,{includeBoundTextElement:!0,includeElementsInFrames:!0}),i=a7(n,e,t,o,r),a=re(i);return e.map(l=>a.get(l.id)||l)},a7=(e,t,o,r,n)=>{let{minX:i,minY:a,maxX:l,maxY:s}=vo(e);return Zf(o,e,o,"nw",!0,n==="horizontal"?l:i,n==="horizontal"?a:s),Qr(r)?mc(e,t,o):uc(e,o),e}});var Ja,dx,md,pd,ud,gd,mx=v(()=>{"use strict";f();ue();je();Ai();Ub();Bi();he();Bi();X();U();ee();Ja=H({name:"copy",label:"labels.copy",icon:ts,trackEvent:{category:"element"},perform:async(e,t,o,r)=>{let n=r.scene.getSelectedElements({selectedElementIds:t.selectedElementIds,includeBoundTextElement:!0,includeElementsInFrames:!0});try{await Tp(n,r.files,o)}catch(i){return{commitToHistory:!1,appState:{...t,errorMessage:i.message}}}return{commitToHistory:!1}},keyTest:void 0}),dx=H({name:"paste",label:"labels.paste",trackEvent:{category:"element"},perform:async(e,t,o,r)=>{let n;try{n=await Xw()}catch(i){return i.name==="AbortError"||i.name==="NotAllowedError"?!1:(console.error(`actionPaste ${i.name}: ${i.message}`),Sn?{commitToHistory:!1,appState:{...t,errorMessage:b("hints.firefox_clipboard_write")}}:{commitToHistory:!1,appState:{...t,errorMessage:b("errors.asyncPasteFailedOnRead")}})}try{r.pasteFromClipboard(Kw({types:n}))}catch(i){return console.error(i),{commitToHistory:!1,appState:{...t,errorMessage:b("errors.asyncPasteFailedOnParse")}}}return{commitToHistory:!1}},keyTest:void 0}),md=H({name:"cut",label:"labels.cut",icon:yb,trackEvent:{category:"element"},perform:(e,t,o,r)=>(Ja.perform(e,t,o,r),as.perform(e,t,null,r)),keyTest:e=>e[I.CTRL_OR_CMD]&&e.key===I.X}),pd=H({name:"copyAsSvg",label:"labels.copyAsSvg",icon:Ob,trackEvent:{category:"element"},perform:async(e,t,o,r)=>{if(!r.canvas)return{commitToHistory:!1};let{exportedElements:n,exportingFrame:i}=$a(e,t,!0);try{return await Xa({type:"clipboard-svg",data:{elements:n,appState:t,files:r.files},config:{...t,exportingFrame:i,name:r.getName()}}),{commitToHistory:!1}}catch(a){return console.error(a),{appState:{...t,errorMessage:a.message},commitToHistory:!1}}},predicate:e=>vp&&e.length>0,keywords:["svg","clipboard","copy"]}),ud=H({name:"copyAsPng",label:"labels.copyAsPng",icon:Bb,trackEvent:{category:"element"},perform:async(e,t,o,r)=>{if(!r.canvas)return{commitToHistory:!1};let n=r.scene.getSelectedElements({selectedElementIds:t.selectedElementIds,includeBoundTextElement:!0,includeElementsInFrames:!0}),{exportedElements:i,exportingFrame:a}=$a(e,t,!0);try{return await Xa({type:"clipboard",data:{elements:i,appState:t,files:r.files},config:{...t,exportingFrame:a,name:t.name||r.getName()}}),{appState:{...t,toast:{message:b("toast.copyToClipboardAsPng",{exportSelection:n.length?b("toast.selection"):b("toast.canvas"),exportColorScheme:t.exportWithDarkMode?b("buttons.darkMode"):b("buttons.lightMode")})}},commitToHistory:!1}}catch(l){return console.error(l),{appState:{...t,errorMessage:l.message},commitToHistory:!1}}},predicate:e=>jl&&e.length>0,keyTest:e=>e.code===fe.C&&e.altKey&&e.shiftKey,keywords:["png","clipboard","copy"]}),gd=H({name:"copyText",label:"labels.copyText",trackEvent:{category:"element"},perform:(e,t,o,r)=>{let i=r.scene.getSelectedElements({selectedElementIds:t.selectedElementIds,includeBoundTextElement:!0}).reduce((a,l)=>(W(l)&&a.push(l.text),a),[]).join(`
69
+ ${b("hints.firefox_clipboard_write")}`):new Error(b("alerts.couldNotCopyToClipboard"))}else throw new Error("Unsupported export type")}});var sS,cS=y(()=>{"use strict";f();Xi();Xi();_r();sS=async(e,t,r,o)=>{let{exportBackground:n,viewBackgroundColor:i,fileHandle:a}=t,l=Jf(a);if(!a||!iv(l))throw new Error("fileHandle should exist and should be of type svg or png when resaving");t={...t,exportEmbedScene:!0};let{exportedElements:s,exportingFrame:c}=il(e,t,!1);return await al({type:l,data:{elements:s,appState:t,files:r},config:{exportBackground:n,viewBackgroundColor:i,name:o,fileHandle:a,exportingFrame:c}}),{fileHandle:a}}});var dS=y(()=>{});import o7 from"clsx";import{jsx as mS,jsxs as n7}from"react/jsx-runtime";var ll,eh=y(()=>{"use strict";f();ne();dS();ll=({children:e,checked:t,onChange:r,className:o})=>n7("div",{className:o7("Checkbox",o,{"is-checked":t}),onClick:n=>{r(!t,n),n.currentTarget.querySelector(".Checkbox-box").focus()},children:[mS("button",{className:"Checkbox-box",role:"checkbox","aria-checked":t,children:cb}),mS("div",{className:"Checkbox-label",children:e})]})});import{Fragment as i7,jsx as ni,jsxs as a7}from"react/jsx-runtime";var th,pS,rh,oh,Sd,Ts,sl,uS,Cd=y(()=>{"use strict";f();ne();nS();Dt();Ki();lS();Xi();cS();q();we();be();Je();eh();ts();W();qe();xe();_r();Xn();ri();ze();th=U({name:"changeProjectName",label:"labels.fileTitle",trackEvent:!1,perform:(e,t,r)=>({appState:{...t,name:r},storeAction:_.NONE}),PanelComponent:({appState:e,updateData:t,appProps:r,data:o,app:n})=>ni(oS,{label:b("labels.fileTitle"),value:n.getName(),onChange:i=>t(i),ignoreFocus:o?.ignoreFocus??!1})}),pS=U({name:"changeExportScale",label:"imageExportDialog.scale",trackEvent:{category:"export",action:"scale"},perform:(e,t,r)=>({appState:{...t,exportScale:r},storeAction:_.NONE}),PanelComponent:({elements:e,appState:t,updateData:r})=>{let o=ye(e),i=Xe(o,t)?ge(o,t):o,a=(l,s,c)=>{let[,,d,m]=Gp(l).map(p=>Math.trunc(p*c));return[d+s*2,m+s*2]};return ni(i7,{children:Al.map(l=>{let[s,c]=a(i,Jo,l),d=`${b("imageExportDialog.label.scale")} ${l}x (${s}x${c})`;return ni(pe,{size:"small",type:"radio",icon:`${l}x`,name:"export-canvas-scale",title:d,"aria-label":d,id:"export-canvas-scale",checked:l===t.exportScale,onChange:()=>r(l)},l)})})}}),rh=U({name:"changeExportBackground",label:"imageExportDialog.label.withBackground",trackEvent:{category:"export",action:"toggleBackground"},perform:(e,t,r)=>({appState:{...t,exportBackground:r},storeAction:_.NONE}),PanelComponent:({appState:e,updateData:t})=>ni(ll,{checked:e.exportBackground,onChange:r=>t(r),children:b("imageExportDialog.label.withBackground")})}),oh=U({name:"changeExportEmbedScene",label:"imageExportDialog.tooltip.embedScene",trackEvent:{category:"export",action:"embedScene"},perform:(e,t,r)=>({appState:{...t,exportEmbedScene:r},storeAction:_.NONE}),PanelComponent:({appState:e,updateData:t})=>a7(ll,{checked:e.exportEmbedScene,onChange:r=>t(r),children:[b("imageExportDialog.label.embedScene"),ni(no,{label:b("imageExportDialog.tooltip.embedScene"),long:!0,children:ni("div",{className:"excalidraw-tooltip-icon",children:gb})})]})}),Sd=U({name:"saveToActiveFile",label:"buttons.save",icon:Ui,trackEvent:{category:"export"},predicate:(e,t,r,o)=>!!o.props.UIOptions.canvasActions.saveToActiveFile&&!!t.fileHandle&&!t.viewModeEnabled,perform:async(e,t,r,o)=>{let n=!!t.fileHandle;try{let{fileHandle:i}=ql(t.fileHandle)?await sS(e,t,o.files,o.getName()):await kp(e,t,o.files,o.getName());return{storeAction:_.NONE,appState:{...t,fileHandle:i,toast:n?{message:i?.name?b("toast.fileSavedToFilename").replace("{filename}",`"${i.name}"`):b("toast.fileSaved")}:null}}}catch(i){return i?.name!=="AbortError"?console.error(i):console.warn(i),{storeAction:_.NONE}}},keyTest:e=>e.key===C.S&&e[C.CTRL_OR_CMD]&&!e.shiftKey}),Ts=U({name:"saveFileToDisk",label:"exportDialog.disk_title",icon:Ui,viewMode:!0,trackEvent:{category:"export"},perform:async(e,t,r,o)=>{try{let{fileHandle:n}=await kp(e,{...t,fileHandle:null},o.files,o.getName());return{storeAction:_.NONE,appState:{...t,openDialog:null,fileHandle:n,toast:{message:b("toast.fileSaved")}}}}catch(n){return n?.name!=="AbortError"?console.error(n):console.warn(n),{storeAction:_.NONE}}},keyTest:e=>e.key===C.S&&e.shiftKey&&e[C.CTRL_OR_CMD],PanelComponent:({updateData:e})=>ni(pe,{type:"button",icon:mb,title:b("buttons.saveAs"),"aria-label":b("buttons.saveAs"),showAriaLabel:_e().editor.isMobile,hidden:!Ri,onClick:()=>e(null),"data-testid":"save-as-button"})}),sl=U({name:"loadScene",label:"buttons.load",trackEvent:{category:"export"},predicate:(e,t,r,o)=>!!o.props.UIOptions.canvasActions.loadScene&&!t.viewModeEnabled,perform:async(e,t,r,o)=>{try{let{elements:n,appState:i,files:a}=await o1(t,e);return{elements:n,appState:i,files:a,storeAction:_.CAPTURE}}catch(n){return n?.name==="AbortError"?(console.warn(n),!1):{elements:e,appState:{...t,errorMessage:n.message},files:o.files,storeAction:_.NONE}}},keyTest:e=>e[C.CTRL_OR_CMD]&&e.key===C.O}),uS=U({name:"exportWithDarkMode",label:"imageExportDialog.label.darkMode",trackEvent:{category:"export",action:"toggleTheme"},perform:(e,t,r)=>({appState:{...t,exportWithDarkMode:r},storeAction:_.NONE}),PanelComponent:({appState:e,updateData:t})=>ni("div",{style:{display:"flex",justifyContent:"flex-end",marginTop:"-45px",marginBottom:"10px"},children:ni(aS,{value:e.exportWithDarkMode?se.DARK:se.LIGHT,onChange:r=>{t(r===se.DARK)},title:b("imageExportDialog.label.darkMode")})})})});var hS,nh,ih,gS=y(()=>{"use strict";f();xe();be();q();Je();Ye();W();mt();me();qe();ne();ze();hS="{}",nh=U({name:"copyStyles",label:"labels.copyStyles",icon:Ou,trackEvent:{category:"element"},perform:(e,t,r,o)=>{let n=[],i=e.find(a=>t.selectedElementIds[a.id]);if(n.push(i),i&&lr(i)){let a=ue(i,o.scene.getNonDeletedElementsMap());n.push(a)}return i&&(hS=JSON.stringify(n)),{appState:{...t,toast:{message:b("toast.copyStyles")}},storeAction:_.NONE}},keyTest:e=>e[C.CTRL_OR_CMD]&&e.altKey&&e.code===Ee.C}),ih=U({name:"pasteStyles",label:"labels.pasteStyles",icon:Ou,trackEvent:{category:"element"},perform:(e,t,r,o)=>{let n=JSON.parse(hS),i=n[0],a=n[1];if(!lc(i))return{elements:e,storeAction:_.NONE};let l=ge(e,t,{includeBoundTextElement:!0}),s=l.map(c=>c.id);return{elements:e.map(c=>{if(s.includes(c.id)){let d=i;if(V(c)&&c.containerId&&(d=a),!d)return c;let m=le(c,{backgroundColor:d?.backgroundColor,strokeWidth:d?.strokeWidth,strokeColor:d?.strokeColor,strokeStyle:d?.strokeStyle,fillStyle:d?.fillStyle,opacity:d?.opacity,roughness:d?.roughness,roundness:d.roundness?pw(d.roundness.type,c)?d.roundness:uw(c):null});if(V(m)){let p=d.fontSize||Ot,u=d.fontFamily||tr;m=le(m,{fontSize:p,fontFamily:u,textAlign:d.textAlign||gi,lineHeight:d.lineHeight||Xr(u)});let h=null;m.containerId&&(h=l.find(E=>V(m)&&E.id===m.containerId)||null),Ht(m,h,o.scene.getNonDeletedElementsMap())}return m.type==="arrow"&&Ce(d)&&(m=le(m,{startArrowhead:d.startArrowhead,endArrowhead:d.endArrowhead})),re(c)&&(m=le(m,{roundness:null,backgroundColor:"transparent"})),m}return c}),storeAction:_.CAPTURE}},keyTest:e=>e[C.CTRL_OR_CMD]&&e.altKey&&e.code===Ee.V})});import{jsx as ES}from"react/jsx-runtime";var fS,bS,Zi,xS=y(()=>{"use strict";f();ne();Dt();q();xe();Je();be();ze();fS=U({name:"toggleCanvasMenu",label:"buttons.menu",trackEvent:{category:"menu"},perform:(e,t)=>({appState:{...t,openMenu:t.openMenu==="canvas"?null:"canvas"},storeAction:_.NONE}),PanelComponent:({appState:e,updateData:t})=>ES(pe,{type:"button",icon:rd,"aria-label":b("buttons.menu"),onClick:t,selected:e.openMenu==="canvas"})}),bS=U({name:"toggleEditMenu",label:"buttons.edit",trackEvent:{category:"menu"},perform:(e,t)=>({appState:{...t,openMenu:t.openMenu==="shape"?null:"shape"},storeAction:_.NONE}),PanelComponent:({elements:e,appState:t,updateData:r})=>ES(pe,{visible:$a(t,ye(e)),type:"button",icon:pb,"aria-label":b("buttons.edit"),onClick:r,selected:t.openMenu==="shape"})}),Zi=U({name:"toggleShortcuts",label:"welcomeScreen.defaults.helpHint",icon:ab,viewMode:!0,trackEvent:{category:"menu",action:"toggleHelpDialog"},perform:(e,t,r,{focusContainer:o})=>(t.openDialog?.name==="help"&&o(),{appState:{...t,openDialog:t.openDialog?.name==="help"?null:{name:"help"}},storeAction:_.NONE}),keyTest:e=>e.key===C.QUESTION_MARK})});import{jsx as Ss}from"react/jsx-runtime";var l7,yS,ah,lh,wS=y(()=>{"use strict";f();be();q();G();Je();ne();Ye();qe();xr();xe();Oo();Dt();me();dr();bo();ze();l7=e=>{if(e.length>=2){let t=e[0].groupIds;for(let r of t)if(e.reduce((o,n)=>o&&_a(n,r),!0))return!0}return!1},yS=(e,t,r)=>{let o=r.scene.getSelectedElements({selectedElementIds:t.selectedElementIds,includeBoundTextElement:!0});return o.length>=2&&!l7(o)},ah=U({name:"group",label:"labels.group",icon:e=>Ss(Lu,{theme:e.theme}),trackEvent:{category:"element"},perform:(e,t,r,o)=>{let n=o.scene.getSelectedElements({selectedElementIds:t.selectedElementIds,includeBoundTextElement:!0});if(n.length<2)return{appState:t,elements:e,storeAction:_.NONE};let i=Vn(t);if(i.length===1){let x=i[0],T=new Set(it(e,x).map(I=>I.id)),v=new Set(n.map(I=>I.id));if(new Set([...Array.from(T),...Array.from(v)]).size===T.size)return{appState:t,elements:e,storeAction:_.NONE}}let a=[...e];new Set(n.map(x=>x.frameId)).size>1&&iT(n).forEach((T,v)=>{cs(T,o.scene.getNonDeletedElementsMap())});let s=zt(),c=X(n);a=a.map(x=>c.get(x.id)?le(x,{groupIds:C2(x.groupIds,s,t.editingGroupId)}):x);let d=it(a,s),m=d[d.length-1],p=a.lastIndexOf(m),u=a.slice(p+1),h=a.slice(0,p).filter(x=>!_a(x,s)),E=Yt([...h,...d,...u],X(d));return{appState:{...t,...zf(s,{...t,selectedGroupIds:{}},ye(a))},elements:E,storeAction:_.CAPTURE}},predicate:(e,t,r,o)=>yS(e,t,o),keyTest:e=>!e.shiftKey&&e[C.CTRL_OR_CMD]&&e.key===C.G,PanelComponent:({elements:e,appState:t,updateData:r,app:o})=>Ss(pe,{hidden:!yS(e,t,o),type:"button",icon:Ss(Lu,{theme:t.theme}),onClick:()=>r(null),title:`${b("labels.group")} \u2014 ${N("CtrlOrCmd+G")}`,"aria-label":b("labels.group"),visible:Xe(ye(e),t)})}),lh=U({name:"ungroup",label:"labels.ungroup",icon:e=>Ss(Pu,{theme:e.theme}),trackEvent:{category:"element"},perform:(e,t,r,o)=>{let n=Vn(t),i=X(e);if(n.length===0)return{appState:t,elements:e,storeAction:_.NONE};let a=[...e],l=[];a=a.map(p=>{Pe(p)&&l.push(p.id);let u=I2(p.groupIds,t.selectedGroupIds);return u.length===p.groupIds.length?p:le(p,{groupIds:u})});let s=nr(t,ye(a),t,null),c=o.scene.getSelectedElements(t),d=new Set(c.filter(p=>p.frameId).map(p=>p.frameId));return $c(e).filter(p=>d.has(p.id)).forEach(p=>{p&&(a=ru(a,ss(a,p,t,i),p,o))}),s.selectedElementIds=Object.entries(s.selectedElementIds).reduce((p,[u,h])=>(h&&!l.includes(u)&&(p[u]=!0),p),{}),{appState:{...t,...s},elements:a,storeAction:_.CAPTURE}},keyTest:e=>e.shiftKey&&e[C.CTRL_OR_CMD]&&e.key===C.G.toUpperCase(),predicate:(e,t)=>Vn(t).length>0,PanelComponent:({elements:e,appState:t,updateData:r})=>Ss(pe,{type:"button",hidden:Vn(t).length===0,icon:Ss(Pu,{theme:t.theme}),onClick:()=>r(null),title:`${b("labels.ungroup")} \u2014 ${N("CtrlOrCmd+Shift+G")}`,"aria-label":b("labels.ungroup"),visible:Xe(ye(e),t)})})});var sh,GE=y(()=>{"use strict";f();sh=(e,t,r,o,n,i,a)=>{e.beginPath(),e.moveTo(t+i,r),e.lineTo(t+o-i,r),e.quadraticCurveTo(t+o,r,t+o,r+i),e.lineTo(t+o,r+n-i),e.quadraticCurveTo(t+o,r+n,t+o-i,r+n),e.lineTo(t+i,r+n),e.quadraticCurveTo(t,r+n,t,r+n-i),e.lineTo(t,r+i),e.quadraticCurveTo(t,r,t+i,r),e.closePath(),e.fill(),a&&(e.strokeStyle=a),e.stroke()}});var vS=y(()=>{"use strict";f()});function s7(e){let t=0;if(e.length===0)return t;for(let r=0;r<e.length;r++){let o=e.charCodeAt(r);t=(t<<5)-t+o}return t}var cl,TS,SS,Id=y(()=>{"use strict";f();W();GE();vS();cl=(e,t)=>`hsl(${Math.abs(s7(t?.id||e))%37*10}, 100%, 83%)`,TS=e=>{let t=e?.trim()?.codePointAt(0);return(t?String.fromCodePoint(t):"?").toUpperCase()},SS=({context:e,renderConfig:t,appState:r,normalizedWidth:o,normalizedHeight:n})=>{for(let[i,a]of t.remotePointerViewportCoords){let{x:l,y:s}=a,c=r.collaborators.get(i);l-=r.offsetLeft,s-=r.offsetTop;let d=11,m=14,p=l<0||l>o-d||s<0||s>n-m;l=Math.max(l,0),l=Math.min(l,o-d),s=Math.max(s,0),s=Math.min(s,n-m);let u=cl(i,c);e.save(),e.strokeStyle=u,e.fillStyle=u;let h=t.remotePointerUserStates.get(i),E=p||h==="idle"||h==="away";E&&(e.globalAlpha=.3),t.remotePointerButton.get(i)==="down"&&(e.beginPath(),e.arc(l,s,15,0,2*Math.PI,!1),e.lineWidth=3,e.strokeStyle="#ffffff88",e.stroke(),e.closePath(),e.beginPath(),e.arc(l,s,15,0,2*Math.PI,!1),e.lineWidth=1,e.strokeStyle=u,e.stroke(),e.closePath());let x=r.theme===se.DARK?"#2f6330":My,T=c?.isSpeaking;T&&(e.fillStyle=x,e.strokeStyle=x,e.lineWidth=10,e.lineJoin="round",e.beginPath(),e.moveTo(l,s),e.lineTo(l+0,s+14),e.lineTo(l+4,s+9),e.lineTo(l+11,s+8),e.closePath(),e.stroke(),e.fill()),e.fillStyle=Gt,e.strokeStyle=Gt,e.lineWidth=6,e.lineJoin="round",e.beginPath(),e.moveTo(l,s),e.lineTo(l+0,s+14),e.lineTo(l+4,s+9),e.lineTo(l+11,s+8),e.closePath(),e.stroke(),e.fill(),e.fillStyle=u,e.strokeStyle=u,e.lineWidth=2,e.lineJoin="round",e.beginPath(),E?(e.moveTo(l-1,s-1),e.lineTo(l-1,s+15),e.lineTo(l+5,s+10),e.lineTo(l+12,s+9),e.closePath(),e.fill()):(e.moveTo(l,s),e.lineTo(l+0,s+14),e.lineTo(l+4,s+9),e.lineTo(l+11,s+8),e.closePath(),e.fill(),e.stroke());let v=t.remotePointerUsernames.get(i)||"";if(!p&&v){e.font="600 12px sans-serif";let w=(T?l+0:l)+d/2,I=(T?s+0:s)+m+2,L=5,A=3,M=e.measureText(v),D=M.actualBoundingBoxDescent+M.actualBoundingBoxAscent,O=Math.max(D,12),R=w-1,B=I-1,k=M.width+2+L*2+2,z=O+2+A*2+2;if(e.roundRect?(e.beginPath(),e.roundRect(R,B,k,z,8),e.fillStyle=u,e.fill(),e.strokeStyle=Gt,e.stroke(),T&&(e.beginPath(),e.roundRect(R-2,B-2,k+4,z+4,8),e.strokeStyle=x,e.stroke())):sh(e,R,B,k,z,8,Gt),e.fillStyle=bi,e.fillText(v,w+L+1,I+A+M.actualBoundingBoxAscent+Math.floor((O-D)/2)+2),T){e.fillStyle=x;let ee=8,j=8,ie=5;e.fillRect(R+k+j,B+(z/2-ee/2),2,ee),e.fillRect(R+k+j+ie,B+(z/2-ee*2/2),2,ee*2),e.fillRect(R+k+j+ie*2,B+(z/2-ee/2),2,ee)}}e.restore(),e.closePath()}}});var CS=y(()=>{});import{useState as c7}from"react";import d7 from"clsx";import{jsx as IS}from"react/jsx-runtime";var VE,AS=y(()=>{"use strict";f();CS();Id();VE=({color:e,onClick:t,name:r,src:o,className:n})=>{let i=TS(r),[a,l]=c7(!1),s=!a&&o,c=s?void 0:{background:e};return IS("div",{className:d7("Avatar",n),style:c,onClick:t,children:s?IS("img",{className:"Avatar-img",src:o,alt:i,referrerPolicy:"no-referrer",onError:()=>l(!0)}):i})}});import m7 from"clsx";import{jsx as vn,jsxs as ch}from"react/jsx-runtime";var kS,MS=y(()=>{"use strict";f();Id();AS();ne();q();ze();Je();kS=U({name:"goToCollaborator",label:"Go to a collaborator",viewMode:!0,trackEvent:{category:"collab"},perform:(e,t,r)=>!r.socketId||t.userToFollow?.socketId===r.socketId||r.isCurrentUser?{appState:{...t,userToFollow:null},storeAction:_.NONE}:{appState:{...t,userToFollow:{socketId:r.socketId,username:r.username||""},openMenu:t.openMenu==="canvas"?null:t.openMenu},storeAction:_.NONE},PanelComponent:({updateData:e,data:t,appState:r})=>{let{socketId:o,collaborator:n,withName:i,isBeingFollowed:a}=t,l=cl(o,n),s=m7({"is-followed":a,"is-current-user":n.isCurrentUser===!0,"is-speaking":n.isSpeaking,"is-in-call":n.isInCall,"is-muted":n.isMuted}),c=n.isInCall?n.isSpeaking?ch("div",{className:"UserList__collaborator-status-icon-speaking-indicator",title:b("userList.hint.isSpeaking"),children:[vn("div",{}),vn("div",{}),vn("div",{})]}):n.isMuted?vn("div",{className:"UserList__collaborator-status-icon-microphone-muted",title:b("userList.hint.micMuted"),children:dE}):vn("div",{title:b("userList.hint.inCall"),children:cE}):null;return i?ch("div",{className:`dropdown-menu-item dropdown-menu-item-base UserList__collaborator ${s}`,style:{"--avatar-size":"1.5rem"},onClick:()=>e(n),children:[vn(VE,{color:l,onClick:()=>{},name:n.username||"",src:n.avatarUrl,className:s}),vn("div",{className:"UserList__collaborator-name",children:n.username}),ch("div",{className:"UserList__collaborator-status-icons","aria-hidden":!0,children:[a&&vn("div",{className:"UserList__collaborator-status-icon-is-followed",title:b("userList.hint.followStatus"),children:rl}),c]})]}):ch("div",{className:`UserList__collaborator UserList__collaborator--avatar-only ${s}`,children:[vn(VE,{color:l,onClick:()=>{e(n)},name:n.username||"",src:n.avatarUrl,className:s}),c&&vn("div",{className:"UserList__collaborator-status-icon",children:c})]})}})});var dh,LS=y(()=>{"use strict";f();Je();hn();Oo();q();W();ze();dh=U({name:"addToLibrary",trackEvent:{category:"element"},perform:(e,t,r,o)=>{let n=o.scene.getSelectedElements({selectedElementIds:t.selectedElementIds,includeBoundTextElement:!0,includeElementsInFrames:!0});for(let i of Am)if(n.some(a=>a.type===i))return{storeAction:_.NONE,appState:{...t,errorMessage:b(`errors.libraryElementTypeError.${i}`)}};return o.library.getLatestLibrary().then(i=>o.library.setLibrary([{id:zt(),status:"unpublished",elements:n.map(Yn),created:Date.now()},...i])).then(()=>({storeAction:_.NONE,appState:{...t,toast:{message:b("toast.addedToLibrary")}}})).catch(i=>({storeAction:_.NONE,appState:{...t,errorMessage:i.message}}))},label:"labels.addToLibrary"})});var PS,p7,DS=y(()=>{"use strict";f();Ye();dt();xr();PS=(e,t,r)=>{let o=Ra(e,t),n=Lr(e);return o.flatMap(i=>{let a=p7(i,n,r);return i.map(l=>le(l,{x:l.x+a.x,y:l.y+a.y}))})},p7=(e,t,{axis:r,position:o})=>{let n=Lr(e),[i,a]=r==="x"?["minX","maxX"]:["minY","maxY"],l={x:0,y:0};return o==="start"?{...l,[r]:t[i]-n[i]}:o==="end"?{...l,[r]:t[a]-n[a]}:{...l,[r]:(t[i]+t[a])/2-(n[i]+n[a])/2}}});import{jsx as Is}from"react/jsx-runtime";var Io,Cs,_S,RS,NS,OS,BS,FS,zS=y(()=>{"use strict";f();DS();ne();Dt();xe();me();dr();q();be();qe();ze();G();Je();Io=(e,t,r,o)=>{let n=o.scene.getSelectedElements(t);return n.length>1&&!n.some(i=>re(i))},Cs=(e,t,r,o)=>{let n=r.scene.getSelectedElements(t),i=X(e),a=PS(n,i,o),l=X(a);return bn(e.map(s=>l.get(s.id)||s),t,r)},_S=U({name:"alignTop",label:"labels.alignTop",icon:Su,trackEvent:{category:"element"},predicate:Io,perform:(e,t,r,o)=>({appState:t,elements:Cs(e,t,o,{position:"start",axis:"y"}),storeAction:_.CAPTURE}),keyTest:e=>e[C.CTRL_OR_CMD]&&e.shiftKey&&e.key===C.ARROW_UP,PanelComponent:({elements:e,appState:t,updateData:r,app:o})=>Is(pe,{hidden:!Io(e,t,null,o),type:"button",icon:Su,onClick:()=>r(null),title:`${b("labels.alignTop")} \u2014 ${N("CtrlOrCmd+Shift+Up")}`,"aria-label":b("labels.alignTop"),visible:Xe(ye(e),t)})}),RS=U({name:"alignBottom",label:"labels.alignBottom",icon:Cu,trackEvent:{category:"element"},predicate:Io,perform:(e,t,r,o)=>({appState:t,elements:Cs(e,t,o,{position:"end",axis:"y"}),storeAction:_.CAPTURE}),keyTest:e=>e[C.CTRL_OR_CMD]&&e.shiftKey&&e.key===C.ARROW_DOWN,PanelComponent:({elements:e,appState:t,updateData:r,app:o})=>Is(pe,{hidden:!Io(e,t,null,o),type:"button",icon:Cu,onClick:()=>r(null),title:`${b("labels.alignBottom")} \u2014 ${N("CtrlOrCmd+Shift+Down")}`,"aria-label":b("labels.alignBottom"),visible:Xe(ye(e),t)})}),NS=U({name:"alignLeft",label:"labels.alignLeft",icon:Iu,trackEvent:{category:"element"},predicate:Io,perform:(e,t,r,o)=>({appState:t,elements:Cs(e,t,o,{position:"start",axis:"x"}),storeAction:_.CAPTURE}),keyTest:e=>e[C.CTRL_OR_CMD]&&e.shiftKey&&e.key===C.ARROW_LEFT,PanelComponent:({elements:e,appState:t,updateData:r,app:o})=>Is(pe,{hidden:!Io(e,t,null,o),type:"button",icon:Iu,onClick:()=>r(null),title:`${b("labels.alignLeft")} \u2014 ${N("CtrlOrCmd+Shift+Left")}`,"aria-label":b("labels.alignLeft"),visible:Xe(ye(e),t)})}),OS=U({name:"alignRight",label:"labels.alignRight",icon:Au,trackEvent:{category:"element"},predicate:Io,perform:(e,t,r,o)=>({appState:t,elements:Cs(e,t,o,{position:"end",axis:"x"}),storeAction:_.CAPTURE}),keyTest:e=>e[C.CTRL_OR_CMD]&&e.shiftKey&&e.key===C.ARROW_RIGHT,PanelComponent:({elements:e,appState:t,updateData:r,app:o})=>Is(pe,{hidden:!Io(e,t,null,o),type:"button",icon:Au,onClick:()=>r(null),title:`${b("labels.alignRight")} \u2014 ${N("CtrlOrCmd+Shift+Right")}`,"aria-label":b("labels.alignRight"),visible:Xe(ye(e),t)})}),BS=U({name:"alignVerticallyCentered",label:"labels.centerVertically",icon:ku,trackEvent:{category:"element"},predicate:Io,perform:(e,t,r,o)=>({appState:t,elements:Cs(e,t,o,{position:"center",axis:"y"}),storeAction:_.CAPTURE}),PanelComponent:({elements:e,appState:t,updateData:r,app:o})=>Is(pe,{hidden:!Io(e,t,null,o),type:"button",icon:ku,onClick:()=>r(null),title:b("labels.centerVertically"),"aria-label":b("labels.centerVertically"),visible:Xe(ye(e),t)})}),FS=U({name:"alignHorizontallyCentered",label:"labels.centerHorizontally",icon:Mu,trackEvent:{category:"element"},predicate:Io,perform:(e,t,r,o)=>({appState:t,elements:Cs(e,t,o,{position:"center",axis:"x"}),storeAction:_.CAPTURE}),PanelComponent:({elements:e,appState:t,updateData:r,app:o})=>Is(pe,{hidden:!Io(e,t,null,o),type:"button",icon:Mu,onClick:()=>r(null),title:b("labels.centerHorizontally"),"aria-label":b("labels.centerHorizontally"),visible:Xe(ye(e),t)})})});var HS,US=y(()=>{"use strict";f();Ye();xr();dt();HS=(e,t,r)=>{let[o,n,i,a]=r.axis==="x"?["minX","midX","maxX","width"]:["minY","midY","maxY","height"],l=Lr(e),s=Ra(e,t).map(p=>[p,Lr(p)]).sort((p,u)=>p[1][n]-u[1][n]),c=0;for(let p of s)c+=p[1][a];let d=(l[a]-c)/(s.length-1);if(d<0){let p=s.findIndex(x=>x[1][o]===l[o]),u=s.findIndex(x=>x[1][i]===l[i]),h=(s[u][1][n]-s[p][1][n])/(s.length-1),E=s[p][1][n];return s.flatMap(([x,T],v)=>{let w={x:0,y:0};return v!==p&&v!==u&&(E+=h,w[r.axis]=E-T[n]),x.map(I=>le(I,{x:I.x+w.x,y:I.y+w.y}))})}let m=l[o];return s.flatMap(([p,u])=>{let h={x:0,y:0};return h[r.axis]=m-u[o],m+=d,m+=u[a],p.map(E=>le(E,{x:E.x+h.x,y:E.y+h.y}))})}});import{jsx as KS}from"react/jsx-runtime";var GS,VS,WS,YS,$S=y(()=>{"use strict";f();ne();Dt();US();xe();me();dr();q();be();qe();ze();G();Je();GS=(e,t)=>{let r=t.scene.getSelectedElements(e);return r.length>1&&!r.some(o=>re(o))},VS=(e,t,r,o)=>{let n=r.scene.getSelectedElements(t),i=HS(n,r.scene.getNonDeletedElementsMap(),o),a=X(i);return bn(e.map(l=>a.get(l.id)||l),t,r)},WS=U({name:"distributeHorizontally",label:"labels.distributeHorizontally",trackEvent:{category:"element"},perform:(e,t,r,o)=>({appState:t,elements:VS(e,t,o,{space:"between",axis:"x"}),storeAction:_.CAPTURE}),keyTest:e=>!e[C.CTRL_OR_CMD]&&e.altKey&&e.code===Ee.H,PanelComponent:({elements:e,appState:t,updateData:r,app:o})=>KS(pe,{hidden:!GS(t,o),type:"button",icon:bb,onClick:()=>r(null),title:`${b("labels.distributeHorizontally")} \u2014 ${N("Alt+H")}`,"aria-label":b("labels.distributeHorizontally"),visible:Xe(ye(e),t)})}),YS=U({name:"distributeVertically",label:"labels.distributeVertically",trackEvent:{category:"element"},perform:(e,t,r,o)=>({appState:t,elements:VS(e,t,o,{space:"between",axis:"y"}),storeAction:_.CAPTURE}),keyTest:e=>!e[C.CTRL_OR_CMD]&&e.altKey&&e.code===Ee.V,PanelComponent:({elements:e,appState:t,updateData:r,app:o})=>KS(pe,{hidden:!GS(t,o),type:"button",icon:Eb,onClick:()=>r(null),title:`${b("labels.distributeVertically")} \u2014 ${N("Alt+V")}`,"aria-label":b("labels.distributeVertically"),visible:Xe(ye(e),t)})})});var mh,ph,XS,u7,ZS=y(()=>{"use strict";f();Je();qe();xe();P1();G();be();dt();Eo();dr();ne();ze();mh=U({name:"flipHorizontal",label:"labels.flipHorizontal",icon:hE,trackEvent:{category:"element"},perform:(e,t,r,o)=>({elements:bn(XS(e,o.scene.getNonDeletedElementsMap(),t,"horizontal",o),t,o),appState:t,storeAction:_.CAPTURE}),keyTest:e=>e.shiftKey&&e.code===Ee.H}),ph=U({name:"flipVertical",label:"labels.flipVertical",icon:uE,trackEvent:{category:"element"},perform:(e,t,r,o)=>({elements:bn(XS(e,o.scene.getNonDeletedElementsMap(),t,"vertical",o),t,o),appState:t,storeAction:_.CAPTURE}),keyTest:e=>e.shiftKey&&e.code===Ee.V&&!e[C.CTRL_OR_CMD]}),XS=(e,t,r,o,n)=>{let i=ge(ye(e),r,{includeBoundTextElement:!0,includeElementsInFrames:!0}),a=u7(i,e,t,r,o,n),l=X(a);return e.map(s=>l.get(s.id)||s)},u7=(e,t,r,o,n,i)=>{let{minX:a,minY:l,maxX:s,maxY:c}=Lr(e);return k1(r,e,r,"nw",!0,!0,n==="horizontal"?s:a,n==="horizontal"?l:c),mn(o)?yc(e,i):vc(e,r),e}});var dl,WE,Ad,kd,Md,Ld,YE=y(()=>{"use strict";f();be();Je();zi();vE();Xi();xe();Xi();q();W();ne();ze();dl=U({name:"copy",label:"labels.copy",icon:ps,trackEvent:{category:"element"},perform:async(e,t,r,o)=>{let n=o.scene.getSelectedElements({selectedElementIds:t.selectedElementIds,includeBoundTextElement:!0,includeElementsInFrames:!0});try{await Zp(n,o.files,r)}catch(i){return{storeAction:_.NONE,appState:{...t,errorMessage:i.message}}}return{storeAction:_.NONE}},keyTest:void 0}),WE=U({name:"paste",label:"labels.paste",trackEvent:{category:"element"},perform:async(e,t,r,o)=>{let n;try{n=await Wv()}catch(i){return i.name==="AbortError"||i.name==="NotAllowedError"?!1:(console.error(`actionPaste ${i.name}: ${i.message}`),Rn?{storeAction:_.NONE,appState:{...t,errorMessage:b("hints.firefox_clipboard_write")}}:{storeAction:_.NONE,appState:{...t,errorMessage:b("errors.asyncPasteFailedOnRead")}})}try{o.pasteFromClipboard(Gv({types:n}))}catch(i){return console.error(i),{storeAction:_.NONE,appState:{...t,errorMessage:b("errors.asyncPasteFailedOnParse")}}}return{storeAction:_.NONE}},keyTest:void 0}),Ad=U({name:"cut",label:"labels.cut",icon:Qb,trackEvent:{category:"element"},perform:(e,t,r,o)=>(dl.perform(e,t,r,o),bs.perform(e,t,null,o)),keyTest:e=>e[C.CTRL_OR_CMD]&&e.key===C.X}),kd=U({name:"copyAsSvg",label:"labels.copyAsSvg",icon:gE,trackEvent:{category:"element"},perform:async(e,t,r,o)=>{if(!o.canvas)return{storeAction:_.NONE};let{exportedElements:n,exportingFrame:i}=il(e,t,!0);try{return await al({type:"clipboard-svg",data:{elements:n,appState:t,files:o.files},config:{...t,exportingFrame:i,name:o.getName()}}),{storeAction:_.NONE}}catch(a){return console.error(a),{appState:{...t,errorMessage:a.message},storeAction:_.NONE}}},predicate:e=>Xp&&e.length>0,keywords:["svg","clipboard","copy"]}),Md=U({name:"copyAsPng",label:"labels.copyAsPng",icon:fE,trackEvent:{category:"element"},perform:async(e,t,r,o)=>{if(!o.canvas)return{storeAction:_.NONE};let n=o.scene.getSelectedElements({selectedElementIds:t.selectedElementIds,includeBoundTextElement:!0,includeElementsInFrames:!0}),{exportedElements:i,exportingFrame:a}=il(e,t,!0);try{return await al({type:"clipboard",data:{elements:i,appState:t,files:o.files},config:{...t,exportingFrame:a,name:t.name||o.getName()}}),{appState:{...t,toast:{message:b("toast.copyToClipboardAsPng",{exportSelection:n.length?b("toast.selection"):b("toast.canvas"),exportColorScheme:t.exportWithDarkMode?b("buttons.darkMode"):b("buttons.lightMode")})}},storeAction:_.NONE}}catch(l){return console.error(l),{appState:{...t,errorMessage:l.message},storeAction:_.NONE}}},predicate:e=>as&&e.length>0,keyTest:e=>e.code===Ee.C&&e.altKey&&e.shiftKey,keywords:["png","clipboard","copy"]}),Ld=U({name:"copyText",label:"labels.copyText",trackEvent:{category:"element"},perform:(e,t,r,o)=>{let i=o.scene.getSelectedElements({selectedElementIds:t.selectedElementIds,includeBoundTextElement:!0}).reduce((a,l)=>(V(l)&&a.push(l.text),a),[]).join(`
70
70
 
71
- `);try{Xn(i)}catch{throw new Error(b("errors.copyToSystemClipboardFailed"))}return{commitToHistory:!1}},predicate:(e,t,o,r)=>vp&&r.scene.getSelectedElements({selectedElementIds:t.selectedElementIds,includeBoundTextElement:!0}).some(W),keywords:["text","clipboard","copy"]})});var hd,jT=v(()=>{"use strict";f();ue();je();U();hd=H({name:"gridMode",label:"labels.showGrid",viewMode:!0,trackEvent:{category:"canvas",predicate:e=>!e.gridSize},perform(e,t){return{appState:{...t,gridSize:this.checked(t)?null:An,objectsSnapModeEnabled:!1},commitToHistory:!1}},checked:e=>e.gridSize!==null,predicate:(e,t,o)=>typeof o.gridModeEnabled>"u",keyTest:e=>e[I.CTRL_OR_CMD]&&e.code===fe.QUOTE})});var Qa,qT=v(()=>{"use strict";f();ee();ue();je();Qa=H({name:"zenMode",label:"buttons.zenMode",icon:Hb,paletteName:"Toggle zen mode",viewMode:!0,trackEvent:{category:"canvas",predicate:e=>!e.zenModeEnabled},perform(e,t){return{appState:{...t,zenModeEnabled:!this.checked(t)},commitToHistory:!1}},checked:e=>e.zenModeEnabled,predicate:(e,t,o)=>typeof o.zenModeEnabled>"u",keyTest:e=>!e[I.CTRL_OR_CMD]&&e.altKey&&e.code===fe.Z})});var Hu,JT=v(()=>{"use strict";f();ee();ue();je();Hu=H({name:"objectsSnapMode",label:"buttons.objectsSnapMode",icon:Fb,viewMode:!1,trackEvent:{category:"canvas",predicate:e=>!e.objectsSnapModeEnabled},perform(e,t){return{appState:{...t,objectsSnapModeEnabled:!this.checked(t),gridSize:null},commitToHistory:!1}},checked:e=>e.objectsSnapModeEnabled,predicate:(e,t,o)=>typeof o.objectsSnapModeEnabled>"u",keyTest:e=>!e[I.CTRL_OR_CMD]&&e.altKey&&e.code===fe.S})});var Qn,px=v(()=>{"use strict";f();je();ue();ee();Qn=H({name:"stats",label:"stats.title",icon:Db,paletteName:"Toggle stats",viewMode:!0,trackEvent:{category:"menu"},perform(e,t){return{appState:{...t,showStats:!this.checked(t)},commitToHistory:!1}},checked:e=>e.showStats,keyTest:e=>!e[I.CTRL_OR_CMD]&&e.altKey&&e.code===fe.SLASH})});var zu,Gu,l7,s7,QT,ux=v(()=>{"use strict";f();U();he();Ze();pt();Nm();se();G();je();zu=H({name:"unbindText",label:"labels.unbindText",trackEvent:{category:"element"},predicate:(e,t,o,r)=>r.scene.getSelectedElements(t).some(i=>Eo(i)),perform:(e,t,o,r)=>{let n=r.scene.getSelectedElements(t),i=r.scene.getNonDeletedElementsMap();return n.forEach(a=>{let l=me(a,i);if(l){let{width:s,height:c}=Pr(l.originalText,Ke(l),l.lineHeight),d=k2(a.id);Rm(a.id);let{x:m,y:p}=Pl(a,l,i);z(l,{containerId:null,width:s,height:c,text:l.originalText,x:m,y:p}),z(a,{boundElements:a.boundElements?.filter(u=>u.id!==l.id),height:d||a.height})}}),{elements:e,appState:t,commitToHistory:!0}}}),Gu=H({name:"bindText",label:"labels.bindText",trackEvent:{category:"element"},predicate:(e,t,o,r)=>{let n=r.scene.getSelectedElements(t);if(n.length===2){let i=W(n[0])||W(n[1]),a;if(jr(n[0])?a=n[0]:jr(n[1])&&(a=n[1]),i&&a&&me(a,r.scene.getNonDeletedElementsMap())===null)return!0}return!1},perform:(e,t,o,r)=>{let n=r.scene.getSelectedElements(t),i,a;W(n[0])&&jr(n[1])?(i=n[0],a=n[1]):(i=n[1],a=n[0]),z(i,{containerId:a.id,verticalAlign:yt.MIDDLE,textAlign:ci.CENTER}),z(a,{boundElements:(a.boundElements||[]).concat({type:"text",id:i.id})});let l=a.height;return eo(i,a,r.scene.getNonDeletedElementsMap()),ya(a.id,l),{elements:l7(e,a,i),appState:{...t,selectedElementIds:{[a.id]:!0}},commitToHistory:!0}}}),l7=(e,t,o)=>{let r=e.slice(),n=r.findIndex(a=>a.id===o.id);r.splice(n,1);let i=r.findIndex(a=>a.id===t.id);return r.splice(i+1,0,o),r},s7=(e,t,o)=>{let r=e.slice(),n=r.findIndex(a=>a.id===t.id);r.splice(n,1);let i=r.findIndex(a=>a.id===o.id);return r.splice(i,0,t),r},QT=H({name:"wrapTextInContainer",label:"labels.createContainerFromText",trackEvent:{category:"element"},predicate:(e,t,o,r)=>{let n=r.scene.getSelectedElements(t),i=n.every(a=>W(a));return n.length>0&&i},perform:(e,t,o,r)=>{let n=r.scene.getSelectedElements(t),i=e.slice(),a={};for(let l of n)if(W(l)){let s=Uo({type:"rectangle",backgroundColor:t.currentItemBackgroundColor,boundElements:[...l.boundElements||[],{id:l.id,type:"text"}],angle:l.angle,fillStyle:t.currentItemFillStyle,strokeColor:t.currentItemStrokeColor,roughness:t.currentItemRoughness,strokeWidth:t.currentItemStrokeWidth,strokeStyle:t.currentItemStrokeStyle,roundness:t.currentItemRoundness==="round"?{type:qr("rectangle")?at.ADAPTIVE_RADIUS:at.PROPORTIONAL_RADIUS}:null,opacity:100,locked:!1,x:l.x-xt,y:l.y-xt,width:On(l.width,"rectangle"),height:On(l.height,"rectangle"),groupIds:l.groupIds,frameId:l.frameId});if(l.boundElements?.length){let c=l.boundElements.filter(m=>m.type==="arrow").map(m=>m.id);i.filter(m=>c.includes(m.id)).forEach(m=>{let p=m.startBinding,u=m.endBinding;p?.elementId===l.id&&(p={...p,elementId:s.id}),u?.elementId===l.id&&(u={...u,elementId:s.id}),(p||u)&&z(m,{startBinding:p,endBinding:u},!1)})}z(l,{containerId:s.id,verticalAlign:yt.MIDDLE,boundElements:null,textAlign:ci.CENTER},!1),eo(l,s,r.scene.getNonDeletedElementsMap()),i=s7([...i,s],s,l),a[s.id]=!0}return{elements:i,appState:{...t,selectedElementIds:a},commitToHistory:!0}}})});var e5=v(()=>{});import{useCallback as t5,useEffect as c7,useLayoutEffect as d7,useRef as m7,useState as p7}from"react";import u7 from"clsx";import{jsx as fd,jsxs as o5}from"react/jsx-runtime";var fx,r5,gx,g7,h7,hx,Uu,n5,i5,bx,bd,a5,f7,l5,b7,xx=v(()=>{"use strict";f();G();vc();Ze();Mt();ee();X();ue();U();bt();Ni();We();Ei();Dl();e5();So();ye();se();dp();fx=320,r5=85,gx=5,g7=42,h7=500,hx=!1,Uu=new Map,n5=({element:e,elementsMap:t,setAppState:o,onLinkOpen:r,setToast:n,updateEmbedValidationStatus:i})=>{let a=fs(),l=Hi(),s=e.link||"",[c,d]=p7(s),m=m7(null),p=a.showHyperlinkPopup==="editor",u=t5(()=>{if(!m.current)return;let T=po(m.current.value)||null;if(!e.link&&T&&we("hyperlink","create"),St(e)){if(a.activeEmbeddable?.element===e&&o({activeEmbeddable:null}),!T){z(e,{link:null}),i(e,!1);return}if(!Bl(T,l.validateEmbeddable))T&&n({message:b("toast.unableToEmbed"),closable:!0}),e.link&&Uu.set(e.id,e.link),z(e,{link:T}),i(e,!1);else{let{width:w,height:S}=e,M=Un(T);M?.error instanceof URIError&&n({message:b("toast.unrecognizedLinkFormat"),closable:!0});let k=M?M.intrinsicSize.w/M.intrinsicSize.h:1,R=Uu.get(e.id)!==e.link;z(e,{...R?{width:M?.type==="video"?w>S?w:S*k:w,height:M?.type==="video"&&w>S?w/k:S}:{},link:T}),i(e,!0),Uu.has(e.id)&&Uu.delete(e.id)}}else z(e,{link:T})},[e,n,l.validateEmbeddable,a.activeEmbeddable,o,i]);d7(()=>()=>{u()},[u]),c7(()=>{let T=null,w=S=>{if(p)return;T&&clearTimeout(T),b7(e,t,a,[S.clientX,S.clientY])&&(T=window.setTimeout(()=>{o({showHyperlinkPopup:!1})},h7))};return window.addEventListener("pointermove",w,!1),()=>{window.removeEventListener("pointermove",w,!1),T&&clearTimeout(T)}},[a,e,p,o,t]);let g=t5(()=>{we("hyperlink","delete"),z(e,{link:null}),p&&(m.current.value=""),o({showHyperlinkPopup:!1})},[o,e,p]),x=()=>{we("hyperlink","edit","popup-ui"),o({showHyperlinkPopup:"editor"})},{x:E,y}=i5(e,a,t);return a.contextMenu||a.draggingElement||a.resizingElement||a.isRotating||a.openMenu||a.viewModeEnabled?null:o5("div",{className:"excalidraw-hyperlinkContainer",style:{top:`${y}px`,left:`${E}px`,width:fx,padding:gx},onClick:()=>{!e.link&&!p&&o({showHyperlinkPopup:"editor"})},children:[p?fd("input",{className:u7("excalidraw-hyperlinkContainer-input"),placeholder:"Type or paste your link here",ref:m,value:c,onChange:T=>d(T.target.value),autoFocus:!0,onKeyDown:T=>{T.stopPropagation(),T[I.CTRL_OR_CMD]&&T.key===I.K&&T.preventDefault(),(T.key===I.ENTER||T.key===I.ESCAPE)&&(u(),o({showHyperlinkPopup:"info"}))}}):e.link?fd("a",{href:po(e.link||""),className:"excalidraw-hyperlinkContainer-link",target:Vm(e.link)?"_self":"_blank",onClick:T=>{if(e.link&&r){let w=xm("excalidraw-link",T.nativeEvent);r({...e,link:po(e.link)},w),w.defaultPrevented&&T.preventDefault()}},rel:"noopener noreferrer",children:e.link}):fd("div",{className:"excalidraw-hyperlinkContainer-link",children:b("labels.link.empty")}),o5("div",{className:"excalidraw-hyperlinkContainer__buttons",children:[!p&&fd(ce,{type:"button",title:b("buttons.edit"),"aria-label":b("buttons.edit"),label:b("buttons.edit"),onClick:x,className:"excalidraw-hyperlinkContainer--edit",icon:Ha}),s&&!St(e)&&fd(ce,{type:"button",title:b("buttons.remove"),"aria-label":b("buttons.remove"),label:b("buttons.remove"),onClick:g,className:"excalidraw-hyperlinkContainer--remove",icon:ur})]})]})},i5=(e,t,o)=>{let[r,n]=te(e,o),{x:i,y:a}=zt({sceneX:r+e.width/2,sceneY:n},t),l=i-t.offsetLeft-fx/2,s=a-t.offsetTop-r5;return{x:l,y:s}},bx=(e,t)=>{let o=de(e,t);return o[0]?.link?St(o[0])?"labels.link.editEmbed":"labels.link.edit":St(o[0])?"labels.link.createEmbed":"labels.link.create"},bd=null,a5=(e,t,o)=>{bd&&clearTimeout(bd),bd=window.setTimeout(()=>f7(e,t,o),ey)},f7=(e,t,o)=>{if(!e.link)return;let r=ms();r.classList.add("excalidraw-tooltip--visible"),r.style.maxWidth="20rem",r.textContent=e.link;let[n,i,a,l]=te(e,o),[s,c,d,m]=Lc([n,i,a,l],e.angle,t),p=zt({sceneX:s,sceneY:c},t);lx(r,{left:p.x,top:p.y,width:d,height:m},"top"),we("hyperlink","tooltip","link-icon"),hx=!0},l5=()=>{bd&&clearTimeout(bd),hx&&(hx=!1,ms().classList.remove("excalidraw-tooltip--visible"))},b7=(e,t,o,[r,n])=>{let{x:i,y:a}=$e({clientX:r,clientY:n},o),l=15/o.zoom.value;if(Cl(e,t,[i,a],l,null))return!1;let[s,c,d]=te(e,t);if(i>=s&&i<=d&&a>=c-r5&&a<=c)return!1;let{x:m,y:p}=i5(e,o,t);return!(r>=m-l&&r<=m+fx+gx*2+l&&n>=p-l&&n<=p+l+gx*2+g7)}});import{jsx as x7}from"react/jsx-runtime";var bs,s5=v(()=>{"use strict";f();xx();ee();Mt();se();X();ue();We();G();je();bs=H({name:"hyperlink",label:(e,t)=>bx(e,t),icon:ns,perform:(e,t)=>t.showHyperlinkPopup==="editor"?!1:{elements:e,appState:{...t,showHyperlinkPopup:"editor",openMenu:null},commitToHistory:!0},trackEvent:{category:"hyperlink",action:"click"},keyTest:e=>e[I.CTRL_OR_CMD]&&e.key===I.K,predicate:(e,t)=>de(e,t).length===1,PanelComponent:({elements:e,appState:t,updateData:o})=>{let r=de(e,t);return x7(ce,{type:"button",icon:ns,"aria-label":b(bx(e,t)),title:`${St(e[0])?b("labels.link.labelEmbed"):b("labels.link.label")} - ${N("CtrlOrCmd+K")}`,onClick:()=>o(null),selected:r.length===1&&!!r[0].link})}})});var Ex,Wu,c5,yx=v(()=>{"use strict";f();ee();Ze();se();ue();We();G();je();Ex=e=>e.every(t=>!t.locked),Wu=H({name:"toggleElementLock",label:(e,t,o)=>{let r=o.scene.getSelectedElements({selectedElementIds:t.selectedElementIds,includeBoundTextElement:!1});return r.length===1&&!Q(r[0])?r[0].locked?"labels.elementLock.unlock":"labels.elementLock.lock":Ex(r)?"labels.elementLock.lockAll":"labels.elementLock.unlockAll"},icon:(e,t)=>{let o=de(t,e);return Ex(o)?Fa:Mi},trackEvent:{category:"element"},predicate:(e,t,o,r)=>{let n=r.scene.getSelectedElements(t);return n.length>0&&!n.some(i=>i.locked&&i.frameId)},perform:(e,t,o,r)=>{let n=r.scene.getSelectedElements({selectedElementIds:t.selectedElementIds,includeBoundTextElement:!0,includeElementsInFrames:!0});if(!n.length)return!1;let i=Ex(n),a=re(n);return{elements:e.map(l=>a.has(l.id)?ae(l,{locked:i}):l),appState:{...t,selectedLinearElement:i?null:t.selectedLinearElement},commitToHistory:!0}},keyTest:(e,t,o,r)=>e.key.toLocaleLowerCase()===I.L&&e[I.CTRL_OR_CMD]&&e.shiftKey&&r.scene.getSelectedElements({selectedElementIds:t.selectedElementIds,includeBoundTextElement:!1}).length>0}),c5=H({name:"unlockAllElements",paletteName:"Unlock all elements",trackEvent:{category:"canvas"},viewMode:!1,icon:Mi,predicate:(e,t)=>de(e,t).length===0&&e.some(r=>r.locked),perform:(e,t)=>{let o=e.filter(r=>r.locked);return{elements:e.map(r=>r.locked?ae(r,{locked:!1}):r),appState:{...t,selectedElementIds:Object.fromEntries(o.map(r=>[r.id,!0]))},commitToHistory:!0}},label:"labels.elementLock.unlockAll"})});import{useCallback as E7,useState as y7}from"react";var d5,m5=v(()=>{"use strict";f();d5=()=>{let[e,t]=y7(null),o=E7(r=>t(r),[]);return[e,o]}});var p5=v(()=>{});var u5=v(()=>{});import w7 from"react";import v7 from"clsx";import{jsx as T7}from"react/jsx-runtime";var oo,zi=v(()=>{"use strict";f();u5();oo=w7.forwardRef(({children:e,padding:t,className:o,style:r},n)=>T7("div",{className:v7("Island",o),style:{"--padding":t,...r},ref:n,children:e}))});var g5=v(()=>{});import{createPortal as C7}from"react-dom";import I7 from"clsx";import{useRef as S7}from"react";import{jsx as h5,jsxs as k7}from"react/jsx-runtime";var f5,b5=v(()=>{"use strict";f();g5();ue();Jb();f5=e=>{let{closeOnClickOutside:t=!0}=e,o=xu({className:"excalidraw-modal-container"}),r=S7(document.body.classList.contains("excalidraw-animations-disabled"));if(!o)return null;let n=i=>{i.key===I.ESCAPE&&(i.nativeEvent.stopImmediatePropagation(),i.stopPropagation(),e.onCloseRequest())};return C7(k7("div",{className:I7("Modal",e.className,{"animations-disabled":r.current}),role:"dialog","aria-modal":"true",onKeyDown:n,"aria-labelledby":e.labelledBy,"data-prevent-outside-click":!0,children:[h5("div",{className:"Modal__background",onClick:t?e.onCloseRequest:void 0}),h5("div",{className:"Modal__content",style:{"--max-width":`${e.maxWidth}px`},tabIndex:0,children:e.children})]}),o)}});import{atom as A7,useAtom as M7}from"jotai";import{useEffect as L7,useState as _7}from"react";var wx,x5,E5,Vu,xd=v(()=>{"use strict";f();Wo();Tt();Pa();wx=A7(new Map),x5=async e=>await ql({data:{elements:e,appState:{exportBackground:!1,viewBackgroundColor:ve.white},files:null},config:{}}),E5=(e,t,o)=>{let[r,n]=_7();return L7(()=>{if(t)if(e){let i=o.get(e);i?n(i):(async()=>{let a=await x5(t);a.querySelector(".style-fonts")?.remove(),a&&(o.set(e,a),n(a))})()}else(async()=>{let i=await x5(t);n(i)})()},[e,t,o,n]),r},Vu=()=>{let[e]=M7(wx,He);return{clearLibraryCache:()=>e.clear(),deleteItemsFromLibraryCache:r=>{r.forEach(n=>e.delete(n))},svgCache:e}}});var br,vx=v(()=>{"use strict";f();br=class{subscribers=[];on(...t){let o=t.flat().filter(r=>typeof r=="function");return this.subscribers.push(...o),()=>this.off(o)}once(...t){let o=t.flat().filter(n=>typeof n=="function");o.push(()=>r());let r=this.on(...o);return r}off(...t){let o=t.flat();this.subscribers=this.subscribers.filter(r=>!o.includes(r))}trigger(...t){for(let o of this.subscribers)o(...t);return this}clear(){this.subscribers=[]}}});var Yu,y5=v(()=>{"use strict";f();G();Yu=class{jobs=[];running=!1;tick(){if(this.running)return;let t=this.jobs.shift();t?(this.running=!0,t.promise.resolve($s(t.jobFactory,...t.args).finally(()=>{this.running=!1,this.tick()}))):this.running=!1}push(t,...o){let r=bm();return this.jobs.push({jobFactory:t,promise:r,args:o}),this.tick(),r}}});import{atom as P7}from"jotai";import{useEffect as w5,useRef as v5}from"react";var C5,Gi,Ed,D7,I5,S5,Tx,Ix,Xu,Cx,xs,yd,Ku,$u,T5,R7,el=v(()=>{"use strict";f();Co();Aa();Tt();bt();Ia();X();U();xd();G();vx();y5();he();C5=new br,Gi=P7({status:"loaded",isInitialized:!1,libraryItems:[]}),Ed=e=>Zr(e),D7=(e,t)=>!e.find(o=>o.elements.length!==t.elements.length?!1:o.elements.every((r,n)=>r.id===t.elements[n].id&&r.versionNonce===t.elements[n].versionNonce)),I5=(e,t)=>{let o=[];for(let r of t)D7(e,r)&&o.push(r);return[...o,...e]},S5=(e,t)=>{let o=re(t),r={deletedItems:new Map,addedItems:new Map};for(let i of e)o.has(i.id)||r.deletedItems.set(i.id,i);let n=re(e);for(let i of t)n.has(i.id)||r.addedItems.set(i.id,i);return r},Tx=class{currLibraryItems=[];prevLibraryItems=Ed(this.currLibraryItems);app;constructor(t){this.app=t}updateQueue=[];getLastUpdateTask=()=>this.updateQueue[this.updateQueue.length-1];notifyListeners=()=>{if(this.updateQueue.length>0)Zt.set(Gi,t=>({status:"loading",libraryItems:this.currLibraryItems,isInitialized:t.isInitialized}));else{Zt.set(Gi,{status:"loaded",libraryItems:this.currLibraryItems,isInitialized:!0});try{let t=this.prevLibraryItems;this.prevLibraryItems=Ed(this.currLibraryItems);let o=Ed(this.currLibraryItems);this.app.props.onLibraryChange?.(o),C5.trigger(S5(t,o),o)}catch(t){console.error(t)}}};destroy=()=>{this.updateQueue=[],this.currLibraryItems=[],Zt.set(wx,new Map)};resetLibrary=()=>this.setLibrary([]);getLatestLibrary=()=>new Promise(async t=>{try{let o=await(this.getLastUpdateTask()||this.currLibraryItems);this.updateQueue.length>0?t(this.getLatestLibrary()):t(Ed(o))}catch{return t(this.currLibraryItems)}});updateLibrary=async({libraryItems:t,prompt:o=!1,merge:r=!1,openLibraryMenu:n=!1,defaultStatus:i="unpublished"})=>(n&&this.app.setState({openSidebar:{name:Do.name,tab:Ws}}),this.setLibrary(()=>new Promise(async(a,l)=>{try{let s=await(typeof t=="function"&&!(t instanceof Blob)?t(this.currLibraryItems):t),c;s instanceof Blob?c=await Tf(s,i):c=ka(s,i),!o||window.confirm(b("alerts.confirmAddLibrary",{numShapes:c.length}))?(o&&this.app.focusContainer(),a(r?I5(this.currLibraryItems,c):c)):l(new rn)}catch(s){l(s)}})));setLibrary=t=>{let o=new Promise(async(r,n)=>{try{await this.getLastUpdateTask(),typeof t=="function"&&(t=t(this.currLibraryItems)),this.currLibraryItems=Ed(await t),r(this.currLibraryItems)}catch(i){n(i)}}).catch(r=>{if(r.name==="AbortError")return console.warn("Library update aborted by user"),this.currLibraryItems;throw r}).finally(()=>{this.updateQueue=this.updateQueue.filter(r=>r!==o),this.notifyListeners()});return this.updateQueue.push(o),this.notifyListeners(),o}},Ix=Tx,Xu=e=>{let o=Math.ceil(Math.sqrt(e.length)),r=[],n=u=>e.slice(u*o,u*o+o).reduce((x,E)=>{let{height:y}=vo(E.elements);return Math.max(x,y)},0),i=u=>{let g=0,x=0,E=0;for(let y of e){if(g%o===0&&(x=0),x===u){let{width:T}=vo(y.elements);E=Math.max(E,T)}g++,x++}return E},a=0,l=0,s=0,c=0,d=0,m=0,p=0;for(let u of e){d&&d%o===0&&(l+=s+50,a=0,m=0,p++),m===0&&(s=n(p)),c=i(m);let{minX:g,minY:x,width:E,height:y}=vo(u.elements),T=(c-E)/2,w=(s-y)/2;r.push(...u.elements.map(S=>({...S,x:S.x+a+T-g,y:S.y+l+w-x}))),a+=c+50,d++,m++}return r},Cx=()=>{let e=new URLSearchParams(window.location.hash.slice(1)).get(lm.addLibrary)||new URLSearchParams(window.location.search).get(am.addLibrary),t=e?new URLSearchParams(window.location.hash.slice(1)).get("token"):null;return e?{libraryUrl:e,idToken:t}:null},xs=class e{static queue=new Yu;static async getLibraryItems(t,o,r=!0){let n=()=>new Promise(async(i,a)=>{try{let l=await t.load({source:o});i(ka(l?.libraryItems||[],"published"))}catch(l){a(l)}});return r?e.queue.push(n):n()}static run=async(t,o)=>{let r=new e(t);return e.queue.push(()=>o(r))};adapter;constructor(t){this.adapter=t}getLibraryItems(t){return e.getLibraryItems(this.adapter,t,!1)}},yd=0,Ku=0,$u=e=>o1(e.map(t=>`${t.id}:${t1(t.elements)}`).sort().join()),T5=async(e,t)=>{try{return Ku++,await xs.run(e,async o=>{let r=re(await o.getLibraryItems("save"));for(let[l]of t.deletedItems)r.delete(l);let n=[];for(let[l,s]of t.addedItems)r.has(l)?r.set(l,s):n.push(s);let i=n.concat(Array.from(r.values())),a=$u(i);return a!==yd&&await e.save({libraryItems:i}),yd=a,i})}finally{Ku--}},R7=e=>{let{excalidrawAPI:t}=e,o=v5(e);o.current=e;let r=v5(!1);w5(()=>{if(!t)return;r.current=!1;let n=async({libraryUrl:l,idToken:s})=>{let c=new Promise(async(m,p)=>{try{let g=await(await fetch(decodeURIComponent(l))).blob();m(g)}catch(u){p(u)}}),d=s!==t.id;await(d&&document.hidden?new Promise(m=>{window.addEventListener("focus",()=>m(),{once:!0})}):null);try{await t.updateLibrary({libraryItems:c,prompt:d,merge:!0,defaultStatus:"published",openLibraryMenu:!0})}catch(m){throw m}finally{if(window.location.hash.includes(lm.addLibrary)){let m=new URLSearchParams(window.location.hash.slice(1));m.delete(lm.addLibrary),window.history.replaceState({},Fs,`#${m.toString()}`)}else if(window.location.search.includes(am.addLibrary)){let m=new URLSearchParams(window.location.search);m.delete(am.addLibrary),window.history.replaceState({},Fs,`?${m.toString()}`)}}},i=l=>{l.preventDefault();let s=Cx();s&&(l.stopImmediatePropagation(),window.history.replaceState({},"",l.oldURL),n(s))},a=Cx();if(a&&n(a),"getInitialLibraryItems"in o.current&&o.current.getInitialLibraryItems&&(console.warn("useHandleLibrar `opts.getInitialLibraryItems` is deprecated. Use `opts.adapter` instead."),Promise.resolve(o.current.getInitialLibraryItems()).then(l=>{t.updateLibrary({libraryItems:l,merge:!0})}).catch(l=>{console.error(`UseHandeLibrary getInitialLibraryItems failed: ${l?.message}`)})),"adapter"in o.current&&o.current.adapter){let l=o.current.adapter,s=o.current.migrationAdapter,c=bm();s?c.resolve($s(s.load).then(async d=>{let m=null;try{if(!d)return xs.getLibraryItems(l,"load");m=ka(d.libraryItems||[],"published");let p=await T5(l,S5([],m));try{await s.clear()}catch(u){console.error(`couldn't delete legacy library data: ${u.message}`)}return p}catch(p){return console.error(`couldn't migrate legacy library data: ${p.message}`),m}}).catch(d=>(console.error(`error during library migration: ${d.message}`),xs.getLibraryItems(l,"load")))):c.resolve($s(xs.getLibraryItems,l,"load")),t.updateLibrary({libraryItems:c.then(d=>{let m=d||[];return yd=$u(m),m}),merge:!0}).finally(()=>{r.current=!0})}return window.addEventListener("hashchange",i),()=>{window.removeEventListener("hashchange",i)}},[t]),w5(()=>{let n=C5.on(async(a,l)=>{let s=r.current,c="adapter"in o.current&&o.current.adapter||null;try{c&&yd!==$u(l)&&await T5(c,a)}catch(d){console.error(`couldn't persist library update: ${d.message}`,a),s&&o.current.excalidrawAPI&&o.current.excalidrawAPI.updateScene({appState:{errorMessage:b("errors.saveLibraryError")}})}}),i=a=>{Ku&&vy(a)};return window.addEventListener("beforeunload",i),()=>{window.removeEventListener("beforeunload",i),n(),yd=0,Ku=0}},[])}});var k5=v(()=>{});import{forwardRef as A5}from"react";import M5 from"clsx";import{jsx as L5}from"react/jsx-runtime";var N7,O7,Yt,tl=v(()=>{"use strict";f();k5();N7=A5(({children:e,gap:t,align:o,justifyContent:r,className:n,style:i},a)=>L5("div",{className:M5("Stack Stack_horizontal",n),style:{"--gap":t,alignItems:o,justifyContent:r,...i},ref:a,children:e})),O7=A5(({children:e,gap:t,align:o,justifyContent:r,className:n,style:i},a)=>L5("div",{className:M5("Stack Stack_vertical",n),style:{"--gap":t,justifyItems:o,justifyContent:r,...i},ref:a,children:e})),Yt={Row:N7,Col:O7}});import{jsx as F7}from"react/jsx-runtime";var B7,_5,P5=v(()=>{"use strict";f();U();X();B7=({theme:e,id:t,libraryReturnUrl:o})=>{let r=o||window.location.origin+window.location.pathname;return F7("a",{className:"library-menu-browse-button",href:`${C.VITE_APP_LIBRARY_URL}?target=${window.name||"_blank"}&referrer=${r}&useHash=true&token=${t}&theme=${e}&version=${sa.excalidrawLibrary}`,target:"_excalidraw_libraries",children:b("labels.libraries")})},_5=B7});import H7 from"clsx";import{jsx as z7,jsxs as G7}from"react/jsx-runtime";var Zu,Sx=v(()=>{"use strict";f();P5();Zu=({libraryReturnUrl:e,theme:t,id:o,style:r,children:n,className:i})=>G7("div",{className:H7("library-menu-control-buttons",i),style:r,children:[z7(_5,{id:o,libraryReturnUrl:e,theme:t}),n]})});import ju from"react";var U7,W7,V7,Y7,K7,$7,uo,Es=v(()=>{"use strict";f();X();U7=/({{[\w-]+}})|(<[\w-]+>)|(<\/[\w-]+>)/g,W7=/{{([\w-]+)}}/,V7=/<([\w-]+)>/,Y7=/<\/([\w-]+)>/,K7=(e,t)=>{let o=[{name:"",children:[]}];return e.split(U7).filter(Boolean).forEach(r=>{let n=r.match(V7),i=r.match(Y7),a=r.match(W7);if(n!==null){let l=n[1];t.hasOwnProperty(l)?o.push({name:l,children:[]}):console.warn(`Trans: missed to pass in prop ${l} for interpolating ${e}`)}else if(i!==null)if(i[1]===o[o.length-1].name){let s=o.pop(),c=ju.createElement(ju.Fragment,{},...s.children),d=t[s.name];typeof d=="function"&&o[o.length-1].children.push(d(c))}else console.warn(`Trans: unexpected end tag ${r} for interpolating ${e}`);else if(a!==null){let l=a[1];t.hasOwnProperty(l)?o[o.length-1].children.push(t[l]):console.warn(`Trans: key ${l} not in props for interpolating ${e}`)}else o[o.length-1].children.push(r)}),o.length!==1&&console.warn(`Trans: stack not empty for interpolating ${e}`),o[0].children},$7=({i18nKey:e,children:t,...o})=>{let{t:r}=Ct();return ju.createElement(ju.Fragment,{},...K7(r(e),o))},uo=$7});var D5=v(()=>{});var R5=v(()=>{});import X7 from"clsx";import{jsx as qu,jsxs as j7}from"react/jsx-runtime";var Z7,ys,kx=v(()=>{"use strict";f();R5();In();Z7=({label:e,onClick:t,className:o,children:r,actionType:n,type:i="button",isLoading:a,...l})=>{let s=n?`Dialog__action-button--${n}`:"";return j7("button",{className:X7("Dialog__action-button",s,o),type:i,"aria-label":e,onClick:t,...l,children:[r&&qu("div",{style:a?{visibility:"hidden"}:{},children:r}),qu("div",{style:a?{visibility:"hidden"}:{},children:e}),a&&qu("div",{style:{position:"absolute",inset:0},children:qu(jt,{})})]})},ys=Z7});import{useSetAtom as q7}from"jotai";import{jsx as N5,jsxs as O5}from"react/jsx-runtime";var J7,Ju,Ax=v(()=>{"use strict";f();X();jo();D5();kx();wd();ye();Tt();J7=e=>{let{onConfirm:t,onCancel:o,children:r,confirmText:n=b("buttons.confirm"),cancelText:i=b("buttons.cancel"),className:a="",...l}=e,s=Be(),c=q7(ws,He),{container:d}=Wt();return O5(gt,{onCloseRequest:o,size:"small",...l,className:`confirm-dialog ${a}`,children:[r,O5("div",{className:"confirm-dialog-buttons",children:[N5(ys,{label:i,onClick:()=>{s({openMenu:null}),c(!1),o(),d?.focus()}}),N5(ys,{label:n,onClick:()=>{s({openMenu:null}),c(!1),t(),d?.focus()},actionType:"danger"})]})]})},Ju=J7});var Mo,vd=v(()=>{"use strict";f();Mo=class{static has(t){try{return!!window.localStorage.getItem(t)}catch(o){return console.warn(`localStorage.getItem error: ${o.message}`),!1}}static get(t){try{let o=window.localStorage.getItem(t);return o?JSON.parse(o):null}catch(o){return console.warn(`localStorage.getItem error: ${o.message}`),null}}static set=(t,o)=>{try{return window.localStorage.setItem(t,JSON.stringify(o)),!0}catch(r){return console.warn(`localStorage.setItem error: ${r.message}`),!1}};static delete=t=>{try{window.localStorage.removeItem(t)}catch(o){console.warn(`localStorage.removeItem error: ${o.message}`)}}}});var B5=v(()=>{});import{useCallback as Q7,useEffect as Lx,useRef as F5,useState as Mx}from"react";import H5 from"open-color";import{jsx as Ie,jsxs as lo}from"react/jsx-runtime";var e_,t_,o_,z5,G5=v(()=>{"use strict";f();jo();X();Es();Pa();U();Co();G();kx();ee();Mt();vd();B5();e_=async e=>{let r=Math.round(8),n=Math.max(Math.round(128/64),2),i=Ey(e,6),a=document.createElement("canvas");a.width=i[0].length*128+(i[0].length+1)*(r*2)-r*2,a.height=i.length*128+(i.length+1)*(r*2)-r*2;let l=a.getContext("2d");l.fillStyle=Ht,l.fillRect(0,0,a.width,a.height);for(let[s,c]of e.entries()){let d=await Sp({data:{elements:c.elements,files:null},config:{maxWidthOrHeight:128}}),{width:m,height:p}=d,u=Math.floor(s/6)*(128+r*2),g=s%6*(128+r*2);l.drawImage(d,g+(128-m)/2+r,u+(128-p)/2+r),l.lineWidth=n,l.strokeStyle=H5.gray[4],l.strokeRect(g+r/2,u+r/2,128+r,128+r)}return await Ac(new File([await Yn(a)],"preview",{type:J.png}),{outputType:J.jpg,maxWidthOrHeight:5e3})},t_=({libItem:e,appState:t,index:o,onChange:r,onRemove:n})=>{let i=F5(null),a=F5(null);return Lx(()=>{let l=i.current;l&&(async()=>{let s=await ql({data:{elements:e.elements,appState:{...t,viewBackgroundColor:Ht,exportBackground:!0},files:null}});l.innerHTML=s.outerHTML})()},[e.elements,t]),lo("div",{className:"single-library-item",children:[e.status==="published"&&Ie("span",{className:"single-library-item-status",children:b("labels.statusPublished")}),Ie("div",{ref:i,className:"single-library-item__svg"}),Ie(ce,{"aria-label":b("buttons.remove"),type:"button",icon:Yo,className:"single-library-item--remove",onClick:n.bind(null,e.id),title:b("buttons.remove")}),lo("div",{style:{display:"flex",margin:"0.8rem 0",width:"100%",fontSize:"14px",fontWeight:500,flexDirection:"column"},children:[lo("label",{style:{display:"flex",justifyContent:"space-between",flexDirection:"column"},children:[lo("div",{style:{padding:"0.5em 0"},children:[Ie("span",{style:{fontWeight:500,color:H5.gray[6]},children:b("publishDialog.itemName")}),Ie("span",{"aria-hidden":"true",className:"required",children:"*"})]}),Ie("input",{type:"text",ref:a,style:{width:"80%",padding:"0.2rem"},defaultValue:e.name,placeholder:"Item name",onChange:l=>{r(l.target.value,o)}})]}),Ie("span",{className:"error",children:e.error})]})]})},o_=({onClose:e,libraryItems:t,appState:o,onSuccess:r,onError:n,updateItemsInStorage:i,onRemove:a})=>{let[l,s]=Mx({authorName:"",githubHandle:"",name:"",description:"",twitterHandle:"",website:""}),[c,d]=Mx(!1);Lx(()=>{let w=Mo.get(or.PUBLISH_LIBRARY);w&&s(w)},[]);let[m,p]=Mx(t.slice());Lx(()=>{p(t.slice())},[t]);let u=w=>{s({...l,[w.target.name]:w.target.value})},g=async w=>{w.preventDefault(),d(!0);let S=[],M=!1;if(m.forEach(L=>{let A="";L.name||(A=b("publishDialog.errors.required"),M=!0),S.push({...L,error:A})}),M){p(S),d(!1);return}let k=await e_(m),R={type:ro.excalidrawLibrary,version:sa.excalidrawLibrary,source:Us,libraryItems:m},P=JSON.stringify(R,null,2),F=new Blob([P],{type:"application/json"}),D=new FormData;D.append("excalidrawLib",F),D.append("previewImage",k),D.append("previewImageType",k.type),D.append("title",l.name),D.append("authorName",l.authorName),D.append("githubHandle",l.githubHandle),D.append("name",l.name),D.append("description",l.description),D.append("twitterHandle",l.twitterHandle),D.append("website",l.website),fetch(`${C.VITE_APP_LIBRARY_BACKEND}/submit`,{method:"post",body:D}).then(L=>L.ok?L.json().then(({url:A})=>{Mo.delete(or.PUBLISH_LIBRARY),r({url:A,authorName:l.authorName,items:m})}):L.json().catch(()=>{throw new Error(L.statusText||"something went wrong")}).then(A=>{throw new Error(A.message||L.statusText||"something went wrong")}),L=>{console.error(L),n(L),d(!1)}).catch(L=>{console.error(L),n(L),d(!1)})},x=()=>{let w=[];return m.forEach((S,M)=>{w.push(Ie("div",{className:"single-library-item-wrapper",children:Ie(t_,{libItem:S,appState:o,index:M,onChange:(k,R)=>{let P=m.slice();P[R].name=k,p(P)},onRemove:a})},M))}),Ie("div",{className:"selected-library-items",children:w})},E=Q7(()=>{i(m),Mo.set(or.PUBLISH_LIBRARY,l),e()},[m,e,i,l]),y=!!t.length,T=t.some(w=>w.status==="published");return Ie(gt,{onCloseRequest:E,title:b("publishDialog.title"),className:"publish-library",children:y?lo("form",{onSubmit:g,children:[Ie("div",{className:"publish-library-note",children:Ie(uo,{i18nKey:"publishDialog.noteDescription",link:w=>Ie("a",{href:"https://libraries.excalidraw.com",target:"_blank",rel:"noopener noreferrer",children:w})})}),Ie("span",{className:"publish-library-note",children:Ie(uo,{i18nKey:"publishDialog.noteGuidelines",link:w=>Ie("a",{href:"https://github.com/excalidraw/excalidraw-libraries#guidelines",target:"_blank",rel:"noopener noreferrer",children:w})})}),Ie("div",{className:"publish-library-note",children:b("publishDialog.noteItems")}),T&&Ie("span",{className:"publish-library-note publish-library-warning",children:b("publishDialog.republishWarning")}),x(),lo("div",{className:"publish-library__fields",children:[lo("label",{children:[lo("div",{children:[Ie("span",{children:b("publishDialog.libraryName")}),Ie("span",{"aria-hidden":"true",className:"required",children:"*"})]}),Ie("input",{type:"text",name:"name",required:!0,value:l.name,onChange:u,placeholder:b("publishDialog.placeholder.libraryName")})]}),lo("label",{style:{alignItems:"flex-start"},children:[lo("div",{children:[Ie("span",{children:b("publishDialog.libraryDesc")}),Ie("span",{"aria-hidden":"true",className:"required",children:"*"})]}),Ie("textarea",{name:"description",rows:4,required:!0,value:l.description,onChange:u,placeholder:b("publishDialog.placeholder.libraryDesc")})]}),lo("label",{children:[lo("div",{children:[Ie("span",{children:b("publishDialog.authorName")}),Ie("span",{"aria-hidden":"true",className:"required",children:"*"})]}),Ie("input",{type:"text",name:"authorName",required:!0,value:l.authorName,onChange:u,placeholder:b("publishDialog.placeholder.authorName")})]}),lo("label",{children:[Ie("span",{children:b("publishDialog.githubUsername")}),Ie("input",{type:"text",name:"githubHandle",value:l.githubHandle,onChange:u,placeholder:b("publishDialog.placeholder.githubHandle")})]}),lo("label",{children:[Ie("span",{children:b("publishDialog.twitterUsername")}),Ie("input",{type:"text",name:"twitterHandle",value:l.twitterHandle,onChange:u,placeholder:b("publishDialog.placeholder.twitterHandle")})]}),lo("label",{children:[Ie("span",{children:b("publishDialog.website")}),Ie("input",{type:"text",name:"website",pattern:"https?://.+",title:b("publishDialog.errors.website"),value:l.website,onChange:u,placeholder:b("publishDialog.placeholder.website")})]}),Ie("span",{className:"publish-library-note",children:Ie(uo,{i18nKey:"publishDialog.noteLicense",link:w=>Ie("a",{href:"https://github.com/excalidraw/excalidraw-libraries/blob/main/LICENSE",target:"_blank",rel:"noopener noreferrer",children:w})})})]}),lo("div",{className:"publish-library__buttons",children:[Ie(ys,{label:b("buttons.cancel"),onClick:E,"data-testid":"cancel-clear-canvas-button"}),Ie(ys,{type:"submit",label:b("buttons.submit"),actionType:"primary",isLoading:c})]})]}):Ie("p",{style:{padding:"1em",textAlign:"center",fontWeight:500},children:b("publishDialog.atleastOneLibItem")})})},z5=o_});import r_ from"clsx";import{jsx as n_}from"react/jsx-runtime";var U5,W5,V5=v(()=>{"use strict";f();ye();U5=({className:e="",children:t,onToggle:o,title:r,...n})=>{let i=_e(),a=r_(`dropdown-menu-button ${e}`,"zen-mode-transition",{"dropdown-menu-button--mobile":i.editor.isMobile}).trim();return n_("button",{"data-prevent-outside-click":!0,className:a,onClick:o,type:"button","data-testid":"dropdown-menu-button",title:r,...n,children:t})},W5=U5;U5.displayName="DropdownMenuTrigger"});import i_,{useContext as a_}from"react";var _x,Qu,eg,tg=v(()=>{"use strict";f();U();G();_x=i_.createContext({}),Qu=(e="",t=!1)=>`dropdown-menu-item dropdown-menu-item-base ${e} ${t?"dropdown-menu-item--selected":""}`.trim(),eg=(e,t)=>{let o=a_(_x);return di(e,r=>{let n=new CustomEvent("menu.itemSelect",{bubbles:!0,cancelable:!0});t?.(n),n.defaultPrevented||o.onSelect?.(n)})}});import{Fragment as s_,jsx as Px,jsxs as c_}from"react/jsx-runtime";var l_,og,Dx=v(()=>{"use strict";f();ye();l_=({icon:e,shortcut:t,children:o})=>{let r=_e();return c_(s_,{children:[Px("div",{className:"dropdown-menu-item__icon",children:e}),Px("div",{className:"dropdown-menu-item__text",children:o}),t&&!r.editor.isMobile&&Px("div",{className:"dropdown-menu-item__shortcut",children:t})]})},og=l_});import{jsx as Rx}from"react/jsx-runtime";var Nx,Y5,xr,Ox=v(()=>{"use strict";f();tg();Dx();Nx=({icon:e,onSelect:t,children:o,shortcut:r,className:n,selected:i,...a})=>{let l=eg(a.onClick,t);return Rx("button",{...a,onClick:l,type:"button",className:Qu(n,i),title:a.title??a["aria-label"],children:Rx(og,{icon:e,shortcut:r,children:o})})};Nx.displayName="DropdownMenuItem";Y5=({children:e})=>Rx("div",{style:{display:"inline-flex",marginLeft:"auto",padding:"2px 4px",background:"pink",borderRadius:6,fontSize:9,color:"black",fontFamily:"Cascadia, monospace"},children:e});Y5.displayName="DropdownMenuItemBadge";Nx.Badge=Y5;xr=Nx});import{jsx as d_}from"react/jsx-runtime";var K5,$5,X5=v(()=>{"use strict";f();K5=()=>d_("div",{style:{height:"1px",backgroundColor:"var(--default-border-color)",margin:".5rem 0"}}),$5=K5;K5.displayName="DropdownMenuSeparator"});import{jsx as m_,jsxs as p_}from"react/jsx-runtime";var Z5,j5,q5=v(()=>{"use strict";f();Z5=({children:e,className:t="",style:o,title:r})=>p_("div",{className:`dropdown-menu-group ${t}`,style:o,children:[r&&m_("p",{className:"dropdown-menu-group-title",children:r}),e]}),j5=Z5;Z5.displayName="DropdownMenuGroup"});import u_ from"clsx";import{useEffect as g_,useRef as h_}from"react";import{jsx as rg}from"react/jsx-runtime";var J5,Q5,eC=v(()=>{"use strict";f();zi();ye();tl();tg();Eu();ue();U();yu();J5=({children:e,onClickOutside:t,className:o="",onSelect:r,style:n})=>{let i=_e(),a=h_(null),l=ds({onClickOutside:t});cs(a,()=>{l.onClickOutside?.()}),g_(()=>{let c=m=>{m.key===I.ESCAPE&&(m.stopImmediatePropagation(),l.onClickOutside?.())},d={capture:!0};return document.addEventListener("keydown",c,d),()=>{document.removeEventListener("keydown",c,d)}},[l]);let s=u_(`dropdown-menu ${o}`,{"dropdown-menu--mobile":i.editor.isMobile}).trim();return rg(_x.Provider,{value:{onSelect:r},children:rg("div",{ref:a,className:s,style:n,"data-testid":"dropdown-menu",children:i.editor.isMobile?rg(Yt.Col,{className:"dropdown-menu-container",children:e}):rg(oo,{className:"dropdown-menu-container",padding:2,style:{zIndex:2},children:e})})})};J5.displayName="DropdownMenuContent";Q5=J5});import{jsx as tC}from"react/jsx-runtime";var oC,vs,Bx=v(()=>{"use strict";f();Dx();tg();oC=({icon:e,shortcut:t,href:o,children:r,onSelect:n,className:i="",selected:a,...l})=>{let s=eg(l.onClick,n);return tC("a",{...l,href:o,target:"_blank",rel:"noreferrer",className:Qu(i,a),title:l.title??l["aria-label"],onClick:s,children:tC(og,{icon:e,shortcut:t,children:r})})},vs=oC;oC.displayName="DropdownMenuItemLink"});import{jsx as b_}from"react/jsx-runtime";var f_,rC,nC=v(()=>{"use strict";f();f_=({children:e,className:t="",selected:o,...r})=>b_("div",{...r,className:`dropdown-menu-item-base dropdown-menu-item-custom ${t} ${o?"dropdown-menu-item--selected":""}`.trim(),children:e}),rC=f_});import ng from"react";var iC,aC,lC=v(()=>{"use strict";f();iC=e=>{let t=ng.Children.toArray(e).find(o=>ng.isValidElement(o)&&typeof o.type!="string"&&o?.type.displayName&&o.type.displayName==="DropdownMenuTrigger");return t||null},aC=e=>{let t=ng.Children.toArray(e).find(o=>ng.isValidElement(o)&&typeof o.type!="string"&&o?.type.displayName&&o.type.displayName==="DropdownMenuContent");return t||null}});var sC=v(()=>{});import{Fragment as x_,jsxs as E_}from"react/jsx-runtime";var ei,Ge,Td=v(()=>{"use strict";f();V5();Ox();X5();q5();eC();Bx();nC();lC();sC();ei=({children:e,open:t})=>{let o=iC(e),r=aC(e);return E_(x_,{children:[o,t&&r]})};ei.Trigger=W5;ei.Content=Q5;ei.Item=xr;ei.ItemLink=vs;ei.ItemCustom=rC;ei.Group=j5;ei.Separator=$5;Ge=ei;ei.displayName="DropdownMenu"});import{useCallback as y_,useState as Fx}from"react";import{useAtom as Hx}from"jotai";import w_ from"clsx";import{jsx as Lo,jsxs as ig}from"react/jsx-runtime";var v_,T_,zx,cC=v(()=>{"use strict";f();X();Es();Tt();ye();Kn();el();ee();Mt();Wn();G();Ax();G5();jo();Td();wd();Vt();xd();v_=(e,t)=>e.filter(o=>t.includes(o.id)),T_=({setAppState:e,selectedItems:t,library:o,onRemoveFromLibrary:r,resetLibrary:n,onSelectItems:i,appState:a,className:l})=>{let[s]=Hx(Gi,He),[c,d]=Hx(ws,He),m=()=>{let D=t.length?b("alerts.removeItemsFromsLibrary",{count:t.length}):b("alerts.resetLibrary"),L=t.length?b("confirmDialog.removeItemsFromLib"):b("confirmDialog.resetLibrary");return Lo(Ju,{onConfirm:()=>{t.length?r():n(),u(!1)},onCancel:()=>{u(!1)},title:L,children:Lo("p",{children:D})})},[p,u]=Fx(!1),g=!!t.length,x=g?s.libraryItems.filter(D=>t.includes(D.id)):s.libraryItems,E=g?b("buttons.remove"):b("buttons.resetLibrary"),[y,T]=Fx(!1),[w,S]=Fx(null),M=y_(()=>ig(gt,{onCloseRequest:()=>S(null),title:b("publishSuccessDialog.title"),className:"publish-library-success",size:"small",children:[Lo("p",{children:Lo(uo,{i18nKey:"publishSuccessDialog.content",authorName:w.authorName,link:D=>Lo("a",{href:w?.url,target:"_blank",rel:"noopener noreferrer",children:D})})}),Lo(ce,{type:"button",title:b("buttons.close"),"aria-label":b("buttons.close"),label:b("buttons.close"),onClick:()=>S(null),"data-testid":"publish-library-success-close",className:"publish-library-success-close"})]}),[S,w]),k=(D,L)=>{T(!1),S({url:D.url,authorName:D.authorName});let A=L.slice();A.forEach(B=>{t.includes(B.id)&&(B.status="published")}),o.setLibrary(A)},R=async()=>{try{await o.updateLibrary({libraryItems:Fl({description:"Excalidraw library files"}),merge:!0,openLibraryMenu:!0})}catch(D){if(D?.name==="AbortError"){console.warn(D);return}e({errorMessage:b("errors.importLibraryError")})}},P=async()=>{let D=g?x:await o.getLatestLibrary();Tw(D).catch(fm).catch(L=>{e({errorMessage:L.message})})},F=()=>ig(Ge,{open:c,children:[Lo(Ge.Trigger,{onToggle:()=>d(!c),children:d1}),ig(Ge.Content,{onClickOutside:()=>d(!1),onSelect:()=>d(!1),className:"library-menu",children:[!g&&Lo(Ge.Item,{onSelect:R,icon:Ga,"data-testid":"lib-dropdown--load",children:b("buttons.load")}),!!x.length&&Lo(Ge.Item,{onSelect:P,icon:Li,"data-testid":"lib-dropdown--export",children:b("buttons.export")}),!!x.length&&Lo(Ge.Item,{onSelect:()=>u(!0),icon:ur,children:E}),g&&Lo(Ge.Item,{icon:Eb,onSelect:()=>T(!0),"data-testid":"lib-dropdown--remove",children:b("buttons.publishLibrary")})]})]});return ig("div",{className:w_("library-menu-dropdown-container",l),children:[F(),t.length>0&&Lo("div",{className:"library-actions-counter",children:t.length}),p&&m(),y&&Lo(z5,{onClose:()=>T(!1),libraryItems:v_(s.libraryItems,t),appState:a,onSuccess:D=>k(D,s.libraryItems),onError:D=>window.alert(D),updateItemsInStorage:()=>o.setLibrary(s.libraryItems),onRemove:D=>i(t.filter(L=>L!==D))}),w&&M()]})},zx=({selectedItems:e,onSelectItems:t,className:o})=>{let{library:r}=ko(),{clearLibraryCache:n,deleteItemsFromLibraryCache:i}=Vu(),a=Re(),l=Be(),[s]=Hx(Gi,He),c=async m=>{let p=m.filter(u=>!e.includes(u.id));r.setLibrary(p).catch(()=>{l({errorMessage:b("alerts.errorRemovingFromLibrary")})}),i(e),t([])};return Lo(T_,{appState:a,setAppState:l,selectedItems:e,onSelectItems:t,library:r,onRemoveFromLibrary:()=>c(s.libraryItems),resetLibrary:()=>{r.resetLibrary(),n()},className:o})}});var dC=v(()=>{});import mC from"clsx";import{memo as C_,useEffect as I_,useRef as S_,useState as k_}from"react";import{jsx as ag,jsxs as A_}from"react/jsx-runtime";var pC,uC,gC=v(()=>{"use strict";f();ye();dC();Su();ee();xd();pC=C_(({id:e,elements:t,isPending:o,onClick:r,selected:n,onToggle:i,onDrag:a,svgCache:l})=>{let s=S_(null),c=E5(e,t,l);I_(()=>{let g=s.current;if(g)return c&&(g.innerHTML=c.outerHTML),()=>{g.innerHTML=""}},[c]);let[d,m]=k_(!1),p=_e().editor.isMobile,u=o&&ag("div",{className:"library-unit__adder",children:c1});return A_("div",{className:mC("library-unit",{"library-unit__active":t,"library-unit--hover":t&&d,"library-unit--selected":n,"library-unit--skeleton":!c}),onMouseEnter:()=>m(!0),onMouseLeave:()=>m(!1),children:[ag("div",{className:mC("library-unit__dragger",{"library-unit__pulse":!!o}),ref:s,draggable:!!t,onClick:t||o?g=>{e&&g.shiftKey?i(e,g):r(e)}:void 0,onDragStart:g=>{if(!e){g.preventDefault();return}m(!1),a(e,g)}}),u,e&&t&&(d||p||n)&&ag(Za,{checked:n,onChange:(g,x)=>i(e,x),className:"library-unit__checkbox"})]})}),uC=()=>ag("div",{className:"library-unit library-unit--skeleton"})});import M_,{useCallback as L_}from"react";function __(){return[!1,L_(t=>t(),[])]}var hC,fC=v(()=>{"use strict";f();hC=M_.useTransition||__});import{memo as P_,useEffect as D_,useState as R_}from"react";import{Fragment as N_,jsx as lg}from"react/jsx-runtime";var Gx,sg,bC=v(()=>{"use strict";f();gC();fC();Gx=({children:e})=>lg("div",{className:"library-menu-items-container__grid",children:e}),sg=P_(({items:e,onItemSelectToggle:t,onItemDrag:o,isItemSelected:r,onClick:n,svgCache:i,itemsRenderedPerBatch:a})=>{let[,l]=hC(),[s,c]=R_(0);return D_(()=>{s<e.length&&l(()=>{c(s+a)})},[s,e.length,l,a]),lg(N_,{children:e.map((d,m)=>m<s?lg(pC,{elements:d?.elements,isPending:!d?.id&&!!d?.elements,onClick:n,svgCache:i,id:d?.id,selected:r(d.id),onToggle:t,onDrag:o},d?.id??m):lg(uC,{},m))})})});import{useEffect as O_}from"react";import{atom as B_,useAtom as F_}from"jotai";import H_ from"lodash.throttle";var z_,xC,EC=v(()=>{"use strict";f();z_=B_(0),xC=e=>{let[t,o]=F_(z_);return O_(()=>{let{current:r}=e;if(!r)return;let n=H_(()=>{let{scrollTop:i}=r;o(i)},200);return r.addEventListener("scroll",n),()=>{n.cancel(),r.removeEventListener("scroll",n)}},[e,o]),t}});var yC=v(()=>{});import{useCallback as Ts,useEffect as G_,useMemo as wC,useRef as U_,useState as W_}from"react";import{Fragment as vC,jsx as _o,jsxs as Cs}from"react/jsx-runtime";function Ux({isLoading:e,libraryItems:t,onAddToLibrary:o,onInsertLibraryItems:r,pendingElements:n,theme:i,id:a,libraryReturnUrl:l,onSelectItems:s,selectedItems:c}){let d=U_(null),m=xC(d);G_(()=>{m>0&&d.current?.scrollTo(0,m)},[]);let{svgCache:p}=Vu(),u=wC(()=>t.filter(D=>D.status!=="published"),[t]),g=wC(()=>t.filter(D=>D.status==="published"),[t]),x=!t.length&&!n.length,E=!n.length&&!u.length&&!g.length,[y,T]=W_(null),w=Ts((D,L)=>{let A=!c.includes(D),B=[...u,...g];if(A){if(L.shiftKey&&y){let j=B.findIndex(Te=>Te.id===y),Y=B.findIndex(Te=>Te.id===D);if(j===-1||Y===-1){s([...c,D]);return}let oe=re(c),Ce=B.reduce((Te,K,ge)=>((ge>=j&&ge<=Y||oe.has(K.id))&&Te.push(K.id),Te),[]);s(Ce)}else s([...c,D]);T(D)}else T(null),s(c.filter(j=>j!==D))},[y,s,g,c,u]),S=Ts(D=>{let L;return c.includes(D)?L=t.filter(A=>c.includes(A.id)):L=t.filter(A=>A.id===D),L.map(A=>({...A,elements:yc(A.elements,{randomizeSeed:!0})}))},[t,c]),M=Ts((D,L)=>{L.dataTransfer.setData(J.excalidrawlib,ap(S(D)))},[S]),k=Ts(D=>D?c.includes(D):!1,[c]),R=Ts(()=>{o(n)},[n,o]),P=Ts(D=>{D&&r(S(D))},[S,r]),F=p.size>=t.length?Y_:V_;return Cs("div",{className:"library-menu-items-container",style:n.length||u.length||g.length?{justifyContent:"flex-start"}:{borderBottom:0},children:[!E&&_o(zx,{selectedItems:c,onSelectItems:s,className:"library-menu-dropdown-container--in-heading"}),Cs(Yt.Col,{className:"library-menu-items-container__items",align:"start",gap:1,style:{flex:g.length>0?1:"0 1 auto",marginBottom:0},ref:d,children:[Cs(vC,{children:[!E&&_o("div",{className:"library-menu-items-container__header",children:b("labels.personalLib")}),e&&_o("div",{style:{position:"absolute",top:"var(--container-padding-y)",right:"var(--container-padding-x)",transform:"translateY(50%)"},children:_o(jt,{})}),!n.length&&!u.length?Cs("div",{className:"library-menu-items__no-items",children:[_o("div",{className:"library-menu-items__no-items__label",children:b("library.noItems")}),_o("div",{className:"library-menu-items__no-items__hint",children:g.length>0?b("library.hint_emptyPrivateLibrary"):b("library.hint_emptyLibrary")})]}):Cs(Gx,{children:[n.length>0&&_o(sg,{itemsRenderedPerBatch:F,items:[{id:null,elements:n}],onItemSelectToggle:w,onItemDrag:M,onClick:R,isItemSelected:k,svgCache:p}),_o(sg,{itemsRenderedPerBatch:F,items:u,onItemSelectToggle:w,onItemDrag:M,onClick:P,isItemSelected:k,svgCache:p})]})]}),Cs(vC,{children:[(g.length>0||n.length>0||u.length>0)&&_o("div",{className:"library-menu-items-container__header library-menu-items-container__header--excal",children:b("labels.excalidrawLib")}),g.length>0?_o(Gx,{children:_o(sg,{itemsRenderedPerBatch:F,items:g,onItemSelectToggle:w,onItemDrag:M,onClick:P,isItemSelected:k,svgCache:p})}):u.length>0?_o("div",{style:{margin:"1rem 0",display:"flex",flexDirection:"column",alignItems:"center",justifyContent:"center",width:"100%",fontSize:".9rem"},children:b("library.noItems")}):null]}),x&&_o(Zu,{style:{padding:"16px 0",width:"100%"},id:a,libraryReturnUrl:l,theme:i,children:_o(zx,{selectedItems:c,onSelectItems:s})})]})]})}var V_,Y_,TC=v(()=>{"use strict";f();Kn();X();G();tl();U();In();on();Sx();cC();bC();EC();xd();yC();V_=17,Y_=64});var CC=v(()=>{});import{useState as K_,useCallback as Vx,useMemo as kC,useRef as Wx}from"react";import{atom as $_,useAtom as X_}from"jotai";import{jsx as Ui,jsxs as SC}from"react/jsx-runtime";var ws,IC,Z_,j_,AC,wd=v(()=>{"use strict";f();el();X();Sr();TC();So();Tt();In();ye();We();Vt();CC();Sx();G();U();ws=$_(!1),IC=({children:e})=>Ui("div",{className:"layer-ui__library",children:e}),Z_=({onInsertLibraryItems:e,pendingElements:t,onAddToLibrary:o,setAppState:r,libraryReturnUrl:n,library:i,id:a,theme:l,selectedItems:s,onSelectItems:c})=>{let[d]=X_(Gi,He),m=Vx(g=>{(async(E,y)=>{we("element","addToLibrary","ui");for(let w of mm)if(E.some(S=>S.type===w))return r({errorMessage:b(`errors.libraryElementTypeError.${w}`)});let T=[{status:"unpublished",elements:E,id:Bt(),created:Date.now()},...y];o(),i.setLibrary(T).catch(()=>{r({errorMessage:b("alerts.errorAddingToLibrary")})})})(g,d.libraryItems)},[o,i,r,d.libraryItems]),p=kC(()=>d.libraryItems,[d]);if(d.status==="loading"&&!d.isInitialized)return Ui(IC,{children:Ui("div",{className:"layer-ui__library-message",children:SC("div",{children:[Ui(jt,{size:"2em"}),Ui("span",{children:b("labels.libraryLoadingMessage")})]})})});let u=d.libraryItems.length>0||t.length>0;return SC(IC,{children:[Ui(Ux,{isLoading:d.status==="loading",libraryItems:p,onAddToLibrary:m,onInsertLibraryItems:e,pendingElements:t,id:a,libraryReturnUrl:n,theme:l,onSelectItems:c,selectedItems:s}),u&&Ui(Zu,{className:"library-menu-control-buttons--at-bottom",style:{padding:"16px 12px 0 12px"},id:a,libraryReturnUrl:n,theme:l})]})},j_=(e,t)=>{let o=()=>de(t,e,{includeBoundTextElement:!0,includeElementsInFrames:!0}),r=Wx(o()),n=Wx(e),i=Wx(t);return(!It(e.selectedElementIds,n.current.selectedElementIds)||!It(t,i.current))&&(r.current=o(),n.current=e,i.current=t),r.current},AC=()=>{let{library:e,id:t,onInsertElements:o}=ko(),r=Hi(),n=Re(),i=Be(),a=Di(),[l,s]=K_([]),c=kC(()=>e,[e]),d=j_(n,a),m=Vx(u=>{o(Xu(u))},[o]),p=Vx(()=>{i({selectedElementIds:{},selectedGroupIds:{},activeEmbeddable:null})},[i]);return Ui(Z_,{pendingElements:d,onInsertLibraryItems:m,onAddToLibrary:p,setAppState:i,libraryReturnUrl:r.libraryReturnUrl,library:c,id:t,theme:n.theme,selectedItems:l,onSelectItems:s})}});import q_ from"clsx";import{useEffect as J_,useState as Q_}from"react";import{useSetAtom as eP}from"jotai";import{jsx as Cd,jsxs as oP}from"react/jsx-runtime";function tP(e){if(e&&typeof e=="number")return e;switch(e){case"small":return 550;case"wide":return 1024;case"regular":default:return 800}}var gt,jo=v(()=>{"use strict";f();m5();ye();ue();p5();zi();b5();G();wd();Tt();X();ee();gt=e=>{let[t,o]=d5(),[r]=Q_(document.activeElement),{id:n}=Wt(),i=_e().viewport.isMobile;J_(()=>{if(!t)return;let c=Ys(t);setTimeout(()=>{c.length>0&&e.autofocus!==!1&&(c[1]||c[0]).focus()});let d=m=>{if(m.key===I.TAB){let p=Ys(t),{activeElement:u}=document,g=p.findIndex(x=>x===u);g===0&&m.shiftKey?(p[p.length-1].focus(),m.preventDefault()):g===p.length-1&&!m.shiftKey&&(p[0].focus(),m.preventDefault())}};return t.addEventListener("keydown",d),()=>t.removeEventListener("keydown",d)},[t,e.autofocus]);let a=Be(),l=eP(ws,He),s=()=>{a({openMenu:null}),l(!1),r.focus(),e.onCloseRequest()};return Cd(f5,{className:q_("Dialog",e.className,{"Dialog--fullscreen":i}),labelledBy:"dialog-title",maxWidth:tP(e.size),onCloseRequest:s,closeOnClickOutside:e.closeOnClickOutside,children:oP(oo,{ref:o,children:[e.title&&Cd("h2",{id:`${n}-dialog-title`,className:"Dialog__title",children:Cd("span",{className:"Dialog__titleContent",children:e.title})}),i&&Cd("button",{className:"Dialog__close",onClick:s,title:b("buttons.close"),"aria-label":b("buttons.close"),children:Yo}),Cd("div",{className:"Dialog__content",children:e.children})]})})}});var MC=v(()=>{});var LC=v(()=>{});import rP from"clsx";import{jsx as nP}from"react/jsx-runtime";var un,Is=v(()=>{"use strict";f();G();LC();un=({type:e="button",onSelect:t,selected:o,children:r,className:n="",...i})=>nP("button",{onClick:di(i.onClick,a=>{t()}),type:e,className:rP("excalidraw-button",n,{selected:o}),...i,children:r})});import{forwardRef as iP,useRef as aP,useImperativeHandle as lP,useLayoutEffect as sP,useState as cP}from"react";import Yx from"clsx";import{jsx as Kx,jsxs as _C}from"react/jsx-runtime";var cg,$x=v(()=>{"use strict";f();MC();Is();ee();cg=iP(({onChange:e,label:t,fullWidth:o,placeholder:r,readonly:n,selectOnRender:i,onKeyDown:a,isRedacted:l=!1,...s},c)=>{let d=aP(null);lP(c,()=>d.current),sP(()=>{i&&d.current?.select()},[i]);let[m,p]=cP(!1);return _C("div",{className:Yx("ExcTextField",{"ExcTextField--fullWidth":o}),onClick:()=>{d.current?.focus()},children:[Kx("div",{className:"ExcTextField__label",children:t}),_C("div",{className:Yx("ExcTextField__input",{"ExcTextField__input--readonly":n}),children:[Kx("input",{className:Yx({"is-redacted":"value"in s&&s.value&&l&&!m}),readOnly:n,value:"value"in s?s.value:void 0,defaultValue:"defaultValue"in s?s.defaultValue:void 0,placeholder:r,ref:d,onChange:u=>e?.(u.target.value),onKeyDown:a}),l&&Kx(un,{onSelect:()=>p(!m),style:{border:0,userSelect:"none"},children:m?Sb:Va})]})]})})});var dP,Lt,ol=v(()=>{"use strict";f();U();X();G();dP={toggleTheme:[N("Shift+Alt+D")],saveScene:[N("CtrlOrCmd+S")],loadScene:[N("CtrlOrCmd+O")],clearCanvas:[N("CtrlOrCmd+Delete")],imageExport:[N("CtrlOrCmd+Shift+E")],commandPalette:[N("CtrlOrCmd+/"),N("CtrlOrCmd+Shift+P")],cut:[N("CtrlOrCmd+X")],copy:[N("CtrlOrCmd+C")],paste:[N("CtrlOrCmd+V")],copyStyles:[N("CtrlOrCmd+Alt+C")],pasteStyles:[N("CtrlOrCmd+Alt+V")],selectAll:[N("CtrlOrCmd+A")],deleteSelectedElements:[N("Delete")],duplicateSelection:[N("CtrlOrCmd+D"),N(`Alt+${b("helpDialog.drag")}`)],sendBackward:[N("CtrlOrCmd+[")],bringForward:[N("CtrlOrCmd+]")],sendToBack:[so?N("CtrlOrCmd+Alt+["):N("CtrlOrCmd+Shift+[")],bringToFront:[so?N("CtrlOrCmd+Alt+]"):N("CtrlOrCmd+Shift+]")],copyAsPng:[N("Shift+Alt+C")],copyAsSvg:[],group:[N("CtrlOrCmd+G")],ungroup:[N("CtrlOrCmd+Shift+G")],gridMode:[N("CtrlOrCmd+'")],zenMode:[N("Alt+Z")],objectsSnapMode:[N("Alt+S")],stats:[N("Alt+/")],addToLibrary:[],flipHorizontal:[N("Shift+H")],flipVertical:[N("Shift+V")],viewMode:[N("Alt+R")],hyperlink:[N("CtrlOrCmd+K")],toggleElementLock:[N("CtrlOrCmd+Shift+L")],resetZoom:[N("CtrlOrCmd+0")],zoomOut:[N("CtrlOrCmd+-")],zoomIn:[N("CtrlOrCmd++")],zoomToFitSelection:[N("Shift+3")],zoomToFit:[N("Shift+1")],zoomToFitSelectionInViewport:[N("Shift+2")],toggleEraserTool:[N("E")],toggleHandTool:[N("H")],setFrameAsActiveTool:[N("F")],saveFileToDisk:[N("CtrlOrCmd+S")],saveToActiveFile:[N("CtrlOrCmd+S")],toggleShortcuts:[N("?")]},Lt=(e,t=0)=>{let o=dP[e];return o&&o.length>0?o[t]||o[0]:""}});var mP,pP,uP,gP,hP,fP,bP,xP,Xx,PC=v(()=>{"use strict";f();mP="\\u0300-\\u036f",pP="\\ufe20-\\ufe2f",uP="\\u20d0-\\u20ff",gP=mP+pP+uP,hP=`[${gP}]`,fP=RegExp(hP,"g"),bP=/[\xc0-\xd6\xd8-\xf6\xf8-\xff\u0100-\u017f]/g,xP={\u00C0:"A",\u00C1:"A",\u00C2:"A",\u00C3:"A",\u00C4:"A",\u00C5:"A",\u00E0:"a",\u00E1:"a",\u00E2:"a",\u00E3:"a",\u00E4:"a",\u00E5:"a",\u00C7:"C",\u00E7:"c",\u00D0:"D",\u00F0:"d",\u00C8:"E",\u00C9:"E",\u00CA:"E",\u00CB:"E",\u00E8:"e",\u00E9:"e",\u00EA:"e",\u00EB:"e",\u00CC:"I",\u00CD:"I",\u00CE:"I",\u00CF:"I",\u00EC:"i",\u00ED:"i",\u00EE:"i",\u00EF:"i",\u00D1:"N",\u00F1:"n",\u00D2:"O",\u00D3:"O",\u00D4:"O",\u00D5:"O",\u00D6:"O",\u00D8:"O",\u00F2:"o",\u00F3:"o",\u00F4:"o",\u00F5:"o",\u00F6:"o",\u00F8:"o",\u00D9:"U",\u00DA:"U",\u00DB:"U",\u00DC:"U",\u00F9:"u",\u00FA:"u",\u00FB:"u",\u00FC:"u",\u00DD:"Y",\u00FD:"y",\u00FF:"y",\u00C6:"E",\u00E6:"e",\u00DE:"T",\u00FE:"t",\u00DF:"s",\u0100:"A",\u0102:"A",\u0104:"A",\u0101:"a",\u0103:"a",\u0105:"a",\u0106:"C",\u0108:"C",\u010A:"C",\u010C:"C",\u0107:"c",\u0109:"c",\u010B:"c",\u010D:"c",\u010E:"D",\u0110:"D",\u010F:"d",\u0111:"d",\u0112:"E",\u0114:"E",\u0116:"E",\u0118:"E",\u011A:"E",\u0113:"e",\u0115:"e",\u0117:"e",\u0119:"e",\u011B:"e",\u011C:"G",\u011E:"G",\u0120:"G",\u0122:"G",\u011D:"g",\u011F:"g",\u0121:"g",\u0123:"g",\u0124:"H",\u0126:"H",\u0125:"h",\u0127:"h",\u0128:"I",\u012A:"I",\u012C:"I",\u012E:"I",\u0130:"I",\u0129:"i",\u012B:"i",\u012D:"i",\u012F:"i",\u0131:"i",\u0134:"J",\u0135:"j",\u0136:"K",\u0137:"k",\u0138:"k",\u0139:"L",\u013B:"L",\u013D:"L",\u013F:"L",\u0141:"L",\u013A:"l",\u013C:"l",\u013E:"l",\u0140:"l",\u0142:"l",\u0143:"N",\u0145:"N",\u0147:"N",\u014A:"N",\u0144:"n",\u0146:"n",\u0148:"n",\u014B:"n",\u014C:"O",\u014E:"O",\u0150:"O",\u014D:"o",\u014F:"o",\u0151:"o",\u0154:"R",\u0156:"R",\u0158:"R",\u0155:"r",\u0157:"r",\u0159:"r",\u015A:"S",\u015C:"S",\u015E:"S",\u0160:"S",\u015B:"s",\u015D:"s",\u015F:"s",\u0161:"s",\u0162:"T",\u0164:"T",\u0166:"T",\u0163:"t",\u0165:"t",\u0167:"t",\u0168:"U",\u016A:"U",\u016C:"U",\u016E:"U",\u0170:"U",\u0172:"U",\u0169:"u",\u016B:"u",\u016D:"u",\u016F:"u",\u0171:"u",\u0173:"u",\u0174:"W",\u0175:"w",\u0176:"Y",\u0177:"y",\u0178:"Y",\u0179:"Z",\u017B:"Z",\u017D:"Z",\u017A:"z",\u017C:"z",\u017E:"z",\u0132:"I",\u0133:"i",\u0152:"E",\u0153:"e",\u0149:"n",\u017F:"s"},Xx=e=>e.replace(bP,t=>xP[t]||t).replace(fP,"")});import{jsx as EP}from"react/jsx-runtime";var Wi,dg=v(()=>{"use strict";f();Wi=({icon:e})=>EP("span",{style:{width:"1em",margin:"0 0.5ex 0 0.5ex",display:"inline-block",lineHeight:0,verticalAlign:"middle"},children:e})});var Id,DC,mg=v(()=>{"use strict";f();ee();ue();Id=[{icon:h1,value:"selection",key:I.V,numericKey:I[1],fillable:!0},{icon:f1,value:"rectangle",key:I.R,numericKey:I[2],fillable:!0},{icon:b1,value:"diamond",key:I.D,numericKey:I[3],fillable:!0},{icon:x1,value:"ellipse",key:I.O,numericKey:I[4],fillable:!0},{icon:E1,value:"arrow",key:I.A,numericKey:I[5],fillable:!0},{icon:y1,value:"line",key:I.L,numericKey:I[6],fillable:!0},{icon:Ha,value:"freedraw",key:[I.P,I.X],numericKey:I[7],fillable:!1},{icon:v1,value:"text",key:I.T,numericKey:I[8],fillable:!1},{icon:T1,value:"image",key:null,numericKey:I[9],fillable:!1},{icon:C1,value:"eraser",key:I.E,numericKey:I[0],fillable:!1}],DC=e=>Id.find((o,r)=>o.numericKey!=null&&e===o.numericKey.toString()||o.key&&(typeof o.key=="string"?o.key===e:o.key.includes(e)))?.value||null});var RC=v(()=>{});import Zx from"react";import gn from"tunnel-rat";var jx,nt,NC,qo=v(()=>{"use strict";f();jx=Zx.createContext(null),nt=()=>Zx.useContext(jx),NC=()=>Zx.useMemo(()=>({MainMenuTunnel:gn(),WelcomeScreenMenuHintTunnel:gn(),WelcomeScreenToolbarHintTunnel:gn(),WelcomeScreenHelpHintTunnel:gn(),WelcomeScreenCenterTunnel:gn(),FooterCenterTunnel:gn(),DefaultSidebarTriggerTunnel:gn(),DefaultSidebarTabTriggersTunnel:gn(),OverwriteConfirmDialogTunnel:gn(),TTDDialogTriggerTunnel:gn(),jotaiScope:Symbol()}),[])});import{useState as yP}from"react";import qx from"clsx";import{Fragment as Vi,jsx as st,jsxs as vt}from"react/jsx-runtime";var Jx,Qx,pg,ug,OC,BC,FC,HC,Sd=v(()=>{"use strict";f();X();ye();We();mg();G();tl();Mt();nc();So();se();Er();Ni();pt();RC();Td();ee();ue();qo();Jx=(e,t)=>{let o=t[0]?.type||null;for(let r of t)if(r.type!==o){o=null;break}return rc(e.activeTool.type)&&e.activeTool.type!=="image"&&o!=="image"&&o!=="frame"&&o!=="magicframe"||t.some(r=>rc(r.type))},Qx=(e,t)=>Pn(e.activeTool.type)||t.some(o=>Pn(o.type)),pg=({appState:e,elementsMap:t,renderAction:o})=>{let r=Ba(t,e),n=!1;r.length===2&&(Eo(r[0])||Eo(r[1]))&&(n=!0);let i=!!e.editingElement,a=_e(),l=document.documentElement.getAttribute("dir")==="rtl",s=Pn(e.activeTool.type)&&!co(e.currentItemBackgroundColor)||r.some(d=>Pn(d.type)&&!co(d.backgroundColor)),c=r.length===1||n;return vt("div",{className:"panelColumn",children:[st("div",{children:Jx(e,r)&&o("changeStrokeColor")}),Qx(e,r)&&st("div",{children:o("changeBackgroundColor")}),s&&o("changeFillStyle"),(Tm(e.activeTool.type)||r.some(d=>Tm(d.type)))&&o("changeStrokeWidth"),(e.activeTool.type==="freedraw"||r.some(d=>d.type==="freedraw"))&&o("changeStrokeShape"),(Cm(e.activeTool.type)||r.some(d=>Cm(d.type)))&&vt(Vi,{children:[o("changeStrokeStyle"),o("changeSloppiness")]}),(bl(e.activeTool.type)||r.some(d=>bl(d.type)))&&st(Vi,{children:o("changeRoundness")}),(e.activeTool.type==="text"||r.some(W))&&vt(Vi,{children:[o("changeFontSize"),o("changeFontFamily"),(e.activeTool.type==="text"||R2(r,t))&&o("changeTextAlign")]}),D2(r,t)&&o("changeVerticalAlign"),(pa(e.activeTool.type)||r.some(d=>pa(d.type)))&&st(Vi,{children:o("changeArrowhead")}),o("changeOpacity"),vt("fieldset",{children:[st("legend",{children:b("labels.layers")}),vt("div",{className:"buttonList",children:[o("sendToBack"),o("sendBackward"),o("bringToFront"),o("bringForward")]})]}),r.length>1&&!n&&vt("fieldset",{children:[st("legend",{children:b("labels.align")}),vt("div",{className:"buttonList",children:[l?vt(Vi,{children:[o("alignRight"),o("alignHorizontallyCentered"),o("alignLeft")]}):vt(Vi,{children:[o("alignLeft"),o("alignHorizontallyCentered"),o("alignRight")]}),r.length>2&&o("distributeHorizontally"),st("div",{style:{flexBasis:"100%",height:0}}),vt("div",{style:{display:"flex",flexWrap:"wrap",gap:".5rem",marginTop:"-0.5rem"},children:[o("alignTop"),o("alignVerticallyCentered"),o("alignBottom"),r.length>2&&o("distributeVertically")]})]})]}),!i&&r.length>0&&vt("fieldset",{children:[st("legend",{children:b("labels.actions")}),vt("div",{className:"buttonList",children:[!a.editor.isMobile&&o("duplicateSelection"),!a.editor.isMobile&&o("deleteSelectedElements"),o("group"),o("ungroup"),c&&o("hyperlink")]})]})]})},ug=({activeTool:e,appState:t,app:o,UIOptions:r})=>{let[n,i]=yP(!1),a=e.type==="frame",l=e.type==="laser",s=e.type==="embeddable",{TTDDialogTriggerTunnel:c}=nt();return vt(Vi,{children:[Id.map(({value:d,icon:m,key:p,numericKey:u,fillable:g},x)=>{if(r.tools?.[d]===!1)return null;let E=b(`toolBar.${d}`),y=p&&$r(typeof p=="string"?p:p[0]),T=y?`${y} ${b("helpDialog.or")} ${u}`:`${u}`;return st(ce,{className:qx("Shape",{fillable:g}),type:"radio",icon:m,checked:e.type===d,name:"editor-current-shape",title:`${$r(E)} \u2014 ${T}`,keyBindingLabel:u||y,"aria-label":$r(E),"aria-keyshortcuts":T,"data-testid":`toolbar-${d}`,onPointerDown:({pointerType:w})=>{!t.penDetected&&w==="pen"&&o.togglePenMode(!0)},onChange:({pointerType:w})=>{t.activeTool.type!==d&&we("toolbar",d,"ui"),d==="image"?o.setActiveTool({type:d,insertOnCanvasDirectly:w!=="mouse"}):o.setActiveTool({type:d})}},d)}),st("div",{className:"App-toolbar__divider"}),vt(Ge,{open:n,children:[vt(Ge.Trigger,{className:qx("App-toolbar__extra-tools-trigger",{"App-toolbar__extra-tools-trigger--selected":a||s||l&&!o.props.isCollaborating}),onToggle:()=>i(!n),title:b("toolBar.extraTools"),children:[Cb,o.props.aiEnabled!==!1&&st("div",{style:{display:"inline-flex",marginLeft:"auto",padding:"2px 4px",borderRadius:6,fontSize:8,fontFamily:"Cascadia, monospace",position:"absolute",background:"pink",color:"black",bottom:3,right:4},children:"AI"})]}),vt(Ge.Content,{onClickOutside:()=>i(!1),onSelect:()=>i(!1),className:"App-toolbar__extra-tools-dropdown",children:[st(Ge.Item,{onSelect:()=>o.setActiveTool({type:"frame"}),icon:$c,shortcut:I.F.toLocaleUpperCase(),"data-testid":"toolbar-frame",selected:a,children:b("toolBar.frame")}),st(Ge.Item,{onSelect:()=>o.setActiveTool({type:"embeddable"}),icon:S1,"data-testid":"toolbar-embeddable",selected:s,children:b("toolBar.embeddable")}),st(Ge.Item,{onSelect:()=>o.setActiveTool({type:"laser"}),icon:Zc,"data-testid":"toolbar-laser",selected:l,shortcut:I.K.toLocaleUpperCase(),children:b("toolBar.laser")}),st("div",{style:{margin:"6px 0",fontSize:14,fontWeight:600},children:"Generate"}),o.props.aiEnabled!==!1&&st(c.Out,{}),st(Ge.Item,{onSelect:()=>o.setOpenDialog({name:"ttd",tab:"mermaid"}),icon:Xc,"data-testid":"toolbar-embeddable",children:b("toolBar.mermaidToExcalidraw")}),o.props.aiEnabled!==!1&&vt(Vi,{children:[vt(Ge.Item,{onSelect:()=>o.onMagicframeToolSelect(),icon:Wa,"data-testid":"toolbar-magicframe",children:[b("toolBar.magicframe"),st(Ge.Item.Badge,{children:"AI"})]}),st(Ge.Item,{onSelect:()=>{we("ai","open-settings","d2c"),o.setOpenDialog({name:"settings",source:"settings",tab:"diagram-to-code"})},icon:is,"data-testid":"toolbar-magicSettings",children:b("toolBar.magicSettings")})]})]})]})]})},OC=({renderAction:e,zoom:t})=>st(Yt.Col,{gap:1,className:"zoom-actions",children:vt(Yt.Row,{align:"center",children:[e("zoomOut"),e("resetZoom"),e("zoomIn")]})}),BC=({renderAction:e,className:t})=>vt("div",{className:`undo-redo-buttons ${t}`,children:[st("div",{className:"undo-button-container",children:st(Xo,{label:b("buttons.undo"),children:e("undo")})}),st("div",{className:"redo-button-container",children:vt(Xo,{label:b("buttons.redo"),children:[" ",e("redo")]})})]}),FC=({actionManager:e,showExitZenModeBtn:t})=>st("button",{className:qx("disable-zen-mode",{"disable-zen-mode--visible":t}),onClick:()=>e.executeAction(Qa),children:b("buttons.exitZenMode")}),HC=({renderAction:e,className:t})=>st("div",{className:`finalize-button ${t}`,children:e("finalize",{size:"small"})})});import{useRef as wP}from"react";var eE,zC=v(()=>{"use strict";f();eE=e=>{let t=wP({userFn:e});return t.current.userFn=e,t.current.stableFn||(t.current.stableFn=(...o)=>t.current.userFn(...o)),t.current.stableFn}});import{atom as vP,useAtom as TP}from"jotai";import{jsx as IP,jsxs as CP}from"react/jsx-runtime";var rl,GC,kd=v(()=>{"use strict";f();Er();X();Tt();ye();Ax();rl=vP(null),GC=()=>{let[e,t]=TP(rl,He),o=Ft();return e&&e==="clearCanvas"?IP(Ju,{onConfirm:()=>{o.executeAction(mn),t(null)},onCancel:()=>t(null),title:b("clearCanvasDialog.title"),children:CP("p",{className:"clear-canvas__content",children:[" ",b("alerts.clearReset")]})}):null}});var tE={};Os(tE,{toggleTheme:()=>SP});var SP,UC=v(()=>{"use strict";f();Er();SP={...Oi,category:"App",label:"Toggle theme",perform:({actionManager:e})=>{e.executeAction(Oi,"commandPalette")}}});var WC=v(()=>{});import{useEffect as hg,useRef as kP,useState as gg}from"react";import YC from"clsx";import AP from"fuzzy";import{atom as MP,useAtom as LP}from"jotai";import{jsx as go,jsxs as hn}from"react/jsx-runtime";function RP({customCommandPaletteItems:e}){let t=ko(),o=Re(),r=Be(),n=Hi(),i=Ft(),[a,l]=LP(_P),[s,c]=gg(null),d=kP(null),m=ds({uiAppState:o,customCommandPaletteItems:e,appProps:n});hg(()=>{let{uiAppState:k,customCommandPaletteItems:R,appProps:P}=m,F=B=>{let j="";return B.label&&(typeof B.label=="function"?j=b(B.label(t.scene.getNonDeletedElements(),k,t)):j=b(B.label)),j},D=B=>typeof B.icon=="function"?B.icon(k,t.scene.getNonDeletedElements()):B.icon,L=[],A=(B,j,Y)=>{let oe={label:F(B),icon:D(B),category:j,shortcut:Lt(B.name),keywords:B.keywords,predicate:B.predicate,viewMode:B.viewMode,perform:()=>{i.executeAction(B,"commandPalette")}};return Y?Y(oe,B):oe};if(k&&t.scene&&i){let B=[i.actions.group,i.actions.ungroup,i.actions.cut,i.actions.copy,i.actions.deleteSelectedElements,i.actions.copyStyles,i.actions.pasteStyles,i.actions.sendBackward,i.actions.sendToBack,i.actions.bringForward,i.actions.bringToFront,i.actions.alignTop,i.actions.alignBottom,i.actions.alignLeft,i.actions.alignRight,i.actions.alignVerticallyCentered,i.actions.alignHorizontallyCentered,i.actions.duplicateSelection,i.actions.flipHorizontal,i.actions.flipVertical,i.actions.zoomToFitSelection,i.actions.zoomToFitSelectionInViewport,i.actions.increaseFontSize,i.actions.decreaseFontSize,i.actions.toggleLinearEditor,bs].map(K=>A(K,Et.elements,(ge,xe)=>({...ge,predicate:xe.predicate?xe.predicate:(Ne,Le,$t,wn)=>de(Ne,Le).length>0}))),j=[i.actions.toggleHandTool,i.actions.setFrameAsActiveTool].map(K=>A(K,Et.tools)),Y=[i.actions.undo,i.actions.redo,i.actions.zoomIn,i.actions.zoomOut,i.actions.resetZoom,i.actions.zoomToFit,i.actions.zenMode,i.actions.viewMode,i.actions.objectsSnapMode,i.actions.toggleShortcuts,i.actions.selectAll,i.actions.toggleElementLock,i.actions.unlockAllElements,i.actions.stats].map(K=>A(K,Et.editor)),oe=[i.actions.saveToActiveFile,i.actions.saveFileToDisk,i.actions.copyAsPng,i.actions.copyAsSvg].map(K=>A(K,Et.export));L=[...B,...Y,{label:F(mn),icon:D(mn),shortcut:Lt(mn.name),category:Et.editor,keywords:["delete","destroy"],viewMode:!1,perform:()=>{Zt.set(rl,"clearCanvas")}},{label:b("buttons.exportImage"),category:Et.export,icon:Wc,shortcut:Lt("imageExport"),keywords:["export","image","png","jpeg","svg","clipboard","picture"],perform:()=>{r({openDialog:{name:"imageExport"}})}},...oe];let Ce=[{label:b("toolBar.library"),category:Et.app,icon:Hc,viewMode:!1,perform:()=>{k.openSidebar?r({openSidebar:null}):r({openSidebar:{name:Do.name,tab:Do.defaultTab}})}},{label:b("labels.changeStroke"),keywords:["color","outline"],category:Et.elements,icon:Uc,viewMode:!1,predicate:(K,ge)=>{let xe=de(K,ge);return xe.length>0&&Jx(ge,xe)},perform:()=>{r(K=>({openMenu:K.openMenu==="shape"?null:"shape",openPopup:"elementStroke"}))}},{label:b("labels.changeBackground"),keywords:["color","fill"],icon:Uc,category:Et.elements,viewMode:!1,predicate:(K,ge)=>{let xe=de(K,ge);return xe.length>0&&Qx(ge,xe)},perform:()=>{r(K=>({openMenu:K.openMenu==="shape"?null:"shape",openPopup:"elementBackground"}))}},{label:b("labels.canvasBackground"),keywords:["color"],icon:Uc,category:Et.editor,viewMode:!1,perform:()=>{r(K=>({openMenu:K.openMenu==="canvas"?null:"canvas",openPopup:"canvasBackground"}))}},...Id.reduce((K,ge)=>{let{value:xe,icon:Ne,key:Le,numericKey:$t}=ge;if(P.UIOptions.tools?.[xe]===!1)return K;let Xt=Le&&$r(typeof Le=="string"?Le:Le[0])||$t,Wr={label:b(`toolBar.${xe}`),category:Et.tools,shortcut:Xt,icon:Ne,keywords:["toolbar"],viewMode:!1,perform:({event:vn})=>{xe==="image"?t.setActiveTool({type:xe,insertOnCanvasDirectly:vn.type==="keydown"}):t.setActiveTool({type:xe})}};return K.push(Wr),K},[]),...j,{label:b("toolBar.lock"),category:Et.tools,icon:k.activeTool.locked?Fa:Mi,shortcut:I.Q.toLocaleUpperCase(),viewMode:!1,perform:()=>{t.toggleLock()}},{label:`${b("labels.textToDiagram")}...`,category:Et.tools,icon:Ab,viewMode:!1,predicate:P.aiEnabled,perform:()=>{r(K=>({...K,openDialog:{name:"ttd",tab:"text-to-diagram"}}))}},{label:`${b("toolBar.mermaidToExcalidraw")}...`,category:Et.tools,icon:Xc,viewMode:!1,predicate:P.aiEnabled,perform:()=>{r(K=>({...K,openDialog:{name:"ttd",tab:"mermaid"}}))}}],Te=[...L,...Ce,...R||[]].map(K=>({...K,icon:K.icon||qc,order:K.order??PP(K.category),haystack:`${Xx(K.label)} ${K.keywords?.join(" ")||""}`}));c(Te),l(Te.find(K=>K.label===a?.label)??null)}},[m,t,i,c,a?.label,l,r]);let[p,u]=gg(""),[g,x]=gg(null),[E,y]=gg({}),T=k=>{r({openDialog:null},k),u("")},w=(k,R)=>{o.openDialog?.name==="commandPalette"&&(R.stopPropagation(),R.preventDefault(),document.body.classList.add("excalidraw-animations-disabled"),T(()=>{k.perform({actionManager:i,event:R}),l(k),requestAnimationFrame(()=>{document.body.classList.remove("excalidraw-animations-disabled")})}))},S=eE(k=>k.viewMode===!1&&o.viewModeEnabled?!1:typeof k.predicate=="function"?k.predicate(t.scene.getNonDeletedElements(),o,n,t):k.predicate===void 0||k.predicate),M=eE(k=>{let R=rr(k.target)||KC(k)||k.key===I.ESCAPE;if(R&&k.key!==I.ARROW_UP&&k.key!==I.ARROW_DOWN&&k.key!==I.ENTER)return;let P=Object.values(E).flat(),F=a&&!p&&S(a);if(k.key===I.ARROW_UP){k.preventDefault();let D=P.findIndex(B=>B.label===g?.label);if(F){if(D===0){x(a);return}if(g===a){let B=P[P.length-1];B&&x(B);return}}let L;D===-1?L=P.length-1:L=D===0?P.length-1:(D-1)%P.length;let A=P[L];A&&x(A);return}if(k.key===I.ARROW_DOWN){k.preventDefault();let D=P.findIndex(B=>B.label===g?.label);if(F){if(!g||D===P.length-1){x(a);return}if(g===a){let B=P[0];B&&x(B);return}}let L=(D+1)%P.length,A=P[L];A&&x(A);return}if(k.key===I.ENTER&&g&&setTimeout(()=>{w(g,k)}),!R){if(k.stopPropagation(),/^[a-zA-Z0-9]$/.test(k.key)){d?.current?.focus();return}k.preventDefault()}});return hg(()=>(window.addEventListener("keydown",M,{capture:!0}),()=>window.removeEventListener("keydown",M,{capture:!0})),[M]),hg(()=>{if(!s)return;let k=D=>{let L={};for(let A of D)L[A.category]?L[A.category].push(A):L[A.category]=[A];return L},R=s.filter(S).sort((D,L)=>D.order-L.order),P=!p&&a&&S(a);if(!p){y(k(P?R.filter(D=>D.label!==a?.label):R)),x(P?a:R[0]||null);return}let F=Xx(p.replace(/[<>-_| ]/g,""));R=AP.filter(F,R,{extract:D=>D.haystack}).sort((D,L)=>L.score-D.score).map(D=>D.original),y(k(R)),x(R[0]??null)},[p,s,S,a]),hn(gt,{onCloseRequest:()=>T(),closeOnClickOutside:!0,title:!1,size:720,autofocus:!0,className:"command-palette-dialog",children:[go(cg,{value:p,placeholder:b("commandPalette.search.placeholder"),onChange:k=>{u(k)},selectOnRender:!0,ref:d}),!t.device.viewport.isMobile&&hn("div",{className:"shortcuts-wrapper",children:[go(fg,{shortcut:"\u2191\u2193",children:b("commandPalette.shortcuts.select")}),go(fg,{shortcut:"\u21B5",children:b("commandPalette.shortcuts.confirm")}),go(fg,{shortcut:N("Esc"),children:b("commandPalette.shortcuts.close")})]}),hn("div",{className:"commands",children:[a&&!p&&hn("div",{className:"command-category",children:[hn("div",{className:"command-category-title",children:[b("commandPalette.recents"),go("div",{className:"icon",style:{marginLeft:"6px"},children:Mb})]}),go(VC,{command:a,isSelected:a.label===g?.label,onClick:k=>w(a,k),disabled:!S(a),onMouseMove:()=>x(a),showShortcut:!t.device.viewport.isMobile,appState:o})]}),Object.keys(E).length>0?Object.keys(E).map((k,R)=>hn("div",{className:"command-category",children:[go("div",{className:"command-category-title",children:k}),E[k].map(P=>go(VC,{command:P,isSelected:P.label===g?.label,onClick:F=>w(P,F),onMouseMove:()=>x(P),showShortcut:!t.device.viewport.isMobile,appState:o},P.label))]},k)):s?hn("div",{className:"no-match",children:[go("div",{className:"icon",children:jc})," ",b("commandPalette.search.noMatch")]}):null]})]})}var _P,Et,PP,fg,KC,DP,VC,oE=v(()=>{"use strict";f();ye();ue();jo();$x();We();X();ol();U();ee();Vt();G();PC();dg();mg();Sd();zC();Er();Tt();kd();UC();So();yu();WC();_P=MP(null),Et={app:"App",export:"Export",tools:"Tools",editor:"Editor",elements:"Elements",links:"Links"},PP=e=>{switch(e){case Et.app:return 1;case Et.export:return 2;case Et.editor:return 3;case Et.tools:return 4;case Et.elements:return 5;case Et.links:return 6;default:return 10}},fg=({shortcut:e,className:t,children:o})=>{let r=e.replace("++","+$").split("+");return hn("div",{className:YC("shortcut",t),children:[r.map((n,i)=>go("div",{className:"shortcut-wrapper",children:go("div",{className:"shortcut-key",children:n==="$"?"+":n})},n)),go("div",{className:"shortcut-desc",children:o})]})},KC=e=>!e.altKey&&e[I.CTRL_OR_CMD]&&(e.shiftKey&&e.key.toLowerCase()===I.P||e.key===I.SLASH),DP=Object.assign(e=>{let t=Re(),o=Be();return hg(()=>{let r=n=>{KC(n)&&(n.preventDefault(),n.stopPropagation(),o(i=>{let a=i.openDialog?.name==="commandPalette"?null:{name:"commandPalette"};return a&&we("command_palette","open","shortcut"),{openDialog:a}}))};return window.addEventListener("keydown",r,{capture:!0}),()=>window.removeEventListener("keydown",r,{capture:!0})},[o]),t.openDialog?.name!=="commandPalette"?null:go(RP,{...e})},{defaultItems:tE});VC=({command:e,isSelected:t,disabled:o,onMouseMove:r,onClick:n,showShortcut:i,appState:a})=>{let l=()=>{};return hn("div",{className:YC("command-item",{"item-selected":t,"item-disabled":o}),ref:s=>{t&&!o&&s?.scrollIntoView?.({block:"nearest"})},onClick:o?l:n,onMouseMove:o?l:r,title:o?b("commandPalette.itemNotAvailable"):"",children:[hn("div",{className:"name",children:[e.icon&&go(Wi,{icon:typeof e.icon=="function"?e.icon(a):e.icon}),e.label]}),i&&e.shortcut&&go(fg,{shortcut:e.shortcut})]})}});var bg,$C=v(()=>{"use strict";f();oE();io();se();je();bg=H({name:"toggleLinearEditor",category:Et.elements,label:(e,t,o)=>{let r=o.scene.getSelectedElements({selectedElementIds:t.selectedElementIds,includeBoundTextElement:!0})[0];return t.editingLinearElement?.elementId===r?.id?"labels.lineEditor.exit":"labels.lineEditor.edit"},trackEvent:{category:"element"},predicate:(e,t,o,r)=>{let n=r.scene.getSelectedElements(t);return!!(n.length===1&&ne(n[0]))},perform(e,t,o,r){let n=r.scene.getSelectedElements({selectedElementIds:t.selectedElementIds,includeBoundTextElement:!0})[0],i=t.editingLinearElement?.elementId===n.id?null:new $(n);return{appState:{...t,editingLinearElement:i},commitToHistory:!1}}})});var XC={};Os(XC,{actionAddToLibrary:()=>Ou,actionAlignBottom:()=>RT,actionAlignHorizontallyCentered:()=>FT,actionAlignLeft:()=>NT,actionAlignRight:()=>OT,actionAlignTop:()=>DT,actionAlignVerticallyCentered:()=>BT,actionBindText:()=>Gu,actionBringForward:()=>du,actionBringToFront:()=>pu,actionChangeBackgroundColor:()=>B3,actionChangeExportBackground:()=>Au,actionChangeFillStyle:()=>F3,actionChangeFontFamily:()=>W3,actionChangeFontSize:()=>U3,actionChangeOpacity:()=>G3,actionChangeProjectName:()=>ku,actionChangeSloppiness:()=>z3,actionChangeStrokeColor:()=>O3,actionChangeStrokeWidth:()=>H3,actionChangeTextAlign:()=>V3,actionChangeVerticalAlign:()=>Y3,actionChangeViewBackgroundColor:()=>X3,actionClearCanvas:()=>mn,actionCopy:()=>Ja,actionCopyAsPng:()=>ud,actionCopyAsSvg:()=>pd,actionCopyStyles:()=>Lu,actionCut:()=>md,actionDeleteSelected:()=>as,actionDuplicateSelection:()=>hu,actionFinalize:()=>Zo,actionFlipHorizontal:()=>Bu,actionFlipVertical:()=>Fu,actionGoToCollaborator:()=>AT,actionGroup:()=>Pu,actionLink:()=>bs,actionLoadScene:()=>ja,actionPasteStyles:()=>_u,actionResetZoom:()=>Z3,actionSaveFileToDisk:()=>ps,actionSaveToActiveFile:()=>sd,actionSelectAll:()=>gu,actionSendBackward:()=>cu,actionSendToBack:()=>mu,actionShortcuts:()=>Fi,actionToggleCanvasMenu:()=>fT,actionToggleEditMenu:()=>bT,actionToggleElementLock:()=>Wu,actionToggleGridMode:()=>hd,actionToggleLinearEditor:()=>bg,actionToggleObjectsSnapMode:()=>Hu,actionToggleStats:()=>Qn,actionToggleTheme:()=>Oi,actionToggleZenMode:()=>Qa,actionUnbindText:()=>zu,actionUngroup:()=>Du,actionZoomIn:()=>rd,actionZoomOut:()=>nd,actionZoomToFit:()=>q3,copyText:()=>gd,distributeHorizontally:()=>VT,distributeVertically:()=>YT});var Er=v(()=>{"use strict";f();Ub();Yv();Kv();Zv();ax();ad();Q3();cd();hT();ET();wT();MT();LT();HT();$T();ZT();mx();jT();qT();JT();px();ux();s5();yx();$C()});import{jsx as JC}from"react/jsx-runtime";var ZC,jC,qC,QC=v(()=>{"use strict";f();ee();Mt();X();ue();Ze();_r();G();U();ZC=(e,t,o)=>{if(!t.multiElement&&!t.resizingElement&&!t.editingElement&&!t.draggingElement){let n=o();if(n===null)return{commitToHistory:!1};let i=re(e),a=n.elements,l=re(a),s=e.filter(d=>!l.has(d.id)),c=a.map(d=>ae(i.get(d.id)||d,d)).concat(s.map(d=>ae(d,{isDeleted:!0})));return Ml(c,s),{elements:c,appState:{...t,...n.appState},commitToHistory:!1,syncHistory:!0}}return{commitToHistory:!1}},jC=e=>({name:"undo",label:"buttons.undo",icon:Vp,trackEvent:{category:"history"},viewMode:!1,perform:(t,o)=>ZC(t,o,()=>e.undoOnce()),keyTest:t=>t[I.CTRL_OR_CMD]&&t.key.toLowerCase()===I.Z&&!t.shiftKey,PanelComponent:({updateData:t,data:o})=>JC(ce,{type:"button",icon:Vp,"aria-label":b("buttons.undo"),onClick:t,size:o?.size||"medium"}),commitToHistory:()=>!1}),qC=e=>({name:"redo",label:"buttons.redo",icon:Yp,trackEvent:{category:"history"},viewMode:!1,perform:(t,o)=>ZC(t,o,()=>e.redoOnce()),keyTest:t=>t[I.CTRL_OR_CMD]&&t.shiftKey&&t.key.toLowerCase()===I.Z||em&&t.ctrlKey&&!t.shiftKey&&t.key===I.Y,PanelComponent:({updateData:t,data:o})=>JC(ce,{type:"button",icon:Yp,"aria-label":b("buttons.redo"),onClick:t,size:o?.size||"medium"}),commitToHistory:()=>!1})});import{jsx as NP}from"react/jsx-runtime";var rE,Ad,e6=v(()=>{"use strict";f();So();G();rE=(e,t,o,r,n,i)=>{if(e.trackEvent)try{typeof e.trackEvent=="object"&&(!e.trackEvent.predicate||e.trackEvent.predicate(o,r,i))&&we(e.trackEvent.category,e.trackEvent.action||e.name,`${t} (${n.device.editor.isMobile?"mobile":"desktop"})`)}catch(a){console.error("error while logging action:",a)}},Ad=class{actions={};updater;getAppState;getElementsIncludingDeleted;app;constructor(t,o,r,n){this.updater=i=>{if(Xr(i))i.then(a=>t(a));else return t(i)},this.getAppState=o,this.getElementsIncludingDeleted=r,this.app=n}registerAction(t){this.actions[t.name]=t}registerAll(t){t.forEach(o=>this.registerAction(o))}handleKeyDown(t){let o=this.app.props.UIOptions.canvasActions,r=Object.values(this.actions).sort((s,c)=>(c.keyPriority||0)-(s.keyPriority||0)).filter(s=>(s.name in o?o[s.name]:!0)&&s.keyTest&&s.keyTest(t,this.getAppState(),this.getElementsIncludingDeleted(),this.app));if(r.length!==1)return r.length>1&&console.warn("Canceling as multiple actions match this shortcut",r),!1;let n=r[0];if(this.getAppState().viewModeEnabled&&n.viewMode!==!0)return!1;let i=this.getElementsIncludingDeleted(),a=this.getAppState(),l=null;return rE(n,"keyboard",a,i,this.app,null),t.preventDefault(),t.stopPropagation(),this.updater(r[0].perform(i,a,l,this.app)),!0}executeAction(t,o="api",r=null){let n=this.getElementsIncludingDeleted(),i=this.getAppState();rE(t,o,i,n,this.app,r),this.updater(t.perform(n,i,r,this.app))}renderAction=(t,o)=>{let r=this.app.props.UIOptions.canvasActions;if(this.actions[t]&&"PanelComponent"in this.actions[t]&&(!(t in r)||r[t])){let n=this.actions[t],i=n.PanelComponent;i.displayName="PanelComponent";let a=this.getElementsIncludingDeleted(),l=this.getAppState(),s=c=>{rE(n,"ui",l,a,this.app,c),this.updater(n.perform(this.getElementsIncludingDeleted(),this.getAppState(),c,this.app))};return NP(i,{elements:this.getElementsIncludingDeleted(),appState:this.getAppState(),updateData:s,appProps:this.app.props,app:this.app,data:o})}return null};isActionEnabled=t=>{let o=this.getElementsIncludingDeleted(),r=this.getAppState();return!t.predicate||t.predicate(o,r,this.app.props,this.app)}}});var nE,iE,t6,o6=v(()=>{"use strict";f();nE=e=>{let t=Array.from(e.values());return{x:t6(t,o=>o.x)/t.length,y:t6(t,o=>o.y)/t.length}},iE=([e,t])=>Math.hypot(e.x-t.x,e.y-t.y),t6=(e,t)=>e.reduce((o,r)=>o+t(r),0)});var OP,aE,lE,r6=v(()=>{"use strict";f();se();on();OP=e=>({selectedElementIds:e.selectedElementIds,selectedGroupIds:e.selectedGroupIds,viewBackgroundColor:e.viewBackgroundColor,editingLinearElement:e.editingLinearElement,editingGroupId:e.editingGroupId,name:e.name}),aE=class{elementCache=new Map;recording=!0;stateHistory=[];redoStack=[];lastEntry=null;hydrateHistoryEntry({appState:t,elements:o}){return{appState:JSON.parse(t),elements:o.map(r=>{let n=this.elementCache.get(r.id)?.get(r.versionNonce);if(!n)throw new Error(`Element not found: ${r.id}:${r.versionNonce}`);return n})}}dehydrateHistoryEntry({appState:t,elements:o}){return{appState:JSON.stringify(t),elements:o.map(r=>{this.elementCache.has(r.id)||this.elementCache.set(r.id,new Map);let n=this.elementCache.get(r.id);return n.has(r.versionNonce)||n.set(r.versionNonce,zn(r)),{id:r.id,versionNonce:r.versionNonce}})}}getSnapshotForTest(){return{recording:this.recording,stateHistory:this.stateHistory.map(t=>this.hydrateHistoryEntry(t)),redoStack:this.redoStack.map(t=>this.hydrateHistoryEntry(t))}}clear(){this.stateHistory.length=0,this.redoStack.length=0,this.lastEntry=null,this.elementCache.clear()}generateEntry=(t,o)=>this.dehydrateHistoryEntry({appState:OP(t),elements:o.reduce((r,n)=>{if(ne(n)&&t.multiElement&&t.multiElement.id===n.id){if(t.multiElement&&t.multiElement.id===n.id&&n.points.length<2)return r;r.push({...n,points:n.lastCommittedPoint!==n.points[n.points.length-1]?n.points.slice(0,-1):n.points})}else r.push(n);return r},[])});shouldCreateEntry(t){let{lastEntry:o}=this;if(!o||t.elements.length!==o.elements.length)return!0;for(let n=t.elements.length-1;n>-1;n--){let i=t.elements[n],a=o.elements[n];if(!i||!a||i.id!==a.id||i.versionNonce!==a.versionNonce)return!0}let r;for(r in t.appState)if(!(r==="editingLinearElement"&&t.appState[r]?.elementId===o.appState[r]?.elementId)&&!(r==="selectedElementIds"||r==="selectedGroupIds")&&t.appState[r]!==o.appState[r])return!0;return!1}pushEntry(t,o){let r=this.generateEntry(t,o),n=this.hydrateHistoryEntry(r);if(n){if(!this.shouldCreateEntry(n))return;this.stateHistory.push(r),this.lastEntry=n,this.clearRedoStack()}}clearRedoStack(){this.redoStack.splice(0,this.redoStack.length)}redoOnce(){if(this.redoStack.length===0)return null;let t=this.redoStack.pop();return t!==void 0?(this.stateHistory.push(t),this.hydrateHistoryEntry(t)):null}undoOnce(){if(this.stateHistory.length===1)return null;let t=this.stateHistory.pop(),o=this.stateHistory[this.stateHistory.length-1];return t!==void 0?(this.redoStack.push(t),this.hydrateHistoryEntry(o)):null}setCurrentState(t,o){this.lastEntry=this.hydrateHistoryEntry(this.generateEntry(t,o))}resumeRecording(){this.recording=!0}record(t,o){this.recording&&(this.pushEntry(t,o),this.recording=!1)}},lE=aE});var n6=v(()=>{});import BP from"clsx";import FP from"react";import{jsx as Ss,jsxs as HP}from"react/jsx-runtime";var ho,i6,a6=v(()=>{"use strict";f();ex();X();n6();ol();ye();ho="separator",i6=FP.memo(({actionManager:e,items:t,top:o,left:r,onClose:n})=>{let i=fs(),a=Di(),l=t.reduce((s,c)=>(c&&(c===ho||!c.predicate||c.predicate(a,i,e.app.props,e.app))&&s.push(c),s),[]);return Ss(Cu,{onCloseRequest:()=>{n()},top:o,left:r,fitInViewport:!0,offsetLeft:i.offsetLeft,offsetTop:i.offsetTop,viewportWidth:i.width,viewportHeight:i.height,children:Ss("ul",{className:"context-menu",onContextMenu:s=>s.preventDefault(),children:l.map((s,c)=>{if(s===ho)return!l[c-1]||l[c-1]===ho?null:Ss("hr",{className:"context-menu-item-separator"},c);let d=s.name,m="";return s.label&&(typeof s.label=="function"?m=b(s.label(a,i,e.app)):m=b(s.label)),Ss("li",{"data-testid":d,onClick:()=>{n(()=>{e.executeAction(s,"contextMenu")})},children:HP("button",{className:BP("context-menu-item",{dangerous:d==="deleteSelectedElements",checkmark:s.checked?.(i)}),children:[Ss("div",{className:"context-menu-item__label",children:m}),Ss("kbd",{className:"context-menu-item__shortcut",children:d?Lt(d):""})]})},c)})})})})});import zP,{useState as GP}from"react";import{Fragment as UP,jsx as sE}from"react/jsx-runtime";var l6,s6=v(()=>{"use strict";f();X();jo();ye();l6=({children:e,onClose:t})=>{let[o,r]=GP(!!e),{container:n}=Wt(),i=zP.useCallback(()=>{r(!1),t&&t(),n?.focus()},[t,n]);return sE(UP,{children:o&&sE(gt,{size:"small",onCloseRequest:i,title:b("errorDialog.title"),children:sE("div",{style:{whiteSpace:"pre-wrap"},children:e})})})}});var c6=v(()=>{});import WP from"clsx";import{jsx as d6,jsxs as VP}from"react/jsx-runtime";var xg,cE=v(()=>{"use strict";f();c6();xg=function({onChange:e,value:t,choices:o,name:r}){return d6("div",{className:"RadioGroup",children:o.map(n=>VP("div",{className:WP("RadioGroup__choice",{active:n.value===t}),title:n.ariaLabel,children:[d6("input",{name:r,type:"radio",checked:n.value===t,onChange:()=>e(n.value),"aria-label":n.ariaLabel}),n.label]},String(n.value)))})}});var m6=v(()=>{});import YP from"clsx";import{jsx as p6}from"react/jsx-runtime";var Md,u6=v(()=>{"use strict";f();m6();Md=({title:e,name:t,checked:o,onChange:r,disabled:n=!1})=>p6("div",{className:YP("Switch",{toggled:o,disabled:n}),children:p6("input",{name:t,id:t,title:e,type:"checkbox",checked:o,disabled:n,onChange:()=>r(!o),onKeyDown:i=>{i.key===" "&&r(!o)}})})});var g6=v(()=>{});var h6=v(()=>{});import{forwardRef as KP,useState as $P}from"react";import XP from"clsx";import{jsx as dE,jsxs as ZP}from"react/jsx-runtime";var fn,Ld=v(()=>{"use strict";f();h6();Ia();In();G();fn=KP(({children:e,icon:t,onClick:o,label:r,variant:n="filled",color:i="primary",size:a="medium",fullWidth:l,className:s},c)=>{let[d,m]=$P(!1),p=async u=>{let g=o?.(u);if(Xr(g))try{m(!0),await g}catch(x){if(x instanceof rn)console.warn(x);else throw x}finally{m(!1)}};return dE("button",{className:XP("ExcButton",`ExcButton--color-${i}`,`ExcButton--variant-${n}`,`ExcButton--size-${a}`,{"ExcButton--fullWidth":l},s),onClick:p,type:"button","aria-label":r,ref:c,disabled:d,children:ZP("div",{className:"ExcButton__contents",children:[d&&dE(jt,{}),t&&dE("div",{className:"ExcButton__icon","aria-hidden":!0,children:t}),n!=="icon"&&(e??r)]})})})});import{useEffect as jP,useRef as qP,useState as Yi}from"react";import{jsx as it,jsxs as Ki}from"react/jsx-runtime";var JP,QP,eD,_d,f6,b6=v(()=>{"use strict";f();cd();Ai();U();Co();Wn();X();We();Pa();ee();jo();cE();u6();Ni();g6();Ld();G();Bi();JP="filter"in document.createElement("canvas").getContext("2d"),QP=()=>Ki("div",{children:[it("h3",{children:b("canvasError.cannotShowPreview")}),it("p",{children:it("span",{children:b("canvasError.canvasTooBig")})}),Ki("em",{children:["(",b("canvasError.canvasTooBigTip"),")"]})]}),eD=({appStateSnapshot:e,elementsSnapshot:t,files:o,actionManager:r,onExportImage:n,name:i})=>{let a=Ye(t,e),[l,s]=Yi(i),[c,d]=Yi(a),[m,p]=Yi(e.exportBackground),[u,g]=Yi(e.exportWithDarkMode),[x,E]=Yi(e.exportEmbedScene),[y,T]=Yi(e.exportScale),w=qP(null),[S,M]=Yi(null),{exportedElements:k,exportingFrame:R}=$a(t,e,c);return jP(()=>{let P=w.current;if(!P)return;let F=P.offsetWidth,D=P.offsetHeight;F&&Sp({data:{elements:k,appState:{...e,name:l,exportEmbedScene:x},files:o},config:{canvasBackgroundColor:m?e.viewBackgroundColor:!1,padding:Kr,theme:u?"dark":"light",scale:y,maxWidthOrHeight:Math.max(F,D),exportingFrame:R}}).then(L=>(M(null),Yn(L).then(()=>{P.replaceChildren(L)}).catch(A=>{throw A.name==="CANVAS_POSSIBLY_TOO_BIG"?new Error(b("canvasError.canvasTooBig")):A}))).catch(L=>{console.error(L),M(L)})},[e,o,k,R,l,m,u,y,x]),Ki("div",{className:"ImageExportModal",children:[it("h3",{children:b("imageExportDialog.header")}),Ki("div",{className:"ImageExportModal__preview",children:[it("div",{className:"ImageExportModal__preview__canvas",ref:w,children:S&&it(QP,{})}),it("div",{className:"ImageExportModal__preview__filename",children:!Ti&&it("input",{type:"text",className:"TextInput",value:l,style:{width:"30ch"},onChange:P=>{s(P.target.value),r.executeAction(ku,"ui",P.target.value)}})})]}),Ki("div",{className:"ImageExportModal__settings",children:[it("h3",{children:b("imageExportDialog.header")}),a&&it(_d,{label:b("imageExportDialog.label.onlySelected"),name:"exportOnlySelected",children:it(Md,{name:"exportOnlySelected",checked:c,onChange:P=>{d(P)}})}),it(_d,{label:b("imageExportDialog.label.withBackground"),name:"exportBackgroundSwitch",children:it(Md,{name:"exportBackgroundSwitch",checked:m,onChange:P=>{p(P),r.executeAction(Au,"ui",P)}})}),JP&&it(_d,{label:b("imageExportDialog.label.darkMode"),name:"exportDarkModeSwitch",children:it(Md,{name:"exportDarkModeSwitch",checked:u,onChange:P=>{g(P),r.executeAction(uT,"ui",P)}})}),it(_d,{label:b("imageExportDialog.label.embedScene"),tooltip:b("imageExportDialog.tooltip.embedScene"),name:"exportEmbedSwitch",children:it(Md,{name:"exportEmbedSwitch",checked:x,onChange:P=>{E(P),r.executeAction(Mu,"ui",P)}})}),it(_d,{label:b("imageExportDialog.label.scale"),name:"exportScale",children:it(xg,{name:"exportScale",value:y,onChange:P=>{T(P),r.executeAction(pT,"ui",P)},choices:pl.map(P=>({value:P,label:`${P}\xD7`}))})}),Ki("div",{className:"ImageExportModal__settings__buttons",children:[it(fn,{className:"ImageExportModal__settings__buttons__button",label:b("imageExportDialog.title.exportToPng"),onClick:()=>n(nm.png,k,{exportingFrame:R}),icon:lu,children:b("imageExportDialog.button.exportToPng")}),it(fn,{className:"ImageExportModal__settings__buttons__button",label:b("imageExportDialog.title.exportToSvg"),onClick:()=>n(nm.svg,k,{exportingFrame:R}),icon:lu,children:b("imageExportDialog.button.exportToSvg")}),(jl||Sn)&&it(fn,{className:"ImageExportModal__settings__buttons__button",label:b("imageExportDialog.title.copyPngToClipboard"),onClick:()=>n(nm.clipboard,k,{exportingFrame:R}),icon:Kc,children:b("imageExportDialog.button.copyPngToClipboard")})]})]})]})},_d=({label:e,children:t,tooltip:o,name:r})=>Ki("div",{className:"ImageExportModal__settings__setting",title:e,children:[Ki("label",{htmlFor:r,className:"ImageExportModal__settings__setting__label",children:[e,o&&it(Xo,{label:o,long:!0,children:wb})]}),it("div",{className:"ImageExportModal__settings__setting__content",children:t})]}),f6=({elements:e,appState:t,files:o,actionManager:r,onExportImage:n,onCloseRequest:i,name:a})=>{let[{appStateSnapshot:l,elementsSnapshot:s}]=Yi(()=>({appStateSnapshot:Zr(t),elementsSnapshot:Zr(e)}));return it(gt,{onCloseRequest:i,size:"wide",title:!1,children:it(eD,{elementsSnapshot:s,appStateSnapshot:l,files:o,actionManager:r,onExportImage:n,name:a})})}});var x6=v(()=>{});import tD from"clsx";import{jsx as oD}from"react/jsx-runtime";var Eg,mE=v(()=>{"use strict";f();x6();Eg=({children:e,side:t,className:o})=>oD("div",{className:tD("FixedSideContainer",`FixedSideContainer_side_${t}`,o),children:e})});var E6=v(()=>{});import{jsx as y6}from"react/jsx-runtime";var rD,yg,pE=v(()=>{"use strict";f();X();se();G();Fo();E6();rD=({appState:e,isMobile:t,device:o,app:r})=>{let{activeTool:n,isResizing:i,isRotating:a,lastPointerDownWith:l}=e,s=e.multiElement!==null;if(e.openSidebar&&!o.editor.canFitSidebar)return null;if(To(e))return b("hints.eraserRevert");if(n.type==="arrow"||n.type==="line")return s?b("hints.linearElementMulti"):b("hints.linearElement");if(n.type==="freedraw")return b("hints.freeDraw");if(n.type==="text")return b("hints.text");if(n.type==="embeddable")return b("hints.embeddable");if(e.activeTool.type==="image"&&e.pendingImageElementId)return b("hints.placeImage");let c=r.scene.getSelectedElements(e);if(i&&l==="mouse"&&c.length===1){let d=c[0];return ne(d)&&d.points.length===2?b("hints.lockAngle"):nr(d)?b("hints.resizeImage"):b("hints.resize")}if(a&&l==="mouse")return b("hints.rotate");if(c.length===1&&W(c[0]))return b("hints.text_selected");if(e.editingElement&&W(e.editingElement))return b("hints.text_editing");if(n.type==="selection"){if(e.draggingElement?.type==="selection"&&!c.length&&!e.editingElement&&!e.editingLinearElement)return b("hints.deepBoxSelect");if(e.gridSize&&e.draggingElement)return b("hints.disableSnapping");if(!c.length&&!t)return b("hints.canvasPanning");if(c.length===1){if(ne(c[0]))return e.editingLinearElement?e.editingLinearElement.selectedPointsIndices?b("hints.lineEditor_pointSelected"):b("hints.lineEditor_nothingSelected"):b("hints.lineEditor_info");if(!e.draggingElement&&jr(c[0]))return b("hints.bindTextToElement")}}return null},yg=({appState:e,isMobile:t,device:o,app:r})=>{let n=rD({appState:e,isMobile:t,device:o,app:r});return n?(n=N(n),y6("div",{className:"HintViewer",children:y6("span",{children:n})})):null}});import nD from"clsx";import{jsx as v6,jsxs as aD}from"react/jsx-runtime";var iD,w6,wg,uE=v(()=>{"use strict";f();jn();ee();iD="medium",w6={CHECKED:Fa,UNCHECKED:Mi},wg=e=>aD("label",{className:nD("ToolIcon ToolIcon__lock",`ToolIcon_size_${iD}`,{"is-mobile":e.isMobile}),title:`${e.title} \u2014 Q`,children:[v6("input",{className:"ToolIcon_type_checkbox",type:"checkbox",name:e.name,onChange:e.onChange,checked:e.checked,"aria-label":e.title,"data-testid":"toolbar-lock"}),v6("div",{className:"ToolIcon__icon",children:e.checked?w6.CHECKED:w6.UNCHECKED})]})});import{Fragment as lD,jsx as T6,jsxs as sD}from"react/jsx-runtime";var $i,vg=v(()=>{"use strict";f();X();ye();$i=({heading:e,children:t,...o})=>{let{id:r}=Wt(),n=T6("h2",{className:"visually-hidden",id:`${r}-${e}-title`,children:b(`headings.${e}`)});return T6("section",{...o,"aria-labelledby":`${r}-${e}-title`,children:typeof t=="function"?t(n):sD(lD,{children:[n,t]})})}});var Gr,bn,C6,I6,gE,Tg=v(()=>{"use strict";f();he();G();X();Gr=4,bn=6,C6="rgba(0,0,0,0.3)",I6=(e,t,o,r)=>{if(!e.length)return{horizontal:null,vertical:null};let[n,i,a,l]=Se(e),s=t/r.zoom.value,c=o/r.zoom.value,d=t-s,m=o-c,p={top:parseInt(Vs("sat"))||0,bottom:parseInt(Vs("sab"))||0,left:parseInt(Vs("sal"))||0,right:parseInt(Vs("sar"))||0},u=Cn().rtl,g=-r.scrollX+d/2+p.left,x=-r.scrollY+m/2+p.top,E=g+s-p.right,y=x+c-p.bottom,T=Math.min(n,g),w=Math.min(i,x),S=Math.max(a,E),M=Math.max(l,y);return{horizontal:g===T&&E===S?null:{x:Math.max(p.left,Gr)+(g-T)/(S-T)*t,y:o-bn-Math.max(Gr,p.bottom),width:(E-g)/(S-T)*t-Math.max(Gr*2,p.left+p.right),height:bn},vertical:x===w&&y===M?null:{x:u?Math.max(p.left,Gr):t-bn-Math.max(p.right,Gr),y:(x-w)/(M-w)*o+Math.max(p.top,Gr),width:bn,height:(y-x)/(M-w)*o-Math.max(Gr*2,p.top+p.bottom)}}},gE=(e,t,o)=>{let[r,n]=[e.horizontal,e.vertical].map(a=>a!=null&&a.x<=t&&t<=a.x+a.width&&a.y<=o&&o<=a.y+a.height);return{isOverEither:r||n,isOverHorizontal:r,isOverVertical:n}}});import cD from"clsx";import{jsx as S6,jsxs as mD}from"react/jsx-runtime";var dD,Cg,hE=v(()=>{"use strict";f();jn();ee();dD="medium",Cg=e=>e.penDetected?mD("label",{className:cD("ToolIcon ToolIcon__penMode",`ToolIcon_size_${dD}`,{"is-mobile":e.isMobile}),title:`${e.title}`,children:[S6("input",{className:"ToolIcon_type_checkbox",type:"checkbox",name:e.name,onChange:e.onChange,checked:e.checked,"aria-label":e.title}),S6("div",{className:"ToolIcon__icon",children:w1})]}):null});var k6=v(()=>{});import{Fragment as A6,jsx as tt,jsxs as Jo}from"react/jsx-runtime";var Ig,fE=v(()=>{"use strict";f();bt();X();We();ee();zi();k6();Ig=e=>{let t=Se(e.elements),o=Ba(e.elements,e.appState),r=Se(o);return tt("div",{className:"Stats",children:Jo(oo,{padding:2,children:[tt("div",{className:"close",onClick:e.onClose,children:Yo}),tt("h3",{children:b("stats.title")}),tt("table",{children:Jo("tbody",{children:[tt("tr",{children:tt("th",{colSpan:2,children:b("stats.scene")})}),Jo("tr",{children:[tt("td",{children:b("stats.elements")}),tt("td",{children:e.elements.length})]}),Jo("tr",{children:[tt("td",{children:b("stats.width")}),tt("td",{children:Math.round(t[2])-Math.round(t[0])})]}),Jo("tr",{children:[tt("td",{children:b("stats.height")}),tt("td",{children:Math.round(t[3])-Math.round(t[1])})]}),o.length===1&&tt("tr",{children:tt("th",{colSpan:2,children:b("stats.element")})}),o.length>1&&Jo(A6,{children:[tt("tr",{children:tt("th",{colSpan:2,children:b("stats.selected")})}),Jo("tr",{children:[tt("td",{children:b("stats.elements")}),tt("td",{children:o.length})]})]}),o.length>0&&Jo(A6,{children:[Jo("tr",{children:[tt("td",{children:"x"}),tt("td",{children:Math.round(r[0])})]}),Jo("tr",{children:[tt("td",{children:"y"}),tt("td",{children:Math.round(r[1])})]}),Jo("tr",{children:[tt("td",{children:b("stats.width")}),tt("td",{children:Math.round(r[2]-r[0])})]}),Jo("tr",{children:[tt("td",{children:b("stats.height")}),tt("td",{children:Math.round(r[3]-r[1])})]})]}),o.length===1&&Jo("tr",{children:[tt("td",{children:b("stats.angle")}),tt("td",{children:`${Math.round(o[0].angle*180/Math.PI)}\xB0`})]}),e.renderCustomStats?.(e.elements,e.appState)]})})]})})}});import pD from"clsx";import{jsx as uD}from"react/jsx-runtime";var Sg,bE=v(()=>{"use strict";f();jn();Mt();ee();ue();Sg=e=>uD(ce,{className:pD("Shape",{fillable:!1}),type:"radio",icon:Yc,name:"editor-current-shape",checked:e.checked,title:`${e.title} \u2014 H`,keyBindingLabel:e.isMobile?void 0:I.H.toLocaleUpperCase(),"aria-label":`${e.title} \u2014 H`,"aria-keyshortcuts":I.H,"data-testid":"toolbar-hand",onChange:()=>e.onChange?.()})});var M6=v(()=>{});import{jsx as xE}from"react/jsx-runtime";var L6,_6=v(()=>{"use strict";f();X();G();ee();M6();L6=({onHomeButtonClick:e})=>xE("label",{title:`${$r(b("toolBar.library"))} \u2014 0`,children:xE("div",{className:"library-button",onClick:e,children:xE("div",{children:s1})})})});import{Fragment as gD,jsx as _t,jsxs as Xi}from"react/jsx-runtime";var P6,D6=v(()=>{"use strict";f();X();tl();he();mE();zi();pE();We();Sd();vg();Tg();uE();hE();fE();Er();bE();Fo();qo();_6();P6=({appState:e,elements:t,actionManager:o,setAppState:r,onLockToggle:n,onHandToolToggle:i,onPenModeToggle:a,renderTopRightUI:l,renderCustomStats:s,renderSidebars:c,device:d,renderWelcomeScreen:m,UIOptions:p,app:u,onHomeButtonClick:g})=>{let{WelcomeScreenCenterTunnel:x,MainMenuTunnel:E,DefaultSidebarTriggerTunnel:y}=nt(),T=()=>Xi(Eg,{side:"top",className:"App-top-bar",children:[m&&_t(x.Out,{}),_t($i,{heading:"shapes",children:S=>_t(Yt.Col,{gap:4,align:"center",children:Xi(Yt.Row,{gap:1,className:"App-toolbar-container",children:[Xi(oo,{padding:1,className:"App-toolbar App-toolbar--mobile",children:[S,_t(Yt.Row,{gap:1,children:_t(ug,{appState:e,activeTool:e.activeTool,UIOptions:p,app:u})})]}),l&&l(!0,e),Xi("div",{className:"mobile-misc-tools-container",children:[!e.viewModeEnabled&&_t(y.Out,{}),_t(Cg,{checked:e.penMode,onChange:()=>a(null),title:b("toolBar.penMode"),isMobile:!0,penDetected:e.penDetected}),_t(wg,{checked:e.activeTool.locked,onChange:n,title:b("toolBar.lock"),isMobile:!0}),_t(Sg,{checked:Rr(e),onChange:()=>i(),title:b("toolBar.hand"),isMobile:!0})]}),_t("div",{className:"mobile-misc-tools-container-left",children:_t(L6,{onHomeButtonClick:g})})]})})}),_t(yg,{appState:e,isMobile:!0,device:d,app:u})]}),w=()=>e.viewModeEnabled?_t("div",{className:"App-toolbar-content",children:_t(E.Out,{})}):Xi("div",{className:"App-toolbar-content",children:[_t(E.Out,{}),o.renderAction("toggleEditMenu"),o.renderAction("undo"),o.renderAction("redo"),o.renderAction(e.multiElement?"finalize":"duplicateSelection"),o.renderAction("deleteSelectedElements")]});return Xi(gD,{children:[c(),!e.viewModeEnabled&&T(),!e.openMenu&&e.showStats&&_t(Ig,{appState:e,setAppState:r,elements:t,onClose:()=>{o.executeAction(Qn)},renderCustomStats:s}),_t("div",{className:"App-bottom-bar",style:{marginBottom:bn+Gr*2,marginLeft:bn+Gr*2,marginRight:bn+Gr*2},children:Xi(oo,{padding:0,children:[e.openMenu==="shape"&&!e.viewModeEnabled&&Na(e,t)?_t($i,{className:"App-mobile-menu",heading:"selectedShapeActions",children:_t(pg,{appState:e,elementsMap:u.scene.getNonDeletedElementsMap(),renderAction:o.renderAction})}):null,Xi("footer",{className:"App-toolbar",children:[w(),e.scrolledOutside&&!e.openMenu&&!e.openSidebar&&_t("button",{className:"scroll-back-to-content",onClick:()=>{r(S=>({...nn(t,S)}))},children:b("buttons.scrollBackToContent")})]})]})})]})}});var R6=v(()=>{});import hD,{useLayoutEffect as fD,useRef as bD,useState as xD}from"react";import{jsx as Pd,jsxs as ED}from"react/jsx-runtime";var N6,O6,B6=v(()=>{"use strict";f();So();Nf();U();X();Yl();ye();jo();R6();N6=e=>{let t=bD(null),[o,r]=xD(null);return fD(()=>{if(!e.spreadsheet)return;let n=Yw(e.chartType,e.spreadsheet,0,0);r(n);let i,a=t.current;return(async()=>(i=await Vl({data:{elements:n,appState:{exportBackground:!1,viewBackgroundColor:Ht},files:null}}),i.querySelector(".style-fonts")?.remove(),a.replaceChildren(),a.appendChild(i),e.selected&&a.parentNode.focus()))(),()=>{a.replaceChildren()}},[e.spreadsheet,e.chartType,e.selected]),Pd("button",{className:"ChartPreview",onClick:()=>{o&&e.onClick(e.chartType,o)},children:Pd("div",{ref:t})})},O6=({setAppState:e,appState:t,onClose:o})=>{let{onInsertElements:r}=ko(),n=hD.useCallback(()=>{o&&o()},[o]),i=(a,l)=>{r(l),we("paste","chart",a),e({currentChartType:a,pasteDialog:{shown:!1,data:null}})};return Pd(gt,{size:"small",onCloseRequest:n,title:b("labels.pasteCharts"),className:"PasteChartDialog",autofocus:!1,children:ED("div",{className:"container",children:[Pd(N6,{chartType:"bar",spreadsheet:t.pasteDialog.data,selected:t.currentChartType==="bar",onClick:i}),Pd(N6,{chartType:"line",spreadsheet:t.pasteDialog.data,selected:t.currentChartType==="line",onClick:i})]})})}});var F6=v(()=>{});import yD from"react";import{Fragment as z6,jsx as V,jsxs as Qo}from"react/jsx-runtime";function*TD(e,t){let o=!0;for(let r of e)o||(yield t),o=!1,yield r}var wD,vD,EE,CD,Z,ID,H6,G6=v(()=>{"use strict";f();X();ue();jo();G();F6();ee();Ai();U();ol();wD=()=>Qo("div",{className:"HelpDialog__header",children:[Qo("a",{className:"HelpDialog__btn",href:"https://docs.excalidraw.com",target:"_blank",rel:"noopener noreferrer",children:[V("div",{className:"HelpDialog__link-icon",children:Wp}),b("helpDialog.documentation")]}),Qo("a",{className:"HelpDialog__btn",href:"https://blog.excalidraw.com",target:"_blank",rel:"noopener noreferrer",children:[V("div",{className:"HelpDialog__link-icon",children:Wp}),b("helpDialog.blog")]}),Qo("a",{className:"HelpDialog__btn",href:"https://github.com/excalidraw/excalidraw/issues",target:"_blank",rel:"noopener noreferrer",children:[V("div",{className:"HelpDialog__link-icon",children:Gc}),b("helpDialog.github")]}),Qo("a",{className:"HelpDialog__btn",href:"https://youtube.com/@excalidraw",target:"_blank",rel:"noopener noreferrer",children:[V("div",{className:"HelpDialog__link-icon",children:Gb}),"YouTube"]})]}),vD=e=>Qo(z6,{children:[V("h3",{children:e.title}),V("div",{className:"HelpDialog__islands-container",children:e.children})]}),EE=e=>Qo("div",{className:`HelpDialog__island ${e.className}`,children:[V("h4",{className:"HelpDialog__island-title",children:e.caption}),V("div",{className:"HelpDialog__island-content",children:e.children})]});CD=e=>e.replace(/\b[a-z]\b/,t=>t.toUpperCase()),Z=({label:e,shortcuts:t,isOr:o=!0})=>{let r=t.map(n=>(n.endsWith("++")?[...n.slice(0,-2).split("+"),"+"]:n.split("+")).map(a=>V(ID,{children:CD(a)},a)));return Qo("div",{className:"HelpDialog__shortcut",children:[V("div",{children:e}),V("div",{className:"HelpDialog__key-container",children:[...TD(r,o?b("helpDialog.or"):null)]})]})},ID=e=>V("kbd",{className:"HelpDialog__key",...e}),H6=({onClose:e})=>{let t=yD.useCallback(()=>{e&&e()},[e]);return V(z6,{children:Qo(gt,{onCloseRequest:t,title:b("helpDialog.title"),className:"HelpDialog",children:[V(wD,{}),Qo(vD,{title:b("helpDialog.shortcuts"),children:[Qo(EE,{className:"HelpDialog__island--tools",caption:b("helpDialog.tools"),children:[V(Z,{label:b("toolBar.hand"),shortcuts:[I.H]}),V(Z,{label:b("toolBar.selection"),shortcuts:[I.V,I[1]]}),V(Z,{label:b("toolBar.rectangle"),shortcuts:[I.R,I[2]]}),V(Z,{label:b("toolBar.diamond"),shortcuts:[I.D,I[3]]}),V(Z,{label:b("toolBar.ellipse"),shortcuts:[I.O,I[4]]}),V(Z,{label:b("toolBar.arrow"),shortcuts:[I.A,I[5]]}),V(Z,{label:b("toolBar.line"),shortcuts:[I.L,I[6]]}),V(Z,{label:b("toolBar.freedraw"),shortcuts:[I.P,I[7]]}),V(Z,{label:b("toolBar.text"),shortcuts:[I.T,I[8]]}),V(Z,{label:b("toolBar.image"),shortcuts:[I[9]]}),V(Z,{label:b("toolBar.eraser"),shortcuts:[I.E,I[0]]}),V(Z,{label:b("toolBar.frame"),shortcuts:[I.F]}),V(Z,{label:b("toolBar.laser"),shortcuts:[I.K]}),V(Z,{label:b("labels.eyeDropper"),shortcuts:[I.I,"Shift+S","Shift+G"]}),V(Z,{label:b("helpDialog.editLineArrowPoints"),shortcuts:[N("CtrlOrCmd+Enter")]}),V(Z,{label:b("helpDialog.editText"),shortcuts:[N("Enter")]}),V(Z,{label:b("helpDialog.textNewLine"),shortcuts:[N("Enter"),N("Shift+Enter")]}),V(Z,{label:b("helpDialog.textFinish"),shortcuts:[N("Esc"),N("CtrlOrCmd+Enter")]}),V(Z,{label:b("helpDialog.curvedArrow"),shortcuts:["A",b("helpDialog.click"),b("helpDialog.click"),b("helpDialog.click")],isOr:!1}),V(Z,{label:b("helpDialog.curvedLine"),shortcuts:["L",b("helpDialog.click"),b("helpDialog.click"),b("helpDialog.click")],isOr:!1}),V(Z,{label:b("toolBar.lock"),shortcuts:[I.Q]}),V(Z,{label:b("helpDialog.preventBinding"),shortcuts:[N("CtrlOrCmd")]}),V(Z,{label:b("toolBar.link"),shortcuts:[N("CtrlOrCmd+K")]})]}),Qo(EE,{className:"HelpDialog__island--view",caption:b("helpDialog.view"),children:[V(Z,{label:b("buttons.zoomIn"),shortcuts:[N("CtrlOrCmd++")]}),V(Z,{label:b("buttons.zoomOut"),shortcuts:[N("CtrlOrCmd+-")]}),V(Z,{label:b("buttons.resetZoom"),shortcuts:[N("CtrlOrCmd+0")]}),V(Z,{label:b("helpDialog.zoomToFit"),shortcuts:["Shift+1"]}),V(Z,{label:b("helpDialog.zoomToSelection"),shortcuts:["Shift+2"]}),V(Z,{label:b("helpDialog.movePageUpDown"),shortcuts:["PgUp/PgDn"]}),V(Z,{label:b("helpDialog.movePageLeftRight"),shortcuts:["Shift+PgUp/PgDn"]}),V(Z,{label:b("buttons.zenMode"),shortcuts:[N("Alt+Z")]}),V(Z,{label:b("buttons.objectsSnapMode"),shortcuts:[N("Alt+S")]}),V(Z,{label:b("labels.showGrid"),shortcuts:[N("CtrlOrCmd+'")]}),V(Z,{label:b("labels.viewMode"),shortcuts:[N("Alt+R")]}),V(Z,{label:b("labels.toggleTheme"),shortcuts:[N("Alt+Shift+D")]}),V(Z,{label:b("stats.title"),shortcuts:[N("Alt+/")]}),V(Z,{label:b("commandPalette.title"),shortcuts:Sn?[Lt("commandPalette")]:[Lt("commandPalette"),Lt("commandPalette",1)]})]}),Qo(EE,{className:"HelpDialog__island--editor",caption:b("helpDialog.editor"),children:[V(Z,{label:b("labels.moveCanvas"),shortcuts:[N(`Space+${b("helpDialog.drag")}`),N(`Wheel+${b("helpDialog.drag")}`)],isOr:!0}),V(Z,{label:b("buttons.clearReset"),shortcuts:[N("CtrlOrCmd+Delete")]}),V(Z,{label:b("labels.delete"),shortcuts:[N("Delete")]}),V(Z,{label:b("labels.cut"),shortcuts:[N("CtrlOrCmd+X")]}),V(Z,{label:b("labels.copy"),shortcuts:[N("CtrlOrCmd+C")]}),V(Z,{label:b("labels.paste"),shortcuts:[N("CtrlOrCmd+V")]}),V(Z,{label:b("labels.pasteAsPlaintext"),shortcuts:[N("CtrlOrCmd+Shift+V")]}),V(Z,{label:b("labels.selectAll"),shortcuts:[N("CtrlOrCmd+A")]}),V(Z,{label:b("labels.multiSelect"),shortcuts:[N(`Shift+${b("helpDialog.click")}`)]}),V(Z,{label:b("helpDialog.deepSelect"),shortcuts:[N(`CtrlOrCmd+${b("helpDialog.click")}`)]}),V(Z,{label:b("helpDialog.deepBoxSelect"),shortcuts:[N(`CtrlOrCmd+${b("helpDialog.drag")}`)]}),(jl||Sn)&&V(Z,{label:b("labels.copyAsPng"),shortcuts:[N("Shift+Alt+C")]}),V(Z,{label:b("labels.copyStyles"),shortcuts:[N("CtrlOrCmd+Alt+C")]}),V(Z,{label:b("labels.pasteStyles"),shortcuts:[N("CtrlOrCmd+Alt+V")]}),V(Z,{label:b("labels.sendToBack"),shortcuts:[so?N("CtrlOrCmd+Alt+["):N("CtrlOrCmd+Shift+[")]}),V(Z,{label:b("labels.bringToFront"),shortcuts:[so?N("CtrlOrCmd+Alt+]"):N("CtrlOrCmd+Shift+]")]}),V(Z,{label:b("labels.sendBackward"),shortcuts:[N("CtrlOrCmd+[")]}),V(Z,{label:b("labels.bringForward"),shortcuts:[N("CtrlOrCmd+]")]}),V(Z,{label:b("labels.alignTop"),shortcuts:[N("CtrlOrCmd+Shift+Up")]}),V(Z,{label:b("labels.alignBottom"),shortcuts:[N("CtrlOrCmd+Shift+Down")]}),V(Z,{label:b("labels.alignLeft"),shortcuts:[N("CtrlOrCmd+Shift+Left")]}),V(Z,{label:b("labels.alignRight"),shortcuts:[N("CtrlOrCmd+Shift+Right")]}),V(Z,{label:b("labels.duplicateSelection"),shortcuts:[N("CtrlOrCmd+D"),N(`Alt+${b("helpDialog.drag")}`)]}),V(Z,{label:b("helpDialog.toggleElementLock"),shortcuts:[N("CtrlOrCmd+Shift+L")]}),V(Z,{label:b("buttons.undo"),shortcuts:[N("CtrlOrCmd+Z")]}),V(Z,{label:b("buttons.redo"),shortcuts:em?[N("CtrlOrCmd+Y"),N("CtrlOrCmd+Shift+Z")]:[N("CtrlOrCmd+Shift+Z")]}),V(Z,{label:b("labels.group"),shortcuts:[N("CtrlOrCmd+G")]}),V(Z,{label:b("labels.ungroup"),shortcuts:[N("CtrlOrCmd+Shift+G")]}),V(Z,{label:b("labels.flipHorizontal"),shortcuts:[N("Shift+H")]}),V(Z,{label:b("labels.flipVertical"),shortcuts:[N("Shift+V")]}),V(Z,{label:b("labels.showStroke"),shortcuts:[N("S")]}),V(Z,{label:b("labels.showBackground"),shortcuts:[N("G")]}),V(Z,{label:b("labels.decreaseFontSize"),shortcuts:[N("CtrlOrCmd+Shift+<")]}),V(Z,{label:b("labels.increaseFontSize"),shortcuts:[N("CtrlOrCmd+Shift+>")]})]})]})]})})}});var U6=v(()=>{});import Dd,{useLayoutEffect as SD}from"react";import W6 from"clsx";import*as As from"@radix-ui/react-popover";import{jsx as ti,jsxs as ks}from"react/jsx-runtime";var kD,AD,MD,yE,LD,kg,wE=v(()=>{"use strict";f();U6();Ni();ye();zi();ee();X();G();U();kD=4,AD=8,MD=({shouldWrap:e,children:t,username:o})=>e?ti(Xo,{label:o||"Unknown user",children:t}):ti(Dd.Fragment,{children:t}),yE=({actionManager:e,collaborator:t,socketId:o,withName:r=!1,shouldWrapWithTooltip:n=!1,isBeingFollowed:i})=>{let a={socketId:o,collaborator:t,withName:r,isBeingFollowed:i},l=e.renderAction("goToCollaborator",a);return ti(MD,{username:t.username,shouldWrap:n,children:l},o)},LD=["avatarUrl","id","socketId","username","isInCall","isSpeaking","isMuted"],kg=Dd.memo(({className:e,mobile:t,collaborators:o,userToFollow:r})=>{let n=Ft(),i=new Map;o.forEach((E,y)=>{let T=E.id||y;i.set(T,{...E,socketId:y})});let a=Array.from(i.values()).filter(E=>E.username?.trim()),[l,s]=Dd.useState(""),c=Dd.useRef(null);SD(()=>{if(c.current){let E=T=>{let w=Math.max(1,Math.min(8,Math.floor(T/38)));m(w)};if(E(c.current.clientWidth),!Bs)return;let y=new ResizeObserver(T=>{for(let w of T){let{width:S}=w.contentRect;E(S)}});return y.observe(c.current),()=>{y.disconnect()}}},[]);let[d,m]=Dd.useState(kD),u=l.trim().toLowerCase()?a.filter(E=>E.username?.toLowerCase().includes(l)):a,x=a.slice(0,d-1).map(E=>yE({actionManager:n,collaborator:E,socketId:E.socketId,shouldWrapWithTooltip:!0,isBeingFollowed:E.socketId===r}));return t?ti("div",{className:W6("UserList UserList_mobile",e),children:a.map(E=>yE({actionManager:n,collaborator:E,socketId:E.socketId,shouldWrapWithTooltip:!0,isBeingFollowed:E.socketId===r}))}):ti("div",{className:"UserList-wrapper",ref:c,children:ks("div",{className:W6("UserList",e),style:{"--max-avatars":d},children:[x,a.length>d-1&&ks(As.Root,{onOpenChange:E=>{E||s("")},children:[ks(As.Trigger,{className:"UserList__more",children:["+",a.length-d+1]}),ti(As.Content,{style:{zIndex:2,width:"15rem",textAlign:"left"},align:"end",sideOffset:10,children:ks(oo,{style:{overflow:"hidden"},children:[a.length>=AD&&ks("div",{className:"UserList__search-wrapper",children:[jc,ti("input",{className:"UserList__search",type:"text",placeholder:b("userList.search.placeholder"),value:l,onChange:E=>{s(E.target.value)}})]}),ks("div",{className:"dropdown-menu UserList__collaborators",children:[u.length===0&&ti("div",{className:"UserList__collaborators__empty",children:b("userList.search.empty")}),ti("div",{className:"UserList__hint",children:b("userList.hint.text")}),u.map(E=>yE({actionManager:n,collaborator:E,socketId:E.socketId,withName:!0,isBeingFollowed:E.socketId===r}))]})]})})]})]})})},(e,t)=>{if(e.collaborators.size!==t.collaborators.size||e.mobile!==t.mobile||e.className!==t.className||e.userToFollow!==t.userToFollow)return!1;let o=t.collaborators.keys();for(let[r,n]of e.collaborators){let i=t.collaborators.get(r);if(!i||r!==o.next().value||!It(n,i,LD))return!1}return!0})});var V6=v(()=>{});import vE from"open-color";import{jsx as _D}from"react/jsx-runtime";var TE,Y6=v(()=>{"use strict";f();V6();TE=({children:e,color:t})=>_D("div",{className:"Card",style:{"--card-color":t==="primary"?"var(--color-primary)":vE[t][7],"--card-color-darker":t==="primary"?"var(--color-primary-darker)":vE[t][8],"--card-color-darkest":t==="primary"?"var(--color-primary-darkest)":vE[t][9]},children:e})});var K6=v(()=>{});import PD from"react";import{Fragment as RD,jsx as Ur,jsxs as Ag}from"react/jsx-runtime";var DD,$6,X6=v(()=>{"use strict";f();X();jo();ee();Mt();cd();Y6();K6();Wn();So();G();DD=({elements:e,appState:t,setAppState:o,files:r,actionManager:n,exportOpts:i,canvas:a,onCloseRequest:l})=>{let{onExportToBackend:s}=i;return Ur("div",{className:"ExportDialog ExportDialog--json",children:Ag("div",{className:"ExportDialog-cards",children:[i.saveFileToDisk&&Ag(TE,{color:"lime",children:[Ur("div",{className:"Card-icon",children:R1}),Ur("h2",{children:b("exportDialog.disk_title")}),Ag("div",{className:"Card-details",children:[b("exportDialog.disk_details"),!Ti&&n.renderAction("changeProjectName")]}),Ur(ce,{className:"Card-button",type:"button",title:b("exportDialog.disk_button"),"aria-label":b("exportDialog.disk_button"),showAriaLabel:!0,onClick:()=>{n.executeAction(ps,"ui")}})]}),s&&Ag(TE,{color:"pink",children:[Ur("div",{className:"Card-icon",children:ns}),Ur("h2",{children:b("exportDialog.link_title")}),Ur("div",{className:"Card-details",children:b("exportDialog.link_details")}),Ur(ce,{className:"Card-button",type:"button",title:b("exportDialog.link_button"),"aria-label":b("exportDialog.link_button"),showAriaLabel:!0,onClick:async()=>{try{we("export","link",`ui (${Sy()})`),await s(e,t,r),l()}catch(c){o({errorMessage:c.message})}}})]}),i.renderCustomUI&&i.renderCustomUI(e,t,r,a)]})})},$6=({elements:e,appState:t,files:o,actionManager:r,exportOpts:n,canvas:i,setAppState:a})=>{let l=PD.useCallback(()=>{a({openDialog:null})},[a]);return Ur(RD,{children:t.openDialog?.name==="jsonExport"&&Ur(gt,{onCloseRequest:l,title:b("buttons.export"),children:Ur(DD,{elements:e,appState:t,setAppState:a,files:o,actionManager:r,onCloseRequest:l,exportOpts:n,canvas:i})})})}});import{jsx as ND}from"react/jsx-runtime";var Z6,j6=v(()=>{"use strict";f();X();ee();Z6=e=>ND("button",{className:"help-icon",onClick:e.onClick,type:"button",title:`${b("helpDialog.title")} \u2014 ?`,"aria-label":b("helpDialog.title"),children:za})});import Mg from"clsx";import{jsx as xn,jsxs as CE}from"react/jsx-runtime";var q6,J6,Q6=v(()=>{"use strict";f();Er();Sd();ye();qo();j6();vg();tl();q6=({appState:e,actionManager:t,showExitZenModeBtn:o,renderWelcomeScreen:r})=>{let{FooterCenterTunnel:n,WelcomeScreenHelpHintTunnel:i}=nt(),a=_e(),l=!e.viewModeEnabled&&e.multiElement&&a.isTouchScreen;return CE("footer",{role:"contentinfo",className:"layer-ui__wrapper__footer App-menu App-menu_bottom",children:[xn("div",{className:Mg("layer-ui__wrapper__footer-left zen-mode-transition",{"layer-ui__wrapper__footer-left--transition-left":e.zenModeEnabled}),children:xn(Yt.Col,{gap:2,children:CE($i,{heading:"canvasActions",children:[xn(OC,{renderAction:t.renderAction,zoom:e.zoom}),!e.viewModeEnabled&&xn(BC,{renderAction:t.renderAction,className:Mg("zen-mode-transition",{"layer-ui__wrapper__footer-left--transition-bottom":e.zenModeEnabled})}),l&&xn(HC,{renderAction:t.renderAction,className:Mg("zen-mode-transition",{"layer-ui__wrapper__footer-left--transition-left":e.zenModeEnabled})})]})})}),xn(n.Out,{}),xn("div",{className:Mg("layer-ui__wrapper__footer-right zen-mode-transition",{"transition-right":e.zenModeEnabled}),children:CE("div",{style:{position:"relative"},children:[r&&xn(i.Out,{}),xn(Z6,{onClick:()=>t.executeAction(Fi)})]})}),xn(FC,{actionManager:t,showExitZenModeBtn:o})]})},J6=q6;q6.displayName="Footer"});import OD from"react";var Lg,IE=v(()=>{"use strict";f();Lg=OD.createContext({})});import BD from"clsx";import{useContext as FD}from"react";import{jsx as SE,jsxs as eI}from"react/jsx-runtime";var kE,tI=v(()=>{"use strict";f();X();ye();IE();ee();Ni();Is();kE=({children:e,className:t})=>{let o=_e(),r=FD(Lg),n=!!(o.editor.canFitSidebar&&r.shouldRenderDockButton);return eI("div",{className:BD("sidebar__header",t),"data-testid":"sidebar-header",children:[e,eI("div",{className:"sidebar__header__buttons",children:[n&&SE(Xo,{label:b("labels.sidebarLock"),children:SE(un,{onSelect:()=>r.onDock?.(!r.docked),selected:!!r.docked,className:"sidebar__dock","data-testid":"sidebar-dock","aria-label":b("labels.sidebarLock"),children:m1})}),SE(un,{"data-testid":"sidebar-close",className:"sidebar__close",onSelect:r.onCloseRequest,"aria-label":b("buttons.close"),children:Yo})]})]})};kE.displayName="SidebarHeader"});var oI=v(()=>{});import HD from"clsx";import{jsx as AE,jsxs as rI}from"react/jsx-runtime";var ME,nI=v(()=>{"use strict";f();ye();Vt();oI();ME=({name:e,tab:t,icon:o,title:r,children:n,onToggle:i,className:a,style:l})=>{let s=Be(),c=Re();return rI("label",{title:r,className:"sidebar-trigger__label-element",children:[AE("input",{className:"ToolIcon_type_checkbox",type:"checkbox",onChange:d=>{document.querySelector(".layer-ui__wrapper")?.classList.remove("animate");let m=d.target.checked;s({openSidebar:m?{name:e,tab:t}:null}),i?.(m)},checked:c.openSidebar?.name===e,"aria-label":r,"aria-keyshortcuts":"0"}),rI("div",{className:HD("sidebar-trigger",a),style:l,children:[o&&AE("div",{children:o}),n&&AE("div",{className:"sidebar-trigger__label",children:n})]})]})};ME.displayName="SidebarTrigger"});import*as iI from"@radix-ui/react-tabs";import{jsx as zD}from"react/jsx-runtime";var LE,aI=v(()=>{"use strict";f();LE=({children:e,...t})=>zD(iI.List,{className:"sidebar-triggers",...t,children:e});LE.displayName="SidebarTabTriggers"});import*as sI from"@radix-ui/react-tabs";import{jsx as lI}from"react/jsx-runtime";var _E,cI=v(()=>{"use strict";f();_E=({children:e,tab:t,onSelect:o,...r})=>lI(sI.Trigger,{value:t,asChild:!0,onSelect:o,children:lI("button",{type:"button",className:"excalidraw-button sidebar-tab-trigger",...r,children:e})});_E.displayName="SidebarTabTrigger"});import*as dI from"@radix-ui/react-tabs";import{jsx as GD}from"react/jsx-runtime";var PE,mI=v(()=>{"use strict";f();Vt();ye();PE=({children:e,...t})=>{let o=Re(),r=Be();if(!o.openSidebar)return null;let{name:n}=o.openSidebar;return GD(dI.Root,{className:"sidebar-tabs-root",value:o.openSidebar.tab,onValueChange:i=>r(a=>({...a,openSidebar:{...a.openSidebar,name:n,tab:i}})),...t,children:e})};PE.displayName="SidebarTabs"});import*as pI from"@radix-ui/react-tabs";import{jsx as UD}from"react/jsx-runtime";var DE,uI=v(()=>{"use strict";f();DE=({tab:e,children:t,...o})=>UD(pI.Content,{...o,value:e,"data-testid":e,children:t});DE.displayName="SidebarTab"});var gI=v(()=>{});import{useEffect as bI,useLayoutEffect as xI,useRef as RE,useState as WD,forwardRef as EI,useImperativeHandle as VD,useCallback as hI}from"react";import{atom as YD,useSetAtom as KD}from"jotai";import $D from"clsx";import{jsx as fI}from"react/jsx-runtime";import{createElement as XD}from"react";var Rd,yI,oi,Nd=v(()=>{"use strict";f();zi();Tt();IE();tI();ye();G();ue();U();nI();aI();cI();mI();uI();Vt();Eu();gI();Rd=YD(!1),yI=EI(({name:e,children:t,onDock:o,docked:r,className:n,...i},a)=>{C.DEV&&o&&r==null&&console.warn("Sidebar: `docked` must be set when `onDock` is supplied for the sidebar to be user-dockable. To hide this message, either pass `docked` or remove `onDock`");let l=Be(),s=KD(Rd,He);xI(()=>(s(!!r),()=>{s(!1)}),[s,r]);let c=RE({});c.current.onCloseRequest=()=>{l({openSidebar:null})},c.current.onDock=u=>o?.(u),c.current=hl(c.current,{docked:r,shouldRenderDockButton:!!o&&r!=null});let d=RE(null);VD(a,()=>d.current);let m=_e(),p=hI(()=>{document.querySelector(".Dialog")||l({openSidebar:null})},[l]);return cs(d,hI(u=>{u.target.closest(".sidebar-trigger")||(!r||!m.editor.canFitSidebar)&&p()},[p,r,m.editor.canFitSidebar])),bI(()=>{let u=g=>{g.key===I.ESCAPE&&(!r||!m.editor.canFitSidebar)&&p()};return document.addEventListener("keydown",u),()=>{document.removeEventListener("keydown",u)}},[p,r,m.editor.canFitSidebar]),fI(oo,{...i,className:$D("sidebar",{"sidebar--docked":r},n),ref:d,children:fI(Lg.Provider,{value:c.current,children:t})})});yI.displayName="SidebarInner";oi=Object.assign(EI((e,t)=>{let o=Re(),{onStateChange:r}=e,n=RE(o.openSidebar);bI(()=>{(!o.openSidebar&&n?.current?.name===e.name||o.openSidebar?.name===e.name&&n?.current?.name!==e.name||n.current?.name===e.name)&&o.openSidebar!==n.current&&r?.(o.openSidebar?.name!==e.name?null:o.openSidebar),n.current=o.openSidebar},[o.openSidebar,r,e.name]);let[i,a]=WD(!1);return xI(()=>(a(!0),()=>a(!1)),[]),i&&o.openSidebar?.name===e.name?XD(yI,{...e,ref:t,key:e.name}):null}),{Header:kE,TabTriggers:LE,TabTrigger:_E,Tabs:PE,Tab:DE,Trigger:ME});oi.displayName="Sidebar"});import{atom as ZD}from"jotai";async function wI({title:e,description:t,actionLabel:o,color:r}){return new Promise(n=>{Zt.set(NE,{active:!0,onConfirm:()=>n(!0),onClose:()=>n(!1),onReject:()=>n(!1),title:e,description:t,actionLabel:o,color:r})})}var NE,OE=v(()=>{"use strict";f();Tt();NE=ZD({active:!1})});import{Fragment as jD,jsx as BE,jsxs as vI}from"react/jsx-runtime";var TI,CI,II=v(()=>{"use strict";f();ye();cE();TI=({value:e,shortcut:t,onChange:o,choices:r,children:n,name:i})=>{let a=_e();return vI(jD,{children:[vI("div",{className:"dropdown-menu-item-base dropdown-menu-item-bare",children:[BE("label",{className:"dropdown-menu-item__text",htmlFor:i,children:n}),BE(xg,{name:i,value:e,onChange:o,choices:r})]}),t&&!a.editor.isMobile&&BE("div",{className:"dropdown-menu-item__shortcut dropdown-menu-item__shortcut--orphaned",children:t})]})};TI.displayName="DropdownMenuItemContentRadio";CI=TI});var SI=v(()=>{});var FE={};Os(FE,{ChangeCanvasBackground:()=>RI,ClearCanvas:()=>PI,CommandPalette:()=>LI,Export:()=>NI,Help:()=>_I,LiveCollaborationTrigger:()=>BI,LoadScene:()=>kI,SaveAsImage:()=>MI,SaveToActiveFile:()=>AI,Socials:()=>OI,ToggleTheme:()=>DI});import qD from"clsx";import{useSetAtom as JD}from"jotai";import{Fragment as QD,jsx as Kt,jsxs as FI}from"react/jsx-runtime";var kI,AI,MI,LI,_I,PI,DI,RI,NI,OI,BI,HI=v(()=>{"use strict";f();ol();X();ye();ee();ee();Ox();Bx();Er();kd();Tt();Vt();OE();Es();II();U();So();SI();kI=()=>{let{t:e}=Ct(),t=Ft(),o=Di();return t.isActionEnabled(ja)?Kt(xr,{icon:Ga,onSelect:async()=>{(!o.length||await wI({title:e("overwriteConfirm.modal.loadFromFile.title"),actionLabel:e("overwriteConfirm.modal.loadFromFile.button"),color:"warning",description:Kt(uo,{i18nKey:"overwriteConfirm.modal.loadFromFile.description",bold:n=>Kt("strong",{children:n}),br:()=>Kt("br",{})})}))&&t.executeAction(ja)},"data-testid":"load-button",shortcut:Lt("loadScene"),"aria-label":e("buttons.load"),children:e("buttons.load")}):null};kI.displayName="LoadScene";AI=()=>{let{t:e}=Ct(),t=Ft();return t.isActionEnabled(sd)?Kt(xr,{shortcut:Lt("saveScene"),"data-testid":"save-button",onSelect:()=>t.executeAction(sd),icon:_1,"aria-label":`${e("buttons.save")}`,children:`${e("buttons.save")}`}):null};AI.displayName="SaveToActiveFile";MI=()=>{let e=Be(),{t}=Ct();return Kt(xr,{icon:Wc,"data-testid":"image-export-button",onSelect:()=>e({openDialog:{name:"imageExport"}}),shortcut:Lt("imageExport"),"aria-label":t("buttons.exportImage"),children:t("buttons.exportImage")})};MI.displayName="SaveAsImage";LI=e=>{let t=Be(),{t:o}=Ct();return Kt(xr,{icon:qc,"data-testid":"command-palette-button",onSelect:()=>{we("command_palette","open","menu"),t({openDialog:{name:"commandPalette"}})},shortcut:Lt("commandPalette"),"aria-label":o("commandPalette.title"),className:e?.className,children:o("commandPalette.title")})};LI.displayName="CommandPalette";_I=()=>{let{t:e}=Ct(),t=Ft();return Kt(xr,{"data-testid":"help-menu-item",icon:za,onSelect:()=>t.executeAction(Fi),shortcut:"?","aria-label":e("helpDialog.title"),children:e("helpDialog.title")})};_I.displayName="Help";PI=()=>{let{t:e}=Ct(),t=JD(rl,He);return Ft().isActionEnabled(mn)?Kt(xr,{icon:ur,onSelect:()=>t("clearCanvas"),"data-testid":"clear-canvas-button","aria-label":e("buttons.clearReset"),children:e("buttons.clearReset")}):null};PI.displayName="ClearCanvas";DI=e=>{let{t}=Ct(),o=Re(),r=Ft(),n=Lt("toggleTheme");return r.isActionEnabled(Oi)?e?.allowSystemTheme?Kt(CI,{name:"theme",value:e.theme,onChange:i=>e.onSelect(i),choices:[{value:ie.LIGHT,label:rs,ariaLabel:`${t("buttons.lightMode")} - ${n}`},{value:ie.DARK,label:os,ariaLabel:`${t("buttons.darkMode")} - ${n}`},{value:"system",label:zb,ariaLabel:t("buttons.systemMode")}],children:t("labels.theme")}):Kt(xr,{onSelect:i=>{if(i.preventDefault(),e?.onSelect)e.onSelect(o.theme===ie.DARK?ie.LIGHT:ie.DARK);else return r.executeAction(Oi)},icon:o.theme===ie.DARK?rs:os,"data-testid":"toggle-dark-mode",shortcut:n,"aria-label":o.theme===ie.DARK?t("buttons.lightMode"):t("buttons.darkMode"),children:o.theme===ie.DARK?t("buttons.lightMode"):t("buttons.darkMode")}):null};DI.displayName="ToggleTheme";RI=()=>{let{t:e}=Ct(),t=Re(),o=Ft(),r=Hi();return t.viewModeEnabled||!r.UIOptions.canvasActions.changeViewBackgroundColor?null:FI("div",{style:{marginTop:"0.5rem"},children:[Kt("div",{"data-testid":"canvas-background-label",style:{fontSize:".75rem",marginBottom:".5rem"},children:e("labels.canvasBackground")}),Kt("div",{style:{padding:"0 0.625rem"},children:o.renderAction("changeViewBackgroundColor")})]})};RI.displayName="ChangeCanvasBackground";NI=()=>{let{t:e}=Ct(),t=Be();return Kt(xr,{icon:Li,onSelect:()=>{t({openDialog:{name:"jsonExport"}})},"data-testid":"json-export-button","aria-label":e("buttons.export"),children:e("buttons.export")})};NI.displayName="Export";OI=()=>{let{t:e}=Ct();return FI(QD,{children:[Kt(vs,{icon:Gc,href:"https://github.com/excalidraw/excalidraw","aria-label":"GitHub",children:"GitHub"}),Kt(vs,{icon:M1,href:"https://x.com/excalidraw","aria-label":"X",children:e("labels.followUs")}),Kt(vs,{icon:A1,href:"https://discord.gg/UexuTaE","aria-label":"Discord",children:e("labels.discordChat")})]})};OI.displayName="Socials";BI=({onSelect:e,isCollaborating:t})=>{let{t:o}=Ct();return Kt(xr,{"data-testid":"collab-button",icon:Vc,className:qD({"active-collab":t}),onSelect:e,children:o("labels.liveCollaboration")})};BI.displayName="LiveCollaborationTrigger"});import{atom as eR,useAtom as tR}from"jotai";import{useLayoutEffect as oR,useRef as rR}from"react";import{jsx as nR}from"react/jsx-runtime";var ri,Od=v(()=>{"use strict";f();qo();ri=(e,t)=>{let o=eR(0),r=n=>{let{jotaiScope:i}=nt(),[,a]=tR(o,i),l=rR({preferHost:!1,counter:0});return oR(()=>{let s=l.current;return a(c=>{let d=c+1;return s.counter=d,d}),()=>{a(c=>{let d=c-1;return s.counter=d,d||(s.preferHost=!1),d})}},[a]),n.__fallback||(l.current.preferHost=!0),!l.current.counter&&n.__fallback&&l.current.preferHost||l.current.counter>1&&n.__fallback?null:nR(t,{...n})};return r.displayName=e,r}});import{jsx as _g,jsxs as HE}from"react/jsx-runtime";var iR,fo,zE=v(()=>{"use strict";f();ye();Td();HI();wE();X();ee();Od();G();qo();Vt();iR=Object.assign(ri("MainMenu",({children:e,onSelect:t})=>{let{MainMenuTunnel:o}=nt(),r=_e(),n=Re(),i=Be(),a=r.editor.isMobile?void 0:()=>i({openMenu:null});return _g(o.In,{children:HE(Ge,{open:n.openMenu==="canvas",children:[_g(Ge.Trigger,{onToggle:()=>{i({openMenu:n.openMenu==="canvas"?null:"canvas"})},"data-testid":"main-menu-trigger",className:"main-menu-trigger",children:zc}),HE(Ge.Content,{onClickOutside:a,onSelect:di(t,()=>{i({openMenu:null})}),children:[e,r.editor.isMobile&&n.collaborators.size>0&&HE("fieldset",{className:"UserList-Wrapper",children:[_g("legend",{children:b("labels.collaborators")}),_g(kg,{mobile:!0,collaborators:n.collaborators,userToFollow:n.userToFollow?.socketId||null})]})]})]})})}),{Trigger:Ge.Trigger,Item:Ge.Item,ItemLink:Ge.ItemLink,ItemCustom:Ge.ItemCustom,Group:Ge.Group,Separator:Ge.Separator,DefaultItems:FE}),fo=iR});import{jsx as Ms,jsxs as sR}from"react/jsx-runtime";var Pg,aR,lR,GE,zI=v(()=>{"use strict";f();Ld();ye();Er();X();cd();Pg=({title:e,children:t,actionLabel:o,onClick:r})=>sR("div",{className:"OverwriteConfirm__Actions__Action",children:[Ms("h4",{children:e}),Ms("div",{className:"OverwriteConfirm__Actions__Action__content",children:t}),Ms(fn,{variant:"outlined",color:"muted",label:o,size:"large",fullWidth:!0,onClick:r})]}),aR=()=>{let{t:e}=Ct(),t=Ft(),o=Be();return Ms(Pg,{title:e("overwriteConfirm.action.exportToImage.title"),actionLabel:e("overwriteConfirm.action.exportToImage.button"),onClick:()=>{t.executeAction(Mu,"ui",!0),o({openDialog:{name:"imageExport"}})},children:e("overwriteConfirm.action.exportToImage.description")})},lR=()=>{let{t:e}=Ct(),t=Ft();return Ms(Pg,{title:e("overwriteConfirm.action.saveToDisk.title"),actionLabel:e("overwriteConfirm.action.saveToDisk.button"),onClick:()=>{t.executeAction(ps,"ui")},children:e("overwriteConfirm.action.saveToDisk.description")})},GE=Object.assign(({children:e})=>Ms("div",{className:"OverwriteConfirm__Actions",children:e}),{ExportToImage:aR,SaveToDisk:lR})});var GI=v(()=>{});import{useAtom as cR}from"jotai";import{jsx as Zi,jsxs as UI}from"react/jsx-runtime";var Dg,WI=v(()=>{"use strict";f();qo();Tt();jo();Od();OE();Ld();ee();zI();GI();Dg=Object.assign(ri("OverwriteConfirmDialog",({children:e})=>{let{OverwriteConfirmDialogTunnel:t}=nt(),[o,r]=cR(NE,He);if(!o.active)return null;let n=()=>{o.onClose(),r(a=>({...a,active:!1}))},i=()=>{o.onConfirm(),r(a=>({...a,active:!1}))};return Zi(t.In,{children:Zi(gt,{onCloseRequest:n,title:!1,size:916,children:UI("div",{className:"OverwriteConfirm",children:[Zi("h3",{children:o.title}),UI("div",{className:`OverwriteConfirm__Description OverwriteConfirm__Description--color-${o.color}`,children:[Zi("div",{className:"OverwriteConfirm__Description__icon",children:vb}),Zi("div",{children:o.description}),Zi("div",{className:"OverwriteConfirm__Description__spacer"}),Zi(fn,{color:o.color,size:"large",label:o.actionLabel,onClick:i})]}),Zi(GE,{children:e})]})})})}),{Actions:GE,Action:Pg})});import dR from"clsx";import{jsx as ji,jsxs as VI}from"react/jsx-runtime";import{createElement as mR}from"react";var YI,KI,Rg,UE=v(()=>{"use strict";f();U();qo();Vt();X();G();ye();Od();wd();Nd();YI=ri("DefaultSidebarTrigger",e=>{let{DefaultSidebarTriggerTunnel:t}=nt();return ji(t.In,{children:ji(oi.Trigger,{...e,className:"default-sidebar-trigger",name:Do.name})})});YI.displayName="DefaultSidebarTrigger";KI=({children:e,...t})=>{let{DefaultSidebarTabTriggersTunnel:o}=nt();return ji(o.In,{children:ji(oi.TabTriggers,{...t,children:e})})};KI.displayName="DefaultTabTriggers";Rg=Object.assign(ri("DefaultSidebar",({children:e,className:t,onDock:o,docked:r,...n})=>{let i=Re(),a=Be(),{DefaultSidebarTabTriggersTunnel:l}=nt();return mR(oi,{...n,name:"default",key:"default",className:dR("default-sidebar",t),docked:r??i.defaultSidebarDockedPreference,onDock:o===!1||!o&&r!=null?void 0:di(o,s=>{a({defaultSidebarDockedPreference:s})})},VI(oi.Tabs,{children:[VI(oi.Header,{children:[n.__fallback&&ji("div",{style:{color:"var(--color-primary)",fontSize:"1.2em",fontWeight:"bold",textOverflow:"ellipsis",overflow:"hidden",whiteSpace:"nowrap",paddingRight:"1em"},children:b("toolBar.library")}),ji(l.Out,{})]}),ji(oi.Tab,{tab:Ws,children:ji(AC,{})}),e]}))}),{Trigger:YI,TabTriggers:KI})});var $I=v(()=>{});var XI=v(()=>{});import pR from"clsx";import{jsx as ZI,jsxs as gR}from"react/jsx-runtime";var uR,jI,qI=v(()=>{"use strict";f();jn();ee();uR="small",jI=e=>gR("label",{className:pR("ToolIcon ToolIcon__LaserPointer",`ToolIcon_size_${uR}`,{"is-mobile":e.isMobile}),title:`${e.title}`,children:[ZI("input",{className:"ToolIcon_type_checkbox",type:"checkbox",name:e.name,onChange:e.onChange,checked:e.checked,"aria-label":e.title,"data-testid":"toolbar-LaserPointer"}),ZI("div",{className:"ToolIcon__icon",children:Zc})]})});import{jsx as hR}from"react/jsx-runtime";var Ls,JI=v(()=>{"use strict";f();Ls=e=>hR("p",{className:"excalidraw__paragraph",style:e.style,children:e.children})});var QI=v(()=>{});import*as tS from"@radix-ui/react-tabs";import{useRef as eS}from"react";import{jsx as fR}from"react/jsx-runtime";var oS,Ng,WE=v(()=>{"use strict";f();ye();G();oS=e=>{let t=Be(),o=eS(null),r=eS(0);return fR(tS.Root,{ref:o,className:"ttd-dialog-tabs-root",value:e.tab,onValueChange:n=>{if(!n)return;let i=o.current?.closest(".Modal__content");if(i){let a=i.offsetHeight||0;a>r.current&&(r.current=a,i.style.minHeight=`min(${r.current}px, 100%)`)}e.dialog==="settings"&&Ks(["text-to-diagram","diagram-to-code"],n)?t({openDialog:{name:e.dialog,tab:n,source:"settings"}}):e.dialog==="ttd"&&Ks(["text-to-diagram","mermaid"],n)&&t({openDialog:{name:e.dialog,tab:n}})},children:e.children})};oS.displayName="TTDDialogTabs";Ng=oS});import*as rS from"@radix-ui/react-tabs";import{jsx as bR}from"react/jsx-runtime";var _s,VE=v(()=>{"use strict";f();_s=({tab:e,children:t,...o})=>bR(rS.Content,{...o,value:e,children:t});_s.displayName="TTDDialogTab"});import{useState as nS}from"react";import{jsx as Po,jsxs as Bd}from"react/jsx-runtime";var iS,aS=v(()=>{"use strict";f();jo();$x();ee();Ld();Su();ue();Vt();dg();JI();QI();WE();VE();iS=e=>{let[t,o]=nS(e.openAIKey||""),[r,n]=nS(e.isPersisted),i=Re(),a=()=>{e.onConfirm(t.trim(),r)};return i.openDialog?.name!=="settings"?null:Po(gt,{onCloseRequest:()=>{e.onClose(),e.onConfirm(t.trim(),r)},title:Bd("div",{style:{display:"flex"},children:["Wireframe to Code (AI)"," ",Po("div",{style:{display:"flex",alignItems:"center",justifyContent:"center",padding:"0.1rem 0.5rem",marginLeft:"1rem",fontSize:14,borderRadius:"12px",color:"#000",background:"pink"},children:"Experimental"})]}),className:"MagicSettings",autofocus:!1,children:Po(Ng,{dialog:"settings",tab:i.openDialog.tab,children:Bd(_s,{tab:"diagram-to-code",children:[Bd(Ls,{children:["For the diagram-to-code feature we use"," ",Po(Wi,{icon:is}),"OpenAI."]}),Bd(Ls,{children:["While the OpenAI API is in beta, its use is strictly limited \u2014 as such we require you use your own API key. You can create an"," ",Po("a",{href:"https://platform.openai.com/login?launch",rel:"noopener noreferrer",target:"_blank",children:"OpenAI account"}),", add a small credit (5 USD minimum), and"," ",Po("a",{href:"https://platform.openai.com/api-keys",rel:"noopener noreferrer",target:"_blank",children:"generate your own API key"}),"."]}),Po(Ls,{children:"Your OpenAI key does not leave the browser, and you can also set your own limit in your OpenAI account dashboard if needed."}),Po(cg,{isRedacted:!0,value:t,placeholder:"Paste your API key here",label:"OpenAI API key",onChange:l=>{o(l),e.onChange(l.trim(),r)},selectOnRender:!0,onKeyDown:l=>l.key===I.ENTER&&a()}),Po(Ls,{children:"By default, your API token is not persisted anywhere so you'll need to insert it again after reload. But, you can persist locally in your browser below."}),Po(Za,{checked:r,onChange:n,children:"Persist API key in browser storage"}),Bd(Ls,{children:["Once API key is set, you can use the ",Po(Wi,{icon:Wa})," ","tool to wrap your elements in a frame that will then allow you to turn it into code. This dialog can be accessed using the"," ",Po("b",{children:"AI Settings"})," ",Po(Wi,{icon:is}),"."]}),Po(fn,{className:"MagicSettings__confirm",size:"large",label:"Confirm",onClick:a})]})})})}});var lS=v(()=>{});var xR,Og,Fd,Bg,YE=v(()=>{"use strict";f();U();Of();Co();vd();X();xR=({canvasRef:e,setError:t})=>{let o=e.current;if(!o)return;let r=o.parentElement;r&&(r.style.background="",t(null),o.replaceChildren())},Og=async({canvasRef:e,mermaidToExcalidrawLib:t,mermaidDefinition:o,setError:r,data:n})=>{let i=e.current,a=i?.parentElement;if(!(!i||!a)){if(!o){xR({canvasRef:e,setError:r});return}try{let l=await t.api,s;try{s=await l.parseMermaidToExcalidraw(o,{fontSize:Rt})}catch{s=await l.parseMermaidToExcalidraw(o.replace(/"/g,"'"),{fontSize:Rt})}let{elements:c,files:d}=s;r(null),n.current={elements:Hd(c,{regenerateIds:!0}),files:d};let m=await Si({data:{elements:n.current.elements,files:n.current.files},config:{padding:Kr,maxWidthOrHeight:Math.max(a.offsetWidth,a.offsetHeight)*window.devicePixelRatio}});try{await Yn(m)}catch(p){throw p.name==="CANVAS_POSSIBLY_TOO_BIG"?new Error(b("canvasError.canvasTooBig")):p}a.style.background="var(--default-bg-color)",i.replaceChildren(m)}catch(l){throw a.style.background="var(--default-bg-color)",o&&r(l),l}}},Fd=e=>{Mo.set(or.MERMAID_TO_EXCALIDRAW,e)},Bg=({app:e,data:t,text:o,shouldSaveMermaidDataToStorage:r})=>{let{elements:n,files:i}=t.current;n.length&&(e.addElementsFromPasteOrLibrary({elements:n,files:i,position:"center",fitToContent:!0}),e.setOpenDialog(null),r&&o&&Fd(o))}});import{jsx as ER}from"react/jsx-runtime";var Fg,KE=v(()=>{"use strict";f();Fg=({children:e})=>ER("div",{className:"ttd-dialog-panels",children:e})});import sS from"clsx";import{jsx as $E,jsxs as zd}from"react/jsx-runtime";var Ps,XE=v(()=>{"use strict";f();Is();In();Ps=({label:e,children:t,panelAction:o,panelActionDisabled:r=!1,onTextSubmitInProgess:n,renderTopRight:i,renderSubmitShortcut:a,renderBottomRight:l})=>zd("div",{className:"ttd-dialog-panel",children:[zd("div",{className:"ttd-dialog-panel__header",children:[$E("label",{children:e}),i?.()]}),t,zd("div",{className:sS("ttd-dialog-panel-button-container",{invisible:!o}),style:{display:"flex",alignItems:"center"},children:[zd(un,{className:"ttd-dialog-panel-button",onSelect:o?o.action:()=>{},disabled:r||n,children:[zd("div",{className:sS({invisible:n}),children:[o?.label,o?.icon&&$E("span",{children:o.icon})]}),n&&$E(jt,{})]}),!r&&!n&&a?.(),l?.()]})]})});import{useEffect as yR,useRef as cS}from"react";import{jsx as wR}from"react/jsx-runtime";var Hg,ZE=v(()=>{"use strict";f();U();ue();Hg=({input:e,placeholder:t,onChange:o,onKeyboardSubmit:r})=>{let n=cS(null),i=cS(r);return i.current=r,yR(()=>{if(!i.current)return;let a=n.current;if(a){let l=s=>{s[I.CTRL_OR_CMD]&&s.key===I.ENTER&&(s.preventDefault(),i.current?.())};return a.addEventListener("keydown",l),()=>{a.removeEventListener("keydown",l)}}},[]),wR("textarea",{className:"ttd-dialog-input",onChange:o,value:e,placeholder:t,autoFocus:!0,ref:n})}});import{jsx as zg,jsxs as dS}from"react/jsx-runtime";var vR,Gg,jE=v(()=>{"use strict";f();In();vR=({error:e})=>dS("div",{"data-testid":"ttd-dialog-output-error",className:"ttd-dialog-output-error",children:["Error! ",zg("p",{children:e})]}),Gg=({error:e,canvasRef:t,loaded:o})=>dS("div",{className:"ttd-dialog-output-wrapper",children:[e&&zg(vR,{error:e.message}),o?zg("div",{ref:t,style:{opacity:e?"0.15":1},className:"ttd-dialog-output-canvas-container"}):zg(jt,{size:"2rem"})]})});import{jsx as mS,jsxs as TR}from"react/jsx-runtime";var Ug,qE=v(()=>{"use strict";f();G();Ug=()=>TR("div",{className:"ttd-dialog-submit-shortcut",children:[mS("div",{className:"ttd-dialog-submit-shortcut__key",children:N("CtrlOrCmd")}),mS("div",{className:"ttd-dialog-submit-shortcut__key",children:N("Enter")})]})});import{useState as pS,useRef as uS,useEffect as gS,useDeferredValue as CR}from"react";import{Fragment as kR,jsx as En,jsxs as fS}from"react/jsx-runtime";var IR,hS,SR,bS,xS=v(()=>{"use strict";f();ye();ee();lS();X();Es();YE();KE();XE();ZE();jE();vd();U();G();qE();IR=`flowchart TD
71
+ `);try{Qn(i)}catch{throw new Error(b("errors.copyToSystemClipboardFailed"))}return{storeAction:_.NONE}},predicate:(e,t,r,o)=>Xp&&o.scene.getSelectedElements({selectedElementIds:t.selectedElementIds,includeBoundTextElement:!0}).some(V),keywords:["text","clipboard","copy"]})});var Pd,jS=y(()=>{"use strict";f();be();Je();W();ne();ze();Pd=U({name:"gridMode",icon:wE,keywords:["snap"],label:"labels.toggleGrid",viewMode:!0,trackEvent:{category:"canvas",predicate:e=>!e.gridSize},perform(e,t){return{appState:{...t,gridSize:this.checked(t)?null:On,objectsSnapModeEnabled:!1},storeAction:_.NONE}},checked:e=>e.gridSize!==null,predicate:(e,t,r)=>typeof r.gridModeEnabled>"u",keyTest:e=>e[C.CTRL_OR_CMD]&&e.code===Ee.QUOTE})});var ml,qS=y(()=>{"use strict";f();ne();be();ze();Je();ml=U({name:"zenMode",label:"buttons.zenMode",icon:EE,paletteName:"Toggle zen mode",viewMode:!0,trackEvent:{category:"canvas",predicate:e=>!e.zenModeEnabled},perform(e,t){return{appState:{...t,zenModeEnabled:!this.checked(t)},storeAction:_.NONE}},checked:e=>e.zenModeEnabled,predicate:(e,t,r)=>typeof r.zenModeEnabled>"u",keyTest:e=>!e[C.CTRL_OR_CMD]&&e.altKey&&e.code===Ee.Z})});var uh,JS=y(()=>{"use strict";f();ne();be();ze();Je();uh=U({name:"objectsSnapMode",label:"buttons.objectsSnapMode",icon:bE,viewMode:!1,trackEvent:{category:"canvas",predicate:e=>!e.objectsSnapModeEnabled},perform(e,t){return{appState:{...t,objectsSnapModeEnabled:!this.checked(t),gridSize:null},storeAction:_.NONE}},checked:e=>e.objectsSnapModeEnabled,predicate:(e,t,r)=>typeof r.objectsSnapModeEnabled>"u",keyTest:e=>!e[C.CTRL_OR_CMD]&&e.altKey&&e.code===Ee.S})});var ii,KE=y(()=>{"use strict";f();Je();be();ne();ze();ii=U({name:"stats",label:"stats.title",icon:pE,paletteName:"Toggle stats",viewMode:!0,trackEvent:{category:"menu"},perform(e,t){return{appState:{...t,showStats:!this.checked(t)},storeAction:_.NONE}},checked:e=>e.showStats,keyTest:e=>!e[C.CTRL_OR_CMD]&&e.altKey&&e.code===Ee.SLASH})});var hh,gh,h7,g7,QS,$E=y(()=>{"use strict";f();W();xe();Ye();mt();tp();me();G();Je();bo();ze();hh=U({name:"unbindText",label:"labels.unbindText",trackEvent:{category:"element"},predicate:(e,t,r,o)=>o.scene.getSelectedElements(t).some(i=>lr(i)),perform:(e,t,r,o)=>{let n=o.scene.getSelectedElements(t),i=o.scene.getNonDeletedElementsMap();return n.forEach(a=>{let l=ue(a,i);if(l){let{width:s,height:c}=Ho(l.originalText,Ze(l),l.lineHeight),d=c2(a.id);ep(a.id);let{x:m,y:p}=Ul(a,l,i);H(l,{containerId:null,width:s,height:c,text:l.originalText,x:m,y:p}),H(a,{boundElements:a.boundElements?.filter(u=>u.id!==l.id),height:d||a.height})}}),{elements:e,appState:t,storeAction:_.CAPTURE}}}),gh=U({name:"bindText",label:"labels.bindText",trackEvent:{category:"element"},predicate:(e,t,r,o)=>{let n=o.scene.getSelectedElements(t);if(n.length===2){let i=V(n[0])||V(n[1]),a;if(on(n[0])?a=n[0]:on(n[1])&&(a=n[1]),i&&a&&ue(a,o.scene.getNonDeletedElementsMap())===null)return!0}return!1},perform:(e,t,r,o)=>{let n=o.scene.getSelectedElements(t),i,a;V(n[0])&&on(n[1])?(i=n[0],a=n[1]):(i=n[1],a=n[0]),H(i,{containerId:a.id,verticalAlign:Tt.MIDDLE,textAlign:Ei.CENTER}),H(a,{boundElements:(a.boundElements||[]).concat({type:"text",id:i.id})});let l=a.height;return Ht(i,a,o.scene.getNonDeletedElementsMap()),Pa(a.id,l),{elements:h7(e,a,i),appState:{...t,selectedElementIds:{[a.id]:!0}},storeAction:_.CAPTURE}}}),h7=(e,t,r)=>{let o=e.slice(),n=o.findIndex(a=>a.id===r.id);o.splice(n,1);let i=o.findIndex(a=>a.id===t.id);return o.splice(i+1,0,r),Yt(o,X([t,r])),o},g7=(e,t,r)=>{let o=e.slice(),n=o.findIndex(a=>a.id===t.id);o.splice(n,1);let i=o.findIndex(a=>a.id===r.id);return o.splice(i,0,t),Yt(o,X([t,r])),o},QS=U({name:"wrapTextInContainer",label:"labels.createContainerFromText",trackEvent:{category:"element"},predicate:(e,t,r,o)=>{let n=o.scene.getSelectedElements(t),i=n.every(a=>V(a));return n.length>0&&i},perform:(e,t,r,o)=>{let n=o.scene.getSelectedElements(t),i=e.slice(),a={};for(let l of n)if(V(l)){let s=Jr({type:"rectangle",backgroundColor:t.currentItemBackgroundColor,boundElements:[...l.boundElements||[],{id:l.id,type:"text"}],angle:l.angle,fillStyle:t.currentItemFillStyle,strokeColor:t.currentItemStrokeColor,roughness:t.currentItemRoughness,strokeWidth:t.currentItemStrokeWidth,strokeStyle:t.currentItemStrokeStyle,roundness:t.currentItemRoundness==="round"?{type:nn("rectangle")?ct.ADAPTIVE_RADIUS:ct.PROPORTIONAL_RADIUS}:null,opacity:100,locked:!1,x:l.x-yt,y:l.y-yt,width:Gn(l.width,"rectangle"),height:Gn(l.height,"rectangle"),groupIds:l.groupIds,frameId:l.frameId});if(l.boundElements?.length){let c=l.boundElements.filter(m=>m.type==="arrow").map(m=>m.id);i.filter(m=>c.includes(m.id)).forEach(m=>{let p=m.startBinding,u=m.endBinding;p?.elementId===l.id&&(p={...p,elementId:s.id}),u?.elementId===l.id&&(u={...u,elementId:s.id}),(p||u)&&H(m,{startBinding:p,endBinding:u},!1)})}H(l,{containerId:s.id,verticalAlign:Tt.MIDDLE,boundElements:null,textAlign:Ei.CENTER},!1),Ht(l,s,o.scene.getNonDeletedElementsMap()),i=g7([...i,s],s,l),a[s.id]=!0}return{elements:i,appState:{...t,selectedElementIds:a},storeAction:_.CAPTURE}}})});var e5=y(()=>{});import{useCallback as t5,useEffect as f7,useLayoutEffect as b7,useRef as E7,useState as x7}from"react";import y7 from"clsx";import{jsx as Dd,jsxs as r5}from"react/jsx-runtime";var jE,o5,XE,w7,v7,ZE,fh,n5,i5,qE,_d,a5,T7,l5,S7,JE=y(()=>{"use strict";f();G();Oc();Ye();Dt();ne();q();be();W();dt();Ki();qe();Rp();Na();e5();Nr();we();me();Op();jE=320,o5=85,XE=5,w7=42,v7=500,ZE=!1,fh=new Map,n5=({element:e,elementsMap:t,setAppState:r,onLinkOpen:o,setToast:n,updateEmbedValidationStatus:i})=>{let a=As(),l=ji(),s=e.link||"",[c,d]=x7(s),m=E7(null),p=a.showHyperlinkPopup==="editor",u=t5(()=>{if(!m.current)return;let v=yr(m.current.value)||null;if(!e.link&&v&&ve("hyperlink","create"),Lt(e)){if(a.activeEmbeddable?.element===e&&r({activeEmbeddable:null}),!v){H(e,{link:null}),i(e,!1);return}if(!Kl(v,l.validateEmbeddable))v&&n({message:b("toast.unableToEmbed"),closable:!0}),e.link&&fh.set(e.id,e.link),H(e,{link:v}),i(e,!1);else{let{width:w,height:I}=e,L=$n(v);L?.error instanceof URIError&&n({message:b("toast.unrecognizedLinkFormat"),closable:!0});let A=L?L.intrinsicSize.w/L.intrinsicSize.h:1,M=fh.get(e.id)!==e.link;H(e,{...M?{width:L?.type==="video"?w>I?w:I*A:w,height:L?.type==="video"&&w>I?w/A:I}:{},link:v}),i(e,!0),fh.has(e.id)&&fh.delete(e.id)}}else H(e,{link:v})},[e,n,l.validateEmbeddable,a.activeEmbeddable,r,i]);b7(()=>()=>{u()},[u]),f7(()=>{let v=null,w=I=>{if(p)return;v&&clearTimeout(v),S7(e,t,a,[I.clientX,I.clientY])&&(v=window.setTimeout(()=>{r({showHyperlinkPopup:!1})},v7))};return window.addEventListener("pointermove",w,!1),()=>{window.removeEventListener("pointermove",w,!1),v&&clearTimeout(v)}},[a,e,p,r,t]);let h=t5(()=>{ve("hyperlink","delete"),H(e,{link:null}),p&&(m.current.value=""),r({showHyperlinkPopup:!1})},[r,e,p]),E=()=>{ve("hyperlink","edit","popup-ui"),r({showHyperlinkPopup:"editor"})},{x,y:T}=i5(e,a,t);return a.contextMenu||a.draggingElement||a.resizingElement||a.isRotating||a.openMenu||a.viewModeEnabled?null:r5("div",{className:"excalidraw-hyperlinkContainer",style:{top:`${T}px`,left:`${x}px`,width:jE,padding:XE},onClick:()=>{!e.link&&!p&&r({showHyperlinkPopup:"editor"})},children:[p?Dd("input",{className:y7("excalidraw-hyperlinkContainer-input"),placeholder:"Type or paste your link here",ref:m,value:c,onChange:v=>d(v.target.value),autoFocus:!0,onKeyDown:v=>{v.stopPropagation(),v[C.CTRL_OR_CMD]&&v.key===C.K&&v.preventDefault(),(v.key===C.ENTER||v.key===C.ESCAPE)&&(u(),r({showHyperlinkPopup:"info"}))}}):e.link?Dd("a",{href:yr(e.link||""),className:"excalidraw-hyperlinkContainer-link",target:mp(e.link)?"_self":"_blank",onClick:v=>{if(e.link&&o){let w=Rm("excalidraw-link",v.nativeEvent);o({...e,link:yr(e.link)},w),w.defaultPrevented&&v.preventDefault()}},rel:"noopener noreferrer",children:e.link}):Dd("div",{className:"excalidraw-hyperlinkContainer-link",children:b("labels.link.empty")}),r5("div",{className:"excalidraw-hyperlinkContainer__buttons",children:[!p&&Dd(pe,{type:"button",title:b("buttons.edit"),"aria-label":b("buttons.edit"),label:b("buttons.edit"),onClick:E,className:"excalidraw-hyperlinkContainer--edit",icon:qa}),s&&!Lt(e)&&Dd(pe,{type:"button",title:b("buttons.remove"),"aria-label":b("buttons.remove"),label:b("buttons.remove"),onClick:h,className:"excalidraw-hyperlinkContainer--remove",icon:To})]})]})},i5=(e,t,r)=>{let[o,n]=oe(e,r),{x:i,y:a}=Vt({sceneX:o+e.width/2,sceneY:n},t),l=i-t.offsetLeft-jE/2,s=a-t.offsetTop-o5;return{x:l,y:s}},qE=(e,t)=>{let r=ge(e,t);return r[0]?.link?Lt(r[0])?"labels.link.editEmbed":"labels.link.edit":Lt(r[0])?"labels.link.createEmbed":"labels.link.create"},_d=null,a5=(e,t,r)=>{_d&&clearTimeout(_d),_d=window.setTimeout(()=>T7(e,t,r),Ny)},T7=(e,t,r)=>{if(!e.link)return;let o=vs();o.classList.add("excalidraw-tooltip--visible"),o.style.maxWidth="20rem",o.textContent=e.link;let[n,i,a,l]=oe(e,r),[s,c,d,m]=Yc([n,i,a,l],e.angle,t),p=Vt({sceneX:s,sceneY:c},t);UE(o,{left:p.x,top:p.y,width:d,height:m},"top"),ve("hyperlink","tooltip","link-icon"),ZE=!0},l5=()=>{_d&&clearTimeout(_d),ZE&&(ZE=!1,vs().classList.remove("excalidraw-tooltip--visible"))},S7=(e,t,r,[o,n])=>{let{x:i,y:a}=je({clientX:o,clientY:n},r),l=15/r.zoom.value;if(Wc(i,a,e,t))return!1;let[s,c,d]=oe(e,t);if(i>=s&&i<=d&&a>=c-o5&&a<=c)return!1;let{x:m,y:p}=i5(e,r,t);return!(o>=m-l&&o<=m+jE+XE*2+l&&n>=p-l&&n<=p+l+XE*2+w7)}});import{jsx as C7}from"react/jsx-runtime";var ks,s5=y(()=>{"use strict";f();JE();ne();Dt();me();q();be();qe();ze();G();Je();ks=U({name:"hyperlink",label:(e,t)=>qE(e,t),icon:gs,perform:(e,t)=>t.showHyperlinkPopup==="editor"?!1:{elements:e,appState:{...t,showHyperlinkPopup:"editor",openMenu:null},storeAction:_.CAPTURE},trackEvent:{category:"hyperlink",action:"click"},keyTest:e=>e[C.CTRL_OR_CMD]&&e.key===C.K,predicate:(e,t)=>ge(e,t).length===1,PanelComponent:({elements:e,appState:t,updateData:r})=>{let o=ge(e,t);return C7(pe,{type:"button",icon:gs,"aria-label":b(qE(e,t)),title:`${Lt(e[0])?b("labels.link.labelEmbed"):b("labels.link.label")} - ${N("CtrlOrCmd+K")}`,onClick:()=>r(null),selected:o.length===1&&!!o[0].link})}})});var QE,bh,c5,ex=y(()=>{"use strict";f();ne();Ye();me();be();qe();ze();G();Je();QE=e=>e.every(t=>!t.locked),bh=U({name:"toggleElementLock",label:(e,t,r)=>{let o=r.scene.getSelectedElements({selectedElementIds:t.selectedElementIds,includeBoundTextElement:!1});return o.length===1&&!re(o[0])?o[0].locked?"labels.elementLock.unlock":"labels.elementLock.lock":QE(o)?"labels.elementLock.lockAll":"labels.elementLock.unlockAll"},icon:(e,t)=>{let r=ge(t,e);return QE(r)?ja:Hi},trackEvent:{category:"element"},predicate:(e,t,r,o)=>{let n=o.scene.getSelectedElements(t);return n.length>0&&!n.some(i=>i.locked&&i.frameId)},perform:(e,t,r,o)=>{let n=o.scene.getSelectedElements({selectedElementIds:t.selectedElementIds,includeBoundTextElement:!0,includeElementsInFrames:!0});if(!n.length)return!1;let i=QE(n),a=X(n);return{elements:e.map(l=>a.has(l.id)?le(l,{locked:i}):l),appState:{...t,selectedLinearElement:i?null:t.selectedLinearElement},storeAction:_.CAPTURE}},keyTest:(e,t,r,o)=>e.key.toLocaleLowerCase()===C.L&&e[C.CTRL_OR_CMD]&&e.shiftKey&&o.scene.getSelectedElements({selectedElementIds:t.selectedElementIds,includeBoundTextElement:!1}).length>0}),c5=U({name:"unlockAllElements",paletteName:"Unlock all elements",trackEvent:{category:"canvas"},viewMode:!1,icon:Hi,predicate:(e,t)=>ge(e,t).length===0&&e.some(o=>o.locked),perform:(e,t)=>{let r=e.filter(o=>o.locked);return{elements:e.map(o=>o.locked?le(o,{locked:!1}):o),appState:{...t,selectedElementIds:Object.fromEntries(r.map(o=>[o.id,!0]))},storeAction:_.CAPTURE}},label:"labels.elementLock.unlockAll"})});import{useCallback as I7,useState as A7}from"react";var d5,m5=y(()=>{"use strict";f();d5=()=>{let[e,t]=A7(null),r=I7(o=>t(o),[]);return[e,r]}});var p5=y(()=>{});var u5=y(()=>{});import k7 from"react";import M7 from"clsx";import{jsx as L7}from"react/jsx-runtime";var ir,qi=y(()=>{"use strict";f();u5();ir=k7.forwardRef(({children:e,padding:t,className:r,style:o},n)=>L7("div",{className:M7("Island",r),style:{"--padding":t,...o},ref:n,children:e}))});var h5=y(()=>{});import{createPortal as P7}from"react-dom";import D7 from"clsx";import{useRef as _7}from"react";import{jsx as g5,jsxs as R7}from"react/jsx-runtime";var f5,b5=y(()=>{"use strict";f();h5();be();DE();f5=e=>{let{closeOnClickOutside:t=!0}=e,r=Ku({className:"excalidraw-modal-container"}),o=_7(document.body.classList.contains("excalidraw-animations-disabled"));if(!r)return null;let n=i=>{i.key===C.ESCAPE&&(i.nativeEvent.stopImmediatePropagation(),i.stopPropagation(),e.onCloseRequest())};return P7(R7("div",{className:D7("Modal",e.className,{"animations-disabled":o.current}),role:"dialog","aria-modal":"true",onKeyDown:n,"aria-labelledby":e.labelledBy,"data-prevent-outside-click":!0,children:[g5("div",{className:"Modal__background",onClick:t?e.onCloseRequest:void 0}),g5("div",{className:"Modal__content",style:{"--max-width":`${e.maxWidth}px`},tabIndex:0,children:e.children})]}),r)}});import{atom as N7,useAtom as O7}from"jotai";import{useEffect as B7,useState as F7}from"react";var tx,E5,x5,Eh,Rd=y(()=>{"use strict";f();Qr();kt();Va();tx=N7(new Map),E5=async e=>await ls({data:{elements:e,appState:{exportBackground:!1,viewBackgroundColor:Te.white},files:null},config:{}}),x5=(e,t,r)=>{let[o,n]=F7();return B7(()=>{if(t)if(e){let i=r.get(e);i?n(i):(async()=>{let a=await E5(t);a.querySelector(".style-fonts")?.remove(),a&&(r.set(e,a),n(a))})()}else(async()=>{let i=await E5(t);n(i)})()},[e,t,r,n]),o},Eh=()=>{let[e]=O7(tx,Ge);return{clearLibraryCache:()=>e.clear(),deleteItemsFromLibraryCache:o=>{o.forEach(n=>e.delete(n))},svgCache:e}}});var xh,y5=y(()=>{"use strict";f();G();xh=class{jobs=[];running=!1;tick(){if(this.running)return;let t=this.jobs.shift();t?(this.running=!0,t.promise.resolve(ic(t.jobFactory,...t.args).finally(()=>{this.running=!1,this.tick()}))):this.running=!1}push(t,...r){let o=_m();return this.jobs.push({jobFactory:t,promise:o,args:r}),this.tick(),o}}});import{atom as z7}from"jotai";import{useEffect as w5,useRef as v5}from"react";var S5,Ji,Nd,H7,C5,I5,rx,nx,vh,ox,Ms,Od,yh,wh,T5,U7,pl=y(()=>{"use strict";f();_r();Fa();kt();dt();wi();q();W();Rd();G();Rc();y5();xe();S5=new cr,Ji=z7({status:"loaded",isInitialized:!1,libraryItems:[]}),Nd=e=>rn(e),H7=(e,t)=>!e.find(r=>r.elements.length!==t.elements.length?!1:r.elements.every((o,n)=>o.id===t.elements[n].id&&o.versionNonce===t.elements[n].versionNonce)),C5=(e,t)=>{let r=[];for(let o of t)H7(e,o)&&r.push(o);return[...r,...e]},I5=(e,t)=>{let r=X(t),o={deletedItems:new Map,addedItems:new Map};for(let i of e)r.has(i.id)||o.deletedItems.set(i.id,i);let n=X(e);for(let i of t)n.has(i.id)||o.addedItems.set(i.id,i);return o},rx=class{currLibraryItems=[];prevLibraryItems=Nd(this.currLibraryItems);app;constructor(t){this.app=t}updateQueue=[];getLastUpdateTask=()=>this.updateQueue[this.updateQueue.length-1];notifyListeners=()=>{if(this.updateQueue.length>0)Qt.set(Ji,t=>({status:"loading",libraryItems:this.currLibraryItems,isInitialized:t.isInitialized}));else{Qt.set(Ji,{status:"loaded",libraryItems:this.currLibraryItems,isInitialized:!0});try{let t=this.prevLibraryItems;this.prevLibraryItems=Nd(this.currLibraryItems);let r=Nd(this.currLibraryItems);this.app.props.onLibraryChange?.(r),S5.trigger(I5(t,r),r)}catch(t){console.error(t)}}};destroy=()=>{this.updateQueue=[],this.currLibraryItems=[],Qt.set(tx,new Map)};resetLibrary=()=>this.setLibrary([]);getLatestLibrary=()=>new Promise(async t=>{try{let r=await(this.getLastUpdateTask()||this.currLibraryItems);this.updateQueue.length>0?t(this.getLatestLibrary()):t(Nd(r))}catch{return t(this.currLibraryItems)}});updateLibrary=async({libraryItems:t,prompt:r=!1,merge:o=!1,openLibraryMenu:n=!1,defaultStatus:i="unpublished"})=>(n&&this.app.setState({openSidebar:{name:Vr.name,tab:tc}}),this.setLibrary(()=>new Promise(async(a,l)=>{try{let s=await(typeof t=="function"&&!(t instanceof Blob)?t(this.currLibraryItems):t),c;s instanceof Blob?c=await e1(s,i):c=Ba(s,i),!r||window.confirm(b("alerts.confirmAddLibrary",{numShapes:c.length}))?(r&&this.app.focusContainer(),a(o?C5(this.currLibraryItems,c):c)):l(new an)}catch(s){l(s)}})));setLibrary=t=>{let r=new Promise(async(o,n)=>{try{await this.getLastUpdateTask(),typeof t=="function"&&(t=t(this.currLibraryItems)),this.currLibraryItems=Nd(await t),o(this.currLibraryItems)}catch(i){n(i)}}).catch(o=>{if(o.name==="AbortError")return console.warn("Library update aborted by user"),this.currLibraryItems;throw o}).finally(()=>{this.updateQueue=this.updateQueue.filter(o=>o!==r),this.notifyListeners()});return this.updateQueue.push(r),this.notifyListeners(),r}},nx=rx,vh=e=>{let r=Math.ceil(Math.sqrt(e.length)),o=[],n=u=>e.slice(u*r,u*r+r).reduce((E,x)=>{let{height:T}=Lr(x.elements);return Math.max(E,T)},0),i=u=>{let h=0,E=0,x=0;for(let T of e){if(h%r===0&&(E=0),E===u){let{width:v}=Lr(T.elements);x=Math.max(x,v)}h++,E++}return x},a=0,l=0,s=0,c=0,d=0,m=0,p=0;for(let u of e){d&&d%r===0&&(l+=s+50,a=0,m=0,p++),m===0&&(s=n(p)),c=i(m);let{minX:h,minY:E,width:x,height:T}=Lr(u.elements),v=(c-x)/2,w=(s-T)/2;o.push(...u.elements.map(I=>({...I,x:I.x+a+v-h,y:I.y+l+w-E}))),a+=c+50,d++,m++}return o},ox=()=>{let e=new URLSearchParams(window.location.hash.slice(1)).get(Sm.addLibrary)||new URLSearchParams(window.location.search).get(Tm.addLibrary),t=e?new URLSearchParams(window.location.hash.slice(1)).get("token"):null;return e?{libraryUrl:e,idToken:t}:null},Ms=class e{static queue=new xh;static async getLibraryItems(t,r,o=!0){let n=()=>new Promise(async(i,a)=>{try{let l=await t.load({source:r});i(Ba(l?.libraryItems||[],"published"))}catch(l){a(l)}});return o?e.queue.push(n):n()}static run=async(t,r)=>{let o=new e(t);return e.queue.push(()=>r(o))};adapter;constructor(t){this.adapter=t}getLibraryItems(t){return e.getLibraryItems(this.adapter,t,!1)}},Od=0,yh=0,wh=e=>N1(e.map(t=>`${t.id}:${R1(t.elements)}`).sort().join()),T5=async(e,t)=>{try{return yh++,await Ms.run(e,async r=>{let o=X(await r.getLibraryItems("save"));for(let[l]of t.deletedItems)o.delete(l);let n=[];for(let[l,s]of t.addedItems)o.has(l)?o.set(l,s):n.push(s);let i=n.concat(Array.from(o.values())),a=wh(i);return a!==Od&&await e.save({libraryItems:i}),Od=a,i})}finally{yh--}},U7=e=>{let{excalidrawAPI:t}=e,r=v5(e);r.current=e;let o=v5(!1);w5(()=>{if(!t)return;o.current=!1;let n=async({libraryUrl:l,idToken:s})=>{let c=new Promise(async(m,p)=>{try{let h=await(await fetch(decodeURIComponent(l))).blob();m(h)}catch(u){p(u)}}),d=s!==t.id;await(d&&document.hidden?new Promise(m=>{window.addEventListener("focus",()=>m(),{once:!0})}):null);try{await t.updateLibrary({libraryItems:c,prompt:d,merge:!0,defaultStatus:"published",openLibraryMenu:!0})}catch(m){throw m}finally{if(window.location.hash.includes(Sm.addLibrary)){let m=new URLSearchParams(window.location.hash.slice(1));m.delete(Sm.addLibrary),window.history.replaceState({},js,`#${m.toString()}`)}else if(window.location.search.includes(Tm.addLibrary)){let m=new URLSearchParams(window.location.search);m.delete(Tm.addLibrary),window.history.replaceState({},js,`?${m.toString()}`)}}},i=l=>{l.preventDefault();let s=ox();s&&(l.stopImmediatePropagation(),window.history.replaceState({},"",l.oldURL),n(s))},a=ox();if(a&&n(a),"getInitialLibraryItems"in r.current&&r.current.getInitialLibraryItems&&(console.warn("useHandleLibrar `opts.getInitialLibraryItems` is deprecated. Use `opts.adapter` instead."),Promise.resolve(r.current.getInitialLibraryItems()).then(l=>{t.updateLibrary({libraryItems:l,merge:!0})}).catch(l=>{console.error(`UseHandeLibrary getInitialLibraryItems failed: ${l?.message}`)})),"adapter"in r.current&&r.current.adapter){let l=r.current.adapter,s=r.current.migrationAdapter,c=_m();s?c.resolve(ic(s.load).then(async d=>{let m=null;try{if(!d)return Ms.getLibraryItems(l,"load");m=Ba(d.libraryItems||[],"published");let p=await T5(l,I5([],m));try{await s.clear()}catch(u){console.error(`couldn't delete legacy library data: ${u.message}`)}return p}catch(p){return console.error(`couldn't migrate legacy library data: ${p.message}`),m}}).catch(d=>(console.error(`error during library migration: ${d.message}`),Ms.getLibraryItems(l,"load")))):c.resolve(ic(Ms.getLibraryItems,l,"load")),t.updateLibrary({libraryItems:c.then(d=>{let m=d||[];return Od=wh(m),m}),merge:!0}).finally(()=>{o.current=!0})}return window.addEventListener("hashchange",i),()=>{window.removeEventListener("hashchange",i)}},[t]),w5(()=>{let n=S5.on(async(a,l)=>{let s=o.current,c="adapter"in r.current&&r.current.adapter||null;try{c&&Od!==wh(l)&&await T5(c,a)}catch(d){console.error(`couldn't persist library update: ${d.message}`,a),s&&r.current.excalidrawAPI&&r.current.excalidrawAPI.updateScene({appState:{errorMessage:b("errors.saveLibraryError")}})}}),i=a=>{yh&&ow(a)};return window.addEventListener("beforeunload",i),()=>{window.removeEventListener("beforeunload",i),n(),Od=0,yh=0}},[])}});var A5=y(()=>{});import{forwardRef as k5}from"react";import M5 from"clsx";import{jsx as L5}from"react/jsx-runtime";var G7,V7,qt,ul=y(()=>{"use strict";f();A5();G7=k5(({children:e,gap:t,align:r,justifyContent:o,className:n,style:i},a)=>L5("div",{className:M5("Stack Stack_horizontal",n),style:{"--gap":t,alignItems:r,justifyContent:o,...i},ref:a,children:e})),V7=k5(({children:e,gap:t,align:r,justifyContent:o,className:n,style:i},a)=>L5("div",{className:M5("Stack Stack_vertical",n),style:{"--gap":t,justifyItems:r,justifyContent:o,...i},ref:a,children:e})),qt={Row:G7,Col:V7}});import{jsx as Y7}from"react/jsx-runtime";var W7,P5,D5=y(()=>{"use strict";f();W();q();W7=({theme:e,id:t,libraryReturnUrl:r})=>{let o=r||window.location.origin+window.location.pathname;return Y7("a",{className:"library-menu-browse-button",href:`${S.VITE_APP_LIBRARY_URL}?target=${window.name||"_blank"}&referrer=${o}&useHash=true&token=${t}&theme=${e}&version=${Ea.excalidrawLibrary}`,target:"_excalidraw_libraries",children:b("labels.libraries")})},P5=W7});import K7 from"clsx";import{jsx as $7,jsxs as X7}from"react/jsx-runtime";var Th,ix=y(()=>{"use strict";f();D5();Th=({libraryReturnUrl:e,theme:t,id:r,style:o,children:n,className:i})=>X7("div",{className:K7("library-menu-control-buttons",i),style:o,children:[$7(P5,{id:r,libraryReturnUrl:e,theme:t}),n]})});import Sh from"react";var Z7,j7,q7,J7,Q7,eD,wr,Ls=y(()=>{"use strict";f();q();Z7=/({{[\w-]+}})|(<[\w-]+>)|(<\/[\w-]+>)/g,j7=/{{([\w-]+)}}/,q7=/<([\w-]+)>/,J7=/<\/([\w-]+)>/,Q7=(e,t)=>{let r=[{name:"",children:[]}];return e.split(Z7).filter(Boolean).forEach(o=>{let n=o.match(q7),i=o.match(J7),a=o.match(j7);if(n!==null){let l=n[1];t.hasOwnProperty(l)?r.push({name:l,children:[]}):console.warn(`Trans: missed to pass in prop ${l} for interpolating ${e}`)}else if(i!==null)if(i[1]===r[r.length-1].name){let s=r.pop(),c=Sh.createElement(Sh.Fragment,{},...s.children),d=t[s.name];typeof d=="function"&&r[r.length-1].children.push(d(c))}else console.warn(`Trans: unexpected end tag ${o} for interpolating ${e}`);else if(a!==null){let l=a[1];t.hasOwnProperty(l)?r[r.length-1].children.push(t[l]):console.warn(`Trans: key ${l} not in props for interpolating ${e}`)}else r[r.length-1].children.push(o)}),r.length!==1&&console.warn(`Trans: stack not empty for interpolating ${e}`),r[0].children},eD=({i18nKey:e,children:t,...r})=>{let{t:o}=Mt();return Sh.createElement(Sh.Fragment,{},...Q7(o(e),r))},wr=eD});var _5=y(()=>{});var R5=y(()=>{});import tD from"clsx";import{jsx as Ch,jsxs as oD}from"react/jsx-runtime";var rD,Ps,ax=y(()=>{"use strict";f();R5();_n();rD=({label:e,onClick:t,className:r,children:o,actionType:n,type:i="button",isLoading:a,...l})=>{let s=n?`Dialog__action-button--${n}`:"";return oD("button",{className:tD("Dialog__action-button",s,r),type:i,"aria-label":e,onClick:t,...l,children:[o&&Ch("div",{style:a?{visibility:"hidden"}:{},children:o}),Ch("div",{style:a?{visibility:"hidden"}:{},children:e}),a&&Ch("div",{style:{position:"absolute",inset:0},children:Ch(er,{})})]})},Ps=rD});import{useSetAtom as nD}from"jotai";import{jsx as N5,jsxs as O5}from"react/jsx-runtime";var iD,Ih,lx=y(()=>{"use strict";f();q();ao();_5();ax();Bd();we();kt();iD=e=>{let{onConfirm:t,onCancel:r,children:o,confirmText:n=b("buttons.confirm"),cancelText:i=b("buttons.cancel"),className:a="",...l}=e,s=He(),c=nD(Ds,Ge),{container:d}=Zt();return O5(ft,{onCloseRequest:r,size:"small",...l,className:`confirm-dialog ${a}`,children:[o,O5("div",{className:"confirm-dialog-buttons",children:[N5(Ps,{label:i,onClick:()=>{s({openMenu:null}),c(!1),r(),d?.focus()}}),N5(Ps,{label:n,onClick:()=>{s({openMenu:null}),c(!1),t(),d?.focus()},actionType:"danger"})]})]})},Ih=iD});var Fr,Fd=y(()=>{"use strict";f();Fr=class{static has(t){try{return!!window.localStorage.getItem(t)}catch(r){return console.warn(`localStorage.getItem error: ${r.message}`),!1}}static get(t){try{let r=window.localStorage.getItem(t);return r?JSON.parse(r):null}catch(r){return console.warn(`localStorage.getItem error: ${r.message}`),null}}static set=(t,r)=>{try{return window.localStorage.setItem(t,JSON.stringify(r)),!0}catch(o){return console.warn(`localStorage.setItem error: ${o.message}`),!1}};static delete=t=>{try{window.localStorage.removeItem(t)}catch(r){console.warn(`localStorage.removeItem error: ${r.message}`)}}}});var B5=y(()=>{});import{useCallback as aD,useEffect as cx,useRef as F5,useState as sx}from"react";import z5 from"open-color";import{jsx as Ie,jsxs as mr}from"react/jsx-runtime";var lD,sD,cD,H5,U5=y(()=>{"use strict";f();ao();q();Ls();Va();W();_r();G();ax();ne();Dt();Fd();B5();lD=async e=>{let o=Math.round(8),n=Math.max(Math.round(128/64),2),i=ew(e,6),a=document.createElement("canvas");a.width=i[0].length*128+(i[0].length+1)*(o*2)-o*2,a.height=i.length*128+(i.length+1)*(o*2)-o*2;let l=a.getContext("2d");l.fillStyle=Gt,l.fillRect(0,0,a.width,a.height);for(let[s,c]of e.entries()){let d=await Jp({data:{elements:c.elements,files:null},config:{maxWidthOrHeight:128}}),{width:m,height:p}=d,u=Math.floor(s/6)*(128+o*2),h=s%6*(128+o*2);l.drawImage(d,h+(128-m)/2+o,u+(128-p)/2+o),l.lineWidth=n,l.strokeStyle=z5.gray[4],l.strokeRect(h+o/2,u+o/2,128+o,128+o)}return await Gc(new File([await jn(a)],"preview",{type:te.png}),{outputType:te.jpg,maxWidthOrHeight:5e3})},sD=({libItem:e,appState:t,index:r,onChange:o,onRemove:n})=>{let i=F5(null),a=F5(null);return cx(()=>{let l=i.current;l&&(async()=>{let s=await ls({data:{elements:e.elements,appState:{...t,viewBackgroundColor:Gt,exportBackground:!0},files:null}});l.innerHTML=s.outerHTML})()},[e.elements,t]),mr("div",{className:"single-library-item",children:[e.status==="published"&&Ie("span",{className:"single-library-item-status",children:b("labels.statusPublished")}),Ie("div",{ref:i,className:"single-library-item__svg"}),Ie(pe,{"aria-label":b("buttons.remove"),type:"button",icon:to,className:"single-library-item--remove",onClick:n.bind(null,e.id),title:b("buttons.remove")}),mr("div",{style:{display:"flex",margin:"0.8rem 0",width:"100%",fontSize:"14px",fontWeight:500,flexDirection:"column"},children:[mr("label",{style:{display:"flex",justifyContent:"space-between",flexDirection:"column"},children:[mr("div",{style:{padding:"0.5em 0"},children:[Ie("span",{style:{fontWeight:500,color:z5.gray[6]},children:b("publishDialog.itemName")}),Ie("span",{"aria-hidden":"true",className:"required",children:"*"})]}),Ie("input",{type:"text",ref:a,style:{width:"80%",padding:"0.2rem"},defaultValue:e.name,placeholder:"Item name",onChange:l=>{o(l.target.value,r)}})]}),Ie("span",{className:"error",children:e.error})]})]})},cD=({onClose:e,libraryItems:t,appState:r,onSuccess:o,onError:n,updateItemsInStorage:i,onRemove:a})=>{let[l,s]=sx({authorName:"",githubHandle:"",name:"",description:"",twitterHandle:"",website:""}),[c,d]=sx(!1);cx(()=>{let w=Fr.get(po.PUBLISH_LIBRARY);w&&s(w)},[]);let[m,p]=sx(t.slice());cx(()=>{p(t.slice())},[t]);let u=w=>{s({...l,[w.target.name]:w.target.value})},h=async w=>{w.preventDefault(),d(!0);let I=[],L=!1;if(m.forEach(B=>{let k="";B.name||(k=b("publishDialog.errors.required"),L=!0),I.push({...B,error:k})}),L){p(I),d(!1);return}let A=await lD(m),M={type:ar.excalidrawLibrary,version:Ea.excalidrawLibrary,source:ec,libraryItems:m},D=JSON.stringify(M,null,2),O=new Blob([D],{type:"application/json"}),R=new FormData;R.append("excalidrawLib",O),R.append("previewImage",A),R.append("previewImageType",A.type),R.append("title",l.name),R.append("authorName",l.authorName),R.append("githubHandle",l.githubHandle),R.append("name",l.name),R.append("description",l.description),R.append("twitterHandle",l.twitterHandle),R.append("website",l.website),fetch(`${S.VITE_APP_LIBRARY_BACKEND}/submit`,{method:"post",body:R}).then(B=>B.ok?B.json().then(({url:k})=>{Fr.delete(po.PUBLISH_LIBRARY),o({url:k,authorName:l.authorName,items:m})}):B.json().catch(()=>{throw new Error(B.statusText||"something went wrong")}).then(k=>{throw new Error(k.message||B.statusText||"something went wrong")}),B=>{console.error(B),n(B),d(!1)}).catch(B=>{console.error(B),n(B),d(!1)})},E=()=>{let w=[];return m.forEach((I,L)=>{w.push(Ie("div",{className:"single-library-item-wrapper",children:Ie(sD,{libItem:I,appState:r,index:L,onChange:(A,M)=>{let D=m.slice();D[M].name=A,p(D)},onRemove:a})},L))}),Ie("div",{className:"selected-library-items",children:w})},x=aD(()=>{i(m),Fr.set(po.PUBLISH_LIBRARY,l),e()},[m,e,i,l]),T=!!t.length,v=t.some(w=>w.status==="published");return Ie(ft,{onCloseRequest:x,title:b("publishDialog.title"),className:"publish-library",children:T?mr("form",{onSubmit:h,children:[Ie("div",{className:"publish-library-note",children:Ie(wr,{i18nKey:"publishDialog.noteDescription",link:w=>Ie("a",{href:"https://libraries.excalidraw.com",target:"_blank",rel:"noopener noreferrer",children:w})})}),Ie("span",{className:"publish-library-note",children:Ie(wr,{i18nKey:"publishDialog.noteGuidelines",link:w=>Ie("a",{href:"https://github.com/excalidraw/excalidraw-libraries#guidelines",target:"_blank",rel:"noopener noreferrer",children:w})})}),Ie("div",{className:"publish-library-note",children:b("publishDialog.noteItems")}),v&&Ie("span",{className:"publish-library-note publish-library-warning",children:b("publishDialog.republishWarning")}),E(),mr("div",{className:"publish-library__fields",children:[mr("label",{children:[mr("div",{children:[Ie("span",{children:b("publishDialog.libraryName")}),Ie("span",{"aria-hidden":"true",className:"required",children:"*"})]}),Ie("input",{type:"text",name:"name",required:!0,value:l.name,onChange:u,placeholder:b("publishDialog.placeholder.libraryName")})]}),mr("label",{style:{alignItems:"flex-start"},children:[mr("div",{children:[Ie("span",{children:b("publishDialog.libraryDesc")}),Ie("span",{"aria-hidden":"true",className:"required",children:"*"})]}),Ie("textarea",{name:"description",rows:4,required:!0,value:l.description,onChange:u,placeholder:b("publishDialog.placeholder.libraryDesc")})]}),mr("label",{children:[mr("div",{children:[Ie("span",{children:b("publishDialog.authorName")}),Ie("span",{"aria-hidden":"true",className:"required",children:"*"})]}),Ie("input",{type:"text",name:"authorName",required:!0,value:l.authorName,onChange:u,placeholder:b("publishDialog.placeholder.authorName")})]}),mr("label",{children:[Ie("span",{children:b("publishDialog.githubUsername")}),Ie("input",{type:"text",name:"githubHandle",value:l.githubHandle,onChange:u,placeholder:b("publishDialog.placeholder.githubHandle")})]}),mr("label",{children:[Ie("span",{children:b("publishDialog.twitterUsername")}),Ie("input",{type:"text",name:"twitterHandle",value:l.twitterHandle,onChange:u,placeholder:b("publishDialog.placeholder.twitterHandle")})]}),mr("label",{children:[Ie("span",{children:b("publishDialog.website")}),Ie("input",{type:"text",name:"website",pattern:"https?://.+",title:b("publishDialog.errors.website"),value:l.website,onChange:u,placeholder:b("publishDialog.placeholder.website")})]}),Ie("span",{className:"publish-library-note",children:Ie(wr,{i18nKey:"publishDialog.noteLicense",link:w=>Ie("a",{href:"https://github.com/excalidraw/excalidraw-libraries/blob/main/LICENSE",target:"_blank",rel:"noopener noreferrer",children:w})})})]}),mr("div",{className:"publish-library__buttons",children:[Ie(Ps,{label:b("buttons.cancel"),onClick:x,"data-testid":"cancel-clear-canvas-button"}),Ie(Ps,{type:"submit",label:b("buttons.submit"),actionType:"primary",isLoading:c})]})]}):Ie("p",{style:{padding:"1em",textAlign:"center",fontWeight:500},children:b("publishDialog.atleastOneLibItem")})})},H5=cD});import dD from"clsx";import{jsx as mD}from"react/jsx-runtime";var G5,V5,W5=y(()=>{"use strict";f();we();G5=({className:e="",children:t,onToggle:r,title:o,...n})=>{let i=_e(),a=dD(`dropdown-menu-button ${e}`,"zen-mode-transition",{"dropdown-menu-button--mobile":i.editor.isMobile}).trim();return mD("button",{"data-prevent-outside-click":!0,className:a,onClick:r,type:"button","data-testid":"dropdown-menu-button",title:o,...n,children:t})},V5=G5;G5.displayName="DropdownMenuTrigger"});import pD,{useContext as uD}from"react";var dx,Ah,kh,Mh=y(()=>{"use strict";f();W();G();dx=pD.createContext({}),Ah=(e="",t=!1)=>`dropdown-menu-item dropdown-menu-item-base ${e} ${t?"dropdown-menu-item--selected":""}`.trim(),kh=(e,t)=>{let r=uD(dx);return xi(e,o=>{let n=new CustomEvent("menu.itemSelect",{bubbles:!0,cancelable:!0});t?.(n),n.defaultPrevented||r.onSelect?.(n)})}});import{Fragment as gD,jsx as mx,jsxs as fD}from"react/jsx-runtime";var hD,Lh,px=y(()=>{"use strict";f();we();hD=({icon:e,shortcut:t,children:r})=>{let o=_e();return fD(gD,{children:[mx("div",{className:"dropdown-menu-item__icon",children:e}),mx("div",{className:"dropdown-menu-item__text",children:r}),t&&!o.editor.isMobile&&mx("div",{className:"dropdown-menu-item__shortcut",children:t})]})},Lh=hD});import{jsx as ux}from"react/jsx-runtime";var hx,Y5,Ao,gx=y(()=>{"use strict";f();Mh();px();hx=({icon:e,onSelect:t,children:r,shortcut:o,className:n,selected:i,...a})=>{let l=kh(a.onClick,t);return ux("button",{...a,onClick:l,type:"button",className:Ah(n,i),title:a.title??a["aria-label"],children:ux(Lh,{icon:e,shortcut:o,children:r})})};hx.displayName="DropdownMenuItem";Y5=({children:e})=>ux("div",{style:{display:"inline-flex",marginLeft:"auto",padding:"2px 4px",background:"pink",borderRadius:6,fontSize:9,color:"black",fontFamily:"Cascadia, monospace"},children:e});Y5.displayName="DropdownMenuItemBadge";hx.Badge=Y5;Ao=hx});import{jsx as bD}from"react/jsx-runtime";var K5,$5,X5=y(()=>{"use strict";f();K5=()=>bD("div",{style:{height:"1px",backgroundColor:"var(--default-border-color)",margin:".5rem 0"}}),$5=K5;K5.displayName="DropdownMenuSeparator"});import{jsx as ED,jsxs as xD}from"react/jsx-runtime";var Z5,j5,q5=y(()=>{"use strict";f();Z5=({children:e,className:t="",style:r,title:o})=>xD("div",{className:`dropdown-menu-group ${t}`,style:r,children:[o&&ED("p",{className:"dropdown-menu-group-title",children:o}),e]}),j5=Z5;Z5.displayName="DropdownMenuGroup"});import yD from"clsx";import{useEffect as wD,useRef as vD}from"react";import{jsx as Ph}from"react/jsx-runtime";var J5,Q5,eC=y(()=>{"use strict";f();qi();we();ul();Mh();$u();be();W();Xu();J5=({children:e,onClickOutside:t,className:r="",onSelect:o,style:n})=>{let i=_e(),a=vD(null),l=ws({onClickOutside:t});ys(a,()=>{l.onClickOutside?.()}),wD(()=>{let c=m=>{m.key===C.ESCAPE&&(m.stopImmediatePropagation(),l.onClickOutside?.())},d={capture:!0};return document.addEventListener("keydown",c,d),()=>{document.removeEventListener("keydown",c,d)}},[l]);let s=yD(`dropdown-menu ${r}`,{"dropdown-menu--mobile":i.editor.isMobile}).trim();return Ph(dx.Provider,{value:{onSelect:o},children:Ph("div",{ref:a,className:s,style:n,"data-testid":"dropdown-menu",children:i.editor.isMobile?Ph(qt.Col,{className:"dropdown-menu-container",children:e}):Ph(ir,{className:"dropdown-menu-container",padding:2,style:{zIndex:2},children:e})})})};J5.displayName="DropdownMenuContent";Q5=J5});import{jsx as tC}from"react/jsx-runtime";var rC,_s,fx=y(()=>{"use strict";f();px();Mh();rC=({icon:e,shortcut:t,href:r,children:o,onSelect:n,className:i="",selected:a,...l})=>{let s=kh(l.onClick,n);return tC("a",{...l,href:r,target:"_blank",rel:"noreferrer",className:Ah(i,a),title:l.title??l["aria-label"],onClick:s,children:tC(Lh,{icon:e,shortcut:t,children:o})})},_s=rC;rC.displayName="DropdownMenuItemLink"});import{jsx as SD}from"react/jsx-runtime";var TD,oC,nC=y(()=>{"use strict";f();TD=({children:e,className:t="",selected:r,...o})=>SD("div",{...o,className:`dropdown-menu-item-base dropdown-menu-item-custom ${t} ${r?"dropdown-menu-item--selected":""}`.trim(),children:e}),oC=TD});import Dh from"react";var iC,aC,lC=y(()=>{"use strict";f();iC=e=>{let t=Dh.Children.toArray(e).find(r=>Dh.isValidElement(r)&&typeof r.type!="string"&&r?.type.displayName&&r.type.displayName==="DropdownMenuTrigger");return t||null},aC=e=>{let t=Dh.Children.toArray(e).find(r=>Dh.isValidElement(r)&&typeof r.type!="string"&&r?.type.displayName&&r.type.displayName==="DropdownMenuContent");return t||null}});var sC=y(()=>{});import{Fragment as CD,jsxs as ID}from"react/jsx-runtime";var ai,Ve,zd=y(()=>{"use strict";f();W5();gx();X5();q5();eC();fx();nC();lC();sC();ai=({children:e,open:t})=>{let r=iC(e),o=aC(e);return ID(CD,{children:[r,t&&o]})};ai.Trigger=V5;ai.Content=Q5;ai.Item=Ao;ai.ItemLink=_s;ai.ItemCustom=oC;ai.Group=j5;ai.Separator=$5;Ve=ai;ai.displayName="DropdownMenu"});import{useCallback as AD,useState as bx}from"react";import{useAtom as Ex}from"jotai";import kD from"clsx";import{jsx as zr,jsxs as _h}from"react/jsx-runtime";var MD,LD,xx,cC=y(()=>{"use strict";f();q();Ls();kt();we();qn();pl();ne();Dt();Xn();G();lx();U5();ao();zd();Bd();jt();Rd();MD=(e,t)=>e.filter(r=>t.includes(r.id)),LD=({setAppState:e,selectedItems:t,library:r,onRemoveFromLibrary:o,resetLibrary:n,onSelectItems:i,appState:a,className:l})=>{let[s]=Ex(Ji,Ge),[c,d]=Ex(Ds,Ge),m=()=>{let R=t.length?b("alerts.removeItemsFromsLibrary",{count:t.length}):b("alerts.resetLibrary"),B=t.length?b("confirmDialog.removeItemsFromLib"):b("confirmDialog.resetLibrary");return zr(Ih,{onConfirm:()=>{t.length?o():n(),u(!1)},onCancel:()=>{u(!1)},title:B,children:zr("p",{children:R})})},[p,u]=bx(!1),h=!!t.length,E=h?s.libraryItems.filter(R=>t.includes(R.id)):s.libraryItems,x=h?b("buttons.remove"):b("buttons.resetLibrary"),[T,v]=bx(!1),[w,I]=bx(null),L=AD(()=>_h(ft,{onCloseRequest:()=>I(null),title:b("publishSuccessDialog.title"),className:"publish-library-success",size:"small",children:[zr("p",{children:zr(wr,{i18nKey:"publishSuccessDialog.content",authorName:w.authorName,link:R=>zr("a",{href:w?.url,target:"_blank",rel:"noopener noreferrer",children:R})})}),zr(pe,{type:"button",title:b("buttons.close"),"aria-label":b("buttons.close"),label:b("buttons.close"),onClick:()=>I(null),"data-testid":"publish-library-success-close",className:"publish-library-success-close"})]}),[I,w]),A=(R,B)=>{v(!1),I({url:R.url,authorName:R.authorName});let k=B.slice();k.forEach(z=>{t.includes(z.id)&&(z.status="published")}),r.setLibrary(k)},M=async()=>{try{await r.updateLibrary({libraryItems:$l({description:"Excalidraw library files"}),merge:!0,openLibraryMenu:!0})}catch(R){if(R?.name==="AbortError"){console.warn(R);return}e({errorMessage:b("errors.importLibraryError")})}},D=async()=>{let R=h?E:await r.getLatestLibrary();mv(R).catch(Dm).catch(B=>{e({errorMessage:B.message})})},O=()=>_h(Ve,{open:c,children:[zr(Ve.Trigger,{onToggle:()=>d(!c),children:V1}),_h(Ve.Content,{onClickOutside:()=>d(!1),onSelect:()=>d(!1),className:"library-menu",children:[!h&&zr(Ve.Item,{onSelect:M,icon:Qa,"data-testid":"lib-dropdown--load",children:b("buttons.load")}),!!E.length&&zr(Ve.Item,{onSelect:D,icon:Ui,"data-testid":"lib-dropdown--export",children:b("buttons.export")}),!!E.length&&zr(Ve.Item,{onSelect:()=>u(!0),icon:To,children:x}),h&&zr(Ve.Item,{icon:Jb,onSelect:()=>v(!0),"data-testid":"lib-dropdown--remove",children:b("buttons.publishLibrary")})]})]});return _h("div",{className:kD("library-menu-dropdown-container",l),children:[O(),t.length>0&&zr("div",{className:"library-actions-counter",children:t.length}),p&&m(),T&&zr(H5,{onClose:()=>v(!1),libraryItems:MD(s.libraryItems,t),appState:a,onSuccess:R=>A(R,s.libraryItems),onError:R=>window.alert(R),updateItemsInStorage:()=>r.setLibrary(s.libraryItems),onRemove:R=>i(t.filter(B=>B!==R))}),w&&L()]})},xx=({selectedItems:e,onSelectItems:t,className:r})=>{let{library:o}=Or(),{clearLibraryCache:n,deleteItemsFromLibraryCache:i}=Eh(),a=Be(),l=He(),[s]=Ex(Ji,Ge),c=async m=>{let p=m.filter(u=>!e.includes(u.id));o.setLibrary(p).catch(()=>{l({errorMessage:b("alerts.errorRemovingFromLibrary")})}),i(e),t([])};return zr(LD,{appState:a,setAppState:l,selectedItems:e,onSelectItems:t,library:o,onRemoveFromLibrary:()=>c(s.libraryItems),resetLibrary:()=>{o.resetLibrary(),n()},className:r})}});var dC=y(()=>{});import mC from"clsx";import{memo as PD,useEffect as DD,useRef as _D,useState as RD}from"react";import{jsx as Rh,jsxs as ND}from"react/jsx-runtime";var pC,uC,hC=y(()=>{"use strict";f();we();dC();eh();ne();Rd();pC=PD(({id:e,elements:t,isPending:r,onClick:o,selected:n,onToggle:i,onDrag:a,svgCache:l})=>{let s=_D(null),c=x5(e,t,l);DD(()=>{let h=s.current;if(h)return c&&(h.innerHTML=c.outerHTML),()=>{h.innerHTML=""}},[c]);let[d,m]=RD(!1),p=_e().editor.isMobile,u=r&&Rh("div",{className:"library-unit__adder",children:G1});return ND("div",{className:mC("library-unit",{"library-unit__active":t,"library-unit--hover":t&&d,"library-unit--selected":n,"library-unit--skeleton":!c}),onMouseEnter:()=>m(!0),onMouseLeave:()=>m(!1),children:[Rh("div",{className:mC("library-unit__dragger",{"library-unit__pulse":!!r}),ref:s,draggable:!!t,onClick:t||r?h=>{e&&h.shiftKey?i(e,h):o(e)}:void 0,onDragStart:h=>{if(!e){h.preventDefault();return}m(!1),a(e,h)}}),u,e&&t&&(d||p||n)&&Rh(ll,{checked:n,onChange:(h,E)=>i(e,E),className:"library-unit__checkbox"})]})}),uC=()=>Rh("div",{className:"library-unit library-unit--skeleton"})});import OD,{useCallback as BD}from"react";function FD(){return[!1,BD(t=>t(),[])]}var gC,fC=y(()=>{"use strict";f();gC=OD.useTransition||FD});import{memo as zD,useEffect as HD,useState as UD}from"react";import{Fragment as GD,jsx as Nh}from"react/jsx-runtime";var yx,Oh,bC=y(()=>{"use strict";f();hC();fC();yx=({children:e})=>Nh("div",{className:"library-menu-items-container__grid",children:e}),Oh=zD(({items:e,onItemSelectToggle:t,onItemDrag:r,isItemSelected:o,onClick:n,svgCache:i,itemsRenderedPerBatch:a})=>{let[,l]=gC(),[s,c]=UD(0);return HD(()=>{s<e.length&&l(()=>{c(s+a)})},[s,e.length,l,a]),Nh(GD,{children:e.map((d,m)=>m<s?Nh(pC,{elements:d?.elements,isPending:!d?.id&&!!d?.elements,onClick:n,svgCache:i,id:d?.id,selected:o(d.id),onToggle:t,onDrag:r},d?.id??m):Nh(uC,{},m))})})});import{useEffect as VD}from"react";import{atom as WD,useAtom as YD}from"jotai";import KD from"lodash.throttle";var $D,EC,xC=y(()=>{"use strict";f();$D=WD(0),EC=e=>{let[t,r]=YD($D);return VD(()=>{let{current:o}=e;if(!o)return;let n=KD(()=>{let{scrollTop:i}=o;r(i)},200);return o.addEventListener("scroll",n),()=>{n.cancel(),o.removeEventListener("scroll",n)}},[e,r]),t}});var yC=y(()=>{});import{useCallback as Rs,useEffect as XD,useMemo as wC,useRef as ZD,useState as jD}from"react";import{Fragment as vC,jsx as Hr,jsxs as Ns}from"react/jsx-runtime";function wx({isLoading:e,libraryItems:t,onAddToLibrary:r,onInsertLibraryItems:o,pendingElements:n,theme:i,id:a,libraryReturnUrl:l,onSelectItems:s,selectedItems:c}){let d=ZD(null),m=EC(d);XD(()=>{m>0&&d.current?.scrollTo(0,m)},[]);let{svgCache:p}=Eh(),u=wC(()=>t.filter(R=>R.status!=="published"),[t]),h=wC(()=>t.filter(R=>R.status==="published"),[t]),E=!t.length&&!n.length,x=!n.length&&!u.length&&!h.length,[T,v]=jD(null),w=Rs((R,B)=>{let k=!c.includes(R),z=[...u,...h];if(k){if(B.shiftKey&&T){let ee=z.findIndex($=>$.id===T),j=z.findIndex($=>$.id===R);if(ee===-1||j===-1){s([...c,R]);return}let ie=X(c),ke=z.reduce(($,Y,ae)=>((ae>=ee&&ae<=j||ie.has(Y.id))&&$.push(Y.id),$),[]);s(ke)}else s([...c,R]);v(R)}else v(null),s(c.filter(ee=>ee!==R))},[T,s,h,c,u]),I=Rs(R=>{let B;return c.includes(R)?B=t.filter(k=>c.includes(k.id)):B=t.filter(k=>k.id===R),B.map(k=>({...k,elements:Lc(k.elements,{randomizeSeed:!0})}))},[t,c]),L=Rs((R,B)=>{B.dataTransfer.setData(te.excalidrawlib,Mp(I(R)))},[I]),A=Rs(R=>R?c.includes(R):!1,[c]),M=Rs(()=>{r(n)},[n,r]),D=Rs(R=>{R&&o(I(R))},[I,o]),O=p.size>=t.length?JD:qD;return Ns("div",{className:"library-menu-items-container",style:n.length||u.length||h.length?{justifyContent:"flex-start"}:{borderBottom:0},children:[!x&&Hr(xx,{selectedItems:c,onSelectItems:s,className:"library-menu-dropdown-container--in-heading"}),Ns(qt.Col,{className:"library-menu-items-container__items",align:"start",gap:1,style:{flex:h.length>0?1:"0 1 auto",marginBottom:0},ref:d,children:[Ns(vC,{children:[!x&&Hr("div",{className:"library-menu-items-container__header",children:b("labels.personalLib")}),e&&Hr("div",{style:{position:"absolute",top:"var(--container-padding-y)",right:"var(--container-padding-x)",transform:"translateY(50%)"},children:Hr(er,{})}),!n.length&&!u.length?Ns("div",{className:"library-menu-items__no-items",children:[Hr("div",{className:"library-menu-items__no-items__label",children:b("library.noItems")}),Hr("div",{className:"library-menu-items__no-items__hint",children:h.length>0?b("library.hint_emptyPrivateLibrary"):b("library.hint_emptyLibrary")})]}):Ns(yx,{children:[n.length>0&&Hr(Oh,{itemsRenderedPerBatch:O,items:[{id:null,elements:n}],onItemSelectToggle:w,onItemDrag:L,onClick:M,isItemSelected:A,svgCache:p}),Hr(Oh,{itemsRenderedPerBatch:O,items:u,onItemSelectToggle:w,onItemDrag:L,onClick:D,isItemSelected:A,svgCache:p})]})]}),Ns(vC,{children:[(h.length>0||n.length>0||u.length>0)&&Hr("div",{className:"library-menu-items-container__header library-menu-items-container__header--excal",children:b("labels.excalidrawLib")}),h.length>0?Hr(yx,{children:Hr(Oh,{itemsRenderedPerBatch:O,items:h,onItemSelectToggle:w,onItemDrag:L,onClick:D,isItemSelected:A,svgCache:p})}):u.length>0?Hr("div",{style:{margin:"1rem 0",display:"flex",flexDirection:"column",alignItems:"center",justifyContent:"center",width:"100%",fontSize:".9rem"},children:b("library.noItems")}):null]}),E&&Hr(Th,{style:{padding:"16px 0",width:"100%"},id:a,libraryReturnUrl:l,theme:i,children:Hr(xx,{selectedItems:c,onSelectItems:s})})]})]})}var qD,JD,TC=y(()=>{"use strict";f();qn();q();G();ul();W();_n();hn();ix();cC();bC();xC();Rd();yC();qD=17,JD=64});var SC=y(()=>{});import{useState as QD,useCallback as Tx,useMemo as AC,useRef as vx}from"react";import{atom as e_,useAtom as t_}from"jotai";import{jsx as Qi,jsxs as IC}from"react/jsx-runtime";var Ds,CC,r_,o_,kC,Bd=y(()=>{"use strict";f();pl();q();Oo();TC();Nr();kt();_n();we();qe();jt();SC();ix();G();W();Ds=e_(!1),CC=({children:e})=>Qi("div",{className:"layer-ui__library",children:e}),r_=({onInsertLibraryItems:e,pendingElements:t,onAddToLibrary:r,setAppState:o,libraryReturnUrl:n,library:i,id:a,theme:l,selectedItems:s,onSelectItems:c})=>{let[d]=t_(Ji,Ge),m=Tx(h=>{(async(x,T)=>{ve("element","addToLibrary","ui");for(let w of Am)if(x.some(I=>I.type===w))return o({errorMessage:b(`errors.libraryElementTypeError.${w}`)});let v=[{status:"unpublished",elements:x,id:zt(),created:Date.now()},...T];r(),i.setLibrary(v).catch(()=>{o({errorMessage:b("alerts.errorAddingToLibrary")})})})(h,d.libraryItems)},[r,i,o,d.libraryItems]),p=AC(()=>d.libraryItems,[d]);if(d.status==="loading"&&!d.isInitialized)return Qi(CC,{children:Qi("div",{className:"layer-ui__library-message",children:IC("div",{children:[Qi(er,{size:"2em"}),Qi("span",{children:b("labels.libraryLoadingMessage")})]})})});let u=d.libraryItems.length>0||t.length>0;return IC(CC,{children:[Qi(wx,{isLoading:d.status==="loading",libraryItems:p,onAddToLibrary:m,onInsertLibraryItems:e,pendingElements:t,id:a,libraryReturnUrl:n,theme:l,onSelectItems:c,selectedItems:s}),u&&Qi(Th,{className:"library-menu-control-buttons--at-bottom",style:{padding:"16px 12px 0 12px"},id:a,libraryReturnUrl:n,theme:l})]})},o_=(e,t)=>{let r=()=>ge(t,e,{includeBoundTextElement:!0,includeElementsInFrames:!0}),o=vx(r()),n=vx(e),i=vx(t);return(!rt(e.selectedElementIds,n.current.selectedElementIds)||!rt(t,i.current))&&(o.current=r(),n.current=e,i.current=t),o.current},kC=()=>{let{library:e,id:t,onInsertElements:r}=Or(),o=ji(),n=Be(),i=He(),a=Wi(),[l,s]=QD([]),c=AC(()=>e,[e]),d=o_(n,a),m=Tx(u=>{r(vh(u))},[r]),p=Tx(()=>{i({selectedElementIds:{},selectedGroupIds:{},activeEmbeddable:null})},[i]);return Qi(r_,{pendingElements:d,onInsertLibraryItems:m,onAddToLibrary:p,setAppState:i,libraryReturnUrl:o.libraryReturnUrl,library:c,id:t,theme:n.theme,selectedItems:l,onSelectItems:s})}});import n_ from"clsx";import{useEffect as i_,useState as a_}from"react";import{useSetAtom as l_}from"jotai";import{jsx as Hd,jsxs as c_}from"react/jsx-runtime";function s_(e){if(e&&typeof e=="number")return e;switch(e){case"small":return 550;case"wide":return 1024;case"regular":default:return 800}}var ft,ao=y(()=>{"use strict";f();m5();we();be();p5();qi();b5();G();Bd();kt();q();ne();ft=e=>{let[t,r]=d5(),[o]=a_(document.activeElement),{id:n}=Zt(),i=_e().viewport.isMobile;i_(()=>{if(!t)return;let c=oc(t);setTimeout(()=>{c.length>0&&e.autofocus!==!1&&(c[1]||c[0]).focus()});let d=m=>{if(m.key===C.TAB){let p=oc(t),{activeElement:u}=document,h=p.findIndex(E=>E===u);h===0&&m.shiftKey?(p[p.length-1].focus(),m.preventDefault()):h===p.length-1&&!m.shiftKey&&(p[0].focus(),m.preventDefault())}};return t.addEventListener("keydown",d),()=>t.removeEventListener("keydown",d)},[t,e.autofocus]);let a=He(),l=l_(Ds,Ge),s=()=>{a({openMenu:null}),l(!1),o.focus(),e.onCloseRequest()};return Hd(f5,{className:n_("Dialog",e.className,{"Dialog--fullscreen":i}),labelledBy:"dialog-title",maxWidth:s_(e.size),onCloseRequest:s,closeOnClickOutside:e.closeOnClickOutside,children:c_(ir,{ref:r,children:[e.title&&Hd("h2",{id:`${n}-dialog-title`,className:"Dialog__title",children:Hd("span",{className:"Dialog__titleContent",children:e.title})}),i&&Hd("button",{className:"Dialog__close",onClick:s,title:b("buttons.close"),"aria-label":b("buttons.close"),children:to}),Hd("div",{className:"Dialog__content",children:e.children})]})})}});var MC=y(()=>{});var LC=y(()=>{});import d_ from"clsx";import{jsx as m_}from"react/jsx-runtime";var Tn,Os=y(()=>{"use strict";f();G();LC();Tn=({type:e="button",onSelect:t,selected:r,children:o,className:n="",...i})=>m_("button",{onClick:xi(i.onClick,a=>{t()}),type:e,className:d_("excalidraw-button",n,{selected:r}),...i,children:o})});import{forwardRef as p_,useRef as u_,useImperativeHandle as h_,useLayoutEffect as g_,useState as f_}from"react";import Sx from"clsx";import{jsx as Cx,jsxs as PC}from"react/jsx-runtime";var Bh,Ix=y(()=>{"use strict";f();MC();Os();ne();Bh=p_(({onChange:e,label:t,fullWidth:r,placeholder:o,readonly:n,selectOnRender:i,onKeyDown:a,isRedacted:l=!1,...s},c)=>{let d=u_(null);h_(c,()=>d.current),g_(()=>{i&&d.current?.select()},[i]);let[m,p]=f_(!1);return PC("div",{className:Sx("ExcTextField",{"ExcTextField--fullWidth":r}),onClick:()=>{d.current?.focus()},children:[Cx("div",{className:"ExcTextField__label",children:t}),PC("div",{className:Sx("ExcTextField__input",{"ExcTextField__input--readonly":n}),children:[Cx("input",{className:Sx({"is-redacted":"value"in s&&s.value&&l&&!m}),readOnly:n,value:"value"in s?s.value:void 0,defaultValue:"defaultValue"in s?s.defaultValue:void 0,placeholder:o,ref:d,onChange:u=>e?.(u.target.value),onKeyDown:a}),l&&Cx(Tn,{onSelect:()=>p(!m),style:{border:0,userSelect:"none"},children:m?iE:rl})]})]})})});var b_,_t,hl=y(()=>{"use strict";f();W();q();G();b_={toggleTheme:[N("Shift+Alt+D")],saveScene:[N("CtrlOrCmd+S")],loadScene:[N("CtrlOrCmd+O")],clearCanvas:[N("CtrlOrCmd+Delete")],imageExport:[N("CtrlOrCmd+Shift+E")],commandPalette:[N("CtrlOrCmd+/"),N("CtrlOrCmd+Shift+P")],cut:[N("CtrlOrCmd+X")],copy:[N("CtrlOrCmd+C")],paste:[N("CtrlOrCmd+V")],copyStyles:[N("CtrlOrCmd+Alt+C")],pasteStyles:[N("CtrlOrCmd+Alt+V")],selectAll:[N("CtrlOrCmd+A")],deleteSelectedElements:[N("Delete")],duplicateSelection:[N("CtrlOrCmd+D"),N(`Alt+${b("helpDialog.drag")}`)],sendBackward:[N("CtrlOrCmd+[")],bringForward:[N("CtrlOrCmd+]")],sendToBack:[ur?N("CtrlOrCmd+Alt+["):N("CtrlOrCmd+Shift+[")],bringToFront:[ur?N("CtrlOrCmd+Alt+]"):N("CtrlOrCmd+Shift+]")],copyAsPng:[N("Shift+Alt+C")],copyAsSvg:[],group:[N("CtrlOrCmd+G")],ungroup:[N("CtrlOrCmd+Shift+G")],gridMode:[N("CtrlOrCmd+'")],zenMode:[N("Alt+Z")],objectsSnapMode:[N("Alt+S")],stats:[N("Alt+/")],addToLibrary:[],flipHorizontal:[N("Shift+H")],flipVertical:[N("Shift+V")],viewMode:[N("Alt+R")],hyperlink:[N("CtrlOrCmd+K")],toggleElementLock:[N("CtrlOrCmd+Shift+L")],resetZoom:[N("CtrlOrCmd+0")],zoomOut:[N("CtrlOrCmd+-")],zoomIn:[N("CtrlOrCmd++")],zoomToFitSelection:[N("Shift+3")],zoomToFit:[N("Shift+1")],zoomToFitSelectionInViewport:[N("Shift+2")],toggleEraserTool:[N("E")],toggleHandTool:[N("H")],setFrameAsActiveTool:[N("F")],saveFileToDisk:[N("CtrlOrCmd+S")],saveToActiveFile:[N("CtrlOrCmd+S")],toggleShortcuts:[N("?")]},_t=(e,t=0)=>{let r=b_[e];return r&&r.length>0?r[t]||r[0]:""}});var E_,x_,y_,w_,v_,T_,S_,C_,Ax,DC=y(()=>{"use strict";f();E_="\\u0300-\\u036f",x_="\\ufe20-\\ufe2f",y_="\\u20d0-\\u20ff",w_=E_+x_+y_,v_=`[${w_}]`,T_=RegExp(v_,"g"),S_=/[\xc0-\xd6\xd8-\xf6\xf8-\xff\u0100-\u017f]/g,C_={\u00C0:"A",\u00C1:"A",\u00C2:"A",\u00C3:"A",\u00C4:"A",\u00C5:"A",\u00E0:"a",\u00E1:"a",\u00E2:"a",\u00E3:"a",\u00E4:"a",\u00E5:"a",\u00C7:"C",\u00E7:"c",\u00D0:"D",\u00F0:"d",\u00C8:"E",\u00C9:"E",\u00CA:"E",\u00CB:"E",\u00E8:"e",\u00E9:"e",\u00EA:"e",\u00EB:"e",\u00CC:"I",\u00CD:"I",\u00CE:"I",\u00CF:"I",\u00EC:"i",\u00ED:"i",\u00EE:"i",\u00EF:"i",\u00D1:"N",\u00F1:"n",\u00D2:"O",\u00D3:"O",\u00D4:"O",\u00D5:"O",\u00D6:"O",\u00D8:"O",\u00F2:"o",\u00F3:"o",\u00F4:"o",\u00F5:"o",\u00F6:"o",\u00F8:"o",\u00D9:"U",\u00DA:"U",\u00DB:"U",\u00DC:"U",\u00F9:"u",\u00FA:"u",\u00FB:"u",\u00FC:"u",\u00DD:"Y",\u00FD:"y",\u00FF:"y",\u00C6:"E",\u00E6:"e",\u00DE:"T",\u00FE:"t",\u00DF:"s",\u0100:"A",\u0102:"A",\u0104:"A",\u0101:"a",\u0103:"a",\u0105:"a",\u0106:"C",\u0108:"C",\u010A:"C",\u010C:"C",\u0107:"c",\u0109:"c",\u010B:"c",\u010D:"c",\u010E:"D",\u0110:"D",\u010F:"d",\u0111:"d",\u0112:"E",\u0114:"E",\u0116:"E",\u0118:"E",\u011A:"E",\u0113:"e",\u0115:"e",\u0117:"e",\u0119:"e",\u011B:"e",\u011C:"G",\u011E:"G",\u0120:"G",\u0122:"G",\u011D:"g",\u011F:"g",\u0121:"g",\u0123:"g",\u0124:"H",\u0126:"H",\u0125:"h",\u0127:"h",\u0128:"I",\u012A:"I",\u012C:"I",\u012E:"I",\u0130:"I",\u0129:"i",\u012B:"i",\u012D:"i",\u012F:"i",\u0131:"i",\u0134:"J",\u0135:"j",\u0136:"K",\u0137:"k",\u0138:"k",\u0139:"L",\u013B:"L",\u013D:"L",\u013F:"L",\u0141:"L",\u013A:"l",\u013C:"l",\u013E:"l",\u0140:"l",\u0142:"l",\u0143:"N",\u0145:"N",\u0147:"N",\u014A:"N",\u0144:"n",\u0146:"n",\u0148:"n",\u014B:"n",\u014C:"O",\u014E:"O",\u0150:"O",\u014D:"o",\u014F:"o",\u0151:"o",\u0154:"R",\u0156:"R",\u0158:"R",\u0155:"r",\u0157:"r",\u0159:"r",\u015A:"S",\u015C:"S",\u015E:"S",\u0160:"S",\u015B:"s",\u015D:"s",\u015F:"s",\u0161:"s",\u0162:"T",\u0164:"T",\u0166:"T",\u0163:"t",\u0165:"t",\u0167:"t",\u0168:"U",\u016A:"U",\u016C:"U",\u016E:"U",\u0170:"U",\u0172:"U",\u0169:"u",\u016B:"u",\u016D:"u",\u016F:"u",\u0171:"u",\u0173:"u",\u0174:"W",\u0175:"w",\u0176:"Y",\u0177:"y",\u0178:"Y",\u0179:"Z",\u017B:"Z",\u017D:"Z",\u017A:"z",\u017C:"z",\u017E:"z",\u0132:"I",\u0133:"i",\u0152:"E",\u0153:"e",\u0149:"n",\u017F:"s"},Ax=e=>e.replace(S_,t=>C_[t]||t).replace(T_,"")});import{jsx as I_}from"react/jsx-runtime";var ea,Fh=y(()=>{"use strict";f();ea=({icon:e})=>I_("span",{style:{width:"1em",margin:"0 0.5ex 0 0.5ex",display:"inline-block",lineHeight:0,verticalAlign:"middle"},children:e})});var Ud,_C,zh=y(()=>{"use strict";f();ne();be();Ud=[{icon:X1,value:"selection",key:C.V,numericKey:C[1],fillable:!0},{icon:Z1,value:"rectangle",key:C.R,numericKey:C[2],fillable:!0},{icon:j1,value:"diamond",key:C.D,numericKey:C[3],fillable:!0},{icon:q1,value:"ellipse",key:C.O,numericKey:C[4],fillable:!0},{icon:J1,value:"arrow",key:C.A,numericKey:C[5],fillable:!0},{icon:Q1,value:"line",key:C.L,numericKey:C[6],fillable:!0},{icon:qa,value:"freedraw",key:[C.P,C.X],numericKey:C[7],fillable:!1},{icon:tb,value:"text",key:C.T,numericKey:C[8],fillable:!1},{icon:rb,value:"image",key:null,numericKey:C[9],fillable:!1},{icon:ob,value:"eraser",key:C.E,numericKey:C[0],fillable:!1}],_C=e=>Ud.find((r,o)=>r.numericKey!=null&&e===r.numericKey.toString()||r.key&&(typeof r.key=="string"?r.key===e:r.key.includes(e)))?.value||null});var RC=y(()=>{});import kx from"react";import Sn from"tunnel-rat";var Mx,lt,NC,lo=y(()=>{"use strict";f();Mx=kx.createContext(null),lt=()=>kx.useContext(Mx),NC=()=>kx.useMemo(()=>({MainMenuTunnel:Sn(),WelcomeScreenMenuHintTunnel:Sn(),WelcomeScreenToolbarHintTunnel:Sn(),WelcomeScreenHelpHintTunnel:Sn(),WelcomeScreenCenterTunnel:Sn(),FooterCenterTunnel:Sn(),DefaultSidebarTriggerTunnel:Sn(),DefaultSidebarTabTriggersTunnel:Sn(),OverwriteConfirmDialogTunnel:Sn(),TTDDialogTriggerTunnel:Sn(),jotaiScope:Symbol()}),[])});import{useState as A_}from"react";import Lx from"clsx";import{Fragment as ta,jsx as pt,jsxs as At}from"react/jsx-runtime";var Px,Dx,Hh,Uh,OC,BC,FC,zC,Gd=y(()=>{"use strict";f();q();we();qe();zh();G();ul();Dt();fc();Nr();me();ko();Ki();mt();RC();zd();ne();be();lo();Px=(e,t)=>{let r=t[0]?.type||null;for(let o of t)if(o.type!==r){r=null;break}return gc(e.activeTool.type)&&e.activeTool.type!=="image"&&r!=="image"&&r!=="frame"&&r!=="magicframe"||t.some(o=>gc(o.type))},Dx=(e,t)=>Hn(e.activeTool.type)||t.some(r=>Hn(r.type)),Hh=({appState:e,elementsMap:t,renderAction:r})=>{let o=Za(t,e),n=!1;o.length===2&&(lr(o[0])||lr(o[1]))&&(n=!0);let i=!!e.editingElement,a=_e(),l=document.documentElement.getAttribute("dir")==="rtl",s=Hn(e.activeTool.type)&&!hr(e.currentItemBackgroundColor)||o.some(d=>Hn(d.type)&&!hr(d.backgroundColor)),c=o.length===1||n;return At("div",{className:"panelColumn",children:[pt("div",{children:Px(e,o)&&r("changeStrokeColor")}),Dx(e,o)&&pt("div",{children:r("changeBackgroundColor")}),s&&r("changeFillStyle"),(Gm(e.activeTool.type)||o.some(d=>Gm(d.type)))&&r("changeStrokeWidth"),(e.activeTool.type==="freedraw"||o.some(d=>d.type==="freedraw"))&&r("changeStrokeShape"),(Vm(e.activeTool.type)||o.some(d=>Vm(d.type)))&&At(ta,{children:[r("changeStrokeStyle"),r("changeSloppiness")]}),(Pl(e.activeTool.type)||o.some(d=>Pl(d.type)))&&pt(ta,{children:r("changeRoundness")}),(e.activeTool.type==="text"||o.some(V))&&At(ta,{children:[r("changeFontSize"),r("changeFontFamily"),(e.activeTool.type==="text"||f2(o,t))&&r("changeTextAlign")]}),g2(o,t)&&r("changeVerticalAlign"),(wa(e.activeTool.type)||o.some(d=>wa(d.type)))&&pt(ta,{children:r("changeArrowhead")}),r("changeOpacity"),At("fieldset",{children:[pt("legend",{children:b("labels.layers")}),At("div",{className:"buttonList",children:[r("sendToBack"),r("sendBackward"),r("bringToFront"),r("bringForward")]})]}),o.length>1&&!n&&At("fieldset",{children:[pt("legend",{children:b("labels.align")}),At("div",{className:"buttonList",children:[l?At(ta,{children:[r("alignRight"),r("alignHorizontallyCentered"),r("alignLeft")]}):At(ta,{children:[r("alignLeft"),r("alignHorizontallyCentered"),r("alignRight")]}),o.length>2&&r("distributeHorizontally"),pt("div",{style:{flexBasis:"100%",height:0}}),At("div",{style:{display:"flex",flexWrap:"wrap",gap:".5rem",marginTop:"-0.5rem"},children:[r("alignTop"),r("alignVerticallyCentered"),r("alignBottom"),o.length>2&&r("distributeVertically")]})]})]}),!i&&o.length>0&&At("fieldset",{children:[pt("legend",{children:b("labels.actions")}),At("div",{className:"buttonList",children:[!a.editor.isMobile&&r("duplicateSelection"),!a.editor.isMobile&&r("deleteSelectedElements"),r("group"),r("ungroup"),c&&r("hyperlink")]})]})]})},Uh=({activeTool:e,appState:t,app:r,UIOptions:o})=>{let[n,i]=A_(!1),a=e.type==="frame",l=e.type==="laser",s=e.type==="embeddable",{TTDDialogTriggerTunnel:c}=lt();return At(ta,{children:[Ud.map(({value:d,icon:m,key:p,numericKey:u,fillable:h},E)=>{if(o.tools?.[d]===!1)return null;let x=b(`toolBar.${d}`),T=p&&Qo(typeof p=="string"?p:p[0]),v=T?`${T} ${b("helpDialog.or")} ${u}`:`${u}`;return pt(pe,{className:Lx("Shape",{fillable:h}),type:"radio",icon:m,checked:e.type===d,name:"editor-current-shape",title:`${Qo(x)} \u2014 ${v}`,keyBindingLabel:u||T,"aria-label":Qo(x),"aria-keyshortcuts":v,"data-testid":`toolbar-${d}`,onPointerDown:({pointerType:w})=>{!t.penDetected&&w==="pen"&&r.togglePenMode(!0)},onChange:({pointerType:w})=>{t.activeTool.type!==d&&ve("toolbar",d,"ui"),d==="image"?r.setActiveTool({type:d,insertOnCanvasDirectly:w!=="mouse"}):r.setActiveTool({type:d})}},d)}),pt("div",{className:"App-toolbar__divider"}),At(Ve,{open:n,children:[At(Ve.Trigger,{className:Lx("App-toolbar__extra-tools-trigger",{"App-toolbar__extra-tools-trigger--selected":a||s||l&&!r.props.isCollaborating}),onToggle:()=>i(!n),title:b("toolBar.extraTools"),children:[oE,r.props.aiEnabled!==!1&&pt("div",{style:{display:"inline-flex",marginLeft:"auto",padding:"2px 4px",borderRadius:6,fontSize:8,fontFamily:"Cascadia, monospace",position:"absolute",background:"pink",color:"black",bottom:3,right:4},children:"AI"})]}),At(Ve.Content,{onClickOutside:()=>i(!1),onSelect:()=>i(!1),className:"App-toolbar__extra-tools-dropdown",children:[pt(Ve.Item,{onSelect:()=>r.setActiveTool({type:"frame"}),icon:cd,shortcut:C.F.toLocaleUpperCase(),"data-testid":"toolbar-frame",selected:a,children:b("toolBar.frame")}),pt(Ve.Item,{onSelect:()=>r.setActiveTool({type:"embeddable"}),icon:ib,"data-testid":"toolbar-embeddable",selected:s,children:b("toolBar.embeddable")}),pt(Ve.Item,{onSelect:()=>r.setActiveTool({type:"laser"}),icon:md,"data-testid":"toolbar-laser",selected:l,shortcut:C.K.toLocaleUpperCase(),children:b("toolBar.laser")}),pt("div",{style:{margin:"6px 0",fontSize:14,fontWeight:600},children:"Generate"}),r.props.aiEnabled!==!1&&pt(c.Out,{}),pt(Ve.Item,{onSelect:()=>r.setOpenDialog({name:"ttd",tab:"mermaid"}),icon:dd,"data-testid":"toolbar-embeddable",children:b("toolBar.mermaidToExcalidraw")}),r.props.aiEnabled!==!1&&At(ta,{children:[At(Ve.Item,{onSelect:()=>r.onMagicframeToolSelect(),icon:tl,"data-testid":"toolbar-magicframe",children:[b("toolBar.magicframe"),pt(Ve.Item.Badge,{children:"AI"})]}),pt(Ve.Item,{onSelect:()=>{ve("ai","open-settings","d2c"),r.setOpenDialog({name:"settings",source:"settings",tab:"diagram-to-code"})},icon:fs,"data-testid":"toolbar-magicSettings",children:b("toolBar.magicSettings")})]})]})]})]})},OC=({renderAction:e,zoom:t})=>pt(qt.Col,{gap:1,className:"zoom-actions",children:At(qt.Row,{align:"center",children:[e("zoomOut"),e("resetZoom"),e("zoomIn")]})}),BC=({renderAction:e,className:t})=>At("div",{className:`undo-redo-buttons ${t}`,children:[pt("div",{className:"undo-button-container",children:pt(no,{label:b("buttons.undo"),children:e("undo")})}),pt("div",{className:"redo-button-container",children:At(no,{label:b("buttons.redo"),children:[" ",e("redo")]})})]}),FC=({actionManager:e,showExitZenModeBtn:t})=>pt("button",{className:Lx("disable-zen-mode",{"disable-zen-mode--visible":t}),onClick:()=>e.executeAction(ml),children:b("buttons.exitZenMode")}),zC=({renderAction:e,className:t})=>pt("div",{className:`finalize-button ${t}`,children:e("finalize",{size:"small"})})});import{useRef as k_}from"react";var _x,HC=y(()=>{"use strict";f();_x=e=>{let t=k_({userFn:e});return t.current.userFn=e,t.current.stableFn||(t.current.stableFn=(...r)=>t.current.userFn(...r)),t.current.stableFn}});import{atom as M_,useAtom as L_}from"jotai";import{jsx as D_,jsxs as P_}from"react/jsx-runtime";var gl,UC,Vd=y(()=>{"use strict";f();ko();q();kt();we();lx();gl=M_(null),UC=()=>{let[e,t]=L_(gl,Ge),r=Ut();return e&&e==="clearCanvas"?D_(Ih,{onConfirm:()=>{r.executeAction(wn),t(null)},onCancel:()=>t(null),title:b("clearCanvasDialog.title"),children:P_("p",{className:"clear-canvas__content",children:[" ",b("alerts.clearReset")]})}):null}});var Rx={};Xs(Rx,{toggleTheme:()=>__});var __,GC=y(()=>{"use strict";f();ko();__={...$i,category:"App",label:"Toggle theme",perform:({actionManager:e})=>{e.executeAction($i,"commandPalette")}}});var VC=y(()=>{});import{useEffect as Vh,useRef as R_,useState as Gh}from"react";import YC from"clsx";import N_ from"fuzzy";import{atom as O_,useAtom as B_}from"jotai";import{jsx as vr,jsxs as Cn}from"react/jsx-runtime";function U_({customCommandPaletteItems:e}){let t=Or(),r=Be(),o=He(),n=ji(),i=Ut(),[a,l]=B_(F_),[s,c]=Gh(null),d=R_(null),m=ws({uiAppState:r,customCommandPaletteItems:e,appProps:n});Vh(()=>{let{uiAppState:A,customCommandPaletteItems:M,appProps:D}=m,O=z=>{let ee="";return z.label&&(typeof z.label=="function"?ee=b(z.label(t.scene.getNonDeletedElements(),A,t)):ee=b(z.label)),ee},R=z=>typeof z.icon=="function"?z.icon(A,t.scene.getNonDeletedElements()):z.icon,B=[],k=(z,ee,j)=>{let ie={label:O(z),icon:R(z),category:ee,shortcut:_t(z.name),keywords:z.keywords,predicate:z.predicate,viewMode:z.viewMode,perform:()=>{i.executeAction(z,"commandPalette")}};return j?j(ie,z):ie};if(A&&t.scene&&i){let z=[i.actions.group,i.actions.ungroup,i.actions.cut,i.actions.copy,i.actions.deleteSelectedElements,i.actions.copyStyles,i.actions.pasteStyles,i.actions.sendBackward,i.actions.sendToBack,i.actions.bringForward,i.actions.bringToFront,i.actions.alignTop,i.actions.alignBottom,i.actions.alignLeft,i.actions.alignRight,i.actions.alignVerticallyCentered,i.actions.alignHorizontallyCentered,i.actions.duplicateSelection,i.actions.flipHorizontal,i.actions.flipVertical,i.actions.zoomToFitSelection,i.actions.zoomToFitSelectionInViewport,i.actions.increaseFontSize,i.actions.decreaseFontSize,i.actions.toggleLinearEditor,ks].map(Y=>k(Y,vt.elements,(ae,fe)=>({...ae,predicate:fe.predicate?fe.predicate:(De,Le,pr,mi)=>ge(De,Le).length>0}))),ee=[i.actions.toggleHandTool,i.actions.setFrameAsActiveTool].map(Y=>k(Y,vt.tools)),j=[i.actions.undo,i.actions.redo,i.actions.zoomIn,i.actions.zoomOut,i.actions.resetZoom,i.actions.zoomToFit,i.actions.zenMode,i.actions.viewMode,i.actions.gridMode,i.actions.objectsSnapMode,i.actions.toggleShortcuts,i.actions.selectAll,i.actions.toggleElementLock,i.actions.unlockAllElements,i.actions.stats].map(Y=>k(Y,vt.editor)),ie=[i.actions.saveToActiveFile,i.actions.saveFileToDisk,i.actions.copyAsPng,i.actions.copyAsSvg].map(Y=>k(Y,vt.export));B=[...z,...j,{label:O(wn),icon:R(wn),shortcut:_t(wn.name),category:vt.editor,keywords:["delete","destroy"],viewMode:!1,perform:()=>{Qt.set(gl,"clearCanvas")}},{label:b("buttons.exportImage"),category:vt.export,icon:id,shortcut:_t("imageExport"),keywords:["export","image","png","jpeg","svg","clipboard","picture"],perform:()=>{o({openDialog:{name:"imageExport"}})}},...ie];let ke=[{label:b("toolBar.library"),category:vt.app,icon:td,viewMode:!1,perform:()=>{A.openSidebar?o({openSidebar:null}):o({openSidebar:{name:Vr.name,tab:Vr.defaultTab}})}},{label:b("labels.changeStroke"),keywords:["color","outline"],category:vt.elements,icon:nd,viewMode:!1,predicate:(Y,ae)=>{let fe=ge(Y,ae);return fe.length>0&&Px(ae,fe)},perform:()=>{o(Y=>({openMenu:Y.openMenu==="shape"?null:"shape",openPopup:"elementStroke"}))}},{label:b("labels.changeBackground"),keywords:["color","fill"],icon:nd,category:vt.elements,viewMode:!1,predicate:(Y,ae)=>{let fe=ge(Y,ae);return fe.length>0&&Dx(ae,fe)},perform:()=>{o(Y=>({openMenu:Y.openMenu==="shape"?null:"shape",openPopup:"elementBackground"}))}},{label:b("labels.canvasBackground"),keywords:["color"],icon:nd,category:vt.editor,viewMode:!1,perform:()=>{o(Y=>({openMenu:Y.openMenu==="canvas"?null:"canvas",openPopup:"canvasBackground"}))}},...Ud.reduce((Y,ae)=>{let{value:fe,icon:De,key:Le,numericKey:pr}=ae;if(D.UIOptions.tools?.[fe]===!1)return Y;let Zo=Le&&Qo(typeof Le=="string"?Le:Le[0])||pr,Pn={label:b(`toolBar.${fe}`),category:vt.tools,shortcut:Zo,icon:De,keywords:["toolbar"],viewMode:!1,perform:({event:pi})=>{fe==="image"?t.setActiveTool({type:fe,insertOnCanvasDirectly:pi.type==="keydown"}):t.setActiveTool({type:fe})}};return Y.push(Pn),Y},[]),...ee,{label:b("toolBar.lock"),category:vt.tools,icon:A.activeTool.locked?ja:Hi,shortcut:C.Q.toLocaleUpperCase(),viewMode:!1,perform:()=>{t.toggleLock()}},{label:`${b("labels.textToDiagram")}...`,category:vt.tools,icon:lE,viewMode:!1,predicate:D.aiEnabled,perform:()=>{o(Y=>({...Y,openDialog:{name:"ttd",tab:"text-to-diagram"}}))}},{label:`${b("toolBar.mermaidToExcalidraw")}...`,category:vt.tools,icon:dd,viewMode:!1,predicate:D.aiEnabled,perform:()=>{o(Y=>({...Y,openDialog:{name:"ttd",tab:"mermaid"}}))}}],$=[...B,...ke,...M||[]].map(Y=>({...Y,icon:Y.icon||ud,order:Y.order??z_(Y.category),haystack:`${Ax(Y.label)} ${Y.keywords?.join(" ")||""}`}));c($),l($.find(Y=>Y.label===a?.label)??null)}},[m,t,i,c,a?.label,l,o]);let[p,u]=Gh(""),[h,E]=Gh(null),[x,T]=Gh({}),v=A=>{o({openDialog:null},A),u("")},w=(A,M)=>{r.openDialog?.name==="commandPalette"&&(M.stopPropagation(),M.preventDefault(),document.body.classList.add("excalidraw-animations-disabled"),v(()=>{A.perform({actionManager:i,event:M}),l(A),requestAnimationFrame(()=>{document.body.classList.remove("excalidraw-animations-disabled")})}))},I=_x(A=>A.viewMode===!1&&r.viewModeEnabled?!1:typeof A.predicate=="function"?A.predicate(t.scene.getNonDeletedElements(),r,n,t):A.predicate===void 0||A.predicate),L=_x(A=>{let M=uo(A.target)||KC(A)||A.key===C.ESCAPE;if(M&&A.key!==C.ARROW_UP&&A.key!==C.ARROW_DOWN&&A.key!==C.ENTER)return;let D=Object.values(x).flat(),O=a&&!p&&I(a);if(A.key===C.ARROW_UP){A.preventDefault();let R=D.findIndex(z=>z.label===h?.label);if(O){if(R===0){E(a);return}if(h===a){let z=D[D.length-1];z&&E(z);return}}let B;R===-1?B=D.length-1:B=R===0?D.length-1:(R-1)%D.length;let k=D[B];k&&E(k);return}if(A.key===C.ARROW_DOWN){A.preventDefault();let R=D.findIndex(z=>z.label===h?.label);if(O){if(!h||R===D.length-1){E(a);return}if(h===a){let z=D[0];z&&E(z);return}}let B=(R+1)%D.length,k=D[B];k&&E(k);return}if(A.key===C.ENTER&&h&&setTimeout(()=>{w(h,A)}),!M){if(A.stopPropagation(),/^[a-zA-Z0-9]$/.test(A.key)){d?.current?.focus();return}A.preventDefault()}});return Vh(()=>(window.addEventListener("keydown",L,{capture:!0}),()=>window.removeEventListener("keydown",L,{capture:!0})),[L]),Vh(()=>{if(!s)return;let A=R=>{let B={};for(let k of R)B[k.category]?B[k.category].push(k):B[k.category]=[k];return B},M=s.filter(I).sort((R,B)=>R.order-B.order),D=!p&&a&&I(a);if(!p){T(A(D?M.filter(R=>R.label!==a?.label):M)),E(D?a:M[0]||null);return}let O=Ax(p.replace(/[<>-_| ]/g,""));M=N_.filter(O,M,{extract:R=>R.haystack}).sort((R,B)=>B.score-R.score).map(R=>R.original),T(A(M)),E(M[0]??null)},[p,s,I,a]),Cn(ft,{onCloseRequest:()=>v(),closeOnClickOutside:!0,title:!1,size:720,autofocus:!0,className:"command-palette-dialog",children:[vr(Bh,{value:p,placeholder:b("commandPalette.search.placeholder"),onChange:A=>{u(A)},selectOnRender:!0,ref:d}),!t.device.viewport.isMobile&&Cn("div",{className:"shortcuts-wrapper",children:[vr(Wh,{shortcut:"\u2191\u2193",children:b("commandPalette.shortcuts.select")}),vr(Wh,{shortcut:"\u21B5",children:b("commandPalette.shortcuts.confirm")}),vr(Wh,{shortcut:N("Esc"),children:b("commandPalette.shortcuts.close")})]}),Cn("div",{className:"commands",children:[a&&!p&&Cn("div",{className:"command-category",children:[Cn("div",{className:"command-category-title",children:[b("commandPalette.recents"),vr("div",{className:"icon",style:{marginLeft:"6px"},children:sE})]}),vr(WC,{command:a,isSelected:a.label===h?.label,onClick:A=>w(a,A),disabled:!I(a),onMouseMove:()=>E(a),showShortcut:!t.device.viewport.isMobile,appState:r})]}),Object.keys(x).length>0?Object.keys(x).map((A,M)=>Cn("div",{className:"command-category",children:[vr("div",{className:"command-category-title",children:A}),x[A].map(D=>vr(WC,{command:D,isSelected:D.label===h?.label,onClick:O=>w(D,O),onMouseMove:()=>E(D),showShortcut:!t.device.viewport.isMobile,appState:r},D.label))]},A)):s?Cn("div",{className:"no-match",children:[vr("div",{className:"icon",children:pd})," ",b("commandPalette.search.noMatch")]}):null]})]})}var F_,vt,z_,Wh,KC,H_,WC,Nx=y(()=>{"use strict";f();we();be();ao();Ix();qe();q();hl();W();ne();jt();G();DC();Fh();zh();Gd();HC();ko();kt();Vd();GC();Nr();Xu();VC();F_=O_(null),vt={app:"App",export:"Export",tools:"Tools",editor:"Editor",elements:"Elements",links:"Links"},z_=e=>{switch(e){case vt.app:return 1;case vt.export:return 2;case vt.editor:return 3;case vt.tools:return 4;case vt.elements:return 5;case vt.links:return 6;default:return 10}},Wh=({shortcut:e,className:t,children:r})=>{let o=e.replace("++","+$").split("+");return Cn("div",{className:YC("shortcut",t),children:[o.map((n,i)=>vr("div",{className:"shortcut-wrapper",children:vr("div",{className:"shortcut-key",children:n==="$"?"+":n})},n)),vr("div",{className:"shortcut-desc",children:r})]})},KC=e=>!e.altKey&&e[C.CTRL_OR_CMD]&&(e.shiftKey&&e.key.toLowerCase()===C.P||e.key===C.SLASH),H_=Object.assign(e=>{let t=Be(),r=He();return Vh(()=>{let o=n=>{KC(n)&&(n.preventDefault(),n.stopPropagation(),r(i=>{let a=i.openDialog?.name==="commandPalette"?null:{name:"commandPalette"};return a&&ve("command_palette","open","shortcut"),{openDialog:a}}))};return window.addEventListener("keydown",o,{capture:!0}),()=>window.removeEventListener("keydown",o,{capture:!0})},[r]),t.openDialog?.name!=="commandPalette"?null:vr(U_,{...e})},{defaultItems:Rx});WC=({command:e,isSelected:t,disabled:r,onMouseMove:o,onClick:n,showShortcut:i,appState:a})=>{let l=()=>{};return Cn("div",{className:YC("command-item",{"item-selected":t,"item-disabled":r}),ref:s=>{t&&!r&&s?.scrollIntoView?.({block:"nearest"})},onClick:r?l:n,onMouseMove:r?l:o,title:r?b("commandPalette.itemNotAvailable"):"",children:[Cn("div",{className:"name",children:[e.icon&&vr(ea,{icon:typeof e.icon=="function"?e.icon(a):e.icon}),e.label]}),i&&e.shortcut&&vr(Wh,{shortcut:e.shortcut})]})}});var Yh,$C=y(()=>{"use strict";f();Nx();or();me();ze();Je();Yh=U({name:"toggleLinearEditor",category:vt.elements,label:(e,t,r)=>{let o=r.scene.getSelectedElements({selectedElementIds:t.selectedElementIds,includeBoundTextElement:!0})[0];return t.editingLinearElement?.elementId===o?.id?"labels.lineEditor.exit":"labels.lineEditor.edit"},trackEvent:{category:"element"},predicate:(e,t,r,o)=>{let n=o.scene.getSelectedElements(t);return!!(n.length===1&&ce(n[0]))},perform(e,t,r,o){let n=o.scene.getSelectedElements({selectedElementIds:t.selectedElementIds,includeBoundTextElement:!0})[0],i=t.editingLinearElement?.elementId===n.id?null:new Z(n);return{appState:{...t,editingLinearElement:i},storeAction:_.CAPTURE}}})});var XC={};Xs(XC,{actionAddToLibrary:()=>dh,actionAlignBottom:()=>RS,actionAlignHorizontallyCentered:()=>FS,actionAlignLeft:()=>NS,actionAlignRight:()=>OS,actionAlignTop:()=>_S,actionAlignVerticallyCentered:()=>BS,actionBindText:()=>gh,actionBringForward:()=>Fu,actionBringToFront:()=>Hu,actionChangeBackgroundColor:()=>B3,actionChangeExportBackground:()=>rh,actionChangeFillStyle:()=>F3,actionChangeFontFamily:()=>V3,actionChangeFontSize:()=>G3,actionChangeOpacity:()=>U3,actionChangeProjectName:()=>th,actionChangeSloppiness:()=>H3,actionChangeStrokeColor:()=>O3,actionChangeStrokeWidth:()=>z3,actionChangeTextAlign:()=>W3,actionChangeVerticalAlign:()=>Y3,actionChangeViewBackgroundColor:()=>X3,actionClearCanvas:()=>wn,actionCopy:()=>dl,actionCopyAsPng:()=>Md,actionCopyAsSvg:()=>kd,actionCopyStyles:()=>nh,actionCut:()=>Ad,actionDeleteSelected:()=>bs,actionDuplicateSelection:()=>Vu,actionFinalize:()=>io,actionFlipHorizontal:()=>mh,actionFlipVertical:()=>ph,actionGoToCollaborator:()=>kS,actionGroup:()=>ah,actionLink:()=>ks,actionLoadScene:()=>sl,actionPasteStyles:()=>ih,actionResetZoom:()=>Z3,actionSaveFileToDisk:()=>Ts,actionSaveToActiveFile:()=>Sd,actionSelectAll:()=>Gu,actionSendBackward:()=>Bu,actionSendToBack:()=>zu,actionShortcuts:()=>Zi,actionToggleCanvasMenu:()=>fS,actionToggleEditMenu:()=>bS,actionToggleElementLock:()=>bh,actionToggleGridMode:()=>Pd,actionToggleLinearEditor:()=>Yh,actionToggleObjectsSnapMode:()=>uh,actionToggleStats:()=>ii,actionToggleTheme:()=>$i,actionToggleZenMode:()=>ml,actionUnbindText:()=>hh,actionUngroup:()=>lh,actionZoomIn:()=>xd,actionZoomOut:()=>yd,actionZoomToFit:()=>q3,copyText:()=>Ld,distributeHorizontally:()=>WS,distributeVertically:()=>YS});var ko=y(()=>{"use strict";f();vE();YT();KT();ZT();HE();vd();Q3();Cd();gS();xS();wS();MS();LS();zS();$S();ZS();YE();jS();qS();JS();KE();$E();s5();ex();$C()});var fl,Bs,Ox,Bx=y(()=>{"use strict";f();Rc();fl=class{constructor(t=!0,r=!0){this.isUndoStackEmpty=t;this.isRedoStackEmpty=r}},Bs=class e{onHistoryChangedEmitter=new cr;undoStack=[];redoStack=[];get isUndoStackEmpty(){return this.undoStack.length===0}get isRedoStackEmpty(){return this.redoStack.length===0}clear(){this.undoStack.length=0,this.redoStack.length=0}record(t,r){let o=Ox.create(r,t);o.isEmpty()||(this.undoStack.push(o.inverse()),o.elementsChange.isEmpty()||(this.redoStack.length=0),this.onHistoryChangedEmitter.trigger(new fl(this.isUndoStackEmpty,this.isRedoStackEmpty)))}undo(t,r,o){return this.perform(t,r,o,()=>e.pop(this.undoStack),n=>e.push(this.redoStack,n,t))}redo(t,r,o){return this.perform(t,r,o,()=>e.pop(this.redoStack),n=>e.push(this.undoStack,n,t))}perform(t,r,o,n,i){try{let a=n();if(a===null)return;let l=t,s=r,c=!1;for(;a;){try{[l,s,c]=a.applyTo(l,s,o)}finally{i(a)}if(c)break;a=n()}return[l,s]}finally{this.onHistoryChangedEmitter.trigger(new fl(this.isUndoStackEmpty,this.isRedoStackEmpty))}}static pop(t){if(!t.length)return null;let r=t.pop();return r!==void 0?r:null}static push(t,r,o){let n=r.inverse().applyLatestChanges(o);return t.push(n)}},Ox=class e{constructor(t,r){this.appStateChange=t;this.elementsChange=r}static create(t,r){return new e(t,r)}inverse(){return new e(this.appStateChange.inverse(),this.elementsChange.inverse())}applyTo(t,r,o){let[n,i]=this.elementsChange.applyTo(t,o.elements),[a,l]=this.appStateChange.applyTo(r,n);return[n,a,i||l]}applyLatestChanges(t){let r=this.elementsChange.applyLatestChanges(t);return e.create(this.appStateChange,r)}isEmpty(){return this.appStateChange.isEmpty()&&this.elementsChange.isEmpty()}}});import{useEffect as G_,useState as V_}from"react";var Fx,ZC=y(()=>{"use strict";f();Fx=(e,t)=>{let[r,o]=V_(t);return G_(()=>{let n=e.on(i=>{o(i)});return()=>{n()}},[e]),r}});import{jsx as QC}from"react/jsx-runtime";var jC,qC,JC,eI=y(()=>{"use strict";f();ne();Dt();q();Bx();be();G();W();ze();ZC();jC=(e,t)=>{if(!e.multiElement&&!e.resizingElement&&!e.editingElement&&!e.draggingElement){let r=t();if(!r)return{storeAction:_.NONE};let[o,n]=r,i=Array.from(o.values());return{appState:n,elements:i,storeAction:_.UPDATE}}return{storeAction:_.NONE}},qC=(e,t)=>({name:"undo",label:"buttons.undo",icon:Eu,trackEvent:{category:"history"},viewMode:!1,perform:(r,o)=>jC(o,()=>e.undo(X(r),o,t.snapshot)),keyTest:r=>r[C.CTRL_OR_CMD]&&r.key.toLowerCase()===C.Z&&!r.shiftKey,PanelComponent:({updateData:r,data:o})=>{let{isUndoStackEmpty:n}=Fx(e.onHistoryChangedEmitter,new fl);return QC(pe,{type:"button",icon:Eu,"aria-label":b("buttons.undo"),onClick:r,size:o?.size||"medium",disabled:n})}}),JC=(e,t)=>({name:"redo",label:"buttons.redo",icon:xu,trackEvent:{category:"history"},viewMode:!1,perform:(r,o)=>jC(o,()=>e.redo(X(r),o,t.snapshot)),keyTest:r=>r[C.CTRL_OR_CMD]&&r.shiftKey&&r.key.toLowerCase()===C.Z||fm&&r.ctrlKey&&!r.shiftKey&&r.key===C.Y,PanelComponent:({updateData:r,data:o})=>{let{isRedoStackEmpty:n}=Fx(e.onHistoryChangedEmitter,new fl);return QC(pe,{type:"button",icon:xu,"aria-label":b("buttons.redo"),onClick:r,size:o?.size||"medium",disabled:n})}})});import{jsx as W_}from"react/jsx-runtime";var zx,Wd,tI=y(()=>{"use strict";f();Nr();G();zx=(e,t,r,o,n,i)=>{if(e.trackEvent)try{typeof e.trackEvent=="object"&&(!e.trackEvent.predicate||e.trackEvent.predicate(r,o,i))&&ve(e.trackEvent.category,e.trackEvent.action||e.name,`${t} (${n.device.editor.isMobile?"mobile":"desktop"})`)}catch(a){console.error("error while logging action:",a)}},Wd=class{actions={};updater;getAppState;getElementsIncludingDeleted;app;constructor(t,r,o,n){this.updater=i=>{if(tn(i))i.then(a=>t(a));else return t(i)},this.getAppState=r,this.getElementsIncludingDeleted=o,this.app=n}registerAction(t){this.actions[t.name]=t}registerAll(t){t.forEach(r=>this.registerAction(r))}handleKeyDown(t){let r=this.app.props.UIOptions.canvasActions,o=Object.values(this.actions).sort((s,c)=>(c.keyPriority||0)-(s.keyPriority||0)).filter(s=>(s.name in r?r[s.name]:!0)&&s.keyTest&&s.keyTest(t,this.getAppState(),this.getElementsIncludingDeleted(),this.app));if(o.length!==1)return o.length>1&&console.warn("Canceling as multiple actions match this shortcut",o),!1;let n=o[0];if(this.getAppState().viewModeEnabled&&n.viewMode!==!0)return!1;let i=this.getElementsIncludingDeleted(),a=this.getAppState(),l=null;return zx(n,"keyboard",a,i,this.app,null),t.preventDefault(),t.stopPropagation(),this.updater(o[0].perform(i,a,l,this.app)),!0}executeAction(t,r="api",o=null){let n=this.getElementsIncludingDeleted(),i=this.getAppState();zx(t,r,i,n,this.app,o),this.updater(t.perform(n,i,o,this.app))}renderAction=(t,r)=>{let o=this.app.props.UIOptions.canvasActions;if(this.actions[t]&&"PanelComponent"in this.actions[t]&&(!(t in o)||o[t])){let n=this.actions[t],i=n.PanelComponent;i.displayName="PanelComponent";let a=this.getElementsIncludingDeleted(),l=this.getAppState(),s=c=>{zx(n,"ui",l,a,this.app,c),this.updater(n.perform(this.getElementsIncludingDeleted(),this.getAppState(),c,this.app))};return W_(i,{elements:this.getElementsIncludingDeleted(),appState:this.getAppState(),updateData:s,appProps:this.app.props,app:this.app,data:r})}return null};isActionEnabled=t=>{let r=this.getElementsIncludingDeleted(),o=this.getAppState();return!t.predicate||t.predicate(r,o,this.app.props,this.app)}}});var Hx,Ux,rI,oI=y(()=>{"use strict";f();Hx=e=>{let t=Array.from(e.values());return{x:rI(t,r=>r.x)/t.length,y:rI(t,r=>r.y)/t.length}},Ux=([e,t])=>Math.hypot(e.x-t.x,e.y-t.y),rI=(e,t)=>e.reduce((r,o)=>r+t(o),0)});var nI=y(()=>{});import Y_ from"clsx";import K_ from"react";import{jsx as Fs,jsxs as $_}from"react/jsx-runtime";var Tr,iI,aI=y(()=>{"use strict";f();RE();q();nI();hl();we();Tr="separator",iI=K_.memo(({actionManager:e,items:t,top:r,left:o,onClose:n})=>{let i=As(),a=Wi(),l=t.reduce((s,c)=>(c&&(c===Tr||!c.predicate||c.predicate(a,i,e.app.props,e.app))&&s.push(c),s),[]);return Fs(Ju,{onCloseRequest:()=>{n()},top:r,left:o,fitInViewport:!0,offsetLeft:i.offsetLeft,offsetTop:i.offsetTop,viewportWidth:i.width,viewportHeight:i.height,children:Fs("ul",{className:"context-menu",onContextMenu:s=>s.preventDefault(),children:l.map((s,c)=>{if(s===Tr)return!l[c-1]||l[c-1]===Tr?null:Fs("hr",{className:"context-menu-item-separator"},c);let d=s.name,m="";return s.label&&(typeof s.label=="function"?m=b(s.label(a,i,e.app)):m=b(s.label)),Fs("li",{"data-testid":d,onClick:()=>{n(()=>{e.executeAction(s,"contextMenu")})},children:$_("button",{className:Y_("context-menu-item",{dangerous:d==="deleteSelectedElements",checkmark:s.checked?.(i)}),children:[Fs("div",{className:"context-menu-item__label",children:m}),Fs("kbd",{className:"context-menu-item__shortcut",children:d?_t(d):""})]})},c)})})})})});import X_,{useState as Z_}from"react";import{Fragment as j_,jsx as Gx}from"react/jsx-runtime";var lI,sI=y(()=>{"use strict";f();q();ao();we();lI=({children:e,onClose:t})=>{let[r,o]=Z_(!!e),{container:n}=Zt(),i=X_.useCallback(()=>{o(!1),t&&t(),n?.focus()},[t,n]);return Gx(j_,{children:r&&Gx(ft,{size:"small",onCloseRequest:i,title:b("errorDialog.title"),children:Gx("div",{style:{whiteSpace:"pre-wrap"},children:e})})})}});var cI=y(()=>{});import q_ from"clsx";import{jsx as dI,jsxs as J_}from"react/jsx-runtime";var Kh,Vx=y(()=>{"use strict";f();cI();Kh=function({onChange:e,value:t,choices:r,name:o}){return dI("div",{className:"RadioGroup",children:r.map(n=>J_("div",{className:q_("RadioGroup__choice",{active:n.value===t}),title:n.ariaLabel,children:[dI("input",{name:o,type:"radio",checked:n.value===t,onChange:()=>e(n.value),"aria-label":n.ariaLabel}),n.label]},String(n.value)))})}});var mI=y(()=>{});import Q_ from"clsx";import{jsx as pI}from"react/jsx-runtime";var Yd,uI=y(()=>{"use strict";f();mI();Yd=({title:e,name:t,checked:r,onChange:o,disabled:n=!1})=>pI("div",{className:Q_("Switch",{toggled:r,disabled:n}),children:pI("input",{name:t,id:t,title:e,type:"checkbox",checked:r,disabled:n,onChange:()=>o(!r),onKeyDown:i=>{i.key===" "&&o(!r)}})})});var hI=y(()=>{});var gI=y(()=>{});import{forwardRef as eR,useState as tR}from"react";import rR from"clsx";import{jsx as Wx,jsxs as oR}from"react/jsx-runtime";var In,Kd=y(()=>{"use strict";f();gI();wi();_n();G();In=eR(({children:e,icon:t,onClick:r,label:o,variant:n="filled",color:i="primary",size:a="medium",fullWidth:l,className:s},c)=>{let[d,m]=tR(!1),p=async u=>{let h=r?.(u);if(tn(h))try{m(!0),await h}catch(E){if(E instanceof an)console.warn(E);else throw E}finally{m(!1)}};return Wx("button",{className:rR("ExcButton",`ExcButton--color-${i}`,`ExcButton--variant-${n}`,`ExcButton--size-${a}`,{"ExcButton--fullWidth":l},s),onClick:p,type:"button","aria-label":o,ref:c,disabled:d,children:oR("div",{className:"ExcButton__contents",children:[d&&Wx(er,{}),t&&Wx("div",{className:"ExcButton__icon","aria-hidden":!0,children:t}),n!=="icon"&&(e??o)]})})})});import{useEffect as nR,useRef as iR,useState as ra}from"react";import{jsx as st,jsxs as oa}from"react/jsx-runtime";var aR,lR,sR,$d,fI,bI=y(()=>{"use strict";f();Cd();zi();W();_r();Xn();q();qe();Va();ne();ao();Vx();uI();Ki();hI();Kd();G();Xi();aR="filter"in document.createElement("canvas").getContext("2d"),lR=()=>oa("div",{children:[st("h3",{children:b("canvasError.cannotShowPreview")}),st("p",{children:st("span",{children:b("canvasError.canvasTooBig")})}),oa("em",{children:["(",b("canvasError.canvasTooBigTip"),")"]})]}),sR=({appStateSnapshot:e,elementsSnapshot:t,files:r,actionManager:o,onExportImage:n,name:i})=>{let a=Xe(t,e),[l,s]=ra(i),[c,d]=ra(a),[m,p]=ra(e.exportBackground),[u,h]=ra(e.exportWithDarkMode),[E,x]=ra(e.exportEmbedScene),[T,v]=ra(e.exportScale),w=iR(null),[I,L]=ra(null),{exportedElements:A,exportingFrame:M}=il(t,e,c);return nR(()=>{let D=w.current;if(!D)return;let O=D.offsetWidth,R=D.offsetHeight;O&&Jp({data:{elements:A,appState:{...e,name:l,exportEmbedScene:E},files:r},config:{canvasBackgroundColor:m?e.viewBackgroundColor:!1,padding:Jo,theme:u?"dark":"light",scale:T,maxWidthOrHeight:Math.max(O,R),exportingFrame:M}}).then(B=>(L(null),jn(B).then(()=>{D.replaceChildren(B)}).catch(k=>{throw k.name==="CANVAS_POSSIBLY_TOO_BIG"?new Error(b("canvasError.canvasTooBig")):k}))).catch(B=>{console.error(B),L(B)})},[e,r,A,M,l,m,u,T,E]),oa("div",{className:"ImageExportModal",children:[st("h3",{children:b("imageExportDialog.header")}),oa("div",{className:"ImageExportModal__preview",children:[st("div",{className:"ImageExportModal__preview__canvas",ref:w,children:I&&st(lR,{})}),st("div",{className:"ImageExportModal__preview__filename",children:!Ri&&st("input",{type:"text",className:"TextInput",value:l,style:{width:"30ch"},onChange:D=>{s(D.target.value),o.executeAction(th,"ui",D.target.value)}})})]}),oa("div",{className:"ImageExportModal__settings",children:[st("h3",{children:b("imageExportDialog.header")}),a&&st($d,{label:b("imageExportDialog.label.onlySelected"),name:"exportOnlySelected",children:st(Yd,{name:"exportOnlySelected",checked:c,onChange:D=>{d(D)}})}),st($d,{label:b("imageExportDialog.label.withBackground"),name:"exportBackgroundSwitch",children:st(Yd,{name:"exportBackgroundSwitch",checked:m,onChange:D=>{p(D),o.executeAction(rh,"ui",D)}})}),aR&&st($d,{label:b("imageExportDialog.label.darkMode"),name:"exportDarkModeSwitch",children:st(Yd,{name:"exportDarkModeSwitch",checked:u,onChange:D=>{h(D),o.executeAction(uS,"ui",D)}})}),st($d,{label:b("imageExportDialog.label.embedScene"),tooltip:b("imageExportDialog.tooltip.embedScene"),name:"exportEmbedSwitch",children:st(Yd,{name:"exportEmbedSwitch",checked:E,onChange:D=>{x(D),o.executeAction(oh,"ui",D)}})}),st($d,{label:b("imageExportDialog.label.scale"),name:"exportScale",children:st(Kh,{name:"exportScale",value:T,onChange:D=>{v(D),o.executeAction(pS,"ui",D)},choices:Al.map(D=>({value:D,label:`${D}\xD7`}))})}),oa("div",{className:"ImageExportModal__settings__buttons",children:[st(In,{className:"ImageExportModal__settings__buttons__button",label:b("imageExportDialog.title.exportToPng"),onClick:()=>n(vm.png,A,{exportingFrame:M}),icon:Nu,children:b("imageExportDialog.button.exportToPng")}),st(In,{className:"ImageExportModal__settings__buttons__button",label:b("imageExportDialog.title.exportToSvg"),onClick:()=>n(vm.svg,A,{exportingFrame:M}),icon:Nu,children:b("imageExportDialog.button.exportToSvg")}),(as||Rn)&&st(In,{className:"ImageExportModal__settings__buttons__button",label:b("imageExportDialog.title.copyPngToClipboard"),onClick:()=>n(vm.clipboard,A,{exportingFrame:M}),icon:sd,children:b("imageExportDialog.button.copyPngToClipboard")})]})]})]})},$d=({label:e,children:t,tooltip:r,name:o})=>oa("div",{className:"ImageExportModal__settings__setting",title:e,children:[oa("label",{htmlFor:o,className:"ImageExportModal__settings__setting__label",children:[e,r&&st(no,{label:r,long:!0,children:eE})]}),st("div",{className:"ImageExportModal__settings__setting__content",children:t})]}),fI=({elements:e,appState:t,files:r,actionManager:o,onExportImage:n,onCloseRequest:i,name:a})=>{let[{appStateSnapshot:l,elementsSnapshot:s}]=ra(()=>({appStateSnapshot:rn(t),elementsSnapshot:rn(e)}));return st(ft,{onCloseRequest:i,size:"wide",title:!1,children:st(sR,{elementsSnapshot:s,appStateSnapshot:l,files:r,actionManager:o,onExportImage:n,name:a})})}});var EI=y(()=>{});import cR from"clsx";import{jsx as dR}from"react/jsx-runtime";var $h,Yx=y(()=>{"use strict";f();EI();$h=({children:e,side:t,className:r})=>dR("div",{className:cR("FixedSideContainer",`FixedSideContainer_side_${t}`,r),children:e})});var xI=y(()=>{});import{jsx as yI}from"react/jsx-runtime";var mR,Xh,Kx=y(()=>{"use strict";f();q();me();G();Dr();xI();mR=({appState:e,isMobile:t,device:r,app:o})=>{let{activeTool:n,isResizing:i,isRotating:a,lastPointerDownWith:l}=e,s=e.multiElement!==null;if(e.openSidebar&&!r.editor.canFitSidebar)return null;if(Pr(e))return b("hints.eraserRevert");if(n.type==="arrow"||n.type==="line")return s?b("hints.linearElementMulti"):b("hints.linearElement");if(n.type==="freedraw")return b("hints.freeDraw");if(n.type==="text")return b("hints.text");if(n.type==="embeddable")return b("hints.embeddable");if(e.activeTool.type==="image"&&e.pendingImageElementId)return b("hints.placeImage");let c=o.scene.getSelectedElements(e);if(i&&l==="mouse"&&c.length===1){let d=c[0];return ce(d)&&d.points.length===2?b("hints.lockAngle"):ho(d)?b("hints.resizeImage"):b("hints.resize")}if(a&&l==="mouse")return b("hints.rotate");if(c.length===1&&V(c[0]))return b("hints.text_selected");if(e.editingElement&&V(e.editingElement))return b("hints.text_editing");if(n.type==="selection"){if(e.draggingElement?.type==="selection"&&!c.length&&!e.editingElement&&!e.editingLinearElement)return b("hints.deepBoxSelect");if(e.gridSize&&e.draggingElement)return b("hints.disableSnapping");if(!c.length&&!t)return b("hints.canvasPanning");if(c.length===1){if(ce(c[0]))return e.editingLinearElement?e.editingLinearElement.selectedPointsIndices?b("hints.lineEditor_pointSelected"):b("hints.lineEditor_nothingSelected"):b("hints.lineEditor_info");if(!e.draggingElement&&on(c[0]))return b("hints.bindTextToElement")}}return null},Xh=({appState:e,isMobile:t,device:r,app:o})=>{let n=mR({appState:e,isMobile:t,device:r,app:o});return n?(n=N(n),yI("div",{className:"HintViewer",children:yI("span",{children:n})})):null}});import pR from"clsx";import{jsx as vI,jsxs as hR}from"react/jsx-runtime";var uR,wI,Zh,$x=y(()=>{"use strict";f();ri();ne();uR="medium",wI={CHECKED:ja,UNCHECKED:Hi},Zh=e=>hR("label",{className:pR("ToolIcon ToolIcon__lock",`ToolIcon_size_${uR}`,{"is-mobile":e.isMobile}),title:`${e.title} \u2014 Q`,children:[vI("input",{className:"ToolIcon_type_checkbox",type:"checkbox",name:e.name,onChange:e.onChange,checked:e.checked,"aria-label":e.title,"data-testid":"toolbar-lock"}),vI("div",{className:"ToolIcon__icon",children:e.checked?wI.CHECKED:wI.UNCHECKED})]})});import{Fragment as gR,jsx as TI,jsxs as fR}from"react/jsx-runtime";var na,jh=y(()=>{"use strict";f();q();we();na=({heading:e,children:t,...r})=>{let{id:o}=Zt(),n=TI("h2",{className:"visually-hidden",id:`${o}-${e}-title`,children:b(`headings.${e}`)});return TI("section",{...r,"aria-labelledby":`${o}-${e}-title`,children:typeof t=="function"?t(n):fR(gR,{children:[n,t]})})}});var $o,An,SI,CI,Xx,qh=y(()=>{"use strict";f();xe();G();q();$o=4,An=6,SI="rgba(0,0,0,0.3)",CI=(e,t,r,o)=>{if(!e.length)return{horizontal:null,vertical:null};let[n,i,a,l]=Ae(e),s=t/o.zoom.value,c=r/o.zoom.value,d=t-s,m=r-c,p={top:parseInt(rc("sat"))||0,bottom:parseInt(rc("sab"))||0,left:parseInt(rc("sal"))||0,right:parseInt(rc("sar"))||0},u=Dn().rtl,h=-o.scrollX+d/2+p.left,E=-o.scrollY+m/2+p.top,x=h+s-p.right,T=E+c-p.bottom,v=Math.min(n,h),w=Math.min(i,E),I=Math.max(a,x),L=Math.max(l,T);return{horizontal:h===v&&x===I?null:{x:Math.max(p.left,$o)+(h-v)/(I-v)*t,y:r-An-Math.max($o,p.bottom),width:(x-h)/(I-v)*t-Math.max($o*2,p.left+p.right),height:An},vertical:E===w&&T===L?null:{x:u?Math.max(p.left,$o):t-An-Math.max(p.right,$o),y:(E-w)/(L-w)*r+Math.max(p.top,$o),width:An,height:(T-E)/(L-w)*r-Math.max($o*2,p.top+p.bottom)}}},Xx=(e,t,r)=>{let[o,n]=[e.horizontal,e.vertical].map(a=>a!=null&&a.x<=t&&t<=a.x+a.width&&a.y<=r&&r<=a.y+a.height);return{isOverEither:o||n,isOverHorizontal:o,isOverVertical:n}}});import bR from"clsx";import{jsx as II,jsxs as xR}from"react/jsx-runtime";var ER,Jh,Zx=y(()=>{"use strict";f();ri();ne();ER="medium",Jh=e=>e.penDetected?xR("label",{className:bR("ToolIcon ToolIcon__penMode",`ToolIcon_size_${ER}`,{"is-mobile":e.isMobile}),title:`${e.title}`,children:[II("input",{className:"ToolIcon_type_checkbox",type:"checkbox",name:e.name,onChange:e.onChange,checked:e.checked,"aria-label":e.title}),II("div",{className:"ToolIcon__icon",children:eb})]}):null});var AI=y(()=>{});import{Fragment as kI,jsx as nt,jsxs as so}from"react/jsx-runtime";var Qh,jx=y(()=>{"use strict";f();dt();q();qe();ne();qi();AI();Qh=e=>{let t=Ae(e.elements),r=Za(e.elements,e.appState),o=Ae(r);return nt("div",{className:"Stats",children:so(ir,{padding:2,children:[nt("div",{className:"close",onClick:e.onClose,children:to}),nt("h3",{children:b("stats.title")}),nt("table",{children:so("tbody",{children:[nt("tr",{children:nt("th",{colSpan:2,children:b("stats.scene")})}),so("tr",{children:[nt("td",{children:b("stats.elements")}),nt("td",{children:e.elements.length})]}),so("tr",{children:[nt("td",{children:b("stats.width")}),nt("td",{children:Math.round(t[2])-Math.round(t[0])})]}),so("tr",{children:[nt("td",{children:b("stats.height")}),nt("td",{children:Math.round(t[3])-Math.round(t[1])})]}),r.length===1&&nt("tr",{children:nt("th",{colSpan:2,children:b("stats.element")})}),r.length>1&&so(kI,{children:[nt("tr",{children:nt("th",{colSpan:2,children:b("stats.selected")})}),so("tr",{children:[nt("td",{children:b("stats.elements")}),nt("td",{children:r.length})]})]}),r.length>0&&so(kI,{children:[so("tr",{children:[nt("td",{children:"x"}),nt("td",{children:Math.round(o[0])})]}),so("tr",{children:[nt("td",{children:"y"}),nt("td",{children:Math.round(o[1])})]}),so("tr",{children:[nt("td",{children:b("stats.width")}),nt("td",{children:Math.round(o[2]-o[0])})]}),so("tr",{children:[nt("td",{children:b("stats.height")}),nt("td",{children:Math.round(o[3]-o[1])})]})]}),r.length===1&&so("tr",{children:[nt("td",{children:b("stats.angle")}),nt("td",{children:`${Math.round(r[0].angle*180/Math.PI)}\xB0`})]}),e.renderCustomStats?.(e.elements,e.appState)]})})]})})}});import yR from"clsx";import{jsx as wR}from"react/jsx-runtime";var eg,qx=y(()=>{"use strict";f();ri();Dt();ne();be();eg=e=>wR(pe,{className:yR("Shape",{fillable:!1}),type:"radio",icon:ld,name:"editor-current-shape",checked:e.checked,title:`${e.title} \u2014 H`,keyBindingLabel:e.isMobile?void 0:C.H.toLocaleUpperCase(),"aria-label":`${e.title} \u2014 H`,"aria-keyshortcuts":C.H,"data-testid":"toolbar-hand",onChange:()=>e.onChange?.()})});var MI=y(()=>{});import{jsx as Jx}from"react/jsx-runtime";var LI,PI=y(()=>{"use strict";f();q();G();ne();MI();LI=({onHomeButtonClick:e})=>Jx("label",{title:`${Qo(b("toolBar.library"))} \u2014 0`,children:Jx("div",{className:"library-button",onClick:e,children:Jx("div",{children:U1})})})});import{Fragment as vR,jsx as Rt,jsxs as ia}from"react/jsx-runtime";var DI,_I=y(()=>{"use strict";f();q();ul();xe();Yx();qi();Kx();qe();Gd();jh();qh();$x();Zx();jx();ko();qx();Dr();lo();PI();DI=({appState:e,elements:t,actionManager:r,setAppState:o,onLockToggle:n,onHandToolToggle:i,onPenModeToggle:a,renderTopRightUI:l,renderCustomStats:s,renderSidebars:c,device:d,renderWelcomeScreen:m,UIOptions:p,app:u,onHomeButtonClick:h})=>{let{WelcomeScreenCenterTunnel:E,MainMenuTunnel:x,DefaultSidebarTriggerTunnel:T}=lt(),v=()=>ia($h,{side:"top",className:"App-top-bar",children:[m&&Rt(E.Out,{}),Rt(na,{heading:"shapes",children:I=>Rt(qt.Col,{gap:4,align:"center",children:ia(qt.Row,{gap:1,className:"App-toolbar-container",children:[ia(ir,{padding:1,className:"App-toolbar App-toolbar--mobile",children:[I,Rt(qt.Row,{gap:1,children:Rt(Uh,{appState:e,activeTool:e.activeTool,UIOptions:p,app:u})})]}),l&&l(!0,e),ia("div",{className:"mobile-misc-tools-container",children:[!e.viewModeEnabled&&Rt(T.Out,{}),Rt(Jh,{checked:e.penMode,onChange:()=>a(null),title:b("toolBar.penMode"),isMobile:!0,penDetected:e.penDetected}),Rt(Zh,{checked:e.activeTool.locked,onChange:n,title:b("toolBar.lock"),isMobile:!0}),Rt(eg,{checked:Go(e),onChange:()=>i(),title:b("toolBar.hand"),isMobile:!0})]}),Rt("div",{className:"mobile-misc-tools-container-left",children:Rt(LI,{onHomeButtonClick:h})})]})})}),Rt(Xh,{appState:e,isMobile:!0,device:d,app:u})]}),w=()=>e.viewModeEnabled?Rt("div",{className:"App-toolbar-content",children:Rt(x.Out,{})}):ia("div",{className:"App-toolbar-content",children:[Rt(x.Out,{}),r.renderAction("toggleEditMenu"),r.renderAction("undo"),r.renderAction("redo"),r.renderAction(e.multiElement?"finalize":"duplicateSelection"),r.renderAction("deleteSelectedElements")]});return ia(vR,{children:[c(),!e.viewModeEnabled&&v(),!e.openMenu&&e.showStats&&Rt(Qh,{appState:e,setAppState:o,elements:t,onClose:()=>{r.executeAction(ii)},renderCustomStats:s}),Rt("div",{className:"App-bottom-bar",style:{marginBottom:An+$o*2,marginLeft:An+$o*2,marginRight:An+$o*2},children:ia(ir,{padding:0,children:[e.openMenu==="shape"&&!e.viewModeEnabled&&$a(e,t)?Rt(na,{className:"App-mobile-menu",heading:"selectedShapeActions",children:Rt(Hh,{appState:e,elementsMap:u.scene.getNonDeletedElementsMap(),renderAction:r.renderAction})}):null,ia("footer",{className:"App-toolbar",children:[w(),e.scrolledOutside&&!e.openMenu&&!e.openSidebar&&Rt("button",{className:"scroll-back-to-content",onClick:()=>{o(I=>({...gn(t,I)}))},children:b("buttons.scrollBackToContent")})]})]})})]})}});var RI=y(()=>{});import TR,{useLayoutEffect as SR,useRef as CR,useState as IR}from"react";import{jsx as Xd,jsxs as AR}from"react/jsx-runtime";var NI,OI,BI=y(()=>{"use strict";f();Nr();u1();W();q();ts();we();ao();RI();NI=e=>{let t=CR(null),[r,o]=IR(null);return SR(()=>{if(!e.spreadsheet)return;let n=Uv(e.chartType,e.spreadsheet,0,0);o(n);let i,a=t.current;return(async()=>(i=await es({data:{elements:n,appState:{exportBackground:!1,viewBackgroundColor:Gt},files:null}}),i.querySelector(".style-fonts")?.remove(),a.replaceChildren(),a.appendChild(i),e.selected&&a.parentNode.focus()))(),()=>{a.replaceChildren()}},[e.spreadsheet,e.chartType,e.selected]),Xd("button",{className:"ChartPreview",onClick:()=>{r&&e.onClick(e.chartType,r)},children:Xd("div",{ref:t})})},OI=({setAppState:e,appState:t,onClose:r})=>{let{onInsertElements:o}=Or(),n=TR.useCallback(()=>{r&&r()},[r]),i=(a,l)=>{o(l),ve("paste","chart",a),e({currentChartType:a,pasteDialog:{shown:!1,data:null}})};return Xd(ft,{size:"small",onCloseRequest:n,title:b("labels.pasteCharts"),className:"PasteChartDialog",autofocus:!1,children:AR("div",{className:"container",children:[Xd(NI,{chartType:"bar",spreadsheet:t.pasteDialog.data,selected:t.currentChartType==="bar",onClick:i}),Xd(NI,{chartType:"line",spreadsheet:t.pasteDialog.data,selected:t.currentChartType==="line",onClick:i})]})})}});var FI=y(()=>{});import kR from"react";import{Fragment as HI,jsx as K,jsxs as co}from"react/jsx-runtime";function*PR(e,t){let r=!0;for(let o of e)r||(yield t),r=!1,yield o}var MR,LR,Qx,DR,J,_R,zI,UI=y(()=>{"use strict";f();q();be();ao();G();FI();ne();zi();W();hl();MR=()=>co("div",{className:"HelpDialog__header",children:[co("a",{className:"HelpDialog__btn",href:"https://docs.excalidraw.com",target:"_blank",rel:"noopener noreferrer",children:[K("div",{className:"HelpDialog__link-icon",children:bu}),b("helpDialog.documentation")]}),co("a",{className:"HelpDialog__btn",href:"https://blog.excalidraw.com",target:"_blank",rel:"noopener noreferrer",children:[K("div",{className:"HelpDialog__link-icon",children:bu}),b("helpDialog.blog")]}),co("a",{className:"HelpDialog__btn",href:"https://github.com/excalidraw/excalidraw/issues",target:"_blank",rel:"noopener noreferrer",children:[K("div",{className:"HelpDialog__link-icon",children:od}),b("helpDialog.github")]}),co("a",{className:"HelpDialog__btn",href:"https://youtube.com/@excalidraw",target:"_blank",rel:"noopener noreferrer",children:[K("div",{className:"HelpDialog__link-icon",children:yE}),"YouTube"]})]}),LR=e=>co(HI,{children:[K("h3",{children:e.title}),K("div",{className:"HelpDialog__islands-container",children:e.children})]}),Qx=e=>co("div",{className:`HelpDialog__island ${e.className}`,children:[K("h4",{className:"HelpDialog__island-title",children:e.caption}),K("div",{className:"HelpDialog__island-content",children:e.children})]});DR=e=>e.replace(/\b[a-z]\b/,t=>t.toUpperCase()),J=({label:e,shortcuts:t,isOr:r=!0})=>{let o=t.map(n=>(n.endsWith("++")?[...n.slice(0,-2).split("+"),"+"]:n.split("+")).map(a=>K(_R,{children:DR(a)},a)));return co("div",{className:"HelpDialog__shortcut",children:[K("div",{children:e}),K("div",{className:"HelpDialog__key-container",children:[...PR(o,r?b("helpDialog.or"):null)]})]})},_R=e=>K("kbd",{className:"HelpDialog__key",...e}),zI=({onClose:e})=>{let t=kR.useCallback(()=>{e&&e()},[e]);return K(HI,{children:co(ft,{onCloseRequest:t,title:b("helpDialog.title"),className:"HelpDialog",children:[K(MR,{}),co(LR,{title:b("helpDialog.shortcuts"),children:[co(Qx,{className:"HelpDialog__island--tools",caption:b("helpDialog.tools"),children:[K(J,{label:b("toolBar.hand"),shortcuts:[C.H]}),K(J,{label:b("toolBar.selection"),shortcuts:[C.V,C[1]]}),K(J,{label:b("toolBar.rectangle"),shortcuts:[C.R,C[2]]}),K(J,{label:b("toolBar.diamond"),shortcuts:[C.D,C[3]]}),K(J,{label:b("toolBar.ellipse"),shortcuts:[C.O,C[4]]}),K(J,{label:b("toolBar.arrow"),shortcuts:[C.A,C[5]]}),K(J,{label:b("toolBar.line"),shortcuts:[C.L,C[6]]}),K(J,{label:b("toolBar.freedraw"),shortcuts:[C.P,C[7]]}),K(J,{label:b("toolBar.text"),shortcuts:[C.T,C[8]]}),K(J,{label:b("toolBar.image"),shortcuts:[C[9]]}),K(J,{label:b("toolBar.eraser"),shortcuts:[C.E,C[0]]}),K(J,{label:b("toolBar.frame"),shortcuts:[C.F]}),K(J,{label:b("toolBar.laser"),shortcuts:[C.K]}),K(J,{label:b("labels.eyeDropper"),shortcuts:[C.I,"Shift+S","Shift+G"]}),K(J,{label:b("helpDialog.editLineArrowPoints"),shortcuts:[N("CtrlOrCmd+Enter")]}),K(J,{label:b("helpDialog.editText"),shortcuts:[N("Enter")]}),K(J,{label:b("helpDialog.textNewLine"),shortcuts:[N("Enter"),N("Shift+Enter")]}),K(J,{label:b("helpDialog.textFinish"),shortcuts:[N("Esc"),N("CtrlOrCmd+Enter")]}),K(J,{label:b("helpDialog.curvedArrow"),shortcuts:["A",b("helpDialog.click"),b("helpDialog.click"),b("helpDialog.click")],isOr:!1}),K(J,{label:b("helpDialog.curvedLine"),shortcuts:["L",b("helpDialog.click"),b("helpDialog.click"),b("helpDialog.click")],isOr:!1}),K(J,{label:b("toolBar.lock"),shortcuts:[C.Q]}),K(J,{label:b("helpDialog.preventBinding"),shortcuts:[N("CtrlOrCmd")]}),K(J,{label:b("toolBar.link"),shortcuts:[N("CtrlOrCmd+K")]})]}),co(Qx,{className:"HelpDialog__island--view",caption:b("helpDialog.view"),children:[K(J,{label:b("buttons.zoomIn"),shortcuts:[N("CtrlOrCmd++")]}),K(J,{label:b("buttons.zoomOut"),shortcuts:[N("CtrlOrCmd+-")]}),K(J,{label:b("buttons.resetZoom"),shortcuts:[N("CtrlOrCmd+0")]}),K(J,{label:b("helpDialog.zoomToFit"),shortcuts:["Shift+1"]}),K(J,{label:b("helpDialog.zoomToSelection"),shortcuts:["Shift+2"]}),K(J,{label:b("helpDialog.movePageUpDown"),shortcuts:["PgUp/PgDn"]}),K(J,{label:b("helpDialog.movePageLeftRight"),shortcuts:["Shift+PgUp/PgDn"]}),K(J,{label:b("buttons.zenMode"),shortcuts:[N("Alt+Z")]}),K(J,{label:b("buttons.objectsSnapMode"),shortcuts:[N("Alt+S")]}),K(J,{label:b("labels.toggleGrid"),shortcuts:[N("CtrlOrCmd+'")]}),K(J,{label:b("labels.viewMode"),shortcuts:[N("Alt+R")]}),K(J,{label:b("labels.toggleTheme"),shortcuts:[N("Alt+Shift+D")]}),K(J,{label:b("stats.title"),shortcuts:[N("Alt+/")]}),K(J,{label:b("commandPalette.title"),shortcuts:Rn?[_t("commandPalette")]:[_t("commandPalette"),_t("commandPalette",1)]})]}),co(Qx,{className:"HelpDialog__island--editor",caption:b("helpDialog.editor"),children:[K(J,{label:b("labels.moveCanvas"),shortcuts:[N(`Space+${b("helpDialog.drag")}`),N(`Wheel+${b("helpDialog.drag")}`)],isOr:!0}),K(J,{label:b("buttons.clearReset"),shortcuts:[N("CtrlOrCmd+Delete")]}),K(J,{label:b("labels.delete"),shortcuts:[N("Delete")]}),K(J,{label:b("labels.cut"),shortcuts:[N("CtrlOrCmd+X")]}),K(J,{label:b("labels.copy"),shortcuts:[N("CtrlOrCmd+C")]}),K(J,{label:b("labels.paste"),shortcuts:[N("CtrlOrCmd+V")]}),K(J,{label:b("labels.pasteAsPlaintext"),shortcuts:[N("CtrlOrCmd+Shift+V")]}),K(J,{label:b("labels.selectAll"),shortcuts:[N("CtrlOrCmd+A")]}),K(J,{label:b("labels.multiSelect"),shortcuts:[N(`Shift+${b("helpDialog.click")}`)]}),K(J,{label:b("helpDialog.deepSelect"),shortcuts:[N(`CtrlOrCmd+${b("helpDialog.click")}`)]}),K(J,{label:b("helpDialog.deepBoxSelect"),shortcuts:[N(`CtrlOrCmd+${b("helpDialog.drag")}`)]}),(as||Rn)&&K(J,{label:b("labels.copyAsPng"),shortcuts:[N("Shift+Alt+C")]}),K(J,{label:b("labels.copyStyles"),shortcuts:[N("CtrlOrCmd+Alt+C")]}),K(J,{label:b("labels.pasteStyles"),shortcuts:[N("CtrlOrCmd+Alt+V")]}),K(J,{label:b("labels.sendToBack"),shortcuts:[ur?N("CtrlOrCmd+Alt+["):N("CtrlOrCmd+Shift+[")]}),K(J,{label:b("labels.bringToFront"),shortcuts:[ur?N("CtrlOrCmd+Alt+]"):N("CtrlOrCmd+Shift+]")]}),K(J,{label:b("labels.sendBackward"),shortcuts:[N("CtrlOrCmd+[")]}),K(J,{label:b("labels.bringForward"),shortcuts:[N("CtrlOrCmd+]")]}),K(J,{label:b("labels.alignTop"),shortcuts:[N("CtrlOrCmd+Shift+Up")]}),K(J,{label:b("labels.alignBottom"),shortcuts:[N("CtrlOrCmd+Shift+Down")]}),K(J,{label:b("labels.alignLeft"),shortcuts:[N("CtrlOrCmd+Shift+Left")]}),K(J,{label:b("labels.alignRight"),shortcuts:[N("CtrlOrCmd+Shift+Right")]}),K(J,{label:b("labels.duplicateSelection"),shortcuts:[N("CtrlOrCmd+D"),N(`Alt+${b("helpDialog.drag")}`)]}),K(J,{label:b("helpDialog.toggleElementLock"),shortcuts:[N("CtrlOrCmd+Shift+L")]}),K(J,{label:b("buttons.undo"),shortcuts:[N("CtrlOrCmd+Z")]}),K(J,{label:b("buttons.redo"),shortcuts:fm?[N("CtrlOrCmd+Y"),N("CtrlOrCmd+Shift+Z")]:[N("CtrlOrCmd+Shift+Z")]}),K(J,{label:b("labels.group"),shortcuts:[N("CtrlOrCmd+G")]}),K(J,{label:b("labels.ungroup"),shortcuts:[N("CtrlOrCmd+Shift+G")]}),K(J,{label:b("labels.flipHorizontal"),shortcuts:[N("Shift+H")]}),K(J,{label:b("labels.flipVertical"),shortcuts:[N("Shift+V")]}),K(J,{label:b("labels.showStroke"),shortcuts:[N("S")]}),K(J,{label:b("labels.showBackground"),shortcuts:[N("G")]}),K(J,{label:b("labels.decreaseFontSize"),shortcuts:[N("CtrlOrCmd+Shift+<")]}),K(J,{label:b("labels.increaseFontSize"),shortcuts:[N("CtrlOrCmd+Shift+>")]})]})]})]})})}});var GI=y(()=>{});import Zd,{useLayoutEffect as RR}from"react";import VI from"clsx";import*as Hs from"@radix-ui/react-popover";import{jsx as li,jsxs as zs}from"react/jsx-runtime";var NR,OR,BR,e0,FR,tg,t0=y(()=>{"use strict";f();GI();Ki();we();qi();ne();q();G();W();NR=4,OR=8,BR=({shouldWrap:e,children:t,username:r})=>e?li(no,{label:r||"Unknown user",children:t}):li(Zd.Fragment,{children:t}),e0=({actionManager:e,collaborator:t,socketId:r,withName:o=!1,shouldWrapWithTooltip:n=!1,isBeingFollowed:i})=>{let a={socketId:r,collaborator:t,withName:o,isBeingFollowed:i},l=e.renderAction("goToCollaborator",a);return li(BR,{username:t.username,shouldWrap:n,children:l},r)},FR=["avatarUrl","id","socketId","username","isInCall","isSpeaking","isMuted"],tg=Zd.memo(({className:e,mobile:t,collaborators:r,userToFollow:o})=>{let n=Ut(),i=new Map;r.forEach((x,T)=>{let v=x.id||T;i.set(v,{...x,socketId:T})});let a=Array.from(i.values()).filter(x=>x.username?.trim()),[l,s]=Zd.useState(""),c=Zd.useRef(null);RR(()=>{if(c.current){let x=v=>{let w=Math.max(1,Math.min(8,Math.floor(v/38)));m(w)};if(x(c.current.clientWidth),!Zs)return;let T=new ResizeObserver(v=>{for(let w of v){let{width:I}=w.contentRect;x(I)}});return T.observe(c.current),()=>{T.disconnect()}}},[]);let[d,m]=Zd.useState(NR),u=l.trim().toLowerCase()?a.filter(x=>x.username?.toLowerCase().includes(l)):a,E=a.slice(0,d-1).map(x=>e0({actionManager:n,collaborator:x,socketId:x.socketId,shouldWrapWithTooltip:!0,isBeingFollowed:x.socketId===o}));return t?li("div",{className:VI("UserList UserList_mobile",e),children:a.map(x=>e0({actionManager:n,collaborator:x,socketId:x.socketId,shouldWrapWithTooltip:!0,isBeingFollowed:x.socketId===o}))}):li("div",{className:"UserList-wrapper",ref:c,children:zs("div",{className:VI("UserList",e),style:{"--max-avatars":d},children:[E,a.length>d-1&&zs(Hs.Root,{onOpenChange:x=>{x||s("")},children:[zs(Hs.Trigger,{className:"UserList__more",children:["+",a.length-d+1]}),li(Hs.Content,{style:{zIndex:2,width:"15rem",textAlign:"left"},align:"end",sideOffset:10,children:zs(ir,{style:{overflow:"hidden"},children:[a.length>=OR&&zs("div",{className:"UserList__search-wrapper",children:[pd,li("input",{className:"UserList__search",type:"text",placeholder:b("userList.search.placeholder"),value:l,onChange:x=>{s(x.target.value)}})]}),zs("div",{className:"dropdown-menu UserList__collaborators",children:[u.length===0&&li("div",{className:"UserList__collaborators__empty",children:b("userList.search.empty")}),li("div",{className:"UserList__hint",children:b("userList.hint.text")}),u.map(x=>e0({actionManager:n,collaborator:x,socketId:x.socketId,withName:!0,isBeingFollowed:x.socketId===o}))]})]})})]})]})})},(e,t)=>{if(e.collaborators.size!==t.collaborators.size||e.mobile!==t.mobile||e.className!==t.className||e.userToFollow!==t.userToFollow)return!1;let r=t.collaborators.keys();for(let[o,n]of e.collaborators){let i=t.collaborators.get(o);if(!i||o!==r.next().value||!rt(n,i,FR))return!1}return!0})});var WI=y(()=>{});import r0 from"open-color";import{jsx as zR}from"react/jsx-runtime";var o0,YI=y(()=>{"use strict";f();WI();o0=({children:e,color:t})=>zR("div",{className:"Card",style:{"--card-color":t==="primary"?"var(--color-primary)":r0[t][7],"--card-color-darker":t==="primary"?"var(--color-primary-darker)":r0[t][8],"--card-color-darkest":t==="primary"?"var(--color-primary-darkest)":r0[t][9]},children:e})});var KI=y(()=>{});import HR from"react";import{Fragment as GR,jsx as Xo,jsxs as rg}from"react/jsx-runtime";var UR,$I,XI=y(()=>{"use strict";f();q();ao();ne();Dt();Cd();YI();KI();Xn();Nr();G();UR=({elements:e,appState:t,setAppState:r,files:o,actionManager:n,exportOpts:i,canvas:a,onCloseRequest:l})=>{let{onExportToBackend:s}=i;return Xo("div",{className:"ExportDialog ExportDialog--json",children:rg("div",{className:"ExportDialog-cards",children:[i.saveFileToDisk&&rg(o0,{color:"lime",children:[Xo("div",{className:"Card-icon",children:ub}),Xo("h2",{children:b("exportDialog.disk_title")}),rg("div",{className:"Card-details",children:[b("exportDialog.disk_details"),!Ri&&n.renderAction("changeProjectName")]}),Xo(pe,{className:"Card-button",type:"button",title:b("exportDialog.disk_button"),"aria-label":b("exportDialog.disk_button"),showAriaLabel:!0,onClick:()=>{n.executeAction(Ts,"ui")}})]}),s&&rg(o0,{color:"pink",children:[Xo("div",{className:"Card-icon",children:gs}),Xo("h2",{children:b("exportDialog.link_title")}),Xo("div",{className:"Card-details",children:b("exportDialog.link_details")}),Xo(pe,{className:"Card-button",type:"button",title:b("exportDialog.link_button"),"aria-label":b("exportDialog.link_button"),showAriaLabel:!0,onClick:async()=>{try{ve("export","link",`ui (${lw()})`),await s(e,t,o),l()}catch(c){r({errorMessage:c.message})}}})]}),i.renderCustomUI&&i.renderCustomUI(e,t,o,a)]})})},$I=({elements:e,appState:t,files:r,actionManager:o,exportOpts:n,canvas:i,setAppState:a})=>{let l=HR.useCallback(()=>{a({openDialog:null})},[a]);return Xo(GR,{children:t.openDialog?.name==="jsonExport"&&Xo(ft,{onCloseRequest:l,title:b("buttons.export"),children:Xo(UR,{elements:e,appState:t,setAppState:a,files:r,actionManager:o,onCloseRequest:l,exportOpts:n,canvas:i})})})}});import{jsx as VR}from"react/jsx-runtime";var ZI,jI=y(()=>{"use strict";f();q();ne();ZI=e=>VR("button",{className:"help-icon",onClick:e.onClick,type:"button",title:`${b("helpDialog.title")} \u2014 ?`,"aria-label":b("helpDialog.title"),children:Ja})});import og from"clsx";import{jsx as kn,jsxs as n0}from"react/jsx-runtime";var qI,JI,QI=y(()=>{"use strict";f();ko();Gd();we();lo();jI();jh();ul();qI=({appState:e,actionManager:t,showExitZenModeBtn:r,renderWelcomeScreen:o})=>{let{FooterCenterTunnel:n,WelcomeScreenHelpHintTunnel:i}=lt(),a=_e(),l=!e.viewModeEnabled&&e.multiElement&&a.isTouchScreen;return n0("footer",{role:"contentinfo",className:"layer-ui__wrapper__footer App-menu App-menu_bottom",children:[kn("div",{className:og("layer-ui__wrapper__footer-left zen-mode-transition",{"layer-ui__wrapper__footer-left--transition-left":e.zenModeEnabled}),children:kn(qt.Col,{gap:2,children:n0(na,{heading:"canvasActions",children:[kn(OC,{renderAction:t.renderAction,zoom:e.zoom}),!e.viewModeEnabled&&kn(BC,{renderAction:t.renderAction,className:og("zen-mode-transition",{"layer-ui__wrapper__footer-left--transition-bottom":e.zenModeEnabled})}),l&&kn(zC,{renderAction:t.renderAction,className:og("zen-mode-transition",{"layer-ui__wrapper__footer-left--transition-left":e.zenModeEnabled})})]})})}),kn(n.Out,{}),kn("div",{className:og("layer-ui__wrapper__footer-right zen-mode-transition",{"transition-right":e.zenModeEnabled}),children:n0("div",{style:{position:"relative"},children:[o&&kn(i.Out,{}),kn(ZI,{onClick:()=>t.executeAction(Zi)})]})}),kn(FC,{actionManager:t,showExitZenModeBtn:r})]})},JI=qI;qI.displayName="Footer"});import WR from"react";var ng,i0=y(()=>{"use strict";f();ng=WR.createContext({})});import YR from"clsx";import{useContext as KR}from"react";import{jsx as a0,jsxs as e6}from"react/jsx-runtime";var l0,t6=y(()=>{"use strict";f();q();we();i0();ne();Ki();Os();l0=({children:e,className:t})=>{let r=_e(),o=KR(ng),n=!!(r.editor.canFitSidebar&&o.shouldRenderDockButton);return e6("div",{className:YR("sidebar__header",t),"data-testid":"sidebar-header",children:[e,e6("div",{className:"sidebar__header__buttons",children:[n&&a0(no,{label:b("labels.sidebarLock"),children:a0(Tn,{onSelect:()=>o.onDock?.(!o.docked),selected:!!o.docked,className:"sidebar__dock","data-testid":"sidebar-dock","aria-label":b("labels.sidebarLock"),children:W1})}),a0(Tn,{"data-testid":"sidebar-close",className:"sidebar__close",onSelect:o.onCloseRequest,"aria-label":b("buttons.close"),children:to})]})]})};l0.displayName="SidebarHeader"});var r6=y(()=>{});import $R from"clsx";import{jsx as s0,jsxs as o6}from"react/jsx-runtime";var c0,n6=y(()=>{"use strict";f();we();jt();r6();c0=({name:e,tab:t,icon:r,title:o,children:n,onToggle:i,className:a,style:l})=>{let s=He(),c=Be();return o6("label",{title:o,className:"sidebar-trigger__label-element",children:[s0("input",{className:"ToolIcon_type_checkbox",type:"checkbox",onChange:d=>{document.querySelector(".layer-ui__wrapper")?.classList.remove("animate");let m=d.target.checked;s({openSidebar:m?{name:e,tab:t}:null}),i?.(m)},checked:c.openSidebar?.name===e,"aria-label":o,"aria-keyshortcuts":"0"}),o6("div",{className:$R("sidebar-trigger",a),style:l,children:[r&&s0("div",{children:r}),n&&s0("div",{className:"sidebar-trigger__label",children:n})]})]})};c0.displayName="SidebarTrigger"});import*as i6 from"@radix-ui/react-tabs";import{jsx as XR}from"react/jsx-runtime";var d0,a6=y(()=>{"use strict";f();d0=({children:e,...t})=>XR(i6.List,{className:"sidebar-triggers",...t,children:e});d0.displayName="SidebarTabTriggers"});import*as s6 from"@radix-ui/react-tabs";import{jsx as l6}from"react/jsx-runtime";var m0,c6=y(()=>{"use strict";f();m0=({children:e,tab:t,onSelect:r,...o})=>l6(s6.Trigger,{value:t,asChild:!0,onSelect:r,children:l6("button",{type:"button",className:"excalidraw-button sidebar-tab-trigger",...o,children:e})});m0.displayName="SidebarTabTrigger"});import*as d6 from"@radix-ui/react-tabs";import{jsx as ZR}from"react/jsx-runtime";var p0,m6=y(()=>{"use strict";f();jt();we();p0=({children:e,...t})=>{let r=Be(),o=He();if(!r.openSidebar)return null;let{name:n}=r.openSidebar;return ZR(d6.Root,{className:"sidebar-tabs-root",value:r.openSidebar.tab,onValueChange:i=>o(a=>({...a,openSidebar:{...a.openSidebar,name:n,tab:i}})),...t,children:e})};p0.displayName="SidebarTabs"});import*as p6 from"@radix-ui/react-tabs";import{jsx as jR}from"react/jsx-runtime";var u0,u6=y(()=>{"use strict";f();u0=({tab:e,children:t,...r})=>jR(p6.Content,{...r,value:e,"data-testid":e,children:t});u0.displayName="SidebarTab"});var h6=y(()=>{});import{useEffect as b6,useLayoutEffect as E6,useRef as h0,useState as qR,forwardRef as x6,useImperativeHandle as JR,useCallback as g6}from"react";import{atom as QR,useSetAtom as e9}from"jotai";import t9 from"clsx";import{jsx as f6}from"react/jsx-runtime";import{createElement as r9}from"react";var jd,y6,si,qd=y(()=>{"use strict";f();qi();kt();i0();t6();we();G();be();W();n6();a6();c6();m6();u6();jt();$u();h6();jd=QR(!1),y6=x6(({name:e,children:t,onDock:r,docked:o,className:n,...i},a)=>{S.DEV&&r&&o==null&&console.warn("Sidebar: `docked` must be set when `onDock` is supplied for the sidebar to be user-dockable. To hide this message, either pass `docked` or remove `onDock`");let l=He(),s=e9(jd,Ge);E6(()=>(s(!!o),()=>{s(!1)}),[s,o]);let c=h0({});c.current.onCloseRequest=()=>{l({openSidebar:null})},c.current.onDock=u=>r?.(u),c.current=Ll(c.current,{docked:o,shouldRenderDockButton:!!r&&o!=null});let d=h0(null);JR(a,()=>d.current);let m=_e(),p=g6(()=>{document.querySelector(".Dialog")||l({openSidebar:null})},[l]);return ys(d,g6(u=>{u.target.closest(".sidebar-trigger")||(!o||!m.editor.canFitSidebar)&&p()},[p,o,m.editor.canFitSidebar])),b6(()=>{let u=h=>{h.key===C.ESCAPE&&(!o||!m.editor.canFitSidebar)&&p()};return document.addEventListener("keydown",u),()=>{document.removeEventListener("keydown",u)}},[p,o,m.editor.canFitSidebar]),f6(ir,{...i,className:t9("sidebar",{"sidebar--docked":o},n),ref:d,children:f6(ng.Provider,{value:c.current,children:t})})});y6.displayName="SidebarInner";si=Object.assign(x6((e,t)=>{let r=Be(),{onStateChange:o}=e,n=h0(r.openSidebar);b6(()=>{(!r.openSidebar&&n?.current?.name===e.name||r.openSidebar?.name===e.name&&n?.current?.name!==e.name||n.current?.name===e.name)&&r.openSidebar!==n.current&&o?.(r.openSidebar?.name!==e.name?null:r.openSidebar),n.current=r.openSidebar},[r.openSidebar,o,e.name]);let[i,a]=qR(!1);return E6(()=>(a(!0),()=>a(!1)),[]),i&&r.openSidebar?.name===e.name?r9(y6,{...e,ref:t,key:e.name}):null}),{Header:l0,TabTriggers:d0,TabTrigger:m0,Tabs:p0,Tab:u0,Trigger:c0});si.displayName="Sidebar"});import{atom as o9}from"jotai";async function w6({title:e,description:t,actionLabel:r,color:o}){return new Promise(n=>{Qt.set(g0,{active:!0,onConfirm:()=>n(!0),onClose:()=>n(!1),onReject:()=>n(!1),title:e,description:t,actionLabel:r,color:o})})}var g0,f0=y(()=>{"use strict";f();kt();g0=o9({active:!1})});import{Fragment as n9,jsx as b0,jsxs as v6}from"react/jsx-runtime";var T6,S6,C6=y(()=>{"use strict";f();we();Vx();T6=({value:e,shortcut:t,onChange:r,choices:o,children:n,name:i})=>{let a=_e();return v6(n9,{children:[v6("div",{className:"dropdown-menu-item-base dropdown-menu-item-bare",children:[b0("label",{className:"dropdown-menu-item__text",htmlFor:i,children:n}),b0(Kh,{name:i,value:e,onChange:r,choices:o})]}),t&&!a.editor.isMobile&&b0("div",{className:"dropdown-menu-item__shortcut dropdown-menu-item__shortcut--orphaned",children:t})]})};T6.displayName="DropdownMenuItemContentRadio";S6=T6});var I6=y(()=>{});var E0={};Xs(E0,{ChangeCanvasBackground:()=>R6,ClearCanvas:()=>D6,CommandPalette:()=>L6,Export:()=>N6,Help:()=>P6,LiveCollaborationTrigger:()=>B6,LoadScene:()=>A6,SaveAsImage:()=>M6,SaveToActiveFile:()=>k6,Socials:()=>O6,ToggleTheme:()=>_6});import i9 from"clsx";import{useSetAtom as a9}from"jotai";import{Fragment as l9,jsx as Jt,jsxs as F6}from"react/jsx-runtime";var A6,k6,M6,L6,P6,D6,_6,R6,N6,O6,B6,z6=y(()=>{"use strict";f();hl();q();we();ne();ne();gx();fx();ko();Vd();kt();jt();f0();Ls();C6();W();Nr();I6();A6=()=>{let{t:e}=Mt(),t=Ut(),r=Wi();return t.isActionEnabled(sl)?Jt(Ao,{icon:Qa,onSelect:async()=>{(!r.length||await w6({title:e("overwriteConfirm.modal.loadFromFile.title"),actionLabel:e("overwriteConfirm.modal.loadFromFile.button"),color:"warning",description:Jt(wr,{i18nKey:"overwriteConfirm.modal.loadFromFile.description",bold:n=>Jt("strong",{children:n}),br:()=>Jt("br",{})})}))&&t.executeAction(sl)},"data-testid":"load-button",shortcut:_t("loadScene"),"aria-label":e("buttons.load"),children:e("buttons.load")}):null};A6.displayName="LoadScene";k6=()=>{let{t:e}=Mt(),t=Ut();return t.isActionEnabled(Sd)?Jt(Ao,{shortcut:_t("saveScene"),"data-testid":"save-button",onSelect:()=>t.executeAction(Sd),icon:db,"aria-label":`${e("buttons.save")}`,children:`${e("buttons.save")}`}):null};k6.displayName="SaveToActiveFile";M6=()=>{let e=He(),{t}=Mt();return Jt(Ao,{icon:id,"data-testid":"image-export-button",onSelect:()=>e({openDialog:{name:"imageExport"}}),shortcut:_t("imageExport"),"aria-label":t("buttons.exportImage"),children:t("buttons.exportImage")})};M6.displayName="SaveAsImage";L6=e=>{let t=He(),{t:r}=Mt();return Jt(Ao,{icon:ud,"data-testid":"command-palette-button",onSelect:()=>{ve("command_palette","open","menu"),t({openDialog:{name:"commandPalette"}})},shortcut:_t("commandPalette"),"aria-label":r("commandPalette.title"),className:e?.className,children:r("commandPalette.title")})};L6.displayName="CommandPalette";P6=()=>{let{t:e}=Mt(),t=Ut();return Jt(Ao,{"data-testid":"help-menu-item",icon:Ja,onSelect:()=>t.executeAction(Zi),shortcut:"?","aria-label":e("helpDialog.title"),children:e("helpDialog.title")})};P6.displayName="Help";D6=()=>{let{t:e}=Mt(),t=a9(gl,Ge);return Ut().isActionEnabled(wn)?Jt(Ao,{icon:To,onSelect:()=>t("clearCanvas"),"data-testid":"clear-canvas-button","aria-label":e("buttons.clearReset"),children:e("buttons.clearReset")}):null};D6.displayName="ClearCanvas";_6=e=>{let{t}=Mt(),r=Be(),o=Ut(),n=_t("toggleTheme");return o.isActionEnabled($i)?e?.allowSystemTheme?Jt(S6,{name:"theme",value:e.theme,onChange:i=>e.onSelect(i),choices:[{value:se.LIGHT,label:hs,ariaLabel:`${t("buttons.lightMode")} - ${n}`},{value:se.DARK,label:us,ariaLabel:`${t("buttons.darkMode")} - ${n}`},{value:"system",label:xE,ariaLabel:t("buttons.systemMode")}],children:t("labels.theme")}):Jt(Ao,{onSelect:i=>{if(i.preventDefault(),e?.onSelect)e.onSelect(r.theme===se.DARK?se.LIGHT:se.DARK);else return o.executeAction($i)},icon:r.theme===se.DARK?hs:us,"data-testid":"toggle-dark-mode",shortcut:n,"aria-label":r.theme===se.DARK?t("buttons.lightMode"):t("buttons.darkMode"),children:r.theme===se.DARK?t("buttons.lightMode"):t("buttons.darkMode")}):null};_6.displayName="ToggleTheme";R6=()=>{let{t:e}=Mt(),t=Be(),r=Ut(),o=ji();return t.viewModeEnabled||!o.UIOptions.canvasActions.changeViewBackgroundColor?null:F6("div",{style:{marginTop:"0.5rem"},children:[Jt("div",{"data-testid":"canvas-background-label",style:{fontSize:".75rem",marginBottom:".5rem"},children:e("labels.canvasBackground")}),Jt("div",{style:{padding:"0 0.625rem"},children:r.renderAction("changeViewBackgroundColor")})]})};R6.displayName="ChangeCanvasBackground";N6=()=>{let{t:e}=Mt(),t=He();return Jt(Ao,{icon:Ui,onSelect:()=>{t({openDialog:{name:"jsonExport"}})},"data-testid":"json-export-button","aria-label":e("buttons.export"),children:e("buttons.export")})};N6.displayName="Export";O6=()=>{let{t:e}=Mt();return F6(l9,{children:[Jt(_s,{icon:od,href:"https://github.com/excalidraw/excalidraw","aria-label":"GitHub",children:"GitHub"}),Jt(_s,{icon:sb,href:"https://x.com/excalidraw","aria-label":"X",children:e("labels.followUs")}),Jt(_s,{icon:lb,href:"https://discord.gg/UexuTaE","aria-label":"Discord",children:e("labels.discordChat")})]})};O6.displayName="Socials";B6=({onSelect:e,isCollaborating:t})=>{let{t:r}=Mt();return Jt(Ao,{"data-testid":"collab-button",icon:ad,className:i9({"active-collab":t}),onSelect:e,children:r("labels.liveCollaboration")})};B6.displayName="LiveCollaborationTrigger"});import{atom as s9,useAtom as c9}from"jotai";import{useLayoutEffect as d9,useRef as m9}from"react";import{jsx as p9}from"react/jsx-runtime";var ci,Jd=y(()=>{"use strict";f();lo();ci=(e,t)=>{let r=s9(0),o=n=>{let{jotaiScope:i}=lt(),[,a]=c9(r,i),l=m9({preferHost:!1,counter:0});return d9(()=>{let s=l.current;return a(c=>{let d=c+1;return s.counter=d,d}),()=>{a(c=>{let d=c-1;return s.counter=d,d||(s.preferHost=!1),d})}},[a]),n.__fallback||(l.current.preferHost=!0),!l.current.counter&&n.__fallback&&l.current.preferHost||l.current.counter>1&&n.__fallback?null:p9(t,{...n})};return o.displayName=e,o}});import{jsx as ig,jsxs as x0}from"react/jsx-runtime";var u9,Sr,y0=y(()=>{"use strict";f();we();zd();z6();t0();q();ne();Jd();G();lo();jt();u9=Object.assign(ci("MainMenu",({children:e,onSelect:t})=>{let{MainMenuTunnel:r}=lt(),o=_e(),n=Be(),i=He(),a=o.editor.isMobile?void 0:()=>i({openMenu:null});return ig(r.In,{children:x0(Ve,{open:n.openMenu==="canvas",children:[ig(Ve.Trigger,{onToggle:()=>{i({openMenu:n.openMenu==="canvas"?null:"canvas"})},"data-testid":"main-menu-trigger",className:"main-menu-trigger",children:rd}),x0(Ve.Content,{onClickOutside:a,onSelect:xi(t,()=>{i({openMenu:null})}),children:[e,o.editor.isMobile&&n.collaborators.size>0&&x0("fieldset",{className:"UserList-Wrapper",children:[ig("legend",{children:b("labels.collaborators")}),ig(tg,{mobile:!0,collaborators:n.collaborators,userToFollow:n.userToFollow?.socketId||null})]})]})]})})}),{Trigger:Ve.Trigger,Item:Ve.Item,ItemLink:Ve.ItemLink,ItemCustom:Ve.ItemCustom,Group:Ve.Group,Separator:Ve.Separator,DefaultItems:E0}),Sr=u9});import{jsx as Us,jsxs as f9}from"react/jsx-runtime";var ag,h9,g9,w0,H6=y(()=>{"use strict";f();Kd();we();ko();q();Cd();ag=({title:e,children:t,actionLabel:r,onClick:o})=>f9("div",{className:"OverwriteConfirm__Actions__Action",children:[Us("h4",{children:e}),Us("div",{className:"OverwriteConfirm__Actions__Action__content",children:t}),Us(In,{variant:"outlined",color:"muted",label:r,size:"large",fullWidth:!0,onClick:o})]}),h9=()=>{let{t:e}=Mt(),t=Ut(),r=He();return Us(ag,{title:e("overwriteConfirm.action.exportToImage.title"),actionLabel:e("overwriteConfirm.action.exportToImage.button"),onClick:()=>{t.executeAction(oh,"ui",!0),r({openDialog:{name:"imageExport"}})},children:e("overwriteConfirm.action.exportToImage.description")})},g9=()=>{let{t:e}=Mt(),t=Ut();return Us(ag,{title:e("overwriteConfirm.action.saveToDisk.title"),actionLabel:e("overwriteConfirm.action.saveToDisk.button"),onClick:()=>{t.executeAction(Ts,"ui")},children:e("overwriteConfirm.action.saveToDisk.description")})},w0=Object.assign(({children:e})=>Us("div",{className:"OverwriteConfirm__Actions",children:e}),{ExportToImage:h9,SaveToDisk:g9})});var U6=y(()=>{});import{useAtom as b9}from"jotai";import{jsx as aa,jsxs as G6}from"react/jsx-runtime";var lg,V6=y(()=>{"use strict";f();lo();kt();ao();Jd();f0();Kd();ne();H6();U6();lg=Object.assign(ci("OverwriteConfirmDialog",({children:e})=>{let{OverwriteConfirmDialogTunnel:t}=lt(),[r,o]=b9(g0,Ge);if(!r.active)return null;let n=()=>{r.onClose(),o(a=>({...a,active:!1}))},i=()=>{r.onConfirm(),o(a=>({...a,active:!1}))};return aa(t.In,{children:aa(ft,{onCloseRequest:n,title:!1,size:916,children:G6("div",{className:"OverwriteConfirm",children:[aa("h3",{children:r.title}),G6("div",{className:`OverwriteConfirm__Description OverwriteConfirm__Description--color-${r.color}`,children:[aa("div",{className:"OverwriteConfirm__Description__icon",children:tE}),aa("div",{children:r.description}),aa("div",{className:"OverwriteConfirm__Description__spacer"}),aa(In,{color:r.color,size:"large",label:r.actionLabel,onClick:i})]}),aa(w0,{children:e})]})})})}),{Actions:w0,Action:ag})});import E9 from"clsx";import{jsx as la,jsxs as W6}from"react/jsx-runtime";import{createElement as x9}from"react";var Y6,K6,sg,v0=y(()=>{"use strict";f();W();lo();jt();q();G();we();Jd();Bd();qd();Y6=ci("DefaultSidebarTrigger",e=>{let{DefaultSidebarTriggerTunnel:t}=lt();return la(t.In,{children:la(si.Trigger,{...e,className:"default-sidebar-trigger",name:Vr.name})})});Y6.displayName="DefaultSidebarTrigger";K6=({children:e,...t})=>{let{DefaultSidebarTabTriggersTunnel:r}=lt();return la(r.In,{children:la(si.TabTriggers,{...t,children:e})})};K6.displayName="DefaultTabTriggers";sg=Object.assign(ci("DefaultSidebar",({children:e,className:t,onDock:r,docked:o,...n})=>{let i=Be(),a=He(),{DefaultSidebarTabTriggersTunnel:l}=lt();return x9(si,{...n,name:"default",key:"default",className:E9("default-sidebar",t),docked:o??i.defaultSidebarDockedPreference,onDock:r===!1||!r&&o!=null?void 0:xi(r,s=>{a({defaultSidebarDockedPreference:s})})},W6(si.Tabs,{children:[W6(si.Header,{children:[n.__fallback&&la("div",{style:{color:"var(--color-primary)",fontSize:"1.2em",fontWeight:"bold",textOverflow:"ellipsis",overflow:"hidden",whiteSpace:"nowrap",paddingRight:"1em"},children:b("toolBar.library")}),la(l.Out,{})]}),la(si.Tab,{tab:tc,children:la(kC,{})}),e]}))}),{Trigger:Y6,TabTriggers:K6})});var $6=y(()=>{});var X6=y(()=>{});import y9 from"clsx";import{jsx as Z6,jsxs as v9}from"react/jsx-runtime";var w9,j6,q6=y(()=>{"use strict";f();ri();ne();w9="small",j6=e=>v9("label",{className:y9("ToolIcon ToolIcon__LaserPointer",`ToolIcon_size_${w9}`,{"is-mobile":e.isMobile}),title:`${e.title}`,children:[Z6("input",{className:"ToolIcon_type_checkbox",type:"checkbox",name:e.name,onChange:e.onChange,checked:e.checked,"aria-label":e.title,"data-testid":"toolbar-LaserPointer"}),Z6("div",{className:"ToolIcon__icon",children:md})]})});import{jsx as T9}from"react/jsx-runtime";var Gs,J6=y(()=>{"use strict";f();Gs=e=>T9("p",{className:"excalidraw__paragraph",style:e.style,children:e.children})});var Q6=y(()=>{});import*as t4 from"@radix-ui/react-tabs";import{useRef as e4}from"react";import{jsx as S9}from"react/jsx-runtime";var r4,cg,T0=y(()=>{"use strict";f();we();G();r4=e=>{let t=He(),r=e4(null),o=e4(0);return S9(t4.Root,{ref:r,className:"ttd-dialog-tabs-root",value:e.tab,onValueChange:n=>{if(!n)return;let i=r.current?.closest(".Modal__content");if(i){let a=i.offsetHeight||0;a>o.current&&(o.current=a,i.style.minHeight=`min(${o.current}px, 100%)`)}e.dialog==="settings"&&nc(["text-to-diagram","diagram-to-code"],n)?t({openDialog:{name:e.dialog,tab:n,source:"settings"}}):e.dialog==="ttd"&&nc(["text-to-diagram","mermaid"],n)&&t({openDialog:{name:e.dialog,tab:n}})},children:e.children})};r4.displayName="TTDDialogTabs";cg=r4});import*as o4 from"@radix-ui/react-tabs";import{jsx as C9}from"react/jsx-runtime";var Vs,S0=y(()=>{"use strict";f();Vs=({tab:e,children:t,...r})=>C9(o4.Content,{...r,value:e,children:t});Vs.displayName="TTDDialogTab"});import{useState as n4}from"react";import{jsx as Ur,jsxs as Qd}from"react/jsx-runtime";var i4,a4=y(()=>{"use strict";f();ao();Ix();ne();Kd();eh();be();jt();Fh();J6();Q6();T0();S0();i4=e=>{let[t,r]=n4(e.openAIKey||""),[o,n]=n4(e.isPersisted),i=Be(),a=()=>{e.onConfirm(t.trim(),o)};return i.openDialog?.name!=="settings"?null:Ur(ft,{onCloseRequest:()=>{e.onClose(),e.onConfirm(t.trim(),o)},title:Qd("div",{style:{display:"flex"},children:["Wireframe to Code (AI)"," ",Ur("div",{style:{display:"flex",alignItems:"center",justifyContent:"center",padding:"0.1rem 0.5rem",marginLeft:"1rem",fontSize:14,borderRadius:"12px",color:"#000",background:"pink"},children:"Experimental"})]}),className:"MagicSettings",autofocus:!1,children:Ur(cg,{dialog:"settings",tab:i.openDialog.tab,children:Qd(Vs,{tab:"diagram-to-code",children:[Qd(Gs,{children:["For the diagram-to-code feature we use"," ",Ur(ea,{icon:fs}),"OpenAI."]}),Qd(Gs,{children:["While the OpenAI API is in beta, its use is strictly limited \u2014 as such we require you use your own API key. You can create an"," ",Ur("a",{href:"https://platform.openai.com/login?launch",rel:"noopener noreferrer",target:"_blank",children:"OpenAI account"}),", add a small credit (5 USD minimum), and"," ",Ur("a",{href:"https://platform.openai.com/api-keys",rel:"noopener noreferrer",target:"_blank",children:"generate your own API key"}),"."]}),Ur(Gs,{children:"Your OpenAI key does not leave the browser, and you can also set your own limit in your OpenAI account dashboard if needed."}),Ur(Bh,{isRedacted:!0,value:t,placeholder:"Paste your API key here",label:"OpenAI API key",onChange:l=>{r(l),e.onChange(l.trim(),o)},selectOnRender:!0,onKeyDown:l=>l.key===C.ENTER&&a()}),Ur(Gs,{children:"By default, your API token is not persisted anywhere so you'll need to insert it again after reload. But, you can persist locally in your browser below."}),Ur(ll,{checked:o,onChange:n,children:"Persist API key in browser storage"}),Qd(Gs,{children:["Once API key is set, you can use the ",Ur(ea,{icon:tl})," ","tool to wrap your elements in a frame that will then allow you to turn it into code. This dialog can be accessed using the"," ",Ur("b",{children:"AI Settings"})," ",Ur(ea,{icon:fs}),"."]}),Ur(In,{className:"MagicSettings__confirm",size:"large",label:"Confirm",onClick:a})]})})})}});var l4=y(()=>{});var I9,dg,em,mg,C0=y(()=>{"use strict";f();W();h1();_r();Fd();q();I9=({canvasRef:e,setError:t})=>{let r=e.current;if(!r)return;let o=r.parentElement;o&&(o.style.background="",t(null),r.replaceChildren())},dg=async({canvasRef:e,mermaidToExcalidrawLib:t,mermaidDefinition:r,setError:o,data:n})=>{let i=e.current,a=i?.parentElement;if(!(!i||!a)){if(!r){I9({canvasRef:e,setError:o});return}try{let l=await t.api,s;try{s=await l.parseMermaidToExcalidraw(r,{fontSize:Ot})}catch{s=await l.parseMermaidToExcalidraw(r.replace(/"/g,"'"),{fontSize:Ot})}let{elements:c,files:d}=s;o(null),n.current={elements:tm(c,{regenerateIds:!0}),files:d};let m=await Bi({data:{elements:n.current.elements,files:n.current.files},config:{padding:Jo,maxWidthOrHeight:Math.max(a.offsetWidth,a.offsetHeight)*window.devicePixelRatio}});try{await jn(m)}catch(p){throw p.name==="CANVAS_POSSIBLY_TOO_BIG"?new Error(b("canvasError.canvasTooBig")):p}a.style.background="var(--default-bg-color)",i.replaceChildren(m)}catch(l){throw a.style.background="var(--default-bg-color)",r&&o(l),l}}},em=e=>{Fr.set(po.MERMAID_TO_EXCALIDRAW,e)},mg=({app:e,data:t,text:r,shouldSaveMermaidDataToStorage:o})=>{let{elements:n,files:i}=t.current;n.length&&(e.addElementsFromPasteOrLibrary({elements:n,files:i,position:"center",fitToContent:!0}),e.setOpenDialog(null),o&&r&&em(r))}});import{jsx as A9}from"react/jsx-runtime";var pg,I0=y(()=>{"use strict";f();pg=({children:e})=>A9("div",{className:"ttd-dialog-panels",children:e})});import s4 from"clsx";import{jsx as A0,jsxs as rm}from"react/jsx-runtime";var Ws,k0=y(()=>{"use strict";f();Os();_n();Ws=({label:e,children:t,panelAction:r,panelActionDisabled:o=!1,onTextSubmitInProgess:n,renderTopRight:i,renderSubmitShortcut:a,renderBottomRight:l})=>rm("div",{className:"ttd-dialog-panel",children:[rm("div",{className:"ttd-dialog-panel__header",children:[A0("label",{children:e}),i?.()]}),t,rm("div",{className:s4("ttd-dialog-panel-button-container",{invisible:!r}),style:{display:"flex",alignItems:"center"},children:[rm(Tn,{className:"ttd-dialog-panel-button",onSelect:r?r.action:()=>{},disabled:o||n,children:[rm("div",{className:s4({invisible:n}),children:[r?.label,r?.icon&&A0("span",{children:r.icon})]}),n&&A0(er,{})]}),!o&&!n&&a?.(),l?.()]})]})});import{useEffect as k9,useRef as c4}from"react";import{jsx as M9}from"react/jsx-runtime";var ug,M0=y(()=>{"use strict";f();W();be();ug=({input:e,placeholder:t,onChange:r,onKeyboardSubmit:o})=>{let n=c4(null),i=c4(o);return i.current=o,k9(()=>{if(!i.current)return;let a=n.current;if(a){let l=s=>{s[C.CTRL_OR_CMD]&&s.key===C.ENTER&&(s.preventDefault(),i.current?.())};return a.addEventListener("keydown",l),()=>{a.removeEventListener("keydown",l)}}},[]),M9("textarea",{className:"ttd-dialog-input",onChange:r,value:e,placeholder:t,autoFocus:!0,ref:n})}});import{jsx as hg,jsxs as d4}from"react/jsx-runtime";var L9,gg,L0=y(()=>{"use strict";f();_n();L9=({error:e})=>d4("div",{"data-testid":"ttd-dialog-output-error",className:"ttd-dialog-output-error",children:["Error! ",hg("p",{children:e})]}),gg=({error:e,canvasRef:t,loaded:r})=>d4("div",{className:"ttd-dialog-output-wrapper",children:[e&&hg(L9,{error:e.message}),r?hg("div",{ref:t,style:{opacity:e?"0.15":1},className:"ttd-dialog-output-canvas-container"}):hg(er,{size:"2rem"})]})});import{jsx as m4,jsxs as P9}from"react/jsx-runtime";var fg,P0=y(()=>{"use strict";f();G();fg=()=>P9("div",{className:"ttd-dialog-submit-shortcut",children:[m4("div",{className:"ttd-dialog-submit-shortcut__key",children:N("CtrlOrCmd")}),m4("div",{className:"ttd-dialog-submit-shortcut__key",children:N("Enter")})]})});import{useState as p4,useRef as u4,useEffect as h4,useDeferredValue as D9}from"react";import{Fragment as N9,jsx as Mn,jsxs as f4}from"react/jsx-runtime";var _9,g4,R9,b4,E4=y(()=>{"use strict";f();we();ne();l4();q();Ls();C0();I0();k0();M0();L0();Fd();W();G();P0();_9=`flowchart TD
72
72
  A[Christmas] -->|Get money| B(Go shopping)
73
73
  B --> C{Let me think}
74
74
  C -->|One| D[Laptop]
75
75
  C -->|Two| E[iPhone]
76
- C -->|Three| F[Car]`,hS=ca(Fd,300),SR=({mermaidToExcalidrawLib:e})=>{let[t,o]=pS(()=>Mo.get(or.MERMAID_TO_EXCALIDRAW)||IR),r=CR(t.trim()),[n,i]=pS(null),a=uS(null),l=uS({elements:[],files:null}),s=ko();gS(()=>{Og({canvasRef:a,data:l,mermaidToExcalidrawLib:e,setError:i,mermaidDefinition:r}).catch(d=>{Iy()&&console.error("Failed to parse mermaid definition",d)}),hS(r)},[r,e]),gS(()=>()=>{hS.flush()},[]);let c=()=>{Bg({app:s,data:l,text:t,shouldSaveMermaidDataToStorage:!0})};return fS(kR,{children:[En("div",{className:"ttd-dialog-desc",children:En(uo,{i18nKey:"mermaid.description",flowchartLink:d=>En("a",{href:"https://mermaid.js.org/syntax/flowchart.html",children:d}),sequenceLink:d=>En("a",{href:"https://mermaid.js.org/syntax/sequenceDiagram.html",children:d}),classLink:d=>En("a",{href:"https://mermaid.js.org/syntax/classDiagram.html",children:d})})}),fS(Fg,{children:[En(Ps,{label:b("mermaid.syntax"),children:En(Hg,{input:t,placeholder:"Write Mermaid diagram defintion here...",onChange:d=>o(d.target.value),onKeyboardSubmit:()=>{c()}})}),En(Ps,{label:b("mermaid.preview"),panelAction:{action:()=>{c()},label:b("mermaid.button"),icon:Ua},renderSubmitShortcut:()=>En(Ug,{}),children:En(Gg,{canvasRef:a,loaded:e.loaded,error:n})})]})]})},bS=SR});import*as ES from"@radix-ui/react-tabs";import{jsx as AR}from"react/jsx-runtime";var JE,yS=v(()=>{"use strict";f();JE=({children:e,...t})=>AR(ES.List,{className:"ttd-dialog-triggers",...t,children:e});JE.displayName="TTDDialogTabTriggers"});import*as vS from"@radix-ui/react-tabs";import{jsx as wS}from"react/jsx-runtime";var Wg,TS=v(()=>{"use strict";f();Wg=({children:e,tab:t,onSelect:o,...r})=>wS(vS.Trigger,{value:t,asChild:!0,onSelect:o,children:wS("button",{type:"button",className:"ttd-dialog-tab-trigger",...r,children:e})});Wg.displayName="TTDDialogTabTrigger"});var CS=v(()=>{});import{useEffect as MR,useRef as QE,useState as Vg}from"react";import{atom as SS,useAtom as IS}from"jotai";import{jsx as bo,jsxs as qi}from"react/jsx-runtime";var e0,Ds,LR,_R,t0,PR,o0=v(()=>{"use strict";f();jo();ye();xS();WE();Vt();Od();yS();TS();VE();X();ZE();jE();XE();KE();YE();ee();CS();G();So();dg();qE();e0=3,Ds=1e3,LR=SS(null),_R=SS(null),t0=e=>{let t=Re();return t.openDialog?.name!=="ttd"?null:bo(PR,{...e,tab:t.openDialog.tab})},PR=ri("TTDDialogBase",({tab:e,...t})=>{let o=ko(),r=Be(),n=QE(null),[i,a]=IS(_R),[l,s]=Vg(i?.prompt??""),c=l.trim(),d=k=>{s(k.target.value),a(R=>({generatedResponse:R?.generatedResponse??null,prompt:k.target.value}))},[m,p]=Vg(!1),[u,g]=IS(LR),x=async()=>{if(c.length>Ds||c.length<e0||m||u?.rateLimitRemaining===0||"__fallback"in t){c.length<e0&&M(new Error(`Prompt is too short (min ${e0} characters)`)),c.length>Ds&&M(new Error(`Prompt is too long (max ${Ds} characters)`));return}try{p(!0),we("ai","generate","ttd");let{generatedResponse:k,error:R,rateLimit:P,rateLimitRemaining:F}=await t.onTextSubmit(c);if(typeof k=="string"&&a(D=>({generatedResponse:k,prompt:D?.prompt??null})),Th(P)&&Th(F)&&g({rateLimit:P,rateLimitRemaining:F}),R){M(R);return}if(!k){M(new Error("Generation failed"));return}try{await Og({canvasRef:n,data:w,mermaidToExcalidrawLib:y,setError:M,mermaidDefinition:k}),we("ai","mermaid parse success","ttd")}catch(D){console.info(`%cTTD mermaid render errror: ${D.message}`,"color: red"),console.info(`>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>
77
- TTD mermaid definition render errror: ${D.message}`,"color: yellow"),we("ai","mermaid parse failed","ttd"),M(new Error("Generated an invalid diagram :(. You may also try a different prompt."))}}catch(k){let R=k.message;(!R||R==="Failed to fetch")&&(R="Request failed"),M(new Error(R))}finally{p(!1)}},E=QE(x);E.current=x;let[y,T]=Vg({loaded:!1,api:import("@excalidraw/mermaid-to-excalidraw")});MR(()=>{(async()=>{await y.api,T(R=>({...R,loaded:!0}))})()},[y.api]);let w=QE({elements:[],files:null}),[S,M]=Vg(null);return bo(gt,{className:"ttd-dialog",onCloseRequest:()=>{o.setOpenDialog(null)},size:1200,title:!1,...t,autofocus:!1,children:qi(Ng,{dialog:"ttd",tab:e,children:["__fallback"in t&&t.__fallback?bo("p",{className:"dialog-mermaid-title",children:b("mermaid.title")}):qi(JE,{children:[bo(Wg,{tab:"text-to-diagram",children:qi("div",{style:{display:"flex",alignItems:"center"},children:[b("labels.textToDiagram"),bo("div",{style:{display:"flex",alignItems:"center",justifyContent:"center",padding:"1px 6px",marginLeft:"10px",fontSize:10,borderRadius:"12px",background:"pink",color:"#000"},children:"AI Beta"})]})}),bo(Wg,{tab:"mermaid",children:"Mermaid"})]}),bo(_s,{className:"ttd-dialog-content",tab:"mermaid",children:bo(bS,{mermaidToExcalidrawLib:y})}),!("__fallback"in t)&&qi(_s,{className:"ttd-dialog-content",tab:"text-to-diagram",children:[bo("div",{className:"ttd-dialog-desc",children:"Currently we use Mermaid as a middle step, so you'll get best results if you describe a diagram, workflow, flow chart, and similar."}),qi(Fg,{children:[bo(Ps,{label:b("labels.prompt"),panelAction:{action:x,label:"Generate",icon:Ua},onTextSubmitInProgess:m,panelActionDisabled:c.length>Ds||u?.rateLimitRemaining===0,renderTopRight:()=>u?qi("div",{className:"ttd-dialog-rate-limit",style:{fontSize:12,marginLeft:"auto",color:u.rateLimitRemaining===0?"var(--color-danger)":void 0},children:[u.rateLimitRemaining," requests left today"]}):null,renderSubmitShortcut:()=>bo(Ug,{}),renderBottomRight:()=>{if(typeof i?.generatedResponse=="string")return qi("div",{className:"excalidraw-link",style:{marginLeft:"auto",fontSize:14},onClick:()=>{typeof i?.generatedResponse=="string"&&(Fd(i.generatedResponse),r({openDialog:{name:"ttd",tab:"mermaid"}}))},children:["View as Mermaid",bo(Wi,{icon:Ua})]});let k=c.length/Ds;return k>.8?qi("div",{style:{marginLeft:"auto",fontSize:12,fontFamily:"monospace",color:k>1?"var(--color-danger)":void 0},children:["Length: ",c.length,"/",Ds]}):null},children:bo(Hg,{onChange:d,input:l,placeholder:"Describe what you want to see...",onKeyboardSubmit:()=>{E.current()}})}),bo(Ps,{label:"Preview",panelAction:{action:()=>{console.info("Panel action clicked"),Bg({app:o,data:w})},label:"Insert",icon:Ua},children:bo(Gg,{canvasRef:n,error:S,loaded:y.loaded})})]})]})]})})})});import Gd from"clsx";import DR from"react";import{Provider as RR,useAtom as NR,useAtomValue as OR}from"jotai";import{Fragment as AS,jsx as le,jsxs as er}from"react/jsx-runtime";var BR,FR,HR,kS,zR,MS,LS=v(()=>{"use strict";f();U();he();X();We();G();Sd();s6();b6();mE();pE();zi();xh();uE();D6();B6();vg();G6();tl();wE();X6();hE();So();ye();fE();px();Q6();Nd();Tt();zE();kd();WI();bE();Fo();qo();ee();Vt();UE();td();$I();XI();Ze();Mr();_n();qI();aS();o0();BR=({UIOptions:e})=>er(fo,{__fallback:!0,children:[le(fo.DefaultItems.LoadScene,{}),le(fo.DefaultItems.SaveToActiveFile,{}),e.canvasActions.export&&le(fo.DefaultItems.Export,{}),e.canvasActions.saveAsImage&&le(fo.DefaultItems.SaveAsImage,{}),le(fo.DefaultItems.Help,{}),le(fo.DefaultItems.ClearCanvas,{}),le(fo.Separator,{}),le(fo.Group,{title:"Excalidraw links",children:le(fo.DefaultItems.Socials,{})}),le(fo.Separator,{}),le(fo.DefaultItems.ToggleTheme,{}),le(fo.DefaultItems.ChangeCanvasBackground,{})]}),FR=()=>er(Dg,{__fallback:!0,children:[le(Dg.Actions.SaveToDisk,{}),le(Dg.Actions.ExportToImage,{})]}),HR=({actionManager:e,appState:t,files:o,setAppState:r,elements:n,canvas:i,onLockToggle:a,onHandToolToggle:l,onPenModeToggle:s,showExitZenModeBtn:c,renderTopRightUI:d,renderCustomStats:m,UIOptions:p,onExportImage:u,renderWelcomeScreen:g,onHomeButtonClick:x,children:E,app:y,isCollaborating:T,openAIKey:w,isOpenAIKeyPersisted:S,onOpenAIAPIKeyChange:M,onMagicSettingsConfirm:k,uiDisabled:R})=>{let P=_e(),F=NC(),[D,L]=NR(Pi,He),A=()=>p.canvasActions.export?le($6,{elements:n,appState:t,files:o,actionManager:e,exportOpts:p.canvasActions.export,canvas:i,setAppState:r}):null,B=()=>!p.canvasActions.saveAsImage||t.openDialog?.name!=="imageExport"?null:le(f6,{elements:n,appState:t,files:o,actionManager:e,onExportImage:u,onCloseRequest:()=>r({openDialog:null}),name:y.getName()}),j=()=>er("div",{style:{position:"relative"},children:[le(F.MainMenuTunnel.Out,{}),g&&le(F.WelcomeScreenMenuHintTunnel.Out,{})]}),Y=()=>le($i,{heading:"selectedShapeActions",className:Gd("selected-shape-actions zen-mode-transition",{"transition-left":t.zenModeEnabled}),children:le(oo,{className:tm.SHAPE_ACTIONS_MENU,padding:2,style:{maxHeight:`${t.height-166}px`},children:le(pg,{appState:t,elementsMap:y.scene.getNonDeletedElementsMap(),renderAction:e.renderAction})})}),oe=()=>{let ge=Na(t,n);return le(Eg,{side:"top",children:er("div",{className:"App-menu App-menu_top",children:[er(Yt.Col,{gap:6,className:Gd("App-menu_top__left"),children:[j(),ge&&Y()]}),!t.viewModeEnabled&&le($i,{heading:"shapes",className:"shapes-section",children:xe=>er("div",{style:{position:"relative"},children:[g&&le(F.WelcomeScreenToolbarHintTunnel.Out,{}),le(Yt.Col,{gap:4,align:"start",children:er(Yt.Row,{gap:1,className:Gd("App-toolbar-container",{"zen-mode":t.zenModeEnabled}),children:[er(oo,{padding:1,className:Gd("App-toolbar",{"zen-mode":t.zenModeEnabled}),children:[le(yg,{appState:t,isMobile:P.editor.isMobile,device:P,app:y}),xe,er(Yt.Row,{gap:1,children:[le(Cg,{zenModeEnabled:t.zenModeEnabled,checked:t.penMode,onChange:()=>s(null),title:b("toolBar.penMode"),penDetected:t.penDetected}),le(wg,{checked:t.activeTool.locked,onChange:a,title:b("toolBar.lock")}),le("div",{className:"App-toolbar__divider"}),le(Sg,{checked:Rr(t),onChange:()=>l(),title:b("toolBar.hand"),isMobile:!0}),le(ug,{appState:t,activeTool:t.activeTool,UIOptions:p,app:y})]})]}),T&&le(oo,{style:{marginLeft:8,alignSelf:"center",height:"fit-content"},children:le(jI,{title:b("toolBar.laser"),checked:t.activeTool.type===wt.laser,onChange:()=>y.setActiveTool({type:wt.laser}),isMobile:!0})})]})})]})}),er("div",{className:Gd("layer-ui__wrapper__top-right zen-mode-transition",{"transition-right":t.zenModeEnabled}),children:[t.collaborators.size>0&&le(kg,{collaborators:t.collaborators,userToFollow:t.userToFollow?.socketId||null}),d?.(P.editor.isMobile,t),!t.viewModeEnabled&&(!Te||t.openSidebar?.name!==Do.name)&&le(F.DefaultSidebarTriggerTunnel.Out,{})]})]})})},Ce=()=>le(Rg,{__fallback:!0,onDock:ge=>{we("sidebar",`toggleDock (${ge?"dock":"undock"})`,`(${P.editor.isMobile?"mobile":"desktop"})`)}}),Te=OR(Rd,He);if(R)return null;let K=er(AS,{children:[E,le(BR,{UIOptions:p}),le(Rg.Trigger,{__fallback:!0,icon:Hc,title:$r(b("toolBar.library")),onToggle:ge=>{ge&&we("sidebar",`${Do.name} (open)`,`button (${P.editor.isMobile?"mobile":"desktop"})`)},tab:Do.defaultTab,children:b("toolBar.library")}),le(FR,{}),t.openDialog?.name==="ttd"&&le(t0,{__fallback:!0}),t.isLoading&&le(um,{delay:250}),t.errorMessage&&le(l6,{onClose:()=>r({errorMessage:null}),children:t.errorMessage}),D&&!P.editor.isMobile&&le(E3,{colorPickerType:D.colorPickerType,onCancel:()=>{L(null)},onChange:(ge,xe,Ne,{altKey:Le})=>{if(!(ge!=="elementBackground"&&ge!=="elementStroke"))if(Ne.length){for(let $t of Ne)z($t,{[Le&&D.swapPreviewOnAlt?ge==="elementBackground"?"strokeColor":"backgroundColor":ge==="elementBackground"?"backgroundColor":"strokeColor"]:xe},!1),Me.delete($t);lt.getScene(Ne[0])?.informMutation()}else r(ge==="elementBackground"?{currentItemBackgroundColor:xe}:{currentItemStrokeColor:xe})},onSelect:(ge,xe)=>{L(Ne=>Ne?.keepOpenOnAlt&&xe.altKey?Ne:null),D?.onSelect?.(ge,xe)}}),t.openDialog?.name==="help"&&le(H6,{onClose:()=>{r({openDialog:null})}}),t.openDialog?.name==="settings"&&le(iS,{openAIKey:w,isPersisted:S,onChange:M,onConfirm:(ge,xe)=>{let Ne=t.openDialog?.name==="settings"?t.openDialog?.source:"settings";r({openDialog:null},()=>{k(ge,xe,Ne)})},onClose:()=>{r({openDialog:null})}}),le(GC,{}),le(F.OverwriteConfirmDialogTunnel.Out,{}),B(),A(),t.pasteDialog.shown&&le(O6,{setAppState:r,appState:t,onClose:()=>r({pasteDialog:{shown:!1,data:null}})}),P.editor.isMobile&&le(P6,{app:y,onHomeButtonClick:x,appState:t,elements:n,actionManager:e,renderJSONExportDialog:A,renderImageExportDialog:B,setAppState:r,onLockToggle:a,onHandToolToggle:l,onPenModeToggle:s,renderTopRightUI:d,renderCustomStats:m,renderSidebars:Ce,device:P,renderWelcomeScreen:g,UIOptions:p}),!P.editor.isMobile&&er(AS,{children:[er("div",{className:"layer-ui__wrapper",style:t.openSidebar&&Te&&P.editor.canFitSidebar?{width:`calc(100% - ${iy}px)`}:{},children:[g&&le(F.WelcomeScreenCenterTunnel.Out,{}),oe(),le(J6,{appState:t,actionManager:e,showExitZenModeBtn:c,renderWelcomeScreen:g}),t.showStats&&le(Ig,{appState:t,setAppState:r,elements:n,onClose:()=>{e.executeAction(Qn)},renderCustomStats:m}),t.scrolledOutside&&le("button",{className:"scroll-back-to-content",onClick:()=>{r(ge=>({...nn(n,ge)}))},children:b("buttons.scrollBackToContent")})]}),Ce()]})]});return le(qb.Provider,{value:t,children:le(RR,{scope:F.jotaiScope,children:le(jx.Provider,{value:F,children:K})})})},kS=e=>{let{suggestedBindings:t,startBoundElement:o,cursorButton:r,scrollX:n,scrollY:i,...a}=e;return a},zR=(e,t)=>{if(e.children!==t.children)return!1;let{canvas:o,appState:r,...n}=e,{canvas:i,appState:a,...l}=t;return It(kS(r),kS(a),{selectedElementIds:It,selectedGroupIds:It})&&It(n,l)},MS=DR.memo(HR,zR)});var _S=v(()=>{});import{useCallback as GR,useEffect as UR,useRef as WR}from"react";import{jsx as PS,jsxs as YR}from"react/jsx-runtime";var VR,DS,RS=v(()=>{"use strict";f();ee();_S();Mt();VR=5e3,DS=({message:e,onClose:t,closable:o=!1,duration:r=VR,style:n})=>{let i=WR(0),a=r!==1/0,l=GR(()=>{a&&(i.current=window.setTimeout(()=>t(),r))},[t,r,a]);return UR(()=>{if(a)return l(),()=>clearTimeout(i.current)},[l,e,r,a]),YR("div",{className:"Toast",onMouseEnter:a?()=>clearTimeout(i?.current):void 0,onMouseLeave:a?l:void 0,style:n,children:[PS("p",{className:"Toast__message",children:e}),o&&PS(ce,{icon:Yo,"aria-label":"close",type:"icon",onClick:t,className:"close"})]})}});var r0,NS=v(()=>{"use strict";f();ee();ue();je();r0=H({name:"viewMode",label:"labels.viewMode",paletteName:"Toggle view mode",icon:Va,viewMode:!0,trackEvent:{category:"canvas",predicate:e=>!e.viewModeEnabled},perform(e,t){return{appState:{...t,viewModeEnabled:!this.checked(t)},commitToHistory:!1}},checked:e=>e.viewModeEnabled,predicate:(e,t,o)=>typeof o.viewModeEnabled>"u",keyTest:e=>!e[I.CTRL_OR_CMD]&&e.altKey&&e.code===fe.R})});var Yg,OS=v(()=>{"use strict";f();he();Ze();pt();se();G();Mr();Yg=class e{scene;onSceneUpdated;constructor({scene:t,onSceneUpdated:o}){this.scene=t,this.onSceneUpdated=o}static loadedFontFaces=new Set;onFontsLoaded=t=>{if(t.every(r=>{let n=`${r.family}-${r.style}-${r.weight}`;return e.loadedFontFaces.has(n)?!0:(e.loadedFontFaces.add(n),!1)}))return!1;let o=!1;this.scene.mapElements(r=>W(r)&&!ze(r)?(Me.delete(r),o=!0,ae(r,{...Nl(r,ut(r,this.scene.getNonDeletedElementsMap()),this.scene.getNonDeletedElementsMap())})):r),o&&this.onSceneUpdated()};loadFontsForElements=async t=>{let o=await Promise.all([...new Set(t.filter(r=>W(r)).map(r=>r.fontFamily))].map(r=>{let n=Ke({fontFamily:r,fontSize:16});if(!document.fonts?.check?.(n))return document.fonts?.load?.(n)}));this.onFontsLoaded(o.flat().filter(Boolean))}}});var BS,FS,HS,P0e,D0e,zS=v(()=>{"use strict";f();he();ao();ao();ue();G();Rl();je();se();ee();BS=(e,t)=>{let o=t.scene.getSelectedElements(e);return o.length===1&&Q(o[0])},FS=H({name:"selectAllElementsInFrame",label:"labels.selectAllElementsInFrame",trackEvent:{category:"canvas"},perform:(e,t,o,r)=>{let n=r.scene.getSelectedElements(t).at(0)||null;if(Q(n)){let i=Vo(be(e),n.id).filter(a=>!(a.type==="text"&&a.containerId));return{elements:e,appState:{...t,selectedElementIds:i.reduce((a,l)=>(a[l.id]=!0,a),{})},commitToHistory:!1}}return{elements:e,appState:t,commitToHistory:!1}},predicate:(e,t,o,r)=>BS(t,r)}),HS=H({name:"removeAllElementsFromFrame",label:"labels.removeAllElementsFromFrame",trackEvent:{category:"history"},perform:(e,t,o,r)=>{let n=r.scene.getSelectedElements(t).at(0)||null;return Q(n)?{elements:Uf(e,n),appState:{...t,selectedElementIds:{[n.id]:!0}},commitToHistory:!0}:{elements:e,appState:t,commitToHistory:!1}},predicate:(e,t,o,r)=>BS(t,r)}),P0e=H({name:"updateFrameRendering",label:"labels.updateFrameRendering",viewMode:!0,trackEvent:{category:"canvas"},perform:(e,t)=>({elements:e,appState:{...t,frameRendering:{...t.frameRendering,enabled:!t.frameRendering.enabled}},commitToHistory:!1}),checked:e=>e.frameRendering.enabled}),D0e=H({name:"setFrameAsActiveTool",label:"toolBar.frame",trackEvent:{category:"toolbar"},icon:$c,viewMode:!1,perform:(e,t,o,r)=>{let n=Qe(t,{type:"frame"});return Go(r.interactiveCanvas,{...t,activeTool:n}),{elements:e,appState:{...t,activeTool:Qe(t,{type:"frame"})},commitToHistory:!1}},keyTest:e=>!e[I.CTRL_OR_CMD]&&!e.shiftKey&&!e.altKey&&e.key.toLocaleLowerCase()===I.F})});var KR,GS,Kg,yr,ni,$R,Ud,VS,YS,US,KS,Rs,$S,ht,WS,n0,XR,ZR,XS,ZS,jS,qS,JS=v(()=>{"use strict";f();U();bt();se();Ho();ue();Qt();ui();KR=8,GS=99999,Kg=e=>KR/e,yr=class e{static referenceSnapPoints=null;static visibleGaps=null;static setReferenceSnapPoints=t=>{e.referenceSnapPoints=t};static getReferenceSnapPoints=()=>e.referenceSnapPoints;static setVisibleGaps=t=>{e.visibleGaps=t};static getVisibleGaps=()=>e.visibleGaps;static destroy=()=>{e.referenceSnapPoints=null,e.visibleGaps=null}},ni=({event:e,appState:t,selectedElements:o})=>e?t.objectsSnapModeEnabled&&!e[I.CTRL_OR_CMD]||!t.objectsSnapModeEnabled&&e[I.CTRL_OR_CMD]&&t.gridSize===null:o.length===1&&o[0].type==="arrow"?!1:t.objectsSnapModeEnabled,$R=(e,t,o=.01)=>Math.abs(e-t)<=o,Ud=(e,t,{omitCenter:o,boundingBoxCorners:r,dragOffset:n}={omitCenter:!1,boundingBoxCorners:!1})=>{let i=[];if(e.length===1){let a=e[0],[l,s,c,d,m,p]=te(a,t);n&&(l+=n.x,c+=n.x,m+=n.x,s+=n.y,d+=n.y,p+=n.y);let u=(c-l)/2,g=(d-s)/2;if((a.type==="diamond"||a.type==="ellipse")&&!r){let x=Xe([l,s+g],[m,p],a.angle),E=Xe([l+u,s],[m,p],a.angle),y=Xe([c,s+g],[m,p],a.angle),T=Xe([l+u,d],[m,p],a.angle);i=o?[x,E,y,T]:[x,E,y,T,[m,p]]}else{let x=Xe([l,s],[m,p],a.angle),E=Xe([c,s],[m,p],a.angle),y=Xe([l,d],[m,p],a.angle),T=Xe([c,d],[m,p],a.angle);i=o?[x,E,y,T]:[x,E,y,T,[m,p]]}}else if(e.length>1){let[a,l,s,c]=Gm(e,n??{x:0,y:0}),d=s-a,m=c-l,p=[a,l],u=[s,l],g=[a,c],x=[s,c],E=[a+d/2,l+m/2];i=o?[p,u,g,x]:[p,u,g,x,E]}return i.map(a=>[ht(a[0]),ht(a[1])])},VS=(e,t,o,r)=>{let n=t.filter(i=>Q(i)).map(i=>i.id);return r1(e,t,o,r).filter(i=>!(i.frameId&&n.includes(i.frameId)))},YS=(e,t,o,r)=>{let n=VS(e,t,o,r),i=Ca(n,r).filter(m=>!(m.length===1&&ze(m[0]))).map(m=>Se(m).map(p=>ht(p))),a=i.sort((m,p)=>m[0]-p[0]),l=[],s=0;e:for(let m=0;m<a.length;m++){let p=a[m];for(let u=m+1;u<a.length;u++){if(++s>GS)break e;let g=a[u],[,x,E,y]=p,[T,w,,S]=g;E<T&&ec([x,y],[w,S])&&l.push({startBounds:p,endBounds:g,startSide:[[E,x],[E,y]],endSide:[[T,w],[T,S]],length:T-E,overlap:tc([x,y],[w,S])})}}let c=i.sort((m,p)=>m[1]-p[1]),d=[];s=0;e:for(let m=0;m<c.length;m++){let p=c[m];for(let u=m+1;u<c.length;u++){if(++s>GS)break e;let g=c[u],[x,,E,y]=p,[T,w,S]=g;y<w&&ec([x,E],[T,S])&&d.push({startBounds:p,endBounds:g,startSide:[[x,y],[E,y]],endSide:[[T,w],[S,w]],length:w-y,overlap:tc([x,E],[T,S])})}}return{horizontalGaps:l,verticalGaps:d}},US=(e,t,o,r,n,i,a)=>{if(!ni({appState:o,event:r,selectedElements:e}))return[];if(e.length===0)return[];let l=yr.getVisibleGaps();if(l){let{horizontalGaps:s,verticalGaps:c}=l,[d,m,p,u]=Gm(e,t).map(E=>ht(E)),g=(d+p)/2,x=(m+u)/2;for(let E of s){if(!ec([m,u],E.overlap))continue;let y=E.startSide[0][0]+E.length/2,T=ht(y-g);if(E.length>p-d&&Math.abs(T)<=a.x){Math.abs(T)<a.x&&(n.length=0),a.x=Math.abs(T);let D={type:"gap",direction:"center_horizontal",gap:E,offset:T};n.push(D);continue}let[,,S]=E.endBounds,M=d-S,k=ht(E.length-M);if(Math.abs(k)<=a.x){Math.abs(k)<a.x&&(n.length=0),a.x=Math.abs(k);let D={type:"gap",direction:"side_right",gap:E,offset:k};n.push(D);continue}let[R,,,]=E.startBounds,P=R-p,F=ht(P-E.length);if(Math.abs(F)<=a.x){Math.abs(F)<a.x&&(n.length=0),a.x=Math.abs(F);let D={type:"gap",direction:"side_left",gap:E,offset:F};n.push(D);continue}}for(let E of c){if(!ec([d,p],E.overlap))continue;let y=E.startSide[0][1]+E.length/2,T=ht(y-x);if(E.length>u-m&&Math.abs(T)<=a.y){Math.abs(T)<a.y&&(i.length=0),a.y=Math.abs(T);let D={type:"gap",direction:"center_vertical",gap:E,offset:T};i.push(D);continue}let[,S,,]=E.startBounds,M=S-u,k=ht(M-E.length);if(Math.abs(k)<=a.y){Math.abs(k)<a.y&&(i.length=0),a.y=Math.abs(k);let D={type:"gap",direction:"side_top",gap:E,offset:k};i.push(D);continue}let[,,,R]=E.endBounds,P=ht(m-R),F=E.length-P;if(Math.abs(F)<=a.y){Math.abs(F)<a.y&&(i.length=0),a.y=Math.abs(F);let D={type:"gap",direction:"side_bottom",gap:E,offset:F};i.push(D);continue}}}},KS=(e,t,o,r)=>{let n=VS(e,t,o,r);return Ca(n,r).filter(i=>!(i.length===1&&ze(i[0]))).flatMap(i=>Ud(i,r))},Rs=(e,t,o,r,n,i,a)=>{if(!ni({appState:o,event:r,selectedElements:e})||e.length===0&&t.length===0)return[];let l=yr.getReferenceSnapPoints();if(l)for(let s of t)for(let c of l){let d=c[0]-s[0],m=c[1]-s[1];Math.abs(d)<=a.x&&(Math.abs(d)<a.x&&(n.length=0),n.push({type:"point",points:[s,c],offset:d}),a.x=Math.abs(d)),Math.abs(m)<=a.y&&(Math.abs(m)<a.y&&(i.length=0),i.push({type:"point",points:[s,c],offset:m}),a.y=Math.abs(m))}},$S=(e,t,o,r,n)=>{let i=de(e,o);if(!ni({appState:o,event:r,selectedElements:i})||i.length===0)return{snapOffset:{x:0,y:0},snapLines:[]};t.x=ht(t.x),t.y=ht(t.y);let a=[],l=[],s=Kg(o.zoom.value),c={x:s,y:s},d=Ud(i,n,{dragOffset:t});Rs(i,d,o,r,a,l,c),US(i,t,o,r,a,l,c);let m={x:a[0]?.offset??0,y:l[0]?.offset??0};c.x=0,c.y=0,a.length=0,l.length=0;let p={x:ht(t.x+m.x),y:ht(t.y+m.y)};Rs(i,Ud(i,n,{dragOffset:p}),o,r,a,l,c),US(i,p,o,r,a,l,c);let u=n0(a,l),g=ZR(i,p,[...a,...l].filter(x=>x.type==="gap"));return{snapOffset:m,snapLines:[...u,...g]}},ht=e=>Math.round(e*10**6)/10**6,WS=e=>{let t=new Map;for(let o of e){let r=o.join(",");t.has(r)||t.set(r,o)}return Array.from(t.values())},n0=(e,t)=>{let o={},r={};if(e.length>0){for(let n of e)if(n.type==="point"){let i=ht(n.points[0][0]);o[i]||(o[i]=[]),o[i].push(...n.points.map(a=>[ht(a[0]),ht(a[1])]))}}if(t.length>0){for(let n of t)if(n.type==="point"){let i=ht(n.points[0][1]);r[i]||(r[i]=[]),r[i].push(...n.points.map(a=>[ht(a[0]),ht(a[1])]))}}return Object.entries(o).map(([n,i])=>({type:"points",points:WS(i.map(a=>[Number(n),a[1]]).sort((a,l)=>a[1]-l[1]))})).concat(Object.entries(r).map(([n,i])=>({type:"points",points:WS(i.map(a=>[a[0],Number(n)]).sort((a,l)=>a[0]-l[0]))})))},XR=e=>{let t=new Map;for(let o of e){let r=o.points.flat().map(n=>[ht(n)]).join(",");t.has(r)||t.set(r,o)}return Array.from(t.values())},ZR=(e,t,o)=>{let[r,n,i,a]=Gm(e,t),l=[];for(let s of o){let[c,d,m,p]=s.gap.startBounds,[u,g,x,E]=s.gap.endBounds,y=tc([n,a],s.gap.overlap),T=tc([r,i],s.gap.overlap);switch(s.direction){case"center_horizontal":{if(y){let w=(y[0]+y[1])/2;l.push({type:"gap",direction:"horizontal",points:[[s.gap.startSide[0][0],w],[r,w]]},{type:"gap",direction:"horizontal",points:[[i,w],[s.gap.endSide[0][0],w]]})}break}case"center_vertical":{if(T){let w=(T[0]+T[1])/2;l.push({type:"gap",direction:"vertical",points:[[w,s.gap.startSide[0][1]],[w,n]]},{type:"gap",direction:"vertical",points:[[w,a],[w,s.gap.endSide[0][1]]]})}break}case"side_right":{if(y){let w=(y[0]+y[1])/2;l.push({type:"gap",direction:"horizontal",points:[[m,w],[u,w]]},{type:"gap",direction:"horizontal",points:[[x,w],[r,w]]})}break}case"side_left":{if(y){let w=(y[0]+y[1])/2;l.push({type:"gap",direction:"horizontal",points:[[i,w],[c,w]]},{type:"gap",direction:"horizontal",points:[[m,w],[u,w]]})}break}case"side_top":{if(T){let w=(T[0]+T[1])/2;l.push({type:"gap",direction:"vertical",points:[[w,a],[w,d]]},{type:"gap",direction:"vertical",points:[[w,p],[w,g]]})}break}case"side_bottom":{if(T){let w=(T[0]+T[1])/2;l.push({type:"gap",direction:"vertical",points:[[w,p],[w,g]]},{type:"gap",direction:"vertical",points:[[w,E],[w,n]]})}break}}}return XR(l.map(s=>({...s,points:s.points.map(c=>[ht(c[0]),ht(c[1])])})))},XS=(e,t,o,r,n,i)=>{if(!ni({event:r,selectedElements:e,appState:o})||e.length===0||e.length===1&&!$R(e[0].angle,0))return{snapOffset:{x:0,y:0},snapLines:[]};let[a,l,s,c]=Se(t);i&&(i.includes("e")?s+=n.x:i.includes("w")&&(a+=n.x),i.includes("n")?l+=n.y:i.includes("s")&&(c+=n.y));let d=[];if(i)switch(i){case"e":{d.push([s,l],[s,c]);break}case"w":{d.push([a,l],[a,c]);break}case"n":{d.push([a,l],[s,l]);break}case"s":{d.push([a,c],[s,c]);break}case"ne":{d.push([s,l]);break}case"nw":{d.push([a,l]);break}case"se":{d.push([s,c]);break}case"sw":{d.push([a,c]);break}}let m=Kg(o.zoom.value),p={x:m,y:m},u=[],g=[];Rs(t,d,o,r,u,g,p);let x={x:u[0]?.offset??0,y:g[0]?.offset??0};p.x=0,p.y=0,u.length=0,g.length=0;let[E,y,T,w]=Se(e).map(k=>ht(k));Rs(e,[[E,y],[E,w],[T,y],[T,w]],o,r,u,g,p);let M=n0(u,g);return{snapOffset:x,snapLines:M}},ZS=(e,t,o,r,n,i)=>{if(!ni({event:o,selectedElements:[e],appState:t}))return{snapOffset:{x:0,y:0},snapLines:[]};let a=[[r.x+n.x,r.y+n.y]],l=Kg(t.zoom.value),s={x:l,y:l},c=[],d=[];Rs([e],a,t,o,c,d,s);let m={x:c[0]?.offset??0,y:d[0]?.offset??0};s.x=0,s.y=0,c.length=0,d.length=0;let p=Ud([e],i,{boundingBoxCorners:!0,omitCenter:!0});Rs([e],p,t,o,c,d,s);let u=n0(c,d);return{snapOffset:m,snapLines:u}},jS=(e,t,o,r,n)=>{if(!ni({event:r,selectedElements:[],appState:t}))return{originOffset:{x:0,y:0},snapLines:[]};let i=r1(e,[],t,n),a=Kg(t.zoom.value),l={x:a,y:a},s=[],c=[];for(let d of i){let m=Ud([d],n);for(let p of m){let u=p[0]-o.x;Math.abs(u)<=Math.abs(l.x)&&(Math.abs(u)<Math.abs(l.x)&&(c.length=0),c.push({type:"pointer",points:[p,[p[0],o.y]],direction:"vertical"}),l.x=u);let g=p[1]-o.y;Math.abs(g)<=Math.abs(l.y)&&(Math.abs(g)<Math.abs(l.y)&&(s.length=0),s.push({type:"pointer",points:[p,[o.x,p[1]]],direction:"horizontal"}),l.y=g)}}return{originOffset:{x:c.length>0?c[0].points[0][0]-o.x:0,y:s.length>0?s[0].points[0][1]-o.y:0},snapLines:[...c,...s]}},qS=e=>e===wt.rectangle||e===wt.ellipse||e===wt.diamond||e===wt.frame||e===wt.magicframe||e===wt.image});import{jsx as wr,jsxs as QS}from"react/jsx-runtime";var jR,e4,t4=v(()=>{"use strict";f();Es();jR=()=>QS("div",{"data-testid":"brave-measure-text-error",children:[wr("p",{children:wr(uo,{i18nKey:"errors.brave_measure_text_error.line1",bold:e=>wr("span",{style:{fontWeight:600},children:e})})}),wr("p",{children:wr(uo,{i18nKey:"errors.brave_measure_text_error.line2",bold:e=>wr("span",{style:{fontWeight:600},children:e})})}),wr("p",{children:wr(uo,{i18nKey:"errors.brave_measure_text_error.line3",link:e=>wr("a",{href:"http://docs.excalidraw.com/docs/@excalidraw/excalidraw/faq#turning-off-aggresive-block-fingerprinting-in-brave-browser",children:e})})}),wr("p",{children:wr(uo,{i18nKey:"errors.brave_measure_text_error.line4",issueLink:e=>wr("a",{href:"https://github.com/excalidraw/excalidraw/issues/new",children:e}),discordLink:e=>QS("a",{href:"https://discord.gg/UexuTaE",children:[e,"."]})})})]}),e4=jR});var $g,Ji,qR,o4,i0,Hd,a0=v(()=>{"use strict";f();U();he();_r();on();pt();G();qs();Sr();$g={width:100,height:0},Ji=100,qR=(e,t,o)=>{let r=Gt({x:0,y:0,textAlign:ci.CENTER,verticalAlign:yt.MIDDLE,...t,containerId:e.id,strokeColor:t.strokeColor||e.strokeColor});return Object.assign(e,{boundElements:(e.boundElements||[]).concat({type:"text",id:r.id})}),eo(r,e,o),[e,r]},o4=(e,t,o,r,n)=>{let i,a;if(Object.assign(e,{startBinding:e?.startBinding||null,endBinding:e.endBinding||null}),t){let d=t?.width??Ji,m=t?.height??Ji,p;t.id&&(p=r.getElement(t.id),p||console.error(`No element for start binding with id ${t.id} found`));let u=t.x||e.x-d,g=t.y||e.y-m/2,x=p?p.type:t.type;if(x){if(x==="text"){let E="";p&&p.type==="text"?E=p.text:t.type==="text"&&(E=t.text),E||console.error(`No text found for start binding text element for ${e.id}`),i=Gt({x:u,y:g,type:"text",...p,...t,text:E}),Object.assign(i,{x:t.x||e.x-i.width,y:t.y||e.y-i.height/2})}else switch(x){case"rectangle":case"ellipse":case"diamond":{i=Uo({x:u,y:g,width:d,height:m,...p,...t,type:x});break}default:mi(e,`Unhandled element start type "${t.type}"`,!0)}Al(e,i,"start",n)}}if(o){let d=o?.height??Ji,m=o?.width??Ji,p;o.id&&(p=r.getElement(o.id),p||console.error(`No element for end binding with id ${o.id} found`));let u=o.x||e.x+e.width,g=o.y||e.y-d/2,x=p?p.type:o.type;if(x){if(x==="text"){let E="";p&&p.type==="text"?E=p.text:o.type==="text"&&(E=o.text),E||console.error(`No text found for end binding text element for ${e.id}`),a=Gt({x:u,y:g,type:"text",...p,...o,text:E}),Object.assign(a,{y:o.y||e.y-a.height/2})}else switch(x){case"rectangle":case"ellipse":case"diamond":{a=Uo({x:u,y:g,width:m,height:d,...p,...o,type:x});break}default:mi(e,`Unhandled element end type "${x}"`,!0)}Al(e,a,"end",n)}}if(e.points.length<2)return{linearElement:e,startBoundElement:i,endBoundElement:a};let l=e.points.length-1,s=.5,c=Zr(e.points);return e.points[l][0]>e.points[l-1][0]&&(c[0][0]=s,c[l][0]-=s),e.points[l][0]<e.points[l-1][0]&&(c[0][0]=-s,c[l][0]+=s),e.points[l][1]>e.points[l-1][1]&&(c[0][1]=s,c[l][1]-=s),e.points[l][1]<e.points[l-1][1]&&(c[0][1]=-s,c[l][1]+=s),Object.assign(e,{points:c}),{linearElement:e,startBoundElement:i,endBoundElement:a}},i0=class{excalidrawElements=new Map;add=t=>{t&&this.excalidrawElements.set(t.id,t)};getElements=()=>Array.from(this.excalidrawElements.values());getElementsMap=()=>Ir(this.excalidrawElements);getElement=t=>this.excalidrawElements.get(t)},Hd=(e,t)=>{if(!e)return[];let o=Zr(e),r=new i0,n=new Map,i=new Map;for(let l of o){let s,c=l.id;switch(t?.regenerateIds!==!1&&Object.assign(l,{id:Bt()}),l.type){case"rectangle":case"ellipse":case"diamond":{let m=l?.label?.text&&l.width===void 0?0:l?.width||Ji,p=l?.label?.text&&l.height===void 0?0:l?.height||Ji;s=Uo({...l,width:m,height:p});break}case"line":{let m=l.width||$g.width,p=l.height||$g.height;s=cr({width:m,height:p,points:[[0,0],[m,p]],...l});break}case"arrow":{let m=l.width||$g.width,p=l.height||$g.height;s=cr({width:m,height:p,endArrowhead:"arrow",points:[[0,0],[m,p]],...l}),Object.assign(s,wm(s.points));break}case"text":{let m=l?.fontFamily||qt,p=l?.fontSize||Rt,u=l?.lineHeight||Oo(m),g=l.text??"",x=yi(g),E=Pr(x,Ke({fontFamily:m,fontSize:p}),u);s=Gt({width:E.width,height:E.height,fontFamily:m,fontSize:p,...l});break}case"image":{s=Ec({width:l?.width||Ji,height:l?.height||Ji,...l});break}case"frame":{s=jm({x:0,y:0,...l});break}case"magicframe":{s=xc({x:0,y:0,...l});break}case"freedraw":case"iframe":case"embeddable":{s=l;break}default:s=l,mi(l,`Unhandled element type "${l.type}"`,!0)}r.getElement(s.id)?console.error(`Duplicate id found for ${s.id}`):(r.add(s),n.set(s.id,l),c&&i.set(c,s.id))}let a=r.getElementsMap();for(let[l,s]of n){let c=r.getElement(l);switch(s.type){case"rectangle":case"ellipse":case"diamond":case"arrow":{if(s.label?.text){let[d,m]=qR(c,s?.label,a);if(r.add(d),r.add(m),d.type==="arrow"){let p=s.type==="arrow"?s?.start:void 0,u=s.type==="arrow"?s?.end:void 0;if(p&&p.id){let y=i.get(p.id);y&&Object.assign(p,{id:y})}if(u&&u.id){let y=i.get(u.id);y&&Object.assign(u,{id:y})}let{linearElement:g,startBoundElement:x,endBoundElement:E}=o4(d,p,u,r,a);d=g,r.add(g),r.add(x),r.add(E)}}else switch(s.type){case"arrow":{let{start:d,end:m}=s;if(d&&d.id){let x=i.get(d.id);Object.assign(d,{id:x})}if(m&&m.id){let x=i.get(m.id);Object.assign(m,{id:x})}let{linearElement:p,startBoundElement:u,endBoundElement:g}=o4(c,d,m,r,a);r.add(p),r.add(u),r.add(g);break}}break}}}for(let[l,s]of n){if(s.type!=="frame"&&s.type!=="magicframe")continue;let c=r.getElement(l);if(!c)throw new Error(`Excalidraw element with id ${l} doesn't exist`);let d=[];s.children.forEach(T=>{let w=i.get(T);if(!w)throw new Error(`Element with ${T} wasn't mapped correctly`);let S=r.getElement(w);if(!S)throw new Error(`Frame element with id ${w} doesn't exist`);Object.assign(S,{frameId:c.id}),S?.boundElements?.forEach(M=>{let k=r.getElement(M.id);if(!k)throw new Error(`Bound element with id ${M.id} doesn't exist`);Object.assign(k,{frameId:c.id}),d.push(k)}),d.push(S)});let[m,p,u,g]=Se(d),x=10;m=m-x,p=p-x,u=u+x,g=g+x;let E=Math.max(c?.width,u-m),y=Math.max(c?.height,g-p);Object.assign(c,{x:m,y:p,width:E,height:y})}return r.getElements()}});import{unstable_batchedUpdates as r4}from"react-dom";import{version as JR}from"react";var ct,Xg,Zg,jg=v(()=>{"use strict";f();G();ct=e=>t=>{r4(e,t)},Xg=e=>gl(t=>{r4(e,t)}),Zg=(()=>{let e;try{let o=JR.split(".");e=Number(o[0])>17}catch{e=!1}let t=!1;return()=>window.EXCALIDRAW_THROTTLE_RENDER===!0?e?!0:(t||(t=!0,console.warn("Excalidraw: render throttling is disabled on React versions < 18.")),!1):!1})()});var QR,e9,n4,i4,a4,t9,o9,l4,vr,r9,s4=v(()=>{"use strict";f();U();QR="#ff6b6b",e9="#ff0000",n4=1,i4=2,a4=(e,t)=>{if(!t.snapLines.length)return;let o=t.theme===ie.LIGHT||t.zenModeEnabled?QR:e9,r=(t.zenModeEnabled?n4*1.5:n4)/t.zoom.value;e.save(),e.translate(t.scrollX,t.scrollY);for(let n of t.snapLines)n.type==="pointer"?(e.lineWidth=r,e.strokeStyle=o,o9(n,e,t)):n.type==="gap"?(e.lineWidth=r,e.strokeStyle=o,r9(n.points[0],n.points[1],n.direction,t,e)):n.type==="points"&&(e.lineWidth=r,e.strokeStyle=o,t9(n,e,t));e.restore()},t9=(e,t,o)=>{if(!o.zenModeEnabled){let r=e.points[0],n=e.points[e.points.length-1];vr(r,n,t)}for(let r of e.points)l4(r,o,t)},o9=(e,t,o)=>{l4(e.points[0],o,t),o.zenModeEnabled||vr(e.points[0],e.points[1],t)},l4=([e,t],o,r)=>{r.save();let n=(o.zenModeEnabled?i4*1.5:i4)/o.zoom.value;r.beginPath(),r.moveTo(e-n,t-n),r.lineTo(e+n,t+n),r.moveTo(e+n,t-n),r.lineTo(e-n,t+n),r.stroke(),r.restore()},vr=(e,t,o)=>{o.beginPath(),o.lineTo(...e),o.lineTo(...t),o.stroke()},r9=(e,t,o,r,n)=>{let i=8/r.zoom.value,a=i/2,l=i/4;if(o==="horizontal"){let s=[(e[0]+t[0])/2,e[1]];r.zenModeEnabled||vr([e[0],e[1]-i],[e[0],e[1]+i],n),vr([s[0]-l,s[1]-a],[s[0]-l,s[1]+a],n),vr([s[0]+l,s[1]-a],[s[0]+l,s[1]+a],n),r.zenModeEnabled||(vr([t[0],t[1]-i],[t[0],t[1]+i],n),vr(e,t,n))}else{let s=[e[0],(e[1]+t[1])/2];r.zenModeEnabled||vr([e[0]-i,e[1]],[e[0]+i,e[1]],n),vr([s[0]-a,s[1]-l],[s[0]+a,s[1]-l],n),vr([s[0]-a,s[1]+l],[s[0]+a,s[1]+l],n),r.zenModeEnabled||(vr([t[0]-i,t[1]],[t[0]+i,t[1]],n),vr(e,t,n))}}});import qg from"open-color";var n9,s0,Wd,i9,Jg,a9,l9,s9,d4,c9,d9,m9,l0,c4,m4,c0,p4,d0=v(()=>{"use strict";f();he();sx();Tg();Jr();dd();Ho();vl();G();U();s4();Ei();io();_f();se();n9=(e,t,o)=>{let{elementId:r,hoverPointIndex:n}=t.selectedLinearElement;if(t.editingLinearElement?.selectedPointsIndices?.includes(n))return;let i=$.getElement(r,o);if(!i)return;let a=$.getPointAtIndexGlobalCoordinates(i,n,o);e.save(),e.translate(t.scrollX,t.scrollY),s0(a,e,t),e.restore()},s0=(e,t,o)=>{t.fillStyle="rgba(105, 101, 219, 0.4)",_c(t,e[0],e[1],$.POINT_HANDLE_SIZE/o.zoom.value,!1)},Wd=(e,t,o,r,n,i,a,l,s=!1,c=0)=>{e.save(),e.translate(i,a),e.rotate(l),s&&e.fillRect(t-i,o-a,r,n),c&&e.roundRect?(e.beginPath(),e.roundRect(t-i,o-a,r,n,c),e.stroke(),e.closePath()):e.strokeRect(t-i,o-a,r,n),e.restore()},i9=(e,t,o,r,n,i)=>{e.save(),e.translate(r,n),e.rotate(i),e.beginPath(),e.moveTo(0,o/2),e.lineTo(t/2,0),e.lineTo(0,-o/2),e.lineTo(-t/2,0),e.closePath(),e.stroke(),e.restore()},Jg=(e,t,o,r,n,i=!1)=>{e.strokeStyle="#5e5ad8",e.setLineDash([]),e.fillStyle="rgba(255, 255, 255, 0.9)",n?e.fillStyle="rgba(134, 131, 226, 0.9)":i&&(e.fillStyle="rgba(177, 151, 252, 0.7)"),_c(e,o[0],o[1],r/t.zoom.value,!i)},a9=(e,t,o,r,n,i)=>{e.beginPath(),e.ellipse(r,n,t/2,o/2,i,0,Math.PI*2),e.stroke()},l9=(e,t,o)=>{let[r,n,i,a]=te(t,o),l=i-r,s=a-n,c=Il(t,l,s),d=4;e.strokeStyle="rgba(0,0,0,.05)",e.lineWidth=c-d;let m=d/2+c/2;switch(t.type){case"rectangle":case"text":case"image":case"iframe":case"embeddable":case"frame":case"magicframe":Wd(e,r-m,n-m,l+m*2,s+m*2,r+l/2,n+s/2,t.angle);break;case"diamond":let p=Math.hypot(l,s),u=m*p/s,g=m*p/l;i9(e,l+u*2,s+g*2,r+l/2,n+s/2,t.angle);break;case"ellipse":a9(e,l+m*2,s+m*2,r+l/2,n+s/2,t.angle);break}},s9=(e,t,o)=>{let[r,n,i]=t,a=Il(i,i.width,i.height);e.strokeStyle="rgba(0,0,0,0)",e.fillStyle="rgba(0,0,0,.05)",(n==="both"?[0,-1]:n==="start"?[0]:[-1]).forEach(s=>{let[c,d]=$.getPointAtIndexGlobalCoordinates(r,s,o);_c(e,c,d,a)})},d4=(e,t,o,r=aa*2)=>{let{angle:n,elementX1:i,elementY1:a,elementX2:l,elementY2:s,selectionColors:c,cx:d,cy:m,dashed:p,activeEmbeddable:u}=o,g=l-i,x=s-a,E=r/t.zoom.value,y=8/t.zoom.value,T=4/t.zoom.value;e.save(),e.translate(t.scrollX,t.scrollY),e.lineWidth=(u?4:1)/t.zoom.value;let w=c.length;for(let S=0;S<w;++S)e.strokeStyle=c[S],p&&e.setLineDash([y,T+(y+T)*(w-1)]),e.lineDashOffset=(y+T)*S,Wd(e,i-E,a-E,g+E*2,x+E*2,d,m,n);e.restore()},c9=(e,t,o,r)=>{let n=Array.isArray(o)?s9:l9;e.save(),e.translate(t.scrollX,t.scrollY),n(e,o,r),e.restore()},d9=(e,t,o,r)=>{let[n,i,a,l]=te(o,r),s=a-n,c=l-i;e.strokeStyle="rgb(0,118,255)",e.lineWidth=Je.strokeWidth/t.zoom.value,e.save(),e.translate(t.scrollX,t.scrollY),Wd(e,n,i,s,c,n+s/2,i+c/2,o.angle,!1,Je.radius/t.zoom.value),e.restore()},m9=(e,t,o)=>{let r=o.filter(l=>l.groupIds.length===0),n=o.filter(l=>l.groupIds.length>0),i=l=>{let[s,c,d,m]=Se(l);return{angle:0,elementX1:s,elementX2:d,elementY1:c,elementY2:m,selectionColors:["rgb(0,118,255)"],dashed:!1,cx:s+(d-s)/2,cy:c+(m-c)/2,activeEmbeddable:!1}},a=l=>{let s=ot(o,l);return i(s)};Object.entries(Wm(n,t)).filter(([l,s])=>s).map(([l,s])=>l).map(l=>a(l)).concat(r.map(l=>i([l]))).forEach(l=>d4(e,t,l))},l0=(e,t,o,r)=>{if(!t.selectedLinearElement)return;e.save(),e.translate(t.scrollX,t.scrollY),e.lineWidth=1/t.zoom.value;let n=$.getPointsGlobalCoordinates(o,r),{POINT_HANDLE_SIZE:i}=$,a=t.editingLinearElement?i:i/2;n.forEach((s,c)=>{let d=!!t.editingLinearElement?.selectedPointsIndices?.includes(c);Jg(e,t,s,a,d)}),$.getEditorMidPoints(o,r,t).filter(s=>s!==null).forEach(s=>{t?.selectedLinearElement?.segmentMidPointHoveredCoords&&$.arePointsEqual(s,t.selectedLinearElement.segmentMidPointHoveredCoords)?t.editingLinearElement?(Jg(e,t,s,a,!1),s0(s,e,t)):(s0(s,e,t),Jg(e,t,s,a,!1)):(t.editingLinearElement||n.length===2)&&Jg(e,t,s,i/2,!1,!0)}),e.restore()},c4=(e,t,o,r,n)=>{Object.keys(r).forEach(i=>{let a=r[i];if(a!==void 0){let[l,s,c,d]=a;e.save(),e.lineWidth=1/o.zoom.value,t.selectionColor&&(e.strokeStyle=t.selectionColor),i==="rotation"?_c(e,l+c/2,s+d/2,c/2):e.roundRect?(e.beginPath(),e.roundRect(l,s,c,d,2/o.zoom.value),e.fill(),e.stroke()):Wd(e,l,s,c,d,l+c/2,s+d/2,n,!0),e.restore()}})},m4=({canvas:e,elementsMap:t,visibleElements:o,selectedElements:r,scale:n,appState:i,renderConfig:a})=>{if(e===null)return{atLeastOneVisibleElement:!1,elementsMap:t};let[l,s]=mp(e,n),c=pp({canvas:e,scale:n,normalizedWidth:l,normalizedHeight:s});c.save(),c.scale(i.zoom.value,i.zoom.value);let d;if(o.forEach(u=>{i.editingLinearElement?.elementId===u.id&&u&&(d=u)}),d&&l0(c,i,d,t),i.selectionElement)try{wv(i.selectionElement,c,i)}catch(u){console.error(u)}i.isBindingEnabled&&i.suggestedBindings.filter(u=>u!=null).forEach(u=>{c9(c,i,u,t)}),i.frameToHighlight&&d9(c,i,i.frameToHighlight,t),i.elementsToHighlight&&m9(c,i,i.elementsToHighlight);let m=r.some(u=>Q(u));if(r.length===1&&i.editingLinearElement?.elementId===r[0].id&&l0(c,i,r[0],t),i.selectedLinearElement&&i.selectedLinearElement.hoverPointIndex>=0&&n9(c,i,t),!i.multiElement&&!i.editingLinearElement){let u=wl(r,i);r.length===1&&ne(r[0])&&i.selectedLinearElement?.elementId===r[0].id&&!r[0].locked&&l0(c,i,r[0],t);let x=a.selectionColor||qg.black;if(u){let E=re(r),y=[];for(let w of t.values()){let S=[];E.has(w.id)&&!Um(i,w)&&S.push(x);let M=a.remoteSelectedElementIds.get(w.id);if(M&&S.push(...M.map(k=>qa(k,i.collaborators.get(k)))),S.length){let[k,R,P,F,D,L]=te(w,t,!0);y.push({angle:w.angle,elementX1:k,elementY1:R,elementX2:P,elementY2:F,selectionColors:S,dashed:!!M,cx:D,cy:L,activeEmbeddable:i.activeEmbeddable?.element===w&&i.activeEmbeddable.state==="active"})}}let T=w=>{let S=ot(t,w),[M,k,R,P]=Se(S);y.push({angle:0,elementX1:M,elementX2:R,elementY1:k,elementY2:P,selectionColors:[qg.black],dashed:!0,cx:M+(R-M)/2,cy:k+(P-k)/2,activeEmbeddable:!1})};for(let w of Fn(i))T(w);i.editingGroupId&&T(i.editingGroupId),y.forEach(w=>d4(c,i,w))}if(c.save(),c.translate(i.scrollX,i.scrollY),r.length===1){c.fillStyle=qg.white;let E=sc(r[0],i.zoom,t,"mouse");!i.viewModeEnabled&&u&&c4(c,a,i,E,r[0].angle)}else if(r.length>1&&!i.isRotating){let E=aa*2/i.zoom.value;c.fillStyle=qg.white;let[y,T,w,S]=Se(r),M=c.getLineDash();c.setLineDash([2/i.zoom.value]);let k=c.lineWidth;c.lineWidth=1/i.zoom.value,c.strokeStyle=x,Wd(c,y-E,T-E,w-y+E*2,S-T+E*2,(y+w)/2,(T+S)/2,0),c.lineWidth=k,c.setLineDash(M);let R=yl([y,T,w,S,(y+w)/2,(T+S)/2],0,i.zoom,"mouse",m?s2:lc);r.some(P=>!P.locked)&&c4(c,a,i,R,0)}c.restore()}a4(c,i),c.restore(),CT({context:c,renderConfig:a,appState:i,normalizedWidth:l,normalizedHeight:s});let p;return a.renderScrollbars&&(p=I6(o,l,s,i),c.save(),c.fillStyle=C6,c.strokeStyle="rgba(255,255,255,0.8)",[p.horizontal,p.vertical].forEach(u=>{u&&Ru(c,u.x,u.y,u.width,u.height,bn/2)}),c.restore()),{scrollBars:p,atLeastOneVisibleElement:o.length>0,elementsMap:t}},c0=gl(e=>{let t=m4(e);e.callback?.(t)},{trailing:!0}),p4=(e,t)=>{if(t){c0(e);return}let o=m4(e);return e.callback(o),o}});import p9,{useEffect as u9,useRef as g9}from"react";import{jsx as b9}from"react/jsx-runtime";var h9,u4,f9,m0,g4=v(()=>{"use strict";f();G();U();X();jg();d0();h9=e=>{let t=g9(!1);return u9(()=>{if(!t.current){t.current=!0;return}let o=new Map,r=new Map,n=new Map,i=new Map,a=new Map;e.appState.collaborators.forEach((s,c)=>{if(s.selectedElementIds)for(let d of Object.keys(s.selectedElementIds))n.has(d)||n.set(d,[]),n.get(d).push(c);!s.pointer||s.pointer.renderCursor===!1||(s.username&&i.set(c,s.username),s.userState&&a.set(c,s.userState),r.set(c,zt({sceneX:s.pointer.x,sceneY:s.pointer.y},e.appState)),o.set(c,s.button))});let l=e.containerRef?.current&&getComputedStyle(e.containerRef.current).getPropertyValue("--color-selection")||"#6965db";p4({canvas:e.canvas,elementsMap:e.elementsMap,visibleElements:e.visibleElements,selectedElements:e.selectedElements,scale:window.devicePixelRatio,appState:e.appState,renderConfig:{remotePointerViewportCoords:r,remotePointerButton:o,remoteSelectedElementIds:n,remotePointerUsernames:i,remotePointerUserStates:a,selectionColor:l,renderScrollbars:!1},callback:e.renderInteractiveSceneCallback},Zg())}),b9("canvas",{className:"excalidraw__canvas interactive",style:{width:e.appState.width,height:e.appState.height,cursor:e.appState.viewModeEnabled?Pe.GRAB:Pe.AUTO},width:e.appState.width*e.scale,height:e.appState.height*e.scale,ref:e.handleCanvasRef,onContextMenu:e.onContextMenu,onPointerMove:e.onPointerMove,onPointerUp:e.onPointerUp,onPointerCancel:e.onPointerCancel,onTouchMove:e.onTouchMove,onPointerDown:e.onPointerDown,onDoubleClick:e.appState.viewModeEnabled?void 0:e.onDoubleClick,children:b("labels.drawingCanvas")})},u4=e=>({zoom:e.zoom,scrollX:e.scrollX,scrollY:e.scrollY,width:e.width,height:e.height,viewModeEnabled:e.viewModeEnabled,editingGroupId:e.editingGroupId,editingLinearElement:e.editingLinearElement,selectedElementIds:e.selectedElementIds,frameToHighlight:e.frameToHighlight,offsetLeft:e.offsetLeft,offsetTop:e.offsetTop,theme:e.theme,pendingImageElementId:e.pendingImageElementId,selectionElement:e.selectionElement,selectedGroupIds:e.selectedGroupIds,selectedLinearElement:e.selectedLinearElement,multiElement:e.multiElement,isBindingEnabled:e.isBindingEnabled,suggestedBindings:e.suggestedBindings,isRotating:e.isRotating,elementsToHighlight:e.elementsToHighlight,collaborators:e.collaborators,activeEmbeddable:e.activeEmbeddable,snapLines:e.snapLines,zenModeEnabled:e.zenModeEnabled}),f9=(e,t)=>e.selectionNonce!==t.selectionNonce||e.versionNonce!==t.versionNonce||e.scale!==t.scale||e.elementsMap!==t.elementsMap||e.visibleElements!==t.visibleElements||e.selectedElements!==t.selectedElements?!1:It(u4(e.appState),u4(t.appState)),m0=p9.memo(h9,f9)});import x9,{useEffect as E9,useRef as h4}from"react";import{jsx as v9}from"react/jsx-runtime";var y9,f4,w9,p0,b4=v(()=>{"use strict";f();hp();G();jg();y9=e=>{let t=h4(null),o=h4(!1);return E9(()=>{let r=t.current;if(!r)return;let n=e.canvas;o.current||(o.current=!0,r.replaceChildren(n),n.classList.add("excalidraw__canvas","static"));let i=`${e.appState.width}px`,a=`${e.appState.height}px`;n.style.width!==i&&(n.style.width=i),n.style.height!==a&&(n.style.height=a);let l=e.appState.width*e.scale,s=e.appState.height*e.scale;n.width!==l&&(n.width=l),n.height!==s&&(n.height=s),gp({canvas:n,rc:e.rc,scale:e.scale,elementsMap:e.elementsMap,allElementsMap:e.allElementsMap,visibleElements:e.visibleElements,appState:e.appState,renderConfig:e.renderConfig},Zg())}),v9("div",{className:"excalidraw__canvas-wrapper",ref:t})},f4=e=>({zoom:e.zoom,scrollX:e.scrollX,scrollY:e.scrollY,width:e.width,height:e.height,viewModeEnabled:e.viewModeEnabled,offsetLeft:e.offsetLeft,offsetTop:e.offsetTop,theme:e.theme,pendingImageElementId:e.pendingImageElementId,shouldCacheIgnoreZoom:e.shouldCacheIgnoreZoom,exportScale:e.exportScale,selectedElementsAreBeingDragged:e.selectedElementsAreBeingDragged,gridSize:e.gridSize,frameRendering:e.frameRendering,selectedElementIds:e.selectedElementIds,frameToHighlight:e.frameToHighlight,editingGroupId:e.editingGroupId}),w9=(e,t)=>e.versionNonce!==t.versionNonce||e.scale!==t.scale||e.elementsMap!==t.elementsMap||e.visibleElements!==t.visibleElements?!1:It(f4(e.appState),f4(t.appState))&&It(e.renderConfig,t.renderConfig),p0=x9.memo(y9,w9)});var x4=v(()=>{"use strict";f();g4();b4()});var Vd,E4=v(()=>{"use strict";f();Ra();se();d0();hp();G();Vd=class{scene;constructor(t){this.scene=t}getRenderableElements=(()=>{let t=({elementsMap:r,zoom:n,offsetLeft:i,offsetTop:a,scrollX:l,scrollY:s,height:c,width:d})=>{let m=[];for(let p of r.values())Da(p,d,c,{zoom:n,offsetLeft:i,offsetTop:a,scrollX:l,scrollY:s},r)&&m.push(p);return m},o=({elements:r,editingElement:n,pendingImageElementId:i})=>{let a=Ir(new Map);for(let l of r)nr(l)&&i===l.id||(!n||n.type!=="text"||l.id!==n.id)&&a.set(l.id,l);return a};return ky(({zoom:r,offsetLeft:n,offsetTop:i,scrollX:a,scrollY:l,height:s,width:c,editingElement:d,pendingImageElementId:m,versionNonce:p})=>{let u=this.scene.getNonDeletedElements(),g=o({elements:u,editingElement:d,pendingImageElementId:m}),x=t({elementsMap:g,zoom:r,offsetLeft:n,offsetTop:i,scrollX:a,scrollY:l,height:s,width:c});return{elementsMap:g,visibleElements:x}})})();destroy(){c0.cancel(),Pf.cancel(),this.getRenderableElements.clear()}}});var y4=v(()=>{});import{useEffect as T9,useRef as C9}from"react";import{jsx as w4}from"react/jsx-runtime";var v4,T4=v(()=>{"use strict";f();y4();v4=({trails:e})=>{let t=C9(null);return T9(()=>{if(t.current)for(let o of e)o.start(t.current);return()=>{for(let o of e)o.stop()}},e),w4("div",{className:"SVGLayer",children:w4("svg",{ref:t})})}});var C4=v(()=>{});import{jsx as k9}from"react/jsx-runtime";var I9,S9,u0,I4=v(()=>{"use strict";f();G();he();ye();C4();I9=5,S9=(e,t,o)=>{let[r,n]=te(e,o),{x:i,y:a}=zt({sceneX:r+e.width,sceneY:n},t),l=i-t.offsetLeft+10,s=a-t.offsetTop;return{x:l,y:s}},u0=({children:e,element:t,elementsMap:o})=>{let r=fs();if(r.contextMenu||r.draggingElement||r.resizingElement||r.isRotating||r.openMenu||r.viewModeEnabled)return null;let{x:n,y:i}=S9(t,r,o);return k9("div",{className:"excalidraw-canvas-buttons",style:{top:`${i}px`,left:`${n}px`,padding:I9},children:e})}});async function S4({image:e,apiKey:t,text:o,theme:r=ie.LIGHT}){let n={model:"gpt-4-vision-preview",max_tokens:4096,temperature:.1,messages:[{role:"system",content:A9},{role:"user",content:[{type:"image_url",image_url:{url:e,detail:"high"}},{type:"text",text:`Above is the reference wireframe. Please make a new website based on these and return just the HTML file. Also, please make it for the ${r} theme. What follows are the wireframe's text annotations (if any)...`},{type:"text",text:o}]}]},i,a=await fetch("https://api.openai.com/v1/chat/completions",{method:"POST",headers:{"Content-Type":"application/json",Authorization:`Bearer ${t}`},body:JSON.stringify(n)});return a.ok?i={...await a.json(),ok:!0}:i={...await a.json(),ok:!1},i}var A9,k4=v(()=>{"use strict";f();U();A9=`You are a skilled front-end developer who builds interactive prototypes from wireframes, and is an expert at CSS Grid and Flex design.
76
+ C -->|Three| F[Car]`,g4=xa(em,300),R9=({mermaidToExcalidrawLib:e})=>{let[t,r]=p4(()=>Fr.get(po.MERMAID_TO_EXCALIDRAW)||_9),o=D9(t.trim()),[n,i]=p4(null),a=u4(null),l=u4({elements:[],files:null}),s=Or();h4(()=>{dg({canvasRef:a,data:l,mermaidToExcalidrawLib:e,setError:i,mermaidDefinition:o}).catch(d=>{aw()&&console.error("Failed to parse mermaid definition",d)}),g4(o)},[o,e]),h4(()=>()=>{g4.flush()},[]);let c=()=>{mg({app:s,data:l,text:t,shouldSaveMermaidDataToStorage:!0})};return f4(N9,{children:[Mn("div",{className:"ttd-dialog-desc",children:Mn(wr,{i18nKey:"mermaid.description",flowchartLink:d=>Mn("a",{href:"https://mermaid.js.org/syntax/flowchart.html",children:d}),sequenceLink:d=>Mn("a",{href:"https://mermaid.js.org/syntax/sequenceDiagram.html",children:d}),classLink:d=>Mn("a",{href:"https://mermaid.js.org/syntax/classDiagram.html",children:d})})}),f4(pg,{children:[Mn(Ws,{label:b("mermaid.syntax"),children:Mn(ug,{input:t,placeholder:"Write Mermaid diagram defintion here...",onChange:d=>r(d.target.value),onKeyboardSubmit:()=>{c()}})}),Mn(Ws,{label:b("mermaid.preview"),panelAction:{action:()=>{c()},label:b("mermaid.button"),icon:el},renderSubmitShortcut:()=>Mn(fg,{}),children:Mn(gg,{canvasRef:a,loaded:e.loaded,error:n})})]})]})},b4=R9});import*as x4 from"@radix-ui/react-tabs";import{jsx as O9}from"react/jsx-runtime";var D0,y4=y(()=>{"use strict";f();D0=({children:e,...t})=>O9(x4.List,{className:"ttd-dialog-triggers",...t,children:e});D0.displayName="TTDDialogTabTriggers"});import*as v4 from"@radix-ui/react-tabs";import{jsx as w4}from"react/jsx-runtime";var bg,T4=y(()=>{"use strict";f();bg=({children:e,tab:t,onSelect:r,...o})=>w4(v4.Trigger,{value:t,asChild:!0,onSelect:r,children:w4("button",{type:"button",className:"ttd-dialog-tab-trigger",...o,children:e})});bg.displayName="TTDDialogTabTrigger"});var S4=y(()=>{});import{useEffect as B9,useRef as _0,useState as Eg}from"react";import{atom as I4,useAtom as C4}from"jotai";import{jsx as Cr,jsxs as sa}from"react/jsx-runtime";var R0,Ys,F9,z9,N0,H9,O0=y(()=>{"use strict";f();ao();we();E4();T0();jt();Jd();y4();T4();S0();q();M0();L0();k0();I0();C0();ne();S4();G();Nr();Fh();P0();R0=3,Ys=1e3,F9=I4(null),z9=I4(null),N0=e=>{let t=Be();return t.openDialog?.name!=="ttd"?null:Cr(H9,{...e,tab:t.openDialog.tab})},H9=ci("TTDDialogBase",({tab:e,...t})=>{let r=Or(),o=He(),n=_0(null),[i,a]=C4(z9),[l,s]=Eg(i?.prompt??""),c=l.trim(),d=A=>{s(A.target.value),a(M=>({generatedResponse:M?.generatedResponse??null,prompt:A.target.value}))},[m,p]=Eg(!1),[u,h]=C4(F9),E=async()=>{if(c.length>Ys||c.length<R0||m||u?.rateLimitRemaining===0||"__fallback"in t){c.length<R0&&L(new Error(`Prompt is too short (min ${R0} characters)`)),c.length>Ys&&L(new Error(`Prompt is too long (max ${Ys} characters)`));return}try{p(!0),ve("ai","generate","ttd");let{generatedResponse:A,error:M,rateLimit:D,rateLimitRemaining:O}=await t.onTextSubmit(c);if(typeof A=="string"&&a(R=>({generatedResponse:A,prompt:R?.prompt??null})),qg(D)&&qg(O)&&h({rateLimit:D,rateLimitRemaining:O}),M){L(M);return}if(!A){L(new Error("Generation failed"));return}try{await dg({canvasRef:n,data:w,mermaidToExcalidrawLib:T,setError:L,mermaidDefinition:A}),ve("ai","mermaid parse success","ttd")}catch(R){console.info(`%cTTD mermaid render errror: ${R.message}`,"color: red"),console.info(`>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>
77
+ TTD mermaid definition render errror: ${R.message}`,"color: yellow"),ve("ai","mermaid parse failed","ttd"),L(new Error("Generated an invalid diagram :(. You may also try a different prompt."))}}catch(A){let M=A.message;(!M||M==="Failed to fetch")&&(M="Request failed"),L(new Error(M))}finally{p(!1)}},x=_0(E);x.current=E;let[T,v]=Eg({loaded:!1,api:import("@excalidraw/mermaid-to-excalidraw")});B9(()=>{(async()=>{await T.api,v(M=>({...M,loaded:!0}))})()},[T.api]);let w=_0({elements:[],files:null}),[I,L]=Eg(null);return Cr(ft,{className:"ttd-dialog",onCloseRequest:()=>{r.setOpenDialog(null)},size:1200,title:!1,...t,autofocus:!1,children:sa(cg,{dialog:"ttd",tab:e,children:["__fallback"in t&&t.__fallback?Cr("p",{className:"dialog-mermaid-title",children:b("mermaid.title")}):sa(D0,{children:[Cr(bg,{tab:"text-to-diagram",children:sa("div",{style:{display:"flex",alignItems:"center"},children:[b("labels.textToDiagram"),Cr("div",{style:{display:"flex",alignItems:"center",justifyContent:"center",padding:"1px 6px",marginLeft:"10px",fontSize:10,borderRadius:"12px",background:"pink",color:"#000"},children:"AI Beta"})]})}),Cr(bg,{tab:"mermaid",children:"Mermaid"})]}),Cr(Vs,{className:"ttd-dialog-content",tab:"mermaid",children:Cr(b4,{mermaidToExcalidrawLib:T})}),!("__fallback"in t)&&sa(Vs,{className:"ttd-dialog-content",tab:"text-to-diagram",children:[Cr("div",{className:"ttd-dialog-desc",children:"Currently we use Mermaid as a middle step, so you'll get best results if you describe a diagram, workflow, flow chart, and similar."}),sa(pg,{children:[Cr(Ws,{label:b("labels.prompt"),panelAction:{action:E,label:"Generate",icon:el},onTextSubmitInProgess:m,panelActionDisabled:c.length>Ys||u?.rateLimitRemaining===0,renderTopRight:()=>u?sa("div",{className:"ttd-dialog-rate-limit",style:{fontSize:12,marginLeft:"auto",color:u.rateLimitRemaining===0?"var(--color-danger)":void 0},children:[u.rateLimitRemaining," requests left today"]}):null,renderSubmitShortcut:()=>Cr(fg,{}),renderBottomRight:()=>{if(typeof i?.generatedResponse=="string")return sa("div",{className:"excalidraw-link",style:{marginLeft:"auto",fontSize:14},onClick:()=>{typeof i?.generatedResponse=="string"&&(em(i.generatedResponse),o({openDialog:{name:"ttd",tab:"mermaid"}}))},children:["View as Mermaid",Cr(ea,{icon:el})]});let A=c.length/Ys;return A>.8?sa("div",{style:{marginLeft:"auto",fontSize:12,fontFamily:"monospace",color:A>1?"var(--color-danger)":void 0},children:["Length: ",c.length,"/",Ys]}):null},children:Cr(ug,{onChange:d,input:l,placeholder:"Describe what you want to see...",onKeyboardSubmit:()=>{x.current()}})}),Cr(Ws,{label:"Preview",panelAction:{action:()=>{console.info("Panel action clicked"),mg({app:r,data:w})},label:"Insert",icon:el},children:Cr(gg,{canvasRef:n,error:I,loaded:T.loaded})})]})]})]})})})});import om from"clsx";import U9 from"react";import{Provider as G9,useAtom as V9,useAtomValue as W9}from"jotai";import{Fragment as k4,jsx as de,jsxs as mo}from"react/jsx-runtime";var Y9,K9,$9,A4,X9,M4,L4=y(()=>{"use strict";f();W();xe();q();qe();G();Gd();sI();bI();Yx();Kx();qi();Kg();$x();_I();BI();jh();UI();ul();t0();XI();Zx();Nr();we();jx();KE();QI();qd();kt();y0();Vd();V6();qx();Dr();lo();ne();jt();v0();bd();$6();X6();Ye();ln();vi();q6();a4();O0();Y9=({UIOptions:e})=>mo(Sr,{__fallback:!0,children:[de(Sr.DefaultItems.LoadScene,{}),de(Sr.DefaultItems.SaveToActiveFile,{}),e.canvasActions.export&&de(Sr.DefaultItems.Export,{}),e.canvasActions.saveAsImage&&de(Sr.DefaultItems.SaveAsImage,{}),de(Sr.DefaultItems.Help,{}),de(Sr.DefaultItems.ClearCanvas,{}),de(Sr.Separator,{}),de(Sr.Group,{title:"Excalidraw links",children:de(Sr.DefaultItems.Socials,{})}),de(Sr.Separator,{}),de(Sr.DefaultItems.ToggleTheme,{}),de(Sr.DefaultItems.ChangeCanvasBackground,{})]}),K9=()=>mo(lg,{__fallback:!0,children:[de(lg.Actions.SaveToDisk,{}),de(lg.Actions.ExportToImage,{})]}),$9=({actionManager:e,appState:t,files:r,setAppState:o,elements:n,canvas:i,onLockToggle:a,onHandToolToggle:l,onPenModeToggle:s,showExitZenModeBtn:c,renderTopRightUI:d,renderCustomStats:m,UIOptions:p,onExportImage:u,renderWelcomeScreen:h,onHomeButtonClick:E,children:x,app:T,isCollaborating:v,openAIKey:w,isOpenAIKeyPersisted:I,onOpenAIAPIKeyChange:L,onMagicSettingsConfirm:A,uiDisabled:M})=>{let D=_e(),O=NC(),[R,B]=V9(Vi,Ge),k=()=>p.canvasActions.export?de($I,{elements:n,appState:t,files:r,actionManager:e,exportOpts:p.canvasActions.export,canvas:i,setAppState:o}):null,z=()=>!p.canvasActions.saveAsImage||t.openDialog?.name!=="imageExport"?null:de(fI,{elements:n,appState:t,files:r,actionManager:e,onExportImage:u,onCloseRequest:()=>o({openDialog:null}),name:T.getName()}),ee=()=>mo("div",{style:{position:"relative"},children:[de(O.MainMenuTunnel.Out,{}),h&&de(O.WelcomeScreenMenuHintTunnel.Out,{})]}),j=()=>de(na,{heading:"selectedShapeActions",className:om("selected-shape-actions zen-mode-transition",{"transition-left":t.zenModeEnabled}),children:de(ir,{className:Em.SHAPE_ACTIONS_MENU,padding:2,style:{maxHeight:`${t.height-166}px`},children:de(Hh,{appState:t,elementsMap:T.scene.getNonDeletedElementsMap(),renderAction:e.renderAction})})}),ie=()=>{let ae=$a(t,n);return de($h,{side:"top",children:mo("div",{className:"App-menu App-menu_top",children:[mo(qt.Col,{gap:6,className:om("App-menu_top__left"),children:[ee(),ae&&j()]}),!t.viewModeEnabled&&de(na,{heading:"shapes",className:"shapes-section",children:fe=>mo("div",{style:{position:"relative"},children:[h&&de(O.WelcomeScreenToolbarHintTunnel.Out,{}),de(qt.Col,{gap:4,align:"start",children:mo(qt.Row,{gap:1,className:om("App-toolbar-container",{"zen-mode":t.zenModeEnabled}),children:[mo(ir,{padding:1,className:om("App-toolbar",{"zen-mode":t.zenModeEnabled}),children:[de(Xh,{appState:t,isMobile:D.editor.isMobile,device:D,app:T}),fe,mo(qt.Row,{gap:1,children:[de(Jh,{zenModeEnabled:t.zenModeEnabled,checked:t.penMode,onChange:()=>s(null),title:b("toolBar.penMode"),penDetected:t.penDetected}),de(Zh,{checked:t.activeTool.locked,onChange:a,title:b("toolBar.lock")}),de("div",{className:"App-toolbar__divider"}),de(eg,{checked:Go(t),onChange:()=>l(),title:b("toolBar.hand"),isMobile:!0}),de(Uh,{appState:t,activeTool:t.activeTool,UIOptions:p,app:T})]})]}),v&&de(ir,{style:{marginLeft:8,alignSelf:"center",height:"fit-content"},children:de(j6,{title:b("toolBar.laser"),checked:t.activeTool.type===St.laser,onChange:()=>T.setActiveTool({type:St.laser}),isMobile:!0})})]})})]})}),mo("div",{className:om("layer-ui__wrapper__top-right zen-mode-transition",{"transition-right":t.zenModeEnabled}),children:[t.collaborators.size>0&&de(tg,{collaborators:t.collaborators,userToFollow:t.userToFollow?.socketId||null}),d?.(D.editor.isMobile,t),!t.viewModeEnabled&&(!$||t.openSidebar?.name!==Vr.name)&&de(O.DefaultSidebarTriggerTunnel.Out,{})]})]})})},ke=()=>de(sg,{__fallback:!0,onDock:ae=>{ve("sidebar",`toggleDock (${ae?"dock":"undock"})`,`(${D.editor.isMobile?"mobile":"desktop"})`)}}),$=W9(jd,Ge);if(M)return null;let Y=mo(k4,{children:[x,de(Y9,{UIOptions:p}),de(sg.Trigger,{__fallback:!0,icon:td,title:Qo(b("toolBar.library")),onToggle:ae=>{ae&&ve("sidebar",`${Vr.name} (open)`,`button (${D.editor.isMobile?"mobile":"desktop"})`)},tab:Vr.defaultTab,children:b("toolBar.library")}),de(K9,{}),t.openDialog?.name==="ttd"&&de(N0,{__fallback:!0}),t.isLoading&&de(Mm,{delay:250}),t.errorMessage&&de(lI,{onClose:()=>o({errorMessage:null}),children:t.errorMessage}),R&&!D.editor.isMobile&&de(x3,{colorPickerType:R.colorPickerType,onCancel:()=>{B(null)},onChange:(ae,fe,De,{altKey:Le})=>{if(!(ae!=="elementBackground"&&ae!=="elementStroke"))if(De.length){for(let pr of De)H(pr,{[Le&&R.swapPreviewOnAlt?ae==="elementBackground"?"strokeColor":"backgroundColor":ae==="elementBackground"?"backgroundColor":"strokeColor"]:fe},!1),Ne.delete(pr);Ct.getScene(De[0])?.informMutation()}else o(ae==="elementBackground"?{currentItemBackgroundColor:fe}:{currentItemStrokeColor:fe})},onSelect:(ae,fe)=>{B(De=>De?.keepOpenOnAlt&&fe.altKey?De:null),R?.onSelect?.(ae,fe)}}),t.openDialog?.name==="help"&&de(zI,{onClose:()=>{o({openDialog:null})}}),t.openDialog?.name==="settings"&&de(i4,{openAIKey:w,isPersisted:I,onChange:L,onConfirm:(ae,fe)=>{let De=t.openDialog?.name==="settings"?t.openDialog?.source:"settings";o({openDialog:null},()=>{A(ae,fe,De)})},onClose:()=>{o({openDialog:null})}}),de(UC,{}),de(O.OverwriteConfirmDialogTunnel.Out,{}),z(),k(),t.pasteDialog.shown&&de(OI,{setAppState:o,appState:t,onClose:()=>o({pasteDialog:{shown:!1,data:null}})}),D.editor.isMobile&&de(DI,{app:T,onHomeButtonClick:E,appState:t,elements:n,actionManager:e,renderJSONExportDialog:k,renderImageExportDialog:z,setAppState:o,onLockToggle:a,onHandToolToggle:l,onPenModeToggle:s,renderTopRightUI:d,renderCustomStats:m,renderSidebars:ke,device:D,renderWelcomeScreen:h,UIOptions:p}),!D.editor.isMobile&&mo(k4,{children:[mo("div",{className:"layer-ui__wrapper",style:t.openSidebar&&$&&D.editor.canFitSidebar?{width:`calc(100% - ${Hy}px)`}:{},children:[h&&de(O.WelcomeScreenCenterTunnel.Out,{}),ie(),de(JI,{appState:t,actionManager:e,showExitZenModeBtn:c,renderWelcomeScreen:h}),t.showStats&&de(Qh,{appState:t,setAppState:o,elements:n,onClose:()=>{e.executeAction(ii)},renderCustomStats:m}),t.scrolledOutside&&de("button",{className:"scroll-back-to-content",onClick:()=>{o(ae=>({...gn(n,ae)}))},children:b("buttons.scrollBackToContent")})]}),ke()]})]});return de(PE.Provider,{value:t,children:de(G9,{scope:O.jotaiScope,children:de(Mx.Provider,{value:O,children:Y})})})},A4=e=>{let{suggestedBindings:t,startBoundElement:r,cursorButton:o,scrollX:n,scrollY:i,...a}=e;return a},X9=(e,t)=>{if(e.children!==t.children)return!1;let{canvas:r,appState:o,...n}=e,{canvas:i,appState:a,...l}=t;return rt(A4(o),A4(a),{selectedElementIds:rt,selectedGroupIds:rt})&&rt(n,l)},M4=U9.memo($9,X9)});var P4=y(()=>{});import{useCallback as Z9,useEffect as j9,useRef as q9}from"react";import{jsx as D4,jsxs as Q9}from"react/jsx-runtime";var J9,_4,R4=y(()=>{"use strict";f();ne();P4();Dt();J9=5e3,_4=({message:e,onClose:t,closable:r=!1,duration:o=J9,style:n})=>{let i=q9(0),a=o!==1/0,l=Z9(()=>{a&&(i.current=window.setTimeout(()=>t(),o))},[t,o,a]);return j9(()=>{if(a)return l(),()=>clearTimeout(i.current)},[l,e,o,a]),Q9("div",{className:"Toast",onMouseEnter:a?()=>clearTimeout(i?.current):void 0,onMouseLeave:a?l:void 0,style:n,children:[D4("p",{className:"Toast__message",children:e}),r&&D4(pe,{icon:to,"aria-label":"close",type:"icon",onClick:t,className:"close"})]})}});var B0,N4=y(()=>{"use strict";f();ne();be();ze();Je();B0=U({name:"viewMode",label:"labels.viewMode",paletteName:"Toggle view mode",icon:rl,viewMode:!0,trackEvent:{category:"canvas",predicate:e=>!e.viewModeEnabled},perform(e,t){return{appState:{...t,viewModeEnabled:!this.checked(t)},storeAction:_.NONE}},checked:e=>e.viewModeEnabled,predicate:(e,t,r)=>typeof r.viewModeEnabled>"u",keyTest:e=>!e[C.CTRL_OR_CMD]&&e.altKey&&e.code===Ee.R})});var xg,O4=y(()=>{"use strict";f();xe();Ye();mt();me();G();ln();xg=class e{scene;onSceneUpdated;constructor({scene:t,onSceneUpdated:r}){this.scene=t,this.onSceneUpdated=r}static loadedFontFaces=new Set;onFontsLoaded=t=>{if(t.every(o=>{let n=`${o.family}-${o.style}-${o.weight}`;return e.loadedFontFaces.has(n)?!0:(e.loadedFontFaces.add(n),!1)}))return!1;let r=!1;this.scene.mapElements(o=>V(o)&&!Pe(o)?(Ne.delete(o),r=!0,le(o,{...Wl(o,gt(o,this.scene.getNonDeletedElementsMap()),this.scene.getNonDeletedElementsMap())})):o),r&&this.onSceneUpdated()};loadFontsForElements=async t=>{let r=await Promise.all([...new Set(t.filter(o=>V(o)).map(o=>o.fontFamily))].map(o=>{let n=Ze({fontFamily:o,fontSize:16});if(!document.fonts?.check?.(n))return document.fonts?.load?.(n)}));this.onFontsLoaded(r.flat().filter(Boolean))}}});var B4,F4,z4,x2e,y2e,H4=y(()=>{"use strict";f();xe();dr();dr();be();G();Vl();Je();me();ne();ze();B4=(e,t)=>{let r=t.scene.getSelectedElements(e);return r.length===1&&re(r[0])},F4=U({name:"selectAllElementsInFrame",label:"labels.selectAllElementsInFrame",trackEvent:{category:"canvas"},perform:(e,t,r,o)=>{let n=o.scene.getSelectedElements(t).at(0)||null;if(re(n)){let i=eo(ye(e),n.id).filter(a=>!(a.type==="text"&&a.containerId));return{elements:e,appState:{...t,selectedElementIds:i.reduce((a,l)=>(a[l.id]=!0,a),{})},storeAction:_.CAPTURE}}return{elements:e,appState:t,storeAction:_.NONE}},predicate:(e,t,r,o)=>B4(t,o)}),z4=U({name:"removeAllElementsFromFrame",label:"labels.removeAllElementsFromFrame",trackEvent:{category:"history"},perform:(e,t,r,o)=>{let n=o.scene.getSelectedElements(t).at(0)||null;return re(n)?{elements:y1(e,n),appState:{...t,selectedElementIds:{[n.id]:!0}},storeAction:_.CAPTURE}:{elements:e,appState:t,storeAction:_.NONE}},predicate:(e,t,r,o)=>B4(t,o)}),x2e=U({name:"updateFrameRendering",label:"labels.updateFrameRendering",viewMode:!0,trackEvent:{category:"canvas"},perform:(e,t)=>({elements:e,appState:{...t,frameRendering:{...t.frameRendering,enabled:!t.frameRendering.enabled}},storeAction:_.NONE}),checked:e=>e.frameRendering.enabled}),y2e=U({name:"setFrameAsActiveTool",label:"toolBar.frame",trackEvent:{category:"toolbar"},icon:cd,viewMode:!1,perform:(e,t,r,o)=>{let n=tt(t,{type:"frame"});return qr(o.interactiveCanvas,{...t,activeTool:n}),{elements:e,appState:{...t,activeTool:tt(t,{type:"frame"})},storeAction:_.NONE}},keyTest:e=>!e[C.CTRL_OR_CMD]&&!e.shiftKey&&!e.altKey&&e.key.toLocaleLowerCase()===C.F})});var eN,U4,yg,Mo,di,tN,nm,W4,Y4,G4,K4,Ks,$4,bt,V4,F0,rN,oN,X4,Z4,j4,q4,J4=y(()=>{"use strict";f();W();dt();me();xr();be();Kt();Ti();eN=8,U4=99999,yg=e=>eN/e,Mo=class e{static referenceSnapPoints=null;static visibleGaps=null;static setReferenceSnapPoints=t=>{e.referenceSnapPoints=t};static getReferenceSnapPoints=()=>e.referenceSnapPoints;static setVisibleGaps=t=>{e.visibleGaps=t};static getVisibleGaps=()=>e.visibleGaps;static destroy=()=>{e.referenceSnapPoints=null,e.visibleGaps=null}},di=({event:e,appState:t,selectedElements:r})=>e?t.objectsSnapModeEnabled&&!e[C.CTRL_OR_CMD]||!t.objectsSnapModeEnabled&&e[C.CTRL_OR_CMD]&&t.gridSize===null:r.length===1&&r[0].type==="arrow"?!1:t.objectsSnapModeEnabled,tN=(e,t,r=.01)=>Math.abs(e-t)<=r,nm=(e,t,{omitCenter:r,boundingBoxCorners:o,dragOffset:n}={omitCenter:!1,boundingBoxCorners:!1})=>{let i=[];if(e.length===1){let a=e[0],[l,s,c,d,m,p]=oe(a,t);n&&(l+=n.x,c+=n.x,m+=n.x,s+=n.y,d+=n.y,p+=n.y);let u=(c-l)/2,h=(d-s)/2;if((a.type==="diamond"||a.type==="ellipse")&&!o){let E=Ke([l,s+h],[m,p],a.angle),x=Ke([l+u,s],[m,p],a.angle),T=Ke([c,s+h],[m,p],a.angle),v=Ke([l+u,d],[m,p],a.angle);i=r?[E,x,T,v]:[E,x,T,v,[m,p]]}else{let E=Ke([l,s],[m,p],a.angle),x=Ke([c,s],[m,p],a.angle),T=Ke([l,d],[m,p],a.angle),v=Ke([c,d],[m,p],a.angle);i=r?[E,x,T,v]:[E,x,T,v,[m,p]]}}else if(e.length>1){let[a,l,s,c]=lp(e,n??{x:0,y:0}),d=s-a,m=c-l,p=[a,l],u=[s,l],h=[a,c],E=[s,c],x=[a+d/2,l+m/2];i=r?[p,u,h,E]:[p,u,h,E,x]}return i.map(a=>[bt(a[0]),bt(a[1])])},W4=(e,t,r,o)=>{let n=t.filter(i=>re(i)).map(i=>i.id);return O1(e,t,r,o).filter(i=>!(i.frameId&&n.includes(i.frameId)))},Y4=(e,t,r,o)=>{let n=W4(e,t,r,o),i=Ra(n,o).filter(m=>!(m.length===1&&Pe(m[0]))).map(m=>Ae(m).map(p=>bt(p))),a=i.sort((m,p)=>m[0]-p[0]),l=[],s=0;e:for(let m=0;m<a.length;m++){let p=a[m];for(let u=m+1;u<a.length;u++){if(++s>U4)break e;let h=a[u],[,E,x,T]=p,[v,w,,I]=h;x<v&&pc([E,T],[w,I])&&l.push({startBounds:p,endBounds:h,startSide:[[x,E],[x,T]],endSide:[[v,w],[v,I]],length:v-x,overlap:uc([E,T],[w,I])})}}let c=i.sort((m,p)=>m[1]-p[1]),d=[];s=0;e:for(let m=0;m<c.length;m++){let p=c[m];for(let u=m+1;u<c.length;u++){if(++s>U4)break e;let h=c[u],[E,,x,T]=p,[v,w,I]=h;T<w&&pc([E,x],[v,I])&&d.push({startBounds:p,endBounds:h,startSide:[[E,T],[x,T]],endSide:[[v,w],[I,w]],length:w-T,overlap:uc([E,x],[v,I])})}}return{horizontalGaps:l,verticalGaps:d}},G4=(e,t,r,o,n,i,a)=>{if(!di({appState:r,event:o,selectedElements:e}))return[];if(e.length===0)return[];let l=Mo.getVisibleGaps();if(l){let{horizontalGaps:s,verticalGaps:c}=l,[d,m,p,u]=lp(e,t).map(x=>bt(x)),h=(d+p)/2,E=(m+u)/2;for(let x of s){if(!pc([m,u],x.overlap))continue;let T=x.startSide[0][0]+x.length/2,v=bt(T-h);if(x.length>p-d&&Math.abs(v)<=a.x){Math.abs(v)<a.x&&(n.length=0),a.x=Math.abs(v);let R={type:"gap",direction:"center_horizontal",gap:x,offset:v};n.push(R);continue}let[,,I]=x.endBounds,L=d-I,A=bt(x.length-L);if(Math.abs(A)<=a.x){Math.abs(A)<a.x&&(n.length=0),a.x=Math.abs(A);let R={type:"gap",direction:"side_right",gap:x,offset:A};n.push(R);continue}let[M,,,]=x.startBounds,D=M-p,O=bt(D-x.length);if(Math.abs(O)<=a.x){Math.abs(O)<a.x&&(n.length=0),a.x=Math.abs(O);let R={type:"gap",direction:"side_left",gap:x,offset:O};n.push(R);continue}}for(let x of c){if(!pc([d,p],x.overlap))continue;let T=x.startSide[0][1]+x.length/2,v=bt(T-E);if(x.length>u-m&&Math.abs(v)<=a.y){Math.abs(v)<a.y&&(i.length=0),a.y=Math.abs(v);let R={type:"gap",direction:"center_vertical",gap:x,offset:v};i.push(R);continue}let[,I,,]=x.startBounds,L=I-u,A=bt(L-x.length);if(Math.abs(A)<=a.y){Math.abs(A)<a.y&&(i.length=0),a.y=Math.abs(A);let R={type:"gap",direction:"side_top",gap:x,offset:A};i.push(R);continue}let[,,,M]=x.endBounds,D=bt(m-M),O=x.length-D;if(Math.abs(O)<=a.y){Math.abs(O)<a.y&&(i.length=0),a.y=Math.abs(O);let R={type:"gap",direction:"side_bottom",gap:x,offset:O};i.push(R);continue}}}},K4=(e,t,r,o)=>{let n=W4(e,t,r,o);return Ra(n,o).filter(i=>!(i.length===1&&Pe(i[0]))).flatMap(i=>nm(i,o))},Ks=(e,t,r,o,n,i,a)=>{if(!di({appState:r,event:o,selectedElements:e})||e.length===0&&t.length===0)return[];let l=Mo.getReferenceSnapPoints();if(l)for(let s of t)for(let c of l){let d=c[0]-s[0],m=c[1]-s[1];Math.abs(d)<=a.x&&(Math.abs(d)<a.x&&(n.length=0),n.push({type:"point",points:[s,c],offset:d}),a.x=Math.abs(d)),Math.abs(m)<=a.y&&(Math.abs(m)<a.y&&(i.length=0),i.push({type:"point",points:[s,c],offset:m}),a.y=Math.abs(m))}},$4=(e,t,r,o,n)=>{let i=ge(e,r);if(!di({appState:r,event:o,selectedElements:i})||i.length===0)return{snapOffset:{x:0,y:0},snapLines:[]};t.x=bt(t.x),t.y=bt(t.y);let a=[],l=[],s=yg(r.zoom.value),c={x:s,y:s},d=nm(i,n,{dragOffset:t});Ks(i,d,r,o,a,l,c),G4(i,t,r,o,a,l,c);let m={x:a[0]?.offset??0,y:l[0]?.offset??0};c.x=0,c.y=0,a.length=0,l.length=0;let p={x:bt(t.x+m.x),y:bt(t.y+m.y)};Ks(i,nm(i,n,{dragOffset:p}),r,o,a,l,c),G4(i,p,r,o,a,l,c);let u=F0(a,l),h=oN(i,p,[...a,...l].filter(E=>E.type==="gap"));return{snapOffset:m,snapLines:[...u,...h]}},bt=e=>Math.round(e*10**6)/10**6,V4=e=>{let t=new Map;for(let r of e){let o=r.join(",");t.has(o)||t.set(o,r)}return Array.from(t.values())},F0=(e,t)=>{let r={},o={};if(e.length>0){for(let n of e)if(n.type==="point"){let i=bt(n.points[0][0]);r[i]||(r[i]=[]),r[i].push(...n.points.map(a=>[bt(a[0]),bt(a[1])]))}}if(t.length>0){for(let n of t)if(n.type==="point"){let i=bt(n.points[0][1]);o[i]||(o[i]=[]),o[i].push(...n.points.map(a=>[bt(a[0]),bt(a[1])]))}}return Object.entries(r).map(([n,i])=>({type:"points",points:V4(i.map(a=>[Number(n),a[1]]).sort((a,l)=>a[1]-l[1]))})).concat(Object.entries(o).map(([n,i])=>({type:"points",points:V4(i.map(a=>[a[0],Number(n)]).sort((a,l)=>a[0]-l[0]))})))},rN=e=>{let t=new Map;for(let r of e){let o=r.points.flat().map(n=>[bt(n)]).join(",");t.has(o)||t.set(o,r)}return Array.from(t.values())},oN=(e,t,r)=>{let[o,n,i,a]=lp(e,t),l=[];for(let s of r){let[c,d,m,p]=s.gap.startBounds,[u,h,E,x]=s.gap.endBounds,T=uc([n,a],s.gap.overlap),v=uc([o,i],s.gap.overlap);switch(s.direction){case"center_horizontal":{if(T){let w=(T[0]+T[1])/2;l.push({type:"gap",direction:"horizontal",points:[[s.gap.startSide[0][0],w],[o,w]]},{type:"gap",direction:"horizontal",points:[[i,w],[s.gap.endSide[0][0],w]]})}break}case"center_vertical":{if(v){let w=(v[0]+v[1])/2;l.push({type:"gap",direction:"vertical",points:[[w,s.gap.startSide[0][1]],[w,n]]},{type:"gap",direction:"vertical",points:[[w,a],[w,s.gap.endSide[0][1]]]})}break}case"side_right":{if(T){let w=(T[0]+T[1])/2;l.push({type:"gap",direction:"horizontal",points:[[m,w],[u,w]]},{type:"gap",direction:"horizontal",points:[[E,w],[o,w]]})}break}case"side_left":{if(T){let w=(T[0]+T[1])/2;l.push({type:"gap",direction:"horizontal",points:[[i,w],[c,w]]},{type:"gap",direction:"horizontal",points:[[m,w],[u,w]]})}break}case"side_top":{if(v){let w=(v[0]+v[1])/2;l.push({type:"gap",direction:"vertical",points:[[w,a],[w,d]]},{type:"gap",direction:"vertical",points:[[w,p],[w,h]]})}break}case"side_bottom":{if(v){let w=(v[0]+v[1])/2;l.push({type:"gap",direction:"vertical",points:[[w,p],[w,h]]},{type:"gap",direction:"vertical",points:[[w,x],[w,n]]})}break}}}return rN(l.map(s=>({...s,points:s.points.map(c=>[bt(c[0]),bt(c[1])])})))},X4=(e,t,r,o,n,i)=>{if(!di({event:o,selectedElements:e,appState:r})||e.length===0||e.length===1&&!tN(e[0].angle,0))return{snapOffset:{x:0,y:0},snapLines:[]};let[a,l,s,c]=Ae(t);i&&(i.includes("e")?s+=n.x:i.includes("w")&&(a+=n.x),i.includes("n")?l+=n.y:i.includes("s")&&(c+=n.y));let d=[];if(i)switch(i){case"e":{d.push([s,l],[s,c]);break}case"w":{d.push([a,l],[a,c]);break}case"n":{d.push([a,l],[s,l]);break}case"s":{d.push([a,c],[s,c]);break}case"ne":{d.push([s,l]);break}case"nw":{d.push([a,l]);break}case"se":{d.push([s,c]);break}case"sw":{d.push([a,c]);break}}let m=yg(r.zoom.value),p={x:m,y:m},u=[],h=[];Ks(t,d,r,o,u,h,p);let E={x:u[0]?.offset??0,y:h[0]?.offset??0};p.x=0,p.y=0,u.length=0,h.length=0;let[x,T,v,w]=Ae(e).map(A=>bt(A));Ks(e,[[x,T],[x,w],[v,T],[v,w]],r,o,u,h,p);let L=F0(u,h);return{snapOffset:E,snapLines:L}},Z4=(e,t,r,o,n,i)=>{if(!di({event:r,selectedElements:[e],appState:t}))return{snapOffset:{x:0,y:0},snapLines:[]};let a=[[o.x+n.x,o.y+n.y]],l=yg(t.zoom.value),s={x:l,y:l},c=[],d=[];Ks([e],a,t,r,c,d,s);let m={x:c[0]?.offset??0,y:d[0]?.offset??0};s.x=0,s.y=0,c.length=0,d.length=0;let p=nm([e],i,{boundingBoxCorners:!0,omitCenter:!0});Ks([e],p,t,r,c,d,s);let u=F0(c,d);return{snapOffset:m,snapLines:u}},j4=(e,t,r,o,n)=>{if(!di({event:o,selectedElements:[],appState:t}))return{originOffset:{x:0,y:0},snapLines:[]};let i=O1(e,[],t,n),a=yg(t.zoom.value),l={x:a,y:a},s=[],c=[];for(let d of i){let m=nm([d],n);for(let p of m){let u=p[0]-r.x;Math.abs(u)<=Math.abs(l.x)&&(Math.abs(u)<Math.abs(l.x)&&(c.length=0),c.push({type:"pointer",points:[p,[p[0],r.y]],direction:"vertical"}),l.x=u);let h=p[1]-r.y;Math.abs(h)<=Math.abs(l.y)&&(Math.abs(h)<Math.abs(l.y)&&(s.length=0),s.push({type:"pointer",points:[p,[r.x,p[1]]],direction:"horizontal"}),l.y=h)}}return{originOffset:{x:c.length>0?c[0].points[0][0]-r.x:0,y:s.length>0?s[0].points[0][1]-r.y:0},snapLines:[...c,...s]}},q4=e=>e===St.rectangle||e===St.ellipse||e===St.diamond||e===St.frame||e===St.magicframe||e===St.image});import{jsx as Lo,jsxs as Q4}from"react/jsx-runtime";var nN,eA,tA=y(()=>{"use strict";f();Ls();nN=()=>Q4("div",{"data-testid":"brave-measure-text-error",children:[Lo("p",{children:Lo(wr,{i18nKey:"errors.brave_measure_text_error.line1",bold:e=>Lo("span",{style:{fontWeight:600},children:e})})}),Lo("p",{children:Lo(wr,{i18nKey:"errors.brave_measure_text_error.line2",bold:e=>Lo("span",{style:{fontWeight:600},children:e})})}),Lo("p",{children:Lo(wr,{i18nKey:"errors.brave_measure_text_error.line3",link:e=>Lo("a",{href:"http://docs.excalidraw.com/docs/@excalidraw/excalidraw/faq#turning-off-aggresive-block-fingerprinting-in-brave-browser",children:e})})}),Lo("p",{children:Lo(wr,{i18nKey:"errors.brave_measure_text_error.line4",issueLink:e=>Lo("a",{href:"https://github.com/excalidraw/excalidraw/issues/new",children:e}),discordLink:e=>Q4("a",{href:"https://discord.gg/UexuTaE",children:[e,"."]})})})]}),eA=nN});var wg,ca,iN,rA,z0,tm,H0=y(()=>{"use strict";f();W();xe();Eo();hn();mt();G();dc();Oo();bo();wg={width:100,height:0},ca=100,iN=(e,t,r)=>{let o=$t({x:0,y:0,textAlign:Ei.CENTER,verticalAlign:Tt.MIDDLE,...t,containerId:e.id,strokeColor:t.strokeColor||e.strokeColor});return Object.assign(e,{boundElements:(e.boundElements||[]).concat({type:"text",id:o.id})}),Ht(o,e,r),[e,o]},rA=(e,t,r,o,n)=>{let i,a;if(Object.assign(e,{startBinding:e?.startBinding||null,endBinding:e.endBinding||null}),t){let d=t?.width??ca,m=t?.height??ca,p;t.id&&(p=o.getElement(t.id),p||console.error(`No element for start binding with id ${t.id} found`));let u=t.x||e.x-d,h=t.y||e.y-m/2,E=p?p.type:t.type;if(E){if(E==="text"){let x="";p&&p.type==="text"?x=p.text:t.type==="text"&&(x=t.text),x||console.error(`No text found for start binding text element for ${e.id}`),i=$t({x:u,y:h,type:"text",...p,...t,text:x}),Object.assign(i,{x:t.x||e.x-i.width,y:t.y||e.y-i.height/2})}else switch(E){case"rectangle":case"ellipse":case"diamond":{i=Jr({x:u,y:h,width:d,height:m,...p,...t,type:E});break}default:No(e,`Unhandled element start type "${t.type}"`,!0)}zl(e,i,"start",n)}}if(r){let d=r?.height??ca,m=r?.width??ca,p;r.id&&(p=o.getElement(r.id),p||console.error(`No element for end binding with id ${r.id} found`));let u=r.x||e.x+e.width,h=r.y||e.y-d/2,E=p?p.type:r.type;if(E){if(E==="text"){let x="";p&&p.type==="text"?x=p.text:r.type==="text"&&(x=r.text),x||console.error(`No text found for end binding text element for ${e.id}`),a=$t({x:u,y:h,type:"text",...p,...r,text:x}),Object.assign(a,{y:r.y||e.y-a.height/2})}else switch(E){case"rectangle":case"ellipse":case"diamond":{a=Jr({x:u,y:h,width:m,height:d,...p,...r,type:E});break}default:No(e,`Unhandled element end type "${E}"`,!0)}zl(e,a,"end",n)}}if(e.points.length<2)return{linearElement:e,startBoundElement:i,endBoundElement:a};let l=e.points.length-1,s=.5,c=rn(e.points);return e.points[l][0]>e.points[l-1][0]&&(c[0][0]=s,c[l][0]-=s),e.points[l][0]<e.points[l-1][0]&&(c[0][0]=-s,c[l][0]+=s),e.points[l][1]>e.points[l-1][1]&&(c[0][1]=s,c[l][1]-=s),e.points[l][1]<e.points[l-1][1]&&(c[0][1]=-s,c[l][1]+=s),Object.assign(e,{points:c}),{linearElement:e,startBoundElement:i,endBoundElement:a}},z0=class{excalidrawElements=new Map;add=t=>{t&&this.excalidrawElements.set(t.id,t)};getElements=()=>fr(Array.from(this.excalidrawElements.values()));getElementsMap=()=>Yr(X(this.getElements()));getElement=t=>this.excalidrawElements.get(t)},tm=(e,t)=>{if(!e)return[];let r=rn(e),o=new z0,n=new Map,i=new Map;for(let l of r){let s,c=l.id;switch(t?.regenerateIds!==!1&&Object.assign(l,{id:zt()}),l.type){case"rectangle":case"ellipse":case"diamond":{let m=l?.label?.text&&l.width===void 0?0:l?.width||ca,p=l?.label?.text&&l.height===void 0?0:l?.height||ca;s=Jr({...l,width:m,height:p});break}case"line":{let m=l.width||wg.width,p=l.height||wg.height;s=xo({width:m,height:p,points:[[0,0],[m,p]],...l});break}case"arrow":{let m=l.width||wg.width,p=l.height||wg.height;s=xo({width:m,height:p,endArrowhead:"arrow",points:[[0,0],[m,p]],...l}),Object.assign(s,Hm(s.points));break}case"text":{let m=l?.fontFamily||tr,p=l?.fontSize||Ot,u=l?.lineHeight||Xr(m),h=l.text??"",E=Li(h),x=Ho(E,Ze({fontFamily:m,fontSize:p}),u);s=$t({width:x.width,height:x.height,fontFamily:m,fontSize:p,...l});break}case"image":{s=Mc({width:l?.width||ca,height:l?.height||ca,...l});break}case"frame":{s=bp({x:0,y:0,...l});break}case"magicframe":{s=kc({x:0,y:0,...l});break}case"freedraw":case"iframe":case"embeddable":{s=l;break}default:s=l,No(l,`Unhandled element type "${l.type}"`,!0)}o.getElement(s.id)?console.error(`Duplicate id found for ${s.id}`):(o.add(s),n.set(s.id,l),c&&i.set(c,s.id))}let a=o.getElementsMap();for(let[l,s]of n){let c=o.getElement(l);switch(s.type){case"rectangle":case"ellipse":case"diamond":case"arrow":{if(s.label?.text){let[d,m]=iN(c,s?.label,a);if(o.add(d),o.add(m),d.type==="arrow"){let p=s.type==="arrow"?s?.start:void 0,u=s.type==="arrow"?s?.end:void 0;if(p&&p.id){let T=i.get(p.id);T&&Object.assign(p,{id:T})}if(u&&u.id){let T=i.get(u.id);T&&Object.assign(u,{id:T})}let{linearElement:h,startBoundElement:E,endBoundElement:x}=rA(d,p,u,o,a);d=h,o.add(h),o.add(E),o.add(x)}}else switch(s.type){case"arrow":{let{start:d,end:m}=s;if(d&&d.id){let E=i.get(d.id);Object.assign(d,{id:E})}if(m&&m.id){let E=i.get(m.id);Object.assign(m,{id:E})}let{linearElement:p,startBoundElement:u,endBoundElement:h}=rA(c,d,m,o,a);o.add(p),o.add(u),o.add(h);break}}break}}}for(let[l,s]of n){if(s.type!=="frame"&&s.type!=="magicframe")continue;let c=o.getElement(l);if(!c)throw new Error(`Excalidraw element with id ${l} doesn't exist`);let d=[];s.children.forEach(v=>{let w=i.get(v);if(!w)throw new Error(`Element with ${v} wasn't mapped correctly`);let I=o.getElement(w);if(!I)throw new Error(`Frame element with id ${w} doesn't exist`);Object.assign(I,{frameId:c.id}),I?.boundElements?.forEach(L=>{let A=o.getElement(L.id);if(!A)throw new Error(`Bound element with id ${L.id} doesn't exist`);Object.assign(A,{frameId:c.id}),d.push(A)}),d.push(I)});let[m,p,u,h]=Ae(d),E=10;m=m-E,p=p-E,u=u+E,h=h+E;let x=Math.max(c?.width,u-m),T=Math.max(c?.height,h-p);Object.assign(c,{x:m,y:p,width:x,height:T})}return o.getElements()}});import{unstable_batchedUpdates as oA}from"react-dom";import{version as aN}from"react";var ut,vg,Tg,Sg=y(()=>{"use strict";f();G();ut=e=>t=>{oA(e,t)},vg=e=>Ml(t=>{oA(e,t)}),Tg=(()=>{let e;try{let r=aN.split(".");e=Number(r[0])>17}catch{e=!1}let t=!1;return()=>window.EXCALIDRAW_THROTTLE_RENDER===!0?e?!0:(t||(t=!0,console.warn("Excalidraw: render throttling is disabled on React versions < 18.")),!1):!1})()});var lN,sN,nA,iA,aA,cN,dN,lA,Po,mN,sA=y(()=>{"use strict";f();W();lN="#ff6b6b",sN="#ff0000",nA=1,iA=2,aA=(e,t)=>{if(!t.snapLines.length)return;let r=t.theme===se.LIGHT||t.zenModeEnabled?lN:sN,o=(t.zenModeEnabled?nA*1.5:nA)/t.zoom.value;e.save(),e.translate(t.scrollX,t.scrollY);for(let n of t.snapLines)n.type==="pointer"?(e.lineWidth=o,e.strokeStyle=r,dN(n,e,t)):n.type==="gap"?(e.lineWidth=o,e.strokeStyle=r,mN(n.points[0],n.points[1],n.direction,t,e)):n.type==="points"&&(e.lineWidth=o,e.strokeStyle=r,cN(n,e,t));e.restore()},cN=(e,t,r)=>{if(!r.zenModeEnabled){let o=e.points[0],n=e.points[e.points.length-1];Po(o,n,t)}for(let o of e.points)lA(o,r,t)},dN=(e,t,r)=>{lA(e.points[0],r,t),r.zenModeEnabled||Po(e.points[0],e.points[1],t)},lA=([e,t],r,o)=>{o.save();let n=(r.zenModeEnabled?iA*1.5:iA)/r.zoom.value;o.beginPath(),o.moveTo(e-n,t-n),o.lineTo(e+n,t+n),o.moveTo(e+n,t-n),o.lineTo(e-n,t+n),o.stroke(),o.restore()},Po=(e,t,r)=>{r.beginPath(),r.lineTo(...e),r.lineTo(...t),r.stroke()},mN=(e,t,r,o,n)=>{let i=8/o.zoom.value,a=i/2,l=i/4;if(r==="horizontal"){let s=[(e[0]+t[0])/2,e[1]];o.zenModeEnabled||Po([e[0],e[1]-i],[e[0],e[1]+i],n),Po([s[0]-l,s[1]-a],[s[0]-l,s[1]+a],n),Po([s[0]+l,s[1]-a],[s[0]+l,s[1]+a],n),o.zenModeEnabled||(Po([t[0],t[1]-i],[t[0],t[1]+i],n),Po(e,t,n))}else{let s=[e[0],(e[1]+t[1])/2];o.zenModeEnabled||Po([e[0]-i,e[1]],[e[0]+i,e[1]],n),Po([s[0]-a,s[1]-l],[s[0]+a,s[1]-l],n),Po([s[0]-a,s[1]+l],[s[0]+a,s[1]+l],n),o.zenModeEnabled||(Po([t[0]-i,t[1]],[t[0]+i,t[1]],n),Po(e,t,n))}}});import Cg from"open-color";var pN,G0,im,uN,Ig,hN,gN,fN,dA,bN,EN,xN,U0,cA,mA,V0,pA,W0=y(()=>{"use strict";f();xe();GE();qh();sn();Id();xr();Jc();G();W();sA();Eo();or();c1();me();pN=(e,t,r)=>{let{elementId:o,hoverPointIndex:n}=t.selectedLinearElement;if(t.editingLinearElement?.selectedPointsIndices?.includes(n))return;let i=Z.getElement(o,r);if(!i)return;let a=Z.getPointAtIndexGlobalCoordinates(i,n,r);e.save(),e.translate(t.scrollX,t.scrollY),G0(a,e,t),e.restore()},G0=(e,t,r)=>{t.fillStyle="rgba(105, 101, 219, 0.4)",Kc(t,e[0],e[1],Z.POINT_HANDLE_SIZE/r.zoom.value,!1)},im=(e,t,r,o,n,i,a,l,s=!1,c=0)=>{e.save(),e.translate(i,a),e.rotate(l),s&&e.fillRect(t-i,r-a,o,n),c&&e.roundRect?(e.beginPath(),e.roundRect(t-i,r-a,o,n,c),e.stroke(),e.closePath()):e.strokeRect(t-i,r-a,o,n),e.restore()},uN=(e,t,r,o,n,i)=>{e.save(),e.translate(o,n),e.rotate(i),e.beginPath(),e.moveTo(0,r/2),e.lineTo(t/2,0),e.lineTo(0,-r/2),e.lineTo(-t/2,0),e.closePath(),e.stroke(),e.restore()},Ig=(e,t,r,o,n,i=!1)=>{e.strokeStyle="#5e5ad8",e.setLineDash([]),e.fillStyle="rgba(255, 255, 255, 0.9)",n?e.fillStyle="rgba(134, 131, 226, 0.9)":i&&(e.fillStyle="rgba(177, 151, 252, 0.7)"),Kc(e,r[0],r[1],o/t.zoom.value,!i)},hN=(e,t,r,o,n,i)=>{e.beginPath(),e.ellipse(o,n,t/2,r/2,i,0,Math.PI*2),e.stroke()},gN=(e,t,r)=>{let[o,n,i,a]=oe(t,r),l=i-o,s=a-n,c=Tc(t,l,s),d=4;e.strokeStyle="rgba(0,0,0,.05)",e.lineWidth=c-d;let m=d/2+c/2;switch(t.type){case"rectangle":case"text":case"image":case"iframe":case"embeddable":case"frame":case"magicframe":im(e,o-m,n-m,l+m*2,s+m*2,o+l/2,n+s/2,t.angle);break;case"diamond":let p=Math.hypot(l,s),u=m*p/s,h=m*p/l;uN(e,l+u*2,s+h*2,o+l/2,n+s/2,t.angle);break;case"ellipse":hN(e,l+m*2,s+m*2,o+l/2,n+s/2,t.angle);break}},fN=(e,t,r)=>{let[o,n,i]=t,a=Tc(i,i.width,i.height);e.strokeStyle="rgba(0,0,0,0)",e.fillStyle="rgba(0,0,0,.05)",(n==="both"?[0,-1]:n==="start"?[0]:[-1]).forEach(s=>{let[c,d]=Z.getPointAtIndexGlobalCoordinates(o,s,r);Kc(e,c,d,a)})},dA=(e,t,r,o=fi*2)=>{let{angle:n,elementX1:i,elementY1:a,elementX2:l,elementY2:s,selectionColors:c,cx:d,cy:m,dashed:p,activeEmbeddable:u}=r,h=l-i,E=s-a,x=o/t.zoom.value,T=8/t.zoom.value,v=4/t.zoom.value;e.save(),e.translate(t.scrollX,t.scrollY),e.lineWidth=(u?4:1)/t.zoom.value;let w=c.length;for(let I=0;I<w;++I)e.strokeStyle=c[I],p&&e.setLineDash([T,v+(T+v)*(w-1)]),e.lineDashOffset=(T+v)*I,im(e,i-x,a-x,h+x*2,E+x*2,d,m,n);e.restore()},bN=(e,t,r,o)=>{let n=Array.isArray(r)?fN:gN;e.save(),e.translate(t.scrollX,t.scrollY),n(e,r,o),e.restore()},EN=(e,t,r,o)=>{let[n,i,a,l]=oe(r,o),s=a-n,c=l-i;e.strokeStyle="rgb(0,118,255)",e.lineWidth=et.strokeWidth/t.zoom.value,e.save(),e.translate(t.scrollX,t.scrollY),im(e,n,i,s,c,n+s/2,i+c/2,r.angle,!1,et.radius/t.zoom.value),e.restore()},xN=(e,t,r)=>{let o=r.filter(l=>l.groupIds.length===0),n=r.filter(l=>l.groupIds.length>0),i=l=>{let[s,c,d,m]=Ae(l);return{angle:0,elementX1:s,elementX2:d,elementY1:c,elementY2:m,selectionColors:["rgb(0,118,255)"],dashed:!1,cx:s+(d-s)/2,cy:c+(m-c)/2,activeEmbeddable:!1}},a=l=>{let s=it(r,l);return i(s)};Object.entries(cp(n,t)).filter(([l,s])=>s).map(([l,s])=>l).map(l=>a(l)).concat(o.map(l=>i([l]))).forEach(l=>dA(e,t,l))},U0=(e,t,r,o)=>{if(!t.selectedLinearElement)return;e.save(),e.translate(t.scrollX,t.scrollY),e.lineWidth=1/t.zoom.value;let n=Z.getPointsGlobalCoordinates(r,o),{POINT_HANDLE_SIZE:i}=Z,a=t.editingLinearElement?i:i/2;n.forEach((s,c)=>{let d=!!t.editingLinearElement?.selectedPointsIndices?.includes(c);Ig(e,t,s,a,d)}),Z.getEditorMidPoints(r,o,t).filter(s=>s!==null).forEach(s=>{t?.selectedLinearElement?.segmentMidPointHoveredCoords&&Z.arePointsEqual(s,t.selectedLinearElement.segmentMidPointHoveredCoords)?t.editingLinearElement?(Ig(e,t,s,a,!1),G0(s,e,t)):(G0(s,e,t),Ig(e,t,s,a,!1)):(t.editingLinearElement||n.length===2)&&Ig(e,t,s,i/2,!1,!0)}),e.restore()},cA=(e,t,r,o,n)=>{Object.keys(o).forEach(i=>{let a=o[i];if(a!==void 0){let[l,s,c,d]=a;e.save(),e.lineWidth=1/r.zoom.value,t.selectionColor&&(e.strokeStyle=t.selectionColor),i==="rotation"?Kc(e,l+c/2,s+d/2,c/2):e.roundRect?(e.beginPath(),e.roundRect(l,s,c,d,2/r.zoom.value),e.fill(),e.stroke()):im(e,l,s,c,d,l+c/2,s+d/2,n,!0),e.restore()}})},mA=({canvas:e,elementsMap:t,visibleElements:r,selectedElements:o,scale:n,appState:i,renderConfig:a,device:l})=>{if(e===null)return{atLeastOneVisibleElement:!1,elementsMap:t};let[s,c]=Bp(e,n),d=Fp({canvas:e,scale:n,normalizedWidth:s,normalizedHeight:c});d.save(),d.scale(i.zoom.value,i.zoom.value);let m;if(r.forEach(h=>{i.editingLinearElement?.elementId===h.id&&h&&(m=h)}),m&&U0(d,i,m,t),i.selectionElement)try{bT(i.selectionElement,d,i)}catch(h){console.error(h)}i.isBindingEnabled&&i.suggestedBindings.filter(h=>h!=null).forEach(h=>{bN(d,i,h,t)}),i.frameToHighlight&&EN(d,i,i.frameToHighlight,t),i.elementsToHighlight&&xN(d,i,i.elementsToHighlight);let p=o.some(h=>re(h));if(o.length===1&&i.editingLinearElement?.elementId===o[0].id&&U0(d,i,o[0],t),i.selectedLinearElement&&i.selectedLinearElement.hoverPointIndex>=0&&pN(d,i,t),!i.multiElement&&!i.editingLinearElement){let h=su(o,i);o.length===1&&ce(o[0])&&i.selectedLinearElement?.elementId===o[0].id&&!o[0].locked&&U0(d,i,o[0],t);let x=a.selectionColor||Cg.black;if(h){let T=X(o),v=[];for(let I of t.values()){let L=[];T.has(I.id)&&!sp(i,I)&&L.push(x);let A=a.remoteSelectedElementIds.get(I.id);if(A&&L.push(...A.map(M=>cl(M,i.collaborators.get(M)))),L.length){let[M,D,O,R,B,k]=oe(I,t,!0);v.push({angle:I.angle,elementX1:M,elementY1:D,elementX2:O,elementY2:R,selectionColors:L,dashed:!!A,cx:B,cy:k,activeEmbeddable:i.activeEmbeddable?.element===I&&i.activeEmbeddable.state==="active"})}}let w=I=>{let L=it(t,I),[A,M,D,O]=Ae(L);v.push({angle:0,elementX1:A,elementX2:D,elementY1:M,elementY2:O,selectionColors:[Cg.black],dashed:!0,cx:A+(D-A)/2,cy:M+(O-M)/2,activeEmbeddable:!1})};for(let I of Vn(i))w(I);i.editingGroupId&&w(i.editingGroupId),v.forEach(I=>dA(d,i,I))}if(d.save(),d.translate(i.scrollX,i.scrollY),o.length===1){d.fillStyle=Cg.white;let T=qc(o[0],i.zoom,t,"mouse",Ka(l));!i.viewModeEnabled&&h&&cA(d,a,i,T,o[0].angle)}else if(o.length>1&&!i.isRotating){let T=fi*2/i.zoom.value;d.fillStyle=Cg.white;let[v,w,I,L]=Ae(o),A=d.getLineDash();d.setLineDash([2/i.zoom.value]);let M=d.lineWidth;d.lineWidth=1/i.zoom.value,d.strokeStyle=x,im(d,v-T,w-T,I-v+T*2,L-w+T*2,(v+I)/2,(w+L)/2,0),d.lineWidth=M,d.setLineDash(A);let D=ms([v,w,I,L,(v+I)/2,(w+L)/2],0,i.zoom,"mouse",p?{...Ka(l),rotation:!0}:Ka(l));o.some(O=>!O.locked)&&cA(d,a,i,D,0)}d.restore()}aA(d,i),d.restore(),SS({context:d,renderConfig:a,appState:i,normalizedWidth:s,normalizedHeight:c});let u;return a.renderScrollbars&&(u=CI(r,s,c,i),d.save(),d.fillStyle=SI,d.strokeStyle="rgba(255,255,255,0.8)",[u.horizontal,u.vertical].forEach(h=>{h&&sh(d,h.x,h.y,h.width,h.height,An/2)}),d.restore()),{scrollBars:u,atLeastOneVisibleElement:r.length>0,elementsMap:t}},V0=Ml(e=>{let t=mA(e);e.callback?.(t)},{trailing:!0}),pA=(e,t)=>{if(t){V0(e);return}let r=mA(e);return e.callback(r),r}});import yN,{useEffect as wN,useRef as vN}from"react";import{jsx as CN}from"react/jsx-runtime";var TN,uA,SN,Y0,hA=y(()=>{"use strict";f();G();W();q();Sg();W0();TN=e=>{let t=vN(!1);return wN(()=>{if(!t.current){t.current=!0;return}let r=new Map,o=new Map,n=new Map,i=new Map,a=new Map;e.appState.collaborators.forEach((s,c)=>{if(s.selectedElementIds)for(let d of Object.keys(s.selectedElementIds))n.has(d)||n.set(d,[]),n.get(d).push(c);!s.pointer||s.pointer.renderCursor===!1||(s.username&&i.set(c,s.username),s.userState&&a.set(c,s.userState),o.set(c,Vt({sceneX:s.pointer.x,sceneY:s.pointer.y},e.appState)),r.set(c,s.button))});let l=e.containerRef?.current&&getComputedStyle(e.containerRef.current).getPropertyValue("--color-selection")||"#6965db";pA({canvas:e.canvas,elementsMap:e.elementsMap,visibleElements:e.visibleElements,selectedElements:e.selectedElements,scale:window.devicePixelRatio,appState:e.appState,renderConfig:{remotePointerViewportCoords:o,remotePointerButton:r,remoteSelectedElementIds:n,remotePointerUsernames:i,remotePointerUserStates:a,selectionColor:l,renderScrollbars:!1},device:e.device,callback:e.renderInteractiveSceneCallback},Tg())}),CN("canvas",{className:"excalidraw__canvas interactive",style:{width:e.appState.width,height:e.appState.height,cursor:e.appState.viewModeEnabled?Re.GRAB:Re.AUTO},width:e.appState.width*e.scale,height:e.appState.height*e.scale,ref:e.handleCanvasRef,onContextMenu:e.onContextMenu,onPointerMove:e.onPointerMove,onPointerUp:e.onPointerUp,onPointerCancel:e.onPointerCancel,onTouchMove:e.onTouchMove,onPointerDown:e.onPointerDown,onDoubleClick:e.appState.viewModeEnabled?void 0:e.onDoubleClick,children:b("labels.drawingCanvas")})},uA=e=>({zoom:e.zoom,scrollX:e.scrollX,scrollY:e.scrollY,width:e.width,height:e.height,viewModeEnabled:e.viewModeEnabled,editingGroupId:e.editingGroupId,editingLinearElement:e.editingLinearElement,selectedElementIds:e.selectedElementIds,frameToHighlight:e.frameToHighlight,offsetLeft:e.offsetLeft,offsetTop:e.offsetTop,theme:e.theme,pendingImageElementId:e.pendingImageElementId,selectionElement:e.selectionElement,selectedGroupIds:e.selectedGroupIds,selectedLinearElement:e.selectedLinearElement,multiElement:e.multiElement,isBindingEnabled:e.isBindingEnabled,suggestedBindings:e.suggestedBindings,isRotating:e.isRotating,elementsToHighlight:e.elementsToHighlight,collaborators:e.collaborators,activeEmbeddable:e.activeEmbeddable,snapLines:e.snapLines,zenModeEnabled:e.zenModeEnabled}),SN=(e,t)=>e.selectionNonce!==t.selectionNonce||e.versionNonce!==t.versionNonce||e.scale!==t.scale||e.elementsMap!==t.elementsMap||e.visibleElements!==t.visibleElements||e.selectedElements!==t.selectedElements?!1:rt(uA(e.appState),uA(t.appState)),Y0=yN.memo(TN,SN)});import IN,{useEffect as AN,useRef as gA}from"react";import{jsx as LN}from"react/jsx-runtime";var kN,fA,MN,K0,bA=y(()=>{"use strict";f();Up();G();Sg();kN=e=>{let t=gA(null),r=gA(!1);return AN(()=>{let o=t.current;if(!o)return;let n=e.canvas;r.current||(r.current=!0,o.replaceChildren(n),n.classList.add("excalidraw__canvas","static"));let i=`${e.appState.width}px`,a=`${e.appState.height}px`;n.style.width!==i&&(n.style.width=i),n.style.height!==a&&(n.style.height=a);let l=e.appState.width*e.scale,s=e.appState.height*e.scale;n.width!==l&&(n.width=l),n.height!==s&&(n.height=s),Hp({canvas:n,rc:e.rc,scale:e.scale,elementsMap:e.elementsMap,allElementsMap:e.allElementsMap,visibleElements:e.visibleElements,appState:e.appState,renderConfig:e.renderConfig},Tg())}),LN("div",{className:"excalidraw__canvas-wrapper",ref:t})},fA=e=>({zoom:e.zoom,scrollX:e.scrollX,scrollY:e.scrollY,width:e.width,height:e.height,viewModeEnabled:e.viewModeEnabled,offsetLeft:e.offsetLeft,offsetTop:e.offsetTop,theme:e.theme,pendingImageElementId:e.pendingImageElementId,shouldCacheIgnoreZoom:e.shouldCacheIgnoreZoom,exportScale:e.exportScale,selectedElementsAreBeingDragged:e.selectedElementsAreBeingDragged,gridSize:e.gridSize,frameRendering:e.frameRendering,selectedElementIds:e.selectedElementIds,frameToHighlight:e.frameToHighlight,editingGroupId:e.editingGroupId}),MN=(e,t)=>e.versionNonce!==t.versionNonce||e.scale!==t.scale||e.elementsMap!==t.elementsMap||e.visibleElements!==t.visibleElements?!1:rt(fA(e.appState),fA(t.appState))&&rt(e.renderConfig,t.renderConfig),K0=IN.memo(kN,MN)});var EA=y(()=>{"use strict";f();hA();bA()});var am,xA=y(()=>{"use strict";f();Ya();me();W0();Up();G();am=class{scene;constructor(t){this.scene=t}getRenderableElements=(()=>{let t=({elementsMap:o,zoom:n,offsetLeft:i,offsetTop:a,scrollX:l,scrollY:s,height:c,width:d})=>{let m=[];for(let p of o.values())Wa(p,d,c,{zoom:n,offsetLeft:i,offsetTop:a,scrollX:l,scrollY:s},o)&&m.push(p);return m},r=({elements:o,editingElement:n,pendingImageElementId:i})=>{let a=Yr(new Map);for(let l of o)ho(l)&&i===l.id||(!n||n.type!=="text"||l.id!==n.id)&&a.set(l.id,l);return a};return sw(({zoom:o,offsetLeft:n,offsetTop:i,scrollX:a,scrollY:l,height:s,width:c,editingElement:d,pendingImageElementId:m,versionNonce:p})=>{let u=this.scene.getNonDeletedElements(),h=r({elements:u,editingElement:d,pendingImageElementId:m}),E=t({elementsMap:h,zoom:o,offsetLeft:n,offsetTop:i,scrollX:a,scrollY:l,height:s,width:c});return{elementsMap:h,visibleElements:E}})})();destroy(){V0.cancel(),d1.cancel(),this.getRenderableElements.clear()}}});var yA=y(()=>{});import{useEffect as PN,useRef as DN}from"react";import{jsx as wA}from"react/jsx-runtime";var vA,TA=y(()=>{"use strict";f();yA();vA=({trails:e})=>{let t=DN(null);return PN(()=>{if(t.current)for(let r of e)r.start(t.current);return()=>{for(let r of e)r.stop()}},e),wA("div",{className:"SVGLayer",children:wA("svg",{ref:t})})}});var SA=y(()=>{});import{jsx as NN}from"react/jsx-runtime";var _N,RN,$0,CA=y(()=>{"use strict";f();G();xe();we();SA();_N=5,RN=(e,t,r)=>{let[o,n]=oe(e,r),{x:i,y:a}=Vt({sceneX:o+e.width,sceneY:n},t),l=i-t.offsetLeft+10,s=a-t.offsetTop;return{x:l,y:s}},$0=({children:e,element:t,elementsMap:r})=>{let o=As();if(o.contextMenu||o.draggingElement||o.resizingElement||o.isRotating||o.openMenu||o.viewModeEnabled)return null;let{x:n,y:i}=RN(t,o,r);return NN("div",{className:"excalidraw-canvas-buttons",style:{top:`${i}px`,left:`${n}px`,padding:_N},children:e})}});async function IA({image:e,apiKey:t,text:r,theme:o=se.LIGHT}){let n={model:"gpt-4-vision-preview",max_tokens:4096,temperature:.1,messages:[{role:"system",content:ON},{role:"user",content:[{type:"image_url",image_url:{url:e,detail:"high"}},{type:"text",text:`Above is the reference wireframe. Please make a new website based on these and return just the HTML file. Also, please make it for the ${o} theme. What follows are the wireframe's text annotations (if any)...`},{type:"text",text:r}]}]},i,a=await fetch("https://api.openai.com/v1/chat/completions",{method:"POST",headers:{"Content-Type":"application/json",Authorization:`Bearer ${t}`},body:JSON.stringify(n)});return a.ok?i={...await a.json(),ok:!0}:i={...await a.json(),ok:!1},i}var ON,AA=y(()=>{"use strict";f();W();ON=`You are a skilled front-end developer who builds interactive prototypes from wireframes, and is an expert at CSS Grid and Flex design.
78
78
  Your role is to transform low-fidelity wireframes into working front-end HTML code.
79
79
 
80
80
  YOU MUST FOLLOW FOLLOWING RULES:
@@ -94,13 +94,13 @@ If the wireframes, diagrams, or text is unclear or unreadable, refer to provided
94
94
 
95
95
  Your goal is a production-ready prototype that brings the wireframes to life.
96
96
 
97
- Please output JUST THE HTML file containing your best attempt at implementing the provided wireframes.`});import M9 from"clsx";import{jsx as A4,jsxs as _9}from"react/jsx-runtime";var L9,Qg,M4=v(()=>{"use strict";f();jn();L9="small",Qg=e=>_9("label",{className:M9("ToolIcon ToolIcon__MagicButton",`ToolIcon_size_${L9}`,{"is-mobile":e.isMobile}),title:`${e.title}`,children:[A4("input",{className:"ToolIcon_type_checkbox",type:"checkbox",name:e.name,onChange:e.onChange,checked:e.checked,"aria-label":e.title}),A4("div",{className:"ToolIcon__icon",children:e.icon})]})});var L4=v(()=>{});import{jsx as g0,jsxs as _4}from"react/jsx-runtime";var P9,P4,D4=v(()=>{"use strict";f();ee();L4();P9=({height:e,width:t,userToFollow:o,onDisconnect:r})=>g0("div",{className:"follow-mode",style:{width:t,height:e},children:_4("div",{className:"follow-mode__badge",children:[_4("div",{className:"follow-mode__badge__label",children:["Following"," ",g0("span",{className:"follow-mode__badge__username",title:o.username,children:o.username})]}),g0("button",{onClick:r,className:"follow-mode__disconnect-btn",children:Yo})]})}),P4=P9});var eh,R4=v(()=>{"use strict";f();eh=class{targets=new WeakMap;rafIds=new WeakMap;register(t,o){this.targets.set(t,{callback:o,stopped:!0})}start(t){let o=this.targets.get(t);o&&(this.rafIds.has(t)||(this.targets.set(t,{...o,stopped:!1}),this.scheduleFrame(t)))}stop(t){let o=this.targets.get(t);o&&!o.stopped&&this.targets.set(t,{...o,stopped:!0}),this.cancelFrame(t)}constructFrame(t){return o=>{let r=this.targets.get(t);if(!r)return;let n=this.onFrame(r,o);!r.stopped&&!n?this.scheduleFrame(t):this.cancelFrame(t)}}scheduleFrame(t){let o=requestAnimationFrame(this.constructFrame(t));this.rafIds.set(t,o)}cancelFrame(t){if(this.rafIds.has(t)){let o=this.rafIds.get(t);cancelAnimationFrame(o)}this.rafIds.delete(t)}onFrame(t,o){return t.callback(o)??!1}}});import{LaserPointer as D9}from"@excalidraw/laser-pointer";var nl,h0=v(()=>{"use strict";f();G();U();nl=class{constructor(t,o,r){this.animationFrameHandler=t;this.app=o;this.options=r;this.animationFrameHandler.register(this,this.onFrame.bind(this)),this.trailElement=document.createElementNS(Ue,"path")}currentTrail;pastTrails=[];container;trailElement;get hasCurrentTrail(){return!!this.currentTrail}hasLastPoint(t,o){if(this.currentTrail){let r=this.currentTrail.originalPoints.length;return this.currentTrail.originalPoints[r-1][0]===t&&this.currentTrail.originalPoints[r-1][1]===o}return!1}start(t){t&&(this.container=t),this.trailElement.parentNode!==this.container&&this.container&&this.container.appendChild(this.trailElement),this.animationFrameHandler.start(this)}stop(){this.animationFrameHandler.stop(this),this.trailElement.parentNode===this.container&&this.container?.removeChild(this.trailElement)}startPath(t,o){this.currentTrail=new D9(this.options),this.currentTrail.addPoint([t,o,performance.now()]),this.update()}addPointToPath(t,o){this.currentTrail&&(this.currentTrail.addPoint([t,o,performance.now()]),this.update())}endPath(){this.currentTrail&&(this.currentTrail.close(),this.currentTrail.options.keepHead=!1,this.pastTrails.push(this.currentTrail),this.currentTrail=void 0,this.update())}update(){this.start()}onFrame(){let t=[];for(let r of this.pastTrails)t.push(this.drawTrail(r,this.app.state));if(this.currentTrail){let r=this.drawTrail(this.currentTrail,this.app.state);t.push(r)}this.pastTrails=this.pastTrails.filter(r=>r.getStrokeOutline().length!==0),t.length===0&&this.stop();let o=t.join(" ").trim();this.trailElement.setAttribute("d",o),this.trailElement.setAttribute("fill",(this.options.fill??(()=>"black"))(this))}drawTrail(t,o){let r=t.getStrokeOutline(t.options.size/o.zoom.value).map(([n,i])=>{let a=zt({sceneX:n,sceneY:i},o);return[a.x,a.y]});return Ay(r,!0)}}});var th,N4=v(()=>{"use strict";f();h0();G();dd();U();th=class{constructor(t,o){this.animationFrameHandler=t;this.app=o;this.animationFrameHandler.register(this,this.onFrame.bind(this)),this.localTrail=new nl(t,o,{...this.getTrailOptions(),fill:()=>mh})}localTrail;collabTrails=new Map;container;getTrailOptions(){return{simplify:0,streamline:.4,sizeMapping:t=>{let n=Math.max(0,1-(performance.now()-t.pressure)/1e3),i=(50-Math.min(50,t.totalLength-t.currentIndex))/50;return Math.min(Mn(i),Mn(n))}}}startPath(t,o){this.localTrail.startPath(t,o)}addPointToPath(t,o){this.localTrail.addPointToPath(t,o)}endPath(){this.localTrail.endPath()}start(t){this.container=t,this.animationFrameHandler.start(this),this.localTrail.start(t)}stop(){this.animationFrameHandler.stop(this),this.localTrail.stop()}onFrame(){this.updateCollabTrails()}updateCollabTrails(){if(!(!this.container||this.app.state.collaborators.size===0)){for(let[t,o]of this.app.state.collaborators.entries()){let r;this.collabTrails.has(t)?r=this.collabTrails.get(t):(r=new nl(this.animationFrameHandler,this.app,{...this.getTrailOptions(),fill:()=>o.pointer?.laserColor||qa(t,o)}),r.start(this.container),this.collabTrails.set(t,r)),o.pointer&&o.pointer.tool==="laser"&&(o.button==="down"&&!r.hasCurrentTrail&&r.startPath(o.pointer.x,o.pointer.y),o.button==="down"&&r.hasCurrentTrail&&!r.hasLastPoint(o.pointer.x,o.pointer.y)&&r.addPointToPath(o.pointer.x,o.pointer.y),o.button==="up"&&r.hasCurrentTrail&&(r.addPointToPath(o.pointer.x,o.pointer.y),r.endPath()))}for(let t of this.collabTrails.keys())this.app.state.collaborators.has(t)||(this.collabTrails.get(t).stop(),this.collabTrails.delete(t))}}}});var R9,O4,B4=v(()=>{"use strict";f();ue();G();_n();se();U();Ze();pt();ax();ad();io();Ai();Nm();R9=(e,t,o,r,n,i)=>{let{zoom:a}=r,l=180*o/Math.PI,s=e*(a.value-1)/2,c=t*(a.value-1)/2;return e>n&&a.value!==1&&(s=n*(a.value-1)/2),t>i&&a.value!==1&&(c=i*(a.value-1)/2),`translate(${s}px, ${c}px) scale(${a.value}) rotate(${l}deg)`},O4=({id:e,onChange:t,onSubmit:o,getViewportCoords:r,element:n,canvas:i,excalidrawContainer:a,app:l})=>{let s=(A,B)=>{if(!B.style.fontFamily||!B.style.fontSize)return!1;let j=B.style.fontFamily.replace(/"/g,"");return ul({fontFamily:A.fontFamily})!==j||`${A.fontSize}px`!==B.style.fontSize},c=()=>{let A=l.state,B=lt.getScene(n)?.getElement(e);if(!B)return;let{textAlign:j,verticalAlign:Y}=B,oe=l.scene.getNonDeletedElementsMap();if(B&&W(B)){let Ce=B.x,Te=B.y,K=ut(B,l.scene.getNonDeletedElementsMap()),ge=B.width,xe=B.height,Ne=B.width,Le=B.height;if(K&&B.containerId){if(ke(K)){let Dt=$.getBoundTextElementPosition(K,B,oe);Ce=Dt.x,Te=Dt.y}let tr=s(B,d),Tn;if(tr?Tn=ya(K.id,K.height):(Tn=Ea[K.id],Tn||(Tn=ya(K.id,K.height))),ge=wo(K,B),xe=wa(K,B),!ke(K)&&Le>xe){let Dt=On(Le,K.type);z(K,{height:Dt});return}else if(!ke(K)&&K.height>Tn.height&&Le<xe){let Dt=On(Le,K.type);z(K,{height:Dt})}else{let{y:Dt}=Pl(K,B,oe);Te=Dt}}let[$t,wn]=r(Ce,Te),Xt=d.selectionStart,Wr=d.selectionEnd,vn=d.value.length;if(Xt===Wr&&Wr!==vn){let tr=vn-Wr;d.selectionStart=d.value.length-tr,d.selectionEnd=d.value.length-tr}K||(ge=(A.width-8-$t)/A.zoom.value,Ne=Math.min(Ne,ge));let oa=(A.height-wn)/A.zoom.value;Object.assign(d.style,{font:Ke(B),lineHeight:B.lineHeight,width:`${Ne}px`,height:`${Le}px`,left:`${$t}px`,top:`${wn}px`,transform:R9(Ne,Le,P2(B,K),A,ge,oa),textAlign:j,verticalAlign:Y,color:B.strokeColor,opacity:B.opacity/100,filter:"var(--theme-filter)",maxHeight:`${oa}px`}),d.scrollTop=0,Ro()&&(d.style.fontFamily=ul(B)),z(B,{x:Ce,y:Te})}},d=document.createElement("textarea");d.dir="auto",d.tabIndex=0,d.dataset.type="wysiwyg",d.wrap="off",d.classList.add("excalidraw-wysiwyg");let m="pre",p="normal";ze(n)&&(m="pre-wrap",p="break-word"),Object.assign(d.style,{position:"absolute",display:"inline-block",minHeight:"1em",backfaceVisibility:"hidden",margin:0,padding:0,border:0,outline:0,resize:"none",background:"transparent",overflow:"hidden",zIndex:"var(--zIndex-wysiwyg)",wordBreak:p,whiteSpace:m,overflowWrap:"break-word",boxSizing:"content-box"}),d.value=n.originalText,c(),t&&(d.onpaste=async A=>{let B=await Cp(A,!0);if(!B.text)return;let j=yi(B.text);if(!j)return;let Y=ut(n,l.scene.getNonDeletedElementsMap()),oe=Ke({fontSize:l.state.currentItemFontSize,fontFamily:l.state.currentItemFontFamily});if(Y){let Ce=me(Y,l.scene.getNonDeletedElementsMap()),Te=vi(`${d.value}${j}`,oe,wo(Y,Ce)),K=fc(Te,oe);d.style.width=`${K}px`}},d.oninput=()=>{t(yi(d.value))}),d.onkeydown=A=>{if(!A.shiftKey&&rd.keyTest(A))A.preventDefault(),l.actionManager.executeAction(rd),c();else if(!A.shiftKey&&nd.keyTest(A))A.preventDefault(),l.actionManager.executeAction(nd),c();else if(nx.keyTest(A))l.actionManager.executeAction(nx);else if(ix.keyTest(A))l.actionManager.executeAction(ix);else if(A.key===I.ESCAPE)A.preventDefault(),S=!0,M();else if(A.key===I.ENTER&&A[I.CTRL_OR_CMD]){if(A.preventDefault(),A.isComposing||A.keyCode===229)return;S=!0,M()}else if(A.key===I.TAB||A[I.CTRL_OR_CMD]&&(A.code===fe.BRACKET_LEFT||A.code===fe.BRACKET_RIGHT)){if(A.preventDefault(),A.isComposing)return;A.shiftKey||A.code===fe.BRACKET_LEFT?y():E(),d.dispatchEvent(new Event("input"))}};let u=4,g=" ".repeat(u),x=new RegExp(`^ {1,${u}}`),E=()=>{let{selectionStart:A,selectionEnd:B}=d,j=T(),Y=d.value;j.forEach(oe=>{let Ce=Y.slice(0,oe),Te=Y.slice(oe);Y=`${Ce}${g}${Te}`}),d.value=Y,d.selectionStart=A+u,d.selectionEnd=B+u*j.length},y=()=>{let{selectionStart:A,selectionEnd:B}=d,j=T(),Y=[],oe=d.value;j.forEach(Ce=>{let Te=oe.slice(Ce,Ce+u).match(x);if(Te){let K=oe.slice(0,Ce),ge=oe.slice(Ce+Te[0].length);oe=`${K}${ge}`,Y.push(Ce)}}),d.value=oe,Y.length&&(A>Y[Y.length-1]?d.selectionStart=Math.max(A-u,Y[Y.length-1]):d.selectionStart=A,d.selectionEnd=Math.max(d.selectionStart,B-u*Y.length))},T=()=>{let{selectionStart:A,selectionEnd:B,value:j}=d,Y=j.slice(0,A).match(/[^\n]*$/)[0].length;return A=A-Y,j.slice(A,B).split(`
98
- `).reduce((Ce,Te,K,ge)=>Ce.concat(K?Ce[K-1]+ge[K-1].length+1:A),[]).reverse()},w=A=>{A.preventDefault(),A.stopPropagation()},S=!1,M=()=>{k();let A=lt.getScene(n)?.getElement(n.id);if(!A)return;let B=d.value,j=ut(A,l.scene.getNonDeletedElementsMap());if(j){if(B=A.text,d.value.trim()){let Y=Bn(j);!Y||Y!==n.id?z(j,{boundElements:(j.boundElements||[]).concat({type:"text",id:n.id})}):ke(j)&&Nr(j)}else z(j,{boundElements:j.boundElements?.filter(Y=>!W(Y))});eo(A,j,l.scene.getNonDeletedElementsMap())}o({text:B,viaKeyboard:S,originalText:d.value})},k=()=>{D||(D=!0,d.onblur=null,d.oninput=null,d.onkeydown=null,L&&L.disconnect(),window.removeEventListener("resize",c),window.removeEventListener("wheel",w,!0),window.removeEventListener("pointerdown",P),window.removeEventListener("pointerup",R),window.removeEventListener("blur",M),window.removeEventListener("beforeunload",M),F(),d.remove())},R=A=>{window.removeEventListener("pointerup",R);let B=A?.target,j=B instanceof HTMLElement&&B.classList.contains("active-color");setTimeout(()=>{if(d.onblur=M,j){let Y=(Ce,Te)=>{Ce.find(ge=>ge.removedNodes.length>0&&ge.removedNodes[0].dataset?.radixPopperContentWrapper!==void 0)&&(setTimeout(()=>{d.focus()}),Te.disconnect())};new MutationObserver(Y).observe(document.querySelector(".excalidraw-container"),{childList:!0})}j||d.focus()})},P=A=>{let B=A.target instanceof HTMLElement&&A.target.classList.contains("active-color");((A.target instanceof HTMLElement||A.target instanceof SVGElement)&&A.target.closest(`.${tm.SHAPE_ACTIONS_MENU}`)&&!rr(A.target)||B)&&(d.onblur=null,window.addEventListener("pointerup",R),window.addEventListener("blur",M))},F=lt.getScene(n).addCallback(()=>{c(),!!document.activeElement?.closest(".color-picker-content")||d.focus()}),D=!1;d.select(),R();let L=null;i&&"ResizeObserver"in window?(L=new window.ResizeObserver(()=>{c()}),L.observe(i)):window.addEventListener("resize",c),window.addEventListener("pointerdown",P),window.addEventListener("wheel",w,{passive:!1,capture:!0}),window.addEventListener("beforeunload",M),a?.querySelector(".excalidraw-textEditorContainer").appendChild(d)}});import yn,{useContext as ea}from"react";import{flushSync as f0}from"react-dom";import N9 from"roughjs/bin/rough";import F4 from"clsx";import{nanoid as O9}from"nanoid";import B9 from"lodash.throttle";import{Fragment as H9,jsx as qe,jsxs as rh}from"react/jsx-runtime";var G4,U4,W4,v0,T0,C0,I0,S0,k0,ko,Hi,_e,Wt,Di,fs,Be,Ft,Yd,b0,il,Kd,x0,E0,Qi,$d,y0,oh,H4,z4,Xd,Fe,w0,F9,V4,ye=v(()=>{"use strict";f();Er();QC();e6();je();So();Fo();Ai();U();Bi();el();Aa();he();_r();io();Ze();on();se();o6();Ho();r6();X();ue();Ra();Qt();Jr();We();_n();zp();mg();G();vc();a6();LS();RS();NS();Co();Af();Wn();pt();Ei();xx();Dl();vl();yx();OS();ao();ui();mx();zS();ad();Tt();kd();Ia();JS();ux();t4();td();a0();Nd();x4();E4();Mr();T4();Rl();vx();I4();k4();Pa();Wo();M4();ee();vd();D4();R4();h0();N4();jg();Jr();B4();Tg();dp();ol();G4=yn.createContext(null),U4=yn.createContext(null),W4={viewport:{isMobile:!1,isLandscape:!1},editor:{isMobile:!1,canFitSidebar:!1},isTouchScreen:!1},v0=yn.createContext(W4);v0.displayName="DeviceContext";T0=yn.createContext({container:null,id:null});T0.displayName="ExcalidrawContainerContext";C0=yn.createContext([]);C0.displayName="ExcalidrawElementsContext";I0=yn.createContext({...Bo(),width:0,height:0,offsetLeft:0,offsetTop:0});I0.displayName="ExcalidrawAppStateContext";S0=yn.createContext(()=>{console.warn("Uninitialized ExcalidrawSetAppStateContext context!")});S0.displayName="ExcalidrawSetAppStateContext";k0=yn.createContext(null);k0.displayName="ExcalidrawActionManagerContext";ko=()=>ea(G4),Hi=()=>ea(U4),_e=()=>ea(v0),Wt=()=>ea(T0),Di=()=>ea(C0),fs=()=>ea(I0),Be=()=>ea(S0),Ft=()=>ea(k0),Yd=!1,b0=0,il=!1,Kd=!1,x0=!1,E0={horizontal:null,vertical:null},Qi=0,$d=!1,y0=new Map,oh=!1,H4=0,z4=!1,Xd=null,Fe={pointers:new Map,lastCenter:null,initialDistance:null,initialScale:null},w0=class e extends yn.Component{canvas;interactiveCanvas=null;rc;unmounted=!1;actionManager;device=W4;excalidrawContainerRef=yn.createRef();scene;renderer;fonts;resizeObserver;nearestScrollableContainer;library;libraryItemsFromStorage;id;history;excalidrawContainerValue;files={};imageCache=new Map;iFrameRefs=new Map;embedsValidationStatus=new Map;initializedEmbeds=new Set;elementsPendingErasure=new Set;hitLinkElement;lastPointerDownEvent=null;lastPointerUpEvent=null;lastPointerMoveEvent=null;lastViewportPosition={x:0,y:0};animationFrameHandler=new eh;laserTrails=new th(this.animationFrameHandler,this);eraserTrail=new nl(this.animationFrameHandler,this,{streamline:.2,size:5,keepHead:!0,sizeMapping:t=>{let n=Math.max(0,1-(performance.now()-t.pressure)/200),i=(10-Math.min(10,t.totalLength-t.currentIndex))/10;return Math.min(Mn(i),Mn(n))},fill:()=>this.state.theme===ie.LIGHT?"rgba(0, 0, 0, 0.2)":"rgba(255, 255, 255, 0.2)"});onChangeEmitter=new br;onPointerDownEmitter=new br;onPointerUpEmitter=new br;onUserFollowEmitter=new br;onScrollChangeEmitter=new br;missingPointerEventCleanupEmitter=new br;onRemoveEventListenersEmitter=new br;constructor(t){super(t);let o=Bo(),{excalidrawAPI:r,viewModeEnabled:n=!1,zenModeEnabled:i=!1,gridModeEnabled:a=!1,objectsSnapModeEnabled:l=!1,theme:s=o.theme,name:c=`${b("labels.untitled")}-${Eh()}`}=t;if(this.state={...o,theme:s,isLoading:!0,...this.getCanvasOffsets(),viewModeEnabled:n,zenModeEnabled:i,objectsSnapModeEnabled:l,gridSize:a?An:null,name:c,width:window.innerWidth,height:window.innerHeight},this.id=O9(),this.library=new Ix(this),this.actionManager=new Ad(this.syncActionResult,()=>this.state,()=>this.scene.getElementsIncludingDeleted(),this),this.scene=new lt,this.canvas=document.createElement("canvas"),this.rc=N9.canvas(this.canvas),this.renderer=new Vd(this.scene),r){let d={updateScene:this.updateScene,updateLibrary:this.library.updateLibrary,addFiles:this.addFiles,resetScene:this.resetScene,getSceneElementsIncludingDeleted:this.getSceneElementsIncludingDeleted,history:{clear:this.resetHistory},scrollToContent:this.scrollToContent,getSceneElements:this.getSceneElements,getAppState:()=>this.state,getFiles:()=>this.files,getName:this.getName,registerAction:m=>{this.actionManager.registerAction(m)},refresh:this.refresh,setToast:this.setToast,id:this.id,setActiveTool:this.setActiveTool,setCursor:this.setCursor,resetCursor:this.resetCursor,updateFrameRendering:this.updateFrameRendering,toggleSidebar:this.toggleSidebar,app:this,onChange:m=>this.onChangeEmitter.on(m),onPointerDown:m=>this.onPointerDownEmitter.on(m),onPointerUp:m=>this.onPointerUpEmitter.on(m),onScrollChange:m=>this.onScrollChangeEmitter.on(m),onUserFollow:m=>this.onUserFollowEmitter.on(m)};typeof r=="function"?r(d):console.error("excalidrawAPI should be a function!")}this.excalidrawContainerValue={container:this.excalidrawContainerRef.current,id:this.id},this.fonts=new Yg({scene:this.scene,onSceneUpdated:this.onSceneUpdated}),this.history=new lE,this.actionManager.registerAll(Km),this.actionManager.registerAction(jC(this.history)),this.actionManager.registerAction(qC(this.history))}onWindowMessage(t){if(t.origin!=="https://player.vimeo.com"&&t.origin!=="https://www.youtube.com")return;let o=null;try{o=JSON.parse(t.data)}catch{}if(o)switch(t.origin){case"https://player.vimeo.com":if(o.method==="paused"){let r=null,n=document.body.querySelectorAll("iframe.excalidraw__embeddable");if(!n)break;for(let i of n)i.contentWindow===t.source&&(r=i.contentWindow);r?.postMessage(JSON.stringify({method:o.value?"play":"pause",value:!0}),"*")}break;case"https://www.youtube.com":if(o.event==="infoDelivery"&&o.info&&o.id&&typeof o.info.playerState=="number"){let r=o.id,n=o.info.playerState;Object.values(Hs).includes(n)&&y0.set(r,n)}break}}cacheEmbeddableRef(t,o){o&&this.iFrameRefs.set(t.id,o)}getHTMLIFrameElement(t){return this.iFrameRefs.get(t.id)}handleEmbeddableCenterClick(t){if(this.state.activeEmbeddable?.element===t&&this.state.activeEmbeddable?.state==="active"||(setTimeout(()=>{this.setState({activeEmbeddable:{element:t,state:"active"},selectedElementIds:{[t.id]:!0},draggingElement:null,selectionElement:null})},100),ir(t)))return;let o=this.getHTMLIFrameElement(t);if(o?.contentWindow){if(o.src.includes("youtube")){let r=y0.get(t.id);switch(r||(y0.set(t.id,Hs.UNSTARTED),o.contentWindow.postMessage(JSON.stringify({event:"listening",id:t.id}),"*")),r){case Hs.PLAYING:case Hs.BUFFERING:o.contentWindow?.postMessage(JSON.stringify({event:"command",func:"pauseVideo",args:""}),"*");break;default:o.contentWindow?.postMessage(JSON.stringify({event:"command",func:"playVideo",args:""}),"*")}}o.src.includes("player.vimeo.com")&&o.contentWindow.postMessage(JSON.stringify({method:"paused"}),"*")}}isIframeLikeElementCenter(t,o,r,n){return t&&!o.altKey&&!o.shiftKey&&!o.metaKey&&!o.ctrlKey&&(this.state.activeEmbeddable?.element!==t||this.state.activeEmbeddable?.state==="hover"||!this.state.activeEmbeddable)&&r>=t.x+t.width/3&&r<=t.x+2*t.width/3&&n>=t.y+t.height/3&&n<=t.y+2*t.height/3}updateEmbedValidationStatus=(t,o)=>{this.embedsValidationStatus.set(t.id,o),Me.delete(t)};updateEmbeddables=()=>{let t=new Set,o=!1;this.scene.getNonDeletedElements().filter(r=>{if(St(r)){if(t.add(r.id),!this.embedsValidationStatus.has(r.id)){o=!0;let n=Bl(r.link,this.props.validateEmbeddable);this.updateEmbedValidationStatus(r,n)}}else ir(r)&&t.add(r.id);return!1}),o&&this.scene.informMutation(),this.iFrameRefs.forEach((r,n)=>{t.has(n)||this.iFrameRefs.delete(n)})};renderEmbeddables(){let t=this.state.zoom.value,o=this.state.width,r=this.state.height,n=this.scene.getNonDeletedElements().filter(i=>St(i)&&this.embedsValidationStatus.get(i.id)===!0||ir(i));return qe(H9,{children:n.map(i=>{let{x:a,y:l}=zt({sceneX:i.x,sceneY:i.y},this.state),s=Da(i,o,r,this.state,this.scene.getNonDeletedElementsMap()),c=this.initializedEmbeds.has(i.id);if(s&&!c&&this.initializedEmbeds.add(i.id),!(s||c))return null;let m;if(ir(i)){m=null;let g=(i.customData?.generationData??this.magicGenerations.get(i.id))||{status:"error",message:"No generation data",code:"ERR_NO_GENERATION_DATA"};if(g.status==="done"){let x=g.html;m={intrinsicSize:{w:i.width,h:i.height},type:"document",srcdoc:()=>x}}else if(g.status==="pending")m={intrinsicSize:{w:i.width,h:i.height},type:"document",srcdoc:()=>wc(`
97
+ Please output JUST THE HTML file containing your best attempt at implementing the provided wireframes.`});import BN from"clsx";import{jsx as kA,jsxs as zN}from"react/jsx-runtime";var FN,Ag,MA=y(()=>{"use strict";f();ri();FN="small",Ag=e=>zN("label",{className:BN("ToolIcon ToolIcon__MagicButton",`ToolIcon_size_${FN}`,{"is-mobile":e.isMobile}),title:`${e.title}`,children:[kA("input",{className:"ToolIcon_type_checkbox",type:"checkbox",name:e.name,onChange:e.onChange,checked:e.checked,"aria-label":e.title}),kA("div",{className:"ToolIcon__icon",children:e.icon})]})});var LA=y(()=>{});import{jsx as X0,jsxs as PA}from"react/jsx-runtime";var HN,DA,_A=y(()=>{"use strict";f();ne();LA();HN=({height:e,width:t,userToFollow:r,onDisconnect:o})=>X0("div",{className:"follow-mode",style:{width:t,height:e},children:PA("div",{className:"follow-mode__badge",children:[PA("div",{className:"follow-mode__badge__label",children:["Following"," ",X0("span",{className:"follow-mode__badge__username",title:r.username,children:r.username})]}),X0("button",{onClick:o,className:"follow-mode__disconnect-btn",children:to})]})}),DA=HN});var kg,RA=y(()=>{"use strict";f();kg=class{targets=new WeakMap;rafIds=new WeakMap;register(t,r){this.targets.set(t,{callback:r,stopped:!0})}start(t){let r=this.targets.get(t);r&&(this.rafIds.has(t)||(this.targets.set(t,{...r,stopped:!1}),this.scheduleFrame(t)))}stop(t){let r=this.targets.get(t);r&&!r.stopped&&this.targets.set(t,{...r,stopped:!0}),this.cancelFrame(t)}constructFrame(t){return r=>{let o=this.targets.get(t);if(!o)return;let n=this.onFrame(o,r);!o.stopped&&!n?this.scheduleFrame(t):this.cancelFrame(t)}}scheduleFrame(t){let r=requestAnimationFrame(this.constructFrame(t));this.rafIds.set(t,r)}cancelFrame(t){if(this.rafIds.has(t)){let r=this.rafIds.get(t);cancelAnimationFrame(r)}this.rafIds.delete(t)}onFrame(t,r){return t.callback(r)??!1}}});import{LaserPointer as UN}from"@excalidraw/laser-pointer";var bl,Z0=y(()=>{"use strict";f();G();W();bl=class{constructor(t,r,o){this.animationFrameHandler=t;this.app=r;this.options=o;this.animationFrameHandler.register(this,this.onFrame.bind(this)),this.trailElement=document.createElementNS(We,"path")}currentTrail;pastTrails=[];container;trailElement;get hasCurrentTrail(){return!!this.currentTrail}hasLastPoint(t,r){if(this.currentTrail){let o=this.currentTrail.originalPoints.length;return this.currentTrail.originalPoints[o-1][0]===t&&this.currentTrail.originalPoints[o-1][1]===r}return!1}start(t){t&&(this.container=t),this.trailElement.parentNode!==this.container&&this.container&&this.container.appendChild(this.trailElement),this.animationFrameHandler.start(this)}stop(){this.animationFrameHandler.stop(this),this.trailElement.parentNode===this.container&&this.container?.removeChild(this.trailElement)}startPath(t,r){this.currentTrail=new UN(this.options),this.currentTrail.addPoint([t,r,performance.now()]),this.update()}addPointToPath(t,r){this.currentTrail&&(this.currentTrail.addPoint([t,r,performance.now()]),this.update())}endPath(){this.currentTrail&&(this.currentTrail.close(),this.currentTrail.options.keepHead=!1,this.pastTrails.push(this.currentTrail),this.currentTrail=void 0,this.update())}update(){this.start()}onFrame(){let t=[];for(let o of this.pastTrails)t.push(this.drawTrail(o,this.app.state));if(this.currentTrail){let o=this.drawTrail(this.currentTrail,this.app.state);t.push(o)}this.pastTrails=this.pastTrails.filter(o=>o.getStrokeOutline().length!==0),t.length===0&&this.stop();let r=t.join(" ").trim();this.trailElement.setAttribute("d",r),this.trailElement.setAttribute("fill",(this.options.fill??(()=>"black"))(this))}drawTrail(t,r){let o=t.getStrokeOutline(t.options.size/r.zoom.value).map(([n,i])=>{let a=Vt({sceneX:n,sceneY:i},r);return[a.x,a.y]});return cw(o,!0)}}});var Mg,NA=y(()=>{"use strict";f();Z0();G();Id();W();Mg=class{constructor(t,r){this.animationFrameHandler=t;this.app=r;this.animationFrameHandler.register(this,this.onFrame.bind(this)),this.localTrail=new bl(t,r,{...this.getTrailOptions(),fill:()=>zg})}localTrail;collabTrails=new Map;container;getTrailOptions(){return{simplify:0,streamline:.4,sizeMapping:t=>{let n=Math.max(0,1-(performance.now()-t.pressure)/1e3),i=(50-Math.min(50,t.totalLength-t.currentIndex))/50;return Math.min(Bn(i),Bn(n))}}}startPath(t,r){this.localTrail.startPath(t,r)}addPointToPath(t,r){this.localTrail.addPointToPath(t,r)}endPath(){this.localTrail.endPath()}start(t){this.container=t,this.animationFrameHandler.start(this),this.localTrail.start(t)}stop(){this.animationFrameHandler.stop(this),this.localTrail.stop()}onFrame(){this.updateCollabTrails()}updateCollabTrails(){if(!(!this.container||this.app.state.collaborators.size===0)){for(let[t,r]of this.app.state.collaborators.entries()){let o;this.collabTrails.has(t)?o=this.collabTrails.get(t):(o=new bl(this.animationFrameHandler,this.app,{...this.getTrailOptions(),fill:()=>r.pointer?.laserColor||cl(t,r)}),o.start(this.container),this.collabTrails.set(t,o)),r.pointer&&r.pointer.tool==="laser"&&(r.button==="down"&&!o.hasCurrentTrail&&o.startPath(r.pointer.x,r.pointer.y),r.button==="down"&&o.hasCurrentTrail&&!o.hasLastPoint(r.pointer.x,r.pointer.y)&&o.addPointToPath(r.pointer.x,r.pointer.y),r.button==="up"&&o.hasCurrentTrail&&(o.addPointToPath(r.pointer.x,r.pointer.y),o.endPath()))}for(let t of this.collabTrails.keys())this.app.state.collaborators.has(t)||(this.collabTrails.get(t).stop(),this.collabTrails.delete(t))}}}});var GN,OA,BA=y(()=>{"use strict";f();be();G();vi();me();W();Ye();mt();HE();vd();or();zi();tp();GN=(e,t,r,o,n,i)=>{let{zoom:a}=o,l=180*r/Math.PI,s=e*(a.value-1)/2,c=t*(a.value-1)/2;return e>n&&a.value!==1&&(s=n*(a.value-1)/2),t>i&&a.value!==1&&(c=i*(a.value-1)/2),`translate(${s}px, ${c}px) scale(${a.value}) rotate(${l}deg)`},OA=({id:e,onChange:t,onSubmit:r,getViewportCoords:o,element:n,canvas:i,excalidrawContainer:a,app:l})=>{let s=(k,z)=>{if(!z.style.fontFamily||!z.style.fontSize)return!1;let ee=z.style.fontFamily.replace(/"/g,"");return kl({fontFamily:k.fontFamily})!==ee||`${k.fontSize}px`!==z.style.fontSize},c=()=>{let k=l.state,z=Ct.getScene(n)?.getElement(e);if(!z)return;let{textAlign:ee,verticalAlign:j}=z,ie=l.scene.getNonDeletedElementsMap();if(z&&V(z)){let ke=z.x,$=z.y,Y=gt(z,l.scene.getNonDeletedElementsMap()),ae=z.width,fe=z.height,De=z.width,Le=z.height;if(Y&&z.containerId){if(Ce(Y)){let Ir=Z.getBoundTextElementPosition(Y,z,ie);ke=Ir.x,$=Ir.y}let _o=s(z,d),Gr;if(_o?Gr=Pa(Y.id,Y.height):(Gr=La[Y.id],Gr||(Gr=Pa(Y.id,Y.height))),ae=Mr(Y,z),fe=Da(Y,z),!Ce(Y)&&Le>fe){let Ir=Gn(Le,Y.type);H(Y,{height:Ir});return}else if(!Ce(Y)&&Y.height>Gr.height&&Le<fe){let Ir=Gn(Le,Y.type);H(Y,{height:Ir})}else{let{y:Ir}=Ul(Y,z,ie);$=Ir}}let[pr,mi]=o(ke,$),Zo=d.selectionStart,Pn=d.selectionEnd,pi=d.value.length;if(Zo===Pn&&Pn!==pi){let _o=pi-Pn;d.selectionStart=d.value.length-_o,d.selectionEnd=d.value.length-_o}Y||(ae=(k.width-8-pr)/k.zoom.value,De=Math.min(De,ae));let xl=(k.height-mi)/k.zoom.value;Object.assign(d.style,{font:Ze(z),lineHeight:z.lineHeight,width:`${De}px`,height:`${Le}px`,left:`${pr}px`,top:`${mi}px`,transform:GN(De,Le,h2(z,Y),k,ae,xl),textAlign:ee,verticalAlign:j,color:z.strokeColor,opacity:z.opacity/100,filter:"var(--theme-filter)",maxHeight:`${xl}px`}),d.scrollTop=0,Wr()&&(d.style.fontFamily=kl(z)),H(z,{x:ke,y:$})}},d=document.createElement("textarea");d.dir="auto",d.tabIndex=0,d.dataset.type="wysiwyg",d.wrap="off",d.classList.add("excalidraw-wysiwyg");let m="pre",p="normal";Pe(n)&&(m="pre-wrap",p="break-word"),Object.assign(d.style,{position:"absolute",display:"inline-block",minHeight:"1em",backfaceVisibility:"hidden",margin:0,padding:0,border:0,outline:0,resize:"none",background:"transparent",overflow:"hidden",zIndex:"var(--zIndex-wysiwyg)",wordBreak:p,whiteSpace:m,overflowWrap:"break-word",boxSizing:"content-box"}),d.value=n.originalText,c(),t&&(d.onpaste=async k=>{let z=await jp(k,!0);if(!z.text)return;let ee=Li(z.text);if(!ee)return;let j=gt(n,l.scene.getNonDeletedElementsMap()),ie=Ze({fontSize:l.state.currentItemFontSize,fontFamily:l.state.currentItemFontFamily});if(j){let ke=ue(j,l.scene.getNonDeletedElementsMap()),$=Di(`${d.value}${ee}`,ie,Mr(j,ke)),Y=Ic($,ie);d.style.width=`${Y}px`}},d.oninput=()=>{t(Li(d.value))}),d.onkeydown=k=>{if(!k.shiftKey&&xd.keyTest(k))k.preventDefault(),l.actionManager.executeAction(xd),c();else if(!k.shiftKey&&yd.keyTest(k))k.preventDefault(),l.actionManager.executeAction(yd),c();else if(FE.keyTest(k))l.actionManager.executeAction(FE);else if(zE.keyTest(k))l.actionManager.executeAction(zE);else if(k.key===C.ESCAPE)k.preventDefault(),I=!0,L();else if(k.key===C.ENTER&&k[C.CTRL_OR_CMD]){if(k.preventDefault(),k.isComposing||k.keyCode===229)return;I=!0,L()}else if(k.key===C.TAB||k[C.CTRL_OR_CMD]&&(k.code===Ee.BRACKET_LEFT||k.code===Ee.BRACKET_RIGHT)){if(k.preventDefault(),k.isComposing)return;k.shiftKey||k.code===Ee.BRACKET_LEFT?T():x(),d.dispatchEvent(new Event("input"))}};let u=4,h=" ".repeat(u),E=new RegExp(`^ {1,${u}}`),x=()=>{let{selectionStart:k,selectionEnd:z}=d,ee=v(),j=d.value;ee.forEach(ie=>{let ke=j.slice(0,ie),$=j.slice(ie);j=`${ke}${h}${$}`}),d.value=j,d.selectionStart=k+u,d.selectionEnd=z+u*ee.length},T=()=>{let{selectionStart:k,selectionEnd:z}=d,ee=v(),j=[],ie=d.value;ee.forEach(ke=>{let $=ie.slice(ke,ke+u).match(E);if($){let Y=ie.slice(0,ke),ae=ie.slice(ke+$[0].length);ie=`${Y}${ae}`,j.push(ke)}}),d.value=ie,j.length&&(k>j[j.length-1]?d.selectionStart=Math.max(k-u,j[j.length-1]):d.selectionStart=k,d.selectionEnd=Math.max(d.selectionStart,z-u*j.length))},v=()=>{let{selectionStart:k,selectionEnd:z,value:ee}=d,j=ee.slice(0,k).match(/[^\n]*$/)[0].length;return k=k-j,ee.slice(k,z).split(`
98
+ `).reduce((ke,$,Y,ae)=>ke.concat(Y?ke[Y-1]+ae[Y-1].length+1:k),[]).reverse()},w=k=>{k.preventDefault(),k.stopPropagation()},I=!1,L=()=>{A();let k=Ct.getScene(n)?.getElement(n.id);if(!k)return;let z=d.value,ee=gt(k,l.scene.getNonDeletedElementsMap());if(ee){if(z=k.text,d.value.trim()){let j=Uo(ee);!j||j!==n.id?H(ee,{boundElements:(ee.boundElements||[]).concat({type:"text",id:n.id})}):Ce(ee)&&_i(ee)}else H(ee,{boundElements:ee.boundElements?.filter(j=>!V(j))});Ht(k,ee,l.scene.getNonDeletedElementsMap())}r({text:z,viaKeyboard:I,originalText:d.value})},A=()=>{R||(R=!0,d.onblur=null,d.oninput=null,d.onkeydown=null,B&&B.disconnect(),window.removeEventListener("resize",c),window.removeEventListener("wheel",w,!0),window.removeEventListener("pointerdown",D),window.removeEventListener("pointerup",M),window.removeEventListener("blur",L),window.removeEventListener("beforeunload",L),O(),d.remove())},M=k=>{window.removeEventListener("pointerup",M);let z=k?.target,ee=z instanceof HTMLElement&&z.classList.contains("active-color");setTimeout(()=>{if(d.onblur=L,ee){let j=(ke,$)=>{ke.find(ae=>ae.removedNodes.length>0&&ae.removedNodes[0].dataset?.radixPopperContentWrapper!==void 0)&&(setTimeout(()=>{d.focus()}),$.disconnect())};new MutationObserver(j).observe(document.querySelector(".excalidraw-container"),{childList:!0})}ee||d.focus()})},D=k=>{let z=k.target instanceof HTMLElement&&k.target.classList.contains("active-color");((k.target instanceof HTMLElement||k.target instanceof SVGElement)&&k.target.closest(`.${Em.SHAPE_ACTIONS_MENU}`)&&!uo(k.target)||z)&&(d.onblur=null,window.addEventListener("pointerup",M),window.addEventListener("blur",L))},O=Ct.getScene(n).addCallback(()=>{c(),!!document.activeElement?.closest(".color-picker-content")||d.focus()}),R=!1;d.select(),M();let B=null;i&&"ResizeObserver"in window?(B=new window.ResizeObserver(()=>{c()}),B.observe(i)):window.addEventListener("resize",c),window.addEventListener("pointerdown",D),window.addEventListener("wheel",w,{passive:!1,capture:!0}),window.addEventListener("beforeunload",L),a?.querySelector(".excalidraw-textEditorContainer").appendChild(d)}});import Ln,{useContext as ma}from"react";import{flushSync as j0}from"react-dom";import VN from"roughjs/bin/rough";import FA from"clsx";import{nanoid as WN}from"nanoid";import YN from"lodash.throttle";import{Fragment as $N,jsx as Qe,jsxs as Pg}from"react/jsx-runtime";var UA,GA,VA,ry,oy,ny,iy,ay,ly,Or,ji,_e,Zt,Wi,As,He,Ut,lm,q0,El,sm,J0,Q0,da,cm,ey,Lg,zA,HA,dm,Ue,ty,KN,WA,we=y(()=>{"use strict";f();ko();eI();tI();Je();Nr();Dr();zi();W();Xi();pl();Fa();xe();Eo();or();Ye();hn();me();oI();xr();Bx();q();be();Ya();Kt();sn();qe();vi();hu();zh();a1();$m();G();Oc();aI();L4();R4();N4();_r();i1();Xn();mt();JE();Na();Jc();ex();O4();dr();Ti();YE();H4();vd();kt();Vd();wi();J4();$E();tA();bd();H0();qd();EA();xA();ln();TA();Vl();Rc();CA();AA();Va();Qr();MA();ne();Fd();_A();ze();RA();Z0();NA();Sg();sn();Rp();BA();qh();bo();Op();hl();UA=Ln.createContext(null),GA=Ln.createContext(null),VA={viewport:{isMobile:!1,isLandscape:!1},editor:{isMobile:!1,canFitSidebar:!1},isTouchScreen:!1},ry=Ln.createContext(VA);ry.displayName="DeviceContext";oy=Ln.createContext({container:null,id:null});oy.displayName="ExcalidrawContainerContext";ny=Ln.createContext([]);ny.displayName="ExcalidrawElementsContext";iy=Ln.createContext({...Er(),width:0,height:0,offsetLeft:0,offsetTop:0});iy.displayName="ExcalidrawAppStateContext";ay=Ln.createContext(()=>{console.warn("Uninitialized ExcalidrawSetAppStateContext context!")});ay.displayName="ExcalidrawSetAppStateContext";ly=Ln.createContext(null);ly.displayName="ExcalidrawActionManagerContext";Or=()=>ma(UA),ji=()=>ma(GA),_e=()=>ma(ry),Zt=()=>ma(oy),Wi=()=>ma(ny),As=()=>ma(iy),He=()=>ma(ay),Ut=()=>ma(ly),lm=!1,q0=0,El=!1,sm=!1,J0=!1,Q0={horizontal:null,vertical:null},da=0,cm=!1,ey=new Map,Lg=!1,zA=0,HA=!1,dm=null,Ue={pointers:new Map,lastCenter:null,initialDistance:null,initialScale:null},ty=class e extends Ln.Component{canvas;interactiveCanvas=null;rc;unmounted=!1;actionManager;device=VA;excalidrawContainerRef=Ln.createRef();scene;renderer;fonts;resizeObserver;nearestScrollableContainer;library;libraryItemsFromStorage;id;store;history;excalidrawContainerValue;files={};imageCache=new Map;iFrameRefs=new Map;embedsValidationStatus=new Map;initializedEmbeds=new Set;elementsPendingErasure=new Set;hitLinkElement;lastPointerDownEvent=null;lastPointerUpEvent=null;lastPointerMoveEvent=null;lastViewportPosition={x:0,y:0};animationFrameHandler=new kg;laserTrails=new Mg(this.animationFrameHandler,this);eraserTrail=new bl(this.animationFrameHandler,this,{streamline:.2,size:5,keepHead:!0,sizeMapping:t=>{let n=Math.max(0,1-(performance.now()-t.pressure)/200),i=(10-Math.min(10,t.totalLength-t.currentIndex))/10;return Math.min(Bn(i),Bn(n))},fill:()=>this.state.theme===se.LIGHT?"rgba(0, 0, 0, 0.2)":"rgba(255, 255, 255, 0.2)"});onChangeEmitter=new cr;onPointerDownEmitter=new cr;onPointerUpEmitter=new cr;onUserFollowEmitter=new cr;onScrollChangeEmitter=new cr;missingPointerEventCleanupEmitter=new cr;onRemoveEventListenersEmitter=new cr;constructor(t){super(t);let r=Er(),{excalidrawAPI:o,viewModeEnabled:n=!1,zenModeEnabled:i=!1,gridModeEnabled:a=!1,objectsSnapModeEnabled:l=!1,theme:s=r.theme,name:c=`${b("labels.untitled")}-${$g()}`}=t;if(this.state={...r,theme:s,isLoading:!0,...this.getCanvasOffsets(),viewModeEnabled:n,zenModeEnabled:i,objectsSnapModeEnabled:l,gridSize:a?On:null,name:c,width:window.innerWidth,height:window.innerHeight},this.id=WN(),this.library=new nx(this),this.actionManager=new Wd(this.syncActionResult,()=>this.state,()=>this.scene.getElementsIncludingDeleted(),this),this.scene=new Ct,this.canvas=document.createElement("canvas"),this.rc=VN.canvas(this.canvas),this.renderer=new am(this.scene),this.store=new Ep,this.history=new Bs,o){let d={updateScene:this.updateScene,updateLibrary:this.library.updateLibrary,addFiles:this.addFiles,resetScene:this.resetScene,getSceneElementsIncludingDeleted:this.getSceneElementsIncludingDeleted,history:{clear:this.resetHistory},scrollToContent:this.scrollToContent,getSceneElements:this.getSceneElements,getAppState:()=>this.state,getFiles:()=>this.files,getName:this.getName,registerAction:m=>{this.actionManager.registerAction(m)},refresh:this.refresh,setToast:this.setToast,id:this.id,setActiveTool:this.setActiveTool,setCursor:this.setCursor,resetCursor:this.resetCursor,updateFrameRendering:this.updateFrameRendering,toggleSidebar:this.toggleSidebar,app:this,onChange:m=>this.onChangeEmitter.on(m),onPointerDown:m=>this.onPointerDownEmitter.on(m),onPointerUp:m=>this.onPointerUpEmitter.on(m),onScrollChange:m=>this.onScrollChangeEmitter.on(m),onUserFollow:m=>this.onUserFollowEmitter.on(m)};typeof o=="function"?o(d):console.error("excalidrawAPI should be a function!")}this.excalidrawContainerValue={container:this.excalidrawContainerRef.current,id:this.id},this.fonts=new xg({scene:this.scene,onSceneUpdated:this.onSceneUpdated}),this.history=new Bs,this.actionManager.registerAll(up),this.actionManager.registerAction(qC(this.history,this.store)),this.actionManager.registerAction(JC(this.history,this.store))}onWindowMessage(t){if(t.origin!=="https://player.vimeo.com"&&t.origin!=="https://www.youtube.com")return;let r=null;try{r=JSON.parse(t.data)}catch{}if(r)switch(t.origin){case"https://player.vimeo.com":if(r.method==="paused"){let o=null,n=document.body.querySelectorAll("iframe.excalidraw__embeddable");if(!n)break;for(let i of n)i.contentWindow===t.source&&(o=i.contentWindow);o?.postMessage(JSON.stringify({method:r.value?"play":"pause",value:!0}),"*")}break;case"https://www.youtube.com":if(r.event==="infoDelivery"&&r.info&&r.id&&typeof r.info.playerState=="number"){let o=r.id,n=r.info.playerState;Object.values(qs).includes(n)&&ey.set(o,n)}break}}cacheEmbeddableRef(t,r){r&&this.iFrameRefs.set(t.id,r)}getHTMLIFrameElement(t){return this.iFrameRefs.get(t.id)}handleEmbeddableCenterClick(t){if(this.state.activeEmbeddable?.element===t&&this.state.activeEmbeddable?.state==="active"||(setTimeout(()=>{this.setState({activeEmbeddable:{element:t,state:"active"},selectedElementIds:{[t.id]:!0},draggingElement:null,selectionElement:null})},100),go(t)))return;let r=this.getHTMLIFrameElement(t);if(r?.contentWindow){if(r.src.includes("youtube")){let o=ey.get(t.id);switch(o||(ey.set(t.id,qs.UNSTARTED),r.contentWindow.postMessage(JSON.stringify({event:"listening",id:t.id}),"*")),o){case qs.PLAYING:case qs.BUFFERING:r.contentWindow?.postMessage(JSON.stringify({event:"command",func:"pauseVideo",args:""}),"*");break;default:r.contentWindow?.postMessage(JSON.stringify({event:"command",func:"playVideo",args:""}),"*")}}r.src.includes("player.vimeo.com")&&r.contentWindow.postMessage(JSON.stringify({method:"paused"}),"*")}}isIframeLikeElementCenter(t,r,o,n){return t&&!r.altKey&&!r.shiftKey&&!r.metaKey&&!r.ctrlKey&&(this.state.activeEmbeddable?.element!==t||this.state.activeEmbeddable?.state==="hover"||!this.state.activeEmbeddable)&&o>=t.x+t.width/3&&o<=t.x+2*t.width/3&&n>=t.y+t.height/3&&n<=t.y+2*t.height/3}updateEmbedValidationStatus=(t,r)=>{this.embedsValidationStatus.set(t.id,r),Ne.delete(t)};updateEmbeddables=()=>{let t=new Set,r=!1;this.scene.getNonDeletedElements().filter(o=>{if(Lt(o)){if(t.add(o.id),!this.embedsValidationStatus.has(o.id)){r=!0;let n=Kl(o.link,this.props.validateEmbeddable);this.updateEmbedValidationStatus(o,n)}}else go(o)&&t.add(o.id);return!1}),r&&this.scene.informMutation(),this.iFrameRefs.forEach((o,n)=>{t.has(n)||this.iFrameRefs.delete(n)})};renderEmbeddables(){let t=this.state.zoom.value,r=this.state.width,o=this.state.height,n=this.scene.getNonDeletedElements().filter(i=>Lt(i)&&this.embedsValidationStatus.get(i.id)===!0||go(i));return Qe($N,{children:n.map(i=>{let{x:a,y:l}=Vt({sceneX:i.x,sceneY:i.y},this.state),s=Wa(i,r,o,this.state,this.scene.getNonDeletedElementsMap()),c=this.initializedEmbeds.has(i.id);if(s&&!c&&this.initializedEmbeds.add(i.id),!(s||c))return null;let m;if(go(i)){m=null;let h=(i.customData?.generationData??this.magicGenerations.get(i.id))||{status:"error",message:"No generation data",code:"ERR_NO_GENERATION_DATA"};if(h.status==="done"){let E=h.html;m={intrinsicSize:{w:i.width,h:i.height},type:"document",srcdoc:()=>E}}else if(h.status==="pending")m={intrinsicSize:{w:i.width,h:i.height},type:"document",srcdoc:()=>Nc(`
99
99
  <style>
100
100
  html, body {
101
101
  width: 100%;
102
102
  height: 100%;
103
- color: ${this.state.theme===ie.DARK?"white":"black"};
103
+ color: ${this.state.theme===se.DARK?"white":"black"};
104
104
  }
105
105
  body {
106
106
  display: flex;
@@ -167,7 +167,7 @@ Please output JUST THE HTML file containing your best attempt at implementing th
167
167
  </svg>
168
168
  </div>
169
169
  <div>Generating...</div>
170
- `)};else{let x;g.code==="ERR_GENERATION_INTERRUPTED"?x="Generation was interrupted...":x=g.message||"Generation failed",m={intrinsicSize:{w:i.width,h:i.height},type:"document",srcdoc:()=>wc(`
170
+ `)};else{let E;h.code==="ERR_GENERATION_INTERRUPTED"?E="Generation was interrupted...":E=h.message||"Generation failed",m={intrinsicSize:{w:i.width,h:i.height},type:"document",srcdoc:()=>Nc(`
171
171
  <style>
172
172
  html, body {
173
173
  height: 100%;
@@ -177,7 +177,7 @@ Please output JUST THE HTML file containing your best attempt at implementing th
177
177
  flex-direction: column;
178
178
  align-items: center;
179
179
  justify-content: center;
180
- color: ${ve.red[3]};
180
+ color: ${Te.red[3]};
181
181
  }
182
182
  h1, h3 {
183
183
  margin-top: 0;
@@ -185,10 +185,10 @@ Please output JUST THE HTML file containing your best attempt at implementing th
185
185
  }
186
186
  </style>
187
187
  <h1>Error!</h1>
188
- <h3>${x}</h3>
189
- `)}}}else m=Un(Ym(i.link||""));let p=this.state.activeEmbeddable?.element===i&&this.state.activeEmbeddable?.state==="active",u=this.state.activeEmbeddable?.element===i&&this.state.activeEmbeddable?.state==="hover";return qe("div",{className:F4("excalidraw__embeddable-container",{"is-hovered":u}),style:{transform:s?`translate(${a-this.state.offsetLeft}px, ${l-this.state.offsetTop}px) scale(${t})`:"none",display:s?"block":"none",opacity:Wf(i,Ut(i,this.scene.getNonDeletedElementsMap()),this.elementsPendingErasure),"--embeddable-radius":`${kr(Math.min(i.width,i.height),i)}px`},children:rh("div",{className:"excalidraw__embeddable-container__inner",style:{width:s?`${i.width}px`:0,height:s?`${i.height}px`:0,transform:s?`rotate(${i.angle}rad)`:"none",pointerEvents:p?na.enabled:na.disabled},children:[u&&qe("div",{className:"excalidraw__embeddable-hint",children:b("buttons.embeddableInteractionButton")}),qe("div",{className:"excalidraw__embeddable__outer",style:{padding:`${i.strokeWidth}px`},children:(St(i)?this.props.renderEmbeddable?.(i,this.state):null)??qe("iframe",{ref:g=>this.cacheEmbeddableRef(i,g),className:"excalidraw__embeddable",srcDoc:m?.type==="document"?m.srcdoc(this.state.theme):void 0,src:m?.type!=="document"?m?.link??"":void 0,scrolling:"no",referrerPolicy:"no-referrer-when-downgrade",title:"Excalidraw Embedded Content",allow:"accelerometer; autoplay; clipboard-write; encrypted-media; gyroscope; picture-in-picture",allowFullScreen:!0,sandbox:`${m?.sandbox?.allowSameOrigin?"allow-same-origin":""} allow-scripts allow-forms allow-popups allow-popups-to-escape-sandbox allow-presentation allow-downloads`})})]})},i.id)})})}getFrameNameDOMId=t=>`${this.id}-frame-name-${t.id}`;frameNameBoundsCache={get:t=>{let o=this.frameNameBoundsCache._cache.get(t.id);if(!o||o.zoom!==this.state.zoom.value||o.versionNonce!==t.versionNonce){let r=document.getElementById(this.getFrameNameDOMId(t));if(r){let n=r.getBoundingClientRect(),i=$e({clientX:n.x,clientY:n.y},this.state),a=$e({clientX:n.right,clientY:n.bottom},this.state);return o={x:i.x,y:i.y,width:a.x-i.x,height:a.y-i.y,angle:0,zoom:this.state.zoom.value,versionNonce:t.versionNonce},this.frameNameBoundsCache._cache.set(t.id,o),o}return null}return o},_cache:new Map};renderFrameNames=()=>{if(!this.state.frameRendering.enabled||!this.state.frameRendering.name)return null;let t=this.state.theme===ie.DARK,o=0,r=0;return this.scene.getNonDeletedFramesLikes().map(n=>{if(pi(n)?o++:r++,!Da(n,this.canvas.width/window.devicePixelRatio,this.canvas.height/window.devicePixelRatio,{offsetLeft:this.state.offsetLeft,offsetTop:this.state.offsetTop,scrollX:this.state.scrollX,scrollY:this.state.scrollY,zoom:this.state.zoom},this.scene.getNonDeletedElementsMap()))return null;let{x:i,y:a}=zt({sceneX:n.x,sceneY:n.y},this.state),l=6,s=()=>{z(n,{name:n.name?.trim()||null}),this.setState({editingFrame:null})},c,d=bp(n,pi(n)?o:r);if(n.id===this.state.editingFrame){let m=d;c=qe("input",{autoFocus:!0,value:m,onChange:p=>{z(n,{name:p.target.value})},onFocus:p=>p.target.select(),onBlur:()=>s(),onKeyDown:p=>{(p.key===I.ESCAPE||p.key===I.ENTER)&&s()},style:{background:this.state.viewBackgroundColor,filter:t?dl:"none",zIndex:2,border:"none",display:"block",padding:`${l}px`,borderRadius:4,boxShadow:"inset 0 0 0 1px var(--color-primary)",fontFamily:"Assistant",fontSize:"14px",transform:`translate(-${l}px, ${l}px)`,color:"var(--color-gray-80)",overflow:"hidden",maxWidth:`${document.body.clientWidth-i-l}px`},size:m.length+1||1,dir:"auto",autoComplete:"off",autoCapitalize:"off",autoCorrect:"off"})}else c=d;return qe("div",{id:this.getFrameNameDOMId(n),style:{position:"absolute",bottom:`${this.state.height+Je.nameOffsetY-a+this.state.offsetTop}px`,left:`${i-this.state.offsetLeft}px`,zIndex:2,fontSize:Je.nameFontSize,color:t?Je.nameColorDarkTheme:Je.nameColorLightTheme,lineHeight:Je.nameLineHeight,width:"max-content",maxWidth:`${n.width}px`,overflow:n.id===this.state.editingFrame?"visible":"hidden",whiteSpace:"nowrap",textOverflow:"ellipsis",cursor:Pe.MOVE,pointerEvents:this.state.viewModeEnabled?na.disabled:na.enabled},onPointerDown:m=>this.handleCanvasPointerDown(m),onWheel:m=>this.handleWheel(m),onContextMenu:this.handleCanvasContextMenu,onDoubleClick:()=>{this.setState({editingFrame:n.id})},children:c},n.id)})};toggleOverscrollBehavior(t){document.documentElement.style.overscrollBehaviorX=t.type==="pointerenter"?"none":"auto"}render(){let t=this.scene.getSelectedElements(this.state),{renderTopRightUI:o,renderCustomStats:r}=this.props,n=this.scene.getVersionNonce(),{elementsMap:i,visibleElements:a}=this.renderer.getRenderableElements({versionNonce:n,zoom:this.state.zoom,offsetLeft:this.state.offsetLeft,offsetTop:this.state.offsetTop,scrollX:this.state.scrollX,scrollY:this.state.scrollY,height:this.state.height,width:this.state.width,editingElement:this.state.editingElement,pendingImageElementId:this.state.pendingImageElementId}),l=this.scene.getNonDeletedElementsMap(),s=!(this.state.editingElement&&ne(this.state.editingElement))&&(this.state.selectionElement||this.state.draggingElement||this.state.resizingElement||this.state.activeTool.type==="laser"&&this.state.cursorButton==="down"||this.state.editingElement&&!W(this.state.editingElement)),c=t[0];return qe("div",{className:F4("excalidraw excalidraw-container",{"excalidraw--view-mode":this.state.viewModeEnabled,"excalidraw--mobile":this.device.editor.isMobile,"excalidraw--zen-mode":this.state.zenModeEnabled}),style:{"--ui-pointerEvents":s?na.disabled:na.enabled},ref:this.excalidrawContainerRef,onDrop:this.handleAppOnDrop,tabIndex:0,onKeyDown:this.props.handleKeyboardGlobally?void 0:this.onKeyDown,onPointerEnter:this.toggleOverscrollBehavior,onPointerLeave:this.toggleOverscrollBehavior,children:qe(G4.Provider,{value:this,children:qe(U4.Provider,{value:this.props,children:qe(T0.Provider,{value:this.excalidrawContainerValue,children:qe(v0.Provider,{value:this.device,children:qe(S0.Provider,{value:this.setAppState,children:qe(I0.Provider,{value:this.state,children:rh(C0.Provider,{value:this.scene.getNonDeletedElements(),children:[rh(k0.Provider,{value:this.actionManager,children:[qe(MS,{onHomeButtonClick:this.props.onHomeButtonClick||(()=>{}),canvas:this.canvas,appState:this.state,files:this.files,setAppState:this.setAppState,actionManager:this.actionManager,elements:this.scene.getNonDeletedElements(),onLockToggle:this.toggleLock,onPenModeToggle:this.togglePenMode,onHandToolToggle:this.onHandToolToggle,langCode:Cn().code,renderCustomStats:r,showExitZenModeBtn:typeof this.props?.zenModeEnabled>"u"&&this.state.zenModeEnabled,UIOptions:this.props.UIOptions,onExportImage:this.onExportImage,renderWelcomeScreen:!this.state.isLoading&&this.state.showWelcomeScreen&&this.state.activeTool.type==="selection"&&!this.state.zenModeEnabled&&!this.scene.getElementsIncludingDeleted().length,app:this,isCollaborating:this.props.isCollaborating,openAIKey:this.OPENAI_KEY,isOpenAIKeyPersisted:this.OPENAI_KEY_IS_PERSISTED,onOpenAIAPIKeyChange:this.onOpenAIKeyChange,onMagicSettingsConfirm:this.onMagicSettingsConfirm,renderTopRightUI:o,uiDisabled:this.props.ui===!1,children:this.props.children}),qe("div",{className:"excalidraw-textEditorContainer"}),qe("div",{className:"excalidraw-contextMenuContainer"}),qe("div",{className:"excalidraw-eye-dropper-container"}),qe(v4,{trails:[this.laserTrails,this.eraserTrail]}),t.length===1&&this.state.showHyperlinkPopup&&qe(n5,{element:c,elementsMap:l,setAppState:this.setAppState,onLinkOpen:this.props.onLinkOpen,setToast:this.setToast,updateEmbedValidationStatus:this.updateEmbedValidationStatus},c.id),this.props.aiEnabled!==!1&&t.length===1&&da(c)&&qe(u0,{element:c,elementsMap:i,children:qe(Qg,{title:b("labels.convertToCode"),icon:Wa,checked:!1,onChange:()=>this.onMagicFrameGenerate(c,"button")})}),t.length===1&&ir(c)&&c.customData?.generationData?.status==="done"&&rh(u0,{element:c,elementsMap:i,children:[qe(Qg,{title:b("labels.copySource"),icon:Kc,checked:!1,onChange:()=>this.onIframeSrcCopy(c)}),qe(Qg,{title:"Enter fullscreen",icon:Ib,checked:!1,onChange:()=>{let d=this.getHTMLIFrameElement(c);if(d)try{d.requestFullscreen(),this.setState({activeEmbeddable:{element:c,state:"active"},selectedElementIds:{[c.id]:!0},draggingElement:null,selectionElement:null})}catch(m){console.warn(m),this.setState({errorMessage:"Couldn't enter fullscreen"})}}})]}),this.state.toast!==null&&qe(DS,{message:this.state.toast.message,onClose:()=>this.setToast(null),duration:this.state.toast.duration,closable:this.state.toast.closable}),this.state.contextMenu&&this.props.interactive!==!1&&this.props.ui!==!1&&qe(i6,{items:this.state.contextMenu.items,top:this.state.contextMenu.top,left:this.state.contextMenu.left,actionManager:this.actionManager,onClose:d=>{this.setState({contextMenu:null},()=>{this.focusContainer(),d?.()})}}),qe(p0,{canvas:this.canvas,rc:this.rc,elementsMap:i,allElementsMap:l,visibleElements:a,versionNonce:n,selectionNonce:this.state.selectionElement?.versionNonce,scale:window.devicePixelRatio,appState:this.state,renderConfig:{imageCache:this.imageCache,isExporting:!1,renderGrid:!0,canvasBackgroundColor:this.state.viewBackgroundColor,embedsValidationStatus:this.embedsValidationStatus,elementsPendingErasure:this.elementsPendingErasure}}),qe(m0,{containerRef:this.excalidrawContainerRef,canvas:this.interactiveCanvas,elementsMap:i,visibleElements:a,selectedElements:t,versionNonce:n,selectionNonce:this.state.selectionElement?.versionNonce,scale:window.devicePixelRatio,appState:this.state,renderInteractiveSceneCallback:this.renderInteractiveSceneCallback,handleCanvasRef:this.handleInteractiveCanvasRef,onContextMenu:this.handleCanvasContextMenu,onPointerMove:this.handleCanvasPointerMove,onPointerUp:this.handleCanvasPointerUp,onPointerCancel:this.removePointer,onTouchMove:this.handleTouchMove,onPointerDown:this.handleCanvasPointerDown,onDoubleClick:this.handleCanvasDoubleClick}),this.state.userToFollow&&qe(P4,{width:this.state.width,height:this.state.height,userToFollow:this.state.userToFollow,onDisconnect:this.maybeUnfollowRemoteUser}),this.renderFrameNames()]}),this.renderEmbeddables()]})})})})})})})})}focusContainer=()=>{this.excalidrawContainerRef.current?.focus()};getSceneElementsIncludingDeleted=()=>this.scene.getElementsIncludingDeleted();getSceneElements=()=>this.scene.getNonDeletedElements();onInsertElements=t=>{this.addElementsFromPasteOrLibrary({elements:t,position:"center",files:null})};onExportImage=async(t,o,r)=>{we("export",t,"ui");let n=await Xa({type:t,data:{elements:o,appState:this.state,files:this.files},config:{exportBackground:this.state.exportBackground,name:this.getName(),viewBackgroundColor:this.state.viewBackgroundColor,exportingFrame:r.exportingFrame}}).catch(fm).catch(i=>{console.error(i),this.setState({errorMessage:i.message})});this.state.exportEmbedScene&&n&&Ul(n)&&this.setState({fileHandle:n})};magicGenerations=new Map;updateMagicGeneration=({frameElement:t,data:o})=>{o.status==="pending"?z(t,{customData:{generationData:void 0}},!1):z(t,{customData:{generationData:o}},!1),this.magicGenerations.set(t.id,o),this.onSceneUpdated()};getTextFromElements(t){return t.reduce((r,n)=>(W(n)&&r.push(n.text),r),[]).join(`
188
+ <h3>${E}</h3>
189
+ `)}}}else m=$n(pp(i.link||""));let p=this.state.activeEmbeddable?.element===i&&this.state.activeEmbeddable?.state==="active",u=this.state.activeEmbeddable?.element===i&&this.state.activeEmbeddable?.state==="hover";return Qe("div",{className:FA("excalidraw__embeddable-container",{"is-hovered":u}),style:{transform:s?`translate(${a-this.state.offsetLeft}px, ${l-this.state.offsetTop}px) scale(${t})`:"none",display:s?"block":"none",opacity:w1(i,Xt(i,this.scene.getNonDeletedElementsMap()),this.elementsPendingErasure),"--embeddable-radius":`${Fo(Math.min(i.width,i.height),i)}px`},children:Pg("div",{className:"excalidraw__embeddable-container__inner",style:{width:s?`${i.width}px`:0,height:s?`${i.height}px`:0,transform:s?`rotate(${i.angle}rad)`:"none",pointerEvents:p?ga.enabled:ga.disabled},children:[u&&Qe("div",{className:"excalidraw__embeddable-hint",children:b("buttons.embeddableInteractionButton")}),Qe("div",{className:"excalidraw__embeddable__outer",style:{padding:`${i.strokeWidth}px`},children:(Lt(i)?this.props.renderEmbeddable?.(i,this.state):null)??Qe("iframe",{ref:h=>this.cacheEmbeddableRef(i,h),className:"excalidraw__embeddable",srcDoc:m?.type==="document"?m.srcdoc(this.state.theme):void 0,src:m?.type!=="document"?m?.link??"":void 0,scrolling:"no",referrerPolicy:"no-referrer-when-downgrade",title:"Excalidraw Embedded Content",allow:"accelerometer; autoplay; clipboard-write; encrypted-media; gyroscope; picture-in-picture",allowFullScreen:!0,sandbox:`${m?.sandbox?.allowSameOrigin?"allow-same-origin":""} allow-scripts allow-forms allow-popups allow-popups-to-escape-sandbox allow-presentation allow-downloads`})})]})},i.id)})})}getFrameNameDOMId=t=>`${this.id}-frame-name-${t.id}`;frameNameBoundsCache={get:t=>{let r=this.frameNameBoundsCache._cache.get(t.id);if(!r||r.zoom!==this.state.zoom.value||r.versionNonce!==t.versionNonce){let o=document.getElementById(this.getFrameNameDOMId(t));if(o){let n=o.getBoundingClientRect(),i=je({clientX:n.x,clientY:n.y},this.state),a=je({clientX:n.right,clientY:n.bottom},this.state);return r={x:i.x,y:i.y,width:a.x-i.x,height:a.y-i.y,angle:0,zoom:this.state.zoom.value,versionNonce:t.versionNonce},this.frameNameBoundsCache._cache.set(t.id,r),r}return null}return r},_cache:new Map};renderFrameNames=()=>{if(!this.state.frameRendering.enabled||!this.state.frameRendering.name)return null;let t=this.state.theme===se.DARK,r=0,o=0;return this.scene.getNonDeletedFramesLikes().map(n=>{if(yi(n)?r++:o++,!Wa(n,this.canvas.width/window.devicePixelRatio,this.canvas.height/window.devicePixelRatio,{offsetLeft:this.state.offsetLeft,offsetTop:this.state.offsetTop,scrollX:this.state.scrollX,scrollY:this.state.scrollY,zoom:this.state.zoom},this.scene.getNonDeletedElementsMap()))return null;let{x:i,y:a}=Vt({sceneX:n.x,sceneY:n.y},this.state),l=6,s=()=>{H(n,{name:n.name?.trim()||null}),this.setState({editingFrame:null})},c,d=Vp(n,yi(n)?r:o);if(n.id===this.state.editingFrame){let m=d;c=Qe("input",{autoFocus:!0,value:m,onChange:p=>{H(n,{name:p.target.value})},onFocus:p=>p.target.select(),onBlur:()=>s(),onKeyDown:p=>{(p.key===C.ESCAPE||p.key===C.ENTER)&&s()},style:{background:this.state.viewBackgroundColor,filter:t?Cl:"none",zIndex:2,border:"none",display:"block",padding:`${l}px`,borderRadius:4,boxShadow:"inset 0 0 0 1px var(--color-primary)",fontFamily:"Assistant",fontSize:"14px",transform:`translate(-${l}px, ${l}px)`,color:"var(--color-gray-80)",overflow:"hidden",maxWidth:`${document.body.clientWidth-i-l}px`},size:m.length+1||1,dir:"auto",autoComplete:"off",autoCapitalize:"off",autoCorrect:"off"})}else c=d;return Qe("div",{id:this.getFrameNameDOMId(n),style:{position:"absolute",bottom:`${this.state.height+et.nameOffsetY-a+this.state.offsetTop}px`,left:`${i-this.state.offsetLeft}px`,zIndex:2,fontSize:et.nameFontSize,color:t?et.nameColorDarkTheme:et.nameColorLightTheme,lineHeight:et.nameLineHeight,width:"max-content",maxWidth:`${n.width}px`,overflow:n.id===this.state.editingFrame?"visible":"hidden",whiteSpace:"nowrap",textOverflow:"ellipsis",cursor:Re.MOVE,pointerEvents:this.state.viewModeEnabled?ga.disabled:ga.enabled},onPointerDown:m=>this.handleCanvasPointerDown(m),onWheel:m=>this.handleWheel(m),onContextMenu:this.handleCanvasContextMenu,onDoubleClick:()=>{this.setState({editingFrame:n.id})},children:c},n.id)})};toggleOverscrollBehavior(t){document.documentElement.style.overscrollBehaviorX=t.type==="pointerenter"?"none":"auto"}render(){let t=this.scene.getSelectedElements(this.state),{renderTopRightUI:r,renderCustomStats:o}=this.props,n=this.scene.getVersionNonce(),{elementsMap:i,visibleElements:a}=this.renderer.getRenderableElements({versionNonce:n,zoom:this.state.zoom,offsetLeft:this.state.offsetLeft,offsetTop:this.state.offsetTop,scrollX:this.state.scrollX,scrollY:this.state.scrollY,height:this.state.height,width:this.state.width,editingElement:this.state.editingElement,pendingImageElementId:this.state.pendingImageElementId}),l=this.scene.getNonDeletedElementsMap(),s=!(this.state.editingElement&&ce(this.state.editingElement))&&(this.state.selectionElement||this.state.draggingElement||this.state.resizingElement||this.state.activeTool.type==="laser"&&this.state.cursorButton==="down"||this.state.editingElement&&!V(this.state.editingElement)),c=t[0];return Qe("div",{className:FA("excalidraw excalidraw-container",{"excalidraw--view-mode":this.state.viewModeEnabled,"excalidraw--mobile":this.device.editor.isMobile,"excalidraw--zen-mode":this.state.zenModeEnabled}),style:{"--ui-pointerEvents":s?ga.disabled:ga.enabled},ref:this.excalidrawContainerRef,onDrop:this.handleAppOnDrop,tabIndex:0,onKeyDown:this.props.handleKeyboardGlobally?void 0:this.onKeyDown,onPointerEnter:this.toggleOverscrollBehavior,onPointerLeave:this.toggleOverscrollBehavior,children:Qe(UA.Provider,{value:this,children:Qe(GA.Provider,{value:this.props,children:Qe(oy.Provider,{value:this.excalidrawContainerValue,children:Qe(ry.Provider,{value:this.device,children:Qe(ay.Provider,{value:this.setAppState,children:Qe(iy.Provider,{value:this.state,children:Pg(ny.Provider,{value:this.scene.getNonDeletedElements(),children:[Pg(ly.Provider,{value:this.actionManager,children:[Qe(M4,{onHomeButtonClick:this.props.onHomeButtonClick||(()=>{}),canvas:this.canvas,appState:this.state,files:this.files,setAppState:this.setAppState,actionManager:this.actionManager,elements:this.scene.getNonDeletedElements(),onLockToggle:this.toggleLock,onPenModeToggle:this.togglePenMode,onHandToolToggle:this.onHandToolToggle,langCode:Dn().code,renderCustomStats:o,showExitZenModeBtn:typeof this.props?.zenModeEnabled>"u"&&this.state.zenModeEnabled,UIOptions:this.props.UIOptions,onExportImage:this.onExportImage,renderWelcomeScreen:!this.state.isLoading&&this.state.showWelcomeScreen&&this.state.activeTool.type==="selection"&&!this.state.zenModeEnabled&&!this.scene.getElementsIncludingDeleted().length,app:this,isCollaborating:this.props.isCollaborating,openAIKey:this.OPENAI_KEY,isOpenAIKeyPersisted:this.OPENAI_KEY_IS_PERSISTED,onOpenAIAPIKeyChange:this.onOpenAIKeyChange,onMagicSettingsConfirm:this.onMagicSettingsConfirm,renderTopRightUI:r,uiDisabled:this.props.ui===!1,children:this.props.children}),Qe("div",{className:"excalidraw-textEditorContainer"}),Qe("div",{className:"excalidraw-contextMenuContainer"}),Qe("div",{className:"excalidraw-eye-dropper-container"}),Qe(vA,{trails:[this.laserTrails,this.eraserTrail]}),t.length===1&&this.state.showHyperlinkPopup&&Qe(n5,{element:c,elementsMap:l,setAppState:this.setAppState,onLinkOpen:this.props.onLinkOpen,setToast:this.setToast,updateEmbedValidationStatus:this.updateEmbedValidationStatus},c.id),this.props.aiEnabled!==!1&&t.length===1&&ya(c)&&Qe($0,{element:c,elementsMap:i,children:Qe(Ag,{title:b("labels.convertToCode"),icon:tl,checked:!1,onChange:()=>this.onMagicFrameGenerate(c,"button")})}),t.length===1&&go(c)&&c.customData?.generationData?.status==="done"&&Pg($0,{element:c,elementsMap:i,children:[Qe(Ag,{title:b("labels.copySource"),icon:sd,checked:!1,onChange:()=>this.onIframeSrcCopy(c)}),Qe(Ag,{title:"Enter fullscreen",icon:nE,checked:!1,onChange:()=>{let d=this.getHTMLIFrameElement(c);if(d)try{d.requestFullscreen(),this.setState({activeEmbeddable:{element:c,state:"active"},selectedElementIds:{[c.id]:!0},draggingElement:null,selectionElement:null})}catch(m){console.warn(m),this.setState({errorMessage:"Couldn't enter fullscreen"})}}})]}),this.state.toast!==null&&Qe(_4,{message:this.state.toast.message,onClose:()=>this.setToast(null),duration:this.state.toast.duration,closable:this.state.toast.closable}),this.state.contextMenu&&this.props.interactive!==!1&&this.props.ui!==!1&&Qe(iI,{items:this.state.contextMenu.items,top:this.state.contextMenu.top,left:this.state.contextMenu.left,actionManager:this.actionManager,onClose:d=>{this.setState({contextMenu:null},()=>{this.focusContainer(),d?.()})}}),Qe(K0,{canvas:this.canvas,rc:this.rc,elementsMap:i,allElementsMap:l,visibleElements:a,versionNonce:n,selectionNonce:this.state.selectionElement?.versionNonce,scale:window.devicePixelRatio,appState:this.state,renderConfig:{imageCache:this.imageCache,isExporting:!1,renderGrid:!0,canvasBackgroundColor:this.state.viewBackgroundColor,embedsValidationStatus:this.embedsValidationStatus,elementsPendingErasure:this.elementsPendingErasure}}),Qe(Y0,{containerRef:this.excalidrawContainerRef,canvas:this.interactiveCanvas,elementsMap:i,visibleElements:a,selectedElements:t,versionNonce:n,selectionNonce:this.state.selectionElement?.versionNonce,scale:window.devicePixelRatio,appState:this.state,device:this.device,renderInteractiveSceneCallback:this.renderInteractiveSceneCallback,handleCanvasRef:this.handleInteractiveCanvasRef,onContextMenu:this.handleCanvasContextMenu,onPointerMove:this.handleCanvasPointerMove,onPointerUp:this.handleCanvasPointerUp,onPointerCancel:this.removePointer,onTouchMove:this.handleTouchMove,onPointerDown:this.handleCanvasPointerDown,onDoubleClick:this.handleCanvasDoubleClick}),this.state.userToFollow&&Qe(DA,{width:this.state.width,height:this.state.height,userToFollow:this.state.userToFollow,onDisconnect:this.maybeUnfollowRemoteUser}),this.renderFrameNames()]}),this.renderEmbeddables()]})})})})})})})})}focusContainer=()=>{this.excalidrawContainerRef.current?.focus()};getSceneElementsIncludingDeleted=()=>this.scene.getElementsIncludingDeleted();getSceneElements=()=>this.scene.getNonDeletedElements();onInsertElements=t=>{this.addElementsFromPasteOrLibrary({elements:t,position:"center",files:null})};onExportImage=async(t,r,o)=>{ve("export",t,"ui");let n=await al({type:t,data:{elements:r,appState:this.state,files:this.files},config:{exportBackground:this.state.exportBackground,name:this.getName(),viewBackgroundColor:this.state.viewBackgroundColor,exportingFrame:o.exportingFrame}}).catch(Dm).catch(i=>{console.error(i),this.setState({errorMessage:i.message})});this.state.exportEmbedScene&&n&&ql(n)&&this.setState({fileHandle:n})};magicGenerations=new Map;updateMagicGeneration=({frameElement:t,data:r})=>{r.status==="pending"?H(t,{customData:{generationData:void 0}},!1):H(t,{customData:{generationData:r}},!1),this.magicGenerations.set(t.id,r),this.onSceneUpdated()};getTextFromElements(t){return t.reduce((o,n)=>(V(n)&&o.push(n.text),o),[]).join(`
190
190
 
191
- `)}async onMagicFrameGenerate(t,o){if(!this.OPENAI_KEY){this.setState({openDialog:{name:"settings",tab:"diagram-to-code",source:"generation"}}),we("ai","generate (missing key)","d2c");return}let r=Kl(this.scene.getNonDeletedElements(),t).filter(m=>!da(m));if(!r.length){o==="button"?(this.setState({errorMessage:"Cannot generate from an empty frame"}),we("ai","generate (no-children)","d2c")):this.setActiveTool({type:"magicframe"});return}let n=this.insertIframeElement({sceneX:t.x+t.width+30,sceneY:t.y,width:t.width,height:t.height});if(!n)return;this.updateMagicGeneration({frameElement:n,data:{status:"pending"}}),this.setState({selectedElementIds:{[n.id]:!0}});let i=await kp({data:{elements:this.scene.getNonDeletedElements(),appState:{...this.state,exportBackground:!0,viewBackgroundColor:this.state.viewBackgroundColor},files:this.files},config:{exportingFrame:t}}),a=await rp(i),l=this.getTextFromElements(r);we("ai","generate (start)","d2c");let s=await S4({image:a,apiKey:this.OPENAI_KEY,text:l,theme:this.state.theme});if(!s.ok){we("ai","generate (failed)","d2c"),console.error(s.error),this.updateMagicGeneration({frameElement:n,data:{status:"error",code:"ERR_OAI",message:s.error?.message||"Unknown error during generation"}});return}if(we("ai","generate (success)","d2c"),s.choices[0].message.content==null){this.updateMagicGeneration({frameElement:n,data:{status:"error",code:"ERR_OAI",message:"Nothing genereated :("}});return}let c=s.choices[0].message.content,d=c.slice(c.indexOf("<!DOCTYPE html>"),c.indexOf("</html>")+7);this.updateMagicGeneration({frameElement:n,data:{status:"done",html:d}})}onIframeSrcCopy(t){t.customData?.generationData?.status==="done"&&(Xn(t.customData.generationData.html),this.setToast({message:"copied to clipboard",closable:!1,duration:1500}))}OPENAI_KEY=Mo.get(or.OAI_API_KEY);OPENAI_KEY_IS_PERSISTED=Mo.has(or.OAI_API_KEY)||!1;onOpenAIKeyChange=(t,o)=>{if(this.OPENAI_KEY=t||null,o){let r=Mo.set(or.OAI_API_KEY,t);this.OPENAI_KEY_IS_PERSISTED=r}else this.OPENAI_KEY_IS_PERSISTED=!1};onMagicSettingsConfirm=(t,o,r)=>{if(this.OPENAI_KEY=t||null,this.onOpenAIKeyChange(this.OPENAI_KEY,o),r==="settings")return;let n=this.scene.getSelectedElements({selectedElementIds:this.state.selectedElementIds});t?n.length?this.onMagicframeToolSelect():this.setActiveTool({type:"magicframe"}):da(n[0])||this.setActiveTool({type:"magicframe"})};onMagicframeToolSelect=()=>{if(!this.OPENAI_KEY){this.setState({openDialog:{name:"settings",tab:"diagram-to-code",source:"tool"}}),we("ai","tool-select (missing key)","d2c");return}let t=this.scene.getSelectedElements({selectedElementIds:this.state.selectedElementIds});if(t.length===0)this.setActiveTool({type:wt.magicframe}),we("ai","tool-select (empty-selection)","d2c");else{let o=t.length===1&&da(t[0])&&t[0];if(!o&&t.some(n=>Q(n)||n.frameId)){this.setActiveTool({type:wt.magicframe});return}we("ai","tool-select (existing selection)","d2c");let r;if(o)r=o;else{let[n,i,a,l]=Se(t),s=50;r=xc({...Je,x:n-s,y:i-s,width:a-n+s*2,height:l-i+s*2,opacity:100,locked:!1}),this.scene.addNewElement(r);for(let c of t)z(c,{frameId:r.id});this.setState({selectedElementIds:{[r.id]:!0}})}this.onMagicFrameGenerate(r,"upstream")}};openEyeDropper=({type:t})=>{Zt.set(Pi,{swapPreviewOnAlt:!0,colorPickerType:t==="stroke"?"elementStroke":"elementBackground",onSelect:(o,r)=>{let n=t==="background"&&r.altKey||t==="stroke"&&!r.altKey;!this.scene.getSelectedElements(this.state).length||this.state.activeTool.type!=="selection"?n?this.syncActionResult({appState:{...this.state,currentItemStrokeColor:o},commitToHistory:!0}):this.syncActionResult({appState:{...this.state,currentItemBackgroundColor:o},commitToHistory:!0}):this.updateScene({elements:this.scene.getElementsIncludingDeleted().map(a=>this.state.selectedElementIds[a.id]?ae(a,{[n?"strokeColor":"backgroundColor"]:o}):a)})},keepOpenOnAlt:!1})};syncActionResult=ct(t=>{if(this.unmounted||t===!1)return;let o=null;if(t.elements&&(t.elements.forEach(r=>{this.state.editingElement?.id===r.id&&this.state.editingElement!==r&&js(r)&&(o=r)}),this.scene.replaceAllElements(t.elements),t.commitToHistory&&this.history.resumeRecording()),t.files&&(this.files=t.replaceFiles?t.files:{...this.files,...t.files},this.addNewImagesToImageCache()),t.appState||o||this.state.contextMenu){t.commitToHistory&&this.history.resumeRecording();let r=t?.appState?.viewModeEnabled||!1,n=t?.appState?.zenModeEnabled||!1,i=t?.appState?.gridSize||null,a=t?.appState?.theme||this.props.theme||ie.LIGHT,l=t?.appState?.name??this.state.name,s=t?.appState?.errorMessage??this.state.errorMessage;typeof this.props.viewModeEnabled<"u"&&(r=this.props.viewModeEnabled),typeof this.props.zenModeEnabled<"u"&&(n=this.props.zenModeEnabled),typeof this.props.gridModeEnabled<"u"&&(i=this.props.gridModeEnabled?An:null),o=o||t.appState?.editingElement||null,o?.isDeleted&&(o=null),this.setState(c=>Object.assign(t.appState||{},{contextMenu:null,editingElement:o,viewModeEnabled:r,zenModeEnabled:n,gridSize:i,theme:a,name:l,errorMessage:s}),()=>{t.syncHistory&&this.history.setCurrentState(this.state,this.scene.getElementsIncludingDeleted())})}});onBlur=ct(()=>{il=!1,this.setState({isBindingEnabled:!0})});onUnload=()=>{this.onBlur()};disableEvent=t=>{t.preventDefault()};resetHistory=()=>{this.history.clear()};resetScene=ct(t=>{this.scene.replaceAllElements([]),this.setState(o=>({...Bo(),isLoading:t?.resetLoadingState?!1:o.isLoading,theme:this.state.theme})),this.resetHistory()});initializeScene=async()=>{"launchQueue"in window&&"LaunchParams"in window&&window.launchQueue.setConsumer(async r=>{if(!r.files.length)return;let n=r.files[0],i=await n.getFile();this.loadFileToCanvas(new File([i],i.name||"",{type:i.type}),n)}),this.props.theme&&this.setState({theme:this.props.theme}),this.state.isLoading||this.setState({isLoading:!0});let t=null;try{t=await this.props.initialData||null,t?.libraryItems&&this.library.updateLibrary({libraryItems:t.libraryItems,merge:!0}).catch(r=>{console.error(r)})}catch(r){console.error(r),t={appState:{errorMessage:r.message||"Encountered an error during importing or restoring scene data"}}}let o=Sa(t,null,null,{repairBindings:!0});o.appState={...o.appState,theme:this.props.theme||o.appState.theme,openSidebar:o.appState?.openSidebar||this.state.openSidebar,activeTool:o.appState.activeTool.type==="image"?{...o.appState.activeTool,type:"selection"}:o.appState.activeTool,isLoading:!1,toast:this.state.toast},t?.scrollToContent&&(o.appState={...o.appState,...nn(o.elements,{...o.appState,width:this.state.width,height:this.state.height,offsetTop:this.state.offsetTop,offsetLeft:this.state.offsetLeft})}),this.fonts.loadFontsForElements(o.elements),t?.scrollX!=null&&(o.appState.scrollX=t.scrollX),t?.scrollY!=null&&(o.appState.scrollY=t.scrollY),this.resetHistory(),this.syncActionResult({...o,commitToHistory:!0})};isMobileBreakpoint=(t,o)=>t<ty||o<ry&&t<oy;refreshViewportBreakpoints=()=>{if(!this.excalidrawContainerRef.current)return;let{clientWidth:o,clientHeight:r}=document.body,n=this.device.viewport,i=hl(n,{isLandscape:o>r,isMobile:this.isMobileBreakpoint(o,r)});return n!==i?(this.device={...this.device,viewport:i},!0):!1};refreshEditorBreakpoints=()=>{let t=this.excalidrawContainerRef.current;if(!t)return;let{width:o,height:r}=t.getBoundingClientRect(),n=this.props.UIOptions.dockedSidebarBreakpoint!=null?this.props.UIOptions.dockedSidebarBreakpoint:ny,i=this.device.editor,a=hl(i,{isMobile:this.isMobileBreakpoint(o,r),canFitSidebar:o>n});return i!==a?(this.device={...this.device,editor:a},!0):!1};async componentDidMount(){if(this.unmounted=!1,this.excalidrawContainerValue.container=this.excalidrawContainerRef.current,C.MODE===ph.TEST||C.DEV){let o=this.setState.bind(this);Object.defineProperties(window.h,{state:{configurable:!0,get:()=>this.state},setState:{configurable:!0,value:(...r)=>this.setState(...r)},app:{configurable:!0,value:this},history:{configurable:!0,value:this.history}})}this.scene.addCallback(this.onSceneUpdated),this.addEventListeners(),this.props.autoFocus&&this.excalidrawContainerRef.current&&this.focusContainer(),Ro()||(this.refreshViewportBreakpoints(),this.refreshEditorBreakpoints()),Bs&&this.excalidrawContainerRef.current&&(this.resizeObserver=new ResizeObserver(()=>{this.refreshEditorBreakpoints(),this.updateDOMRect()}),this.resizeObserver?.observe(this.excalidrawContainerRef.current)),new URLSearchParams(window.location.search.slice(1)).has("web-share-target")?this.restoreFileFromShare():this.updateDOMRect(this.initializeScene),Y0()&&!O2()&&this.setState({errorMessage:qe(e4,{})})}componentWillUnmount(){this.renderer.destroy(),this.scene=new lt,this.renderer=new Vd(this.scene),this.files={},this.imageCache.clear(),this.resizeObserver?.disconnect(),this.unmounted=!0,this.removeEventListeners(),this.scene.destroy(),this.library.destroy(),this.laserTrails.stop(),this.eraserTrail.stop(),this.onChangeEmitter.clear(),Me.destroy(),yr.destroy(),yv(),this.onChangeEmitter.clear(),C.PROD&&(this.history=new lE,this.library=new Ix(this),this.actionManager=new Ad(this.syncActionResult,()=>this.state,()=>this.scene.getElementsIncludingDeleted(),this),this.canvas=null,this.interactiveCanvas=null,this.rc=null,this.excalidrawContainerRef.current=void 0,this.nearestScrollableContainer=void 0,this.excalidrawContainerValue={container:null,id:"unmounted"}),clearTimeout(Qi),Ye.clearCache(),to.clearCache(),Qi=0,document.documentElement.style.overscrollBehaviorX=""}onResize=ct(()=>{this.scene.getElementsIncludingDeleted().forEach(t=>Me.delete(t)),this.refreshViewportBreakpoints(),this.updateDOMRect(),Bs||this.refreshEditorBreakpoints(),this.setState({})});onFullscreenChange=()=>{!document.fullscreenElement&&this.state.activeEmbeddable?.state==="active"&&this.setState({activeEmbeddable:null})};removeEventListeners(){this.onRemoveEventListenersEmitter.trigger()}addEventListeners(){this.removeEventListeners(),this.props.handleKeyboardGlobally&&this.onRemoveEventListenersEmitter.once(ft(document,"keydown",this.onKeyDown,!1)),this.onRemoveEventListenersEmitter.once(ft(this.excalidrawContainerRef.current,"wheel",this.onWheel,{passive:!1}),ft(window,"message",this.onWindowMessage,!1),ft(document,"pointerup",this.removePointer),ft(document,"copy",this.onCopy),ft(document,"keyup",this.onKeyUp,{passive:!0}),ft(document,"mousemove",this.updateCurrentCursorPosition),ft(document.fonts,"loadingdone",t=>{let o=t.fontfaces;this.fonts.onFontsLoaded(o)}),ft(document,"gesturestart",this.onGestureStart,!1),ft(document,"gesturechange",this.onGestureChange,!1),ft(document,"gestureend",this.onGestureEnd,!1),ft(window,"focus",()=>{this.maybeCleanupAfterMissingPointerUp(null)})),!this.state.viewModeEnabled&&(this.onRemoveEventListenersEmitter.once(ft(document,"fullscreenchange",this.onFullscreenChange),ft(document,"paste",this.pasteFromClipboard),ft(document,"cut",this.onCut),ft(window,"resize",this.onResize,!1),ft(window,"unload",this.onUnload,!1),ft(window,"blur",this.onBlur,!1),ft(this.excalidrawContainerRef.current,"dragover",this.disableEvent,!1),ft(this.excalidrawContainerRef.current,"drop",this.disableEvent,!1)),this.props.detectScroll&&this.onRemoveEventListenersEmitter.once(ft(yy(this.excalidrawContainerRef.current),"scroll",this.onScroll)))}componentDidUpdate(t,o){this.updateEmbeddables();let r=this.scene.getElementsIncludingDeleted(),n=this.scene.getNonDeletedElementsMap();!this.state.showWelcomeScreen&&!r.length&&this.setState({showWelcomeScreen:!0}),t.UIOptions.dockedSidebarBreakpoint!==this.props.UIOptions.dockedSidebarBreakpoint&&this.refreshEditorBreakpoints(),o.userToFollow&&!this.state.collaborators.has(o.userToFollow.socketId)&&this.maybeUnfollowRemoteUser(),this.props.activeTool&&this.props.activeTool.type!==this.state.activeTool.type&&this.setActiveTool(this.props.activeTool),(o.zoom.value!==this.state.zoom.value||o.scrollX!==this.state.scrollX||o.scrollY!==this.state.scrollY)&&(this.props?.onScrollChange?.(this.state.scrollX,this.state.scrollY,this.state.zoom),this.onScrollChangeEmitter.trigger(this.state.scrollX,this.state.scrollY,this.state.zoom)),o.userToFollow!==this.state.userToFollow&&(o.userToFollow&&this.onUserFollowEmitter.trigger({userToFollow:o.userToFollow,action:"UNFOLLOW"}),this.state.userToFollow&&this.onUserFollowEmitter.trigger({userToFollow:this.state.userToFollow,action:"FOLLOW"})),Object.keys(this.state.selectedElementIds).length&&To(this.state)&&this.setState({activeTool:Qe(this.state,{type:"selection"})}),this.state.activeTool.type==="eraser"&&o.theme!==this.state.theme&&mf(this.interactiveCanvas,this.state.theme),o.activeTool.type==="selection"&&this.state.activeTool.type!=="selection"&&this.state.showHyperlinkPopup&&this.setState({showHyperlinkPopup:!1}),t.langCode!==this.props.langCode&&this.updateLanguage(),To(o)&&!To(this.state)&&this.eraserTrail.endPath(),t.viewModeEnabled!==this.props.viewModeEnabled&&this.setState({viewModeEnabled:!!this.props.viewModeEnabled}),o.viewModeEnabled!==this.state.viewModeEnabled&&(this.addEventListeners(),this.deselectElements()),t.zenModeEnabled!==this.props.zenModeEnabled&&this.setState({zenModeEnabled:!!this.props.zenModeEnabled}),t.theme!==this.props.theme&&this.props.theme&&this.setState({theme:this.props.theme}),t.gridModeEnabled!==this.props.gridModeEnabled&&this.setState({gridSize:this.props.gridModeEnabled?An:null}),!this.props.UIOptions.canvasActions&&this.state.openMenu==="canvas"&&this.setState({openMenu:null}),this.excalidrawContainerRef.current?.classList.toggle("theme--dark",this.state.theme===ie.DARK),this.state.editingLinearElement&&!this.state.selectedElementIds[this.state.editingLinearElement.elementId]&&setTimeout(()=>{this.state.editingLinearElement&&this.actionManager.executeAction(Zo)}),this.state.editingElement?.isDeleted&&this.setState({editingElement:null}),this.state.selectedLinearElement&&!this.state.selectedElementIds[this.state.selectedLinearElement.elementId]&&this.setState({selectedLinearElement:null});let{multiElement:a}=o;o.activeTool!==this.state.activeTool&&a!=null&&Qr(this.state)&&kt(a,!1)&&pc(a,this.state,this.scene,Cr($.getPointAtIndexGlobalCoordinates(a,-1,n)),n),this.history.record(this.state,r),this.state.isLoading||(this.props.onChange?.(r,this.state,this.files,this.props.id),this.onChangeEmitter.trigger(r,this.state,this.files))}renderInteractiveSceneCallback=({atLeastOneVisibleElement:t,scrollBars:o,elementsMap:r})=>{o&&(E0=o);let n=W(this.state.editingElement)?!1:!t&&r.size>0;this.state.scrolledOutside!==n&&this.setState({scrolledOutside:n}),this.scheduleImageRefresh()};onScroll=ca(()=>{let{offsetTop:t,offsetLeft:o}=this.getCanvasOffsets();this.setState(r=>r.offsetLeft===o&&r.offsetTop===t?null:{offsetTop:t,offsetLeft:o})},Q0);onCut=ct(t=>{!this.excalidrawContainerRef.current?.contains(document.activeElement)||rr(t.target)||(this.actionManager.executeAction(md,"keyboard",t),t.preventDefault(),t.stopPropagation())});onCopy=ct(t=>{!this.excalidrawContainerRef.current?.contains(document.activeElement)||rr(t.target)||(this.actionManager.executeAction(Ja,"keyboard",t),t.preventDefault(),t.stopPropagation())});static resetTapTwice(){Yd=!1}onTouchStart=t=>{if(V0&&t.preventDefault(),this.props.interactive!==!1){if(!Yd){Yd=!0,clearTimeout(b0),b0=window.setTimeout(e.resetTapTwice,q0);return}if(Yd&&t.touches.length===1){let o=t.touches[0];this.handleCanvasDoubleClick({clientX:o.clientX,clientY:o.clientY}),Yd=!1,clearTimeout(b0)}t.touches.length===2&&this.setState({selectedElementIds:Oe({},this.state),activeEmbeddable:null})}};onTouchEnd=t=>{this.props.interactive!==!1&&(this.resetContextMenuTimer(),t.touches.length>0?this.setState({previousSelectedElementIds:{},selectedElementIds:Oe(this.state.previousSelectedElementIds,this.state)}):Fe.pointers.clear())};pasteFromClipboard=ct(async t=>{if(this.props.interactive===!1)return;let o=!!oh,r=document.activeElement,n=this.excalidrawContainerRef.current?.contains(r);if(t&&!n)return;let i=document.elementFromPoint(this.lastViewportPosition.x,this.lastViewportPosition.y);if(t&&(!(i instanceof HTMLCanvasElement)||rr(r)))return;let{x:a,y:l}=$e({clientX:this.lastViewportPosition.x,clientY:this.lastViewportPosition.y},this.state),s=t?.clipboardData?.files[0],c=await Cp(t,o);if(!s&&!o){if(c.mixedContent)return this.addElementsFromMixedContentPaste(c.mixedContent,{isPlainPaste:o,sceneX:a,sceneY:l});if(c.text){let d=c.text.trim();d.startsWith("<svg")&&d.endsWith("</svg>")&&(s=Cf(d))}}if(Ci(s)&&!c.spreadsheet){if(!this.isToolSupported("image")){this.setState({errorMessage:b("errors.imageToolNotSupported")});return}let d=this.createImageElement({sceneX:a,sceneY:l});this.insertImageElement(d,s),this.initializeImageDimensions(d),this.setState({selectedElementIds:Oe({[d.id]:!0},this.state)});return}if(this.props.onPaste)try{if(await this.props.onPaste(c,t)===!1)return}catch(d){console.error(d)}if(c.errorMessage)this.setState({errorMessage:c.errorMessage});else if(c.spreadsheet&&!o)this.setState({pasteDialog:{data:c.spreadsheet,shown:!0}});else if(c.elements){let d=c.programmaticAPI?Hd(c.elements):c.elements;this.addElementsFromPasteOrLibrary({elements:d,files:c.files||null,position:"cursor",retainSeed:o})}else if(c.text){let d=ym(c.text).split(/\n+/).map(p=>p.trim()).filter(Boolean),m=d.map(p=>Q2(p)).filter(p=>Bl(p,this.props.validateEmbeddable)&&(/^(http|https):\/\/[^\s/$.?#].[^\s]*$/.test(p)||Un(p)?.type==="video"));if(!oh&&m.length>0&&m.length===d.length){let p=[];for(let u of m){let g=p[p.length-1],x=this.insertEmbeddableElement({sceneX:g?g.x+g.width+20:a,sceneY:l,link:po(u)});x&&p.push(x)}p.length&&this.setState({selectedElementIds:Object.fromEntries(p.map(u=>[u.id,!0]))});return}this.addTextFromPaste(c.text,o)}this.setActiveTool({type:"selection"}),t?.preventDefault()});addElementsFromPasteOrLibrary=t=>{let o=Ic(t.elements,null,void 0),[r,n,i,a]=Se(o),l=Nt(r,i)/2,s=Nt(n,a)/2,c=typeof t.position=="object"?t.position.clientX:t.position==="cursor"?this.lastViewportPosition.x:this.state.width/2+this.state.offsetLeft,d=typeof t.position=="object"?t.position.clientY:t.position==="cursor"?this.lastViewportPosition.y:this.state.height/2+this.state.offsetTop,{x:m,y:p}=$e({clientX:c,clientY:d},this.state),u=m-l,g=p-s,[x,E]=At(u,g,this.state.gridSize),y=yc(o.map(M=>ae(M,{x:M.x+x-r,y:M.y+E-n})),{randomizeSeed:!t.retainSeed}),T=[...this.scene.getElementsIncludingDeleted(),...y],w=this.getTopLayerFrameAtSceneCoords({x:m,y:p});if(w){let M=mv(y,w);Nc(T,M,w)}this.scene.replaceAllElements(T),y.forEach(M=>{if(W(M)&&ze(M)){let k=ut(M,this.scene.getElementsMapIncludingDeleted());eo(M,k,this.scene.getElementsMapIncludingDeleted())}}),t.files&&(this.files={...this.files,...t.files}),this.history.resumeRecording();let S=Oa(y);this.setState({...this.state,openSidebar:this.state.openSidebar&&this.device.editor.canFitSidebar&&Zt.get(Rd)?this.state.openSidebar:null,...to({editingGroupId:null,selectedElementIds:S.reduce((M,k)=>(ze(k)||(M[k.id]=!0),M),{})},this.scene.getNonDeletedElements(),this.state,this)},()=>{t.files&&this.addNewImagesToImageCache()}),this.setActiveTool({type:"selection"}),t.fitToContent&&this.scrollToContent(y,{fitToContent:!0})};async addElementsFromMixedContentPaste(t,{isPlainPaste:o,sceneX:r,sceneY:n}){if(!o&&t.some(i=>i.type==="imageUrl")&&this.isToolSupported("image")){let i=t.filter(m=>m.type==="imageUrl").map(m=>m.value),a=await Promise.all(i.map(async m=>{try{return{file:await yw(m)}}catch(p){let u=p.message;return p.cause==="FETCH_ERROR"?u=b("errors.failedToFetchImage"):p.cause==="UNSUPPORTED"&&(u=b("errors.unsupportedFileType")),{errorMessage:u}}})),l=n,s=!1,c={};for(let m of a)if(m.file){let p=this.createImageElement({sceneX:r,sceneY:l}),u=await this.insertImageElement(p,m.file);u&&(s||(s=!0,l-=u.height/2),z(u,{y:l},!1),l=p.y+p.height+25,c[p.id]=!0)}this.setState({selectedElementIds:Oe(c,this.state)});let d=a.find(m=>!!m.errorMessage);d&&d.errorMessage&&this.setState({errorMessage:d.errorMessage})}else{let i=t.filter(a=>a.type==="text");i.length&&this.addTextFromPaste(i.map(a=>a.value).join(`
191
+ `)}async onMagicFrameGenerate(t,r){if(!this.OPENAI_KEY){this.setState({openDialog:{name:"settings",tab:"diagram-to-code",source:"generation"}}),ve("ai","generate (missing key)","d2c");return}let o=rs(this.scene.getNonDeletedElements(),t).filter(m=>!ya(m));if(!o.length){r==="button"?(this.setState({errorMessage:"Cannot generate from an empty frame"}),ve("ai","generate (no-children)","d2c")):this.setActiveTool({type:"magicframe"});return}let n=this.insertIframeElement({sceneX:t.x+t.width+30,sceneY:t.y,width:t.width,height:t.height});if(!n)return;this.updateMagicGeneration({frameElement:n,data:{status:"pending"}}),this.setState({selectedElementIds:{[n.id]:!0}});let i=await Qp({data:{elements:this.scene.getNonDeletedElements(),appState:{...this.state,exportBackground:!0,viewBackgroundColor:this.state.viewBackgroundColor},files:this.files},config:{exportingFrame:t}}),a=await Ip(i),l=this.getTextFromElements(o);ve("ai","generate (start)","d2c");let s=await IA({image:a,apiKey:this.OPENAI_KEY,text:l,theme:this.state.theme});if(!s.ok){ve("ai","generate (failed)","d2c"),console.error(s.error),this.updateMagicGeneration({frameElement:n,data:{status:"error",code:"ERR_OAI",message:s.error?.message||"Unknown error during generation"}});return}if(ve("ai","generate (success)","d2c"),s.choices[0].message.content==null){this.updateMagicGeneration({frameElement:n,data:{status:"error",code:"ERR_OAI",message:"Nothing genereated :("}});return}let c=s.choices[0].message.content,d=c.slice(c.indexOf("<!DOCTYPE html>"),c.indexOf("</html>")+7);this.updateMagicGeneration({frameElement:n,data:{status:"done",html:d}})}onIframeSrcCopy(t){t.customData?.generationData?.status==="done"&&(Qn(t.customData.generationData.html),this.setToast({message:"copied to clipboard",closable:!1,duration:1500}))}OPENAI_KEY=Fr.get(po.OAI_API_KEY);OPENAI_KEY_IS_PERSISTED=Fr.has(po.OAI_API_KEY)||!1;onOpenAIKeyChange=(t,r)=>{if(this.OPENAI_KEY=t||null,r){let o=Fr.set(po.OAI_API_KEY,t);this.OPENAI_KEY_IS_PERSISTED=o}else this.OPENAI_KEY_IS_PERSISTED=!1};onMagicSettingsConfirm=(t,r,o)=>{if(this.OPENAI_KEY=t||null,this.onOpenAIKeyChange(this.OPENAI_KEY,r),o==="settings")return;let n=this.scene.getSelectedElements({selectedElementIds:this.state.selectedElementIds});t?n.length?this.onMagicframeToolSelect():this.setActiveTool({type:"magicframe"}):ya(n[0])||this.setActiveTool({type:"magicframe"})};onMagicframeToolSelect=()=>{if(!this.OPENAI_KEY){this.setState({openDialog:{name:"settings",tab:"diagram-to-code",source:"tool"}}),ve("ai","tool-select (missing key)","d2c");return}let t=this.scene.getSelectedElements({selectedElementIds:this.state.selectedElementIds});if(t.length===0)this.setActiveTool({type:St.magicframe}),ve("ai","tool-select (empty-selection)","d2c");else{let r=t.length===1&&ya(t[0])&&t[0];if(!r&&t.some(n=>re(n)||n.frameId)){this.setActiveTool({type:St.magicframe});return}ve("ai","tool-select (existing selection)","d2c");let o;if(r)o=r;else{let[n,i,a,l]=Ae(t),s=50;o=kc({...et,x:n-s,y:i-s,width:a-n+s*2,height:l-i+s*2,opacity:100,locked:!1}),this.scene.insertElement(o);for(let c of t)H(c,{frameId:o.id});this.setState({selectedElementIds:{[o.id]:!0}})}this.onMagicFrameGenerate(o,"upstream")}};openEyeDropper=({type:t})=>{Qt.set(Vi,{swapPreviewOnAlt:!0,colorPickerType:t==="stroke"?"elementStroke":"elementBackground",onSelect:(r,o)=>{let n=t==="background"&&o.altKey||t==="stroke"&&!o.altKey;!this.scene.getSelectedElements(this.state).length||this.state.activeTool.type!=="selection"?n?this.syncActionResult({appState:{...this.state,currentItemStrokeColor:r},storeAction:_.CAPTURE}):this.syncActionResult({appState:{...this.state,currentItemBackgroundColor:r},storeAction:_.CAPTURE}):this.updateScene({elements:this.scene.getElementsIncludingDeleted().map(a=>this.state.selectedElementIds[a.id]?le(a,{[n?"strokeColor":"backgroundColor"]:r}):a),storeAction:_.CAPTURE})},keepOpenOnAlt:!1})};syncActionResult=ut(t=>{if(this.unmounted||t===!1)return;let r=null;if(t.elements&&(t.elements.forEach(o=>{this.state.editingElement?.id===o.id&&this.state.editingElement!==o&&cc(o)&&(r=o)}),t.storeAction===_.UPDATE?this.store.shouldUpdateSnapshot():t.storeAction===_.CAPTURE&&this.store.shouldCaptureIncrement(),this.scene.replaceAllElements(t.elements)),t.files&&(this.files=t.replaceFiles?t.files:{...this.files,...t.files},this.addNewImagesToImageCache()),t.appState||r||this.state.contextMenu){t.storeAction===_.UPDATE?this.store.shouldUpdateSnapshot():t.storeAction===_.CAPTURE&&this.store.shouldCaptureIncrement();let o=t?.appState?.viewModeEnabled||!1,n=t?.appState?.zenModeEnabled||!1,i=t?.appState?.gridSize||null,a=t?.appState?.theme||this.props.theme||se.LIGHT,l=t?.appState?.name??this.state.name,s=t?.appState?.errorMessage??this.state.errorMessage;typeof this.props.viewModeEnabled<"u"&&(o=this.props.viewModeEnabled),typeof this.props.zenModeEnabled<"u"&&(n=this.props.zenModeEnabled),typeof this.props.gridModeEnabled<"u"&&(i=this.props.gridModeEnabled?On:null),r=r||t.appState?.editingElement||null,r?.isDeleted&&(r=null),this.setState(c=>Object.assign(t.appState||{},{contextMenu:null,editingElement:r,viewModeEnabled:o,zenModeEnabled:n,gridSize:i,theme:a,name:l,errorMessage:s}))}});onBlur=ut(()=>{El=!1,this.setState({isBindingEnabled:!0})});onUnload=()=>{this.onBlur()};disableEvent=t=>{t.preventDefault()};resetHistory=()=>{this.history.clear()};resetStore=()=>{this.store.clear()};resetScene=ut(t=>{this.scene.replaceAllElements([]),this.setState(r=>({...Er(),isLoading:t?.resetLoadingState?!1:r.isLoading,theme:this.state.theme})),this.resetStore(),this.resetHistory()});initializeScene=async()=>{"launchQueue"in window&&"LaunchParams"in window&&window.launchQueue.setConsumer(async o=>{if(!o.files.length)return;let n=o.files[0],i=await n.getFile();this.loadFileToCanvas(new File([i],i.name||"",{type:i.type}),n)}),this.props.theme&&this.setState({theme:this.props.theme}),this.state.isLoading||this.setState({isLoading:!0});let t=null;try{t=await this.props.initialData||null,t?.libraryItems&&this.library.updateLibrary({libraryItems:t.libraryItems,merge:!0}).catch(o=>{console.error(o)})}catch(o){console.error(o),t={appState:{errorMessage:o.message||"Encountered an error during importing or restoring scene data"}}}let r=Oa(t,null,null,{repairBindings:!0});r.appState={...r.appState,theme:this.props.theme||r.appState.theme,openSidebar:r.appState?.openSidebar||this.state.openSidebar,activeTool:r.appState.activeTool.type==="image"?{...r.appState.activeTool,type:"selection"}:r.appState.activeTool,isLoading:!1,toast:this.state.toast},t?.scrollToContent&&(r.appState={...r.appState,...gn(r.elements,{...r.appState,width:this.state.width,height:this.state.height,offsetTop:this.state.offsetTop,offsetLeft:this.state.offsetLeft})}),this.fonts.loadFontsForElements(r.elements),this.resetStore(),t?.scrollX!=null&&(r.appState.scrollX=t.scrollX),t?.scrollY!=null&&(r.appState.scrollY=t.scrollY),this.resetHistory(),this.syncActionResult({...r,storeAction:_.UPDATE})};isMobileBreakpoint=(t,r)=>t<Oy||r<Fy&&t<By;refreshViewportBreakpoints=()=>{if(!this.excalidrawContainerRef.current)return;let{clientWidth:r,clientHeight:o}=document.body,n=this.device.viewport,i=Ll(n,{isLandscape:r>o,isMobile:this.isMobileBreakpoint(r,o)});return n!==i?(this.device={...this.device,viewport:i},!0):!1};refreshEditorBreakpoints=()=>{let t=this.excalidrawContainerRef.current;if(!t)return;let{width:r,height:o}=t.getBoundingClientRect(),n=this.props.UIOptions.dockedSidebarBreakpoint!=null?this.props.UIOptions.dockedSidebarBreakpoint:zy,i=this.device.editor,a=Ll(i,{isMobile:this.isMobileBreakpoint(r,o),canFitSidebar:r>n});return i!==a?(this.device={...this.device,editor:a},!0):!1};async componentDidMount(){if(this.unmounted=!1,this.excalidrawContainerValue.container=this.excalidrawContainerRef.current,S.MODE===kr.TEST||S.DEV){let r=this.setState.bind(this);Object.defineProperties(window.h,{state:{configurable:!0,get:()=>this.state},setState:{configurable:!0,value:(...o)=>this.setState(...o)},app:{configurable:!0,value:this},history:{configurable:!0,value:this.history},store:{configurable:!0,value:this.store}})}this.store.onStoreIncrementEmitter.on(r=>{this.history.record(r.elementsChange,r.appStateChange)}),this.scene.addCallback(this.onSceneUpdated),this.addEventListeners(),this.props.autoFocus&&this.excalidrawContainerRef.current&&this.focusContainer(),Wr()||(this.refreshViewportBreakpoints(),this.refreshEditorBreakpoints()),Zs&&this.excalidrawContainerRef.current&&(this.resizeObserver=new ResizeObserver(()=>{this.refreshEditorBreakpoints(),this.updateDOMRect()}),this.resizeObserver?.observe(this.excalidrawContainerRef.current)),new URLSearchParams(window.location.search.slice(1)).has("web-share-target")?this.restoreFileFromShare():this.updateDOMRect(this.initializeScene),Cy()&&!E2()&&this.setState({errorMessage:Qe(eA,{})})}componentWillUnmount(){this.renderer.destroy(),this.scene=new Ct,this.renderer=new am(this.scene),this.files={},this.imageCache.clear(),this.resizeObserver?.disconnect(),this.unmounted=!0,this.removeEventListeners(),this.scene.destroy(),this.library.destroy(),this.laserTrails.stop(),this.eraserTrail.stop(),this.onChangeEmitter.clear(),this.store.onStoreIncrementEmitter.clear(),Ne.destroy(),Mo.destroy(),fT(),this.onChangeEmitter.clear(),S.PROD&&(this.history=new Bs,this.library=new nx(this),this.actionManager=new Wd(this.syncActionResult,()=>this.state,()=>this.scene.getElementsIncludingDeleted(),this),this.canvas=null,this.interactiveCanvas=null,this.rc=null,this.excalidrawContainerRef.current=void 0,this.nearestScrollableContainer=void 0,this.excalidrawContainerValue={container:null,id:"unmounted"}),clearTimeout(da),Xe.clearCache(),nr.clearCache(),da=0,document.documentElement.style.overscrollBehaviorX=""}onResize=ut(()=>{this.scene.getElementsIncludingDeleted().forEach(t=>Ne.delete(t)),this.refreshViewportBreakpoints(),this.updateDOMRect(),Zs||this.refreshEditorBreakpoints(),this.setState({})});onFullscreenChange=()=>{!document.fullscreenElement&&this.state.activeEmbeddable?.state==="active"&&this.setState({activeEmbeddable:null})};removeEventListeners(){this.onRemoveEventListenersEmitter.trigger()}addEventListeners(){this.removeEventListeners(),this.props.handleKeyboardGlobally&&this.onRemoveEventListenersEmitter.once(Et(document,"keydown",this.onKeyDown,!1)),this.onRemoveEventListenersEmitter.once(Et(this.excalidrawContainerRef.current,"wheel",this.onWheel,{passive:!1}),Et(window,"message",this.onWindowMessage,!1),Et(document,"pointerup",this.removePointer),Et(document,"copy",this.onCopy),Et(document,"keyup",this.onKeyUp,{passive:!0}),Et(document,"mousemove",this.updateCurrentCursorPosition),Et(document.fonts,"loadingdone",t=>{let r=t.fontfaces;this.fonts.onFontsLoaded(r)}),Et(document,"gesturestart",this.onGestureStart,!1),Et(document,"gesturechange",this.onGestureChange,!1),Et(document,"gestureend",this.onGestureEnd,!1),Et(window,"focus",()=>{this.maybeCleanupAfterMissingPointerUp(null)})),!this.state.viewModeEnabled&&(this.onRemoveEventListenersEmitter.once(Et(document,"fullscreenchange",this.onFullscreenChange),Et(document,"paste",this.pasteFromClipboard),Et(document,"cut",this.onCut),Et(window,"resize",this.onResize,!1),Et(window,"unload",this.onUnload,!1),Et(window,"blur",this.onBlur,!1),Et(this.excalidrawContainerRef.current,"dragover",this.disableEvent,!1),Et(this.excalidrawContainerRef.current,"drop",this.disableEvent,!1)),this.props.detectScroll&&this.onRemoveEventListenersEmitter.once(Et(tw(this.excalidrawContainerRef.current),"scroll",this.onScroll)))}componentDidUpdate(t,r){this.updateEmbeddables();let o=this.scene.getElementsIncludingDeleted(),n=this.scene.getElementsMapIncludingDeleted(),i=this.scene.getNonDeletedElementsMap();!this.state.showWelcomeScreen&&!o.length&&this.setState({showWelcomeScreen:!0}),t.UIOptions.dockedSidebarBreakpoint!==this.props.UIOptions.dockedSidebarBreakpoint&&this.refreshEditorBreakpoints(),r.userToFollow&&!this.state.collaborators.has(r.userToFollow.socketId)&&this.maybeUnfollowRemoteUser(),this.props.activeTool&&this.props.activeTool.type!==this.state.activeTool.type&&this.setActiveTool(this.props.activeTool),(r.zoom.value!==this.state.zoom.value||r.scrollX!==this.state.scrollX||r.scrollY!==this.state.scrollY)&&(this.props?.onScrollChange?.(this.state.scrollX,this.state.scrollY,this.state.zoom),this.onScrollChangeEmitter.trigger(this.state.scrollX,this.state.scrollY,this.state.zoom)),r.userToFollow!==this.state.userToFollow&&(r.userToFollow&&this.onUserFollowEmitter.trigger({userToFollow:r.userToFollow,action:"UNFOLLOW"}),this.state.userToFollow&&this.onUserFollowEmitter.trigger({userToFollow:this.state.userToFollow,action:"FOLLOW"})),Object.keys(this.state.selectedElementIds).length&&Pr(this.state)&&this.setState({activeTool:tt(this.state,{type:"selection"})}),this.state.activeTool.type==="eraser"&&r.theme!==this.state.theme&&Uf(this.interactiveCanvas,this.state.theme),r.activeTool.type==="selection"&&this.state.activeTool.type!=="selection"&&this.state.showHyperlinkPopup&&this.setState({showHyperlinkPopup:!1}),t.langCode!==this.props.langCode&&this.updateLanguage(),Pr(r)&&!Pr(this.state)&&this.eraserTrail.endPath(),t.viewModeEnabled!==this.props.viewModeEnabled&&this.setState({viewModeEnabled:!!this.props.viewModeEnabled}),r.viewModeEnabled!==this.state.viewModeEnabled&&(this.addEventListeners(),this.deselectElements()),t.zenModeEnabled!==this.props.zenModeEnabled&&this.setState({zenModeEnabled:!!this.props.zenModeEnabled}),t.theme!==this.props.theme&&this.props.theme&&this.setState({theme:this.props.theme}),t.gridModeEnabled!==this.props.gridModeEnabled&&this.setState({gridSize:this.props.gridModeEnabled?On:null}),!this.props.UIOptions.canvasActions&&this.state.openMenu==="canvas"&&this.setState({openMenu:null}),this.excalidrawContainerRef.current?.classList.toggle("theme--dark",this.state.theme===se.DARK),this.state.editingLinearElement&&!this.state.selectedElementIds[this.state.editingLinearElement.elementId]&&setTimeout(()=>{this.state.editingLinearElement&&this.actionManager.executeAction(io)}),this.state.editingElement?.isDeleted&&this.setState({editingElement:null}),this.state.selectedLinearElement&&!this.state.selectedElementIds[this.state.selectedLinearElement.elementId]&&this.setState({selectedLinearElement:null});let{multiElement:l}=r;r.activeTool!==this.state.activeTool&&l!=null&&mn(this.state)&&Wt(l,!1)&&wc(l,this.state,Ro(Z.getPointAtIndexGlobalCoordinates(l,-1,i)),this),this.store.commit(n,this.state),this.state.isLoading||(this.props.onChange?.(o,this.state,this.files,this.props.id),this.onChangeEmitter.trigger(o,this.state,this.files))}renderInteractiveSceneCallback=({atLeastOneVisibleElement:t,scrollBars:r,elementsMap:o})=>{r&&(Q0=r);let n=V(this.state.editingElement)?!1:!t&&o.size>0;this.state.scrolledOutside!==n&&this.setState({scrolledOutside:n}),this.scheduleImageRefresh()};onScroll=xa(()=>{let{offsetTop:t,offsetLeft:r}=this.getCanvasOffsets();this.setState(o=>o.offsetLeft===r&&o.offsetTop===t?null:{offsetTop:t,offsetLeft:r})},Ry);onCut=ut(t=>{!this.excalidrawContainerRef.current?.contains(document.activeElement)||uo(t.target)||(this.actionManager.executeAction(Ad,"keyboard",t),t.preventDefault(),t.stopPropagation())});onCopy=ut(t=>{!this.excalidrawContainerRef.current?.contains(document.activeElement)||uo(t.target)||(this.actionManager.executeAction(dl,"keyboard",t),t.preventDefault(),t.stopPropagation())});static resetTapTwice(){lm=!1}onTouchStart=t=>{if(bm&&t.preventDefault(),this.props.interactive!==!1){if(!lm){lm=!0,clearTimeout(q0),q0=window.setTimeout(e.resetTapTwice,Dy);return}if(lm&&t.touches.length===1){let r=t.touches[0];this.handleCanvasDoubleClick({clientX:r.clientX,clientY:r.clientY}),lm=!1,clearTimeout(q0)}t.touches.length===2&&this.setState({selectedElementIds:Fe({},this.state),activeEmbeddable:null})}};onTouchEnd=t=>{this.props.interactive!==!1&&(this.resetContextMenuTimer(),t.touches.length>0?this.setState({previousSelectedElementIds:{},selectedElementIds:Fe(this.state.previousSelectedElementIds,this.state)}):Ue.pointers.clear())};pasteFromClipboard=ut(async t=>{if(this.props.interactive===!1)return;let r=!!Lg,o=document.activeElement,n=this.excalidrawContainerRef.current?.contains(o);if(t&&!n)return;let i=document.elementFromPoint(this.lastViewportPosition.x,this.lastViewportPosition.y);if(t&&(!(i instanceof HTMLCanvasElement)||uo(o)))return;let{x:a,y:l}=je({clientX:this.lastViewportPosition.x,clientY:this.lastViewportPosition.y},this.state),s=t?.clipboardData?.files[0],c=await jp(t,r);if(!s&&!r){if(c.mixedContent)return this.addElementsFromMixedContentPaste(c.mixedContent,{isPlainPaste:r,sceneX:a,sceneY:l});if(c.text){let d=c.text.trim();d.startsWith("<svg")&&d.endsWith("</svg>")&&(s=t1(d))}}if(Ni(s)&&!c.spreadsheet){if(!this.isToolSupported("image")){this.setState({errorMessage:b("errors.imageToolNotSupported")});return}let d=this.createImageElement({sceneX:a,sceneY:l});this.insertImageElement(d,s),this.initializeImageDimensions(d),this.setState({selectedElementIds:Fe({[d.id]:!0},this.state)});return}if(this.props.onPaste)try{if(await this.props.onPaste(c,t)===!1)return}catch(d){console.error(d)}if(c.errorMessage)this.setState({errorMessage:c.errorMessage});else if(c.spreadsheet&&!r)this.setState({pasteDialog:{data:c.spreadsheet,shown:!0}});else if(c.elements){let d=c.programmaticAPI?tm(c.elements):c.elements;this.addElementsFromPasteOrLibrary({elements:d,files:c.files||null,position:"cursor",retainSeed:r})}else if(c.text){let d=Om(c.text).split(/\n+/).map(p=>p.trim()).filter(Boolean),m=d.map(p=>U2(p)).filter(p=>Kl(p,this.props.validateEmbeddable)&&(/^(http|https):\/\/[^\s/$.?#].[^\s]*$/.test(p)||$n(p)?.type==="video"));if(!Lg&&m.length>0&&m.length===d.length){let p=[];for(let u of m){let h=p[p.length-1],E=this.insertEmbeddableElement({sceneX:h?h.x+h.width+20:a,sceneY:l,link:yr(u)});E&&p.push(E)}p.length&&this.setState({selectedElementIds:Object.fromEntries(p.map(u=>[u.id,!0]))});return}this.addTextFromPaste(c.text,r)}this.setActiveTool({type:"selection"}),t?.preventDefault()});addElementsFromPasteOrLibrary=t=>{let r=zc(t.elements,null,void 0),[o,n,i,a]=Ae(r),l=Bt(o,i)/2,s=Bt(n,a)/2,c=typeof t.position=="object"?t.position.clientX:t.position==="cursor"?this.lastViewportPosition.x:this.state.width/2+this.state.offsetLeft,d=typeof t.position=="object"?t.position.clientY:t.position==="cursor"?this.lastViewportPosition.y:this.state.height/2+this.state.offsetTop,{x:m,y:p}=je({clientX:c,clientY:d},this.state),u=m-l,h=p-s,[E,x]=Pt(u,h,this.state.gridSize),T=Lc(r.map(A=>le(A,{x:A.x+E-o,y:A.y+x-n})),{randomizeSeed:!t.retainSeed}),w=[...this.scene.getElementsIncludingDeleted(),...T];Yt(w,X(T));let I=this.getTopLayerFrameAtSceneCoords({x:m,y:p});if(I){let A=lT(T,I);Zc(w,A,I)}this.scene.replaceAllElements(w),T.forEach(A=>{if(V(A)&&Pe(A)){let M=gt(A,this.scene.getElementsMapIncludingDeleted());Ht(A,M,this.scene.getElementsMapIncludingDeleted())}}),t.files&&(this.files={...this.files,...t.files}),this.store.shouldCaptureIncrement();let L=Xa(T);this.setState({...this.state,openSidebar:this.state.openSidebar&&this.device.editor.canFitSidebar&&Qt.get(jd)?this.state.openSidebar:null,...nr({editingGroupId:null,selectedElementIds:L.reduce((A,M)=>(Pe(M)||(A[M.id]=!0),A),{})},this.scene.getNonDeletedElements(),this.state,this)},()=>{t.files&&this.addNewImagesToImageCache()}),this.setActiveTool({type:"selection"}),t.fitToContent&&this.scrollToContent(T,{fitToContent:!0})};async addElementsFromMixedContentPaste(t,{isPlainPaste:r,sceneX:o,sceneY:n}){if(!r&&t.some(i=>i.type==="imageUrl")&&this.isToolSupported("image")){let i=t.filter(m=>m.type==="imageUrl").map(m=>m.value),a=await Promise.all(i.map(async m=>{try{return{file:await sv(m)}}catch(p){let u=p.message;return p.cause==="FETCH_ERROR"?u=b("errors.failedToFetchImage"):p.cause==="UNSUPPORTED"&&(u=b("errors.unsupportedFileType")),{errorMessage:u}}})),l=n,s=!1,c={};for(let m of a)if(m.file){let p=this.createImageElement({sceneX:o,sceneY:l}),u=await this.insertImageElement(p,m.file);u&&(s||(s=!0,l-=u.height/2),H(u,{y:l},!1),l=p.y+p.height+25,c[p.id]=!0)}this.setState({selectedElementIds:Fe(c,this.state)});let d=a.find(m=>!!m.errorMessage);d&&d.errorMessage&&this.setState({errorMessage:d.errorMessage})}else{let i=t.filter(a=>a.type==="text");i.length&&this.addTextFromPaste(i.map(a=>a.value).join(`
192
192
 
193
- `),o)}}addTextFromPaste(t,o=!1){let{x:r,y:n}=$e({clientX:this.lastViewportPosition.x,clientY:this.lastViewportPosition.y},this.state),i={x:r,y:n,strokeColor:this.state.currentItemStrokeColor,backgroundColor:this.state.currentItemBackgroundColor,fillStyle:this.state.currentItemFillStyle,strokeWidth:this.state.currentItemStrokeWidth,strokeStyle:this.state.currentItemStrokeStyle,roundness:null,roughness:this.state.currentItemRoughness,opacity:this.state.currentItemOpacity,text:t,fontSize:this.state.currentItemFontSize,fontFamily:this.state.currentItemFontFamily,textAlign:this.state.currentItemTextAlign,verticalAlign:ia,locked:!1},a=10,l=n,s=o?[t]:t.split(`
194
- `),c=s.reduce((m,p,u)=>{let g=p.trim(),x=Oo(i.fontFamily);if(g.length){let E=this.getTopLayerFrameAtSceneCoords({x:r,y:l}),y=Gt({...i,x:r,y:l,text:g,lineHeight:x,frameId:E?E.id:null});m.push(y),l+=y.height+a}else s[u-1]?.trim()&&(l+=wi(i.fontSize,x)+a);return m},[]);if(c.length===0)return;let d=c[0].frameId;d?this.scene.insertElementsAtIndex(c,this.scene.getElementIndex(d)):this.scene.replaceAllElements([...this.scene.getElementsIncludingDeleted(),...c]),this.setState({selectedElementIds:Oe(Object.fromEntries(c.map(m=>[m.id,!0])),this.state)}),!o&&c.length>1&&z4===!1&&!this.device.editor.isMobile&&(this.setToast({message:b("toast.pasteAsSingleElement",{shortcut:N("CtrlOrCmd+Shift+V")}),duration:5e3}),z4=!0),this.history.resumeRecording()}setAppState=(t,o)=>{this.setState(t,o)};removePointer=t=>{Qi&&this.resetContextMenuTimer(),Fe.pointers.delete(t.pointerId)};toggleLock=(t="ui")=>{this.state.activeTool.locked||we("toolbar","toggleLock",`${t} (${this.device.editor.isMobile?"mobile":"desktop"})`),this.setState(o=>({activeTool:{...o.activeTool,...Qe(this.state,o.activeTool.locked?{type:"selection"}:o.activeTool),locked:!o.activeTool.locked}}))};updateFrameRendering=t=>{this.setState(o=>{let r=typeof t=="function"?t(o.frameRendering):t;return{frameRendering:{enabled:r?.enabled??o.frameRendering.enabled,clip:r?.clip??o.frameRendering.clip,name:r?.name??o.frameRendering.name,outline:r?.outline??o.frameRendering.outline}}})};togglePenMode=t=>{this.setState(o=>({penMode:t??!o.penMode,penDetected:!0}))};onHandToolToggle=()=>{this.actionManager.executeAction(J3)};zoomCanvas=t=>{this.setState({...Zn({viewportX:this.state.width/2+this.state.offsetLeft,viewportY:this.state.height/2+this.state.offsetTop,nextZoom:sn(t)},this.state)})};cancelInProgressAnimation=null;scrollToContent=(t=this.scene.getNonDeletedElements(),o)=>{this.cancelInProgressAnimation?.();let r=Array.isArray(t)?t:[t],n=this.state.zoom,i=this.state.scrollX,a=this.state.scrollY;if(o?.fitToContent||o?.fitToViewport){let{appState:l}=id({targetElements:r,appState:this.state,fitToViewport:!!o?.fitToViewport,viewportZoomFactor:o?.viewportZoomFactor});n=l.zoom,i=l.scrollX,a=l.scrollY}else{let l=nn(r,this.state);i=l.scrollX,a=l.scrollY}if(o?.animate){let l=this.state.scrollX,s=this.state.scrollY,c=this.state.zoom.value,d=xy({fromValues:{scrollX:l,scrollY:s,zoom:c},toValues:{scrollX:i,scrollY:a,zoom:n.value},interpolateValue:(m,p,u,g)=>{if(g==="zoom")return m*Math.pow(p/m,Mn(u))},onStep:({scrollX:m,scrollY:p,zoom:u})=>{this.setState({scrollX:m,scrollY:p,zoom:{value:u}})},onStart:()=>{this.setState({shouldCacheIgnoreZoom:!0})},onEnd:()=>{this.setState({shouldCacheIgnoreZoom:!1})},onCancel:()=>{this.setState({shouldCacheIgnoreZoom:!1})},duration:o?.duration??500});this.cancelInProgressAnimation=()=>{d(),this.cancelInProgressAnimation=null}}else this.setState({scrollX:i,scrollY:a,zoom:n})};maybeUnfollowRemoteUser=()=>{this.state.userToFollow&&this.setState({userToFollow:null})};translateCanvas=t=>{this.cancelInProgressAnimation?.(),this.maybeUnfollowRemoteUser(),this.setState(t)};setToast=t=>{this.setState({toast:t})};restoreFileFromShare=async()=>{try{let t=await caches.open("web-share-target"),o=await t.match("shared-file");if(o){let r=await o.blob(),n=new File([r],r.name||"",{type:r.type});this.loadFileToCanvas(n,null),await t.delete("shared-file"),window.history.replaceState(null,Fs,window.location.pathname)}}catch(t){this.setState({errorMessage:t.message})}};addFiles=ct(t=>{let o=t.reduce((r,n)=>(r.set(n.id,n),r),new Map);this.files={...this.files,...Object.fromEntries(o)},this.scene.getNonDeletedElements().forEach(r=>{mo(r)&&o.has(r.fileId)&&(this.imageCache.delete(r.fileId),Me.delete(r))}),this.scene.informMutation(),this.addNewImagesToImageCache()});updateScene=ct(t=>{t.commitToHistory&&this.history.resumeRecording(),t.appState&&this.setState(t.appState),t.elements&&this.scene.replaceAllElements(t.elements),t.collaborators&&this.setState({collaborators:t.collaborators})});onSceneUpdated=()=>{this.setState({})};toggleSidebar=({name:t,tab:o,force:r})=>{let n;r===void 0?n=this.state.openSidebar?.name===t&&this.state.openSidebar?.tab===o?null:t:n=r?t:null;let i=n?{name:n}:null;return i&&o&&(i.tab=o),this.setState({openSidebar:i}),!!n};updateCurrentCursorPosition=ct(t=>{this.lastViewportPosition.x=t.clientX,this.lastViewportPosition.y=t.clientY});onKeyDown=ct(t=>{if("Proxy"in window&&(!t.shiftKey&&/^[A-Z]$/.test(t.key)||t.shiftKey&&/^[a-z]$/.test(t.key))&&(t=new Proxy(t,{get(i,a){let l=i[a];return typeof l=="function"?l.bind(i):a==="key"?t.shiftKey?i.key.toUpperCase():i.key.toLowerCase():l}})),t[I.CTRL_OR_CMD]&&t.key===I.P&&!t.shiftKey&&!t.altKey){this.setToast({message:b("commandPalette.shortcutHint",{shortcut:Lt("commandPalette")})}),t.preventDefault();return}if(t[I.CTRL_OR_CMD]&&t.key.toLowerCase()===I.V&&(oh=t.shiftKey,clearTimeout(H4),H4=window.setTimeout(()=>{oh=!1},100)),t[I.CTRL_OR_CMD]&&rr(t.target)&&(t.code===fe.MINUS||t.code===fe.EQUAL)){t.preventDefault();return}if(rr(t.target)&&t.key!==I.ESCAPE||Sl(t.key)&&yh(t.target))return;if(t.key===I.QUESTION_MARK){this.setState({openDialog:{name:"help"}});return}else if(t.key.toLowerCase()===I.E&&t.shiftKey&&t[I.CTRL_OR_CMD]){t.preventDefault(),this.setState({openDialog:{name:"imageExport"}});return}if(t.key===I.PAGE_UP||t.key===I.PAGE_DOWN){let i=(t.shiftKey?this.state.width:this.state.height)/this.state.zoom.value;t.key===I.PAGE_DOWN&&(i=-i),t.shiftKey?this.translateCanvas(a=>({scrollX:a.scrollX+i})):this.translateCanvas(a=>({scrollY:a.scrollY+i}))}if(this.actionManager.handleKeyDown(t)||this.state.viewModeEnabled)return;if(t[I.CTRL_OR_CMD]&&this.state.isBindingEnabled&&this.setState({isBindingEnabled:!1}),Sl(t.key)){let i=this.state.gridSize&&(t.shiftKey?dh:this.state.gridSize)||(t.shiftKey?K0:dh),a=0,l=0;t.key===I.ARROW_LEFT?a=-i:t.key===I.ARROW_RIGHT?a=i:t.key===I.ARROW_UP?l=-i:t.key===I.ARROW_DOWN&&(l=i);let s=this.scene.getSelectedElements({selectedElementIds:this.state.selectedElementIds,includeBoundTextElement:!0,includeElementsInFrames:!0});s.forEach(c=>{z(c,{x:c.x+a,y:c.y+l}),Lr(c,this.scene.getNonDeletedElementsMap(),{simultaneouslyUpdated:s})}),this.maybeSuggestBindingForAll(s),t.preventDefault()}else if(t.key===I.ENTER){let i=this.scene.getSelectedElements(this.state);if(i.length===1){let a=i[0];if(t[I.CTRL_OR_CMD])ne(a)&&(!this.state.editingLinearElement||this.state.editingLinearElement.elementId!==i[0].id)&&(this.history.resumeRecording(),this.setState({editingLinearElement:new $(a)}));else if(W(a)||N2(a)){let l;W(a)||(l=a);let s=zm(a,this.state,this.scene.getNonDeletedElementsMap()),c=s.x,d=s.y;this.startTextEditing({sceneX:c,sceneY:d,container:l}),t.preventDefault();return}else Q(a)&&this.setState({editingFrame:a.id})}}else if(!t.ctrlKey&&!t.altKey&&!t.metaKey&&this.state.draggingElement===null){let i=DC(t.key);i?(this.state.activeTool.type!==i&&we("toolbar",i,`keyboard (${this.device.editor.isMobile?"mobile":"desktop"})`),this.setActiveTool({type:i}),t.stopPropagation()):t.key===I.Q&&(this.toggleLock("keyboard"),t.stopPropagation())}if(t.key===I.SPACE&&Fe.pointers.size===0&&(il=!0,Ve(this.interactiveCanvas,Pe.GRAB),t.preventDefault()),(t.key===I.G||t.key===I.S)&&!t.altKey&&!t[I.CTRL_OR_CMD]){let i=this.scene.getSelectedElements(this.state);if(this.state.activeTool.type==="selection"&&!i.length)return;t.key===I.G&&(Pn(this.state.activeTool.type)||i.some(a=>Pn(a.type)))&&(this.setState({openPopup:"elementBackground"}),t.stopPropagation()),t.key===I.S&&(this.setState({openPopup:"elementStroke"}),t.stopPropagation())}if(t.key===I.K&&!t.altKey&&!t[I.CTRL_OR_CMD]){this.state.activeTool.type==="laser"?this.setActiveTool({type:"selection"}):this.setActiveTool({type:"laser"});return}t[I.CTRL_OR_CMD]&&(t.key===I.BACKSPACE||t.key===I.DELETE)&&Zt.set(rl,"clearCanvas");let o=t.key.toLocaleLowerCase(),r=o===I.S&&t.shiftKey,n=t.key===I.I||o===I.G&&t.shiftKey;(r||n)&&this.openEyeDropper({type:r?"stroke":"background"})});onWheel=ct(t=>{!(t.target instanceof HTMLCanvasElement)&&t.ctrlKey&&t.preventDefault()});onKeyUp=ct(t=>{if(t.key===I.SPACE&&(this.state.viewModeEnabled?Ve(this.interactiveCanvas,Pe.GRAB):this.state.activeTool.type==="selection"?zo(this.interactiveCanvas):(Go(this.interactiveCanvas,this.state),this.setState({selectedElementIds:Oe({},this.state),selectedGroupIds:{},editingGroupId:null,activeEmbeddable:null})),il=!1),!t[I.CTRL_OR_CMD]&&!this.state.isBindingEnabled&&this.setState({isBindingEnabled:!0}),Sl(t.key)){let o=this.scene.getSelectedElements(this.state),r=this.scene.getNonDeletedElementsMap();Qr(this.state)?mc(o,this.scene.getNonDeletedElements(),r):uc(o,r),this.setState({suggestedBindings:[]})}});isToolSupported=t=>this.props.UIOptions.tools?.[t]!==!1;setActiveTool=t=>{if(!this.isToolSupported(t.type)){console.warn(`"${t.type}" tool is disabled via "UIOptions.canvasActions.tools.${t.type}"`);return}let o=Qe(this.state,t);fy(document.activeElement)&&this.focusContainer(),Xs(o.type)||this.setState({suggestedBindings:[]}),o.type==="image"&&this.onImageAction({insertOnCanvasDirectly:(t.type==="image"&&t.insertOnCanvasDirectly)??!1}),this.setState(r=>{let n={snapLines:r.snapLines.length?[]:r.snapLines,originSnapOffset:null,activeEmbeddable:null},i;return o.type!=="selection"?i={...r,activeTool:o,selectedElementIds:Oe({},r),selectedGroupIds:Oe({},r),editingGroupId:null,multiElement:null,...n}:i={...r,activeTool:o,...n},o.type==="hand"?Ve(this.interactiveCanvas,Pe.GRAB):il||Go(this.interactiveCanvas,i),i})};setOpenDialog=t=>{this.setState({openDialog:t})};setCursor=t=>{Ve(this.interactiveCanvas,t)};resetCursor=()=>{zo(this.interactiveCanvas)};isTouchScreenMultiTouchGesture=()=>Fe.pointers.size>=2;getName=()=>this.state.name||this.props.name||`${b("labels.untitled")}-${Eh()}`;onGestureStart=ct(t=>{if(t.preventDefault(),this.props.interactive===!1)return!1;this.isTouchScreenMultiTouchGesture()&&this.setState({selectedElementIds:Oe({},this.state),activeEmbeddable:null}),Fe.initialScale=this.state.zoom.value});onGestureChange=ct(t=>{if(t.preventDefault(),this.props.interactive===!1)return!1;if(this.isTouchScreenMultiTouchGesture())return;let o=Fe.initialScale;o&&this.setState(r=>({...Zn({viewportX:this.lastViewportPosition.x,viewportY:this.lastViewportPosition.y,nextZoom:sn(o*t.scale)},r)}))});onGestureEnd=ct(t=>{if(t.preventDefault(),this.props.interactive===!1)return!1;this.isTouchScreenMultiTouchGesture()&&this.setState({previousSelectedElementIds:{},selectedElementIds:Oe(this.state.previousSelectedElementIds,this.state)}),Fe.initialScale=null});handleTextWysiwyg(t,{isExistingElement:o=!1}){let r=this.scene.getElementsMapIncludingDeleted(),n=(i,a,l)=>{this.scene.replaceAllElements([...this.scene.getElementsIncludingDeleted().map(s=>s.id===t.id&&W(s)?uf(s,ut(s,r),r,{text:i,isDeleted:l,originalText:a}):s)])};O4({id:t.id,canvas:this.canvas,getViewportCoords:(i,a)=>{let{x:l,y:s}=zt({sceneX:i,sceneY:a},this.state);return[l-this.state.offsetLeft,s-this.state.offsetTop]},onChange:ct(i=>{n(i,i,!1),js(t)&&Lr(t,r)}),onSubmit:ct(({text:i,viaKeyboard:a,originalText:l})=>{let s=!i.trim();if(n(i,l,s),!s&&a){let c=t.containerId?t.containerId:t.id;this.setState(d=>({selectedElementIds:Oe({...d.selectedElementIds,[c]:!0},d)}))}s&&Ml(this.scene.getNonDeletedElements(),[t]),(!s||o)&&this.history.resumeRecording(),this.setState({draggingElement:null,editingElement:null}),this.state.activeTool.locked&&Go(this.interactiveCanvas,this.state),this.focusContainer()}),element:t,excalidrawContainer:this.excalidrawContainerRef.current,app:this}),this.deselectElements(),n(t.text,t.originalText,!1)}deselectElements(){this.setState({selectedElementIds:Oe({},this.state),selectedGroupIds:{},editingGroupId:null,activeEmbeddable:null})}getTextElementAtPosition(t,o){let r=this.getElementAtPosition(t,o,{includeBoundTextElement:!0});return r&&W(r)&&!r.isDeleted?r:null}getElementAtPosition(t,o,r){let n=this.getElementsAtPosition(t,o,r?.includeBoundTextElement,r?.includeLockedElements);if(n.length>1){if(r?.preferSelected){for(let a=n.length-1;a>-1;a--)if(this.state.selectedElementIds[n[a].id])return n[a]}let i=n[n.length-1];return dc(i,this.state,this.frameNameBoundsCache,t,o,this.scene.getNonDeletedElementsMap())?n[n.length-2]:i}return n.length===1?n[0]:null}getElementsAtPosition(t,o,r=!1,n=!1){let i=r&&n?this.scene.getNonDeletedElements():this.scene.getNonDeletedElements().filter(l=>(n||!l.locked)&&(r||!(W(l)&&l.containerId))),a=this.scene.getNonDeletedElementsMap();return _h(i,l=>Tl(l,this.state,this.frameNameBoundsCache,t,o,a)).filter(l=>{let s=Ut(l,a);return s&&this.state.frameRendering.enabled&&this.state.frameRendering.clip?Gf({x:t,y:o},s,a):!0})}startTextEditing=({sceneX:t,sceneY:o,insertAtParentCenter:r=!0,container:n})=>{let i=!1,a=r&&this.getTextWysiwygSnappedToCenterPosition(t,o,this.state,n);n&&a&&(me(n,this.scene.getNonDeletedElementsMap())||(i=!0));let l=null,s=this.scene.getSelectedElements(this.state);s.length===1?W(s[0])?l=s[0]:n?l=me(s[0],this.scene.getNonDeletedElementsMap()):l=this.getTextElementAtPosition(t,o):l=this.getTextElementAtPosition(t,o);let c=l?.fontFamily||this.state.currentItemFontFamily,d=l?.lineHeight||Oo(c),m=this.state.currentItemFontSize;if(!l&&i&&n&&!ke(n)){let x=Hm(Ke({fontSize:m,fontFamily:c}),d),E=Fm(m,d),y=Math.max(n.height,E),T=Math.max(n.width,x);z(n,{height:y,width:T}),t=n.x+T/2,o=n.y+y/2,a&&(a=this.getTextWysiwygSnappedToCenterPosition(t,o,this.state,n))}let p=this.getTopLayerFrameAtSceneCoords({x:t,y:o}),u=l||Gt({x:a?a.elementCenterX:t,y:a?a.elementCenterY:o,strokeColor:this.state.currentItemStrokeColor,backgroundColor:this.state.currentItemBackgroundColor,fillStyle:this.state.currentItemFillStyle,strokeWidth:this.state.currentItemStrokeWidth,strokeStyle:this.state.currentItemStrokeStyle,roughness:this.state.currentItemRoughness,opacity:this.state.currentItemOpacity,text:"",fontSize:m,fontFamily:c,textAlign:a?"center":this.state.currentItemTextAlign,verticalAlign:a?yt.MIDDLE:ia,containerId:i?n?.id:void 0,groupIds:n?.groupIds??[],lineHeight:d,angle:n?.angle??0,frameId:p?p.id:null});if(!l&&i&&n&&z(n,{boundElements:(n.boundElements||[]).concat({type:"text",id:u.id})}),this.setState({editingElement:u}),!l)if(n&&i){let g=this.scene.getElementIndex(n.id);this.scene.insertElementAtIndex(u,g+1)}else this.scene.addNewElement(u);this.setState({editingElement:u}),this.handleTextWysiwyg(u,{isExistingElement:!!l})};handleCanvasDoubleClick=t=>{if(this.state.multiElement||this.state.activeTool.type!=="selection")return;let o=this.scene.getSelectedElements(this.state);if(o.length===1&&ne(o[0])&&t[I.CTRL_OR_CMD]&&(!this.state.editingLinearElement||this.state.editingLinearElement.elementId!==o[0].id)){this.history.resumeRecording(),this.setState({editingLinearElement:new $(o[0])});return}zo(this.interactiveCanvas);let{x:r,y:n}=$e(t,this.state);if(Fn(this.state).length>0){let a=this.getElementAtPosition(r,n),l=a&&G2(a,this.state.selectedGroupIds);if(l){this.setState(s=>({...s,...to({editingGroupId:l,selectedElementIds:{[a.id]:!0}},this.scene.getNonDeletedElements(),s,this)}));return}}if(zo(this.interactiveCanvas),!t[I.CTRL_OR_CMD]&&!this.state.viewModeEnabled){let a=this.getElementAtPosition(r,n);if(Jt(a)){this.setState({activeEmbeddable:{element:a,state:"active"}});return}let l=tf(this.scene.getNonDeletedElements(),this.state,r,n,this.scene.getNonDeletedElementsMap());if(l&&(Eo(l)||!co(l.backgroundColor)||fa(l,this.state,this.frameNameBoundsCache,[r,n],this.scene.getNonDeletedElementsMap()))){let s=zm(l,this.state,this.scene.getNonDeletedElementsMap());r=s.x,n=s.y}this.startTextEditing({sceneX:r,sceneY:n,insertAtParentCenter:!t.altKey,container:l})}};getElementLinkAtPosition=(t,o)=>{let r=this.scene.getNonDeletedElements().slice().reverse(),n=1/0;return r.find((i,a)=>(o&&i.id===o.id&&(n=a),i.link&&a<=n&&cp(i,this.scene.getNonDeletedElementsMap(),this.state,[t.x,t.y],this.device.editor.isMobile)))};redirectToLink=(t,o)=>{let r=mt(this.lastPointerDownEvent.clientX,this.lastPointerDownEvent.clientY,this.lastPointerUpEvent.clientX,this.lastPointerUpEvent.clientY);if(!this.hitLinkElement||o&&r>kn||!o&&r!==0)return;let n=$e(this.lastPointerDownEvent,this.state),i=this.scene.getNonDeletedElementsMap(),a=cp(this.hitLinkElement,i,this.state,[n.x,n.y],this.device.editor.isMobile),l=$e(this.lastPointerUpEvent,this.state),s=cp(this.hitLinkElement,i,this.state,[l.x,l.y],this.device.editor.isMobile);if(a&&s){let c=this.hitLinkElement.link;if(c){c=po(c);let d;if(this.props.onLinkOpen&&(d=xm("excalidraw-link",t.nativeEvent),this.props.onLinkOpen({...this.hitLinkElement,link:c},d)),!d?.defaultPrevented){let m=Vm(c)?"_self":"_blank",p=window.open(void 0,m);p&&(p.opener=null,p.location=c)}}}};getTopLayerFrameAtSceneCoords=t=>{let o=this.scene.getNonDeletedElementsMap(),r=this.scene.getNonDeletedFramesLikes().filter(n=>Gf(t,n,o));return r.length?r[r.length-1]:null};handleCanvasPointerMove=t=>{if(this.props.interactive===!1)return!1;this.savePointer(t.clientX,t.clientY,this.state.cursorButton),this.lastPointerMoveEvent=t.nativeEvent,Fe.pointers.has(t.pointerId)&&Fe.pointers.set(t.pointerId,{x:t.clientX,y:t.clientY});let o=Fe.initialScale;if(Fe.pointers.size===2&&Fe.lastCenter&&o&&Fe.initialDistance){let p=nE(Fe.pointers),u=p.x-Fe.lastCenter.x,g=p.y-Fe.lastCenter.y;Fe.lastCenter=p;let x=iE(Array.from(Fe.pointers.values())),E=this.state.activeTool.type==="freedraw"&&this.state.penMode?1:x/Fe.initialDistance,y=E?sn(o*E):this.state.zoom.value;this.setState(T=>{let w=Zn({viewportX:p.x,viewportY:p.y,nextZoom:y},T);this.translateCanvas({zoom:w.zoom,scrollX:w.scrollX+u/y,scrollY:w.scrollY+g/y,shouldCacheIgnoreZoom:!0})}),this.resetShouldCacheIgnoreZoomDebounced()}else Fe.lastCenter=Fe.initialDistance=Fe.initialScale=null;if(il||Kd||x0||Rr(this.state))return;let n=gE(E0,t.clientX-this.state.offsetLeft,t.clientY-this.state.offsetTop).isOverEither;!this.state.draggingElement&&!this.state.multiElement&&(n?zo(this.interactiveCanvas):Go(this.interactiveCanvas,this.state));let i=$e(t,this.state),{x:a,y:l}=i;if(!this.state.draggingElement&&qS(this.state.activeTool.type)){let{originOffset:p,snapLines:u}=jS(this.scene.getNonDeletedElements(),this.state,{x:a,y:l},t,this.scene.getNonDeletedElementsMap());this.setState(g=>{let x=Em(g.snapLines,u),E=g.originSnapOffset?Em(g.originSnapOffset,p):p;return g.snapLines===x&&g.originSnapOffset===E?null:{snapLines:x,originSnapOffset:E}})}else this.state.draggingElement||this.setState(p=>p.snapLines.length?{snapLines:[]}:null);if(this.state.editingLinearElement&&!this.state.editingLinearElement.isDragging){let p=$.handlePointerMove(t,a,l,this.state,this.scene.getNonDeletedElementsMap());p&&p!==this.state.editingLinearElement&&f0(()=>{this.setState({editingLinearElement:p})}),p?.lastUncommittedPoint!=null?this.maybeSuggestBindingAtCursor(i):f0(()=>{this.setState({suggestedBindings:[]})})}if(Ch(this.state.activeTool.type)){let{draggingElement:p}=this.state;kt(p,!1)?this.maybeSuggestBindingsForLinearElementAtCoords(p,[i],this.state.startBoundElement):this.maybeSuggestBindingAtCursor(i)}if(this.state.multiElement){let{multiElement:p}=this.state,{x:u,y:g}=p,{points:x,lastCommittedPoint:E}=p,y=x[x.length-1];if(Go(this.interactiveCanvas,this.state),y===E)mt(a-u,l-g,y[0],y[1])>=cl?z(p,{points:[...x,[a-u,l-g]]}):Ve(this.interactiveCanvas,Pe.POINTER);else if(x.length>2&&E&&mt(a-u,l-g,E[0],E[1])<cl)Ve(this.interactiveCanvas,Pe.POINTER),z(p,{points:x.slice(0,-1)});else{let[T,w]=At(a,l,t[I.CTRL_OR_CMD]?null:this.state.gridSize),[S,M]=p?.lastCommittedPoint??[0,0],k=T-u-S,R=w-g-M;ba(t)&&({width:k,height:R}=_l(S+u,M+g,T,w)),yo(x,this.state.zoom.value)&&Ve(this.interactiveCanvas,Pe.POINTER),z(p,{points:[...x.slice(0,-1),[S+k,M+R]]})}return}if(!!t.buttons||this.state.activeTool.type!=="selection"&&this.state.activeTool.type!=="text"&&this.state.activeTool.type!=="eraser")return;let c=this.scene.getNonDeletedElements(),d=this.scene.getSelectedElements(this.state);if(d.length===1&&!n&&!this.state.editingLinearElement){let p=Np(c,this.state,a,l,this.state.zoom,t.pointerType,this.scene.getNonDeletedElementsMap());if(p&&p.transformHandleType){Ve(this.interactiveCanvas,Bp(p));return}}else if(d.length>1&&!n){let p=Op(Se(d),a,l,this.state.zoom,t.pointerType);if(p){Ve(this.interactiveCanvas,Bp({transformHandleType:p}));return}}let m=this.getElementAtPosition(i.x,i.y);this.hitLinkElement=this.getElementLinkAtPosition(i,m),!To(this.state)&&(this.hitLinkElement&&!this.state.selectedElementIds[this.hitLinkElement.id]?(Ve(this.interactiveCanvas,Pe.POINTER),a5(this.hitLinkElement,this.state,this.scene.getNonDeletedElementsMap())):(l5(),m&&(m.link||St(m))&&this.state.selectedElementIds[m.id]&&!this.state.contextMenu&&!this.state.showHyperlinkPopup?this.setState({showHyperlinkPopup:"info"}):this.state.activeTool.type==="text"?Ve(this.interactiveCanvas,W(m)?Pe.TEXT:Pe.CROSSHAIR):this.state.viewModeEnabled?Ve(this.interactiveCanvas,Pe.GRAB):n?Ve(this.interactiveCanvas,Pe.AUTO):this.state.selectedLinearElement?this.handleHoverSelectedLinearElement(this.state.selectedLinearElement,a,l):t[I.CTRL_OR_CMD]?Ve(this.interactiveCanvas,Pe.AUTO):(m||this.isHittingCommonBoundingBoxOfSelectedElements(i,d))&&!m?.locked&&(m&&Jt(m)&&this.isIframeLikeElementCenter(m,t,a,l)?(Ve(this.interactiveCanvas,Pe.POINTER),this.setState({activeEmbeddable:{element:m,state:"hover"}})):(Ve(this.interactiveCanvas,Pe.MOVE),this.state.activeEmbeddable?.state==="hover"&&this.setState({activeEmbeddable:null})))))};handleEraser=(t,o,r)=>{this.eraserTrail.addPointToPath(r.x,r.y);let n=!1,i=new Set,a=this.scene.getNonDeletedElements(),l=p=>{for(let u of p){if(u.locked)return;if(t.altKey?this.elementsPendingErasure.delete(u.id)&&(n=!0):this.elementsPendingErasure.has(u.id)||(n=!0,this.elementsPendingErasure.add(u.id)),n&&u.groupIds?.length){let g=u.groupIds.at(-1);if(!i.has(g)){i.add(g);let x=ot(a,g);for(let E of x)t.altKey?this.elementsPendingErasure.delete(E.id):this.elementsPendingErasure.add(E.id)}}}},s=mt(o.lastCoords.x,o.lastCoords.y,r.x,r.y),c=10/this.state.zoom.value,d={...o.lastCoords},m=0;for(;m<=s;){let p=this.getElementsAtPosition(d.x,d.y);if(l(p),m===s)break;m=Math.min(m+c,s);let u=m/s,g=(1-u)*d.x+u*r.x,x=(1-u)*d.y+u*r.y;d.x=g,d.y=x}if(o.lastCoords.x=r.x,o.lastCoords.y=r.y,n){for(let p of this.scene.getNonDeletedElements())ze(p)&&(this.elementsPendingErasure.has(p.id)||this.elementsPendingErasure.has(p.containerId))&&(t.altKey?(this.elementsPendingErasure.delete(p.id),this.elementsPendingErasure.delete(p.containerId)):(this.elementsPendingErasure.add(p.id),this.elementsPendingErasure.add(p.containerId)));this.elementsPendingErasure=new Set(this.elementsPendingErasure),this.onSceneUpdated()}};handleTouchMove=t=>{$d=!0};handleHoverSelectedLinearElement(t,o,r){let n=this.scene.getNonDeletedElementsMap(),i=$.getElement(t.elementId,n),a=me(i,n);if(i)if(this.state.selectedLinearElement){let l=-1,s=null;fa(i,this.state,this.frameNameBoundsCache,[o,r],n)?(l=$.getPointIndexUnderCursor(i,n,this.state.zoom,o,r),s=$.getSegmentMidpointHitCoords(t,{x:o,y:r},this.state,this.scene.getNonDeletedElementsMap()),l>=0||s?Ve(this.interactiveCanvas,Pe.POINTER):Ve(this.interactiveCanvas,Pe.MOVE)):wl([i],this.state)&&dc(i,this.state,this.frameNameBoundsCache,o,r,n)?Ve(this.interactiveCanvas,Pe.MOVE):a&&Tl(a,this.state,this.frameNameBoundsCache,o,r,this.scene.getNonDeletedElementsMap())&&Ve(this.interactiveCanvas,Pe.MOVE),this.state.selectedLinearElement.hoverPointIndex!==l&&this.setState({selectedLinearElement:{...this.state.selectedLinearElement,hoverPointIndex:l}}),$.arePointsEqual(this.state.selectedLinearElement.segmentMidPointHoveredCoords,s)||this.setState({selectedLinearElement:{...this.state.selectedLinearElement,segmentMidPointHoveredCoords:s}})}else Ve(this.interactiveCanvas,Pe.AUTO)}handleCanvasPointerDown=t=>{if(this.maybeCleanupAfterMissingPointerUp(t.nativeEvent),this.maybeUnfollowRemoteUser(),this.state.contextMenu&&this.setState({contextMenu:null}),this.state.snapLines&&this.setAppState({snapLines:[]}),this.updateGestureOnPointerDown(t),t.pointerType==="touch"&&this.state.draggingElement&&this.state.draggingElement.type==="freedraw"){let c=this.state.draggingElement;this.updateScene({...c.points.length<10?{elements:this.scene.getElementsIncludingDeleted().filter(d=>d.id!==c.id)}:{},appState:{draggingElement:null,editingElement:null,startBoundElement:null,suggestedBindings:[],selectedElementIds:Oe(Object.keys(this.state.selectedElementIds).filter(d=>d!==c.id).reduce((d,m)=>(d[m]=this.state.selectedElementIds[m],d),{}),this.state)}});return}let o=document.getSelection();if(o?.anchorNode&&o.removeAllRanges(),this.maybeOpenContextMenuAfterPointerDownOnTouchDevices(t),!this.state.penDetected&&t.pointerType==="pen"&&this.setState(c=>({penMode:!0,penDetected:!0})),!this.device.isTouchScreen&&["pen","touch"].includes(t.pointerType)&&(this.device=hl(this.device,{isTouchScreen:!0})),Kd||(this.lastPointerDownEvent=t,this.props.interactive!==!1&&this.handleCanvasPanUsingWheelOrSpaceDrag(t)))return;if(this.setState({lastPointerDownWith:t.pointerType,cursorButton:"down"}),this.savePointer(t.clientX,t.clientY,"down"),t.button===ai.ERASER&&this.state.activeTool.type!==wt.eraser){this.setState({activeTool:Qe(this.state,{type:wt.eraser,lastActiveToolBeforeEraser:this.state.activeTool})},()=>{this.handleCanvasPointerDown(t);let c=()=>{d(),m?.(),To(this.state)&&this.setState({activeTool:Qe(this.state,{...this.state.activeTool.lastActiveTool||{type:wt.selection},lastActiveToolBeforeEraser:null})})},d=ft(window,"pointerup",c,{once:!0}),m;requestAnimationFrame(()=>{m=this.missingPointerEventCleanupEmitter.once(c)})});return}if(t.button!==ai.MAIN&&t.button!==ai.TOUCH&&t.button!==ai.ERASER||Fe.pointers.size>1)return;let r=this.initialPointerDownState(t);if(this.setState({selectedElementsAreBeingDragged:!1}),this.props.interactive!==!1&&this.handleDraggingScrollBar(t,r)||(this.clearSelectionIfNotUsingSelection(),this.updateBindingEnabledOnPointerMove(t),this.props.interactive!==!1&&this.handleSelectionOnPointerDown(t,r))||!(!this.state.penMode||t.pointerType!=="touch"||this.state.activeTool.type==="selection"||this.state.activeTool.type==="text"||this.state.activeTool.type==="image"))return;if(this.state.activeTool.type==="text"){this.handleTextOnPointerDown(t,r);return}else if(this.state.activeTool.type==="arrow"||this.state.activeTool.type==="line")this.handleLinearElementOnPointerDown(t,this.state.activeTool.type,r);else if(this.state.activeTool.type==="image"){Ve(this.interactiveCanvas,Pe.CROSSHAIR);let c=this.state.pendingImageElementId&&this.scene.getElement(this.state.pendingImageElementId);if(!c)return;this.setState({draggingElement:c,editingElement:c,pendingImageElementId:null,multiElement:null});let{x:d,y:m}=$e(t,this.state),p=this.getTopLayerFrameAtSceneCoords({x:d,y:m});z(c,{x:d,y:m,frameId:p?p.id:null})}else this.state.activeTool.type==="freedraw"?this.handleFreeDrawElementOnPointerDown(t,this.state.activeTool.type,r):this.state.activeTool.type==="custom"?Go(this.interactiveCanvas,this.state):this.state.activeTool.type===wt.frame||this.state.activeTool.type===wt.magicframe?this.createFrameElementOnPointerDown(r,this.state.activeTool.type):this.state.activeTool.type==="laser"?this.laserTrails.startPath(r.lastCoords.x,r.lastCoords.y):this.state.activeTool.type!=="eraser"&&this.state.activeTool.type!=="hand"&&this.createGenericElementOnPointerDown(this.state.activeTool.type,r);this.props?.onPointerDown?.(this.state.activeTool,r),this.onPointerDownEmitter.trigger(this.state.activeTool,r,t),this.state.activeTool.type==="eraser"&&this.eraserTrail.startPath(r.lastCoords.x,r.lastCoords.y);let i=this.onPointerMoveFromPointerDownHandler(r),a=this.onPointerUpFromPointerDownHandler(r),l=this.onKeyDownFromPointerDownHandler(r),s=this.onKeyUpFromPointerDownHandler(r);this.missingPointerEventCleanupEmitter.once(c=>a(c||t.nativeEvent)),(!this.state.viewModeEnabled||this.state.activeTool.type==="laser")&&(window.addEventListener("pointermove",i),window.addEventListener("pointerup",a),window.addEventListener("keydown",l),window.addEventListener("keyup",s),r.eventListeners.onMove=i,r.eventListeners.onUp=a,r.eventListeners.onKeyUp=s,r.eventListeners.onKeyDown=l)};handleCanvasPointerUp=t=>{this.removePointer(t),this.lastPointerUpEvent=t;let o=$e({clientX:t.clientX,clientY:t.clientY},this.state),r=t.timeStamp-(this.lastPointerDownEvent?.timeStamp??0);if(this.device.editor.isMobile&&r<300){let n=this.getElementAtPosition(o.x,o.y);if(Jt(n)&&this.isIframeLikeElementCenter(n,t,o.x,o.y)){this.handleEmbeddableCenterClick(n);return}}if(this.device.isTouchScreen){let n=this.getElementAtPosition(o.x,o.y);this.hitLinkElement=this.getElementLinkAtPosition(o,n)}this.hitLinkElement&&!this.state.selectedElementIds[this.hitLinkElement.id]?r<300&&Jt(this.hitLinkElement)&&!Lf(this.hitLinkElement,this.scene.getNonDeletedElementsMap(),this.state,[o.x,o.y])?this.handleEmbeddableCenterClick(this.hitLinkElement):this.redirectToLink(t,this.device.isTouchScreen):this.state.viewModeEnabled&&this.setState({activeEmbeddable:null,selectedElementIds:{}})};maybeOpenContextMenuAfterPointerDownOnTouchDevices=t=>{t.pointerType==="touch"&&($d=!1,Qi?$d=!0:Qi=window.setTimeout(()=>{Qi=0,$d||this.handleCanvasContextMenu(t)},J0))};resetContextMenuTimer=()=>{clearTimeout(Qi),Qi=0,$d=!1};maybeCleanupAfterMissingPointerUp=t=>{Xd?.(),this.missingPointerEventCleanupEmitter.trigger(t).clear()};handleCanvasPanUsingWheelOrSpaceDrag=t=>{if(!(Fe.pointers.size<=1&&(t.button===ai.WHEEL||t.button===ai.MAIN&&il||Rr(this.state)||this.state.viewModeEnabled))||W(this.state.editingElement))return!1;Kd=!0,t.preventDefault();let o=!1,r=typeof window===void 0?!1:/Linux/.test(window.navigator.platform);Ve(this.interactiveCanvas,Pe.GRABBING);let{clientX:n,clientY:i}=t,a=Xg(s=>{let c=n-s.clientX,d=i-s.clientY;if(n=s.clientX,i=s.clientY,r&&!o&&(Math.abs(c)>1||Math.abs(d)>1)){o=!0;let m=u=>{document.body.removeEventListener("paste",m),u.stopPropagation()},p=()=>{setTimeout(()=>{document.body.removeEventListener("paste",m),window.removeEventListener("pointerup",p)},100)};document.body.addEventListener("paste",m),window.addEventListener("pointerup",p)}this.translateCanvas({scrollX:this.state.scrollX-c/this.state.zoom.value,scrollY:this.state.scrollY-d/this.state.zoom.value})}),l=ct(Xd=()=>{Xd=null,Kd=!1,il||(this.state.viewModeEnabled?Ve(this.interactiveCanvas,Pe.GRAB):Go(this.interactiveCanvas,this.state)),this.setState({cursorButton:"up"}),this.savePointer(t.clientX,t.clientY,"up"),window.removeEventListener("pointermove",a),window.removeEventListener("pointerup",l),window.removeEventListener("blur",l),a.flush()});return window.addEventListener("blur",l),window.addEventListener("pointermove",a,{passive:!0}),window.addEventListener("pointerup",l),!0};updateGestureOnPointerDown(t){Fe.pointers.set(t.pointerId,{x:t.clientX,y:t.clientY}),Fe.pointers.size===2&&(Fe.lastCenter=nE(Fe.pointers),Fe.initialScale=this.state.zoom.value,Fe.initialDistance=iE(Array.from(Fe.pointers.values())))}initialPointerDownState(t){let o=$e(t,this.state),r=this.scene.getSelectedElements(this.state),[n,i,a,l]=Se(r);return{origin:o,withCmdOrCtrl:t[I.CTRL_OR_CMD],originInGrid:Cr(At(o.x,o.y,t[I.CTRL_OR_CMD]?null:this.state.gridSize)),scrollbars:gE(E0,t.clientX-this.state.offsetLeft,t.clientY-this.state.offsetTop),lastCoords:{...o},originalElements:this.scene.getNonDeletedElements().reduce((s,c)=>(s.set(c.id,zn(c)),s),new Map),resize:{handleType:!1,isResizing:!1,offset:{x:0,y:0},arrowDirection:"origin",center:{x:(a+n)/2,y:(l+i)/2}},hit:{element:null,allHitElements:[],wasAddedToSelection:!1,hasBeenDuplicated:!1,hasHitCommonBoundingBoxOfSelectedElements:this.isHittingCommonBoundingBoxOfSelectedElements(o,r)},drag:{hasOccurred:!1,offset:null},eventListeners:{onMove:null,onUp:null,onKeyUp:null,onKeyDown:null},boxSelection:{hasOccurred:!1}}}handleDraggingScrollBar(t,o){if(!(o.scrollbars.isOverEither&&!this.state.multiElement))return!1;x0=!0,o.lastCoords.x=t.clientX,o.lastCoords.y=t.clientY;let r=Xg(i=>{i.target instanceof HTMLElement&&this.handlePointerMoveOverScrollbars(i,o)}),n=ct(()=>{Xd=null,x0=!1,Go(this.interactiveCanvas,this.state),this.setState({cursorButton:"up"}),this.savePointer(t.clientX,t.clientY,"up"),window.removeEventListener("pointermove",r),window.removeEventListener("pointerup",n),r.flush()});return Xd=n,window.addEventListener("pointermove",r),window.addEventListener("pointerup",n),!0}clearSelectionIfNotUsingSelection=()=>{this.state.activeTool.type!=="selection"&&this.setState({selectedElementIds:Oe({},this.state),selectedGroupIds:{},editingGroupId:null,activeEmbeddable:null})};handleSelectionOnPointerDown=(t,o)=>{if(this.state.activeTool.type==="selection"){let r=this.scene.getNonDeletedElements(),n=this.scene.getNonDeletedElementsMap(),i=this.scene.getSelectedElements(this.state);if(i.length===1&&!this.state.editingLinearElement){let a=Np(r,this.state,o.origin.x,o.origin.y,this.state.zoom,t.pointerType,this.scene.getNonDeletedElementsMap());a!=null&&(this.setState({resizingElement:a.element}),o.resize.handleType=a.transformHandleType)}else i.length>1&&(o.resize.handleType=Op(Se(i),o.origin.x,o.origin.y,this.state.zoom,t.pointerType));if(o.resize.handleType)o.resize.isResizing=!0,o.resize.offset=Cr(jf(o.resize.handleType,i,n,o.origin.x,o.origin.y)),i.length===1&&ne(i[0])&&i[0].points.length===2&&(o.resize.arrowDirection=qf(o.resize.handleType,i[0]));else{if(this.state.selectedLinearElement){let s=this.state.editingLinearElement||this.state.selectedLinearElement,c=$.handlePointerDown(t,this.state,this.history,o.origin,s,this.scene.getNonDeletedElements(),n);if(c.hitElement&&(o.hit.element=c.hitElement),c.linearElementEditor&&(this.setState({selectedLinearElement:c.linearElementEditor}),this.state.editingLinearElement&&this.setState({editingLinearElement:c.linearElementEditor})),c.didAddPoint)return!0}if(o.hit.element=o.hit.element??this.getElementAtPosition(o.origin.x,o.origin.y),o.hit.element&&this.getElementLinkAtPosition({x:o.origin.x,y:o.origin.y},o.hit.element))return!1;o.hit.allHitElements=this.getElementsAtPosition(o.origin.x,o.origin.y);let a=o.hit.element,l=o.hit.allHitElements.some(s=>this.isASelectedElement(s));if((a===null||!l)&&!t.shiftKey&&!o.hit.hasHitCommonBoundingBoxOfSelectedElements&&this.clearSelection(a),this.state.editingLinearElement)this.setState({selectedElementIds:Oe({[this.state.editingLinearElement.elementId]:!0},this.state)});else if(a!=null){if(t[I.CTRL_OR_CMD])return this.state.selectedElementIds[a.id]||(o.hit.wasAddedToSelection=!0),this.setState(s=>({...z2(s,a),previousSelectedElementIds:this.state.selectedElementIds})),!1;this.state.selectedElementIds[a.id]||(this.state.editingGroupId&&!Ta(a,this.state.editingGroupId)&&this.setState({selectedElementIds:Oe({},this.state),selectedGroupIds:{},editingGroupId:null,activeEmbeddable:null}),!l&&!o.hit.hasHitCommonBoundingBoxOfSelectedElements&&(this.setState(s=>{let c={...s.selectedElementIds,[a.id]:!0},d=[];if(Object.keys(s.selectedElementIds).forEach(m=>{let p=this.scene.getElement(m);p&&d.push(p)}),Q(a))Vo(d,a.id).forEach(m=>{delete c[m.id]});else if(a.frameId)c[a.frameId]&&delete c[a.id];else{let m=a.groupIds,p=new Set(m.flatMap(u=>ot(this.scene.getNonDeletedElements(),u)).filter(u=>Q(u)).map(u=>u.id));p.size>0&&d.forEach(u=>{u.frameId&&p.has(u.frameId)&&(delete c[u.id],u.groupIds.flatMap(g=>ot(this.scene.getNonDeletedElements(),g)).forEach(g=>{delete c[g.id]}))})}return{...to({editingGroupId:s.editingGroupId,selectedElementIds:c},this.scene.getNonDeletedElements(),s,this),showHyperlinkPopup:a.link||St(a)?"info":!1}}),o.hit.wasAddedToSelection=!0))}this.setState({previousSelectedElementIds:this.state.selectedElementIds})}}return!1};isASelectedElement(t){return t!=null&&this.state.selectedElementIds[t.id]}isHittingCommonBoundingBoxOfSelectedElements(t,o){if(o.length<2)return!1;let r=10/this.state.zoom.value,[n,i,a,l]=Se(o);return t.x>n-r&&t.x<a+r&&t.y>i-r&&t.y<l+r}handleTextOnPointerDown=(t,o)=>{if(W(this.state.editingElement))return;let r=o.origin.x,n=o.origin.y,i=this.getElementAtPosition(r,n,{includeBoundTextElement:!0}),a=tf(this.scene.getNonDeletedElements(),this.state,r,n,this.scene.getNonDeletedElementsMap());Eo(i)&&(a=i,r=i.x+i.width/2,n=i.y+i.height/2),this.startTextEditing({sceneX:r,sceneY:n,insertAtParentCenter:!t.altKey,container:a}),zo(this.interactiveCanvas),this.state.activeTool.locked||this.setState({activeTool:Qe(this.state,{type:"selection"})})};handleFreeDrawElementOnPointerDown=(t,o,r)=>{let[n,i]=At(r.origin.x,r.origin.y,null),a=this.getTopLayerFrameAtSceneCoords({x:n,y:i}),l=j2({type:o,x:n,y:i,strokeColor:this.state.currentItemStrokeColor,backgroundColor:this.state.currentItemBackgroundColor,fillStyle:this.state.currentItemFillStyle,strokeWidth:this.state.currentItemStrokeWidth,strokeStyle:this.state.currentItemStrokeStyle,roughness:this.state.currentItemRoughness,opacity:this.state.currentItemOpacity,roundness:null,simulatePressure:t.pressure===.5,locked:!1,frameId:a?a.id:null});this.setState(d=>{let m={...d.selectedElementIds};return delete m[l.id],{selectedElementIds:Oe(m,d)}});let s=l.simulatePressure?l.pressures:[...l.pressures,t.pressure];z(l,{points:[[0,0]],pressures:s});let c=en(r.origin,this.scene.getNonDeletedElements(),this.scene.getNonDeletedElementsMap());this.scene.addNewElement(l),this.setState({draggingElement:l,editingElement:l,startBoundElement:c,suggestedBindings:[]})};insertIframeElement=({sceneX:t,sceneY:o,width:r,height:n})=>{let[i,a]=At(t,o,this.lastPointerDownEvent?.[I.CTRL_OR_CMD]?null:this.state.gridSize),l=X2({type:"iframe",x:i,y:a,strokeColor:"transparent",backgroundColor:"transparent",fillStyle:this.state.currentItemFillStyle,strokeWidth:this.state.currentItemStrokeWidth,strokeStyle:this.state.currentItemStrokeStyle,roughness:this.state.currentItemRoughness,roundness:this.getCurrentItemRoundness("iframe"),opacity:this.state.currentItemOpacity,locked:!1,width:r,height:n});return this.scene.replaceAllElements([...this.scene.getElementsIncludingDeleted(),l]),l};insertEmbeddableElement=({sceneX:t,sceneY:o,link:r})=>{let[n,i]=At(t,o,this.lastPointerDownEvent?.[I.CTRL_OR_CMD]?null:this.state.gridSize),a=Un(r);if(!a)return;a.error instanceof URIError&&this.setToast({message:b("toast.unrecognizedLinkFormat"),closable:!0});let l=pf({type:"embeddable",x:n,y:i,strokeColor:"transparent",backgroundColor:"transparent",fillStyle:this.state.currentItemFillStyle,strokeWidth:this.state.currentItemStrokeWidth,strokeStyle:this.state.currentItemStrokeStyle,roughness:this.state.currentItemRoughness,roundness:this.getCurrentItemRoundness("embeddable"),opacity:this.state.currentItemOpacity,locked:!1,width:a.intrinsicSize.w,height:a.intrinsicSize.h,link:r});return this.scene.replaceAllElements([...this.scene.getElementsIncludingDeleted(),l]),l};createImageElement=({sceneX:t,sceneY:o,addToFrameUnderCursor:r=!0})=>{let[n,i]=At(t,o,this.lastPointerDownEvent?.[I.CTRL_OR_CMD]?null:this.state.gridSize),a=r?this.getTopLayerFrameAtSceneCoords({x:n,y:i}):null;return Ec({type:"image",x:n,y:i,strokeColor:this.state.currentItemStrokeColor,backgroundColor:this.state.currentItemBackgroundColor,fillStyle:this.state.currentItemFillStyle,strokeWidth:this.state.currentItemStrokeWidth,strokeStyle:this.state.currentItemStrokeStyle,roughness:this.state.currentItemRoughness,roundness:null,opacity:this.state.currentItemOpacity,locked:!1,frameId:a?a.id:null})};handleLinearElementOnPointerDown=(t,o,r)=>{if(this.state.multiElement){let{multiElement:n}=this.state;if(n.type==="line"&&yo(n.points,this.state.zoom.value)){z(n,{lastCommittedPoint:n.points[n.points.length-1]}),this.actionManager.executeAction(Zo);return}let{x:i,y:a,lastCommittedPoint:l}=n;if(n.points.length>1&&l&&mt(r.origin.x-i,r.origin.y-a,l[0],l[1])<cl){this.actionManager.executeAction(Zo);return}this.setState(s=>({selectedElementIds:Oe({...s.selectedElementIds,[n.id]:!0},s)})),z(n,{lastCommittedPoint:n.points[n.points.length-1]}),Ve(this.interactiveCanvas,Pe.POINTER)}else{let[n,i]=At(r.origin.x,r.origin.y,t[I.CTRL_OR_CMD]?null:this.state.gridSize),a=this.getTopLayerFrameAtSceneCoords({x:n,y:i}),{currentItemStartArrowhead:l,currentItemEndArrowhead:s}=this.state,[c,d]=o==="arrow"?[l,s]:[null,null],m=cr({type:o,x:n,y:i,strokeColor:this.state.currentItemStrokeColor,backgroundColor:this.state.currentItemBackgroundColor,fillStyle:this.state.currentItemFillStyle,strokeWidth:this.state.currentItemStrokeWidth,strokeStyle:this.state.currentItemStrokeStyle,roughness:this.state.currentItemRoughness,opacity:this.state.currentItemOpacity,roundness:this.state.currentItemRoundness==="round"?{type:at.PROPORTIONAL_RADIUS}:null,startArrowhead:c,endArrowhead:d,locked:!1,frameId:a?a.id:null});this.setState(u=>{let g={...u.selectedElementIds};return delete g[m.id],{selectedElementIds:Oe(g,u)}}),z(m,{points:[...m.points,[0,0]]});let p=en(r.origin,this.scene.getNonDeletedElements(),this.scene.getNonDeletedElementsMap());this.scene.addNewElement(m),this.setState({draggingElement:m,editingElement:m,startBoundElement:p,suggestedBindings:[]})}};getCurrentItemRoundness(t){return this.state.currentItemRoundness==="round"?{type:qr(t)?at.ADAPTIVE_RADIUS:at.PROPORTIONAL_RADIUS}:null}createGenericElementOnPointerDown=(t,o)=>{let[r,n]=At(o.origin.x,o.origin.y,this.lastPointerDownEvent?.[I.CTRL_OR_CMD]?null:this.state.gridSize),i=this.getTopLayerFrameAtSceneCoords({x:r,y:n}),a={x:r,y:n,strokeColor:this.state.currentItemStrokeColor,backgroundColor:this.state.currentItemBackgroundColor,fillStyle:this.state.currentItemFillStyle,strokeWidth:this.state.currentItemStrokeWidth,strokeStyle:this.state.currentItemStrokeStyle,roughness:this.state.currentItemRoughness,opacity:this.state.currentItemOpacity,roundness:this.getCurrentItemRoundness(t),locked:!1,frameId:i?i.id:null},l;t==="embeddable"?l=pf({type:"embeddable",...a}):l=Uo({type:t,...a}),l.type==="selection"?this.setState({selectionElement:l,draggingElement:l}):(this.scene.addNewElement(l),this.setState({multiElement:null,draggingElement:l,editingElement:l}))};createFrameElementOnPointerDown=(t,o)=>{let[r,n]=At(t.origin.x,t.origin.y,this.lastPointerDownEvent?.[I.CTRL_OR_CMD]?null:this.state.gridSize),i={x:r,y:n,opacity:this.state.currentItemOpacity,locked:!1,...Je},a=o===wt.magicframe?xc(i):jm(i);this.scene.replaceAllElements([...this.scene.getElementsIncludingDeleted(),a]),this.setState({multiElement:null,draggingElement:a,editingElement:a})};maybeCacheReferenceSnapPoints(t,o,r=!1){ni({event:t,appState:this.state,selectedElements:o})&&(r||!yr.getReferenceSnapPoints())&&yr.setReferenceSnapPoints(KS(this.scene.getNonDeletedElements(),o,this.state,this.scene.getNonDeletedElementsMap()))}maybeCacheVisibleGaps(t,o,r=!1){ni({event:t,appState:this.state,selectedElements:o})&&(r||!yr.getVisibleGaps())&&yr.setVisibleGaps(YS(this.scene.getNonDeletedElements(),o,this.state,this.scene.getNonDeletedElementsMap()))}onKeyDownFromPointerDownHandler(t){return ct(o=>{this.maybeHandleResize(t,o)||this.maybeDragNewGenericElement(t,o)})}onKeyUpFromPointerDownHandler(t){return ct(o=>{o.key===I.ALT&&o.preventDefault(),!this.maybeHandleResize(t,o)&&this.maybeDragNewGenericElement(t,o)})}onPointerMoveFromPointerDownHandler(t){return Xg(o=>{if(t.drag.offset===null&&(t.drag.offset=Cr(e1(this.scene.getSelectedElements(this.state),t.origin.x,t.origin.y))),!(o.target instanceof HTMLElement)||this.handlePointerMoveOverScrollbars(o,t))return;let n=$e(o,this.state);if(To(this.state)){this.handleEraser(o,t,n);return}this.state.activeTool.type==="laser"&&this.laserTrails.addPointToPath(n.x,n.y);let[i,a]=At(n.x,n.y,o[I.CTRL_OR_CMD]?null:this.state.gridSize);if(!t.drag.hasOccurred&&(this.state.activeTool.type==="arrow"||this.state.activeTool.type==="line")&&mt(n.x,n.y,t.origin.x,t.origin.y)<kn)return;if(t.resize.isResizing&&(t.lastCoords.x=n.x,t.lastCoords.y=n.y,this.maybeHandleResize(t,o)))return!0;let l=this.scene.getNonDeletedElementsMap();if(this.state.selectedLinearElement){let m=this.state.editingLinearElement||this.state.selectedLinearElement;if($.shouldAddMidpoint(this.state.selectedLinearElement,n,this.state,l)){let u=$.addMidpoint(this.state.selectedLinearElement,n,this.state,!o[I.CTRL_OR_CMD],l);if(!u)return;f0(()=>{this.state.selectedLinearElement&&this.setState({selectedLinearElement:{...this.state.selectedLinearElement,pointerDownState:u.pointerDownState,selectedPointsIndices:u.selectedPointsIndices}}),this.state.editingLinearElement&&this.setState({editingLinearElement:{...this.state.editingLinearElement,pointerDownState:u.pointerDownState,selectedPointsIndices:u.selectedPointsIndices}})});return}else if(m.pointerDownState.segmentMidpoint.value!==null&&!m.pointerDownState.segmentMidpoint.added)return;if($.handlePointDragging(o,this.state,n.x,n.y,(u,g)=>{this.maybeSuggestBindingsForLinearElementAtCoords(u,g)},m,this.scene.getNonDeletedElementsMap())){t.lastCoords.x=n.x,t.lastCoords.y=n.y,t.drag.hasOccurred=!0,this.state.editingLinearElement&&!this.state.editingLinearElement.isDragging&&this.setState({editingLinearElement:{...this.state.editingLinearElement,isDragging:!0}}),this.state.selectedLinearElement.isDragging||this.setState({selectedLinearElement:{...this.state.selectedLinearElement,isDragging:!0}});return}}let s=t.hit.allHitElements.some(m=>this.isASelectedElement(m)),c=this.state.editingLinearElement&&o.shiftKey&&this.state.editingLinearElement.elementId===t.hit.element?.id;if((s||t.hit.hasHitCommonBoundingBoxOfSelectedElements)&&!c){let m=this.scene.getSelectedElements(this.state);if(m.every(g=>g.locked))return;let p=m.find(g=>Q(g)),u=this.getTopLayerFrameAtSceneCoords(n);if(this.setState({frameToHighlight:u&&!p?u:null}),t.drag.hasOccurred=!0,this.setState({selectedElementsAreBeingDragged:!0}),m.length>0&&!t.withCmdOrCtrl&&!this.state.editingElement&&this.state.activeEmbeddable?.state!=="active"){let g={x:n.x-t.origin.x,y:n.y-t.origin.y},x=[...t.originalElements.values()],E=o.shiftKey;if(E){let w=Math.abs(g.x),S=Math.abs(g.y),M=E&&w<S,k=E&&w>S;M&&(g.x=0),k&&(g.y=0)}this.maybeCacheVisibleGaps(o,m),this.maybeCacheReferenceSnapPoints(o,m);let{snapOffset:y,snapLines:T}=$S(x,g,this.state,o,this.scene.getNonDeletedElementsMap());if(this.setState({snapLines:T}),!this.state.editingFrame&&Qf(t,m,g,this.state,this.scene,y,o[I.CTRL_OR_CMD]?null:this.state.gridSize),this.maybeSuggestBindingForAll(m),o.altKey&&!t.hit.hasBeenDuplicated){t.hit.hasBeenDuplicated=!0;let w=[],S=[],M=new Map,k=new Map,R=t.hit.element,P=new Set(this.scene.getSelectedElements({selectedElementIds:this.state.selectedElementIds,includeBoundTextElement:!0,includeElementsInFrames:!0}).map(L=>L.id)),F=this.scene.getElementsIncludingDeleted();for(let L of F)if(P.has(L.id)||L.id===R?.id&&t.hit.wasAddedToSelection){let A=Ol(this.state.editingGroupId,M,L),B=t.originalElements.get(L.id);z(A,{x:B.x,y:B.y}),t.originalElements.set(A.id,A),w.push(A),S.push(L),k.set(L.id,A.id)}else w.push(L);let D=[...w,...S];Om(w,S,k),Dm(D,S,k,"duplicatesServeAsOld"),Mp(D,S,k),this.scene.replaceAllElements(D),this.maybeCacheVisibleGaps(o,m,!0),this.maybeCacheReferenceSnapPoints(o,m,!0)}return}}let d=this.state.draggingElement;if(d){if(d.type==="freedraw"){let m=d.points,p=n.x-d.x,u=n.y-d.y,g=m.length>0&&m[m.length-1];if(!(g&&g[0]===p&&g[1]===u)){let E=d.simulatePressure?d.pressures:[...d.pressures,o.pressure];z(d,{points:[...m,[p,u]],pressures:E})}}else if(ne(d)){t.drag.hasOccurred=!0,this.setState({selectedElementsAreBeingDragged:!0});let m=d.points,p=i-d.x,u=a-d.y;ba(o)&&m.length===2&&({width:p,height:u}=_l(d.x,d.y,n.x,n.y)),m.length===1?z(d,{points:[...m,[p,u]]}):m.length===2&&z(d,{points:[...m.slice(0,-1),[p,u]]}),kt(d,!1)&&this.maybeSuggestBindingsForLinearElementAtCoords(d,[n],this.state.startBoundElement)}else t.lastCoords.x=n.x,t.lastCoords.y=n.y,this.maybeDragNewGenericElement(t,o);if(this.state.activeTool.type==="selection"){t.boxSelection.hasOccurred=!0;let m=this.scene.getNonDeletedElements();if(this.state.editingLinearElement)$.handleBoxSelection(o,this.state,this.setState.bind(this),this.scene.getNonDeletedElementsMap());else{let p=!0;!o.shiftKey&&Ye(m,this.state)&&(t.withCmdOrCtrl&&t.hit.element?this.setState(g=>to({...g,selectedElementIds:{[t.hit.element.id]:!0}},this.scene.getNonDeletedElements(),g,this)):p=!1);let u=es(m,d,this.scene.getNonDeletedElementsMap());this.setState(g=>{let x={...p&&g.selectedElementIds,...u.reduce((E,y)=>(E[y.id]=!0,E),{})};return t.hit.element&&(u.length?delete x[t.hit.element.id]:x[t.hit.element.id]=!0),g=p?g:{...g,selectedGroupIds:{},editingGroupId:null},{...to({editingGroupId:g.editingGroupId,selectedElementIds:x},this.scene.getNonDeletedElements(),g,this),selectedLinearElement:u.length===1&&ne(u[0])?new $(u[0]):null,showHyperlinkPopup:u.length===1&&(u[0].link||St(u[0]))?"info":!1}})}}}})}handlePointerMoveOverScrollbars(t,o){if(o.scrollbars.isOverHorizontal){let r=t.clientX,n=r-o.lastCoords.x;return this.translateCanvas({scrollX:this.state.scrollX-n/this.state.zoom.value}),o.lastCoords.x=r,!0}if(o.scrollbars.isOverVertical){let r=t.clientY,n=r-o.lastCoords.y;return this.translateCanvas({scrollY:this.state.scrollY-n/this.state.zoom.value}),o.lastCoords.y=r,!0}return!1}onPointerUpFromPointerDownHandler(t){return ct(o=>{this.removePointer(o),t.eventListeners.onMove&&t.eventListeners.onMove.flush();let{draggingElement:r,resizingElement:n,multiElement:i,activeTool:a,isResizing:l,isRotating:s}=this.state;this.setState(u=>({isResizing:!1,isRotating:!1,resizingElement:null,selectionElement:null,frameToHighlight:null,elementsToHighlight:null,cursorButton:"up",editingElement:i||W(this.state.editingElement)?this.state.editingElement:null,snapLines:Em(u.snapLines,[]),originSnapOffset:null})),yr.setReferenceSnapPoints(null),yr.setVisibleGaps(null),this.savePointer(o.clientX,o.clientY,"up"),this.setState({selectedElementsAreBeingDragged:!1}),this.onPointerUpEmitter.trigger(this.state.activeTool,t,o);let c=this.scene.getNonDeletedElementsMap();if(this.state.editingLinearElement)if(!t.boxSelection.hasOccurred&&t.hit?.element?.id!==this.state.editingLinearElement.elementId)this.actionManager.executeAction(Zo);else{let u=$.handlePointerUp(o,this.state.editingLinearElement,this.state,this.scene.getNonDeletedElements(),c);u!==this.state.editingLinearElement&&this.setState({editingLinearElement:u,suggestedBindings:[]})}else if(this.state.selectedLinearElement)if(t.hit?.element?.id!==this.state.selectedLinearElement.elementId)this.scene.getSelectedElements(this.state).length>1&&this.setState({selectedLinearElement:null});else{let u=$.handlePointerUp(o,this.state.selectedLinearElement,this.state,this.scene.getNonDeletedElements(),c),{startBindingElement:g,endBindingElement:x}=u,E=this.scene.getElement(u.elementId);kt(E)&&Rn(E,g,x,c),u!==this.state.selectedLinearElement&&this.setState({selectedLinearElement:{...u,selectedPointsIndices:null},suggestedBindings:[]})}if(this.missingPointerEventCleanupEmitter.clear(),window.removeEventListener("pointermove",t.eventListeners.onMove),window.removeEventListener("pointerup",t.eventListeners.onUp),window.removeEventListener("keydown",t.eventListeners.onKeyDown),window.removeEventListener("keyup",t.eventListeners.onKeyUp),this.state.pendingImageElementId&&this.setState({pendingImageElementId:null}),this.props?.onPointerUp?.(a,t),this.onPointerUpEmitter.trigger(this.state.activeTool,t,o),r?.type==="freedraw"){let u=$e(o,this.state),g=r.points,x=u.x-r.x,E=u.y-r.y;x===g[0][0]&&E===g[0][1]&&(E+=1e-4,x+=1e-4);let y=r.simulatePressure?[]:[...r.pressures,o.pressure];z(r,{points:[...g,[x,E]],pressures:y,lastCommittedPoint:[x,E]}),this.actionManager.executeAction(Zo);return}if(nr(r)){let u=r;try{this.initializeImageDimensions(u),this.setState({selectedElementIds:Oe({[u.id]:!0},this.state)},()=>{this.actionManager.executeAction(Zo)})}catch(g){console.error(g),this.scene.replaceAllElements(this.scene.getElementsIncludingDeleted().filter(x=>x.id!==u.id)),this.actionManager.executeAction(Zo)}return}if(ne(r)){r.points.length>1&&this.history.resumeRecording();let u=$e(o,this.state);!t.drag.hasOccurred&&r&&!i?(z(r,{points:[...r.points,[u.x-r.x,u.y-r.y]]}),this.setState({multiElement:r,editingElement:this.state.draggingElement})):t.drag.hasOccurred&&!i&&(Qr(this.state)&&kt(r,!1)&&pc(r,this.state,this.scene,u,c),this.setState({suggestedBindings:[],startBoundElement:null}),a.locked?this.setState(g=>({draggingElement:null})):(zo(this.interactiveCanvas),this.setState(g=>({draggingElement:null,activeTool:Qe(this.state,{type:"selection"}),selectedElementIds:Oe({...g.selectedElementIds,[r.id]:!0},g),selectedLinearElement:new $(r)}))));return}if(a.type!=="selection"&&r&&dr(r)){this.scene.replaceAllElements(this.scene.getElementsIncludingDeleted().filter(u=>u.id!==r.id)),this.setState({draggingElement:null});return}if(r){if(t.drag.hasOccurred){let u=$e(o,this.state);if(this.state.selectedLinearElement&&this.state.selectedLinearElement.isDragging){let g=this.scene.getElement(this.state.selectedLinearElement.elementId);if(g?.frameId){let x=Ut(g,c);x&&g&&(an(g,x,this.scene.getNonDeletedElementsMap())||(z(g,{groupIds:[]}),Ql([g],this.scene.getNonDeletedElementsMap()),this.scene.informMutation()))}}else{let g=this.getTopLayerFrameAtSceneCoords(u),x=this.scene.getSelectedElements(this.state),E=this.scene.getElementsMapIncludingDeleted(),y=T=>{if(T.length>0){for(let w of T){let S=w.groupIds.indexOf(this.state.editingGroupId);z(w,{groupIds:w.groupIds.slice(0,S)},!1)}E.forEach(w=>{w.groupIds.length&&ot(E,w.groupIds[w.groupIds.length-1]).length<2&&z(w,{groupIds:[]},!1)}),this.setState({editingGroupId:null})}};if(g&&!this.state.selectedElementIds[g.id]){let T=x.filter(w=>w.frameId!==g.id&&Ma(w,E,this.state));this.state.editingGroupId&&y(T),E=Nc(E,T,g)}else if(!g&&this.state.editingGroupId){let T=x.filter(w=>w.frameId&&!Ma(w,E,this.state));y(T)}E=ln(E,this.state,this),this.scene.replaceAllElements(E)}}if(Q(r)){let u=dv(this.scene.getElementsIncludingDeleted(),r,this.scene.getNonDeletedElementsMap());this.scene.replaceAllElements(Nc(this.scene.getElementsMapIncludingDeleted(),u,r))}z(r,Sc(r))}if(n&&this.history.resumeRecording(),n&&dr(n)&&this.scene.replaceAllElements(this.scene.getElementsIncludingDeleted().filter(u=>u.id!==n.id)),t.resize.isResizing){let u=ln(this.scene.getElementsIncludingDeleted(),this.state,this),g=this.scene.getSelectedElements(this.state).filter(x=>Q(x));for(let x of g)u=Lp(u,Jl(this.scene.getElementsIncludingDeleted(),x,this.state,c),x,this);this.scene.replaceAllElements(u)}let d=t.hit.element;this.state.selectedLinearElement?.elementId!==d?.id&&ne(d)&&this.scene.getSelectedElements(this.state).length===1&&this.setState({selectedLinearElement:new $(d)});let m=this.lastPointerDownEvent,p=this.lastPointerUpEvent||this.lastPointerMoveEvent;if(To(this.state)&&m&&p){if(this.eraserTrail.endPath(),mt(m.clientX,m.clientY,p.clientX,p.clientY)===0){let g=$e({clientX:p.clientX,clientY:p.clientY},this.state);this.getElementsAtPosition(g.x,g.y).forEach(E=>this.elementsPendingErasure.add(E.id))}this.eraseElements();return}else this.elementsPendingErasure.size&&this.restoreReadyToEraseElements();if(d&&!t.drag.hasOccurred&&!t.hit.wasAddedToSelection&&(!this.state.editingLinearElement||!t.boxSelection.hasOccurred)&&(o.shiftKey&&!this.state.editingLinearElement?this.state.selectedElementIds[d.id]?Um(this.state,d)?this.setState(u=>{let g={...u.selectedElementIds};for(let x of d.groupIds.flatMap(E=>ot(this.scene.getNonDeletedElements(),E)))delete g[x.id];return{selectedGroupIds:{...u.selectedElementIds,...d.groupIds.map(x=>({[x]:!1})).reduce((x,E)=>({...x,...E}),{})},selectedElementIds:Oe(g,u)}}):this.state.selectedLinearElement?.isDragging||this.setState(u=>{let g={...u.selectedElementIds};delete g[d.id];let x=de(this.scene.getNonDeletedElements(),{selectedElementIds:g});return{...to({editingGroupId:u.editingGroupId,selectedElementIds:g},this.scene.getNonDeletedElements(),u,this),selectedLinearElement:x.length===1&&ne(x[0])?new $(x[0]):u.selectedLinearElement}}):d.frameId&&this.state.selectedElementIds[d.frameId]?this.setState(u=>{let g={...u.selectedElementIds,[d.id]:!0};return delete g[d.frameId],(this.scene.getElement(d.frameId)?.groupIds??[]).flatMap(x=>ot(this.scene.getNonDeletedElements(),x)).forEach(x=>{delete g[x.id]}),{...to({editingGroupId:u.editingGroupId,selectedElementIds:g},this.scene.getNonDeletedElements(),u,this),showHyperlinkPopup:d.link||St(d)?"info":!1}}):this.setState(u=>({selectedElementIds:Oe({...u.selectedElementIds,[d.id]:!0},u)})):this.setState(u=>({...to({editingGroupId:u.editingGroupId,selectedElementIds:{[d.id]:!0}},this.scene.getNonDeletedElements(),u,this),selectedLinearElement:ne(d)&&u.selectedLinearElement?.elementId!==d.id?new $(d):u.selectedLinearElement}))),!t.drag.hasOccurred&&!this.state.isResizing&&(d&&dc(d,this.state,this.frameNameBoundsCache,t.origin.x,t.origin.y,this.scene.getNonDeletedElementsMap())||!d&&t.hit.hasHitCommonBoundingBoxOfSelectedElements)){this.state.editingLinearElement?this.setState({editingLinearElement:null}):this.setState({selectedElementIds:Oe({},this.state),selectedGroupIds:{},editingGroupId:null,activeEmbeddable:null});return}if(!a.locked&&a.type!=="freedraw"&&r&&r.type!=="selection"&&this.setState(u=>({selectedElementIds:Oe({...u.selectedElementIds,[r.id]:!0},u),showHyperlinkPopup:St(r)&&!r.link?"editor":u.showHyperlinkPopup})),(a.type!=="selection"||Ye(this.scene.getNonDeletedElements(),this.state))&&this.history.resumeRecording(),(t.drag.hasOccurred||l||s)&&(Qr(this.state)?mc(this.scene.getSelectedElements(this.state),this.scene.getNonDeletedElements(),c):uc(this.scene.getSelectedElements(this.state),c)),a.type==="laser"){this.laserTrails.endPath();return}!a.locked&&a.type!=="freedraw"?(zo(this.interactiveCanvas),this.setState({draggingElement:null,suggestedBindings:[],activeTool:Qe(this.state,{type:"selection"})})):this.setState({draggingElement:null,suggestedBindings:[]}),d&&this.lastPointerUpEvent&&this.lastPointerDownEvent&&this.lastPointerUpEvent.timeStamp-this.lastPointerDownEvent.timeStamp<300&&Fe.pointers.size<=1&&Jt(d)&&this.isIframeLikeElementCenter(d,this.lastPointerUpEvent,t.origin.x,t.origin.y)&&this.handleEmbeddableCenterClick(d)})}restoreReadyToEraseElements=()=>{this.elementsPendingErasure=new Set,this.onSceneUpdated()};eraseElements=()=>{let t=!1,o=this.scene.getElementsIncludingDeleted().map(r=>this.elementsPendingErasure.has(r.id)||r.frameId&&this.elementsPendingErasure.has(r.frameId)||ze(r)&&this.elementsPendingErasure.has(r.containerId)?(t=!0,ae(r,{isDeleted:!0})):r);this.elementsPendingErasure=new Set,t&&(this.history.resumeRecording(),this.scene.replaceAllElements(o))};initializeImage=async({imageFile:t,imageElement:o,showCursorImagePreview:r=!1})=>{if(!Ci(t))throw new Error(b("errors.unsupportedFileType"));let n=t.type;if(Ve(this.interactiveCanvas,"wait"),n===J.svg)try{t=Cf(await Iw(await t.text()),t.name)}catch(c){throw console.warn(c),new Error(b("errors.svgImageInsertError"))}let i=await(this.props.generateIdForFile?.(t)||xw(t));if(!i)throw console.warn("Couldn't generate file id or the supplied `generateIdForFile` didn't resolve to one."),new Error(b("errors.imageInsertError"));if(!this.files[i]?.dataURL){try{t=await Ac(t,{maxWidthOrHeight:ay})}catch(c){console.error("Error trying to resizing image file on insertion",c)}if(t.size>hh)throw new Error(b("errors.fileTooBig",{maxSize:`${Math.trunc(hh/1024/1024)}MB`}))}if(r){let c=this.files[i]?.dataURL,d=c&&Ew(c);this.setImagePreviewCursor(d||t)}let l=this.files[i]?.dataURL||await rp(t),s=z(o,{fileId:i},!1);return new Promise(async(c,d)=>{try{this.files={...this.files,[i]:{mimeType:n,id:i,dataURL:l,created:Date.now(),lastRetrieved:Date.now()}};let m=this.imageCache.get(i);m||(this.addNewImagesToImageCache(),await this.updateImageCache([s])),m?.image instanceof Promise&&await m.image,this.state.pendingImageElementId!==s.id&&this.state.draggingElement?.id!==s.id&&this.initializeImageDimensions(s,!0),c(s)}catch(m){console.error(m),d(new Error(b("errors.imageInsertError")))}finally{r||zo(this.interactiveCanvas)}})};insertImageElement=async(t,o,r)=>{if(!this.isToolSupported("image")){this.setState({errorMessage:b("errors.imageToolNotSupported")});return}this.scene.addNewElement(t);try{return await this.initializeImage({imageFile:o,imageElement:t,showCursorImagePreview:r})}catch(n){return z(t,{isDeleted:!0}),this.actionManager.executeAction(Zo),this.setState({errorMessage:n.message||b("errors.imageInsertError")}),null}};setImagePreviewCursor=async t=>{let r;try{r=await Ac(t,{maxWidthOrHeight:96})}catch(i){throw i.cause==="UNSUPPORTED"?new Error(b("errors.unsupportedFileType")):i}let n=await rp(r);if(t.type===J.svg){let i=await kf(n),a=Math.min(i.height,96),l=a*(i.width/i.height);l>96&&(l=96,a=l*(i.height/i.width));let s=document.createElement("canvas");s.height=a,s.width=l,s.getContext("2d").drawImage(i,0,0,l,a),n=s.toDataURL(J.svg)}this.state.pendingImageElementId&&Ve(this.interactiveCanvas,`url(${n}) 4 4, auto`)};onImageAction=async({insertOnCanvasDirectly:t})=>{try{let o=this.state.width/2+this.state.offsetLeft,r=this.state.height/2+this.state.offsetTop,{x:n,y:i}=$e({clientX:o,clientY:r},this.state),a=await Fl({description:"Image",extensions:Object.keys(Gs)}),l=this.createImageElement({sceneX:n,sceneY:i,addToFrameUnderCursor:!1});t?(this.insertImageElement(l,a),this.initializeImageDimensions(l),this.setState({selectedElementIds:Oe({[l.id]:!0},this.state)},()=>{this.actionManager.executeAction(Zo)})):this.setState({pendingImageElementId:l.id},()=>{this.insertImageElement(l,a,!0)})}catch(o){o.name!=="AbortError"?console.error(o):console.warn(o),this.setState({pendingImageElementId:null,editingElement:null,activeTool:Qe(this.state,{type:"selection"})},()=>{this.actionManager.executeAction(Zo)})}};initializeImageDimensions=(t,o=!1)=>{let r=mo(t)&&this.imageCache.get(t.fileId)?.image;if(!r||r instanceof Promise){if(t.width<kn/this.state.zoom.value&&t.height<kn/this.state.zoom.value){let n=100/this.state.zoom.value;z(t,{x:t.x-n/2,y:t.y-n/2,width:n,height:n})}return}if(o||t.width<kn/this.state.zoom.value&&t.height<kn/this.state.zoom.value){let n=Math.max(this.state.height-120,160),i=Math.min(n,Math.floor(this.state.height*.5)/this.state.zoom.value),a=Math.min(r.naturalHeight,i),l=a*(r.naturalWidth/r.naturalHeight),s=t.x+t.width/2-l/2,c=t.y+t.height/2-a/2;z(t,{x:s,y:c,width:l,height:a})}};updateImageCache=async(t,o=this.files)=>{let{updatedFiles:r,erroredFiles:n}=await lp({imageCache:this.imageCache,fileIds:t.map(i=>i.fileId),files:o});if(r.size||n.size)for(let i of t)r.has(i.fileId)&&Me.delete(i);return n.size&&this.scene.replaceAllElements(this.scene.getElementsIncludingDeleted().map(i=>mo(i)&&n.has(i.fileId)?ae(i,{status:"error"}):i)),{updatedFiles:r,erroredFiles:n}};addNewImagesToImageCache=async(t=sp(this.scene.getNonDeletedElements()),o=this.files)=>{let r=t.filter(n=>!n.isDeleted&&!this.imageCache.has(n.fileId));if(r.length){let{updatedFiles:n}=await this.updateImageCache(r,o);n.size&&this.scene.informMutation()}};scheduleImageRefresh=B9(()=>{this.addNewImagesToImageCache()},j0);updateBindingEnabledOnPointerMove=t=>{let o=v2(t);this.state.isBindingEnabled!==o&&this.setState({isBindingEnabled:o})};maybeSuggestBindingAtCursor=t=>{let o=en(t,this.scene.getNonDeletedElements(),this.scene.getNonDeletedElementsMap());this.setState({suggestedBindings:o!=null?[o]:[]})};maybeSuggestBindingsForLinearElementAtCoords=(t,o,r)=>{if(!o.length)return;let n=o.reduce((i,a)=>{let l=en(a,this.scene.getNonDeletedElements(),this.scene.getNonDeletedElementsMap());return l!=null&&!jh(t,r?.id,l)&&i.push(l),i},[]);this.setState({suggestedBindings:n})};maybeSuggestBindingForAll(t){if(t.length>50)return;let o=C2(t,this.scene.getNonDeletedElements(),this.scene.getNonDeletedElementsMap());this.setState({suggestedBindings:o})}clearSelection(t){this.setState(o=>({selectedElementIds:Oe({},o),activeEmbeddable:null,selectedGroupIds:{},editingGroupId:o.editingGroupId&&t!=null&&Ta(t,o.editingGroupId)?o.editingGroupId:null})),this.setState({selectedElementIds:Oe({},this.state),activeEmbeddable:null,previousSelectedElementIds:this.state.selectedElementIds})}handleInteractiveCanvasRef=t=>{t!==null?(this.interactiveCanvas=t,this.interactiveCanvas.addEventListener("wheel",this.handleWheel),this.interactiveCanvas.addEventListener("touchstart",this.onTouchStart),this.interactiveCanvas.addEventListener("touchend",this.onTouchEnd)):(this.interactiveCanvas?.removeEventListener("wheel",this.handleWheel),this.interactiveCanvas?.removeEventListener("touchstart",this.onTouchStart),this.interactiveCanvas?.removeEventListener("touchend",this.onTouchEnd))};handleAppOnDrop=async t=>{let{file:o,fileHandle:r}=await ww(t),{x:n,y:i}=$e(t,this.state);try{if(Ci(o)&&this.isToolSupported("image")){if(o?.type===J.png||o?.type===J.svg)try{let s=await Wl(o,this.state,this.scene.getElementsIncludingDeleted(),r);this.syncActionResult({...s,appState:{...s.appState||this.state,isLoading:!1},replaceFiles:!0,commitToHistory:!0});return}catch(s){if(s.name!=="EncodingError")throw new Error(b("alerts.couldNotLoadInvalidFile"))}let l=this.createImageElement({sceneX:n,sceneY:i});this.insertImageElement(l,o),this.initializeImageDimensions(l),this.setState({selectedElementIds:Oe({[l.id]:!0},this.state)});return}}catch(l){return this.setState({isLoading:!1,errorMessage:l.message})}let a=t.dataTransfer.getData(J.excalidrawlib);if(a&&typeof a=="string"){try{let l=vf(a);this.addElementsFromPasteOrLibrary({elements:Xu(l),position:t,files:null})}catch(l){this.setState({errorMessage:l.message})}return}if(o&&await this.loadFileToCanvas(o,r),t.dataTransfer?.types?.includes("text/plain")){let l=t.dataTransfer?.getData("text");if(l&&Bl(l,this.props.validateEmbeddable)&&(/^(http|https):\/\/[^\s/$.?#].[^\s]*$/.test(l)||Un(l)?.type==="video")){let s=this.insertEmbeddableElement({sceneX:n,sceneY:i,link:po(l)});s&&this.setState({selectedElementIds:{[s.id]:!0}})}}};loadFileToCanvas=async(t,o)=>{t=await Mc(t);try{let r;try{r=await op(t,this.state,this.scene.getElementsIncludingDeleted(),o)}catch(n){let i=n instanceof Or;if(i&&n.code==="IMAGE_NOT_CONTAINS_SCENE_DATA"&&!this.isToolSupported("image")){this.setState({isLoading:!1,errorMessage:b("errors.imageToolNotSupported")});return}let a=i?b("alerts.cannotRestoreFromImage"):b("alerts.couldNotLoadInvalidFile");this.setState({isLoading:!1,errorMessage:a})}if(!r)return;r.type===J.excalidraw?(this.setState({isLoading:!0}),this.syncActionResult({...r.data,appState:{...r.data.appState||this.state,isLoading:!1},replaceFiles:!0,commitToHistory:!0})):r.type===J.excalidrawlib&&await this.library.updateLibrary({libraryItems:t,merge:!0,openLibraryMenu:!0}).catch(n=>{console.error(n),this.setState({errorMessage:b("errors.importLibraryError")})})}catch(r){this.setState({isLoading:!1,errorMessage:r.message})}};handleCanvasContextMenu=t=>{if(t.preventDefault(),this.props.interactive===!1||("pointerType"in t.nativeEvent&&t.nativeEvent.pointerType==="touch"||"pointerType"in t.nativeEvent&&t.nativeEvent.pointerType==="pen"&&t.button!==ai.SECONDARY)&&this.state.activeTool.type!=="selection")return;let{x:o,y:r}=$e(t,this.state),n=this.getElementAtPosition(o,r,{preferSelected:!0,includeLockedElements:!0}),i=this.scene.getSelectedElements(this.state),a=this.isHittingCommonBoundingBoxOfSelectedElements({x:o,y:r},i),l=n||a?"element":"canvas",s=this.excalidrawContainerRef.current,{top:c,left:d}=s.getBoundingClientRect(),m=t.clientX-d,p=t.clientY-c;we("contextMenu","openContextMenu",l),this.setState({...n&&!this.state.selectedElementIds[n.id]?{...this.state,...to({editingGroupId:this.state.editingGroupId,selectedElementIds:{[n.id]:!0}},this.scene.getNonDeletedElements(),this.state,this),selectedLinearElement:ne(n)?new $(n):null}:this.state,showHyperlinkPopup:!1},()=>{this.setState({contextMenu:{top:p,left:m,items:this.getContextMenuItems(l)}})})};maybeDragNewGenericElement=(t,o)=>{let r=this.state.draggingElement,n=t.lastCoords;if(r)if(r.type==="selection"&&this.state.activeTool.type!=="eraser")Hp(r,this.state.activeTool.type,t.origin.x,t.origin.y,n.x,n.y,Nt(t.origin.x,n.x),Nt(t.origin.y,n.y),kl(o),_m(o));else{let[i,a]=At(n.x,n.y,o[I.CTRL_OR_CMD]?null:this.state.gridSize),l=mo(r)&&this.imageCache.get(r.fileId)?.image,s=l&&!(l instanceof Promise)?l.width/l.height:null;this.maybeCacheReferenceSnapPoints(o,[r]);let{snapOffset:c,snapLines:d}=ZS(r,this.state,o,{x:t.originInGrid.x+(this.state.originSnapOffset?.x??0),y:t.originInGrid.y+(this.state.originSnapOffset?.y??0)},{x:i-t.originInGrid.x,y:a-t.originInGrid.y},this.scene.getNonDeletedElementsMap());i+=c.x,a+=c.y,this.setState({snapLines:d}),Hp(r,this.state.activeTool.type,t.originInGrid.x,t.originInGrid.y,i,a,Nt(t.originInGrid.x,i),Nt(t.originInGrid.y,a),nr(r)?!kl(o):kl(o),_m(o),s,this.state.originSnapOffset),this.maybeSuggestBindingForAll([r]),(this.state.activeTool.type===wt.frame||this.state.activeTool.type===wt.magicframe)&&this.setState({elementsToHighlight:Jl(this.scene.getNonDeletedElements(),r,this.state,this.scene.getNonDeletedElementsMap())})}};maybeHandleResize=(t,o)=>{let r=this.scene.getSelectedElements(this.state),n=r.filter(d=>Q(d)),i=t.resize.handleType;if(n.length>0&&i==="rotation")return!1;this.setState({isResizing:i&&i!=="rotation",isRotating:i==="rotation",activeEmbeddable:null});let a=t.lastCoords,[l,s]=At(a.x-t.resize.offset.x,a.y-t.resize.offset.y,o[I.CTRL_OR_CMD]?null:this.state.gridSize),c=new Map;if(n.forEach(d=>{Vo(this.scene.getNonDeletedElements(),d.id).forEach(p=>{c.set(d.id+p.id,{x:p.x-d.x,y:p.y-d.y})})}),!this.state.selectedElementsAreBeingDragged){let[d,m]=At(a.x,a.y,o[I.CTRL_OR_CMD]?null:this.state.gridSize),p={x:d-t.originInGrid.x,y:m-t.originInGrid.y},u=[...t.originalElements.values()];this.maybeCacheReferenceSnapPoints(o,r);let{snapOffset:g,snapLines:x}=XS(r,de(u,this.state),this.state,o,p,i);l+=g.x,s+=g.y,this.setState({snapLines:x})}if($f(t.originalElements,i,r,this.scene.getElementsMapIncludingDeleted(),ba(o),_m(o),r.length===1&&nr(r[0])?!kl(o):kl(o),l,s,t.resize.center.x,t.resize.center.y)){this.maybeSuggestBindingForAll(r);let d=new Set;return n.forEach(m=>{Jl(this.scene.getNonDeletedElements(),m,this.state,this.scene.getNonDeletedElementsMap()).forEach(p=>d.add(p))}),this.setState({elementsToHighlight:[...d]}),!0}return!1};getContextMenuItems=t=>{let o=[];return o.push(ud,pd),t==="canvas"?this.state.viewModeEnabled?[...o,hd,Qa,r0,Qn]:[dx,ho,ud,pd,gd,ho,gu,c5,ho,hd,Hu,Qa,r0,Qn]:(o.push(gd),this.state.viewModeEnabled?[Ja,...o]:[md,Ja,dx,FS,HS,ho,...o,ho,Lu,_u,ho,Pu,zu,Gu,QT,Du,ho,Ou,ho,cu,du,mu,pu,ho,Bu,Fu,ho,bg,bs,hu,Wu,ho,as])};handleWheel=ct(t=>{if(t.preventDefault(),Kd||this.props.interactive===!1)return;let{deltaX:o,deltaY:r}=t;if(t.metaKey||t.ctrlKey){let n=Math.sign(r),i=la*100,a=Math.abs(r),l=r;a>i&&(l=i*n);let s=this.state.zoom.value-l/100;s+=Math.log10(Math.max(1,this.state.zoom.value))*-n*Math.min(1,a/20),this.translateCanvas(c=>({...Zn({viewportX:this.lastViewportPosition.x,viewportY:this.lastViewportPosition.y,nextZoom:sn(s)},c),shouldCacheIgnoreZoom:!0})),this.resetShouldCacheIgnoreZoomDebounced();return}if(t.shiftKey){this.translateCanvas(({zoom:n,scrollX:i})=>({scrollX:i-(r||o)/n.value}));return}this.translateCanvas(({zoom:n,scrollX:i,scrollY:a})=>({scrollX:i-o/n.value,scrollY:a-r/n.value}))});getTextWysiwygSnappedToCenterPosition(t,o,r,n){if(n){let i=n.x+n.width/2,a=n.y+n.height/2,l=zm(n,r,this.scene.getNonDeletedElementsMap());if(l&&(i=l.x,a=l.y),Math.hypot(t-i,o-a)<$0){let{x:d,y:m}=zt({sceneX:i,sceneY:a},r);return{viewportX:d,viewportY:m,elementCenterX:i,elementCenterY:a}}}}savePointer=(t,o,r)=>{if(!t||!o)return;let{x:n,y:i}=$e({clientX:t,clientY:o},this.state);isNaN(n)||isNaN(i);let a={x:n,y:i,tool:this.state.activeTool.type==="laser"?"laser":"pointer"};this.props.onPointerUpdate?.({pointer:a,button:r,pointersMap:Fe.pointers})};resetShouldCacheIgnoreZoomDebounced=ca(()=>{this.unmounted||this.setState({shouldCacheIgnoreZoom:!1})},300);updateDOMRect=t=>{if(this.excalidrawContainerRef?.current){let o=this.excalidrawContainerRef.current,{width:r,height:n,left:i,top:a}=o.getBoundingClientRect(),{width:l,height:s,offsetTop:c,offsetLeft:d}=this.state;if(r===l&&n===s&&i===d&&a===c){t&&t();return}this.setState({width:r,height:n,offsetLeft:i,offsetTop:a},()=>{t&&t()})}};refresh=()=>{this.setState({...this.getCanvasOffsets()})};getCanvasOffsets(){if(this.excalidrawContainerRef?.current){let t=this.excalidrawContainerRef.current,{left:o,top:r}=t.getBoundingClientRect();return{offsetLeft:o,offsetTop:r}}return{offsetLeft:0,offsetTop:0}}async updateLanguage(){let t=sl.find(o=>o.code===this.props.langCode)||Vr;await Qd(t),this.setAppState({})}},F9=()=>{(C.MODE===ph.TEST||C.DEV)&&(window.h=window.h||{},Object.defineProperties(window.h,{elements:{configurable:!0,get(){return this.app?.scene.getElementsIncludingDeleted()},set(e){return this.app?.scene.replaceAllElements(e)}}}))};F9();V4=w0});var Y4=v(()=>{});var K4=v(()=>{});var $4=v(()=>{});var z9,X4,Z4=v(()=>{"use strict";f();z9=()=>{Array.prototype.at||Object.defineProperty(Array.prototype,"at",{value:function(e){if(e=Math.trunc(e)||0,e<0&&(e+=this.length),!(e<0||e>=this.length))return this[e]},writable:!0,enumerable:!1,configurable:!0}),Element.prototype.replaceChildren||(Element.prototype.replaceChildren=function(...e){this.innerHTML="",this.append(...e)})},X4=z9});var j4=v(()=>{});import G9 from"clsx";import{jsx as q4}from"react/jsx-runtime";var J4,U9,Q4=v(()=>{"use strict";f();qo();j4();Vt();J4=({children:e})=>{let{FooterCenterTunnel:t}=nt(),o=Re();return q4(t.In,{children:q4("div",{className:G9("footer-center zen-mode-transition",{"layer-ui__wrapper__footer-left--transition-bottom":o.zenModeEnabled}),children:e})})},U9=J4;J4.displayName="FooterCenter"});var ek=v(()=>{});import{jsx as ta,jsxs as ok}from"react/jsx-runtime";var W9,V9,tk,rk=v(()=>{"use strict";f();ek();W9=()=>ta("svg",{viewBox:"0 0 40 40",fill:"none",xmlns:"http://www.w3.org/2000/svg",className:"ExcalidrawLogo-icon",children:ta("path",{d:"M39.9 32.889a.326.326 0 0 0-.279-.056c-2.094-3.083-4.774-6-7.343-8.833l-.419-.472a.212.212 0 0 0-.056-.139.586.586 0 0 0-.167-.111l-.084-.083-.056-.056c-.084-.167-.28-.278-.475-.167-.782.39-1.507.973-2.206 1.528-.92.722-1.842 1.445-2.708 2.25a8.405 8.405 0 0 0-.977 1.028c-.14.194-.028.361.14.444-.615.611-1.23 1.223-1.843 1.861a.315.315 0 0 0-.084.223c0 .083.056.166.111.194l1.09.833v.028c1.535 1.528 4.244 3.611 7.12 5.861.418.334.865.667 1.284 1 .195.223.39.473.558.695.084.11.28.139.391.055.056.056.14.111.196.167a.398.398 0 0 0 .167.056.255.255 0 0 0 .224-.111.394.394 0 0 0 .055-.167c.029 0 .028.028.056.028a.318.318 0 0 0 .224-.084l5.082-5.528a.309.309 0 0 0 0-.444Zm-14.63-1.917a.485.485 0 0 0 .111.14c.586.5 1.2 1 1.843 1.555l-2.569-1.945-.251-.166c-.056-.028-.112-.084-.168-.111l-.195-.167.056-.056.055-.055.112-.111c.866-.861 2.346-2.306 3.1-3.028-.81.805-2.43 3.167-2.095 3.944Zm8.767 6.89-2.122-1.612a44.713 44.713 0 0 0-2.625-2.5c1.145.861 2.122 1.611 2.262 1.75 1.117.972 1.06.806 1.815 1.445l.921.666a1.06 1.06 0 0 1-.251.25Zm.558.416-.056-.028c.084-.055.168-.111.252-.194l-.196.222ZM1.089 5.75c.055.361.14.722.195 1.056.335 1.833.67 3.5 1.284 4.75l.252.944c.084.361.223.806.363.917 1.424 1.25 3.602 3.11 5.947 4.889a.295.295 0 0 0 .363 0s0 .027.028.027a.254.254 0 0 0 .196.084.318.318 0 0 0 .223-.084c2.988-3.305 5.221-6.027 6.813-8.305.112-.111.14-.278.14-.417.111-.111.195-.25.307-.333.111-.111.111-.306 0-.39l-.028-.027c0-.055-.028-.139-.084-.167-.698-.666-1.2-1.138-1.731-1.638-.922-.862-1.871-1.75-3.881-3.75l-.028-.028c-.028-.028-.056-.056-.112-.056-.558-.194-1.703-.389-3.127-.639C6.087 2.223 3.21 1.723.614.944c0 0-.168 0-.196.028l-.083.084c-.028.027-.056.055-.224.11h.056-.056c.028.167.028.278.084.473 0 .055.112.5.112.555l.782 3.556Zm15.496 3.278-.335-.334c.084.112.196.195.335.334Zm-3.546 4.666-.056.056c0-.028.028-.056.056-.056Zm-2.038-10c.168.167.866.834 1.033.973-.726-.334-2.54-1.167-3.379-1.445.838.167 1.983.334 2.346.472ZM1.424 2.306c.419.722.754 3.222 1.089 5.666-.196-.778-.335-1.555-.503-2.278-.251-1.277-.503-2.416-.838-3.416.056 0 .14 0 .252.028Zm-.168-.584c-.112 0-.223-.028-.307-.028 0-.027 0-.055-.028-.055.14 0 .223.028.335.083Zm-1.089.222c0-.027 0-.027 0 0ZM39.453 1.333c.028-.11-.558-.61-.363-.639.42-.027.42-.666 0-.666-.558.028-1.144.166-1.675.25-.977.194-1.982.389-2.96.61-2.205.473-4.383.973-6.561 1.557-.67.194-1.424.333-2.066.666-.224.111-.196.333-.084.472-.056.028-.084.028-.14.056-.195.028-.363.056-.558.083-.168.028-.252.167-.224.334 0 .027.028.083.028.11-1.173 1.556-2.485 3.195-3.909 4.945-1.396 1.611-2.876 3.306-4.356 5.056-4.719 5.5-10.052 11.75-15.943 17.25a.268.268 0 0 0 0 .389c.028.027.056.055.084.055-.084.084-.168.14-.252.222-.056.056-.084.111-.084.167a.605.605 0 0 0-.111.139c-.112.111-.112.305.028.389.111.11.307.11.39-.028.029-.028.029-.056.056-.056a.44.44 0 0 1 .615 0c.335.362.67.723.977 1.028l-.698-.583c-.112-.111-.307-.083-.39.028-.113.11-.085.305.027.389l7.427 6.194c.056.056.112.056.196.056s.14-.028.195-.084l.168-.166c.028.027.083.027.111.027.084 0 .14-.027.196-.083 10.052-10.055 18.15-17.639 27.42-24.417.083-.055.111-.166.111-.25.112 0 .196-.083.251-.194 1.704-5.194 2.039-9.806 2.15-12.083v-.028c0-.028.028-.056.028-.083.028-.056.028-.084.028-.084a1.626 1.626 0 0 0-.111-1.028ZM21.472 9.5c.446-.5.893-1.028 1.34-1.5-2.876 3.778-7.65 9.583-14.408 16.5 4.607-5.083 9.242-10.333 13.068-15ZM5.193 35.778h.084-.084Zm3.462 3.194c-.027-.028-.027-.028 0-.028v.028Zm4.16-3.583c.224-.25.448-.472.699-.722 0 0 0 .027.028.027-.252.223-.475.445-.726.695Zm1.146-1.111c.14-.14.279-.334.446-.5l.028-.028c1.648-1.694 3.351-3.389 5.082-5.111l.028-.028c.419-.333.921-.694 1.368-1.028a379.003 379.003 0 0 0-6.952 6.695ZM24.794 6.472c-.921 1.195-1.954 2.778-2.82 4.028-2.736 3.944-11.532 13.583-11.727 13.75a1976.983 1976.983 0 0 1-8.042 7.639l-.167.167c-.14-.167-.14-.417.028-.556C14.49 19.861 22.03 10.167 25.074 5.917c-.084.194-.14.36-.28.555Zm4.83 5.695c-1.116-.64-1.646-1.64-1.34-2.611l.084-.334c.028-.083.084-.194.14-.277.307-.5.754-.917 1.257-1.167.027 0 .055 0 .083-.028-.028-.056-.028-.139-.028-.222.028-.167.14-.278.335-.278.335 0 1.369.306 1.76.639.111.083.223.194.335.305.14.167.363.445.474.667.056.028.112.306.196.445.056.222.111.472.084.694-.028.028 0 .194-.028.194a2.668 2.668 0 0 1-.363 1.028c-.028.028-.028.056-.056.084l-.028.027c-.14.223-.335.417-.53.556-.643.444-1.369.583-2.095.389 0 0-.195-.084-.28-.111Zm8.154-.834a39.098 39.098 0 0 1-.893 3.167c0 .028-.028.083 0 .111-.056 0-.084.028-.14.056-2.206 1.61-4.356 3.305-6.506 5.028 1.843-1.64 3.686-3.306 5.613-4.945.558-.5.949-1.139 1.06-1.861l.28-1.667v-.055c.14-.334.67-.195.586.166Z",fill:"currentColor"})}),V9=()=>ok("svg",{viewBox:"0 0 450 55",xmlns:"http://www.w3.org/2000/svg",fill:"none",className:"ExcalidrawLogo-text",children:[ta("path",{d:"M429.27 96.74c2.47-1.39 4.78-3.02 6.83-4.95 1.43-1.35 2.73-2.86 3.81-4.51-.66.9-1.4 1.77-2.23 2.59-2.91 2.84-5.72 5.09-8.42 6.87h.01ZM343.6 69.36c.33 3.13.58 6.27.79 9.4.09 1.37.18 2.75.25 4.12-.12-4.46-.27-8.93-.5-13.39-.11-2.08-.24-4.16-.4-6.24-.06 1.79-.11 3.85-.13 6.11h-.01ZM378.47 98.34c.01-.37.07-1.13.01-6.51-.11 1.9-.22 3.81-.31 5.71-.07 1.42-.22 2.91-.16 4.35.39.03.78.07 1.17.1-.92-.85-.76-2.01-.72-3.66l.01.01ZM344.09 86.12c-.09-2.41-.22-4.83-.39-7.24v12.21c.15-.05.32-.09.47-.14.05-1.61-.03-3.23-.09-4.83h.01ZM440.69 66.79c-.22-.34-.45-.67-.69-.99-3.71-4.87-9.91-7.14-15.65-8.55-1.05-.26-2.12-.49-3.18-.71 2.29.59 4.48 1.26 6.64 2.02 7.19 2.54 10.57 5.41 12.88 8.23ZM305.09 72.46l1.2 3.6c.84 2.53 1.67 5.06 2.46 7.61.24.78.5 1.57.73 2.36.22-.04.44-.08.67-.12a776.9 776.9 0 0 1-5.01-13.57c-.02.04-.03.09-.05.13v-.01ZM345.49 90.25v.31c1.48-.42 3.05-.83 4.66-1.2-1.56.25-3.12.52-4.66.89ZM371.02 90.22c0-.57-.04-1.14-.11-1.71-.06-.02-.12-.04-.19-.05-.21-.05-.43-.08-.65-.11.42.16.74.88.95 1.87ZM398.93 54.23c-.13 0-.27-.01-.4-.02l.03.4c.11-.15.23-.27.37-.38ZM401.57 62.28v-.15c-1.22-.24-2.86-.61-3.23-1.25-.09-.15-.18-.51-.27-.98-.09.37-.2.73-.33 1.09 1.24.56 2.52.98 3.83 1.29ZM421.73 88.68c-2.97 1.65-6.28 3.12-9.69 3.68v.18c4.72-.14 11.63-3.85 16.33-8.38-2.04 1.75-4.33 3.24-6.63 4.53l-.01-.01ZM411.28 80.92c-.05-1.2-.09-2.4-.15-3.6-.21 5.66-.46 11.38-.47 14.51.24-.02.48-.04.71-.07.15-3.61.05-7.23-.09-10.83v-.01Z",transform:"translate(-144.023 -51.76)"}),ta("path",{d:"M425.38 67.41c-3.5-1.45-7.19-2.57-14.06-3.62.09 1.97.06 4.88-.03 8.12.03.04.06.09.06.15.19 1.36.28 2.73.37 4.1.25 3.77.39 7.55.41 11.33 0 1.38-.01 2.76-.07 4.13 1.4-.25 2.78-.65 4.12-1.15 4.07-1.5 7.94-3.78 11.28-6.54 2.33-1.92 5.13-4.49 5.88-7.58.63-3.53-2.45-6.68-7.97-8.96l.01.02ZM411.35 92.53v-.06l-.34.03c.11.01.22.03.34.03ZM314.26 64.06c-.23-.59-.47-1.17-.7-1.75.57 1.62 1.11 3.25 1.6 4.9l.15.54 2.35 6.05c.32.82.66 1.64.98 2.46-1.38-4.1-2.83-8.17-4.39-12.2h.01ZM156.82 103.07c-.18.13-.38.23-.58.33 1.32-.03 2.66-.2 3.93-.34.86-.09 1.72-.22 2.58-.33-2.12.1-4.12.17-5.94.34h.01ZM210.14 68.88s.03.04.05.07c.18-.31.39-.64.58-.96-.21.3-.42.6-.64.89h.01ZM201.65 82.8c-.5.77-1.02 1.56-1.49 2.37 1.11-1.55 2.21-3.1 3.2-4.59-.23.23-.49.51-.75.79-.32.47-.65.95-.96 1.43ZM194.03 98.66c-.33-.4-.65-.84-1.05-1.17-.24-.2-.07-.49.17-.56-.23-.26-.42-.5-.63-.75 1.51-2.55 3.93-5.87 6.4-9.28-.17-.08-.29-.28-.2-.49.04-.09.09-.17.13-.26-1.21 1.78-2.42 3.55-3.61 5.33-.87 1.31-1.74 2.64-2.54 4-.29.5-.63 1.04-.87 1.61.81.65 1.63 1.27 2.47 1.88-.09-.11-.18-.21-.27-.32v.01ZM307.79 82.93c-1-3.17-2.05-6.32-3.1-9.48-1.62 4.08-3.69 9.17-6.16 15.19 3.32-1.04 6.77-1.87 10.27-2.5-.32-1.08-.67-2.15-1.01-3.21ZM149.5 80.7c.05-1.71.04-3.43 0-5.14-.1 2.26-.16 4.51-.22 6.77-.02.73-.03 1.46-.04 2.19.14-1.27.2-2.55.24-3.82h.02ZM228.98 98.3c.39 1.25.91 3.03.94 3.91.06-.03.12-.07.17-.1.08-1.29-.55-2.65-1.11-3.81ZM307.72 53.36c.81.5 1.53 1.04 2.07 1.49-.38-.8-.78-1.58-1.21-2.35-.17.03-.34.06-.51.11-.43.12-.86.26-1.29.41.35-.01.53.1.94.34ZM283.69 96.14c3.91-7.25 6.89-13.35 8.88-18.15l1.1-2.66c-1.27 2.64-2.56 5.27-3.83 7.9-1.53 3.15-3.06 6.31-4.58 9.47-.87 1.81-1.76 3.62-2.54 5.47.04.02.07.04.11.07.05.05.1.09.15.14.05-.73.27-1.48.71-2.24ZM289.92 103.23s-.04.01-.05.03c0-.02.04-.03.05-.04.05-.05.11-.1.16-.15l.21-.21c-.55 0-1.5-.27-2.55-.72.4.26.8.51 1.22.74.24.13.48.26.73.37.05.02.1.03.14.05a.27.27 0 0 1 .08-.07h.01ZM269.23 68.49c-.39-.19-.82-.48-1.33-.87-3.06-1.56-6.31-2.78-9.36-2.35-3.5.49-5.7 1.11-7.74 2.44 5.71-2.6 12.82-2.07 18.44.79l-.01-.01ZM177.87 53.69l1.06.03c-.96-.22-2-.25-2.89-.3-4.95-.26-9.99.33-14.86 1.19-2.44.43-4.88.95-7.28 1.59 9.09-1.76 15.69-2.77 23.97-2.51ZM219.85 55.51c-.18.12-.36.27-.56.45-.45.53-.86 1.11-1.26 1.66-1.91 2.61-3.71 5.31-5.57 7.95l-.12.18 8.05-10.11c-.18-.05-.36-.1-.55-.13h.01ZM510.71 54.1c.12-.15.29-.3.53-.45.69-.4 3.72-.63 5.87-.74-.36-.02-.73-.04-1.09-.05-1.84-.03-3.67.09-5.49.35.05.3.12.59.18.88v.01ZM510.76 86.02c1.37-3.07 2.49-6.27 3.57-9.46.55-1.64 1.12-3.3 1.6-4.97-1.59 4.01-3.67 9.14-6.2 15.3.24-.08.5-.14.74-.22.1-.22.19-.44.29-.65ZM566.95 75.76c.11-.02.23.03.31.11-.05-.13-.09-.26-.14-.39-.05.09-.11.18-.17.28ZM511.33 86.41c3.08-.89 6.24-1.62 9.46-2.14-1.51-3.98-2.98-7.96-4.39-11.87-.05.15-.09.31-.14.46-1.02 3.32-2.15 6.61-3.39 9.85-.48 1.25-.98 2.49-1.53 3.7h-.01ZM578.24 74.45c.11-.44.23-.87.35-1.31-.31.7-.64 1.39-.97 2.08.09.21.19.4.28.61.12-.46.23-.92.35-1.38h-.01ZM520.62 53.11c-.09 0-.18-.01-.28-.02.38.34.29 1.08.93 2.53l6.65 17.15c2.2 5.68 4.69 11.36 7.41 16.87l1.06 2.17c-2.95-7.05-5.92-14.08-8.87-21.13-1.58-3.79-3.16-7.59-4.7-11.4-.78-1.92-1.73-3.89-2.25-5.91-.03-.1 0-.19.04-.26h.01ZM578.78 77.87c1.45-5.77 3.07-10.43 3.58-13.36.05-.34.16-.88.31-1.55-.67 1.79-1.37 3.56-2.08 5.33-.12.43-.23.86-.35 1.29-.65 2.43-1.29 4.86-1.9 7.3.14.33.29.65.43 1l.01-.01ZM545.3 94.66c.02-.44.03-.83.05-1.12.02-1.01.05-2.02.11-3.02.03-6.66-.46-14.33-1.46-22.8-.13-.42-.27-1.24-.56-2.89 0-.02 0-.04-.01-.06.62 6.61.95 13.25 1.32 19.87.17 3.08.33 6.16.52 9.23.02.25.03.52.04.78l-.01.01ZM580.77 102.81c.13.2.27.38.37.49.27-.11.53-.22.8-.32-.43.09-.82.05-1.17-.16v-.01ZM530.48 104.07h.33c-.36-.13-.71-.32-1.04-.56.14.24.3.47.45.7.06-.08.14-.13.26-.13v-.01ZM542.63 58.82c.06.23.11.47.15.71.14-.33.36-.62.7-.86-.28.05-.57.11-.85.15ZM583.81 57.87c.15-.7.29-1.41.42-2.11-.14.45-.28.9-.42 1.34-.46 1.44-.89 2.89-1.31 4.34.44-1.19.88-2.37 1.31-3.57ZM523.62 91.48c-4.66 1.17-9.05 2.89-14.02 5.27 4.65-1.84 9.48-3.29 14.28-4.63-.09-.22-.17-.41-.26-.64ZM460.64 78.3c-.04-2.9-.11-5.81-.28-8.71-.1-1.68-.17-3.43-.5-5.09-.07.02-.14.03-.2.05.3 6.54.45 12.17.51 17.12.17-.07.34-.14.51-.2 0-1.06-.01-2.11-.03-3.17h-.01ZM470.63 63.24c-3.38-.26-6.81.32-10.1 1.1.41 2.01.47 4.14.57 6.18.18 3.55.25 7.11.27 10.67 3.31-1.38 6.5-3.12 9.3-5.35 1.96-1.56 3.86-3.41 5.02-5.66.73-1.41 1.19-3.22.26-4.65-1.09-1.7-3.46-2.14-5.32-2.29ZM460.29 63.68c1-.24 2.01-.46 3.04-.65-1.15.16-2.37.38-3.71.69v.13c.07-.02.15-.04.22-.05.11-.13.3-.18.45-.11v-.01ZM457.24 100.96c.43-.03.86-.07 1.29-.11.14-.49.27-.99.38-1.49-.44.7-1 1.23-1.67 1.6ZM482.88 104.98c-.18.23-.36.38-.55.47.14.09.27.19.4.28a70.76 70.76 0 0 0 4.37-4.63c.76-.89 1.52-1.81 2.19-2.77-.3-.27-.61-.53-.92-.79-.07 1.94-4.62 6.32-5.49 7.45v-.01Z",transform:"translate(-144.023 -51.76)"}),ta("path",{d:"M474.36 63.31c-.4-.16-.84-.27-1.29-.37 1.56.42 3.08 1.22 3.76 2.74.62 1.4.32 2.95-.28 4.32.7-1.22.94-2.34.74-3.47-.24-1.33-1.19-2.54-2.93-3.21v-.01ZM477.34 89.18c-1.2-.81-2.4-1.62-3.6-2.42-.14.1-.26.19-.4.29 1.4.67 2.73 1.39 4 2.13ZM465.88 93.85c.37.25.74.5 1.1.75.46.32.92.65 1.38.97-1.57-1.2-2.01-1.61-2.49-1.72h.01ZM574.92 90.06c-2.28-5.21-4.93-11.13-5.67-12.26-.1-.15-1.57-3.01-1.63-3.08 0 0-.01.02-.02.02.4 1.37 1.09 2.69 1.65 3.99 2.14 4.95 4.36 9.86 6.67 14.73.6 1.26 1.21 2.52 1.83 3.78-.75-2.01-1.64-4.45-2.83-7.18ZM448.73 65.29c.1.2.22.38.34.57.22-.02.43-.06.65-.08v-.08c-.14-.05-.25 0-.99-.41ZM460.16 94.81c-.02.31-.06.59-.1.89-.03 1.71-.33 3.43-.79 5.07.15-.02.3-.03.45-.05.01-.04.02-.08.03-.11.09-.34.15-.69.2-1.03.17-1.07.25-2.16.33-3.24.05-.69.08-1.39.12-2.08-.27.1-.27.26-.24.57v-.02Z",transform:"translate(-144.023 -51.76)"}),ta("path",{d:"m328.67 98.12-3.22-6.58c-1.29-2.63-2.53-5.29-3.72-7.97-.25-.85-.52-1.69-.79-2.53-.81-2.57-1.67-5.12-2.55-7.67-1.92-5.53-3.9-11.08-6.32-16.41-.72-1.58-1.46-3.44-2.63-4.79-.03-.17-.16-.29-.34-.36a.282.282 0 0 0-.23-.04c-.06-.01-.12 0-.18.01-.74.06-1.5.38-2.19.61-2.22.77-4.4 1.64-6.63 2.38-.03-.08-.06-.16-.09-.25-.15-.42-.82-.24-.67.19.03.09.07.19.1.28l-.18.06c-.36.11-.28.6 0 .68.18 1.18.63 2.36.98 3.49.03.09.06.17.08.26-.08.23-.17.46-.24.64-.37.98-.79 1.94-1.21 2.9-1.27 2.89-2.62 5.75-3.98 8.6-3.18 6.67-6.44 13.31-9.64 19.97-1.08 2.25-2.2 4.5-3.15 6.81-.13.32.24.5.5.37 1.34 1.33 2.84 2.5 4.4 3.57.65.44 1.31.87 2.01 1.24.4.22.86.48 1.33.5.24.01.35-.19.33-.37.11-.1.21-.21.28-.28.41-.41.81-.84 1.2-1.26.85-.92 1.69-1.87 2.5-2.84 6.31-2.34 12.6-4.31 18.71-5.84 2.14 5.3 3.43 8.43 3.97 9.58.55 1.05 1.15 1.88 1.82 2.52 1.32.56 6.96-.03 9.23-1.96.87-1.28 1.19-2.67.93-4.15-.09-.5-.22-.95-.4-1.33l-.01-.03Zm-20.09-45.61c.43.77.83 1.56 1.21 2.35-.54-.45-1.27-.99-2.07-1.49-.42-.24-.6-.35-.94-.34.43-.15.85-.29 1.29-.41.17-.05.34-.08.51-.11Zm-25.86 45.66c.78-1.85 1.67-3.66 2.54-5.47 1.51-3.16 3.05-6.31 4.58-9.47 1.28-2.63 2.56-5.26 3.83-7.9l-1.1 2.66c-1.99 4.79-4.97 10.9-8.88 18.15-.43.76-.66 1.51-.71 2.24-.05-.05-.1-.09-.15-.14a.259.259 0 0 0-.11-.07Zm6.24 4.71c-.42-.23-.82-.48-1.22-.74 1.05.45 2 .72 2.55.72l-.21.21c-.05.05-.11.1-.16.15-.01.01-.04.03-.05.04 0-.02.03-.02.05-.03a.27.27 0 0 0-.08.07c-.05-.02-.1-.03-.14-.05-.25-.1-.49-.24-.73-.37h-.01Zm15.73-29.43c1.05 3.15 2.1 6.31 3.1 9.48.34 1.06.69 2.13 1.01 3.21-3.5.63-6.95 1.46-10.27 2.5 2.48-6.03 4.54-11.11 6.16-15.19Zm4.79 12.57c-.23-.79-.49-1.58-.73-2.36-.79-2.54-1.63-5.08-2.46-7.61l-1.2-3.6c.02-.04.04-.09.05-.13 1.6 4.45 3.28 9 5.01 13.57l-.67.12v.01Zm5.83-18.27-.15-.54c-.49-1.64-1.03-3.28-1.6-4.9.23.58.47 1.17.7 1.75 1.56 4.03 3.01 8.1 4.39 12.2-.33-.82-.67-1.64-.98-2.46l-2.35-6.05h-.01ZM390.43 79.37c-.13-10.43-.22-17.5-.24-19.97-.24-1.6.21-2.88-.65-3.65-.14-.13-.32-.23-.52-.32h.03c.45 0 .45-.69 0-.7-1.75-.03-3.5-.04-5.25-.14-1.38-.08-2.76-.21-4.15-.31-.07 0-.12.01-.17.04-.21-.07-.47.03-.45.31l.03.45c-.11.14-.19.3-.22.5-.21 1.26-.32 13.67-.36 23.59-.32 5.79-.67 11.57-.97 17.36-.09 1.73-.29 3.54-.21 5.3-.39.02-.38.64.04.69v.12c.05.44.74.45.7 0v-.06c1.1.09 2.2.21 3.3.3 1.14.19 2.44.2 3.29.17 1.73-.05 2.92-.05 3.8-.37.45-.05.9-.11 1.35-.17.44-.06.25-.73-.19-.67h-.01c.24-.32.45-.72.62-1.25.66-1.84.41-6.36.34-11.33l-.13-9.9.02.01Zm-12.26 18.17c.09-1.91.2-3.81.31-5.71.06 5.38 0 6.14-.01 6.51-.05 1.65-.21 2.81.72 3.66-.39-.04-.78-.07-1.17-.1-.06-1.44.09-2.93.16-4.35l-.01-.01ZM588.97 53.85c-2.06-.25-3.17-.51-3.76-.6a.3.3 0 0 1 .04-.08c.22-.39-.39-.75-.6-.35-.56 1.02-.9 2.19-1.26 3.29-.61 1.88-1.17 3.78-1.72 5.68-.63 2.19-1.24 4.39-1.83 6.59-.81 2.03-1.67 4.05-2.61 6.03-1.7-3.64-3.11-6.04-4.03-7.57-2.26-3.74-2.85-5.48-3.57-6.08l.31-.09c.43-.12.25-.8-.19-.67-1.06.3-2.12.6-3.17.95-.93.32-1.85.69-2.76 1.07-.13.05-.19.16-.22.27-.04.02-.08.05-.11.07-.04-.06-.07-.12-.11-.18a.354.354 0 0 0-.48-.12c-.16.09-.22.32-.13.48l.33.54c0 .09.02.18.06.28.51 1.16.78 1.38.72 1.47-2.42 3.44-5.41 7.86-6.2 9.1-1.27 1.97-2.01 3.14-2.45 3.84l-.91-6.56-.43-4.1c-.19-1.85-.37-3.23-.53-4.13-.19-1.1-.3-2.15-.45-3.16-.2-1.36-.29-2.06-.47-2.42h.04c.45.02.45-.68 0-.7-3.43-.16-6.81.94-10.17 1.48-.24-.22-.73-.04-.58.32.24.59.33 1.25.43 1.87.17 1.06.29 2.13.4 3.2.32 3.09.53 6.2.74 9.3.44 6.75.77 13.51 1.17 20.26.11 1.95.13 3.96.46 5.89.05.3.37.31.55.14.74 1.71 2.87 1.27 6.13 1.27 1.34 0 2.39.04 2.99-.11.02.32.48.53.63.18 3.61-8.26 7.41-16.46 12.05-24.2.03-.05.04-.1.05-.15.3.73.64 1.45.94 2.16.97 2.26 1.97 4.52 2.98 6.76 2.26 5.03 4.54 10.07 7.09 14.96.47.9.94 1.79 1.47 2.65.2.32.4.67.66.96-.18.25 0 .68.34.54.91-.38 1.82-.75 2.76-1.07 1.04-.35 2.11-.65 3.17-.95.39-.11.28-.66-.07-.68.62-.4.95-.96.87-1.91-.3-3.34.72-7.47.86-8.52l2.14-11.43c1.75-10.74 3.13-17.51 3.23-20.86.02-.49.08-2.84.13-3.24.17-1.25.48-1-4.96-1.65l.03-.02Zm-46.19 5.67c-.04-.24-.09-.48-.15-.71l.85-.15c-.34.24-.56.53-.7.86Zm1.95 25.12c-.36-6.63-.7-13.26-1.32-19.87 0 .02 0 .04.01.06.29 1.65.44 2.47.56 2.89 1 8.46 1.5 16.14 1.46 22.8-.06.99-.1 2-.11 3.02-.01.29-.03.68-.05 1.12-.01-.26-.03-.53-.04-.78-.19-3.08-.35-6.16-.52-9.23l.01-.01Zm36.4 18.66c-.11-.11-.24-.29-.37-.49.35.21.74.26 1.17.16-.27.11-.53.22-.8.32v.01Zm-.89-33.72c.12-.43.23-.86.35-1.29.71-1.77 1.41-3.55 2.08-5.33-.15.68-.26 1.22-.31 1.55-.5 2.94-2.13 7.59-3.58 13.36-.15-.35-.29-.66-.43-1 .61-2.44 1.25-4.87 1.9-7.3l-.01.01Zm3.56-12.48c.14-.44.28-.89.42-1.34-.13.7-.27 1.41-.42 2.11-.43 1.19-.86 2.38-1.31 3.57.42-1.45.85-2.9 1.31-4.34Zm-5.22 16.05c-.11.44-.23.87-.35 1.31-.12.46-.23.92-.35 1.38-.1-.22-.19-.4-.28-.61.34-.69.66-1.38.97-2.08h.01Zm-11.64 2.62c.06-.1.12-.19.17-.28.05.13.09.26.14.39a.398.398 0 0 0-.31-.11Zm2.3 2.98c-.56-1.3-1.25-2.63-1.65-3.99 0 0 .01-.02.02-.02.06.08 1.52 2.93 1.63 3.08.73 1.13 3.38 7.04 5.67 12.26 1.2 2.73 2.08 5.17 2.83 7.18-.62-1.25-1.23-2.51-1.83-3.78-2.31-4.87-4.53-9.78-6.67-14.73ZM275.92 87.03c-1.06-2.18-1.13-3.45-2.44-2.93-1.52.57-2.94 1.3-4.5 2.1-1.4.72-2.68 1.44-3.92 2.12.01-.25-.24-.5-.51-.34-4.8 2.93-12.41 4.7-17.28 1.31-1.98-1.77-3.32-4.15-3.97-5.78-.29-.95-.49-1.94-.63-2.93-.14-3.34 1.58-6.53 3.9-9.12.8-.79 1.68-1.51 2.66-2.12 3.7-2.3 8.22-3.07 12.51-2.51 2.71.35 5.32 1.24 7.71 2.55.39.22.75-.39.35-.6-.18-.1-.37-.18-.55-.27.56.27 1.03.33 1.51.19l-.48.39c-.15.11-.23.3-.13.48.09.15.33.24.48.13 1.3-.97 2.46-2.09 3.45-3.37.37-.29.64-.6.65-.97v-.02c.08-.33-.03-.7-.21-1.08-.31-.87-.98-2.01-2.19-3.26-2.43-2.52-3.79-3.45-5.68-4.26-1.14-.49-3.12-1.06-4.42-1.23-3.28-.42-10.64-1.21-18.18 4.11-7.74 5.46-11.94 12.3-12.23 20.61-.08 2.06.04 3.98.34 5.71.74 4.18 2.57 8 5.44 11.34 4.26 4.99 9.76 7.52 16.34 7.52 4.85 0 9.69-1.77 14.89-4.62.23-.12.45-.23.68-.35 2.19-1.1 4.37-2.23 6.46-3.5.49-.3 1.03-.61 1.5-.98 1.47-.87 1.11-1.12.49-2.95-.39-1.14-.76-2.7-2.06-5.36l.02-.01Zm-17.38-21.76c3.05-.42 6.31.79 9.36 2.35.51.39.94.68 1.33.87-5.61-2.86-12.72-3.39-18.44-.79 2.05-1.33 4.24-1.95 7.74-2.44l.01.01ZM443.67 72.67c-.4-2.2-1.15-4.33-2.37-6.22-1.49-2.32-3.58-4.19-5.91-5.64-6.17-3.81-13.75-5.11-20.83-6.01-3.23-.41-6.47-.69-9.72-.92l-1.39-.12c-.85-.07-1.52-.1-2.05-.1-1.08-.06-2.17-.12-3.25-.17-.08 0-.14.02-.19.05-.1.05-.18.14-.16.3.27 2.55-.01 5.12-.92 7.52-.15.38.4.56.62.28 1.32.59 2.68 1.05 4.08 1.37 0 2.78-.14 7.58-.33 12.91 0 0 0 .02-.01.03-.61 3.66-.79 7.42-1 11.12-.23 4.01-.43 8.03-.44 12.05 0 .64 0 1.28.03 1.93.02.31 0 .68.15.96.06.11.14.16.24.17-.2.17-.21.54.11.59 3.83.67 7.78.71 11.68.25 2.3-.19 4.87-.65 7.65-1.56 1.85-.54 3.67-1.18 5.43-1.91 7.2-3.02 14.31-8.07 17.35-15.53.76-1.86 1.17-3.8 1.31-5.75.3-1.93.28-3.82-.09-5.58l.01-.02Zm-19.32-15.42c5.74 1.41 11.94 3.68 15.65 8.55.25.32.47.65.69.99-2.3-2.82-5.68-5.69-12.88-8.23-2.16-.76-4.35-1.43-6.64-2.02 1.06.21 2.13.45 3.18.71Zm-25.82-3.04c.13 0 .27.01.4.02-.14.1-.26.23-.37.38 0-.13-.02-.26-.03-.4Zm34.82 22.17c-.75 3.09-3.55 5.66-5.88 7.58-3.35 2.76-7.21 5.03-11.28 6.54-1.33.49-2.71.9-4.12 1.15.06-1.38.08-2.76.07-4.13-.02-3.78-.16-7.56-.41-11.33-.09-1.37-.18-2.74-.37-4.1 0-.06-.03-.11-.06-.15.09-3.25.12-6.16.03-8.12 6.86 1.05 10.56 2.17 14.06 3.62 5.52 2.28 8.59 5.44 7.97 8.96l-.01-.02Zm-22 16.15c-.12 0-.23-.02-.34-.03l.34-.03v.06Zm-.69-.7c0-3.13.26-8.84.47-14.51.06 1.2.11 2.41.15 3.6.15 3.6.25 7.23.09 10.83-.24.03-.48.05-.71.07v.01Zm-12.33-30.94c.37.63 2.01 1.01 3.23 1.25v.15c-1.31-.31-2.59-.73-3.83-1.29.12-.36.23-.72.33-1.09.08.48.18.84.27.98Zm13.7 31.65v-.18c3.41-.56 6.71-2.02 9.69-3.68 2.31-1.28 4.59-2.78 6.63-4.53-4.69 4.53-11.61 8.24-16.33 8.38l.01.01Zm24.07-.75c-2.05 1.93-4.37 3.56-6.83 4.95 2.7-1.78 5.52-4.03 8.42-6.87.82-.82 1.56-1.69 2.23-2.59-1.08 1.65-2.38 3.16-3.81 4.51h-.01ZM187.16 92.14c-.79-2.47-2.1-7.12-3.1-6.87-.19-.01-2.09.77-4.08 1.54-3.06 1.18-5.91 2.13-10.09 2.82-2.74.42-5.87 1.01-10.61 1.06.04-3.34.05-6.01.05-7.99 7.97-.65 12.33-2.11 16.37-3.55 1.11-.39 2.69-1.01 2.63-1.8-.08-.35-.55-1.39-1.17-2.61-.47-1.16-.98-2.31-1.61-3.38-.42-.71-1.04-1.69-1.86-2.06-.11-.08-.22-.13-.29-.12-.02 0-.04 0-.07.01-.19-.04-.39-.05-.6-.01-.17.03-.24.15-.25.28-.04.02-.09.04-.14.05-4.33 1.48-8.85 2.33-13.24 3.61a499.1 499.1 0 0 0-.31-8.19c4.51-.99 8.88-1.38 13.11-1.82 3.68-.38 6.28.12 7.47.34.59.11.9.16 1.16.18h.1c-.1.37.44.66.62.28.02-.04.03-.08.05-.13.15.2.53.22.62-.1.17-.58.19-1.21.21-1.81v-.36c.03-.15.05-.3.07-.45.52-2.47.33-5.09-.64-7.44-.11-.27-.44-.28-.6-.14-.08-.21-.15-.42-.24-.62-.19-.41-.79-.05-.6.35.03.07.05.15.09.22-.98-.42-2.15-.54-3.17-.63-2.17-.19-4.37-.14-6.54 0-5.7.35-11.4 1.3-16.91 2.79-2.08.56-4.13 1.22-6.14 2-4.54 1.05-3.79 1.51-2.17 6.07.18.51.46 1.68.54 1.94.82 2.47 1.08 2.13 3.1 2.13s0 .05 0 .08h.52c-.48 2.66-.51 5.45-.62 8.13-.15 3.48-.22 6.96-.28 10.45 0 .41-.01.82-.02 1.23-.16.29-.33.57-.51.85-.05.38-.09.77-.14 1.18-.42 3.52-.59 6.48-.52 8.8v.34c.02.47.05.76.06.87.16 1.57-.26 3.47 1.35 3.79 1.61.32 3.5.55 4.85.55.11 0 .22-.02.33-.02 1.79.24 3.67.05 5.45-.12 2.85-.28 5.69-.7 8.51-1.19 3.03-.53 6.05-1.14 9.04-1.86 2.4-.58 4.82-1.19 7.13-2.06.51-.19 1.73-.57 2.46-1.14 1.81-.68 2.18-1 1.57-2.67-.23-.62-.48-1.49-.91-2.78l-.03-.02Zm-11.12-38.71c.89.05 1.93.08 2.89.3-.33 0-.68-.02-1.06-.03-8.28-.26-14.88.75-23.97 2.51 2.41-.64 4.85-1.16 7.28-1.59 4.87-.86 9.91-1.45 14.86-1.19Zm-26.53 22.13c.03 1.71.04 3.43 0 5.14-.04 1.27-.11 2.55-.24 3.82 0-.73.02-1.46.04-2.19.05-2.26.12-4.51.22-6.77h-.02Zm6.73 27.85c.2-.1.4-.21.58-.33 1.82-.17 3.82-.24 5.94-.34-.86.11-1.72.24-2.58.33-1.27.14-2.61.31-3.93.34h-.01ZM534.48 85.44c-3.52-8.38-7.07-16.75-10.5-25.17-.63-1.54-1.25-3.09-1.86-4.65-.31-.8-.65-1.6-.87-2.43-.04-.17-.17-.24-.31-.25.1-.2 0-.51-.29-.53-1.59-.08-3.18-.22-4.78-.25-1.96-.03-3.91.13-5.84.42-.31.05-.31.38-.13.56-.03.06-.05.14-.04.22.23 1.54.63 3.06 1.16 4.53.13.35.27.7.41 1.06l-2.68 6.18c-.11.03-.2.09-.25.22-.67 1.9-1.52 3.73-2.34 5.56a536.85 536.85 0 0 1-3.9 8.45c-2.64 5.64-5.34 11.25-7.91 16.93-.44.97-.88 1.94-1.29 2.93-.2.48-.47 1-.55 1.52v.05c-.02.12.02.26.16.34 1.19.73 2.41 1.41 3.66 2.05 1.2.62 2.45 1.25 3.76 1.61.43.12.62-.55.19-.67-1.13-.31-2.2-.83-3.24-1.36 1.09.36 2.1.69 2.75.93 2.82 1.01 2.38 1.1 4.3-3.75 2.1-1.09 4.34-1.96 6.53-2.79 4.35-1.64 8.8-3.03 13.27-4.29.82 2.01 1.77 3.97 2.72 5.92.35.83.62 1.45.79 1.82.22.42.45.8.69 1.15.17.33.33.67.5 1 .42.8.84 1.63 1.4 2.35.23.29.6 0 .55-.31 1.53-.02 3.06-.07 4.58-.27.92-.12 1.82-.32 2.71-.54 1.39-.27 3.85-1.11 3.74-1.42-.67-1.96-1.55-3.87-2.34-5.78-1.57-3.78-3.16-7.56-4.75-11.33v-.01Zm-11.65-26.16c1.54 3.81 3.12 7.6 4.7 11.4 2.94 7.05 5.91 14.09 8.87 21.13l-1.06-2.17c-2.71-5.51-5.2-11.19-7.41-16.87l-6.65-17.15c-.65-1.45-.55-2.19-.93-2.53.09 0 .18.01.28.02a.29.29 0 0 0-.04.26c.52 2.02 1.47 3.98 2.25 5.91h-.01Zm-6.58 13.58c.05-.15.09-.31.14-.46 1.41 3.92 2.88 7.9 4.39 11.87-3.22.52-6.38 1.25-9.46 2.14.55-1.22 1.05-2.46 1.53-3.7 1.24-3.24 2.37-6.53 3.39-9.85h.01Zm-.23-20c.36 0 .73.03 1.09.05-2.15.1-5.18.33-5.87.74-.24.15-.41.3-.53.45-.06-.29-.13-.58-.18-.88 1.82-.26 3.65-.39 5.49-.35v-.01Zm-.09 18.72c-.49 1.67-1.05 3.33-1.6 4.97-1.07 3.19-2.19 6.38-3.57 9.46-.09.21-.19.43-.29.65-.25.07-.5.14-.74.22 2.53-6.16 4.61-11.29 6.2-15.3Zm-6.34 25.16c4.97-2.38 9.37-4.1 14.02-5.27l.26.64c-4.8 1.35-9.63 2.8-14.28 4.63Zm20.17 6.76c.33.23.68.42 1.04.56h-.33c-.12 0-.21.06-.26.13-.15-.23-.31-.45-.45-.7v.01ZM226.57 91.75c-3.55-4.74-6.68-9.11-9.31-12.99 9.2-15.25 10.05-17.81 10.35-18.38.17-.34 1.09-2.27.64-2.53-1.13-.65-1.03-.65-2.97-1.71-1.19-.65-3.04-1.61-4.53-2.12-1.71-.59-1.24-.36-3 2.77-.06.1-.11.2-.17.3-.75 1.02-1.48 2.05-2.2 3.09-1.88 2.71-3.73 5.45-5.69 8.1-3.68-4.91-6.88-8.76-9.51-11.43-.15-.15-.3-.29-.46-.42-1.27-1.28-7.24 3.53-7.93 5.58-.09.09-.19.16-.28.25-.27.26.03.64.33.58.19.65.5 1.29.94 1.91 3.85 5.06 7.19 9.76 9.94 14-1.23 2.61-3.06 5-4.67 7.38l-2.28 3.33c-.5.66-.93 1.23-1.29 1.69-.67.93-2.09 2.61-2.3 3.87-.51.85-1.16 1.84-1.29 2.83-.06.44.61.63.67.19.01-.08.04-.15.06-.22 1.36 1.08 2.76 2.11 4.19 3.11 1.3.91 2.62 1.85 4.04 2.56.21.1.4 0 .48-.17.24.07.48.14.72.2.44.1.62-.57.19-.67-2.02-.48-3.77-1.57-5.23-3.02-.47-.46-.9-.96-1.32-1.46 1.74 1.35 4.2 2.89 5.89 4.14 1.39 1.03 2.85-2.27 4.22-4.2 1.86-2.64 3.96-5.86 5.52-8.29l10.39 14.51c.67.81 1.14 1.21 1.57 1.36-.05.24.12.51.41.4 1.53-.58 3.05-1.19 4.54-1.87 1.52-.69 3.06-1.45 4.36-2.5a.28.28 0 0 0 .12-.23c1.66-1.1.81-1.74-1.41-4.91-1.13-1.58-1.71-2.36-3.7-5.01l-.03-.02Zm2.41 6.54c.56 1.15 1.19 2.52 1.11 3.81-.06.04-.12.07-.17.1-.03-.88-.55-2.66-.94-3.91Zm-16.51-32.73c1.86-2.65 3.65-5.35 5.57-7.95.4-.55.81-1.13 1.26-1.66.19-.18.38-.33.56-.45.18.03.36.08.55.13l-8.05 10.11.12-.18h-.01ZM192.7 95.48c.79-1.37 1.66-2.69 2.54-4 1.19-1.79 2.4-3.56 3.61-5.33-.04.09-.09.17-.13.26-.1.22.03.41.2.49-2.47 3.42-4.89 6.73-6.4 9.28.21.24.4.48.63.75-.24.07-.4.36-.17.56.4.33.72.77 1.05 1.17.09.11.18.21.27.32-.84-.61-1.66-1.24-2.47-1.88.24-.57.58-1.11.87-1.61v-.01Zm7.46-10.32c.47-.81.98-1.59 1.49-2.37.31-.48.64-.95.96-1.43.26-.29.52-.56.75-.79-.99 1.48-2.09 3.03-3.2 4.59Zm10.03-16.22s-.03-.05-.05-.07c.22-.29.43-.59.64-.89-.2.32-.4.65-.58.96h-.01ZM371.54 87.96c-.01-.08-.01-.16-.03-.23-.06-.38-.58-.29-.66.03-.3-.05-.6-.08-.81-.11-1.14-.15-2.29-.19-3.44-.2 1.04-.09 2.09-.18 3.14-.23.45-.02.45-.72 0-.7-6.57.35-13.14 1.23-19.65 2.11-1.53.21-3.05.42-4.57.68-.01 0-.02.01-.04.01-.04-3.33-.13-6.66-.24-9.99-.19-5.7-.4-11.41-.88-17.1-.13-1.51-.23-3.07-.49-4.58 0-.25 0-.48-.02-.68-.06-1.19-.04-2.61-.68-2.78-.16-.07-.72-.16-1.5-.24.22-.17.16-.62-.2-.63-1.19-.04-2.39.09-3.57.23-1.2.14-2.41.32-3.59.6-.16-.1-.41-.06-.5.12-.06.02-.13.03-.19.05-.35.1-.29.55-.03.66-.26.6-.19 2.27-.21 3-.02.66-.66 33.73-.9 40.3-.03.65.06 1.12.04 1.45-.16 3.05.87 4.96 6.34 3.93 1.09-.08 2.75-.77 5.36-1.43 4.13-1.04 5.78-1.52 6.2-1.65 6.43-1.69 6.78-1.97 11.72-2.43.55-.05 4.8-.38 6.03-.3.64.04 1.19.07 1.65.1.09 0 .16-.03.24-.05.1.27.56.33.66-.02.39-1.32.61-2.71.78-4.08.2-1.61.29-3.24.15-4.86.24.03.52-.23.38-.53-.09-.2-.27-.33-.49-.43v-.02Zm-.63.56c.07.57.11 1.14.11 1.71-.21-.99-.53-1.71-.95-1.87.22.03.44.06.65.11.06.01.12.04.19.05Zm-25.41 1.73c1.54-.36 3.1-.64 4.66-.89-1.61.37-3.18.77-4.66 1.2v-.31Zm-.86-7.37c-.07-1.37-.16-2.75-.25-4.12-.21-3.13-.45-6.27-.79-9.4.02-2.25.08-4.31.13-6.11.16 2.08.29 4.16.4 6.24.23 4.46.38 8.93.5 13.39h.01Zm-.94-4c.16 2.41.29 4.83.39 7.24.06 1.6.14 3.22.09 4.83-.15.05-.32.09-.47.14V78.88h-.01ZM483.72 92.83c-3.05-2.28-6.22-4.4-9.38-6.51 8.86-6.49 13.49-12.95 13.73-19.23.04-.76 0-1.5-.13-2.2-.67-3.82-3.5-6.68-8.39-8.48.13.04.27.08.4.13 3.92 1.39 7.74 4.23 8.5 8.56.34 1.95-.05 3.96-.98 5.69-.21.4.39.75.6.35 1.86-3.46 1.46-7.55-.97-10.63-3.53-4.47-9.76-5.88-15.16-6.16-2.32-.12-4.64-.04-6.95.19-6 .32-12.71 1.68-17.63 3.21-.37.11-.67.23-.92.35-.2-.17-.62.02-.57.37v.03c-.64.68-.18 1.64.48 3.21.38.91.67 1.89 1.15 2.58.32.76.68 1.51 1.13 2.19.14.21.38.19.53.07.19-.02.38-.05.57-.08v1.57c-.06.06-.1.13-.11.23-.27 4.18-.34 8.38-.48 12.57l-.3 9.03c-.24 3.91-.44 6.77-.46 7.26-.05.88-.11 1.95.07 2.81-.01.22-.02.43-.04.65 0 .11-.02.23-.03.35 0 .05-.03.27-.01.16-.05.4.5.59.64.28.05.04.12.08.2.08 1.75.13 3.5.28 5.25.3 1.69.02 3.38-.12 5.06-.32.08.23.36.39.55.15.06-.08.11-.17.16-.26.18-.09.24-.32.18-.48.05-.2.1-.4.13-.6.16-.86.25-1.74.33-2.62.11-1.17.17-2.34.23-3.51.15-.01.32-.03.52-.04.36-.03 1.73-.15 2.06-.15.39 0 .7-.02.95-.04 1.76 1.11 3.45 2.35 5.14 3.55 2.83 2.01 5.64 4.04 8.47 6.04 1.42 1 2.85 2 4.29 2.97.1.06.19.07.27.04.08 0 .17-.02.25-.1 1.61-1.56 3.15-3.18 4.6-4.88.75-.88 1.49-1.78 2.15-2.73.01.01.03.02.04.03.34.3.83-.2.49-.49-2.16-1.9-4.34-3.76-6.64-5.48l.03-.01Zm-6.38-3.65a55.72 55.72 0 0 0-4-2.13c.14-.1.26-.19.4-.29 1.2.81 2.4 1.61 3.6 2.42Zm-20.1 11.78c.67-.37 1.23-.91 1.67-1.6-.11.5-.24 1-.38 1.49-.43.04-.86.08-1.29.11Zm2.38-37.24c1.34-.31 2.56-.52 3.71-.69-1.03.19-2.04.41-3.04.65-.14-.07-.34-.02-.45.11-.07.02-.15.04-.22.05v-.13.01Zm.04.84c.07-.02.14-.03.2-.05.34 1.66.41 3.41.5 5.09.17 2.9.24 5.81.28 8.71l.03 3.17c-.17.07-.34.14-.51.2-.06-4.96-.21-10.58-.51-17.12h.01Zm16.04 5.62c-1.16 2.25-3.06 4.1-5.02 5.66-2.8 2.23-5.99 3.97-9.3 5.35-.01-3.56-.09-7.12-.27-10.67-.1-2.04-.16-4.16-.57-6.18 3.3-.78 6.72-1.36 10.1-1.1 1.85.14 4.23.59 5.32 2.29.92 1.43.46 3.24-.26 4.65Zm.85-.18c.6-1.37.9-2.92.28-4.32-.67-1.52-2.2-2.32-3.76-2.74.46.1.89.21 1.29.37 1.74.67 2.69 1.88 2.93 3.21.2 1.13-.05 2.25-.74 3.47V70Zm-27.47-4.14c-.12-.19-.23-.38-.34-.57.74.42.85.36.99.41v.08c-.22.03-.43.06-.65.08Zm11.21 30.46c-.08 1.08-.16 2.17-.33 3.24-.05.35-.11.69-.2 1.03 0 .04-.02.07-.03.11-.15.02-.3.04-.45.05.45-1.64.76-3.36.79-5.07.03-.29.08-.57.1-.89-.03-.31-.03-.47.24-.57-.04.69-.07 1.39-.12 2.08v.02Zm5.6-2.47c.48.11.92.52 2.49 1.72-.46-.32-.92-.65-1.38-.97-.37-.25-.73-.5-1.1-.75h-.01Zm21.23 7.24a70.76 70.76 0 0 1-4.37 4.63c-.14-.09-.27-.19-.4-.28.19-.09.37-.24.55-.47.87-1.14 5.43-5.51 5.49-7.45.31.26.62.53.92.79-.67.97-1.42 1.88-2.19 2.77v.01Z",fill:"currentColor",transform:"translate(-144.023 -51.76)"})]}),tk=({style:e,size:t="small",withText:o})=>ok("div",{className:`ExcalidrawLogo is-${t}`,style:e,children:[ta(W9,{}),o&&ta(V9,{})]})});import{Fragment as ak,jsx as Pt,jsxs as A0}from"react/jsx-runtime";var M0,Zd,nk,Tr,L0,_0,P0,D0,R0,ik,lk=v(()=>{"use strict";f();Er();ol();X();ye();qo();ee();Vt();rk();M0=({icon:e,shortcut:t,children:o})=>{let r=_e();return A0(ak,{children:[Pt("div",{className:"welcome-screen-menu-item__icon",children:e}),Pt("div",{className:"welcome-screen-menu-item__text",children:o}),t&&!r.editor.isMobile&&Pt("div",{className:"welcome-screen-menu-item__shortcut",children:t})]})};M0.displayName="WelcomeScreenMenuItemContent";Zd=({onSelect:e,children:t,icon:o,shortcut:r,className:n="",...i})=>Pt("button",{...i,type:"button",className:`welcome-screen-menu-item ${n}`,onClick:e,children:Pt(M0,{icon:o,shortcut:r,children:t})});Zd.displayName="WelcomeScreenMenuItem";nk=({children:e,href:t,icon:o,shortcut:r,className:n="",...i})=>Pt("a",{...i,className:`welcome-screen-menu-item ${n}`,href:t,target:"_blank",rel:"noreferrer",children:Pt(M0,{icon:o,shortcut:r,children:e})});nk.displayName="WelcomeScreenMenuItemLink";Tr=({children:e})=>{let{WelcomeScreenCenterTunnel:t}=nt();return Pt(t.In,{children:Pt("div",{className:"welcome-screen-center",children:e||A0(ak,{children:[Pt(L0,{}),Pt(_0,{children:b("welcomeScreen.defaults.center_heading")}),A0(P0,{children:[Pt(R0,{}),Pt(D0,{})]})]})})})};Tr.displayName="Center";L0=({children:e})=>Pt("div",{className:"welcome-screen-center__logo virgil welcome-screen-decor",children:e||Pt(tk,{withText:!0})});L0.displayName="Logo";_0=({children:e})=>Pt("div",{className:"welcome-screen-center__heading welcome-screen-decor virgil",children:e});_0.displayName="Heading";P0=({children:e})=>Pt("div",{className:"welcome-screen-menu",children:e});P0.displayName="Menu";D0=()=>{let e=Ft();return Pt(Zd,{onSelect:()=>e.executeAction(Fi),shortcut:"?",icon:za,children:b("helpDialog.title")})};D0.displayName="MenuItemHelp";R0=()=>{let e=Re(),t=Ft();return e.viewModeEnabled?null:Pt(Zd,{onSelect:()=>t.executeAction(ja),shortcut:Lt("loadScene"),icon:Ga,children:b("buttons.load")})};R0.displayName="MenuItemLoadScene";ik=({onSelect:e})=>{let{t}=Ct();return Pt(Zd,{shortcut:null,onSelect:e,icon:Vc,children:t("labels.liveCollaboration")})};ik.displayName="MenuItemLiveCollaborationTrigger";Tr.Logo=L0;Tr.Heading=_0;Tr.Menu=P0;Tr.MenuItem=Zd;Tr.MenuItemLink=nk;Tr.MenuItemHelp=D0;Tr.MenuItemLoadScene=R0;Tr.MenuItemLiveCollaborationTrigger=ik});import{jsx as Ns,jsxs as N0}from"react/jsx-runtime";var nh,ih,ah,sk=v(()=>{"use strict";f();X();qo();ee();nh=({children:e})=>{let{WelcomeScreenMenuHintTunnel:t}=nt();return Ns(t.In,{children:N0("div",{className:"virgil welcome-screen-decor welcome-screen-decor-hint welcome-screen-decor-hint--menu",children:[p1,Ns("div",{className:"welcome-screen-decor-hint__label",children:e||b("welcomeScreen.defaults.menuHint")})]})})};nh.displayName="MenuHint";ih=({children:e})=>{let{WelcomeScreenToolbarHintTunnel:t}=nt();return Ns(t.In,{children:N0("div",{className:"virgil welcome-screen-decor welcome-screen-decor-hint welcome-screen-decor-hint--toolbar",children:[Ns("div",{className:"welcome-screen-decor-hint__label",children:e||b("welcomeScreen.defaults.toolbarHint")}),g1]})})};ih.displayName="ToolbarHint";ah=({children:e})=>{let{WelcomeScreenHelpHintTunnel:t}=nt();return Ns(t.In,{children:N0("div",{className:"virgil welcome-screen-decor welcome-screen-decor-hint welcome-screen-decor-hint--help",children:[Ns("div",{children:e||b("welcomeScreen.defaults.helpHint")}),u1]})})};ah.displayName="HelpHint"});var ck=v(()=>{});import{Fragment as dk,jsx as jd,jsxs as K9}from"react/jsx-runtime";var lh,Y9,mk=v(()=>{"use strict";f();lk();sk();ck();lh=e=>jd(dk,{children:e.children||K9(dk,{children:[jd(Tr,{}),jd(nh,{}),jd(ih,{}),jd(ah,{})]})});lh.displayName="WelcomeScreen";lh.Center=Tr;lh.Hints={MenuHint:nh,ToolbarHint:ih,HelpHint:ah};Y9=lh});var pk=v(()=>{});import $9 from"clsx";import{jsx as Z9,jsxs as j9}from"react/jsx-runtime";var uk,X9,gk=v(()=>{"use strict";f();X();ee();Is();pk();Vt();uk=({isCollaborating:e,onSelect:t,...o})=>{let r=Re(),n=r.width<830;return j9(un,{...o,className:$9("collab-button",{active:e}),type:"button",onSelect:t,style:{position:"relative",width:n?void 0:"auto"},title:b("labels.liveCollaboration"),children:[n?B1:b("labels.share"),r.collaborators.size>0&&Z9("div",{className:"CollabButton-collaborators",children:r.collaborators.size})]})},X9=uk;uk.displayName="LiveCollaborationTrigger"});import{jsx as hk,jsxs as q9}from"react/jsx-runtime";var fk,bk=v(()=>{"use strict";f();qo();Td();ye();ee();X();So();fk=({children:e,icon:t})=>{let{TTDDialogTriggerTunnel:o}=nt(),r=Be();return hk(o.In,{children:q9(Ge.Item,{onSelect:()=>{we("ai","dialog open","ttd"),r({openDialog:{name:"ttd",tab:"text-to-diagram"}})},icon:t??kb,children:[e??b("labels.textToDiagram"),hk(Ge.Item.Badge,{children:"AI"})]})})};fk.displayName="TTDDialogTrigger"});import J9,{useEffect as Q9}from"react";import{Provider as eN}from"jotai";import{parseMermaidToExcalidraw as m5e}from"@excalidraw/mermaid-to-excalidraw";import{jsx as O0}from"react/jsx-runtime";var tN,oN,rN,Of=v(()=>{f();py();ye();G();Y4();K4();$4();Z4();X();U();Tt();Q4();zE();mk();gk();he();X();Aa();Pa();Kn();Co();Jr();el();se();U();Ze();el();G();Nd();Is();ye();Yl();UE();o0();bk();Dl();ad();a0();bt();Hf();Fo();Tt();el();ee();Er();on();oE();X4();tN=e=>{let{onChange:t,initialData:o,excalidrawAPI:r,isCollaborating:n=!1,onPointerUpdate:i,renderTopRightUI:a,langCode:l=Vr.code,viewModeEnabled:s,zenModeEnabled:c,gridModeEnabled:d,libraryReturnUrl:m,theme:p,name:u,renderCustomStats:g,onPaste:x,detectScroll:E=!0,handleKeyboardGlobally:y=!1,onLibraryChange:T,autoFocus:w=!1,generateIdForFile:S,onLinkOpen:M,onPointerDown:k,onPointerUp:R,onScrollChange:P,id:F,onHomeButtonClick:D,children:L,validateEmbeddable:A,renderEmbeddable:B,aiEnabled:j,ui:Y,interactive:oe,activeTool:Ce}=e,Te=e.UIOptions?.canvasActions,K={...e.UIOptions,canvasActions:{...gh.canvasActions,...Te},tools:{image:e.UIOptions?.tools?.image??!0}};return Te?.export&&(K.canvasActions.export.saveFileToDisk=Te.export?.saveFileToDisk??gh.canvasActions.export.saveFileToDisk),K.canvasActions.toggleTheme===null&&typeof p>"u"&&(K.canvasActions.toggleTheme=!0),Q9(()=>{(async()=>{await import("canvas-roundrect-polyfill")})();let xe=Ne=>{typeof Ne.scale=="number"&&Ne.scale!==1&&Ne.preventDefault()};return document.addEventListener("touchmove",xe,{passive:!1}),()=>{document.removeEventListener("touchmove",xe)}},[]),O0(eN,{unstable_createStore:()=>Zt,scope:He,children:O0(my,{langCode:l,theme:p,children:O0(V4,{id:F,onChange:t,initialData:o,excalidrawAPI:r,isCollaborating:n,onPointerUpdate:i,renderTopRightUI:a,langCode:l,viewModeEnabled:oe===!1?!0:s,zenModeEnabled:c,gridModeEnabled:d,libraryReturnUrl:m,theme:p,name:u,renderCustomStats:g,UIOptions:K,onPaste:x,detectScroll:E,handleKeyboardGlobally:y,onLibraryChange:T,autoFocus:w,generateIdForFile:S,onLinkOpen:M,onPointerDown:k,onPointerUp:R,onScrollChange:P,validateEmbeddable:A,renderEmbeddable:B,aiEnabled:j!==!1,onHomeButtonClick:D,ui:Y,interactive:oe,activeTool:Ce,children:L})})})},oN=(e,t)=>{if(e.children!==t.children)return!1;let{initialData:o,UIOptions:r={},...n}=e,{initialData:i,UIOptions:a={},...l}=t,s=Object.keys(r),c=Object.keys(a);return s.length!==c.length?!1:s.every(m=>m==="canvasActions"?Object.keys(r.canvasActions).every(u=>u==="export"&&r?.canvasActions?.export&&a?.canvasActions?.export?r.canvasActions.export.saveFileToDisk===a.canvasActions.export.saveFileToDisk:r?.canvasActions?.[u]===a?.canvasActions?.[u]):r[m]===a[m])&&It(n,l)},rN=J9.memo(tN,oN);rN.displayName="Excalidraw"});Of();export{un as Button,DP as CommandPalette,mh as DEFAULT_LASER_COLOR,Rg as DefaultSidebar,rN as Excalidraw,dt as FONT_FAMILY,U9 as Footer,X9 as LiveCollaborationTrigger,J as MIME_TYPES,fo as MainMenu,at as ROUNDNESS,oi as Sidebar,ie as THEME,t0 as TTDDialog,fk as TTDDialogTrigger,Y9 as WelcomeScreen,XC as actions,Nr as bumpVersion,bc as cleanAppStateForExport,YA as clearAppStateForLocalStorage,Hd as convertToExcalidrawElements,Vr as defaultLang,Ol as duplicateElement,yc as duplicateElements,qw as elementPartiallyOverlapsWithOrContainsBBox,Ff as elementsOverlappingBBox,kp as exportToBlob,Si as exportToCanvas,UM as exportToClipboard,ql as exportToSvg,Se as getCommonBounds,Bo as getDefaultAppState,Jm as getFreeDrawSvgPath,$u as getLibraryItemsHash,be as getNonDeletedElements,dL as getSceneVersion,UA as getVisibleSceneBounds,t1 as hashElementsVersion,o1 as hashString,Pv as icons,Bf as isElementInsideBBox,dr as isInvisiblySmallElement,ne as isLinearElement,He as jotaiScope,Zt as jotaiStore,sl as languages,Gi as libraryItemsAtom,Wl as loadFromBlob,Tf as loadLibraryFromBlob,op as loadSceneOrLibraryFromBlob,I5 as mergeLibraryItems,z as mutateElement,ae as newElementWith,po as normalizeLink,Cx as parseLibraryTokensFromUrl,m5e as parseMermaidToExcalidraw,Sa as restore,ep as restoreAppState,Ic as restoreElements,ka as restoreLibraryItems,zt as sceneCoordsToViewportCoords,Ii as serializeAsJSON,ap as serializeLibraryAsJSON,_e as useDevice,R7 as useHandleLibrary,Ct as useI18n,$e as viewportCoordsToSceneCoords,j3 as zoomToFitBounds};
193
+ `),r)}}addTextFromPaste(t,r=!1){let{x:o,y:n}=je({clientX:this.lastViewportPosition.x,clientY:this.lastViewportPosition.y},this.state),i={x:o,y:n,strokeColor:this.state.currentItemStrokeColor,backgroundColor:this.state.currentItemBackgroundColor,fillStyle:this.state.currentItemFillStyle,strokeWidth:this.state.currentItemStrokeWidth,strokeStyle:this.state.currentItemStrokeStyle,roundness:null,roughness:this.state.currentItemRoughness,opacity:this.state.currentItemOpacity,text:t,fontSize:this.state.currentItemFontSize,fontFamily:this.state.currentItemFontFamily,textAlign:this.state.currentItemTextAlign,verticalAlign:fa,locked:!1},a=10,l=n,s=r?[t]:t.split(`
194
+ `),c=s.reduce((d,m,p)=>{let u=m.trim(),h=Xr(i.fontFamily);if(u.length){let E=this.getTopLayerFrameAtSceneCoords({x:o,y:l}),x=$t({...i,x:o,y:l,text:u,lineHeight:h,frameId:E?E.id:null});d.push(x),l+=x.height+a}else s[p-1]?.trim()&&(l+=Pi(i.fontSize,h)+a);return d},[]);c.length!==0&&(this.scene.insertElements(c),this.setState({selectedElementIds:Fe(Object.fromEntries(c.map(d=>[d.id,!0])),this.state)}),!r&&c.length>1&&HA===!1&&!this.device.editor.isMobile&&(this.setToast({message:b("toast.pasteAsSingleElement",{shortcut:N("CtrlOrCmd+Shift+V")}),duration:5e3}),HA=!0),this.store.shouldCaptureIncrement())}setAppState=(t,r)=>{this.setState(t,r)};removePointer=t=>{da&&this.resetContextMenuTimer(),Ue.pointers.delete(t.pointerId)};toggleLock=(t="ui")=>{this.state.activeTool.locked||ve("toolbar","toggleLock",`${t} (${this.device.editor.isMobile?"mobile":"desktop"})`),this.setState(r=>({activeTool:{...r.activeTool,...tt(this.state,r.activeTool.locked?{type:"selection"}:r.activeTool),locked:!r.activeTool.locked}}))};updateFrameRendering=t=>{this.setState(r=>{let o=typeof t=="function"?t(r.frameRendering):t;return{frameRendering:{enabled:o?.enabled??r.frameRendering.enabled,clip:o?.clip??r.frameRendering.clip,name:o?.name??r.frameRendering.name,outline:o?.outline??r.frameRendering.outline}}})};togglePenMode=t=>{this.setState(r=>({penMode:t??!r.penMode,penDetected:!0}))};onHandToolToggle=()=>{this.actionManager.executeAction(J3)};zoomCanvas=t=>{this.setState({...ti({viewportX:this.state.width/2+this.state.offsetLeft,viewportY:this.state.height/2+this.state.offsetTop,nextZoom:En(t)},this.state)})};cancelInProgressAnimation=null;scrollToContent=(t=this.scene.getNonDeletedElements(),r)=>{this.cancelInProgressAnimation?.();let o=Array.isArray(t)?t:[t],n=this.state.zoom,i=this.state.scrollX,a=this.state.scrollY;if(r?.fitToContent||r?.fitToViewport){let{appState:l}=wd({targetElements:o,appState:this.state,fitToViewport:!!r?.fitToViewport,viewportZoomFactor:r?.viewportZoomFactor});n=l.zoom,i=l.scrollX,a=l.scrollY}else{let l=gn(o,this.state);i=l.scrollX,a=l.scrollY}if(r?.animate){let l=this.state.scrollX,s=this.state.scrollY,c=this.state.zoom.value,d=Qy({fromValues:{scrollX:l,scrollY:s,zoom:c},toValues:{scrollX:i,scrollY:a,zoom:n.value},interpolateValue:(m,p,u,h)=>{if(h==="zoom")return m*Math.pow(p/m,Bn(u))},onStep:({scrollX:m,scrollY:p,zoom:u})=>{this.setState({scrollX:m,scrollY:p,zoom:{value:u}})},onStart:()=>{this.setState({shouldCacheIgnoreZoom:!0})},onEnd:()=>{this.setState({shouldCacheIgnoreZoom:!1})},onCancel:()=>{this.setState({shouldCacheIgnoreZoom:!1})},duration:r?.duration??500});this.cancelInProgressAnimation=()=>{d(),this.cancelInProgressAnimation=null}}else this.setState({scrollX:i,scrollY:a,zoom:n})};maybeUnfollowRemoteUser=()=>{this.state.userToFollow&&this.setState({userToFollow:null})};translateCanvas=t=>{this.cancelInProgressAnimation?.(),this.maybeUnfollowRemoteUser(),this.setState(t)};setToast=t=>{this.setState({toast:t})};restoreFileFromShare=async()=>{try{let t=await caches.open("web-share-target"),r=await t.match("shared-file");if(r){let o=await r.blob(),n=new File([o],o.name||"",{type:o.type});this.loadFileToCanvas(n,null),await t.delete("shared-file"),window.history.replaceState(null,js,window.location.pathname)}}catch(t){this.setState({errorMessage:t.message})}};addFiles=ut(t=>{let r=t.reduce((o,n)=>(o.set(n.id,n),o),new Map);this.files={...this.files,...Object.fromEntries(r)},this.scene.getNonDeletedElements().forEach(o=>{gr(o)&&r.has(o.fileId)&&(this.imageCache.delete(o.fileId),Ne.delete(o))}),this.scene.informMutation(),this.addNewImagesToImageCache()});updateScene=ut(t=>{let r=fr(t.elements??[]);if(t.storeAction&&t.storeAction!==_.NONE){let o=this.store.snapshot.appState,n=this.store.snapshot.elements,i=t.appState?Object.assign({},o,t.appState):o,a=t.elements?this.store.filterUncomittedElements(this.scene.getElementsMapIncludingDeleted(),X(r)):n;t.storeAction===_.CAPTURE?this.store.captureIncrement(a,i):t.storeAction===_.UPDATE&&this.store.updateSnapshot(a,i)}t.appState&&this.setState(t.appState),t.elements&&this.scene.replaceAllElements(r),t.collaborators&&this.setState({collaborators:t.collaborators})});onSceneUpdated=()=>{this.setState({})};toggleSidebar=({name:t,tab:r,force:o})=>{let n;o===void 0?n=this.state.openSidebar?.name===t&&this.state.openSidebar?.tab===r?null:t:n=o?t:null;let i=n?{name:n}:null;return i&&r&&(i.tab=r),this.setState({openSidebar:i}),!!n};updateCurrentCursorPosition=ut(t=>{this.lastViewportPosition.x=t.clientX,this.lastViewportPosition.y=t.clientY});onKeyDown=ut(t=>{if("Proxy"in window&&(!t.shiftKey&&/^[A-Z]$/.test(t.key)||t.shiftKey&&/^[a-z]$/.test(t.key))&&(t=new Proxy(t,{get(i,a){let l=i[a];return typeof l=="function"?l.bind(i):a==="key"?t.shiftKey?i.key.toUpperCase():i.key.toLowerCase():l}})),t[C.CTRL_OR_CMD]&&t.key===C.P&&!t.shiftKey&&!t.altKey){this.setToast({message:b("commandPalette.shortcutHint",{shortcut:_t("commandPalette")})}),t.preventDefault();return}if(t[C.CTRL_OR_CMD]&&t.key.toLowerCase()===C.V&&(Lg=t.shiftKey,clearTimeout(zA),zA=window.setTimeout(()=>{Lg=!1},100)),t[C.CTRL_OR_CMD]&&uo(t.target)&&(t.code===Ee.MINUS||t.code===Ee.EQUAL)){t.preventDefault();return}if(uo(t.target)&&t.key!==C.ESCAPE||Bl(t.key)&&Xg(t.target))return;if(t.key===C.QUESTION_MARK){this.setState({openDialog:{name:"help"}});return}else if(t.key.toLowerCase()===C.E&&t.shiftKey&&t[C.CTRL_OR_CMD]){t.preventDefault(),this.setState({openDialog:{name:"imageExport"}});return}if(t.key===C.PAGE_UP||t.key===C.PAGE_DOWN){let i=(t.shiftKey?this.state.width:this.state.height)/this.state.zoom.value;t.key===C.PAGE_DOWN&&(i=-i),t.shiftKey?this.translateCanvas(a=>({scrollX:a.scrollX+i})):this.translateCanvas(a=>({scrollY:a.scrollY+i}))}if(this.actionManager.handleKeyDown(t)||this.state.viewModeEnabled)return;if(t[C.CTRL_OR_CMD]&&this.state.isBindingEnabled&&this.setState({isBindingEnabled:!1}),Bl(t.key)){let i=this.state.gridSize&&(t.shiftKey?Fg:this.state.gridSize)||(t.shiftKey?Iy:Fg),a=0,l=0;t.key===C.ARROW_LEFT?a=-i:t.key===C.ARROW_RIGHT?a=i:t.key===C.ARROW_UP?l=-i:t.key===C.ARROW_DOWN&&(l=i);let s=this.scene.getSelectedElements({selectedElementIds:this.state.selectedElementIds,includeBoundTextElement:!0,includeElementsInFrames:!0});s.forEach(c=>{H(c,{x:c.x+a,y:c.y+l}),$r(c,this.scene.getNonDeletedElementsMap(),{simultaneouslyUpdated:s})}),this.maybeSuggestBindingForAll(s),t.preventDefault()}else if(t.key===C.ENTER){let i=this.scene.getSelectedElements(this.state);if(i.length===1){let a=i[0];if(t[C.CTRL_OR_CMD])ce(a)&&(!this.state.editingLinearElement||this.state.editingLinearElement.elementId!==i[0].id)&&(this.store.shouldCaptureIncrement(),this.setState({editingLinearElement:new Z(a)}));else if(V(a)||b2(a)){let l;V(a)||(l=a);let s=ap(a,this.state,this.scene.getNonDeletedElementsMap()),c=s.x,d=s.y;this.startTextEditing({sceneX:c,sceneY:d,container:l}),t.preventDefault();return}else re(a)&&this.setState({editingFrame:a.id})}}else if(!t.ctrlKey&&!t.altKey&&!t.metaKey&&this.state.draggingElement===null){let i=_C(t.key);i?(this.state.activeTool.type!==i&&ve("toolbar",i,`keyboard (${this.device.editor.isMobile?"mobile":"desktop"})`),this.setActiveTool({type:i}),t.stopPropagation()):t.key===C.Q&&(this.toggleLock("keyboard"),t.stopPropagation())}if(t.key===C.SPACE&&Ue.pointers.size===0&&(El=!0,$e(this.interactiveCanvas,Re.GRAB),t.preventDefault()),(t.key===C.G||t.key===C.S)&&!t.altKey&&!t[C.CTRL_OR_CMD]){let i=this.scene.getSelectedElements(this.state);if(this.state.activeTool.type==="selection"&&!i.length)return;t.key===C.G&&(Hn(this.state.activeTool.type)||i.some(a=>Hn(a.type)))&&(this.setState({openPopup:"elementBackground"}),t.stopPropagation()),t.key===C.S&&(this.setState({openPopup:"elementStroke"}),t.stopPropagation())}if(t.key===C.K&&!t.altKey&&!t[C.CTRL_OR_CMD]){this.state.activeTool.type==="laser"?this.setActiveTool({type:"selection"}):this.setActiveTool({type:"laser"});return}t[C.CTRL_OR_CMD]&&(t.key===C.BACKSPACE||t.key===C.DELETE)&&Qt.set(gl,"clearCanvas");let r=t.key.toLocaleLowerCase(),o=r===C.S&&t.shiftKey,n=t.key===C.I||r===C.G&&t.shiftKey;(o||n)&&this.openEyeDropper({type:o?"stroke":"background"})});onWheel=ut(t=>{!(t.target instanceof HTMLCanvasElement)&&t.ctrlKey&&t.preventDefault()});onKeyUp=ut(t=>{if(t.key===C.SPACE&&(this.state.viewModeEnabled?$e(this.interactiveCanvas,Re.GRAB):this.state.activeTool.type==="selection"?jr(this.interactiveCanvas):(qr(this.interactiveCanvas,this.state),this.setState({selectedElementIds:Fe({},this.state),selectedGroupIds:{},editingGroupId:null,activeEmbeddable:null})),El=!1),!t[C.CTRL_OR_CMD]&&!this.state.isBindingEnabled&&this.setState({isBindingEnabled:!0}),Bl(t.key)){let r=this.scene.getSelectedElements(this.state),o=this.scene.getNonDeletedElementsMap();mn(this.state)?yc(r,this):vc(r,o),this.setState({suggestedBindings:[]})}});isToolSupported=t=>this.props.UIOptions.tools?.[t]!==!1;setActiveTool=t=>{if(!this.isToolSupported(t.type)){console.warn(`"${t.type}" tool is disabled via "UIOptions.canvasActions.tools.${t.type}"`);return}let r=tt(this.state,t);qy(document.activeElement)&&this.focusContainer(),ac(r.type)||this.setState({suggestedBindings:[]}),r.type==="image"&&this.onImageAction({insertOnCanvasDirectly:(t.type==="image"&&t.insertOnCanvasDirectly)??!1}),this.setState(o=>{let n={snapLines:o.snapLines.length?[]:o.snapLines,originSnapOffset:null,activeEmbeddable:null};r.type==="freedraw"&&this.store.shouldCaptureIncrement();let i;return r.type!=="selection"?i={...o,activeTool:r,selectedElementIds:Fe({},o),selectedGroupIds:Fe({},o),editingGroupId:null,multiElement:null,...n}:i={...o,activeTool:r,...n},r.type==="hand"?$e(this.interactiveCanvas,Re.GRAB):El||qr(this.interactiveCanvas,i),i})};setOpenDialog=t=>{this.setState({openDialog:t})};setCursor=t=>{$e(this.interactiveCanvas,t)};resetCursor=()=>{jr(this.interactiveCanvas)};isTouchScreenMultiTouchGesture=()=>Ue.pointers.size>=2;getName=()=>this.state.name||this.props.name||`${b("labels.untitled")}-${$g()}`;onGestureStart=ut(t=>{if(t.preventDefault(),this.props.interactive===!1)return!1;this.isTouchScreenMultiTouchGesture()&&this.setState({selectedElementIds:Fe({},this.state),activeEmbeddable:null}),Ue.initialScale=this.state.zoom.value});onGestureChange=ut(t=>{if(t.preventDefault(),this.props.interactive===!1)return!1;if(this.isTouchScreenMultiTouchGesture())return;let r=Ue.initialScale;r&&this.setState(o=>({...ti({viewportX:this.lastViewportPosition.x,viewportY:this.lastViewportPosition.y,nextZoom:En(r*t.scale)},o)}))});onGestureEnd=ut(t=>{if(t.preventDefault(),this.props.interactive===!1)return!1;this.isTouchScreenMultiTouchGesture()&&this.setState({previousSelectedElementIds:{},selectedElementIds:Fe(this.state.previousSelectedElementIds,this.state)}),Ue.initialScale=null});handleTextWysiwyg(t,{isExistingElement:r=!1}){let o=this.scene.getElementsMapIncludingDeleted(),n=(i,a,l)=>{this.scene.replaceAllElements([...this.scene.getElementsIncludingDeleted().map(s=>s.id===t.id&&V(s)?Vf(s,gt(s,o),o,{text:i,isDeleted:l,originalText:a}):s)])};OA({id:t.id,canvas:this.canvas,getViewportCoords:(i,a)=>{let{x:l,y:s}=Vt({sceneX:i,sceneY:a},this.state);return[l-this.state.offsetLeft,s-this.state.offsetTop]},onChange:ut(i=>{n(i,i,!1),cc(t)&&$r(t,o)}),onSubmit:ut(({text:i,viaKeyboard:a,originalText:l})=>{let s=!i.trim();if(n(i,l,s),!s&&a){let c=t.containerId?t.containerId:t.id;this.setState(d=>({selectedElementIds:Fe({...d.selectedElementIds,[c]:!0},d)}))}s&&Qm(this.scene.getNonDeletedElements(),[t]),(!s||r)&&this.store.shouldCaptureIncrement(),this.setState({draggingElement:null,editingElement:null}),this.state.activeTool.locked&&qr(this.interactiveCanvas,this.state),this.focusContainer()}),element:t,excalidrawContainer:this.excalidrawContainerRef.current,app:this}),this.deselectElements(),n(t.text,t.originalText,!1)}deselectElements(){this.setState({selectedElementIds:Fe({},this.state),selectedGroupIds:{},editingGroupId:null,activeEmbeddable:null})}getTextElementAtPosition(t,r){let o=this.getElementAtPosition(t,r,{includeBoundTextElement:!0});return o&&V(o)&&!o.isDeleted?o:null}getElementShape(t){switch(t.type){case"rectangle":case"diamond":case"frame":case"magicframe":case"embeddable":case"image":case"iframe":case"text":case"selection":return Dp(t);case"arrow":case"line":{let r=Ne.get(t)?.[0]??Ne.generateElementShape(t,null)[0],[,,,,o,n]=oe(t,this.scene.getNonDeletedElementsMap());return _p(t)?xv(t,r,[t.x,t.y],t.angle,[o,n]):bv(r,[t.x,t.y],t.angle,[o,n])}case"ellipse":return gv(t);case"freedraw":{let[,,,,r,o]=oe(t,this.scene.getNonDeletedElementsMap());return Ev(t,[r,o],_p(t))}}}getBoundTextShape(t){let r=ue(t,this.scene.getNonDeletedElementsMap());return r?t.type==="arrow"?this.getElementShape({...r,...Z.getBoundTextElementPosition(t,r,this.scene.getNonDeletedElementsMap())}):this.getElementShape(r):null}getElementAtPosition(t,r,o){let n=this.getElementsAtPosition(t,r,o?.includeBoundTextElement,o?.includeLockedElements);if(n.length>1){if(o?.preferSelected){for(let a=n.length-1;a>-1;a--)if(this.state.selectedElementIds[n[a].id])return n[a]}let i=n[n.length-1];return za({x:t,y:r,element:i,shape:this.getElementShape(i),threshold:this.getElementHitThreshold()/2,frameNameBound:re(i)?this.frameNameBoundsCache.get(i):null})?i:n[n.length-2]}return n.length===1?n[0]:null}getElementsAtPosition(t,r,o=!1,n=!1){let i=[],a=this.scene.getNonDeletedElementsMap();return(o&&n?this.scene.getNonDeletedElements():this.scene.getNonDeletedElements().filter(s=>(n||!s.locked)&&(o||!(V(s)&&s.containerId)))).filter(s=>this.hitElement(t,r,s)).filter(s=>{let c=Xt(s,a);return c&&this.state.frameRendering.enabled&&this.state.frameRendering.clip?x1({x:t,y:r},c,a):!0}).filter(s=>go(s)?(i.push(s),!1):!0).concat(i)}getElementHitThreshold(){return ky/this.state.zoom.value}hitElement(t,r,o,n=!0){if(n&&this.state.selectedElementIds[o.id]&&su([o],this.state)){let a=hv(o,this.scene.getNonDeletedElementsMap(),this.getElementHitThreshold());return Ol([t,r],a)}return wv(t,r,this.getBoundTextShape(o))?!0:za({x:t,y:r,element:o,shape:this.getElementShape(o),threshold:this.getElementHitThreshold(),frameNameBound:re(o)?this.frameNameBoundsCache.get(o):null})}getTextBindableContainerAtPosition(t,r){let o=this.scene.getNonDeletedElements(),n=this.scene.getSelectedElements(this.state);if(n.length===1)return on(n[0],!1)?n[0]:null;let i=null;for(let a=o.length-1;a>=0;--a){if(o[a].isDeleted)continue;let[l,s,c,d]=oe(o[a],this.scene.getNonDeletedElementsMap());if(Ce(o[a])&&za({x:t,y:r,element:o[a],shape:this.getElementShape(o[a]),threshold:this.getElementHitThreshold()})){i=o[a];break}else if(l<t&&t<c&&s<r&&r<d){i=o[a];break}}return on(i,!1)?i:null}startTextEditing=({sceneX:t,sceneY:r,insertAtParentCenter:o=!0,container:n})=>{let i=!1,a=o&&this.getTextWysiwygSnappedToCenterPosition(t,r,this.state,n);n&&a&&(ue(n,this.scene.getNonDeletedElementsMap())||(i=!0));let l=null,s=this.scene.getSelectedElements(this.state);s.length===1?V(s[0])?l=s[0]:n?l=ue(s[0],this.scene.getNonDeletedElementsMap()):l=this.getTextElementAtPosition(t,r):l=this.getTextElementAtPosition(t,r);let c=l?.fontFamily||this.state.currentItemFontFamily,d=l?.lineHeight||Xr(c),m=this.state.currentItemFontSize;if(!l&&i&&n&&!Ce(n)){let E=ip(Ze({fontSize:m,fontFamily:c}),d),x=np(m,d),T=Math.max(n.height,x),v=Math.max(n.width,E);H(n,{height:T,width:v}),t=n.x+v/2,r=n.y+T/2,a&&(a=this.getTextWysiwygSnappedToCenterPosition(t,r,this.state,n))}let p=this.getTopLayerFrameAtSceneCoords({x:t,y:r}),u=l||$t({x:a?a.elementCenterX:t,y:a?a.elementCenterY:r,strokeColor:this.state.currentItemStrokeColor,backgroundColor:this.state.currentItemBackgroundColor,fillStyle:this.state.currentItemFillStyle,strokeWidth:this.state.currentItemStrokeWidth,strokeStyle:this.state.currentItemStrokeStyle,roughness:this.state.currentItemRoughness,opacity:this.state.currentItemOpacity,text:"",fontSize:m,fontFamily:c,textAlign:a?"center":this.state.currentItemTextAlign,verticalAlign:a?Tt.MIDDLE:fa,containerId:i?n?.id:void 0,groupIds:n?.groupIds??[],lineHeight:d,angle:n?.angle??0,frameId:p?p.id:null});if(!l&&i&&n&&H(n,{boundElements:(n.boundElements||[]).concat({type:"text",id:u.id})}),this.setState({editingElement:u}),!l)if(n&&i){let h=this.scene.getElementIndex(n.id);this.scene.insertElementAtIndex(u,h+1)}else this.scene.insertElement(u);this.setState({editingElement:u}),this.handleTextWysiwyg(u,{isExistingElement:!!l})};handleCanvasDoubleClick=t=>{if(this.state.multiElement||this.state.activeTool.type!=="selection")return;let r=this.scene.getSelectedElements(this.state);if(r.length===1&&ce(r[0])&&t[C.CTRL_OR_CMD]&&(!this.state.editingLinearElement||this.state.editingLinearElement.elementId!==r[0].id)){this.store.shouldCaptureIncrement(),this.setState({editingLinearElement:new Z(r[0])});return}jr(this.interactiveCanvas);let{x:o,y:n}=je(t,this.state);if(Vn(this.state).length>0){let a=this.getElementAtPosition(o,n),l=a&&T2(a,this.state.selectedGroupIds);if(l){this.store.shouldCaptureIncrement(),this.setState(s=>({...s,...nr({editingGroupId:l,selectedElementIds:{[a.id]:!0}},this.scene.getNonDeletedElements(),s,this)}));return}}if(jr(this.interactiveCanvas),!t[C.CTRL_OR_CMD]&&!this.state.viewModeEnabled){let a=this.getElementAtPosition(o,n);if(rr(a)){this.setState({activeEmbeddable:{element:a,state:"active"}});return}let l=this.getTextBindableContainerAtPosition(o,n);if(l&&(lr(l)||!hr(l.backgroundColor)||za({x:o,y:n,element:l,shape:this.getElementShape(l),threshold:this.getElementHitThreshold()}))){let s=ap(l,this.state,this.scene.getNonDeletedElementsMap());o=s.x,n=s.y}this.startTextEditing({sceneX:o,sceneY:n,insertAtParentCenter:!t.altKey,container:l})}};getElementLinkAtPosition=(t,r)=>{let o=this.scene.getNonDeletedElements().slice().reverse(),n=1/0;return o.find((i,a)=>(r&&i.id===r.id&&(n=a),i.link&&a<=n&&Np(i,this.scene.getNonDeletedElementsMap(),this.state,[t.x,t.y],this.device.editor.isMobile)))};redirectToLink=(t,r)=>{let o=It(this.lastPointerDownEvent.clientX,this.lastPointerDownEvent.clientY,this.lastPointerUpEvent.clientX,this.lastPointerUpEvent.clientY);if(!this.hitLinkElement||r&&o>Nn||!r&&o!==0)return;let n=je(this.lastPointerDownEvent,this.state),i=this.scene.getNonDeletedElementsMap(),a=Np(this.hitLinkElement,i,this.state,[n.x,n.y],this.device.editor.isMobile),l=je(this.lastPointerUpEvent,this.state),s=Np(this.hitLinkElement,i,this.state,[l.x,l.y],this.device.editor.isMobile);if(a&&s){let c=this.hitLinkElement.link;if(c){c=yr(c);let d;if(this.props.onLinkOpen&&(d=Rm("excalidraw-link",t.nativeEvent),this.props.onLinkOpen({...this.hitLinkElement,link:c},d)),!d?.defaultPrevented){let m=mp(c)?"_self":"_blank",p=window.open(void 0,m);p&&(p.opener=null,p.location=c)}}}};getTopLayerFrameAtSceneCoords=t=>{let r=this.scene.getNonDeletedElementsMap(),o=this.scene.getNonDeletedFramesLikes().filter(n=>x1(t,n,r));return o.length?o[o.length-1]:null};handleCanvasPointerMove=t=>{if(this.props.interactive===!1)return!1;this.savePointer(t.clientX,t.clientY,this.state.cursorButton),this.lastPointerMoveEvent=t.nativeEvent,Ue.pointers.has(t.pointerId)&&Ue.pointers.set(t.pointerId,{x:t.clientX,y:t.clientY});let r=Ue.initialScale;if(Ue.pointers.size===2&&Ue.lastCenter&&r&&Ue.initialDistance){let p=Hx(Ue.pointers),u=p.x-Ue.lastCenter.x,h=p.y-Ue.lastCenter.y;Ue.lastCenter=p;let E=Ux(Array.from(Ue.pointers.values())),x=this.state.activeTool.type==="freedraw"&&this.state.penMode?1:E/Ue.initialDistance,T=x?En(r*x):this.state.zoom.value;this.setState(v=>{let w=ti({viewportX:p.x,viewportY:p.y,nextZoom:T},v);this.translateCanvas({zoom:w.zoom,scrollX:w.scrollX+u/T,scrollY:w.scrollY+h/T,shouldCacheIgnoreZoom:!0})}),this.resetShouldCacheIgnoreZoomDebounced()}else Ue.lastCenter=Ue.initialDistance=Ue.initialScale=null;if(El||sm||J0||Go(this.state))return;let n=Xx(Q0,t.clientX-this.state.offsetLeft,t.clientY-this.state.offsetTop).isOverEither;!this.state.draggingElement&&!this.state.multiElement&&(n?jr(this.interactiveCanvas):qr(this.interactiveCanvas,this.state));let i=je(t,this.state),{x:a,y:l}=i;if(!this.state.draggingElement&&q4(this.state.activeTool.type)){let{originOffset:p,snapLines:u}=j4(this.scene.getNonDeletedElements(),this.state,{x:a,y:l},t,this.scene.getNonDeletedElementsMap());this.setState(h=>{let E=Nm(h.snapLines,u),x=h.originSnapOffset?Nm(h.originSnapOffset,p):p;return h.snapLines===E&&h.originSnapOffset===x?null:{snapLines:E,originSnapOffset:x}})}else this.state.draggingElement||this.setState(p=>p.snapLines.length?{snapLines:[]}:null);if(this.state.editingLinearElement&&!this.state.editingLinearElement.isDragging){let p=Z.handlePointerMove(t,a,l,this.state,this.scene.getNonDeletedElementsMap());p&&p!==this.state.editingLinearElement&&j0(()=>{this.setState({editingLinearElement:p})}),p?.lastUncommittedPoint!=null?this.maybeSuggestBindingAtCursor(i):j0(()=>{this.setState({suggestedBindings:[]})})}if(Jg(this.state.activeTool.type)){let{draggingElement:p}=this.state;Wt(p,!1)?this.maybeSuggestBindingsForLinearElementAtCoords(p,[i],this.state.startBoundElement):this.maybeSuggestBindingAtCursor(i)}if(this.state.multiElement){let{multiElement:p}=this.state,{x:u,y:h}=p,{points:E,lastCommittedPoint:x}=p,T=E[E.length-1];if(qr(this.interactiveCanvas,this.state),T===x)It(a-u,l-h,T[0],T[1])>=Tl?H(p,{points:[...E,[a-u,l-h]]}):$e(this.interactiveCanvas,Re.POINTER);else if(E.length>2&&x&&It(a-u,l-h,x[0],x[1])<Tl)$e(this.interactiveCanvas,Re.POINTER),H(p,{points:E.slice(0,-1)});else{let[v,w]=Pt(a,l,t[C.CTRL_OR_CMD]?null:this.state.gridSize),[I,L]=p?.lastCommittedPoint??[0,0],A=v-u-I,M=w-h-L;ka(t)&&({width:A,height:M}=Hl(I+u,L+h,v,w)),br(E,this.state.zoom.value)&&$e(this.interactiveCanvas,Re.POINTER),H(p,{points:[...E.slice(0,-1),[I+A,L+M]]})}return}if(!!t.buttons||this.state.activeTool.type!=="selection"&&this.state.activeTool.type!=="text"&&this.state.activeTool.type!=="eraser")return;let c=this.scene.getNonDeletedElements(),d=this.scene.getSelectedElements(this.state);if(d.length===1&&!n&&!this.state.editingLinearElement){if(this.state.selectedLinearElement&&this.handleHoverSelectedLinearElement(this.state.selectedLinearElement,a,l),!this.state.selectedLinearElement||this.state.selectedLinearElement.hoverPointIndex===-1){let p=cu(c,this.state,a,l,this.state.zoom,t.pointerType,this.scene.getNonDeletedElementsMap(),this.device);if(p&&p.transformHandleType){$e(this.interactiveCanvas,mu(p));return}}}else if(d.length>1&&!n){let p=du(Ae(d),a,l,this.state.zoom,t.pointerType,this.device);if(p){$e(this.interactiveCanvas,mu({transformHandleType:p}));return}}let m=this.getElementAtPosition(i.x,i.y);this.hitLinkElement=this.getElementLinkAtPosition(i,m),!Pr(this.state)&&(this.hitLinkElement&&!this.state.selectedElementIds[this.hitLinkElement.id]?($e(this.interactiveCanvas,Re.POINTER),a5(this.hitLinkElement,this.state,this.scene.getNonDeletedElementsMap())):(l5(),m&&(m.link||Lt(m))&&this.state.selectedElementIds[m.id]&&!this.state.contextMenu&&!this.state.showHyperlinkPopup?this.setState({showHyperlinkPopup:"info"}):this.state.activeTool.type==="text"?$e(this.interactiveCanvas,V(m)?Re.TEXT:Re.CROSSHAIR):this.state.viewModeEnabled?$e(this.interactiveCanvas,Re.GRAB):n?$e(this.interactiveCanvas,Re.AUTO):this.state.selectedLinearElement?this.handleHoverSelectedLinearElement(this.state.selectedLinearElement,a,l):t[C.CTRL_OR_CMD]?$e(this.interactiveCanvas,Re.AUTO):(m||this.isHittingCommonBoundingBoxOfSelectedElements(i,d))&&!m?.locked&&(m&&rr(m)&&this.isIframeLikeElementCenter(m,t,a,l)?($e(this.interactiveCanvas,Re.POINTER),this.setState({activeEmbeddable:{element:m,state:"hover"}})):($e(this.interactiveCanvas,Re.MOVE),this.state.activeEmbeddable?.state==="hover"&&this.setState({activeEmbeddable:null})))))};handleEraser=(t,r,o)=>{this.eraserTrail.addPointToPath(o.x,o.y);let n=!1,i=new Set,a=this.scene.getNonDeletedElements(),l=p=>{for(let u of p){if(u.locked)return;if(t.altKey?this.elementsPendingErasure.delete(u.id)&&(n=!0):this.elementsPendingErasure.has(u.id)||(n=!0,this.elementsPendingErasure.add(u.id)),n&&u.groupIds?.length){let h=u.groupIds.at(-1);if(!i.has(h)){i.add(h);let E=it(a,h);for(let x of E)t.altKey?this.elementsPendingErasure.delete(x.id):this.elementsPendingErasure.add(x.id)}}}},s=It(r.lastCoords.x,r.lastCoords.y,o.x,o.y),c=this.getElementHitThreshold(),d={...r.lastCoords},m=0;for(;m<=s;){let p=this.getElementsAtPosition(d.x,d.y);if(l(p),m===s)break;m=Math.min(m+c,s);let u=m/s,h=(1-u)*d.x+u*o.x,E=(1-u)*d.y+u*o.y;d.x=h,d.y=E}if(r.lastCoords.x=o.x,r.lastCoords.y=o.y,n){for(let p of this.scene.getNonDeletedElements())Pe(p)&&(this.elementsPendingErasure.has(p.id)||this.elementsPendingErasure.has(p.containerId))&&(t.altKey?(this.elementsPendingErasure.delete(p.id),this.elementsPendingErasure.delete(p.containerId)):(this.elementsPendingErasure.add(p.id),this.elementsPendingErasure.add(p.containerId)));this.elementsPendingErasure=new Set(this.elementsPendingErasure),this.onSceneUpdated()}};handleTouchMove=t=>{cm=!0};handleHoverSelectedLinearElement(t,r,o){let n=this.scene.getNonDeletedElementsMap(),i=Z.getElement(t.elementId,n);if(i)if(this.state.selectedLinearElement){let a=-1,l=null;za({x:r,y:o,element:i,shape:this.getElementShape(i)})?(a=Z.getPointIndexUnderCursor(i,n,this.state.zoom,r,o),l=Z.getSegmentMidpointHitCoords(t,{x:r,y:o},this.state,this.scene.getNonDeletedElementsMap()),a>=0||l?$e(this.interactiveCanvas,Re.POINTER):this.hitElement(r,o,i)&&$e(this.interactiveCanvas,Re.MOVE)):this.hitElement(r,o,i)&&$e(this.interactiveCanvas,Re.MOVE),this.state.selectedLinearElement.hoverPointIndex!==a&&this.setState({selectedLinearElement:{...this.state.selectedLinearElement,hoverPointIndex:a}}),Z.arePointsEqual(this.state.selectedLinearElement.segmentMidPointHoveredCoords,l)||this.setState({selectedLinearElement:{...this.state.selectedLinearElement,segmentMidPointHoveredCoords:l}})}else $e(this.interactiveCanvas,Re.AUTO)}handleCanvasPointerDown=t=>{if(this.maybeCleanupAfterMissingPointerUp(t.nativeEvent),this.maybeUnfollowRemoteUser(),this.state.contextMenu&&this.setState({contextMenu:null}),this.state.snapLines&&this.setAppState({snapLines:[]}),this.updateGestureOnPointerDown(t),t.pointerType==="touch"&&this.state.draggingElement&&this.state.draggingElement.type==="freedraw"){let c=this.state.draggingElement;this.updateScene({...c.points.length<10?{elements:this.scene.getElementsIncludingDeleted().filter(d=>d.id!==c.id)}:{},appState:{draggingElement:null,editingElement:null,startBoundElement:null,suggestedBindings:[],selectedElementIds:Fe(Object.keys(this.state.selectedElementIds).filter(d=>d!==c.id).reduce((d,m)=>(d[m]=this.state.selectedElementIds[m],d),{}),this.state)},storeAction:_.UPDATE});return}let r=document.getSelection();if(r?.anchorNode&&r.removeAllRanges(),this.maybeOpenContextMenuAfterPointerDownOnTouchDevices(t),!this.state.penDetected&&t.pointerType==="pen"&&this.setState(c=>({penMode:!0,penDetected:!0})),!this.device.isTouchScreen&&["pen","touch"].includes(t.pointerType)&&(this.device=Ll(this.device,{isTouchScreen:!0})),sm||(this.lastPointerDownEvent=t,this.props.interactive!==!1&&this.handleCanvasPanUsingWheelOrSpaceDrag(t)))return;if(this.setState({lastPointerDownWith:t.pointerType,cursorButton:"down"}),this.savePointer(t.clientX,t.clientY,"down"),t.button===hi.ERASER&&this.state.activeTool.type!==St.eraser){this.setState({activeTool:tt(this.state,{type:St.eraser,lastActiveToolBeforeEraser:this.state.activeTool})},()=>{this.handleCanvasPointerDown(t);let c=()=>{d(),m?.(),Pr(this.state)&&this.setState({activeTool:tt(this.state,{...this.state.activeTool.lastActiveTool||{type:St.selection},lastActiveToolBeforeEraser:null})})},d=Et(window,"pointerup",c,{once:!0}),m;requestAnimationFrame(()=>{m=this.missingPointerEventCleanupEmitter.once(c)})});return}if(t.button!==hi.MAIN&&t.button!==hi.TOUCH&&t.button!==hi.ERASER||Ue.pointers.size>1)return;let o=this.initialPointerDownState(t);if(this.setState({selectedElementsAreBeingDragged:!1}),this.props.interactive!==!1&&this.handleDraggingScrollBar(t,o)||(this.clearSelectionIfNotUsingSelection(),this.updateBindingEnabledOnPointerMove(t),this.props.interactive!==!1&&this.handleSelectionOnPointerDown(t,o))||!(!this.state.penMode||t.pointerType!=="touch"||this.state.activeTool.type==="selection"||this.state.activeTool.type==="text"||this.state.activeTool.type==="image"))return;if(this.state.activeTool.type==="text"){this.handleTextOnPointerDown(t,o);return}else if(this.state.activeTool.type==="arrow"||this.state.activeTool.type==="line")this.handleLinearElementOnPointerDown(t,this.state.activeTool.type,o);else if(this.state.activeTool.type==="image"){$e(this.interactiveCanvas,Re.CROSSHAIR);let c=this.state.pendingImageElementId&&this.scene.getElement(this.state.pendingImageElementId);if(!c)return;this.setState({draggingElement:c,editingElement:c,pendingImageElementId:null,multiElement:null});let{x:d,y:m}=je(t,this.state),p=this.getTopLayerFrameAtSceneCoords({x:d,y:m});H(c,{x:d,y:m,frameId:p?p.id:null})}else this.state.activeTool.type==="freedraw"?this.handleFreeDrawElementOnPointerDown(t,this.state.activeTool.type,o):this.state.activeTool.type==="custom"?qr(this.interactiveCanvas,this.state):this.state.activeTool.type===St.frame||this.state.activeTool.type===St.magicframe?this.createFrameElementOnPointerDown(o,this.state.activeTool.type):this.state.activeTool.type==="laser"?this.laserTrails.startPath(o.lastCoords.x,o.lastCoords.y):this.state.activeTool.type!=="eraser"&&this.state.activeTool.type!=="hand"&&this.createGenericElementOnPointerDown(this.state.activeTool.type,o);this.props?.onPointerDown?.(this.state.activeTool,o),this.onPointerDownEmitter.trigger(this.state.activeTool,o,t),this.state.activeTool.type==="eraser"&&this.eraserTrail.startPath(o.lastCoords.x,o.lastCoords.y);let i=this.onPointerMoveFromPointerDownHandler(o),a=this.onPointerUpFromPointerDownHandler(o),l=this.onKeyDownFromPointerDownHandler(o),s=this.onKeyUpFromPointerDownHandler(o);this.missingPointerEventCleanupEmitter.once(c=>a(c||t.nativeEvent)),(!this.state.viewModeEnabled||this.state.activeTool.type==="laser")&&(window.addEventListener("pointermove",i),window.addEventListener("pointerup",a),window.addEventListener("keydown",l),window.addEventListener("keyup",s),o.eventListeners.onMove=i,o.eventListeners.onUp=a,o.eventListeners.onKeyUp=s,o.eventListeners.onKeyDown=l)};handleCanvasPointerUp=t=>{this.removePointer(t),this.lastPointerUpEvent=t;let r=je({clientX:t.clientX,clientY:t.clientY},this.state),o=t.timeStamp-(this.lastPointerDownEvent?.timeStamp??0);if(this.device.editor.isMobile&&o<300){let n=this.getElementAtPosition(r.x,r.y);if(rr(n)&&this.isIframeLikeElementCenter(n,t,r.x,r.y)){this.handleEmbeddableCenterClick(n);return}}if(this.device.isTouchScreen){let n=this.getElementAtPosition(r.x,r.y);this.hitLinkElement=this.getElementLinkAtPosition(r,n)}this.hitLinkElement&&!this.state.selectedElementIds[this.hitLinkElement.id]?o<300&&rr(this.hitLinkElement)&&!s1(this.hitLinkElement,this.scene.getNonDeletedElementsMap(),this.state,[r.x,r.y])?this.handleEmbeddableCenterClick(this.hitLinkElement):this.redirectToLink(t,this.device.isTouchScreen):this.state.viewModeEnabled&&this.setState({activeEmbeddable:null,selectedElementIds:{}})};maybeOpenContextMenuAfterPointerDownOnTouchDevices=t=>{t.pointerType==="touch"&&(cm=!1,da?cm=!0:da=window.setTimeout(()=>{da=0,cm||this.handleCanvasContextMenu(t)},_y))};resetContextMenuTimer=()=>{clearTimeout(da),da=0,cm=!1};maybeCleanupAfterMissingPointerUp=t=>{dm?.(),this.missingPointerEventCleanupEmitter.trigger(t).clear()};handleCanvasPanUsingWheelOrSpaceDrag=t=>{if(!(Ue.pointers.size<=1&&(t.button===hi.WHEEL||t.button===hi.MAIN&&El||Go(this.state)||this.state.viewModeEnabled))||V(this.state.editingElement))return!1;sm=!0,t.preventDefault();let r=!1,o=typeof window===void 0?!1:/Linux/.test(window.navigator.platform);$e(this.interactiveCanvas,Re.GRABBING);let{clientX:n,clientY:i}=t,a=vg(s=>{let c=n-s.clientX,d=i-s.clientY;if(n=s.clientX,i=s.clientY,o&&!r&&(Math.abs(c)>1||Math.abs(d)>1)){r=!0;let m=u=>{document.body.removeEventListener("paste",m),u.stopPropagation()},p=()=>{setTimeout(()=>{document.body.removeEventListener("paste",m),window.removeEventListener("pointerup",p)},100)};document.body.addEventListener("paste",m),window.addEventListener("pointerup",p)}this.translateCanvas({scrollX:this.state.scrollX-c/this.state.zoom.value,scrollY:this.state.scrollY-d/this.state.zoom.value})}),l=ut(dm=()=>{dm=null,sm=!1,El||(this.state.viewModeEnabled?$e(this.interactiveCanvas,Re.GRAB):qr(this.interactiveCanvas,this.state)),this.setState({cursorButton:"up"}),this.savePointer(t.clientX,t.clientY,"up"),window.removeEventListener("pointermove",a),window.removeEventListener("pointerup",l),window.removeEventListener("blur",l),a.flush()});return window.addEventListener("blur",l),window.addEventListener("pointermove",a,{passive:!0}),window.addEventListener("pointerup",l),!0};updateGestureOnPointerDown(t){Ue.pointers.set(t.pointerId,{x:t.clientX,y:t.clientY}),Ue.pointers.size===2&&(Ue.lastCenter=Hx(Ue.pointers),Ue.initialScale=this.state.zoom.value,Ue.initialDistance=Ux(Array.from(Ue.pointers.values())))}initialPointerDownState(t){let r=je(t,this.state),o=this.scene.getSelectedElements(this.state),[n,i,a,l]=Ae(o);return{origin:r,withCmdOrCtrl:t[C.CTRL_OR_CMD],originInGrid:Ro(Pt(r.x,r.y,t[C.CTRL_OR_CMD]?null:this.state.gridSize)),scrollbars:Xx(Q0,t.clientX-this.state.offsetLeft,t.clientY-this.state.offsetTop),lastCoords:{...r},originalElements:this.scene.getNonDeletedElements().reduce((s,c)=>(s.set(c.id,Yn(c)),s),new Map),resize:{handleType:!1,isResizing:!1,offset:{x:0,y:0},arrowDirection:"origin",center:{x:(a+n)/2,y:(l+i)/2}},hit:{element:null,allHitElements:[],wasAddedToSelection:!1,hasBeenDuplicated:!1,hasHitCommonBoundingBoxOfSelectedElements:this.isHittingCommonBoundingBoxOfSelectedElements(r,o)},drag:{hasOccurred:!1,offset:null},eventListeners:{onMove:null,onUp:null,onKeyUp:null,onKeyDown:null},boxSelection:{hasOccurred:!1}}}handleDraggingScrollBar(t,r){if(!(r.scrollbars.isOverEither&&!this.state.multiElement))return!1;J0=!0,r.lastCoords.x=t.clientX,r.lastCoords.y=t.clientY;let o=vg(i=>{i.target instanceof HTMLElement&&this.handlePointerMoveOverScrollbars(i,r)}),n=ut(()=>{dm=null,J0=!1,qr(this.interactiveCanvas,this.state),this.setState({cursorButton:"up"}),this.savePointer(t.clientX,t.clientY,"up"),window.removeEventListener("pointermove",o),window.removeEventListener("pointerup",n),o.flush()});return dm=n,window.addEventListener("pointermove",o),window.addEventListener("pointerup",n),!0}clearSelectionIfNotUsingSelection=()=>{this.state.activeTool.type!=="selection"&&this.setState({selectedElementIds:Fe({},this.state),selectedGroupIds:{},editingGroupId:null,activeEmbeddable:null})};handleSelectionOnPointerDown=(t,r)=>{if(this.state.activeTool.type==="selection"){let o=this.scene.getNonDeletedElements(),n=this.scene.getNonDeletedElementsMap(),i=this.scene.getSelectedElements(this.state);if(i.length===1&&!this.state.editingLinearElement&&!(this.state.selectedLinearElement&&this.state.selectedLinearElement.hoverPointIndex!==-1)){let a=cu(o,this.state,r.origin.x,r.origin.y,this.state.zoom,t.pointerType,this.scene.getNonDeletedElementsMap(),this.device);a!=null&&(this.setState({resizingElement:a.element}),r.resize.handleType=a.transformHandleType)}else i.length>1&&(r.resize.handleType=du(Ae(i),r.origin.x,r.origin.y,this.state.zoom,t.pointerType,this.device));if(r.resize.handleType)r.resize.isResizing=!0,r.resize.offset=Ro(M1(r.resize.handleType,i,n,r.origin.x,r.origin.y)),i.length===1&&ce(i[0])&&i[0].points.length===2&&(r.resize.arrowDirection=L1(r.resize.handleType,i[0]));else{if(this.state.selectedLinearElement){let s=this.state.editingLinearElement||this.state.selectedLinearElement,c=Z.handlePointerDown(t,this.state,this.store,r.origin,s,this);if(c.hitElement&&(r.hit.element=c.hitElement),c.linearElementEditor&&(this.setState({selectedLinearElement:c.linearElementEditor}),this.state.editingLinearElement&&this.setState({editingLinearElement:c.linearElementEditor})),c.didAddPoint)return!0}if(r.hit.element=r.hit.element??this.getElementAtPosition(r.origin.x,r.origin.y),r.hit.element&&this.getElementLinkAtPosition({x:r.origin.x,y:r.origin.y},r.hit.element))return!1;r.hit.allHitElements=this.getElementsAtPosition(r.origin.x,r.origin.y);let a=r.hit.element,l=r.hit.allHitElements.some(s=>this.isASelectedElement(s));if((a===null||!l)&&!t.shiftKey&&!r.hit.hasHitCommonBoundingBoxOfSelectedElements&&this.clearSelection(a),this.state.editingLinearElement)this.setState({selectedElementIds:Fe({[this.state.editingLinearElement.elementId]:!0},this.state)});else if(a!=null){if(t[C.CTRL_OR_CMD])return this.state.selectedElementIds[a.id]||(r.hit.wasAddedToSelection=!0),this.setState(s=>({...v2(s,a),previousSelectedElementIds:this.state.selectedElementIds})),!1;this.state.selectedElementIds[a.id]||(this.state.editingGroupId&&!_a(a,this.state.editingGroupId)&&this.setState({selectedElementIds:Fe({},this.state),selectedGroupIds:{},editingGroupId:null,activeEmbeddable:null}),!l&&!r.hit.hasHitCommonBoundingBoxOfSelectedElements&&(this.setState(s=>{let c={...s.selectedElementIds,[a.id]:!0},d=[];if(Object.keys(s.selectedElementIds).forEach(m=>{let p=this.scene.getElement(m);p&&d.push(p)}),re(a))eo(d,a.id).forEach(m=>{delete c[m.id]});else if(a.frameId)c[a.frameId]&&delete c[a.id];else{let m=a.groupIds,p=new Set(m.flatMap(u=>it(this.scene.getNonDeletedElements(),u)).filter(u=>re(u)).map(u=>u.id));p.size>0&&d.forEach(u=>{u.frameId&&p.has(u.frameId)&&(delete c[u.id],u.groupIds.flatMap(h=>it(this.scene.getNonDeletedElements(),h)).forEach(h=>{delete c[h.id]}))})}return{...nr({editingGroupId:s.editingGroupId,selectedElementIds:c},this.scene.getNonDeletedElements(),s,this),showHyperlinkPopup:a.link||Lt(a)?"info":!1}}),r.hit.wasAddedToSelection=!0))}this.setState({previousSelectedElementIds:this.state.selectedElementIds})}}return!1};isASelectedElement(t){return t!=null&&this.state.selectedElementIds[t.id]}isHittingCommonBoundingBoxOfSelectedElements(t,r){if(r.length<2)return!1;let o=this.getElementHitThreshold(),[n,i,a,l]=Ae(r);return t.x>n-o&&t.x<a+o&&t.y>i-o&&t.y<l+o}handleTextOnPointerDown=(t,r)=>{if(V(this.state.editingElement))return;let o=r.origin.x,n=r.origin.y,i=this.getElementAtPosition(o,n,{includeBoundTextElement:!0}),a=this.getTextBindableContainerAtPosition(o,n);lr(i)&&(a=i,o=i.x+i.width/2,n=i.y+i.height/2),this.startTextEditing({sceneX:o,sceneY:n,insertAtParentCenter:!t.altKey,container:a}),jr(this.interactiveCanvas),this.state.activeTool.locked||this.setState({activeTool:tt(this.state,{type:"selection"})})};handleFreeDrawElementOnPointerDown=(t,r,o)=>{let[n,i]=Pt(o.origin.x,o.origin.y,null),a=this.getTopLayerFrameAtSceneCoords({x:n,y:i}),l=R2({type:r,x:n,y:i,strokeColor:this.state.currentItemStrokeColor,backgroundColor:this.state.currentItemBackgroundColor,fillStyle:this.state.currentItemFillStyle,strokeWidth:this.state.currentItemStrokeWidth,strokeStyle:this.state.currentItemStrokeStyle,roughness:this.state.currentItemRoughness,opacity:this.state.currentItemOpacity,roundness:null,simulatePressure:t.pressure===.5,locked:!1,frameId:a?a.id:null});this.setState(d=>{let m={...d.selectedElementIds};return delete m[l.id],{selectedElementIds:Fe(m,d)}});let s=l.simulatePressure?l.pressures:[...l.pressures,t.pressure];H(l,{points:[[0,0]],pressures:s});let c=pn(o.origin,this);this.scene.insertElement(l),this.setState({draggingElement:l,editingElement:l,startBoundElement:c,suggestedBindings:[]})};insertIframeElement=({sceneX:t,sceneY:r,width:o,height:n})=>{let[i,a]=Pt(t,r,this.lastPointerDownEvent?.[C.CTRL_OR_CMD]?null:this.state.gridSize),l=D2({type:"iframe",x:i,y:a,strokeColor:"transparent",backgroundColor:"transparent",fillStyle:this.state.currentItemFillStyle,strokeWidth:this.state.currentItemStrokeWidth,strokeStyle:this.state.currentItemStrokeStyle,roughness:this.state.currentItemRoughness,roundness:this.getCurrentItemRoundness("iframe"),opacity:this.state.currentItemOpacity,locked:!1,width:o,height:n});return this.scene.insertElement(l),l};insertEmbeddableElement=({sceneX:t,sceneY:r,link:o})=>{let[n,i]=Pt(t,r,this.lastPointerDownEvent?.[C.CTRL_OR_CMD]?null:this.state.gridSize),a=$n(o);if(!a)return;a.error instanceof URIError&&this.setToast({message:b("toast.unrecognizedLinkFormat"),closable:!0});let l=Gf({type:"embeddable",x:n,y:i,strokeColor:"transparent",backgroundColor:"transparent",fillStyle:this.state.currentItemFillStyle,strokeWidth:this.state.currentItemStrokeWidth,strokeStyle:this.state.currentItemStrokeStyle,roughness:this.state.currentItemRoughness,roundness:this.getCurrentItemRoundness("embeddable"),opacity:this.state.currentItemOpacity,locked:!1,width:a.intrinsicSize.w,height:a.intrinsicSize.h,link:o});return this.scene.insertElement(l),l};createImageElement=({sceneX:t,sceneY:r,addToFrameUnderCursor:o=!0})=>{let[n,i]=Pt(t,r,this.lastPointerDownEvent?.[C.CTRL_OR_CMD]?null:this.state.gridSize),a=o?this.getTopLayerFrameAtSceneCoords({x:n,y:i}):null;return Mc({type:"image",x:n,y:i,strokeColor:this.state.currentItemStrokeColor,backgroundColor:this.state.currentItemBackgroundColor,fillStyle:this.state.currentItemFillStyle,strokeWidth:this.state.currentItemStrokeWidth,strokeStyle:this.state.currentItemStrokeStyle,roughness:this.state.currentItemRoughness,roundness:null,opacity:this.state.currentItemOpacity,locked:!1,frameId:a?a.id:null})};handleLinearElementOnPointerDown=(t,r,o)=>{if(this.state.multiElement){let{multiElement:n}=this.state;if(n.type==="line"&&br(n.points,this.state.zoom.value)){H(n,{lastCommittedPoint:n.points[n.points.length-1]}),this.actionManager.executeAction(io);return}let{x:i,y:a,lastCommittedPoint:l}=n;if(n.points.length>1&&l&&It(o.origin.x-i,o.origin.y-a,l[0],l[1])<Tl){this.actionManager.executeAction(io);return}this.setState(s=>({selectedElementIds:Fe({...s.selectedElementIds,[n.id]:!0},s)})),H(n,{lastCommittedPoint:n.points[n.points.length-1]}),$e(this.interactiveCanvas,Re.POINTER)}else{let[n,i]=Pt(o.origin.x,o.origin.y,t[C.CTRL_OR_CMD]?null:this.state.gridSize),a=this.getTopLayerFrameAtSceneCoords({x:n,y:i}),{currentItemStartArrowhead:l,currentItemEndArrowhead:s}=this.state,[c,d]=r==="arrow"?[l,s]:[null,null],m=xo({type:r,x:n,y:i,strokeColor:this.state.currentItemStrokeColor,backgroundColor:this.state.currentItemBackgroundColor,fillStyle:this.state.currentItemFillStyle,strokeWidth:this.state.currentItemStrokeWidth,strokeStyle:this.state.currentItemStrokeStyle,roughness:this.state.currentItemRoughness,opacity:this.state.currentItemOpacity,roundness:this.state.currentItemRoundness==="round"?{type:ct.PROPORTIONAL_RADIUS}:null,startArrowhead:c,endArrowhead:d,locked:!1,frameId:a?a.id:null});this.setState(u=>{let h={...u.selectedElementIds};return delete h[m.id],{selectedElementIds:Fe(h,u)}}),H(m,{points:[...m.points,[0,0]]});let p=pn(o.origin,this);this.scene.insertElement(m),this.setState({draggingElement:m,editingElement:m,startBoundElement:p,suggestedBindings:[]})}};getCurrentItemRoundness(t){return this.state.currentItemRoundness==="round"?{type:nn(t)?ct.ADAPTIVE_RADIUS:ct.PROPORTIONAL_RADIUS}:null}createGenericElementOnPointerDown=(t,r)=>{let[o,n]=Pt(r.origin.x,r.origin.y,this.lastPointerDownEvent?.[C.CTRL_OR_CMD]?null:this.state.gridSize),i=this.getTopLayerFrameAtSceneCoords({x:o,y:n}),a={x:o,y:n,strokeColor:this.state.currentItemStrokeColor,backgroundColor:this.state.currentItemBackgroundColor,fillStyle:this.state.currentItemFillStyle,strokeWidth:this.state.currentItemStrokeWidth,strokeStyle:this.state.currentItemStrokeStyle,roughness:this.state.currentItemRoughness,opacity:this.state.currentItemOpacity,roundness:this.getCurrentItemRoundness(t),locked:!1,frameId:i?i.id:null},l;t==="embeddable"?l=Gf({type:"embeddable",...a}):l=Jr({type:t,...a}),l.type==="selection"?this.setState({selectionElement:l,draggingElement:l}):(this.scene.insertElement(l),this.setState({multiElement:null,draggingElement:l,editingElement:l}))};createFrameElementOnPointerDown=(t,r)=>{let[o,n]=Pt(t.origin.x,t.origin.y,this.lastPointerDownEvent?.[C.CTRL_OR_CMD]?null:this.state.gridSize),i={x:o,y:n,opacity:this.state.currentItemOpacity,locked:!1,...et},a=r===St.magicframe?kc(i):bp(i);this.scene.insertElement(a),this.setState({multiElement:null,draggingElement:a,editingElement:a})};maybeCacheReferenceSnapPoints(t,r,o=!1){di({event:t,appState:this.state,selectedElements:r})&&(o||!Mo.getReferenceSnapPoints())&&Mo.setReferenceSnapPoints(K4(this.scene.getNonDeletedElements(),r,this.state,this.scene.getNonDeletedElementsMap()))}maybeCacheVisibleGaps(t,r,o=!1){di({event:t,appState:this.state,selectedElements:r})&&(o||!Mo.getVisibleGaps())&&Mo.setVisibleGaps(Y4(this.scene.getNonDeletedElements(),r,this.state,this.scene.getNonDeletedElementsMap()))}onKeyDownFromPointerDownHandler(t){return ut(r=>{this.maybeHandleResize(t,r)||this.maybeDragNewGenericElement(t,r)})}onKeyUpFromPointerDownHandler(t){return ut(r=>{r.key===C.ALT&&r.preventDefault(),!this.maybeHandleResize(t,r)&&this.maybeDragNewGenericElement(t,r)})}onPointerMoveFromPointerDownHandler(t){return vg(r=>{if(t.drag.offset===null&&(t.drag.offset=Ro(_1(this.scene.getSelectedElements(this.state),t.origin.x,t.origin.y))),!(r.target instanceof HTMLElement)||this.handlePointerMoveOverScrollbars(r,t))return;let n=je(r,this.state);if(Pr(this.state)){this.handleEraser(r,t,n);return}this.state.activeTool.type==="laser"&&this.laserTrails.addPointToPath(n.x,n.y);let[i,a]=Pt(n.x,n.y,r[C.CTRL_OR_CMD]?null:this.state.gridSize);if(!t.drag.hasOccurred&&(this.state.activeTool.type==="arrow"||this.state.activeTool.type==="line")&&It(n.x,n.y,t.origin.x,t.origin.y)<Nn)return;if(t.resize.isResizing&&(t.lastCoords.x=n.x,t.lastCoords.y=n.y,this.maybeHandleResize(t,r)))return!0;let l=this.scene.getNonDeletedElementsMap();if(this.state.selectedLinearElement){let m=this.state.editingLinearElement||this.state.selectedLinearElement;if(Z.shouldAddMidpoint(this.state.selectedLinearElement,n,this.state,l)){let u=Z.addMidpoint(this.state.selectedLinearElement,n,this.state,!r[C.CTRL_OR_CMD],l);if(!u)return;j0(()=>{this.state.selectedLinearElement&&this.setState({selectedLinearElement:{...this.state.selectedLinearElement,pointerDownState:u.pointerDownState,selectedPointsIndices:u.selectedPointsIndices}}),this.state.editingLinearElement&&this.setState({editingLinearElement:{...this.state.editingLinearElement,pointerDownState:u.pointerDownState,selectedPointsIndices:u.selectedPointsIndices}})});return}else if(m.pointerDownState.segmentMidpoint.value!==null&&!m.pointerDownState.segmentMidpoint.added)return;if(Z.handlePointDragging(r,this.state,n.x,n.y,(u,h)=>{this.maybeSuggestBindingsForLinearElementAtCoords(u,h)},m,this.scene.getNonDeletedElementsMap())){t.lastCoords.x=n.x,t.lastCoords.y=n.y,t.drag.hasOccurred=!0,this.state.editingLinearElement&&!this.state.editingLinearElement.isDragging&&this.setState({editingLinearElement:{...this.state.editingLinearElement,isDragging:!0}}),this.state.selectedLinearElement.isDragging||this.setState({selectedLinearElement:{...this.state.selectedLinearElement,isDragging:!0}});return}}let s=t.hit.allHitElements.some(m=>this.isASelectedElement(m)),c=this.state.editingLinearElement&&r.shiftKey&&this.state.editingLinearElement.elementId===t.hit.element?.id;if((s||t.hit.hasHitCommonBoundingBoxOfSelectedElements)&&!c){let m=this.scene.getSelectedElements(this.state);if(m.every(h=>h.locked))return;let p=m.find(h=>re(h)),u=this.getTopLayerFrameAtSceneCoords(n);if(this.setState({frameToHighlight:u&&!p?u:null}),t.drag.hasOccurred=!0,this.setState({selectedElementsAreBeingDragged:!0}),m.length>0&&!t.withCmdOrCtrl&&!this.state.editingElement&&this.state.activeEmbeddable?.state!=="active"){let h={x:n.x-t.origin.x,y:n.y-t.origin.y},E=[...t.originalElements.values()],x=r.shiftKey;if(x){let w=Math.abs(h.x),I=Math.abs(h.y),L=x&&w<I,A=x&&w>I;L&&(h.x=0),A&&(h.y=0)}this.maybeCacheVisibleGaps(r,m),this.maybeCacheReferenceSnapPoints(r,m);let{snapOffset:T,snapLines:v}=$4(E,h,this.state,r,this.scene.getNonDeletedElementsMap());if(this.setState({snapLines:v}),!this.state.editingFrame&&D1(t,m,h,this.state,this.scene,T,r[C.CTRL_OR_CMD]?null:this.state.gridSize),this.maybeSuggestBindingForAll(m),r.altKey&&!t.hit.hasBeenDuplicated){t.hit.hasBeenDuplicated=!0;let w=[],I=[],L=new Map,A=new Map,M=t.hit.element,D=new Set(this.scene.getSelectedElements({selectedElementIds:this.state.selectedElementIds,includeBoundTextElement:!0,includeElementsInFrames:!0}).map(B=>B.id)),O=this.scene.getElementsIncludingDeleted();for(let B of O)if(D.has(B.id)||B.id===M?.id&&t.hit.wasAddedToSelection){let k=Yl(this.state.editingGroupId,L,B),z=t.originalElements.get(B.id);H(k,{x:z.x,y:z.y}),t.originalElements.set(k.id,k),w.push(k),I.push(B),A.set(B.id,k.id)}else w.push(B);let R=[...w,...I];Yt(R,X(I)),rp(w,I,A),Jm(R,I,A,"duplicatesServeAsOld"),tu(R,I,A),this.scene.replaceAllElements(R),this.maybeCacheVisibleGaps(r,m,!0),this.maybeCacheReferenceSnapPoints(r,m,!0)}return}}let d=this.state.draggingElement;if(d){if(d.type==="freedraw"){let m=d.points,p=n.x-d.x,u=n.y-d.y,h=m.length>0&&m[m.length-1];if(!(h&&h[0]===p&&h[1]===u)){let x=d.simulatePressure?d.pressures:[...d.pressures,r.pressure];H(d,{points:[...m,[p,u]],pressures:x})}}else if(ce(d)){t.drag.hasOccurred=!0,this.setState({selectedElementsAreBeingDragged:!0});let m=d.points,p=i-d.x,u=a-d.y;ka(r)&&m.length===2&&({width:p,height:u}=Hl(d.x,d.y,n.x,n.y)),m.length===1?H(d,{points:[...m,[p,u]]}):m.length===2&&H(d,{points:[...m.slice(0,-1),[p,u]]}),Wt(d,!1)&&this.maybeSuggestBindingsForLinearElementAtCoords(d,[n],this.state.startBoundElement)}else t.lastCoords.x=n.x,t.lastCoords.y=n.y,this.maybeDragNewGenericElement(t,r);if(this.state.activeTool.type==="selection"){t.boxSelection.hasOccurred=!0;let m=this.scene.getNonDeletedElements();if(this.state.editingLinearElement)Z.handleBoxSelection(r,this.state,this.setState.bind(this),this.scene.getNonDeletedElementsMap());else{let p=!0;!r.shiftKey&&Xe(m,this.state)&&(t.withCmdOrCtrl&&t.hit.element?this.setState(h=>nr({...h,selectedElementIds:{[t.hit.element.id]:!0}},this.scene.getNonDeletedElements(),h,this)):p=!1);let u=ds(m,d,this.scene.getNonDeletedElementsMap());this.setState(h=>{let E={...p&&h.selectedElementIds,...u.reduce((x,T)=>(x[T.id]=!0,x),{})};return t.hit.element&&(u.length?delete E[t.hit.element.id]:E[t.hit.element.id]=!0),h=p?h:{...h,selectedGroupIds:{},editingGroupId:null},{...nr({editingGroupId:h.editingGroupId,selectedElementIds:E},this.scene.getNonDeletedElements(),h,this),selectedLinearElement:u.length===1&&ce(u[0])?new Z(u[0]):null,showHyperlinkPopup:u.length===1&&(u[0].link||Lt(u[0]))?"info":!1}})}}}})}handlePointerMoveOverScrollbars(t,r){if(r.scrollbars.isOverHorizontal){let o=t.clientX,n=o-r.lastCoords.x;return this.translateCanvas({scrollX:this.state.scrollX-n/this.state.zoom.value}),r.lastCoords.x=o,!0}if(r.scrollbars.isOverVertical){let o=t.clientY,n=o-r.lastCoords.y;return this.translateCanvas({scrollY:this.state.scrollY-n/this.state.zoom.value}),r.lastCoords.y=o,!0}return!1}onPointerUpFromPointerDownHandler(t){return ut(r=>{this.removePointer(r),t.eventListeners.onMove&&t.eventListeners.onMove.flush();let{draggingElement:o,resizingElement:n,multiElement:i,activeTool:a,isResizing:l,isRotating:s}=this.state;this.setState(u=>({isResizing:!1,isRotating:!1,resizingElement:null,selectionElement:null,frameToHighlight:null,elementsToHighlight:null,cursorButton:"up",editingElement:i||V(this.state.editingElement)?this.state.editingElement:null,snapLines:Nm(u.snapLines,[]),originSnapOffset:null})),Mo.setReferenceSnapPoints(null),Mo.setVisibleGaps(null),this.savePointer(r.clientX,r.clientY,"up"),this.setState({selectedElementsAreBeingDragged:!1}),this.onPointerUpEmitter.trigger(this.state.activeTool,t,r);let c=this.scene.getNonDeletedElementsMap();if(this.state.editingLinearElement)if(!t.boxSelection.hasOccurred&&t.hit?.element?.id!==this.state.editingLinearElement.elementId)this.actionManager.executeAction(io);else{let u=Z.handlePointerUp(r,this.state.editingLinearElement,this.state,this);u!==this.state.editingLinearElement&&this.setState({editingLinearElement:u,suggestedBindings:[]})}else if(this.state.selectedLinearElement)if(t.hit?.element?.id!==this.state.selectedLinearElement.elementId)this.scene.getSelectedElements(this.state).length>1&&this.setState({selectedLinearElement:null});else{let u=Z.handlePointerUp(r,this.state.selectedLinearElement,this.state,this),{startBindingElement:h,endBindingElement:E}=u,x=this.scene.getElement(u.elementId);Wt(x)&&dn(x,h,E,c),u!==this.state.selectedLinearElement&&this.setState({selectedLinearElement:{...u,selectedPointsIndices:null},suggestedBindings:[]})}if(this.missingPointerEventCleanupEmitter.clear(),window.removeEventListener("pointermove",t.eventListeners.onMove),window.removeEventListener("pointerup",t.eventListeners.onUp),window.removeEventListener("keydown",t.eventListeners.onKeyDown),window.removeEventListener("keyup",t.eventListeners.onKeyUp),this.state.pendingImageElementId&&this.setState({pendingImageElementId:null}),this.props?.onPointerUp?.(a,t),this.onPointerUpEmitter.trigger(this.state.activeTool,t,r),o?.type==="freedraw"){let u=je(r,this.state),h=o.points,E=u.x-o.x,x=u.y-o.y;E===h[0][0]&&x===h[0][1]&&(x+=1e-4,E+=1e-4);let T=o.simulatePressure?[]:[...o.pressures,r.pressure];H(o,{points:[...h,[E,x]],pressures:T,lastCommittedPoint:[E,x]}),this.actionManager.executeAction(io);return}if(ho(o)){let u=o;try{this.initializeImageDimensions(u),this.setState({selectedElementIds:Fe({[u.id]:!0},this.state)},()=>{this.actionManager.executeAction(io)})}catch(h){console.error(h),this.scene.replaceAllElements(this.scene.getElementsIncludingDeleted().filter(E=>E.id!==u.id)),this.actionManager.executeAction(io)}return}if(ce(o)){o.points.length>1&&this.store.shouldCaptureIncrement();let u=je(r,this.state);!t.drag.hasOccurred&&o&&!i?(H(o,{points:[...o.points,[u.x-o.x,u.y-o.y]]}),this.setState({multiElement:o,editingElement:this.state.draggingElement})):t.drag.hasOccurred&&!i&&(mn(this.state)&&Wt(o,!1)&&wc(o,this.state,u,this),this.setState({suggestedBindings:[],startBoundElement:null}),a.locked?this.setState(h=>({draggingElement:null})):(jr(this.interactiveCanvas),this.setState(h=>({draggingElement:null,activeTool:tt(this.state,{type:"selection"}),selectedElementIds:Fe({...h.selectedElementIds,[o.id]:!0},h),selectedLinearElement:new Z(o)}))));return}if(a.type!=="selection"&&o&&yo(o)){this.updateScene({elements:this.scene.getElementsIncludingDeleted().filter(u=>u.id!==o.id),appState:{draggingElement:null},storeAction:_.UPDATE});return}if(o){if(t.drag.hasOccurred){let u=je(r,this.state);if(this.state.selectedLinearElement&&this.state.selectedLinearElement.isDragging){let h=this.scene.getElement(this.state.selectedLinearElement.elementId);if(h?.frameId){let E=Xt(h,c);E&&h&&(fn(h,E,this.scene.getNonDeletedElementsMap())||(H(h,{groupIds:[]}),cs([h],this.scene.getNonDeletedElementsMap()),this.scene.informMutation()))}}else{let h=this.getTopLayerFrameAtSceneCoords(u),E=this.scene.getSelectedElements(this.state),x=this.scene.getElementsMapIncludingDeleted(),T=v=>{if(v.length>0){for(let w of v){let I=w.groupIds.indexOf(this.state.editingGroupId);H(w,{groupIds:w.groupIds.slice(0,I)},!1)}x.forEach(w=>{w.groupIds.length&&it(x,w.groupIds[w.groupIds.length-1]).length<2&&H(w,{groupIds:[]},!1)}),this.setState({editingGroupId:null})}};if(h&&!this.state.selectedElementIds[h.id]){let v=E.filter(w=>w.frameId!==h.id&&Ha(w,x,this.state));this.state.editingGroupId&&T(v),x=Zc(x,v,h)}else if(!h&&this.state.editingGroupId){let v=E.filter(w=>w.frameId&&!Ha(w,x,this.state));T(v)}x=bn(x,this.state,this),this.scene.replaceAllElements(x)}}if(re(o)){let u=aT(this.scene.getElementsIncludingDeleted(),o,this.scene.getNonDeletedElementsMap());this.scene.replaceAllElements(Zc(this.scene.getElementsMapIncludingDeleted(),u,o))}H(o,Hc(o))}if(n&&this.store.shouldCaptureIncrement(),n&&yo(n)&&this.updateScene({elements:this.scene.getElementsIncludingDeleted().filter(u=>u.id!==n.id),storeAction:_.UPDATE}),t.resize.isResizing){let u=bn(this.scene.getElementsIncludingDeleted(),this.state,this),h=this.scene.getSelectedElements(this.state).filter(E=>re(E));for(let E of h)u=ru(u,ss(this.scene.getElementsIncludingDeleted(),E,this.state,c),E,this);this.scene.replaceAllElements(u)}let d=t.hit.element;this.state.selectedLinearElement?.elementId!==d?.id&&ce(d)&&this.scene.getSelectedElements(this.state).length===1&&this.setState({selectedLinearElement:new Z(d)});let m=this.lastPointerDownEvent,p=this.lastPointerUpEvent||this.lastPointerMoveEvent;if(Pr(this.state)&&m&&p){if(this.eraserTrail.endPath(),It(m.clientX,m.clientY,p.clientX,p.clientY)===0){let h=je({clientX:p.clientX,clientY:p.clientY},this.state);this.getElementsAtPosition(h.x,h.y).forEach(x=>this.elementsPendingErasure.add(x.id))}this.eraseElements();return}else this.elementsPendingErasure.size&&this.restoreReadyToEraseElements();if(d&&!t.drag.hasOccurred&&!t.hit.wasAddedToSelection&&(!this.state.editingLinearElement||!t.boxSelection.hasOccurred)&&(r.shiftKey&&!this.state.editingLinearElement?this.state.selectedElementIds[d.id]?sp(this.state,d)?this.setState(u=>{let h={...u.selectedElementIds};for(let E of d.groupIds.flatMap(x=>it(this.scene.getNonDeletedElements(),x)))delete h[E.id];return{selectedGroupIds:{...u.selectedElementIds,...d.groupIds.map(E=>({[E]:!1})).reduce((E,x)=>({...E,...x}),{})},selectedElementIds:Fe(h,u)}}):this.state.selectedLinearElement?.isDragging||this.setState(u=>{let h={...u.selectedElementIds};delete h[d.id];let E=ge(this.scene.getNonDeletedElements(),{selectedElementIds:h});return{...nr({editingGroupId:u.editingGroupId,selectedElementIds:h},this.scene.getNonDeletedElements(),u,this),selectedLinearElement:E.length===1&&ce(E[0])?new Z(E[0]):u.selectedLinearElement}}):d.frameId&&this.state.selectedElementIds[d.frameId]?this.setState(u=>{let h={...u.selectedElementIds,[d.id]:!0};return delete h[d.frameId],(this.scene.getElement(d.frameId)?.groupIds??[]).flatMap(E=>it(this.scene.getNonDeletedElements(),E)).forEach(E=>{delete h[E.id]}),{...nr({editingGroupId:u.editingGroupId,selectedElementIds:h},this.scene.getNonDeletedElements(),u,this),showHyperlinkPopup:d.link||Lt(d)?"info":!1}}):this.setState(u=>({selectedElementIds:Fe({...u.selectedElementIds,[d.id]:!0},u)})):this.setState(u=>({...nr({editingGroupId:u.editingGroupId,selectedElementIds:{[d.id]:!0}},this.scene.getNonDeletedElements(),u,this),selectedLinearElement:ce(d)&&u.selectedLinearElement?.elementId!==d.id?new Z(d):u.selectedLinearElement}))),!t.drag.hasOccurred&&!this.state.isResizing&&(d&&yv({x:t.origin.x,y:t.origin.y,element:d,shape:this.getElementShape(d),threshold:this.getElementHitThreshold(),frameNameBound:re(d)?this.frameNameBoundsCache.get(d):null},c)||!d&&t.hit.hasHitCommonBoundingBoxOfSelectedElements)){this.state.editingLinearElement?this.setState({editingLinearElement:null}):this.setState({selectedElementIds:Fe({},this.state),selectedGroupIds:{},editingGroupId:null,activeEmbeddable:null}),$e(this.interactiveCanvas,Re.AUTO);return}if(!a.locked&&a.type!=="freedraw"&&o&&o.type!=="selection"&&this.setState(u=>({selectedElementIds:Fe({...u.selectedElementIds,[o.id]:!0},u),showHyperlinkPopup:Lt(o)&&!o.link?"editor":u.showHyperlinkPopup})),(a.type!=="selection"||Xe(this.scene.getNonDeletedElements(),this.state)||!rt(this.state.previousSelectedElementIds,this.state.selectedElementIds))&&this.store.shouldCaptureIncrement(),(t.drag.hasOccurred||l||s)&&(mn(this.state)?yc(this.scene.getSelectedElements(this.state),this):vc(this.scene.getSelectedElements(this.state),c)),a.type==="laser"){this.laserTrails.endPath();return}!a.locked&&a.type!=="freedraw"?(jr(this.interactiveCanvas),this.setState({draggingElement:null,suggestedBindings:[],activeTool:tt(this.state,{type:"selection"})})):this.setState({draggingElement:null,suggestedBindings:[]}),d&&this.lastPointerUpEvent&&this.lastPointerDownEvent&&this.lastPointerUpEvent.timeStamp-this.lastPointerDownEvent.timeStamp<300&&Ue.pointers.size<=1&&rr(d)&&this.isIframeLikeElementCenter(d,this.lastPointerUpEvent,t.origin.x,t.origin.y)&&this.handleEmbeddableCenterClick(d)})}restoreReadyToEraseElements=()=>{this.elementsPendingErasure=new Set,this.onSceneUpdated()};eraseElements=()=>{let t=!1,r=this.scene.getElementsIncludingDeleted().map(o=>this.elementsPendingErasure.has(o.id)||o.frameId&&this.elementsPendingErasure.has(o.frameId)||Pe(o)&&this.elementsPendingErasure.has(o.containerId)?(t=!0,le(o,{isDeleted:!0})):o);this.elementsPendingErasure=new Set,t&&(this.store.shouldCaptureIncrement(),this.scene.replaceAllElements(r))};initializeImage=async({imageFile:t,imageElement:r,showCursorImagePreview:o=!1})=>{if(!Ni(t))throw new Error(b("errors.unsupportedFileType"));let n=t.type;if($e(this.interactiveCanvas,"wait"),n===te.svg)try{t=t1(await uv(await t.text()),t.name)}catch(c){throw console.warn(c),new Error(b("errors.svgImageInsertError"))}let i=await(this.props.generateIdForFile?.(t)||av(t));if(!i)throw console.warn("Couldn't generate file id or the supplied `generateIdForFile` didn't resolve to one."),new Error(b("errors.imageInsertError"));if(!this.files[i]?.dataURL){try{t=await Gc(t,{maxWidthOrHeight:Uy})}catch(c){console.error("Error trying to resizing image file on insertion",c)}if(t.size>Vg)throw new Error(b("errors.fileTooBig",{maxSize:`${Math.trunc(Vg/1024/1024)}MB`}))}if(o){let c=this.files[i]?.dataURL,d=c&&lv(c);this.setImagePreviewCursor(d||t)}let l=this.files[i]?.dataURL||await Ip(t),s=H(r,{fileId:i},!1);return new Promise(async(c,d)=>{try{this.files={...this.files,[i]:{mimeType:n,id:i,dataURL:l,created:Date.now(),lastRetrieved:Date.now()}};let m=this.imageCache.get(i);m||(this.addNewImagesToImageCache(),await this.updateImageCache([s])),m?.image instanceof Promise&&await m.image,this.state.pendingImageElementId!==s.id&&this.state.draggingElement?.id!==s.id&&this.initializeImageDimensions(s,!0),c(s)}catch(m){console.error(m),d(new Error(b("errors.imageInsertError")))}finally{o||jr(this.interactiveCanvas)}})};insertImageElement=async(t,r,o)=>{if(!this.isToolSupported("image")){this.setState({errorMessage:b("errors.imageToolNotSupported")});return}this.scene.insertElement(t);try{return await this.initializeImage({imageFile:r,imageElement:t,showCursorImagePreview:o})}catch(n){return H(t,{isDeleted:!0}),this.actionManager.executeAction(io),this.setState({errorMessage:n.message||b("errors.imageInsertError")}),null}};setImagePreviewCursor=async t=>{let o;try{o=await Gc(t,{maxWidthOrHeight:96})}catch(i){throw i.cause==="UNSUPPORTED"?new Error(b("errors.unsupportedFileType")):i}let n=await Ip(o);if(t.type===te.svg){let i=await n1(n),a=Math.min(i.height,96),l=a*(i.width/i.height);l>96&&(l=96,a=l*(i.height/i.width));let s=document.createElement("canvas");s.height=a,s.width=l,s.getContext("2d").drawImage(i,0,0,l,a),n=s.toDataURL(te.svg)}this.state.pendingImageElementId&&$e(this.interactiveCanvas,`url(${n}) 4 4, auto`)};onImageAction=async({insertOnCanvasDirectly:t})=>{try{let r=this.state.width/2+this.state.offsetLeft,o=this.state.height/2+this.state.offsetTop,{x:n,y:i}=je({clientX:r,clientY:o},this.state),a=await $l({description:"Image",extensions:Object.keys(Qs)}),l=this.createImageElement({sceneX:n,sceneY:i,addToFrameUnderCursor:!1});t?(this.insertImageElement(l,a),this.initializeImageDimensions(l),this.setState({selectedElementIds:Fe({[l.id]:!0},this.state)},()=>{this.actionManager.executeAction(io)})):this.setState({pendingImageElementId:l.id},()=>{this.insertImageElement(l,a,!0)})}catch(r){r.name!=="AbortError"?console.error(r):console.warn(r),this.setState({pendingImageElementId:null,editingElement:null,activeTool:tt(this.state,{type:"selection"})},()=>{this.actionManager.executeAction(io)})}};initializeImageDimensions=(t,r=!1)=>{let o=gr(t)&&this.imageCache.get(t.fileId)?.image;if(!o||o instanceof Promise){if(t.width<Nn/this.state.zoom.value&&t.height<Nn/this.state.zoom.value){let n=100/this.state.zoom.value;H(t,{x:t.x-n/2,y:t.y-n/2,width:n,height:n})}return}if(r||t.width<Nn/this.state.zoom.value&&t.height<Nn/this.state.zoom.value){let n=Math.max(this.state.height-120,160),i=Math.min(n,Math.floor(this.state.height*.5)/this.state.zoom.value),a=Math.min(o.naturalHeight,i),l=a*(o.naturalWidth/o.naturalHeight),s=t.x+t.width/2-l/2,c=t.y+t.height/2-a/2;H(t,{x:s,y:c,width:l,height:a})}};updateImageCache=async(t,r=this.files)=>{let{updatedFiles:o,erroredFiles:n}=await Lp({imageCache:this.imageCache,fileIds:t.map(i=>i.fileId),files:r});if(o.size||n.size)for(let i of t)o.has(i.fileId)&&Ne.delete(i);return n.size&&this.scene.replaceAllElements(this.scene.getElementsIncludingDeleted().map(i=>gr(i)&&n.has(i.fileId)?le(i,{status:"error"}):i)),{updatedFiles:o,erroredFiles:n}};addNewImagesToImageCache=async(t=Pp(this.scene.getNonDeletedElements()),r=this.files)=>{let o=t.filter(n=>!n.isDeleted&&!this.imageCache.has(n.fileId));if(o.length){let{updatedFiles:n}=await this.updateImageCache(o,r);n.size&&this.scene.informMutation()}};scheduleImageRefresh=YN(()=>{this.addNewImagesToImageCache()},Py);updateBindingEnabledOnPointerMove=t=>{let r=r2(t);this.state.isBindingEnabled!==r&&this.setState({isBindingEnabled:r})};maybeSuggestBindingAtCursor=t=>{let r=pn(t,this);this.setState({suggestedBindings:r!=null?[r]:[]})};maybeSuggestBindingsForLinearElementAtCoords=(t,r,o)=>{if(!r.length)return;let n=r.reduce((i,a)=>{let l=pn(a,this);return l!=null&&!Sf(t,o?.id,l)&&i.push(l),i},[]);this.setState({suggestedBindings:n})};maybeSuggestBindingForAll(t){if(t.length>50)return;let r=o2(t,this);this.setState({suggestedBindings:r})}clearSelection(t){this.setState(r=>({selectedElementIds:Fe({},r),activeEmbeddable:null,selectedGroupIds:{},editingGroupId:r.editingGroupId&&t!=null&&_a(t,r.editingGroupId)?r.editingGroupId:null})),this.setState({selectedElementIds:Fe({},this.state),activeEmbeddable:null,previousSelectedElementIds:this.state.selectedElementIds})}handleInteractiveCanvasRef=t=>{t!==null?(this.interactiveCanvas=t,this.interactiveCanvas.addEventListener("wheel",this.handleWheel),this.interactiveCanvas.addEventListener("touchstart",this.onTouchStart),this.interactiveCanvas.addEventListener("touchend",this.onTouchEnd)):(this.interactiveCanvas?.removeEventListener("wheel",this.handleWheel),this.interactiveCanvas?.removeEventListener("touchstart",this.onTouchStart),this.interactiveCanvas?.removeEventListener("touchend",this.onTouchEnd))};handleAppOnDrop=async t=>{let{file:r,fileHandle:o}=await cv(t),{x:n,y:i}=je(t,this.state);try{if(Ni(r)&&this.isToolSupported("image")){if(r?.type===te.png||r?.type===te.svg)try{let s=await Jl(r,this.state,this.scene.getElementsIncludingDeleted(),o);this.syncActionResult({...s,appState:{...s.appState||this.state,isLoading:!1},replaceFiles:!0,storeAction:_.CAPTURE});return}catch(s){if(s.name!=="EncodingError")throw new Error(b("alerts.couldNotLoadInvalidFile"))}let l=this.createImageElement({sceneX:n,sceneY:i});this.insertImageElement(l,r),this.initializeImageDimensions(l),this.setState({selectedElementIds:Fe({[l.id]:!0},this.state)});return}}catch(l){return this.setState({isLoading:!1,errorMessage:l.message})}let a=t.dataTransfer.getData(te.excalidrawlib);if(a&&typeof a=="string"){try{let l=Qf(a);this.addElementsFromPasteOrLibrary({elements:vh(l),position:t,files:null})}catch(l){this.setState({errorMessage:l.message})}return}if(r&&await this.loadFileToCanvas(r,o),t.dataTransfer?.types?.includes("text/plain")){let l=t.dataTransfer?.getData("text");if(l&&Kl(l,this.props.validateEmbeddable)&&(/^(http|https):\/\/[^\s/$.?#].[^\s]*$/.test(l)||$n(l)?.type==="video")){let s=this.insertEmbeddableElement({sceneX:n,sceneY:i,link:yr(l)});s&&this.setState({selectedElementIds:{[s.id]:!0}})}}};loadFileToCanvas=async(t,r)=>{t=await Vc(t);try{let o=this.scene.getElementsIncludingDeleted(),n;try{n=await Cp(t,this.state,o,r)}catch(i){let a=i instanceof Bo;if(a&&i.code==="IMAGE_NOT_CONTAINS_SCENE_DATA"&&!this.isToolSupported("image")){this.setState({isLoading:!1,errorMessage:b("errors.imageToolNotSupported")});return}let l=a?b("alerts.cannotRestoreFromImage"):b("alerts.couldNotLoadInvalidFile");this.setState({isLoading:!1,errorMessage:l})}if(!n)return;n.type===te.excalidraw?(fr(o.concat(n.data.elements)),this.store.updateSnapshot(X(o),this.state),this.setState({isLoading:!0}),this.syncActionResult({...n.data,appState:{...n.data.appState||this.state,isLoading:!1},replaceFiles:!0,storeAction:_.CAPTURE})):n.type===te.excalidrawlib&&await this.library.updateLibrary({libraryItems:t,merge:!0,openLibraryMenu:!0}).catch(i=>{console.error(i),this.setState({errorMessage:b("errors.importLibraryError")})})}catch(o){this.setState({isLoading:!1,errorMessage:o.message})}};handleCanvasContextMenu=t=>{if(t.preventDefault(),this.props.interactive===!1||("pointerType"in t.nativeEvent&&t.nativeEvent.pointerType==="touch"||"pointerType"in t.nativeEvent&&t.nativeEvent.pointerType==="pen"&&t.button!==hi.SECONDARY)&&this.state.activeTool.type!=="selection")return;let{x:r,y:o}=je(t,this.state),n=this.getElementAtPosition(r,o,{preferSelected:!0,includeLockedElements:!0}),i=this.scene.getSelectedElements(this.state),a=this.isHittingCommonBoundingBoxOfSelectedElements({x:r,y:o},i),l=n||a?"element":"canvas",s=this.excalidrawContainerRef.current,{top:c,left:d}=s.getBoundingClientRect(),m=t.clientX-d,p=t.clientY-c;ve("contextMenu","openContextMenu",l),this.setState({...n&&!this.state.selectedElementIds[n.id]?{...this.state,...nr({editingGroupId:this.state.editingGroupId,selectedElementIds:{[n.id]:!0}},this.scene.getNonDeletedElements(),this.state,this),selectedLinearElement:ce(n)?new Z(n):null}:this.state,showHyperlinkPopup:!1},()=>{this.setState({contextMenu:{top:p,left:m,items:this.getContextMenuItems(l)}})})};maybeDragNewGenericElement=(t,r)=>{let o=this.state.draggingElement,n=t.lastCoords;if(o)if(o.type==="selection"&&this.state.activeTool.type!=="eraser")uu(o,this.state.activeTool.type,t.origin.x,t.origin.y,n.x,n.y,Bt(t.origin.x,n.x),Bt(t.origin.y,n.y),Fl(r),Xm(r));else{let[i,a]=Pt(n.x,n.y,r[C.CTRL_OR_CMD]?null:this.state.gridSize),l=gr(o)&&this.imageCache.get(o.fileId)?.image,s=l&&!(l instanceof Promise)?l.width/l.height:null;this.maybeCacheReferenceSnapPoints(r,[o]);let{snapOffset:c,snapLines:d}=Z4(o,this.state,r,{x:t.originInGrid.x+(this.state.originSnapOffset?.x??0),y:t.originInGrid.y+(this.state.originSnapOffset?.y??0)},{x:i-t.originInGrid.x,y:a-t.originInGrid.y},this.scene.getNonDeletedElementsMap());i+=c.x,a+=c.y,this.setState({snapLines:d}),uu(o,this.state.activeTool.type,t.originInGrid.x,t.originInGrid.y,i,a,Bt(t.originInGrid.x,i),Bt(t.originInGrid.y,a),ho(o)?!Fl(r):Fl(r),Xm(r),s,this.state.originSnapOffset),this.maybeSuggestBindingForAll([o]),(this.state.activeTool.type===St.frame||this.state.activeTool.type===St.magicframe)&&this.setState({elementsToHighlight:ss(this.scene.getNonDeletedElements(),o,this.state,this.scene.getNonDeletedElementsMap())})}};maybeHandleResize=(t,r)=>{let o=this.scene.getSelectedElements(this.state),n=o.filter(d=>re(d)),i=t.resize.handleType;if(n.length>0&&i==="rotation")return!1;this.setState({isResizing:i&&i!=="rotation",isRotating:i==="rotation",activeEmbeddable:null});let a=t.lastCoords,[l,s]=Pt(a.x-t.resize.offset.x,a.y-t.resize.offset.y,r[C.CTRL_OR_CMD]?null:this.state.gridSize),c=new Map;if(n.forEach(d=>{eo(this.scene.getNonDeletedElements(),d.id).forEach(p=>{c.set(d.id+p.id,{x:p.x-d.x,y:p.y-d.y})})}),!this.state.selectedElementsAreBeingDragged){let[d,m]=Pt(a.x,a.y,r[C.CTRL_OR_CMD]?null:this.state.gridSize),p={x:d-t.originInGrid.x,y:m-t.originInGrid.y},u=[...t.originalElements.values()];this.maybeCacheReferenceSnapPoints(r,o);let{snapOffset:h,snapLines:E}=X4(o,ge(u,this.state),this.state,r,p,i);l+=h.x,s+=h.y,this.setState({snapLines:E})}if(I1(t.originalElements,i,o,this.scene.getElementsMapIncludingDeleted(),ka(r),Xm(r),o.some(d=>ho(d))?!Fl(r):Fl(r),l,s,t.resize.center.x,t.resize.center.y)){this.maybeSuggestBindingForAll(o);let d=new Set;return n.forEach(m=>{ss(this.scene.getNonDeletedElements(),m,this.state,this.scene.getNonDeletedElementsMap()).forEach(p=>d.add(p))}),this.setState({elementsToHighlight:[...d]}),!0}return!1};getContextMenuItems=t=>{let r=[];return r.push(Md,kd),t==="canvas"?this.state.viewModeEnabled?[...r,Pd,ml,B0,ii]:[WE,Tr,Md,kd,Ld,Tr,Gu,c5,Tr,Pd,uh,ml,B0,ii]:(r.push(Ld),this.state.viewModeEnabled?[dl,...r]:[Ad,dl,WE,F4,z4,Tr,...r,Tr,nh,ih,Tr,ah,hh,gh,QS,lh,Tr,dh,Tr,Bu,Fu,zu,Hu,Tr,mh,ph,Tr,Yh,ks,Vu,bh,Tr,bs])};handleWheel=ut(t=>{if(t.preventDefault(),sm||this.props.interactive===!1)return;let{deltaX:r,deltaY:o}=t;if(t.metaKey||t.ctrlKey){let n=Math.sign(o),i=ba*100,a=Math.abs(o),l=o;a>i&&(l=i*n);let s=this.state.zoom.value-l/100;s+=Math.log10(Math.max(1,this.state.zoom.value))*-n*Math.min(1,a/20),this.translateCanvas(c=>({...ti({viewportX:this.lastViewportPosition.x,viewportY:this.lastViewportPosition.y,nextZoom:En(s)},c),shouldCacheIgnoreZoom:!0})),this.resetShouldCacheIgnoreZoomDebounced();return}if(t.shiftKey){this.translateCanvas(({zoom:n,scrollX:i})=>({scrollX:i-(o||r)/n.value}));return}this.translateCanvas(({zoom:n,scrollX:i,scrollY:a})=>({scrollX:i-r/n.value,scrollY:a-o/n.value}))});getTextWysiwygSnappedToCenterPosition(t,r,o,n){if(n){let i=n.x+n.width/2,a=n.y+n.height/2,l=ap(n,o,this.scene.getNonDeletedElementsMap());if(l&&(i=l.x,a=l.y),Math.hypot(t-i,r-a)<Ay){let{x:d,y:m}=Vt({sceneX:i,sceneY:a},o);return{viewportX:d,viewportY:m,elementCenterX:i,elementCenterY:a}}}}savePointer=(t,r,o)=>{if(!t||!r)return;let{x:n,y:i}=je({clientX:t,clientY:r},this.state);isNaN(n)||isNaN(i);let a={x:n,y:i,tool:this.state.activeTool.type==="laser"?"laser":"pointer"};this.props.onPointerUpdate?.({pointer:a,button:o,pointersMap:Ue.pointers})};resetShouldCacheIgnoreZoomDebounced=xa(()=>{this.unmounted||this.setState({shouldCacheIgnoreZoom:!1})},300);updateDOMRect=t=>{if(this.excalidrawContainerRef?.current){let r=this.excalidrawContainerRef.current,{width:o,height:n,left:i,top:a}=r.getBoundingClientRect(),{width:l,height:s,offsetTop:c,offsetLeft:d}=this.state;if(o===l&&n===s&&i===d&&a===c){t&&t();return}this.setState({width:o,height:n,offsetLeft:i,offsetTop:a},()=>{t&&t()})}};refresh=()=>{this.setState({...this.getCanvasOffsets()})};getCanvasOffsets(){if(this.excalidrawContainerRef?.current){let t=this.excalidrawContainerRef.current,{left:r,top:o}=t.getBoundingClientRect();return{offsetLeft:r,offsetTop:o}}return{offsetLeft:0,offsetTop:0}}async updateLanguage(){let t=vl.find(r=>r.code===this.props.langCode)||jo;await gm(t),this.setAppState({})}},KN=()=>{(S.MODE===kr.TEST||S.DEV)&&(window.h=window.h||{},Object.defineProperties(window.h,{elements:{configurable:!0,get(){return this.app?.scene.getElementsIncludingDeleted()},set(e){return this.app?.scene.replaceAllElements(fr(e))}}}))};KN();WA=ty});var YA=y(()=>{});var KA=y(()=>{});var $A=y(()=>{});var XN,XA,ZA=y(()=>{"use strict";f();XN=()=>{Array.prototype.at||Object.defineProperty(Array.prototype,"at",{value:function(e){if(e=Math.trunc(e)||0,e<0&&(e+=this.length),!(e<0||e>=this.length))return this[e]},writable:!0,enumerable:!1,configurable:!0}),Element.prototype.replaceChildren||(Element.prototype.replaceChildren=function(...e){this.innerHTML="",this.append(...e)})},XA=XN});var jA=y(()=>{});import ZN from"clsx";import{jsx as qA}from"react/jsx-runtime";var JA,jN,QA=y(()=>{"use strict";f();lo();jA();jt();JA=({children:e})=>{let{FooterCenterTunnel:t}=lt(),r=Be();return qA(t.In,{children:qA("div",{className:ZN("footer-center zen-mode-transition",{"layer-ui__wrapper__footer-left--transition-bottom":r.zenModeEnabled}),children:e})})},jN=JA;JA.displayName="FooterCenter"});var ek=y(()=>{});import{jsx as pa,jsxs as rk}from"react/jsx-runtime";var qN,JN,tk,ok=y(()=>{"use strict";f();ek();qN=()=>pa("svg",{viewBox:"0 0 40 40",fill:"none",xmlns:"http://www.w3.org/2000/svg",className:"ExcalidrawLogo-icon",children:pa("path",{d:"M39.9 32.889a.326.326 0 0 0-.279-.056c-2.094-3.083-4.774-6-7.343-8.833l-.419-.472a.212.212 0 0 0-.056-.139.586.586 0 0 0-.167-.111l-.084-.083-.056-.056c-.084-.167-.28-.278-.475-.167-.782.39-1.507.973-2.206 1.528-.92.722-1.842 1.445-2.708 2.25a8.405 8.405 0 0 0-.977 1.028c-.14.194-.028.361.14.444-.615.611-1.23 1.223-1.843 1.861a.315.315 0 0 0-.084.223c0 .083.056.166.111.194l1.09.833v.028c1.535 1.528 4.244 3.611 7.12 5.861.418.334.865.667 1.284 1 .195.223.39.473.558.695.084.11.28.139.391.055.056.056.14.111.196.167a.398.398 0 0 0 .167.056.255.255 0 0 0 .224-.111.394.394 0 0 0 .055-.167c.029 0 .028.028.056.028a.318.318 0 0 0 .224-.084l5.082-5.528a.309.309 0 0 0 0-.444Zm-14.63-1.917a.485.485 0 0 0 .111.14c.586.5 1.2 1 1.843 1.555l-2.569-1.945-.251-.166c-.056-.028-.112-.084-.168-.111l-.195-.167.056-.056.055-.055.112-.111c.866-.861 2.346-2.306 3.1-3.028-.81.805-2.43 3.167-2.095 3.944Zm8.767 6.89-2.122-1.612a44.713 44.713 0 0 0-2.625-2.5c1.145.861 2.122 1.611 2.262 1.75 1.117.972 1.06.806 1.815 1.445l.921.666a1.06 1.06 0 0 1-.251.25Zm.558.416-.056-.028c.084-.055.168-.111.252-.194l-.196.222ZM1.089 5.75c.055.361.14.722.195 1.056.335 1.833.67 3.5 1.284 4.75l.252.944c.084.361.223.806.363.917 1.424 1.25 3.602 3.11 5.947 4.889a.295.295 0 0 0 .363 0s0 .027.028.027a.254.254 0 0 0 .196.084.318.318 0 0 0 .223-.084c2.988-3.305 5.221-6.027 6.813-8.305.112-.111.14-.278.14-.417.111-.111.195-.25.307-.333.111-.111.111-.306 0-.39l-.028-.027c0-.055-.028-.139-.084-.167-.698-.666-1.2-1.138-1.731-1.638-.922-.862-1.871-1.75-3.881-3.75l-.028-.028c-.028-.028-.056-.056-.112-.056-.558-.194-1.703-.389-3.127-.639C6.087 2.223 3.21 1.723.614.944c0 0-.168 0-.196.028l-.083.084c-.028.027-.056.055-.224.11h.056-.056c.028.167.028.278.084.473 0 .055.112.5.112.555l.782 3.556Zm15.496 3.278-.335-.334c.084.112.196.195.335.334Zm-3.546 4.666-.056.056c0-.028.028-.056.056-.056Zm-2.038-10c.168.167.866.834 1.033.973-.726-.334-2.54-1.167-3.379-1.445.838.167 1.983.334 2.346.472ZM1.424 2.306c.419.722.754 3.222 1.089 5.666-.196-.778-.335-1.555-.503-2.278-.251-1.277-.503-2.416-.838-3.416.056 0 .14 0 .252.028Zm-.168-.584c-.112 0-.223-.028-.307-.028 0-.027 0-.055-.028-.055.14 0 .223.028.335.083Zm-1.089.222c0-.027 0-.027 0 0ZM39.453 1.333c.028-.11-.558-.61-.363-.639.42-.027.42-.666 0-.666-.558.028-1.144.166-1.675.25-.977.194-1.982.389-2.96.61-2.205.473-4.383.973-6.561 1.557-.67.194-1.424.333-2.066.666-.224.111-.196.333-.084.472-.056.028-.084.028-.14.056-.195.028-.363.056-.558.083-.168.028-.252.167-.224.334 0 .027.028.083.028.11-1.173 1.556-2.485 3.195-3.909 4.945-1.396 1.611-2.876 3.306-4.356 5.056-4.719 5.5-10.052 11.75-15.943 17.25a.268.268 0 0 0 0 .389c.028.027.056.055.084.055-.084.084-.168.14-.252.222-.056.056-.084.111-.084.167a.605.605 0 0 0-.111.139c-.112.111-.112.305.028.389.111.11.307.11.39-.028.029-.028.029-.056.056-.056a.44.44 0 0 1 .615 0c.335.362.67.723.977 1.028l-.698-.583c-.112-.111-.307-.083-.39.028-.113.11-.085.305.027.389l7.427 6.194c.056.056.112.056.196.056s.14-.028.195-.084l.168-.166c.028.027.083.027.111.027.084 0 .14-.027.196-.083 10.052-10.055 18.15-17.639 27.42-24.417.083-.055.111-.166.111-.25.112 0 .196-.083.251-.194 1.704-5.194 2.039-9.806 2.15-12.083v-.028c0-.028.028-.056.028-.083.028-.056.028-.084.028-.084a1.626 1.626 0 0 0-.111-1.028ZM21.472 9.5c.446-.5.893-1.028 1.34-1.5-2.876 3.778-7.65 9.583-14.408 16.5 4.607-5.083 9.242-10.333 13.068-15ZM5.193 35.778h.084-.084Zm3.462 3.194c-.027-.028-.027-.028 0-.028v.028Zm4.16-3.583c.224-.25.448-.472.699-.722 0 0 0 .027.028.027-.252.223-.475.445-.726.695Zm1.146-1.111c.14-.14.279-.334.446-.5l.028-.028c1.648-1.694 3.351-3.389 5.082-5.111l.028-.028c.419-.333.921-.694 1.368-1.028a379.003 379.003 0 0 0-6.952 6.695ZM24.794 6.472c-.921 1.195-1.954 2.778-2.82 4.028-2.736 3.944-11.532 13.583-11.727 13.75a1976.983 1976.983 0 0 1-8.042 7.639l-.167.167c-.14-.167-.14-.417.028-.556C14.49 19.861 22.03 10.167 25.074 5.917c-.084.194-.14.36-.28.555Zm4.83 5.695c-1.116-.64-1.646-1.64-1.34-2.611l.084-.334c.028-.083.084-.194.14-.277.307-.5.754-.917 1.257-1.167.027 0 .055 0 .083-.028-.028-.056-.028-.139-.028-.222.028-.167.14-.278.335-.278.335 0 1.369.306 1.76.639.111.083.223.194.335.305.14.167.363.445.474.667.056.028.112.306.196.445.056.222.111.472.084.694-.028.028 0 .194-.028.194a2.668 2.668 0 0 1-.363 1.028c-.028.028-.028.056-.056.084l-.028.027c-.14.223-.335.417-.53.556-.643.444-1.369.583-2.095.389 0 0-.195-.084-.28-.111Zm8.154-.834a39.098 39.098 0 0 1-.893 3.167c0 .028-.028.083 0 .111-.056 0-.084.028-.14.056-2.206 1.61-4.356 3.305-6.506 5.028 1.843-1.64 3.686-3.306 5.613-4.945.558-.5.949-1.139 1.06-1.861l.28-1.667v-.055c.14-.334.67-.195.586.166Z",fill:"currentColor"})}),JN=()=>rk("svg",{viewBox:"0 0 450 55",xmlns:"http://www.w3.org/2000/svg",fill:"none",className:"ExcalidrawLogo-text",children:[pa("path",{d:"M429.27 96.74c2.47-1.39 4.78-3.02 6.83-4.95 1.43-1.35 2.73-2.86 3.81-4.51-.66.9-1.4 1.77-2.23 2.59-2.91 2.84-5.72 5.09-8.42 6.87h.01ZM343.6 69.36c.33 3.13.58 6.27.79 9.4.09 1.37.18 2.75.25 4.12-.12-4.46-.27-8.93-.5-13.39-.11-2.08-.24-4.16-.4-6.24-.06 1.79-.11 3.85-.13 6.11h-.01ZM378.47 98.34c.01-.37.07-1.13.01-6.51-.11 1.9-.22 3.81-.31 5.71-.07 1.42-.22 2.91-.16 4.35.39.03.78.07 1.17.1-.92-.85-.76-2.01-.72-3.66l.01.01ZM344.09 86.12c-.09-2.41-.22-4.83-.39-7.24v12.21c.15-.05.32-.09.47-.14.05-1.61-.03-3.23-.09-4.83h.01ZM440.69 66.79c-.22-.34-.45-.67-.69-.99-3.71-4.87-9.91-7.14-15.65-8.55-1.05-.26-2.12-.49-3.18-.71 2.29.59 4.48 1.26 6.64 2.02 7.19 2.54 10.57 5.41 12.88 8.23ZM305.09 72.46l1.2 3.6c.84 2.53 1.67 5.06 2.46 7.61.24.78.5 1.57.73 2.36.22-.04.44-.08.67-.12a776.9 776.9 0 0 1-5.01-13.57c-.02.04-.03.09-.05.13v-.01ZM345.49 90.25v.31c1.48-.42 3.05-.83 4.66-1.2-1.56.25-3.12.52-4.66.89ZM371.02 90.22c0-.57-.04-1.14-.11-1.71-.06-.02-.12-.04-.19-.05-.21-.05-.43-.08-.65-.11.42.16.74.88.95 1.87ZM398.93 54.23c-.13 0-.27-.01-.4-.02l.03.4c.11-.15.23-.27.37-.38ZM401.57 62.28v-.15c-1.22-.24-2.86-.61-3.23-1.25-.09-.15-.18-.51-.27-.98-.09.37-.2.73-.33 1.09 1.24.56 2.52.98 3.83 1.29ZM421.73 88.68c-2.97 1.65-6.28 3.12-9.69 3.68v.18c4.72-.14 11.63-3.85 16.33-8.38-2.04 1.75-4.33 3.24-6.63 4.53l-.01-.01ZM411.28 80.92c-.05-1.2-.09-2.4-.15-3.6-.21 5.66-.46 11.38-.47 14.51.24-.02.48-.04.71-.07.15-3.61.05-7.23-.09-10.83v-.01Z",transform:"translate(-144.023 -51.76)"}),pa("path",{d:"M425.38 67.41c-3.5-1.45-7.19-2.57-14.06-3.62.09 1.97.06 4.88-.03 8.12.03.04.06.09.06.15.19 1.36.28 2.73.37 4.1.25 3.77.39 7.55.41 11.33 0 1.38-.01 2.76-.07 4.13 1.4-.25 2.78-.65 4.12-1.15 4.07-1.5 7.94-3.78 11.28-6.54 2.33-1.92 5.13-4.49 5.88-7.58.63-3.53-2.45-6.68-7.97-8.96l.01.02ZM411.35 92.53v-.06l-.34.03c.11.01.22.03.34.03ZM314.26 64.06c-.23-.59-.47-1.17-.7-1.75.57 1.62 1.11 3.25 1.6 4.9l.15.54 2.35 6.05c.32.82.66 1.64.98 2.46-1.38-4.1-2.83-8.17-4.39-12.2h.01ZM156.82 103.07c-.18.13-.38.23-.58.33 1.32-.03 2.66-.2 3.93-.34.86-.09 1.72-.22 2.58-.33-2.12.1-4.12.17-5.94.34h.01ZM210.14 68.88s.03.04.05.07c.18-.31.39-.64.58-.96-.21.3-.42.6-.64.89h.01ZM201.65 82.8c-.5.77-1.02 1.56-1.49 2.37 1.11-1.55 2.21-3.1 3.2-4.59-.23.23-.49.51-.75.79-.32.47-.65.95-.96 1.43ZM194.03 98.66c-.33-.4-.65-.84-1.05-1.17-.24-.2-.07-.49.17-.56-.23-.26-.42-.5-.63-.75 1.51-2.55 3.93-5.87 6.4-9.28-.17-.08-.29-.28-.2-.49.04-.09.09-.17.13-.26-1.21 1.78-2.42 3.55-3.61 5.33-.87 1.31-1.74 2.64-2.54 4-.29.5-.63 1.04-.87 1.61.81.65 1.63 1.27 2.47 1.88-.09-.11-.18-.21-.27-.32v.01ZM307.79 82.93c-1-3.17-2.05-6.32-3.1-9.48-1.62 4.08-3.69 9.17-6.16 15.19 3.32-1.04 6.77-1.87 10.27-2.5-.32-1.08-.67-2.15-1.01-3.21ZM149.5 80.7c.05-1.71.04-3.43 0-5.14-.1 2.26-.16 4.51-.22 6.77-.02.73-.03 1.46-.04 2.19.14-1.27.2-2.55.24-3.82h.02ZM228.98 98.3c.39 1.25.91 3.03.94 3.91.06-.03.12-.07.17-.1.08-1.29-.55-2.65-1.11-3.81ZM307.72 53.36c.81.5 1.53 1.04 2.07 1.49-.38-.8-.78-1.58-1.21-2.35-.17.03-.34.06-.51.11-.43.12-.86.26-1.29.41.35-.01.53.1.94.34ZM283.69 96.14c3.91-7.25 6.89-13.35 8.88-18.15l1.1-2.66c-1.27 2.64-2.56 5.27-3.83 7.9-1.53 3.15-3.06 6.31-4.58 9.47-.87 1.81-1.76 3.62-2.54 5.47.04.02.07.04.11.07.05.05.1.09.15.14.05-.73.27-1.48.71-2.24ZM289.92 103.23s-.04.01-.05.03c0-.02.04-.03.05-.04.05-.05.11-.1.16-.15l.21-.21c-.55 0-1.5-.27-2.55-.72.4.26.8.51 1.22.74.24.13.48.26.73.37.05.02.1.03.14.05a.27.27 0 0 1 .08-.07h.01ZM269.23 68.49c-.39-.19-.82-.48-1.33-.87-3.06-1.56-6.31-2.78-9.36-2.35-3.5.49-5.7 1.11-7.74 2.44 5.71-2.6 12.82-2.07 18.44.79l-.01-.01ZM177.87 53.69l1.06.03c-.96-.22-2-.25-2.89-.3-4.95-.26-9.99.33-14.86 1.19-2.44.43-4.88.95-7.28 1.59 9.09-1.76 15.69-2.77 23.97-2.51ZM219.85 55.51c-.18.12-.36.27-.56.45-.45.53-.86 1.11-1.26 1.66-1.91 2.61-3.71 5.31-5.57 7.95l-.12.18 8.05-10.11c-.18-.05-.36-.1-.55-.13h.01ZM510.71 54.1c.12-.15.29-.3.53-.45.69-.4 3.72-.63 5.87-.74-.36-.02-.73-.04-1.09-.05-1.84-.03-3.67.09-5.49.35.05.3.12.59.18.88v.01ZM510.76 86.02c1.37-3.07 2.49-6.27 3.57-9.46.55-1.64 1.12-3.3 1.6-4.97-1.59 4.01-3.67 9.14-6.2 15.3.24-.08.5-.14.74-.22.1-.22.19-.44.29-.65ZM566.95 75.76c.11-.02.23.03.31.11-.05-.13-.09-.26-.14-.39-.05.09-.11.18-.17.28ZM511.33 86.41c3.08-.89 6.24-1.62 9.46-2.14-1.51-3.98-2.98-7.96-4.39-11.87-.05.15-.09.31-.14.46-1.02 3.32-2.15 6.61-3.39 9.85-.48 1.25-.98 2.49-1.53 3.7h-.01ZM578.24 74.45c.11-.44.23-.87.35-1.31-.31.7-.64 1.39-.97 2.08.09.21.19.4.28.61.12-.46.23-.92.35-1.38h-.01ZM520.62 53.11c-.09 0-.18-.01-.28-.02.38.34.29 1.08.93 2.53l6.65 17.15c2.2 5.68 4.69 11.36 7.41 16.87l1.06 2.17c-2.95-7.05-5.92-14.08-8.87-21.13-1.58-3.79-3.16-7.59-4.7-11.4-.78-1.92-1.73-3.89-2.25-5.91-.03-.1 0-.19.04-.26h.01ZM578.78 77.87c1.45-5.77 3.07-10.43 3.58-13.36.05-.34.16-.88.31-1.55-.67 1.79-1.37 3.56-2.08 5.33-.12.43-.23.86-.35 1.29-.65 2.43-1.29 4.86-1.9 7.3.14.33.29.65.43 1l.01-.01ZM545.3 94.66c.02-.44.03-.83.05-1.12.02-1.01.05-2.02.11-3.02.03-6.66-.46-14.33-1.46-22.8-.13-.42-.27-1.24-.56-2.89 0-.02 0-.04-.01-.06.62 6.61.95 13.25 1.32 19.87.17 3.08.33 6.16.52 9.23.02.25.03.52.04.78l-.01.01ZM580.77 102.81c.13.2.27.38.37.49.27-.11.53-.22.8-.32-.43.09-.82.05-1.17-.16v-.01ZM530.48 104.07h.33c-.36-.13-.71-.32-1.04-.56.14.24.3.47.45.7.06-.08.14-.13.26-.13v-.01ZM542.63 58.82c.06.23.11.47.15.71.14-.33.36-.62.7-.86-.28.05-.57.11-.85.15ZM583.81 57.87c.15-.7.29-1.41.42-2.11-.14.45-.28.9-.42 1.34-.46 1.44-.89 2.89-1.31 4.34.44-1.19.88-2.37 1.31-3.57ZM523.62 91.48c-4.66 1.17-9.05 2.89-14.02 5.27 4.65-1.84 9.48-3.29 14.28-4.63-.09-.22-.17-.41-.26-.64ZM460.64 78.3c-.04-2.9-.11-5.81-.28-8.71-.1-1.68-.17-3.43-.5-5.09-.07.02-.14.03-.2.05.3 6.54.45 12.17.51 17.12.17-.07.34-.14.51-.2 0-1.06-.01-2.11-.03-3.17h-.01ZM470.63 63.24c-3.38-.26-6.81.32-10.1 1.1.41 2.01.47 4.14.57 6.18.18 3.55.25 7.11.27 10.67 3.31-1.38 6.5-3.12 9.3-5.35 1.96-1.56 3.86-3.41 5.02-5.66.73-1.41 1.19-3.22.26-4.65-1.09-1.7-3.46-2.14-5.32-2.29ZM460.29 63.68c1-.24 2.01-.46 3.04-.65-1.15.16-2.37.38-3.71.69v.13c.07-.02.15-.04.22-.05.11-.13.3-.18.45-.11v-.01ZM457.24 100.96c.43-.03.86-.07 1.29-.11.14-.49.27-.99.38-1.49-.44.7-1 1.23-1.67 1.6ZM482.88 104.98c-.18.23-.36.38-.55.47.14.09.27.19.4.28a70.76 70.76 0 0 0 4.37-4.63c.76-.89 1.52-1.81 2.19-2.77-.3-.27-.61-.53-.92-.79-.07 1.94-4.62 6.32-5.49 7.45v-.01Z",transform:"translate(-144.023 -51.76)"}),pa("path",{d:"M474.36 63.31c-.4-.16-.84-.27-1.29-.37 1.56.42 3.08 1.22 3.76 2.74.62 1.4.32 2.95-.28 4.32.7-1.22.94-2.34.74-3.47-.24-1.33-1.19-2.54-2.93-3.21v-.01ZM477.34 89.18c-1.2-.81-2.4-1.62-3.6-2.42-.14.1-.26.19-.4.29 1.4.67 2.73 1.39 4 2.13ZM465.88 93.85c.37.25.74.5 1.1.75.46.32.92.65 1.38.97-1.57-1.2-2.01-1.61-2.49-1.72h.01ZM574.92 90.06c-2.28-5.21-4.93-11.13-5.67-12.26-.1-.15-1.57-3.01-1.63-3.08 0 0-.01.02-.02.02.4 1.37 1.09 2.69 1.65 3.99 2.14 4.95 4.36 9.86 6.67 14.73.6 1.26 1.21 2.52 1.83 3.78-.75-2.01-1.64-4.45-2.83-7.18ZM448.73 65.29c.1.2.22.38.34.57.22-.02.43-.06.65-.08v-.08c-.14-.05-.25 0-.99-.41ZM460.16 94.81c-.02.31-.06.59-.1.89-.03 1.71-.33 3.43-.79 5.07.15-.02.3-.03.45-.05.01-.04.02-.08.03-.11.09-.34.15-.69.2-1.03.17-1.07.25-2.16.33-3.24.05-.69.08-1.39.12-2.08-.27.1-.27.26-.24.57v-.02Z",transform:"translate(-144.023 -51.76)"}),pa("path",{d:"m328.67 98.12-3.22-6.58c-1.29-2.63-2.53-5.29-3.72-7.97-.25-.85-.52-1.69-.79-2.53-.81-2.57-1.67-5.12-2.55-7.67-1.92-5.53-3.9-11.08-6.32-16.41-.72-1.58-1.46-3.44-2.63-4.79-.03-.17-.16-.29-.34-.36a.282.282 0 0 0-.23-.04c-.06-.01-.12 0-.18.01-.74.06-1.5.38-2.19.61-2.22.77-4.4 1.64-6.63 2.38-.03-.08-.06-.16-.09-.25-.15-.42-.82-.24-.67.19.03.09.07.19.1.28l-.18.06c-.36.11-.28.6 0 .68.18 1.18.63 2.36.98 3.49.03.09.06.17.08.26-.08.23-.17.46-.24.64-.37.98-.79 1.94-1.21 2.9-1.27 2.89-2.62 5.75-3.98 8.6-3.18 6.67-6.44 13.31-9.64 19.97-1.08 2.25-2.2 4.5-3.15 6.81-.13.32.24.5.5.37 1.34 1.33 2.84 2.5 4.4 3.57.65.44 1.31.87 2.01 1.24.4.22.86.48 1.33.5.24.01.35-.19.33-.37.11-.1.21-.21.28-.28.41-.41.81-.84 1.2-1.26.85-.92 1.69-1.87 2.5-2.84 6.31-2.34 12.6-4.31 18.71-5.84 2.14 5.3 3.43 8.43 3.97 9.58.55 1.05 1.15 1.88 1.82 2.52 1.32.56 6.96-.03 9.23-1.96.87-1.28 1.19-2.67.93-4.15-.09-.5-.22-.95-.4-1.33l-.01-.03Zm-20.09-45.61c.43.77.83 1.56 1.21 2.35-.54-.45-1.27-.99-2.07-1.49-.42-.24-.6-.35-.94-.34.43-.15.85-.29 1.29-.41.17-.05.34-.08.51-.11Zm-25.86 45.66c.78-1.85 1.67-3.66 2.54-5.47 1.51-3.16 3.05-6.31 4.58-9.47 1.28-2.63 2.56-5.26 3.83-7.9l-1.1 2.66c-1.99 4.79-4.97 10.9-8.88 18.15-.43.76-.66 1.51-.71 2.24-.05-.05-.1-.09-.15-.14a.259.259 0 0 0-.11-.07Zm6.24 4.71c-.42-.23-.82-.48-1.22-.74 1.05.45 2 .72 2.55.72l-.21.21c-.05.05-.11.1-.16.15-.01.01-.04.03-.05.04 0-.02.03-.02.05-.03a.27.27 0 0 0-.08.07c-.05-.02-.1-.03-.14-.05-.25-.1-.49-.24-.73-.37h-.01Zm15.73-29.43c1.05 3.15 2.1 6.31 3.1 9.48.34 1.06.69 2.13 1.01 3.21-3.5.63-6.95 1.46-10.27 2.5 2.48-6.03 4.54-11.11 6.16-15.19Zm4.79 12.57c-.23-.79-.49-1.58-.73-2.36-.79-2.54-1.63-5.08-2.46-7.61l-1.2-3.6c.02-.04.04-.09.05-.13 1.6 4.45 3.28 9 5.01 13.57l-.67.12v.01Zm5.83-18.27-.15-.54c-.49-1.64-1.03-3.28-1.6-4.9.23.58.47 1.17.7 1.75 1.56 4.03 3.01 8.1 4.39 12.2-.33-.82-.67-1.64-.98-2.46l-2.35-6.05h-.01ZM390.43 79.37c-.13-10.43-.22-17.5-.24-19.97-.24-1.6.21-2.88-.65-3.65-.14-.13-.32-.23-.52-.32h.03c.45 0 .45-.69 0-.7-1.75-.03-3.5-.04-5.25-.14-1.38-.08-2.76-.21-4.15-.31-.07 0-.12.01-.17.04-.21-.07-.47.03-.45.31l.03.45c-.11.14-.19.3-.22.5-.21 1.26-.32 13.67-.36 23.59-.32 5.79-.67 11.57-.97 17.36-.09 1.73-.29 3.54-.21 5.3-.39.02-.38.64.04.69v.12c.05.44.74.45.7 0v-.06c1.1.09 2.2.21 3.3.3 1.14.19 2.44.2 3.29.17 1.73-.05 2.92-.05 3.8-.37.45-.05.9-.11 1.35-.17.44-.06.25-.73-.19-.67h-.01c.24-.32.45-.72.62-1.25.66-1.84.41-6.36.34-11.33l-.13-9.9.02.01Zm-12.26 18.17c.09-1.91.2-3.81.31-5.71.06 5.38 0 6.14-.01 6.51-.05 1.65-.21 2.81.72 3.66-.39-.04-.78-.07-1.17-.1-.06-1.44.09-2.93.16-4.35l-.01-.01ZM588.97 53.85c-2.06-.25-3.17-.51-3.76-.6a.3.3 0 0 1 .04-.08c.22-.39-.39-.75-.6-.35-.56 1.02-.9 2.19-1.26 3.29-.61 1.88-1.17 3.78-1.72 5.68-.63 2.19-1.24 4.39-1.83 6.59-.81 2.03-1.67 4.05-2.61 6.03-1.7-3.64-3.11-6.04-4.03-7.57-2.26-3.74-2.85-5.48-3.57-6.08l.31-.09c.43-.12.25-.8-.19-.67-1.06.3-2.12.6-3.17.95-.93.32-1.85.69-2.76 1.07-.13.05-.19.16-.22.27-.04.02-.08.05-.11.07-.04-.06-.07-.12-.11-.18a.354.354 0 0 0-.48-.12c-.16.09-.22.32-.13.48l.33.54c0 .09.02.18.06.28.51 1.16.78 1.38.72 1.47-2.42 3.44-5.41 7.86-6.2 9.1-1.27 1.97-2.01 3.14-2.45 3.84l-.91-6.56-.43-4.1c-.19-1.85-.37-3.23-.53-4.13-.19-1.1-.3-2.15-.45-3.16-.2-1.36-.29-2.06-.47-2.42h.04c.45.02.45-.68 0-.7-3.43-.16-6.81.94-10.17 1.48-.24-.22-.73-.04-.58.32.24.59.33 1.25.43 1.87.17 1.06.29 2.13.4 3.2.32 3.09.53 6.2.74 9.3.44 6.75.77 13.51 1.17 20.26.11 1.95.13 3.96.46 5.89.05.3.37.31.55.14.74 1.71 2.87 1.27 6.13 1.27 1.34 0 2.39.04 2.99-.11.02.32.48.53.63.18 3.61-8.26 7.41-16.46 12.05-24.2.03-.05.04-.1.05-.15.3.73.64 1.45.94 2.16.97 2.26 1.97 4.52 2.98 6.76 2.26 5.03 4.54 10.07 7.09 14.96.47.9.94 1.79 1.47 2.65.2.32.4.67.66.96-.18.25 0 .68.34.54.91-.38 1.82-.75 2.76-1.07 1.04-.35 2.11-.65 3.17-.95.39-.11.28-.66-.07-.68.62-.4.95-.96.87-1.91-.3-3.34.72-7.47.86-8.52l2.14-11.43c1.75-10.74 3.13-17.51 3.23-20.86.02-.49.08-2.84.13-3.24.17-1.25.48-1-4.96-1.65l.03-.02Zm-46.19 5.67c-.04-.24-.09-.48-.15-.71l.85-.15c-.34.24-.56.53-.7.86Zm1.95 25.12c-.36-6.63-.7-13.26-1.32-19.87 0 .02 0 .04.01.06.29 1.65.44 2.47.56 2.89 1 8.46 1.5 16.14 1.46 22.8-.06.99-.1 2-.11 3.02-.01.29-.03.68-.05 1.12-.01-.26-.03-.53-.04-.78-.19-3.08-.35-6.16-.52-9.23l.01-.01Zm36.4 18.66c-.11-.11-.24-.29-.37-.49.35.21.74.26 1.17.16-.27.11-.53.22-.8.32v.01Zm-.89-33.72c.12-.43.23-.86.35-1.29.71-1.77 1.41-3.55 2.08-5.33-.15.68-.26 1.22-.31 1.55-.5 2.94-2.13 7.59-3.58 13.36-.15-.35-.29-.66-.43-1 .61-2.44 1.25-4.87 1.9-7.3l-.01.01Zm3.56-12.48c.14-.44.28-.89.42-1.34-.13.7-.27 1.41-.42 2.11-.43 1.19-.86 2.38-1.31 3.57.42-1.45.85-2.9 1.31-4.34Zm-5.22 16.05c-.11.44-.23.87-.35 1.31-.12.46-.23.92-.35 1.38-.1-.22-.19-.4-.28-.61.34-.69.66-1.38.97-2.08h.01Zm-11.64 2.62c.06-.1.12-.19.17-.28.05.13.09.26.14.39a.398.398 0 0 0-.31-.11Zm2.3 2.98c-.56-1.3-1.25-2.63-1.65-3.99 0 0 .01-.02.02-.02.06.08 1.52 2.93 1.63 3.08.73 1.13 3.38 7.04 5.67 12.26 1.2 2.73 2.08 5.17 2.83 7.18-.62-1.25-1.23-2.51-1.83-3.78-2.31-4.87-4.53-9.78-6.67-14.73ZM275.92 87.03c-1.06-2.18-1.13-3.45-2.44-2.93-1.52.57-2.94 1.3-4.5 2.1-1.4.72-2.68 1.44-3.92 2.12.01-.25-.24-.5-.51-.34-4.8 2.93-12.41 4.7-17.28 1.31-1.98-1.77-3.32-4.15-3.97-5.78-.29-.95-.49-1.94-.63-2.93-.14-3.34 1.58-6.53 3.9-9.12.8-.79 1.68-1.51 2.66-2.12 3.7-2.3 8.22-3.07 12.51-2.51 2.71.35 5.32 1.24 7.71 2.55.39.22.75-.39.35-.6-.18-.1-.37-.18-.55-.27.56.27 1.03.33 1.51.19l-.48.39c-.15.11-.23.3-.13.48.09.15.33.24.48.13 1.3-.97 2.46-2.09 3.45-3.37.37-.29.64-.6.65-.97v-.02c.08-.33-.03-.7-.21-1.08-.31-.87-.98-2.01-2.19-3.26-2.43-2.52-3.79-3.45-5.68-4.26-1.14-.49-3.12-1.06-4.42-1.23-3.28-.42-10.64-1.21-18.18 4.11-7.74 5.46-11.94 12.3-12.23 20.61-.08 2.06.04 3.98.34 5.71.74 4.18 2.57 8 5.44 11.34 4.26 4.99 9.76 7.52 16.34 7.52 4.85 0 9.69-1.77 14.89-4.62.23-.12.45-.23.68-.35 2.19-1.1 4.37-2.23 6.46-3.5.49-.3 1.03-.61 1.5-.98 1.47-.87 1.11-1.12.49-2.95-.39-1.14-.76-2.7-2.06-5.36l.02-.01Zm-17.38-21.76c3.05-.42 6.31.79 9.36 2.35.51.39.94.68 1.33.87-5.61-2.86-12.72-3.39-18.44-.79 2.05-1.33 4.24-1.95 7.74-2.44l.01.01ZM443.67 72.67c-.4-2.2-1.15-4.33-2.37-6.22-1.49-2.32-3.58-4.19-5.91-5.64-6.17-3.81-13.75-5.11-20.83-6.01-3.23-.41-6.47-.69-9.72-.92l-1.39-.12c-.85-.07-1.52-.1-2.05-.1-1.08-.06-2.17-.12-3.25-.17-.08 0-.14.02-.19.05-.1.05-.18.14-.16.3.27 2.55-.01 5.12-.92 7.52-.15.38.4.56.62.28 1.32.59 2.68 1.05 4.08 1.37 0 2.78-.14 7.58-.33 12.91 0 0 0 .02-.01.03-.61 3.66-.79 7.42-1 11.12-.23 4.01-.43 8.03-.44 12.05 0 .64 0 1.28.03 1.93.02.31 0 .68.15.96.06.11.14.16.24.17-.2.17-.21.54.11.59 3.83.67 7.78.71 11.68.25 2.3-.19 4.87-.65 7.65-1.56 1.85-.54 3.67-1.18 5.43-1.91 7.2-3.02 14.31-8.07 17.35-15.53.76-1.86 1.17-3.8 1.31-5.75.3-1.93.28-3.82-.09-5.58l.01-.02Zm-19.32-15.42c5.74 1.41 11.94 3.68 15.65 8.55.25.32.47.65.69.99-2.3-2.82-5.68-5.69-12.88-8.23-2.16-.76-4.35-1.43-6.64-2.02 1.06.21 2.13.45 3.18.71Zm-25.82-3.04c.13 0 .27.01.4.02-.14.1-.26.23-.37.38 0-.13-.02-.26-.03-.4Zm34.82 22.17c-.75 3.09-3.55 5.66-5.88 7.58-3.35 2.76-7.21 5.03-11.28 6.54-1.33.49-2.71.9-4.12 1.15.06-1.38.08-2.76.07-4.13-.02-3.78-.16-7.56-.41-11.33-.09-1.37-.18-2.74-.37-4.1 0-.06-.03-.11-.06-.15.09-3.25.12-6.16.03-8.12 6.86 1.05 10.56 2.17 14.06 3.62 5.52 2.28 8.59 5.44 7.97 8.96l-.01-.02Zm-22 16.15c-.12 0-.23-.02-.34-.03l.34-.03v.06Zm-.69-.7c0-3.13.26-8.84.47-14.51.06 1.2.11 2.41.15 3.6.15 3.6.25 7.23.09 10.83-.24.03-.48.05-.71.07v.01Zm-12.33-30.94c.37.63 2.01 1.01 3.23 1.25v.15c-1.31-.31-2.59-.73-3.83-1.29.12-.36.23-.72.33-1.09.08.48.18.84.27.98Zm13.7 31.65v-.18c3.41-.56 6.71-2.02 9.69-3.68 2.31-1.28 4.59-2.78 6.63-4.53-4.69 4.53-11.61 8.24-16.33 8.38l.01.01Zm24.07-.75c-2.05 1.93-4.37 3.56-6.83 4.95 2.7-1.78 5.52-4.03 8.42-6.87.82-.82 1.56-1.69 2.23-2.59-1.08 1.65-2.38 3.16-3.81 4.51h-.01ZM187.16 92.14c-.79-2.47-2.1-7.12-3.1-6.87-.19-.01-2.09.77-4.08 1.54-3.06 1.18-5.91 2.13-10.09 2.82-2.74.42-5.87 1.01-10.61 1.06.04-3.34.05-6.01.05-7.99 7.97-.65 12.33-2.11 16.37-3.55 1.11-.39 2.69-1.01 2.63-1.8-.08-.35-.55-1.39-1.17-2.61-.47-1.16-.98-2.31-1.61-3.38-.42-.71-1.04-1.69-1.86-2.06-.11-.08-.22-.13-.29-.12-.02 0-.04 0-.07.01-.19-.04-.39-.05-.6-.01-.17.03-.24.15-.25.28-.04.02-.09.04-.14.05-4.33 1.48-8.85 2.33-13.24 3.61a499.1 499.1 0 0 0-.31-8.19c4.51-.99 8.88-1.38 13.11-1.82 3.68-.38 6.28.12 7.47.34.59.11.9.16 1.16.18h.1c-.1.37.44.66.62.28.02-.04.03-.08.05-.13.15.2.53.22.62-.1.17-.58.19-1.21.21-1.81v-.36c.03-.15.05-.3.07-.45.52-2.47.33-5.09-.64-7.44-.11-.27-.44-.28-.6-.14-.08-.21-.15-.42-.24-.62-.19-.41-.79-.05-.6.35.03.07.05.15.09.22-.98-.42-2.15-.54-3.17-.63-2.17-.19-4.37-.14-6.54 0-5.7.35-11.4 1.3-16.91 2.79-2.08.56-4.13 1.22-6.14 2-4.54 1.05-3.79 1.51-2.17 6.07.18.51.46 1.68.54 1.94.82 2.47 1.08 2.13 3.1 2.13s0 .05 0 .08h.52c-.48 2.66-.51 5.45-.62 8.13-.15 3.48-.22 6.96-.28 10.45 0 .41-.01.82-.02 1.23-.16.29-.33.57-.51.85-.05.38-.09.77-.14 1.18-.42 3.52-.59 6.48-.52 8.8v.34c.02.47.05.76.06.87.16 1.57-.26 3.47 1.35 3.79 1.61.32 3.5.55 4.85.55.11 0 .22-.02.33-.02 1.79.24 3.67.05 5.45-.12 2.85-.28 5.69-.7 8.51-1.19 3.03-.53 6.05-1.14 9.04-1.86 2.4-.58 4.82-1.19 7.13-2.06.51-.19 1.73-.57 2.46-1.14 1.81-.68 2.18-1 1.57-2.67-.23-.62-.48-1.49-.91-2.78l-.03-.02Zm-11.12-38.71c.89.05 1.93.08 2.89.3-.33 0-.68-.02-1.06-.03-8.28-.26-14.88.75-23.97 2.51 2.41-.64 4.85-1.16 7.28-1.59 4.87-.86 9.91-1.45 14.86-1.19Zm-26.53 22.13c.03 1.71.04 3.43 0 5.14-.04 1.27-.11 2.55-.24 3.82 0-.73.02-1.46.04-2.19.05-2.26.12-4.51.22-6.77h-.02Zm6.73 27.85c.2-.1.4-.21.58-.33 1.82-.17 3.82-.24 5.94-.34-.86.11-1.72.24-2.58.33-1.27.14-2.61.31-3.93.34h-.01ZM534.48 85.44c-3.52-8.38-7.07-16.75-10.5-25.17-.63-1.54-1.25-3.09-1.86-4.65-.31-.8-.65-1.6-.87-2.43-.04-.17-.17-.24-.31-.25.1-.2 0-.51-.29-.53-1.59-.08-3.18-.22-4.78-.25-1.96-.03-3.91.13-5.84.42-.31.05-.31.38-.13.56-.03.06-.05.14-.04.22.23 1.54.63 3.06 1.16 4.53.13.35.27.7.41 1.06l-2.68 6.18c-.11.03-.2.09-.25.22-.67 1.9-1.52 3.73-2.34 5.56a536.85 536.85 0 0 1-3.9 8.45c-2.64 5.64-5.34 11.25-7.91 16.93-.44.97-.88 1.94-1.29 2.93-.2.48-.47 1-.55 1.52v.05c-.02.12.02.26.16.34 1.19.73 2.41 1.41 3.66 2.05 1.2.62 2.45 1.25 3.76 1.61.43.12.62-.55.19-.67-1.13-.31-2.2-.83-3.24-1.36 1.09.36 2.1.69 2.75.93 2.82 1.01 2.38 1.1 4.3-3.75 2.1-1.09 4.34-1.96 6.53-2.79 4.35-1.64 8.8-3.03 13.27-4.29.82 2.01 1.77 3.97 2.72 5.92.35.83.62 1.45.79 1.82.22.42.45.8.69 1.15.17.33.33.67.5 1 .42.8.84 1.63 1.4 2.35.23.29.6 0 .55-.31 1.53-.02 3.06-.07 4.58-.27.92-.12 1.82-.32 2.71-.54 1.39-.27 3.85-1.11 3.74-1.42-.67-1.96-1.55-3.87-2.34-5.78-1.57-3.78-3.16-7.56-4.75-11.33v-.01Zm-11.65-26.16c1.54 3.81 3.12 7.6 4.7 11.4 2.94 7.05 5.91 14.09 8.87 21.13l-1.06-2.17c-2.71-5.51-5.2-11.19-7.41-16.87l-6.65-17.15c-.65-1.45-.55-2.19-.93-2.53.09 0 .18.01.28.02a.29.29 0 0 0-.04.26c.52 2.02 1.47 3.98 2.25 5.91h-.01Zm-6.58 13.58c.05-.15.09-.31.14-.46 1.41 3.92 2.88 7.9 4.39 11.87-3.22.52-6.38 1.25-9.46 2.14.55-1.22 1.05-2.46 1.53-3.7 1.24-3.24 2.37-6.53 3.39-9.85h.01Zm-.23-20c.36 0 .73.03 1.09.05-2.15.1-5.18.33-5.87.74-.24.15-.41.3-.53.45-.06-.29-.13-.58-.18-.88 1.82-.26 3.65-.39 5.49-.35v-.01Zm-.09 18.72c-.49 1.67-1.05 3.33-1.6 4.97-1.07 3.19-2.19 6.38-3.57 9.46-.09.21-.19.43-.29.65-.25.07-.5.14-.74.22 2.53-6.16 4.61-11.29 6.2-15.3Zm-6.34 25.16c4.97-2.38 9.37-4.1 14.02-5.27l.26.64c-4.8 1.35-9.63 2.8-14.28 4.63Zm20.17 6.76c.33.23.68.42 1.04.56h-.33c-.12 0-.21.06-.26.13-.15-.23-.31-.45-.45-.7v.01ZM226.57 91.75c-3.55-4.74-6.68-9.11-9.31-12.99 9.2-15.25 10.05-17.81 10.35-18.38.17-.34 1.09-2.27.64-2.53-1.13-.65-1.03-.65-2.97-1.71-1.19-.65-3.04-1.61-4.53-2.12-1.71-.59-1.24-.36-3 2.77-.06.1-.11.2-.17.3-.75 1.02-1.48 2.05-2.2 3.09-1.88 2.71-3.73 5.45-5.69 8.1-3.68-4.91-6.88-8.76-9.51-11.43-.15-.15-.3-.29-.46-.42-1.27-1.28-7.24 3.53-7.93 5.58-.09.09-.19.16-.28.25-.27.26.03.64.33.58.19.65.5 1.29.94 1.91 3.85 5.06 7.19 9.76 9.94 14-1.23 2.61-3.06 5-4.67 7.38l-2.28 3.33c-.5.66-.93 1.23-1.29 1.69-.67.93-2.09 2.61-2.3 3.87-.51.85-1.16 1.84-1.29 2.83-.06.44.61.63.67.19.01-.08.04-.15.06-.22 1.36 1.08 2.76 2.11 4.19 3.11 1.3.91 2.62 1.85 4.04 2.56.21.1.4 0 .48-.17.24.07.48.14.72.2.44.1.62-.57.19-.67-2.02-.48-3.77-1.57-5.23-3.02-.47-.46-.9-.96-1.32-1.46 1.74 1.35 4.2 2.89 5.89 4.14 1.39 1.03 2.85-2.27 4.22-4.2 1.86-2.64 3.96-5.86 5.52-8.29l10.39 14.51c.67.81 1.14 1.21 1.57 1.36-.05.24.12.51.41.4 1.53-.58 3.05-1.19 4.54-1.87 1.52-.69 3.06-1.45 4.36-2.5a.28.28 0 0 0 .12-.23c1.66-1.1.81-1.74-1.41-4.91-1.13-1.58-1.71-2.36-3.7-5.01l-.03-.02Zm2.41 6.54c.56 1.15 1.19 2.52 1.11 3.81-.06.04-.12.07-.17.1-.03-.88-.55-2.66-.94-3.91Zm-16.51-32.73c1.86-2.65 3.65-5.35 5.57-7.95.4-.55.81-1.13 1.26-1.66.19-.18.38-.33.56-.45.18.03.36.08.55.13l-8.05 10.11.12-.18h-.01ZM192.7 95.48c.79-1.37 1.66-2.69 2.54-4 1.19-1.79 2.4-3.56 3.61-5.33-.04.09-.09.17-.13.26-.1.22.03.41.2.49-2.47 3.42-4.89 6.73-6.4 9.28.21.24.4.48.63.75-.24.07-.4.36-.17.56.4.33.72.77 1.05 1.17.09.11.18.21.27.32-.84-.61-1.66-1.24-2.47-1.88.24-.57.58-1.11.87-1.61v-.01Zm7.46-10.32c.47-.81.98-1.59 1.49-2.37.31-.48.64-.95.96-1.43.26-.29.52-.56.75-.79-.99 1.48-2.09 3.03-3.2 4.59Zm10.03-16.22s-.03-.05-.05-.07c.22-.29.43-.59.64-.89-.2.32-.4.65-.58.96h-.01ZM371.54 87.96c-.01-.08-.01-.16-.03-.23-.06-.38-.58-.29-.66.03-.3-.05-.6-.08-.81-.11-1.14-.15-2.29-.19-3.44-.2 1.04-.09 2.09-.18 3.14-.23.45-.02.45-.72 0-.7-6.57.35-13.14 1.23-19.65 2.11-1.53.21-3.05.42-4.57.68-.01 0-.02.01-.04.01-.04-3.33-.13-6.66-.24-9.99-.19-5.7-.4-11.41-.88-17.1-.13-1.51-.23-3.07-.49-4.58 0-.25 0-.48-.02-.68-.06-1.19-.04-2.61-.68-2.78-.16-.07-.72-.16-1.5-.24.22-.17.16-.62-.2-.63-1.19-.04-2.39.09-3.57.23-1.2.14-2.41.32-3.59.6-.16-.1-.41-.06-.5.12-.06.02-.13.03-.19.05-.35.1-.29.55-.03.66-.26.6-.19 2.27-.21 3-.02.66-.66 33.73-.9 40.3-.03.65.06 1.12.04 1.45-.16 3.05.87 4.96 6.34 3.93 1.09-.08 2.75-.77 5.36-1.43 4.13-1.04 5.78-1.52 6.2-1.65 6.43-1.69 6.78-1.97 11.72-2.43.55-.05 4.8-.38 6.03-.3.64.04 1.19.07 1.65.1.09 0 .16-.03.24-.05.1.27.56.33.66-.02.39-1.32.61-2.71.78-4.08.2-1.61.29-3.24.15-4.86.24.03.52-.23.38-.53-.09-.2-.27-.33-.49-.43v-.02Zm-.63.56c.07.57.11 1.14.11 1.71-.21-.99-.53-1.71-.95-1.87.22.03.44.06.65.11.06.01.12.04.19.05Zm-25.41 1.73c1.54-.36 3.1-.64 4.66-.89-1.61.37-3.18.77-4.66 1.2v-.31Zm-.86-7.37c-.07-1.37-.16-2.75-.25-4.12-.21-3.13-.45-6.27-.79-9.4.02-2.25.08-4.31.13-6.11.16 2.08.29 4.16.4 6.24.23 4.46.38 8.93.5 13.39h.01Zm-.94-4c.16 2.41.29 4.83.39 7.24.06 1.6.14 3.22.09 4.83-.15.05-.32.09-.47.14V78.88h-.01ZM483.72 92.83c-3.05-2.28-6.22-4.4-9.38-6.51 8.86-6.49 13.49-12.95 13.73-19.23.04-.76 0-1.5-.13-2.2-.67-3.82-3.5-6.68-8.39-8.48.13.04.27.08.4.13 3.92 1.39 7.74 4.23 8.5 8.56.34 1.95-.05 3.96-.98 5.69-.21.4.39.75.6.35 1.86-3.46 1.46-7.55-.97-10.63-3.53-4.47-9.76-5.88-15.16-6.16-2.32-.12-4.64-.04-6.95.19-6 .32-12.71 1.68-17.63 3.21-.37.11-.67.23-.92.35-.2-.17-.62.02-.57.37v.03c-.64.68-.18 1.64.48 3.21.38.91.67 1.89 1.15 2.58.32.76.68 1.51 1.13 2.19.14.21.38.19.53.07.19-.02.38-.05.57-.08v1.57c-.06.06-.1.13-.11.23-.27 4.18-.34 8.38-.48 12.57l-.3 9.03c-.24 3.91-.44 6.77-.46 7.26-.05.88-.11 1.95.07 2.81-.01.22-.02.43-.04.65 0 .11-.02.23-.03.35 0 .05-.03.27-.01.16-.05.4.5.59.64.28.05.04.12.08.2.08 1.75.13 3.5.28 5.25.3 1.69.02 3.38-.12 5.06-.32.08.23.36.39.55.15.06-.08.11-.17.16-.26.18-.09.24-.32.18-.48.05-.2.1-.4.13-.6.16-.86.25-1.74.33-2.62.11-1.17.17-2.34.23-3.51.15-.01.32-.03.52-.04.36-.03 1.73-.15 2.06-.15.39 0 .7-.02.95-.04 1.76 1.11 3.45 2.35 5.14 3.55 2.83 2.01 5.64 4.04 8.47 6.04 1.42 1 2.85 2 4.29 2.97.1.06.19.07.27.04.08 0 .17-.02.25-.1 1.61-1.56 3.15-3.18 4.6-4.88.75-.88 1.49-1.78 2.15-2.73.01.01.03.02.04.03.34.3.83-.2.49-.49-2.16-1.9-4.34-3.76-6.64-5.48l.03-.01Zm-6.38-3.65a55.72 55.72 0 0 0-4-2.13c.14-.1.26-.19.4-.29 1.2.81 2.4 1.61 3.6 2.42Zm-20.1 11.78c.67-.37 1.23-.91 1.67-1.6-.11.5-.24 1-.38 1.49-.43.04-.86.08-1.29.11Zm2.38-37.24c1.34-.31 2.56-.52 3.71-.69-1.03.19-2.04.41-3.04.65-.14-.07-.34-.02-.45.11-.07.02-.15.04-.22.05v-.13.01Zm.04.84c.07-.02.14-.03.2-.05.34 1.66.41 3.41.5 5.09.17 2.9.24 5.81.28 8.71l.03 3.17c-.17.07-.34.14-.51.2-.06-4.96-.21-10.58-.51-17.12h.01Zm16.04 5.62c-1.16 2.25-3.06 4.1-5.02 5.66-2.8 2.23-5.99 3.97-9.3 5.35-.01-3.56-.09-7.12-.27-10.67-.1-2.04-.16-4.16-.57-6.18 3.3-.78 6.72-1.36 10.1-1.1 1.85.14 4.23.59 5.32 2.29.92 1.43.46 3.24-.26 4.65Zm.85-.18c.6-1.37.9-2.92.28-4.32-.67-1.52-2.2-2.32-3.76-2.74.46.1.89.21 1.29.37 1.74.67 2.69 1.88 2.93 3.21.2 1.13-.05 2.25-.74 3.47V70Zm-27.47-4.14c-.12-.19-.23-.38-.34-.57.74.42.85.36.99.41v.08c-.22.03-.43.06-.65.08Zm11.21 30.46c-.08 1.08-.16 2.17-.33 3.24-.05.35-.11.69-.2 1.03 0 .04-.02.07-.03.11-.15.02-.3.04-.45.05.45-1.64.76-3.36.79-5.07.03-.29.08-.57.1-.89-.03-.31-.03-.47.24-.57-.04.69-.07 1.39-.12 2.08v.02Zm5.6-2.47c.48.11.92.52 2.49 1.72-.46-.32-.92-.65-1.38-.97-.37-.25-.73-.5-1.1-.75h-.01Zm21.23 7.24a70.76 70.76 0 0 1-4.37 4.63c-.14-.09-.27-.19-.4-.28.19-.09.37-.24.55-.47.87-1.14 5.43-5.51 5.49-7.45.31.26.62.53.92.79-.67.97-1.42 1.88-2.19 2.77v.01Z",fill:"currentColor",transform:"translate(-144.023 -51.76)"})]}),tk=({style:e,size:t="small",withText:r})=>rk("div",{className:`ExcalidrawLogo is-${t}`,style:e,children:[pa(qN,{}),r&&pa(JN,{})]})});import{Fragment as ak,jsx as Nt,jsxs as sy}from"react/jsx-runtime";var cy,mm,nk,Do,dy,my,py,uy,hy,ik,lk=y(()=>{"use strict";f();ko();hl();q();we();lo();ne();jt();ok();cy=({icon:e,shortcut:t,children:r})=>{let o=_e();return sy(ak,{children:[Nt("div",{className:"welcome-screen-menu-item__icon",children:e}),Nt("div",{className:"welcome-screen-menu-item__text",children:r}),t&&!o.editor.isMobile&&Nt("div",{className:"welcome-screen-menu-item__shortcut",children:t})]})};cy.displayName="WelcomeScreenMenuItemContent";mm=({onSelect:e,children:t,icon:r,shortcut:o,className:n="",...i})=>Nt("button",{...i,type:"button",className:`welcome-screen-menu-item ${n}`,onClick:e,children:Nt(cy,{icon:r,shortcut:o,children:t})});mm.displayName="WelcomeScreenMenuItem";nk=({children:e,href:t,icon:r,shortcut:o,className:n="",...i})=>Nt("a",{...i,className:`welcome-screen-menu-item ${n}`,href:t,target:"_blank",rel:"noreferrer",children:Nt(cy,{icon:r,shortcut:o,children:e})});nk.displayName="WelcomeScreenMenuItemLink";Do=({children:e})=>{let{WelcomeScreenCenterTunnel:t}=lt();return Nt(t.In,{children:Nt("div",{className:"welcome-screen-center",children:e||sy(ak,{children:[Nt(dy,{}),Nt(my,{children:b("welcomeScreen.defaults.center_heading")}),sy(py,{children:[Nt(hy,{}),Nt(uy,{})]})]})})})};Do.displayName="Center";dy=({children:e})=>Nt("div",{className:"welcome-screen-center__logo virgil welcome-screen-decor",children:e||Nt(tk,{withText:!0})});dy.displayName="Logo";my=({children:e})=>Nt("div",{className:"welcome-screen-center__heading welcome-screen-decor virgil",children:e});my.displayName="Heading";py=({children:e})=>Nt("div",{className:"welcome-screen-menu",children:e});py.displayName="Menu";uy=()=>{let e=Ut();return Nt(mm,{onSelect:()=>e.executeAction(Zi),shortcut:"?",icon:Ja,children:b("helpDialog.title")})};uy.displayName="MenuItemHelp";hy=()=>{let e=Be(),t=Ut();return e.viewModeEnabled?null:Nt(mm,{onSelect:()=>t.executeAction(sl),shortcut:_t("loadScene"),icon:Qa,children:b("buttons.load")})};hy.displayName="MenuItemLoadScene";ik=({onSelect:e})=>{let{t}=Mt();return Nt(mm,{shortcut:null,onSelect:e,icon:ad,children:t("labels.liveCollaboration")})};ik.displayName="MenuItemLiveCollaborationTrigger";Do.Logo=dy;Do.Heading=my;Do.Menu=py;Do.MenuItem=mm;Do.MenuItemLink=nk;Do.MenuItemHelp=uy;Do.MenuItemLoadScene=hy;Do.MenuItemLiveCollaborationTrigger=ik});import{jsx as $s,jsxs as gy}from"react/jsx-runtime";var Dg,_g,Rg,sk=y(()=>{"use strict";f();q();lo();ne();Dg=({children:e})=>{let{WelcomeScreenMenuHintTunnel:t}=lt();return $s(t.In,{children:gy("div",{className:"virgil welcome-screen-decor welcome-screen-decor-hint welcome-screen-decor-hint--menu",children:[Y1,$s("div",{className:"welcome-screen-decor-hint__label",children:e||b("welcomeScreen.defaults.menuHint")})]})})};Dg.displayName="MenuHint";_g=({children:e})=>{let{WelcomeScreenToolbarHintTunnel:t}=lt();return $s(t.In,{children:gy("div",{className:"virgil welcome-screen-decor welcome-screen-decor-hint welcome-screen-decor-hint--toolbar",children:[$s("div",{className:"welcome-screen-decor-hint__label",children:e||b("welcomeScreen.defaults.toolbarHint")}),$1]})})};_g.displayName="ToolbarHint";Rg=({children:e})=>{let{WelcomeScreenHelpHintTunnel:t}=lt();return $s(t.In,{children:gy("div",{className:"virgil welcome-screen-decor welcome-screen-decor-hint welcome-screen-decor-hint--help",children:[$s("div",{children:e||b("welcomeScreen.defaults.helpHint")}),K1]})})};Rg.displayName="HelpHint"});var ck=y(()=>{});import{Fragment as dk,jsx as pm,jsxs as eO}from"react/jsx-runtime";var Ng,QN,mk=y(()=>{"use strict";f();lk();sk();ck();Ng=e=>pm(dk,{children:e.children||eO(dk,{children:[pm(Do,{}),pm(Dg,{}),pm(_g,{}),pm(Rg,{})]})});Ng.displayName="WelcomeScreen";Ng.Center=Do;Ng.Hints={MenuHint:Dg,ToolbarHint:_g,HelpHint:Rg};QN=Ng});var pk=y(()=>{});import tO from"clsx";import{jsx as oO,jsxs as nO}from"react/jsx-runtime";var uk,rO,hk=y(()=>{"use strict";f();q();ne();Os();pk();jt();uk=({isCollaborating:e,onSelect:t,...r})=>{let o=Be(),n=o.width<830;return nO(Tn,{...r,className:tO("collab-button",{active:e}),type:"button",onSelect:t,style:{position:"relative",width:n?void 0:"auto"},title:b("labels.liveCollaboration"),children:[n?fb:b("labels.share"),o.collaborators.size>0&&oO("div",{className:"CollabButton-collaborators",children:o.collaborators.size})]})},rO=uk;uk.displayName="LiveCollaborationTrigger"});var iO,aO,gk=y(()=>{"use strict";f();bo();G();iO=(e,t,r)=>!!(t&&(t.id===e.editingElement?.id||t.id===e.resizingElement?.id||t.id===e.draggingElement?.id||t.version>r.version||t.version===r.version&&t.versionNonce<r.versionNonce)),aO=(e,t,r)=>{let o=X(e),n=[],i=new Set;for(let l of t)if(!i.has(l.id)){let s=o.get(l.id),c=iO(r,s,l);s&&c?(n.push(s),i.add(s.id)):(n.push(l),i.add(l.id))}for(let l of e)i.has(l.id)||(n.push(l),i.add(l.id));let a=zm(n);return fr(a),a}});import{jsx as fk,jsxs as lO}from"react/jsx-runtime";var bk,Ek=y(()=>{"use strict";f();lo();zd();we();ne();q();Nr();bk=({children:e,icon:t})=>{let{TTDDialogTriggerTunnel:r}=lt(),o=He();return fk(r.In,{children:lO(Ve.Item,{onSelect:()=>{ve("ai","dialog open","ttd"),o({openDialog:{name:"ttd",tab:"text-to-diagram"}})},icon:t??aE,children:[e??b("labels.textToDiagram"),fk(Ve.Item.Badge,{children:"AI"})]})})};bk.displayName="TTDDialogTrigger"});import sO,{useEffect as cO}from"react";import{Provider as dO}from"jotai";import{parseMermaidToExcalidraw as pIe}from"@excalidraw/mermaid-to-excalidraw";import{jsx as fy}from"react/jsx-runtime";var mO,pO,uO,h1=y(()=>{f();$y();we();G();YA();KA();$A();ZA();q();W();kt();QA();y0();mk();hk();xe();q();Fa();gk();Va();qn();_r();sn();pl();me();W();Ye();ze();pl();G();qd();Os();we();ts();v0();O0();Ek();Na();vd();H0();dt();b1();Dr();kt();pl();ne();ko();hn();Nx();XA();mO=e=>{let{onChange:t,initialData:r,excalidrawAPI:o,isCollaborating:n=!1,onPointerUpdate:i,renderTopRightUI:a,langCode:l=jo.code,viewModeEnabled:s,zenModeEnabled:c,gridModeEnabled:d,libraryReturnUrl:m,theme:p,name:u,renderCustomStats:h,onPaste:E,detectScroll:x=!0,handleKeyboardGlobally:T=!1,onLibraryChange:v,autoFocus:w=!1,generateIdForFile:I,onLinkOpen:L,onPointerDown:A,onPointerUp:M,onScrollChange:D,id:O,onHomeButtonClick:R,children:B,validateEmbeddable:k,renderEmbeddable:z,aiEnabled:ee,ui:j,interactive:ie,activeTool:ke}=e,$=e.UIOptions?.canvasActions,Y={...e.UIOptions,canvasActions:{...Gg.canvasActions,...$},tools:{image:e.UIOptions?.tools?.image??!0}};return $?.export&&(Y.canvasActions.export.saveFileToDisk=$.export?.saveFileToDisk??Gg.canvasActions.export.saveFileToDisk),Y.canvasActions.toggleTheme===null&&typeof p>"u"&&(Y.canvasActions.toggleTheme=!0),cO(()=>{(async()=>{await import("canvas-roundrect-polyfill")})();let fe=De=>{typeof De.scale=="number"&&De.scale!==1&&De.preventDefault()};return document.addEventListener("touchmove",fe,{passive:!1}),()=>{document.removeEventListener("touchmove",fe)}},[]),fy(dO,{unstable_createStore:()=>Qt,scope:Ge,children:fy(Ky,{langCode:l,theme:p,children:fy(WA,{id:O,onChange:t,initialData:r,excalidrawAPI:o,isCollaborating:n,onPointerUpdate:i,renderTopRightUI:a,langCode:l,viewModeEnabled:ie===!1?!0:s,zenModeEnabled:c,gridModeEnabled:d,libraryReturnUrl:m,theme:p,name:u,renderCustomStats:h,UIOptions:Y,onPaste:E,detectScroll:x,handleKeyboardGlobally:T,onLibraryChange:v,autoFocus:w,generateIdForFile:I,onLinkOpen:L,onPointerDown:A,onPointerUp:M,onScrollChange:D,validateEmbeddable:k,renderEmbeddable:z,aiEnabled:ee!==!1,onHomeButtonClick:R,ui:j,interactive:ie,activeTool:ke,children:B})})})},pO=(e,t)=>{if(e.children!==t.children)return!1;let{initialData:r,UIOptions:o={},...n}=e,{initialData:i,UIOptions:a={},...l}=t,s=Object.keys(o),c=Object.keys(a);return s.length!==c.length?!1:s.every(m=>m==="canvasActions"?Object.keys(o.canvasActions).every(u=>u==="export"&&o?.canvasActions?.export&&a?.canvasActions?.export?o.canvasActions.export.saveFileToDisk===a.canvasActions.export.saveFileToDisk:o?.canvasActions?.[u]===a?.canvasActions?.[u]):o[m]===a[m])&&rt(n,l)},uO=sO.memo(mO,pO);uO.displayName="Excalidraw"});h1();export{Tn as Button,H_ as CommandPalette,zg as DEFAULT_LASER_COLOR,sg as DefaultSidebar,uO as Excalidraw,ht as FONT_FAMILY,jN as Footer,rO as LiveCollaborationTrigger,te as MIME_TYPES,Sr as MainMenu,ct as ROUNDNESS,si as Sidebar,_ as StoreAction,se as THEME,N0 as TTDDialog,bk as TTDDialogTrigger,QN as WelcomeScreen,XC as actions,_i as bumpVersion,Ac as cleanAppStateForExport,jM as clearAppStateForLocalStorage,tm as convertToExcalidrawElements,jo as defaultLang,Yl as duplicateElement,Lc as duplicateElements,$v as elementPartiallyOverlapsWithOrContainsBBox,f1 as elementsOverlappingBBox,Qp as exportToBlob,Bi as exportToCanvas,XL as exportToClipboard,ls as exportToSvg,Ae as getCommonBounds,Er as getDefaultAppState,vp as getFreeDrawSvgPath,wh as getLibraryItemsHash,ye as getNonDeletedElements,bP as getSceneVersion,$M as getVisibleSceneBounds,R1 as hashElementsVersion,N1 as hashString,DT as icons,g1 as isElementInsideBBox,yo as isInvisiblySmallElement,ce as isLinearElement,Ge as jotaiScope,Qt as jotaiStore,vl as languages,Ji as libraryItemsAtom,Jl as loadFromBlob,e1 as loadLibraryFromBlob,Cp as loadSceneOrLibraryFromBlob,C5 as mergeLibraryItems,H as mutateElement,le as newElementWith,yr as normalizeLink,ox as parseLibraryTokensFromUrl,pIe as parseMermaidToExcalidraw,aO as reconcileElements,Oa as restore,Tp as restoreAppState,zc as restoreElements,Ba as restoreLibraryItems,Vt as sceneCoordsToViewportCoords,Oi as serializeAsJSON,Mp as serializeLibraryAsJSON,_e as useDevice,U7 as useHandleLibrary,Mt as useI18n,je as viewportCoordsToSceneCoords,j3 as zoomToFitBounds};