@excalidraw/excalidraw 0.17.1-7500-ac247a0 → 0.17.1-b7babe5
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.
- package/CHANGELOG.md +56 -2
- package/dist/browser/dev/excalidraw-assets-dev/{chunk-2W5GQUR4.js → chunk-6NMK7JTV.js} +13 -6
- package/dist/browser/dev/excalidraw-assets-dev/chunk-6NMK7JTV.js.map +7 -0
- package/dist/browser/dev/excalidraw-assets-dev/chunk-CX3RATXT.js +20324 -0
- package/dist/browser/dev/excalidraw-assets-dev/chunk-CX3RATXT.js.map +7 -0
- package/dist/browser/dev/excalidraw-assets-dev/{en-OC6JWP3X.js → en-BZY7JRTM.js} +4 -2
- package/dist/browser/dev/excalidraw-assets-dev/{image-5TVMINCA.js → image-CVN3YKRW.js} +2 -4
- package/dist/browser/dev/excalidraw-assets-dev/image-LK4UNFRZ.css +6 -0
- package/dist/browser/dev/excalidraw-assets-dev/image-LK4UNFRZ.css.map +7 -0
- package/dist/browser/dev/excalidraw-assets-dev/roundRect-T5BX56ZF.js +161 -0
- package/dist/browser/dev/excalidraw-assets-dev/roundRect-T5BX56ZF.js.map +7 -0
- package/dist/browser/dev/index.css +189 -129
- package/dist/browser/dev/index.css.map +3 -3
- package/dist/browser/dev/index.js +34964 -37
- package/dist/browser/dev/index.js.map +4 -4
- package/dist/browser/prod/excalidraw-assets/chunk-VJAIK3AX.js +55 -0
- package/dist/browser/prod/excalidraw-assets/chunk-YYO5DFUW.js +11 -0
- package/dist/browser/prod/excalidraw-assets/en-O2YCQM2W.js +1 -0
- package/dist/browser/prod/excalidraw-assets/image-6FKY54X5.js +1 -0
- package/dist/browser/prod/excalidraw-assets/image-X66R2EM5.css +1 -0
- package/dist/browser/prod/excalidraw-assets/roundRect-2ACQK4DA.js +1 -0
- package/dist/browser/prod/index.css +1 -1
- package/dist/browser/prod/index.js +203 -1
- package/dist/{prod/en-RLIAOBCI.json → dev/en-EY7E2L5O.json} +10 -5
- package/dist/dev/index.css +189 -129
- package/dist/dev/index.css.map +3 -3
- package/dist/dev/index.js +38702 -39409
- package/dist/dev/index.js.map +4 -4
- package/dist/excalidraw/actions/actionAddToLibrary.d.ts +15 -15
- package/dist/excalidraw/actions/actionAlign.d.ts +6 -6
- package/dist/excalidraw/actions/actionAlign.js +2 -1
- package/dist/excalidraw/actions/actionBoundText.d.ts +10 -10
- package/dist/excalidraw/actions/actionBoundText.js +8 -8
- package/dist/excalidraw/actions/actionCanvas.d.ts +58 -58
- package/dist/excalidraw/actions/actionClipboard.d.ts +34 -34
- package/dist/excalidraw/actions/actionClipboard.js +9 -2
- package/dist/excalidraw/actions/actionDeleteSelected.d.ts +15 -15
- package/dist/excalidraw/actions/actionDeleteSelected.js +3 -2
- package/dist/excalidraw/actions/actionDistribute.d.ts +2 -2
- package/dist/excalidraw/actions/actionDistribute.js +1 -1
- package/dist/excalidraw/actions/actionDuplicateSelection.d.ts +1 -1
- package/dist/excalidraw/actions/actionDuplicateSelection.js +4 -3
- package/dist/excalidraw/actions/actionElementLock.d.ts +10 -10
- package/dist/excalidraw/actions/actionExport.d.ts +43 -43
- package/dist/excalidraw/actions/actionExport.js +4 -4
- package/dist/excalidraw/actions/actionFinalize.d.ts +9 -9
- package/dist/excalidraw/actions/actionFinalize.js +7 -6
- package/dist/excalidraw/actions/actionFlip.d.ts +2 -2
- package/dist/excalidraw/actions/actionFlip.js +11 -11
- package/dist/excalidraw/actions/actionFrame.d.ts +16 -16
- package/dist/excalidraw/actions/actionFrame.js +1 -1
- package/dist/excalidraw/actions/actionGroup.d.ts +10 -10
- package/dist/excalidraw/actions/actionGroup.js +3 -2
- package/dist/excalidraw/actions/actionLinearEditor.d.ts +5 -5
- package/dist/excalidraw/actions/actionLinearEditor.js +1 -1
- package/dist/excalidraw/{element/Hyperlink.d.ts → actions/actionLink.d.ts} +29 -51
- package/dist/excalidraw/actions/actionLink.js +40 -0
- package/dist/excalidraw/actions/actionMenu.d.ts +13 -13
- package/dist/excalidraw/actions/actionNavigate.d.ts +10 -10
- package/dist/excalidraw/actions/actionNavigate.js +1 -1
- package/dist/excalidraw/actions/actionProperties.d.ts +77 -77
- package/dist/excalidraw/actions/actionProperties.js +32 -27
- package/dist/excalidraw/actions/actionSelectAll.d.ts +5 -5
- package/dist/excalidraw/actions/actionSelectAll.js +1 -1
- package/dist/excalidraw/actions/actionStyles.d.ts +7 -7
- package/dist/excalidraw/actions/actionStyles.js +4 -4
- package/dist/excalidraw/actions/actionToggleGridMode.d.ts +5 -5
- package/dist/excalidraw/actions/actionToggleObjectsSnapMode.d.ts +5 -5
- package/dist/excalidraw/actions/actionToggleStats.d.ts +5 -5
- package/dist/excalidraw/actions/actionToggleViewMode.d.ts +5 -5
- package/dist/excalidraw/actions/actionToggleZenMode.d.ts +5 -5
- package/dist/excalidraw/actions/index.d.ts +1 -1
- package/dist/excalidraw/actions/index.js +1 -1
- package/dist/excalidraw/actions/manager.js +2 -1
- package/dist/excalidraw/align.d.ts +2 -2
- package/dist/excalidraw/align.js +2 -2
- package/dist/excalidraw/animated-trail.d.ts +33 -0
- package/dist/excalidraw/animated-trail.js +96 -0
- package/dist/excalidraw/animation-frame-handler.d.ts +16 -0
- package/dist/excalidraw/animation-frame-handler.js +55 -0
- package/dist/excalidraw/appState.d.ts +1 -1
- package/dist/excalidraw/appState.js +1 -3
- package/dist/excalidraw/clipboard.js +5 -5
- package/dist/excalidraw/components/Actions.d.ts +3 -3
- package/dist/excalidraw/components/Actions.js +18 -7
- package/dist/excalidraw/components/App.d.ts +23 -16
- package/dist/excalidraw/components/App.js +387 -272
- package/dist/excalidraw/components/Button.d.ts +1 -1
- package/dist/excalidraw/components/FilledButton.d.ts +2 -2
- package/dist/excalidraw/components/FilledButton.js +27 -3
- package/dist/excalidraw/components/FollowMode/FollowMode.js +1 -1
- package/dist/excalidraw/components/ImageExportDialog.d.ts +2 -1
- package/dist/excalidraw/components/ImageExportDialog.js +17 -13
- package/dist/excalidraw/components/JSONExportDialog.js +1 -1
- package/dist/excalidraw/components/{LaserTool/LaserPointerButton.d.ts → LaserPointerButton.d.ts} +1 -1
- package/dist/excalidraw/components/{LaserTool/LaserPointerButton.js → LaserPointerButton.js} +2 -2
- package/dist/excalidraw/components/LayerUI.js +3 -3
- package/dist/excalidraw/components/MobileMenu.js +1 -1
- package/dist/excalidraw/components/ProjectName.d.ts +0 -1
- package/dist/excalidraw/components/ProjectName.js +1 -1
- package/dist/excalidraw/components/PublishLibrary.js +1 -1
- package/dist/excalidraw/components/SVGLayer.d.ts +8 -0
- package/dist/excalidraw/components/SVGLayer.js +20 -0
- package/dist/excalidraw/components/ShareableLinkDialog.js +10 -10
- package/dist/excalidraw/components/Sidebar/Sidebar.d.ts +1 -1
- package/dist/excalidraw/components/Stack.d.ts +2 -2
- package/dist/excalidraw/components/TTDDialog/common.js +10 -1
- package/dist/excalidraw/components/TextField.d.ts +5 -2
- package/dist/excalidraw/components/TextField.js +6 -3
- package/dist/excalidraw/components/Toast.d.ts +3 -2
- package/dist/excalidraw/components/Toast.js +2 -2
- package/dist/excalidraw/components/ToolButton.js +2 -1
- package/dist/excalidraw/components/canvases/InteractiveCanvas.d.ts +2 -2
- package/dist/excalidraw/components/canvases/InteractiveCanvas.js +6 -5
- package/dist/excalidraw/components/canvases/StaticCanvas.d.ts +4 -3
- package/dist/excalidraw/components/canvases/StaticCanvas.js +7 -5
- package/dist/excalidraw/components/dropdownMenu/DropdownMenuContent.js +22 -2
- package/dist/excalidraw/components/hyperlink/Hyperlink.d.ts +19 -0
- package/dist/excalidraw/{element → components/hyperlink}/Hyperlink.js +40 -115
- package/dist/excalidraw/components/hyperlink/helpers.d.ts +7 -0
- package/dist/excalidraw/components/hyperlink/helpers.js +49 -0
- package/dist/excalidraw/components/icons.d.ts +2 -1
- package/dist/excalidraw/components/icons.js +2 -1
- package/dist/excalidraw/components/live-collaboration/LiveCollaborationTrigger.js +3 -2
- package/dist/excalidraw/components/main-menu/DefaultItems.js +5 -2
- package/dist/excalidraw/constants.d.ts +6 -0
- package/dist/excalidraw/constants.js +6 -0
- package/dist/excalidraw/data/blob.js +13 -14
- package/dist/excalidraw/data/filesystem.d.ts +1 -1
- package/dist/excalidraw/data/index.d.ts +2 -1
- package/dist/excalidraw/data/index.js +20 -16
- package/dist/excalidraw/data/json.d.ts +1 -1
- package/dist/excalidraw/data/json.js +5 -3
- package/dist/excalidraw/data/library.d.ts +60 -8
- package/dist/excalidraw/data/library.js +302 -33
- package/dist/excalidraw/data/resave.d.ts +1 -1
- package/dist/excalidraw/data/resave.js +2 -2
- package/dist/excalidraw/data/restore.js +8 -13
- package/dist/excalidraw/data/transform.js +13 -9
- package/dist/excalidraw/distribute.d.ts +2 -2
- package/dist/excalidraw/distribute.js +2 -2
- package/dist/excalidraw/element/ElementCanvasButtons.d.ts +3 -2
- package/dist/excalidraw/element/ElementCanvasButtons.js +4 -4
- package/dist/excalidraw/element/binding.d.ts +9 -9
- package/dist/excalidraw/element/binding.js +61 -59
- package/dist/excalidraw/element/bounds.d.ts +5 -5
- package/dist/excalidraw/element/bounds.js +29 -32
- package/dist/excalidraw/element/collision.d.ts +11 -11
- package/dist/excalidraw/element/collision.js +49 -46
- package/dist/excalidraw/element/containerCache.d.ts +11 -0
- package/dist/excalidraw/element/containerCache.js +14 -0
- package/dist/excalidraw/element/dragElements.js +10 -19
- package/dist/excalidraw/element/embeddable.d.ts +12 -13
- package/dist/excalidraw/element/embeddable.js +17 -27
- package/dist/excalidraw/element/image.js +1 -2
- package/dist/excalidraw/element/index.d.ts +8 -1
- package/dist/excalidraw/element/index.js +23 -1
- package/dist/excalidraw/element/linearElementEditor.d.ts +36 -36
- package/dist/excalidraw/element/linearElementEditor.js +79 -80
- package/dist/excalidraw/element/newElement.d.ts +4 -6
- package/dist/excalidraw/element/newElement.js +11 -16
- package/dist/excalidraw/element/resizeElements.d.ts +6 -6
- package/dist/excalidraw/element/resizeElements.js +40 -46
- package/dist/excalidraw/element/resizeTest.d.ts +3 -3
- package/dist/excalidraw/element/resizeTest.js +4 -4
- package/dist/excalidraw/element/sizeHelpers.d.ts +2 -2
- package/dist/excalidraw/element/sizeHelpers.js +2 -2
- package/dist/excalidraw/element/textElement.d.ts +34 -21
- package/dist/excalidraw/element/textElement.js +87 -111
- package/dist/excalidraw/element/textWysiwyg.d.ts +1 -6
- package/dist/excalidraw/element/textWysiwyg.js +15 -37
- package/dist/excalidraw/element/transformHandles.d.ts +4 -4
- package/dist/excalidraw/element/transformHandles.js +6 -6
- package/dist/excalidraw/element/typeChecks.js +4 -1
- package/dist/excalidraw/element/types.d.ts +24 -11
- package/dist/excalidraw/frame.d.ts +26 -20
- package/dist/excalidraw/frame.js +157 -84
- package/dist/excalidraw/groups.d.ts +3 -3
- package/dist/excalidraw/groups.js +11 -3
- package/dist/excalidraw/history.d.ts +1 -1
- package/dist/excalidraw/hooks/useLibraryItemSvg.js +1 -1
- package/dist/excalidraw/index.d.ts +9 -10
- package/dist/excalidraw/index.js +16 -12
- package/dist/excalidraw/laser-trails.d.ts +19 -0
- package/dist/excalidraw/laser-trails.js +95 -0
- package/dist/excalidraw/locales/en.json +10 -5
- package/dist/excalidraw/queue.d.ts +9 -0
- package/dist/excalidraw/queue.js +27 -0
- package/dist/excalidraw/reactUtils.d.ts +14 -0
- package/dist/excalidraw/reactUtils.js +45 -0
- package/dist/excalidraw/renderer/helpers.d.ts +13 -0
- package/dist/excalidraw/renderer/helpers.js +39 -0
- package/dist/excalidraw/renderer/interactiveScene.d.ts +20 -0
- package/dist/excalidraw/renderer/{renderScene.js → interactiveScene.js} +199 -474
- package/dist/excalidraw/renderer/renderElement.d.ts +6 -6
- package/dist/excalidraw/renderer/renderElement.js +54 -366
- package/dist/excalidraw/renderer/staticScene.d.ts +11 -0
- package/dist/excalidraw/renderer/staticScene.js +205 -0
- package/dist/excalidraw/renderer/staticSvgScene.d.ts +5 -0
- package/dist/excalidraw/renderer/staticSvgScene.js +385 -0
- package/dist/excalidraw/scene/Fonts.js +2 -1
- package/dist/excalidraw/scene/Renderer.d.ts +1 -1
- package/dist/excalidraw/scene/Renderer.js +32 -20
- package/dist/excalidraw/scene/Scene.d.ts +10 -9
- package/dist/excalidraw/scene/Scene.js +45 -21
- package/dist/excalidraw/scene/Shape.d.ts +3 -1
- package/dist/excalidraw/scene/Shape.js +7 -5
- package/dist/excalidraw/scene/ShapeCache.d.ts +2 -1
- package/dist/excalidraw/scene/ShapeCache.js +1 -0
- package/dist/excalidraw/scene/comparisons.js +2 -1
- package/dist/excalidraw/scene/export.d.ts +3 -0
- package/dist/excalidraw/scene/export.js +20 -40
- package/dist/excalidraw/scene/index.d.ts +0 -1
- package/dist/excalidraw/scene/index.js +0 -1
- package/dist/excalidraw/scene/scrollbars.d.ts +1 -1
- package/dist/excalidraw/scene/scrollbars.js +1 -1
- package/dist/excalidraw/scene/selection.d.ts +5 -5
- package/dist/excalidraw/scene/selection.js +16 -14
- package/dist/excalidraw/scene/types.d.ts +11 -5
- package/dist/excalidraw/snapping.d.ts +7 -7
- package/dist/excalidraw/snapping.js +21 -20
- package/dist/excalidraw/types.d.ts +16 -17
- package/dist/excalidraw/utility-types.d.ts +7 -0
- package/dist/excalidraw/utils.d.ts +21 -16
- package/dist/excalidraw/utils.js +43 -45
- package/dist/{dev/en-RLIAOBCI.json → prod/en-EY7E2L5O.json} +10 -5
- package/dist/prod/index.css +1 -1
- package/dist/prod/index.js +42 -42
- package/dist/utils/bbox.d.ts +2 -2
- package/dist/utils/export.d.ts +3 -3
- package/dist/utils/export.js +3 -13
- package/dist/utils/index.d.ts +2 -2
- package/dist/utils/index.js +2 -2
- package/dist/utils/withinBounds.d.ts +1 -1
- package/dist/utils/withinBounds.js +5 -2
- package/package.json +4 -4
- package/dist/browser/dev/excalidraw-assets-dev/chunk-2W5GQUR4.js.map +0 -7
- package/dist/browser/dev/excalidraw-assets-dev/chunk-KGZXLFLR.js +0 -53497
- package/dist/browser/dev/excalidraw-assets-dev/chunk-KGZXLFLR.js.map +0 -7
- package/dist/browser/dev/excalidraw-assets-dev/image-3MFRCKYM.css +0 -5797
- package/dist/browser/dev/excalidraw-assets-dev/image-3MFRCKYM.css.map +0 -7
- package/dist/browser/prod/excalidraw-assets/chunk-4YN2HN3S.js +0 -257
- package/dist/browser/prod/excalidraw-assets/chunk-OWLL6VOG.js +0 -11
- package/dist/browser/prod/excalidraw-assets/en-ERQOR3OC.js +0 -1
- package/dist/browser/prod/excalidraw-assets/image-LTLHTTSE.js +0 -1
- package/dist/browser/prod/excalidraw-assets/image-QBL334OA.css +0 -1
- package/dist/excalidraw/components/LaserTool/LaserPathManager.d.ts +0 -28
- package/dist/excalidraw/components/LaserTool/LaserPathManager.js +0 -225
- package/dist/excalidraw/components/LaserTool/LaserTool.d.ts +0 -8
- package/dist/excalidraw/components/LaserTool/LaserTool.js +0 -15
- package/dist/excalidraw/renderer/renderScene.d.ts +0 -25
- package/dist/excalidraw/vite.config.d.mts +0 -2
- package/dist/excalidraw/vite.config.mjs +0 -13
- /package/dist/browser/dev/excalidraw-assets-dev/{en-OC6JWP3X.js.map → en-BZY7JRTM.js.map} +0 -0
- /package/dist/browser/dev/excalidraw-assets-dev/{image-5TVMINCA.js.map → image-CVN3YKRW.js.map} +0 -0
package/dist/prod/index.js
CHANGED
|
@@ -1,40 +1,34 @@
|
|
|
1
|
-
var hC=Object.defineProperty;var Sb=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 Cb=(e,t)=>{for(var r in t)hC(e,r,{get:t[r],enumerable:!0})};var I,h=y(()=>{I={PROD:!0}});import{unstable_createStore as bC,useAtom as FD}from"jotai";import{useLayoutEffect as zD}from"react";var Be,mr,_t=y(()=>{"use strict";h();Be=Symbol(),mr=bC()});var xC,wp=y(()=>{xC=Sb({"./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-RLIAOBCI.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 Ab from"./en-RLIAOBCI.json";import EC from"./percentages-UCQDHIQF.json";import{atom as yC,useAtomValue as wC}from"jotai";var vC,Ro,Ma,Kc,Aa,Yc,$c,rn,kb,f,Mb,Pt,Y=y(()=>{"use strict";h();_t();wp();vC=85,Ro={code:"en",label:"English"},Ma=[Ro,...[{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=>EC[e.code]>=vC).sort((e,t)=>e.label>t.label?1:-1)],Kc="__test__";I.DEV&&Ma.unshift({code:Kc,label:"test language"},{code:`${Kc}.rtl`,label:"\u202Atest language (rtl)\u202C",rtl:!0});Aa=Ro,Yc={},$c=async e=>{if(Aa=e,document.documentElement.dir=Aa.rtl?"rtl":"ltr",document.documentElement.lang=Aa.code,e.code.startsWith(Kc))Yc={};else try{Yc=await xC(`./locales/${Aa.code}.json`)}catch(t){console.error(`Failed to load language ${e.code}:`,t.message),Yc=Ab}mr.set(Mb,e.code)},rn=()=>Aa,kb=(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},f=(e,t,r)=>{if(Aa.code.startsWith(Kc))return`\u202A[[${t?`${e}(${JSON.stringify(t).slice(1,-1)})`:e}]]\u202C`;let o=e.split("."),n=kb(Yc,o)||kb(Ab,o)||r;if(n===void 0){let i=`Can't find translation for ${e}`;if(I.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},Mb=yC(Ro.code),Pt=()=>{let e=wC(Mb,Be);return{t:f,langCode:e}}});var Lb=y(()=>{});import TC from"react";import{jsx as vp}from"react/jsx-runtime";var IC,tr,Wn=y(()=>{"use strict";h();Lb();IC=({size:e="1em",circleWidth:t=8,synchronized:r=!1})=>{let n=-(TC.useRef(Date.now()).current%1600);return vp("div",{className:"Spinner",children:vp("svg",{viewBox:"0 0 100 100",style:{width:e,height:e,"--spinner-delay":r?`${n}ms`:0},children:vp("circle",{cx:"50",cy:"50",r:50-t/2,strokeWidth:t,fill:"none",strokeMiterlimit:"10"})})})},tr=IC});var Tp,_b=y(()=>{Tp={}});import CC from"open-color";var kC,Pb,Ui,Db,La,_a,ho,fo,oe,Rb,Xc,Zc,jc,Nb,Bb,Ob,Fb,Yt=y(()=>{"use strict";h();kC=(e,t)=>t.reduce((r,o)=>(o in e&&(r[o]=e[o]),r),{}),Pb=5,Ui=5,Db=4,La=4,_a=1,ho=[0,2,4,6,8],fo=(e,t)=>t.map(r=>CC[e][r]),oe={transparent:"transparent",black:"#1e1e1e",white:"#ffffff",gray:fo("gray",ho),red:fo("red",ho),pink:fo("pink",ho),grape:fo("grape",ho),violet:fo("violet",ho),blue:fo("blue",ho),cyan:fo("cyan",ho),teal:fo("teal",ho),green:fo("green",ho),yellow:fo("yellow",ho),orange:fo("orange",ho),bronze:["#f8f1ee","#eaddd7","#d2bab0","#a18072","#846358"]},Rb=kC(oe,["cyan","blue","violet","grape","pink","green","teal","yellow","orange","red"]),Xc=[oe.black,oe.red[La],oe.green[La],oe.blue[La],oe.yellow[La]],Zc=[oe.transparent,oe.red[_a],oe.green[_a],oe.blue[_a],oe.yellow[_a]],jc=[oe.white,"#f8f9fa","#f5faff","#fffce8","#fdf8f6"],Nb={transparent:oe.transparent,white:oe.white,gray:oe.gray,black:oe.black,bronze:oe.bronze,...Rb},Bb={transparent:oe.transparent,white:oe.white,gray:oe.gray,black:oe.black,bronze:oe.bronze,...Rb},Ob=e=>[oe.cyan[e],oe.blue[e],oe.violet[e],oe.grape[e],oe.pink[e],oe.green[e],oe.teal[e],oe.yellow[e],oe.orange[e],oe.red[e]],Fb=(e,t,r)=>`#${((1<<24)+(e<<16)+(t<<8)+r).toString(16).slice(1)}`});var rr,qc,m9,Vn,AC,Jc,Hb,zb,ss,on,Pa,Gb,Ip,Ub,No,Me,Yn,Wi,cs,Sp,Qc,St,nt,Qe,Cp,ed,Ct,Ft,Kn,Vi,nn,ds,Wb,Z,td,Kt,ms,Vb,Yb,Kb,$b,Yi,rd,Xb,Da,od,nd,kp,Zb,jb,qb,Jb,Qb,Ra,Na,bo,ex,Ap,et,Ki,ut,tx,rx,ht,$n,ox,id,nx,st,ad,Mp,ld,tt,us,Bo,sd,ft,Wr,X=y(()=>{"use strict";h();_b();Yt();rr=/Mac|iPod|iPhone|iPad/.test(navigator.platform),qc=/^Win/.test(navigator.platform),m9=/\b(android)\b/i.test(navigator.userAgent),Vn="netscape"in window&&navigator.userAgent.indexOf("rv:")>1&&navigator.userAgent.indexOf("Gecko")>1,AC=navigator.userAgent.indexOf("Chrome")!==-1,Jc=!AC&&navigator.userAgent.indexOf("Safari")!==-1,Hb=/iPad|iPhone/.test(navigator.platform)||navigator.userAgent.includes("Mac")&&"ontouchend"in document,zb=()=>navigator.brave?.isBrave?.name==="isBrave",ss="Excalidraw",on=10,Pa=8,Gb=5,Ip=1,Ub=30,No=Math.PI/12,Me={TEXT:"text",CROSSHAIR:"crosshair",GRABBING:"grabbing",GRAB:"grab",POINTER:"pointer",MOVE:"move",AUTO:""},Yn={MAIN:0,WHEEL:1,SECONDARY:2,TOUCH:-1,ERASER:5},Wi={enabled:"all",disabled:"none",inheritFromUI:"var(--ui-pointerEvents)"},cs={UNSTARTED:-1,ENDED:0,PLAYING:1,PAUSED:2,BUFFERING:3,CUED:5},Sp={TEST:"test",DEVELOPMENT:"development"},Qc={SHAPE_ACTIONS_MENU:"App-menu__left"},St={Virgil:1,Helvetica:2,Cascadia:3,Assistant:4},nt={LIGHT:"light",DARK:"dark"},Qe={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},Cp="Segoe UI Emoji",ed=1,Ct=20,Ft=St.Virgil,Kn="left",Vi="top",nn=20,ds={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"},Wb=["text/plain","text/html"],Z={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",...ds},td={png:"png",svg:"svg",clipboard:"clipboard"},Kt={excalidraw:"excalidraw",excalidrawClipboard:"excalidraw/clipboard",excalidrawLibrary:"excalidrawlib",excalidrawClipboardWithAPI:"excalidraw-api/clipboard"},ms=window.EXCALIDRAW_EXPORT_SOURCE||window.location.origin,Vb=500,Yb=300,Kb=500,$b=100,Yi=.1,rd=.1,Xb=300,Da=Tp.themeFilter,od={addLibrary:"addLibrary"},nd={addLibrary:"addLibrary"},kp={canvasActions:{changeViewBackgroundColor:!0,clearCanvas:!0,export:{saveFileToDisk:!0},loadScene:!0,saveToActiveFile:!0,toggleTheme:null,saveAsImage:!0},tools:{image:!0}},Zb=730,jb=1e3,qb=500,Jb=1229,Qb=parseInt(Tp.rightSidebarWidth),Ra=2,Na=[1,2,3],bo=10,ex=1440,Ap=2*1024*1024,et="http://www.w3.org/2000/svg",Ki={excalidraw:2,excalidrawLibrary:2},ut=5,tx=.7,rx=11,ht={TOP:"top",MIDDLE:"middle",BOTTOM:"bottom"},$n={LEFT:"left",CENTER:"center",RIGHT:"right"},ox=20,id=.25,nx=32,st={LEGACY:1,PROPORTIONAL_RADIUS:2,ADAPTIVE_RADIUS:3},ad="__precedingElement__",Mp={architect:0,artist:1,cartoonist:2},ld={thin:1,bold:2,extraBold:4},tt={strokeColor:oe.black,backgroundColor:oe.transparent,fillStyle:"solid",strokeWidth:2,strokeStyle:"solid",roughness:Mp.artist,opacity:100,locked:!1},us="library",Bo={name:"default",defaultTab:us},sd=new Set(["iframe","embeddable","image"]),ft={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"},Wr={OAI_API_KEY:"excalidraw-oai-api-key",MERMAID_TO_EXCALIDRAW:"mermaid-to-excalidraw",PUBLISH_LIBRARY:"publish-library-data"}});import{useState as MC,useEffect as LC}from"react";import _C from"clsx";import{jsx as Lp,jsxs as PC}from"react/jsx-runtime";var cd,_p=y(()=>{"use strict";h();Y();Wn();X();cd=({delay:e,theme:t})=>{let[r,o]=MC(!!e);return LC(()=>{if(!e)return;let n=setTimeout(()=>{o(!1)},e);return()=>clearTimeout(n)},[e]),r?null:PC("div",{className:_C("LoadingMessage",{"LoadingMessage--dark":t===nt.DARK}),children:[Lp("div",{children:Lp(tr,{})}),Lp("div",{className:"LoadingMessage-text",children:f("labels.loadingScene")})]})}});import{useEffect as DC,useState as RC}from"react";import{jsx as NC}from"react/jsx-runtime";var ix,ax=y(()=>{"use strict";h();_p();Y();ix=e=>{let[t,r]=RC(!0);return DC(()=>{let o=async()=>{await $c(n),r(!1)},n=Ma.find(i=>i.code===e.langCode)||Ro;o()},[e.langCode]),t?NC(cd,{theme:e.theme}):e.children}});import{unstable_batchedUpdates as dx}from"react-dom";import BC from"react";function mt(e,t,r,o){return e?(e?.addEventListener?.(t,r,o),()=>{e?.removeEventListener?.(t,r,o)}):()=>{}}var lx,mx,Ba,ux,Pp,px,Oo,Oa,_e,$i,dd,md,sx,gx,hx,kt,Xe,_,Ue,Dt,ps,OC,FC,HC,Dp,xo,ud,Rp,Np,or,it,pd,fx,bx,xx,an,Ce,Ex,kr,gd,Fa,yx,hd,gs,cx,bt,Xn,Zn,wx,fd,hs,Vr,Bp,bd,W=y(()=>{"use strict";h();Yt();X();lx=null,mx=()=>{if(lx)return lx;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}`},Ba=e=>e.charAt(0).toUpperCase()+e.slice(1),ux=e=>e instanceof HTMLElement&&e.className.includes("ToolIcon"),Pp=e=>e instanceof HTMLElement&&e.dataset.type==="wysiwyg"||e instanceof HTMLBRElement||e instanceof HTMLInputElement||e instanceof HTMLTextAreaElement||e instanceof HTMLSelectElement,px=e=>Pp(e)||e instanceof Element&&!!e.closest("label, button"),Oo=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"),Oa=({fontFamily:e})=>{for(let[t,r]of Object.entries(St))if(r===e)return`${t}, ${Cp}`;return Cp},_e=({fontSize:e,fontFamily:t})=>`${e}px ${Oa({fontFamily:t})}`,$i=(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},dd=(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(I.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},md=e=>1-Math.pow(1-e,4),sx=(e,t,r)=>(t-e)*md(r)+e,gx=({fromValues:e,toValues:t,onStep:r,duration:o=250,interpolateValue:n,onStart:i,onEnd:a,onCancel:l})=>{let c=!1,s=0,d;function m(u){if(c)return;d===void 0&&(d=u,i?.());let p=Math.min(u-d,o),g=md(p/o),b={};if(Object.keys(e).forEach(E=>{let w=E,v=(t[w]-e[w])*g+e[w];b[w]=v}),r(b),p<o){let E=p/o,w={};Object.keys(e).forEach(v=>{let T=v,k=e[T],M=t[T],A;A=n?n(k,M,E,T):sx(k,M,E),A==null&&(A=sx(k,M,E)),w[T]=A}),r(w),s=window.requestAnimationFrame(m)}else r(t),a?.()}return s=window.requestAnimationFrame(m),()=>{l?.(),c=!0,window.cancelAnimationFrame(s)}},hx=(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},kt=(e,t)=>Math.abs(e-t),Xe=(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},_=e=>(e=e.replace(/\bAlt\b/i,"Alt").replace(/\bShift\b/i,"Shift").replace(/\b(Enter|Return)\b/i,"Enter"),rr?e.replace(/\bCtrlOrCmd\b/gi,"Cmd").replace(/\bAlt\b/i,"Option"):e.replace(/\bCtrlOrCmd\b/gi,"Ctrl")),Ue=({clientX:e,clientY:t},{zoom:r,offsetLeft:o,offsetTop:n,scrollX:i,scrollY:a})=>{let l=(e-o)/r.value-i,c=(t-n)/r.value-a;return{x:l,y:c}},Dt=({sceneX:e,sceneY:t},{zoom:r,offsetLeft:o,offsetTop:n,scrollX:i,scrollY:a})=>{let l=(e+i)*r.value+o,c=(t+a)*r.value+n;return{x:l,y:c}},ps=e=>getComputedStyle(document.documentElement).getPropertyValue(`--${e}`),OC="A-Za-z\xC0-\xD6\xD8-\xF6\xF8-\u02B8\u0300-\u0590\u0800-\u1FFF\u2C00-\uFB1C\uFDFE-\uFE6F\uFEFD-\uFFFF",FC="\u0591-\u07FF\uFB1D-\uFDFD\uFE70-\uFEFC",HC=new RegExp(`^[^${OC}]*[${FC}]`),Dp=e=>HC.test(e),xo=e=>{let[t,r]=e;return{x:t,y:r}},ud=e=>{if(e?.name==="AbortError"){console.warn(e);return}throw e},Rp=(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},Np=(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},or=e=>{let t=e.length===5&&e.substr(4,1)==="0",r=e.length===9&&e.substr(7,2)==="00";return t||r||e===oe.transparent},it=e=>t=>{dx(e,t)},pd=e=>dd(t=>{dx(e,t)}),fx=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},bx=e=>{let t=e.parentElement;for(;t;){if(t.tabIndex>-1){t.focus();return}t=t.parentElement}},xx=e=>Array.from(e).map(t=>`0${t.toString(16)}`.slice(-2)).join(""),an=()=>kr()?1:Date.now(),Ce=e=>e.reduce((t,r)=>(t.set(typeof r=="string"?r:r.id,r),t),new Map),Ex=e=>e.reduce((t,r,o)=>(t.set(r.id,[r,o]),t),new Map),kr=()=>I.MODE==="test",gd=(e,t)=>new CustomEvent(e,{detail:{nativeEvent:t},cancelable:!0}),Fa=(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},yx=()=>{try{return window.self===window.top?"top":"iframe"}catch{return"iframe"}},hd=e=>!!e&&typeof e=="object"&&"then"in e&&"catch"in e&&"finally"in e,gs=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):[]},cx=(e,t)=>Array.isArray(e)&&Array.isArray(t)&&e.length===0&&t.length===0?!0:e===t,bt=(e,t,r,o=!1)=>{let n=Object.keys(e),i=Object.keys(t);if(n.length!==i.length)return!1;if(r&&Array.isArray(r)){for(let a of r)if(!(e[a]===t[a]||cx(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],c=l?l(e[a],t[a]):e[a]===t[a]||cx(e[a],t[a]);return!c&&o&&console.warn(`%cisShallowEqual: ${a} not equal ->`,"color: #8B4000",e[a],t[a]),c})},Xn=(e,t,{checkForDefaultPrevented:r=!0}={})=>function(n){if(e?.(n),!r||!n.defaultPrevented)return t?.(n)},Zn=(e,t,r)=>{if(!t)return e;if(r)return console.error(t),e;throw new Error(t)},wx=e=>{let t,r,o=function(n){let i=Object.entries(n);if(t){let l=!0;for(let[c,s]of i)if(t.get(c)!==s){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},fd=(()=>{let e;try{let r=BC.version.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})(),hs=(e,t)=>e instanceof Set||e instanceof Map?e.has(t):"includes"in e?e.includes(t):e.hasOwnProperty(t),Vr=e=>JSON.parse(JSON.stringify(e)),Bp=e=>typeof e=="number"&&Number.isFinite(e),bd=(e,t)=>bt(e,t)?e:t});var ur,Yr,At,Kr,nr,z,jn,Xi,J,xt,zC,te,ve,fs,Et,Op,Ha,Fo,za,pr,ke,Ho,vx,Tx,Ix,ae=y(()=>{"use strict";h();X();W();ur=e=>!!e&&e.type==="image"&&!!e.fileId,Yr=e=>!!e&&e.type==="image",At=e=>!!e&&e.type==="embeddable",Kr=e=>!!e&&e.type==="iframe",nr=e=>!!e&&(e.type==="iframe"||e.type==="embeddable"),z=e=>e!=null&&e.type==="text",jn=e=>e!=null&&e.type==="frame",Xi=e=>e!=null&&e.type==="magicframe",J=e=>e!=null&&(e.type==="frame"||e.type==="magicframe"),xt=e=>e!=null&&zC(e.type),zC=e=>e==="freedraw",te=e=>e!=null&&fs(e.type),ve=e=>e!=null&&e.type==="arrow",fs=e=>e==="arrow"||e==="line",Et=(e,t=!0)=>e!=null&&(!e.locked||t===!0)&&Op(e.type),Op=e=>e==="arrow",Ha=(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),Fo=(e,t=!0)=>e!=null&&(!e.locked||t===!0)&&(e.type==="rectangle"||e.type==="diamond"||e.type==="ellipse"||ve(e)),za=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 Zn(t,null),!1}},pr=e=>Fo(e)&&!!e.boundElements?.some(({type:t})=>t==="text"),ke=e=>e!==null&&"containerId"in e&&e.containerId!==null&&z(e),Ho=e=>e==="rectangle"||e==="embeddable"||e==="iframe",vx=e=>e==="line"||e==="arrow"||e==="diamond",Tx=(e,t)=>!!((e===st.ADAPTIVE_RADIUS||e===st.LEGACY)&&Ho(t.type)||e===st.PROPORTIONAL_RADIUS&&vx(t.type)),Ix=e=>vx(e.type)?{type:st.PROPORTIONAL_RADIUS}:Ho(e.type)?{type:st.ADAPTIVE_RADIUS}:null});var GC,$t,UC,Sx,xd,Cx,$r,Eo,Ar=y(()=>{"use strict";h();Yt();X();Y();W();GC=Na.includes(devicePixelRatio)?devicePixelRatio:1,$t=()=>({showWelcomeScreen:!1,theme:nt.LIGHT,collaborators:new Map,currentChartType:"bar",currentItemBackgroundColor:tt.backgroundColor,currentItemEndArrowhead:"arrow",currentItemFillStyle:tt.fillStyle,currentItemFontFamily:Ft,currentItemFontSize:Ct,currentItemOpacity:tt.opacity,currentItemRoughness:tt.roughness,currentItemStartArrowhead:null,currentItemStrokeColor:tt.strokeColor,currentItemRoundness:"round",currentItemStrokeStyle:tt.strokeStyle,currentItemStrokeWidth:tt.strokeWidth,currentItemTextAlign:Kn,cursorButton:"up",activeEmbeddable:null,draggingElement:null,editingElement:null,editingGroupId:null,editingLinearElement:null,activeTool:{type:"selection",customType:null,locked:tt.locked,lastActiveTool:null},penMode:!1,penDetected:!1,errorMessage:null,exportBackground:!0,exportScale:GC,exportEmbedScene:!1,exportWithDarkMode:!1,fileHandle:null,gridSize:null,isBindingEnabled:!0,defaultSidebarDockedPreference:!1,isLoading:!1,isResizing:!1,isRotating:!1,lastPointerDownWith:"mouse",multiElement:null,name:`${f("labels.untitled")}-${mx()}`,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:oe.white,zenModeEnabled:!1,zoom:{value:1},viewModeEnabled:!1,pendingImageElementId:null,showHyperlinkPopup:!1,selectedLinearElement:null,snapLines:[],originSnapOffset:{x:0,y:0},objectsSnapModeEnabled:!1,userToFollow:null,followedBy:new Set}),UC=(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}}),Sx=(e,t)=>{let r={};for(let o of Object.keys(e))if(UC[o]?.[t]){let i=e[o];r[o]=i}return r},xd=e=>Sx(e,"export"),Cx=e=>Sx(e,"server"),$r=({activeTool:e})=>e.type==="eraser",Eo=({activeTool:e})=>e.type==="hand"});var Xt,Fp,Zi,Ga,kx,bs,qn,WC,Hp,Ed,zp,Ax,Gp,Mx,ji,Lx,Up,X9,Z9,j9,q9,J9,Q9,eR,qi=y(()=>{"use strict";h();Xt=(e,t)=>[0,0,0,0,t,e,1,0],Fp=(e,t)=>[0,0,0,0,t,e,0,0],Zi=(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},Ga=e=>[e[0],e[1],e[2],e[3],-e[4],-e[5],-e[6],-e[7]],kx=(e,t)=>Up(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]],bs=(e,t)=>Up(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]],qn=(e,t)=>Up(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]:[WC(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]],WC=(e,t)=>t[0]*e[0]+t[2]*e[2]+t[3]*e[3]-t[6]*e[6],Hp=(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]],Ed=(e,t)=>[zp(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]],zp=(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],Ax=(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]],Gp=e=>Math.sqrt(Math.abs(e[0]*e[0]-e[2]*e[2]-e[3]*e[3]+e[6]*e[6])),Mx=e=>Math.sqrt(Math.abs(e[7]*e[7]-e[5]*e[5]-e[4]*e[4]+e[1]*e[1])),ji=e=>{let t=Gp(e);if(t===0||t===1)return e;let r=e[6]<0?-1:1;return qn(e,r/t)},Lx=e=>{let t=Mx(e);return t===0||t===1?e:qn(e,1/t)},Up=e=>typeof e=="number",X9=Zi(1,1),Z9=Zi(1,2),j9=Zi(1,3),q9=Zi(1,4),J9=Zi(1,5),Q9=Zi(1,6),eR=Zi(1,7)});var Jn,Ua,_x,Px,Dx,Wp=y(()=>{"use strict";h();qi();Jn=(e,t,r)=>ji([0,r,e,t,0,0,0,0]),Ua=(e,t)=>ji(Ed(t,e)),_x=(e,t)=>Ax(e,t),Px=(e,t)=>_x(Ua(e,t),t),Dx=e=>Math.sign(e[1])});var Qn,ei,Vp,Nx,Yp,Xr,Bx=y(()=>{"use strict";h();qi();Wp();qi();Qn=([e,t])=>[0,0,0,0,t,e,1,0],ei=e=>[e[5],e[4]],Vp=e=>[0,0,0,0,Math.abs(e[4]),Math.abs(e[5]),1,0],Nx=(e,t)=>ji(Hp(e,t)),Yp=(e,t)=>Gp(Ed(e,t)),Xr=(e,t)=>zp(e,t)});var yd,Ox,Kp=y(()=>{"use strict";h();qi();yd=e=>[0,0,0,0,e[4],e[5],0,0],Ox=(e,t)=>Lx([0,0,0,0,t[4]-e[4],t[5]-e[5],0,0])});var wd,Hx,zx,Gx,Zr,Ux=y(()=>{"use strict";h();qi();Kp();wd=(e,t)=>kx(qn(e,Math.sin(t/2)),Math.cos(t/2)),Hx=e=>[1,0,0,0,-(.5*e[5]),.5*e[4],0,0],zx=(e,t)=>{let r=.5*t;return[1,0,0,0,r*e[4],r*e[5],0,0]},Gx=(e,t)=>qn(t,e),Zr=(e,t)=>ji(qn(qn(e,t),Ga(e)))});var $p,Wx=y(()=>{"use strict";h();$p=(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()}});function KC(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 Ji,Vx,Es=y(()=>{"use strict";h();Ji=e=>`hsl(${Math.abs(KC(e))%37*10}, 100%, 83%)`,Vx=e=>{let t=e?.trim()?.codePointAt(0);return(t?String.fromCodePoint(t):"?").toUpperCase()}});var Xp,Ht,Wa,Zp,ln,vd,Yx,Qi,at,Kx,$x,Xx,Zx,ea,gr=y(()=>{"use strict";h();Ze();pt();ti();Xp=(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}}},Ht=function(){let e=null,t=null,r=null,o=(i,a,l,c)=>{if(r!==void 0&&a===t&&i===e&&l.editingGroupId===r?.editingGroupId)return r;let s={};for(let u of i){let p=u.groupIds;if(l.editingGroupId){let g=p.indexOf(l.editingGroupId);g>-1&&(p=p.slice(0,g))}if(p.length>0){let g=p[p.length-1];s[g]=!0}}let d={},m=a.reduce((u,p)=>{let g=p.groupIds.find(b=>s[b]);return g&&(u[p.id]=!0,Array.isArray(d[g])?d[g].push(p.id):d[g]=[p.id]),u},{});for(let u of Object.keys(d))d[u].length<2&&s[u]&&(s[u]=!1);return t=a,e=i,r={editingGroupId:l.editingGroupId,selectedGroupIds:s,selectedElementIds:Pe({...l.selectedElementIds,...m},c)},r},n=(i,a,l,c)=>{let s=c?c.scene.getSelectedElements({selectedElementIds:i.selectedElementIds,elements:a}):ge(a,i);return s.length?o(s,a,i,l):{selectedGroupIds:{},editingGroupId:null,selectedElementIds:Pe(i.selectedElementIds,l)}};return n.clearCache=()=>{t=null,e=null,r=null},n}(),Wa=(e,t)=>Zp(e,t)!=null,Zp=(e,t)=>t.groupIds.filter(r=>r!==e.editingGroupId).find(r=>e.selectedGroupIds[r]),ln=e=>Object.entries(e.selectedGroupIds).filter(([t,r])=>r).map(([t,r])=>t),vd=(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,...Xp(i,r,e)}}}return r.selectedGroupIds},Yx=(e,t)=>({...e,editingGroupId:t.groupIds.length?t.groupIds[0]:null,selectedGroupIds:{},selectedElementIds:{[t.id]:!0}}),Qi=(e,t)=>e.groupIds.includes(t),at=(e,t)=>e.filter(r=>Qi(r,t)),Kx=(e,t)=>e.groupIds.find(r=>t[r]),$x=(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},Xx=(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},Zx=(e,t)=>e.filter(r=>!t[r]),ea=e=>{let t=new Map;return e.forEach(r=>{let o=r.groupIds.length===0?r.id:r.groupIds[r.groupIds.length-1],n=t.get(o)||[],i=le(r);i&&n.push(i),t.set(o,[...n,r])}),Array.from(t.values())}});var jx=y(()=>{"use strict";h()});var Td,N,We=y(()=>{"use strict";h();Td=[],N=e=>(Td=Td.concat(e),e)});import Id from"open-color";var Jx,$C,Qx,XC,ZC,Mr,Oe,zo,qx,jp,Lr,Va=y(()=>{"use strict";h();X();Ar();Jx='<svg viewBox="0 0 24 24" stroke-width="1" width="28" height="28" xmlns="http://www.w3.org/2000/svg">',$C='<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"/>',Qx='<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"/>',XC=`data:${Z.svg},${encodeURIComponent(`${Jx}${Qx}</svg>`)}`,ZC=`data:${Z.svg},${encodeURIComponent(`${Jx}${$C}${Qx}</svg>`)}`,Mr=e=>{e&&(e.style.cursor="")},Oe=(e,t)=>{e&&(e.style.cursor=t)},jp=(e,t)=>{let o=()=>{let n=t===nt.DARK;zo=document.createElement("canvas"),zo.theme=t,zo.height=20,zo.width=20;let i=zo.getContext("2d");i.lineWidth=1,i.beginPath(),i.arc(zo.width/2,zo.height/2,5,0,2*Math.PI),i.fillStyle=n?Id.black:Id.white,i.fill(),i.strokeStyle=n?Id.white:Id.black,i.stroke(),qx=zo.toDataURL(Z.svg)};(!zo||zo.theme!==t)&&o(),Oe(e,`url(${qx}) ${20/2} ${20/2}, auto`)},Lr=(e,t)=>{if(e)if(t.activeTool.type==="selection")Mr(e);else if(Eo(t))e.style.cursor=Me.GRAB;else if($r(t))jp(e,t.theme);else if(t.activeTool.type==="laser"){let r=t.theme===nt.LIGHT?XC:ZC;e.style.cursor=`url(${r}), auto`}else["image","custom"].includes(t.activeTool.type)?t.activeTool.type!=="image"&&(e.style.cursor=Me.AUTO):e.style.cursor=Me.CROSSHAIR}});import{Random as jC}from"roughjs/bin/math";import{nanoid as qC}from"nanoid";var JC,QC,jr,Mt,yo=y(()=>{"use strict";h();W();JC=new jC(Date.now()),QC=0,jr=()=>Math.floor(JC.next()*2**31),Mt=()=>kr()?`id${QC++}`:qC()});var sn,Pr,qp,eE,kd,ys,tE,Rt,e4,Ya,Jp,rE,qr,ws,Sd,cn,Cd,vs,Ad,dn=y(()=>{"use strict";h();W();yo();Ve();gr();ue();Zt();yt();pt();X();sn=(e,{x:t,y:r,strokeColor:o=tt.strokeColor,backgroundColor:n=tt.backgroundColor,fillStyle:i=tt.fillStyle,strokeWidth:a=tt.strokeWidth,strokeStyle:l=tt.strokeStyle,roughness:c=tt.roughness,opacity:s=tt.opacity,width:d=0,height:m=0,angle:u=0,groupIds:p=[],frameId:g=null,roundness:b=null,boundElements:E=null,link:w=null,locked:v=tt.locked,...T})=>({id:T.id||Mt(),type:e,x:t,y:r,width:d,height:m,angle:u,strokeColor:o,backgroundColor:n,fillStyle:i,strokeWidth:a,strokeStyle:l,roughness:c,opacity:s,groupIds:p,frameId:g,roundness:b,seed:T.seed??jr(),version:T.version||1,versionNonce:T.versionNonce??0,isDeleted:!1,boundElements:E,updated:an(),link:w,locked:v}),Pr=e=>sn(e.type,e),qp=e=>({...sn("embeddable",e),validated:e.validated}),eE=e=>({...sn("iframe",e)}),kd=e=>Q({...sn("frame",e),type:"frame",name:e?.name||null},{}),ys=e=>Q({...sn("magicframe",e),type:"magicframe",name:e?.name||null},{}),tE=(e,t)=>({x:e.textAlign==="center"?t.width/2:e.textAlign==="right"?t.width:0,y:e.verticalAlign==="middle"?t.height/2:0}),Rt=e=>{let t=e.fontFamily||Ft,r=e.fontSize||Ct,o=e.lineHeight||Dr(t),n=ri(e.text),i=_r(n,_e({fontFamily:t,fontSize:r}),o),a=e.textAlign||Kn,l=e.verticalAlign||Vi,c=tE({textAlign:a,verticalAlign:l},i);return Q({...sn("text",e),text:n,fontSize:r,fontFamily:t,textAlign:a,verticalAlign:l,x:e.x-c.x,y:e.y-c.y,width:i.width,height:i.height,baseline:i.baseline,containerId:e.containerId||null,originalText:n,lineHeight:o},{})},e4=(e,t)=>{let{width:r,height:o,baseline:n}=_r(t,_e(e),e.lineHeight),{textAlign:i,verticalAlign:a}=e,l,c;if(i==="center"&&a===ht.MIDDLE&&!e.containerId){let s=_r(e.text,_e(e),e.lineHeight),d=tE(e,{width:r-s.width,height:o-s.height});l=e.x-d.x,c=e.y-d.y}else{let[s,d,m,u]=ee(e),[p,g,b,E]=ta(e,r,o,!1),w=(s-p)/2,v=(d-g)/2,T=(m-b)/2,k=(u-E)/2;[l,c]=Md({s:!0,e:i==="center"||i==="left",w:i==="center"||i==="right"},e.x,e.y,e.angle,w,v,T,k)}return{width:r,height:o,baseline:n,x:Number.isFinite(l)?l:e.x,y:Number.isFinite(c)?c:e.y}},Ya=(e,t=e.text)=>{if(e.isDeleted)return;let r=je(e);r&&(t=oi(t,_e(e),hr(r)));let o=e4(e,t);return{text:t,...o}},Jp=(e,{text:t,isDeleted:r,originalText:o})=>Q(e,{originalText:o,isDeleted:r??e.isDeleted,...Ya(e,o)}),rE=e=>({...sn(e.type,e),points:e.points||[],pressures:[],simulatePressure:e.simulatePressure,lastCommittedPoint:null}),qr=e=>({...sn(e.type,e),points:e.points||[],lastCommittedPoint:null,startBinding:null,endBinding:null,startArrowhead:e.startArrowhead||null,endArrowhead:e.endArrowhead||null}),ws=e=>({...sn("image",e),strokeColor:"transparent",status:e.status??"pending",fileId:e.fileId??null,scale:e.scale??[1,1]}),Sd=(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]=Sd(e[n],t+1)}return o}if(Array.isArray(e)){let o=e.length,n=new Array(o);for(;o--;)n[o]=Sd(e[o],t+1);return n}return I.DEV&&r!=="[object Object]"&&r!=="[object Array]"&&r.startsWith("[object ")&&console.warn(`_deepCloneElement: unexpected object type ${r}. This value will not be cloned!`),e},cn=e=>Sd(e),Cd=e=>{if(kr()&&e){let t=`${e}_copy`;return window.h?.app?.getSceneElementsIncludingDeleted().find(r=>r.id===t)&&(t+="_copy"),t}return Mt()},vs=(e,t,r,o)=>{let n=cn(r);return n.id=Cd(n.id),n.boundElements=null,n.updated=an(),n.seed=jr(),n.groupIds=$x(n.groupIds,e,i=>(t.has(i)||t.set(i,Cd(i)),t.get(i))),o&&(n=Object.assign(n,o)),n},Ad=(e,t)=>{let r=[],o=Ce(e),n=new Map,i=l=>{if(n.has(l))return n.get(l);if(o.has(l)){let c=Cd(l);return n.set(l,c),c}return null},a=new Map;for(let l of e){let c=Sd(l);if(c.id=i(l.id),t?.randomizeSeed&&(c.seed=jr(),wo(c)),c.groupIds&&(c.groupIds=c.groupIds.map(s=>(a.has(s)||a.set(s,Cd(s)),a.get(s)))),"containerId"in c&&c.containerId){let s=i(c.containerId);c.containerId=s}if("boundElements"in c&&c.boundElements&&(c.boundElements=c.boundElements.reduce((s,d)=>{let m=i(d.id);return m&&s.push({...d,id:m}),s},[])),"endBinding"in c&&c.endBinding){let s=i(c.endBinding.elementId);c.endBinding=s?{...c.endBinding,elementId:s}:null}if("startBinding"in c&&c.startBinding){let s=i(c.startBinding.elementId);c.startBinding=s?{...c.startBinding,elementId:s}:null}c.frameId&&(c.frameId=i(c.frameId)),r.push(c)}return r}});var mn,t4,r4,o4,n4,i4,a4,l4,s4,c4,oE,Qp,ra,un,Ld,_d,QR,nE,iE,Ka,Ts=y(()=>{"use strict";h();We();X();Y();W();Va();dn();pt();ae();mn=new Map,t4=/^(?: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]*$/,r4=/^(?:http(?:s)?:\/\/)?(?:(?:w){3}.)?(?:player\.)?vimeo\.com\/(?:video\/)?([^?\s]+)(?:\?.*)?$/,o4=/^https:\/\/(?:www\.)?figma\.com/,n4=/^https:\/\/gist\.github\.com/,i4=/^<script[\s\S]*?\ssrc=["'](https:\/\/gist.github.com\/.*?)\.js["']/i,a4=/(?:http(?:s)?:\/\/)?(?:(?:w){3}.)?twitter.com/,l4=/^<blockquote[\s\S]*?\shref=["'](https:\/\/twitter.com\/[^"']*)/i,s4=/^https:\/\/(?:www\.)?val.town\/(v|embed)\/[a-zA-Z_$][0-9a-zA-Z_$]+\.[a-zA-Z_$][0-9a-zA-Z_$]+/,c4=/^<(?:iframe|blockquote)[\s\S]*?\s(?:src|href)=["']([^"']*)["'][\s\S]*?>$/i,oE=/giphy.com\/(?:clips|embed|gifs)\/[a-zA-Z0-9]*?-?([a-zA-Z0-9]+)(?:[^a-zA-Z0-9]|$)/,Qp=new Set(["youtube.com","youtu.be","vimeo.com","player.vimeo.com","figma.com","link.excalidraw.com","gist.github.com","twitter.com","*.simplepdf.eu","stackblitz.com","val.town","giphy.com","dddice.com"]),ra=e=>`<html><body>${e}</body></html>`,un=e=>{if(!e)return null;if(mn.has(e))return mn.get(e);let t=e,r="generic",o={w:560,h:840},n=e.match(t4);if(n?.[2]){let c=n[3]?`&start=${n[3]}`:"",s=e.includes("shorts");switch(r="video",n[1]){case"embed/":case"watch?v=":case"shorts/":e=`https://www.youtube.com/embed/${n[2]}?enablejsapi=1${c}`;break;case"playlist?list=":case"embed/videoseries?list=":e=`https://www.youtube.com/embed/videoseries?list=${n[2]}&enablejsapi=1${c}`;break;default:e=`https://www.youtube.com/embed/${n[2]}?enablejsapi=1${c}`;break}return o=s?{w:315,h:560}:{w:560,h:315},mn.set(t,{link:e,intrinsicSize:o,type:r}),{link:e,intrinsicSize:o,type:r}}let i=e.match(r4);if(i?.[1]){let c=i?.[1],s=/^\d+$/.test(c)?void 0:f("toast.unrecognizedLinkFormat");return r="video",e=`https://player.vimeo.com/video/${c}?api=1`,o={w:560,h:315},mn.set(t,{link:e,intrinsicSize:o,type:r}),{link:e,intrinsicSize:o,type:r,warning:s}}if(e.match(o4))return r="generic",e=`https://www.figma.com/embed?embed_host=share&url=${encodeURIComponent(e)}`,o={w:550,h:550},mn.set(t,{link:e,intrinsicSize:o,type:r}),{link:e,intrinsicSize:o,type:r};let l=e.match(s4);if(l)return e=l[1]==="embed"?l[0]:l[0].replace("/v","/embed"),mn.set(t,{link:e,intrinsicSize:o,type:r}),{link:e,intrinsicSize:o,type:r};if(a4.test(e)){let c;if(/<blockquote/.test(e)){let s=ra(e);c={type:"document",srcdoc:()=>s,intrinsicSize:{w:480,h:480}}}else c={type:"document",srcdoc:s=>ra(`<blockquote class="twitter-tweet" data-dnt="true" data-theme="${s}"><a href="${e}"></a></blockquote> <script async src="https://platform.twitter.com/widgets.js" charset="utf-8"><\/script>`),intrinsicSize:{w:480,h:480}};return mn.set(t,c),c}if(n4.test(e)){let c;if(/<script>/.test(e)){let s=ra(e);c={type:"document",srcdoc:()=>s,intrinsicSize:{w:550,h:720}}}else c={type:"document",srcdoc:()=>ra(`
|
|
1
|
+
var e5=Object.defineProperty;var fb=e=>t=>{var r=e[t];if(r)return r();throw new Error("Module not found in bundle: "+t)};var Z=(e,t)=>()=>(e&&(t=e(e=0)),t);var bb=(e,t)=>{for(var r in t)e5(e,r,{get:t[r],enumerable:!0})};var v,h=Z(()=>{v={PROD:!0}});var jp,wb=Z(()=>{jp={}});import m5 from"open-color";var p5,vb,Mi,Tb,wa,va,no,io,ie,Sb,Cc,kc,Ac,Ib,Cb,kb,Ab,Vt=Z(()=>{"use strict";h();p5=(e,t)=>t.reduce((r,o)=>(o in e&&(r[o]=e[o]),r),{}),vb=5,Mi=5,Tb=4,wa=4,va=1,no=[0,2,4,6,8],io=(e,t)=>t.map(r=>m5[e][r]),ie={transparent:"transparent",black:"#1e1e1e",white:"#ffffff",gray:io("gray",no),red:io("red",no),pink:io("pink",no),grape:io("grape",no),violet:io("violet",no),blue:io("blue",no),cyan:io("cyan",no),teal:io("teal",no),green:io("green",no),yellow:io("yellow",no),orange:io("orange",no),bronze:["#f8f1ee","#eaddd7","#d2bab0","#a18072","#846358"]},Sb=p5(ie,["cyan","blue","violet","grape","pink","green","teal","yellow","orange","red"]),Cc=[ie.black,ie.red[wa],ie.green[wa],ie.blue[wa],ie.yellow[wa]],kc=[ie.transparent,ie.red[va],ie.green[va],ie.blue[va],ie.yellow[va]],Ac=[ie.white,"#f8f9fa","#f5faff","#fffce8","#fdf8f6"],Ib={transparent:ie.transparent,white:ie.white,gray:ie.gray,black:ie.black,bronze:ie.bronze,...Sb},Cb={transparent:ie.transparent,white:ie.white,gray:ie.gray,black:ie.black,bronze:ie.bronze,...Sb},kb=e=>[ie.cyan[e],ie.blue[e],ie.violet[e],ie.grape[e],ie.pink[e],ie.green[e],ie.teal[e],ie.yellow[e],ie.orange[e],ie.red[e]],Ab=(e,t,r)=>`#${((1<<24)+(e<<16)+(t<<8)+r).toString(16).slice(1)}`});var qt,Mc,q8,Nn,u5,J8,Mb,Lb,Kl,en,Ta,Pb,qp,_b,ko,Se,Bn,Li,$l,Jp,Lc,it,qe,Ue,Qp,Pc,It,Ot,On,Pi,_i,tn,Xl,Db,$,_c,Yt,Zl,Rb,Nb,Bb,Ob,Di,Dc,Fb,Sa,Rc,Nc,eu,Hb,zb,Gb,Ub,Wb,Ia,Ca,ao,Vb,tu,_e,Ri,pt,Yb,Kb,gt,Fn,$b,Bc,Xb,tt,Oc,ru,Fc,Je,jl,Ao,Hc,ht,Br,zc,W=Z(()=>{"use strict";h();wb();Vt();qt=/Mac|iPod|iPhone|iPad/.test(navigator.platform),Mc=/^Win/.test(navigator.platform),q8=/\b(android)\b/i.test(navigator.userAgent),Nn="netscape"in window&&navigator.userAgent.indexOf("rv:")>1&&navigator.userAgent.indexOf("Gecko")>1,u5=navigator.userAgent.indexOf("Chrome")!==-1,J8=!u5&&navigator.userAgent.indexOf("Safari")!==-1,Mb=/iPad|iPhone/.test(navigator.platform)||navigator.userAgent.includes("Mac")&&"ontouchend"in document,Lb=()=>navigator.brave?.isBrave?.name==="isBrave",Kl="Excalidraw",en=10,Ta=8,Pb=5,qp=1,_b=30,ko=Math.PI/12,Se={TEXT:"text",CROSSHAIR:"crosshair",GRABBING:"grabbing",GRAB:"grab",POINTER:"pointer",MOVE:"move",AUTO:""},Bn={MAIN:0,WHEEL:1,SECONDARY:2,TOUCH:-1,ERASER:5},Li={enabled:"all",disabled:"none",inheritFromUI:"var(--ui-pointerEvents)"},$l={UNSTARTED:-1,ENDED:0,PLAYING:1,PAUSED:2,BUFFERING:3,CUED:5},Jp={TEST:"test",DEVELOPMENT:"development"},Lc={SHAPE_ACTIONS_MENU:"App-menu__left"},it={Virgil:1,Helvetica:2,Cascadia:3,Assistant:4},qe={LIGHT:"light",DARK:"dark"},Ue={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},Qp="Segoe UI Emoji",Pc=1,It=20,Ot=it.Virgil,On="left",Pi="top",_i=2,tn=20,Xl={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"},Db=["text/plain","text/html"],$={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",...Xl},_c={png:"png",svg:"svg",clipboard:"clipboard"},Yt={excalidraw:"excalidraw",excalidrawClipboard:"excalidraw/clipboard",excalidrawLibrary:"excalidrawlib",excalidrawClipboardWithAPI:"excalidraw-api/clipboard"},Zl=window.EXCALIDRAW_EXPORT_SOURCE||window.location.origin,Rb=500,Nb=300,Bb=500,Ob=100,Di=.1,Dc=.1,Fb=300,Sa=jp.themeFilter,Rc={addLibrary:"addLibrary"},Nc={addLibrary:"addLibrary"},eu={canvasActions:{changeViewBackgroundColor:!0,clearCanvas:!0,export:{saveFileToDisk:!0},loadScene:!0,saveToActiveFile:!0,toggleTheme:null,saveAsImage:!0},tools:{image:!0}},Hb=730,zb=1e3,Gb=500,Ub=1229,Wb=parseInt(jp.rightSidebarWidth),Ia=2,Ca=[1,2,3],ao=10,Vb=1440,tu=2*1024*1024,_e="http://www.w3.org/2000/svg",Ri={excalidraw:2,excalidrawLibrary:2},pt=5,Yb=.7,Kb=11,gt={TOP:"top",MIDDLE:"middle",BOTTOM:"bottom"},Fn={LEFT:"left",CENTER:"center",RIGHT:"right"},$b=20,Bc=.25,Xb=32,tt={LEGACY:1,PROPORTIONAL_RADIUS:2,ADAPTIVE_RADIUS:3},Oc="__precedingElement__",ru={architect:0,artist:1,cartoonist:2},Fc={thin:1,bold:2,extraBold:4},Je={strokeColor:ie.black,backgroundColor:ie.transparent,fillStyle:"solid",strokeWidth:2,strokeStyle:"solid",roughness:ru.artist,opacity:100,locked:!1},jl="library",Ao={name:"default",defaultTab:jl},Hc=new Set(["iframe","embeddable","image"]),ht={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"},Br={OAI_API_KEY:"excalidraw-oai-api-key",MERMAID_TO_EXCALIDRAW:"mermaid-to-excalidraw",PUBLISH_LIBRARY:"publish-library-data"},zc="Untitled"});function dt(e,t,r,o){return e?(e?.addEventListener?.(t,r,o),()=>{e?.removeEventListener?.(t,r,o)}):()=>{}}function d1(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)} ${Uc(n[0],i[0]).toFixed(2)},${Uc(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+=`${Uc(o[0],n[0]).toFixed(2)},${Uc(o[1],n[1]).toFixed(2)} `;return t&&(a+="Z"),a}var jb,nu,ka,Qb,iu,e1,Mo,Aa,Be,Ni,Ma,rn,qb,t1,r1,Ct,Ke,_,Oe,Mt,ql,w5,v5,T5,Wc,lo,Vc,au,lu,Jt,Yc,o1,n1,i1,a1,on,J,l1,wr,Kc,La,s1,Lo,Jl,Jb,bt,Hn,zn,c1,Ql,Po,su,$c,Uc,Xc,so,es,F=Z(()=>{"use strict";h();Vt();W();jb=null,nu=()=>{if(jb)return jb;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}`},ka=e=>e.charAt(0).toUpperCase()+e.slice(1),Qb=e=>e instanceof HTMLElement&&e.className.includes("ToolIcon"),iu=e=>e instanceof HTMLElement&&e.dataset.type==="wysiwyg"||e instanceof HTMLBRElement||e instanceof HTMLInputElement||e instanceof HTMLTextAreaElement||e instanceof HTMLSelectElement,e1=e=>iu(e)||e instanceof Element&&!!e.closest("label, button"),Mo=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"),Aa=({fontFamily:e})=>{for(let[t,r]of Object.entries(it))if(r===e)return`${t}, ${Qp}`;return Qp},Be=({fontSize:e,fontFamily:t})=>`${e}px ${Aa({fontFamily:t})}`,Ni=(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},Ma=(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(v.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},rn=e=>1-Math.pow(1-e,4),qb=(e,t,r)=>(t-e)*rn(r)+e,t1=({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),g=rn(u/o),f={};if(Object.keys(e).forEach(E=>{let y=E,T=(t[y]-e[y])*g+e[y];f[y]=T}),r(f),u<o){let E=u/o,y={};Object.keys(e).forEach(T=>{let w=T,I=e[w],k=t[w],C;C=n?n(I,k,E,w):qb(I,k,E),C==null&&(C=qb(I,k,E)),y[w]=C}),r(y),c=window.requestAnimationFrame(m)}else r(t),a?.()}return c=window.requestAnimationFrame(m),()=>{l?.(),s=!0,window.cancelAnimationFrame(c)}},r1=(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},Ct=(e,t)=>Math.abs(e-t),Ke=(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},_=e=>(e=e.replace(/\bAlt\b/i,"Alt").replace(/\bShift\b/i,"Shift").replace(/\b(Enter|Return)\b/i,"Enter"),qt?e.replace(/\bCtrlOrCmd\b/gi,"Cmd").replace(/\bAlt\b/i,"Option"):e.replace(/\bCtrlOrCmd\b/gi,"Ctrl")),Oe=({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}},Mt=({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}},ql=e=>getComputedStyle(document.documentElement).getPropertyValue(`--${e}`),w5="A-Za-z\xC0-\xD6\xD8-\xF6\xF8-\u02B8\u0300-\u0590\u0800-\u1FFF\u2C00-\uFB1C\uFDFE-\uFE6F\uFEFD-\uFFFF",v5="\u0591-\u07FF\uFB1D-\uFDFD\uFE70-\uFEFC",T5=new RegExp(`^[^${w5}]*[${v5}]`),Wc=e=>T5.test(e),lo=e=>{let[t,r]=e;return{x:t,y:r}},Vc=e=>{if(e?.name==="AbortError"){console.warn(e);return}throw e},au=(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},lu=(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},Jt=e=>{let t=e.length===5&&e.substr(4,1)==="0",r=e.length===9&&e.substr(7,2)==="00";return t||r||e===ie.transparent},Yc=()=>{let e,t,r=new Promise((o,n)=>{e=o,t=n});return r.resolve=e,r.reject=t,r},o1=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},n1=e=>{let t=e.parentElement;for(;t;){if(t.tabIndex>-1){t.focus();return}t=t.parentElement}},i1=e=>{e.preventDefault(),e.returnValue=""},a1=e=>Array.from(e).map(t=>`0${t.toString(16)}`.slice(-2)).join(""),on=()=>wr()?1:Date.now(),J=e=>e instanceof Map?e:e.reduce((t,r)=>(t.set(typeof r=="string"?r:r.id,r),t),new Map),l1=e=>e.reduce((t,r,o)=>(t.set(r.id,[r,o]),t),new Map),wr=()=>v.MODE==="test",Kc=(e,t)=>new CustomEvent(e,{detail:{nativeEvent:t},cancelable:!0}),La=(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},s1=()=>{try{return window.self===window.top?"top":"iframe"}catch{return"iframe"}},Lo=e=>!!e&&typeof e=="object"&&"then"in e&&"catch"in e&&"finally"in e,Jl=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):[]},Jb=(e,t)=>Array.isArray(e)&&Array.isArray(t)&&e.length===0&&t.length===0?!0:e===t,bt=(e,t,r,o=!1)=>{let n=Object.keys(e),i=Object.keys(t);if(n.length!==i.length)return!1;if(r&&Array.isArray(r)){for(let a of r)if(!(e[a]===t[a]||Jb(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]||Jb(e[a],t[a]);return!s&&o&&console.warn(`%cisShallowEqual: ${a} not equal ->`,"color: #8B4000",e[a],t[a]),s})},Hn=(e,t,{checkForDefaultPrevented:r=!0}={})=>function(n){if(e?.(n),!r||!n?.defaultPrevented)return t?.(n)},zn=(e,t,r)=>{if(!t)return e;if(r)return console.error(t),e;throw new Error(t)},c1=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},Ql=(e,t)=>e instanceof Set||e instanceof Map?e.has(t):"includes"in e?e.includes(t):e.hasOwnProperty(t),Po=e=>JSON.parse(JSON.stringify(e)),su=e=>typeof e=="number"&&Number.isFinite(e),$c=(e,t)=>bt(e,t)?e:t;Uc=(e,t)=>(e+t)/2;Xc=e=>e.replace(/\r?\n|\r/g,`
|
|
2
|
+
`),so=e=>e,es=async(e,...t)=>new Promise(r=>{r(e(...t))})});var Qt,Or,xt,Fr,Ft,G,Gn,Bi,X,kt,S5,ee,we,ts,Et,cu,Pa,_o,rs,cr,Me,Do,m1,p1,u1,oe=Z(()=>{"use strict";h();W();F();Qt=e=>!!e&&e.type==="image"&&!!e.fileId,Or=e=>!!e&&e.type==="image",xt=e=>!!e&&e.type==="embeddable",Fr=e=>!!e&&e.type==="iframe",Ft=e=>!!e&&(e.type==="iframe"||e.type==="embeddable"),G=e=>e!=null&&e.type==="text",Gn=e=>e!=null&&e.type==="frame",Bi=e=>e!=null&&e.type==="magicframe",X=e=>e!=null&&(e.type==="frame"||e.type==="magicframe"),kt=e=>e!=null&&S5(e.type),S5=e=>e==="freedraw",ee=e=>e!=null&&ts(e.type),we=e=>e!=null&&e.type==="arrow",ts=e=>e==="arrow"||e==="line",Et=(e,t=!0)=>e!=null&&(!e.locked||t===!0)&&cu(e.type),cu=e=>e==="arrow",Pa=(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),_o=(e,t=!0)=>e!=null&&(!e.locked||t===!0)&&(e.type==="rectangle"||e.type==="diamond"||e.type==="ellipse"||we(e)),rs=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 zn(t,null),!1}},cr=e=>_o(e)&&!!e.boundElements?.some(({type:t})=>t==="text"),Me=e=>e!==null&&"containerId"in e&&e.containerId!==null&&G(e),Do=e=>e==="rectangle"||e==="embeddable"||e==="iframe"||e==="image",m1=e=>e==="line"||e==="arrow"||e==="diamond",p1=(e,t)=>!!((e===tt.ADAPTIVE_RADIUS||e===tt.LEGACY)&&Do(t.type)||e===tt.PROPORTIONAL_RADIUS&&m1(t.type)),u1=e=>m1(e.type)?{type:tt.PROPORTIONAL_RADIUS}:Do(e.type)?{type:tt.ADAPTIVE_RADIUS}:null});import{Random as I5}from"roughjs/bin/math";import{nanoid as C5}from"nanoid";var k5,A5,Hr,At,co=Z(()=>{"use strict";h();F();k5=new I5(Date.now()),A5=0,Hr=()=>Math.floor(k5.next()*2**31),At=()=>wr()?`id${A5++}`:C5()});var g1,M5,h1,du,rt,nn=Z(()=>{"use strict";h();me();oe();Un();co();F();g1=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}},M5=e=>{let t=["includeBoundTextElement","includeElementsInFrames"],r="";for(let o of t)r+=`${o}:${e[o]?"1":"0"}`;return r},h1=e=>typeof e=="string",du=class e{static sceneMapByElement=new WeakMap;static sceneMapById=new Map;static mapElementToScene(t,r){h1(t)?this.sceneMapById.set(t,r):(this.sceneMapByElement.set(t,r),this.sceneMapById.set(t.id,r))}static getScene(t){return h1(t)?this.sceneMapById.get(t)||null:this.sceneMapByElement.get(t)||null}callbacks=new Set;nonDeletedElements=[];nonDeletedElementsMap=so(new Map);elements=[];nonDeletedFramesLikes=[];frames=[];elementsMap=so(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 r=M5(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=pe(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&&os(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){this.elements=t instanceof Array?t:Array.from(t.values());let r=[];this.elementsMap.clear(),this.elements.forEach(n=>{X(n)&&r.push(n),this.elementsMap.set(n.id,n),e.mapElementToScene(n,this)});let o=g1(this.elements);this.nonDeletedElements=o.elements,this.nonDeletedElementsMap=o.elementsMap,this.frames=r,this.nonDeletedFramesLikes=g1(this.frames).elements,this.informMutation()}informMutation(){this.versionNonce=Hr();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,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)];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)];this.replaceAllElements(o)}addNewElement=t=>{t.frameId?this.insertElementAtIndex(t,this.getElementIndex(t.frameId)):this.replaceAllElements([...this.elements,t])};getElementIndex(t){return this.elements.findIndex(r=>r.id===t)}getContainerElement=t=>t&&t.containerId&&this.getElement(t.containerId)||null},rt=du});var Zc,Wn,ns=Z(()=>{"use strict";h();Zc=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)}},Wn=(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 g=u[e]*s,f=[...u];return f[e]=g,g<c&&(c=g),f});if(!o||d.length===2)return d;let m=a-c;return d.map(u=>u.map((g,f)=>f===e?g+m:g))}});var ge,Fe,jc,at,as,dr,mu,Oi,is,L5,yt,mo,pu,uu,P5,f1,b1,x1,gu,E1,ls,ss,cs,Ht=Z(()=>{"use strict";h();W();mt();uo();ge=(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],Fe=(e,t,r)=>ge(e[0],e[1],t[0],t[1],r),jc=(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]},at=(e,t,r,o)=>{let n=r-e,i=o-t;return Math.hypot(n,i)},as=(e,t)=>[(e[0]+t[0])/2,(e[1]+t[1])/2],dr=(e,t=1)=>{if(e.length>=3){let[r,o]=[e[0],e[e.length-1]];return at(r[0],r[1],o[0],o[1])<=Ta/t}return!1},mu=(e,t,r)=>{let o=e.length;if(o<3)return!1;let n=[Number.MAX_SAFE_INTEGER,r],i=[t,r],a=0;for(let l=0;l<o;l++){let s=e[l],c=e[(l+1)%o];if(L5(s,c,i,n)){if(is(s,i,c)===0)return Oi(s,i,c);a++}}return a%2===1},Oi=(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]),is=(e,t,r)=>{let o=(t[1]-e[1])*(r[0]-t[0])-(t[0]-e[0])*(r[1]-t[1]);return o===0?0:o>0?1:2},L5=(e,t,r,o)=>{let n=is(e,t,r),i=is(e,t,o),a=is(r,o,e),l=is(r,o,t);return!!(n!==i&&a!==l||n===0&&Oi(e,r,t)||i===0&&Oi(e,o,t)||a===0&&Oi(r,e,o)||l===0&&Oi(r,t,o))},yt=(e,t,r)=>r?[Math.round(e/r)*r,Math.round(t/r)*r]:[e,t],mo=(e,t)=>{if(t.roundness?.type===tt.PROPORTIONAL_RADIUS||t.roundness?.type===tt.LEGACY)return e*Bc;if(t.roundness?.type===tt.ADAPTIVE_RADIUS){let r=t.roundness?.value??Xb,o=r/Bc;return e<=o?e*Bc:r}return 0},pu=(e,t)=>{let r=Te.generateElementShape(e,null);if(!r)return null;let o=po(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]],g=at(u[0],u[1],t[0],t[1]);g<a&&(a=g,l=[d,m,p,u]),n=u}i++}return l},uu=(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]},P5=(e,t)=>{let r=pu(e,t);if(!r)return[];let o=[],n=1;for(;n>0;){let i=uu(r[0],r[1],r[2],r[3],n);o.push([i[0],i[1]]),n-=.05}return o.length&&gu(o.at(-1),t)&&o.push([t[0],t[1]]),o},f1=(e,t)=>{let r=[];r[0]=0;let o=P5(e,t),n=0,i=0;for(;n<o.length-1;){let a=at(o[n][0],o[n][1],o[n+1][0],o[n+1][1]);i+=a,r.push(i),n++}return r},b1=(e,t)=>f1(e,t).at(-1),x1=(e,t,r)=>{let o=f1(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},gu=(e,t)=>e[0]===t[0]&&e[1]===t[1],E1=e=>Math.round(e/Math.PI*1e4)%5e3===0,ls=([e,t],[r,o])=>e<=r?t>=r:e>=r?o>=e:!1,ss=(e,t)=>{let r=Math.max(e[0],t[0]),o=Math.min(e[1],t[1]);return r<=o?[r,o]:null},cs=(e,t,r)=>e>=t&&e<=r});var an,ds,qc,Jc,_a,Fi,hu,fu,ms=Z(()=>{"use strict";h();oe();an=e=>e==="rectangle"||e==="iframe"||e==="embeddable"||e==="ellipse"||e==="diamond"||e==="line"||e==="freedraw",ds=e=>e!=="image"&&e!=="frame"&&e!=="magicframe",qc=e=>e==="rectangle"||e==="iframe"||e==="embeddable"||e==="ellipse"||e==="diamond"||e==="freedraw"||e==="arrow"||e==="line",Jc=e=>e==="rectangle"||e==="iframe"||e==="embeddable"||e==="ellipse"||e==="diamond"||e==="arrow"||e==="line",_a=e=>e==="rectangle"||e==="iframe"||e==="embeddable"||e==="arrow"||e==="line"||e==="diamond"||e==="image",Fi=e=>e==="arrow",hu=(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},fu=(e,t)=>{let r=[];return e.filter(n=>!n.isDeleted&&t(n)?Fr(n)?(r.push(n),!1):!0:!1).concat(r)}});import{simplify as _5}from"points-on-curve";function R5(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&&_a(e.type)||ee(e)&&r>=50?t:Math.min(t/(r<10?3:2),2.5)}var D5,v1,vr,y1,w1,T1,bu=Z(()=>{"use strict";h();me();Ht();ln();F();W();oe();ms();D5=e=>[8,8+e],v1=e=>[1.5,6+e];vr=(e,t=!1)=>{let r={seed:e.seed,strokeLineDash:e.strokeStyle==="dashed"?D5(e.strokeWidth):e.strokeStyle==="dotted"?v1(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:R5(e),stroke:e.strokeColor,preserveVertices:t||e.roughness<ru.cartoonist};switch(e.type){case"rectangle":case"iframe":case"embeddable":case"diamond":case"ellipse":return r.fillStyle=e.fillStyle,r.fill=Jt(e.backgroundColor)?void 0:e.backgroundColor,e.type==="ellipse"&&(r.curveFitting=1),r;case"line":case"freedraw":return dr(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}`)}},y1=(e,t,r)=>Ft(e)&&(t||xt(e)&&r?.get(e.id)!==!0)&&Jt(e.backgroundColor)&&Jt(e.strokeColor)?{...e,roughness:0,backgroundColor:"#d3d3d3",fillStyle:"solid"}:Fr(e)?{...e,strokeColor:Jt(e.strokeColor)?"#000000":e.strokeColor,backgroundColor:Jt(e.backgroundColor)?"#f4f4f6":e.backgroundColor}:e,w1=(e,t,r,o,n,i,a)=>{let l=Eu(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,g,f]=l;return delete i.strokeLineDash,[n.polygon([[s,c],[d,m],[p,u],[g,f],[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 g=v1(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)]}}},T1=(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=mo(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`,vr(y1(e,r,n),!0))}else i=t.rectangle(0,0,e.width,e.height,vr(y1(e,r,n),!1));return i}case"diamond":{let i,[a,l,s,c,d,m,p,u]=xu(e);if(e.roundness){let g=mo(Math.abs(a-p),e),f=mo(Math.abs(c-l),e);i=t.path(`M ${a+g} ${l+f} L ${s-g} ${c-f}
|
|
3
|
+
C ${s} ${c}, ${s} ${c}, ${s-g} ${c+f}
|
|
4
|
+
L ${d+g} ${m-f}
|
|
5
|
+
C ${d} ${m}, ${d} ${m}, ${d-g} ${m-f}
|
|
6
|
+
L ${p+g} ${u+f}
|
|
7
|
+
C ${p} ${u}, ${p} ${u}, ${p+g} ${u-f}
|
|
8
|
+
L ${a-g} ${l+f}
|
|
9
|
+
C ${a} ${l}, ${a} ${l}, ${a+g} ${l+f}`,vr(e,!0))}else i=t.polygon([[a,l],[s,c],[d,m],[p,u]],vr(e));return i}case"ellipse":return t.ellipse(e.width/2,e.height/2,e.width,e.height,vr(e));case"line":case"arrow":{let i,a=vr(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=w1(e,i,"start",s,t,a,o);i.push(...d)}if(c!==null){let d=w1(e,i,"end",c,t,a,o);i.push(...d)}}return i}case"freedraw":{let i;if(S1(e),dr(e.points)){let a=_5(e.points,.75);i=t.curve(a,{...vr(e),stroke:"none"})}else i=null;return i}case"frame":case"magicframe":case"text":case"image":return null;default:return zn(e,`generateElementShape(): Unimplemented type ${e?.type}`),null}}});var Kt,yu,Hi,Da,I1,ps,Vn,N5,wu,Qc,vu,C1,Tu,k1,zi,A1,Su,iP,aP,lP,sP,cP,dP,mP,Gi=Z(()=>{"use strict";h();Kt=(e,t)=>[0,0,0,0,t,e,1,0],yu=(e,t)=>[0,0,0,0,t,e,0,0],Hi=(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},Da=e=>[e[0],e[1],e[2],e[3],-e[4],-e[5],-e[6],-e[7]],I1=(e,t)=>Su(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]],ps=(e,t)=>Su(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]],Vn=(e,t)=>Su(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]:[N5(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]],N5=(e,t)=>t[0]*e[0]+t[2]*e[2]+t[3]*e[3]-t[6]*e[6],wu=(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]],Qc=(e,t)=>[vu(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]],vu=(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],C1=(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]],Tu=e=>Math.sqrt(Math.abs(e[0]*e[0]-e[2]*e[2]-e[3]*e[3]+e[6]*e[6])),k1=e=>Math.sqrt(Math.abs(e[7]*e[7]-e[5]*e[5]-e[4]*e[4]+e[1]*e[1])),zi=e=>{let t=Tu(e);if(t===0||t===1)return e;let r=e[6]<0?-1:1;return Vn(e,r/t)},A1=e=>{let t=k1(e);return t===0||t===1?e:Vn(e,1/t)},Su=e=>typeof e=="number",iP=Hi(1,1),aP=Hi(1,2),lP=Hi(1,3),sP=Hi(1,4),cP=Hi(1,5),dP=Hi(1,6),mP=Hi(1,7)});var Yn,Ra,M1,L1,P1,Iu=Z(()=>{"use strict";h();Gi();Yn=(e,t,r)=>zi([0,r,e,t,0,0,0,0]),Ra=(e,t)=>zi(Qc(t,e)),M1=(e,t)=>C1(e,t),L1=(e,t)=>M1(Ra(e,t),t),P1=e=>Math.sign(e[1])});var Kn,$n,Cu,D1,ku,zr,R1=Z(()=>{"use strict";h();Gi();Iu();Gi();Kn=([e,t])=>[0,0,0,0,t,e,1,0],$n=e=>[e[5],e[4]],Cu=e=>[0,0,0,0,Math.abs(e[4]),Math.abs(e[5]),1,0],D1=(e,t)=>zi(wu(e,t)),ku=(e,t)=>Tu(Qc(e,t)),zr=(e,t)=>vu(e,t)});var ed,N1,Au=Z(()=>{"use strict";h();Gi();ed=e=>[0,0,0,0,e[4],e[5],0,0],N1=(e,t)=>A1([0,0,0,0,t[4]-e[4],t[5]-e[5],0,0])});var td,O1,F1,H1,Gr,z1=Z(()=>{"use strict";h();Gi();Au();td=(e,t)=>I1(Vn(e,Math.sin(t/2)),Math.cos(t/2)),O1=e=>[1,0,0,0,-(.5*e[5]),.5*e[4],0,0],F1=(e,t)=>{let r=.5*t;return[1,0,0,0,r*e[4],r*e[5],0,0]},H1=(e,t)=>Vn(t,e),Gr=(e,t)=>zi(Vn(Vn(e,t),Da(e)))});var G1,F5,gs,W1,H5,U1,Mu,sn,Na,hs,Ba,Oa=Z(()=>{"use strict";h();mt();Ht();me();oe();W();G1={mouse:8,pen:16,touch:28},F5=16,gs={e:!0,s:!0,n:!0,w:!0},W1={e:!0,s:!0,n:!0,w:!0,rotation:!0},H5={e:!0,s:!0,n:!0,w:!0},U1={e:!0,s:!0,n:!0,w:!0,nw:!0,se:!0},Mu={e:!0,s:!0,n:!0,w:!0},sn=(e,t,r,o,n,i,a)=>{let[l,s]=ge(e+r/2,t+o/2,n,i,a);return[l-r/2,s-o/2,r,o]},Na=([e,t,r,o,n,i],a,l,s,c={},d=4)=>{let m=G1[s],p=m/l.value,u=m/l.value,g=m/l.value,f=m/l.value,E=r-e,y=o-t,T=d/l.value,w=(m-_i*2)/(2*l.value),I={nw:c.nw?void 0:sn(e-T-g+w,t-T-f+w,p,u,n,i,a),ne:c.ne?void 0:sn(r+T-w,t-T-f+w,p,u,n,i,a),sw:c.sw?void 0:sn(e-T-g+w,o+T-w,p,u,n,i,a),se:c.se?void 0:sn(r+T-w,o+T-w,p,u,n,i,a),rotation:c.rotation?void 0:sn(e+E/2-p/2,t-T-f+w-F5/l.value,p,u,n,i,a)},k=5*G1.mouse/l.value;return Math.abs(E)>k&&(c.n||(I.n=sn(e+E/2-p/2,t-T-f+w,p,u,n,i,a)),c.s||(I.s=sn(e+E/2-p/2,o+T-w,p,u,n,i,a))),Math.abs(y)>k&&(c.w||(I.w=sn(e-T-g+w,t+y/2-u/2,p,u,n,i,a)),c.e||(I.e=sn(r+T-w,t+y/2-u/2,p,u,n,i,a))),I},hs=(e,t,r,o="mouse")=>{if(e.locked)return{};let n={};if(e.type==="freedraw"||ee(e)){if(e.points.length===2){let[,a]=e.points;a[0]===0||a[1]===0?n=Mu:a[0]>0&&a[1]<0?n=U1:a[0]>0&&a[1]>0?n=Mu:a[0]<0&&a[1]>0?n=U1:a[0]<0&&a[1]<0&&(n=Mu)}}else G(e)?n=H5:X(e)&&(n={rotation:!0});let i=ee(e)?_i+8:_i;return Na(j(e,r,!0),e.angle,t,o,n,i)},Ba=(e,t)=>{if(t.editingLinearElement)return!1;if(e.length>1)return!0;let r=e[0];return ee(r)?r.points.length>2:!0}});import{pointsOnBezierCurves as z5}from"points-on-curve";var G5,Fa,bs,Ui,U5,Ha,Lu,za,Pu,rd,W5,fs,V5,Y5,V1,K5,$5,X5,Z5,j5,q5,od,J5,_u,nd,Y1,K1,$1,Q5,X1,e6,t6,r6,o6,n6,i6,a6,Du,Z1,Xn=Z(()=>{"use strict";h();Gi();R1();Au();Iu();z1();Ht();mt();oe();me();F();Oa();lt();uo();G5=e=>{if(e.type==="arrow")return!1;if(e.type==="freedraw")return!0;let t=!Jt(e.backgroundColor)||cr(e)||Ft(e);return e.type==="line"?t&&dr(e.points):t||Or(e)},Fa=(e,t,r,o,n,i)=>{let a=10/t.zoom.value,l=[o,n];if(U5(t,e)&&Ba([e],t))return Ha(e,i,l,a,r);let s=ae(e,i);return s&&Fa(s,t,r,o,n,i)?!0:Ui(e,t,r,l,i)},bs=(e,t,r,o,n,i)=>{let a=10/t.zoom.value,l=ae(e,i);return l&&Fa(l,t,r,o,n,i)?!1:!Ui(e,t,r,[o,n],i)&&Ha(e,i,[o,n],a,r)},Ui=(e,t,r,o,n)=>{let i=10/t.zoom.value,a=G(e)?W5:G5(e)?fs:V5;return Pu({element:e,elementsMap:n,point:o,threshold:i,check:a,frameNameBoundsCache:r})},U5=(e,t)=>e.selectedElementIds[t.id],Ha=(e,t,[r,o],n,i)=>{if(X(e))return Pu({element:e,elementsMap:t,point:[r,o],threshold:n,check:fs,frameNameBoundsCache:i});let[a,l,s,c]=j(e,t),d=(a+s)/2,m=(l+c)/2,[p,u]=ge(r,o,d,m,-e.angle);return p>a-n&&p<s+n&&u>l-n&&u<c+n},Lu=(e,{x:t,y:r},o)=>{let n=za(e,e.width,e.height);return Pu({element:e,elementsMap:o,point:[t,r],threshold:n,check:Y5,frameNameBoundsCache:null})},za=(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))},Pu=e=>{switch(e.element.type){case"rectangle":case"iframe":case"embeddable":case"image":case"text":case"diamond":case"ellipse":let t=rd(e.element,e.point,e.elementsMap);return e.check(t,e.threshold);case"freedraw":return e.check(V1(e.element,e.point,e.elementsMap),e.threshold)?j5(e.element,e.point,e.threshold,e.elementsMap):!1;case"arrow":case"line":return q5(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(rd(e.element,e.point,e.elementsMap),e.threshold))return!0;let r=e.frameNameBoundsCache?.get(e.element);return r?e.check(K5(r,e.point),e.threshold):!1}}},rd=(e,t,r)=>{switch(e.type){case"rectangle":case"image":case"text":case"iframe":case"embeddable":case"frame":case"magicframe":return V1(e,t,r);case"diamond":return $5(e,t,r);case"ellipse":return X5(e,t,r)}},W5=(e,t)=>e<0,fs=(e,t)=>e<t,V5=(e,t)=>Math.abs(e)<t,Y5=(e,t)=>0<=e&&e<t,V1=(e,t,r)=>{let[,o,n,i]=od(e,t,r);return Math.max(zr(o,Yn(0,1,-i)),zr(o,Yn(1,0,-n)))},K5=(e,t)=>{let[,r,o,n]=J5(t,e);return Math.max(zr(r,Yn(0,1,-n)),zr(r,Yn(1,0,-o)))},$5=(e,t,r)=>{let[,o,n,i]=od(e,t,r),a=Yn(i,n,-i*n);return zr(o,a)},X5=(e,t,r)=>{let[o,n]=Z5(e,t,r);return-P1(n)*zr(o,n)},Z5=(e,t,r)=>{let[,o,n,i]=od(e,t,r),[a,l]=$n(o),s=.707,c=.707,d=n,m=i;[0,1,2,3].forEach(g=>{let f=d*s,E=m*c,y=(d*d-m*m)*s**3/d,T=(m*m-d*d)*c**3/m,w=f-y,I=E-T,k=a-y,C=l-T,D=Math.hypot(I,w),R=Math.hypot(C,k);s=Math.min(1,Math.max(0,(k*D/R+y)/d)),c=Math.min(1,Math.max(0,(C*D/R+T)/m));let z=Math.hypot(c,s);s/=z,c/=z});let p=Kt(d*s,m*c),u=L1(o,p);return[o,u]},j5=(e,t,r,o)=>{let n,i;if(e.angle===0)n=t[0]-e.x,i=t[1]-e.y;else{let[d,m,p,u]=j(e,o),g=Fe(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(at(a[0],a[1],n,i)<r||at(l[0],l[1],n,i)<r)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]],f=(g[0]*u[0]+g[1]*u[1])/Math.hypot(u[1],u[0]);s=[a[0]+u[0]*f,a[1]+u[1]*f];let E=at(s[0],s[1],a[0],a[1]),y=at(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])<r)return!0;a=l,l=e.points[d+1]}let c=Te.get(e);return c&&c.sets.length?e.fillStyle==="solid"?Du(c,n,i,"round"):Z1(c,n,i,r):!1},q5=e=>{let{element:t,threshold:r}=e;if(!Te.get(t))return!1;let[o,n,i,a]=od(e.element,e.point,e.elementsMap),l=Yn(0,1,-a),s=Yn(1,0,-i);if(!fs(zr(n,l),r)||!fs(zr(n,s),r))return!1;let[c,d]=$n(o),m=Te.get(t);return m?e.check===fs&&m.some(u=>Du(u,c,d,t.roundness?"round":"sharp"))?!0:m.some(p=>Z1(p,c,d,r)):!1},od=(e,t,r)=>{let o=Kn(t),[n,i,a,l]=j(e,r),s=nd(n,i,a,l),c=td(s,e.angle),d=Gr(c,o),m=ps(d,ed(s)),p=Cu(m),u=yu(e.x,e.y),g=ps(d,u),f=(a-n)/2,E=(l-i)/2;return[g,p,f,E]},J5=(e,t)=>{let r=Kn(e),[o,n,i,a]=j1(t),l=nd(o,n,i,a),s=td(l,t.angle),c=Gr(s,r),d=ps(c,ed(l)),m=Cu(d),p=yu(t.x,t.y),u=ps(c,p),g=(i-o)/2,f=(a-n)/2;return[u,m,g,f]},_u=(e,t)=>{let[r,o,n,i]=j(e,t),a=nd(r,o,n,i),l=td(a,e.angle),s=Da(O1(ed(a)));return H1(l,s)},nd=(e,t,r,o)=>Kt((e+r)/2,(t+o)/2),Y1=(e,t,r,o)=>{let n=_u(e,o),i=Gr(n,Kn(t)),a=Gr(n,Kn(r)),l=Ra(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),f=Math.abs(m),E;switch(e.type){case"rectangle":case"image":case"text":case"iframe":case"embeddable":case"frame":case"magicframe":E=u/(c*(f+s*g));break;case"diamond":E=g<f?u/(f*c):u/(g*d);break;case"ellipse":E=u/(c*Math.sqrt(m**2+s**2*p**2));break}return E||0},K1=(e,t,r,o)=>{if(t===0){let[s,c,d,m]=j(e,o),p=nd(s,c,d,m);return $n(p)}let n=_u(e,o),i=Gr(n,Kn(r)),a=Da(n),l;switch(e.type){case"rectangle":case"image":case"text":case"diamond":case"iframe":case"embeddable":case"frame":case"magicframe":l=i6(e,t,i);break;case"ellipse":l=n6(e,t,i);break}return $n(Gr(a,l))},$1=(e,t,r,o=0,n)=>{let i=_u(e,n),a=Gr(i,Kn(t)),l=Gr(i,Kn(r)),s=Ra(a,l),c=Da(i);return Q5(e,s,a,o).map(m=>$n(Gr(c,m)))},Q5=(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=X1(e);n=a.flatMap((l,s)=>{let c=[l,a[(s+1)%4]];return e6(t,t6(c,o))}).concat(a.flatMap(l=>o6(l,o,t)));break;case"ellipse":n=r6(e,o,t);break}if(n.length<2)return[];let i=n.sort((a,l)=>ku(a,r)-ku(l,r));return[i[0],i[i.length-1]]},X1=(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[Kt(r,o),Kt(r,-o),Kt(-r,-o),Kt(-r,o)];case"diamond":return[Kt(0,o),Kt(r,0),Kt(0,-o),Kt(-r,0)]}},e6=(e,t)=>{let[r,o]=t,n=zr(r,e),i=zr(o,e);return n*i>=0?[]:[D1(e,Ra(r,o))]},t6=(e,t)=>{let[r,o]=e,n=F1(N1(r,o),t);return[Gr(n,r),Gr(n,o)]},r6=(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[Kt((m+o*n*a*d)/s,(p-o*n*i*d)/s),Kt((m-o*n*a*d)/s,(p+o*n*i*d)/s)]},o6=(e,t,r)=>{if(t===0)return zr(r,e)===0?[e]:[];let o=r[2],n=r[3],i=r[1],[a,l]=$n(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[Kt((p+n*m)/c,(u-o*m)/c),Kt((p-n*m)/c,(u+o*m)/c)]},n6=(e,t,r)=>{let o=Math.abs(t),n=e.width*o/2,i=e.height*o/2,a=Math.sign(t),[l,s]=$n(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 Kt(u,(-m*u-1)/p)},i6=(e,t,r)=>{let o=Math.abs(t),n=Math.sign(t),i=X1(e,o),a=0,l=null;return i.forEach(s=>{let c=n*Ra(r,s)[1];c>a&&(a=c,l=s)}),l},a6=(e,t,r,o,[n,i],a)=>{let l=(c,d)=>Math.pow(1-c,3)*o[d]+3*c*Math.pow(1-c,2)*r[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},Du=(e,t,r,o)=>{let n=po(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(o==="sharp")return mu(i,t,r);let l=z5(i,10,5);return mu(l,t,r)}return!1},Z1=(e,t,r,o)=>{let n=po(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,a6(p,c,d,m,[t,r],o)}else{if(a==="lineTo")return Du(e,t,r,"sharp");a==="qcurveTo"&&console.warn("qcurveTo is not implemented yet")}return!1})}});var ue,S,Ga,id,Ua,Wi,de=Z(()=>{"use strict";h();W();ue={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"},S={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:qt?"metaKey":"ctrlKey",DELETE:"Delete",ENTER:"Enter",ESCAPE:"Escape",QUESTION_MARK:"?",SPACE:" ",TAB:"Tab",CHEVRON_LEFT:"<",CHEVRON_RIGHT:">",PERIOD:".",COMMA:",",SUBTRACT:"-",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"},Ga=e=>e===S.ARROW_LEFT||e===S.ARROW_RIGHT||e===S.ARROW_DOWN||e===S.ARROW_UP,id=e=>e.altKey,Ua=e=>e.shiftKey,Wi=e=>e.shiftKey});var ox,Ro,nx,cn,q1,xs,l6,Es,Wa,Ru,Nu,ys,s6,No,c6,go,d6,m6,J1,Q1,ix,p6,ad,ax,lx,ex,ld,tx,Va,rx,u6,ho=Z(()=>{"use strict";h();We();oe();Xn();He();nn();$t();F();de();lt();ox=e=>!e[S.CTRL_OR_CMD],Ro=e=>e.isBindingEnabled,nx=(e,t)=>{let r=[];return t.forEach(o=>{let n=e.getNonDeletedElement(o);n!=null&&r.push(n)}),r},cn=(e,t,r,o)=>{let n=new Set,i=new Set;q1(e,t,r,"start",n,i,o),q1(e,r,t,"end",n,i,o);let a=Array.from(i).filter(l=>!n.has(l));nx(rt.getScene(e),a).forEach(l=>{B(l,{boundElements:l.boundElements?.filter(s=>s.type!=="arrow"||s.id!==e.id)})})},q1=(e,t,r,o,n,i,a)=>{if(t!=="keep")if(t!=null)(r==null||(r==="keep"?!Ru(e,t,o):o==="start"||r.id!==t.id))&&(Wa(e,t,o,a),n.add(t.id));else{let l=s6(e,o);l!=null&&i.add(l)}},xs=(e,t,r)=>{e.forEach(o=>{Et(o)?cn(o,ad(o,"start",t,r),ad(o,"end",t,r),r):Pa(o)&&l6(o,r)})},l6=(e,t)=>{lx(e,t).forEach(([r,o])=>cn(r,o==="end"?"keep":e,o==="start"?"keep":e,t))},Es=(e,t,r,o,n)=>{t.startBoundElement!=null&&Wa(e,t.startBoundElement,"start",n);let i=No(o,r.getNonDeletedElements(),n);i!=null&&!Ru(e,i,"end")&&Wa(e,i,"end",n)},Wa=(e,t,r,o)=>{B(e,{[r==="start"?"startBinding":"endBinding"]:{elementId:t.id,...c6(e,t,r,o)}}),J(t.boundElements||[]).has(e.id)||B(t,{boundElements:(t.boundElements||[]).concat({id:e.id,type:"arrow"})})},Ru=(e,t,r)=>{let o=e[r==="start"?"endBinding":"startBinding"];return Nu(e,o?.elementId,t)},Nu=(e,t,r)=>t===r.id&&e.points.length<3,ys=(e,t)=>{e.forEach(r=>{Et(r)&&cn(r,null,null,t)})},s6=(e,t)=>{let r=t==="start"?"startBinding":"endBinding",o=e[r];return o==null?null:(B(e,{[r]:null}),o.elementId)},No=(e,t,r)=>hu(t,n=>Pa(n,!1)&&Lu(n,e,r)),c6=(e,t,r,o)=>{let n=r==="start"?-1:1,i=n===-1?0:e.points.length-1,a=i-n,l=V.getPointAtIndexGlobalCoordinates(e,i,o),s=V.getPointAtIndexGlobalCoordinates(e,a,o);return{focus:Y1(t,s,l,o),gap:Math.max(1,rd(t,l,o))}},go=(e,t,r)=>{let o=(e.boundElements??[]).filter(s=>s.type==="arrow");if(o.length===0)return;let{newSize:n,simultaneouslyUpdated:i}=r??{},a=m6(i),l=rt.getScene(e);nx(l,o.map(s=>s.id)).forEach(s=>{if(!ee(s))return;let c=e;if(!d6(s,c))return;let d=Q1(c,s.startBinding,n),m=Q1(c,s.endBinding,n);if(a.has(s.id)){B(s,{startBinding:d,endBinding:m});return}J1(s,"start",d,e,t),J1(s,"end",m,e,t),ae(s,l.getNonDeletedElementsMap())&&Vi(s,l.getNonDeletedElementsMap(),!1)})},d6=(e,t)=>e.startBinding?.elementId===t.id||e.endBinding?.elementId===t.id,m6=e=>new Set((e||[]).map(t=>t.id)),J1=(e,t,r,o,n)=>{if(r==null||r.elementId!==o.id&&e.points.length>2)return;let i=rt.getScene(e).getElement(r.elementId);if(i==null)return;let a=t==="start"?-1:1,l=a===-1?0:e.points.length-1,s=l-a,c=V.getPointAtIndexGlobalCoordinates(e,s,n),d=K1(i,r.focus,c,n),m;if(r.gap===0)m=d;else{let p=$1(i,c,d,r.gap,n);p.length===0?m=d:m=p[0]}V.movePoints(e,[{index:l,point:V.pointFromAbsoluteCoords(e,m,n)}],{[t==="start"?"startBinding":"endBinding"]:r})},Q1=(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(za(e,a,l),o*(a<l?a/s:l/c)));return{elementId:i,gap:d,focus:n}},ix=(e,t,r)=>{let o=new Set(e.map(({id:n})=>n));return e.flatMap(n=>Et(n,!1)?p6(n,t,r).filter(i=>!o.has(i.id)):Pa(n,!1)?lx(n,r).filter(i=>!o.has(i[0].id)):[])},p6=(e,t,r)=>[ad(e,"start",t,r),ad(e,"end",t,r)].filter(o=>o!=null),ad=(e,t,r,o)=>No(ax(e,t,o),r,o),ax=(e,t,r)=>{let o=t==="start"?0:-1;return lo(V.getPointAtIndexGlobalCoordinates(e,o,r))},lx=(e,t)=>rt.getScene(e).getNonDeletedElements().map(o=>{if(!Et(o,!1))return null;let n=ex(o,"start",e,t),i=ex(o,"end",e,t);return!n&&!i?null:[o,n&&i?"both":n?"start":"end",e]}).filter(o=>o!=null),ex=(e,t,r,o)=>e[t==="start"?"startBinding":"endBinding"]==null&&!Ru(e,r,t)&&Lu(r,ax(e,t,o),o),ld=(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))),Et(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;B(l,{startBinding:tx(s,r),endBinding:tx(c,r)})}),e.filter(({id:l})=>i.has(l)).forEach(l=>{let{boundElements:s}=l;s!=null&&s.length>0&&B(l,{boundElements:s.map(c=>r.has(c.id)?{id:r.get(c.id),type:c.type}:c)})})},tx=(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}},Va=(e,t)=>{let r=new Set(t.map(n=>n.id)),o=new Set;t.forEach(n=>{Pa(n)?n.boundElements?.forEach(i=>{r.has(i.id)||o.add(i.id)}):Et(n)&&(n.startBinding&&o.add(n.startBinding.elementId),n.endBinding&&o.add(n.endBinding.elementId))}),e.filter(({id:n})=>o.has(n)).forEach(n=>{Pa(n)?B(n,{boundElements:u6(n.boundElements,r)}):Et(n)&&B(n,{startBinding:rx(n.startBinding,r),endBinding:rx(n.endBinding,r)})})},rx=(e,t)=>e==null||t.has(e.elementId)?null:e,u6=(e,t)=>e?e.filter(r=>!t.has(r.id)):null});var dn,V,g6,$t=Z(()=>{"use strict";h();Ht();me();mt();He();ho();F();oe();de();lt();W();uo();dn={version:null,points:[],zoom:null},V=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]=j(r.draggingElement,n),g=e.getPointsGlobalCoordinates(s,n).reduce((f,E,y)=>((E[0]>=c&&E[0]<=m&&E[1]>=d&&E[1]<=p||t.shiftKey&&a?.includes(y))&&f.push(y),f),[]);o({editingLinearElement:{...i,selectedPointsIndices:g.length?g: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(Wi(t)&&s.length===1&&d.points.length>1){let u=s[0],g=d.points[u===0?1:u-1],[f,E]=e._getShiftLockedDelta(d,l,g,[o,n],t[S.CTRL_OR_CMD]?null:r.gridSize);e.movePoints(d,[{index:u,point:[f+g[0],E+g[1]],isDragging:u===a.pointerDownState.lastClickedPoint}])}else{let u=e.createPointAt(d,l,o-a.pointerOffset.x,n-a.pointerOffset.y,t[S.CTRL_OR_CMD]?null:r.gridSize),g=u[0]-m[0],f=u[1]-m[1];e.movePoints(d,s.map(E=>{let y=E===a.pointerDownState.lastClickedPoint?e.createPointAt(d,l,o-a.pointerOffset.x,n-a.pointerOffset.y,t[S.CTRL_OR_CMD]?null:r.gridSize):[d.points[E][0]+g,d.points[E][1]+f];return{index:E,point:y,isDragging:E===a.pointerDownState.lastClickedPoint}}))}if(ae(d,l)&&Vi(d,l,!1),Et(d,!1)){let u=[];s[0]===0&&u.push(lo(e.getPointGlobalCoordinates(d,d.points[0],l)));let f=s[s.length-1];f===d.points.length-1&&u.push(lo(e.getPointGlobalCoordinates(d,d.points[f],l))),u.length&&i(d,u)}return!0}return!1}static handlePointerUp(t,r,o,n,i){let{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){dr(d.points,o.zoom.value)&&e.movePoints(d,[{index:p,point:p===0?d.points[d.points.length-1]:d.points[0]}]);let u=Ro(o)?No(lo(e.getPointAtIndexGlobalCoordinates(d,p,i)),n,i):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=ae(t,r);return!o.editingLinearElement&&t.points.length>2&&!n?[]:(dn.version===t.version&&dn.zoom===o.zoom.value||e.updateEditorMidPointsCache(t,r,o),dn.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++}dn.points=a,dn.version=t.version,dn.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&&at(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&&at(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=at(r[0],r[1],o[0],o[1]);return t.points.length>2&&t.roundness&&(i=b1(t,o)),i*n.value<e.POINT_HANDLE_SIZE*4}static getSegmentMidPoint(t,r,o,n,i){let a=as(r,o);if(t.points.length>2&&t.roundness){let l=pu(t,t.points[n]);if(l){let s=x1(t,t.points[n],.5),[c,d]=uu(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,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,r,l),p=null;if(m&&(p=e.getSegmentMidPointIndex(i,r,m,l)),t.altKey&&r.editingLinearElement)return i.lastUncommittedPoint==null&&(B(d,{points:[...d.points,e.createPointAt(d,l,n.x,n.y,t[S.CTRL_OR_CMD]?null:r.gridSize)]}),s.didAddPoint=!0),o.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:No(n,a,l)},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:C,endBindingElement:D}=i;Ro(r)&&Et(d)&&cn(d,C,D,l)}let[g,f,E,y]=j(d,l),T=(g+E)/2,w=(f+y)/2,I=u>-1&&ge(d.x+d.points[u][0],d.y+d.points[u][1],T,w,d.angle),k=u>-1||t.shiftKey?t.shiftKey||i.selectedPointsIndices?.includes(u)?g6([...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:k,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:gu(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(Wi(t)&&c.length>=2){let p=c[c.length-2],[u,g]=e._getShiftLockedDelta(s,i,p,[r,o],t[S.CTRL_OR_CMD]?null:n.gridSize);m=[u+p[0],g+p[1]]}else m=e.createPointAt(s,i,r-n.editingLinearElement.pointerOffset.x,o-n.editingLinearElement.pointerOffset.y,t[S.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]=j(t,o),s=(n+a)/2,c=(i+l)/2,{x:d,y:m}=t;return[d,m]=ge(d+r[0],m+r[1],s,c,t.angle),[d,m]}static getPointsGlobalCoordinates(t,r){let[o,n,i,a]=j(t,r),l=(o+i)/2,s=(n+a)/2;return t.points.map(c=>{let{x:d,y:m}=t;return[d,m]=ge(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]=j(t,o),c=(i+l)/2,d=(a+s)/2,m=t.points[n],{x:p,y:u}=t;return m?ge(p+m[0],u+m[1],c,d,t.angle):ge(p,u,c,d,t.angle)}static pointFromAbsoluteCoords(t,r,o){let[n,i,a,l]=j(t,o),s=(n+a)/2,c=(i+l)/2,[d,m]=ge(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(at(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=yt(o,n,i),[l,s,c,d]=j(t,r),m=(l+c)/2,p=(s+d)/2,[u,g]=ge(a[0],a[1],m,p,-t.angle);return[u-t.x,g-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){B(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 f=a[u+1];f||(s=!0),m.push(f?[(p[0]+f[0])/2,(p[1]+f[1])/2]:[p[0],p[1]]),l.push(c+1),++c}return m},[]);if(B(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=at(l.x,l.y,r.x,r.y);return!(!o.editingLinearElement&&s<en/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 B(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=Ya(t,r),l=Ya(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=ge(o,n,p,u,t.angle);B(t,{...i,points:r,x:t.x+g[0],y:t.y+g[1]})}static _getShiftLockedDelta(t,r,o,n,i){let a=e.getPointGlobalCoordinates(t,o,r),[l,s]=yt(n[0],n[1],i),{width:c,height:d}=Ka(a[0],a[1],l,s);return Fe([c,d],[0,0],-t.angle)}static getBoundTextElementPosition=(t,r,o)=>{let n=e.getPointsGlobalCoordinates(t,o);n.length<2&&B(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=dn.points[l];t.points.length===2&&(s=as(n[0],n[1])),(!s||dn.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,g=p+n.height,f=Fe([i,a],[c,d],t.angle),E=Fe([l,a],[c,d],t.angle),y=Fe([m,p],[c,d],-t.angle),T=Fe([u,p],[c,d],-t.angle),w=Fe([m,g],[c,d],-t.angle),I=Fe([u,g],[c,d],-t.angle);return f[0]<E[0]&&f[1]>=E[1]?(i=Math.min(i,w[0]),l=Math.max(l,Math.max(T[0],I[0])),a=Math.min(a,y[1]),s=Math.max(s,I[1])):f[0]>=E[0]&&f[1]>E[1]?(i=Math.min(i,I[0]),l=Math.max(l,Math.max(y[0],T[0])),a=Math.min(a,w[1]),s=Math.max(s,T[1])):f[0]>=E[0]?(i=Math.min(i,T[0]),l=Math.max(l,w[0]),a=Math.min(a,I[1]),s=Math.max(s,y[1])):f[1]<=E[1]&&(i=Math.min(i,Math.min(T[0],y[0])),l=Math.max(l,I[0]),a=Math.min(a,T[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||!Te.get(t)){let{minX:p,minY:u,maxX:g,maxY:f}=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=f+t.y}else{let p=Te.generateElementShape(t,null),u=po(p[0]),[g,f,E,y]=ws(u);i=g+t.x,a=f+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],!o)return n;let m=ae(t,r);return m&&(n=e.getMinMaxXYWithBoundText(t,r,[i,a,l,s],m)),n}},g6=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 Yi,Ki,sd,sx,cd=Z(()=>{"use strict";h();Yi={},Ki=(e,t)=>{let r=Yi[e]||(Yi[e]={height:t});return r.height=t,r},sd=e=>{Yi[e]&&delete Yi[e]},sx=e=>Yi[e]?.height??null});var Zn,Fu,zt,dd,Vi,$a,fo,dx,jn,md,pd,Bu,vs,Ts,h6,f6,qn,mx,px,ud,b6,pn,ae,st,gd,Hu,ux,gx,hx,zu,x6,fx,mn,mr,$i,bx,Ou,cx,Tr,lt=Z(()=>{"use strict";h();F();He();W();me();oe();$t();oe();me();We();Xn();cd();Zn=e=>Xc(e).replace(/\t/g," "),Fu=e=>Zn(e).split(`
|
|
10
|
+
`),zt=(e,t,r)=>{let o,n={x:e.x,y:e.y,text:e.text,width:e.width,height:e.height};n.text=e.text,t&&(o=mr(t,e),n.text=qn(e.originalText,Be(e),o));let i=fo(n.text,Be(e),e.lineHeight);if(n.width=i.width,n.height=i.height,t){let a=$i(t,e),l=mr(t,e);if(!we(t)&&i.height>a){let m=mn(i.height,t.type);B(t,{height:m}),Ki(t.id,m)}if(i.width>l){let m=mn(i.width,t.type);B(t,{width:m})}let s={...e,...n},{x:c,y:d}=$a(t,s,r);n.x=c,n.y=d}B(e,n)},dd=(e,t,r)=>{let o=J(e);t.forEach(n=>{let i=r.get(n.id),a=pn(n);if(a){let l=r.get(a);if(l){let s=o.get(i);s&&B(s,{boundElements:(n.boundElements||[]).filter(d=>d.id!==l&&d.id!==a).concat({type:"text",id:l})});let c=o.get(l);c&&G(c)&&B(c,{containerId:s?i:null})}}})},Vi=(e,t,r,o=!1)=>{if(!pn(e))return;sd(e.id);let i=ae(e,t);if(i&&i.text){if(!e)return;let a=i.text,l=i.height,s=i.width,c=mr(e,i),d=$i(e,i),m=e.height;if(o||r!=="n"&&r!=="s"){a&&(a=qn(i.originalText,Be(i),c));let p=fo(a,Be(i),i.lineHeight);l=p.height,s=p.width}if(l>d){m=mn(l,e.type);let p=m-e.height,u=!we(e)&&(r==="ne"||r==="nw"||r==="n")?e.y-p:e.y;B(e,{height:m,y:u})}B(i,{text:a,width:s,height:l}),we(e)||B(i,$a(e,i,t))}},$a=(e,t,r)=>{if(we(e))return V.getBoundTextElementPosition(e,t,r);let o=Hu(e),n=$i(e,t),i=mr(e,t),a,l;return t.verticalAlign===gt.TOP?l=o.y:t.verticalAlign===gt.BOTTOM?l=o.y+(n-t.height):l=o.y+(n/2-t.height/2),t.textAlign===Fn.LEFT?a=o.x:t.textAlign===Fn.RIGHT?a=o.x+(i-t.width):a=o.x+(i/2-t.width/2),{x:a,y:l}},fo=(e,t,r)=>{e=e.split(`
|
|
11
|
+
`).map(a=>a||" ").join(`
|
|
12
|
+
`);let o=parseFloat(t),n=h6(e,o,r);return{width:Ts(e,t),height:n}},dx=e=>{let t=Fu(e.text).length;return e.height/t/e.fontSize},jn=(e,t)=>e*t,md=(e,t,r)=>{let{unitsPerEm:o,ascender:n,descender:i}=cx[e]||cx[it.Helvetica],a=t/o,l=r-a*n+a*i;return a*n+l},pd=(e,t)=>jn(e,t)+pt*2,vs=(e,t)=>{Bu||(Bu=document.createElement("canvas"));let r=Bu.getContext("2d");r.font=t;let o=r.measureText(e).width;return wr()?o*10:o},Ts=(e,t)=>{let r=Fu(e),o=0;return r.forEach(n=>{o=Math.max(o,vs(n,t))}),o},h6=(e,t,r)=>{let o=Fu(e).length;return jn(t,r)*o},f6=e=>{let t=e.split("-");return t.length>1&&t.forEach((r,o)=>{o!==t.length-1&&(t[o]=r+="-")}),t.join(" ").split(" ")},qn=(e,t,r)=>{if(!Number.isFinite(r)||r<0)return e;let o=[],n=e.split(`
|
|
13
|
+
`),i=vs(" ",t),a="",l=0,s=d=>{d.trim()&&o.push(d)},c=()=>{a="",l=0};return n.forEach(d=>{if(Ts(d,t)<=r){o.push(d);return}let p=f6(d);c();let u=0;for(;u<p.length;){let g=vs(p[u],t);if(g===r)s(p[u]),u++;else if(g>r){for(s(a),c();p[u].length>0;){let f=String.fromCodePoint(p[u].codePointAt(0)),E=mx.calculate(f,t);l+=E,p[u]=p[u].slice(f.length),l>=r?(s(a),a=f,l=E):a+=f}l+i>=r?(s(a),c()):a.endsWith("-")||(a+=" ",l+=i),u++}else for(;l<r&&u<p.length;){let f=p[u];if(l=vs(a+f,t),l>r){s(a),c();break}u++;let E=!f.endsWith("-");if(a+=f,E&&(a+=" "),l+i>=r){E?o.push(a.slice(0,-1)):o.push(a),c();break}}}a.slice(-1)===" "&&(a=a.slice(0,-1),s(a))}),o.join(`
|
|
14
|
+
`)},mx=(()=>{let e={};return{calculate:(o,n)=>{let i=o.charCodeAt(0);if(e[n]||(e[n]=[]),!e[n][i]){let a=vs(o,n);e[n][i]=a}return e[n][i]},getCache:o=>e[o]}})(),px="ABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789".toLocaleUpperCase(),ud=(e,t)=>{let r=b6(e);return r===0?fo(px.split("").join(`
|
|
15
|
+
`),e,t).width+pt*2:r+pt*2},b6=e=>{let t=mx.getCache(e);if(!t)return 0;let r=t.filter(o=>o!==void 0);return Math.max(...r)},pn=e=>e?.boundElements?.length&&e?.boundElements?.filter(t=>t.type==="text")[0]?.id||null,ae=(e,t)=>{if(!e)return null;let r=pn(e);return r&&t.get(r)||null},st=(e,t)=>e&&e.containerId&&t.get(e.containerId)||null,gd=(e,t,r)=>{if(!we(e))return{x:e.x+e.width/2,y:e.y+e.height/2};let o=V.getPointsGlobalCoordinates(e,r);if(o.length%2===1){let a=Math.floor(e.points.length/2),l=V.getPointGlobalCoordinates(e,e.points[a],r);return{x:l[0],y:l[1]}}let n=e.points.length/2-1,i=V.getEditorMidPoints(e,r,t)[n];return i||(i=V.getSegmentMidPoint(e,o[n],o[n+1],n+1,r)),{x:i[0],y:i[1]}},Hu=e=>{let t=pt,r=pt;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}},ux=(e,t)=>!t||we(t)?e.angle:t.angle,gx=(e,t)=>e.some(r=>{if(Me(r)){let o=st(r,t);return!we(o)}return!1}),hx=(e,t)=>e.some(r=>{if(Me(r)){let o=st(r,t);return!we(o)}return G(r)}),zu=(e,t,r,o,n)=>{let i=pe(e,t);if(i.length===1)return _o(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]=j(e[l],n);if(we(e[l])&&Ui(e[l],t,null,[r,o],n)){a=e[l];break}else if(s<r&&r<d&&c<o&&o<m){a=e[l];break}}return _o(a,!1)?a:null},x6=new Set(["rectangle","ellipse","diamond","arrow"]),fx=e=>x6.has(e.type),mn=(e,t)=>{e=Math.ceil(e);let r=pt*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(we(e)){let o=(t?.fontSize??It)*Kb;return Math.max(Yb*r,o)}return e.type==="ellipse"?Math.round(r/2*Math.sqrt(2))-pt*2:e.type==="diamond"?Math.round(r/2)-pt*2:r-pt*2},$i=(e,t)=>{let{height:r}=e;return we(e)?r-pt*8*2<=0?t.height:r:e.type==="ellipse"?Math.round(r/2*Math.sqrt(2))-pt*2:e.type==="diamond"?Math.round(r/2)-pt*2:r-pt*2},bx=()=>Ts(px,Be({fontSize:It,fontFamily:Ot}))>0,Ou={[it.Virgil]:1.25,[it.Helvetica]:1.15,[it.Cascadia]:1.2},cx={[it.Virgil]:{unitsPerEm:1e3,ascender:886,descender:-374},[it.Helvetica]:{unitsPerEm:2048,ascender:1577,descender:-471},[it.Cascadia]:{unitsPerEm:2048,ascender:1977,descender:-480},[it.Assistant]:{unitsPerEm:1e3,ascender:1021,descender:-287}},Tr=e=>e in Ou?Ou[e]:Ou[Ot]});import Uu from"roughjs/bin/rough";var Gu,j,Wu,j1,xu,po,xx,Ex,E6,ws,Vu,y6,w6,v6,Eu,T6,S6,bo,ye,hd,Xi,Ya,Yu,pr,I6,mt=Z(()=>{"use strict";h();Ht();bu();oe();ns();lt();$t();uo();F();Gu=class e{static boundsCache=new WeakMap;static getBounds(t,r){let o=e.boundsCache.get(t);if(o?.version&&o.version===t.version&&!Me(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]=j(t,r);if(kt(t)){let[d,m,p,u]=Vu(t.points.map(([g,f])=>ge(g,f,s-t.x,c-t.y,t.angle)));return[d+t.x,m+t.y,p+t.x,u+t.y]}else if(ee(t))o=S6(t,s,c,r);else if(t.type==="diamond"){let[d,m]=ge(s,i,s,c,t.angle),[p,u]=ge(s,l,s,c,t.angle),[g,f]=ge(n,c,s,c,t.angle),[E,y]=ge(a,c,s,c,t.angle),T=Math.min(d,p,g,E),w=Math.min(m,u,f,y),I=Math.max(d,p,g,E),k=Math.max(m,u,f,y);o=[T,w,I,k]}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),f=Math.hypot(m*p,d*u);o=[s-g,c-f,s+g,c+f]}else{let[d,m]=ge(n,i,s,c,t.angle),[p,u]=ge(n,l,s,c,t.angle),[g,f]=ge(a,l,s,c,t.angle),[E,y]=ge(a,i,s,c,t.angle),T=Math.min(d,p,g,E),w=Math.min(m,u,f,y),I=Math.max(d,p,g,E),k=Math.max(m,u,f,y);o=[T,w,I,k]}return o}},j=(e,t,r=!1)=>{if(kt(e))return y6(e);if(ee(e))return V.getElementAbsoluteCoords(e,t,r);if(G(e)){let o=t?st(e,t):null;if(we(o)){let n=V.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]},Wu=(e,t)=>{let[r,o,n,i,a,l]=j(e,t),s=[a,l];if(ee(e)||kt(e)){let y=[],T=0;for(;T<e.points.length-1;)y.push([Fe([e.points[T][0]+e.x,e.points[T][1]+e.y],s,e.angle),Fe([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,f,E]=[[r,o],[n,o],[r,i],[n,i],[a,o],[a,i],[r,l],[n,l]].map(y=>Fe(y,s,e.angle));return e.type==="diamond"?[[u,f],[u,E],[g,f],[g,E]]:e.type==="ellipse"?[[u,f],[u,E],[g,f],[g,E],[u,f],[u,E],[g,f],[g,E]]:[[c,d],[m,p],[c,m],[d,p],[c,E],[m,E],[d,f],[p,f]]},j1=e=>[e.x,e.y,e.x+e.width,e.y+e.height,e.x+e.width/2,e.y+e.height/2],xu=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]},po=e=>{for(let t of e.sets)if(t.type==="path")return t.ops;return e.sets[0].ops},xx=(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},Ex=(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,g=1/0,f=1/0;return l===0?g=f=-c/s:(g=(-s+Math.sqrt(d))/(2*l),f=(-s-Math.sqrt(d))/(2*l)),g>=0&&g<=1&&(p=xx(g,e,t,r,o)),f>=0&&f<=1&&(u=xx(f,e,t,r,o)),[p,u]},E6=(e,t,r,o)=>{let n=Ex(e[0],t[0],r[0],o[0]),i=Ex(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]},ws=(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,g=t?t(...m):m,f=t?t(...p):p,E=t?t(...r):r;r=p;let[y,T,w,I]=E6(E,u,g,f);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,I)}return l},{minX:1/0,minY:1/0,maxX:-1/0,maxY:-1/0});return[o,n,i,a]},Vu=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]},y6=e=>{let[t,r,o,n]=Vu(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]},w6=e=>{switch(e){case"arrow":return 25;case"diamond":case"diamond_outline":return 12;default:return 15}},v6=e=>{switch(e){case"bar":return 90;case"arrow":return 20;default:return 25}},Eu=(e,t,r,o)=>{let n=po(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=(Y,Q)=>Math.pow(1-Y,3)*l[Q]+3*Y*Math.pow(1-Y,2)*s[Q]+3*Math.pow(Y,2)*(1-Y)*c[Q]+m[Q]*Math.pow(Y,3),[u,g]=r==="start"?m:l,[f,E]=[p(.3,0),p(.3,1)],y=Math.hypot(u-f,g-E),T=(u-f)/y,w=(g-E)/y,I=w6(o),k=0;{let[Y,Q]=r==="end"?e.points[e.points.length-1]:e.points[0],[fe,se]=e.points.length>1?r==="end"?e.points[e.points.length-2]:e.points[1]:[0,0];k=Math.hypot(Y-fe,Q-se)}let D=Math.min(I,k*(o==="diamond"||o==="diamond_outline"?.25:.5)),R=u-T*D,z=g-w*D;if(o==="dot"||o==="circle"||o==="circle_outline"){let Y=Math.hypot(z-g,R-u)+e.strokeWidth-2;return[u,g,Y]}let L=v6(o),[M,A]=ge(R,z,u,g,-L*Math.PI/180),[H,q]=ge(R,z,u,g,L*Math.PI/180);if(o==="diamond"||o==="diamond_outline"){let Y,Q;if(r==="start"){let[fe,se]=e.points.length>1?e.points[1]:[0,0];[Y,Q]=ge(u+D*2,g,u,g,Math.atan2(se-g,fe-u))}else{let[fe,se]=e.points.length>1?e.points[e.points.length-2]:[0,0];[Y,Q]=ge(u-D*2,g,u,g,Math.atan2(g-se,u-fe))}return[u,g,M,A,Y,Q,H,q]}return[u,g,M,A,H,q]},T6=e=>{let t=Uu.generator(),r=vr(e),o=e.roundness?"curve":r.fill?"polygon":"linearPath";return t[o](e.points,r)},S6=(e,t,r,o)=>{let n=ae(e,o);if(e.points.length<2){let[m,p]=e.points[0],[u,g]=ge(e.x+m,e.y+p,t,r,e.angle),f=[u,g,u,g];if(n){let E=V.getMinMaxXYWithBoundText(e,o,[u,g,u,g],n);f=[E[0],E[1],E[2],E[3]]}return f}let a=Te.get(e)?.[0]??T6(e),l=po(a),c=ws(l,(m,p)=>ge(e.x+m,e.y+p,t,r,e.angle)),d=[c[0],c[1],c[2],c[3]];if(n){let m=V.getMinMaxXYWithBoundText(e,o,d,n);d=[m[0],m[1],m[2],m[3]]}return d},bo=(e,t)=>Gu.getBounds(e,t),ye=e=>{if(!e.length)return[0,0,0,0];let t=1/0,r=-1/0,o=1/0,n=-1/0,i=J(e);return e.forEach(a=>{let[l,s,c,d]=bo(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]},hd=(e,t)=>{let[r,o,n,i]=ye(e);return[r+t.x,o+t.y,n+t.x,i+t.y]},Xi=(e,t,r,o)=>{if(!(ee(e)||kt(e)))return[e.x,e.y,e.x+t,e.y+r];let n=Wn(0,t,Wn(1,r,e.points,o),o),i;if(kt(e))i=Vu(n);else{let d=Uu.generator(),m=e.roundness?d.curve(n,vr(e)):d.linearPath(n,vr(e)),p=po(m);i=ws(p)}let[a,l,s,c]=i;return[a+e.x,l+e.y,s+e.x,c+e.y]},Ya=(e,t)=>{let r=Uu.generator(),o=e.roundness==null?r.linearPath(t,vr(e)):r.curve(t,vr(e)),n=po(o),[i,a,l,s]=ws(n);return[i+e.x,a+e.y,l+e.x,s+e.y]},Yu=(e,t)=>{if(!e.length)return[0,0,0,0];let r=1/0,o=e[0],n=J(e);return e.forEach(i=>{let[a,l,s,c]=bo(i,n),d=at((a+s)/2,(l+c)/2,t.x,t.y);d<r&&(r=d,o=i)}),bo(o,n)},pr=e=>{let[t,r,o,n]=ye(e);return{minX:t,minY:r,maxX:o,maxY:n,width:o-t,height:n-r,midX:(t+o)/2,midY:(r+n)/2}},I6=({scrollX:e,scrollY:t,width:r,height:o,zoom:n})=>[-e,-t,-e+r/n.value,-t+o/n.value]});var C6,er,k6,yx,fd,wx,ur,xo,Sr=Z(()=>{"use strict";h();Vt();W();C6=Ca.includes(devicePixelRatio)?devicePixelRatio:1,er=()=>({showWelcomeScreen:!1,theme:qe.LIGHT,collaborators:new Map,currentChartType:"bar",currentItemBackgroundColor:Je.backgroundColor,currentItemEndArrowhead:"arrow",currentItemFillStyle:Je.fillStyle,currentItemFontFamily:Ot,currentItemFontSize:It,currentItemOpacity:Je.opacity,currentItemRoughness:Je.roughness,currentItemStartArrowhead:null,currentItemStrokeColor:Je.strokeColor,currentItemRoundness:"round",currentItemStrokeStyle:Je.strokeStyle,currentItemStrokeWidth:Je.strokeWidth,currentItemTextAlign:On,cursorButton:"up",activeEmbeddable:null,draggingElement:null,editingElement:null,editingGroupId:null,editingLinearElement:null,activeTool:{type:"selection",customType:null,locked:Je.locked,lastActiveTool:null},penMode:!1,penDetected:!1,errorMessage:null,exportBackground:!0,exportScale:C6,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:ie.white,zenModeEnabled:!1,zoom:{value:1},viewModeEnabled:!1,pendingImageElementId:null,showHyperlinkPopup:!1,selectedLinearElement:null,snapLines:[],originSnapOffset:{x:0,y:0},objectsSnapModeEnabled:!1,userToFollow:null,followedBy:new Set}),k6=(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}}),yx=(e,t)=>{let r={};for(let o of Object.keys(e))if(k6[o]?.[t]){let i=e[o];r[o]=i}return r},fd=e=>yx(e,"export"),wx=e=>yx(e,"server"),ur=({activeTool:e})=>e.type==="eraser",xo=({activeTool:e})=>e.type==="hand"});var Ku,Gt,bd,$u,un,xd,vx,Zi,Ze,Tx,Sx,Ix,Cx,ji,Ir=Z(()=>{"use strict";h();We();lt();Un();Ku=(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}}},Gt=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 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(f=>c[f]);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,r={editingGroupId:l.editingGroupId,selectedGroupIds:c,selectedElementIds:Ce({...l.selectedElementIds,...m},s)},r},n=(i,a,l,s)=>{let c=s?s.scene.getSelectedElements({selectedElementIds:i.selectedElementIds,elements:a}):pe(a,i);return c.length?o(c,a,i,l):{selectedGroupIds:{},editingGroupId:null,selectedElementIds:Ce(i.selectedElementIds,l)}};return n.clearCache=()=>{t=null,e=null,r=null},n}(),bd=(e,t)=>$u(e,t)!=null,$u=(e,t)=>t.groupIds.filter(r=>r!==e.editingGroupId).find(r=>e.selectedGroupIds[r]),un=e=>Object.entries(e.selectedGroupIds).filter(([t,r])=>r).map(([t,r])=>t),xd=(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,...Ku(i,r,e)}}}return r.selectedGroupIds},vx=(e,t)=>({...e,editingGroupId:t.groupIds.length?t.groupIds[0]:null,selectedGroupIds:{},selectedElementIds:{[t.id]:!0}}),Zi=(e,t)=>e.groupIds.includes(t),Ze=(e,t)=>{let r=[];for(let o of e.values())Zi(o,t)&&r.push(o);return r},Tx=(e,t)=>e.groupIds.find(r=>t[r]),Sx=(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},Ix=(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},Cx=(e,t)=>e.filter(r=>!t[r]),ji=(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=ae(o,t);a&&i.push(a),r.set(n,[...i,o])}),Array.from(r.values())}});import{sanitizeUrl as A6}from"@braintree/sanitize-url";var tr,Ed,yd,Xa=Z(()=>{"use strict";h();tr=e=>(e=e.trim(),e&&A6(e)),Ed=e=>!!(e?.includes(location.origin)||e?.startsWith("/")),yd=e=>{if(e=tr(e),e.startsWith("/"))return`${location.origin}${e}`;try{new URL(e)}catch{return"about:blank"}return e}});var wd,N,ze=Z(()=>{"use strict";h();wd=[],N=e=>(wd=wd.concat(e),e)});import vd from"open-color";var Ax,M6,Mx,L6,P6,Cr,De,Bo,kx,Xu,kr,Za=Z(()=>{"use strict";h();W();Sr();Ax='<svg viewBox="0 0 24 24" stroke-width="1" width="28" height="28" xmlns="http://www.w3.org/2000/svg">',M6='<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"/>',Mx='<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"/>',L6=`data:${$.svg},${encodeURIComponent(`${Ax}${Mx}</svg>`)}`,P6=`data:${$.svg},${encodeURIComponent(`${Ax}${M6}${Mx}</svg>`)}`,Cr=e=>{e&&(e.style.cursor="")},De=(e,t)=>{e&&(e.style.cursor=t)},Xu=(e,t)=>{let o=()=>{let n=t===qe.DARK;Bo=document.createElement("canvas"),Bo.theme=t,Bo.height=20,Bo.width=20;let i=Bo.getContext("2d");i.lineWidth=1,i.beginPath(),i.arc(Bo.width/2,Bo.height/2,5,0,2*Math.PI),i.fillStyle=n?vd.black:vd.white,i.fill(),i.strokeStyle=n?vd.white:vd.black,i.stroke(),kx=Bo.toDataURL($.svg)};(!Bo||Bo.theme!==t)&&o(),De(e,`url(${kx}) ${20/2} ${20/2}, auto`)},kr=(e,t)=>{if(e)if(t.activeTool.type==="selection")Cr(e);else if(xo(t))e.style.cursor=Se.GRAB;else if(ur(t))Xu(e,t.theme);else if(t.activeTool.type==="laser"){let r=t.theme===qe.LIGHT?L6:P6;e.style.cursor=`url(${r}), auto`}else["image","custom"].includes(t.activeTool.type)?t.activeTool.type!=="image"&&(e.style.cursor=Se.AUTO):e.style.cursor=Se.CROSSHAIR}});var gn,Ar,Zu,Lx,Id,Ss,Px,Lt,_6,ja,ju,_x,Ur,Is,Td,hn,Sd,Cs,Cd,fn=Z(()=>{"use strict";h();F();co();He();Ir();me();Ht();mt();lt();W();gn=(e,{x:t,y:r,strokeColor:o=Je.strokeColor,backgroundColor:n=Je.backgroundColor,fillStyle:i=Je.fillStyle,strokeWidth:a=Je.strokeWidth,strokeStyle:l=Je.strokeStyle,roughness:s=Je.roughness,opacity:c=Je.opacity,width:d=0,height:m=0,angle:p=0,groupIds:u=[],frameId:g=null,roundness:f=null,boundElements:E=null,link:y=null,locked:T=Je.locked,...w})=>({id:w.id||At(),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:g,roundness:f,seed:w.seed??Hr(),version:w.version||1,versionNonce:w.versionNonce??0,isDeleted:!1,boundElements:E,updated:on(),link:y,locked:T,customData:w.customData}),Ar=e=>gn(e.type,e),Zu=e=>gn("embeddable",e),Lx=e=>({...gn("iframe",e)}),Id=e=>te({...gn("frame",e),type:"frame",name:e?.name||null},{}),Ss=e=>te({...gn("magicframe",e),type:"magicframe",name:e?.name||null},{}),Px=(e,t)=>({x:e.textAlign==="center"?t.width/2:e.textAlign==="right"?t.width:0,y:e.verticalAlign==="middle"?t.height/2:0}),Lt=e=>{let t=e.fontFamily||Ot,r=e.fontSize||It,o=e.lineHeight||Tr(t),n=Zn(e.text),i=fo(n,Be({fontFamily:t,fontSize:r}),o),a=e.textAlign||On,l=e.verticalAlign||Pi,s=Px({textAlign:a,verticalAlign:l},i);return te({...gn("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},{})},_6=(e,t,r)=>{let{width:o,height:n}=fo(r,Be(e),e.lineHeight),{textAlign:i,verticalAlign:a}=e,l,s;if(i==="center"&&a===gt.MIDDLE&&!e.containerId){let c=fo(e.text,Be(e),e.lineHeight),d=Px(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]=j(e,t),[u,g,f,E]=Xi(e,o,n,!1),y=(c-u)/2,T=(d-g)/2,w=(m-f)/2,I=(p-E)/2;[l,s]=jc({s:!0,e:i==="center"||i==="left",w:i==="center"||i==="right"},e.x,e.y,e.angle,y,T,w,I)}return{width:o,height:n,x:Number.isFinite(l)?l:e.x,y:Number.isFinite(s)?s:e.y}},ja=(e,t,r,o=e.text)=>{if(e.isDeleted)return;t&&(o=qn(o,Be(e),mr(t,e)));let n=_6(e,r,o);return{text:o,...n}},ju=(e,t,r,{text:o,isDeleted:n,originalText:i})=>te(e,{originalText:i,isDeleted:n??e.isDeleted,...ja(e,t,r,i)}),_x=e=>({...gn(e.type,e),points:e.points||[],pressures:[],simulatePressure:e.simulatePressure,lastCommittedPoint:null}),Ur=e=>({...gn(e.type,e),points:e.points||[],lastCommittedPoint:null,startBinding:null,endBinding:null,startArrowhead:e.startArrowhead||null,endArrowhead:e.endArrowhead||null}),Is=e=>({...gn("image",e),strokeColor:"transparent",status:e.status??"pending",fileId:e.fileId??null,scale:e.scale??[1,1]}),Td=(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]=Td(e[n],t+1)}return o}if(Array.isArray(e)){let o=e.length,n=new Array(o);for(;o--;)n[o]=Td(e[o],t+1);return n}return v.DEV&&r!=="[object Object]"&&r!=="[object Array]"&&r.startsWith("[object ")&&console.warn(`_deepCloneElement: unexpected object type ${r}. This value will not be cloned!`),e},hn=e=>Td(e),Sd=e=>{if(wr()&&e){let t=`${e}_copy`;return window.h?.app?.getSceneElementsIncludingDeleted().find(r=>r.id===t)&&(t+="_copy"),t}return At()},Cs=(e,t,r,o)=>{let n=hn(r);return n.id=Sd(n.id),n.boundElements=null,n.updated=on(),n.seed=Hr(),n.groupIds=Sx(n.groupIds,e,i=>(t.has(i)||t.set(i,Sd(i)),t.get(i))),o&&(n=Object.assign(n,o)),n},Cd=(e,t)=>{let r=[],o=J(e),n=new Map,i=l=>{if(n.has(l))return n.get(l);if(o.has(l)){let s=Sd(l);return n.set(l,s),s}return null},a=new Map;for(let l of e){let s=Td(l);if(s.id=i(l.id),t?.randomizeSeed&&(s.seed=Hr(),Eo(s)),s.groupIds&&(s.groupIds=s.groupIds.map(c=>(a.has(c)||a.set(c,Sd(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 bn,D6,R6,N6,B6,O6,F6,H6,z6,G6,Dx,qu,qi,xn,kd,ID,Rx,Nx,qa,ks=Z(()=>{"use strict";h();ze();W();F();Za();fn();lt();oe();bn=new Map,D6=/^(?: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]*$/,R6=/^(?:http(?:s)?:\/\/)?(?:(?:w){3}.)?(?:player\.)?vimeo\.com\/(?:video\/)?([^?\s]+)(?:\?.*)?$/,N6=/^https:\/\/(?:www\.)?figma\.com/,B6=/^https:\/\/gist\.github\.com/,O6=/^<script[\s\S]*?\ssrc=["'](https:\/\/gist.github.com\/.*?)\.js["']/i,F6=/(?:http(?:s)?:\/\/)?(?:(?:w){3}.)?(?:twitter|x).com/,H6=/^<blockquote[\s\S]*?\shref=["'](https:\/\/(?:twitter|x).com\/[^"']*)/i,z6=/^https:\/\/(?:www\.)?val.town\/(v|embed)\/[a-zA-Z_$][0-9a-zA-Z_$]+\.[a-zA-Z_$][0-9a-zA-Z_$]+/,G6=/^<(?:iframe|blockquote)[\s\S]*?\s(?:src|href)=["']([^"']*)["'][\s\S]*?>$/i,Dx=/giphy.com\/(?:clips|embed|gifs)\/[a-zA-Z0-9]*?-?([a-zA-Z0-9]+)(?:[^a-zA-Z0-9]|$)/,qu=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"]),qi=e=>`<html><body>${e}</body></html>`,xn=e=>{if(!e)return null;if(bn.has(e))return bn.get(e);let t=e,r="generic",o={w:560,h:840},n=e.match(D6);if(n?.[2]){let s=n[3]?`&start=${n[3]}`:"",c=e.includes("shorts");switch(r="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 o=c?{w:315,h:560}:{w:560,h:315},bn.set(t,{link:e,intrinsicSize:o,type:r}),{link:e,intrinsicSize:o,type:r}}let i=e.match(R6);if(i?.[1]){let s=i?.[1],c=/^\d+$/.test(s)?void 0:new URIError("Invalid embed link format");return r="video",e=`https://player.vimeo.com/video/${s}?api=1`,o={w:560,h:315},bn.set(t,{link:e,intrinsicSize:o,type:r}),{link:e,intrinsicSize:o,type:r,error:c}}if(e.match(N6))return r="generic",e=`https://www.figma.com/embed?embed_host=share&url=${encodeURIComponent(e)}`,o={w:550,h:550},bn.set(t,{link:e,intrinsicSize:o,type:r}),{link:e,intrinsicSize:o,type:r};let l=e.match(z6);if(l)return e=l[1]==="embed"?l[0]:l[0].replace("/v","/embed"),bn.set(t,{link:e,intrinsicSize:o,type:r}),{link:e,intrinsicSize:o,type:r};if(F6.test(e)){e=e.replace(/\bx.com\b/,"twitter.com");let s;if(/<blockquote/.test(e)){let c=qi(e);s={type:"document",srcdoc:()=>c,intrinsicSize:{w:480,h:480}}}else s={type:"document",srcdoc:c=>qi(`<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}};return bn.set(t,s),s}if(B6.test(e)){let s;if(/<script>/.test(e)){let c=qi(e);s={type:"document",srcdoc:()=>c,intrinsicSize:{w:550,h:720}}}else s={type:"document",srcdoc:()=>qi(`
|
|
2
16
|
<script src="${e}.js"><\/script>
|
|
3
17
|
<style type="text/css">
|
|
4
18
|
* { margin: 0px; }
|
|
5
19
|
table, .gist { height: 100%; }
|
|
6
20
|
.gist .gist-file { height: calc(100vh - 2px); padding: 0px; display: grid; grid-template-rows: 1fr auto; }
|
|
7
21
|
</style>
|
|
8
|
-
`),intrinsicSize:{w:550,h:720}};return mn.set(e,c),c}return mn.set(e,{link:e,intrinsicSize:o,type:r}),{link:e,intrinsicSize:o,type:r}},Ld=e=>{if(nr(e))return!0;if(e.type==="text"){let t=je(e);if(t&&J(t))return!0}return!1},_d=e=>{let t;Kr(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=St.Helvetica,n=_e({fontSize:r,fontFamily:o});return Rt({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:oi(t,n,e.width-20),textAlign:"center",verticalAlign:ht.MIDDLE,angle:e.angle??0})},QR=N({name:"setEmbeddableAsActiveTool",trackEvent:{category:"toolbar"},perform:(e,t,r,o)=>{let n=Xe(t,{type:"embeddable"});return Lr(o.canvas,{...t,activeTool:n}),{elements:e,appState:{...t,activeTool:Xe(t,{type:"embeddable"})},commitToHistory:!1}}}),nE=(e,t)=>{try{let{hostname:r}=new URL(e),o=r.replace(/^www\./,""),n=o.replace(/^([^.]+)/,"*");if(t instanceof Set)return Qp.has(o)||Qp.has(n);if(o===t.replace(/^www\./,""))return!0}catch{}return!1},iE=e=>{let t=e.match(l4);if(t&&t.length===2)return t[1];let r=e.match(i4);if(r&&r.length===2)return r[1];if(oE.test(e))return`https://giphy.com/embed/${oE.exec(e)[1]}`;let o=e.match(c4);return o&&o.length===2?o[1]:e},Ka=(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(nE(e,r))return!0;return!1}}return nE(e,Qp)}});var pn=y(()=>{});var Pd,ni,vo,$a=y(()=>{"use strict";h();Pd=class extends Error{constructor(t="Couldn't export canvas.",r="CANVAS_ERROR"){super(),this.name=r,this.message=t}},ni=class extends DOMException{constructor(t="Request Aborted"){super(t,"AbortError")}},vo=class extends Error{code;constructor(t="Image Scene Data Error",r="IMAGE_SCENE_DATA_ERROR"){super(t),this.name="EncodingError",this.code=r}}});import eg,{useEffect as d4,useRef as aE,useState as m4}from"react";import lE from"clsx";import{jsx as Is,jsxs as Ss}from"react/jsx-runtime";var ne,Lt=y(()=>{"use strict";h();pn();be();$a();Wn();ne=eg.forwardRef((e,t)=>{let{id:r}=Nt(),o=eg.useRef(null);eg.useImperativeHandle(t,()=>o.current);let n=`ToolIcon_size_${e.size}`,[i,a]=m4(!1),l=aE(!0),c=async d=>{let m="onClick"in e&&e.onClick?.(d);if(m&&"then"in m)try{a(!0),await m}catch(u){if(u instanceof ni)console.warn(u);else throw u}finally{l.current&&a(!1)}};d4(()=>(l.current=!0,()=>{l.current=!1}),[]);let s=aE(null);if(e.type==="button"||e.type==="icon"||e.type==="submit"){let d=e.type==="icon"?"button":e.type;return Ss("button",{className:lE("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:c,ref:o,disabled:i||e.isLoading,children:[(e.icon||e.label)&&Ss("div",{className:"ToolIcon__icon","aria-hidden":"true",children:[e.icon||e.label,e.keyBindingLabel&&Is("span",{className:"ToolIcon__keybinding",children:e.keyBindingLabel}),e.isLoading&&Is(tr,{})]}),e.showAriaLabel&&Ss("div",{className:"ToolIcon__label",children:[e["aria-label"]," ",i&&Is(tr,{})]}),e.children]})}return Ss("label",{className:lE("ToolIcon",e.className),title:e.title,onPointerDown:d=>{s.current=d.pointerType||null,e.onPointerDown?.({pointerType:d.pointerType||null})},onPointerUp:()=>{requestAnimationFrame(()=>{s.current=null})},children:[Is("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:s.current})},checked:e.checked,ref:o}),Ss("div",{className:"ToolIcon__icon",children:[e.icon,e.keyBindingLabel&&Is("span",{className:"ToolIcon__keybinding",children:e.keyBindingLabel})]})]})});ne.defaultProps={visible:!0,className:"",size:"medium"};ne.displayName="ToolButton"});import fr from"react";import u4 from"open-color";import p4 from"clsx";import{Fragment as Le,jsx as x,jsxs as F}from"react/jsx-runtime";var To,sE,L,he,ie,yN,cE,dE,mE,uE,pE,gE,hE,fE,bE,wN,xE,EE,yE,wE,vE,TE,IE,Xa,SE,CE,kE,AE,ME,ii,LE,_E,PE,DE,Dd,Rd,Za,Nd,RE,NE,BE,OE,Bd,FE,HE,ja,vN,zE,GE,UE,TN,IN,WE,SN,VE,YE,KE,CN,kN,AN,MN,$E,XE,ZE,jE,qE,JE,QE,e0,t0,r0,o0,n0,qa,LN,_N,Jr,i0,PN,DN,RN,a0,l0,s0,c0,d0,m0,tg,u0,p0,NN,g0,h0,f0,b0,x0,E0,y0,w0,v0,rg,T0,I0,S0,C0,k0,A0,M0,L0,_0,P0,D0,R0,N0,B0,O0,F0,H0,z0,G0,BN,U0,og,Od,W0,ON,FN,HN,V0,Y0,K0,$0,X0,Ja,Fd,Qa,Cs,Z0,Hd,j0,q0,J0,se=y(()=>{"use strict";h();X();To=e=>"var(--icon-fill-color)",sE=e=>e===nt.LIGHT?u4.white:"#1e1e1e",L=(e,t=512)=>{let{width:r=512,height:o=r,mirror:n,style:i,...a}=typeof t=="number"?{width:t}:t;return x("svg",{"aria-hidden":"true",focusable:"false",role:"img",viewBox:`0 0 ${r} ${o}`,className:p4({"rtl-mirror":n}),style:i,...a,children:typeof e=="string"?x("path",{fill:"currentColor",d:e}):e})},he={width:24,height:24,fill:"none",strokeWidth:2,stroke:"currentColor",strokeLinecap:"round",strokeLinejoin:"round"},ie={width:20,height:20,fill:"none",stroke:"currentColor",strokeLinecap:"round",strokeLinejoin:"round"},yN=L(F("g",{strokeWidth:"1.5",children:[x("path",{stroke:"none",d:"M0 0h24v24H0z",fill:"none"}),x("rect",{x:3,y:8,width:18,height:4,rx:1}),x("line",{x1:12,y1:8,x2:12,y2:21}),x("path",{d:"M19 12v7a2 2 0 0 1 -2 2h-10a2 2 0 0 1 -2 -2v-7"}),x("path",{d:"M7.5 8a2.5 2.5 0 0 1 0 -5a4.8 8 0 0 1 4.5 5a4.8 8 0 0 1 4.5 -5a2.5 2.5 0 0 1 0 5"})]}),he),cE=L(F("g",{strokeWidth:"1.5",children:[x("path",{stroke:"none",d:"M0 0h24v24H0z",fill:"none"}),x("path",{d:"M3 19a9 9 0 0 1 9 0a9 9 0 0 1 9 0"}),x("path",{d:"M3 6a9 9 0 0 1 9 0a9 9 0 0 1 9 0"}),x("line",{x1:"3",y1:"6",x2:"3",y2:"19"}),x("line",{x1:"12",y1:"6",x2:"12",y2:"19"}),x("line",{x1:"21",y1:"6",x2:"21",y2:"19"})]}),he),dE=L(F("svg",{strokeWidth:"1.5",children:[x("path",{stroke:"none",d:"M0 0h24v24H0z",fill:"none"}),x("line",{x1:"12",y1:"5",x2:"12",y2:"19"}),x("line",{x1:"5",y1:"12",x2:"19",y2:"12"})]}),he),mE=L(F("g",{strokeWidth:"1.5",children:[x("path",{stroke:"none",d:"M0 0h24v24H0z",fill:"none"}),x("circle",{cx:"12",cy:"12",r:"1"}),x("circle",{cx:"12",cy:"19",r:"1"}),x("circle",{cx:"12",cy:"5",r:"1"})]}),he),uE=L(F("svg",{strokeWidth:"1.5",children:[x("path",{stroke:"none",d:"M0 0h24v24H0z",fill:"none"}),x("path",{d:"M9 4v6l-2 4v2h10v-2l-2 -4v-6"}),x("line",{x1:"12",y1:"16",x2:"12",y2:"21"}),x("line",{x1:"8",y1:"4",x2:"16",y2:"4"})]}),he),pE=L(F("g",{children:[x("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"}),x("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"}),x("mask",{id:"UnlockedIcon",style:{maskType:"alpha"},maskUnits:"userSpaceOnUse",x:6,y:1,width:9,height:9,children:x("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"})}),x("g",{mask:"url(#UnlockedIcon)",children:x("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"})})]}),ie),gE=L(F("g",{strokeWidth:"1.25",children:[x("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"}),x("path",{d:"M10 13.958a1.042 1.042 0 1 0 0-2.083 1.042 1.042 0 0 0 0 2.083Z"}),x("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"})]}),ie),hE=L(F(Le,{children:[x("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"}),x("path",{fillRule:"evenodd",clipRule:"evenodd",d:"m12.005 10.478 7.905 14.423L6 25.75l6.005-15.273Z",fill:"currentColor"}),x("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"}),fE=L(F(Le,{children:[x("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"}),x("path",{fillRule:"evenodd",clipRule:"evenodd",d:"m72.181 59.247-13.058-10-2.948 13.62 16.006-3.62Z",fill:"currentColor"}),x("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"}),bE=L(F(Le,{children:[x("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"}),x("path",{fillRule:"evenodd",clipRule:"evenodd",d:"m24.165 1.093-2.132 16.309 13.27-4.258-11.138-12.05Z",fill:"currentColor"}),x("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"}),wN=L(x("g",{fill:"currentColor",children:x("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"}),xE=L(F("g",{stroke:"currentColor",strokeLinecap:"round",strokeLinejoin:"round",children:[x("path",{stroke:"none",d:"M0 0h24v24H0z",fill:"none"}),x("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"}),x("path",{d:"M13.5 13.5l4.5 4.5"})]}),{fill:"none",width:22,height:22,strokeWidth:1.25}),EE=L(F("g",{strokeWidth:"1.5",children:[x("path",{stroke:"none",d:"M0 0h24v24H0z",fill:"none"}),x("rect",{x:"4",y:"4",width:"16",height:"16",rx:"2"})]}),he),yE=L(F("g",{strokeWidth:"1.5",children:[x("path",{stroke:"none",d:"M0 0h24v24H0z",fill:"none"}),x("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"})]}),he),wE=L(F("g",{strokeWidth:"1.5",children:[x("path",{stroke:"none",d:"M0 0h24v24H0z",fill:"none"}),x("circle",{cx:"12",cy:"12",r:"9"})]}),he),vE=L(F("g",{strokeWidth:"1.5",children:[x("path",{stroke:"none",d:"M0 0h24v24H0z",fill:"none"}),x("line",{x1:"5",y1:"12",x2:"19",y2:"12"}),x("line",{x1:"15",y1:"16",x2:"19",y2:"12"}),x("line",{x1:"15",y1:"8",x2:"19",y2:"12"})]}),he),TE=L(x("path",{d:"M4.167 10h11.666",strokeWidth:"1.5"}),ie),IE=L(F("g",{strokeWidth:"1.25",children:[x("path",{stroke:"none",d:"M0 0h24v24H0z",fill:"none"}),x("path",{d:"M20 17v-12c0 -1.121 -.879 -2 -2 -2s-2 .879 -2 2v12l2 2l2 -2z"}),x("path",{d:"M16 7h4"}),x("path",{d:"M18 19h-13a2 2 0 1 1 0 -4h4a2 2 0 1 0 0 -4h-3"})]}),he),Xa=L(F("g",{strokeWidth:"1.25",children:[x("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"}),x("path",{d:"m11.25 5.417 3.333 3.333"})]}),ie),SE=L(F("g",{strokeWidth:"1.5",children:[x("path",{stroke:"none",d:"M0 0h24v24H0z",fill:"none"}),x("line",{x1:"4",y1:"20",x2:"7",y2:"20"}),x("line",{x1:"14",y1:"20",x2:"21",y2:"20"}),x("line",{x1:"6.9",y1:"15",x2:"13.8",y2:"15"}),x("line",{x1:"10.2",y1:"6.3",x2:"16",y2:"20"}),x("polyline",{points:"5 20 11 4 13 4 20 20"})]}),he),CE=L(F("g",{strokeWidth:"1.25",children:[x("path",{d:"M12.5 6.667h.01"}),x("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"}),x("path",{d:"m3.333 12.5 3.334-3.333c.773-.745 1.726-.745 2.5 0l4.166 4.166"}),x("path",{d:"m11.667 11.667.833-.834c.774-.744 1.726-.744 2.5 0l1.667 1.667"})]}),ie),kE=L(F("g",{strokeWidth:"1.5",children:[x("path",{stroke:"none",d:"M0 0h24v24H0z",fill:"none"}),x("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"}),x("path",{d:"M18 13.3l-6.3 -6.3"})]}),he),AE=L(x("path",{strokeWidth:"1.25",d:"M10 4.167v11.666M4.167 10h11.666"}),ie),ME=L(x("path",{d:"M5 10h10",strokeWidth:"1.25"}),ie),ii=L(x("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"}),ie),LE=L(F("g",{strokeWidth:"1.25",children:[x("polyline",{points:"12 16 18 10 12 4"}),x("polyline",{points:"8 4 2 10 8 16"})]}),ie),_E=L(F("g",{strokeWidth:"1.25",children:[x("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"}),x("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"})]}),ie),PE=L(x("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"}),ie),DE=L(x("g",{stroke:"currentColor",strokeWidth:"1.25",strokeLinecap:"round",strokeLinejoin:"round",children:x("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"})}),ie),Dd=L(F("g",{strokeWidth:"1.5",children:[x("path",{stroke:"none",d:"M0 0h24v24H0z",fill:"none"}),x("line",{x1:"4",y1:"6",x2:"20",y2:"6"}),x("line",{x1:"4",y1:"12",x2:"20",y2:"12"}),x("line",{x1:"4",y1:"18",x2:"20",y2:"18"})]}),he),Rd=L(x("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"}),ie),Za=L(F("g",{strokeWidth:"1.5",children:[x("path",{stroke:"none",d:"M0 0h24v24H0z",fill:"none"}),x("circle",{cx:"12",cy:"12",r:"9"}),x("line",{x1:"12",y1:"17",x2:"12",y2:"17.01"}),x("path",{d:"M12 13.5a1.5 1.5 0 0 1 1 -1.5a2.6 2.6 0 1 0 -3 -4"})]}),he),Nd=L(x("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"}),ie),RE=L(x("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"}),ie),NE=L(F("g",{strokeWidth:"1.25",children:[x("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"}),x("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"})]}),ie),BE=L(F("g",{strokeWidth:"1.25",children:[x("path",{stroke:"none",d:"M0 0h24v24H0z",fill:"none"}),x("path",{d:"M22 4.01c-1 .49 -1.98 .689 -3 .99c-1.121 -1.265 -2.783 -1.335 -4.38 -.737s-2.643 2.06 -2.62 3.737v1c-3.245 .083 -6.135 -1.395 -8 -4c0 0 -4.182 7.433 4 11c-1.872 1.247 -3.739 2.088 -6 2c3.308 1.803 6.913 2.423 10.034 1.517c3.58 -1.04 6.522 -3.723 7.651 -7.742a13.84 13.84 0 0 0 .497 -3.753c-.002 -.249 1.51 -2.772 1.818 -4.013z"})]}),he),OE=L(x("polyline",{fill:"none",stroke:"currentColor",points:"20 6 9 17 4 12"}),{width:24,height:24}),Bd=L(F("g",{strokeWidth:"1.25",children:[x("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"}),x("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"})]}),ie),FE=L("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}),HE=L("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}),ja=L(x("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"}),ie),vN=L("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}),zE=L("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"),GE=L(F("g",{strokeWidth:"1.25",children:[x("path",{stroke:"none",d:"M0 0h24v24H0z",fill:"none"}),x("path",{d:"M15 8h.01"}),x("path",{d:"M12 20h-5a3 3 0 0 1 -3 -3v-10a3 3 0 0 1 3 -3h10a3 3 0 0 1 3 3v5"}),x("path",{d:"M4 15l4 -4c.928 -.893 2.072 -.893 3 0l4 4"}),x("path",{d:"M14 14l1 -1c.617 -.593 1.328 -.793 2.009 -.598"}),x("path",{d:"M19 16v6"}),x("path",{d:"M22 19l-3 3l-3 -3"})]}),he),UE=L("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}),TN=L("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}),IN=L("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}),WE=L("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"),SN=L("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"),VE=L(x("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"}),ie),YE=L(x("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"}),ie),KE=L("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}),CN=L(x("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"}),ie),kN=L("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}),AN=L(F(Le,{children:[x("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"}),x("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}),MN=L(x("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}),$E=L(F(Le,{children:[F("g",{clipPath:"url(#a)",stroke:"currentColor",strokeWidth:"1.25",strokeLinecap:"round",strokeLinejoin:"round",children:[x("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"}),x("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"})]}),x("defs",{children:x("clipPath",{id:"a",children:x("path",{fill:"#fff",d:"M0 0h20v20H0z"})})})]}),ie),XE=L(F(Le,{children:[F("g",{clipPath:"url(#a)",stroke:"currentColor",strokeWidth:"1.25",strokeLinecap:"round",strokeLinejoin:"round",children:[x("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"}),x("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"})]}),x("defs",{children:x("clipPath",{id:"a",children:x("path",{fill:"#fff",d:"M0 0h20v20H0z"})})})]}),ie),ZE=L(F(Le,{children:[F("g",{clipPath:"url(#a)",stroke:"currentColor",strokeWidth:"1.25",children:[x("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"}),x("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"})]}),x("defs",{children:x("clipPath",{id:"a",children:x("path",{fill:"#fff",d:"M0 0h20v20H0z"})})})]}),ie),jE=L(F(Le,{children:[F("g",{clipPath:"url(#a)",children:[x("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"}),x("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"}),x("mask",{id:"SendToBackIcon",fill:"#fff",children:x("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"})}),x("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"}),x("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)"}),x("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"})]}),x("defs",{children:x("clipPath",{id:"a",children:x("path",{fill:"#fff",d:"M0 0h20v20H0z"})})})]}),ie),qE=L(F(Le,{children:[F("g",{clipPath:"url(#a)",stroke:"currentColor",strokeWidth:"1.25",children:[x("path",{d:"M3.333 3.333h13.334",strokeLinecap:"round",strokeLinejoin:"round"}),x("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"})]}),x("defs",{children:x("clipPath",{id:"a",children:x("path",{fill:"#fff",d:"M0 0h20v20H0z"})})})]}),ie),JE=L(F(Le,{children:[F("g",{clipPath:"url(#a)",stroke:"currentColor",strokeWidth:"1.25",children:[x("path",{d:"M3.333 16.667h13.334",strokeLinecap:"round",strokeLinejoin:"round"}),x("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"})]}),x("defs",{children:x("clipPath",{id:"a",children:x("path",{fill:"#fff",d:"M0 0h20v20H0z"})})})]}),ie),QE=L(F(Le,{children:[F("g",{clipPath:"url(#a)",stroke:"currentColor",strokeWidth:"1.25",children:[x("path",{d:"M3.333 3.333v13.334",strokeLinecap:"round",strokeLinejoin:"round"}),x("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"})]}),x("defs",{children:x("clipPath",{id:"a",children:x("path",{fill:"#fff",d:"M0 0h20v20H0z"})})})]}),ie),e0=L(F(Le,{children:[F("g",{clipPath:"url(#a)",stroke:"currentColor",strokeWidth:"1.25",children:[x("path",{d:"M16.667 3.333v13.334",strokeLinecap:"round",strokeLinejoin:"round"}),x("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"})]}),x("defs",{children:x("clipPath",{id:"a",children:x("path",{fill:"#fff",d:"M0 0h20v20H0z"})})})]}),ie),t0=L(F(Le,{children:[F("g",{clipPath:"url(#a)",stroke:"currentColor",strokeWidth:"1.25",children:[x("path",{d:"M16.667 3.333v13.334M3.333 3.333v13.334",strokeLinecap:"round",strokeLinejoin:"round"}),x("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"})]}),x("defs",{children:x("clipPath",{id:"a",children:x("path",{fill:"#fff",d:"M0 0h20v20H0z"})})})]}),ie),r0=L(F(Le,{children:[F("g",{clipPath:"url(#a)",stroke:"currentColor",strokeWidth:"1.25",children:[x("path",{d:"M3.333 3.333h13.334M3.333 16.667h13.334",strokeLinecap:"round",strokeLinejoin:"round"}),x("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"})]}),x("defs",{children:x("clipPath",{id:"a",children:x("path",{fill:"#fff",d:"M0 0h20v20H0z"})})})]}),ie),o0=L(F("g",{stroke:"currentColor",strokeWidth:"1.25",children:[x("path",{d:"M1.667 10h2.916",strokeLinecap:"round",strokeLinejoin:"round"}),x("path",{d:"M8.333 10h3.334",strokeLinejoin:"round"}),x("path",{d:"M15.417 10h2.916",strokeLinecap:"round",strokeLinejoin:"round"}),x("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"})]}),ie),n0=L(F("g",{stroke:"currentColor",strokeWidth:"1.25",children:[x("path",{d:"M10 18.333v-2.916",strokeLinecap:"round",strokeLinejoin:"round"}),x("path",{d:"M10 11.667V8.333",strokeLinejoin:"round"}),x("path",{d:"M10 4.583V1.667",strokeLinecap:"round",strokeLinejoin:"round"}),x("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"})]}),ie),qa=L(F("g",{strokeWidth:"1.5",children:[x("path",{stroke:"none",d:"M0 0h24v24H0z",fill:"none"}),x("circle",{cx:"9",cy:"7",r:"4"}),x("path",{d:"M3 21v-2a4 4 0 0 1 4 -4h4a4 4 0 0 1 4 4v2"}),x("path",{d:"M16 3.13a4 4 0 0 1 0 7.75"}),x("path",{d:"M21 21v-2a4 4 0 0 0 -3 -3.85"})]}),he),LN=L("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"),_N=L("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"),Jr=L(F(Le,{children:[x("g",{clipPath:"url(#a)",stroke:"currentColor",strokeWidth:"1.25",strokeLinecap:"round",strokeLinejoin:"round",children:x("path",{d:"M15 5 5 15M5 5l10 10"})}),x("defs",{children:x("clipPath",{id:"a",children:x("path",{fill:"#fff",d:"M0 0h20v20H0z"})})})]}),ie),i0=L("M34.52 239.03L228.87 44.69c9.37-9.37 24.57-9.37 33.94 0l22.67 22.67c9.36 9.36 9.37 24.52.04 33.9L131.49 256l154.02 154.75c9.34 9.38 9.32 24.54-.04 33.9l-22.67 22.67c-9.37 9.37-24.57 9.37-33.94 0L34.52 272.97c-9.37-9.37-9.37-24.57 0-33.94z",{width:320,height:512,style:{marginLeft:"-0.2rem"},mirror:!0}),PN=L("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}),DN=L("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}),RN=L("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}),a0=fr.memo(({theme:e})=>L(F(Le,{children:[x("path",{d:"M25 26H111V111H25",fill:To(e)}),x("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:To(e),strokeWidth:"2"}),x("path",{d:"M100 100H160V160H100",fill:To(e)}),x("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:To(e),strokeWidth:"2"}),F("g",{fill:sE(e),stroke:To(e),strokeWidth:"6",children:[x("rect",{x:"2.5",y:"2.5",width:"30",height:"30"}),x("rect",{x:"2.5",y:"149.5",width:"30",height:"30"}),x("rect",{x:"147.5",y:"149.5",width:"30",height:"30"}),x("rect",{x:"147.5",y:"2.5",width:"30",height:"30"})]})]}),{width:182,height:182,mirror:!0})),l0=fr.memo(({theme:e})=>L(F(Le,{children:[x("path",{d:"M25 26H111V111H25",fill:To(e)}),x("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:To(e),strokeWidth:"2"}),x("path",{d:"M100 100H160V160H100",fill:To(e)}),x("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:To(e),strokeWidth:"2"}),F("g",{fill:sE(e),stroke:To(e),strokeWidth:"6",children:[x("rect",{x:"2.5",y:"2.5",width:"30",height:"30"}),x("rect",{x:"78.5",y:"149.5",width:"30",height:"30"}),x("rect",{x:"147.5",y:"149.5",width:"30",height:"30"}),x("rect",{x:"147.5",y:"78.5",width:"30",height:"30"}),x("rect",{x:"105.5",y:"2.5",width:"30",height:"30"}),x("rect",{x:"2.5",y:"102.5",width:"30",height:"30"})]})]}),{width:182,height:182,mirror:!0})),s0=L(x("g",{strokeWidth:1.25,children:x("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"})}),ie),c0=L(F(Le,{children:[x("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"}),x("mask",{id:"FillHachureIcon",style:{maskType:"alpha"},maskUnits:"userSpaceOnUse",x:2,y:2,width:16,height:16,children:x("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"})}),x("g",{mask:"url(#FillHachureIcon)",children:x("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"})})]}),ie),d0=L(F(Le,{children:[F("g",{clipPath:"url(#a)",children:[x("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"}),x("mask",{id:"FillCrossHatchIcon",style:{maskType:"alpha"},maskUnits:"userSpaceOnUse",x:-1,y:-1,width:22,height:22,children:x("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"})}),x("g",{mask:"url(#FillCrossHatchIcon)",children:x("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"})})]}),x("defs",{children:x("clipPath",{id:"a",children:x("path",{fill:"#fff",d:"M0 0h20v20H0z"})})})]}),ie),m0=L(F(Le,{children:[x("g",{clipPath:"url(#a)",children:x("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"})}),x("defs",{children:x("clipPath",{id:"a",children:x("path",{fill:"#fff",d:"M0 0h20v20H0z"})})})]}),{...ie,fill:"currentColor"}),tg=L(x(Le,{children:x("path",{d:"M4.167 10h11.666",stroke:"currentColor",strokeWidth:"1.25",strokeLinecap:"round",strokeLinejoin:"round"})}),ie),u0=L(x("path",{d:"M5 10h10",stroke:"currentColor",strokeWidth:"2.5",strokeLinecap:"round",strokeLinejoin:"round"}),ie),p0=L(x("path",{d:"M5 10h10",stroke:"currentColor",strokeWidth:"3.75",strokeLinecap:"round",strokeLinejoin:"round"}),ie),NN=fr.memo(({theme:e})=>L(x("path",{d:"M6 10H34",stroke:To(e),strokeWidth:2,fill:"none",strokeLinecap:"round"}),{width:40,height:20})),g0=L(F("g",{strokeWidth:"2",children:[x("path",{stroke:"none",d:"M0 0h24v24H0z",fill:"none"}),x("path",{d:"M5 12h2"}),x("path",{d:"M17 12h2"}),x("path",{d:"M11 12h2"})]}),he),h0=L(F("g",{strokeWidth:"2",children:[x("path",{stroke:"none",d:"M0 0h24v24H0z",fill:"none"}),x("path",{d:"M4 12v.01"}),x("path",{d:"M8 12v.01"}),x("path",{d:"M12 12v.01"}),x("path",{d:"M16 12v.01"}),x("path",{d:"M20 12v.01"})]}),he),f0=L(x("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"}),ie),b0=L(x("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"}),ie),x0=L(x("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"}),ie),E0=L(F("svg",{strokeWidth:"1.5",children:[x("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"}),x("path",{d:"M13.3333 3.33331V3.34331"}),x("path",{d:"M16.6667 3.33331V3.34331"}),x("path",{d:"M16.6667 6.66669V6.67669"}),x("path",{d:"M16.6667 10V10.01"}),x("path",{d:"M3.33334 13.3333V13.3433"}),x("path",{d:"M16.6667 13.3333V13.3433"}),x("path",{d:"M3.33334 16.6667V16.6767"}),x("path",{d:"M6.66666 16.6667V16.6767"}),x("path",{d:"M10 16.6667V16.6767"}),x("path",{d:"M13.3333 16.6667V16.6767"}),x("path",{d:"M16.6667 16.6667V16.6767"})]}),ie),y0=L(F("g",{strokeWidth:"1.5",stroke:"currentColor",strokeLinecap:"round",strokeLinejoin:"round",children:[x("path",{stroke:"none",d:"M0 0h24v24H0z",fill:"none"}),x("path",{d:"M4 12v-4a4 4 0 0 1 4 -4h4"}),x("line",{x1:"16",y1:"4",x2:"16",y2:"4.01"}),x("line",{x1:"20",y1:"4",x2:"20",y2:"4.01"}),x("line",{x1:"20",y1:"8",x2:"20",y2:"8.01"}),x("line",{x1:"20",y1:"12",x2:"20",y2:"12.01"}),x("line",{x1:"4",y1:"16",x2:"4",y2:"16.01"}),x("line",{x1:"20",y1:"16",x2:"20",y2:"16.01"}),x("line",{x1:"4",y1:"20",x2:"4",y2:"20.01"}),x("line",{x1:"8",y1:"20",x2:"8",y2:"20.01"}),x("line",{x1:"12",y1:"20",x2:"12",y2:"20.01"}),x("line",{x1:"16",y1:"20",x2:"16",y2:"20.01"}),x("line",{x1:"20",y1:"20",x2:"20",y2:"20.01"})]}),he),w0=L(x("path",{d:"M6 10H34",stroke:"currentColor",strokeWidth:2,fill:"none"}),{width:40,height:20}),v0=fr.memo(({flip:e=!1})=>L(F("g",{transform:e?"translate(40, 0) scale(-1, 1)":"",stroke:"currentColor",strokeWidth:2,fill:"none",children:[x("path",{d:"M34 10H6M34 10L27 5M34 10L27 15"}),x("path",{d:"M27.5 5L34.5 10L27.5 15"})]}),{width:40,height:20})),rg=fr.memo(({flip:e=!1})=>L(F("g",{stroke:"currentColor",fill:"currentColor",transform:e?"translate(40, 0) scale(-1, 1)":"",children:[x("path",{d:"M32 10L6 10",strokeWidth:2}),x("circle",{r:"4",transform:"matrix(-1 0 0 1 30 10)"})]}),{width:40,height:20})),T0=fr.memo(({flip:e=!1})=>L(F("g",{stroke:"currentColor",fill:"none",transform:e?"translate(40, 0) scale(-1, 1)":"",strokeWidth:2,children:[x("path",{d:"M26 10L6 10"}),x("circle",{r:"4",transform:"matrix(-1 0 0 1 30 10)"})]}),{width:40,height:20})),I0=fr.memo(({flip:e=!1})=>L(x("g",{transform:e?"translate(40, 0) scale(-1, 1)":"",children:x("path",{d:"M34 10H5.99996M34 10L34 5M34 10L34 15",stroke:"currentColor",strokeWidth:2,fill:"none"})}),{width:40,height:20})),S0=fr.memo(({flip:e=!1})=>L(F("g",{stroke:"currentColor",fill:"currentColor",transform:e?"translate(40, 0) scale(-1, 1)":"",children:[x("path",{d:"M32 10L6 10",strokeWidth:2}),x("path",{d:"M27.5 5.5L34.5 10L27.5 14.5L27.5 5.5"})]}),{width:40,height:20})),C0=fr.memo(({flip:e=!1})=>L(F("g",{stroke:"currentColor",fill:"none",transform:e?"translate(40, 0) scale(-1, 1)":"",strokeWidth:2,strokeLinejoin:"round",children:[x("path",{d:"M6,9.5H27"}),x("path",{d:"M27,5L34,10L27,14Z",fill:"none"})]}),{width:40,height:20})),k0=fr.memo(({flip:e=!1})=>L(F("g",{stroke:"currentColor",fill:"currentColor",transform:e?"translate(40, 0) scale(-1, 1)":"",strokeLinejoin:"round",strokeWidth:2,children:[x("path",{d:"M6,9.5H20"}),x("path",{d:"M27,5L34,10L27,14L20,9.5Z"})]}),{width:40,height:20})),A0=fr.memo(({flip:e=!1})=>L(F("g",{stroke:"currentColor",fill:"none",transform:e?"translate(40, 0) scale(-1, 1)":"",strokeLinejoin:"round",strokeWidth:2,children:[x("path",{d:"M6,9.5H20"}),x("path",{d:"M27,5L34,10L27,14L20,9.5Z"})]}),{width:40,height:20})),M0=L(F(Le,{children:[x("g",{clipPath:"url(#a)",children:x("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"})}),x("defs",{children:x("clipPath",{id:"a",children:x("path",{fill:"#fff",d:"M0 0h20v20H0z"})})})]}),ie),L0=L(F(Le,{children:[x("g",{clipPath:"url(#a)",children:x("path",{d:"M5 16.667V3.333L10 15l5-11.667v13.334",stroke:"currentColor",strokeWidth:"1.25",strokeLinecap:"round",strokeLinejoin:"round"})}),x("defs",{children:x("clipPath",{id:"a",children:x("path",{fill:"#fff",d:"M0 0h20v20H0z"})})})]}),ie),_0=L(F(Le,{children:[x("g",{clipPath:"url(#a)",children:x("path",{d:"M5.833 3.333v13.334h8.334",stroke:"currentColor",strokeWidth:"1.25",strokeLinecap:"round",strokeLinejoin:"round"})}),x("defs",{children:x("clipPath",{id:"a",children:x("path",{fill:"#fff",d:"M0 0h20v20H0z"})})})]}),ie),P0=L(x(Le,{children:x("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"})}),ie),D0=L(x(Le,{children:x("g",{stroke:"currentColor",strokeWidth:"1.25",strokeLinecap:"round",strokeLinejoin:"round",children:x("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"})})}),ie),R0=L(F(Le,{children:[x("g",{clipPath:"url(#a)",stroke:"currentColor",strokeWidth:"1.25",strokeLinecap:"round",strokeLinejoin:"round",children:x("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"})}),x("defs",{children:x("clipPath",{id:"a",children:x("path",{fill:"#fff",d:"M0 0h20v20H0z"})})})]}),ie),N0=L(F("g",{stroke:"currentColor",fill:"none",strokeLinecap:"round",strokeLinejoin:"round",strokeWidth:2,children:[x("path",{stroke:"none",d:"M0 0h24v24H0z",fill:"none"}),x("line",{x1:"4",y1:"8",x2:"20",y2:"8"}),x("line",{x1:"4",y1:"12",x2:"12",y2:"12"}),x("line",{x1:"4",y1:"16",x2:"16",y2:"16"})]}),he),B0=L(F("g",{stroke:"currentColor",fill:"none",strokeLinecap:"round",strokeLinejoin:"round",children:[x("path",{stroke:"none",d:"M0 0h24v24H0z",fill:"none"}),x("line",{x1:"4",y1:"8",x2:"20",y2:"8"}),x("line",{x1:"8",y1:"12",x2:"16",y2:"12"}),x("line",{x1:"6",y1:"16",x2:"18",y2:"16"})]}),he),O0=L(F("g",{stroke:"currentColor",fill:"none",strokeLinecap:"round",strokeLinejoin:"round",children:[x("path",{stroke:"none",d:"M0 0h24v24H0z",fill:"none"}),x("line",{x1:"4",y1:"8",x2:"20",y2:"8"}),x("line",{x1:"10",y1:"12",x2:"20",y2:"12"}),x("line",{x1:"8",y1:"16",x2:"20",y2:"16"})]}),he),F0=fr.memo(({theme:e})=>L(F("g",{strokeWidth:"1.5",stroke:"currentColor",fill:"none",strokeLinecap:"round",strokeLinejoin:"round",children:[x("path",{stroke:"none",d:"M0 0h24v24H0z",fill:"none"}),x("line",{x1:"4",y1:"4",x2:"20",y2:"4"}),x("rect",{x:"9",y:"8",width:"6",height:"12",rx:"2"})]}),he)),H0=fr.memo(({theme:e})=>L(F("g",{strokeWidth:"2",stroke:"currentColor",fill:"none",strokeLinecap:"round",strokeLinejoin:"round",children:[x("path",{stroke:"none",d:"M0 0h24v24H0z",fill:"none"}),x("line",{x1:"4",y1:"20",x2:"20",y2:"20"}),x("rect",{x:"9",y:"4",width:"6",height:"12",rx:"2"})]}),he)),z0=fr.memo(({theme:e})=>L(F("g",{strokeWidth:"1.5",stroke:"currentColor",fill:"none",strokeLinecap:"round",strokeLinejoin:"round",children:[x("path",{stroke:"none",d:"M0 0h24v24H0z",fill:"none"}),x("line",{x1:"4",y1:"12",x2:"9",y2:"12"}),x("line",{x1:"15",y1:"12",x2:"20",y2:"12"}),x("rect",{x:"9",y:"6",width:"6",height:"12",rx:"2"})]}),he)),G0=L(x("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}),BN=L(x("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"})),U0=L(F("g",{strokeWidth:1.25,children:[x("path",{stroke:"none",d:"M0 0h24v24H0z",fill:"none"}),x("path",{d:"M8 13v-7.5a1.5 1.5 0 0 1 3 0v6.5"}),x("path",{d:"M11 5.5v-2a1.5 1.5 0 1 1 3 0v8.5"}),x("path",{d:"M14 5.5a1.5 1.5 0 0 1 3 0v6.5"}),x("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"})]}),he),og=L(F(Le,{children:[x("path",{stroke:"none",d:"M0 0h24v24H0z",fill:"none"}),x("path",{d:"M4 17v2a2 2 0 0 0 2 2h12a2 2 0 0 0 2 -2v-2"}),x("path",{d:"M7 11l5 5l5 -5"}),x("path",{d:"M12 4l0 12"})]}),he),Od=L(F(Le,{children:[x("path",{stroke:"none",d:"M0 0h24v24H0z",fill:"none"}),x("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"}),x("path",{d:"M16 8v-2a2 2 0 0 0 -2 -2h-8a2 2 0 0 0 -2 2v8a2 2 0 0 0 2 2h2"})]}),he),W0=L(F(Le,{children:[x("path",{stroke:"none",d:"M0 0h24v24H0z",fill:"none"}),x("path",{d:"M12 12m-9 0a9 9 0 1 0 18 0a9 9 0 1 0 -18 0"}),x("path",{d:"M12 17l0 .01"}),x("path",{d:"M12 13.5a1.5 1.5 0 0 1 1 -1.5a2.6 2.6 0 1 0 -3 -4"})]}),he),ON=L(F(Le,{children:[x("path",{stroke:"none",d:"M0 0h24v24H0z",fill:"none"}),x("path",{d:"M7 4v16l13 -8z"})]}),he),FN=L(F(Le,{children:[x("path",{stroke:"none",d:"M0 0h24v24H0z",fill:"none"}),x("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"})]}),he),HN=L(F(Le,{children:[x("path",{stroke:"none",d:"M0 0h24v24H0z",fill:"none"}),x("path",{d:"M5 12l5 5l10 -10"})]}),he),V0=L(F(Le,{children:[x("path",{stroke:"none",d:"M0 0h24v24H0z",fill:"none"}),x("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"}),x("path",{d:"M12 9v4"}),x("path",{d:"M12 17h.01"})]}),he),Y0=L(F("g",{strokeWidth:1.25,children:[x("path",{stroke:"none",d:"M0 0h24v24H0z",fill:"none"}),x("path",{d:"M11 7l6 6"}),x("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"})]}),he),K0=L(F("g",{strokeWidth:1.5,children:[x("path",{stroke:"none",d:"M0 0h24v24H0z",fill:"none"}),x("path",{d:"M12 3l-4 7h8z"}),x("path",{d:"M17 17m-3 0a3 3 0 1 0 6 0a3 3 0 1 0 -6 0"}),x("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"})]}),he),$0=L(F("g",{strokeWidth:1.5,children:[x("path",{stroke:"none",d:"M0 0h24v24H0z",fill:"none"}),x("path",{d:"M4 7l16 0"}),x("path",{d:"M4 17l16 0"}),x("path",{d:"M7 4l0 16"}),x("path",{d:"M17 4l0 16"})]}),he),X0=L(x("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"})),Ja=L(F("g",{strokeWidth:"1.25",children:[x("path",{d:"M4.16602 10H15.8327"}),x("path",{d:"M12.5 13.3333L15.8333 10"}),x("path",{d:"M12.5 6.66666L15.8333 9.99999"})]}),ie),Fd=L(F("g",{fill:"none",stroke:"currentColor",strokeWidth:"1.25",strokeLinecap:"round",strokeLinejoin:"round",transform:"rotate(90 10 10)",children:[x("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"}),x("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),Qa=L(F("g",{stroke:"currentColor",fill:"none",children:[x("path",{stroke:"none",d:"M0 0h24v24H0z"}),x("path",{d:"M6 21l15 -15l-3 -3l-15 15l3 3"}),x("path",{d:"M15 6l3 3"}),x("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"}),x("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"})]}),he),Cs=L(F("g",{stroke:"currentColor",fill:"none",children:[x("path",{stroke:"none",d:"M0 0h24v24H0z",fill:"none"}),x("path",{d:"M11.217 19.384a3.501 3.501 0 0 0 6.783 -1.217v-5.167l-6 -3.35"}),x("path",{d:"M5.214 15.014a3.501 3.501 0 0 0 4.446 5.266l4.34 -2.534v-6.946"}),x("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"}),x("path",{d:"M12.783 4.616a3.501 3.501 0 0 0 -6.783 1.217v5.067l6 3.45"}),x("path",{d:"M18.786 8.986a3.501 3.501 0 0 0 -4.446 -5.266l-4.34 2.534v6.946"}),x("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"})]}),he),Z0=L(F("g",{stroke:"currentColor",fill:"none",children:[x("path",{stroke:"none",d:"M0 0h24v24H0z",fill:"none"}),x("path",{d:"M4 8v-2a2 2 0 0 1 2 -2h2"}),x("path",{d:"M4 16v2a2 2 0 0 0 2 2h2"}),x("path",{d:"M16 4h2a2 2 0 0 1 2 2v2"}),x("path",{d:"M16 20h2a2 2 0 0 0 2 -2v-2"})]}),he),Hd=L(F("g",{stroke:"currentColor",fill:"none",children:[x("path",{stroke:"none",d:"M0 0h24v24H0z",fill:"none"}),x("path",{d:"M10 12a2 2 0 1 0 4 0a2 2 0 0 0 -4 0"}),x("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"})]}),he),j0=L(F("g",{stroke:"currentColor",fill:"none",children:[x("path",{stroke:"none",d:"M0 0h24v24H0z",fill:"none"}),x("path",{d:"M10.585 10.587a2 2 0 0 0 2.829 2.828"}),x("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"}),x("path",{d:"M3 3l18 18"})]}),he),q0=L(F("g",{stroke:"currentColor",fill:"none",children:[x("path",{stroke:"none",d:"M0 0h24v24H0z",fill:"none"}),x("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"}),x("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"}),x("path",{d:"M17.5 16a3.5 3.5 0 0 0 0 -7h-.5"}),x("path",{d:"M19 9.3v-2.8a3.5 3.5 0 0 0 -7 0"}),x("path",{d:"M6.5 16a3.5 3.5 0 0 1 0 -7h.5"}),x("path",{d:"M5 9.3v-2.8a3.5 3.5 0 0 1 7 0v10"})]}),he),J0=L(F("g",{strokeWidth:1.5,children:[x("path",{stroke:"none",d:"M0 0h24v24H0z",fill:"none"}),x("path",{d:"M10 10m-7 0a7 7 0 1 0 14 0a7 7 0 1 0 -14 0"}),x("path",{d:"M21 21l-6 -6"})]}),he)});var de,S,el,zd,tl,oa,me=y(()=>{"use strict";h();X();de={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"},S={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:rr?"metaKey":"ctrlKey",DELETE:"Delete",ENTER:"Enter",ESCAPE:"Escape",QUESTION_MARK:"?",SPACE:" ",TAB:"Tab",CHEVRON_LEFT:"<",CHEVRON_RIGHT:">",PERIOD:".",COMMA:",",SUBTRACT:"-",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"},el=e=>e===S.ARROW_LEFT||e===S.ARROW_RIGHT||e===S.ARROW_DOWN||e===S.ARROW_UP,zd=e=>e.altKey,tl=e=>e.shiftKey,oa=e=>e.shiftKey});var Q0=y(()=>{});import{useEffect as g4}from"react";import{jsx as f4}from"react/jsx-runtime";var rl,ng,h4,Rr,ai=y(()=>{"use strict";h();Q0();rl=()=>{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},ng=(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 c;r==="bottom"?(c=t.top+t.height+a,c+o.height>=i&&(c=t.top-o.height-a)):(c=t.top-o.height-a,c<0&&(c=t.top+t.height+a)),Object.assign(e.style,{top:`${c}px`,left:`${l}px`})},h4=(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();ng(t,n)},Rr=({children:e,label:t,long:r=!1,style:o,disabled:n})=>(g4(()=>()=>rl().classList.remove("excalidraw-tooltip--visible"),[]),n?null:f4("div",{className:"excalidraw-tooltip-wrapper",onPointerEnter:i=>h4(i.currentTarget,rl(),t,r),onPointerLeave:()=>rl().classList.remove("excalidraw-tooltip--visible"),style:o,children:e}))});import{sanitizeUrl as b4}from"@braintree/sanitize-url";var ir,Gd,Ud,ol=y(()=>{"use strict";h();ir=e=>(e=e.trim(),e&&b4(e)),Gd=e=>!!(e?.includes(location.origin)||e?.startsWith("/")),Ud=e=>{if(e=ir(e),e.startsWith("/"))return`${location.origin}${e}`;try{new URL(e)}catch{return"about:blank"}return e}});var ey=y(()=>{});var x4,Ee,Qr=y(()=>{"use strict";h();x4=["ai"],Ee=(e,t,r,o)=>{try{if(typeof window>"u"||I.VITE_WORKER_ID||I.PROD||!x4.includes(e))return;I.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{RoughGenerator as E4}from"roughjs/bin/generator";var Te,Io=y(()=>{"use strict";h();nl();ig();Yt();Te=class e{static rg=new E4;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;Wd.delete(t);let n=ty(t,e.rg,r||{isExporting:!1,canvasBackgroundColor:oe.white});return e.cache.set(t,n),n}}});import{useCallback as ry,useEffect as y4,useLayoutEffect as w4,useRef as v4,useState as T4}from"react";import I4 from"clsx";import{jsx as il,jsxs as ny}from"react/jsx-runtime";var sg,iy,ag,S4,C4,cg,lg,Vd,ay,ly,dg,oy,Yd,mg,Kd,ks,sy,k4,cy,A4,$d=y(()=>{"use strict";h();W();Ts();Ve();We();Lt();se();Y();me();nl();Zt();X();ai();Ze();na();ue();ol();ey();Qr();be();ae();Io();sg=320,iy=85,ag=5,S4=42,C4=500,cg=document.createElement("img");cg.src=`data:${Z.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>')}`;lg=!1,Vd=new Map,ay=({element:e,setAppState:t,onLinkOpen:r,setToast:o})=>{let n=al(),i=li(),a=e.link||"",[l,c]=T4(a),s=v4(null),d=n.showHyperlinkPopup==="editor",m=ry(()=>{if(!s.current)return;let E=ir(s.current.value)||null;if(!e.link&&E&&Ee("hyperlink","create"),At(e)){if(n.activeEmbeddable?.element===e&&t({activeEmbeddable:null}),!E){B(e,{validated:!1,link:null});return}if(!Ka(E,i.validateEmbeddable))E&&o({message:f("toast.unableToEmbed"),closable:!0}),e.link&&Vd.set(e.id,e.link),B(e,{validated:!1,link:E}),Te.delete(e);else{let{width:w,height:v}=e,T=un(E);T?.warning&&o({message:T.warning,closable:!0});let k=T?T.intrinsicSize.w/T.intrinsicSize.h:1,M=Vd.get(e.id)!==e.link;B(e,{...M?{width:T?.type==="video"?w>v?w:v*k:w,height:T?.type==="video"&&w>v?w/k:v}:{},validated:!0,link:E}),Te.delete(e),Vd.has(e.id)&&Vd.delete(e.id)}}else B(e,{link:E})},[e,o,i.validateEmbeddable,n.activeEmbeddable,t]);w4(()=>()=>{m()},[m]),y4(()=>{let E=null,w=v=>{if(d)return;E&&clearTimeout(E),A4(e,n,[v.clientX,v.clientY])&&(E=window.setTimeout(()=>{t({showHyperlinkPopup:!1})},C4))};return window.addEventListener("pointermove",w,!1),()=>{window.removeEventListener("pointermove",w,!1),E&&clearTimeout(E)}},[n,e,d,t]);let u=ry(()=>{Ee("hyperlink","delete"),B(e,{link:null}),d&&(s.current.value=""),t({showHyperlinkPopup:!1})},[t,e,d]),p=()=>{Ee("hyperlink","edit","popup-ui"),t({showHyperlinkPopup:"editor"})},{x:g,y:b}=ly(e,n);return n.contextMenu||n.draggingElement||n.resizingElement||n.isRotating||n.openMenu||n.viewModeEnabled?null:ny("div",{className:"excalidraw-hyperlinkContainer",style:{top:`${b}px`,left:`${g}px`,width:sg,padding:ag},onClick:()=>{!e.link&&!d&&t({showHyperlinkPopup:"editor"})},children:[d?il("input",{className:I4("excalidraw-hyperlinkContainer-input"),placeholder:"Type or paste your link here",ref:s,value:l,onChange:E=>c(E.target.value),autoFocus:!0,onKeyDown:E=>{E.stopPropagation(),E[S.CTRL_OR_CMD]&&E.key===S.K&&E.preventDefault(),(E.key===S.ENTER||E.key===S.ESCAPE)&&(m(),t({showHyperlinkPopup:"info"}))}}):e.link?il("a",{href:ir(e.link||""),className:"excalidraw-hyperlinkContainer-link",target:Gd(e.link)?"_self":"_blank",onClick:E=>{if(e.link&&r){let w=gd("excalidraw-link",E.nativeEvent);r({...e,link:ir(e.link)},w),w.defaultPrevented&&E.preventDefault()}},rel:"noopener noreferrer",children:e.link}):il("div",{className:"excalidraw-hyperlinkContainer-link",children:f("labels.link.empty")}),ny("div",{className:"excalidraw-hyperlinkContainer__buttons",children:[!d&&il(ne,{type:"button",title:f("buttons.edit"),"aria-label":f("buttons.edit"),label:f("buttons.edit"),onClick:p,className:"excalidraw-hyperlinkContainer--edit",icon:Xa}),a&&!At(e)&&il(ne,{type:"button",title:f("buttons.remove"),"aria-label":f("buttons.remove"),label:f("buttons.remove"),onClick:u,className:"excalidraw-hyperlinkContainer--remove",icon:ii})]})]})},ly=(e,t)=>{let[r,o]=ee(e),{x:n,y:i}=Dt({sceneX:r+e.width/2,sceneY:o},t),a=n-t.offsetLeft-sg/2,l=i-t.offsetTop-iy;return{x:a,y:l}},dg=N({name:"hyperlink",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[S.CTRL_OR_CMD]&&e.key===S.K,contextItemLabel:(e,t)=>oy(e,t),predicate:(e,t)=>ge(e,t).length===1,PanelComponent:({elements:e,appState:t,updateData:r})=>{let o=ge(e,t);return il(ne,{type:"button",icon:Bd,"aria-label":f(oy(e,t)),title:`${At(e[0])?f("labels.link.labelEmbed"):f("labels.link.label")} - ${_("CtrlOrCmd+K")}`,onClick:()=>r(null),selected:o.length===1&&!!o[0].link})}}),oy=(e,t)=>{let r=ge(e,t);return r[0].link?At(r[0])?"labels.link.editEmbed":"labels.link.edit":At(r[0])?"labels.link.createEmbed":"labels.link.create"},Yd=([e,t,r,o],n,i)=>{let a=dy,l=a/i.zoom.value,c=a/i.zoom.value,s=a/i.zoom.value,d=(e+r)/2,m=(t+o)/2,u=(a-8)/(2*i.zoom.value),p=4/i.zoom.value,g=r+p-u,b=t-p-s+u,[E,w]=fe(g+l/2,b+c/2,d,m,n);return[E-l/2,w-c/2,l,c]},mg=(e,t,[r,o])=>{let n=4/t.zoom.value,[i,a,l,c]=ee(e),[s,d,m,u]=Yd([i,a,l,c],e.angle,t);return r>s-n&&r<s+n+m&&o>d-n&&o<d+u+n},Kd=(e,t,[r,o],n)=>{if(!e.link||t.selectedElementIds[e.id])return!1;let i=4/t.zoom.value;return!n&&t.viewModeEnabled&&As(e,[r,o],i,null)?!0:mg(e,t,[r,o])},ks=null,sy=(e,t)=>{ks&&clearTimeout(ks),ks=window.setTimeout(()=>k4(e,t),Xb)},k4=(e,t)=>{if(!e.link)return;let r=rl();r.classList.add("excalidraw-tooltip--visible"),r.style.maxWidth="20rem",r.textContent=e.link;let[o,n,i,a]=ee(e),[l,c,s,d]=Yd([o,n,i,a],e.angle,t),m=Dt({sceneX:l,sceneY:c},t);ng(r,{left:m.x,top:m.y,width:s,height:d},"top"),Ee("hyperlink","tooltip","link-icon"),lg=!0},cy=()=>{ks&&clearTimeout(ks),lg&&(lg=!1,rl().classList.remove("excalidraw-tooltip--visible"))},A4=(e,t,[r,o])=>{let{x:n,y:i}=Ue({clientX:r,clientY:o},t),a=15/t.zoom.value;if(As(e,[n,i],a,null))return!1;let[l,c,s]=ee(e);if(n>=l&&n<=s&&i>=c-iy&&i<=c)return!1;let{x:d,y:m}=ly(e,t);return!(r>=d-a&&r<=d+sg+ag*2+a&&o>=m-a&&o<=m+a+ag*2+S4)}});var M4,L4,my,uy,py,_4,P4,gy,eo,D4,hy=y(()=>{"use strict";h();M4="#ff6b6b",L4="#ff0000",my=1,uy=2,py=(e,t)=>{if(!t.snapLines.length)return;let r=t.theme==="light"||t.zenModeEnabled?M4:L4,o=(t.zenModeEnabled?my*1.5:my)/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,P4(n,e,t)):n.type==="gap"?(e.lineWidth=o,e.strokeStyle=r,D4(n.points[0],n.points[1],n.direction,t,e)):n.type==="points"&&(e.lineWidth=o,e.strokeStyle=r,_4(n,e,t));e.restore()},_4=(e,t,r)=>{if(!r.zenModeEnabled){let o=e.points[0],n=e.points[e.points.length-1];eo(o,n,t)}for(let o of e.points)gy(o,r,t)},P4=(e,t,r)=>{gy(e.points[0],r,t),r.zenModeEnabled||eo(e.points[0],e.points[1],t)},gy=([e,t],r,o)=>{o.save();let n=(r.zenModeEnabled?uy*1.5:uy)/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()},eo=(e,t,r)=>{r.beginPath(),r.lineTo(...e),r.lineTo(...t),r.stroke()},D4=(e,t,r,o,n)=>{let i=8/o.zoom.value,a=i/2,l=i/4;if(r==="horizontal"){let c=[(e[0]+t[0])/2,e[1]];o.zenModeEnabled||eo([e[0],e[1]-i],[e[0],e[1]+i],n),eo([c[0]-l,c[1]-a],[c[0]-l,c[1]+a],n),eo([c[0]+l,c[1]-a],[c[0]+l,c[1]+a],n),o.zenModeEnabled||(eo([t[0],t[1]-i],[t[0],t[1]+i],n),eo(e,t,n))}else{let c=[e[0],(e[1]+t[1])/2];o.zenModeEnabled||eo([e[0]-i,e[1]],[e[0]+i,e[1]],n),eo([c[0]-a,c[1]-l],[c[0]+a,c[1]-l],n),eo([c[0]-a,c[1]+l],[c[0]+a,c[1]+l],n),o.zenModeEnabled||(eo([t[0]-i,t[1]],[t[0]+i,t[1]],n),eo(e,t,n))}}});import hn from"open-color";import"canvas-roundrect-polyfill";var ll,Ls,R4,N4,qd,B4,Xd,ug,pg,O4,fy,Ey,yy,wy,vy,Ty,Iy,Sy,Jd,Cy,by,ky,F4,H4,z4,G4,U4,fn,xy,Ay,sl=y(()=>{"use strict";h();ue();Wx();Qd();nl();Es();ar();gr();na();ml();W();jx();X();$d();hy();ae();Ts();br();ll=2,Ls=(e,t,r,o,n,i,a,l,c=!1,s=0)=>{e.save(),e.translate(i,a),e.rotate(l),c&&e.fillRect(t-i,r-a,o,n),s&&e.roundRect?(e.beginPath(),e.roundRect(t-i,r-a,o,n,s),e.stroke(),e.closePath()):e.strokeRect(t-i,r-a,o,n),e.restore()},R4=(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()},N4=(e,t,r,o,n,i)=>{e.beginPath(),e.ellipse(o,n,t/2,r/2,i,0,Math.PI*2),e.stroke()},qd=(e,t,r,o,n=!0)=>{e.beginPath(),e.arc(t,r,o,0,Math.PI*2),e.fill(),n&&e.stroke()},B4=(e,t,r,o,n,i,a)=>{let c;(E=>(E.Bold="#cccccc",E.Regular="#e5e5e5"))(c||={});let s=-Math.round(n.value/t)*t+r%t,d=-Math.round(n.value/t)*t+o%t,m=Math.min(1/n.value,1),u=1/n.value,p=[m*3,u+(m+u)];e.save(),e.lineWidth=m;for(let g=s;g<s+i+t*2;g+=t){let b=Math.round(g-r)%(5*t)===0;e.beginPath(),e.setLineDash(b?[]:p),e.strokeStyle=b?"#cccccc":"#e5e5e5",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 b=Math.round(g-o)%(5*t)===0;e.beginPath(),e.setLineDash(b?[]:p),e.strokeStyle=b?"#cccccc":"#e5e5e5",e.moveTo(s-t,g),e.lineTo(s+i+t*2,g),e.stroke()}e.restore()},Xd=(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)"),qd(e,r[0],r[1],o/t.zoom.value,!i)},ug=(e,t,r)=>{if(!t.selectedLinearElement)return;e.save(),e.translate(t.scrollX,t.scrollY),e.lineWidth=1/t.zoom.value;let o=K.getPointsGlobalCoordinates(r),{POINT_HANDLE_SIZE:n}=K,i=t.editingLinearElement?n:n/2;o.forEach((l,c)=>{let s=!!t.editingLinearElement?.selectedPointsIndices?.includes(c);Xd(e,t,l,i,s)}),K.getEditorMidPoints(r,t).filter(l=>l!==null).forEach(l=>{t?.selectedLinearElement?.segmentMidPointHoveredCoords&&K.arePointsEqual(l,t.selectedLinearElement.segmentMidPointHoveredCoords)?t.editingLinearElement?(Xd(e,t,l,i,!1),pg(l,e,t)):(pg(l,e,t),Xd(e,t,l,i,!1)):(t.editingLinearElement||o.length===2)&&Xd(e,t,l,n/2,!1,!0)}),e.restore()},pg=(e,t,r)=>{t.fillStyle="rgba(105, 101, 219, 0.4)",qd(t,e[0],e[1],K.POINT_HANDLE_SIZE/r.zoom.value,!1)},O4=(e,t)=>{let{elementId:r,hoverPointIndex:o}=t.selectedLinearElement;if(t.editingLinearElement?.selectedPointsIndices?.includes(o))return;let n=K.getElement(r);if(!n)return;let i=K.getPointAtIndexGlobalCoordinates(n,o);e.save(),e.translate(t.scrollX,t.scrollY),pg(i,e,t),e.restore()},fy=(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,Qe.radius/o.zoom.value):t.rect(0,0,e.width,e.height),t.clip(),t.translate(-(e.x+o.scrollX),-(e.y+o.scrollY))},Ey=(e,t)=>[e.width/t,e.height/t],yy=({canvas:e,scale:t,normalizedWidth:r,normalizedHeight:o,theme:n,isExporting:i,viewBackgroundColor:a})=>{let l=e.getContext("2d");return l.setTransform(1,0,0,1,0,0),l.scale(t,t),i&&n==="dark"&&(l.filter=Da),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},wy=({canvas:e,elements:t,visibleElements:r,selectedElements:o,scale:n,appState:i,renderConfig:a})=>{if(e===null)return{atLeastOneVisibleElement:!1,elements:t};let[l,c]=Ey(e,n),s=yy({canvas:e,scale:n,normalizedWidth:l,normalizedHeight:c});s.save(),s.scale(i.zoom.value,i.zoom.value);let d;if(r.forEach(p=>{i.editingLinearElement?.elementId===p.id&&p&&(d=p)}),d&&ug(s,i,d),i.selectionElement)try{Ly(i.selectionElement,s,i)}catch(p){console.error(p)}i.isBindingEnabled&&i.suggestedBindings.filter(p=>p!=null).forEach(p=>{F4(s,i,p)}),i.frameToHighlight&&z4(s,i,i.frameToHighlight),i.elementsToHighlight&&G4(s,i,i.elementsToHighlight);let m=o.some(p=>J(p));if(o.length===1&&i.editingLinearElement?.elementId===o[0].id&&ug(s,i,o[0]),i.selectedLinearElement&&i.selectedLinearElement.hoverPointIndex>=0&&O4(s,i),!i.multiElement&&!i.editingLinearElement){let p=dl(o,i);o.length===1&&te(o[0])&&i.selectedLinearElement?.elementId===o[0].id&&!o[0].locked&&ug(s,i,o[0]);let b=a.selectionColor||hn.black;if(p){let E=o.reduce((T,k)=>(T[k.id]=!0,T),{}),w=t.reduce((T,k)=>{let M=[];if(E[k.id]&&!Wa(i,k)&&M.push(b),a.remoteSelectedElementIds[k.id]&&M.push(...a.remoteSelectedElementIds[k.id].map(A=>Ji(A))),M.length){let[A,D,R,H,C,O]=ee(k,!0);T.push({angle:k.angle,elementX1:A,elementY1:D,elementX2:R,elementY2:H,selectionColors:M,dashed:!!a.remoteSelectedElementIds[k.id],cx:C,cy:O,activeEmbeddable:i.activeEmbeddable?.element===k&&i.activeEmbeddable.state==="active"})}return T},[]),v=T=>{let k=at(t,T),[M,A,D,R]=we(k);w.push({angle:0,elementX1:M,elementX2:D,elementY1:A,elementY2:R,selectionColors:[hn.black],dashed:!0,cx:M+(D-M)/2,cy:A+(R-A)/2,activeEmbeddable:!1})};for(let T of ln(i))v(T);i.editingGroupId&&v(i.editingGroupId),w.forEach(T=>ky(s,i,T))}if(s.save(),s.translate(i.scrollX,i.scrollY),o.length===1){s.fillStyle=hn.white;let E=Ps(o[0],i.zoom,"mouse");!i.viewModeEnabled&&p&&by(s,a,i,E,o[0].angle)}else if(o.length>1&&!i.isRotating){let E=ll*2/i.zoom.value;s.fillStyle=hn.white;let[w,v,T,k]=we(o),M=s.getLineDash();s.setLineDash([2/i.zoom.value]);let A=s.lineWidth;s.lineWidth=1/i.zoom.value,s.strokeStyle=b,Ls(s,w-E,v-E,T-w+E*2,k-v+E*2,(w+T)/2,(v+k)/2,0),s.lineWidth=A,s.setLineDash(M);let D=cl([w,v,T,k,(w+T)/2,(v+k)/2],0,i.zoom,"mouse",m?My:_s);o.some(R=>!R.locked)&&by(s,a,i,D,0)}s.restore()}py(s,i),s.restore();for(let p in a.remotePointerViewportCoords){let{x:g,y:b}=a.remotePointerViewportCoords[p];g-=i.offsetLeft,b-=i.offsetTop;let E=11,w=14,v=g<0||g>l-E||b<0||b>c-w;g=Math.max(g,0),g=Math.min(g,l-E),b=Math.max(b,0),b=Math.min(b,c-w);let T=Ji(p);s.save(),s.strokeStyle=T,s.fillStyle=T;let k=a.remotePointerUserStates[p],M=v||k==="idle"||k==="away";M&&(s.globalAlpha=.3),a.remotePointerButton&&a.remotePointerButton[p]==="down"&&(s.beginPath(),s.arc(g,b,15,0,2*Math.PI,!1),s.lineWidth=3,s.strokeStyle="#ffffff88",s.stroke(),s.closePath(),s.beginPath(),s.arc(g,b,15,0,2*Math.PI,!1),s.lineWidth=1,s.strokeStyle=T,s.stroke(),s.closePath()),s.fillStyle=hn.white,s.strokeStyle=hn.white,s.lineWidth=6,s.lineJoin="round",s.beginPath(),s.moveTo(g,b),s.lineTo(g+0,b+14),s.lineTo(g+4,b+9),s.lineTo(g+11,b+8),s.closePath(),s.stroke(),s.fill(),s.fillStyle=T,s.strokeStyle=T,s.lineWidth=2,s.lineJoin="round",s.beginPath(),M?(s.moveTo(g-1,b-1),s.lineTo(g-1,b+15),s.lineTo(g+5,b+10),s.lineTo(g+12,b+9),s.closePath(),s.fill()):(s.moveTo(g,b),s.lineTo(g+0,b+14),s.lineTo(g+4,b+9),s.lineTo(g+11,b+8),s.closePath(),s.fill(),s.stroke());let A=a.remotePointerUsernames[p]||"";if(!v&&A){s.font="600 12px sans-serif";let D=g+E/2,R=b+w+2,H=5,C=3,O=s.measureText(A),P=O.actualBoundingBoxDescent+O.actualBoundingBoxAscent,G=Math.max(P,12),j=D-1,V=R-1,pe=O.width+2+H*2+2,Se=G+2+C*2+2;s.roundRect?(s.beginPath(),s.roundRect(j,V,pe,Se,8),s.fillStyle=T,s.fill(),s.strokeStyle=hn.white,s.stroke()):$p(s,j,V,pe,Se,8,hn.white),s.fillStyle=hn.black,s.fillText(A,D+H+1,R+C+O.actualBoundingBoxAscent+Math.floor((G-P)/2)+2)}s.restore(),s.closePath()}let u;return a.renderScrollbars&&(u=Py(t,l,c,i),s.save(),s.fillStyle=_y,s.strokeStyle="rgba(255,255,255,0.8)",[u.horizontal,u.vertical].forEach(p=>{p&&$p(s,p.x,p.y,p.width,p.height,Go/2)}),s.restore()),{scrollBars:u,atLeastOneVisibleElement:r.length>0,elements:t}},vy=({canvas:e,rc:t,elements:r,visibleElements:o,scale:n,appState:i,renderConfig:a})=>{if(e===null)return;let{renderGrid:l=!0,isExporting:c}=a,[s,d]=Ey(e,n),m=yy({canvas:e,scale:n,normalizedWidth:s,normalizedHeight:d,theme:i.theme,isExporting:c,viewBackgroundColor:i.viewBackgroundColor});m.scale(i.zoom.value,i.zoom.value),l&&i.gridSize&&B4(m,i.gridSize,i.scrollX,i.scrollY,i.zoom,s/i.zoom.value,d/i.zoom.value);let u=new Set;o.forEach(p=>{p.groupIds.length>0&&i.frameToHighlight&&i.selectedElementIds[p.id]&&(si(p,i.frameToHighlight)||p.groupIds.find(g=>u.has(g)))&&p.groupIds.forEach(g=>u.add(g))}),o.filter(p=>!Ld(p)).forEach(p=>{try{if((p.frameId||i.frameToHighlight?.id)&&i.frameRendering.enabled&&i.frameRendering.clip){m.save();let b=jd(p,i);b&&ia(p,r,i)&&fy(b,m,a,i),Ms(p,t,m,a,i),m.restore()}else Ms(p,t,m,a,i);c||xy(p,m,i)}catch(g){console.error(g)}}),o.filter(p=>Ld(p)).forEach(p=>{try{let g=()=>{if(Ms(p,t,m,a,i),nr(p)&&(c||At(p)&&!p.validated)&&p.width&&p.height){let E=_d(p);Ms(E,t,m,a,i)}c||xy(p,m,i)};if((p.frameId||i.frameToHighlight?.id)&&i.frameRendering.enabled&&i.frameRendering.clip){m.save();let E=jd(p,i);E&&ia(p,r,i)&&fy(E,m,a,i),g(),m.restore()}else g()}catch(g){console.error(g)}})},Ty=dd(e=>{let t=wy(e);e.callback?.(t)},{trailing:!0}),Iy=(e,t)=>{if(t){Ty(e);return}let r=wy(e);return e.callback(r),r},Sy=dd(e=>{vy(e)},{trailing:!0}),Jd=(e,t)=>{if(t){Sy(e);return}vy(e)},Cy=()=>{Ty.cancel(),Sy.cancel()},by=(e,t,r,o,n)=>{Object.keys(o).forEach(i=>{let a=o[i];if(a!==void 0){let[l,c,s,d]=a;e.save(),e.lineWidth=1/r.zoom.value,t.selectionColor&&(e.strokeStyle=t.selectionColor),i==="rotation"?qd(e,l+s/2,c+d/2,s/2):e.roundRect?(e.beginPath(),e.roundRect(l,c,s,d,2/r.zoom.value),e.fill(),e.stroke()):Ls(e,l,c,s,d,l+s/2,c+d/2,n,!0),e.restore()}})},ky=(e,t,r,o=ll*2)=>{let{angle:n,elementX1:i,elementY1:a,elementX2:l,elementY2:c,selectionColors:s,cx:d,cy:m,dashed:u,activeEmbeddable:p}=r,g=l-i,b=c-a,E=o/t.zoom.value,w=8/t.zoom.value,v=4/t.zoom.value;e.save(),e.translate(t.scrollX,t.scrollY),e.lineWidth=(p?4:1)/t.zoom.value;let T=s.length;for(let k=0;k<T;++k)e.strokeStyle=s[k],u&&e.setLineDash([w,v+(w+v)*(T-1)]),e.lineDashOffset=(w+v)*k,Ls(e,i-E,a-E,g+E*2,b+E*2,d,m,n);e.restore()},F4=(e,t,r)=>{let o=Array.isArray(r)?U4:H4;e.save(),e.translate(t.scrollX,t.scrollY),o(e,r),e.restore()},H4=(e,t)=>{let[r,o,n,i]=ee(t),a=n-r,l=i-o,c=ul(t,a,l),s=4;e.strokeStyle="rgba(0,0,0,.05)",e.lineWidth=c-s;let d=s/2+c/2;switch(t.type){case"rectangle":case"text":case"image":case"iframe":case"embeddable":case"frame":case"magicframe":Ls(e,r-d,o-d,a+d*2,l+d*2,r+a/2,o+l/2,t.angle);break;case"diamond":let m=Math.hypot(a,l),u=d*m/l,p=d*m/a;R4(e,a+u*2,l+p*2,r+a/2,o+l/2,t.angle);break;case"ellipse":N4(e,a+d*2,l+d*2,r+a/2,o+l/2,t.angle);break}},z4=(e,t,r)=>{let[o,n,i,a]=ee(r),l=i-o,c=a-n;e.strokeStyle="rgb(0,118,255)",e.lineWidth=Qe.strokeWidth/t.zoom.value,e.save(),e.translate(t.scrollX,t.scrollY),Ls(e,o,n,l,c,o+l/2,n+c/2,r.angle,!1,Qe.radius/t.zoom.value),e.restore()},G4=(e,t,r)=>{let o=r.filter(l=>l.groupIds.length===0),n=r.filter(l=>l.groupIds.length>0),i=l=>{let[c,s,d,m]=we(l);return{angle:0,elementX1:c,elementX2:d,elementY1:s,elementY2:m,selectionColors:["rgb(0,118,255)"],dashed:!1,cx:c+(d-c)/2,cy:s+(m-s)/2,activeEmbeddable:!1}},a=l=>{let c=at(r,l);return i(c)};Object.entries(vd(n,t)).filter(([l,c])=>c).map(([l,c])=>l).map(l=>a(l)).concat(o.map(l=>i([l]))).forEach(l=>ky(e,t,l))},U4=(e,t)=>{let[r,o,n]=t,i=ul(n,n.width,n.height);e.strokeStyle="rgba(0,0,0,0)",e.fillStyle="rgba(0,0,0,.05)",(o==="both"?[0,-1]:o==="start"?[0]:[-1]).forEach(l=>{let[c,s]=K.getPointAtIndexGlobalCoordinates(r,l);qd(e,c,s,i)})},xy=(e,t,r)=>{if(e.link&&!r.selectedElementIds[e.id]){let[o,n,i,a]=ee(e),[l,c,s,d]=Yd([o,n,i,a],e.angle,r),m=l+s/2,u=c+d/2;if(t.save(),t.translate(r.scrollX+m,r.scrollY+u),t.rotate(e.angle),!fn||fn.zoom!==r.zoom.value){fn=document.createElement("canvas"),fn.zoom=r.zoom.value,fn.width=s*window.devicePixelRatio*r.zoom.value,fn.height=d*window.devicePixelRatio*r.zoom.value;let p=fn.getContext("2d");p.scale(window.devicePixelRatio*r.zoom.value,window.devicePixelRatio*r.zoom.value),p.fillStyle="#fff",p.fillRect(0,0,s,d),p.drawImage(cg,0,0,s,d),p.restore(),t.drawImage(fn,l-m,c-u,s,d)}else t.drawImage(fn,l-m,c-u,s,d);t.restore()}},Ay=(e,t,r,o,n)=>{r&&(e.filter(i=>!Ld(i)).forEach(i=>{if(!i.isDeleted)try{Zd(i,t,r,o,i.x+n.offsetX,i.y+n.offsetY,n)}catch(a){console.error(a)}}),e.filter(i=>nr(i)).forEach(i=>{if(!i.isDeleted)try{Zd(i,t,r,o,i.x+n.offsetX,i.y+n.offsetY,n)}catch(a){console.error(a)}}))}});var Dy,W4,_s,My,V4,Ry,gg,bn,cl,Ps,dl,ml=y(()=>{"use strict";h();yt();Zt();ue();ae();sl();Dy={mouse:8,pen:16,touch:28},W4=16,_s={e:!0,s:!0,n:!0,w:!0},My={e:!0,s:!0,n:!0,w:!0,rotation:!0},V4={e:!0,s:!0,n:!0,w:!0},Ry={e:!0,s:!0,n:!0,w:!0,nw:!0,se:!0},gg={e:!0,s:!0,n:!0,w:!0},bn=(e,t,r,o,n,i,a)=>{let[l,c]=fe(e+r/2,t+o/2,n,i,a);return[l-r/2,c-o/2,r,o]},cl=([e,t,r,o,n,i],a,l,c,s={},d=4)=>{let m=Dy[c],u=m/l.value,p=m/l.value,g=m/l.value,b=m/l.value,E=r-e,w=o-t,v=d/l.value,T=(m-ll*2)/(2*l.value),k={nw:s.nw?void 0:bn(e-v-g+T,t-v-b+T,u,p,n,i,a),ne:s.ne?void 0:bn(r+v-T,t-v-b+T,u,p,n,i,a),sw:s.sw?void 0:bn(e-v-g+T,o+v-T,u,p,n,i,a),se:s.se?void 0:bn(r+v-T,o+v-T,u,p,n,i,a),rotation:s.rotation?void 0:bn(e+E/2-u/2,t-v-b+T-W4/l.value,u,p,n,i,a)},M=5*Dy.mouse/l.value;return Math.abs(E)>M&&(s.n||(k.n=bn(e+E/2-u/2,t-v-b+T,u,p,n,i,a)),s.s||(k.s=bn(e+E/2-u/2,o+v-T,u,p,n,i,a))),Math.abs(w)>M&&(s.w||(k.w=bn(e-v-g+T,t+w/2-p/2,u,p,n,i,a)),s.e||(k.e=bn(r+v-T,t+w/2-p/2,u,p,n,i,a))),k},Ps=(e,t,r="mouse")=>{if(e.locked)return{};let o={};if(e.type==="freedraw"||te(e)){if(e.points.length===2){let[,i]=e.points;i[0]===0||i[1]===0?o=gg:i[0]>0&&i[1]<0?o=Ry:i[0]>0&&i[1]>0?o=gg:i[0]<0&&i[1]>0?o=Ry:i[0]<0&&i[1]<0&&(o=gg)}}else z(e)?o=V4:J(e)&&(o={rotation:!0});let n=te(e)?ll+8:ll;return cl(ee(e,!0),e.angle,t,r,o,n)},dl=(e,t)=>{if(t.editingLinearElement)return!1;if(e.length>1)return!0;let r=e[0];return te(r)?r.points.length>2:!0}});import{pointsOnBezierCurves as Y4}from"points-on-curve";var K4,pl,Rs,aa,$4,As,fg,ul,bg,em,X4,Ds,Z4,j4,Ny,q4,J4,Q4,ek,tk,rk,tm,ok,xg,rm,By,Oy,Fy,nk,Hy,ik,ak,lk,sk,ck,dk,mk,Eg,zy,na=y(()=>{"use strict";h();qi();Bx();Kp();Wp();Ux();Zt();yt();ae();ue();W();ml();pt();Io();K4=e=>{if(e.type==="arrow")return!1;if(e.type==="freedraw")return!0;let t=!or(e.backgroundColor)||pr(e)||nr(e);return e.type==="line"?t&&xr(e.points):t||Yr(e)},pl=(e,t,r,o,n)=>{let i=10/t.zoom.value,a=[o,n];if($4(t,e)&&dl([e],t))return As(e,a,i,r);let l=le(e);return l&&pl(l,t,r,o,n)?!0:aa(e,t,r,a)},Rs=(e,t,r,o,n)=>{let i=10/t.zoom.value,a=le(e);return a&&pl(a,t,r,o,n)?!1:!aa(e,t,r,[o,n])&&As(e,[o,n],i,r)},aa=(e,t,r,o)=>{let n=10/t.zoom.value,i=z(e)?X4:K4(e)?Ds:Z4;return bg({element:e,point:o,threshold:n,check:i,frameNameBoundsCache:r})},$4=(e,t)=>e.selectedElementIds[t.id],As=(e,[t,r],o,n)=>{if(J(e))return bg({element:e,point:[t,r],threshold:o,check:Ds,frameNameBoundsCache:n});let[i,a,l,c]=ee(e),s=(i+l)/2,d=(a+c)/2,[m,u]=fe(t,r,s,d,-e.angle);return m>i-o&&m<l+o&&u>a-o&&u<c+o},fg=(e,{x:t,y:r})=>{let o=ul(e,e.width,e.height);return bg({element:e,point:[t,r],threshold:o,check:j4,frameNameBoundsCache:null})},ul=(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))},bg=e=>{switch(e.element.type){case"rectangle":case"iframe":case"embeddable":case"image":case"text":case"diamond":case"ellipse":let t=em(e.element,e.point);return e.check(t,e.threshold);case"freedraw":return e.check(Ny(e.element,e.point),e.threshold)?tk(e.element,e.point,e.threshold):!1;case"arrow":case"line":return rk(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(em(e.element,e.point),e.threshold))return!0;let r=e.frameNameBoundsCache?.get(e.element);return r?e.check(q4(r,e.point),e.threshold):!1}}},em=(e,t)=>{switch(e.type){case"rectangle":case"image":case"text":case"iframe":case"embeddable":case"frame":case"magicframe":return Ny(e,t);case"diamond":return J4(e,t);case"ellipse":return Q4(e,t)}},X4=(e,t)=>e<0,Ds=(e,t)=>e<t,Z4=(e,t)=>Math.abs(e)<t,j4=(e,t)=>0<=e&&e<t,Ny=(e,t)=>{let[,r,o,n]=tm(e,t);return Math.max(Xr(r,Jn(0,1,-n)),Xr(r,Jn(1,0,-o)))},q4=(e,t)=>{let[,r,o,n]=ok(t,e);return Math.max(Xr(r,Jn(0,1,-n)),Xr(r,Jn(1,0,-o)))},J4=(e,t)=>{let[,r,o,n]=tm(e,t),i=Jn(n,o,-n*o);return Xr(r,i)},Q4=(e,t)=>{let[r,o]=ek(e,t);return-Dx(o)*Xr(r,o)},ek=(e,t)=>{let[,r,o,n]=tm(e,t),[i,a]=ei(r),l=.707,c=.707,s=o,d=n;[0,1,2,3].forEach(p=>{let g=s*l,b=d*c,E=(s*s-d*d)*l**3/s,w=(d*d-s*s)*c**3/d,v=g-E,T=b-w,k=i-E,M=a-w,A=Math.hypot(T,v),D=Math.hypot(M,k);l=Math.min(1,Math.max(0,(k*A/D+E)/s)),c=Math.min(1,Math.max(0,(M*A/D+w)/d));let R=Math.hypot(c,l);l/=R,c/=R});let m=Xt(s*l,d*c),u=Px(r,m);return[r,u]},tk=(e,t,r)=>{let o,n;if(e.angle===0)o=t[0]-e.x,n=t[1]-e.y;else{let[s,d,m,u]=ee(e),p=Fe(t,[s+(m-s)/2,d+(u-d)/2],-e.angle);o=p[0]-e.x,n=p[1]-e.y}let[i,a]=e.points,l;if(ct(i[0],i[1],o,n)<r||ct(a[0],a[1],o,n)<r)return!0;for(let s=0;s<e.points.length;s++){let d=[a[0]-i[0],a[1]-i[1]],m=Math.hypot(d[1],d[0]),u=[d[0]/m,d[1]/m],p=[o-i[0],n-i[1]],g=(p[0]*u[0]+p[1]*u[1])/Math.hypot(u[1],u[0]);l=[i[0]+u[0]*g,i[1]+u[1]*g];let b=ct(l[0],l[1],i[0],i[1]),E=ct(l[0],l[1],a[0],a[1]);if(l=E<b&&b>m?a:b<E&&E>m?i:l,Math.hypot(n-l[1],o-l[0])<r)return!0;i=a,a=e.points[s+1]}let c=Te.get(e);return c&&c.sets.length?e.fillStyle==="solid"?Eg(c,o,n,"round"):zy(c,o,n,r):!1},rk=e=>{let{element:t,threshold:r}=e;if(!Te.get(t))return!1;let[o,n,i,a]=tm(e.element,e.point),l=Jn(0,1,-a),c=Jn(1,0,-i);if(!Ds(Xr(n,l),r)||!Ds(Xr(n,c),r))return!1;let[s,d]=ei(o),m=Te.get(t);return m?e.check===Ds&&m.some(p=>Eg(p,s,d,t.roundness?"round":"sharp"))?!0:m.some(u=>zy(u,s,d,r)):!1},tm=(e,t)=>{let r=Qn(t),[o,n,i,a]=ee(e),l=rm(o,n,i,a),c=wd(l,e.angle),s=Zr(c,r),d=bs(s,yd(l)),m=Vp(d),u=Fp(e.x,e.y),p=bs(s,u),g=(i-o)/2,b=(a-n)/2;return[p,m,g,b]},ok=(e,t)=>{let r=Qn(e),[o,n,i,a]=Gy(t),l=rm(o,n,i,a),c=wd(l,t.angle),s=Zr(c,r),d=bs(s,yd(l)),m=Vp(d),u=Fp(t.x,t.y),p=bs(s,u),g=(i-o)/2,b=(a-n)/2;return[p,m,g,b]},xg=e=>{let[t,r,o,n]=ee(e),i=rm(t,r,o,n),a=wd(i,e.angle),l=Ga(Hx(yd(i)));return Gx(a,l)},rm=(e,t,r,o)=>Xt((e+r)/2,(t+o)/2),By=(e,t,r)=>{let o=xg(e),n=Zr(o,Qn(t)),i=Zr(o,Qn(r)),a=Ua(n,i),l=e.height/e.width,c=e.width/2,s=e.height/2,d=a[2],m=a[3],u=a[1],p=Math.abs(m),g=Math.abs(d),b;switch(e.type){case"rectangle":case"image":case"text":case"iframe":case"embeddable":case"frame":case"magicframe":b=u/(c*(g+l*p));break;case"diamond":b=p<g?u/(g*c):u/(p*s);break;case"ellipse":b=u/(c*Math.sqrt(d**2+l**2*m**2));break}return b||0},Oy=(e,t,r)=>{if(t===0){let[l,c,s,d]=ee(e),m=rm(l,c,s,d);return ei(m)}let o=xg(e),n=Zr(o,Qn(r)),i=Ga(o),a;switch(e.type){case"rectangle":case"image":case"text":case"diamond":case"iframe":case"embeddable":case"frame":case"magicframe":a=dk(e,t,n);break;case"ellipse":a=ck(e,t,n);break}return ei(Zr(i,a))},Fy=(e,t,r,o=0)=>{let n=xg(e),i=Zr(n,Qn(t)),a=Zr(n,Qn(r)),l=Ua(i,a),c=Ga(n);return nk(e,l,i,o).map(d=>ei(Zr(c,d)))},nk=(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=Hy(e);n=a.flatMap((l,c)=>{let s=[l,a[(c+1)%4]];return ik(t,ak(s,o))}).concat(a.flatMap(l=>sk(l,o,t)));break;case"ellipse":n=lk(e,o,t);break}if(n.length<2)return[];let i=n.sort((a,l)=>Yp(a,r)-Yp(l,r));return[i[0],i[i.length-1]]},Hy=(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[Xt(r,o),Xt(r,-o),Xt(-r,-o),Xt(-r,o)];case"diamond":return[Xt(0,o),Xt(r,0),Xt(0,-o),Xt(-r,0)]}},ik=(e,t)=>{let[r,o]=t,n=Xr(r,e),i=Xr(o,e);return n*i>=0?[]:[Nx(e,Ua(r,o))]},ak=(e,t)=>{let[r,o]=e,n=zx(Ox(r,o),t);return[Zr(n,r),Zr(n,o)]},lk=(e,t,r)=>{let o=e.width/2+t,n=e.height/2+t,i=r[2],a=r[3],l=r[1],c=o*o*i*i+n*n*a*a,s=c-l*l;if(c===0||s<=0)return[];let d=Math.sqrt(s),m=-o*o*i*l,u=-n*n*a*l;return[Xt((m+o*n*a*d)/c,(u-o*n*i*d)/c),Xt((m-o*n*a*d)/c,(u+o*n*i*d)/c)]},sk=(e,t,r)=>{if(t===0)return Xr(r,e)===0?[e]:[];let o=r[2],n=r[3],i=r[1],[a,l]=ei(e),c=t,s=o*o+n*n,d=c*c*s-(o*a+n*l+i)**2;if(s===0||d<=0)return[];let m=Math.sqrt(d),u=a*n*n-l*o*n-o*i,p=l*o*o-a*o*n-n*i;return[Xt((u+n*m)/s,(p-o*m)/s),Xt((u-n*m)/s,(p+o*m)/s)]},ck=(e,t,r)=>{let o=Math.abs(t),n=e.width*o/2,i=e.height*o/2,a=Math.sign(t),[l,c]=ei(r),s=c===0?1e-4:c,d=l**2*i**2+s**2*n**2,m=(-l*i**2+a*s*Math.sqrt(Math.max(0,d-n**2*i**2)))/d,u=(-m*l-1)/s;u===0&&(u=(Object.is(u,-0)?-1:1)*.01);let p=-(n**2*m)/(u**2*i**2+m**2*n**2);return Xt(p,(-m*p-1)/u)},dk=(e,t,r)=>{let o=Math.abs(t),n=Math.sign(t),i=Hy(e,o),a=0,l=null;return i.forEach(c=>{let s=n*Ua(r,c)[1];s>a&&(a=s,l=c)}),l},mk=(e,t,r,o,[n,i],a)=>{let l=(s,d)=>Math.pow(1-s,3)*o[d]+3*s*Math.pow(1-s,2)*r[d]+3*Math.pow(s,2)*(1-s)*t[d]+e[d]*Math.pow(s,3),c=0;for(;c<=1;){let s=l(c,0),d=l(c,1);if(Math.sqrt(Math.pow(s-n,2)+Math.pow(d-i,2))<a)return!0;c+=.01}return!1},Eg=(e,t,r,o)=>{let n=So(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(o==="sharp")return hg(i,t,r);let l=Y4(i,10,5);return hg(l,t,r)}return!1},zy=(e,t,r,o)=>{let n=So(e),i=[0,0];return n.some(({op:a,data:l},c)=>{if(a==="move")i=l;else if(a==="bcurveTo"){let s=[l[0],l[1]],d=[l[2],l[3]],m=[l[4],l[5]],u=i;return i=m,mk(u,s,d,m,[t,r],o)}else{if(a==="lineTo")return Eg(e,t,r,"sharp");a==="qcurveTo"&&console.warn("qcurveTo is not implemented yet")}return!1})}});var Xy,Uo,Zy,xn,Uy,Ns,uk,Bs,gl,yg,wg,Os,pk,Wo,gk,Co,hk,fk,Wy,Vy,jy,bk,om,qy,Jy,Yy,nm,Ky,hl,$y,xk,ko=y(()=>{"use strict";h();Ze();ae();na();Ve();Er();ar();W();me();pt();Xy=e=>!e[S.CTRL_OR_CMD],Uo=e=>e.isBindingEnabled,Zy=(e,t)=>{let r=[];return t.forEach(o=>{let n=e.getNonDeletedElement(o);n!=null&&r.push(n)}),r},xn=(e,t,r)=>{let o=new Set,n=new Set;Uy(e,t,r,"start",o,n),Uy(e,r,t,"end",o,n);let i=Array.from(n).filter(a=>!o.has(a));Zy(xe.getScene(e),i).forEach(a=>{B(a,{boundElements:a.boundElements?.filter(l=>l.type!=="arrow"||l.id!==e.id)})})},Uy=(e,t,r,o,n,i)=>{if(t!=="keep")if(t!=null)(r==null||(r==="keep"?!yg(e,t,o):o==="start"||r.id!==t.id))&&(gl(e,t,o),n.add(t.id));else{let a=pk(e,o);a!=null&&i.add(a)}},Ns=e=>{e.forEach(t=>{Et(t)?xn(t,om(t,"start"),om(t,"end")):Ha(t)&&uk(t)})},uk=e=>{Jy(e).forEach(([t,r])=>xn(t,r==="end"?"keep":e,r==="start"?"keep":e))},Bs=(e,t,r,o)=>{t.startBoundElement!=null&&gl(e,t.startBoundElement,"start");let n=Wo(o,r);n!=null&&!yg(e,n,"end")&&gl(e,n,"end")},gl=(e,t,r)=>{B(e,{[r==="start"?"startBinding":"endBinding"]:{elementId:t.id,...gk(e,t,r)}}),Ce(t.boundElements||[]).has(e.id)||B(t,{boundElements:(t.boundElements||[]).concat({id:e.id,type:"arrow"})})},yg=(e,t,r)=>{let o=e[r==="start"?"endBinding":"startBinding"];return wg(e,o?.elementId,t)},wg=(e,t,r)=>t===r.id&&e.points.length<3,Os=e=>{e.forEach(t=>{Et(t)&&xn(t,null,null)})},pk=(e,t)=>{let r=t==="start"?"startBinding":"endBinding",o=e[r];return o==null?null:(B(e,{[r]:null}),o.elementId)},Wo=(e,t)=>vg(t.getNonDeletedElements(),o=>Ha(o,!1)&&fg(o,e)),gk=(e,t,r)=>{let o=r==="start"?-1:1,n=o===-1?0:e.points.length-1,i=n-o,a=K.getPointAtIndexGlobalCoordinates(e,n),l=K.getPointAtIndexGlobalCoordinates(e,i);return{focus:By(t,l,a),gap:Math.max(1,em(t,a))}},Co=(e,t)=>{let r=(e.boundElements??[]).filter(a=>a.type==="arrow");if(r.length===0)return;let{newSize:o,simultaneouslyUpdated:n}=t??{},i=fk(n);Zy(xe.getScene(e),r.map(a=>a.id)).forEach(a=>{if(!te(a))return;let l=e;if(!hk(a,l))return;let c=Vy(l,a.startBinding,o),s=Vy(l,a.endBinding,o);if(i.has(a.id)){B(a,{startBinding:c,endBinding:s});return}Wy(a,"start",c,e),Wy(a,"end",s,e),le(a)&&la(a,!1)})},hk=(e,t)=>e.startBinding?.elementId===t.id||e.endBinding?.elementId===t.id,fk=e=>new Set((e||[]).map(t=>t.id)),Wy=(e,t,r,o)=>{if(r==null||r.elementId!==o.id&&e.points.length>2)return;let n=xe.getScene(e).getElement(r.elementId);if(n==null)return;let i=t==="start"?-1:1,a=i===-1?0:e.points.length-1,l=a-i,c=K.getPointAtIndexGlobalCoordinates(e,l),s=Oy(n,r.focus,c),d;if(r.gap===0)d=s;else{let m=Fy(n,c,s,r.gap);m.length===0?d=s:d=m[0]}K.movePoints(e,[{index:a,point:K.pointFromAbsoluteCoords(e,d)}],{[t==="start"?"startBinding":"endBinding"]:r})},Vy=(e,t,r)=>{if(t==null||r==null)return t;let{gap:o,focus:n,elementId:i}=t,{width:a,height:l}=r,{width:c,height:s}=e,d=Math.max(1,Math.min(ul(e,a,l),o*(a<l?a/c:l/s)));return{elementId:i,gap:d,focus:n}},jy=e=>{let t=new Set(e.map(({id:r})=>r));return e.flatMap(r=>Et(r,!1)?bk(r).filter(o=>!t.has(o.id)):Ha(r,!1)?Jy(r).filter(o=>!t.has(o[0].id)):[])},bk=e=>[om(e,"start"),om(e,"end")].filter(t=>t!=null),om=(e,t)=>Wo(qy(e,t),xe.getScene(e)),qy=(e,t)=>{let r=t==="start"?0:-1;return xo(K.getPointAtIndexGlobalCoordinates(e,r))},Jy=e=>xe.getScene(e).getNonDeletedElements().map(t=>{if(!Et(t,!1))return null;let r=Yy(t,"start",e),o=Yy(t,"end",e);return!r&&!o?null:[t,r&&o?"both":r?"start":"end",e]}).filter(t=>t!=null),Yy=(e,t,r)=>e[t==="start"?"startBinding":"endBinding"]==null&&!yg(e,r,t)&&fg(r,qy(e,t)),nm=(e,t,r,o)=>{let n=new Set,i=new Set,a=o==="duplicatesServeAsOld";t.forEach(l=>{let{boundElements:c}=l;if(c!=null&&c.length>0&&(c.forEach(s=>{a&&!r.has(s.id)&&n.add(s.id)}),i.add(r.get(l.id))),Et(l)){if(l.startBinding!=null){let{elementId:s}=l.startBinding;a&&!r.has(s)&&i.add(s)}if(l.endBinding!=null){let{elementId:s}=l.endBinding;a&&!r.has(s)&&i.add(s)}(l.startBinding!=null||l.endBinding!=null)&&n.add(r.get(l.id))}}),e.filter(({id:l})=>n.has(l)).forEach(l=>{let{startBinding:c,endBinding:s}=l;B(l,{startBinding:Ky(c,r),endBinding:Ky(s,r)})}),e.filter(({id:l})=>i.has(l)).forEach(l=>{let{boundElements:c}=l;c!=null&&c.length>0&&B(l,{boundElements:c.map(s=>r.has(s.id)?{id:r.get(s.id),type:s.type}:s)})})},Ky=(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}},hl=(e,t)=>{let r=new Set(t.map(n=>n.id)),o=new Set;t.forEach(n=>{Ha(n)?n.boundElements?.forEach(i=>{r.has(i.id)||o.add(i.id)}):Et(n)&&(n.startBinding&&o.add(n.startBinding.elementId),n.endBinding&&o.add(n.endBinding.elementId))}),e.filter(({id:n})=>o.has(n)).forEach(n=>{Ha(n)?B(n,{boundElements:xk(n.boundElements,r)}):Et(n)&&B(n,{startBinding:$y(n.startBinding,r),endBinding:$y(n.endBinding,r)})})},$y=(e,t)=>e==null||t.has(e.elementId)?null:e,xk=(e,t)=>e?e.filter(r=>!t.has(r.id)):null});var En,K,Ek,ar=y(()=>{"use strict";h();Zt();ue();yt();Ve();Er();ko();W();ae();me();pt();X();Io();En={version:null,points:[],zoom:null},K=class e{elementId;selectedPointsIndices;pointerDownState;isDragging;lastUncommittedPoint;pointerOffset;startBindingElement;endBindingElement;hoverPointIndex;segmentMidPointHoveredCoords;constructor(t,r){this.elementId=t.id,xe.mapElementToScene(this.elementId,r),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){let r=xe.getScene(t)?.getNonDeletedElement(t);return r||null}static handleBoxSelection(t,r,o){if(!r.editingLinearElement||r.draggingElement?.type!=="selection")return!1;let{editingLinearElement:n}=r,{selectedPointsIndices:i,elementId:a}=n,l=e.getElement(a);if(!l)return!1;let[c,s,d,m]=ee(r.draggingElement),p=e.getPointsGlobalCoordinates(l).reduce((g,b,E)=>((b[0]>=c&&b[0]<=d&&b[1]>=s&&b[1]<=m||t.shiftKey&&i?.includes(E))&&g.push(E),g),[]);o({editingLinearElement:{...n,selectedPointsIndices:p.length?p:null}})}static handlePointDragging(t,r,o,n,i,a){if(!a)return!1;let{selectedPointsIndices:l,elementId:c}=a,s=e.getElement(c);if(!s)return!1;let d=s.points[a.pointerDownState.lastClickedPoint];if(l&&d){if(oa(t)&&l.length===1&&s.points.length>1){let u=l[0],p=s.points[u===0?1:u-1],[g,b]=e._getShiftLockedDelta(s,p,[o,n],t[S.CTRL_OR_CMD]?null:r.gridSize);e.movePoints(s,[{index:u,point:[g+p[0],b+p[1]],isDragging:u===a.pointerDownState.lastClickedPoint}])}else{let u=e.createPointAt(s,o-a.pointerOffset.x,n-a.pointerOffset.y,t[S.CTRL_OR_CMD]?null:r.gridSize),p=u[0]-d[0],g=u[1]-d[1];e.movePoints(s,l.map(b=>{let E=b===a.pointerDownState.lastClickedPoint?e.createPointAt(s,o-a.pointerOffset.x,n-a.pointerOffset.y,t[S.CTRL_OR_CMD]?null:r.gridSize):[s.points[b][0]+p,s.points[b][1]+g];return{index:b,point:E,isDragging:b===a.pointerDownState.lastClickedPoint}}))}if(le(s)&&la(s,!1),Et(s,!1)){let u=[];l[0]===0&&u.push(xo(e.getPointGlobalCoordinates(s,s.points[0])));let g=l[l.length-1];g===s.points.length-1&&u.push(xo(e.getPointGlobalCoordinates(s,s.points[g]))),u.length&&i(s,u)}return!0}return!1}static handlePointerUp(t,r,o){let{elementId:n,selectedPointsIndices:i,isDragging:a,pointerDownState:l}=r,c=e.getElement(n);if(!c)return r;let s={};if(a&&i){for(let d of i)if(d===0||d===c.points.length-1){xr(c.points,o.zoom.value)&&e.movePoints(c,[{index:d,point:d===0?c.points[c.points.length-1]:c.points[0]}]);let m=Uo(o)?Wo(xo(e.getPointAtIndexGlobalCoordinates(c,d)),xe.getScene(c)):null;s[d===0?"startBindingElement":"endBindingElement"]=m}}return{...r,...s,selectedPointsIndices:a||t.shiftKey?!a&&t.shiftKey&&l.prevSelectedPointsIndices?.includes(l.lastClickedPoint)?i&&i.filter(d=>d!==l.lastClickedPoint):i:i?.includes(l.lastClickedPoint)?[l.lastClickedPoint]:i,isDragging:!1,pointerOffset:{x:0,y:0}}}static getEditorMidPoints=(t,r)=>{let o=le(t);return!r.editingLinearElement&&t.points.length>2&&!o?[]:(En.version===t.version&&En.zoom===r.zoom.value||e.updateEditorMidPointsCache(t,r),En.points)};static updateEditorMidPointsCache=(t,r)=>{let o=e.getPointsGlobalCoordinates(t),n=0,i=[];for(;n<o.length-1;){if(e.isSegmentTooShort(t,t.points[n],t.points[n+1],r.zoom)){i.push(null),n++;continue}let a=e.getSegmentMidPoint(t,o[n],o[n+1],n+1);i.push(a),n++}En.points=i,En.version=t.version,En.zoom=r.zoom.value};static getSegmentMidpointHitCoords=(t,r,o)=>{let{elementId:n}=t,i=e.getElement(n);if(!i||e.getPointIndexUnderCursor(i,o.zoom,r.x,r.y)>=0||e.getPointsGlobalCoordinates(i).length>=3&&!o.editingLinearElement)return null;let c=e.POINT_HANDLE_SIZE/o.zoom.value,s=t.segmentMidPointHoveredCoords;if(s&&ct(s[0],s[1],r.x,r.y)<=c)return s;let d=0,m=e.getEditorMidPoints(i,o);for(;d<m.length;){if(m[d]!==null&&ct(m[d][0],m[d][1],r.x,r.y)<=c)return m[d];d++}return null};static isSegmentTooShort(t,r,o,n){let i=ct(r[0],r[1],o[0],o[1]);return t.points.length>2&&t.roundness&&(i=Qy(t,o)),i*n.value<e.POINT_HANDLE_SIZE*4}static getSegmentMidPoint(t,r,o,n){let i=Fs(r,o);if(t.points.length>2&&t.roundness){let a=Tg(t,t.points[n]);if(a){let l=ew(t,t.points[n],.5),[c,s]=Ig(a[0],a[1],a[2],a[3],l);i=e.getPointGlobalCoordinates(t,[c,s])}}return i}static getSegmentMidPointIndex(t,r,o){let n=e.getElement(t.elementId);if(!n)return-1;let i=e.getEditorMidPoints(n,r),a=0;for(;a<i.length;){if(e.arePointsEqual(o,i[a]))return a+1;a++}return-1}static handlePointerDown(t,r,o,n,i){let a={didAddPoint:!1,hitElement:null,linearElementEditor:null};if(!i)return a;let{elementId:l}=i,c=e.getElement(l);if(!c)return a;let s=e.getSegmentMidpointHitCoords(i,n,r),d=null;if(s&&(d=e.getSegmentMidPointIndex(i,r,s)),t.altKey&&r.editingLinearElement)return i.lastUncommittedPoint==null&&(B(c,{points:[...c.points,e.createPointAt(c,n.x,n.y,t[S.CTRL_OR_CMD]?null:r.gridSize)]}),a.didAddPoint=!0),o.resumeRecording(),a.linearElementEditor={...i,pointerDownState:{prevSelectedPointsIndices:i.selectedPointsIndices,lastClickedPoint:-1,origin:{x:n.x,y:n.y},segmentMidpoint:{value:s,index:d,added:!1}},selectedPointsIndices:[c.points.length-1],lastUncommittedPoint:null,endBindingElement:Wo(n,xe.getScene(c))},a.didAddPoint=!0,a;let m=e.getPointIndexUnderCursor(c,r.zoom,n.x,n.y);if(m>=0||s)a.hitElement=c;else{let{startBindingElement:k,endBindingElement:M}=i;Uo(r)&&Et(c)&&xn(c,k,M)}let[u,p,g,b]=ee(c),E=(u+g)/2,w=(p+b)/2,v=m>-1&&fe(c.x+c.points[m][0],c.y+c.points[m][1],E,w,c.angle),T=m>-1||t.shiftKey?t.shiftKey||i.selectedPointsIndices?.includes(m)?Ek([...i.selectedPointsIndices||[],m]):[m]:null;return a.linearElementEditor={...i,pointerDownState:{prevSelectedPointsIndices:i.selectedPointsIndices,lastClickedPoint:m,origin:{x:n.x,y:n.y},segmentMidpoint:{value:s,index:d,added:!1}},selectedPointsIndices:T,pointerOffset:v?{x:n.x-v[0],y:n.y-v[1]}:{x:0,y:0}},a}static arePointsEqual(t,r){return!t&&!r?!0:!t||!r?!1:Sg(t,r)}static handlePointerMove(t,r,o,n){if(!n.editingLinearElement)return null;let{elementId:i,lastUncommittedPoint:a}=n.editingLinearElement,l=e.getElement(i);if(!l)return n.editingLinearElement;let{points:c}=l,s=c[c.length-1];if(!t.altKey)return s===a&&e.deletePoints(l,[c.length-1]),{...n.editingLinearElement,lastUncommittedPoint:null};let d;if(oa(t)&&c.length>=2){let m=c[c.length-2],[u,p]=e._getShiftLockedDelta(l,m,[r,o],t[S.CTRL_OR_CMD]?null:n.gridSize);d=[u+m[0],p+m[1]]}else d=e.createPointAt(l,r-n.editingLinearElement.pointerOffset.x,o-n.editingLinearElement.pointerOffset.y,t[S.CTRL_OR_CMD]?null:n.gridSize);return s===a?e.movePoints(l,[{index:l.points.length-1,point:d}]):e.addPoints(l,n,[{point:d}]),{...n.editingLinearElement,lastUncommittedPoint:l.points[l.points.length-1]}}static getPointGlobalCoordinates(t,r){let[o,n,i,a]=ee(t),l=(o+i)/2,c=(n+a)/2,{x:s,y:d}=t;return[s,d]=fe(s+r[0],d+r[1],l,c,t.angle),[s,d]}static getPointsGlobalCoordinates(t){let[r,o,n,i]=ee(t),a=(r+n)/2,l=(o+i)/2;return t.points.map(c=>{let{x:s,y:d}=t;return[s,d]=fe(s+c[0],d+c[1],a,l,t.angle),[s,d]})}static getPointAtIndexGlobalCoordinates(t,r){let o=r<0?t.points.length+r:r,[n,i,a,l]=ee(t),c=(n+a)/2,s=(i+l)/2,d=t.points[o],{x:m,y:u}=t;return d?fe(m+d[0],u+d[1],c,s,t.angle):fe(m,u,c,s,t.angle)}static pointFromAbsoluteCoords(t,r){let[o,n,i,a]=ee(t),l=(o+i)/2,c=(n+a)/2,[s,d]=fe(r[0],r[1],l,c,-t.angle);return[s-t.x,d-t.y]}static getPointIndexUnderCursor(t,r,o,n){let i=e.getPointsGlobalCoordinates(t),a=i.length;for(;--a>-1;){let l=i[a];if(ct(o,n,l[0],l[1])*r.value<e.POINT_HANDLE_SIZE+1)return a}return-1}static createPointAt(t,r,o,n){let i=wt(r,o,n),[a,l,c,s]=ee(t),d=(a+c)/2,m=(l+s)/2,[u,p]=fe(i[0],i[1],d,m,-t.angle);return[u-t.x,p-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){B(t,e.getNormalizedPoints(t))}static duplicateSelectedPoints(t){if(!t.editingLinearElement)return!1;let{selectedPointsIndices:r,elementId:o}=t.editingLinearElement,n=e.getElement(o);if(!n||r===null)return!1;let{points:i}=n,a=[],l=!1,c=-1,s=i.reduce((d,m,u)=>{if(++c,d.push(m),r.includes(u)){let g=i[u+1];g||(l=!0),d.push(g?[(m[0]+g[0])/2,(m[1]+g[1])/2]:[m[0],m[1]]),a.push(c+1),++c}return d},[]);if(B(n,{points:s}),l){let d=n.points[n.points.length-1];e.movePoints(n,[{index:n.points.length-1,point:[d[0]+30,d[1]+30]}])}return{appState:{...t,editingLinearElement:{...t.editingLinearElement,selectedPointsIndices:a}}}}static deletePoints(t,r){let o=0,n=0;if(r.includes(0)){let l=t.points.find((c,s)=>!r.includes(s));l&&(o=l[0],n=l[1])}let a=t.points.reduce((l,c,s)=>(r.includes(s)||l.push(l.length?[c[0]-o,c[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:s})=>s===0);l&&(i=l.point[0]+n[l.index][0],a=l.point[1]+n[l.index][1]);let c=n.map((s,d)=>{let m=r.find(u=>u.index===d);if(m){if(l)return s;let u=m.point[0]-n[m.index][0],p=m.point[1]-n[m.index][1];return[s[0]+u,s[1]+p]}return i||a?[s[0]-i,s[1]-a]:s});e._updatePoints(t,c,i,a,o)}static shouldAddMidpoint(t,r,o){if(!e.getElement(t.elementId))return!1;let{segmentMidpoint:i}=t.pointerDownState;if(i.added||i.value===null||i.index===null||t.pointerDownState.origin===null)return!1;let a=t.pointerDownState.origin,l=ct(a.x,a.y,r.x,r.y);return!(!o.editingLinearElement&&l<on/o.zoom.value)}static addMidpoint(t,r,o,n){let i=e.getElement(t.elementId);if(!i)return;let{segmentMidpoint:a}=t.pointerDownState,l={pointerDownState:t.pointerDownState,selectedPointsIndices:t.selectedPointsIndices},c=e.createPointAt(i,r.x,r.y,n?o.gridSize:null),s=[...i.points.slice(0,a.index),c,...i.points.slice(a.index)];return B(i,{points:s}),l.pointerDownState={...t.pointerDownState,segmentMidpoint:{...t.pointerDownState.segmentMidpoint,added:!0},lastClickedPoint:a.index},l.selectedPointsIndices=[a.index],l}static _updatePoints(t,r,o,n,i){let a=fl(t,r),l=fl(t,t.points),c=(a[0]+a[2])/2,s=(a[1]+a[3])/2,d=(l[0]+l[2])/2,m=(l[1]+l[3])/2,u=d-c,p=m-s,g=fe(o,n,u,p,t.angle);B(t,{...i,points:r,x:t.x+g[0],y:t.y+g[1]})}static _getShiftLockedDelta(t,r,o,n){let i=e.getPointGlobalCoordinates(t,r),[a,l]=wt(o[0],o[1],n),{width:c,height:s}=bl(i[0],i[1],a,l);return Fe([c,s],[0,0],-t.angle)}static getBoundTextElementPosition=(t,r)=>{let o=e.getPointsGlobalCoordinates(t);o.length<2&&B(r,{isDeleted:!0});let n=0,i=0;if(t.points.length%2===1){let a=Math.floor(t.points.length/2),l=e.getPointGlobalCoordinates(t,t.points[a]);n=l[0]-r.width/2,i=l[1]-r.height/2}else{let a=t.points.length/2-1,l=En.points[a];t.points.length===2&&(l=Fs(o[0],o[1])),(!l||En.version!==t.version)&&(l=e.getSegmentMidPoint(t,o[a],o[a+1],a+1)),n=l[0]-r.width/2,i=l[1]-r.height/2}return{x:n,y:i}};static getMinMaxXYWithBoundText=(t,r,o)=>{let[n,i,a,l]=r,c=(n+a)/2,s=(i+l)/2,{x:d,y:m}=e.getBoundTextElementPosition(t,o),u=d+o.width,p=m+o.height,g=Fe([n,i],[c,s],t.angle),b=Fe([a,i],[c,s],t.angle),E=Fe([d,m],[c,s],-t.angle),w=Fe([u,m],[c,s],-t.angle),v=Fe([d,p],[c,s],-t.angle),T=Fe([u,p],[c,s],-t.angle);return g[0]<b[0]&&g[1]>=b[1]?(n=Math.min(n,v[0]),a=Math.max(a,Math.max(w[0],T[0])),i=Math.min(i,E[1]),l=Math.max(l,T[1])):g[0]>=b[0]&&g[1]>b[1]?(n=Math.min(n,T[0]),a=Math.max(a,Math.max(E[0],w[0])),i=Math.min(i,v[1]),l=Math.max(l,w[1])):g[0]>=b[0]?(n=Math.min(n,w[0]),a=Math.max(a,v[0]),i=Math.min(i,T[1]),l=Math.max(l,E[1])):g[1]<=b[1]&&(n=Math.min(n,Math.min(w[0],E[0])),a=Math.max(a,T[0]),i=Math.min(i,w[1]),l=Math.max(l,v[1])),[n,i,a,l,c,s]};static getElementAbsoluteCoords=(t,r=!1)=>{let o,n,i,a,l;if(t.points.length<2||!Te.get(t)){let{minX:m,minY:u,maxX:p,maxY:g}=t.points.reduce((b,[E,w])=>(b.minY=Math.min(b.minY,w),b.minX=Math.min(b.minX,E),b.maxX=Math.max(b.maxX,E),b.maxY=Math.max(b.maxY,w),b),{minX:1/0,minY:1/0,maxX:-1/0,maxY:-1/0});n=m+t.x,i=u+t.y,a=p+t.x,l=g+t.y}else{let m=Te.generateElementShape(t,null),u=So(m[0]),[p,g,b,E]=Hs(u);n=p+t.x,i=g+t.y,a=b+t.x,l=E+t.y}let c=(n+a)/2,s=(i+l)/2;if(o=[n,i,a,l,c,s],!r)return o;let d=le(t);return d&&(o=e.getMinMaxXYWithBoundText(t,[n,i,a,l],d)),o}},Ek=e=>{let t=[...new Set(e.filter(r=>r!==null&&r!==-1))];return t=t.sort((r,o)=>r-o),t.length?t:null}});import tw from"clsx";import{jsx as Cg,jsxs as yk}from"react/jsx-runtime";var Vo,rw=y(()=>{"use strict";h();Vo=e=>Cg("div",{className:"buttonList buttonListIcon",children:e.options.map(t=>e.type==="button"?Cg("button",{onClick:r=>e.onClick(t.value,r),className:tw({active:t.active??e.value===t.value}),"data-testid":t.testId,title:t.text,children:t.icon},t.text):yk("label",{className:tw({active:e.value===t.value}),title:t.text,children:[Cg("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 wk from"clsx";import{jsx as kg}from"react/jsx-runtime";var ow,nw=y(()=>{"use strict";h();Yt();ow=({onChange:e,type:t,activeColor:r,topPicks:o})=>{let n;return t==="elementStroke"&&(n=Xc),t==="elementBackground"&&(n=Zc),t==="canvasBackground"&&(n=jc),o&&(n=o),n?kg("div",{className:"color-picker__top-picks",children:n.map(i=>kg("button",{className:wk("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:kg("div",{className:"color-picker__button-outline"})},i))}):(console.error("Invalid type for TopPicks"),null)}});import{atom as vk}from"jotai";var ci,zs,Ag,aw,to,iw,lw,yn=y(()=>{"use strict";h();Yt();ci=({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},zs=[["q","w","e","r","t"],["a","s","d","f","g"],["z","x","c","v","b"]].flat(),Ag=({color:e,palette:t})=>!Object.values(t).flat().includes(e),aw=(e,t,r)=>{let o={elementBackground:"backgroundColor",elementStroke:"strokeColor"},n=e.filter(a=>{if(a.isDeleted)return!1;let l=a[o[t]];return Ag({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,Pb)},to=vk(null),iw=(e,t,r)=>(e*299+t*587+r*114)/1e3>=160?"black":"white",lw=(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]),c=parseInt(a[1]),s=parseInt(a[2]);return iw(l,c,s)}}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 iw(r,o,n)}});import{jsxs as Ik}from"react/jsx-runtime";var Tk,xl,im=y(()=>{"use strict";h();yn();Tk=({color:e,keyLabel:t,isCustomColor:r=!1,isShade:o=!1})=>Ik("div",{className:"color-picker__button__hotkey-label",style:{color:lw(e,r)},children:[o&&"\u21E7",t]}),xl=Tk});import Sk from"clsx";import{useAtom as Ck}from"jotai";import{useEffect as kk,useRef as Ak}from"react";import{jsx as Gs,jsxs as sw}from"react/jsx-runtime";var cw,dw=y(()=>{"use strict";h();yn();im();Y();cw=({hex:e,onChange:t,palette:r})=>{let o=ci({color:e||"transparent",palette:r}),[n,i]=Ck(to),a=Ak(null);if(kk(()=>{a.current&&n==="shades"&&a.current.focus()},[o,n]),o){let{colorName:l,shade:c}=o,s=r[l];if(Array.isArray(s))return Gs("div",{className:"color-picker-content--default shades",children:s.map((d,m)=>sw("button",{ref:m===c&&n==="shades"?a:void 0,tabIndex:-1,type:"button",className:Sk("color-picker__button color-picker__button--large",{active:m===c}),"aria-label":"Shade",title:`${l} - ${m+1}`,style:d?{"--swatch-color":d}:void 0,onClick:()=>{t(d),i("shades")},children:[Gs("div",{className:"color-picker__button-outline"}),Gs(xl,{color:d,keyLabel:m+1,isShade:!0})]},m))})}return sw("div",{className:"color-picker-content--default",style:{position:"relative"},tabIndex:-1,children:[Gs("button",{type:"button",tabIndex:-1,className:"color-picker__button color-picker__button--large color-picker__button--no-focus-visible"}),Gs("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:f("colorPicker.noShades")})]})}});import Mk from"clsx";import{useAtom as Lk}from"jotai";import{useEffect as _k,useRef as Pk}from"react";import{jsx as Mg,jsxs as Rk}from"react/jsx-runtime";var Dk,mw,uw=y(()=>{"use strict";h();yn();im();Y();Dk=({palette:e,color:t,onChange:r,label:o,activeShade:n})=>{let i=ci({color:t||"transparent",palette:e}),[a,l]=Lk(to),c=Pk(null);return _k(()=>{c.current&&a==="baseColors"&&c.current.focus()},[i?.colorName,a]),Mg("div",{className:"color-picker-content--default",children:Object.entries(e).map(([s,d],m)=>{let u=(Array.isArray(d)?d[n]:d)||"transparent",p=zs[m],g=f(`colors.${s.replace(/\d+/,"")}`,null,"");return Rk("button",{ref:i?.colorName===s?c:void 0,tabIndex:-1,type:"button",className:Mk("color-picker__button color-picker__button--large",{active:i?.colorName===s,"is-transparent":u==="transparent"||!u}),onClick:()=>{r(u),l("baseColors")},title:`${g}${u.startsWith("#")?` ${u}`:""} \u2014 ${p}`,"aria-label":`${g} \u2014 ${p}`,style:u?{"--swatch-color":u}:void 0,"data-testid":`color-${s}`,children:[Mg("div",{className:"color-picker__button-outline"}),Mg(xl,{color:u,keyLabel:p})]},s)})})},mw=Dk});import Nk from"clsx";import{useAtom as Bk}from"jotai";import{useEffect as Ok,useRef as Fk}from"react";import{jsx as Lg,jsxs as Hk}from"react/jsx-runtime";var pw,gw=y(()=>{"use strict";h();yn();im();pw=({colors:e,color:t,onChange:r,label:o})=>{let[n,i]=Bk(to),a=Fk(null);return Ok(()=>{a.current&&a.current.focus()},[t,n]),Lg("div",{className:"color-picker-content--default",children:e.map((l,c)=>Hk("button",{ref:t===l?a:void 0,tabIndex:-1,type:"button",className:Nk("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:[Lg("div",{className:"color-picker__button-outline"}),Lg(xl,{color:l,keyLabel:c+1,isCustomColor:!0})]},c))})}});var _g,zk,hw,fw=y(()=>{"use strict";h();me();Yt();yn();_g=(e,t,r)=>{let o=Math.ceil(r/Ui);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+Ui;return n>=r?t%Ui:n}case"ArrowUp":{let n=t-Ui,i=n<0?Ui*o+n:n;return i>=r?void 0:i}}},zk=({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(zs.includes(e.key)){let l=zs.indexOf(e.key),c=Object.keys(o)[l],s=o[c],d=Array.isArray(s)?s[a]:s;return r(d),i("baseColors"),!0}return!1},hw=({event:e,activeColorPickerSection:t,palette:r,color:o,onChange:n,customColors:i,setActiveColorPickerSection:a,updateData:l,activeShade:c,onEyeDropperToggle:s,onEscape:d})=>{if(e[S.CTRL_OR_CMD])return!1;if(e.key===S.ESCAPE)return d(e),!0;if(e.key===S.ALT)return s(!0),!0;if(e.key===S.I)return s(),!0;let m=ci({color:o,palette:r});if(e.key===S.TAB){let u={custom:!!i.length,baseColors:!0,shades:m?.shade!=null,hex:!0},p=Object.entries(u).reduce((v,[T,k])=>(k&&v.push(T),v),[]),g=p.indexOf(t),b=e.shiftKey?-1:1,E=g+b>p.length-1?0:g+b<0?p.length-1:g+b,w=p[E];return w&&a(w),w==="custom"?n(i[0]):w==="baseColors"&&(Object.entries(r).find(([T,k])=>Array.isArray(k)?k.includes(o):k===o?T:null)||n(oe.black)),e.preventDefault(),e.stopPropagation(),!0}if(zk({e,colorObj:m,onChange:n,palette:r,customColors:i,setActiveColorPickerSection:a,activeShade:c}))return!0;if(t==="shades"&&m){let{shade:u}=m,p=_g(e.key,u,Ui);if(p!==void 0)return n(r[m.colorName][p]),!0}if(t==="baseColors"&&m){let{colorName:u}=m,p=Object.keys(r),g=p.indexOf(u),b=_g(e.key,g,p.length);if(b!==void 0){let E=p[b],w=r[E];return n(Array.isArray(w)?w[c]:w),!0}}if(t==="custom"){let u=i.indexOf(o),p=_g(e.key,u,i.length);if(p!==void 0){let g=i[p];return n(g),!0}}return!1}});import{jsx as Uk}from"react/jsx-runtime";var Gk,El,Pg=y(()=>{"use strict";h();Gk=({children:e})=>Uk("div",{className:"color-picker__heading",children:e}),El=Gk});import bw,{useEffect as xw,useState as Wk}from"react";import{useAtom as Vk}from"jotai";import{jsx as sa,jsxs as am}from"react/jsx-runtime";var Ew,yw=y(()=>{"use strict";h();Y();dw();uw();gw();fw();Pg();yn();Yt();me();X();Ew=({color:e,onChange:t,label:r,type:o,elements:n,palette:i,updateData:a,children:l,onEyeDropperToggle:c,onEscape:s})=>{let[d]=bw.useState(()=>o==="canvasBackground"?[]:aw(n,o,i)),[m,u]=Vk(to),p=ci({color:e,palette:i});xw(()=>{if(!m){let w=Ag({color:e,palette:i}),v=w&&!d.includes(e);u(v?"hex":w?"custom":p?.shade!=null?"shades":"baseColors")}},[m,e,i,u,p,d]);let[g,b]=Wk(p?.shade??(o==="elementBackground"?_a:La));xw(()=>{p?.shade!=null&&b(p.shade);let w=v=>{v.key===S.ALT&&c(!1)};return document.addEventListener("keyup",w,{capture:!0}),()=>{document.removeEventListener("keyup",w,{capture:!0})}},[p,c]);let E=bw.useRef(null);return sa("div",{role:"dialog","aria-modal":"true","aria-label":f("labels.colorPicker"),children:am("div",{ref:E,onKeyDown:w=>{hw({event:w,activeColorPickerSection:m,palette:i,color:e,onChange:t,onEyeDropperToggle:c,customColors:d,setActiveColorPickerSection:u,updateData:a,activeShade:g,onEscape:s})&&(w.preventDefault(),w.stopPropagation())},className:"color-picker-content",tabIndex:-1,children:[!!d.length&&am("div",{children:[sa(El,{children:f("colorPicker.mostUsedCustomColors")}),sa(pw,{colors:d,color:e,label:f("colorPicker.mostUsedCustomColors"),onChange:t})]}),am("div",{children:[sa(El,{children:f("colorPicker.colors")}),sa(mw,{color:e,label:r,palette:i,onChange:t,activeShade:g})]}),am("div",{children:[sa(El,{children:f("colorPicker.shades")}),sa(cw,{hex:e,onChange:t,palette:i})]}),l]})})}});import ww from"react";var Dg,He,zt=y(()=>{"use strict";h();Dg=ww.createContext(null),He=()=>ww.useContext(Dg)});import{useState as Yk,useLayoutEffect as vw}from"react";var lm,Rg=y(()=>{"use strict";h();be();zt();lm=e=>{let[t,r]=Yk(null),o=De(),{theme:n}=He(),{container:i}=Nt();return vw(()=>{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==="dark"))},[t,n,o.editor.isMobile,e?.className]),vw(()=>{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 Kk}from"react";function yl(e,t,r){Kk(()=>{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 sm=y(()=>{"use strict";h();X()});import{useRef as $k}from"react";var Tw,Iw=y(()=>{"use strict";h();Tw=e=>{let t=$k(e);return Object.assign(t.current,e),t.current}});var Sw=y(()=>{});import{atom as Xk}from"jotai";import{useEffect as Zk,useRef as jk}from"react";import{createPortal as qk}from"react-dom";import{jsx as Jk}from"react/jsx-runtime";var di,Cw,Us=y(()=>{"use strict";h();Yt();X();zt();Rg();sm();me();Ze();be();Iw();Sw();di=Xk(null),Cw=({onCancel:e,onChange:t,onSelect:r,colorPickerType:o})=>{let n=lm({className:"excalidraw-eye-dropper-backdrop",parentSelector:".excalidraw-eye-dropper-container"}),i=He(),a=mi(),l=ro(),c=ge(a,i),s=Tw({app:l,onCancel:e,onChange:t,onSelect:r,selectedElements:c}),{container:d}=Nt();Zk(()=>{let u=m.current;if(!u||!l.canvas||!n)return;let p=!1,g=l.canvas.getContext("2d"),b=({clientX:A,clientY:D})=>{let R=g.getImageData((A-i.offsetLeft)*window.devicePixelRatio,(D-i.offsetTop)*window.devicePixelRatio,1,1).data;return Fb(R[0],R[1],R[2])},E=({clientX:A,clientY:D,altKey:R})=>{u.style.top=`${D+20}px`,u.style.left=`${A+20}px`;let H=b({clientX:A,clientY:D});p&&s.onChange(o,H,s.selectedElements,{altKey:R}),u.style.background=H},w=()=>{s.onCancel()},v=(A,D)=>{s.onSelect(A,D)},T=A=>{p=!0,A.stopImmediatePropagation()},k=A=>{p=!1,d?.focus(),A.stopImmediatePropagation(),A.preventDefault(),v(b(A),A)},M=A=>{A.key===S.ESCAPE&&(A.preventDefault(),A.stopImmediatePropagation(),w())};return n.tabIndex=-1,n.focus(),E({clientX:s.app.lastViewportPosition.x,clientY:s.app.lastViewportPosition.y,altKey:!1}),n.addEventListener("keydown",M),n.addEventListener("pointerdown",T),n.addEventListener("pointerup",k),window.addEventListener("pointermove",E,{passive:!0}),window.addEventListener("blur",w),()=>{p=!1,n.removeEventListener("keydown",M),n.removeEventListener("pointerdown",T),n.removeEventListener("pointerup",k),window.removeEventListener("pointermove",E),window.removeEventListener("blur",w)}},[s,l.canvas,n,o,d,i.offsetLeft,i.offsetTop]);let m=jk(null);return yl(m,()=>{e()},u=>!!u.target.closest(".excalidraw-eye-dropper-trigger, .excalidraw-eye-dropper-backdrop")),n?qk(Jk("div",{ref:m,className:"excalidraw-eye-dropper-preview"}),n):null}});import{useCallback as Qk,useEffect as Ng,useRef as kw,useState as eA}from"react";import{useAtom as Aw}from"jotai";import tA from"clsx";import{Fragment as rA,jsx as cm,jsxs as Mw}from"react/jsx-runtime";var Lw,_w=y(()=>{"use strict";h();dm();yn();se();_t();me();Us();Y();be();W();Lw=({color:e,onChange:t,label:r,colorPickerType:o})=>{let n=De(),[i,a]=eA(e),[l,c]=Aw(to);Ng(()=>{a(e)},[e]);let s=Qk(g=>{let b=g.toLowerCase(),E=Pw(b);E&&t(E),a(b)},[t]),d=kw(null),m=kw(null);Ng(()=>{d.current&&d.current.focus()},[l]);let[u,p]=Aw(di,Be);return Ng(()=>()=>{p(null)},[p]),Mw("div",{className:"color-picker__input-label",children:[cm("div",{className:"color-picker__input-hash",children:"#"}),cm("input",{ref:l==="hex"?d:void 0,style:{border:0,padding:0},spellCheck:!1,className:"color-picker-input","aria-label":r,onChange:g=>{s(g.target.value)},value:(i||"").replace(/^#/,""),onBlur:()=>{a(e)},tabIndex:-1,onFocus:()=>c("hex"),onKeyDown:g=>{g.key!==S.TAB&&(g.key===S.ESCAPE&&m.current?.focus(),g.stopPropagation())}}),!n.editor.isMobile&&Mw(rA,{children:[cm("div",{style:{width:"1px",height:"1.25rem",backgroundColor:"var(--default-border-color)"}}),cm("div",{ref:m,className:tA("excalidraw-eye-dropper-trigger",{selected:u}),onClick:()=>p(g=>g?null:{keepOpenOnAlt:!1,onSelect:b=>t(b),colorPickerType:o}),title:`${f("labels.eyeDropper")} \u2014 ${S.I.toLocaleUpperCase()} or ${_("Alt")} `,children:Y0})]})]})}});var Dw=y(()=>{});import*as Yo from"@radix-ui/react-popover";import{useAtom as Rw}from"jotai";import oA from"clsx";import{useRef as nA}from"react";import{jsx as oo,jsxs as mm}from"react/jsx-runtime";var Nw,Pw,iA,aA,Ws,dm=y(()=>{"use strict";h();W();nw();yw();yn();be();Yt();Pg();Y();_t();_w();Us();Dw();Nw=e=>{let t=new Option().style;return t.color=e,!!t.color},Pw=e=>or(e)?e:Nw(`#${e}`)?`#${e}`:Nw(e)?e:null,iA=({type:e,color:t,onChange:r,label:o,elements:n,palette:i=oe,updateData:a})=>{let[,l]=Rw(to),[c,s]=Rw(di,Be),{container:d}=Nt(),m=De(),u=mm("div",{children:[oo(El,{children:f("colorPicker.hexCode")}),oo(Lw,{color:t,label:o,onChange:b=>{r(b)},colorPickerType:e})]}),p=nA(null),g=()=>{p.current?.querySelector(".color-picker-content")?.focus()};return oo(Yo.Portal,{container:d,children:mm(Yo.Content,{ref:p,className:"focus-visible-none","data-prevent-outside-click":!0,onFocusOutside:b=>{g(),b.preventDefault()},onPointerDownOutside:b=>{c&&b.preventDefault()},onCloseAutoFocus:b=>{b.stopPropagation(),b.preventDefault(),d&&!px(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?oo(Ew,{palette:i,color:t,onChange:b=>{r(b)},onEyeDropperToggle:b=>{s(E=>b?(E=E||{keepOpenOnAlt:!0,onSelect:r,colorPickerType:e},E.keepOpenOnAlt=!0,E):b===!1||E?null:{keepOpenOnAlt:!1,onSelect:r,colorPickerType:e})},onEscape:b=>{c?s(null):Oo(b.target)?g():a({openPopup:null})},label:o,type:e,elements:n,updateData:a,children:u}):u,oo(Yo.Arrow,{width:20,height:10,style:{fill:"var(--popup-bg-color)",filter:"drop-shadow(rgba(0, 0, 0, 0.05) 0px 3px 2px)"}})]})})},aA=({label:e,color:t,type:r})=>oo(Yo.Trigger,{type:"button",className:oA("color-picker__button active-color",{"is-transparent":t==="transparent"||!t}),"aria-label":e,style:t?{"--swatch-color":t}:void 0,title:r==="elementStroke"?f("labels.showStroke"):f("labels.showBackground"),children:oo("div",{className:"color-picker__button-outline"})}),Ws=({type:e,color:t,onChange:r,label:o,elements:n,palette:i=oe,topPicks:a,updateData:l,appState:c})=>oo("div",{children:mm("div",{role:"dialog","aria-modal":"true",className:"color-picker-container",children:[oo(ow,{activeColor:t,onChange:r,type:e,topPicks:a}),oo("div",{style:{width:1,height:"100%",backgroundColor:"var(--default-border-color)",margin:"0 auto"}}),mm(Yo.Root,{open:c.openPopup===e,onOpenChange:s=>{l({openPopup:s?e:null})},children:[oo(aA,{color:t,label:o,type:e}),c.openPopup===e&&oo(iA,{type:e,color:t,onChange:r,label:o,elements:n,palette:i,updateData:l})]})]})})});var Bw=y(()=>{});import{useLayoutEffect as lA,useRef as Ow,useEffect as Fw}from"react";import{unstable_batchedUpdates as sA}from"react-dom";import{jsx as cA}from"react/jsx-runtime";var um,Bg=y(()=>{"use strict";h();Bw();W();me();um=({children:e,left:t,top:r,onCloseRequest:o,fitInViewport:n=!1,offsetLeft:i=0,offsetTop:a=0,viewportWidth:l=window.innerWidth,viewportHeight:c=window.innerHeight})=>{let s=Ow(null);Fw(()=>{let m=s.current;if(!m)return;m.contains(document.activeElement)||m.focus();let u=p=>{if(p.key===S.TAB){let g=gs(m),{activeElement:b}=document,E=g.findIndex(w=>w===b);b===m?(p.shiftKey?g[g.length-1]?.focus():g[0].focus(),p.preventDefault(),p.stopImmediatePropagation()):E===0&&p.shiftKey?(g[g.length-1]?.focus(),p.preventDefault(),p.stopImmediatePropagation()):E===g.length-1&&!p.shiftKey&&(g[0]?.focus(),p.preventDefault(),p.stopImmediatePropagation())}};return m.addEventListener("keydown",u),()=>m.removeEventListener("keydown",u)},[]);let d=Ow(null);return lA(()=>{if(n&&s.current&&r!=null&&t!=null){let m=s.current,{width:u,height:p}=m.getBoundingClientRect();if(d.current?.top===r&&d.current?.left===t)return;d.current={top:r,left:t},u>=l?(m.style.width=`${l}px`,m.style.left="0px",m.style.overflowX="scroll"):t+u-i>l?m.style.left=`${l-u-10}px`:m.style.left=`${t}px`,p>=c?(m.style.height=`${c-20}px`,m.style.top="10px",m.style.overflowY="scroll"):r+p-a>c?m.style.top=`${c-p}px`:m.style.top=`${r}px`}},[r,t,n,l,c,i,a]),Fw(()=>{if(o){let m=u=>{s.current?.contains(u.target)||sA(()=>o(u))};return document.addEventListener("pointerdown",m,!1),()=>document.removeEventListener("pointerdown",m,!1)}},[o]),cA("div",{className:"popover",ref:s,tabIndex:-1,children:e})}});var Hw=y(()=>{});import ca from"react";import dA from"clsx";import{Fragment as uA,jsx as ui,jsxs as Og}from"react/jsx-runtime";function mA({options:e,value:t,label:r,onChange:o,onClose:n}){let i=ca.useRef(),a=ca.useRef(),l=ca.useRef(null);return ca.useEffect(()=>{a.current?a.current.focus():l.current&&l.current.focus()},[]),ui("div",{className:"picker",role:"dialog","aria-modal":"true","aria-label":r,onKeyDown:s=>{let d=e.find(m=>m.keyBinding===s.key.toLowerCase());if(!(s.metaKey||s.altKey||s.ctrlKey)&&d){let m=e.indexOf(d);l.current.children[m].focus(),s.preventDefault()}else if(s.key===S.TAB)setTimeout(()=>{let m=a.current,u=document.activeElement;m!==u&&n()},0);else if(el(s.key)){let{activeElement:m}=document,u=rn().rtl,p=Array.prototype.indexOf.call(l.current.children,m);if(p!==-1){let g=e.length,b=p;switch(s.key){case(u?S.ARROW_LEFT:S.ARROW_RIGHT):case S.ARROW_DOWN:{b=(p+1)%g;break}case(u?S.ARROW_RIGHT:S.ARROW_LEFT):case S.ARROW_UP:{b=(g+p-1)%g;break}}l.current.children[b].focus()}s.preventDefault()}else(s.key===S.ESCAPE||s.key===S.ENTER)&&(s.preventDefault(),n());s.nativeEvent.stopImmediatePropagation(),s.stopPropagation()},children:ui("div",{className:"picker-content",ref:l,children:e.map((s,d)=>Og("button",{className:dA("picker-option",{active:t===s.value}),onClick:m=>{m.currentTarget.focus(),o(s.value)},title:`${s.text} ${s.keyBinding&&`\u2014 ${s.keyBinding.toUpperCase()}`}`,"aria-label":s.text||"none","aria-keyshortcuts":s.keyBinding||void 0,ref:m=>{m&&d===0&&(i.current=m),m&&s.value===t&&(a.current=m)},onFocus:()=>{o(s.value)},children:[s.icon,s.keyBinding&&ui("span",{className:"picker-keybinding",children:s.keyBinding})]},s.text))})})}function Fg({value:e,label:t,options:r,onChange:o,group:n=""}){let[i,a]=ca.useState(!1),l=ca.useRef(null),c=rn().rtl;return Og("div",{children:[ui("button",{name:n,className:i?"active":"","aria-label":t,onClick:()=>a(!i),ref:l,children:r.find(s=>s.value===e)?.icon}),ui(ca.Suspense,{fallback:"",children:i?Og(uA,{children:[ui(um,{onCloseRequest:s=>s.target!==l.current&&a(!1),...c?{right:5.5}:{left:-5.5},children:ui(mA,{options:r.filter(s=>s.showInPicker!==!1),value:e,label:t,onChange:o,onClose:()=>{a(!1),l.current?.focus()}})}),ui("div",{className:"picker-triangle"})]}):null})]})}var zw=y(()=>{"use strict";h();Bg();Hw();me();Y()});var wn,Vs,pm,gm,wl,da,vg,Hg,Ys=y(()=>{"use strict";h();ae();wn=e=>e==="rectangle"||e==="iframe"||e==="embeddable"||e==="ellipse"||e==="diamond"||e==="line"||e==="freedraw",Vs=e=>e!=="image"&&e!=="frame"&&e!=="magicframe",pm=e=>e==="rectangle"||e==="iframe"||e==="embeddable"||e==="ellipse"||e==="diamond"||e==="freedraw"||e==="arrow"||e==="line",gm=e=>e==="rectangle"||e==="iframe"||e==="embeddable"||e==="ellipse"||e==="diamond"||e==="arrow"||e==="line",wl=e=>e==="rectangle"||e==="iframe"||e==="embeddable"||e==="arrow"||e==="line"||e==="diamond",da=e=>e==="arrow",vg=(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},Hg=(e,t)=>{let r=[];return e.filter(n=>!n.isDeleted&&t(n)?Kr(n)?(r.push(n),!1):!0:!1).concat(r)}});import{Fragment as Ww,jsx as Ie,jsxs as Nr}from"react/jsx-runtime";var Uw,Br,yr,pA,zg,gA,hA,fA,bA,xA,_G,EA,yA,Gg,Ug,wA,vA,TA,PG,Gw,DG,Wg=y(()=>{"use strict";h();Yt();Qr();rw();dm();zw();se();X();ue();Ve();pt();ae();Y();me();yo();Ze();Ys();W();We();Uw=.1,Br=(e,t,r,o=!1)=>{let n=Ce(ge(e,t,{includeBoundTextElement:o}));return e.map(i=>n.get(i.id)||i.id===t.editingElement?.id?r(i):i)},yr=function(e,t,r,o,n){let i=t.editingElement,a=ce(e),l=null;return i&&(l=r(i)),l||(ze(a,t)?l=Vg(o===!0?a:a.filter(s=>o(s)),t,r)??(typeof n=="function"?n(!0):n):l=typeof n=="function"?n(!1):n),l},pA=(e,t)=>ke(t)?t:B(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),zg=(e,t,r,o)=>{let n=new Set;return{elements:Br(e,t,i=>{if(z(i)){let a=r(i);n.add(a);let l=Q(i,{fontSize:a});return Gt(l,je(i)),l=pA(i,l),l}return i},!0),appState:{...t,currentItemFontSize:n.size===1?[...n][0]:o??t.currentItemFontSize},commitToHistory:!0}},gA=N({name:"changeStrokeColor",trackEvent:!1,perform:(e,t,r)=>({...r.currentItemStrokeColor&&{elements:Br(e,t,o=>Vs(o.type)?Q(o,{strokeColor:r.currentItemStrokeColor}):o,!0)},appState:{...t,...r},commitToHistory:!!r.currentItemStrokeColor}),PanelComponent:({elements:e,appState:t,updateData:r,appProps:o})=>Nr(Ww,{children:[Ie("h3",{"aria-hidden":"true",children:f("labels.stroke")}),Ie(Ws,{topPicks:Xc,palette:Nb,type:"elementStroke",label:f("labels.stroke"),color:yr(e,t,n=>n.strokeColor,!0,t.currentItemStrokeColor),onChange:n=>r({currentItemStrokeColor:n}),elements:e,appState:t,updateData:r})]})}),hA=N({name:"changeBackgroundColor",trackEvent:!1,perform:(e,t,r)=>({...r.currentItemBackgroundColor&&{elements:Br(e,t,o=>Q(o,{backgroundColor:r.currentItemBackgroundColor}))},appState:{...t,...r},commitToHistory:!!r.currentItemBackgroundColor}),PanelComponent:({elements:e,appState:t,updateData:r,appProps:o})=>Nr(Ww,{children:[Ie("h3",{"aria-hidden":"true",children:f("labels.background")}),Ie(Ws,{topPicks:Zc,palette:Bb,type:"elementBackground",label:f("labels.background"),color:yr(e,t,n=>n.backgroundColor,!0,t.currentItemBackgroundColor),onChange:n=>r({currentItemBackgroundColor:n}),elements:e,appState:t,updateData:r})]})}),fA=N({name:"changeFillStyle",trackEvent:!1,perform:(e,t,r,o)=>(Ee("element","changeFillStyle",`${r} (${o.device.editor.isMobile?"mobile":"desktop"})`),{elements:Br(e,t,n=>Q(n,{fillStyle:r})),appState:{...t,currentItemFillStyle:r},commitToHistory:!0}),PanelComponent:({elements:e,appState:t,updateData:r})=>{let o=ge(e,t),n=o.length>0&&o.every(i=>i.fillStyle==="zigzag");return Nr("fieldset",{children:[Ie("legend",{children:f("labels.fill")}),Ie(Vo,{type:"button",options:[{value:"hachure",text:`${n?f("labels.zigzag"):f("labels.hachure")} (${_("Alt-Click")})`,icon:n?s0:c0,active:n?!0:void 0,testId:"fill-hachure"},{value:"cross-hatch",text:f("labels.crossHatch"),icon:d0,testId:"fill-cross-hatch"},{value:"solid",text:f("labels.solid"),icon:m0,testId:"fill-solid"}],value:yr(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(c=>c.fillStyle==="hachure")?"zigzag":i;r(l)}})]})}}),bA=N({name:"changeStrokeWidth",trackEvent:!1,perform:(e,t,r)=>({elements:Br(e,t,o=>Q(o,{strokeWidth:r})),appState:{...t,currentItemStrokeWidth:r},commitToHistory:!0}),PanelComponent:({elements:e,appState:t,updateData:r})=>Nr("fieldset",{children:[Ie("legend",{children:f("labels.strokeWidth")}),Ie(Vo,{group:"stroke-width",options:[{value:ld.thin,text:f("labels.thin"),icon:tg,testId:"strokeWidth-thin"},{value:ld.bold,text:f("labels.bold"),icon:u0,testId:"strokeWidth-bold"},{value:ld.extraBold,text:f("labels.extraBold"),icon:p0,testId:"strokeWidth-extraBold"}],value:yr(e,t,o=>o.strokeWidth,o=>o.hasOwnProperty("strokeWidth"),o=>o?null:t.currentItemStrokeWidth),onChange:o=>r(o)})]})}),xA=N({name:"changeSloppiness",trackEvent:!1,perform:(e,t,r)=>({elements:Br(e,t,o=>Q(o,{seed:jr(),roughness:r})),appState:{...t,currentItemRoughness:r},commitToHistory:!0}),PanelComponent:({elements:e,appState:t,updateData:r})=>Nr("fieldset",{children:[Ie("legend",{children:f("labels.sloppiness")}),Ie(Vo,{group:"sloppiness",options:[{value:0,text:f("labels.architect"),icon:f0},{value:1,text:f("labels.artist"),icon:b0},{value:2,text:f("labels.cartoonist"),icon:x0}],value:yr(e,t,o=>o.roughness,o=>o.hasOwnProperty("roughness"),o=>o?null:t.currentItemRoughness),onChange:o=>r(o)})]})}),_G=N({name:"changeStrokeStyle",trackEvent:!1,perform:(e,t,r)=>({elements:Br(e,t,o=>Q(o,{strokeStyle:r})),appState:{...t,currentItemStrokeStyle:r},commitToHistory:!0}),PanelComponent:({elements:e,appState:t,updateData:r})=>Nr("fieldset",{children:[Ie("legend",{children:f("labels.strokeStyle")}),Ie(Vo,{group:"strokeStyle",options:[{value:"solid",text:f("labels.strokeStyle_solid"),icon:tg},{value:"dashed",text:f("labels.strokeStyle_dashed"),icon:g0},{value:"dotted",text:f("labels.strokeStyle_dotted"),icon:h0}],value:yr(e,t,o=>o.strokeStyle,o=>o.hasOwnProperty("strokeStyle"),o=>o?null:t.currentItemStrokeStyle),onChange:o=>r(o)})]})}),EA=N({name:"changeOpacity",trackEvent:!1,perform:(e,t,r)=>({elements:Br(e,t,o=>Q(o,{opacity:r}),!0),appState:{...t,currentItemOpacity:r},commitToHistory:!0}),PanelComponent:({elements:e,appState:t,updateData:r})=>Nr("label",{className:"control-label",children:[f("labels.opacity"),Ie("input",{type:"range",min:"0",max:"100",step:"10",onChange:o=>r(+o.target.value),value:yr(e,t,o=>o.opacity,!0,t.currentItemOpacity)??void 0})]})}),yA=N({name:"changeFontSize",trackEvent:!1,perform:(e,t,r)=>zg(e,t,()=>r,r),PanelComponent:({elements:e,appState:t,updateData:r})=>Nr("fieldset",{children:[Ie("legend",{children:f("labels.fontSize")}),Ie(Vo,{group:"font-size",options:[{value:16,text:f("labels.small"),icon:M0,testId:"fontSize-small"},{value:20,text:f("labels.medium"),icon:L0,testId:"fontSize-medium"},{value:28,text:f("labels.large"),icon:_0,testId:"fontSize-large"},{value:36,text:f("labels.veryLarge"),icon:P0,testId:"fontSize-veryLarge"}],value:yr(e,t,o=>{if(z(o))return o.fontSize;let n=le(o);return n?n.fontSize:null},o=>z(o)||le(o)!==null,o=>o?null:t.currentItemFontSize||Ct),onChange:o=>r(o)})]})}),Gg=N({name:"decreaseFontSize",trackEvent:!1,perform:(e,t,r)=>zg(e,t,o=>Math.round(1/(1+Uw)*o.fontSize)),keyTest:e=>e[S.CTRL_OR_CMD]&&e.shiftKey&&(e.key===S.CHEVRON_LEFT||e.key===S.COMMA)}),Ug=N({name:"increaseFontSize",trackEvent:!1,perform:(e,t,r)=>zg(e,t,o=>Math.round(o.fontSize*(1+Uw))),keyTest:e=>e[S.CTRL_OR_CMD]&&e.shiftKey&&(e.key===S.CHEVRON_RIGHT||e.key===S.PERIOD)}),wA=N({name:"changeFontFamily",trackEvent:!1,perform:(e,t,r)=>({elements:Br(e,t,o=>{if(z(o)){let n=Q(o,{fontFamily:r,lineHeight:Dr(r)});return Gt(n,je(o)),n}return o},!0),appState:{...t,currentItemFontFamily:r},commitToHistory:!0}),PanelComponent:({elements:e,appState:t,updateData:r})=>{let o=[{value:St.Virgil,text:f("labels.handDrawn"),icon:Xa,testId:"font-family-virgil"},{value:St.Helvetica,text:f("labels.normal"),icon:D0,testId:"font-family-normal"},{value:St.Cascadia,text:f("labels.code"),icon:R0,testId:"font-family-code"}];return Nr("fieldset",{children:[Ie("legend",{children:f("labels.fontFamily")}),Ie(Vo,{group:"font-family",options:o,value:yr(e,t,n=>{if(z(n))return n.fontFamily;let i=le(n);return i?i.fontFamily:null},n=>z(n)||le(n)!==null,n=>n?null:t.currentItemFontFamily||Ft),onChange:n=>r(n)})]})}}),vA=N({name:"changeTextAlign",trackEvent:!1,perform:(e,t,r)=>({elements:Br(e,t,o=>{if(z(o)){let n=Q(o,{textAlign:r});return Gt(n,je(o)),n}return o},!0),appState:{...t,currentItemTextAlign:r},commitToHistory:!0}),PanelComponent:({elements:e,appState:t,updateData:r})=>Nr("fieldset",{children:[Ie("legend",{children:f("labels.textAlign")}),Ie(Vo,{group:"text-align",options:[{value:"left",text:f("labels.left"),icon:N0,testId:"align-left"},{value:"center",text:f("labels.center"),icon:B0,testId:"align-horizontal-center"},{value:"right",text:f("labels.right"),icon:O0,testId:"align-right"}],value:yr(e,t,o=>{if(z(o))return o.textAlign;let n=le(o);return n?n.textAlign:null},o=>z(o)||le(o)!==null,o=>o?null:t.currentItemTextAlign),onChange:o=>r(o)})]})}),TA=N({name:"changeVerticalAlign",trackEvent:{category:"element"},perform:(e,t,r)=>({elements:Br(e,t,o=>{if(z(o)){let n=Q(o,{verticalAlign:r});return Gt(n,je(o)),n}return o},!0),appState:{...t},commitToHistory:!0}),PanelComponent:({elements:e,appState:t,updateData:r})=>Ie("fieldset",{children:Ie(Vo,{group:"text-align",options:[{value:ht.TOP,text:f("labels.alignTop"),icon:Ie(F0,{theme:t.theme}),testId:"align-top"},{value:ht.MIDDLE,text:f("labels.centerVertically"),icon:Ie(z0,{theme:t.theme}),testId:"align-middle"},{value:ht.BOTTOM,text:f("labels.alignBottom"),icon:Ie(H0,{theme:t.theme}),testId:"align-bottom"}],value:yr(e,t,o=>{if(z(o)&&o.containerId)return o.verticalAlign;let n=le(o);return n?n.verticalAlign:null},o=>z(o)||le(o)!==null,o=>o?null:ht.MIDDLE),onChange:o=>r(o)})})}),PG=N({name:"changeRoundness",trackEvent:!1,perform:(e,t,r)=>({elements:Br(e,t,o=>Q(o,{roundness:r==="round"?{type:Ho(o.type)?st.ADAPTIVE_RADIUS:st.PROPORTIONAL_RADIUS}:null})),appState:{...t,currentItemRoundness:r},commitToHistory:!0}),PanelComponent:({elements:e,appState:t,updateData:r})=>{let n=ma(ce(e),t).some(i=>i.roundness?.type===st.LEGACY);return Nr("fieldset",{children:[Ie("legend",{children:f("labels.edges")}),Ie(Vo,{group:"edges",options:[{value:"sharp",text:f("labels.sharp"),icon:E0},{value:"round",text:f("labels.round"),icon:y0}],value:yr(e,t,i=>n?null:i.roundness?"round":"sharp",i=>i.hasOwnProperty("roundness"),i=>i?null:t.currentItemRoundness),onChange:i=>r(i)})]})}}),Gw=e=>[{value:null,text:f("labels.arrowhead_none"),keyBinding:"q",icon:w0},{value:"arrow",text:f("labels.arrowhead_arrow"),keyBinding:"w",icon:Ie(v0,{flip:e})},{value:"bar",text:f("labels.arrowhead_bar"),keyBinding:"e",icon:Ie(I0,{flip:e})},{value:"dot",text:f("labels.arrowhead_circle"),keyBinding:null,icon:Ie(rg,{flip:e}),showInPicker:!1},{value:"circle",text:f("labels.arrowhead_circle"),keyBinding:"r",icon:Ie(rg,{flip:e}),showInPicker:!1},{value:"circle_outline",text:f("labels.arrowhead_circle_outline"),keyBinding:null,icon:Ie(T0,{flip:e}),showInPicker:!1},{value:"triangle",text:f("labels.arrowhead_triangle"),icon:Ie(S0,{flip:e}),keyBinding:"t"},{value:"triangle_outline",text:f("labels.arrowhead_triangle_outline"),icon:Ie(C0,{flip:e}),keyBinding:null,showInPicker:!1},{value:"diamond",text:f("labels.arrowhead_diamond"),icon:Ie(k0,{flip:e}),keyBinding:null,showInPicker:!1},{value:"diamond_outline",text:f("labels.arrowhead_diamond_outline"),icon:Ie(A0,{flip:e}),keyBinding:null,showInPicker:!1}],DG=N({name:"changeArrowhead",trackEvent:!1,perform:(e,t,r)=>({elements:Br(e,t,o=>{if(te(o)){let{position:n,type:i}=r;if(n==="start")return Q(o,{startArrowhead:i});if(n==="end")return Q(o,{endArrowhead:i})}return o}),appState:{...t,[r.position==="start"?"currentItemStartArrowhead":"currentItemEndArrowhead"]:r.type},commitToHistory:!0}),PanelComponent:({elements:e,appState:t,updateData:r})=>{let o=rn().rtl;return Nr("fieldset",{children:[Ie("legend",{children:f("labels.arrowheads")}),Nr("div",{className:"iconSelectList buttonList",children:[Ie(Fg,{label:"arrowhead_start",options:Gw(!o),value:yr(e,t,n=>te(n)&&da(n.type)?n.startArrowhead:t.currentItemStartArrowhead,!0,t.currentItemStartArrowhead),onChange:n=>r({position:"start",type:n})}),Ie(Fg,{label:"arrowhead_end",group:"arrowheads",options:Gw(!!o),value:yr(e,t,n=>te(n)&&da(n.type)?n.endArrowhead:t.currentItemEndArrowhead,!0,t.currentItemEndArrowhead),onChange:n=>r({position:"end",type:n})})]})]})}})});var IA,Yg,Ko,Kg=y(()=>{"use strict";h();ue();W();IA=(e,t)=>{let[r,o,n,i]=t,{x:a,y:l}=Dt({sceneX:r,sceneY:o},e),{x:c,y:s}=Dt({sceneX:n,sceneY:i},e);return c-a>e.width||s-l>e.height},Yg=({scenePoint:e,viewportDimensions:t,zoom:r})=>({scrollX:t.width/2/r.value-e.x,scrollY:t.height/2/r.value-e.y}),Ko=(e,t)=>{if(e=Vw(e),!e.length)return{scrollX:0,scrollY:0};let[r,o,n,i]=we(e);IA(t,[r,o,n,i])&&([r,o,n,i]=$g(e,Ue({clientX:t.scrollX,clientY:t.scrollY},t)));let a=(r+n)/2,l=(o+i)/2;return Yg({scenePoint:{x:a,y:l},viewportDimensions:{width:t.width,height:t.height},zoom:t.zoom})}});var $o,vn,hm=y(()=>{"use strict";h();X();$o=e=>Math.max(rd,Math.min(e,30)),vn=({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),c=o.scrollY+(i-i/a),s=-(n-n/r),d=-(i-i/r);return{scrollX:l+s,scrollY:c+d,zoom:{value:r}}}});import{jsx as Em,jsxs as MA}from"react/jsx-runtime";var SA,Ks,fm,bm,CA,kA,Yw,$s,lU,sU,AA,xm,cU,Kw,Xs=y(()=>{"use strict";h();dm();se();Lt();X();ue();Y();me();Ze();Kg();hm();W();We();ai();Ve();Ar();Yt();Va();SA=N({name:"changeViewBackgroundColor",trackEvent:!1,predicate:(e,t,r,o)=>!!o.props.UIOptions.canvasActions.changeViewBackgroundColor&&!t.viewModeEnabled,perform:(e,t,r)=>({appState:{...t,...r},commitToHistory:!!r.viewBackgroundColor}),PanelComponent:({elements:e,appState:t,updateData:r,appProps:o})=>Em(Ws,{palette:null,topPicks:jc,label:f("labels.canvasBackground"),type:"canvasBackground",color:t.viewBackgroundColor,onChange:n=>r({viewBackgroundColor:n}),"data-testid":"canvas-background-picker",elements:e,appState:t,updateData:r})}),Ks=N({name:"clearCanvas",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=>Q(n,{isDeleted:!0})),appState:{...$t(),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})}),fm=N({name:"zoomIn",viewMode:!0,trackEvent:{category:"canvas"},perform:(e,t,r,o)=>({appState:{...t,...vn({viewportX:t.width/2+t.offsetLeft,viewportY:t.height/2+t.offsetTop,nextZoom:$o(t.zoom.value+Yi)},t),userToFollow:null},commitToHistory:!1}),PanelComponent:({updateData:e})=>Em(ne,{type:"button",className:"zoom-in-button zoom-button",icon:AE,title:`${f("buttons.zoomIn")} \u2014 ${_("CtrlOrCmd++")}`,"aria-label":f("buttons.zoomIn"),onClick:()=>{e(null)}}),keyTest:e=>(e.code===de.EQUAL||e.code===de.NUM_ADD)&&(e[S.CTRL_OR_CMD]||e.shiftKey)}),bm=N({name:"zoomOut",viewMode:!0,trackEvent:{category:"canvas"},perform:(e,t,r,o)=>({appState:{...t,...vn({viewportX:t.width/2+t.offsetLeft,viewportY:t.height/2+t.offsetTop,nextZoom:$o(t.zoom.value-Yi)},t),userToFollow:null},commitToHistory:!1}),PanelComponent:({updateData:e})=>Em(ne,{type:"button",className:"zoom-out-button zoom-button",icon:ME,title:`${f("buttons.zoomOut")} \u2014 ${_("CtrlOrCmd+-")}`,"aria-label":f("buttons.zoomOut"),onClick:()=>{e(null)}}),keyTest:e=>(e.code===de.MINUS||e.code===de.NUM_SUBTRACT)&&(e[S.CTRL_OR_CMD]||e.shiftKey)}),CA=N({name:"resetZoom",viewMode:!0,trackEvent:{category:"canvas"},perform:(e,t,r,o)=>({appState:{...t,...vn({viewportX:t.width/2+t.offsetLeft,viewportY:t.height/2+t.offsetTop,nextZoom:$o(1)},t),userToFollow:null},commitToHistory:!1}),PanelComponent:({updateData:e,appState:t})=>Em(Rr,{label:f("buttons.resetZoom"),style:{height:"100%"},children:MA(ne,{type:"button",className:"reset-zoom-button zoom-button",title:f("buttons.resetZoom"),"aria-label":f("buttons.resetZoom"),onClick:()=>{e(null)},children:[(t.zoom.value*100).toFixed(0),"%"]})}),keyTest:e=>(e.code===de.ZERO||e.code===de.NUM_ZERO)&&(e[S.CTRL_OR_CMD]||e.shiftKey)}),kA=(e,t)=>{let[r,o,n,i]=e,a=n-r,l=t.width/a,c=i-o,s=t.height/c,d=Math.min(l,s),m=Math.floor(d/Yi)*Yi;return Math.min(Math.max(m,rd),1)},Yw=({bounds:e,appState:t,fitToViewport:r=!1,viewportZoomFactor:o=.7})=>{let[n,i,a,l]=e,c=(n+a)/2,s=(i+l)/2,d,m,u;if(r){let p=a-n,g=l-i;d=Math.min(t.width/p,t.height/g)*Math.min(1,Math.max(o,.1)),d=Math.min(Math.max(d,.1),30);let b=t.width;if(t.openSidebar){let w=document.querySelector(".sidebar")?.offsetWidth??0;b=document.documentElement.getAttribute("dir")==="rtl"?t.width+w:t.width-w}m=b/2*(1/d)-c,u=t.height/2*(1/d)-s}else{d=kA(e,{width:t.width,height:t.height});let p=Yg({scenePoint:{x:c,y:s},viewportDimensions:{width:t.width,height:t.height},zoom:{value:d}});m=p.scrollX,u=p.scrollY}return{appState:{...t,scrollX:m,scrollY:u,zoom:{value:d}},commitToHistory:!1}},$s=({targetElements:e,appState:t,fitToViewport:r,viewportZoomFactor:o})=>{let n=we(ce(e));return Yw({bounds:n,appState:t,fitToViewport:r,viewportZoomFactor:o})},lU=N({name:"zoomToFitSelectionInViewport",trackEvent:{category:"canvas"},perform:(e,t,r,o)=>{let n=o.scene.getSelectedElements(t);return $s({targetElements:n.length?n:e,appState:{...t,userToFollow:null},fitToViewport:!1})},keyTest:e=>e.code===de.TWO&&e.shiftKey&&!e.altKey&&!e[S.CTRL_OR_CMD]}),sU=N({name:"zoomToFitSelection",trackEvent:{category:"canvas"},perform:(e,t,r,o)=>{let n=o.scene.getSelectedElements(t);return $s({targetElements:n.length?n:e,appState:{...t,userToFollow:null},fitToViewport:!0})},keyTest:e=>e.code===de.THREE&&e.shiftKey&&!e.altKey&&!e[S.CTRL_OR_CMD]}),AA=N({name:"zoomToFit",viewMode:!0,trackEvent:{category:"canvas"},perform:(e,t)=>$s({targetElements:e,appState:{...t,userToFollow:null},fitToViewport:!1}),keyTest:e=>e.code===de.ONE&&e.shiftKey&&!e.altKey&&!e[S.CTRL_OR_CMD]}),xm=N({name:"toggleTheme",viewMode:!0,trackEvent:{category:"canvas"},perform:(e,t,r)=>({appState:{...t,theme:r||(t.theme===nt.LIGHT?nt.DARK:nt.LIGHT)},commitToHistory:!1}),keyTest:e=>e.altKey&&e.shiftKey&&e.code===de.D,predicate:(e,t,r,o)=>!!o.props.UIOptions.canvasActions.toggleTheme}),cU=N({name:"toggleEraserTool",trackEvent:{category:"toolbar"},perform:(e,t)=>{let r;return $r(t)?r=Xe(t,{...t.activeTool.lastActiveTool||{type:"selection"},lastActiveToolBeforeEraser:null}):r=Xe(t,{type:"eraser",lastActiveToolBeforeEraser:t.activeTool}),{appState:{...t,selectedElementIds:{},selectedGroupIds:{},activeEmbeddable:null,activeTool:r},commitToHistory:!0}},keyTest:e=>e.key===S.E}),Kw=N({name:"toggleHandTool",trackEvent:{category:"toolbar"},perform:(e,t,r,o)=>{let n;return Eo(t)?n=Xe(t,{...t.activeTool.lastActiveTool||{type:"selection"},lastActiveToolBeforeEraser:null}):(n=Xe(t,{type:"hand",lastActiveToolBeforeEraser:t.activeTool}),Oe(o.interactiveCanvas,Me.GRAB)),{appState:{...t,selectedElementIds:{},selectedGroupIds:{},activeEmbeddable:null,activeTool:n},commitToHistory:!0}},keyTest:e=>!e.altKey&&!e[S.CTRL_OR_CMD]&&e.key===S.H})});var Ao,qe,pi,Xw,ua,vl,Zs,Xg,$w,LA,Zw,ym,no,jw,_A,PA,DA,qw,RA,NA,Jw,Zg=y(()=>{"use strict";h();Yt();X();ue();yo();Ao=32,qe=12,pi=256,Xw=50,ua="NOT_SPREADSHEET",vl="VALID_SPREADSHEET",Zs=e=>{let t=/^([-+]?)[$€£¥₩]?([-+]?)([\d.,]+)[%]?$/.exec(e);return t?parseFloat(`${(t[1]||t[2])+t[3]}`.replace(/,/g,"")):null},Xg=(e,t)=>e.slice(1).every(r=>Zs(r[t])!==null),$w=e=>{let t=e[0].length;if(t>2)return{type:ua,reason:"More than 2 columns"};if(t===1){if(!Xg(e,0))return{type:ua,reason:"Value is not numeric"};let c=Zs(e[0][0])===null,s=(c?e.slice(1):e).map(d=>Zs(d[0]));return s.length<2?{type:ua,reason:"Less than two rows"}:{type:vl,spreadsheet:{title:c?e[0][0]:null,labels:null,values:s}}}let r=Xg(e,0),o=Xg(e,1);if(!r&&!o)return{type:ua,reason:"Value is not numeric"};let[n,i]=o?[0,1]:[1,0],a=Zs(e[0][i])===null,l=a?e.slice(1):e;return l.length<2?{type:ua,reason:"Less than 2 rows"}:{type:vl,spreadsheet:{title:a?e[0][i]:null,labels:l.map(c=>c[n]),values:l.map(c=>Zs(c[i]))}}},LA=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},Zw=e=>{let t=e.trim().split(`
|
|
9
|
-
`).map(i=>i.trim().split(" "));if(t.length&&t[0].length!==2&&(t=e.trim().split(`
|
|
10
|
-
`).map(i=>i.trim().split(","))),t.length===0)return{type:ua,reason:"No values"};let r=t[0].length;if(!t.every(i=>i.length===r))return{type:ua,reason:"All rows don't have same number of columns"};let n=$w(t);if(n.type!==vl){let i=$w(LA(t));if(i.type===vl)return i}return n},ym=Ob(Db),no={fillStyle:"hachure",fontFamily:Ft,fontSize:Ct,opacity:100,roughness:1,strokeColor:oe.black,roundness:null,strokeStyle:"solid",strokeWidth:1,verticalAlign:ht.MIDDLE,locked:!1},jw=e=>{let t=(Ao+qe)*e.values.length+qe,r=pi+qe*2;return{chartWidth:t,chartHeight:r}},_A=(e,t,r,o,n)=>e.labels?.map((i,a)=>Rt({groupIds:[o],backgroundColor:n,...no,text:i.length>8?`${i.slice(0,5)}...`:i,x:t+a*(Ao+qe)+qe*2,y:r+qe/2,width:Ao,angle:5.87,fontSize:16,textAlign:"center",verticalAlign:"top"}))||[],PA=(e,t,r,o,n)=>{let i=Rt({groupIds:[o],backgroundColor:n,...no,x:t-qe,y:r-qe,text:"0",textAlign:"right"}),a=Rt({groupIds:[o],backgroundColor:n,...no,x:t-qe,y:r-pi-i.height/2,text:Math.max(...e.values).toLocaleString(),textAlign:"right"});return[i,a]},DA=(e,t,r,o,n)=>{let{chartWidth:i,chartHeight:a}=jw(e),l=qr({backgroundColor:n,groupIds:[o],...no,type:"line",x:t,y:r,startArrowhead:null,endArrowhead:null,width:i,points:[[0,0],[i,0]]}),c=qr({backgroundColor:n,groupIds:[o],...no,type:"line",x:t,y:r,startArrowhead:null,endArrowhead:null,height:a,points:[[0,0],[0,-a]]}),s=qr({backgroundColor:n,groupIds:[o],...no,type:"line",x:t,y:r-pi-qe,startArrowhead:null,endArrowhead:null,strokeStyle:"dotted",width:i,opacity:Xw,points:[[0,0],[i,0]]});return[l,c,s]},qw=(e,t,r,o,n,i)=>{let{chartWidth:a,chartHeight:l}=jw(e),c=e.title?Rt({backgroundColor:n,groupIds:[o],...no,text:e.title,x:t+a/2,y:r-pi-qe*2-Ct,roundness:null,textAlign:"center"}):null,s=i?Pr({backgroundColor:n,groupIds:[o],...no,type:"rectangle",x:t,y:r-l,width:a,height:l,strokeColor:oe.black,fillStyle:"solid",opacity:6}):null;return[...s?[s]:[],...c?[c]:[],..._A(e,t,r,o,n),...PA(e,t,r,o,n),...DA(e,t,r,o,n)]},RA=(e,t,r)=>{let o=Math.max(...e.values),n=Mt(),i=ym[Math.floor(Math.random()*ym.length)];return[...e.values.map((l,c)=>{let s=l/o*pi;return Pr({backgroundColor:i,groupIds:[n],...no,type:"rectangle",x:t+c*(Ao+qe)+qe,y:r-s-qe,width:Ao,height:s})}),...qw(e,t,r,n,i,I.DEV)]},NA=(e,t,r)=>{let o=Math.max(...e.values),n=Mt(),i=ym[Math.floor(Math.random()*ym.length)],a=0,l=[];for(let b of e.values){let E=a*(Ao+qe),w=-(b/o)*pi;l.push([E,w]),a++}let c=Math.max(...l.map(b=>b[0])),s=Math.max(...l.map(b=>b[1])),d=Math.min(...l.map(b=>b[0])),m=Math.min(...l.map(b=>b[1])),u=qr({backgroundColor:i,groupIds:[n],...no,type:"line",x:t+qe+Ao/2,y:r-qe,startArrowhead:null,endArrowhead:null,height:s-m,width:c-d,strokeWidth:2,points:l}),p=e.values.map((b,E)=>{let w=E*(Ao+qe)+qe/2,v=-(b/o)*pi+qe/2;return Pr({backgroundColor:i,groupIds:[n],...no,fillStyle:"solid",strokeWidth:2,type:"ellipse",x:t+w+Ao/2,y:r+v-qe*2,width:qe,height:qe})}),g=e.values.map((b,E)=>{let w=E*(Ao+qe)+qe/2,v=b/o*pi+qe/2+qe;return qr({backgroundColor:i,groupIds:[n],...no,type:"line",x:t+w+Ao/2+qe/2,y:r-v,startArrowhead:null,endArrowhead:null,height:v,strokeStyle:"dotted",opacity:Xw,points:[[0,0],[0,v]]})});return[...qw(e,t,r,n,i,I.DEV),u,...g,...p]},Jw=(e,t,r,o)=>e==="line"?NA(t,r,o):RA(t,r,o)});function e2(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(e2(r));return t}var AU,wm,Tl,BA,Qw,OA,vm,FA,HA,t2,zA,Tm,Im,Tn,GA,gi=y(()=>{"use strict";h();Zg();X();ae();dn();Ve();br();W();Y();AU="clipboard"in navigator&&"readText"in navigator.clipboard,wm="clipboard"in navigator&&"writeText"in navigator.clipboard,Tl="clipboard"in navigator&&"write"in navigator.clipboard&&"ClipboardItem"in window&&"toBlob"in HTMLCanvasElement.prototype,BA=e=>!!([Kt.excalidraw,Kt.excalidrawClipboard,Kt.excalidrawClipboardWithAPI].includes(e?.type)&&Array.isArray(e.elements)),Qw=({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},OA=({elements:e,files:t})=>{let r=new Set(e.filter(a=>J(a))),o=!1,n=e.reduce((a,l)=>(ur(l)&&(o=!0,t&&t[l.fileId]&&(a[l.fileId]=t[l.fileId])),a),{});o&&!t&&console.warn("copyToClipboard: attempting to file element(s) without providing associated `files` object.");let i={type:Kt.excalidrawClipboard,elements:e.map(a=>{if(jt(a)&&!r.has(jt(a))){let l=cn(a);return B(l,{frameId:null}),l}return a}),files:t?n:void 0};return JSON.stringify(i)},vm=async(e,t,r)=>{await Tn(OA({elements:e,files:t}),r)},FA=e=>{let t=Zw(e);return t.type===vl?{spreadsheet:t.spreadsheet}:null};HA=e=>{let t=e.clipboardData?.getData("text/html");if(!t)return null;try{let r=new DOMParser().parseFromString(t,"text/html"),o=e2(r.body);if(o.length)return{type:"mixedContent",value:o}}catch(r){console.error(`error in parseHTMLFromPaste: ${r.message}`)}return null},t2=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(hs(Wb,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},zA=async(e,t=!1)=>{try{let r=!t&&e&&HA(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(`
|
|
11
|
-
`).trim()}:r:{type:"text",value:(e.clipboardData?.getData("text/plain")||"").trim()}}catch{return{type:"text",value:""}}},Tm=async(e,t=!1)=>{let r=await zA(e,t);if(r.type==="mixedContent")return{mixedContent:r.value};try{let o=!t&&FA(r.value);if(o)return o}catch(o){console.error(o)}try{let o=JSON.parse(r.value),n=o.type===Kt.excalidrawClipboardWithAPI;if(BA(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}},Im=async e=>{try{await navigator.clipboard.write([new window.ClipboardItem({[Z.png]:e})])}catch(t){if(hd(e))await navigator.clipboard.write([new window.ClipboardItem({[Z.png]:await e})]);else throw t}},Tn=async(e,t)=>{if(wm)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(!GA(e))throw new Error(f("errors.copyToSystemClipboardFailed"))},GA=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 UA,Il,Sl,Sm,r2,jg,Cm=y(()=>{"use strict";h();me();W();Er();ae();X();Ve();pt();Wg();Xs();ar();gi();UA=(e,t,r,o,n,i)=>{let{zoom:a}=o,l=180*r/Math.PI,c=e*(a.value-1)/2,s=t*(a.value-1)/2;return e>n&&a.value!==1&&(c=n*(a.value-1)/2),t>i&&a.value!==1&&(s=i*(a.value-1)/2),`translate(${c}px, ${s}px) scale(${a.value}) rotate(${l}deg)`},Il={},Sl=(e,t)=>{let r=Il[e]||(Il[e]={height:t});return r.height=t,r},Sm=e=>{Il[e]&&delete Il[e]},r2=e=>Il[e]?.height??null,jg=({id:e,onChange:t,onSubmit:r,getViewportCoords:o,element:n,canvas:i,excalidrawContainer:a,app:l})=>{let c=(P,G)=>{if(!G.style.fontFamily||!G.style.fontSize)return!1;let j=G.style.fontFamily.replace(/"/g,"");return Oa({fontFamily:P.fontFamily})!==j||`${P.fontSize}px`!==G.style.fontSize},s=()=>{let P=l.state,G=xe.getScene(n)?.getElement(e);if(!G)return;let{textAlign:j,verticalAlign:V}=G;if(G&&z(G)){let pe=G.x,Se=G.y,q=je(G),Ge=G.width,Ae=G.height,It=G.width,Ke=G.height;if(q&&G.containerId){if(ve(q)){let Do=K.getBoundTextElementPosition(q,G);pe=Do.x,Se=Do.y}let zn=c(G,d),Vt;if(zn?Vt=Sl(q.id,q.height):(Vt=Il[q.id],Vt||(Vt=Sl(q.id,q.height))),Ge=hr(q),Ae=Cn(q,G),!ve(q)&&Ke>Ae){let Do=In(Ke,q.type);B(q,{height:Do});return}else if(!ve(q)&&q.height>Vt.height&&Ke<Ae){let Do=In(Ke,q.type);B(q,{height:Do})}else{let{y:Do}=Cl(q,G);Se=Do}}let[Ur,Fi]=o(pe,Se),Qt=d.selectionStart,Hn=d.selectionEnd,Hi=d.value.length;if(Qt===Hn&&Hn!==Hi){let zn=Hi-Hn;d.selectionStart=d.value.length-zn,d.selectionEnd=d.value.length-zn}q?It+=.5:(Ge=(P.width-8-Ur)/P.zoom.value,It=Math.min(It,Ge));let zi=G.lineHeight;Jc&&(zi=km({...G,fontSize:Math.round(G.fontSize)}));let Po=(P.height-Fi)/P.zoom.value;Object.assign(d.style,{font:_e(G),lineHeight:zi,width:`${It}px`,height:`${Ke}px`,left:`${Ur}px`,top:`${Fi}px`,transform:UA(It,Ke,o2(G),P,Ge,Po),textAlign:j,verticalAlign:V,color:G.strokeColor,opacity:G.opacity/100,filter:"var(--theme-filter)",maxHeight:`${Po}px`}),d.scrollTop=0,kr()&&(d.style.fontFamily=Oa(G)),B(G,{x:pe,y:Se})}},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",u="normal";ke(n)&&(m="pre-wrap",u="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:u,whiteSpace:m,overflowWrap:"break-word",boxSizing:"content-box"}),d.value=n.originalText,s(),t&&(d.onpaste=async P=>{let G=await Tm(P,!0);if(!G.text)return;let j=ri(G.text);if(!j)return;let V=je(n),pe=_e({fontSize:l.state.currentItemFontSize,fontFamily:l.state.currentItemFontFamily});if(V){let Se=oi(`${d.value}${j}`,pe,hr(V)),q=js(Se,pe);d.style.width=`${q}px`}},d.oninput=()=>{t(ri(d.value))}),d.onkeydown=P=>{if(!P.shiftKey&&fm.keyTest(P))P.preventDefault(),l.actionManager.executeAction(fm),s();else if(!P.shiftKey&&bm.keyTest(P))P.preventDefault(),l.actionManager.executeAction(bm),s();else if(Gg.keyTest(P))l.actionManager.executeAction(Gg);else if(Ug.keyTest(P))l.actionManager.executeAction(Ug);else if(P.key===S.ESCAPE)P.preventDefault(),k=!0,M();else if(P.key===S.ENTER&&P[S.CTRL_OR_CMD]){if(P.preventDefault(),P.isComposing||P.keyCode===229)return;k=!0,M()}else if(P.key===S.TAB||P[S.CTRL_OR_CMD]&&(P.code===de.BRACKET_LEFT||P.code===de.BRACKET_RIGHT)){if(P.preventDefault(),P.isComposing)return;P.shiftKey||P.code===de.BRACKET_LEFT?w():E(),d.dispatchEvent(new Event("input"))}};let p=4,g=" ".repeat(p),b=new RegExp(`^ {1,${p}}`),E=()=>{let{selectionStart:P,selectionEnd:G}=d,j=v(),V=d.value;j.forEach(pe=>{let Se=V.slice(0,pe),q=V.slice(pe);V=`${Se}${g}${q}`}),d.value=V,d.selectionStart=P+p,d.selectionEnd=G+p*j.length},w=()=>{let{selectionStart:P,selectionEnd:G}=d,j=v(),V=[],pe=d.value;j.forEach(Se=>{let q=pe.slice(Se,Se+p).match(b);if(q){let Ge=pe.slice(0,Se),Ae=pe.slice(Se+q[0].length);pe=`${Ge}${Ae}`,V.push(Se)}}),d.value=pe,V.length&&(P>V[V.length-1]?d.selectionStart=Math.max(P-p,V[V.length-1]):d.selectionStart=P,d.selectionEnd=Math.max(d.selectionStart,G-p*V.length))},v=()=>{let{selectionStart:P,selectionEnd:G,value:j}=d,V=j.slice(0,P).match(/[^\n]*$/)[0].length;return P=P-V,j.slice(P,G).split(`
|
|
12
|
-
`).reduce((Se,q,Ge,Ae)=>Se.concat(Ge?Se[Ge-1]+Ae[Ge-1].length+1:P),[]).reverse()},T=P=>{P.preventDefault(),P.stopPropagation()},k=!1,M=()=>{A();let P=xe.getScene(n)?.getElement(n.id);if(!P)return;let G=d.value,j=je(P);if(j){if(G=P.text,d.value.trim()){let V=Sn(j);!V||V!==n.id?B(j,{boundElements:(j.boundElements||[]).concat({type:"text",id:n.id})}):ve(j)&&wo(j)}else B(j,{boundElements:j.boundElements?.filter(V=>!z(V))});Gt(P,j)}r({text:G,viaKeyboard:k,originalText:d.value})},A=()=>{C||(C=!0,d.onblur=null,d.oninput=null,d.onkeydown=null,O&&O.disconnect(),window.removeEventListener("resize",s),window.removeEventListener("wheel",T,!0),window.removeEventListener("pointerdown",R),window.removeEventListener("pointerup",D),window.removeEventListener("blur",M),window.removeEventListener("beforeunload",M),H(),d.remove())},D=P=>{window.removeEventListener("pointerup",D);let G=P?.target,j=G instanceof HTMLElement&&G.classList.contains("active-color");setTimeout(()=>{if(d.onblur=M,j){let V=(Se,q)=>{Se.find(Ae=>Ae.removedNodes.length>0&&Ae.removedNodes[0].dataset?.radixPopperContentWrapper!==void 0)&&(setTimeout(()=>{d.focus()}),q.disconnect())};new MutationObserver(V).observe(document.querySelector(".excalidraw-container"),{childList:!0})}j||d.focus()})},R=P=>{let G=P.target instanceof HTMLElement&&P.target.classList.contains("active-color");((P.target instanceof HTMLElement||P.target instanceof SVGElement)&&P.target.closest(`.${Qc.SHAPE_ACTIONS_MENU}`)&&!Oo(P.target)||G)&&(d.onblur=null,window.addEventListener("pointerup",D),window.addEventListener("blur",M))},H=xe.getScene(n).addCallback(()=>{s(),!!document.activeElement?.closest(".color-picker-content")||d.focus()}),C=!1;d.select(),D();let O=null;i&&"ResizeObserver"in window?(O=new window.ResizeObserver(()=>{s()}),O.observe(i)):window.addEventListener("resize",s),window.addEventListener("pointerdown",R),window.addEventListener("wheel",T,{passive:!1,capture:!0}),window.addEventListener("beforeunload",M),a?.querySelector(".excalidraw-textEditorContainer").appendChild(d)}});var ri,eh,Gt,Am,la,Cl,_r,th,km,pa,Mm,qg,qs,js,Qg,WA,oi,n2,i2,Lm,VA,Sn,le,je,_m,rh,o2,a2,l2,oh,YA,s2,In,hr,Cn,c2,Jg,Dr,pt=y(()=>{"use strict";h();W();Ve();X();Er();ue();ae();ar();ae();ue();Ze();na();Cm();ri=e=>e.replace(/\t/g," ").replace(/\r?\n|\r/g,`
|
|
13
|
-
`),eh=e=>ri(e).split(`
|
|
14
|
-
`),Gt=(e,t)=>{let r,o={x:e.x,y:e.y,text:e.text,width:e.width,height:e.height,baseline:e.baseline};o.text=e.text,t&&(r=hr(t,e),o.text=oi(e.originalText,_e(e),r));let n=_r(o.text,_e(e),e.lineHeight);if(o.width=n.width,o.height=n.height,o.baseline=n.baseline,t){let i=Cn(t,e),a=hr(t);if(!ve(t)&&n.height>i){let d=In(n.height,t.type);B(t,{height:d}),Sl(t.id,d)}if(n.width>a){let d=In(n.width,t.type);B(t,{width:d})}let l={...e,...o},{x:c,y:s}=Cl(t,l);o.x=c,o.y=s}B(e,o)},Am=(e,t,r)=>{let o=Ce(e);t.forEach(n=>{let i=r.get(n.id),a=Sn(n);if(a){let l=r.get(a);if(l){let c=o.get(i);c&&B(c,{boundElements:(n.boundElements||[]).filter(d=>d.id!==l&&d.id!==a).concat({type:"text",id:l})});let s=o.get(l);s&&z(s)&&B(s,{containerId:c?i:null})}}})},la=(e,t,r=!1)=>{let o=Sn(e);if(!o)return;Sm(e.id);let n=xe.getScene(e).getElement(o);if(n&&n.text){if(!e)return;n=xe.getScene(e).getElement(o);let i=n.text,a=n.height,l=n.width,c=hr(e),s=Cn(e,n),d=e.height,m=n.baseline;if(r||t!=="n"&&t!=="s"){i&&(i=oi(n.originalText,_e(n),c));let u=_r(i,_e(n),n.lineHeight);a=u.height,l=u.width,m=u.baseline}if(a>s){d=In(a,e.type);let u=d-e.height,p=!ve(e)&&(t==="ne"||t==="nw"||t==="n")?e.y-u:e.y;B(e,{height:d,y:p})}B(n,{text:i,width:l,height:a,baseline:m}),ve(e)||B(n,Cl(e,n))}},Cl=(e,t)=>{if(ve(e))return K.getBoundTextElementPosition(e,t);let r=rh(e),o=Cn(e,t),n=hr(e),i,a;return t.verticalAlign===ht.TOP?a=r.y:t.verticalAlign===ht.BOTTOM?a=r.y+(o-t.height):a=r.y+(o/2-t.height/2),t.textAlign===$n.LEFT?i=r.x:t.textAlign===$n.RIGHT?i=r.x+(n-t.width):i=r.x+(n/2-t.width/2),{x:i,y:a}},_r=(e,t,r)=>{e=e.split(`
|
|
15
|
-
`).map(l=>l||" ").join(`
|
|
16
|
-
`);let o=parseFloat(t),n=Qg(e,o,r),i=js(e,t),a=th(e,t,r);return{width:i,height:n,baseline:a}},th=(e,t,r,o)=>{let n=document.createElement("div");n.style.position="absolute",n.style.whiteSpace="pre",n.style.font=t,n.style.minHeight="1em",o&&(n.style.overflow="hidden",n.style.wordBreak="break-word",n.style.whiteSpace="pre-wrap"),n.style.lineHeight=String(r),n.innerText=e,document.body.appendChild(n);let i=document.createElement("span");i.style.display="inline-block",i.style.overflow="hidden",i.style.width="1px",i.style.height="1px",n.appendChild(i);let a=i.offsetTop+i.offsetHeight,l=n.offsetHeight;if(Jc){let c=Qg(e,parseFloat(t),r),s=parseFloat(t),d=Qg(e,Math.round(s),r);c>l&&(a+=c-d),l>c&&(a-=d-c)}return document.body.removeChild(n),a},km=e=>{let t=eh(e.text).length;return e.height/t/e.fontSize},pa=(e,t)=>e*t,Mm=(e,t)=>pa(e,t)+ut*2,qs=(e,t)=>{qg||(qg=document.createElement("canvas"));let r=qg.getContext("2d");r.font=t;let o=r.measureText(e).width;return kr()?o*10:o},js=(e,t)=>{let r=eh(e),o=0;return r.forEach(n=>{o=Math.max(o,qs(n,t))}),o},Qg=(e,t,r)=>{let o=eh(e).length;return pa(t,r)*o},WA=e=>{let t=e.split("-");return t.length>1&&t.forEach((r,o)=>{o!==t.length-1&&(t[o]=r+="-")}),t.join(" ").split(" ")},oi=(e,t,r)=>{if(!Number.isFinite(r)||r<0)return e;let o=[],n=e.split(`
|
|
17
|
-
`),i=qs(" ",t),a="",l=0,c=d=>{d.trim()&&o.push(d)},s=()=>{a="",l=0};return n.forEach(d=>{if(js(d,t)<=r){o.push(d);return}let u=WA(d);s();let p=0;for(;p<u.length;){let g=qs(u[p],t);if(g===r)c(u[p]),p++;else if(g>r){for(c(a),s();u[p].length>0;){let b=String.fromCodePoint(u[p].codePointAt(0)),E=n2.calculate(b,t);l+=E,u[p]=u[p].slice(b.length),l>=r?(c(a),a=b,l=E):a+=b}l+i>=r?(c(a),s()):a.endsWith("-")||(a+=" ",l+=i),p++}else for(;l<r&&p<u.length;){let b=u[p];if(l=qs(a+b,t),l>r){c(a),s();break}p++;let E=!b.endsWith("-");if(a+=b,E&&(a+=" "),l+i>=r){E?o.push(a.slice(0,-1)):o.push(a),s();break}}}a.slice(-1)===" "&&(a=a.slice(0,-1),c(a))}),o.join(`
|
|
18
|
-
`)},n2=(()=>{let e={};return{calculate:(o,n)=>{let i=o.charCodeAt(0);if(e[n]||(e[n]=[]),!e[n][i]){let a=qs(o,n);e[n][i]=a}return e[n][i]},getCache:o=>e[o]}})(),i2="ABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789".toLocaleUpperCase(),Lm=(e,t)=>{let r=VA(e);return r===0?_r(i2.split("").join(`
|
|
19
|
-
`),e,t).width+ut*2:r+ut*2},VA=e=>{let t=n2.getCache(e);if(!t)return 0;let r=t.filter(o=>o!==void 0);return Math.max(...r)},Sn=e=>e?.boundElements?.length&&e?.boundElements?.filter(t=>t.type==="text")[0]?.id||null,le=e=>{if(!e)return null;let t=Sn(e);return t&&xe.getScene(e)?.getElement(t)||null},je=e=>e&&e.containerId&&xe.getScene(e)?.getElement(e.containerId)||null,_m=(e,t)=>{if(!ve(e))return{x:e.x+e.width/2,y:e.y+e.height/2};let r=K.getPointsGlobalCoordinates(e);if(r.length%2===1){let i=Math.floor(e.points.length/2),a=K.getPointGlobalCoordinates(e,e.points[i]);return{x:a[0],y:a[1]}}let o=e.points.length/2-1,n=K.getEditorMidPoints(e,t)[o];return n||(n=K.getSegmentMidPoint(e,r[o],r[o+1],o+1)),{x:n[0],y:n[1]}},rh=e=>{let t=ut,r=ut;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}},o2=e=>{let t=je(e);return!t||ve(t)?e.angle:t.angle},a2=e=>e.some(t=>{if(ke(t)){let o=je(t);return!(z(t)&&ve(o))}return!1}),l2=e=>e.some(t=>{if(ke(t)){let o=je(t);return!(z(t)&&ve(o))}return z(t)}),oh=(e,t,r,o)=>{let n=ge(e,t);if(n.length===1)return Fo(n[0],!1)?n[0]:null;let i=null;for(let a=e.length-1;a>=0;--a){if(e[a].isDeleted)continue;let[l,c,s,d]=ee(e[a]);if(ve(e[a])&&aa(e[a],t,null,[r,o])){i=e[a];break}else if(l<r&&r<s&&c<o&&o<d){i=e[a];break}}return Fo(i,!1)?i:null},YA=new Set(["rectangle","ellipse","diamond","arrow"]),s2=e=>YA.has(e.type),In=(e,t)=>{e=Math.ceil(e);let r=ut*2;return t==="ellipse"?Math.round((e+r)/Math.sqrt(2)*2):t==="arrow"?e+r*8:t==="diamond"?2*(e+r):e+r},hr=(e,t=le(e))=>{let{width:r}=e;if(ve(e)){let o=(t?.fontSize??Ct)*rx;return Math.max(tx*r,o)}return e.type==="ellipse"?Math.round(r/2*Math.sqrt(2))-ut*2:e.type==="diamond"?Math.round(r/2)-ut*2:r-ut*2},Cn=(e,t)=>{let{height:r}=e;return ve(e)?r-ut*8*2<=0?t.height:r:e.type==="ellipse"?Math.round(r/2*Math.sqrt(2))-ut*2:e.type==="diamond"?Math.round(r/2)-ut*2:r-ut*2},c2=()=>js(i2,_e({fontSize:Ct,fontFamily:Ft}))>0,Jg={[St.Virgil]:1.25,[St.Helvetica]:1.15,[St.Cascadia]:1.2},Dr=e=>e in Jg?Jg[e]:Jg[Ft]});import p2 from"roughjs/bin/rough";import{getStroke as KA}from"perfect-freehand";function y2(e){let t=nh(e),r=new Path2D(t);return E2.set(e,r),r}function qA(e){return E2.get(e)}function nh(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 QA(KA(t,r))}function u2(e,t){return[(e[0]+t[0])/2,(e[1]+t[1])/2]}function QA(e){if(!e.length)return"";let t=e.length-1;return e.reduce((r,o,n,i)=>(n===t?r.push(o,u2(o,i[0]),"L",i[0],"Z"):r.push(o,u2(o,i[n+1])),r),["M",e[0],"Q"]).join(" ").replace(JA,"$1")}var g2,$A,h2,f2,Dm,XA,ZA,dy,b2,x2,jA,Pm,Wd,d2,m2,Ly,Ms,Js,Qs,Zd,E2,JA,nl=y(()=>{"use strict";h();ae();yt();W();Zt();Ar();X();pt();ar();Ts();br();ol();Io();g2="invert(100%) hue-rotate(180deg) saturate(1.25)",$A=$t(),h2=(e,t)=>ur(e)&&!t.imageCache.has(e.fileId),f2=(e,t,r)=>r.theme==="dark"&&ur(e)&&!h2(e,t)&&t.imageCache.get(e.fileId)?.mimeType!==Z.svg,Dm=e=>e.type==="freedraw"?e.strokeWidth*12:20,XA=(e,t)=>{let n=Dm(e),[i,a,l,c]=ee(e),s=te(e)||xt(e)?kt(i,l):e.width,d=te(e)||xt(e)?kt(a,c):e.height,m=s*window.devicePixelRatio+n*2,u=d*window.devicePixelRatio+n*2,p=t.value;return(m*p>32767||u*p>32767)&&(p=Math.min(32767/m,32767/u)),m*u*p*p>16777216&&(p=Math.sqrt(16777216/(m*u))),m=Math.floor(m*p),u=Math.floor(u*p),{width:m,height:u,scale:p}},ZA=(e,t,r,o)=>{let n=document.createElement("canvas"),i=n.getContext("2d"),a=Dm(e),{width:l,height:c,scale:s}=XA(e,t);n.width=l,n.height=c;let d=0,m=0;if(te(e)||xt(e)){let[p,g]=ee(e);d=e.x>p?kt(e.x,p)*window.devicePixelRatio*s:0,m=e.y>g?kt(e.y,g)*window.devicePixelRatio*s:0,i.translate(d,m)}i.save(),i.translate(a*s,a*s),i.scale(window.devicePixelRatio*s,window.devicePixelRatio*s);let u=p2.canvas(n);return f2(e,r,o)&&(i.filter=g2),Pm(e,u,i,r,o),i.restore(),{element:e,canvas:n,theme:o.theme,scale:s,zoomValue:t.value,canvasOffsetX:d,canvasOffsetY:m,boundTextElementVersion:le(e)?.version||null,containingFrameOpacity:jt(e)?.opacity||100}},dy=14,b2=document.createElement("img");b2.src=`data:${Z.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>')}`;x2=document.createElement("img");x2.src=`data:${Z.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>')}`;jA=(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"?x2:b2,e.width/2-n/2,e.height/2-n/2,n,n)},Pm=(e,t,r,o,n)=>{switch(r.globalAlpha=(jt(e)?.opacity??100)*e.opacity/1e4,e.type){case"rectangle":case"iframe":case"embeddable":case"diamond":case"ellipse":{r.lineJoin="round",r.lineCap="round",t.draw(Te.get(e));break}case"arrow":case"line":{r.lineJoin="round",r.lineCap="round",Te.get(e).forEach(i=>{t.draw(i)});break}case"freedraw":{r.save(),r.fillStyle=e.strokeColor;let i=qA(e),a=Te.get(e);a&&t.draw(a),r.fillStyle=e.strokeColor,r.fill(i),r.restore();break}case"image":{let i=ur(e)?o.imageCache.get(e.fileId)?.image:void 0;i!=null&&!(i instanceof Promise)?r.drawImage(i,0,0,e.width,e.height):jA(e,r,n.zoom.value);break}default:if(z(e)){let i=Dp(e.text),a=i&&!r.canvas.isConnected;a&&document.body.appendChild(r.canvas),r.canvas.setAttribute("dir",i?"rtl":"ltr"),r.save(),r.font=_e(e),r.fillStyle=e.strokeColor,r.textAlign=e.textAlign;let l=e.text.replace(/\r\n?/g,`
|
|
20
|
-
`).split(`
|
|
21
|
-
`),c=e.textAlign==="center"?e.width/2:e.textAlign==="right"?e.width:0,s=pa(e.fontSize,e.lineHeight),d=e.height-e.baseline;for(let m=0;m<l.length;m++)r.fillText(l[m],c,(m+1)*s-d);r.restore(),a&&r.canvas.remove()}else throw new Error(`Unimplemented type ${e.type}`)}r.globalAlpha=1},Wd=new WeakMap,d2=(e,t,r)=>{let o=t?r.zoom:$A.zoom,n=Wd.get(e),i=n&&n.zoomValue!==o.value&&!r?.shouldCacheIgnoreZoom,a=le(e)?.version||null,l=jt(e)?.opacity||100;if(!n||i||n.theme!==r.theme||n.boundTextElementVersion!==a||n.containingFrameOpacity!==l){let c=ZA(e,o,t,r);return Wd.set(e,c),c}return n},m2=(e,t,r,o)=>{let n=e.element,i=Dm(n),a=e.scale,[l,c,s,d]=ee(n);xt(n)&&(l=Math.floor(l),s=Math.ceil(s),c=Math.floor(c),d=Math.ceil(d));let m=((l+s)/2+o.scrollX)*window.devicePixelRatio,u=((c+d)/2+o.scrollY)*window.devicePixelRatio;t.save(),t.scale(1/window.devicePixelRatio,1/window.devicePixelRatio);let p=le(n);if(ve(n)&&p){let g=document.createElement("canvas"),b=g.getContext("2d"),E=Math.max(kt(l,s),kt(c,d));g.width=E*window.devicePixelRatio*a+i*e.scale*10,g.height=E*window.devicePixelRatio*a+i*e.scale*10;let w=(g.width-e.canvas.width)/2,v=(g.height-e.canvas.height)/2;b.translate(g.width/2,g.height/2),b.rotate(n.angle),b.drawImage(e.canvas,-e.canvas.width/2,-e.canvas.height/2,e.canvas.width,e.canvas.height);let[,,,,T,k]=ee(p);b.rotate(-n.angle);let M=g.width/2-(T-l)*window.devicePixelRatio*a-w-i*a,A=g.height/2-(k-c)*window.devicePixelRatio*a-v-i*a;b.translate(-M,-A),b.clearRect(-(p.width/2+ut)*window.devicePixelRatio*a,-(p.height/2+ut)*window.devicePixelRatio*a,(p.width+ut*2)*window.devicePixelRatio*a,(p.height+ut*2)*window.devicePixelRatio*a),t.translate(m,u),t.drawImage(g,-(s-l)/2*window.devicePixelRatio-w/a-i,-(d-c)/2*window.devicePixelRatio-v/a-i,g.width/a,g.height/a)}else if(t.translate(m,u),t.rotate(n.angle),"scale"in e.element&&!h2(n,r)&&t.scale(e.element.scale[0],e.element.scale[1]),t.translate(-m,-u),t.drawImage(e.canvas,(l+o.scrollX)*window.devicePixelRatio-i*e.scale/e.scale,(c+o.scrollY)*window.devicePixelRatio-i*e.scale/e.scale,e.canvas.width/e.scale,e.canvas.height/e.scale),I.VITE_APP_DEBUG_ENABLE_TEXT_CONTAINER_BOUNDING_BOX==="true"&&pr(n)){let g=le(n),b=rh(n);t.strokeStyle="#c92a2a",t.lineWidth=3,t.strokeRect((b.x+o.scrollX)*window.devicePixelRatio,(b.y+o.scrollY)*window.devicePixelRatio,hr(n)*window.devicePixelRatio,Cn(n,g)*window.devicePixelRatio)}t.restore()},Ly=(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()},Ms=(e,t,r,o,n)=>{switch(e.type){case"magicframe":case"frame":{n.frameRendering.enabled&&n.frameRendering.outline&&(r.save(),r.translate(e.x+n.scrollX,e.y+n.scrollY),r.fillStyle="rgba(0, 0, 200, 0.04)",r.lineWidth=Qe.strokeWidth/n.zoom.value,r.strokeStyle=Qe.strokeColor,Xi(e)&&(r.strokeStyle=n.theme==="light"?"#7affd7":"#1d8264"),Qe.radius&&r.roundRect?(r.beginPath(),r.roundRect(0,0,e.width,e.height,Qe.radius/n.zoom.value),r.stroke(),r.closePath()):r.strokeRect(0,0,e.width,e.height),r.restore());break}case"freedraw":{if(Te.generateElementShape(e,null),o.isExporting){let[i,a,l,c]=ee(e),s=(i+l)/2+n.scrollX,d=(a+c)/2+n.scrollY,m=(l-i)/2-(e.x-i),u=(c-a)/2-(e.y-a);r.save(),r.translate(s,d),r.rotate(e.angle),r.translate(-m,-u),Pm(e,t,r,o,n),r.restore()}else{let i=d2(e,o,n);m2(i,r,o,n)}break}case"rectangle":case"diamond":case"ellipse":case"line":case"arrow":case"image":case"text":case"iframe":case"embeddable":{if(Te.generateElementShape(e,o),o.isExporting){let[i,a,l,c]=ee(e),s=(i+l)/2+n.scrollX,d=(a+c)/2+n.scrollY,m=(l-i)/2-(e.x-i),u=(c-a)/2-(e.y-a);if(z(e)){let g=je(e);if(ve(g)){let b=K.getBoundTextElementPosition(g,e);m=(l-i)/2-(b.x-i),u=(c-a)/2-(b.y-a)}}r.save(),r.translate(s,d),f2(e,o,n)&&(r.filter="none");let p=le(e);if(ve(e)&&p){let g=document.createElement("canvas"),b=g.getContext("2d"),E=Math.max(kt(i,l),kt(a,c)),w=Dm(e);g.width=E*n.exportScale+w*10*n.exportScale,g.height=E*n.exportScale+w*10*n.exportScale,b.translate(g.width/2,g.height/2),b.scale(n.exportScale,n.exportScale),m=e.width/2-(e.x-i),u=e.height/2-(e.y-a),b.rotate(e.angle);let v=p2.canvas(g);b.translate(-m,-u),Pm(e,v,b,o,n),b.translate(m,u),b.rotate(-e.angle);let[,,,,T,k]=ee(p),M=(i+l)/2-T,A=(a+c)/2-k;b.translate(-M,-A),b.clearRect(-p.width/2,-p.height/2,p.width,p.height),r.scale(1/n.exportScale,1/n.exportScale),r.drawImage(g,-g.width/2,-g.height/2,g.width,g.height)}else r.rotate(e.angle),e.type==="image"&&r.scale(e.scale[0],e.scale[1]),r.translate(-m,-u),Pm(e,t,r,o,n);r.restore()}else{let i=d2(e,o,n),a=r.imageSmoothingEnabled;!n?.shouldCacheIgnoreZoom&&(!e.angle||w2(e.angle))&&(r.imageSmoothingEnabled=!1),m2(i,r,o,n),r.imageSmoothingEnabled=a}break}default:throw new Error(`Unimplemented type ${e.type}`)}},Js=(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)},Qs=(e,t,r,o)=>{if(!o.enabled||!o.clip)return null;let n=jt(e);if(n){let i=t.ownerDocument.createElementNS(et,"g");return i.setAttributeNS(et,"clip-path",`url(#${n.id})`),r.forEach(a=>i.appendChild(a)),i}return null},Zd=(e,t,r,o,n,i,a)=>{let l={x:n,y:i},[c,s,d,m]=ee(e),u=(d-c)/2-(e.x-c),p=(m-s)/2-(e.y-s);if(z(e)){let v=je(e);if(ve(v)){let[T,k,M,A]=ee(v),D=K.getBoundTextElementPosition(v,e);u=(M-T)/2-(D.x-T),p=(A-k)/2-(D.y-k),n=n+D.x-e.x,i=i+D.y-e.y}}let g=180*e.angle/Math.PI,b=r;if(e.link){let v=r.ownerDocument.createElementNS(et,"a");v.setAttribute("href",ir(e.link)),b.appendChild(v),b=v}let E=(v,T)=>{kr()&&v.setAttribute("data-id",T.id),b.appendChild(v)},w=(jt(e)?.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 v=Te.generateElementShape(e,null),T=Js(t,v,Ra);w!==1&&(T.setAttribute("stroke-opacity",`${w}`),T.setAttribute("fill-opacity",`${w}`)),T.setAttribute("stroke-linecap","round"),T.setAttribute("transform",`translate(${n||0} ${i||0}) rotate(${g} ${u} ${p})`);let k=Qs(e,b,[T],a.frameRendering);E(k||T,e);break}case"iframe":case"embeddable":{let v=Te.generateElementShape(e,a),T=Js(t,v,Ra),k=e.opacity/100;k!==1&&(T.setAttribute("stroke-opacity",`${k}`),T.setAttribute("fill-opacity",`${k}`)),T.setAttribute("stroke-linecap","round"),T.setAttribute("transform",`translate(${n||0} ${i||0}) rotate(${g} ${u} ${p})`),E(T,e);let M=_d(e);Zd(M,t,b,o,M.x+l.x-e.x,M.y+l.y-e.y,a);let A=Js(t,v,Ra);for(A.setAttribute("stroke-linecap","round"),A.setAttribute("transform",`translate(${n||0} ${i||0}) rotate(${g} ${u} ${p})`);A.firstChild;)A.removeChild(A.firstChild);let D=hi(Math.min(e.width,e.height),e),R=un(Ud(e.link||""));if(a.renderEmbeddables===!1||R?.type==="document"){let H=r.ownerDocument.createElementNS(et,"a");H.setAttribute("href",ir(e.link||"")),H.setAttribute("target","_blank"),H.setAttribute("rel","noopener noreferrer"),H.style.borderRadius=`${D}px`,A.appendChild(H)}else{let H=r.ownerDocument.createElementNS(et,"foreignObject");H.style.width=`${e.width}px`,H.style.height=`${e.height}px`,H.style.border="none";let C=H.ownerDocument.createElementNS(et,"div");C.setAttribute("xmlns","http://www.w3.org/1999/xhtml"),C.style.width="100%",C.style.height="100%";let O=C.ownerDocument.createElement("iframe");O.src=R?.link??"",O.style.width="100%",O.style.height="100%",O.style.border="none",O.style.borderRadius=`${D}px`,O.style.top="0",O.style.left="0",O.allowFullscreen=!0,C.appendChild(O),H.appendChild(C),A.appendChild(H)}E(A,e);break}case"line":case"arrow":{let v=le(e),T=r.ownerDocument.createElementNS(et,"mask");if(v){T.setAttribute("id",`mask-${e.id}`);let D=r.ownerDocument.createElementNS(et,"rect");n=n||0,i=i||0,D.setAttribute("x","0"),D.setAttribute("y","0"),D.setAttribute("fill","#fff"),D.setAttribute("width",`${e.width+100+n}`),D.setAttribute("height",`${e.height+100+i}`),T.appendChild(D);let R=r.ownerDocument.createElementNS(et,"rect"),H=K.getBoundTextElementPosition(e,v),C=n+H.x-e.x,O=i+H.y-e.y;R.setAttribute("x",C.toString()),R.setAttribute("y",O.toString()),R.setAttribute("fill","#000"),R.setAttribute("width",`${v.width}`),R.setAttribute("height",`${v.height}`),R.setAttribute("opacity","1"),T.appendChild(R)}let k=r.ownerDocument.createElementNS(et,"g");v&&k.setAttribute("mask",`url(#mask-${e.id})`),k.setAttribute("stroke-linecap","round"),Te.generateElementShape(e,a).forEach(D=>{let R=Js(t,D,Ra);w!==1&&(R.setAttribute("stroke-opacity",`${w}`),R.setAttribute("fill-opacity",`${w}`)),R.setAttribute("transform",`translate(${n||0} ${i||0}) rotate(${g} ${u} ${p})`),e.type==="line"&&xr(e.points)&&e.backgroundColor!=="transparent"&&R.setAttribute("fill-rule","evenodd"),k.appendChild(R)});let A=Qs(e,b,[k,T],a.frameRendering);A?(E(A,e),b.appendChild(A)):(E(k,e),b.append(T));break}case"freedraw":{let v=Te.generateElementShape(e,a),T=v?Js(t,v,Ra):r.ownerDocument.createElementNS(et,"g");w!==1&&(T.setAttribute("stroke-opacity",`${w}`),T.setAttribute("fill-opacity",`${w}`)),T.setAttribute("transform",`translate(${n||0} ${i||0}) rotate(${g} ${u} ${p})`),T.setAttribute("stroke","none");let k=r.ownerDocument.createElementNS(et,"path");k.setAttribute("fill",e.strokeColor),k.setAttribute("d",nh(e)),T.appendChild(k);let M=Qs(e,b,[T],a.frameRendering);E(M||T,e);break}case"image":{let v=Math.round(e.width),T=Math.round(e.height),k=ur(e)&&o[e.fileId];if(k){let M=`image-${k.id}`,A=r.querySelector(`#${M}`);if(!A){A=r.ownerDocument.createElementNS(et,"symbol"),A.id=M;let C=r.ownerDocument.createElementNS(et,"image");C.setAttribute("width","100%"),C.setAttribute("height","100%"),C.setAttribute("href",k.dataURL),A.appendChild(C),b.prepend(A)}let D=r.ownerDocument.createElementNS(et,"use");if(D.setAttribute("href",`#${M}`),a.exportWithDarkMode&&k.mimeType!==Z.svg&&D.setAttribute("filter",g2),D.setAttribute("width",`${v}`),D.setAttribute("height",`${T}`),D.setAttribute("opacity",`${w}`),e.scale[0]!==1||e.scale[1]!==1){let C=e.scale[0]!==1?-v:0,O=e.scale[1]!==1?-T:0;D.setAttribute("transform",`scale(${e.scale[0]}, ${e.scale[1]}) translate(${C} ${O})`)}let R=r.ownerDocument.createElementNS(et,"g");R.appendChild(D),R.setAttribute("transform",`translate(${n||0} ${i||0}) rotate(${g} ${u} ${p})`);let H=Qs(e,b,[R],a.frameRendering);E(H||R,e)}break}case"frame":case"magicframe":{if(a.frameRendering.enabled&&a.frameRendering.outline){let v=document.createElementNS(et,"rect");v.setAttribute("transform",`translate(${n||0} ${i||0}) rotate(${g} ${u} ${p})`),v.setAttribute("width",`${e.width}px`),v.setAttribute("height",`${e.height}px`),v.setAttribute("rx",Qe.radius.toString()),v.setAttribute("ry",Qe.radius.toString()),v.setAttribute("fill","none"),v.setAttribute("stroke",Qe.strokeColor),v.setAttribute("stroke-width",Qe.strokeWidth.toString()),E(v,e)}break}default:if(z(e)){let v=r.ownerDocument.createElementNS(et,"g");w!==1&&(v.setAttribute("stroke-opacity",`${w}`),v.setAttribute("fill-opacity",`${w}`)),v.setAttribute("transform",`translate(${n||0} ${i||0}) rotate(${g} ${u} ${p})`);let T=e.text.replace(/\r\n?/g,`
|
|
22
|
+
`),intrinsicSize:{w:550,h:720}};return bn.set(e,s),s}return bn.set(e,{link:e,intrinsicSize:o,type:r}),{link:e,intrinsicSize:o,type:r}},kd=e=>{let t;Fr(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=it.Helvetica,n=Be({fontSize:r,fontFamily:o});return Lt({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:qn(t,n,e.width-20),textAlign:"center",verticalAlign:gt.MIDDLE,angle:e.angle??0})},ID=N({name:"setEmbeddableAsActiveTool",trackEvent:{category:"toolbar"},perform:(e,t,r,o)=>{let n=Ke(t,{type:"embeddable"});return kr(o.canvas,{...t,activeTool:n}),{elements:e,appState:{...t,activeTool:Ke(t,{type:"embeddable"})},commitToHistory:!1}}}),Rx=(e,t)=>{try{let{hostname:r}=new URL(e),o=r.replace(/^www\./,""),n=o.replace(/^([^.]+)/,"*");if(t instanceof Set)return qu.has(o)||qu.has(n);if(o===t.replace(/^www\./,""))return!0}catch{}return!1},Nx=e=>{let t=e.match(H6);if(t&&t.length===2)return t[1];let r=e.match(O6);if(r&&r.length===2)return r[1];if(Dx.test(e))return`https://giphy.com/embed/${Dx.exec(e)[1]}`;let o=e.match(G6);return o&&o.length===2?o[1]:e},qa=(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(Rx(e,r))return!0;return!1}}return Rx(e,qu)}});var As,Ms,Ju,Bx,Ox=Z(()=>{"use strict";h();W();Xa();me();ks();$t();lt();oe();Xt();Ht();uo();F();ln();As=(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)},Ms=(e,t,r,o,n)=>{if(!o.enabled||!o.clip)return null;let i=Pt(e,n);if(i){let a=t.ownerDocument.createElementNS(_e,"g");return a.setAttributeNS(_e,"clip-path",`url(#${i.id})`),r.forEach(l=>a.appendChild(l)),a}return null},Ju=(e,t,r,o,n,i,a,l)=>{let s={x:i,y:a},[c,d,m,p]=j(e,t),u=(m-c)/2-(e.x-c),g=(p-d)/2-(e.y-d);if(G(e)){let w=st(e,t);if(we(w)){let[I,k,C,D]=j(w,t),R=V.getBoundTextElementPosition(w,e,t);u=(C-I)/2-(R.x-I),g=(D-k)/2-(R.y-k),i=i+R.x-e.x,a=a+R.y-e.y}}let f=180*e.angle/Math.PI,E=o;if(e.link){let w=o.ownerDocument.createElementNS(_e,"a");w.setAttribute("href",tr(e.link)),E.appendChild(w),E=w}let y=(w,I)=>{wr()&&w.setAttribute("data-id",I.id),E.appendChild(w)},T=(Pt(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=Te.generateElementShape(e,null),I=As(r,w,Ia);T!==1&&(I.setAttribute("stroke-opacity",`${T}`),I.setAttribute("fill-opacity",`${T}`)),I.setAttribute("stroke-linecap","round"),I.setAttribute("transform",`translate(${i||0} ${a||0}) rotate(${f} ${u} ${g})`);let k=Ms(e,E,[I],l.frameRendering,t);y(k||I,e);break}case"iframe":case"embeddable":{let w=Te.generateElementShape(e,l),I=As(r,w,Ia),k=e.opacity/100;k!==1&&(I.setAttribute("stroke-opacity",`${k}`),I.setAttribute("fill-opacity",`${k}`)),I.setAttribute("stroke-linecap","round"),I.setAttribute("transform",`translate(${i||0} ${a||0}) rotate(${f} ${u} ${g})`),y(I,e);let C=kd(e);Ju(C,t,r,E,n,C.x+s.x-e.x,C.y+s.y-e.y,l);let D=As(r,w,Ia);for(D.setAttribute("stroke-linecap","round"),D.setAttribute("transform",`translate(${i||0} ${a||0}) rotate(${f} ${u} ${g})`);D.firstChild;)D.removeChild(D.firstChild);let R=mo(Math.min(e.width,e.height),e),z=xn(yd(e.link||""));if(l.renderEmbeddables===!1||z?.type==="document"){let L=o.ownerDocument.createElementNS(_e,"a");L.setAttribute("href",tr(e.link||"")),L.setAttribute("target","_blank"),L.setAttribute("rel","noopener noreferrer"),L.style.borderRadius=`${R}px`,D.appendChild(L)}else{let L=o.ownerDocument.createElementNS(_e,"foreignObject");L.style.width=`${e.width}px`,L.style.height=`${e.height}px`,L.style.border="none";let M=L.ownerDocument.createElementNS(_e,"div");M.setAttribute("xmlns","http://www.w3.org/1999/xhtml"),M.style.width="100%",M.style.height="100%";let A=M.ownerDocument.createElement("iframe");A.src=z?.link??"",A.style.width="100%",A.style.height="100%",A.style.border="none",A.style.borderRadius=`${R}px`,A.style.top="0",A.style.left="0",A.allowFullscreen=!0,M.appendChild(A),L.appendChild(M),D.appendChild(L)}y(D,e);break}case"line":case"arrow":{let w=ae(e,t),I=o.ownerDocument.createElementNS(_e,"mask");if(w){I.setAttribute("id",`mask-${e.id}`);let R=o.ownerDocument.createElementNS(_e,"rect");i=i||0,a=a||0,R.setAttribute("x","0"),R.setAttribute("y","0"),R.setAttribute("fill","#fff"),R.setAttribute("width",`${e.width+100+i}`),R.setAttribute("height",`${e.height+100+a}`),I.appendChild(R);let z=o.ownerDocument.createElementNS(_e,"rect"),L=V.getBoundTextElementPosition(e,w,t),M=i+L.x-e.x,A=a+L.y-e.y;z.setAttribute("x",M.toString()),z.setAttribute("y",A.toString()),z.setAttribute("fill","#000"),z.setAttribute("width",`${w.width}`),z.setAttribute("height",`${w.height}`),z.setAttribute("opacity","1"),I.appendChild(z)}let k=o.ownerDocument.createElementNS(_e,"g");w&&k.setAttribute("mask",`url(#mask-${e.id})`),k.setAttribute("stroke-linecap","round"),Te.generateElementShape(e,l).forEach(R=>{let z=As(r,R,Ia);T!==1&&(z.setAttribute("stroke-opacity",`${T}`),z.setAttribute("fill-opacity",`${T}`)),z.setAttribute("transform",`translate(${i||0} ${a||0}) rotate(${f} ${u} ${g})`),e.type==="line"&&dr(e.points)&&e.backgroundColor!=="transparent"&&z.setAttribute("fill-rule","evenodd"),k.appendChild(z)});let D=Ms(e,E,[k,I],l.frameRendering,t);D?(y(D,e),E.appendChild(D)):(y(k,e),E.append(I));break}case"freedraw":{let w=Te.generateElementShape(e,l),I=w?As(r,w,Ia):o.ownerDocument.createElementNS(_e,"g");T!==1&&(I.setAttribute("stroke-opacity",`${T}`),I.setAttribute("fill-opacity",`${T}`)),I.setAttribute("transform",`translate(${i||0} ${a||0}) rotate(${f} ${u} ${g})`),I.setAttribute("stroke","none");let k=o.ownerDocument.createElementNS(_e,"path");k.setAttribute("fill",e.strokeColor),k.setAttribute("d",Ad(e)),I.appendChild(k);let C=Ms(e,E,[I],l.frameRendering,t);y(C||I,e);break}case"image":{let w=Math.round(e.width),I=Math.round(e.height),k=Qt(e)&&n[e.fileId];if(k){let C=`image-${k.id}`,D=o.querySelector(`#${C}`);if(!D){D=o.ownerDocument.createElementNS(_e,"symbol"),D.id=C;let M=o.ownerDocument.createElementNS(_e,"image");M.setAttribute("width","100%"),M.setAttribute("height","100%"),M.setAttribute("href",k.dataURL),D.appendChild(M),E.prepend(D)}let R=o.ownerDocument.createElementNS(_e,"use");if(R.setAttribute("href",`#${C}`),l.exportWithDarkMode&&k.mimeType!==$.svg&&R.setAttribute("filter",Qu),R.setAttribute("width",`${w}`),R.setAttribute("height",`${I}`),R.setAttribute("opacity",`${T}`),e.scale[0]!==1||e.scale[1]!==1){let M=e.scale[0]!==1?-w:0,A=e.scale[1]!==1?-I:0;R.setAttribute("transform",`scale(${e.scale[0]}, ${e.scale[1]}) translate(${M} ${A})`)}let z=o.ownerDocument.createElementNS(_e,"g");if(z.appendChild(R),z.setAttribute("transform",`translate(${i||0} ${a||0}) rotate(${f} ${u} ${g})`),e.roundness){let M=o.ownerDocument.createElementNS(_e,"clipPath");M.id=`image-clipPath-${e.id}`;let A=o.ownerDocument.createElementNS(_e,"rect"),H=mo(Math.min(e.width,e.height),e);A.setAttribute("width",`${e.width}`),A.setAttribute("height",`${e.height}`),A.setAttribute("rx",`${H}`),A.setAttribute("ry",`${H}`),M.appendChild(A),y(M,e),z.setAttributeNS(_e,"clip-path",`url(#${M.id})`)}let L=Ms(e,E,[z],l.frameRendering,t);y(L||z,e)}break}case"frame":case"magicframe":{if(l.frameRendering.enabled&&l.frameRendering.outline){let w=document.createElementNS(_e,"rect");w.setAttribute("transform",`translate(${i||0} ${a||0}) rotate(${f} ${u} ${g})`),w.setAttribute("width",`${e.width}px`),w.setAttribute("height",`${e.height}px`),w.setAttribute("rx",Ue.radius.toString()),w.setAttribute("ry",Ue.radius.toString()),w.setAttribute("fill","none"),w.setAttribute("stroke",Ue.strokeColor),w.setAttribute("stroke-width",Ue.strokeWidth.toString()),y(w,e)}break}default:if(G(e)){let w=o.ownerDocument.createElementNS(_e,"g");T!==1&&(w.setAttribute("stroke-opacity",`${T}`),w.setAttribute("fill-opacity",`${T}`)),w.setAttribute("transform",`translate(${i||0} ${a||0}) rotate(${f} ${u} ${g})`);let I=e.text.replace(/\r\n?/g,`
|
|
22
23
|
`).split(`
|
|
23
|
-
`),k=pa(e.fontSize,e.lineHeight),M=e.textAlign==="center"?e.width/2:e.textAlign==="right"?e.width:0,A=Dp(e.text)?"rtl":"ltr",D=e.textAlign==="center"?"middle":e.textAlign==="right"||A==="rtl"?"end":"start";for(let H=0;H<T.length;H++){let C=r.ownerDocument.createElementNS(et,"text");C.textContent=T[H],C.setAttribute("x",`${M}`),C.setAttribute("y",`${H*k}`),C.setAttribute("font-family",Oa(e)),C.setAttribute("font-size",`${e.fontSize}px`),C.setAttribute("fill",e.strokeColor),C.setAttribute("text-anchor",D),C.setAttribute("style","white-space: pre;"),C.setAttribute("direction",A),C.setAttribute("dominant-baseline","text-before-edge"),v.appendChild(C)}let R=Qs(e,b,[v],a.frameRendering);E(R||v,e)}else throw new Error(`Unimplemented type ${e.type}`)}},E2=new WeakMap([]);JA=/(\s?[A-Z]?,?-?[0-9]*\.[0-9]{0,2})(([0-9]|e|-)*)/g});import{simplify as eM}from"points-on-curve";function rM(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&&wl(e.type)||te(e)&&r>=50?t:Math.min(t/(r<10?3:2),2.5)}var tM,I2,Or,v2,T2,ty,ig=y(()=>{"use strict";h();ue();Zt();nl();W();X();ae();Ys();tM=e=>[8,8+e],I2=e=>[1.5,6+e];Or=(e,t=!1)=>{let r={seed:e.seed,strokeLineDash:e.strokeStyle==="dashed"?tM(e.strokeWidth):e.strokeStyle==="dotted"?I2(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:rM(e),stroke:e.strokeColor,preserveVertices:t||e.roughness<Mp.cartoonist};switch(e.type){case"rectangle":case"iframe":case"embeddable":case"diamond":case"ellipse":return r.fillStyle=e.fillStyle,r.fill=or(e.backgroundColor)?void 0:e.backgroundColor,e.type==="ellipse"&&(r.curveFitting=1),r;case"line":case"freedraw":return xr(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}`)}},v2=(e,t)=>nr(e)&&(t||At(e)&&!e.validated)&&or(e.backgroundColor)&&or(e.strokeColor)?{...e,roughness:0,backgroundColor:"#d3d3d3",fillStyle:"solid"}:Kr(e)?{...e,strokeColor:or(e.strokeColor)?"#000000":e.strokeColor,backgroundColor:or(e.backgroundColor)?"#f4f4f6":e.backgroundColor}:e,T2=(e,t,r,o,n,i,a)=>{let l=ah(e,t,r,o);if(l===null)return[];switch(o){case"dot":case"circle":case"circle_outline":{let[c,s,d]=l;return delete i.strokeLineDash,[n.circle(c,s,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[c,s,d,m,u,p]=l;return delete i.strokeLineDash,[n.polygon([[c,s],[d,m],[u,p],[c,s]],{...i,fill:o==="triangle_outline"?a:e.strokeColor,fillStyle:"solid",roughness:Math.min(1,i.roughness||0)})]}case"diamond":case"diamond_outline":{let[c,s,d,m,u,p,g,b]=l;return delete i.strokeLineDash,[n.polygon([[c,s],[d,m],[u,p],[g,b],[c,s]],{...i,fill:o==="diamond_outline"?a:e.strokeColor,fillStyle:"solid",roughness:Math.min(1,i.roughness||0)})]}case"bar":case"arrow":default:{let[c,s,d,m,u,p]=l;if(e.strokeStyle==="dotted"){let g=I2(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,c,s,i),n.line(u,p,c,s,i)]}}},ty=(e,t,{isExporting:r,canvasBackgroundColor:o})=>{switch(e.type){case"rectangle":case"iframe":case"embeddable":{let n;if(e.roundness){let i=e.width,a=e.height,l=hi(Math.min(i,a),e);n=t.path(`M ${l} 0 L ${i-l} 0 Q ${i} 0, ${i} ${l} L ${i} ${a-l} Q ${i} ${a}, ${i-l} ${a} L ${l} ${a} Q 0 ${a}, 0 ${a-l} L 0 ${l} Q 0 0, ${l} 0`,Or(v2(e,r),!0))}else n=t.rectangle(0,0,e.width,e.height,Or(v2(e,r),!1));return n}case"diamond":{let n,[i,a,l,c,s,d,m,u]=ih(e);if(e.roundness){let p=hi(Math.abs(i-m),e),g=hi(Math.abs(c-a),e);n=t.path(`M ${i+p} ${a+g} L ${l-p} ${c-g}
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
L ${m+p} ${u+g}
|
|
28
|
-
C ${m} ${u}, ${m} ${u}, ${m+p} ${u-g}
|
|
29
|
-
L ${i-p} ${a+g}
|
|
30
|
-
C ${i} ${a}, ${i} ${a}, ${i+p} ${a+g}`,Or(e,!0))}else n=t.polygon([[i,a],[l,c],[s,d],[m,u]],Or(e));return n}case"ellipse":return t.ellipse(e.width/2,e.height/2,e.width,e.height,Or(e));case"line":case"arrow":{let n,i=Or(e),a=e.points.length?e.points:[[0,0]];if(e.roundness?n=[t.curve(a,i)]:i.fill?n=[t.polygon(a,i)]:n=[t.linearPath(a,i)],e.type==="arrow"){let{startArrowhead:l=null,endArrowhead:c="arrow"}=e;if(l!==null){let s=T2(e,n,"start",l,t,i,o);n.push(...s)}if(c!==null){let s=T2(e,n,"end",c,t,i,o);n.push(...s)}}return n}case"freedraw":{let n;if(y2(e),xr(e.points)){let i=eM(e.points,.75);n=t.curve(i,{...Or(e),stroke:"none"})}else n=null;return n}case"frame":case"magicframe":case"text":case"image":return null;default:return Zn(e,`generateElementShape(): Unimplemented type ${e?.type}`),null}}});var Rm,fi,ec=y(()=>{"use strict";h();Rm=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)}},fi=(e,t,r,o)=>{let n=r.map(p=>p[e]),i=Math.max(...n),a=Math.min(...n),l=i-a,c=l===0?1:t/l,s=1/0,d=r.map(p=>{let g=p[e]*c,b=[...p];return b[e]=g,g<s&&(s=g),b});if(!o||d.length===2)return d;let m=a-s;return d.map(p=>p.map((g,b)=>b===e?g+m:g))}});import sh from"roughjs/bin/rough";var lh,ee,ch,Gy,ih,So,S2,C2,oM,Hs,dh,nM,iM,aM,ah,lM,sM,io,we,Nm,ta,fl,$g,wr,cM,yt=y(()=>{"use strict";h();Zt();ig();ae();ec();pt();ar();Io();Er();lh=class e{static boundsCache=new WeakMap;static getBounds(t){let r=e.boundsCache.get(t);if(r?.version&&r.version===t.version&&!ke(t))return r.bounds;let o=e.calculateBounds(t);return xe.getScene(t)&&e.boundsCache.set(t,{version:t.version,bounds:o}),o}static calculateBounds(t){let r,[o,n,i,a,l,c]=ee(t);if(xt(t)){let[s,d,m,u]=dh(t.points.map(([p,g])=>fe(p,g,l-t.x,c-t.y,t.angle)));return[s+t.x,d+t.y,m+t.x,u+t.y]}else if(te(t))r=sM(t,l,c);else if(t.type==="diamond"){let[s,d]=fe(l,n,l,c,t.angle),[m,u]=fe(l,a,l,c,t.angle),[p,g]=fe(o,c,l,c,t.angle),[b,E]=fe(i,c,l,c,t.angle),w=Math.min(s,m,p,b),v=Math.min(d,u,g,E),T=Math.max(s,m,p,b),k=Math.max(d,u,g,E);r=[w,v,T,k]}else if(t.type==="ellipse"){let s=(i-o)/2,d=(a-n)/2,m=Math.cos(t.angle),u=Math.sin(t.angle),p=Math.hypot(s*m,d*u),g=Math.hypot(d*m,s*u);r=[l-p,c-g,l+p,c+g]}else{let[s,d]=fe(o,n,l,c,t.angle),[m,u]=fe(o,a,l,c,t.angle),[p,g]=fe(i,a,l,c,t.angle),[b,E]=fe(i,n,l,c,t.angle),w=Math.min(s,m,p,b),v=Math.min(d,u,g,E),T=Math.max(s,m,p,b),k=Math.max(d,u,g,E);r=[w,v,T,k]}return r}},ee=(e,t=!1)=>{if(xt(e))return nM(e);if(te(e))return K.getElementAbsoluteCoords(e,t);if(z(e)){let r=je(e);if(ve(r)){let o=K.getBoundTextElementPosition(r,e);return[o.x,o.y,o.x+e.width,o.y+e.height,o.x+e.width/2,o.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]},ch=e=>{let[t,r,o,n,i,a]=ee(e),l=[i,a];if(te(e)||xt(e)){let E=[],w=0;for(;w<e.points.length-1;)E.push([Fe([e.points[w][0]+e.x,e.points[w][1]+e.y],l,e.angle),Fe([e.points[w+1][0]+e.x,e.points[w+1][1]+e.y],l,e.angle)]),w++;return E}let[c,s,d,m,u,p,g,b]=[[t,r],[o,r],[t,n],[o,n],[i,r],[i,n],[t,a],[o,a]].map(E=>Fe(E,l,e.angle));return e.type==="diamond"?[[u,g],[u,b],[p,g],[p,b]]:e.type==="ellipse"?[[u,g],[u,b],[p,g],[p,b],[u,g],[u,b],[p,g],[p,b]]:[[c,s],[d,m],[c,d],[s,m],[c,b],[d,b],[s,g],[m,g]]},Gy=e=>[e.x,e.y,e.x+e.width,e.y+e.height,e.x+e.width/2,e.y+e.height/2],ih=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]},So=e=>{for(let t of e.sets)if(t.type==="path")return t.ops;return e.sets[0].ops},S2=(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},C2=(e,t,r,o)=>{let n=t-e,i=r-t,a=o-r,l=3*n-6*i+3*a,c=6*i-6*n,s=3*n,d=c*c-4*l*s;if(!(d>=0))return!1;let u=null,p=null,g=1/0,b=1/0;return l===0?g=b=-s/c:(g=(-c+Math.sqrt(d))/(2*l),b=(-c-Math.sqrt(d))/(2*l)),g>=0&&g<=1&&(u=S2(g,e,t,r,o)),b>=0&&b<=1&&(p=S2(b,e,t,r,o)),[u,p]},oM=(e,t,r,o)=>{let n=C2(e[0],t[0],r[0],o[0]),i=C2(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 c=Math.min(e[1],o[1]),s=Math.max(e[1],o[1]);if(i){let d=i.filter(m=>m!==null);c=Math.min(c,...d),s=Math.max(s,...d)}return[a,c,l,s]},Hs=(e,t)=>{let r=[0,0],{minX:o,minY:n,maxX:i,maxY:a}=e.reduce((l,{op:c,data:s})=>{if(c==="move")r=s;else if(c==="bcurveTo"){let d=[s[0],s[1]],m=[s[2],s[3]],u=[s[4],s[5]],p=t?t(...d):d,g=t?t(...m):m,b=t?t(...u):u,E=t?t(...r):r;r=u;let[w,v,T,k]=oM(E,p,g,b);l.minX=Math.min(l.minX,w),l.minY=Math.min(l.minY,v),l.maxX=Math.max(l.maxX,T),l.maxY=Math.max(l.maxY,k)}return l},{minX:1/0,minY:1/0,maxX:-1/0,maxY:-1/0});return[o,n,i,a]},dh=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]},nM=e=>{let[t,r,o,n]=dh(e.points),i=t+e.x,a=r+e.y,l=o+e.x,c=n+e.y;return[i,a,l,c,(i+l)/2,(a+c)/2]},iM=e=>{switch(e){case"arrow":return 25;case"diamond":case"diamond_outline":return 12;default:return 15}},aM=e=>{switch(e){case"bar":return 90;case"arrow":return 20;default:return 25}},ah=(e,t,r,o)=>{let n=So(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]],c=[a[2],a[3]],s=[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 u=(V,pe)=>Math.pow(1-V,3)*l[pe]+3*V*Math.pow(1-V,2)*c[pe]+3*Math.pow(V,2)*(1-V)*s[pe]+m[pe]*Math.pow(V,3),[p,g]=r==="start"?m:l,[b,E]=[u(.3,0),u(.3,1)],w=Math.hypot(p-b,g-E),v=(p-b)/w,T=(g-E)/w,k=iM(o),M=0;{let[V,pe]=r==="end"?e.points[e.points.length-1]:e.points[0],[Se,q]=e.points.length>1?r==="end"?e.points[e.points.length-2]:e.points[1]:[0,0];M=Math.hypot(V-Se,pe-q)}let D=Math.min(k,M*(o==="diamond"||o==="diamond_outline"?.25:.5)),R=p-v*D,H=g-T*D;if(o==="dot"||o==="circle"||o==="circle_outline"){let V=Math.hypot(H-g,R-p)+e.strokeWidth-2;return[p,g,V]}let C=aM(o),[O,P]=fe(R,H,p,g,-C*Math.PI/180),[G,j]=fe(R,H,p,g,C*Math.PI/180);if(o==="diamond"||o==="diamond_outline"){let V,pe;if(r==="start"){let[Se,q]=e.points.length>1?e.points[1]:[0,0];[V,pe]=fe(p+D*2,g,p,g,Math.atan2(q-g,Se-p))}else{let[Se,q]=e.points.length>1?e.points[e.points.length-2]:[0,0];[V,pe]=fe(p-D*2,g,p,g,Math.atan2(g-q,p-Se))}return[p,g,O,P,V,pe,G,j]}return[p,g,O,P,G,j]},lM=e=>{let t=sh.generator(),r=Or(e),o=e.roundness?"curve":r.fill?"polygon":"linearPath";return t[o](e.points,r)},sM=(e,t,r)=>{if(e.points.length<2){let[d,m]=e.points[0],[u,p]=fe(e.x+d,e.y+m,t,r,e.angle),g=[u,p,u,p],b=le(e);if(b){let E=K.getMinMaxXYWithBoundText(e,[u,p,u,p],b);g=[E[0],E[1],E[2],E[3]]}return g}let n=Te.get(e)?.[0]??lM(e),i=So(n),l=Hs(i,(d,m)=>fe(e.x+d,e.y+m,t,r,e.angle)),c=[l[0],l[1],l[2],l[3]],s=le(e);if(s){let d=K.getMinMaxXYWithBoundText(e,c,s);c=[d[0],d[1],d[2],d[3]]}return c},io=e=>lh.getBounds(e),we=e=>{if(!e.length)return[0,0,0,0];let t=1/0,r=-1/0,o=1/0,n=-1/0;return e.forEach(i=>{let[a,l,c,s]=io(i);t=Math.min(t,a),o=Math.min(o,l),r=Math.max(r,c),n=Math.max(n,s)}),[t,o,r,n]},Nm=(e,t)=>{let[r,o,n,i]=we(e);return[r+t.x,o+t.y,n+t.x,i+t.y]},ta=(e,t,r,o)=>{if(!(te(e)||xt(e)))return[e.x,e.y,e.x+t,e.y+r];let n=fi(0,t,fi(1,r,e.points,o),o),i;if(xt(e))i=dh(n);else{let d=sh.generator(),m=e.roundness?d.curve(n,Or(e)):d.linearPath(n,Or(e)),u=So(m);i=Hs(u)}let[a,l,c,s]=i;return[a+e.x,l+e.y,c+e.x,s+e.y]},fl=(e,t)=>{let r=sh.generator(),o=e.roundness==null?r.linearPath(t,Or(e)):r.curve(t,Or(e)),n=So(o),[i,a,l,c]=Hs(n);return[i+e.x,a+e.y,l+e.x,c+e.y]},$g=(e,t)=>{if(!e.length)return[0,0,0,0];let r=1/0,o=e[0];return e.forEach(n=>{let[i,a,l,c]=io(n),s=ct((i+l)/2,(a+c)/2,t.x,t.y);s<r&&(r=s,o=n)}),io(o)},wr=e=>{let[t,r,o,n]=we(e);return{minX:t,minY:r,maxX:o,maxY:n,width:o-t,height:n-r,midX:(t+o)/2,midY:(r+n)/2}},cM=({scrollX:e,scrollY:t,width:r,height:o,zoom:n})=>[-e,-t,-e+r/n.value,-t+o/n.value]});var fe,Fe,Md,ct,Fs,xr,hg,ga,tc,dM,wt,hi,Tg,Ig,mM,k2,Qy,ew,Sg,w2,rc,oc,kl,Zt=y(()=>{"use strict";h();X();yt();Io();fe=(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],Fe=(e,t,r)=>fe(e[0],e[1],t[0],t[1],r),Md=(e,t,r,o,n,i,a,l)=>{let c=Math.cos(o),s=Math.sin(o);return e.e&&e.w?t+=n+a:e.e?(t+=n*(1+c),r+=n*s,t+=a*(1-c),r+=a*-s):e.w&&(t+=n*(1-c),r+=n*-s,t+=a*(1+c),r+=a*s),e.n&&e.s?r+=i+l:e.n?(t+=i*s,r+=i*(1-c),t+=l*-s,r+=l*(1+c)):e.s&&(t+=i*-s,r+=i*(1+c),t+=l*s,r+=l*(1-c)),[t,r]},ct=(e,t,r,o)=>{let n=r-e,i=o-t;return Math.hypot(n,i)},Fs=(e,t)=>[(e[0]+t[0])/2,(e[1]+t[1])/2],xr=(e,t=1)=>{if(e.length>=3){let[r,o]=[e[0],e[e.length-1]];return ct(r[0],r[1],o[0],o[1])<=Pa/t}return!1},hg=(e,t,r)=>{let o=e.length;if(o<3)return!1;let n=[Number.MAX_SAFE_INTEGER,r],i=[t,r],a=0;for(let l=0;l<o;l++){let c=e[l],s=e[(l+1)%o];if(dM(c,s,i,n)){if(tc(c,i,s)===0)return ga(c,i,s);a++}}return a%2===1},ga=(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]),tc=(e,t,r)=>{let o=(t[1]-e[1])*(r[0]-t[0])-(t[0]-e[0])*(r[1]-t[1]);return o===0?0:o>0?1:2},dM=(e,t,r,o)=>{let n=tc(e,t,r),i=tc(e,t,o),a=tc(r,o,e),l=tc(r,o,t);return!!(n!==i&&a!==l||n===0&&ga(e,r,t)||i===0&&ga(e,o,t)||a===0&&ga(r,e,o)||l===0&&ga(r,t,o))},wt=(e,t,r)=>r?[Math.round(e/r)*r,Math.round(t/r)*r]:[e,t],hi=(e,t)=>{if(t.roundness?.type===st.PROPORTIONAL_RADIUS||t.roundness?.type===st.LEGACY)return e*id;if(t.roundness?.type===st.ADAPTIVE_RADIUS){let r=t.roundness?.value??nx,o=r/id;return e<=o?e*id:r}return 0},Tg=(e,t)=>{let r=Te.generateElementShape(e,null);if(!r)return null;let o=So(r[0]),n=[0,0],i=0,a=1/0,l=null;for(;i<o.length;){let{op:c,data:s}=o[i];if(c==="move"&&(n=s),c==="bcurveTo"){let d=n,m=[s[0],s[1]],u=[s[2],s[3]],p=[s[4],s[5]],g=ct(p[0],p[1],t[0],t[1]);g<a&&(a=g,l=[d,m,u,p]),n=p}i++}return l},Ig=(e,t,r,o,n)=>{let i=(c,s)=>Math.pow(1-c,3)*o[s]+3*c*Math.pow(1-c,2)*r[s]+3*Math.pow(c,2)*(1-c)*t[s]+e[s]*Math.pow(c,3),a=i(n,0),l=i(n,1);return[a,l]},mM=(e,t)=>{let r=Tg(e,t);if(!r)return[];let o=[],n=1;for(;n>0;){let i=Ig(r[0],r[1],r[2],r[3],n);o.push([i[0],i[1]]),n-=.05}return o.length&&Sg(o.at(-1),t)&&o.push([t[0],t[1]]),o},k2=(e,t)=>{let r=[];r[0]=0;let o=mM(e,t),n=0,i=0;for(;n<o.length-1;){let a=ct(o[n][0],o[n][1],o[n+1][0],o[n+1][1]);i+=a,r.push(i),n++}return r},Qy=(e,t)=>k2(e,t).at(-1),ew=(e,t,r)=>{let o=k2(e,t),n=o.length-1,i=o.at(-1),a=r*i,l=0,c=n,s=0;for(;l<c;)s=Math.floor(l+(c-l)/2),o[s]<a?l=s+1:c=s;return o[s]>a&&s--,o[s]===a?s/n:1-(s+(a-o[s])/(o[s+1]-o[s]))/n},Sg=(e,t)=>e[0]===t[0]&&e[1]===t[1],w2=e=>Math.round(e/Math.PI*1e4)%5e3===0,rc=([e,t],[r,o])=>e<=r?t>=r:e>=r?o>=e:!1,oc=(e,t)=>{let r=Math.max(e[0],t[0]),o=Math.min(e[1],t[1]);return r<=o?[r,o]:null},kl=(e,t,r)=>e>=t&&e<=r});function A2(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 _2(e,t){return e[0]*t[1]-t[0]*e[1]}function uM(e,t){return e[0]<=t[2]&&e[2]>=t[0]&&e[1]<=t[3]&&e[3]>=t[1]}function Bm(e,t){return[e[0]-t[0],e[1]-t[1]]}function M2(e,t){let r=Bm(e[1],e[0]),o=Bm(t,e[0]),n=_2(r,o);return Math.abs(n)<pM}function mh(e,t){let r=Bm(e[1],e[0]),o=Bm(t,e[0]);return _2(r,o)<0}function L2(e,t){return M2(e,t[0])||M2(e,t[1])||(mh(e,t[0])?!mh(e,t[1]):mh(e,t[1]))}function P2(e,t){return uM(A2(e),A2(t))&&L2(e,t)&&L2(t,e)}var pM,D2=y(()=>{"use strict";h();pM=1e-6});var gM,hM,R2,N2,uh,B2,ha,O2=y(()=>{"use strict";h();Om();gM=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]],hM=e=>te(e)||xt(e)?e.points:gM(e),R2=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},N2=e=>{let t=hM(e),{cx:r,cy:o}=R2(t),n=[r,o],i=t.map(d=>Fe([d[0],d[1]],n,e.angle)),{minX:a,minY:l,maxX:c,maxY:s}=R2(i);return[a+e.x,l+e.y,c+e.x,s+e.y]},uh=(e,t,r=!1)=>{let o=N2(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},B2=(e,t)=>{let r=N2(e);return(kl(r[0],t[0],t[2])||kl(t[0],r[0],r[2]))&&(kl(r[1],t[1],t[3])||kl(t[1],r[1],r[3]))},ha=({elements:e,bounds:t,type:r,errorMargin:o=0})=>{za(t)&&(t=io(t));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"?B2(a,n):r==="inside"?uh(a,n):uh(a,n,!0)){if(i.add(a.id),a.boundElements)for(let c of a.boundElements)i.add(c.id);z(a)&&a.containerId&&i.add(a.containerId),ve(a)&&(a.startBinding&&i.add(a.startBinding.elementId),a.endBinding&&i.add(a.endBinding?.elementId))}}return e.filter(a=>i.has(a.id))}});import{fileOpen as fM,fileSave as bM,supported as bi}from"browser-fs-access";var F2,Al,Ml,kn=y(()=>{"use strict";h();X();$a();W();F2=500,Al=e=>{let t=e.extensions?.reduce((o,n)=>(o.push(Z[n]),o),[]),r=e.extensions?.reduce((o,n)=>n==="jpg"?o.concat(".jpg",".jpeg"):o.concat(`.${n}`),[]);return fM({description:e.description,extensions:r,mimeTypes:t,multiple:e.multiple??!1,legacySetup:(o,n,i)=>{let a=$i(n,F2),l=()=>{c(),document.addEventListener("keyup",a),document.addEventListener("pointerup",a),a()},c=()=>{if(i.files?.length){let d=e.multiple?[...i.files]:i.files[0];o(d)}};requestAnimationFrame(()=>{window.addEventListener("focus",l)});let s=window.setInterval(()=>{c()},F2);return d=>{clearInterval(s),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 ni))}}})},Ml=(e,t)=>bM(e,{fileName:`${t.name}.${t.extension}`,description:t.description,extensions:[`.${t.extension}`]},t.fileHandle)});var xM,EM,H2,fa,yM,wM,vM,TM,nc,IM,z2,U2,xi,G2,ic,ac=y(()=>{"use strict";h();ue();ae();yo();X();Ar();ar();Ve();W();W();pt();ol();xM={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},EM=e=>Object.keys(St).includes(e)?St[e]:Ft,H2=e=>e?{...e,focus:e.focus||0}:null,fa=(e,t)=>{let r={type:t.type||e.type,version:e.version||1,versionNonce:e.versionNonce??0,isDeleted:e.isDeleted??!1,id:e.id||Mt(),fillStyle:e.fillStyle||tt.fillStyle,strokeWidth:e.strokeWidth||tt.strokeWidth,strokeStyle:e.strokeStyle??tt.strokeStyle,roughness:e.roughness??tt.roughness,opacity:e.opacity==null?tt.opacity:e.opacity,angle:e.angle||0,x:t.x??e.x??0,y:t.y??e.y??0,strokeColor:e.strokeColor||tt.strokeColor,backgroundColor:e.backgroundColor||tt.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:Ho(e.type)?st.LEGACY:st.PROPORTIONAL_RADIUS}:null,boundElements:e.boundElementIds?e.boundElementIds.map(o=>({type:"arrow",id:o})):e.boundElements??[],updated:e.updated??an(),link:e.link?ir(e.link):null,locked:e.locked??!1};return("customData"in e||"customData"in t)&&(r.customData="customData"in t?t.customData:e.customData),ad in e&&(r[ad]=e[ad]),{...r,...lc(r),...t}},yM=(e,t=!1)=>{switch(e.type){case"text":let r=e.fontSize,o=e.fontFamily;if("font"in e){let[l,c]=e.font.split(" ");r=parseFloat(l),o=EM(c)}let n=typeof e.text=="string"&&e.text||"",i=e.lineHeight||(e.height?km(e):Dr(e.fontFamily)),a=th(e.text,_e(e),i);return e=fa(e,{fontSize:r,fontFamily:o,text:n,textAlign:e.textAlign||Kn,verticalAlign:e.verticalAlign||Vi,containerId:e.containerId??null,originalText:e.originalText||n,lineHeight:i,baseline:a}),!n&&!e.isDeleted&&(e={...e,originalText:n,isDeleted:!0},e=wo(e)),t&&(e={...e,...Ya(e)}),e;case"freedraw":return fa(e,{points:e.points,lastCommittedPoint:null,simulatePressure:e.simulatePressure,pressures:e.pressures});case"image":return fa(e,{status:e.status||"pending",fileId:e.fileId,scale:e.scale||[1,1]});case"line":case"draw":case"arrow":{let{startArrowhead:l=null,endArrowhead:c=e.type==="arrow"?"arrow":null}=e,s=e.x,d=e.y,m=!Array.isArray(e.points)||e.points.length<2?[[0,0],[e.width,e.height]]:e.points;return(m[0][0]!==0||m[0][1]!==0)&&({points:m,x:s,y:d}=K.getNormalizedPoints(e)),fa(e,{type:e.type==="draw"?"line":e.type,startBinding:H2(e.startBinding),endBinding:H2(e.endBinding),lastCommittedPoint:null,startArrowhead:l,endArrowhead:c,points:m,x:s,y:d})}case"ellipse":case"rectangle":case"diamond":case"iframe":return fa(e,{});case"embeddable":return fa(e,{validated:null});case"magicframe":case"frame":return fa(e,{name:e.name??null})}return null},wM=(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),z(a)&&!a.containerId&&(a.containerId=e.id)}return n},[])}},vM=(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}},TM=(e,t)=>{e.frameId&&(t.get(e.frameId)||(e.frameId=null))},nc=(e,t,r)=>{let o=new Set,n=t?Ce(t):null,i=(e||[]).reduce((l,c)=>{if(c.type!=="selection"&&!ao(c)){let s=yM(c,r?.refreshDimensions);if(s){let d=n?.get(c.id);d&&d.version>s.version&&(s=wo(s,d.version)),o.has(s.id)&&(s={...s,id:Mt()}),o.add(s.id),l.push(s)}}return l},[]);if(!r?.repairBindings)return i;let a=Ce(i);for(let l of i)l.frameId&&TM(l,a),z(l)&&l.containerId?vM(l,a):l.boundElements&&wM(l,a);return i},IM=(e,t,r)=>{let o=t[e];return o!==void 0?o:r[e]},z2={isSidebarDocked:(e,t)=>["defaultSidebarDockedPreference",e.isSidebarDocked??IM("defaultSidebarDockedPreference",e,t)]},U2=(e,t)=>{e=e||{};let r=$t(),o={};for(let n of Object.keys(z2))if(n in e){let[i,a]=z2[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:{...Xe(r,o.activeTool.type&&xM[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:Bo.name}:o.openSidebar}},xi=(e,t,r,o)=>({elements:nc(e?.elements,r,o),appState:U2(e?.appState,t||null),files:e?.files||{}}),G2=e=>{let t=nc(ce(e.elements),null);return t.length?{...e,elements:t}:null},ic=(e=[],t)=>{let r=[];for(let o of e)if(Array.isArray(o)){let n=G2({status:t,elements:o,id:Mt(),created:Date.now()});n&&r.push(n)}else{let n=o,i=G2({...n,id:n.id||Mt(),status:n.status||t,created:n.created||Date.now()});i&&r.push(i)}return r}});var W2=y(()=>{"use strict";h();X();vr()});import{deflate as SM,inflate as CM}from"pako";var ph,V2,Y2,K2,$2,gh,hh,X2=y(()=>{"use strict";h();W2();ph=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)}),V2=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},Y2=e=>new TextDecoder("utf-8").decode(V2(e)),K2=async(e,t=!1)=>t?window.btoa(e):window.btoa(await ph(e)),$2=async(e,t=!1)=>t?window.atob(e):Y2(window.atob(e)),gh=async({text:e,compress:t})=>{let r;if(t!==!1)try{r=await ph(SM(e))}catch(o){console.error("encode: cannot deflate",o)}return{version:"1",encoding:"bstring",compressed:!!r,encoded:r||await ph(e)}},hh=async e=>{let t;switch(e.encoding){case"bstring":t=e.compressed?e.encoded:await Y2(e.encoded);break;default:throw new Error(`decode: unknown encoding "${e.encoding}"`)}return e.compressed?CM(new Uint8Array(V2(t)),{to:"string"}):t}});var sc={};Cb(sc,{decodePngMetadata:()=>AM,decodeSvgMetadata:()=>LM,encodePngMetadata:()=>fh,encodeSvgMetadata:()=>MM,getTEXtChunk:()=>q2});import Z2 from"png-chunks-extract";import j2 from"png-chunk-text";import kM from"png-chunks-encode";var q2,fh,AM,MM,LM,Ll=y(()=>{"use strict";h();X2();X();vr();q2=async e=>{let r=Z2(new Uint8Array(await An(e))).find(o=>o.name==="tEXt");return r?j2.decode(r.data):null},fh=async({blob:e,metadata:t})=>{let r=Z2(new Uint8Array(await An(e))),o=j2.encode(Z.excalidraw,JSON.stringify(await gh({text:t,compress:!0})));return r.splice(-1,0,o),new Blob([kM(r)],{type:Z.png})},AM=async e=>{let t=await q2(e);if(t?.keyword===Z.excalidraw)try{let r=JSON.parse(t.text);if(!("encoded"in r)){if("type"in r&&r.type===Kt.excalidraw)return t.text;throw new Error("FAILED")}return await hh(r)}catch(r){throw console.error(r),new Error("FAILED")}throw new Error("INVALID")},MM=async({text:e})=>{let t=await K2(JSON.stringify(await gh({text:e})),!0),r="";return r+=`<!-- payload-type:${Z.excalidraw} -->`,r+="<!-- payload-version:2 -->",r+="<!-- payload-start -->",r+=t,r+="<!-- payload-end -->",r},LM=async({svg:e})=>{if(e.includes(`payload-type:${Z.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 $2(t[1],n),a=JSON.parse(i);if(!("encoded"in a)){if("type"in a&&a.type===Kt.excalidraw)return i;throw new Error("FAILED")}return await hh(a)}catch(i){throw console.error(i),new Error("FAILED")}}throw new Error("INVALID")}});import{nanoid as _M}from"nanoid";var Q2,bh,ev,_l,Ei,Hm,Pl,xh,Eh,Mn,tv,zm,rv,cc,yh,ov,nv,PM,J2,Fm,dc,An,vr=y(()=>{"use strict";h();Ar();X();ue();$a();Y();Ze();W();kn();Ln();ac();Q2=async e=>{let t;if(e.type===Z.png)try{return await(await Promise.resolve().then(()=>(Ll(),sc))).decodePngMetadata(e)}catch(r){throw r.message==="INVALID"?new vo(f("alerts.imageDoesNotContainScene"),"IMAGE_NOT_CONTAINS_SCENE_DATA"):new vo(f("alerts.cannotRestoreFromImage"))}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===Z.svg)try{return await(await Promise.resolve().then(()=>(Ll(),sc))).decodeSvgMetadata({svg:t})}catch(r){throw r.message==="INVALID"?new vo(f("alerts.imageDoesNotContainScene"),"IMAGE_NOT_CONTAINS_SCENE_DATA"):new vo(f("alerts.cannotRestoreFromImage"))}return t},bh=e=>e&&e.name.match(/\.(json|excalidraw|png|svg)$/)?.[1]||null,ev=e=>e==="png"||e==="svg",_l=e=>{let t=bh(e);return t==="png"||t==="svg"},Ei=e=>{let{type:t}=e||{};return!!t&&Object.values(ds).includes(t)},Hm=async(e,t,r,o)=>{let n=await Q2(e),i;try{try{i=JSON.parse(n)}catch(a){throw Ei(e)?new vo(f("alerts.imageDoesNotContainScene"),"IMAGE_NOT_CONTAINS_SCENE_DATA"):a}if(iv(i))return{type:Z.excalidraw,data:xi({elements:Gm(i.elements||[]),appState:{theme:t?.theme,fileHandle:o||e.handle||null,...xd(i.appState||{}),...t?Ko(i.elements||[],t):{}},files:i.files},t,r,{repairBindings:!0,refreshDimensions:!1})};if(wh(i))return{type:Z.excalidrawlib,data:i};throw new Error(f("alerts.couldNotLoadInvalidFile"))}catch(a){throw a instanceof vo?a:new Error(f("alerts.couldNotLoadInvalidFile"))}},Pl=async(e,t,r,o)=>{let n=await Hm(e,t,r,o);if(n.type!==Z.excalidraw)throw new Error(f("alerts.couldNotLoadInvalidFile"));return n.data},xh=(e,t="unpublished")=>{let r=JSON.parse(e);if(!wh(r))throw new Error("Invalid library");let o=r.libraryItems||r.library;return ic(o,t)},Eh=async(e,t="unpublished")=>xh(await Q2(e),t),Mn=async e=>new Promise(async(t,r)=>{try{hd(e)&&(e=await e),e.toBlob(o=>{if(!o)return r(new Pd(f("canvasError.canvasTooBig"),"CANVAS_POSSIBLY_TOO_BIG"));t(o)})}catch(o){r(o)}}),tv=async e=>{try{let t=await window.crypto.subtle.digest("SHA-1",await An(e));return xx(new Uint8Array(t))}catch(t){return console.error(t),_M(40)}},zm=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)}),rv=(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})},cc=async(e,t)=>{if(e.type===Z.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(!Ei(e))throw new Error(f("errors.unsupportedFileType"));return new File([await n.toBlob(e,{max:t.maxWidthOrHeight})],e.name,{type:t.outputType||e.type})},yh=(e,t="")=>new File([new TextEncoder().encode(e)],t,{type:Z.svg}),ov=async(e,t="")=>{let r;try{r=await fetch(e)}catch{throw new Error(f("errors.failedToFetchImage"))}if(!r.ok)throw new Error(f("errors.failedToFetchImage"));let o=await r.blob();if(o.type&&Ei(o)){let n=t||o.name||"";return new File([o],n,{type:o.type})}throw new Error(f("errors.unsupportedFileType"))},nv=async e=>{let t=e.dataTransfer.files.item(0),r=await PM(e);return{file:t?await dc(t):null,fileHandle:r}},PM=async e=>{if(bi)try{return await e.dataTransfer.items[0].getAsFileSystemHandle()||null}catch(t){return console.warn(t.name,t.message),null}return null},J2=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=Z.png:r.startsWith(o.jpg)?t=Z.jpg:r.startsWith(o.gif)&&(t=Z.gif),t},Fm=(e,t,r)=>new File([e],r||"",{type:t}),dc=async e=>{if(e.type){if(Ei(e)){let t=await An(e),r=J2(t);r&&r!==e.type&&(e=Fm(t,r,e.name))}}else if(e?.name?.endsWith(".excalidrawlib"))e=Fm(await An(e),Z.excalidrawlib,e.name);else if(e?.name?.endsWith(".excalidraw"))e=Fm(await An(e),Z.excalidraw,e.name);else{let t=await An(e),r=J2(t);r&&(e=Fm(t,r,e.name))}return e},An=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 DM,yi,Um,vh,iv,wh,Wm,av,Ln=y(()=>{"use strict";h();kn();Ar();X();ue();vr();DM=(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},yi=(e,t,r,o)=>{let n={type:Kt.excalidraw,version:Ki.excalidraw,source:ms,elements:o==="local"?Gm(e):lv(e),appState:o==="local"?xd(t):Cx(t),files:o==="local"?DM(e,r):void 0};return JSON.stringify(n,null,2)},Um=async(e,t,r)=>{let o=yi(e,t,r,"local"),n=new Blob([o],{type:Z.excalidraw});return{fileHandle:await Ml(n,{name:t.name,extension:"excalidraw",description:"Excalidraw file",fileHandle:_l(t.fileHandle)?null:t.fileHandle})}},vh=async(e,t)=>{let r=await Al({description:"Excalidraw files"});return Pl(await dc(r),e,t,r.handle)},iv=e=>e?.type===Kt.excalidraw&&(!e.elements||Array.isArray(e.elements)&&(!e.appState||typeof e.appState=="object")),wh=e=>typeof e=="object"&&e&&e.type===Kt.excalidrawLibrary&&(e.version===1||e.version===2),Wm=e=>{let t={type:Kt.excalidrawLibrary,version:Ki.excalidrawLibrary,source:ms,libraryItems:e};return JSON.stringify(t,null,2)},av=async e=>{let t=Wm(e);await Ml(new Blob([t],{type:Z.excalidrawlib}),{name:"library",extension:"excalidrawlib",description:"Excalidraw library file"})}});var Th,Vm,Ym,RM,sv,Ih=y(()=>{"use strict";h();X();Y();ae();Th=e=>new Promise((t,r)=>{let o=new Image;o.onload=()=>{t(o)},o.onerror=n=>{r(n)},o.src=e}),Vm=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===Z.binary)throw new Error("Only images can be added to ImageCache");let c=Th(l.dataURL),s={image:c,mimeType:l.mimeType};r.set(a,s);let d=await c;r.set(a,{...s,image:d})}catch{n.set(a,!0)}})())):i},[])),{imageCache:r,updatedFiles:o,erroredFiles:n}},Ym=e=>e.filter(t=>ur(t)),RM=e=>e?.nodeName.toLowerCase()==="svg",sv=async e=>{let t=new DOMParser().parseFromString(e,Z.svg),r=t.querySelector("svg");if(t.querySelector("parsererror")||!RM(r))throw new Error(f("errors.invalidSVGString"));if(r.hasAttribute("xmlns")||r.setAttribute("xmlns",et),!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 cv from"roughjs/bin/rough";var NM,dv,BM,OM,mv,uv,Km,Dl,Sh,pv,mc=y(()=>{"use strict";h();yt();sl();W();X();Ar();Ln();Ih();_n();br();ue();Ve();Er();ae();NM="<!-- svg-source:excalidraw -->",dv=e=>{let t=new xe;return t.replaceAllElements(Vr(e),!1),t},BM=(e,t)=>{if(e.width<=t)return e;let o=document.createElement("canvas").getContext("2d");o.font=_e({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 Q(e,{text:n,width:t})},OM=(e,t)=>{let r=[],o=0,n=0;for(let i of e){if(J(i)){jn(i)?o++:n++;let a=Rt({x:i.x,y:i.y-Qe.nameOffsetY,fontFamily:St.Assistant,fontSize:Qe.nameFontSize,lineHeight:Qe.nameLineHeight,strokeColor:t.exportWithDarkMode?Qe.nameColorDarkTheme:Qe.nameColorLightTheme,text:$m(i,jn(i)?o:n)});a.y-=a.height,a=BM(a,i.width),r.push(a)}r.push(i)}return r},mv=(e,t)=>(t=t||$t().frameRendering,{enabled:e?!0:t.enabled,outline:e?!1:t.outline,name:e?!1:t.name,clip:e?!0:t.clip}),uv=({elements:e,exportingFrame:t,frameRendering:r,exportWithDarkMode:o})=>{let n;return t?n=ha({elements:e,bounds:t,type:"overlap"}):r.enabled&&r.name?n=OM(e,{exportWithDarkMode:o}):n=e,n},Km=async(e,t,r,{exportBackground:o,exportPadding:n=bo,viewBackgroundColor:i,exportingFrame:a},l=(c,s)=>{let d=document.createElement("canvas");return d.width=c*t.exportScale,d.height=s*t.exportScale,{canvas:d,scale:t.exportScale}})=>{let c=dv(e);e=c.getNonDeletedElements();let s=mv(a??null,t.frameRendering??null),d=uv({elements:e,exportingFrame:a,exportWithDarkMode:t.exportWithDarkMode,frameRendering:s});a&&(n=0);let[m,u,p,g]=Sh(a?[a]:Ch(d),n),{canvas:b,scale:E=1}=l(p,g),w=$t(),{imageCache:v}=await Vm({imageCache:new Map,fileIds:Ym(d).map(T=>T.fileId),files:r});return Jd({canvas:b,rc:cv.canvas(b),elements:d,visibleElements:d,scale:E,appState:{...t,frameRendering:s,viewBackgroundColor:o?i:null,scrollX:-m+n,scrollY:-u+n,zoom:w.zoom,shouldCacheIgnoreZoom:!1,theme:t.exportWithDarkMode?"dark":"light"},renderConfig:{canvasBackgroundColor:i,imageCache:v,renderGrid:!1,isExporting:!0}}),c.destroy(),b},Dl=async(e,t,r,o)=>{let n=dv(e);e=n.getNonDeletedElements();let i=mv(o?.exportingFrame??null,t.frameRendering??null),{exportPadding:a=bo,exportWithDarkMode:l=!1,viewBackgroundColor:c,exportScale:s=1,exportEmbedScene:d}=t,{exportingFrame:m=null}=o||{},u=uv({elements:e,exportingFrame:m,exportWithDarkMode:l,frameRendering:i});m&&(a=0);let p="";if(d)try{p=await(await Promise.resolve().then(()=>(Ll(),sc))).encodeSvgMetadata({text:yi(e,t,r||{},"local")})}catch(H){console.error(H)}let[g,b,E,w]=Sh(m?[m]:Ch(u),a),v=document.createElementNS(et,"svg");v.setAttribute("version","1.1"),v.setAttribute("xmlns",et),v.setAttribute("viewBox",`0 0 ${E} ${w}`),v.setAttribute("width",`${E*s}`),v.setAttribute("height",`${w*s}`),l&&v.setAttribute("filter",Da);let T="https://excalidraw.com/";I.VITE_IS_EXCALIDRAW_NPM_PACKAGE&&(T=window.EXCALIDRAW_ASSET_PATH||`https://unpkg.com/${I.VITE_PKG_NAME}@${I.PKG_VERSION}`,T?.startsWith("/")&&(T=T.replace("/",`${window.location.origin}/`)),T=`${T}/dist/excalidraw-assets/`);let k=-g+a,M=-b+a,A=uc(e),D="";for(let H of A){let[C,O,P,G]=ee(H),j=(P-C)/2-(H.x-C),V=(G-O)/2-(H.y-O);D+=`<clipPath id=${H.id}>
|
|
31
|
-
<rect transform="translate(${H.x+k} ${H.y+M}) rotate(${H.angle} ${j} ${V})"
|
|
32
|
-
width="${H.width}"
|
|
33
|
-
height="${H.height}"
|
|
24
|
+
`),k=jn(e.fontSize,e.lineHeight),C=e.textAlign==="center"?e.width/2:e.textAlign==="right"?e.width:0,D=md(e.fontFamily,e.fontSize,k),R=Wc(e.text)?"rtl":"ltr",z=e.textAlign==="center"?"middle":e.textAlign==="right"||R==="rtl"?"end":"start";for(let M=0;M<I.length;M++){let A=o.ownerDocument.createElementNS(_e,"text");A.textContent=I[M],A.setAttribute("x",`${C}`),A.setAttribute("y",`${M*k+D}`),A.setAttribute("font-family",Aa(e)),A.setAttribute("font-size",`${e.fontSize}px`),A.setAttribute("fill",e.strokeColor),A.setAttribute("text-anchor",z),A.setAttribute("style","white-space: pre;"),A.setAttribute("direction",R),A.setAttribute("dominant-baseline","alphabetic"),w.appendChild(A)}let L=Ms(e,E,[w],l.frameRendering,t);y(L||w,e)}else throw new Error(`Unimplemented type ${e.type}`)}},Bx=(e,t,r,o,n,i)=>{o&&(e.filter(a=>!Ft(a)).forEach(a=>{if(!a.isDeleted)try{Ju(a,t,r,o,n,a.x+i.offsetX,a.y+i.offsetY,i)}catch(l){console.error(l)}}),e.filter(a=>Ft(a)).forEach(a=>{if(!a.isDeleted)try{Ju(a,t,r,o,n,a.x+i.offsetX,a.y+i.offsetY,i)}catch(l){console.error(l)}}))}});var Md,Oo,yo,Ji=Z(()=>{"use strict";h();Md=class extends Error{constructor(t="Couldn't export canvas.",r="CANVAS_ERROR"){super(),this.name=r,this.message=t}},Oo=class extends DOMException{constructor(t="Request Aborted"){super(t,"AbortError")}},yo=class extends Error{code;constructor(t="Image Scene Data Error",r="IMAGE_SCENE_DATA_ERROR"){super(t),this.name="EncodingError",this.code=r}}});import{fileOpen as U6,fileSave as W6,supported as Jn}from"browser-fs-access";var Fx,Ja,Qa,En=Z(()=>{"use strict";h();W();Ji();F();Fx=500,Ja=e=>{let t=e.extensions?.reduce((o,n)=>(o.push($[n]),o),[]),r=e.extensions?.reduce((o,n)=>n==="jpg"?o.concat(".jpg",".jpeg"):o.concat(`.${n}`),[]);return U6({description:e.description,extensions:r,mimeTypes:t,multiple:e.multiple??!1,legacySetup:(o,n,i)=>{let a=Ni(n,Fx),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()},Fx);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 Oo))}}})},Qa=(e,t)=>W6(e,{fileName:`${t.name}.${t.extension}`,description:t.description,extensions:[`.${t.extension}`]},t.fileHandle)});var V6,Y6,Hx,el,K6,$6,X6,Z6,Ls,j6,zx,Ux,Qn,Gx,Qi,tl=Z(()=>{"use strict";h();me();oe();co();W();Sr();$t();He();F();F();lt();Xa();V6={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},Y6=e=>Object.keys(it).includes(e)?it[e]:Ot,Hx=e=>e?{...e,focus:e.focus||0}:null,el=(e,t)=>{let r={type:t.type||e.type,version:e.version||1,versionNonce:e.versionNonce??0,isDeleted:e.isDeleted??!1,id:e.id||At(),fillStyle:e.fillStyle||Je.fillStyle,strokeWidth:e.strokeWidth||Je.strokeWidth,strokeStyle:e.strokeStyle??Je.strokeStyle,roughness:e.roughness??Je.roughness,opacity:e.opacity==null?Je.opacity:e.opacity,angle:e.angle||0,x:t.x??e.x??0,y:t.y??e.y??0,strokeColor:e.strokeColor||Je.strokeColor,backgroundColor:e.backgroundColor||Je.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:Do(e.type)?tt.LEGACY:tt.PROPORTIONAL_RADIUS}:null,boundElements:e.boundElementIds?e.boundElementIds.map(o=>({type:"arrow",id:o})):e.boundElements??[],updated:e.updated??on(),link:e.link?tr(e.link):null,locked:e.locked??!1};return("customData"in e||"customData"in t)&&(r.customData="customData"in t?t.customData:e.customData),Oc in e&&(r[Oc]=e[Oc]),{...r,...Ps(r),...t}},K6=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=Y6(a)}let o=typeof e.text=="string"&&e.text||"",n=e.lineHeight||(e.height?dx(e):Tr(e.fontFamily));return e=el(e,{fontSize:t,fontFamily:r,text:o,textAlign:e.textAlign||On,verticalAlign:e.verticalAlign||Pi,containerId:e.containerId??null,originalText:e.originalText||o,lineHeight:n}),!o&&!e.isDeleted&&(e={...e,originalText:o,isDeleted:!0},e=Eo(e)),e;case"freedraw":return el(e,{points:e.points,lastCommittedPoint:null,simulatePressure:e.simulatePressure,pressures:e.pressures});case"image":return el(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}=V.getNormalizedPoints(e)),el(e,{type:e.type==="draw"?"line":e.type,startBinding:Hx(e.startBinding),endBinding:Hx(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 el(e,{});case"magicframe":case"frame":return el(e,{name:e.name??null})}return null},$6=(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),G(a)&&!a.containerId&&(a.containerId=e.id)}return n},[])}},X6=(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}},Z6=(e,t)=>{e.frameId&&(t.get(e.frameId)||(e.frameId=null))},Ls=(e,t,r)=>{let o=new Set,n=t?J(t):null,i=(e||[]).reduce((l,s)=>{if(s.type!=="selection"&&!Wr(s)){let c=K6(s);if(c){let d=n?.get(s.id);d&&d.version>c.version&&(c=Eo(c,d.version)),o.has(c.id)&&(c={...c,id:At()}),o.add(c.id),l.push(c)}}return l},[]);if(!r?.repairBindings)return i;let a=J(i);for(let l of i)l.frameId&&Z6(l,a),G(l)&&l.containerId?X6(l,a):l.boundElements&&$6(l,a),r.refreshDimensions&&G(l)&&Object.assign(l,ja(l,st(l,a),a));return i},j6=(e,t,r)=>{let o=t[e];return o!==void 0?o:r[e]},zx={isSidebarDocked:(e,t)=>["defaultSidebarDockedPreference",e.isSidebarDocked??j6("defaultSidebarDockedPreference",e,t)]},Ux=(e,t)=>{e=e||{};let r=er(),o={};for(let n of Object.keys(zx))if(n in e){let[i,a]=zx[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:{...Ke(r,o.activeTool.type&&V6[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:Ao.name}:o.openSidebar}},Qn=(e,t,r,o)=>({elements:Ls(e?.elements,r,o),appState:Ux(e?.appState,t||null),files:e?.files||{}}),Gx=e=>{let t=Ls(be(e.elements),null);return t.length?{...e,elements:t}:null},Qi=(e=[],t)=>{let r=[];for(let o of e)if(Array.isArray(o)){let n=Gx({status:t,elements:o,id:At(),created:Date.now()});n&&r.push(n)}else{let n=o,i=Gx({...n,id:n.id||At(),status:n.status||t,created:n.created||Date.now()});i&&r.push(i)}return r}});var Wx=Z(()=>{"use strict";h();W();gr()});import{deflate as q6,inflate as J6}from"pako";var eg,Vx,Yx,Kx,$x,tg,rg,Xx=Z(()=>{"use strict";h();Wx();eg=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)}),Vx=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},Yx=e=>new TextDecoder("utf-8").decode(Vx(e)),Kx=async(e,t=!1)=>t?window.btoa(e):window.btoa(await eg(e)),$x=async(e,t=!1)=>t?window.atob(e):Yx(window.atob(e)),tg=async({text:e,compress:t})=>{let r;if(t!==!1)try{r=await eg(q6(e))}catch(o){console.error("encode: cannot deflate",o)}return{version:"1",encoding:"bstring",compressed:!!r,encoded:r||await eg(e)}},rg=async e=>{let t;switch(e.encoding){case"bstring":t=e.compressed?e.encoded:await Yx(e.encoded);break;default:throw new Error(`decode: unknown encoding "${e.encoding}"`)}return e.compressed?J6(new Uint8Array(Vx(t)),{to:"string"}):t}});var _s={};bb(_s,{decodePngMetadata:()=>eS,decodeSvgMetadata:()=>rS,encodePngMetadata:()=>og,encodeSvgMetadata:()=>tS,getTEXtChunk:()=>qx});import Zx from"png-chunks-extract";import jx from"png-chunk-text";import Q6 from"png-chunks-encode";var qx,og,eS,tS,rS,rl=Z(()=>{"use strict";h();Xx();W();gr();qx=async e=>{let r=Zx(new Uint8Array(await yn(e))).find(o=>o.name==="tEXt");return r?jx.decode(r.data):null},og=async({blob:e,metadata:t})=>{let r=Zx(new Uint8Array(await yn(e))),o=jx.encode($.excalidraw,JSON.stringify(await tg({text:t,compress:!0})));return r.splice(-1,0,o),new Blob([Q6(r)],{type:$.png})},eS=async e=>{let t=await qx(e);if(t?.keyword===$.excalidraw)try{let r=JSON.parse(t.text);if(!("encoded"in r)){if("type"in r&&r.type===Yt.excalidraw)return t.text;throw new Error("FAILED")}return await rg(r)}catch(r){throw console.error(r),new Error("FAILED")}throw new Error("INVALID")},tS=async({text:e})=>{let t=await Kx(JSON.stringify(await tg({text:e})),!0),r="";return r+=`<!-- payload-type:${$.excalidraw} -->`,r+="<!-- payload-version:2 -->",r+="<!-- payload-start -->",r+=t,r+="<!-- payload-end -->",r},rS=async({svg:e})=>{if(e.includes(`payload-type:${$.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 $x(t[1],n),a=JSON.parse(i);if(!("encoded"in a)){if("type"in a&&a.type===Yt.excalidraw)return i;throw new Error("FAILED")}return await rg(a)}catch(i){throw console.error(i),new Error("FAILED")}}throw new Error("INVALID")}});import{nanoid as oS}from"nanoid";var Qx,ng,eE,ol,ei,Pd,nl,ig,ag,wn,tE,_d,rE,Ds,lg,oE,nE,nS,Jx,Ld,Rs,yn,gr=Z(()=>{"use strict";h();Sr();W();me();Ji();We();F();En();vn();tl();Qx=async e=>{let t;if(e.type===$.png)try{return await(await Promise.resolve().then(()=>(rl(),_s))).decodePngMetadata(e)}catch(r){throw r.message==="INVALID"?new yo("Image doesn't contain scene","IMAGE_NOT_CONTAINS_SCENE_DATA"):new yo("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===$.svg)try{return await(await Promise.resolve().then(()=>(rl(),_s))).decodeSvgMetadata({svg:t})}catch(r){throw r.message==="INVALID"?new yo("Image doesn't contain scene","IMAGE_NOT_CONTAINS_SCENE_DATA"):new yo("Error: cannot restore image")}return t},ng=e=>e&&e.name.match(/\.(json|excalidraw|png|svg)$/)?.[1]||null,eE=e=>e==="png"||e==="svg",ol=e=>{let t=ng(e);return t==="png"||t==="svg"},ei=e=>{let{type:t}=e||{};return!!t&&Object.values(Xl).includes(t)},Pd=async(e,t,r,o)=>{let n=await Qx(e),i;try{try{i=JSON.parse(n)}catch(a){throw ei(e)?new yo("Image doesn't contain scene","IMAGE_NOT_CONTAINS_SCENE_DATA"):a}if(iE(i))return{type:$.excalidraw,data:Qn({elements:Dd(i.elements||[]),appState:{theme:t?.theme,fileHandle:o||e.handle||null,...fd(i.appState||{}),...t?Ho(i.elements||[],t):{}},files:i.files},t,r,{repairBindings:!0,refreshDimensions:!1})};if(sg(i))return{type:$.excalidrawlib,data:i};throw new Error("Error: invalid file")}catch(a){throw a instanceof yo?a:new Error("Error: invalid file")}},nl=async(e,t,r,o)=>{let n=await Pd(e,t,r,o);if(n.type!==$.excalidraw)throw new Error("Error: invalid file");return n.data},ig=(e,t="unpublished")=>{let r=JSON.parse(e);if(!sg(r))throw new Error("Invalid library");let o=r.libraryItems||r.library;return Qi(o,t)},ag=async(e,t="unpublished")=>ig(await Qx(e),t),wn=async e=>new Promise(async(t,r)=>{try{Lo(e)&&(e=await e),e.toBlob(o=>{if(!o)return r(new Md("Error: Canvas too big","CANVAS_POSSIBLY_TOO_BIG"));t(o)})}catch(o){r(o)}}),tE=async e=>{try{let t=await window.crypto.subtle.digest("SHA-1",await yn(e));return a1(new Uint8Array(t))}catch(t){return console.error(t),oS(40)}},_d=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)}),rE=(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})},Ds=async(e,t)=>{if(e.type===$.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(!ei(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})},lg=(e,t="")=>new File([new TextEncoder().encode(e)],t,{type:$.svg}),oE=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&&ei(o)){let n=t||o.name||"";return new File([o],n,{type:o.type})}throw new Error("Error: unsupported file type",{cause:"UNSUPPORTED"})},nE=async e=>{let t=e.dataTransfer.files.item(0),r=await nS(e);return{file:t?await Rs(t):null,fileHandle:r}},nS=async e=>{if(Jn)try{return await e.dataTransfer.items[0].getAsFileSystemHandle()||null}catch(t){return console.warn(t.name,t.message),null}return null},Jx=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=$.png:r.startsWith(o.jpg)?t=$.jpg:r.startsWith(o.gif)&&(t=$.gif),t},Ld=(e,t,r)=>new File([e],r||"",{type:t}),Rs=async e=>{if(e.type){if(ei(e)){let t=await yn(e),r=Jx(t);r&&r!==e.type&&(e=Ld(t,r,e.name))}}else if(e?.name?.endsWith(".excalidrawlib"))e=Ld(await yn(e),$.excalidrawlib,e.name);else if(e?.name?.endsWith(".excalidraw"))e=Ld(await yn(e),$.excalidraw,e.name);else{let t=await yn(e),r=Jx(t);r&&(e=Ld(t,r,e.name))}return e},yn=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 iS,ti,Rd,cg,iE,sg,Nd,aE,vn=Z(()=>{"use strict";h();En();Sr();W();me();gr();iS=(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},ti=(e,t,r,o)=>{let n={type:Yt.excalidraw,version:Ri.excalidraw,source:Zl,elements:o==="local"?Dd(e):lE(e),appState:o==="local"?fd(t):wx(t),files:o==="local"?iS(e,r):void 0};return JSON.stringify(n,null,2)},Rd=async(e,t,r,o=t.name||zc)=>{let n=ti(e,t,r,"local"),i=new Blob([n],{type:$.excalidraw});return{fileHandle:await Qa(i,{name:o,extension:"excalidraw",description:"Excalidraw file",fileHandle:ol(t.fileHandle)?null:t.fileHandle})}},cg=async(e,t)=>{let r=await Ja({description:"Excalidraw files"});return nl(await Rs(r),e,t,r.handle)},iE=e=>e?.type===Yt.excalidraw&&(!e.elements||Array.isArray(e.elements)&&(!e.appState||typeof e.appState=="object")),sg=e=>typeof e=="object"&&e&&e.type===Yt.excalidrawLibrary&&(e.version===1||e.version===2),Nd=e=>{let t={type:Yt.excalidrawLibrary,version:Ri.excalidrawLibrary,source:Zl,libraryItems:e};return JSON.stringify(t,null,2)},aE=async e=>{let t=Nd(e);await Qa(new Blob([t],{type:$.excalidrawlib}),{name:"library",extension:"excalidrawlib",description:"Excalidraw library file"})}});var dg,Bd,Od,aS,sE,mg=Z(()=>{"use strict";h();W();oe();dg=e=>new Promise((t,r)=>{let o=new Image;o.onload=()=>{t(o)},o.onerror=n=>{r(n)},o.src=e}),Bd=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===$.binary)throw new Error("Only images can be added to ImageCache");let s=dg(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}},Od=e=>e.filter(t=>Qt(t)),aS=e=>e?.nodeName.toLowerCase()==="svg",sE=async e=>{let t=new DOMParser().parseFromString(e,$.svg),r=t.querySelector("svg");if(t.querySelector("parsererror")||!aS(r))throw new Error("Invalid SVG");if(r.hasAttribute("xmlns")||r.setAttribute("xmlns",_e),!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}});var pg,Ns,ug,Fd,Hd=Z(()=>{"use strict";h();W();mt();Xn();Ht();ln();pg=document.createElement("img");pg.src=`data:${$.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>')}`;Ns=([e,t,r,o],n,i)=>{let a=cE,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,g=r+u-p,f=t-u-c+p,[E,y]=ge(g+l/2,f+s/2,d,m,n);return[E-l/2,y-s/2,l,s]},ug=(e,t,r,[o,n])=>{let i=4/r.zoom.value,[a,l,s,c]=j(e,t),[d,m,p,u]=Ns([a,l,s,c],e.angle,r);return o>d-i&&o<d+i+p&&n>m-i&&n<m+u+i},Fd=(e,t,r,[o,n],i)=>{if(!e.link||r.selectedElementIds[e.id])return!1;let a=4/r.zoom.value;return!i&&r.viewModeEnabled&&Ha(e,t,[o,n],a,null)?!0:ug(e,t,r,[o,n])}});var Bs,zd,Gd,gg=Z(()=>{"use strict";h();W();Bs=(e,t,r,o,n=!0)=>{e.beginPath(),e.arc(t,r,o,0,Math.PI*2),e.fill(),n&&e.stroke()},zd=(e,t)=>[e.width/t,e.height/t],Gd=({canvas:e,scale:t,normalizedWidth:r,normalizedHeight:o,theme:n,isExporting:i,viewBackgroundColor:a})=>{let l=e.getContext("2d");return l.setTransform(1,0,0,1,0,0),l.scale(t,t),i&&n==="dark"&&(l.filter=Sa),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 lS,dE,Tn,mE,pE,hg,Wd,Vd=Z(()=>{"use strict";h();W();me();Xt();oe();ln();ks();Hd();gg();F();lS=(e,t,r,o,n,i,a)=>{let s;(E=>(E.Bold="#cccccc",E.Regular="#e5e5e5"))(s||={});let 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 g=c;g<c+i+t*2;g+=t){let f=Math.round(g-r)%(5*t)===0;e.beginPath(),e.setLineDash(f?[]:u),e.strokeStyle=f?"#cccccc":"#e5e5e5",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 f=Math.round(g-o)%(5*t)===0;e.beginPath(),e.setLineDash(f?[]:u),e.strokeStyle=f?"#cccccc":"#e5e5e5",e.moveTo(c-t,g),e.lineTo(c+i+t*2,g),e.stroke()}e.restore()},dE=(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,Ue.radius/o.zoom.value):t.rect(0,0,e.width,e.height),t.clip(),t.translate(-(e.x+o.scrollX),-(e.y+o.scrollY))},mE=(e,t,r,o)=>{if(e.link&&!r.selectedElementIds[e.id]){let[n,i,a,l]=j(e,o),[s,c,d,m]=Ns([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),!Tn||Tn.zoom!==r.zoom.value){Tn=document.createElement("canvas"),Tn.zoom=r.zoom.value,Tn.width=d*window.devicePixelRatio*r.zoom.value,Tn.height=m*window.devicePixelRatio*r.zoom.value;let g=Tn.getContext("2d");g.scale(window.devicePixelRatio*r.zoom.value,window.devicePixelRatio*r.zoom.value),g.fillStyle="#fff",g.fillRect(0,0,d,m),g.drawImage(pg,0,0,d,m),g.restore(),t.drawImage(Tn,s-p,c-u,d,m)}else t.drawImage(Tn,s-p,c-u,d,m);t.restore()}},pE=({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]=zd(e,i),p=Gd({canvas:e,scale:i,normalizedWidth:d,normalizedHeight:m,theme:a.theme,isExporting:c,viewBackgroundColor:a.viewBackgroundColor});p.scale(a.zoom.value,a.zoom.value),s&&a.gridSize&&lS(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]&&(zo(g,a.frameToHighlight,r)||g.groupIds.find(f=>u.has(f)))&&g.groupIds.forEach(f=>u.add(f))}),n.filter(g=>!Ft(g)).forEach(g=>{try{if((g.frameId||a.frameToHighlight?.id)&&a.frameRendering.enabled&&a.frameRendering.clip){p.save();let E=Ud(g,r,a);E&&ea(g,r,a)&&dE(E,p,l,a),Os(g,r,o,t,p,l,a),p.restore()}else Os(g,r,o,t,p,l,a);c||mE(g,p,a,r)}catch(f){console.error(f)}}),n.filter(g=>Ft(g)).forEach(g=>{try{let f=()=>{if(Os(g,r,o,t,p,l,a),Ft(g)&&(c||xt(g)&&l.embedsValidationStatus.get(g.id)!==!0)&&g.width&&g.height){let y=kd(g);Os(y,r,o,t,p,l,a)}c||mE(g,p,a,r)};if((g.frameId||a.frameToHighlight?.id)&&a.frameRendering.enabled&&a.frameRendering.clip){p.save();let y=Ud(g,r,a);y&&ea(g,r,a)&&dE(y,p,l,a),f(),p.restore()}else f()}catch(f){console.error(f)}})},hg=Ma(e=>{pE(e)},{trailing:!0}),Wd=(e,t)=>{if(t){hg(e);return}pE(e)}});import uE from"roughjs/bin/rough";var sS,cS,dS,gE,hE,Yd,il,fg,fE,Fs=Z(()=>{"use strict";h();mt();Ox();F();W();Sr();vn();mg();Xt();me();He();oe();Vd();sS="<!-- svg-source:excalidraw -->",cS=(e,t)=>{if(e.width<=t)return e;let o=document.createElement("canvas").getContext("2d");o.font=Be({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 te(e,{text:n,width:t})},dS=(e,t)=>{let r=[],o=0,n=0;for(let i of e){if(X(i)){Gn(i)?o++:n++;let a=Lt({x:i.x,y:i.y-Ue.nameOffsetY,fontFamily:it.Assistant,fontSize:Ue.nameFontSize,lineHeight:Ue.nameLineHeight,strokeColor:t.exportWithDarkMode?Ue.nameColorDarkTheme:Ue.nameColorLightTheme,text:Kd(i,Gn(i)?o:n)});a.y-=a.height,a=cS(a,i.width),r.push(a)}r.push(i)}return r},gE=(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}),hE=({elements:e,exportingFrame:t,frameRendering:r,exportWithDarkMode:o})=>{let n;return t?n=al(e,t):r.enabled&&r.name?n=dS(e,{exportWithDarkMode:o}):n=e,n},Yd=async(e,t,r,{exportBackground:o,exportPadding:n=ao,viewBackgroundColor:i,exportingFrame:a},l=(s,c)=>{let d=document.createElement("canvas");return d.width=s*t.exportScale,d.height=c*t.exportScale,{canvas:d,scale:t.exportScale}})=>{let s=gE(a??null,t.frameRendering??null),c=hE({elements:e,exportingFrame:a,exportWithDarkMode:t.exportWithDarkMode,frameRendering:s});a&&(n=0);let[d,m,p,u]=fg(a?[a]:bg(c),n),{canvas:g,scale:f=1}=l(p,u),E=er(),{imageCache:y}=await Bd({imageCache:new Map,fileIds:Od(c).map(T=>T.fileId),files:r});return Wd({canvas:g,rc:uE.canvas(g),elementsMap:so(J(c)),allElementsMap:so(J(e)),visibleElements:c,scale:f,appState:{...t,frameRendering:s,viewBackgroundColor:o?i:null,scrollX:-d+n,scrollY:-m+n,zoom:E.zoom,shouldCacheIgnoreZoom:!1,theme:t.exportWithDarkMode?"dark":"light"},renderConfig:{canvasBackgroundColor:i,imageCache:y,renderGrid:!1,isExporting:!0,embedsValidationStatus:new Map,elementsPendingErasure:new Set}}),g},il=async(e,t,r,o)=>{let n=gE(o?.exportingFrame??null,t.frameRendering??null),{exportPadding:i=ao,exportWithDarkMode:a=!1,viewBackgroundColor:l,exportScale:s=1,exportEmbedScene:c}=t,{exportingFrame:d=null}=o||{},m=hE({elements:e,exportingFrame:d,exportWithDarkMode:a,frameRendering:n});d&&(i=0);let p="";if(c)try{p=await(await Promise.resolve().then(()=>(rl(),_s))).encodeSvgMetadata({text:ti(e,t,r||{},"local")})}catch(L){console.error(L)}let[u,g,f,E]=fg(d?[d]:bg(m),i),y=document.createElementNS(_e,"svg");y.setAttribute("version","1.1"),y.setAttribute("xmlns",_e),y.setAttribute("viewBox",`0 0 ${f} ${E}`),y.setAttribute("width",`${f*s}`),y.setAttribute("height",`${E*s}`),a&&y.setAttribute("filter",Sa);let T="https://excalidraw.com/";v.VITE_IS_EXCALIDRAW_NPM_PACKAGE&&(T=window.EXCALIDRAW_ASSET_PATH||`https://unpkg.com/${v.VITE_PKG_NAME}@${v.PKG_VERSION}`,T?.startsWith("/")&&(T=T.replace("/",`${window.location.origin}/`)),T=`${T}/dist/excalidraw-assets/`);let w=-u+i,I=-g+i,k=Hs(e),C="",D=J(e);for(let L of k){let[M,A,H,q]=j(L,D),Y=(H-M)/2-(L.x-M),Q=(q-A)/2-(L.y-A);C+=`<clipPath id=${L.id}>
|
|
25
|
+
<rect transform="translate(${L.x+w} ${L.y+I}) rotate(${L.angle} ${Y} ${Q})"
|
|
26
|
+
width="${L.width}"
|
|
27
|
+
height="${L.height}"
|
|
34
28
|
>
|
|
35
29
|
</rect>
|
|
36
|
-
</clipPath>`}if(
|
|
37
|
-
${
|
|
30
|
+
</clipPath>`}if(y.innerHTML=`
|
|
31
|
+
${sS}
|
|
38
32
|
${p}
|
|
39
33
|
<defs>
|
|
40
34
|
<style class="style-fonts">
|
|
@@ -51,19 +45,24 @@ var hC=Object.defineProperty;var Sb=e=>t=>{var r=e[t];if(r)return r();throw new
|
|
|
51
45
|
src: url("${T}Assistant-Regular.woff2");
|
|
52
46
|
}
|
|
53
47
|
</style>
|
|
54
|
-
${
|
|
48
|
+
${C}
|
|
55
49
|
</defs>
|
|
56
|
-
`,t.exportBackground&&c){let H=v.ownerDocument.createElementNS(et,"rect");H.setAttribute("x","0"),H.setAttribute("y","0"),H.setAttribute("width",`${E}`),H.setAttribute("height",`${w}`),H.setAttribute("fill",c),v.appendChild(H)}let R=cv.svg(v);return Ay(u,R,v,r||{},{offsetX:k,offsetY:M,isExporting:!0,exportWithDarkMode:l,renderEmbeddables:o?.renderEmbeddables??!1,frameRendering:i,canvasBackgroundColor:c}),n.destroy(),v},Sh=(e,t)=>{let[r,o,n,i]=we(e),a=kt(r,n)+t*2,l=kt(o,i)+t*2;return[r,o,a,l]},pv=(e,t,r)=>{let[,,o,n]=Sh(e,t).map(i=>Math.trunc(i*r));return[o,n]}});var wi,Xm,Rl,FM,gv=y(()=>{"use strict";h();mc();Om();Ll();Ln();gi();wi=({elements:e,appState:t,files:r,maxWidthOrHeight:o,getDimensions:n,exportPadding:i,exportingFrame:a})=>{let{elements:l,appState:c}=xi({elements:e,appState:t},null,null),{exportBackground:s,viewBackgroundColor:d}=c;return Km(l,{...c,offsetTop:0,offsetLeft:0,width:0,height:0},r||{},{exportBackground:s,exportPadding:i,viewBackgroundColor:d,exportingFrame:a},(m,u)=>{let p=document.createElement("canvas");if(o){typeof n=="function"&&console.warn("`getDimensions()` is ignored when `maxWidthOrHeight` is supplied.");let b=Math.max(m,u),E=o<b?o/b:t?.exportScale??1;return p.width=m*E,p.height=u*E,{canvas:p,scale:E}}let g=n?.(m,u)||{width:m,height:u};return p.width=g.width,p.height=g.height,{canvas:p,scale:g.scale??1}})},Xm=async e=>{let{mimeType:t=Z.png,quality:r}=e;t===Z.png&&typeof r=="number"&&console.warn(`"quality" will be ignored for "${Z.png}" mimeType`),t==="image/jpg"&&(t=Z.jpg),t===Z.jpg&&!e.appState?.exportBackground&&(console.warn(`Defaulting "exportBackground" to "true" for "${Z.jpg}" mimeType`),e={...e,appState:{...e.appState,exportBackground:!0}});let o=await wi(e);return r=r||(/image\/jpe?g/.test(t)?.92:.8),new Promise((n,i)=>{o.toBlob(async a=>{if(!a)return i(new Error("couldn't export to blob"));a&&t===Z.png&&e.appState?.exportEmbedScene&&(a=await fh({blob:a,metadata:yi(e.elements,e.appState,e.files||{},"local")})),n(a)},t,r)})},Rl=async({elements:e,appState:t=$t(),files:r={},exportPadding:o,renderEmbeddables:n,exportingFrame:i})=>{let{elements:a,appState:l}=xi({elements:e,appState:t},null,null),c={...l,exportPadding:o};return Dl(a,c,r,{exportingFrame:i,renderEmbeddables:n})},FM=async e=>{if(e.type==="svg"){let t=await Rl(e);await Tn(t.outerHTML)}else if(e.type==="png")await Im(Xm(e));else if(e.type==="json")await vm(e.elements,e.files);else throw new Error("Invalid export type")}});var _n=y(()=>{"use strict";h();D2();O2();gv()});function hv(e,t){let r=ch(t),o=ch(e);return r.some(i=>o.some(a=>P2(i,a)))}var Zm,fv,bv,xv,si,kh,Ev,Fr,uc,Ch,Nl,yv,jt,jm,Bl,Ah,qm,Xo,Mh,jd,ia,$m,br=y(()=>{"use strict";h();ue();Zt();pt();W();Ve();Ze();gr();Er();yt();_n();ae();Zm=(e,t,r)=>{let o=Ce(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&&B(l,{frameId:a??n.frameId},!1)}}};fv=(e,t)=>Mh(Ol(e,t,!1)).filter(r=>!J(r)&&!r.frameId||r.frameId===t.id),bv=(e,t,r)=>Ol(e,t).some(o=>o.id===r.id),xv=(e,t)=>{let[r,o,n,i]=ee(t),[a,l,c,s]=we(e);return r<=a&&o<=l&&n>=c&&i>=s},si=(e,t)=>xv([e],t)||hv(e,t)||bv([t],e,t),kh=(e,t)=>{let[r,o,n,i]=ee(t);return ga([r,o],[e.x,e.y],[n,i])},Ev=e=>{let t=new Map;for(let r of e){let o=J(r)?r.id:r.frameId;o&&!t.has(o)&&t.set(o,Fr(e,o))}return t},Fr=(e,t)=>e.filter(r=>r.frameId===t),uc=e=>e.filter(t=>J(t)),Ch=e=>{let t=Ce(uc(e));return e.filter(r=>t.has(r.id)||!r.frameId||!t.has(r.frameId))},Nl=(e,t,r)=>{let o=Fr(e,t.id),n=new Set(o),i=new Set([...fv(e,t),...o.filter(m=>bv(e,m,t))]),a=o.filter(m=>!i.has(m)),l=new Set(Array.from(i).flatMap(m=>m.groupIds));for(let m of a)if(!hv(m,t))m.groupIds.length===0&&n.delete(m);else if(m.groupIds.length>0)for(let u of m.groupIds)l.add(u);for(let m of a)if(m.groupIds.length>0){let u=!0;for(let p of m.groupIds)l.has(p)&&(u=!1);u&&n.delete(m)}let c=Array.from(i).filter(m=>m.groupIds.length===0);for(let m of c)n.add(m);let s=Array.from(i).filter(m=>m.groupIds.length>0),d=vd(s,r);for(let[m,u]of Object.entries(d))if(u){let p=at(e,m);if(xv(p,t))for(let g of p)n.add(g)}return[...n].filter(m=>!(z(m)&&m.containerId))},yv=(e,t)=>Mh(e,fv(e,t)),jt=(e,t)=>e.frameId?t?t.get(e.frameId)||null:xe.getScene(e)?.getElement(e.frameId)||null:null,jm=(e,t,r)=>{let{currTargetFrameChildrenMap:o}=e.reduce((a,l,c)=>(l.frameId===r.id&&a.currTargetFrameChildrenMap.set(l.id,!0),a),{currTargetFrameChildrenMap:new Map}),n=new Set(t.map(a=>a.id)),i=[];for(let a of Mh(e,t)){o.has(a.id)||i.push(a);let l=le(a);l&&!n.has(l.id)&&!o.has(l.id)&&i.push(l)}for(let a of i)B(a,{frameId:r.id},!1);return e.slice()},Bl=(e,t,r)=>{let o=new Map,n=new Map;for(let i of t)if(i.frameId){o.set(i.id,i);let a=n.get(i.frameId)||[];a.push(i);let l=le(i);l&&(o.set(l.id,l),a.push(l)),n.set(i.frameId,a)}for(let[,i]of o)B(i,{frameId:null},!1);return e.slice()},Ah=(e,t,r)=>{let o=Fr(e,t.id);return Bl(e,o,r)},qm=(e,t,r,o)=>jm(Ah(e,r,o),t,r),Xo=(e,t,r)=>{let o=r.scene.getSelectedElements({selectedElementIds:t.selectedElementIds,elements:e}),n=new Set(o);if(t.editingGroupId)for(let a of o)a.groupIds.length===0?n.add(a):a.groupIds.flatMap(l=>at(e,l)).forEach(l=>n.add(l));let i=new Set;return n.forEach(a=>{a.frameId&&!J(a)&&!ia(a,e,t)&&i.add(a)}),i.size>0?Bl(e,[...i],t):e},Mh=(e,t)=>{let r=new Set;for(let n of t||e){let i=n.groupIds[n.groupIds.length-1];i&&r.add(i)}let o=new Set;for(let n of r)at(e,n).some(i=>J(i))&&o.add(n);return(t||e).filter(n=>!o.has(n.groupIds[n.groupIds.length-1]))},jd=(e,t)=>{let r=z(e)&&je(e)||e;return t.selectedElementIds[r.id]&&t.selectedElementsAreBeingDragged?t.frameToHighlight:jt(r)},ia=(e,t,r)=>{let o=jd(e,r),n=z(e)&&je(e)||e;if(o){if(!r.selectedElementIds[e.id]||!r.selectedElementsAreBeingDragged)return!0;if(n.groupIds.length===0)return si(n,o);let i=new Set(n.groupIds.flatMap(a=>at(t,a)));if(r.editingGroupId&&r.selectedElementsAreBeingDragged){let a=new Set(ge(t,r));if(r.frameToHighlight!==null)return!0;a.forEach(c=>{i.delete(c)})}for(let a of i)if(J(a))return!1;for(let a of i)if(si(a,o))return!0}return!1},$m=(e,t)=>{let r=e.name?.trim();return r||(jn(e)?`Frame ${t}`:`AI Frame ${t}`)}});var ba,Ol,Lh,ze,Vg,ge,ma,Pe,ti=y(()=>{"use strict";h();ue();ae();br();W();Ea();ba=e=>{let t=new Set;return e.forEach(r=>{J(r)&&t.add(r.id)}),e.filter(r=>!(r.frameId&&t.has(r.frameId)))},Ol=(e,t,r=!0)=>{let[o,n,i,a]=ee(t),l=e.filter(c=>{let[s,d,m,u]=io(c),p=jt(c);if(p){let[g,b,E,w]=io(p);s=Math.max(g,s),d=Math.max(b,d),m=Math.min(E,m),u=Math.min(w,u)}return c.locked===!1&&c.type!=="selection"&&!ke(c)&&o<=s&&n<=d&&i>=m&&a>=u});return l=r?ba(l):l,l=l.filter(c=>{let s=jt(c);return s?si(c,s):!0}),l},Lh=(e,t,r)=>{let o=new Set(t.map(n=>n.id));return e.filter(n=>{let i=xa(n,r.width,r.height,r);return!o.has(n.id)&&i})},ze=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}(),Vg=(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=e.filter(n=>t.selectedElementIds[n.id]||r?.includeBoundTextElement&&ke(n)&&t.selectedElementIds[n?.containerId]?n:null);if(r?.includeElementsInFrames){let n=[];return o.forEach(i=>{J(i)&&Fr(e,i.id).forEach(a=>n.push(a)),n.push(i)}),n}return o},ma=(e,t)=>t.editingElement?[t.editingElement]:ge(e,t,{includeBoundTextElement:!0}),Pe=(e,t)=>bt(t.selectedElementIds,e)?t.selectedElementIds:e});var HM,wv,_h,xe,Er=y(()=>{"use strict";h();ue();ae();ti();yo();HM=e=>{let t=["includeBoundTextElement","includeElementsInFrames"],r="";for(let o of t)r+=`${o}:${e[o]?"1":"0"}`;return r},wv=e=>typeof e=="string",_h=class e{static sceneMapByElement=new WeakMap;static sceneMapById=new Map;static mapElementToScene(t,r,o=!0){if(wv(t)){if(!o)return;this.sceneMapById.set(t,r)}else this.sceneMapByElement.set(t,r),o||this.sceneMapById.set(t.id,r)}static getScene(t){return wv(t)?this.sceneMapById.get(t)||null:this.sceneMapByElement.get(t)||null}callbacks=new Set;nonDeletedElements=[];elements=[];nonDeletedFramesLikes=[];frames=[];elementsMap=new Map;selectedElementsCache={selectedElementIds:null,elements:null,cache:new Map};versionNonce;getElementsIncludingDeleted(){return this.elements}getNonDeletedElements(){return this.nonDeletedElements}getFramesIncludingDeleted(){return this.frames}getSelectedElements(t){let r=HM(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&&pc(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,r=!0){this.elements=t;let o=[];this.elementsMap.clear(),t.forEach(n=>{J(n)&&o.push(n),this.elementsMap.set(n.id,n),e.mapElementToScene(n,this)}),this.nonDeletedElements=ce(this.elements),this.frames=o,this.nonDeletedFramesLikes=ce(this.frames),this.informMutation()}informMutation(){this.versionNonce=jr();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,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)];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)];this.replaceAllElements(o)}addNewElement=t=>{t.frameId?this.insertElementAtIndex(t,this.getElementIndex(t.frameId)):this.replaceAllElements([...this.elements,t])};getElementIndex(t){return this.elements.findIndex(r=>r.id===t)}},xe=_h});var B,Q,wo,Ve=y(()=>{"use strict";h();Er();ec();yo();W();Io();B=(e,t,r=!0)=>{let o=!1,{points:n,fileId:i}=t;typeof n<"u"&&(t={...Rm(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 c=e[a],s=l;if(c[0]===s[0]&&c[1]===s[1])continue}else if(a==="points"){let c=e[a],s=l;if(c.length===s.length){let d=!1,m=c.length;for(;--m;){let u=c[m],p=s[m];if(u[0]!==p[0]||u[1]!==p[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")&&Te.delete(e),e.version++,e.versionNonce=jr(),e.updated=an(),r&&xe.getScene(e)?.informMutation()),e},Q=(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:an(),version:e.version+1,versionNonce:jr()}:e},wo=(e,t)=>(e.version=(t??e.version)+1,e.versionNonce=jr(),e.updated=an(),e)});var ao,xa,Jm,bl,lc,Ea=y(()=>{"use strict";h();Ve();ae();X();yt();W();ao=e=>te(e)||xt(e)?e.points.length<2:e.width===0&&e.height===0,xa=(e,t,r,o)=>{let[n,i,a,l]=io(e),c=Ue({clientX:o.offsetLeft,clientY:o.offsetTop},o),s=Ue({clientX:o.offsetLeft+t,clientY:o.offsetTop+r},o);return c.x<=a&&c.y<=l&&s.x>=n&&s.y>=i},Jm=(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)/No)*No;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}},bl=(e,t,r,o)=>{let n=r-e,i=o-t,a=Math.round(Math.atan(i/n)/No)*No;if(a===0)i=0;else if(a===Math.PI/2)n=0;else{let l=Math.tan(a),c=-1,s=t-l*e,d=-1/l,m=-1,u=o-d*r,p=(c*u-m*s)/(l*m-d*c),g=(s*d-u*l)/(l*m-d*c);n=p-e,i=g-t}return{width:n,height:i}},lc=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 Dh,vv,Qm,eu,Ph,zM,tu,Tv=y(()=>{"use strict";h();ml();Dh=(e,t,r)=>t>=e[0]&&t<=e[0]+e[2]&&r>=e[1]&&r<=e[1]+e[3],vv=(e,t,r,o,n,i)=>{if(!t.selectedElementIds[e.id])return!1;let{rotation:a,...l}=Ps(e,n,i);if(a&&Dh(a,r,o))return"rotation";let c=Object.keys(l).filter(s=>{let d=l[s];return d?Dh(d,r,o):!1});return c.length>0?c[0]:!1},Qm=(e,t,r,o,n,i)=>e.reduce((a,l)=>{if(a)return a;let c=vv(l,t,r,o,n,i);return c?{element:l,transformHandleType:c}:null},null),eu=([e,t,r,o],n,i,a,l)=>{let c=cl([e,t,r,o,(e+r)/2,(t+o)/2],0,a,l,_s);return Object.keys(c).find(d=>{let m=c[d];return m&&Dh(m,n,i)})||!1},Ph=["ns","nesw","ew","nwse"],zM=(e,t)=>{let r=Ph.indexOf(e);if(r>=0){let o=Math.round(t/(Math.PI/4));e=Ph[(r+o)%Ph.length]}return e},tu=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=zM(n,t.angle)),n?`${n}-resize`:""}});var ru,Rh,GM,UM,Nh,WM,VM,YM,Bh,KM,Oh,Fh,Hh=y(()=>{"use strict";h();X();ec();Zt();yt();ae();Ve();W();ko();Er();pt();ar();ru=e=>e<0?e+2*Math.PI:e>=2*Math.PI?e-2*Math.PI:e,Rh=(e,t,r,o,n,i,a,l,c,s,d,m)=>{if(r.length===1){let[u]=r;return t==="rotation"?(GM(u,l,c,n,e.originalElements),Co(u)):z(u)&&(t==="nw"||t==="ne"||t==="sw"||t==="se")?(VM(u,t,i,l,c),Co(u)):t&&YM(e.originalElements,a,u,t,i,l,c),!0}else if(r.length>1){if(t==="rotation")return KM(e,r,l,c,n,s,d),!0;if(t==="nw"||t==="ne"||t==="sw"||t==="se")return Bh(e,r,t,i,l,c),!0}return!1},GM=(e,t,r,o,n)=>{let[i,a,l,c]=ee(e),s=(i+l)/2,d=(a+c)/2,m;J(e)?m=0:(m=5*Math.PI/2+Math.atan2(r-d,t-s),o&&(m+=No/2,m-=m%No),m=ru(m));let u=Sn(e);if(B(e,{angle:m}),u){let p=xe.getScene(e)?.getElement(u);p&&!ve(e)&&B(p,{angle:m})}},UM=(e,t,r,o)=>te(e)||xt(e)?{points:fi(0,t,fi(1,r,e.points,o),o)}:{},Nh=(e,t,r)=>{let o=e.width;if(ke(e)){let l=je(e);l&&(o=hr(l))}let i=e.fontSize*(t/o);if(i<ed)return null;let a=_r(e.text,_e({fontSize:i,fontFamily:e.fontFamily}),e.lineHeight);return{size:i,baseline:a.baseline+(r-a.height)}},WM=(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)}),VM=(e,t,r,o,n)=>{let[i,a,l,c]=ee(e),s=(i+l)/2,d=(a+c)/2,[m,u]=fe(o,n,s,d,-e.angle),p;switch(t){case"se":p=Math.max((m-i)/(l-i),(u-a)/(c-a));break;case"nw":p=Math.max((l-m)/(l-i),(c-u)/(c-a));break;case"ne":p=Math.max((m-i)/(l-i),(c-u)/(c-a));break;case"sw":p=Math.max((l-m)/(l-i),(u-a)/(c-a));break}if(p>0){let g=e.width*p,b=e.height*p,E=Nh(e,g,b);if(E===null)return;let[w,v,T,k]=ta(e,g,b,!1),M=(i-w)/2,A=(a-v)/2,D=(l-T)/2,R=(c-k)/2,[H,C]=Md(WM(t,r),e.x,e.y,e.angle,M,A,D,R);B(e,{fontSize:E.size,width:g,height:b,baseline:E.baseline,x:H,y:C})}},YM=(e,t,r,o,n,i,a)=>{let l=e.get(r.id),[c,s,d,m]=ta(l,l.width,l.height,!0),u=[c,s],p=[d,m],g=Fs(u,p),b=Fe([i,a],g,-l.angle),[E,w,v,T]=ta(r,r.width,r.height,!0),k=v-E,M=T-w,A=p[0]-u[0],D=p[1]-u[1],R=A/k,H=D/M,C={},O=le(r);o.includes("e")&&(R=(b[0]-u[0])/k),o.includes("s")&&(H=(b[1]-u[1])/M),o.includes("w")&&(R=(p[0]-b[0])/k),o.includes("n")&&(H=(p[1]-b[1])/M);let P=l.width,G=l.height,j=r.width*R,V=r.height*H;if(n&&(j=2*j-P,V=2*V-G),t){let er=Math.abs(j)/P,Gi=Math.abs(V)/G;if(o.length===1&&(V*=er,j*=Gi),o.length===2){let Un=Math.max(er,Gi);j=P*Un*Math.sign(j),V=G*Un*Math.sign(V)}}if(O){let er=e.get(O.id);if(er&&(C={fontSize:er.fontSize,baseline:er.baseline}),t){let Gi={...r,width:j,height:V},Un=Nh(O,hr(Gi),Cn(Gi,O));if(Un===null)return;C={fontSize:Un.size,baseline:Un.baseline}}else{let Gi=Lm(_e(O),O.lineHeight),Un=Mm(O.fontSize,O.lineHeight);j=Math.max(j,Gi),V=Math.max(V,Un)}}let[pe,Se,q,Ge]=ta(l,j,V,!0),Ae=q-pe,It=Ge-Se,Ke=[...u];if(["n","w","nw"].includes(o)&&(Ke=[p[0]-Math.abs(Ae),p[1]-Math.abs(It)]),o==="ne"){let er=[u[0],p[1]];Ke=[er[0],er[1]-Math.abs(It)]}if(o==="sw"){let er=[p[0],u[1]];Ke=[er[0]-Math.abs(Ae),er[1]]}t&&(["s","n"].includes(o)&&(Ke[0]=g[0]-Ae/2),["e","w"].includes(o)&&(Ke[1]=g[1]-It/2));let Ur=j<0,Fi=V<0;Ur&&(o.includes("e")&&(Ke[0]-=Math.abs(Ae)),o.includes("w")&&(Ke[0]+=Math.abs(Ae))),Fi&&(o.includes("s")&&(Ke[1]-=Math.abs(It)),o.includes("n")&&(Ke[1]+=Math.abs(It))),n&&(Ke[0]=g[0]-Math.abs(Ae)/2,Ke[1]=g[1]-Math.abs(It)/2);let Qt=l.angle,Hn=Fe(Ke,g,Qt),Hi=[Ke[0]+Math.abs(Ae)/2,Ke[1]+Math.abs(It)/2],zi=Fe(Hi,g,Qt);Ke=Fe(Hn,zi,-Qt);let Po=[...Ke],zn=l.x-pe,Vt=l.y-Se;Po[0]+=zn,Po[1]+=Vt;let Do=Po[0],gC=Po[1],Tb,Ib;(te(r)||xt(r))&&(Tb=fi(1,V,l.points,!0),Ib=fi(0,j,Tb,!0));let Gn={width:Math.abs(j),height:Math.abs(V),x:Do,y:gC,points:Ib};if("scale"in r&&"scale"in l&&B(r,{scale:[(Math.sign(q-l.x)||l.scale[0])*l.scale[0],(Math.sign(Ge-l.y)||l.scale[1])*l.scale[1]]}),ve(r)&&O&&t){let er=Gn.width/r.width*O.fontSize;if(er<ed)return;C.fontSize=er}Gn.width!==0&&Gn.height!==0&&Number.isFinite(Gn.x)&&Number.isFinite(Gn.y)&&(B(r,Gn),Co(r,{newSize:{width:Gn.width,height:Gn.height}}),O&&C!=null&&B(O,{fontSize:C.fontSize,baseline:C.baseline}),la(r,o,t))},Bh=(e,t,r,o,n,i)=>{let a=t.reduce((C,O)=>{let P=e.originalElements.get(O.id);return P&&C.push({orig:P,latest:O}),C},[]),l=a.reduce((C,{orig:O})=>{if(!te(O))return C;let P=Sn(O);if(!P)return C;let G=e.originalElements.get(P)??null;if(!ke(G))return C;let j=K.getBoundTextElementPosition(O,G);return[...C,{...G,...j}]},[]),{minX:c,minY:s,maxX:d,maxY:m,midX:u,midY:p}=wr(a.map(({orig:C})=>C).concat(l)),g=r,b={ne:[c,m],se:[c,s],sw:[d,s],nw:[d,m]},[E,w]=o?[u,p]:b[g],v=Math.max(Math.abs(n-E)/(d-c)||0,Math.abs(i-w)/(m-s)||0)*(o?2:1);if(v===0)return;let T={ne:[n>=E,i<=w],se:[n>=E,i>=w],sw:[n<=E,i>=w],nw:[n<=E,i<=w]},[k,M]=T[g].map(C=>C?1:-1),A=k<0,D=M<0,R=[];for(let{orig:C,latest:O}of a){if(z(C)&&ke(C))continue;let P=C.width*v,G=C.height*v,j=ru(C.angle*k*M),V=te(C)||xt(C),pe=C.x-E,Se=C.y-w,q=A&&!V?P:0,Ge=D&&!V?G:0,Ae=E+k*(pe*v+q),It=w+M*(Se*v+Ge),Ke=UM(C,P*k,G*M,!1),Ur={x:Ae,y:It,width:P,height:G,angle:j,...Ke};if(Yr(C)&&a.length===1&&(Ur.scale=[C.scale[0]*k,C.scale[1]*M]),te(C)&&(A||D)){let Qt=fl(C,C.points),Hn=fl({...C,x:Ae,y:It},Ke.points),Hi=[C.x,C.y],zi=[Ae,It],Po=zn=>{let Vt=zn==="x"?0:1;return(Hn[Vt+2]-zi[Vt]-(Hi[Vt]-Qt[Vt])*v+(Qt[Vt+2]-Hi[Vt])*v-(zi[Vt]-Hn[Vt]))/2};A&&(Ur.x-=Po("x")),D&&(Ur.y-=Po("y"))}if(z(C)){let Qt=Nh(C,P,G);if(!Qt)return;Ur.fontSize=Qt.size,Ur.baseline=Qt.baseline}let Fi=e.originalElements.get(Sn(C)??"");if(Fi){let Qt=Fi.fontSize*v;if(Qt<ed)return;Ur.boundTextFontSize=Qt}R.push({element:O,update:Ur})}let H=R.map(({element:C})=>C);for(let{element:C,update:{boundTextFontSize:O,...P}}of R){let{width:G,height:j,angle:V}=P;B(C,P,!1),Co(C,{simultaneouslyUpdated:H,newSize:{width:G,height:j}});let pe=le(C);pe&&O&&(B(pe,{fontSize:O,angle:te(C)?void 0:V},!1),la(C,r,!0))}xe.getScene(R[0].element)?.informMutation()},KM=(e,t,r,o,n,i,a)=>{let l=5*Math.PI/2+Math.atan2(o-a,r-i);n&&(l+=No/2,l-=l%No),t.filter(c=>!J(c)).forEach(c=>{let[s,d,m,u]=ee(c),p=(s+m)/2,g=(d+u)/2,b=e.originalElements.get(c.id)?.angle??c.angle,[E,w]=fe(p,g,i,a,l+b-c.angle);B(c,{x:c.x+(E-p),y:c.y+(w-g),angle:ru(l+b)},!1),Co(c,{simultaneouslyUpdated:t});let v=le(c);v&&!ve(c)&&B(v,{x:v.x+(E-p),y:v.y+(w-g),angle:ru(l+b)},!1)}),xe.getScene(t[0])?.informMutation()},Oh=(e,t,r,o)=>{let[n,i,a,l]=t.length===1?ee(t[0]):we(t),c=(n+a)/2,s=(i+l)/2,d=t.length===1?t[0].angle:0;switch([r,o]=fe(r,o,c,s,-d),e){case"n":return fe(r-(n+a)/2,o-i,0,0,d);case"s":return fe(r-(n+a)/2,o-l,0,0,d);case"w":return fe(r-n,o-(i+l)/2,0,0,d);case"e":return fe(r-a,o-(i+l)/2,0,0,d);case"nw":return fe(r-n,o-i,0,0,d);case"ne":return fe(r-a,o-i,0,0,d);case"sw":return fe(r-n,o-l,0,0,d);case"se":return fe(r-a,o-l,0,0,d);default:return[0,0]}},Fh=(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 zh,$M,Iv,Gh,ou,Sv=y(()=>{"use strict";h();ko();yt();Ve();Ea();pt();gr();Zt();ae();zh=(e,t,r,o,n,i,a)=>{let l=new Set(t),c=t.filter(m=>J(m)).map(m=>m.id);c.length>0&&n.getNonDeletedElements().filter(u=>!ke(u)).filter(u=>u.frameId!==null).filter(u=>c.includes(u.frameId)).forEach(u=>l.add(u));let s=we(Array.from(l).map(m=>e.originalElements.get(m.id)??m)),d=$M(s,r,i,a);l.forEach(m=>{if(Iv(e,m,d),!ve(m)&&(!m.groupIds.length||o.editingGroupId&&!Wa(o,m))){let u=le(m);u&&Iv(e,u,d)}Co(m,{simultaneouslyUpdated:Array.from(l)})})},$M=(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[c,s]=wt(n+t.x,i+t.y,o);r.x===0&&(a=c),r.y===0&&(l=s)}return{x:a-n,y:l-i}},Iv=(e,t,r)=>{let o=e.originalElements.get(t.id)??t,n=o.x+r.x,i=o.y+r.y;B(t,{x:n,y:i})},Gh=(e,t,r)=>{let[o,n]=we(e);return[t-o,r-n]},ou=(e,t,r,o,n,i,a,l,c,s,d,m=null)=>{c&&e.type!=="selection"&&(d?l=a/d:(Math.abs(i-o)>Math.abs(n-r)?{width:a,height:l}=Jm(t,l,n<r?-a:a):{width:a,height:l}=Jm(t,a,i<o?-l:l),l<0&&(l=-l)));let u=n<r?r-a:r,p=i<o?o-l:o;s&&(a+=a,l+=l,u=r-a/2,p=o-l/2),a!==0&&l!==0&&B(e,{x:u+(m?.x??0),y:p+(m?.y??0),width:a,height:l})}});var ya,Cv=y(()=>{"use strict";h();Ze();ya=(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 XM,Vw,ce,pc,kv,lv,Gm,ue=y(()=>{"use strict";h();Ea();ae();dn();yt();ml();na();Tv();Hh();Sv();ae();Cm();pt();Ea();Cv();XM=e=>e.reduce((t,r)=>t+r.version,0),Vw=e=>e.filter(t=>!t.isDeleted&&!ao(t)),ce=e=>e.filter(t=>!t.isDeleted),pc=e=>!e.isDeleted,kv=e=>ce(e).map(t=>fs(t.type)?{...t,lastCommittedPoint:null}:t),lv=e=>kv(e),Gm=e=>kv(e)});var Mo,Go,_y,Py,nu,Qd=y(()=>{"use strict";h();ue();W();Y();Mo=4,Go=6,_y="rgba(0,0,0,0.3)",Py=(e,t,r,o)=>{if(e.length===0)return{horizontal:null,vertical:null};let[n,i,a,l]=we(e),c=t/o.zoom.value,s=r/o.zoom.value,d=t-c,m=r-s,u={top:parseInt(ps("sat"))||0,bottom:parseInt(ps("sab"))||0,left:parseInt(ps("sal"))||0,right:parseInt(ps("sar"))||0},p=rn().rtl,g=-o.scrollX+d/2+u.left,b=-o.scrollY+m/2+u.top,E=g+c-u.right,w=b+s-u.bottom,v=Math.min(n,g),T=Math.min(i,b),k=Math.max(a,E),M=Math.max(l,w);return{horizontal:g===v&&E===k?null:{x:Math.max(u.left,Mo)+(g-v)/(k-v)*t,y:r-Go-Math.max(Mo,u.bottom),width:(E-g)/(k-v)*t-Math.max(Mo*2,u.left+u.right),height:Go},vertical:b===T&&w===M?null:{x:p?Math.max(u.left,Mo):t-Go-Math.max(u.right,Mo),y:(b-T)/(M-T)*r+Math.max(u.top,Mo),width:Go,height:(w-b)/(M-T)*r-Math.max(Mo*2,u.top+u.bottom)}}},nu=(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}}});var Ze=y(()=>{"use strict";h();Qd();ti();Kg();Ys();hm()});import{jsx as jM}from"react/jsx-runtime";var ZM,Av,gc,Uh=y(()=>{"use strict";h();Ze();me();Lt();Y();We();ue();Ve();gr();ar();ko();ae();W();se();ZM=(e,t)=>{let r=new Set(ge(e.filter(o=>J(o)),t).map(o=>o.id));return{elements:e.map(o=>t.selectedElementIds[o.id]?Q(o,{isDeleted:!0}):o.frameId&&r.has(o.frameId)?Q(o,{isDeleted:!0}):ke(o)&&t.selectedElementIds[o.containerId]?Q(o,{isDeleted:!0}):o),appState:{...t,selectedElementIds:{},selectedGroupIds:{}}}},Av=(e,t)=>{if(e.editingGroupId){let r=at(ce(t),e.editingGroupId);if(r.length)return{...e,selectedElementIds:{[r[0].id]:!0}}}return e},gc=N({name:"deleteSelectedElements",trackEvent:{category:"element",action:"delete"},perform:(e,t)=>{if(t.editingLinearElement){let{elementId:n,selectedPointsIndices:i,startBindingElement:a,endBindingElement:l}=t.editingLinearElement,c=K.getElement(n);if(!c||i==null)return!1;if(c.points.length<2){let d=e.map(u=>u.id===c.id?Q(u,{isDeleted:!0}):u),m=Av(t,d);return{elements:d,appState:{...m,editingLinearElement:null},commitToHistory:!1}}let s={startBindingElement:i?.includes(0)?null:a,endBindingElement:i?.includes(c.points.length-1)?null:l};return K.deletePoints(c,i),{elements:e,appState:{...t,editingLinearElement:{...t.editingLinearElement,...s,selectedPointsIndices:i?.[0]>0?[i[0]-1]:[0]}},commitToHistory:!0}}let{elements:r,appState:o}=ZM(e,t);return hl(r,e.filter(({id:n})=>t.selectedElementIds[n])),o=Av(o,r),{elements:r,appState:{...o,activeTool:Xe(t,{type:"selection"}),multiElement:null,activeEmbeddable:null},commitToHistory:ze(ce(e),t)}},contextItemLabel:"labels.delete",keyTest:(e,t,r)=>(e.key===S.BACKSPACE||e.key===S.DELETE)&&!e[S.CTRL_OR_CMD],PanelComponent:({elements:e,appState:t,updateData:r})=>jM(ne,{type:"button",icon:ii,title:f("labels.delete"),"aria-label":f("labels.delete"),onClick:()=>r(null),visible:ze(ce(e),t)})})});function Rv(e,t,r,o){let n=Ce(ge(e,t,{includeBoundTextElement:!0,includeElementsInFrames:!0})),i={regularElements:[],frameChildren:new Map},a=new Set;for(let s of e)n.has(s.id)&&J(s)&&a.add(s.id);for(let s of e)if(n.has(s.id))if(J(s)||s.frameId&&a.has(s.frameId))i.regularElements.push(s);else if(!s.frameId)i.regularElements.push(s);else{let d=i.frameChildren.get(s.frameId)||[];d.push(s),i.frameChildren.set(s.frameId,d)}let l=e,c=Array.from(i.frameChildren.entries());for(let[s,d]of c)l=o(e,t,r,s,d);return o(l,t,r,null,i.regularElements)}var Wh,Lv,qM,Mv,JM,QM,_v,Pv,Dv,Nv,Bv,Ov,Fv,Hv=y(()=>{"use strict";h();Ve();ae();gr();Ze();Er();W();Wh=(e,t)=>e.frameId===t||e.id===t,Lv=(e,t,r)=>{let o=[],n=[],i=null,a=-1,l=Ce(r||ge(e,t,{includeBoundTextElement:!0,includeElementsInFrames:!0}));for(;++a<e.length;){let c=e[a];l.get(c.id)?(n.length&&(o=o.concat(n),n=[]),o.push(a),i=a+1):c.isDeleted&&i===a?(i=a+1,n.push(a)):n=[]}return o},qM=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),[])},Mv=(e,t,r)=>{if("containerId"in e&&e.containerId)if(r==="left"){let o=xe.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=xe.getScene(e).getElement(o);if(n)return t.indexOf(n)}}},JM=(e,t)=>{let r=-1,o=-1;return e.forEach((n,i)=>{Wh(n,t)&&(r===-1&&(r=i),o=i)}),r===-1?[]:e.slice(r,o+1)},QM=(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"?Np(t,m=>a(m),Math.max(0,r-1)):Rp(t,m=>a(m),r+1),c=t[l];if(!c)return-1;if(e.editingGroupId){if(i?.groupIds.join("")===c?.groupIds.join(""))return Mv(c,t,o)??l;if(!c?.groupIds.includes(e.editingGroupId))return-1}if(!n&&(c.frameId||J(c))){let m=JM(t,c.frameId||c.id);return o==="left"?t.indexOf(m[0]):t.indexOf(m[m.length-1])}if(!c.groupIds.length)return Mv(c,t,o)??l;let s=e.editingGroupId?c.groupIds[c.groupIds.indexOf(e.editingGroupId)-1]:c.groupIds[c.groupIds.length-1],d=at(t,s);return d.length?o==="left"?t.indexOf(d[0]):t.indexOf(d[d.length-1]):l},_v=(e,t)=>t.reduce((r,o)=>{let n=e[o];return r[n.id]=n,r},{}),Pv=(e,t,r)=>{let o=Lv(e,t),n=_v(e,o),i=qM(o);r==="right"&&(i=i.reverse());let a=new Set(o.filter(l=>J(e[l])).map(l=>e[l].id));return i.forEach((l,c)=>{let s=l[0],d=l[l.length-1],m=r==="left"?s:d,u=l.some(v=>{let T=e[v];return T.frameId&&a.has(T.frameId)})?null:e[m]?.frameId,p=QM(t,e,m,r,u);if(p===-1||m===p)return;let g=r==="left"?e.slice(0,p):e.slice(0,s),b=e.slice(s,d+1),E=r==="left"?e.slice(p,s):e.slice(d+1,p+1),w=r==="left"?e.slice(d+1):e.slice(p+1);e=r==="left"?[...g,...b,...E,...w]:[...g,...E,...b,...w]}),e.map(l=>n[l.id]?wo(l):l)},Dv=(e,t,r,o,n)=>{let i=Lv(e,t,n),a=_v(e,i),l=[],c,s;if(r==="left"){if(o)c=Rp(e,p=>Wh(p,o));else if(t.editingGroupId){let p=at(e,t.editingGroupId);if(!p.length)return e;c=e.indexOf(p[0])}else c=0;s=i[i.length-1]}else{if(o)s=Np(e,p=>Wh(p,o));else if(t.editingGroupId){let p=at(e,t.editingGroupId);if(!p.length)return e;s=e.indexOf(p[p.length-1])}else s=e.length-1;c=i[0]}c===-1&&(c=0);for(let p=c;p<s+1;p++)i.includes(p)||l.push(e[p]);let d=Object.values(a).map(p=>wo(p)),m=e.slice(0,c),u=e.slice(s+1);return r==="left"?[...m,...d,...l,...u]:[...m,...l,...d,...u]};Nv=(e,t)=>Pv(e,t,"left"),Bv=(e,t)=>Pv(e,t,"right"),Ov=(e,t)=>Rv(e,t,"left",Dv),Fv=(e,t)=>Rv(e,t,"right",Dv)});import{jsx as iu}from"react/jsx-runtime";var Vh,Yh,Kh,$h,zv=y(()=>{"use strict";h();Hv();me();Y();W();We();se();X();Vh=N({name:"sendBackward",trackEvent:{category:"element"},perform:(e,t)=>({elements:Nv(e,t),appState:t,commitToHistory:!0}),contextItemLabel:"labels.sendBackward",keyPriority:40,keyTest:e=>e[S.CTRL_OR_CMD]&&!e.shiftKey&&e.code===de.BRACKET_LEFT,PanelComponent:({updateData:e,appState:t})=>iu("button",{type:"button",className:"zIndexButton",onClick:()=>e(null),title:`${f("labels.sendBackward")} \u2014 ${_("CtrlOrCmd+[")}`,children:XE})}),Yh=N({name:"bringForward",trackEvent:{category:"element"},perform:(e,t)=>({elements:Bv(e,t),appState:t,commitToHistory:!0}),contextItemLabel:"labels.bringForward",keyPriority:40,keyTest:e=>e[S.CTRL_OR_CMD]&&!e.shiftKey&&e.code===de.BRACKET_RIGHT,PanelComponent:({updateData:e,appState:t})=>iu("button",{type:"button",className:"zIndexButton",onClick:()=>e(null),title:`${f("labels.bringForward")} \u2014 ${_("CtrlOrCmd+]")}`,children:$E})}),Kh=N({name:"sendToBack",trackEvent:{category:"element"},perform:(e,t)=>({elements:Ov(e,t),appState:t,commitToHistory:!0}),contextItemLabel:"labels.sendToBack",keyTest:e=>rr?e[S.CTRL_OR_CMD]&&e.altKey&&e.code===de.BRACKET_LEFT:e[S.CTRL_OR_CMD]&&e.shiftKey&&e.code===de.BRACKET_LEFT,PanelComponent:({updateData:e,appState:t})=>iu("button",{type:"button",className:"zIndexButton",onClick:()=>e(null),title:`${f("labels.sendToBack")} \u2014 ${rr?_("CtrlOrCmd+Alt+["):_("CtrlOrCmd+Shift+[")}`,children:jE})}),$h=N({name:"bringToFront",trackEvent:{category:"element"},perform:(e,t)=>({elements:Fv(e,t),appState:t,commitToHistory:!0}),contextItemLabel:"labels.bringToFront",keyTest:e=>rr?e[S.CTRL_OR_CMD]&&e.altKey&&e.code===de.BRACKET_RIGHT:e[S.CTRL_OR_CMD]&&e.shiftKey&&e.code===de.BRACKET_RIGHT,PanelComponent:({updateData:e,appState:t})=>iu("button",{type:"button",className:"zIndexButton",onClick:r=>e(null),title:`${f("labels.bringToFront")} \u2014 ${rr?_("CtrlOrCmd+Alt+]"):_("CtrlOrCmd+Shift+]")}`,children:ZE})})});var Xh,Gv=y(()=>{"use strict";h();me();We();gr();ue();ae();ar();ti();Xh=N({name:"selectAll",trackEvent:{category:"canvas"},perform:(e,t,r,o)=>{if(t.editingLinearElement)return!1;let n=ba(e.filter(i=>!i.isDeleted&&!(z(i)&&i.containerId)&&!i.locked)).reduce((i,a)=>(i[a.id]=!0,i),{});return{appState:{...t,...Ht({editingGroupId:null,selectedElementIds:n},ce(e),t,o),selectedLinearElement:Object.keys(n).length===1&&te(e[0])?new K(e[0],o.scene):null},commitToHistory:!0}},contextItemLabel:"labels.selectAll",keyTest:e=>e[S.CTRL_OR_CMD]&&e.key===S.A})});var e8,t8,Uv,Wv=y(()=>{"use strict";h();W();e8=e=>{let t=e.slice(),r=new Set,o=i=>{let a=i[0]?.groupIds?.join(""),l=[i[0]],c=[];for(let s of i.slice(1))s.groupIds?.join("")===a?l.push(s):c.push(s);return c.length?[...l,...o(c)]: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],c=t.slice(a).filter(s=>{let d=s?.groupIds?.some(m=>m===l);return d&&n.set(s.id,!0),d});for(let s of o(c))r.add(s)}else r.add(i)}),r.size!==e.length?(console.error("normalizeGroupElementOrder: lost some elements... bailing!"),e):[...r]},t8=e=>{let t=Ex(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]},Uv=e=>t8(e8(e))});import{jsx as o8}from"react/jsx-runtime";var Zh,r8,Vv=y(()=>{"use strict";h();me();We();ue();Ze();Lt();Y();W();ar();gr();ko();X();pt();ae();Wv();se();br();ti();Zh=N({name:"duplicateSelection",trackEvent:{category:"element"},perform:(e,t)=>{if(t.editingLinearElement){let r=K.duplicateSelectedPoints(t);return r?{elements:e,appState:r.appState,commitToHistory:!0}:!1}return{...r8(e,t),commitToHistory:!0}},contextItemLabel:"labels.duplicateSelection",keyTest:e=>e[S.CTRL_OR_CMD]&&e.key===S.D,PanelComponent:({elements:e,appState:t,updateData:r})=>o8(ne,{type:"button",icon:_E,title:`${f("labels.duplicateSelection")} \u2014 ${_("CtrlOrCmd+D")}`,"aria-label":f("labels.duplicateSelection"),onClick:()=>r(null),visible:ze(ce(e),t)})}),r8=(e,t)=>{let r=Uv(e),o=new Map,n=[],i=[],a=new Map,l=w=>{let v=vs(t.editingGroupId,o,w,{x:w.x+nn/2,y:w.y+nn/2});return a.set(w.id,v.id),i.push(w),n.push(v),v},c=Ce(ge(r,t,{includeBoundTextElement:!0,includeElementsInFrames:!0})),s=new Map,d=w=>{for(let v of w)s.set(v.id,!0);return w},m=[],u=-1;for(;++u<r.length;){let w=r[u];if(s.get(w.id))continue;let v=le(w),T=J(w);if(c.get(w.id)){if(w.groupIds.length||v||T){let k=Zp(t,w);if(k){let M=at(r,k).flatMap(A=>J(A)?[...Fr(e,A.id),A]:[A]);m.push(...d([...M,...M.map(A=>l(A))]));continue}if(v){m.push(...d([w,v,l(w),l(v)]));continue}if(T){let M=Fr(r,w.id);m.push(...d([...M,w,...M.map(A=>l(A)),l(w)]));continue}}(!w.frameId||!c.has(w.frameId))&&m.push(...d([w,l(w)]))}else m.push(...d([w]))}let p=[],g=new Map;for(u=m.length;--u>=0;){let w=m[u];g.get(w.id)||(g.set(w.id,!0),p.push(w))}let b=p.reverse();Am(m,i,a),nm(m,i,a),Zm(b,i,a);let E=ba(n);return{elements:b,appState:{...t,...Ht({editingGroupId:t.editingGroupId,selectedElementIds:E.reduce((w,v)=>(ke(v)||(w[v.id]=!0),w),{})},ce(b),t,null)}}}});import{jsx as n8}from"react/jsx-runtime";var lo,Yv=y(()=>{"use strict";h();me();ue();W();Lt();se();Y();We();Ve();Zt();ar();Er();ko();ae();Va();lo=N({name:"finalize",trackEvent:!1,perform:(e,t,r,{interactiveCanvas:o,focusContainer:n,scene:i})=>{if(t.editingLinearElement){let{elementId:d,startBindingElement:m,endBindingElement:u}=t.editingLinearElement,p=K.getElement(d);if(p)return Et(p)&&xn(p,m,u),{elements:p.points.length<2||ao(p)?e.filter(g=>g.id!==p.id):void 0,appState:{...t,cursorButton:"up",editingLinearElement:null},commitToHistory:!0}}let a=e,l=t.pendingImageElementId&&i.getElement(t.pendingImageElementId);l&&B(l,{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:m,lastCommittedPoint:u}=c;(!u||m[m.length-1]!==u)&&B(c,{points:c.points.slice(0,-1)})}ao(c)&&(a=a.filter(m=>m.id!==c.id));let d=xr(c.points,t.zoom.value);if((c.type==="line"||c.type==="freedraw")&&d){let m=c.points,u=m[0];B(c,{points:m.map((p,g)=>g===m.length-1?[u[0],u[1]]:p)})}if(Et(c)&&!d&&c.points.length>1){let[m,u]=K.getPointAtIndexGlobalCoordinates(c,-1);Bs(c,t,xe.getScene(c),{x:m,y:u})}}(!t.activeTool.locked&&t.activeTool.type!=="freedraw"||!c)&&Mr(o);let s;return t.activeTool.type==="eraser"?s=Xe(t,{...t.activeTool.lastActiveTool||{type:"selection"},lastActiveToolBeforeEraser:null}):s=Xe(t,{type:"selection"}),{elements:a,appState:{...t,cursorButton:"up",activeTool:(t.activeTool.locked||t.activeTool.type==="freedraw")&&c?t.activeTool:s,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&&te(c)?new K(c,i):t.selectedLinearElement,pendingImageElementId:null},commitToHistory:t.activeTool.type==="freedraw"}},keyTest:(e,t)=>e.key===S.ESCAPE&&(t.editingLinearElement!==null||!t.draggingElement&&t.multiElement===null)||(e.key===S.ESCAPE||e.key===S.ENTER)&&t.multiElement!==null,PanelComponent:({appState:e,updateData:t,data:r})=>n8(ne,{type:"button",icon:WE,title:f("buttons.done"),"aria-label":f("buttons.done"),onClick:t,visible:e.multiElement!=null,size:r?.size||"medium"})})});var Kv=y(()=>{});var $v=y(()=>{});import{useState as i8}from"react";import{jsx as jh,jsxs as a8}from"react/jsx-runtime";var Xv,Zv=y(()=>{"use strict";h();Kv();W();$v();be();me();Xv=e=>{let{id:t}=Nt(),[r,o]=i8(e.value),n=a=>{e.ignoreFocus||bx(a.target);let l=a.target.value;l!==e.value&&e.onChange(l)},i=a=>{if(a.key===S.ENTER){if(a.preventDefault(),a.nativeEvent.isComposing||a.keyCode===229)return;a.currentTarget.blur()}};return a8("div",{className:"ProjectName",children:[jh("label",{className:"ProjectName-label",htmlFor:"filename",children:`${e.label}${e.isNameEditable?"":":"}`}),e.isNameEditable?jh("input",{type:"text",className:"TextInput",onBlur:n,onKeyDown:i,id:`${t}-filename`,value:r,onChange:a=>o(a.target.value)}):jh("span",{className:"TextInput TextInput--readonly",id:`${t}-filename`,children:e.value})]})}});import{jsx as hc}from"react/jsx-runtime";var qv,jv,Jv=y(()=>{"use strict";h();pn();Y();Lt();X();qv=e=>{let t=e.title||(e.value==="dark"?f("buttons.lightMode"):f("buttons.darkMode"));return hc(ne,{type:"icon",icon:e.value===nt.LIGHT?jv.MOON:jv.SUN,title:t,"aria-label":t,onClick:()=>e.onChange(e.value===nt.DARK?nt.LIGHT:nt.DARK),"data-testid":"toggle-dark-mode"})},jv={SUN:hc("svg",{width:"512",height:"512",className:"rtl-mirror",viewBox:"0 0 512 512",children:hc("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:hc("svg",{width:"512",height:"512",className:"rtl-mirror",viewBox:"0 0 512 512",children:hc("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 wa,va,Fl=y(()=>{"use strict";h();gi();X();ue();ae();Y();_n();Ze();mc();W();vr();kn();Ln();vr();Ln();wa=(e,{selectedElementIds:t},r)=>{e=ce(e);let o=r&&ze(e,{selectedElementIds:t}),n=null,i=o?ge(e,{selectedElementIds:t},{includeBoundTextElement:!0}):e;return o&&(i.length===1&&J(i[0])?(n=i[0],i=ha({elements:e,bounds:n,type:"overlap"})):i.length>1&&(i=ge(e,{selectedElementIds:t},{includeBoundTextElement:!0,includeElementsInFrames:!0}))),{exportingFrame:n,exportedElements:Vr(i)}},va=async(e,t,r,o,{exportBackground:n,exportPadding:i=bo,viewBackgroundColor:a,name:l,fileHandle:c=null,exportingFrame:s=null})=>{if(t.length===0)throw new Error(f("alerts.cannotExportEmptyCanvas"));if(e==="svg"||e==="clipboard-svg"){let m=await Dl(t,{exportBackground:n,exportWithDarkMode:r.exportWithDarkMode,viewBackgroundColor:a,exportPadding:i,exportScale:r.exportScale,exportEmbedScene:r.exportEmbedScene&&e==="svg"},o,{exportingFrame:s});if(e==="svg")return await Ml(new Blob([m.outerHTML],{type:Z.svg}),{description:"Export to SVG",name:l,extension:r.exportEmbedScene?"excalidraw.svg":"svg",fileHandle:c});if(e==="clipboard-svg"){await Tn(m.outerHTML);return}}let d=Km(t,r,o,{exportBackground:n,viewBackgroundColor:a,exportPadding:i,exportingFrame:s});if(e==="png"){let m=await Mn(d);return r.exportEmbedScene&&(m=await(await Promise.resolve().then(()=>(Ll(),sc))).encodePngMetadata({blob:m,metadata:yi(t,r,o,"local")})),await Ml(m,{description:"Export to PNG",name:l,extension:"png",fileHandle:c})}else if(e==="clipboard")try{let m=Mn(d);await Im(m)}catch(m){throw console.warn(m),m.name==="CANVAS_POSSIBLY_TOO_BIG"?m:Vn&&m.name==="TypeError"?new Error(`${f("alerts.couldNotCopyToClipboard")}
|
|
50
|
+
`,t.exportBackground&&l){let L=y.ownerDocument.createElementNS(_e,"rect");L.setAttribute("x","0"),L.setAttribute("y","0"),L.setAttribute("width",`${f}`),L.setAttribute("height",`${E}`),L.setAttribute("fill",l),y.appendChild(L)}let R=uE.svg(y),z=o?.renderEmbeddables??!1;return Bx(m,so(J(m)),R,y,r||{},{offsetX:w,offsetY:I,isExporting:!0,exportWithDarkMode:a,renderEmbeddables:z,frameRendering:n,canvasBackgroundColor:l,embedsValidationStatus:z?new Map(m.filter(L=>X(L)).map(L=>[L.id,!0])):new Map}),y},fg=(e,t)=>{let[r,o,n,i]=ye(e),a=Ct(r,n)+t*2,l=Ct(o,i)+t*2;return[r,o,a,l]},fE=(e,t,r)=>{let[,,o,n]=fg(e,t).map(i=>Math.trunc(i*r));return[o,n]}});var wo,$e,ri,xE,ta,ll,zs,xg,bE,mS,EE,$d,Vr,yE,pS,uS,gS,wE,hS,fS,vE,Eg=Z(()=>{"use strict";h();Vt();W();me();co();wo=32,$e=12,ri=256,xE=50,ta="NOT_SPREADSHEET",ll="VALID_SPREADSHEET",zs=e=>{let t=/^([-+]?)[$€£¥₩]?([-+]?)([\d.,]+)[%]?$/.exec(e);return t?parseFloat(`${(t[1]||t[2])+t[3]}`.replace(/,/g,"")):null},xg=(e,t)=>e.slice(1).every(r=>zs(r[t])!==null),bE=e=>{let t=e[0].length;if(t>2)return{type:ta,reason:"More than 2 columns"};if(t===1){if(!xg(e,0))return{type:ta,reason:"Value is not numeric"};let s=zs(e[0][0])===null,c=(s?e.slice(1):e).map(d=>zs(d[0]));return c.length<2?{type:ta,reason:"Less than two rows"}:{type:ll,spreadsheet:{title:s?e[0][0]:null,labels:null,values:c}}}let r=xg(e,0),o=xg(e,1);if(!r&&!o)return{type:ta,reason:"Value is not numeric"};let[n,i]=o?[0,1]:[1,0],a=zs(e[0][i])===null,l=a?e.slice(1):e;return l.length<2?{type:ta,reason:"Less than 2 rows"}:{type:ll,spreadsheet:{title:a?e[0][i]:null,labels:l.map(s=>s[n]),values:l.map(s=>zs(s[i]))}}},mS=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},EE=e=>{let t=e.trim().split(`
|
|
51
|
+
`).map(i=>i.trim().split(" "));if(t.length&&t[0].length!==2&&(t=e.trim().split(`
|
|
52
|
+
`).map(i=>i.trim().split(","))),t.length===0)return{type:ta,reason:"No values"};let r=t[0].length;if(!t.every(i=>i.length===r))return{type:ta,reason:"All rows don't have same number of columns"};let n=bE(t);if(n.type!==ll){let i=bE(mS(t));if(i.type===ll)return i}return n},$d=kb(Tb),Vr={fillStyle:"hachure",fontFamily:Ot,fontSize:It,opacity:100,roughness:1,strokeColor:ie.black,roundness:null,strokeStyle:"solid",strokeWidth:1,verticalAlign:gt.MIDDLE,locked:!1},yE=e=>{let t=(wo+$e)*e.values.length+$e,r=ri+$e*2;return{chartWidth:t,chartHeight:r}},pS=(e,t,r,o,n)=>e.labels?.map((i,a)=>Lt({groupIds:[o],backgroundColor:n,...Vr,text:i.length>8?`${i.slice(0,5)}...`:i,x:t+a*(wo+$e)+$e*2,y:r+$e/2,width:wo,angle:5.87,fontSize:16,textAlign:"center",verticalAlign:"top"}))||[],uS=(e,t,r,o,n)=>{let i=Lt({groupIds:[o],backgroundColor:n,...Vr,x:t-$e,y:r-$e,text:"0",textAlign:"right"}),a=Lt({groupIds:[o],backgroundColor:n,...Vr,x:t-$e,y:r-ri-i.height/2,text:Math.max(...e.values).toLocaleString(),textAlign:"right"});return[i,a]},gS=(e,t,r,o,n)=>{let{chartWidth:i,chartHeight:a}=yE(e),l=Ur({backgroundColor:n,groupIds:[o],...Vr,type:"line",x:t,y:r,startArrowhead:null,endArrowhead:null,width:i,points:[[0,0],[i,0]]}),s=Ur({backgroundColor:n,groupIds:[o],...Vr,type:"line",x:t,y:r,startArrowhead:null,endArrowhead:null,height:a,points:[[0,0],[0,-a]]}),c=Ur({backgroundColor:n,groupIds:[o],...Vr,type:"line",x:t,y:r-ri-$e,startArrowhead:null,endArrowhead:null,strokeStyle:"dotted",width:i,opacity:xE,points:[[0,0],[i,0]]});return[l,s,c]},wE=(e,t,r,o,n,i)=>{let{chartWidth:a,chartHeight:l}=yE(e),s=e.title?Lt({backgroundColor:n,groupIds:[o],...Vr,text:e.title,x:t+a/2,y:r-ri-$e*2-It,roundness:null,textAlign:"center"}):null,c=i?Ar({backgroundColor:n,groupIds:[o],...Vr,type:"rectangle",x:t,y:r-l,width:a,height:l,strokeColor:ie.black,fillStyle:"solid",opacity:6}):null;return[...c?[c]:[],...s?[s]:[],...pS(e,t,r,o,n),...uS(e,t,r,o,n),...gS(e,t,r,o,n)]},hS=(e,t,r)=>{let o=Math.max(...e.values),n=At(),i=$d[Math.floor(Math.random()*$d.length)];return[...e.values.map((l,s)=>{let c=l/o*ri;return Ar({backgroundColor:i,groupIds:[n],...Vr,type:"rectangle",x:t+s*(wo+$e)+$e,y:r-c-$e,width:wo,height:c})}),...wE(e,t,r,n,i,v.DEV)]},fS=(e,t,r)=>{let o=Math.max(...e.values),n=At(),i=$d[Math.floor(Math.random()*$d.length)],a=0,l=[];for(let f of e.values){let E=a*(wo+$e),y=-(f/o)*ri;l.push([E,y]),a++}let s=Math.max(...l.map(f=>f[0])),c=Math.max(...l.map(f=>f[1])),d=Math.min(...l.map(f=>f[0])),m=Math.min(...l.map(f=>f[1])),p=Ur({backgroundColor:i,groupIds:[n],...Vr,type:"line",x:t+$e+wo/2,y:r-$e,startArrowhead:null,endArrowhead:null,height:c-m,width:s-d,strokeWidth:2,points:l}),u=e.values.map((f,E)=>{let y=E*(wo+$e)+$e/2,T=-(f/o)*ri+$e/2;return Ar({backgroundColor:i,groupIds:[n],...Vr,fillStyle:"solid",strokeWidth:2,type:"ellipse",x:t+y+wo/2,y:r+T-$e*2,width:$e,height:$e})}),g=e.values.map((f,E)=>{let y=E*(wo+$e)+$e/2,T=f/o*ri+$e/2+$e;return Ur({backgroundColor:i,groupIds:[n],...Vr,type:"line",x:t+y+wo/2+$e/2,y:r-T,startArrowhead:null,endArrowhead:null,height:T,strokeStyle:"dotted",opacity:xE,points:[[0,0],[0,T]]})});return[...wE(e,t,r,n,i,v.DEV),p,...g,...u]},vE=(e,t,r,o)=>e==="line"?fS(t,r,o):hS(t,r,o)});function SE(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(SE(r));return t}var jR,Xd,sl,bS,TE,xS,Zd,ES,yS,IE,wS,jd,qd,Sn,vS,oi=Z(()=>{"use strict";h();Eg();W();oe();fn();He();Xt();F();jR="clipboard"in navigator&&"readText"in navigator.clipboard,Xd="clipboard"in navigator&&"writeText"in navigator.clipboard,sl="clipboard"in navigator&&"write"in navigator.clipboard&&"ClipboardItem"in window&&"toBlob"in HTMLCanvasElement.prototype,bS=e=>!!([Yt.excalidraw,Yt.excalidrawClipboard,Yt.excalidrawClipboardWithAPI].includes(e?.type)&&Array.isArray(e.elements)),TE=({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},xS=({elements:e,files:t})=>{let r=J(e),o=new Set(e.filter(l=>X(l))),n=!1,i=e.reduce((l,s)=>(Qt(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:Yt.excalidrawClipboard,elements:e.map(l=>{if(Pt(l,r)&&!o.has(Pt(l,r))){let s=hn(l);return B(s,{frameId:null}),s}return l}),files:t?i:void 0};return JSON.stringify(a)},Zd=async(e,t,r)=>{await Sn(xS({elements:e,files:t}),r)},ES=e=>{let t=EE(e);return t.type===ll?{spreadsheet:t.spreadsheet}:null};yS=e=>{let t=e.clipboardData?.getData("text/html");if(!t)return null;try{let r=new DOMParser().parseFromString(t,"text/html"),o=SE(r.body);if(o.length)return{type:"mixedContent",value:o}}catch(r){console.error(`error in parseHTMLFromPaste: ${r.message}`)}return null},IE=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(Ql(Db,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},wS=async(e,t=!1)=>{try{let r=!t&&e&&yS(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(`
|
|
53
|
+
`).trim()}:r:{type:"text",value:(e.clipboardData?.getData("text/plain")||"").trim()}}catch{return{type:"text",value:""}}},jd=async(e,t=!1)=>{let r=await wS(e,t);if(r.type==="mixedContent")return{mixedContent:r.value};try{let o=!t&&ES(r.value);if(o)return o}catch(o){console.error(o)}try{let o=JSON.parse(r.value),n=o.type===Yt.excalidrawClipboardWithAPI;if(bS(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}},qd=async e=>{try{await navigator.clipboard.write([new window.ClipboardItem({[$.png]:e})])}catch(t){if(Lo(e))await navigator.clipboard.write([new window.ClipboardItem({[$.png]:await e})]);else throw t}},Sn=async(e,t)=>{if(Xd)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(!vS(e))throw new Error("Error copying to clipboard.")},vS=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 ni,Jd,cl,TS,ra=Z(()=>{"use strict";h();Fs();Sr();tl();W();rl();vn();oi();ni=({elements:e,appState:t,files:r,maxWidthOrHeight:o,getDimensions:n,exportPadding:i,exportingFrame:a})=>{let{elements:l,appState:s}=Qn({elements:e,appState:t},null,null),{exportBackground:c,viewBackgroundColor:d}=s;return Yd(l,{...s,offsetTop:0,offsetLeft:0,width:0,height:0},r||{},{exportBackground:c,exportPadding:i,viewBackgroundColor:d,exportingFrame:a},(m,p)=>{let u=document.createElement("canvas");if(o){typeof n=="function"&&console.warn("`getDimensions()` is ignored when `maxWidthOrHeight` is supplied.");let f=Math.max(m,p),E=o<f?o/f:t?.exportScale??1;return u.width=m*E,u.height=p*E,{canvas:u,scale:E}}let g=n?.(m,p)||{width:m,height:p};return u.width=g.width,u.height=g.height,{canvas:u,scale:g.scale??1}})},Jd=async e=>{let{mimeType:t=$.png,quality:r}=e;t===$.png&&typeof r=="number"&&console.warn(`"quality" will be ignored for "${$.png}" mimeType`),t==="image/jpg"&&(t=$.jpg),t===$.jpg&&!e.appState?.exportBackground&&(console.warn(`Defaulting "exportBackground" to "true" for "${$.jpg}" mimeType`),e={...e,appState:{...e.appState,exportBackground:!0}});let o=await ni(e);return r=r||(/image\/jpe?g/.test(t)?.92:.8),new Promise((n,i)=>{o.toBlob(async a=>{if(!a)return i(new Error("couldn't export to blob"));a&&t===$.png&&e.appState?.exportEmbedScene&&(a=await og({blob:a,metadata:ti(e.elements,e.appState,e.files||{},"local")})),n(a)},t,r)})},cl=async({elements:e,appState:t=er(),files:r={},exportPadding:o,renderEmbeddables:n,exportingFrame:i})=>{let{elements:a,appState:l}=Qn({elements:e,appState:t},null,null),s={...l,exportPadding:o};return il(a,s,r,{exportingFrame:i,renderEmbeddables:n})},TS=async e=>{if(e.type==="svg"){let t=await cl(e);await Sn(t.outerHTML)}else if(e.type==="png")await qd(Jd(e));else if(e.type==="json")await Zd(e.elements,e.files);else throw new Error("Invalid export type")}});var SS,IS,CE,kE,yg,AE,wg,vg=Z(()=>{"use strict";h();oe();Ht();mt();F();SS=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]],IS=e=>ee(e)||kt(e)?e.points:SS(e),CE=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},kE=e=>{let t=IS(e),{cx:r,cy:o}=CE(t),n=[r,o],i=t.map(d=>Fe([d[0],d[1]],n,e.angle)),{minX:a,minY:l,maxX:s,maxY:c}=CE(i);return[a+e.x,l+e.y,s+e.x,c+e.y]},yg=(e,t,r=!1)=>{let o=kE(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},AE=(e,t)=>{let r=kE(e);return(cs(r[0],t[0],t[2])||cs(t[0],r[0],r[2]))&&(cs(r[1],t[1],t[3])||cs(t[1],r[1],r[3]))},wg=({elements:e,bounds:t,type:r,errorMargin:o=0})=>{rs(t)&&(t=bo(t,J(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"?AE(a,n):r==="inside"?yg(a,n):yg(a,n,!0)){if(i.add(a.id),a.boundElements)for(let s of a.boundElements)i.add(s.id);G(a)&&a.containerId&&i.add(a.containerId),we(a)&&(a.startBinding&&i.add(a.startBinding.elementId),a.endBinding&&i.add(a.endBinding?.elementId))}}return e.filter(a=>i.has(a.id))}});function ME(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 _E(e,t){return e[0]*t[1]-t[0]*e[1]}function CS(e,t){return e[0]<=t[2]&&e[2]>=t[0]&&e[1]<=t[3]&&e[3]>=t[1]}function Qd(e,t){return[e[0]-t[0],e[1]-t[1]]}function LE(e,t){let r=Qd(e[1],e[0]),o=Qd(t,e[0]),n=_E(r,o);return Math.abs(n)<kS}function Tg(e,t){let r=Qd(e[1],e[0]),o=Qd(t,e[0]);return _E(r,o)<0}function PE(e,t){return LE(e,t[0])||LE(e,t[1])||(Tg(e,t[0])?!Tg(e,t[1]):Tg(e,t[1]))}function DE(e,t){return CS(ME(e),ME(t))&&PE(e,t)&&PE(t,e)}var kS,RE=Z(()=>{"use strict";h();kS=1e-6});var NE=Z(()=>{"use strict";h();ra();vg();RE()});function BE(e,t,r){let o=Wu(t,r),n=Wu(e,r);return o.some(a=>n.some(l=>DE(a,l)))}var em,OE,FE,HE,zo,Sg,zE,Mr,Hs,bg,dl,GE,Pt,UE,Gs,ml,Ig,tm,Go,rm,Ud,ea,Kd,al,Xt=Z(()=>{"use strict";h();me();Ht();lt();F();He();We();Ir();mt();NE();oe();em=(e,t,r)=>{let o=J(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&&B(l,{frameId:a??n.frameId},!1)}}};OE=(e,t,r)=>rm(pl(e,t,r,!1)).filter(o=>!X(o)&&!o.frameId||o.frameId===t.id),FE=(e,t,r,o)=>pl(e,t,o).some(n=>n.id===r.id),HE=(e,t,r)=>{let[o,n,i,a]=j(t,r),[l,s,c,d]=ye(e);return o<=l&&n<=s&&i>=c&&a>=d},zo=(e,t,r)=>HE([e],t,r)||BE(e,t,r)||FE([t],e,t,r),Sg=(e,t,r)=>{let[o,n,i,a]=j(t,r);return Oi([o,n],[e.x,e.y],[i,a])},zE=e=>{let t=new Map;for(let r of e){let o=X(r)?r.id:r.frameId;o&&!t.has(o)&&t.set(o,Mr(e,o))}return t},Mr=(e,t)=>{let r=[];for(let o of e.values())o.frameId===t&&r.push(o);return r},Hs=e=>e.filter(t=>X(t)),bg=e=>{let t=J(Hs(e));return e.filter(r=>t.has(r.id)||!r.frameId||!t.has(r.frameId))},dl=(e,t,r,o)=>{let n=Mr(e,t.id),i=new Set(n),a=new Set([...OE(e,t,o),...n.filter(p=>FE(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(!BE(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 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=xd(d,r);for(let[p,u]of Object.entries(m))if(u){let g=Ze(e,p);if(HE(g,t,o))for(let f of g)i.add(f)}return[...i].filter(p=>!(G(p)&&p.containerId))},GE=(e,t,r)=>rm(e,OE(e,t,r)),Pt=(e,t)=>e.frameId&&t.get(e.frameId)||null,UE=(e,t)=>{let r=new Set,o=J(e);e=rm(e);for(let a of e)X(a)&&a.id!==t.id&&r.add(a.id);let n=new Set,i=[];for(let a of e)if(!(X(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=Ze(e,l);if(s.some(c=>zo(c,t,o)))for(let c of s)i.push(c)}}else zo(a,t,o)&&i.push(a);return i},Gs=(e,t,r)=>{let o=J(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)X(s)&&s.id!==r.id&&l.add(s.id);for(let s of rm(e,t)){if(X(s)||s.frameId&&l.has(s.frameId))continue;n.has(s.id)||a.push(s);let c=ae(s,o);c&&!i.has(c.id)&&!n.has(c.id)&&a.push(c)}for(let s of a)B(s,{frameId:r.id},!1);return e},ml=(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=ae(n,t);a&&(r.set(a.id,a),i.push(a)),o.set(n.frameId,i)}for(let[,n]of r)B(n,{frameId:null},!1)},Ig=(e,t)=>{let r=Mr(e,t.id);return ml(r,J(e)),e},tm=(e,t,r,o)=>Gs(Ig(e,r),t,r).slice(),Go=(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=>Ze(e,s)).forEach(s=>n.add(s));let i=new Set,a=J(e);return n.forEach(l=>{l.frameId&&!X(l)&&!ea(l,a,t)&&i.add(l)}),i.size>0&&ml(i,a),e},rm=(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)Ze(e,a).some(l=>X(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},Ud=(e,t,r)=>{let o=G(e)&&st(e,t)||e;return r.selectedElementIds[o.id]&&r.selectedElementsAreBeingDragged?r.frameToHighlight:Pt(o,t)},ea=(e,t,r)=>{let o=Ud(e,t,r),n=G(e)&&st(e,t)||e;if(o){if(!r.selectedElementIds[e.id]||!r.selectedElementsAreBeingDragged)return!0;if(n.groupIds.length===0)return zo(n,o,t);let i=new Set(n.groupIds.flatMap(a=>Ze(t,a)));if(r.editingGroupId&&r.selectedElementsAreBeingDragged){let a=new Set(pe(t,r));if(r.frameToHighlight!==null)return!0;a.forEach(s=>{i.delete(s)})}for(let a of i)if(X(a))return!1;for(let a of i)if(zo(a,o,t))return!0}return!1},Kd=(e,t)=>e.name===null?Gn(e)?`Frame ${t}`:`AI Frame $${t}`:e.name,al=(e,t)=>wg({elements:e,bounds:t,type:"overlap"}).filter(r=>!r.frameId||r.frameId===t.id)});import KE from"roughjs/bin/rough";import{getStroke as AS}from"perfect-freehand";function S1(e){let t=Ad(e),r=new Path2D(t);return JE.set(e,r),r}function DS(e){return JE.get(e)}function Ad(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 NS(AS(t,r))}function YE(e,t){return[(e[0]+t[0])/2,(e[1]+t[1])/2]}function NS(e){if(!e.length)return"";let t=e.length-1;return e.reduce((r,o,n,i)=>(n===t?r.push(o,YE(o,i[0]),"L",i[0],"Z"):r.push(o,YE(o,i[n+1])),r),["M",e[0],"Q"]).join(" ").replace(RS,"$1")}var Qu,MS,$E,XE,im,Cg,LS,PS,cE,ZE,jE,_S,om,nm,WE,VE,qE,Os,JE,RS,ln=Z(()=>{"use strict";h();oe();mt();F();Ht();Sr();W();lt();$t();Xt();uo();Qu="invert(100%) hue-rotate(180deg) saturate(1.25)",MS=er(),$E=(e,t)=>Qt(e)&&!t.imageCache.has(e.fileId),XE=(e,t,r)=>r.theme==="dark"&&Qt(e)&&!$E(e,t)&&t.imageCache.get(e.fileId)?.mimeType!==$.svg,im=e=>e.type==="freedraw"?e.strokeWidth*12:20,Cg=(e,t,r)=>{let o=(t?.opacity??100)*e.opacity/1e4;return(r.has(e.id)||t&&r.has(t.id))&&(o*=$b/100),o},LS=(e,t,r)=>{let i=im(e),[a,l,s,c]=j(e,t),d=ee(e)||kt(e)?Ct(a,s):e.width,m=ee(e)||kt(e)?Ct(l,c):e.height,p=d*window.devicePixelRatio+i*2,u=m*window.devicePixelRatio+i*2,g=r.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}},PS=(e,t,r,o,n)=>{let i=document.createElement("canvas"),a=i.getContext("2d"),l=im(e),{width:s,height:c,scale:d}=LS(e,t,r);i.width=s,i.height=c;let m=0,p=0;if(ee(e)||kt(e)){let[g,f]=j(e,t);m=e.x>g?Ct(e.x,g)*window.devicePixelRatio*d:0,p=e.y>f?Ct(e.y,f)*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=KE.canvas(i);return XE(e,o,n)&&(a.filter=Qu),om(e,u,a,o,n),a.restore(),{element:e,canvas:i,theme:n.theme,scale:d,zoomValue:r.value,canvasOffsetX:m,canvasOffsetY:p,boundTextElementVersion:ae(e,t)?.version||null,containingFrameOpacity:Pt(e,t)?.opacity||100}},cE=14,ZE=document.createElement("img");ZE.src=`data:${$.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>')}`;jE=document.createElement("img");jE.src=`data:${$.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>')}`;_S=(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"?jE:ZE,e.width/2-n/2,e.height/2-n/2,n,n)},om=(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(Te.get(e));break}case"arrow":case"line":{r.lineJoin="round",r.lineCap="round",Te.get(e).forEach(i=>{t.draw(i)});break}case"freedraw":{r.save(),r.fillStyle=e.strokeColor;let i=DS(e),a=Te.get(e);a&&t.draw(a),r.fillStyle=e.strokeColor,r.fill(i),r.restore();break}case"image":{let i=Qt(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,mo(Math.min(e.width,e.height),e)),r.clip()),r.drawImage(i,0,0,e.width,e.height)):_S(e,r,n.zoom.value);break}default:if(G(e)){let i=Wc(e.text),a=i&&!r.canvas.isConnected;a&&document.body.appendChild(r.canvas),r.canvas.setAttribute("dir",i?"rtl":"ltr"),r.save(),r.font=Be(e),r.fillStyle=e.strokeColor,r.textAlign=e.textAlign;let l=e.text.replace(/\r\n?/g,`
|
|
54
|
+
`).split(`
|
|
55
|
+
`),s=e.textAlign==="center"?e.width/2:e.textAlign==="right"?e.width:0,c=jn(e.fontSize,e.lineHeight),d=md(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}`)}},nm=new WeakMap,WE=(e,t,r,o)=>{let n=r?o.zoom:MS.zoom,i=nm.get(e),a=i&&i.zoomValue!==n.value&&!o?.shouldCacheIgnoreZoom,l=ae(e,t)?.version||null,s=Pt(e,t)?.opacity||100;if(!i||a||i.theme!==o.theme||i.boundTextElementVersion!==l||i.containingFrameOpacity!==s){let c=PS(e,t,n,r,o);return nm.set(e,c),c}return i},VE=(e,t,r,o,n)=>{let i=e.element,a=im(i),l=e.scale,[s,c,d,m]=j(i,n);kt(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 g=ae(i,n);if(we(i)&&g){let f=document.createElement("canvas"),E=f.getContext("2d"),y=Math.max(Ct(s,d),Ct(c,m));f.width=y*window.devicePixelRatio*l+a*e.scale*10,f.height=y*window.devicePixelRatio*l+a*e.scale*10;let T=(f.width-e.canvas.width)/2,w=(f.height-e.canvas.height)/2;E.translate(f.width/2,f.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[,,,,I,k]=j(g,n);E.rotate(-i.angle);let C=f.width/2-(I-s)*window.devicePixelRatio*l-T-a*l,D=f.height/2-(k-c)*window.devicePixelRatio*l-w-a*l;E.translate(-C,-D),E.clearRect(-(g.width/2+pt)*window.devicePixelRatio*l,-(g.height/2+pt)*window.devicePixelRatio*l,(g.width+pt*2)*window.devicePixelRatio*l,(g.height+pt*2)*window.devicePixelRatio*l),t.translate(p,u),t.drawImage(f,-(d-s)/2*window.devicePixelRatio-T/l-a,-(m-c)/2*window.devicePixelRatio-w/l-a,f.width/l,f.height/l)}else if(t.translate(p,u),t.rotate(i.angle),"scale"in e.element&&!$E(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),v.VITE_APP_DEBUG_ENABLE_TEXT_CONTAINER_BOUNDING_BOX==="true"&&cr(i)){let f=ae(i,n),E=Hu(i);t.strokeStyle="#c92a2a",t.lineWidth=3,t.strokeRect((E.x+o.scrollX)*window.devicePixelRatio,(E.y+o.scrollY)*window.devicePixelRatio,mr(i,f)*window.devicePixelRatio,$i(i,f)*window.devicePixelRatio)}t.restore()},qE=(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()},Os=(e,t,r,o,n,i,a)=>{switch(n.globalAlpha=Cg(e,Pt(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=Ue.strokeWidth/a.zoom.value,n.strokeStyle=Ue.strokeColor,Bi(e)&&(n.strokeStyle=a.theme==="light"?"#7affd7":"#1d8264"),Ue.radius&&n.roundRect?(n.beginPath(),n.roundRect(0,0,e.width,e.height,Ue.radius/a.zoom.value),n.stroke(),n.closePath()):n.strokeRect(0,0,e.width,e.height),n.restore());break}case"freedraw":{if(Te.generateElementShape(e,null),i.isExporting){let[l,s,c,d]=j(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),om(e,o,n,i,a),n.restore()}else{let l=WE(e,t,i,a);VE(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(Te.generateElementShape(e,i),i.isExporting){let[l,s,c,d]=j(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(G(e)){let E=st(e,t);if(we(E)){let y=V.getBoundTextElementPosition(E,e,t);u=(c-l)/2-(y.x-l),g=(d-s)/2-(y.y-s)}}n.save(),n.translate(m,p),XE(e,i,a)&&(n.filter="none");let f=ae(e,t);if(we(e)&&f){let E=document.createElement("canvas"),y=E.getContext("2d"),T=Math.max(Ct(l,c),Ct(s,d)),w=im(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 I=KE.canvas(E);y.translate(-u,-g),om(e,I,y,i,a),y.translate(u,g),y.rotate(-e.angle);let[,,,,k,C]=j(f,t),D=(l+c)/2-k,R=(s+d)/2-C;y.translate(-D,-R),y.clearRect(-f.width/2,-f.height/2,f.width,f.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),om(e,o,n,i,a);n.restore()}else{let l=WE(e,t,i,a),s=n.imageSmoothingEnabled;!a?.shouldCacheIgnoreZoom&&(!e.angle||E1(e.angle))&&(n.imageSmoothingEnabled=!1),VE(l,n,i,a,r),n.imageSmoothingEnabled=s}break}default:throw new Error(`Unimplemented type ${e.type}`)}n.globalAlpha=1},JE=new WeakMap([]);RS=/(\s?[A-Z]?,?-?[0-9]*\.[0-9]{0,2})(([0-9]|e|-)*)/g});import{RoughGenerator as BS}from"roughjs/bin/generator";var Te,uo=Z(()=>{"use strict";h();ln();bu();Vt();Te=class e{static rg=new BS;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;nm.delete(t);let n=T1(t,e.rg,r||{isExporting:!1,canvasBackgroundColor:ie.white,embedsValidationStatus:null});return e.cache.set(t,n),n}}});var B,te,Eo,He=Z(()=>{"use strict";h();nn();ns();co();F();uo();B=(e,t,r=!0)=>{let o=!1,{points:n,fileId:i}=t;typeof n<"u"&&(t={...Zc(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")&&Te.delete(e),e.version++,e.versionNonce=Hr(),e.updated=on(),r&&rt.getScene(e)?.informMutation()),e},te=(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:on(),version:e.version+1,versionNonce:Hr()}:e},Eo=(e,t)=>(e.version=(t??e.version)+1,e.versionNonce=Hr(),e.updated=on(),e)});var Wr,oa,am,Ka,Ps,na=Z(()=>{"use strict";h();He();oe();W();mt();F();Wr=e=>ee(e)||kt(e)?e.points.length<2:e.width===0&&e.height===0,oa=(e,t,r,o,n)=>{let[i,a,l,s]=bo(e,n),c=Oe({clientX:o.offsetLeft,clientY:o.offsetTop},o),d=Oe({clientX:o.offsetLeft+t,clientY:o.offsetTop+r},o);return c.x<=l&&c.y<=s&&d.x>=i&&d.y>=a},am=(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)/ko)*ko;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}},Ka=(e,t,r,o)=>{let n=r-e,i=o-t,a=Math.round(Math.atan(i/n)/ko)*ko;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),g=(c*d-p*l)/(l*m-d*s);n=u-e,i=g-t}return{width:n,height:i}},Ps=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 Ag,QE,lm,sm,kg,OS,cm,e0=Z(()=>{"use strict";h();Oa();Ag=(e,t,r)=>t>=e[0]&&t<=e[0]+e[2]&&r>=e[1]&&r<=e[1]+e[3],QE=(e,t,r,o,n,i,a)=>{if(!r.selectedElementIds[e.id])return!1;let{rotation:l,...s}=hs(e,i,t,a);if(l&&Ag(l,o,n))return"rotation";let c=Object.keys(s).filter(d=>{let m=s[d];return m?Ag(m,o,n):!1});return c.length>0?c[0]:!1},lm=(e,t,r,o,n,i,a)=>e.reduce((l,s)=>{if(l)return l;let c=QE(s,a,t,r,o,n,i);return c?{element:s,transformHandleType:c}:null},null),sm=([e,t,r,o],n,i,a,l)=>{let s=Na([e,t,r,o,(e+r)/2,(t+o)/2],0,a,l,gs);return Object.keys(s).find(d=>{let m=s[d];return m&&Ag(m,n,i)})||!1},kg=["ns","nesw","ew","nwse"],OS=(e,t)=>{let r=kg.indexOf(e);if(r>=0){let o=Math.round(t/(Math.PI/4));e=kg[(r+o)%kg.length]}return e},cm=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=OS(n,t.angle)),n?`${n}-resize`:""}});var dm,Mg,FS,HS,Lg,zS,GS,US,Pg,WS,_g,Dg,Rg=Z(()=>{"use strict";h();W();ns();Ht();mt();oe();He();F();ho();nn();lt();$t();dm=e=>e<0?e+2*Math.PI:e>=2*Math.PI?e-2*Math.PI:e,Mg=(e,t,r,o,n,i,a,l,s,c,d)=>{if(r.length===1){let[m]=r;return t==="rotation"?(FS(m,o,l,s,n),go(m,o)):G(m)&&(t==="nw"||t==="ne"||t==="sw"||t==="se")?(GS(m,o,t,i,l,s),go(m,o)):t&&US(e,a,m,o,t,i,l,s),!0}else if(r.length>1){if(t==="rotation")return WS(e,r,o,l,s,n,c,d),!0;if(t==="nw"||t==="ne"||t==="sw"||t==="se")return Pg(e,r,o,t,i,l,s),!0}return!1},FS=(e,t,r,o,n)=>{let[i,a,l,s]=j(e,t),c=(i+l)/2,d=(a+s)/2,m;X(e)?m=0:(m=5*Math.PI/2+Math.atan2(o-d,r-c),n&&(m+=ko/2,m-=m%ko),m=dm(m));let p=pn(e);if(B(e,{angle:m}),p){let u=rt.getScene(e)?.getElement(p);u&&!we(e)&&B(u,{angle:m})}},HS=(e,t,r,o)=>ee(e)||kt(e)?{points:Wn(0,t,Wn(1,r,e.points,o),o)}:{},Lg=(e,t,r)=>{let o=e.width;if(Me(e)){let a=st(e,t);a&&(o=mr(a,e))}let i=e.fontSize*(r/o);return i<Pc?null:{size:i}},zS=(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)}),GS=(e,t,r,o,n,i)=>{let[a,l,s,c]=j(e,t),d=(a+s)/2,m=(l+c)/2,[p,u]=ge(n,i,d,m,-e.angle),g;switch(r){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 f=e.width*g,E=e.height*g,y=Lg(e,t,f);if(y===null)return;let[T,w,I,k]=Xi(e,f,E,!1),C=(a-T)/2,D=(l-w)/2,R=(s-I)/2,z=(c-k)/2,[L,M]=jc(zS(r,o),e.x,e.y,e.angle,C,D,R,z);B(e,{fontSize:y.size,width:f,height:E,x:L,y:M})}},US=(e,t,r,o,n,i,a,l)=>{let s=e.get(r.id),[c,d,m,p]=Xi(s,s.width,s.height,!0),u=[c,d],g=[m,p],f=as(u,g),E=Fe([a,l],f,-s.angle),[y,T,w,I]=Xi(r,r.width,r.height,!0),k=w-y,C=I-T,D=g[0]-u[0],R=g[1]-u[1],z=D/k,L=R/C,M={},A=ae(r,o);n.includes("e")&&(z=(E[0]-u[0])/k),n.includes("s")&&(L=(E[1]-u[1])/C),n.includes("w")&&(z=(g[0]-E[0])/k),n.includes("n")&&(L=(g[1]-E[1])/C);let H=s.width,q=s.height,Y=r.width*z,Q=r.height*L;if(i&&(Y=2*Y-H,Q=2*Q-q),t){let lr=Math.abs(Y)/H,xa=Math.abs(Q)/q;if(n.length===1&&(Q*=lr,Y*=xa),n.length===2){let Ai=Math.max(lr,xa);Y=H*Ai*Math.sign(Y),Q=q*Ai*Math.sign(Q)}}if(A){let lr=e.get(A.id);if(lr&&(M={fontSize:lr.fontSize}),t){let xa={...r,width:Y,height:Q},Ai=Lg(A,o,mr(xa,A));if(Ai===null)return;M={fontSize:Ai.size}}else{let xa=ud(Be(A),A.lineHeight),Ai=pd(A.fontSize,A.lineHeight);Y=Math.max(Y,xa),Q=Math.max(Q,Ai)}}let[fe,se,ce,Ye]=Xi(s,Y,Q,!0),Nt=ce-fe,vt=Ye-se,je=[...u];if(["n","w","nw"].includes(n)&&(je=[g[0]-Math.abs(Nt),g[1]-Math.abs(vt)]),n==="ne"){let lr=[u[0],g[1]];je=[lr[0],lr[1]-Math.abs(vt)]}if(n==="sw"){let lr=[g[0],u[1]];je=[lr[0]-Math.abs(Nt),lr[1]]}t&&(["s","n"].includes(n)&&(je[0]=f[0]-Nt/2),["e","w"].includes(n)&&(je[1]=f[1]-vt/2));let oo=Y<0,Ii=Q<0;oo&&(n.includes("e")&&(je[0]-=Math.abs(Nt)),n.includes("w")&&(je[0]+=Math.abs(Nt))),Ii&&(n.includes("s")&&(je[1]-=Math.abs(vt)),n.includes("n")&&(je[1]+=Math.abs(vt))),i&&(je[0]=f[0]-Math.abs(Nt)/2,je[1]=f[1]-Math.abs(vt)/2);let ar=s.angle,Dn=Fe(je,f,ar),Ci=[je[0]+Math.abs(Nt)/2,je[1]+Math.abs(vt)/2],ki=Fe(Ci,f,ar);je=Fe(Dn,ki,-ar);let Nr=[...je],Jo=s.x-fe,Tt=s.y-se;Nr[0]+=Jo,Nr[1]+=Tt;let JT=Nr[0],QT=Nr[1],gb,hb;(ee(r)||kt(r))&&(gb=Wn(1,Q,s.points,!0),hb=Wn(0,Y,gb,!0));let Rn={width:Math.abs(Y),height:Math.abs(Q),x:JT,y:QT,points:hb};if("scale"in r&&"scale"in s&&B(r,{scale:[(Math.sign(ce-s.x)||s.scale[0])*s.scale[0],(Math.sign(Ye-s.y)||s.scale[1])*s.scale[1]]}),we(r)&&A&&t){let lr=Rn.width/r.width*A.fontSize;if(lr<Pc)return;M.fontSize=lr}Rn.width!==0&&Rn.height!==0&&Number.isFinite(Rn.x)&&Number.isFinite(Rn.y)&&(B(r,Rn),go(r,o,{newSize:{width:Rn.width,height:Rn.height}}),A&&M!=null&&B(A,{fontSize:M.fontSize}),Vi(r,o,n,t))},Pg=(e,t,r,o,n,i,a)=>{let l=t.reduce((M,A)=>{let H=e.get(A.id);return H&&M.push({orig:H,latest:A}),M},[]),s=l.reduce((M,{orig:A})=>{if(!ee(A))return M;let H=pn(A);if(!H)return M;let q=e.get(H)??null;if(!Me(q))return M;let Y=V.getBoundTextElementPosition(A,q,r);return[...M,{...q,...Y}]},[]),{minX:c,minY:d,maxX:m,maxY:p,midX:u,midY:g}=pr(l.map(({orig:M})=>M).concat(s)),f=o,E={ne:[c,p],se:[c,d],sw:[m,d],nw:[m,p]},[y,T]=n?[u,g]:E[f],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 I={ne:[i>=y,a<=T],se:[i>=y,a>=T],sw:[i<=y,a>=T],nw:[i<=y,a<=T]},[k,C]=I[f].map(M=>M?1:-1),D=k<0,R=C<0,z=[];for(let{orig:M,latest:A}of l){if(G(M)&&Me(M))continue;let H=M.width*w,q=M.height*w,Y=dm(M.angle*k*C),Q=ee(M)||kt(M),fe=M.x-y,se=M.y-T,ce=D&&!Q?H:0,Ye=R&&!Q?q:0,Nt=y+k*(fe*w+ce),vt=T+C*(se*w+Ye),je=HS(M,H*k,q*C,!1),oo={x:Nt,y:vt,width:H,height:q,angle:Y,...je};if(Or(M)&&l.length===1&&(oo.scale=[M.scale[0]*k,M.scale[1]*C]),ee(M)&&(D||R)){let ar=Ya(M,M.points),Dn=Ya({...M,x:Nt,y:vt},je.points),Ci=[M.x,M.y],ki=[Nt,vt],Nr=Jo=>{let Tt=Jo==="x"?0:1;return(Dn[Tt+2]-ki[Tt]-(Ci[Tt]-ar[Tt])*w+(ar[Tt+2]-Ci[Tt])*w-(ki[Tt]-Dn[Tt]))/2};D&&(oo.x-=Nr("x")),R&&(oo.y-=Nr("y"))}if(G(M)){let ar=Lg(M,r,H);if(!ar)return;oo.fontSize=ar.size}let Ii=e.get(pn(M)??"");if(Ii){let ar=Ii.fontSize*w;if(ar<Pc)return;oo.boundTextFontSize=ar}z.push({element:A,update:oo})}let L=z.map(({element:M})=>M);for(let{element:M,update:{boundTextFontSize:A,...H}}of z){let{width:q,height:Y,angle:Q}=H;B(M,H,!1),go(M,r,{simultaneouslyUpdated:L,newSize:{width:q,height:Y}});let fe=ae(M,r);fe&&A&&(B(fe,{fontSize:A,angle:ee(M)?void 0:Q},!1),Vi(M,r,o,!0))}rt.getScene(z[0].element)?.informMutation()},WS=(e,t,r,o,n,i,a,l)=>{let s=5*Math.PI/2+Math.atan2(n-l,o-a);i&&(s+=ko/2,s-=s%ko),t.filter(c=>!X(c)).forEach(c=>{let[d,m,p,u]=j(c,r),g=(d+p)/2,f=(m+u)/2,E=e.get(c.id)?.angle??c.angle,[y,T]=ge(g,f,a,l,s+E-c.angle);B(c,{x:c.x+(y-g),y:c.y+(T-f),angle:dm(s+E)},!1),go(c,r,{simultaneouslyUpdated:t});let w=ae(c,r);w&&!we(c)&&B(w,{x:w.x+(y-g),y:w.y+(T-f),angle:dm(s+E)},!1)}),rt.getScene(t[0])?.informMutation()},_g=(e,t,r,o,n)=>{let[i,a,l,s]=t.length===1?j(t[0],r):ye(t),c=(i+l)/2,d=(a+s)/2,m=t.length===1?t[0].angle:0;switch([o,n]=ge(o,n,c,d,-m),e){case"n":return ge(o-(i+l)/2,n-a,0,0,m);case"s":return ge(o-(i+l)/2,n-s,0,0,m);case"w":return ge(o-i,n-(a+s)/2,0,0,m);case"e":return ge(o-l,n-(a+s)/2,0,0,m);case"nw":return ge(o-i,n-a,0,0,m);case"ne":return ge(o-l,n-a,0,0,m);case"sw":return ge(o-i,n-s,0,0,m);case"se":return ge(o-l,n-s,0,0,m);default:return[0,0]}},Dg=(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 Ng,VS,t0,Bg,mm,r0=Z(()=>{"use strict";h();ho();mt();He();na();lt();Ht();oe();Ng=(e,t,r,o,n,i,a)=>{let l=new Set(t),s=t.filter(m=>X(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=ye(Array.from(l).map(m=>e.originalElements.get(m.id)??m)),d=VS(c,r,i,a);l.forEach(m=>{if(t0(e,m,d),!we(m)){let p=ae(m,n.getNonDeletedElementsMap());p&&t0(e,p,d)}go(m,n.getElementsMapIncludingDeleted(),{simultaneouslyUpdated:Array.from(l)})})},VS=(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]=yt(n+t.x,i+t.y,o);r.x===0&&(a=s),r.y===0&&(l=c)}return{x:a-n,y:l-i}},t0=(e,t,r)=>{let o=e.originalElements.get(t.id)??t,n=o.x+r.x,i=o.y+r.y;B(t,{x:n,y:i})},Bg=(e,t,r)=>{let[o,n]=ye(e);return[t-o,r-n]},mm=(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}=am(t,l,n<r?-a:a):{width:a,height:l}=am(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&&B(e,{x:p+(m?.x??0),y:u+(m?.y??0),width:a,height:l})}});var ia,o0=Z(()=>{"use strict";h();We();ia=(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")||pe(t,e).length))});var YS,Og,Fg,n0,be,os,i0,lE,Dd,me=Z(()=>{"use strict";h();na();oe();fn();mt();Oa();Xn();e0();Rg();r0();oe();lt();na();o0();YS=e=>e.reduce((t,r)=>t+r.version,0),Og=e=>{let t=5381;for(let r=0;r<e.length;r++)t=(t<<5)+t+e[r].versionNonce;return t>>>0},Fg=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},n0=e=>e.filter(t=>!t.isDeleted&&!Wr(t)),be=e=>e.filter(t=>!t.isDeleted),os=e=>!e.isDeleted,i0=e=>be(e).map(t=>ts(t.type)?{...t,lastCommittedPoint:null}:t),lE=e=>i0(e),Dd=e=>i0(e)});var aa,pl,Hg,Re,zg,pe,la,Ce,Un=Z(()=>{"use strict";h();me();oe();Xt();F();na();aa=e=>{let t=new Set;return e.forEach(r=>{X(r)&&t.add(r.id)}),e.filter(r=>!(r.frameId&&t.has(r.frameId)))},pl=(e,t,r,o=!0)=>{let[n,i,a,l]=j(t,r),s=e.filter(c=>{let[d,m,p,u]=bo(c,r),g=Pt(c,r);if(g){let[f,E,y,T]=bo(g,r);d=Math.max(f,d),m=Math.max(E,m),p=Math.min(y,p),u=Math.min(T,u)}return c.locked===!1&&c.type!=="selection"&&!Me(c)&&n<=d&&i<=m&&a>=p&&l>=u});return s=o?aa(s):s,s=s.filter(c=>{let d=Pt(c,r);return d?zo(c,d,r):!0}),s},Hg=(e,t,r,o)=>{let n=new Set(t.map(i=>i.id));return e.filter(i=>{let a=oa(i,r.width,r.height,r,o);return!n.has(i.id)&&a})},Re=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}(),zg=(e,t,r)=>{let o=Array.from(new Set(pe(e,t).map(n=>r(n))));return o.length===1?o[0]:null},pe=(e,t,r)=>{let o=[];for(let n of e.values()){if(t.selectedElementIds[n.id]){o.push(n);continue}if(r?.includeBoundTextElement&&Me(n)&&t.selectedElementIds[n?.containerId]){o.push(n);continue}}if(r?.includeElementsInFrames){let n=[];return o.forEach(i=>{X(i)&&Mr(e,i.id).forEach(a=>n.push(a)),n.push(i)}),n}return o},la=(e,t)=>t.editingElement?[t.editingElement]:pe(e,t,{includeBoundTextElement:!0}),Ce=(e,t)=>bt(t.selectedElementIds,e)?t.selectedElementIds:e});var KS,Gg,Ho,Ug=Z(()=>{"use strict";h();me();F();KS=(e,t)=>{let[r,o,n,i]=t,{x:a,y:l}=Mt({sceneX:r,sceneY:o},e),{x:s,y:c}=Mt({sceneX:n,sceneY:i},e);return s-a>e.width||c-l>e.height},Gg=({scenePoint:e,viewportDimensions:t,zoom:r})=>({scrollX:t.width/2/r.value-e.x,scrollY:t.height/2/r.value-e.y}),Ho=(e,t)=>{if(e=n0(e),!e.length)return{scrollX:0,scrollY:0};let[r,o,n,i]=ye(e);KS(t,[r,o,n,i])&&([r,o,n,i]=Yu(e,Oe({clientX:t.scrollX,clientY:t.scrollY},t)));let a=(r+n)/2,l=(o+i)/2;return Gg({scenePoint:{x:a,y:l},viewportDimensions:{width:t.width,height:t.height},zoom:t.zoom})}});var Uo,In,pm=Z(()=>{"use strict";h();W();Uo=e=>Math.max(Dc,Math.min(e,30)),In=({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 We=Z(()=>{"use strict";h();Un();Ug();ms();pm()});h();import g8,{useEffect as h8}from"react";h();import{useEffect as x5,useState as E5}from"react";h();h();import Eb from"./en-EY7E2L5O.json";import n5 from"./percentages-UCQDHIQF.json";h();import{unstable_createStore as r5,useAtom as S8}from"jotai";import{useLayoutEffect as C8}from"react";var Pe=Symbol(),sr=r5();import{atom as i5,useAtomValue as a5}from"jotai";var o5=fb({"./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-EY7E2L5O.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")});var l5=85,Co={code:"en",label:"English"},ya=[Co,...[{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=>n5[e.code]>=l5).sort((e,t)=>e.label>t.label?1:-1)],Sc="__test__";v.DEV&&ya.unshift({code:Sc,label:"test language"},{code:`${Sc}.rtl`,label:"\u202Atest language (rtl)\u202C",rtl:!0});var Ea=Co,Tc={},Ic=async e=>{if(Ea=e,document.documentElement.dir=Ea.rtl?"rtl":"ltr",document.documentElement.lang=Ea.code,e.code.startsWith(Sc))Tc={};else try{Tc=await o5(`./locales/${Ea.code}.json`)}catch(t){console.error(`Failed to load language ${e.code}:`,t.message),Tc=Eb}sr.set(yb,e.code)},Qo=()=>Ea,xb=(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(Ea.code.startsWith(Sc))return`\u202A[[${t?`${e}(${JSON.stringify(t).slice(1,-1)})`:e}]]\u202C`;let o=e.split("."),n=xb(Tc,o)||xb(Eb,o)||r;if(n===void 0){let i=`Can't find translation for ${e}`;if(v.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},yb=i5(Co.code),St=()=>{let e=a5(yb,Pe);return{t:b,langCode:e}};import{useState as g5,useEffect as h5}from"react";h();import s5 from"react";import{jsx as Zp}from"react/jsx-runtime";var c5=({size:e="1em",circleWidth:t=8,synchronized:r=!1})=>{let n=-(s5.useRef(Date.now()).current%1600);return Zp("div",{className:"Spinner",children:Zp("svg",{viewBox:"0 0 100 100",style:{width:e,height:e,"--spinner-delay":r?`${n}ms`:0},children:Zp("circle",{cx:"50",cy:"50",r:50-t/2,strokeWidth:t,fill:"none",strokeMiterlimit:"10"})})})},Bt=c5;W();import f5 from"clsx";import{jsx as ou,jsxs as b5}from"react/jsx-runtime";var Gc=({delay:e,theme:t})=>{let[r,o]=g5(!!e);return h5(()=>{if(!e)return;let n=setTimeout(()=>{o(!1)},e);return()=>clearTimeout(n)},[e]),r?null:b5("div",{className:f5("LoadingMessage",{"LoadingMessage--dark":t===qe.DARK}),children:[ou("div",{children:ou(Bt,{})}),ou("div",{className:"LoadingMessage-text",children:b("labels.loadingScene")})]})};import{jsx as y5}from"react/jsx-runtime";var Zb=e=>{let[t,r]=E5(!0);return x5(()=>{let o=async()=>{await Ic(n),r(!1)},n=ya.find(i=>i.code===e.langCode)||Co;o()},[e.langCode]),t?y5(Gc,{theme:e.theme}):e.children};h();import qo,{useContext as Ti}from"react";import{flushSync as $f}from"react-dom";import qL from"roughjs/bin/rough";import _T from"clsx";import{nanoid as JL}from"nanoid";h();h();We();de();h();import Wg,{useEffect as $S,useRef as a0,useState as XS}from"react";import l0 from"clsx";Ji();F();import{jsx as Us,jsxs as Ws}from"react/jsx-runtime";var ne=Wg.forwardRef((e,t)=>{let{id:r}=_t(),o=Wg.useRef(null);Wg.useImperativeHandle(t,()=>o.current);let n=`ToolIcon_size_${e.size}`,[i,a]=XS(!1),l=a0(!0),s=async d=>{let m="onClick"in e&&e.onClick?.(d);if(Lo(m))try{a(!0),await m}catch(p){if(p instanceof Oo)console.warn(p);else throw p}finally{l.current&&a(!1)}};$S(()=>(l.current=!0,()=>{l.current=!1}),[]);let c=a0(null);if(e.type==="button"||e.type==="icon"||e.type==="submit"){let d=e.type==="icon"?"button":e.type;return Ws("button",{className:l0("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,children:[(e.icon||e.label)&&Ws("div",{className:"ToolIcon__icon","aria-hidden":"true",children:[e.icon||e.label,e.keyBindingLabel&&Us("span",{className:"ToolIcon__keybinding",children:e.keyBindingLabel}),e.isLoading&&Us(Bt,{})]}),e.showAriaLabel&&Ws("div",{className:"ToolIcon__label",children:[e["aria-label"]," ",i&&Us(Bt,{})]}),e.children]})}return Ws("label",{className:l0("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:[Us("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}),Ws("div",{className:"ToolIcon__icon",children:[e.icon,e.keyBindingLabel&&Us("span",{className:"ToolIcon__keybinding",children:e.keyBindingLabel})]})]})});ne.defaultProps={visible:!0,className:"",size:"medium"};ne.displayName="ToolButton";ze();me();He();Ir();$t();ho();oe();F();h();W();import hr from"react";import ZS from"open-color";import jS from"clsx";import{Fragment as Ie,jsx as x,jsxs as O}from"react/jsx-runtime";var vo=e=>"var(--icon-fill-color)",s0=e=>e===qe.LIGHT?ZS.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 x("svg",{"aria-hidden":"true",focusable:"false",role:"img",viewBox:`0 0 ${r} ${o}`,className:jS({"rtl-mirror":n}),style:i,...a,children:typeof e=="string"?x("path",{fill:"currentColor",d:e}):e})},he={width:24,height:24,fill:"none",strokeWidth:2,stroke:"currentColor",strokeLinecap:"round",strokeLinejoin:"round"},le={width:20,height:20,fill:"none",stroke:"currentColor",strokeLinecap:"round",strokeLinejoin:"round"},KO=P(O("g",{strokeWidth:"1.5",children:[x("path",{stroke:"none",d:"M0 0h24v24H0z",fill:"none"}),x("rect",{x:3,y:8,width:18,height:4,rx:1}),x("line",{x1:12,y1:8,x2:12,y2:21}),x("path",{d:"M19 12v7a2 2 0 0 1 -2 2h-10a2 2 0 0 1 -2 -2v-7"}),x("path",{d:"M7.5 8a2.5 2.5 0 0 1 0 -5a4.8 8 0 0 1 4.5 5a4.8 8 0 0 1 4.5 -5a2.5 2.5 0 0 1 0 5"})]}),he),c0=P(O("g",{strokeWidth:"1.5",children:[x("path",{stroke:"none",d:"M0 0h24v24H0z",fill:"none"}),x("path",{d:"M3 19a9 9 0 0 1 9 0a9 9 0 0 1 9 0"}),x("path",{d:"M3 6a9 9 0 0 1 9 0a9 9 0 0 1 9 0"}),x("line",{x1:"3",y1:"6",x2:"3",y2:"19"}),x("line",{x1:"12",y1:"6",x2:"12",y2:"19"}),x("line",{x1:"21",y1:"6",x2:"21",y2:"19"})]}),he),d0=P(O("svg",{strokeWidth:"1.5",children:[x("path",{stroke:"none",d:"M0 0h24v24H0z",fill:"none"}),x("line",{x1:"12",y1:"5",x2:"12",y2:"19"}),x("line",{x1:"5",y1:"12",x2:"19",y2:"12"})]}),he),m0=P(O("g",{strokeWidth:"1.5",children:[x("path",{stroke:"none",d:"M0 0h24v24H0z",fill:"none"}),x("circle",{cx:"12",cy:"12",r:"1"}),x("circle",{cx:"12",cy:"19",r:"1"}),x("circle",{cx:"12",cy:"5",r:"1"})]}),he),p0=P(O("svg",{strokeWidth:"1.5",children:[x("path",{stroke:"none",d:"M0 0h24v24H0z",fill:"none"}),x("path",{d:"M9 4v6l-2 4v2h10v-2l-2 -4v-6"}),x("line",{x1:"12",y1:"16",x2:"12",y2:"21"}),x("line",{x1:"8",y1:"4",x2:"16",y2:"4"})]}),he),u0=P(O("g",{children:[x("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"}),x("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"}),x("mask",{id:"UnlockedIcon",style:{maskType:"alpha"},maskUnits:"userSpaceOnUse",x:6,y:1,width:9,height:9,children:x("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"})}),x("g",{mask:"url(#UnlockedIcon)",children:x("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"})})]}),le),g0=P(O("g",{strokeWidth:"1.25",children:[x("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"}),x("path",{d:"M10 13.958a1.042 1.042 0 1 0 0-2.083 1.042 1.042 0 0 0 0 2.083Z"}),x("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"})]}),le),h0=P(O(Ie,{children:[x("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"}),x("path",{fillRule:"evenodd",clipRule:"evenodd",d:"m12.005 10.478 7.905 14.423L6 25.75l6.005-15.273Z",fill:"currentColor"}),x("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"}),f0=P(O(Ie,{children:[x("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"}),x("path",{fillRule:"evenodd",clipRule:"evenodd",d:"m72.181 59.247-13.058-10-2.948 13.62 16.006-3.62Z",fill:"currentColor"}),x("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"}),b0=P(O(Ie,{children:[x("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"}),x("path",{fillRule:"evenodd",clipRule:"evenodd",d:"m24.165 1.093-2.132 16.309 13.27-4.258-11.138-12.05Z",fill:"currentColor"}),x("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"}),$O=P(x("g",{fill:"currentColor",children:x("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"}),x0=P(O("g",{stroke:"currentColor",strokeLinecap:"round",strokeLinejoin:"round",children:[x("path",{stroke:"none",d:"M0 0h24v24H0z",fill:"none"}),x("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"}),x("path",{d:"M13.5 13.5l4.5 4.5"})]}),{fill:"none",width:22,height:22,strokeWidth:1.25}),E0=P(O("g",{strokeWidth:"1.5",children:[x("path",{stroke:"none",d:"M0 0h24v24H0z",fill:"none"}),x("rect",{x:"4",y:"4",width:"16",height:"16",rx:"2"})]}),he),y0=P(O("g",{strokeWidth:"1.5",children:[x("path",{stroke:"none",d:"M0 0h24v24H0z",fill:"none"}),x("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"})]}),he),w0=P(O("g",{strokeWidth:"1.5",children:[x("path",{stroke:"none",d:"M0 0h24v24H0z",fill:"none"}),x("circle",{cx:"12",cy:"12",r:"9"})]}),he),v0=P(O("g",{strokeWidth:"1.5",children:[x("path",{stroke:"none",d:"M0 0h24v24H0z",fill:"none"}),x("line",{x1:"5",y1:"12",x2:"19",y2:"12"}),x("line",{x1:"15",y1:"16",x2:"19",y2:"12"}),x("line",{x1:"15",y1:"8",x2:"19",y2:"12"})]}),he),T0=P(x("path",{d:"M4.167 10h11.666",strokeWidth:"1.5"}),le),S0=P(O("g",{strokeWidth:"1.25",children:[x("path",{stroke:"none",d:"M0 0h24v24H0z",fill:"none"}),x("path",{d:"M20 17v-12c0 -1.121 -.879 -2 -2 -2s-2 .879 -2 2v12l2 2l2 -2z"}),x("path",{d:"M16 7h4"}),x("path",{d:"M18 19h-13a2 2 0 1 1 0 -4h4a2 2 0 1 0 0 -4h-3"})]}),he),ul=P(O("g",{strokeWidth:"1.25",children:[x("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"}),x("path",{d:"m11.25 5.417 3.333 3.333"})]}),le),I0=P(O("g",{strokeWidth:"1.5",children:[x("path",{stroke:"none",d:"M0 0h24v24H0z",fill:"none"}),x("line",{x1:"4",y1:"20",x2:"7",y2:"20"}),x("line",{x1:"14",y1:"20",x2:"21",y2:"20"}),x("line",{x1:"6.9",y1:"15",x2:"13.8",y2:"15"}),x("line",{x1:"10.2",y1:"6.3",x2:"16",y2:"20"}),x("polyline",{points:"5 20 11 4 13 4 20 20"})]}),he),C0=P(O("g",{strokeWidth:"1.25",children:[x("path",{d:"M12.5 6.667h.01"}),x("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"}),x("path",{d:"m3.333 12.5 3.334-3.333c.773-.745 1.726-.745 2.5 0l4.166 4.166"}),x("path",{d:"m11.667 11.667.833-.834c.774-.744 1.726-.744 2.5 0l1.667 1.667"})]}),le),k0=P(O("g",{strokeWidth:"1.5",children:[x("path",{stroke:"none",d:"M0 0h24v24H0z",fill:"none"}),x("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"}),x("path",{d:"M18 13.3l-6.3 -6.3"})]}),he),A0=P(x("path",{strokeWidth:"1.25",d:"M10 4.167v11.666M4.167 10h11.666"}),le),M0=P(x("path",{d:"M5 10h10",strokeWidth:"1.25"}),le),ii=P(x("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"}),le),L0=P(O("g",{strokeWidth:"1.25",children:[x("polyline",{points:"12 16 18 10 12 4"}),x("polyline",{points:"8 4 2 10 8 16"})]}),le),P0=P(O("g",{strokeWidth:"1.25",children:[x("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"}),x("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"})]}),le),_0=P(x("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"}),le),D0=P(x("g",{stroke:"currentColor",strokeWidth:"1.25",strokeLinecap:"round",strokeLinejoin:"round",children:x("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"})}),le),um=P(O("g",{strokeWidth:"1.5",children:[x("path",{stroke:"none",d:"M0 0h24v24H0z",fill:"none"}),x("line",{x1:"4",y1:"6",x2:"20",y2:"6"}),x("line",{x1:"4",y1:"12",x2:"20",y2:"12"}),x("line",{x1:"4",y1:"18",x2:"20",y2:"18"})]}),he),gm=P(x("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"}),le),gl=P(O("g",{strokeWidth:"1.5",children:[x("path",{stroke:"none",d:"M0 0h24v24H0z",fill:"none"}),x("circle",{cx:"12",cy:"12",r:"9"}),x("line",{x1:"12",y1:"17",x2:"12",y2:"17.01"}),x("path",{d:"M12 13.5a1.5 1.5 0 0 1 1 -1.5a2.6 2.6 0 1 0 -3 -4"})]}),he),hm=P(x("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"}),le),R0=P(x("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"}),le),N0=P(O("g",{strokeWidth:"1.25",children:[x("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"}),x("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"})]}),le),B0=P(O("g",{strokeWidth:"1.25",children:[x("path",{stroke:"none",d:"M0 0h24v24H0z",fill:"none"}),x("path",{d:"M4 4l11.733 16h4.267l-11.733 -16z"}),x("path",{d:"M4 20l6.768 -6.768m2.46 -2.46l6.772 -6.772"})]}),he),O0=P(x("polyline",{fill:"none",stroke:"currentColor",points:"20 6 9 17 4 12"}),{width:24,height:24}),fm=P(O("g",{strokeWidth:"1.25",children:[x("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"}),x("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"})]}),le),F0=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}),H0=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}),hl=P(x("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"}),le),XO=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}),z0=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"),G0=P(O("g",{strokeWidth:"1.25",children:[x("path",{stroke:"none",d:"M0 0h24v24H0z",fill:"none"}),x("path",{d:"M15 8h.01"}),x("path",{d:"M12 20h-5a3 3 0 0 1 -3 -3v-10a3 3 0 0 1 3 -3h10a3 3 0 0 1 3 3v5"}),x("path",{d:"M4 15l4 -4c.928 -.893 2.072 -.893 3 0l4 4"}),x("path",{d:"M14 14l1 -1c.617 -.593 1.328 -.793 2.009 -.598"}),x("path",{d:"M19 16v6"}),x("path",{d:"M22 19l-3 3l-3 -3"})]}),he),U0=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}),ZO=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}),jO=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}),W0=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"),qO=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"),V0=P(x("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"}),le),Y0=P(x("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"}),le),K0=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}),$0=P(x("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"}),le),JO=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"),QO=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}),eF=P(O(Ie,{children:[x("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"}),x("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}),tF=P(x("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}),X0=P(O(Ie,{children:[O("g",{clipPath:"url(#a)",stroke:"currentColor",strokeWidth:"1.25",strokeLinecap:"round",strokeLinejoin:"round",children:[x("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"}),x("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"})]}),x("defs",{children:x("clipPath",{id:"a",children:x("path",{fill:"#fff",d:"M0 0h20v20H0z"})})})]}),le),Z0=P(O(Ie,{children:[O("g",{clipPath:"url(#a)",stroke:"currentColor",strokeWidth:"1.25",strokeLinecap:"round",strokeLinejoin:"round",children:[x("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"}),x("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"})]}),x("defs",{children:x("clipPath",{id:"a",children:x("path",{fill:"#fff",d:"M0 0h20v20H0z"})})})]}),le),j0=P(O(Ie,{children:[O("g",{clipPath:"url(#a)",stroke:"currentColor",strokeWidth:"1.25",children:[x("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"}),x("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"})]}),x("defs",{children:x("clipPath",{id:"a",children:x("path",{fill:"#fff",d:"M0 0h20v20H0z"})})})]}),le),q0=P(O(Ie,{children:[O("g",{clipPath:"url(#a)",children:[x("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"}),x("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"}),x("mask",{id:"SendToBackIcon",fill:"#fff",children:x("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"})}),x("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"}),x("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)"}),x("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"})]}),x("defs",{children:x("clipPath",{id:"a",children:x("path",{fill:"#fff",d:"M0 0h20v20H0z"})})})]}),le),J0=P(O(Ie,{children:[O("g",{clipPath:"url(#a)",stroke:"currentColor",strokeWidth:"1.25",children:[x("path",{d:"M3.333 3.333h13.334",strokeLinecap:"round",strokeLinejoin:"round"}),x("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"})]}),x("defs",{children:x("clipPath",{id:"a",children:x("path",{fill:"#fff",d:"M0 0h20v20H0z"})})})]}),le),Q0=P(O(Ie,{children:[O("g",{clipPath:"url(#a)",stroke:"currentColor",strokeWidth:"1.25",children:[x("path",{d:"M3.333 16.667h13.334",strokeLinecap:"round",strokeLinejoin:"round"}),x("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"})]}),x("defs",{children:x("clipPath",{id:"a",children:x("path",{fill:"#fff",d:"M0 0h20v20H0z"})})})]}),le),ey=P(O(Ie,{children:[O("g",{clipPath:"url(#a)",stroke:"currentColor",strokeWidth:"1.25",children:[x("path",{d:"M3.333 3.333v13.334",strokeLinecap:"round",strokeLinejoin:"round"}),x("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"})]}),x("defs",{children:x("clipPath",{id:"a",children:x("path",{fill:"#fff",d:"M0 0h20v20H0z"})})})]}),le),ty=P(O(Ie,{children:[O("g",{clipPath:"url(#a)",stroke:"currentColor",strokeWidth:"1.25",children:[x("path",{d:"M16.667 3.333v13.334",strokeLinecap:"round",strokeLinejoin:"round"}),x("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"})]}),x("defs",{children:x("clipPath",{id:"a",children:x("path",{fill:"#fff",d:"M0 0h20v20H0z"})})})]}),le),ry=P(O(Ie,{children:[O("g",{clipPath:"url(#a)",stroke:"currentColor",strokeWidth:"1.25",children:[x("path",{d:"M16.667 3.333v13.334M3.333 3.333v13.334",strokeLinecap:"round",strokeLinejoin:"round"}),x("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"})]}),x("defs",{children:x("clipPath",{id:"a",children:x("path",{fill:"#fff",d:"M0 0h20v20H0z"})})})]}),le),oy=P(O(Ie,{children:[O("g",{clipPath:"url(#a)",stroke:"currentColor",strokeWidth:"1.25",children:[x("path",{d:"M3.333 3.333h13.334M3.333 16.667h13.334",strokeLinecap:"round",strokeLinejoin:"round"}),x("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"})]}),x("defs",{children:x("clipPath",{id:"a",children:x("path",{fill:"#fff",d:"M0 0h20v20H0z"})})})]}),le),ny=P(O("g",{stroke:"currentColor",strokeWidth:"1.25",children:[x("path",{d:"M1.667 10h2.916",strokeLinecap:"round",strokeLinejoin:"round"}),x("path",{d:"M8.333 10h3.334",strokeLinejoin:"round"}),x("path",{d:"M15.417 10h2.916",strokeLinecap:"round",strokeLinejoin:"round"}),x("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"})]}),le),iy=P(O("g",{stroke:"currentColor",strokeWidth:"1.25",children:[x("path",{d:"M10 18.333v-2.916",strokeLinecap:"round",strokeLinejoin:"round"}),x("path",{d:"M10 11.667V8.333",strokeLinejoin:"round"}),x("path",{d:"M10 4.583V1.667",strokeLinecap:"round",strokeLinejoin:"round"}),x("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"})]}),le),bm=P(O("g",{strokeWidth:"1.5",children:[x("path",{stroke:"none",d:"M0 0h24v24H0z",fill:"none"}),x("circle",{cx:"9",cy:"7",r:"4"}),x("path",{d:"M3 21v-2a4 4 0 0 1 4 -4h4a4 4 0 0 1 4 4v2"}),x("path",{d:"M16 3.13a4 4 0 0 1 0 7.75"}),x("path",{d:"M21 21v-2a4 4 0 0 0 -3 -3.85"})]}),he),rF=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"),oF=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"),Yr=P(O(Ie,{children:[x("g",{clipPath:"url(#a)",stroke:"currentColor",strokeWidth:"1.25",strokeLinecap:"round",strokeLinejoin:"round",children:x("path",{d:"M15 5 5 15M5 5l10 10"})}),x("defs",{children:x("clipPath",{id:"a",children:x("path",{fill:"#fff",d:"M0 0h20v20H0z"})})})]}),le),ay=P("M34.52 239.03L228.87 44.69c9.37-9.37 24.57-9.37 33.94 0l22.67 22.67c9.36 9.36 9.37 24.52.04 33.9L131.49 256l154.02 154.75c9.34 9.38 9.32 24.54-.04 33.9l-22.67 22.67c-9.37 9.37-24.57 9.37-33.94 0L34.52 272.97c-9.37-9.37-9.37-24.57 0-33.94z",{width:320,height:512,style:{marginLeft:"-0.2rem"},mirror:!0}),nF=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}),iF=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}),aF=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}),ly=hr.memo(({theme:e})=>P(O(Ie,{children:[x("path",{d:"M25 26H111V111H25",fill:vo(e)}),x("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"}),x("path",{d:"M100 100H160V160H100",fill:vo(e)}),x("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"}),O("g",{fill:s0(e),stroke:vo(e),strokeWidth:"6",children:[x("rect",{x:"2.5",y:"2.5",width:"30",height:"30"}),x("rect",{x:"2.5",y:"149.5",width:"30",height:"30"}),x("rect",{x:"147.5",y:"149.5",width:"30",height:"30"}),x("rect",{x:"147.5",y:"2.5",width:"30",height:"30"})]})]}),{width:182,height:182,mirror:!0})),sy=hr.memo(({theme:e})=>P(O(Ie,{children:[x("path",{d:"M25 26H111V111H25",fill:vo(e)}),x("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"}),x("path",{d:"M100 100H160V160H100",fill:vo(e)}),x("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"}),O("g",{fill:s0(e),stroke:vo(e),strokeWidth:"6",children:[x("rect",{x:"2.5",y:"2.5",width:"30",height:"30"}),x("rect",{x:"78.5",y:"149.5",width:"30",height:"30"}),x("rect",{x:"147.5",y:"149.5",width:"30",height:"30"}),x("rect",{x:"147.5",y:"78.5",width:"30",height:"30"}),x("rect",{x:"105.5",y:"2.5",width:"30",height:"30"}),x("rect",{x:"2.5",y:"102.5",width:"30",height:"30"})]})]}),{width:182,height:182,mirror:!0})),cy=P(x("g",{strokeWidth:1.25,children:x("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"})}),le),dy=P(O(Ie,{children:[x("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"}),x("mask",{id:"FillHachureIcon",style:{maskType:"alpha"},maskUnits:"userSpaceOnUse",x:2,y:2,width:16,height:16,children:x("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"})}),x("g",{mask:"url(#FillHachureIcon)",children:x("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"})})]}),le),my=P(O(Ie,{children:[O("g",{clipPath:"url(#a)",children:[x("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"}),x("mask",{id:"FillCrossHatchIcon",style:{maskType:"alpha"},maskUnits:"userSpaceOnUse",x:-1,y:-1,width:22,height:22,children:x("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"})}),x("g",{mask:"url(#FillCrossHatchIcon)",children:x("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"})})]}),x("defs",{children:x("clipPath",{id:"a",children:x("path",{fill:"#fff",d:"M0 0h20v20H0z"})})})]}),le),py=P(O(Ie,{children:[x("g",{clipPath:"url(#a)",children:x("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"})}),x("defs",{children:x("clipPath",{id:"a",children:x("path",{fill:"#fff",d:"M0 0h20v20H0z"})})})]}),{...le,fill:"currentColor"}),Vg=P(x(Ie,{children:x("path",{d:"M4.167 10h11.666",stroke:"currentColor",strokeWidth:"1.25",strokeLinecap:"round",strokeLinejoin:"round"})}),le),uy=P(x("path",{d:"M5 10h10",stroke:"currentColor",strokeWidth:"2.5",strokeLinecap:"round",strokeLinejoin:"round"}),le),gy=P(x("path",{d:"M5 10h10",stroke:"currentColor",strokeWidth:"3.75",strokeLinecap:"round",strokeLinejoin:"round"}),le),lF=hr.memo(({theme:e})=>P(x("path",{d:"M6 10H34",stroke:vo(e),strokeWidth:2,fill:"none",strokeLinecap:"round"}),{width:40,height:20})),hy=P(O("g",{strokeWidth:"2",children:[x("path",{stroke:"none",d:"M0 0h24v24H0z",fill:"none"}),x("path",{d:"M5 12h2"}),x("path",{d:"M17 12h2"}),x("path",{d:"M11 12h2"})]}),he),fy=P(O("g",{strokeWidth:"2",children:[x("path",{stroke:"none",d:"M0 0h24v24H0z",fill:"none"}),x("path",{d:"M4 12v.01"}),x("path",{d:"M8 12v.01"}),x("path",{d:"M12 12v.01"}),x("path",{d:"M16 12v.01"}),x("path",{d:"M20 12v.01"})]}),he),by=P(x("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"}),le),xy=P(x("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"}),le),Ey=P(x("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"}),le),yy=P(O("svg",{strokeWidth:"1.5",children:[x("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"}),x("path",{d:"M13.3333 3.33331V3.34331"}),x("path",{d:"M16.6667 3.33331V3.34331"}),x("path",{d:"M16.6667 6.66669V6.67669"}),x("path",{d:"M16.6667 10V10.01"}),x("path",{d:"M3.33334 13.3333V13.3433"}),x("path",{d:"M16.6667 13.3333V13.3433"}),x("path",{d:"M3.33334 16.6667V16.6767"}),x("path",{d:"M6.66666 16.6667V16.6767"}),x("path",{d:"M10 16.6667V16.6767"}),x("path",{d:"M13.3333 16.6667V16.6767"}),x("path",{d:"M16.6667 16.6667V16.6767"})]}),le),wy=P(O("g",{strokeWidth:"1.5",stroke:"currentColor",strokeLinecap:"round",strokeLinejoin:"round",children:[x("path",{stroke:"none",d:"M0 0h24v24H0z",fill:"none"}),x("path",{d:"M4 12v-4a4 4 0 0 1 4 -4h4"}),x("line",{x1:"16",y1:"4",x2:"16",y2:"4.01"}),x("line",{x1:"20",y1:"4",x2:"20",y2:"4.01"}),x("line",{x1:"20",y1:"8",x2:"20",y2:"8.01"}),x("line",{x1:"20",y1:"12",x2:"20",y2:"12.01"}),x("line",{x1:"4",y1:"16",x2:"4",y2:"16.01"}),x("line",{x1:"20",y1:"16",x2:"20",y2:"16.01"}),x("line",{x1:"4",y1:"20",x2:"4",y2:"20.01"}),x("line",{x1:"8",y1:"20",x2:"8",y2:"20.01"}),x("line",{x1:"12",y1:"20",x2:"12",y2:"20.01"}),x("line",{x1:"16",y1:"20",x2:"16",y2:"20.01"}),x("line",{x1:"20",y1:"20",x2:"20",y2:"20.01"})]}),he),vy=P(x("path",{d:"M6 10H34",stroke:"currentColor",strokeWidth:2,fill:"none"}),{width:40,height:20}),Ty=hr.memo(({flip:e=!1})=>P(O("g",{transform:e?"translate(40, 0) scale(-1, 1)":"",stroke:"currentColor",strokeWidth:2,fill:"none",children:[x("path",{d:"M34 10H6M34 10L27 5M34 10L27 15"}),x("path",{d:"M27.5 5L34.5 10L27.5 15"})]}),{width:40,height:20})),Yg=hr.memo(({flip:e=!1})=>P(O("g",{stroke:"currentColor",fill:"currentColor",transform:e?"translate(40, 0) scale(-1, 1)":"",children:[x("path",{d:"M32 10L6 10",strokeWidth:2}),x("circle",{r:"4",transform:"matrix(-1 0 0 1 30 10)"})]}),{width:40,height:20})),Sy=hr.memo(({flip:e=!1})=>P(O("g",{stroke:"currentColor",fill:"none",transform:e?"translate(40, 0) scale(-1, 1)":"",strokeWidth:2,children:[x("path",{d:"M26 10L6 10"}),x("circle",{r:"4",transform:"matrix(-1 0 0 1 30 10)"})]}),{width:40,height:20})),Iy=hr.memo(({flip:e=!1})=>P(x("g",{transform:e?"translate(40, 0) scale(-1, 1)":"",children:x("path",{d:"M34 10H5.99996M34 10L34 5M34 10L34 15",stroke:"currentColor",strokeWidth:2,fill:"none"})}),{width:40,height:20})),Cy=hr.memo(({flip:e=!1})=>P(O("g",{stroke:"currentColor",fill:"currentColor",transform:e?"translate(40, 0) scale(-1, 1)":"",children:[x("path",{d:"M32 10L6 10",strokeWidth:2}),x("path",{d:"M27.5 5.5L34.5 10L27.5 14.5L27.5 5.5"})]}),{width:40,height:20})),ky=hr.memo(({flip:e=!1})=>P(O("g",{stroke:"currentColor",fill:"none",transform:e?"translate(40, 0) scale(-1, 1)":"",strokeWidth:2,strokeLinejoin:"round",children:[x("path",{d:"M6,9.5H27"}),x("path",{d:"M27,5L34,10L27,14Z",fill:"none"})]}),{width:40,height:20})),Ay=hr.memo(({flip:e=!1})=>P(O("g",{stroke:"currentColor",fill:"currentColor",transform:e?"translate(40, 0) scale(-1, 1)":"",strokeLinejoin:"round",strokeWidth:2,children:[x("path",{d:"M6,9.5H20"}),x("path",{d:"M27,5L34,10L27,14L20,9.5Z"})]}),{width:40,height:20})),My=hr.memo(({flip:e=!1})=>P(O("g",{stroke:"currentColor",fill:"none",transform:e?"translate(40, 0) scale(-1, 1)":"",strokeLinejoin:"round",strokeWidth:2,children:[x("path",{d:"M6,9.5H20"}),x("path",{d:"M27,5L34,10L27,14L20,9.5Z"})]}),{width:40,height:20})),Ly=P(O(Ie,{children:[x("g",{clipPath:"url(#a)",children:x("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"})}),x("defs",{children:x("clipPath",{id:"a",children:x("path",{fill:"#fff",d:"M0 0h20v20H0z"})})})]}),le),Py=P(O(Ie,{children:[x("g",{clipPath:"url(#a)",children:x("path",{d:"M5 16.667V3.333L10 15l5-11.667v13.334",stroke:"currentColor",strokeWidth:"1.25",strokeLinecap:"round",strokeLinejoin:"round"})}),x("defs",{children:x("clipPath",{id:"a",children:x("path",{fill:"#fff",d:"M0 0h20v20H0z"})})})]}),le),_y=P(O(Ie,{children:[x("g",{clipPath:"url(#a)",children:x("path",{d:"M5.833 3.333v13.334h8.334",stroke:"currentColor",strokeWidth:"1.25",strokeLinecap:"round",strokeLinejoin:"round"})}),x("defs",{children:x("clipPath",{id:"a",children:x("path",{fill:"#fff",d:"M0 0h20v20H0z"})})})]}),le),Dy=P(x(Ie,{children:x("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"})}),le),Ry=P(x(Ie,{children:x("g",{stroke:"currentColor",strokeWidth:"1.25",strokeLinecap:"round",strokeLinejoin:"round",children:x("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"})})}),le),Ny=P(O(Ie,{children:[x("g",{clipPath:"url(#a)",stroke:"currentColor",strokeWidth:"1.25",strokeLinecap:"round",strokeLinejoin:"round",children:x("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"})}),x("defs",{children:x("clipPath",{id:"a",children:x("path",{fill:"#fff",d:"M0 0h20v20H0z"})})})]}),le),By=P(O("g",{stroke:"currentColor",fill:"none",strokeLinecap:"round",strokeLinejoin:"round",strokeWidth:2,children:[x("path",{stroke:"none",d:"M0 0h24v24H0z",fill:"none"}),x("line",{x1:"4",y1:"8",x2:"20",y2:"8"}),x("line",{x1:"4",y1:"12",x2:"12",y2:"12"}),x("line",{x1:"4",y1:"16",x2:"16",y2:"16"})]}),he),Oy=P(O("g",{stroke:"currentColor",fill:"none",strokeLinecap:"round",strokeLinejoin:"round",children:[x("path",{stroke:"none",d:"M0 0h24v24H0z",fill:"none"}),x("line",{x1:"4",y1:"8",x2:"20",y2:"8"}),x("line",{x1:"8",y1:"12",x2:"16",y2:"12"}),x("line",{x1:"6",y1:"16",x2:"18",y2:"16"})]}),he),Fy=P(O("g",{stroke:"currentColor",fill:"none",strokeLinecap:"round",strokeLinejoin:"round",children:[x("path",{stroke:"none",d:"M0 0h24v24H0z",fill:"none"}),x("line",{x1:"4",y1:"8",x2:"20",y2:"8"}),x("line",{x1:"10",y1:"12",x2:"20",y2:"12"}),x("line",{x1:"8",y1:"16",x2:"20",y2:"16"})]}),he),Hy=hr.memo(({theme:e})=>P(O("g",{strokeWidth:"1.5",stroke:"currentColor",fill:"none",strokeLinecap:"round",strokeLinejoin:"round",children:[x("path",{stroke:"none",d:"M0 0h24v24H0z",fill:"none"}),x("line",{x1:"4",y1:"4",x2:"20",y2:"4"}),x("rect",{x:"9",y:"8",width:"6",height:"12",rx:"2"})]}),he)),zy=hr.memo(({theme:e})=>P(O("g",{strokeWidth:"2",stroke:"currentColor",fill:"none",strokeLinecap:"round",strokeLinejoin:"round",children:[x("path",{stroke:"none",d:"M0 0h24v24H0z",fill:"none"}),x("line",{x1:"4",y1:"20",x2:"20",y2:"20"}),x("rect",{x:"9",y:"4",width:"6",height:"12",rx:"2"})]}),he)),Gy=hr.memo(({theme:e})=>P(O("g",{strokeWidth:"1.5",stroke:"currentColor",fill:"none",strokeLinecap:"round",strokeLinejoin:"round",children:[x("path",{stroke:"none",d:"M0 0h24v24H0z",fill:"none"}),x("line",{x1:"4",y1:"12",x2:"9",y2:"12"}),x("line",{x1:"15",y1:"12",x2:"20",y2:"12"}),x("rect",{x:"9",y:"6",width:"6",height:"12",rx:"2"})]}),he)),Uy=P(x("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}),sF=P(x("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"})),Wy=P(O("g",{strokeWidth:1.25,children:[x("path",{stroke:"none",d:"M0 0h24v24H0z",fill:"none"}),x("path",{d:"M8 13v-7.5a1.5 1.5 0 0 1 3 0v6.5"}),x("path",{d:"M11 5.5v-2a1.5 1.5 0 1 1 3 0v8.5"}),x("path",{d:"M14 5.5a1.5 1.5 0 0 1 3 0v6.5"}),x("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"})]}),he),Kg=P(O(Ie,{children:[x("path",{stroke:"none",d:"M0 0h24v24H0z",fill:"none"}),x("path",{d:"M4 17v2a2 2 0 0 0 2 2h12a2 2 0 0 0 2 -2v-2"}),x("path",{d:"M7 11l5 5l5 -5"}),x("path",{d:"M12 4l0 12"})]}),he),xm=P(O(Ie,{children:[x("path",{stroke:"none",d:"M0 0h24v24H0z",fill:"none"}),x("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"}),x("path",{d:"M16 8v-2a2 2 0 0 0 -2 -2h-8a2 2 0 0 0 -2 2v8a2 2 0 0 0 2 2h2"})]}),he),Vy=P(O(Ie,{children:[x("path",{stroke:"none",d:"M0 0h24v24H0z",fill:"none"}),x("path",{d:"M12 12m-9 0a9 9 0 1 0 18 0a9 9 0 1 0 -18 0"}),x("path",{d:"M12 17l0 .01"}),x("path",{d:"M12 13.5a1.5 1.5 0 0 1 1 -1.5a2.6 2.6 0 1 0 -3 -4"})]}),he),cF=P(O(Ie,{children:[x("path",{stroke:"none",d:"M0 0h24v24H0z",fill:"none"}),x("path",{d:"M7 4v16l13 -8z"})]}),he),dF=P(O(Ie,{children:[x("path",{stroke:"none",d:"M0 0h24v24H0z",fill:"none"}),x("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"})]}),he),mF=P(O(Ie,{children:[x("path",{stroke:"none",d:"M0 0h24v24H0z",fill:"none"}),x("path",{d:"M5 12l5 5l10 -10"})]}),he),Yy=P(O(Ie,{children:[x("path",{stroke:"none",d:"M0 0h24v24H0z",fill:"none"}),x("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"}),x("path",{d:"M12 9v4"}),x("path",{d:"M12 17h.01"})]}),he),Ky=P(O("g",{strokeWidth:1.25,children:[x("path",{stroke:"none",d:"M0 0h24v24H0z",fill:"none"}),x("path",{d:"M11 7l6 6"}),x("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"})]}),he),$y=P(O("g",{strokeWidth:1.5,children:[x("path",{stroke:"none",d:"M0 0h24v24H0z",fill:"none"}),x("path",{d:"M12 3l-4 7h8z"}),x("path",{d:"M17 17m-3 0a3 3 0 1 0 6 0a3 3 0 1 0 -6 0"}),x("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"})]}),he),Xy=P(O("g",{strokeWidth:1.5,children:[x("path",{stroke:"none",d:"M0 0h24v24H0z",fill:"none"}),x("path",{d:"M4 7l16 0"}),x("path",{d:"M4 17l16 0"}),x("path",{d:"M7 4l0 16"}),x("path",{d:"M17 4l0 16"})]}),he),Zy=P(x("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"})),fl=P(O("g",{strokeWidth:"1.25",children:[x("path",{d:"M4.16602 10H15.8327"}),x("path",{d:"M12.5 13.3333L15.8333 10"}),x("path",{d:"M12.5 6.66666L15.8333 9.99999"})]}),le),Em=P(O("g",{fill:"none",stroke:"currentColor",strokeWidth:"1.25",strokeLinecap:"round",strokeLinejoin:"round",transform:"rotate(90 10 10)",children:[x("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"}),x("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),bl=P(O("g",{stroke:"currentColor",fill:"none",children:[x("path",{stroke:"none",d:"M0 0h24v24H0z"}),x("path",{d:"M6 21l15 -15l-3 -3l-15 15l3 3"}),x("path",{d:"M15 6l3 3"}),x("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"}),x("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"})]}),he),Vs=P(O("g",{stroke:"currentColor",fill:"none",children:[x("path",{stroke:"none",d:"M0 0h24v24H0z",fill:"none"}),x("path",{d:"M11.217 19.384a3.501 3.501 0 0 0 6.783 -1.217v-5.167l-6 -3.35"}),x("path",{d:"M5.214 15.014a3.501 3.501 0 0 0 4.446 5.266l4.34 -2.534v-6.946"}),x("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"}),x("path",{d:"M12.783 4.616a3.501 3.501 0 0 0 -6.783 1.217v5.067l6 3.45"}),x("path",{d:"M18.786 8.986a3.501 3.501 0 0 0 -4.446 -5.266l-4.34 2.534v6.946"}),x("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"})]}),he),jy=P(O("g",{stroke:"currentColor",fill:"none",children:[x("path",{stroke:"none",d:"M0 0h24v24H0z",fill:"none"}),x("path",{d:"M4 8v-2a2 2 0 0 1 2 -2h2"}),x("path",{d:"M4 16v2a2 2 0 0 0 2 2h2"}),x("path",{d:"M16 4h2a2 2 0 0 1 2 2v2"}),x("path",{d:"M16 20h2a2 2 0 0 0 2 -2v-2"})]}),he),ym=P(O("g",{stroke:"currentColor",fill:"none",children:[x("path",{stroke:"none",d:"M0 0h24v24H0z",fill:"none"}),x("path",{d:"M10 12a2 2 0 1 0 4 0a2 2 0 0 0 -4 0"}),x("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"})]}),he),qy=P(O("g",{stroke:"currentColor",fill:"none",children:[x("path",{stroke:"none",d:"M0 0h24v24H0z",fill:"none"}),x("path",{d:"M10.585 10.587a2 2 0 0 0 2.829 2.828"}),x("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"}),x("path",{d:"M3 3l18 18"})]}),he),Jy=P(O("g",{stroke:"currentColor",fill:"none",children:[x("path",{stroke:"none",d:"M0 0h24v24H0z",fill:"none"}),x("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"}),x("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"}),x("path",{d:"M17.5 16a3.5 3.5 0 0 0 0 -7h-.5"}),x("path",{d:"M19 9.3v-2.8a3.5 3.5 0 0 0 -7 0"}),x("path",{d:"M6.5 16a3.5 3.5 0 0 1 0 -7h.5"}),x("path",{d:"M5 9.3v-2.8a3.5 3.5 0 0 1 7 0v10"})]}),he),Qy=P(O("g",{strokeWidth:1.5,children:[x("path",{stroke:"none",d:"M0 0h24v24H0z",fill:"none"}),x("path",{d:"M10 10m-7 0a7 7 0 1 0 14 0a7 7 0 1 0 -14 0"}),x("path",{d:"M21 21l-6 -6"})]}),he);import{jsx as JS}from"react/jsx-runtime";var qS=(e,t)=>{let r=new Set(pe(e.filter(o=>X(o)),t).map(o=>o.id));return{elements:e.map(o=>t.selectedElementIds[o.id]?te(o,{isDeleted:!0}):o.frameId&&r.has(o.frameId)?te(o,{isDeleted:!0}):Me(o)&&t.selectedElementIds[o.containerId]?te(o,{isDeleted:!0}):o),appState:{...t,selectedElementIds:{},selectedGroupIds:{}}}},ew=(e,t)=>{if(e.editingGroupId){let r=Ze(be(t),e.editingGroupId);if(r.length)return{...e,selectedElementIds:{[r[0].id]:!0}}}return e},Ys=N({name:"deleteSelectedElements",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=V.getElement(a,d);if(!m||l==null)return!1;if(m.points.length<2){let u=e.map(f=>f.id===m.id?te(f,{isDeleted:!0}):f),g=ew(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 V.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}=qS(e,t);return Va(n,e.filter(({id:a})=>t.selectedElementIds[a])),i=ew(i,n),{elements:n,appState:{...i,activeTool:Ke(t,{type:"selection"}),multiElement:null,activeEmbeddable:null},commitToHistory:Re(be(e),t)}},contextItemLabel:"labels.delete",keyTest:(e,t,r)=>(e.key===S.BACKSPACE||e.key===S.DELETE)&&!e[S.CTRL_OR_CMD],PanelComponent:({elements:e,appState:t,updateData:r})=>JS(ne,{type:"button",icon:ii,title:b("labels.delete"),"aria-label":b("labels.delete"),onClick:()=>r(null),visible:Re(be(e),t)})});h();h();He();oe();Ir();We();nn();F();var $g=(e,t)=>e.frameId===t||e.id===t,rw=(e,t,r)=>{let o=[],n=[],i=null,a=-1,l=J(r||pe(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},QS=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),[])},tw=(e,t,r)=>{if("containerId"in e&&e.containerId)if(r==="left"){let o=rt.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=rt.getScene(e).getElement(o);if(n)return t.indexOf(n)}}},eI=(e,t)=>{let r=-1,o=-1;return e.forEach((n,i)=>{$g(n,t)&&(r===-1&&(r=i),o=i)}),r===-1?[]:e.slice(r,o+1)},tI=(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"?lu(t,m=>a(m),Math.max(0,r-1)):au(t,m=>a(m),r+1),s=t[l];if(!s)return-1;if(e.editingGroupId){if(i?.groupIds.join("")===s?.groupIds.join(""))return tw(s,t,o)??l;if(!s?.groupIds.includes(e.editingGroupId))return-1}if(!n&&(s.frameId||X(s))){let m=eI(t,s.frameId||s.id);return o==="left"?t.indexOf(m[0]):t.indexOf(m[m.length-1])}if(!s.groupIds.length)return tw(s,t,o)??l;let c=e.editingGroupId?s.groupIds[s.groupIds.indexOf(e.editingGroupId)-1]:s.groupIds[s.groupIds.length-1],d=Ze(t,c);return d.length?o==="left"?t.indexOf(d[0]):t.indexOf(d[d.length-1]):l},ow=(e,t)=>t.reduce((r,o)=>{let n=e[o];return r[n.id]=n,r},{}),nw=(e,t,r)=>{let o=rw(e,t),n=ow(e,o),i=QS(o);r==="right"&&(i=i.reverse());let a=new Set(o.filter(l=>X(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(T=>{let w=e[T];return w.frameId&&a.has(w.frameId)})?null:e[m]?.frameId,u=tI(t,e,m,r,p);if(u===-1||m===u)return;let g=r==="left"?e.slice(0,u):e.slice(0,c),f=e.slice(c,d+1),E=r==="left"?e.slice(u,c):e.slice(d+1,u+1),y=r==="left"?e.slice(d+1):e.slice(u+1);e=r==="left"?[...g,...f,...E,...y]:[...g,...E,...f,...y]}),e.map(l=>n[l.id]?Eo(l):l)},iw=(e,t,r,o,n)=>{let i=rw(e,t,n),a=ow(e,i),l=[],s,c;if(r==="left"){if(o)s=au(e,u=>$g(u,o));else if(t.editingGroupId){let u=Ze(e,t.editingGroupId);if(!u.length)return e;s=e.indexOf(u[0])}else s=0;c=i[i.length-1]}else{if(o)c=lu(e,u=>$g(u,o));else if(t.editingGroupId){let u=Ze(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=>Eo(u)),m=e.slice(0,s),p=e.slice(c+1);return r==="left"?[...m,...d,...l,...p]:[...m,...l,...d,...p]};function aw(e,t,r,o){let n=J(pe(e,t,{includeBoundTextElement:!0,includeElementsInFrames:!0})),i={regularElements:[],frameChildren:new Map},a=new Set;for(let c of e)n.has(c.id)&&X(c)&&a.add(c.id);for(let c of e)if(n.has(c.id))if(X(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 lw=(e,t)=>nw(e,t,"left"),sw=(e,t)=>nw(e,t,"right"),cw=(e,t)=>aw(e,t,"left",iw),dw=(e,t)=>aw(e,t,"right",iw);de();F();ze();W();import{jsx as wm}from"react/jsx-runtime";var Xg=N({name:"sendBackward",trackEvent:{category:"element"},perform:(e,t)=>({elements:lw(e,t),appState:t,commitToHistory:!0}),contextItemLabel:"labels.sendBackward",keyPriority:40,keyTest:e=>e[S.CTRL_OR_CMD]&&!e.shiftKey&&e.code===ue.BRACKET_LEFT,PanelComponent:({updateData:e,appState:t})=>wm("button",{type:"button",className:"zIndexButton",onClick:()=>e(null),title:`${b("labels.sendBackward")} \u2014 ${_("CtrlOrCmd+[")}`,children:Z0})}),Zg=N({name:"bringForward",trackEvent:{category:"element"},perform:(e,t)=>({elements:sw(e,t),appState:t,commitToHistory:!0}),contextItemLabel:"labels.bringForward",keyPriority:40,keyTest:e=>e[S.CTRL_OR_CMD]&&!e.shiftKey&&e.code===ue.BRACKET_RIGHT,PanelComponent:({updateData:e,appState:t})=>wm("button",{type:"button",className:"zIndexButton",onClick:()=>e(null),title:`${b("labels.bringForward")} \u2014 ${_("CtrlOrCmd+]")}`,children:X0})}),jg=N({name:"sendToBack",trackEvent:{category:"element"},perform:(e,t)=>({elements:cw(e,t),appState:t,commitToHistory:!0}),contextItemLabel:"labels.sendToBack",keyTest:e=>qt?e[S.CTRL_OR_CMD]&&e.altKey&&e.code===ue.BRACKET_LEFT:e[S.CTRL_OR_CMD]&&e.shiftKey&&e.code===ue.BRACKET_LEFT,PanelComponent:({updateData:e,appState:t})=>wm("button",{type:"button",className:"zIndexButton",onClick:()=>e(null),title:`${b("labels.sendToBack")} \u2014 ${qt?_("CtrlOrCmd+Alt+["):_("CtrlOrCmd+Shift+[")}`,children:q0})}),qg=N({name:"bringToFront",trackEvent:{category:"element"},perform:(e,t)=>({elements:dw(e,t),appState:t,commitToHistory:!0}),contextItemLabel:"labels.bringToFront",keyTest:e=>qt?e[S.CTRL_OR_CMD]&&e.altKey&&e.code===ue.BRACKET_RIGHT:e[S.CTRL_OR_CMD]&&e.shiftKey&&e.code===ue.BRACKET_RIGHT,PanelComponent:({updateData:e,appState:t})=>wm("button",{type:"button",className:"zIndexButton",onClick:r=>e(null),title:`${b("labels.bringToFront")} \u2014 ${qt?_("CtrlOrCmd+Alt+]"):_("CtrlOrCmd+Shift+]")}`,children:j0})});h();de();ze();Ir();me();oe();$t();Un();var Jg=N({name:"selectAll",trackEvent:{category:"canvas"},perform:(e,t,r,o)=>{if(t.editingLinearElement)return!1;let n=aa(e.filter(i=>!i.isDeleted&&!(G(i)&&i.containerId)&&!i.locked)).reduce((i,a)=>(i[a.id]=!0,i),{});return{appState:{...t,...Gt({editingGroupId:null,selectedElementIds:n},be(e),t,o),selectedLinearElement:Object.keys(n).length===1&&ee(e[0])?new V(e[0]):null},commitToHistory:!0}},contextItemLabel:"labels.selectAll",keyTest:e=>e[S.CTRL_OR_CMD]&&e.key===S.A});h();de();ze();me();We();F();$t();Ir();ho();W();lt();oe();h();F();var rI=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]},oI=e=>{let t=l1(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]},mw=e=>oI(rI(e));Xt();Un();import{jsx as iI}from"react/jsx-runtime";var Qg=N({name:"duplicateSelection",trackEvent:{category:"element"},perform:(e,t,r,o)=>{let n=o.scene.getNonDeletedElementsMap();if(t.editingLinearElement){let i=V.duplicateSelectedPoints(t,n);return i?{elements:e,appState:i.appState,commitToHistory:!0}:!1}return{...nI(e,t),commitToHistory:!0}},contextItemLabel:"labels.duplicateSelection",keyTest:e=>e[S.CTRL_OR_CMD]&&e.key===S.D,PanelComponent:({elements:e,appState:t,updateData:r})=>iI(ne,{type:"button",icon:P0,title:`${b("labels.duplicateSelection")} \u2014 ${_("CtrlOrCmd+D")}`,"aria-label":b("labels.duplicateSelection"),onClick:()=>r(null),visible:Re(be(e),t)})}),nI=(e,t)=>{let r=mw(e),o=new Map,n=[],i=[],a=new Map,l=y=>{let T=Cs(t.editingGroupId,o,y,{x:y.x+tn/2,y:y.y+tn/2});return a.set(y.id,T.id),i.push(y),n.push(T),T},s=J(pe(r,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<r.length;){let y=r[p];if(c.get(y.id))continue;let T=ae(y,J(e)),w=X(y);if(s.get(y.id)){if(y.groupIds.length||T||w){let I=$u(t,y);if(I){let k=Ze(r,I).flatMap(C=>X(C)?[...Mr(e,C.id),C]:[C]);m.push(...d([...k,...k.map(C=>l(C))]));continue}if(T){m.push(...d([y,T,l(y),l(T)]));continue}if(w){let k=Mr(r,y.id);m.push(...d([...k,y,...k.map(C=>l(C)),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 f=u.reverse();dd(m,i,a),ld(m,i,a),em(f,i,a);let E=aa(n);return{elements:f,appState:{...t,...Gt({editingGroupId:t.editingGroupId,selectedElementIds:E.reduce((y,T)=>(Me(T)||(y[T.id]=!0),y),{})},be(f),t,null)}}};h();Vt();h();var aI=["ai"],xe=(e,t,r,o)=>{try{if(typeof window>"u"||v.VITE_WORKER_ID||v.PROD||!aI.includes(e))return;v.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)}};h();import pw from"clsx";import{jsx as eh,jsxs as lI}from"react/jsx-runtime";var Wo=e=>eh("div",{className:"buttonList buttonListIcon",children:e.options.map(t=>e.type==="button"?eh("button",{onClick:r=>e.onClick(t.value,r),className:pw({active:t.active??e.value===t.value}),"data-testid":t.testId,title:t.text,children:t.icon},t.text):lI("label",{className:pw({active:e.value===t.value}),title:t.text,children:[eh("input",{type:"radio",name:e.group,onChange:()=>e.onChange(t.value),checked:e.value===t.value,"data-testid":t.testId}),t.icon]},t.text))});h();F();h();Vt();import sI from"clsx";import{jsx as th}from"react/jsx-runtime";var uw=({onChange:e,type:t,activeColor:r,topPicks:o})=>{let n;return t==="elementStroke"&&(n=Cc),t==="elementBackground"&&(n=kc),t==="canvasBackground"&&(n=Ac),o&&(n=o),n?th("div",{className:"color-picker__top-picks",children:n.map(i=>th("button",{className:sI("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:th("div",{className:"color-picker__button-outline"})},i))}):(console.error("Invalid type for TopPicks"),null)};h();import vw,{useEffect as Tw,useState as LI}from"react";h();import pI from"clsx";import{useAtom as uI}from"jotai";import{useEffect as gI,useRef as hI}from"react";h();Vt();import{atom as cI}from"jotai";var ai=({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},Ks=[["q","w","e","r","t"],["a","s","d","f","g"],["z","x","c","v","b"]].flat(),rh=({color:e,palette:t})=>!Object.values(t).flat().includes(e),hw=(e,t,r)=>{let o={elementBackground:"backgroundColor",elementStroke:"strokeColor"},n=e.filter(a=>{if(a.isDeleted)return!1;let l=a[o[t]];return rh({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,vb)},Kr=cI(null),gw=(e,t,r)=>(e*299+t*587+r*114)/1e3>=160?"black":"white",fw=(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 gw(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 gw(r,o,n)};h();import{jsxs as mI}from"react/jsx-runtime";var dI=({color:e,keyLabel:t,isCustomColor:r=!1,isShade:o=!1})=>mI("div",{className:"color-picker__button__hotkey-label",style:{color:fw(e,r)},children:[o&&"\u21E7",t]}),xl=dI;import{jsx as $s,jsxs as bw}from"react/jsx-runtime";var xw=({hex:e,onChange:t,palette:r})=>{let o=ai({color:e||"transparent",palette:r}),[n,i]=uI(Kr),a=hI(null);if(gI(()=>{a.current&&n==="shades"&&a.current.focus()},[o,n]),o){let{colorName:l,shade:s}=o,c=r[l];if(Array.isArray(c))return $s("div",{className:"color-picker-content--default shades",children:c.map((d,m)=>bw("button",{ref:m===s&&n==="shades"?a:void 0,tabIndex:-1,type:"button",className:pI("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:[$s("div",{className:"color-picker__button-outline"}),$s(xl,{color:d,keyLabel:m+1,isShade:!0})]},m))})}return bw("div",{className:"color-picker-content--default",style:{position:"relative"},tabIndex:-1,children:[$s("button",{type:"button",tabIndex:-1,className:"color-picker__button color-picker__button--large color-picker__button--no-focus-visible"}),$s("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")})]})};h();import fI from"clsx";import{useAtom as bI}from"jotai";import{useEffect as xI,useRef as EI}from"react";import{jsx as oh,jsxs as wI}from"react/jsx-runtime";var yI=({palette:e,color:t,onChange:r,label:o,activeShade:n})=>{let i=ai({color:t||"transparent",palette:e}),[a,l]=bI(Kr),s=EI(null);return xI(()=>{s.current&&a==="baseColors"&&s.current.focus()},[i?.colorName,a]),oh("div",{className:"color-picker-content--default",children:Object.entries(e).map(([c,d],m)=>{let p=(Array.isArray(d)?d[n]:d)||"transparent",u=Ks[m],g=b(`colors.${c.replace(/\d+/,"")}`,null,"");return wI("button",{ref:i?.colorName===c?s:void 0,tabIndex:-1,type:"button",className:fI("color-picker__button color-picker__button--large",{active:i?.colorName===c,"is-transparent":p==="transparent"||!p}),onClick:()=>{r(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:[oh("div",{className:"color-picker__button-outline"}),oh(xl,{color:p,keyLabel:u})]},c)})})},Ew=yI;import{useAtom as PI}from"jotai";h();import vI from"clsx";import{useAtom as TI}from"jotai";import{useEffect as SI,useRef as II}from"react";import{jsx as nh,jsxs as CI}from"react/jsx-runtime";var yw=({colors:e,color:t,onChange:r,label:o})=>{let[n,i]=TI(Kr),a=II(null);return SI(()=>{a.current&&a.current.focus()},[t,n]),nh("div",{className:"color-picker-content--default",children:e.map((l,s)=>CI("button",{ref:t===l?a:void 0,tabIndex:-1,type:"button",className:vI("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:[nh("div",{className:"color-picker__button-outline"}),nh(xl,{color:l,keyLabel:s+1,isCustomColor:!0})]},s))})};h();de();Vt();var ih=(e,t,r)=>{let o=Math.ceil(r/Mi);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+Mi;return n>=r?t%Mi:n}case"ArrowUp":{let n=t-Mi,i=n<0?Mi*o+n:n;return i>=r?void 0:i}}},kI=({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(Ks.includes(e.key)){let l=Ks.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},ww=({event:e,activeColorPickerSection:t,palette:r,color:o,onChange:n,customColors:i,setActiveColorPickerSection:a,updateData:l,activeShade:s,onEyeDropperToggle:c,onEscape:d})=>{if(e[S.CTRL_OR_CMD])return!1;if(e.key===S.ESCAPE)return d(e),!0;if(e.key===S.ALT)return c(!0),!0;if(e.key===S.I)return c(),!0;let m=ai({color:o,palette:r});if(e.key===S.TAB){let p={custom:!!i.length,baseColors:!0,shades:m?.shade!=null,hex:!0},u=Object.entries(p).reduce((T,[w,I])=>(I&&T.push(w),T),[]),g=u.indexOf(t),f=e.shiftKey?-1:1,E=g+f>u.length-1?0:g+f<0?u.length-1:g+f,y=u[E];return y&&a(y),y==="custom"?n(i[0]):y==="baseColors"&&(Object.entries(r).find(([w,I])=>Array.isArray(I)?I.includes(o):I===o?w:null)||n(ie.black)),e.preventDefault(),e.stopPropagation(),!0}if(kI({e,colorObj:m,onChange:n,palette:r,customColors:i,setActiveColorPickerSection:a,activeShade:s}))return!0;if(t==="shades"&&m){let{shade:p}=m,u=ih(e.key,p,Mi);if(u!==void 0)return n(r[m.colorName][u]),!0}if(t==="baseColors"&&m){let{colorName:p}=m,u=Object.keys(r),g=u.indexOf(p),f=ih(e.key,g,u.length);if(f!==void 0){let E=u[f],y=r[E];return n(Array.isArray(y)?y[s]:y),!0}}if(t==="custom"){let p=i.indexOf(o),u=ih(e.key,p,i.length);if(u!==void 0){let g=i[u];return n(g),!0}}return!1};h();import{jsx as MI}from"react/jsx-runtime";var AI=({children:e})=>MI("div",{className:"color-picker__heading",children:e}),El=AI;Vt();de();W();import{jsx as sa,jsxs as vm}from"react/jsx-runtime";var Sw=({color:e,onChange:t,label:r,type:o,elements:n,palette:i,updateData:a,children:l,onEyeDropperToggle:s,onEscape:c})=>{let[d]=vw.useState(()=>o==="canvasBackground"?[]:hw(n,o,i)),[m,p]=PI(Kr),u=ai({color:e,palette:i});Tw(()=>{if(!m){let y=rh({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,f]=LI(u?.shade??(o==="elementBackground"?va:wa));Tw(()=>{u?.shade!=null&&f(u.shade);let y=T=>{T.key===S.ALT&&s(!1)};return document.addEventListener("keyup",y,{capture:!0}),()=>{document.removeEventListener("keyup",y,{capture:!0})}},[u,s]);let E=vw.useRef(null);return sa("div",{role:"dialog","aria-modal":"true","aria-label":b("labels.colorPicker"),children:vm("div",{ref:E,onKeyDown:y=>{ww({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&&vm("div",{children:[sa(El,{children:b("colorPicker.mostUsedCustomColors")}),sa(yw,{colors:d,color:e,label:b("colorPicker.mostUsedCustomColors"),onChange:t})]}),vm("div",{children:[sa(El,{children:b("colorPicker.colors")}),sa(Ew,{color:e,label:r,palette:i,onChange:t,activeShade:g})]}),vm("div",{children:[sa(El,{children:b("colorPicker.shades")}),sa(xw,{hex:e,onChange:t,palette:i})]}),l]})})};import*as Vo from"@radix-ui/react-popover";import{useAtom as Dw}from"jotai";Vt();import VI from"clsx";h();import{useCallback as zI,useEffect as lh,useRef as Aw,useState as GI}from"react";import{useAtom as Mw}from"jotai";de();h();Vt();W();import{atom as NI}from"jotai";import{useEffect as BI,useRef as OI}from"react";import{createPortal as FI}from"react-dom";h();import Iw from"react";var ah=Iw.createContext(null),Ne=()=>Iw.useContext(ah);h();import{useState as _I,useLayoutEffect as Cw}from"react";var Tm=e=>{let[t,r]=_I(null),o=ke(),{theme:n}=Ne(),{container:i}=_t();return Cw(()=>{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==="dark"))},[t,n,o.editor.isMobile,e?.className]),Cw(()=>{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};h();W();import{useEffect as DI}from"react";function yl(e,t,r){DI(()=>{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])}de();We();h();import{useRef as RI}from"react";var Sm=e=>{let t=RI(e);return Object.assign(t.current,e),t.current};import{jsx as HI}from"react/jsx-runtime";var li=NI(null),kw=({onCancel:e,onChange:t,onSelect:r,colorPickerType:o})=>{let n=Tm({className:"excalidraw-eye-dropper-backdrop",parentSelector:".excalidraw-eye-dropper-container"}),i=Ne(),a=si(),l=$r(),s=pe(a,i),c=Sm({app:l,onCancel:e,onChange:t,onSelect:r,selectedElements:s}),{container:d}=_t();BI(()=>{let p=m.current;if(!p||!l.canvas||!n)return;let u=!1,g=l.canvas.getContext("2d"),f=({clientX:C,clientY:D})=>{let R=g.getImageData((C-i.offsetLeft)*window.devicePixelRatio,(D-i.offsetTop)*window.devicePixelRatio,1,1).data;return Ab(R[0],R[1],R[2])},E=({clientX:C,clientY:D,altKey:R})=>{p.style.top=`${D+20}px`,p.style.left=`${C+20}px`;let z=f({clientX:C,clientY:D});u&&c.onChange(o,z,c.selectedElements,{altKey:R}),p.style.background=z},y=()=>{c.onCancel()},T=(C,D)=>{c.onSelect(C,D)},w=C=>{u=!0,C.stopImmediatePropagation()},I=C=>{u=!1,d?.focus(),C.stopImmediatePropagation(),C.preventDefault(),T(f(C),C)},k=C=>{C.key===S.ESCAPE&&(C.preventDefault(),C.stopImmediatePropagation(),y())};return n.tabIndex=-1,n.focus(),E({clientX:c.app.lastViewportPosition.x,clientY:c.app.lastViewportPosition.y,altKey:!1}),n.addEventListener("keydown",k),n.addEventListener("pointerdown",w),n.addEventListener("pointerup",I),window.addEventListener("pointermove",E,{passive:!0}),window.addEventListener("blur",y),()=>{u=!1,n.removeEventListener("keydown",k),n.removeEventListener("pointerdown",w),n.removeEventListener("pointerup",I),window.removeEventListener("pointermove",E),window.removeEventListener("blur",y)}},[c,l.canvas,n,o,d,i.offsetLeft,i.offsetTop]);let m=OI(null);return yl(m,()=>{e()},p=>!!p.target.closest(".excalidraw-eye-dropper-trigger, .excalidraw-eye-dropper-backdrop")),n?FI(HI("div",{ref:m,className:"excalidraw-eye-dropper-preview"}),n):null};import UI from"clsx";F();import{Fragment as WI,jsx as Im,jsxs as Lw}from"react/jsx-runtime";var Pw=({color:e,onChange:t,label:r,colorPickerType:o})=>{let n=ke(),[i,a]=GI(e),[l,s]=Mw(Kr);lh(()=>{a(e)},[e]);let c=zI(g=>{let f=g.toLowerCase(),E=_w(f);E&&t(E),a(f)},[t]),d=Aw(null),m=Aw(null);lh(()=>{d.current&&d.current.focus()},[l]);let[p,u]=Mw(li,Pe);return lh(()=>()=>{u(null)},[u]),Lw("div",{className:"color-picker__input-label",children:[Im("div",{className:"color-picker__input-hash",children:"#"}),Im("input",{ref:l==="hex"?d:void 0,style:{border:0,padding:0},spellCheck:!1,className:"color-picker-input","aria-label":r,onChange:g=>{c(g.target.value)},value:(i||"").replace(/^#/,""),onBlur:()=>{a(e)},tabIndex:-1,onFocus:()=>s("hex"),onKeyDown:g=>{g.key!==S.TAB&&(g.key===S.ESCAPE&&m.current?.focus(),g.stopPropagation())}}),!n.editor.isMobile&&Lw(WI,{children:[Im("div",{style:{width:"1px",height:"1.25rem",backgroundColor:"var(--default-border-color)"}}),Im("div",{ref:m,className:UI("excalidraw-eye-dropper-trigger",{selected:p}),onClick:()=>u(g=>g?null:{keepOpenOnAlt:!1,onSelect:f=>t(f),colorPickerType:o}),title:`${b("labels.eyeDropper")} \u2014 ${S.I.toLocaleUpperCase()} or ${_("Alt")} `,children:Ky})]})]})};import{useRef as YI}from"react";import{jsx as Xr,jsxs as Cm}from"react/jsx-runtime";var Rw=e=>{let t=new Option().style;return t.color=e,!!t.color},_w=e=>Jt(e)?e:Rw(`#${e}`)?`#${e}`:Rw(e)?e:null,KI=({type:e,color:t,onChange:r,label:o,elements:n,palette:i=ie,updateData:a})=>{let[,l]=Dw(Kr),[s,c]=Dw(li,Pe),{container:d}=_t(),m=ke(),p=Cm("div",{children:[Xr(El,{children:b("colorPicker.hexCode")}),Xr(Pw,{color:t,label:o,onChange:f=>{r(f)},colorPickerType:e})]}),u=YI(null),g=()=>{u.current?.querySelector(".color-picker-content")?.focus()};return Xr(Vo.Portal,{container:d,children:Cm(Vo.Content,{ref:u,className:"focus-visible-none","data-prevent-outside-click":!0,onFocusOutside:f=>{g(),f.preventDefault()},onPointerDownOutside:f=>{s&&f.preventDefault()},onCloseAutoFocus:f=>{f.stopPropagation(),f.preventDefault(),d&&!e1(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?Xr(Sw,{palette:i,color:t,onChange:f=>{r(f)},onEyeDropperToggle:f=>{c(E=>f?(E=E||{keepOpenOnAlt:!0,onSelect:r,colorPickerType:e},E.keepOpenOnAlt=!0,E):f===!1||E?null:{keepOpenOnAlt:!1,onSelect:r,colorPickerType:e})},onEscape:f=>{s?c(null):Mo(f.target)?g():a({openPopup:null})},label:o,type:e,elements:n,updateData:a,children:p}):p,Xr(Vo.Arrow,{width:20,height:10,style:{fill:"var(--popup-bg-color)",filter:"drop-shadow(rgba(0, 0, 0, 0.05) 0px 3px 2px)"}})]})})},$I=({label:e,color:t,type:r})=>Xr(Vo.Trigger,{type:"button",className:VI("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:Xr("div",{className:"color-picker__button-outline"})}),Xs=({type:e,color:t,onChange:r,label:o,elements:n,palette:i=ie,topPicks:a,updateData:l,appState:s})=>Xr("div",{children:Cm("div",{role:"dialog","aria-modal":"true",className:"color-picker-container",children:[Xr(uw,{activeColor:t,onChange:r,type:e,topPicks:a}),Xr("div",{style:{width:1,height:"100%",backgroundColor:"var(--default-border-color)",margin:"0 auto"}}),Cm(Vo.Root,{open:s.openPopup===e,onOpenChange:c=>{l({openPopup:c?e:null})},children:[Xr($I,{color:t,label:o,type:e}),s.openPopup===e&&Xr(KI,{type:e,color:t,onChange:r,label:o,elements:n,palette:i,updateData:l})]})]})});h();import ca from"react";h();import{useLayoutEffect as XI,useRef as Nw,useEffect as Bw}from"react";F();de();import{unstable_batchedUpdates as ZI}from"react-dom";import{jsx as jI}from"react/jsx-runtime";var km=({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=Nw(null);Bw(()=>{let m=c.current;if(!m)return;m.contains(document.activeElement)||m.focus();let p=u=>{if(u.key===S.TAB){let g=Jl(m),{activeElement:f}=document,E=g.findIndex(y=>y===f);f===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=Nw(null);return XI(()=>{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]),Bw(()=>{if(o){let m=p=>{c.current?.contains(p.target)||ZI(()=>o(p))};return document.addEventListener("pointerdown",m,!1),()=>document.removeEventListener("pointerdown",m,!1)}},[o]),jI("div",{className:"popover",ref:c,tabIndex:-1,children:e})};de();import qI from"clsx";import{Fragment as QI,jsx as ci,jsxs as sh}from"react/jsx-runtime";function JI({options:e,value:t,label:r,onChange:o,onClose:n}){let i=ca.useRef(),a=ca.useRef(),l=ca.useRef(null);return ca.useEffect(()=>{a.current?a.current.focus():l.current&&l.current.focus()},[]),ci("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===S.TAB)setTimeout(()=>{let m=a.current,p=document.activeElement;m!==p&&n()},0);else if(Ga(c.key)){let{activeElement:m}=document,p=Qo().rtl,u=Array.prototype.indexOf.call(l.current.children,m);if(u!==-1){let g=e.length,f=u;switch(c.key){case(p?S.ARROW_LEFT:S.ARROW_RIGHT):case S.ARROW_DOWN:{f=(u+1)%g;break}case(p?S.ARROW_RIGHT:S.ARROW_LEFT):case S.ARROW_UP:{f=(g+u-1)%g;break}}l.current.children[f].focus()}c.preventDefault()}else(c.key===S.ESCAPE||c.key===S.ENTER)&&(c.preventDefault(),n());c.nativeEvent.stopImmediatePropagation(),c.stopPropagation()},children:ci("div",{className:"picker-content",ref:l,children:e.map((c,d)=>sh("button",{className:qI("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&&ci("span",{className:"picker-keybinding",children:c.keyBinding})]},c.text))})})}function ch({value:e,label:t,options:r,onChange:o,group:n=""}){let[i,a]=ca.useState(!1),l=ca.useRef(null),s=Qo().rtl;return sh("div",{children:[ci("button",{name:n,className:i?"active":"","aria-label":t,onClick:()=>a(!i),ref:l,children:r.find(c=>c.value===e)?.icon}),ci(ca.Suspense,{fallback:"",children:i?sh(QI,{children:[ci(km,{onCloseRequest:c=>c.target!==l.current&&a(!1),...s?{right:5.5}:{left:-5.5},children:ci(JI,{options:r.filter(c=>c.showInPicker!==!1),value:e,label:t,onChange:o,onClose:()=>{a(!1),l.current?.focus()}})}),ci("div",{className:"picker-triangle"})]}):null})]})}W();me();He();lt();oe();de();co();We();ms();F();ze();import{Fragment as Hw,jsx as ve,jsxs as Lr}from"react/jsx-runtime";var Fw=.1,Pr=(e,t,r,o=!1)=>{let n=J(pe(e,t,{includeBoundTextElement:o}));return e.map(i=>n.get(i.id)||i.id===t.editingElement?.id?r(i):i)},fr=function(e,t,r,o,n){let i=t.editingElement,a=be(e),l=null;return i&&(l=r(i)),l||(Re(a,t)?l=zg(o===!0?a:a.filter(c=>o(c)),t,r)??(typeof n=="function"?n(!0):n):l=typeof n=="function"?n(!1):n),l},eC=(e,t)=>Me(t)?t:B(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),dh=(e,t,r,o,n)=>{let i=new Set;return{elements:Pr(e,t,a=>{if(G(a)){let l=o(a);i.add(l);let s=te(a,{fontSize:l});return zt(s,r.scene.getContainerElement(a),r.scene.getNonDeletedElementsMap()),s=eC(a,s),s}return a},!0),appState:{...t,currentItemFontSize:i.size===1?[...i][0]:n??t.currentItemFontSize},commitToHistory:!0}},tC=N({name:"changeStrokeColor",trackEvent:!1,perform:(e,t,r)=>({...r.currentItemStrokeColor&&{elements:Pr(e,t,o=>ds(o.type)?te(o,{strokeColor:r.currentItemStrokeColor}):o,!0)},appState:{...t,...r},commitToHistory:!!r.currentItemStrokeColor}),PanelComponent:({elements:e,appState:t,updateData:r,appProps:o})=>Lr(Hw,{children:[ve("h3",{"aria-hidden":"true",children:b("labels.stroke")}),ve(Xs,{topPicks:Cc,palette:Ib,type:"elementStroke",label:b("labels.stroke"),color:fr(e,t,n=>n.strokeColor,!0,t.currentItemStrokeColor),onChange:n=>r({currentItemStrokeColor:n}),elements:e,appState:t,updateData:r})]})}),rC=N({name:"changeBackgroundColor",trackEvent:!1,perform:(e,t,r)=>({...r.currentItemBackgroundColor&&{elements:Pr(e,t,o=>te(o,{backgroundColor:r.currentItemBackgroundColor}))},appState:{...t,...r},commitToHistory:!!r.currentItemBackgroundColor}),PanelComponent:({elements:e,appState:t,updateData:r,appProps:o})=>Lr(Hw,{children:[ve("h3",{"aria-hidden":"true",children:b("labels.background")}),ve(Xs,{topPicks:kc,palette:Cb,type:"elementBackground",label:b("labels.background"),color:fr(e,t,n=>n.backgroundColor,!0,t.currentItemBackgroundColor),onChange:n=>r({currentItemBackgroundColor:n}),elements:e,appState:t,updateData:r})]})}),oC=N({name:"changeFillStyle",trackEvent:!1,perform:(e,t,r,o)=>(xe("element","changeFillStyle",`${r} (${o.device.editor.isMobile?"mobile":"desktop"})`),{elements:Pr(e,t,n=>te(n,{fillStyle:r})),appState:{...t,currentItemFillStyle:r},commitToHistory:!0}),PanelComponent:({elements:e,appState:t,updateData:r})=>{let o=pe(e,t),n=o.length>0&&o.every(i=>i.fillStyle==="zigzag");return Lr("fieldset",{children:[ve("legend",{children:b("labels.fill")}),ve(Wo,{type:"button",options:[{value:"hachure",text:`${n?b("labels.zigzag"):b("labels.hachure")} (${_("Alt-Click")})`,icon:n?cy:dy,active:n?!0:void 0,testId:"fill-hachure"},{value:"cross-hatch",text:b("labels.crossHatch"),icon:my,testId:"fill-cross-hatch"},{value:"solid",text:b("labels.solid"),icon:py,testId:"fill-solid"}],value:fr(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)}})]})}}),nC=N({name:"changeStrokeWidth",trackEvent:!1,perform:(e,t,r)=>({elements:Pr(e,t,o=>te(o,{strokeWidth:r})),appState:{...t,currentItemStrokeWidth:r},commitToHistory:!0}),PanelComponent:({elements:e,appState:t,updateData:r})=>Lr("fieldset",{children:[ve("legend",{children:b("labels.strokeWidth")}),ve(Wo,{group:"stroke-width",options:[{value:Fc.thin,text:b("labels.thin"),icon:Vg,testId:"strokeWidth-thin"},{value:Fc.bold,text:b("labels.bold"),icon:uy,testId:"strokeWidth-bold"},{value:Fc.extraBold,text:b("labels.extraBold"),icon:gy,testId:"strokeWidth-extraBold"}],value:fr(e,t,o=>o.strokeWidth,o=>o.hasOwnProperty("strokeWidth"),o=>o?null:t.currentItemStrokeWidth),onChange:o=>r(o)})]})}),iC=N({name:"changeSloppiness",trackEvent:!1,perform:(e,t,r)=>({elements:Pr(e,t,o=>te(o,{seed:Hr(),roughness:r})),appState:{...t,currentItemRoughness:r},commitToHistory:!0}),PanelComponent:({elements:e,appState:t,updateData:r})=>Lr("fieldset",{children:[ve("legend",{children:b("labels.sloppiness")}),ve(Wo,{group:"sloppiness",options:[{value:0,text:b("labels.architect"),icon:by},{value:1,text:b("labels.artist"),icon:xy},{value:2,text:b("labels.cartoonist"),icon:Ey}],value:fr(e,t,o=>o.roughness,o=>o.hasOwnProperty("roughness"),o=>o?null:t.currentItemRoughness),onChange:o=>r(o)})]})}),eW=N({name:"changeStrokeStyle",trackEvent:!1,perform:(e,t,r)=>({elements:Pr(e,t,o=>te(o,{strokeStyle:r})),appState:{...t,currentItemStrokeStyle:r},commitToHistory:!0}),PanelComponent:({elements:e,appState:t,updateData:r})=>Lr("fieldset",{children:[ve("legend",{children:b("labels.strokeStyle")}),ve(Wo,{group:"strokeStyle",options:[{value:"solid",text:b("labels.strokeStyle_solid"),icon:Vg},{value:"dashed",text:b("labels.strokeStyle_dashed"),icon:hy},{value:"dotted",text:b("labels.strokeStyle_dotted"),icon:fy}],value:fr(e,t,o=>o.strokeStyle,o=>o.hasOwnProperty("strokeStyle"),o=>o?null:t.currentItemStrokeStyle),onChange:o=>r(o)})]})}),aC=N({name:"changeOpacity",trackEvent:!1,perform:(e,t,r)=>({elements:Pr(e,t,o=>te(o,{opacity:r}),!0),appState:{...t,currentItemOpacity:r},commitToHistory:!0}),PanelComponent:({elements:e,appState:t,updateData:r})=>Lr("label",{className:"control-label",children:[b("labels.opacity"),ve("input",{type:"range",min:"0",max:"100",step:"10",onChange:o=>r(+o.target.value),value:fr(e,t,o=>o.opacity,!0,t.currentItemOpacity)??void 0})]})}),lC=N({name:"changeFontSize",trackEvent:!1,perform:(e,t,r,o)=>dh(e,t,o,()=>r,r),PanelComponent:({elements:e,appState:t,updateData:r,app:o})=>Lr("fieldset",{children:[ve("legend",{children:b("labels.fontSize")}),ve(Wo,{group:"font-size",options:[{value:16,text:b("labels.small"),icon:Ly,testId:"fontSize-small"},{value:20,text:b("labels.medium"),icon:Py,testId:"fontSize-medium"},{value:28,text:b("labels.large"),icon:_y,testId:"fontSize-large"},{value:36,text:b("labels.veryLarge"),icon:Dy,testId:"fontSize-veryLarge"}],value:fr(e,t,n=>{if(G(n))return n.fontSize;let i=ae(n,o.scene.getNonDeletedElementsMap());return i?i.fontSize:null},n=>G(n)||ae(n,o.scene.getNonDeletedElementsMap())!==null,n=>n?null:t.currentItemFontSize||It),onChange:n=>r(n)})]})}),mh=N({name:"decreaseFontSize",trackEvent:!1,perform:(e,t,r,o)=>dh(e,t,o,n=>Math.round(1/(1+Fw)*n.fontSize)),keyTest:e=>e[S.CTRL_OR_CMD]&&e.shiftKey&&(e.key===S.CHEVRON_LEFT||e.key===S.COMMA)}),ph=N({name:"increaseFontSize",trackEvent:!1,perform:(e,t,r,o)=>dh(e,t,o,n=>Math.round(n.fontSize*(1+Fw))),keyTest:e=>e[S.CTRL_OR_CMD]&&e.shiftKey&&(e.key===S.CHEVRON_RIGHT||e.key===S.PERIOD)}),sC=N({name:"changeFontFamily",trackEvent:!1,perform:(e,t,r,o)=>({elements:Pr(e,t,n=>{if(G(n)){let i=te(n,{fontFamily:r,lineHeight:Tr(r)});return zt(i,o.scene.getContainerElement(n),o.scene.getNonDeletedElementsMap()),i}return n},!0),appState:{...t,currentItemFontFamily:r},commitToHistory:!0}),PanelComponent:({elements:e,appState:t,updateData:r,app:o})=>{let n=[{value:it.Virgil,text:b("labels.handDrawn"),icon:ul,testId:"font-family-virgil"},{value:it.Helvetica,text:b("labels.normal"),icon:Ry,testId:"font-family-normal"},{value:it.Cascadia,text:b("labels.code"),icon:Ny,testId:"font-family-code"}];return Lr("fieldset",{children:[ve("legend",{children:b("labels.fontFamily")}),ve(Wo,{group:"font-family",options:n,value:fr(e,t,i=>{if(G(i))return i.fontFamily;let a=ae(i,o.scene.getNonDeletedElementsMap());return a?a.fontFamily:null},i=>G(i)||ae(i,o.scene.getNonDeletedElementsMap())!==null,i=>i?null:t.currentItemFontFamily||Ot),onChange:i=>r(i)})]})}}),cC=N({name:"changeTextAlign",trackEvent:!1,perform:(e,t,r,o)=>({elements:Pr(e,t,n=>{if(G(n)){let i=te(n,{textAlign:r});return zt(i,o.scene.getContainerElement(n),o.scene.getNonDeletedElementsMap()),i}return n},!0),appState:{...t,currentItemTextAlign:r},commitToHistory:!0}),PanelComponent:({elements:e,appState:t,updateData:r,app:o})=>{let n=o.scene.getNonDeletedElementsMap();return Lr("fieldset",{children:[ve("legend",{children:b("labels.textAlign")}),ve(Wo,{group:"text-align",options:[{value:"left",text:b("labels.left"),icon:By,testId:"align-left"},{value:"center",text:b("labels.center"),icon:Oy,testId:"align-horizontal-center"},{value:"right",text:b("labels.right"),icon:Fy,testId:"align-right"}],value:fr(e,t,i=>{if(G(i))return i.textAlign;let a=ae(i,n);return a?a.textAlign:null},i=>G(i)||ae(i,n)!==null,i=>i?null:t.currentItemTextAlign),onChange:i=>r(i)})]})}}),dC=N({name:"changeVerticalAlign",trackEvent:{category:"element"},perform:(e,t,r,o)=>({elements:Pr(e,t,n=>{if(G(n)){let i=te(n,{verticalAlign:r});return zt(i,o.scene.getContainerElement(n),o.scene.getNonDeletedElementsMap()),i}return n},!0),appState:{...t},commitToHistory:!0}),PanelComponent:({elements:e,appState:t,updateData:r,app:o})=>ve("fieldset",{children:ve(Wo,{group:"text-align",options:[{value:gt.TOP,text:b("labels.alignTop"),icon:ve(Hy,{theme:t.theme}),testId:"align-top"},{value:gt.MIDDLE,text:b("labels.centerVertically"),icon:ve(Gy,{theme:t.theme}),testId:"align-middle"},{value:gt.BOTTOM,text:b("labels.alignBottom"),icon:ve(zy,{theme:t.theme}),testId:"align-bottom"}],value:fr(e,t,n=>{if(G(n)&&n.containerId)return n.verticalAlign;let i=ae(n,o.scene.getNonDeletedElementsMap());return i?i.verticalAlign:null},n=>G(n)||ae(n,o.scene.getNonDeletedElementsMap())!==null,n=>n?null:gt.MIDDLE),onChange:n=>r(n)})})}),tW=N({name:"changeRoundness",trackEvent:!1,perform:(e,t,r)=>({elements:Pr(e,t,o=>te(o,{roundness:r==="round"?{type:Do(o.type)?tt.ADAPTIVE_RADIUS:tt.PROPORTIONAL_RADIUS}:null})),appState:{...t,currentItemRoundness:r},commitToHistory:!0}),PanelComponent:({elements:e,appState:t,updateData:r})=>{let n=la(be(e),t).some(i=>i.roundness?.type===tt.LEGACY);return Lr("fieldset",{children:[ve("legend",{children:b("labels.edges")}),ve(Wo,{group:"edges",options:[{value:"sharp",text:b("labels.sharp"),icon:yy},{value:"round",text:b("labels.round"),icon:wy}],value:fr(e,t,i=>n?null:i.roundness?"round":"sharp",i=>i.hasOwnProperty("roundness"),i=>i?null:t.currentItemRoundness),onChange:i=>r(i)})]})}}),Ow=e=>[{value:null,text:b("labels.arrowhead_none"),keyBinding:"q",icon:vy},{value:"arrow",text:b("labels.arrowhead_arrow"),keyBinding:"w",icon:ve(Ty,{flip:e})},{value:"bar",text:b("labels.arrowhead_bar"),keyBinding:"e",icon:ve(Iy,{flip:e})},{value:"dot",text:b("labels.arrowhead_circle"),keyBinding:null,icon:ve(Yg,{flip:e}),showInPicker:!1},{value:"circle",text:b("labels.arrowhead_circle"),keyBinding:"r",icon:ve(Yg,{flip:e}),showInPicker:!1},{value:"circle_outline",text:b("labels.arrowhead_circle_outline"),keyBinding:null,icon:ve(Sy,{flip:e}),showInPicker:!1},{value:"triangle",text:b("labels.arrowhead_triangle"),icon:ve(Cy,{flip:e}),keyBinding:"t"},{value:"triangle_outline",text:b("labels.arrowhead_triangle_outline"),icon:ve(ky,{flip:e}),keyBinding:null,showInPicker:!1},{value:"diamond",text:b("labels.arrowhead_diamond"),icon:ve(Ay,{flip:e}),keyBinding:null,showInPicker:!1},{value:"diamond_outline",text:b("labels.arrowhead_diamond_outline"),icon:ve(My,{flip:e}),keyBinding:null,showInPicker:!1}],rW=N({name:"changeArrowhead",trackEvent:!1,perform:(e,t,r)=>({elements:Pr(e,t,o=>{if(ee(o)){let{position:n,type:i}=r;if(n==="start")return te(o,{startArrowhead:i});if(n==="end")return te(o,{endArrowhead:i})}return o}),appState:{...t,[r.position==="start"?"currentItemStartArrowhead":"currentItemEndArrowhead"]:r.type},commitToHistory:!0}),PanelComponent:({elements:e,appState:t,updateData:r})=>{let o=Qo().rtl;return Lr("fieldset",{children:[ve("legend",{children:b("labels.arrowheads")}),Lr("div",{className:"iconSelectList buttonList",children:[ve(ch,{label:"arrowhead_start",options:Ow(!o),value:fr(e,t,n=>ee(n)&&Fi(n.type)?n.startArrowhead:t.currentItemStartArrowhead,!0,t.currentItemStartArrowhead),onChange:n=>r({position:"start",type:n})}),ve(ch,{label:"arrowhead_end",group:"arrowheads",options:Ow(!!o),value:fr(e,t,n=>ee(n)&&Fi(n.type)?n.endArrowhead:t.currentItemEndArrowhead,!0,t.currentItemEndArrowhead),onChange:n=>r({position:"end",type:n})})]})]})}});h();W();me();de();We();Ug();pm();F();ze();h();import{useEffect as mC}from"react";import{jsx as uC}from"react/jsx-runtime";var wl=()=>{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},uh=(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`})},pC=(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();uh(t,n)},_r=({children:e,label:t,long:r=!1,style:o,disabled:n})=>(mC(()=>()=>wl().classList.remove("excalidraw-tooltip--visible"),[]),n?null:uC("div",{className:"excalidraw-tooltip-wrapper",onPointerEnter:i=>pC(i.currentTarget,wl(),t,r),onPointerLeave:()=>wl().classList.remove("excalidraw-tooltip--visible"),style:o,children:e}));He();Sr();Vt();Za();import{jsx as Pm,jsxs as xC}from"react/jsx-runtime";var gC=N({name:"changeViewBackgroundColor",trackEvent:!1,predicate:(e,t,r,o)=>!!o.props.UIOptions.canvasActions.changeViewBackgroundColor&&!t.viewModeEnabled,perform:(e,t,r)=>({appState:{...t,...r},commitToHistory:!!r.viewBackgroundColor}),PanelComponent:({elements:e,appState:t,updateData:r,appProps:o})=>Pm(Xs,{palette:null,topPicks:Ac,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})}),Zs=N({name:"clearCanvas",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=>te(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},commitToHistory:!0})}),Am=N({name:"zoomIn",viewMode:!0,trackEvent:{category:"canvas"},perform:(e,t,r,o)=>({appState:{...t,...In({viewportX:t.width/2+t.offsetLeft,viewportY:t.height/2+t.offsetTop,nextZoom:Uo(t.zoom.value+Di)},t),userToFollow:null},commitToHistory:!1}),PanelComponent:({updateData:e})=>Pm(ne,{type:"button",className:"zoom-in-button zoom-button",icon:A0,title:`${b("buttons.zoomIn")} \u2014 ${_("CtrlOrCmd++")}`,"aria-label":b("buttons.zoomIn"),onClick:()=>{e(null)}}),keyTest:e=>(e.code===ue.EQUAL||e.code===ue.NUM_ADD)&&(e[S.CTRL_OR_CMD]||e.shiftKey)}),Mm=N({name:"zoomOut",viewMode:!0,trackEvent:{category:"canvas"},perform:(e,t,r,o)=>({appState:{...t,...In({viewportX:t.width/2+t.offsetLeft,viewportY:t.height/2+t.offsetTop,nextZoom:Uo(t.zoom.value-Di)},t),userToFollow:null},commitToHistory:!1}),PanelComponent:({updateData:e})=>Pm(ne,{type:"button",className:"zoom-out-button zoom-button",icon:M0,title:`${b("buttons.zoomOut")} \u2014 ${_("CtrlOrCmd+-")}`,"aria-label":b("buttons.zoomOut"),onClick:()=>{e(null)}}),keyTest:e=>(e.code===ue.MINUS||e.code===ue.NUM_SUBTRACT)&&(e[S.CTRL_OR_CMD]||e.shiftKey)}),hC=N({name:"resetZoom",viewMode:!0,trackEvent:{category:"canvas"},perform:(e,t,r,o)=>({appState:{...t,...In({viewportX:t.width/2+t.offsetLeft,viewportY:t.height/2+t.offsetTop,nextZoom:Uo(1)},t),userToFollow:null},commitToHistory:!1}),PanelComponent:({updateData:e,appState:t})=>Pm(_r,{label:b("buttons.resetZoom"),style:{height:"100%"},children:xC(ne,{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===ue.ZERO||e.code===ue.NUM_ZERO)&&(e[S.CTRL_OR_CMD]||e.shiftKey)}),fC=(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/Di)*Di;return Math.min(Math.max(m,Dc),1)},zw=({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,g=l-i;d=Math.min(t.width/u,t.height/g)*Math.min(1,Math.max(o,.1)),d=Math.min(Math.max(d,.1),30);let f=t.width;if(t.openSidebar){let y=document.querySelector(".sidebar")?.offsetWidth??0;f=document.documentElement.getAttribute("dir")==="rtl"?t.width+y:t.width-y}m=f/2*(1/d)-s,p=t.height/2*(1/d)-c}else{d=fC(e,{width:t.width,height:t.height});let u=Gg({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}},js=({targetElements:e,appState:t,fitToViewport:r,viewportZoomFactor:o})=>{let n=ye(be(e));return zw({bounds:n,appState:t,fitToViewport:r,viewportZoomFactor:o})},PW=N({name:"zoomToFitSelectionInViewport",trackEvent:{category:"canvas"},perform:(e,t,r,o)=>{let n=o.scene.getSelectedElements(t);return js({targetElements:n.length?n:e,appState:{...t,userToFollow:null},fitToViewport:!1})},keyTest:e=>e.code===ue.TWO&&e.shiftKey&&!e.altKey&&!e[S.CTRL_OR_CMD]}),_W=N({name:"zoomToFitSelection",trackEvent:{category:"canvas"},perform:(e,t,r,o)=>{let n=o.scene.getSelectedElements(t);return js({targetElements:n.length?n:e,appState:{...t,userToFollow:null},fitToViewport:!0})},keyTest:e=>e.code===ue.THREE&&e.shiftKey&&!e.altKey&&!e[S.CTRL_OR_CMD]}),bC=N({name:"zoomToFit",viewMode:!0,trackEvent:{category:"canvas"},perform:(e,t)=>js({targetElements:e,appState:{...t,userToFollow:null},fitToViewport:!1}),keyTest:e=>e.code===ue.ONE&&e.shiftKey&&!e.altKey&&!e[S.CTRL_OR_CMD]}),Lm=N({name:"toggleTheme",viewMode:!0,trackEvent:{category:"canvas"},perform:(e,t,r)=>({appState:{...t,theme:r||(t.theme===qe.LIGHT?qe.DARK:qe.LIGHT)},commitToHistory:!1}),keyTest:e=>e.altKey&&e.shiftKey&&e.code===ue.D,predicate:(e,t,r,o)=>!!o.props.UIOptions.canvasActions.toggleTheme}),DW=N({name:"toggleEraserTool",trackEvent:{category:"toolbar"},perform:(e,t)=>{let r;return ur(t)?r=Ke(t,{...t.activeTool.lastActiveTool||{type:"selection"},lastActiveToolBeforeEraser:null}):r=Ke(t,{type:"eraser",lastActiveToolBeforeEraser:t.activeTool}),{appState:{...t,selectedElementIds:{},selectedGroupIds:{},activeEmbeddable:null,activeTool:r},commitToHistory:!0}},keyTest:e=>e.key===S.E}),Gw=N({name:"toggleHandTool",trackEvent:{category:"toolbar"},perform:(e,t,r,o)=>{let n;return xo(t)?n=Ke(t,{...t.activeTool.lastActiveTool||{type:"selection"},lastActiveToolBeforeEraser:null}):(n=Ke(t,{type:"hand",lastActiveToolBeforeEraser:t.activeTool}),De(o.interactiveCanvas,Se.GRAB)),{appState:{...t,selectedElementIds:{},selectedGroupIds:{},activeEmbeddable:null,activeTool:n},commitToHistory:!0}},keyTest:e=>!e.altKey&&!e[S.CTRL_OR_CMD]&&e.key===S.H});h();de();me();F();ze();He();Ht();$t();nn();ho();oe();Za();import{jsx as EC}from"react/jsx-runtime";var Zr=N({name:"finalize",trackEvent:!1,perform:(e,t,r,{interactiveCanvas:o,focusContainer:n,scene:i})=>{let a=i.getNonDeletedElementsMap();if(t.editingLinearElement){let{elementId:m,startBindingElement:p,endBindingElement:u}=t.editingLinearElement,g=V.getElement(m,a);if(g)return Et(g)&&cn(g,p,u,a),{elements:g.points.length<2||Wr(g)?e.filter(f=>f.id!==g.id):void 0,appState:{...t,cursorButton:"up",editingLinearElement:null},commitToHistory:!0}}let l=e,s=t.pendingImageElementId&&i.getElement(t.pendingImageElementId);s&&B(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)&&B(c,{points:c.points.slice(0,-1)})}Wr(c)&&(l=l.filter(p=>p.id!==c.id));let m=dr(c.points,t.zoom.value);if((c.type==="line"||c.type==="freedraw")&&m){let p=c.points,u=p[0];B(c,{points:p.map((g,f)=>f===p.length-1?[u[0],u[1]]:g)})}if(Et(c)&&!m&&c.points.length>1){let[p,u]=V.getPointAtIndexGlobalCoordinates(c,-1,J(e));Es(c,t,rt.getScene(c),{x:p,y:u},a)}}(!t.activeTool.locked&&t.activeTool.type!=="freedraw"||!c)&&Cr(o);let d;return t.activeTool.type==="eraser"?d=Ke(t,{...t.activeTool.lastActiveTool||{type:"selection"},lastActiveToolBeforeEraser:null}):d=Ke(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&&ee(c)?new V(c):t.selectedLinearElement,pendingImageElementId:null},commitToHistory:t.activeTool.type==="freedraw"}},keyTest:(e,t)=>e.key===S.ESCAPE&&(t.editingLinearElement!==null||!t.draggingElement&&t.multiElement===null)||(e.key===S.ESCAPE||e.key===S.ENTER)&&t.multiElement!==null,PanelComponent:({appState:e,updateData:t,data:r})=>EC(ne,{type:"button",icon:W0,title:b("buttons.done"),"aria-label":b("buttons.done"),onClick:t,visible:e.multiElement!=null,size:r?.size||"medium"})});h();h();F();import{useState as yC}from"react";de();import{jsx as Uw,jsxs as wC}from"react/jsx-runtime";var Ww=e=>{let{id:t}=_t(),[r,o]=yC(e.value),n=a=>{e.ignoreFocus||n1(a.target);let l=a.target.value;l!==e.value&&e.onChange(l)},i=a=>{if(a.key===S.ENTER){if(a.preventDefault(),a.nativeEvent.isComposing||a.keyCode===229)return;a.currentTarget.blur()}};return wC("div",{className:"ProjectName",children:[Uw("label",{className:"ProjectName-label",htmlFor:"filename",children:`${e.label}:`}),Uw("input",{type:"text",className:"TextInput",onBlur:n,onKeyDown:i,id:`${t}-filename`,value:r,onChange:a=>o(a.target.value)})]})};h();W();import{jsx as qs}from"react/jsx-runtime";var Yw=e=>{let t=e.title||(e.value==="dark"?b("buttons.lightMode"):b("buttons.darkMode"));return qs(ne,{type:"icon",icon:e.value===qe.LIGHT?Vw.MOON:Vw.SUN,title:t,"aria-label":t,onClick:()=>e.onChange(e.value===qe.DARK?qe.LIGHT:qe.DARK),"data-testid":"toggle-dark-mode"})},Vw={SUN:qs("svg",{width:"512",height:"512",className:"rtl-mirror",viewBox:"0 0 512 512",children:qs("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:qs("svg",{width:"512",height:"512",className:"rtl-mirror",viewBox:"0 0 512 512",children:qs("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"})})};h();oi();W();me();oe();We();Fs();F();gr();En();vn();Xt();gr();vn();var da=(e,{selectedElementIds:t},r)=>{e=be(e);let o=r&&Re(e,{selectedElementIds:t}),n=null,i=o?pe(e,{selectedElementIds:t},{includeBoundTextElement:!0}):e;return o&&(i.length===1&&X(i[0])?(n=i[0],i=al(e,n)):i.length>1&&(i=pe(e,{selectedElementIds:t},{includeBoundTextElement:!0,includeElementsInFrames:!0}))),{exportingFrame:n,exportedElements:Po(i)}},ma=async(e,t,r,o,{exportBackground:n,exportPadding:i=ao,viewBackgroundColor:a,name:l=r.name||zc,fileHandle:s=null,exportingFrame:c=null})=>{if(t.length===0)throw new Error(b("alerts.cannotExportEmptyCanvas"));if(e==="svg"||e==="clipboard-svg"){let m=il(t,{exportBackground:n,exportWithDarkMode:r.exportWithDarkMode,viewBackgroundColor:a,exportPadding:i,exportScale:r.exportScale,exportEmbedScene:r.exportEmbedScene&&e==="svg"},o,{exportingFrame:c});if(e==="svg")return Qa(m.then(p=>new Blob([p.outerHTML],{type:$.svg})),{description:"Export to SVG",name:l,extension:r.exportEmbedScene?"excalidraw.svg":"svg",fileHandle:s});if(e==="clipboard-svg"){let p=await m.then(u=>u.outerHTML);try{await Sn(p)}catch{throw new Error(b("errors.copyToSystemClipboardFailed"))}return}}let d=Yd(t,r,o,{exportBackground:n,viewBackgroundColor:a,exportPadding:i,exportingFrame:c});if(e==="png"){let m=wn(d);return r.exportEmbedScene&&(m=m.then(p=>Promise.resolve().then(()=>(rl(),_s)).then(({encodePngMetadata:u})=>u({blob:p,metadata:ti(t,r,o,"local")})))),Qa(m,{description:"Export to PNG",name:l,extension:"png",fileHandle:s})}else if(e==="clipboard")try{let m=wn(d);await qd(m)}catch(m){throw console.warn(m),m.name==="CANVAS_POSSIBLY_TOO_BIG"?new Error(b("canvasError.canvasTooBig")):Nn&&m.name==="TypeError"?new Error(`${b("alerts.couldNotCopyToClipboard")}
|
|
57
56
|
|
|
58
|
-
${f("hints.firefox_clipboard_write")}`):new Error(f("alerts.couldNotCopyToClipboard"))}else throw new Error("Unsupported export type")}});var Qv,e3=y(()=>{"use strict";h();Fl();vr();Qv=async(e,t,r)=>{let{exportBackground:o,viewBackgroundColor:n,name:i,fileHandle:a}=t,l=bh(a);if(!a||!ev(l))throw new Error("fileHandle should exist and should be of type svg or png when resaving");t={...t,exportEmbedScene:!0};let{exportedElements:c,exportingFrame:s}=wa(e,t,!1);return await va(l,c,t,r,{exportBackground:o,viewBackgroundColor:n,name:i,fileHandle:a,exportingFrame:s}),{fileHandle:a}}});var t3=y(()=>{});import l8 from"clsx";import{jsx as r3,jsxs as s8}from"react/jsx-runtime";var Ta,au=y(()=>{"use strict";h();se();t3();Ta=({children:e,checked:t,onChange:r,className:o})=>s8("div",{className:l8("Checkbox",o,{"is-checked":t}),onClick:n=>{r(!t,n),n.currentTarget.querySelector(".Checkbox-box").focus()},children:[r3("button",{className:"Checkbox-box",role:"checkbox","aria-checked":t,children:OE}),r3("div",{className:"Checkbox-label",children:e})]})});import{Fragment as c8,jsx as Pn,jsxs as d8}from"react/jsx-runtime";var qh,o3,Jh,lu,su,fc,Hl,n3,bc=y(()=>{"use strict";h();se();Zv();Lt();ai();Jv();Fl();e3();Y();be();me();We();au();mc();X();Ze();ue();vr();kn();pn();qh=N({name:"changeProjectName",trackEvent:!1,perform:(e,t,r)=>({appState:{...t,name:r},commitToHistory:!1}),PanelComponent:({appState:e,updateData:t,appProps:r,data:o})=>Pn(Xv,{label:f("labels.fileTitle"),value:e.name||"Unnamed",onChange:n=>t(n),isNameEditable:typeof r.name>"u"&&!e.viewModeEnabled,ignoreFocus:o?.ignoreFocus??!1})}),o3=N({name:"changeExportScale",trackEvent:{category:"export",action:"scale"},perform:(e,t,r)=>({appState:{...t,exportScale:r},commitToHistory:!1}),PanelComponent:({elements:e,appState:t,updateData:r})=>{let o=ce(e),i=ze(o,t)?ge(o,t):o;return Pn(c8,{children:Na.map(a=>{let[l,c]=pv(i,bo,a),s=`${f("imageExportDialog.label.scale")} ${a}x (${l}x${c})`;return Pn(ne,{size:"small",type:"radio",icon:`${a}x`,name:"export-canvas-scale",title:s,"aria-label":s,id:"export-canvas-scale",checked:a===t.exportScale,onChange:()=>r(a)},a)})})}}),Jh=N({name:"changeExportBackground",trackEvent:{category:"export",action:"toggleBackground"},perform:(e,t,r)=>({appState:{...t,exportBackground:r},commitToHistory:!1}),PanelComponent:({appState:e,updateData:t})=>Pn(Ta,{checked:e.exportBackground,onChange:r=>t(r),children:f("imageExportDialog.label.withBackground")})}),lu=N({name:"changeExportEmbedScene",trackEvent:{category:"export",action:"embedScene"},perform:(e,t,r)=>({appState:{...t,exportEmbedScene:r},commitToHistory:!1}),PanelComponent:({appState:e,updateData:t})=>d8(Ta,{checked:e.exportEmbedScene,onChange:r=>t(r),children:[f("imageExportDialog.label.embedScene"),Pn(Rr,{label:f("imageExportDialog.tooltip.embedScene"),long:!0,children:Pn("div",{className:"excalidraw-tooltip-icon",children:KE})})]})}),su=N({name:"saveToActiveFile",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}=_l(t.fileHandle)?await Qv(e,t,o.files):await Um(e,t,o.files);return{commitToHistory:!1,appState:{...t,fileHandle:i,toast:n?{message:i?.name?f("toast.fileSavedToFilename").replace("{filename}",`"${i.name}"`):f("toast.fileSaved")}:null}}}catch(i){return i?.name!=="AbortError"?console.error(i):console.warn(i),{commitToHistory:!1}}},keyTest:e=>e.key===S.S&&e[S.CTRL_OR_CMD]&&!e.shiftKey}),fc=N({name:"saveFileToDisk",viewMode:!0,trackEvent:{category:"export"},perform:async(e,t,r,o)=>{try{let{fileHandle:n}=await Um(e,{...t,fileHandle:null},o.files);return{commitToHistory:!1,appState:{...t,openDialog:null,fileHandle:n,toast:{message:f("toast.fileSaved")}}}}catch(n){return n?.name!=="AbortError"?console.error(n):console.warn(n),{commitToHistory:!1}}},keyTest:e=>e.key===S.S&&e.shiftKey&&e[S.CTRL_OR_CMD],PanelComponent:({updateData:e})=>Pn(ne,{type:"button",icon:HE,title:f("buttons.saveAs"),"aria-label":f("buttons.saveAs"),showAriaLabel:De().editor.isMobile,hidden:!bi,onClick:()=>e(null),"data-testid":"save-as-button"})}),Hl=N({name:"loadScene",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 vh(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:o.files,commitToHistory:!1}}},keyTest:e=>e[S.CTRL_OR_CMD]&&e.key===S.O}),n3=N({name:"exportWithDarkMode",trackEvent:{category:"export",action:"toggleTheme"},perform:(e,t,r)=>({appState:{...t,exportWithDarkMode:r},commitToHistory:!1}),PanelComponent:({appState:e,updateData:t})=>Pn("div",{style:{display:"flex",justifyContent:"flex-end",marginTop:"-45px",marginBottom:"10px"},children:Pn(qv,{value:e.exportWithDarkMode?nt.DARK:nt.LIGHT,onChange:r=>{t(r===nt.DARK)},title:f("imageExportDialog.label.darkMode")})})})});var i3,Qh,ef,a3=y(()=>{"use strict";h();ue();me();Y();We();Ve();X();pt();ae();Ze();i3="{}",Qh=N({name:"copyStyles",trackEvent:{category:"element"},perform:(e,t)=>{let r=[],o=e.find(n=>t.selectedElementIds[n.id]);if(r.push(o),o&&pr(o)){let n=le(o);r.push(n)}return o&&(i3=JSON.stringify(r)),{appState:{...t,toast:{message:f("toast.copyStyles")}},commitToHistory:!1}},contextItemLabel:"labels.copyStyles",keyTest:e=>e[S.CTRL_OR_CMD]&&e.altKey&&e.code===de.C}),ef=N({name:"pasteStyles",trackEvent:{category:"element"},perform:(e,t)=>{let r=JSON.parse(i3),o=r[0],n=r[1];if(!za(o))return{elements:e,commitToHistory:!1};let i=ge(e,t,{includeBoundTextElement:!0}),a=i.map(l=>l.id);return{elements:e.map(l=>{if(a.includes(l.id)){let c=o;if(z(l)&&l.containerId&&(c=n),!c)return l;let s=Q(l,{backgroundColor:c?.backgroundColor,strokeWidth:c?.strokeWidth,strokeColor:c?.strokeColor,strokeStyle:c?.strokeStyle,fillStyle:c?.fillStyle,opacity:c?.opacity,roughness:c?.roughness,roundness:c.roundness?Tx(c.roundness.type,l)?c.roundness:Ix(l):null});if(z(s)){let d=c.fontSize||Ct,m=c.fontFamily||Ft;s=Q(s,{fontSize:d,fontFamily:m,textAlign:c.textAlign||Kn,lineHeight:c.lineHeight||Dr(m)});let u=null;s.containerId&&(u=i.find(p=>z(s)&&p.id===s.containerId)||null),Gt(s,u)}return s.type==="arrow"&&ve(c)&&(s=Q(s,{startArrowhead:c.startArrowhead,endArrowhead:c.endArrowhead})),J(l)&&(s=Q(s,{roundness:null,backgroundColor:"transparent"})),s}return l}),commitToHistory:!0}},contextItemLabel:"labels.pasteStyles",keyTest:e=>e[S.CTRL_OR_CMD]&&e.altKey&&e.code===de.V})});import{jsx as l3}from"react/jsx-runtime";var m8,u8,Ia,s3=y(()=>{"use strict";h();se();Lt();Y();ue();We();me();m8=N({name:"toggleCanvasMenu",trackEvent:{category:"menu"},perform:(e,t)=>({appState:{...t,openMenu:t.openMenu==="canvas"?null:"canvas"},commitToHistory:!1}),PanelComponent:({appState:e,updateData:t})=>l3(ne,{type:"button",icon:Dd,"aria-label":f("buttons.menu"),onClick:t,selected:e.openMenu==="canvas"})}),u8=N({name:"toggleEditMenu",trackEvent:{category:"menu"},perform:(e,t)=>({appState:{...t,openMenu:t.openMenu==="shape"?null:"shape"},commitToHistory:!1}),PanelComponent:({elements:e,appState:t,updateData:r})=>l3(ne,{visible:ya(t,ce(e)),type:"button",icon:zE,"aria-label":f("buttons.edit"),onClick:r,selected:t.openMenu==="shape"})}),Ia=N({name:"toggleShortcuts",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"}},commitToHistory:!1}),keyTest:e=>e.key===S.QUESTION_MARK})});import{jsx as cu}from"react/jsx-runtime";var p8,c3,tf,rf,d3=y(()=>{"use strict";h();me();Y();W();We();se();Ve();Ze();gr();ue();yo();Lt();ae();br();p8=e=>{if(e.length>=2){let t=e[0].groupIds;for(let r of t)if(e.reduce((o,n)=>o&&Qi(n,r),!0))return!0}return!1},c3=(e,t,r)=>{let o=r.scene.getSelectedElements({selectedElementIds:t.selectedElementIds,includeBoundTextElement:!0});return o.length>=2&&!p8(o)},tf=N({name:"group",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,commitToHistory:!1};let i=ln(t);if(i.length===1){let b=i[0],E=new Set(at(e,b).map(T=>T.id)),w=new Set(n.map(T=>T.id));if(new Set([...Array.from(E),...Array.from(w)]).size===E.size)return{appState:t,elements:e,commitToHistory:!1}}let a=[...e];new Set(n.map(b=>b.frameId)).size>1&&Ev(n).forEach((E,w)=>{a=Bl(a,E,t)});let c=Mt(),s=Ce(n);a=a.map(b=>s.get(b.id)?Q(b,{groupIds:Xx(b.groupIds,c,t.editingGroupId)}):b);let d=at(a,c),m=d[d.length-1],u=a.lastIndexOf(m),p=a.slice(u+1);return a=[...a.slice(0,u).filter(b=>!Qi(b,c)),...d,...p],{appState:{...t,...Xp(c,{...t,selectedGroupIds:{}},ce(a))},elements:a,commitToHistory:!0}},contextItemLabel:"labels.group",predicate:(e,t,r,o)=>c3(e,t,o),keyTest:e=>!e.shiftKey&&e[S.CTRL_OR_CMD]&&e.key===S.G,PanelComponent:({elements:e,appState:t,updateData:r,app:o})=>cu(ne,{hidden:!c3(e,t,o),type:"button",icon:cu(a0,{theme:t.theme}),onClick:()=>r(null),title:`${f("labels.group")} \u2014 ${_("CtrlOrCmd+G")}`,"aria-label":f("labels.group"),visible:ze(ce(e),t)})}),rf=N({name:"ungroup",trackEvent:{category:"element"},perform:(e,t,r,o)=>{if(ln(t).length===0)return{appState:t,elements:e,commitToHistory:!1};let i=[...e],a=[];i=i.map(m=>{ke(m)&&a.push(m.id);let u=Zx(m.groupIds,t.selectedGroupIds);return u.length===m.groupIds.length?m:Q(m,{groupIds:u})});let l=Ht(t,ce(i),t,null),c=o.scene.getSelectedElements(t),s=new Set(c.filter(m=>m.frameId).map(m=>m.frameId));return uc(e).filter(m=>s.has(m.id)).forEach(m=>{m&&(i=qm(i,Nl(i,m,t),m,t))}),l.selectedElementIds=Object.entries(l.selectedElementIds).reduce((m,[u,p])=>(p&&!a.includes(u)&&(m[u]=!0),m),{}),{appState:{...t,...l},elements:i,commitToHistory:!0}},keyTest:e=>e.shiftKey&&e[S.CTRL_OR_CMD]&&e.key===S.G.toUpperCase(),contextItemLabel:"labels.ungroup",predicate:(e,t)=>ln(t).length>0,PanelComponent:({elements:e,appState:t,updateData:r})=>cu(ne,{type:"button",hidden:ln(t).length===0,icon:cu(l0,{theme:t.theme}),onClick:()=>r(null),title:`${f("labels.ungroup")} \u2014 ${_("CtrlOrCmd+Shift+G")}`,"aria-label":f("labels.ungroup"),visible:ze(ce(e),t)})})});var m3=y(()=>{});import{useState as g8}from"react";import h8 from"clsx";import{jsx as u3}from"react/jsx-runtime";var of,p3=y(()=>{"use strict";h();m3();Es();of=({color:e,onClick:t,name:r,src:o,isBeingFollowed:n,isCurrentUser:i})=>{let a=Vx(r),[l,c]=g8(!1),s=!l&&o,d=s?void 0:{background:e};return u3("div",{className:h8("Avatar",{"Avatar--is-followed":n,"Avatar--is-current-user":i}),style:d,onClick:t,children:s?u3("img",{className:"Avatar-img",src:o,alt:a,referrerPolicy:"no-referrer",onError:()=>c(!0)}):a})}});import{jsx as nf,jsxs as b8}from"react/jsx-runtime";var f8,g3=y(()=>{"use strict";h();Es();p3();se();Y();We();f8=N({name:"goToCollaborator",viewMode:!0,trackEvent:{category:"collab"},perform:(e,t,r)=>!r.socketId||t.userToFollow?.socketId===r.socketId||r.isCurrentUser?{appState:{...t,userToFollow:null},commitToHistory:!1}:{appState:{...t,userToFollow:{socketId:r.socketId,username:r.username||""},openMenu:t.openMenu==="canvas"?null:t.openMenu},commitToHistory:!1},PanelComponent:({updateData:e,data:t,appState:r})=>{let{clientId:o,collaborator:n,withName:i,isBeingFollowed:a}=t,l=Ji(o);return i?b8("div",{className:"dropdown-menu-item dropdown-menu-item-base UserList__collaborator",onClick:()=>e(n),children:[nf(of,{color:l,onClick:()=>{},name:n.username||"",src:n.avatarUrl,isBeingFollowed:a,isCurrentUser:n.isCurrentUser===!0}),n.username,nf("div",{className:"UserList__collaborator-follow-status-icon",style:{visibility:a?"visible":"hidden"},title:a?f("userList.hint.followStatus"):void 0,"aria-hidden":!0,children:Hd})]}):nf(of,{color:l,onClick:()=>{e(n)},name:n.username||"",src:n.avatarUrl,isBeingFollowed:a,isCurrentUser:n.isCurrentUser===!0})}})});var af,h3=y(()=>{"use strict";h();We();dn();yo();Y();X();af=N({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 sd)if(n.some(a=>a.type===i))return{commitToHistory:!1,appState:{...t,errorMessage:f(`errors.libraryElementTypeError.${i}`)}};return o.library.getLatestLibrary().then(i=>o.library.setLibrary([{id:Mt(),status:"unpublished",elements:n.map(cn),created:Date.now()},...i])).then(()=>({commitToHistory:!1,appState:{...t,toast:{message:f("toast.addedToLibrary")}}})).catch(i=>({commitToHistory:!1,appState:{...t,errorMessage:i.message}}))},contextItemLabel:"labels.addToLibrary"})});var f3,x8,b3=y(()=>{"use strict";h();Ve();yt();gr();f3=(e,t)=>{let r=ea(e),o=wr(e);return r.flatMap(n=>{let i=x8(n,o,t);return n.map(a=>Q(a,{x:a.x+i.x,y:a.y+i.y}))})},x8=(e,t,{axis:r,position:o})=>{let n=wr(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 Gl}from"react/jsx-runtime";var so,zl,E8,y8,w8,v8,T8,I8,x3=y(()=>{"use strict";h();b3();se();Lt();ue();ae();br();Y();me();Ze();W();We();so=(e,t,r,o)=>{let n=o.scene.getSelectedElements(t);return n.length>1&&!n.some(i=>J(i))},zl=(e,t,r,o)=>{let n=r.scene.getSelectedElements(t),i=f3(n,o),a=Ce(i);return Xo(e.map(l=>a.get(l.id)||l),t,r)},E8=N({name:"alignTop",trackEvent:{category:"element"},predicate:so,perform:(e,t,r,o)=>({appState:t,elements:zl(e,t,o,{position:"start",axis:"y"}),commitToHistory:!0}),keyTest:e=>e[S.CTRL_OR_CMD]&&e.shiftKey&&e.key===S.ARROW_UP,PanelComponent:({elements:e,appState:t,updateData:r,app:o})=>Gl(ne,{hidden:!so(e,t,null,o),type:"button",icon:qE,onClick:()=>r(null),title:`${f("labels.alignTop")} \u2014 ${_("CtrlOrCmd+Shift+Up")}`,"aria-label":f("labels.alignTop"),visible:ze(ce(e),t)})}),y8=N({name:"alignBottom",trackEvent:{category:"element"},predicate:so,perform:(e,t,r,o)=>({appState:t,elements:zl(e,t,o,{position:"end",axis:"y"}),commitToHistory:!0}),keyTest:e=>e[S.CTRL_OR_CMD]&&e.shiftKey&&e.key===S.ARROW_DOWN,PanelComponent:({elements:e,appState:t,updateData:r,app:o})=>Gl(ne,{hidden:!so(e,t,null,o),type:"button",icon:JE,onClick:()=>r(null),title:`${f("labels.alignBottom")} \u2014 ${_("CtrlOrCmd+Shift+Down")}`,"aria-label":f("labels.alignBottom"),visible:ze(ce(e),t)})}),w8=N({name:"alignLeft",trackEvent:{category:"element"},predicate:so,perform:(e,t,r,o)=>({appState:t,elements:zl(e,t,o,{position:"start",axis:"x"}),commitToHistory:!0}),keyTest:e=>e[S.CTRL_OR_CMD]&&e.shiftKey&&e.key===S.ARROW_LEFT,PanelComponent:({elements:e,appState:t,updateData:r,app:o})=>Gl(ne,{hidden:!so(e,t,null,o),type:"button",icon:QE,onClick:()=>r(null),title:`${f("labels.alignLeft")} \u2014 ${_("CtrlOrCmd+Shift+Left")}`,"aria-label":f("labels.alignLeft"),visible:ze(ce(e),t)})}),v8=N({name:"alignRight",trackEvent:{category:"element"},predicate:so,perform:(e,t,r,o)=>({appState:t,elements:zl(e,t,o,{position:"end",axis:"x"}),commitToHistory:!0}),keyTest:e=>e[S.CTRL_OR_CMD]&&e.shiftKey&&e.key===S.ARROW_RIGHT,PanelComponent:({elements:e,appState:t,updateData:r,app:o})=>Gl(ne,{hidden:!so(e,t,null,o),type:"button",icon:e0,onClick:()=>r(null),title:`${f("labels.alignRight")} \u2014 ${_("CtrlOrCmd+Shift+Right")}`,"aria-label":f("labels.alignRight"),visible:ze(ce(e),t)})}),T8=N({name:"alignVerticallyCentered",trackEvent:{category:"element"},predicate:so,perform:(e,t,r,o)=>({appState:t,elements:zl(e,t,o,{position:"center",axis:"y"}),commitToHistory:!0}),PanelComponent:({elements:e,appState:t,updateData:r,app:o})=>Gl(ne,{hidden:!so(e,t,null,o),type:"button",icon:o0,onClick:()=>r(null),title:f("labels.centerVertically"),"aria-label":f("labels.centerVertically"),visible:ze(ce(e),t)})}),I8=N({name:"alignHorizontallyCentered",trackEvent:{category:"element"},predicate:so,perform:(e,t,r,o)=>({appState:t,elements:zl(e,t,o,{position:"center",axis:"x"}),commitToHistory:!0}),PanelComponent:({elements:e,appState:t,updateData:r,app:o})=>Gl(ne,{hidden:!so(e,t,null,o),type:"button",icon:n0,onClick:()=>r(null),title:f("labels.centerHorizontally"),"aria-label":f("labels.centerHorizontally"),visible:ze(ce(e),t)})})});var E3,y3=y(()=>{"use strict";h();Ve();gr();yt();E3=(e,t)=>{let[r,o,n,i]=t.axis==="x"?["minX","midX","maxX","width"]:["minY","midY","maxY","height"],a=wr(e),l=ea(e).map(m=>[m,wr(m)]).sort((m,u)=>m[1][o]-u[1][o]),c=0;for(let m of l)c+=m[1][i];let s=(a[i]-c)/(l.length-1);if(s<0){let m=l.findIndex(b=>b[1][r]===a[r]),u=l.findIndex(b=>b[1][n]===a[n]),p=(l[u][1][o]-l[m][1][o])/(l.length-1),g=l[m][1][o];return l.flatMap(([b,E],w)=>{let v={x:0,y:0};return w!==m&&w!==u&&(g+=p,v[t.axis]=g-E[o]),b.map(T=>Q(T,{x:T.x+v.x,y:T.y+v.y}))})}let d=a[r];return l.flatMap(([m,u])=>{let p={x:0,y:0};return p[t.axis]=d-u[r],d+=s,d+=u[i],m.map(g=>Q(g,{x:g.x+p.x,y:g.y+p.y}))})}});import{jsx as T3}from"react/jsx-runtime";var w3,v3,S8,C8,I3=y(()=>{"use strict";h();se();Lt();y3();ue();ae();br();Y();me();Ze();W();We();w3=(e,t)=>{let r=t.scene.getSelectedElements(e);return r.length>1&&!r.some(o=>J(o))},v3=(e,t,r,o)=>{let n=r.scene.getSelectedElements(t),i=E3(n,o),a=Ce(i);return Xo(e.map(l=>a.get(l.id)||l),t,r)},S8=N({name:"distributeHorizontally",trackEvent:{category:"element"},perform:(e,t,r,o)=>({appState:t,elements:v3(e,t,o,{space:"between",axis:"x"}),commitToHistory:!0}),keyTest:e=>!e[S.CTRL_OR_CMD]&&e.altKey&&e.code===de.H,PanelComponent:({elements:e,appState:t,updateData:r,app:o})=>T3(ne,{hidden:!w3(t,o),type:"button",icon:t0,onClick:()=>r(null),title:`${f("labels.distributeHorizontally")} \u2014 ${_("Alt+H")}`,"aria-label":f("labels.distributeHorizontally"),visible:ze(ce(e),t)})}),C8=N({name:"distributeVertically",trackEvent:{category:"element"},perform:(e,t,r,o)=>({appState:t,elements:v3(e,t,o,{space:"between",axis:"y"}),commitToHistory:!0}),keyTest:e=>!e[S.CTRL_OR_CMD]&&e.altKey&&e.code===de.V,PanelComponent:({elements:e,appState:t,updateData:r,app:o})=>T3(ne,{hidden:!w3(t,o),type:"button",icon:r0,onClick:()=>r(null),title:`${f("labels.distributeVertically")} \u2014 ${_("Alt+V")}`,"aria-label":f("labels.distributeVertically"),visible:ze(ce(e),t)})})});var lf,sf,S3,k8,C3=y(()=>{"use strict";h();We();Ze();ue();Hh();W();me();yt();ko();br();lf=N({name:"flipHorizontal",trackEvent:{category:"element"},perform:(e,t,r,o)=>({elements:Xo(S3(e,t,"horizontal"),t,o),appState:t,commitToHistory:!0}),keyTest:e=>e.shiftKey&&e.code===de.H,contextItemLabel:"labels.flipHorizontal"}),sf=N({name:"flipVertical",trackEvent:{category:"element"},perform:(e,t,r,o)=>({elements:Xo(S3(e,t,"vertical"),t,o),appState:t,commitToHistory:!0}),keyTest:e=>e.shiftKey&&e.code===de.V&&!e[S.CTRL_OR_CMD],contextItemLabel:"labels.flipVertical"}),S3=(e,t,r)=>{let o=ge(ce(e),t,{includeBoundTextElement:!0,includeElementsInFrames:!0}),n=k8(o,t,r),i=Ce(n);return e.map(a=>i.get(a.id)||a)},k8=(e,t,r)=>{let{minX:o,minY:n,maxX:i,maxY:a}=wr(e);return Bh({originalElements:Ce(e)},e,"nw",!0,r==="horizontal"?i:o,r==="horizontal"?n:a),(Uo(t)?Ns:Os)(e),e}});var Ul,cf,du,mu,uu,pu,df=y(()=>{"use strict";h();me();We();gi();Uh();Fl();ue();Y();X();Ul=N({name:"copy",trackEvent:{category:"element"},perform:async(e,t,r,o)=>{let n=o.scene.getSelectedElements({selectedElementIds:t.selectedElementIds,includeBoundTextElement:!0,includeElementsInFrames:!0});try{await vm(n,o.files,r)}catch(i){return{commitToHistory:!1,appState:{...t,errorMessage:i.message}}}return{commitToHistory:!1}},contextItemLabel:"labels.copy",keyTest:void 0}),cf=N({name:"paste",trackEvent:{category:"element"},perform:async(e,t,r,o)=>{let n;try{n=await t2()}catch(i){return i.name==="AbortError"||i.name==="NotAllowedError"?!1:(console.error(`actionPaste ${i.name}: ${i.message}`),Vn?{commitToHistory:!1,appState:{...t,errorMessage:f("hints.firefox_clipboard_write")}}:{commitToHistory:!1,appState:{...t,errorMessage:f("errors.asyncPasteFailedOnRead")}})}try{o.pasteFromClipboard(Qw({types:n}))}catch(i){return console.error(i),{commitToHistory:!1,appState:{...t,errorMessage:f("errors.asyncPasteFailedOnParse")}}}return{commitToHistory:!1}},contextItemLabel:"labels.paste",keyTest:void 0}),du=N({name:"cut",trackEvent:{category:"element"},perform:(e,t,r,o)=>(Ul.perform(e,t,r,o),gc.perform(e,t)),contextItemLabel:"labels.cut",keyTest:e=>e[S.CTRL_OR_CMD]&&e.key===S.X}),mu=N({name:"copyAsSvg",trackEvent:{category:"element"},perform:async(e,t,r,o)=>{if(!o.canvas)return{commitToHistory:!1};let{exportedElements:n,exportingFrame:i}=wa(e,t,!0);try{return await va("clipboard-svg",n,t,o.files,{...t,exportingFrame:i}),{commitToHistory:!1}}catch(a){return console.error(a),{appState:{...t,errorMessage:a.message},commitToHistory:!1}}},predicate:e=>wm&&e.length>0,contextItemLabel:"labels.copyAsSvg"}),uu=N({name:"copyAsPng",trackEvent:{category:"element"},perform:async(e,t,r,o)=>{if(!o.canvas)return{commitToHistory:!1};let n=o.scene.getSelectedElements({selectedElementIds:t.selectedElementIds,includeBoundTextElement:!0,includeElementsInFrames:!0}),{exportedElements:i,exportingFrame:a}=wa(e,t,!0);try{return await va("clipboard",i,t,o.files,{...t,exportingFrame:a}),{appState:{...t,toast:{message:f("toast.copyToClipboardAsPng",{exportSelection:n.length?f("toast.selection"):f("toast.canvas"),exportColorScheme:t.exportWithDarkMode?f("buttons.darkMode"):f("buttons.lightMode")})}},commitToHistory:!1}}catch(l){return console.error(l),{appState:{...t,errorMessage:l.message},commitToHistory:!1}}},predicate:e=>Tl&&e.length>0,contextItemLabel:"labels.copyAsPng",keyTest:e=>e.code===de.C&&e.altKey&&e.shiftKey}),pu=N({name:"copyText",trackEvent:{category:"element"},perform:(e,t,r,o)=>{let i=o.scene.getSelectedElements({selectedElementIds:t.selectedElementIds,includeBoundTextElement:!0}).reduce((a,l)=>(z(l)&&a.push(l.text),a),[]).join(`
|
|
57
|
+
${b("hints.firefox_clipboard_write")}`):new Error(b("alerts.couldNotCopyToClipboard"))}else throw new Error("Unsupported export type")};h();gr();var Kw=async(e,t,r,o)=>{let{exportBackground:n,viewBackgroundColor:i,fileHandle:a}=t,l=ng(a);if(!a||!eE(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}=da(e,t,!1);return await ma(l,s,t,r,{exportBackground:n,viewBackgroundColor:i,name:o,fileHandle:a,exportingFrame:c}),{fileHandle:a}};de();ze();h();import vC from"clsx";import{jsx as $w,jsxs as TC}from"react/jsx-runtime";var pa=({children:e,checked:t,onChange:r,className:o})=>TC("div",{className:vC("Checkbox",o,{"is-checked":t}),onClick:n=>{r(!t,n),n.currentTarget.querySelector(".Checkbox-box").focus()},children:[$w("button",{className:"Checkbox-box",role:"checkbox","aria-checked":t,children:O0}),$w("div",{className:"Checkbox-label",children:e})]});Fs();W();We();me();gr();En();import{Fragment as SC,jsx as Cn,jsxs as IC}from"react/jsx-runtime";var gh=N({name:"changeProjectName",trackEvent:!1,perform:(e,t,r)=>({appState:{...t,name:r},commitToHistory:!1}),PanelComponent:({appState:e,updateData:t,appProps:r,data:o,app:n})=>Cn(Ww,{label:b("labels.fileTitle"),value:n.getName(),onChange:i=>t(i),ignoreFocus:o?.ignoreFocus??!1})}),Xw=N({name:"changeExportScale",trackEvent:{category:"export",action:"scale"},perform:(e,t,r)=>({appState:{...t,exportScale:r},commitToHistory:!1}),PanelComponent:({elements:e,appState:t,updateData:r})=>{let o=be(e),i=Re(o,t)?pe(o,t):o;return Cn(SC,{children:Ca.map(a=>{let[l,s]=fE(i,ao,a),c=`${b("imageExportDialog.label.scale")} ${a}x (${l}x${s})`;return Cn(ne,{size:"small",type:"radio",icon:`${a}x`,name:"export-canvas-scale",title:c,"aria-label":c,id:"export-canvas-scale",checked:a===t.exportScale,onChange:()=>r(a)},a)})})}}),hh=N({name:"changeExportBackground",trackEvent:{category:"export",action:"toggleBackground"},perform:(e,t,r)=>({appState:{...t,exportBackground:r},commitToHistory:!1}),PanelComponent:({appState:e,updateData:t})=>Cn(pa,{checked:e.exportBackground,onChange:r=>t(r),children:b("imageExportDialog.label.withBackground")})}),_m=N({name:"changeExportEmbedScene",trackEvent:{category:"export",action:"embedScene"},perform:(e,t,r)=>({appState:{...t,exportEmbedScene:r},commitToHistory:!1}),PanelComponent:({appState:e,updateData:t})=>IC(pa,{checked:e.exportEmbedScene,onChange:r=>t(r),children:[b("imageExportDialog.label.embedScene"),Cn(_r,{label:b("imageExportDialog.tooltip.embedScene"),long:!0,children:Cn("div",{className:"excalidraw-tooltip-icon",children:K0})})]})}),Dm=N({name:"saveToActiveFile",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}=ol(t.fileHandle)?await Kw(e,t,o.files,o.getName()):await Rd(e,t,o.files,o.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===S.S&&e[S.CTRL_OR_CMD]&&!e.shiftKey}),Js=N({name:"saveFileToDisk",viewMode:!0,trackEvent:{category:"export"},perform:async(e,t,r,o)=>{try{let{fileHandle:n}=await Rd(e,{...t,fileHandle:null},o.files,o.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===S.S&&e.shiftKey&&e[S.CTRL_OR_CMD],PanelComponent:({updateData:e})=>Cn(ne,{type:"button",icon:H0,title:b("buttons.saveAs"),"aria-label":b("buttons.saveAs"),showAriaLabel:ke().editor.isMobile,hidden:!Jn,onClick:()=>e(null),"data-testid":"save-as-button"})}),vl=N({name:"loadScene",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 cg(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:o.files,commitToHistory:!1}}},keyTest:e=>e[S.CTRL_OR_CMD]&&e.key===S.O}),Zw=N({name:"exportWithDarkMode",trackEvent:{category:"export",action:"toggleTheme"},perform:(e,t,r)=>({appState:{...t,exportWithDarkMode:r},commitToHistory:!1}),PanelComponent:({appState:e,updateData:t})=>Cn("div",{style:{display:"flex",justifyContent:"flex-end",marginTop:"-45px",marginBottom:"10px"},children:Cn(Yw,{value:e.exportWithDarkMode?qe.DARK:qe.LIGHT,onChange:r=>{t(r===qe.DARK)},title:b("imageExportDialog.label.darkMode")})})});h();me();de();ze();He();W();lt();oe();We();var jw="{}",fh=N({name:"copyStyles",trackEvent:{category:"element"},perform:(e,t,r,o)=>{let n=[],i=e.find(a=>t.selectedElementIds[a.id]);if(n.push(i),i&&cr(i)){let a=ae(i,o.scene.getNonDeletedElementsMap());n.push(a)}return i&&(jw=JSON.stringify(n)),{appState:{...t,toast:{message:b("toast.copyStyles")}},commitToHistory:!1}},contextItemLabel:"labels.copyStyles",keyTest:e=>e[S.CTRL_OR_CMD]&&e.altKey&&e.code===ue.C}),bh=N({name:"pasteStyles",trackEvent:{category:"element"},perform:(e,t,r,o)=>{let n=JSON.parse(jw),i=n[0],a=n[1];if(!rs(i))return{elements:e,commitToHistory:!1};let l=pe(e,t,{includeBoundTextElement:!0}),s=l.map(c=>c.id);return{elements:e.map(c=>{if(s.includes(c.id)){let d=i;if(G(c)&&c.containerId&&(d=a),!d)return c;let m=te(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?p1(d.roundness.type,c)?d.roundness:u1(c):null});if(G(m)){let p=d.fontSize||It,u=d.fontFamily||Ot;m=te(m,{fontSize:p,fontFamily:u,textAlign:d.textAlign||On,lineHeight:d.lineHeight||Tr(u)});let g=null;m.containerId&&(g=l.find(f=>G(m)&&f.id===m.containerId)||null),zt(m,g,o.scene.getNonDeletedElementsMap())}return m.type==="arrow"&&we(d)&&(m=te(m,{startArrowhead:d.startArrowhead,endArrowhead:d.endArrowhead})),X(c)&&(m=te(m,{roundness:null,backgroundColor:"transparent"})),m}return c}),commitToHistory:!0}},contextItemLabel:"labels.pasteStyles",keyTest:e=>e[S.CTRL_OR_CMD]&&e.altKey&&e.code===ue.V});h();me();ze();de();import{jsx as qw}from"react/jsx-runtime";var CC=N({name:"toggleCanvasMenu",trackEvent:{category:"menu"},perform:(e,t)=>({appState:{...t,openMenu:t.openMenu==="canvas"?null:"canvas"},commitToHistory:!1}),PanelComponent:({appState:e,updateData:t})=>qw(ne,{type:"button",icon:um,"aria-label":b("buttons.menu"),onClick:t,selected:e.openMenu==="canvas"})}),kC=N({name:"toggleEditMenu",trackEvent:{category:"menu"},perform:(e,t)=>({appState:{...t,openMenu:t.openMenu==="shape"?null:"shape"},commitToHistory:!1}),PanelComponent:({elements:e,appState:t,updateData:r})=>qw(ne,{visible:ia(t,be(e)),type:"button",icon:z0,"aria-label":b("buttons.edit"),onClick:r,selected:t.openMenu==="shape"})}),ua=N({name:"toggleShortcuts",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"}},commitToHistory:!1}),keyTest:e=>e.key===S.QUESTION_MARK});h();de();F();ze();He();We();Ir();me();co();oe();Xt();import{jsx as Rm}from"react/jsx-runtime";var AC=e=>{if(e.length>=2){let t=e[0].groupIds;for(let r of t)if(e.reduce((o,n)=>o&&Zi(n,r),!0))return!0}return!1},Jw=(e,t,r)=>{let o=r.scene.getSelectedElements({selectedElementIds:t.selectedElementIds,includeBoundTextElement:!0});return o.length>=2&&!AC(o)},xh=N({name:"group",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,commitToHistory:!1};let i=un(t);if(i.length===1){let f=i[0],E=new Set(Ze(e,f).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(f=>f.frameId)).size>1&&zE(n).forEach((E,y)=>{ml(E,o.scene.getNonDeletedElementsMap())});let s=At(),c=J(n);a=a.map(f=>c.get(f.id)?te(f,{groupIds:Ix(f.groupIds,s,t.editingGroupId)}):f);let d=Ze(a,s),m=d[d.length-1],p=a.lastIndexOf(m),u=a.slice(p+1);return a=[...a.slice(0,p).filter(f=>!Zi(f,s)),...d,...u],{appState:{...t,...Ku(s,{...t,selectedGroupIds:{}},be(a))},elements:a,commitToHistory:!0}},contextItemLabel:"labels.group",predicate:(e,t,r,o)=>Jw(e,t,o),keyTest:e=>!e.shiftKey&&e[S.CTRL_OR_CMD]&&e.key===S.G,PanelComponent:({elements:e,appState:t,updateData:r,app:o})=>Rm(ne,{hidden:!Jw(e,t,o),type:"button",icon:Rm(ly,{theme:t.theme}),onClick:()=>r(null),title:`${b("labels.group")} \u2014 ${_("CtrlOrCmd+G")}`,"aria-label":b("labels.group"),visible:Re(be(e),t)})}),Eh=N({name:"ungroup",trackEvent:{category:"element"},perform:(e,t,r,o)=>{let n=un(t),i=J(e);if(n.length===0)return{appState:t,elements:e,commitToHistory:!1};let a=[...e],l=[];a=a.map(p=>{Me(p)&&l.push(p.id);let u=Cx(p.groupIds,t.selectedGroupIds);return u.length===p.groupIds.length?p:te(p,{groupIds:u})});let s=Gt(t,be(a),t,null),c=o.scene.getSelectedElements(t),d=new Set(c.filter(p=>p.frameId).map(p=>p.frameId));return Hs(e).filter(p=>d.has(p.id)).forEach(p=>{p&&(a=tm(a,dl(a,p,t,i),p,o))}),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[S.CTRL_OR_CMD]&&e.key===S.G.toUpperCase(),contextItemLabel:"labels.ungroup",predicate:(e,t)=>un(t).length>0,PanelComponent:({elements:e,appState:t,updateData:r})=>Rm(ne,{type:"button",hidden:un(t).length===0,icon:Rm(sy,{theme:t.theme}),onClick:()=>r(null),title:`${b("labels.ungroup")} \u2014 ${_("CtrlOrCmd+Shift+G")}`,"aria-label":b("labels.ungroup"),visible:Re(be(e),t)})});h();h();function MC(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 ga=e=>`hsl(${Math.abs(MC(e))%37*10}, 100%, 83%)`,Qw=e=>{let t=e?.trim()?.codePointAt(0);return(t?String.fromCodePoint(t):"?").toUpperCase()};h();import{useState as LC}from"react";import PC from"clsx";import{jsx as e2}from"react/jsx-runtime";var yh=({color:e,onClick:t,name:r,src:o,isBeingFollowed:n,isCurrentUser:i})=>{let a=Qw(r),[l,s]=LC(!1),c=!l&&o,d=c?void 0:{background:e};return e2("div",{className:PC("Avatar",{"Avatar--is-followed":n,"Avatar--is-current-user":i}),style:d,onClick:t,children:c?e2("img",{className:"Avatar-img",src:o,alt:a,referrerPolicy:"no-referrer",onError:()=>s(!0)}):a})};ze();import{jsx as Nm,jsxs as DC}from"react/jsx-runtime";var _C=N({name:"goToCollaborator",viewMode:!0,trackEvent:{category:"collab"},perform:(e,t,r)=>!r.socketId||t.userToFollow?.socketId===r.socketId||r.isCurrentUser?{appState:{...t,userToFollow:null},commitToHistory:!1}:{appState:{...t,userToFollow:{socketId:r.socketId,username:r.username||""},openMenu:t.openMenu==="canvas"?null:t.openMenu},commitToHistory:!1},PanelComponent:({updateData:e,data:t,appState:r})=>{let{clientId:o,collaborator:n,withName:i,isBeingFollowed:a}=t,l=ga(o);return i?DC("div",{className:"dropdown-menu-item dropdown-menu-item-base UserList__collaborator",onClick:()=>e(n),children:[Nm(yh,{color:l,onClick:()=>{},name:n.username||"",src:n.avatarUrl,isBeingFollowed:a,isCurrentUser:n.isCurrentUser===!0}),Nm("div",{className:"UserList__collaborator-name",children:n.username}),Nm("div",{className:"UserList__collaborator-follow-status-icon",style:{visibility:a?"visible":"hidden"},title:a?b("userList.hint.followStatus"):void 0,"aria-hidden":!0,children:ym})]}):Nm(yh,{color:l,onClick:()=>{e(n)},name:n.username||"",src:n.avatarUrl,isBeingFollowed:a,isCurrentUser:n.isCurrentUser===!0})}});h();ze();fn();co();W();var wh=N({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 Hc)if(n.some(a=>a.type===i))return{commitToHistory:!1,appState:{...t,errorMessage:b(`errors.libraryElementTypeError.${i}`)}};return o.library.getLatestLibrary().then(i=>o.library.setLibrary([{id:At(),status:"unpublished",elements:n.map(hn),created:Date.now()},...i])).then(()=>({commitToHistory:!1,appState:{...t,toast:{message:b("toast.addedToLibrary")}}})).catch(i=>({commitToHistory:!1,appState:{...t,errorMessage:i.message}}))},contextItemLabel:"labels.addToLibrary"});h();h();He();mt();Ir();var t2=(e,t,r)=>{let o=ji(e,t),n=pr(e);return o.flatMap(i=>{let a=RC(i,n,r);return i.map(l=>te(l,{x:l.x+a.x,y:l.y+a.y}))})},RC=(e,t,{axis:r,position:o})=>{let n=pr(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}};me();oe();Xt();de();We();F();ze();import{jsx as Sl}from"react/jsx-runtime";var jr=(e,t,r,o)=>{let n=o.scene.getSelectedElements(t);return n.length>1&&!n.some(i=>X(i))},Tl=(e,t,r,o)=>{let n=r.scene.getSelectedElements(t),i=J(e),a=t2(n,i,o),l=J(a);return Go(e.map(s=>l.get(s.id)||s),t,r)},NC=N({name:"alignTop",trackEvent:{category:"element"},predicate:jr,perform:(e,t,r,o)=>({appState:t,elements:Tl(e,t,o,{position:"start",axis:"y"}),commitToHistory:!0}),keyTest:e=>e[S.CTRL_OR_CMD]&&e.shiftKey&&e.key===S.ARROW_UP,PanelComponent:({elements:e,appState:t,updateData:r,app:o})=>Sl(ne,{hidden:!jr(e,t,null,o),type:"button",icon:J0,onClick:()=>r(null),title:`${b("labels.alignTop")} \u2014 ${_("CtrlOrCmd+Shift+Up")}`,"aria-label":b("labels.alignTop"),visible:Re(be(e),t)})}),BC=N({name:"alignBottom",trackEvent:{category:"element"},predicate:jr,perform:(e,t,r,o)=>({appState:t,elements:Tl(e,t,o,{position:"end",axis:"y"}),commitToHistory:!0}),keyTest:e=>e[S.CTRL_OR_CMD]&&e.shiftKey&&e.key===S.ARROW_DOWN,PanelComponent:({elements:e,appState:t,updateData:r,app:o})=>Sl(ne,{hidden:!jr(e,t,null,o),type:"button",icon:Q0,onClick:()=>r(null),title:`${b("labels.alignBottom")} \u2014 ${_("CtrlOrCmd+Shift+Down")}`,"aria-label":b("labels.alignBottom"),visible:Re(be(e),t)})}),OC=N({name:"alignLeft",trackEvent:{category:"element"},predicate:jr,perform:(e,t,r,o)=>({appState:t,elements:Tl(e,t,o,{position:"start",axis:"x"}),commitToHistory:!0}),keyTest:e=>e[S.CTRL_OR_CMD]&&e.shiftKey&&e.key===S.ARROW_LEFT,PanelComponent:({elements:e,appState:t,updateData:r,app:o})=>Sl(ne,{hidden:!jr(e,t,null,o),type:"button",icon:ey,onClick:()=>r(null),title:`${b("labels.alignLeft")} \u2014 ${_("CtrlOrCmd+Shift+Left")}`,"aria-label":b("labels.alignLeft"),visible:Re(be(e),t)})}),FC=N({name:"alignRight",trackEvent:{category:"element"},predicate:jr,perform:(e,t,r,o)=>({appState:t,elements:Tl(e,t,o,{position:"end",axis:"x"}),commitToHistory:!0}),keyTest:e=>e[S.CTRL_OR_CMD]&&e.shiftKey&&e.key===S.ARROW_RIGHT,PanelComponent:({elements:e,appState:t,updateData:r,app:o})=>Sl(ne,{hidden:!jr(e,t,null,o),type:"button",icon:ty,onClick:()=>r(null),title:`${b("labels.alignRight")} \u2014 ${_("CtrlOrCmd+Shift+Right")}`,"aria-label":b("labels.alignRight"),visible:Re(be(e),t)})}),HC=N({name:"alignVerticallyCentered",trackEvent:{category:"element"},predicate:jr,perform:(e,t,r,o)=>({appState:t,elements:Tl(e,t,o,{position:"center",axis:"y"}),commitToHistory:!0}),PanelComponent:({elements:e,appState:t,updateData:r,app:o})=>Sl(ne,{hidden:!jr(e,t,null,o),type:"button",icon:ny,onClick:()=>r(null),title:b("labels.centerVertically"),"aria-label":b("labels.centerVertically"),visible:Re(be(e),t)})}),zC=N({name:"alignHorizontallyCentered",trackEvent:{category:"element"},predicate:jr,perform:(e,t,r,o)=>({appState:t,elements:Tl(e,t,o,{position:"center",axis:"x"}),commitToHistory:!0}),PanelComponent:({elements:e,appState:t,updateData:r,app:o})=>Sl(ne,{hidden:!jr(e,t,null,o),type:"button",icon:iy,onClick:()=>r(null),title:b("labels.centerHorizontally"),"aria-label":b("labels.centerHorizontally"),visible:Re(be(e),t)})});h();h();He();Ir();mt();var r2=(e,t,r)=>{let[o,n,i,a]=r.axis==="x"?["minX","midX","maxX","width"]:["minY","midY","maxY","height"],l=pr(e),s=ji(e,t).map(p=>[p,pr(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][o]===l[o]),u=s.findIndex(E=>E[1][i]===l[i]),g=(s[u][1][n]-s[p][1][n])/(s.length-1),f=s[p][1][n];return s.flatMap(([E,y],T)=>{let w={x:0,y:0};return T!==p&&T!==u&&(f+=g,w[r.axis]=f-y[n]),E.map(I=>te(I,{x:I.x+w.x,y:I.y+w.y}))})}let m=l[o];return s.flatMap(([p,u])=>{let g={x:0,y:0};return g[r.axis]=m-u[o],m+=d,m+=u[a],p.map(f=>te(f,{x:f.x+g.x,y:f.y+g.y}))})};me();oe();Xt();de();We();F();ze();import{jsx as i2}from"react/jsx-runtime";var o2=(e,t)=>{let r=t.scene.getSelectedElements(e);return r.length>1&&!r.some(o=>X(o))},n2=(e,t,r,o)=>{let n=r.scene.getSelectedElements(t),i=r2(n,r.scene.getNonDeletedElementsMap(),o),a=J(i);return Go(e.map(l=>a.get(l.id)||l),t,r)},GC=N({name:"distributeHorizontally",trackEvent:{category:"element"},perform:(e,t,r,o)=>({appState:t,elements:n2(e,t,o,{space:"between",axis:"x"}),commitToHistory:!0}),keyTest:e=>!e[S.CTRL_OR_CMD]&&e.altKey&&e.code===ue.H,PanelComponent:({elements:e,appState:t,updateData:r,app:o})=>i2(ne,{hidden:!o2(t,o),type:"button",icon:ry,onClick:()=>r(null),title:`${b("labels.distributeHorizontally")} \u2014 ${_("Alt+H")}`,"aria-label":b("labels.distributeHorizontally"),visible:Re(be(e),t)})}),UC=N({name:"distributeVertically",trackEvent:{category:"element"},perform:(e,t,r,o)=>({appState:t,elements:n2(e,t,o,{space:"between",axis:"y"}),commitToHistory:!0}),keyTest:e=>!e[S.CTRL_OR_CMD]&&e.altKey&&e.code===ue.V,PanelComponent:({elements:e,appState:t,updateData:r,app:o})=>i2(ne,{hidden:!o2(t,o),type:"button",icon:oy,onClick:()=>r(null),title:`${b("labels.distributeVertically")} \u2014 ${_("Alt+V")}`,"aria-label":b("labels.distributeVertically"),visible:Re(be(e),t)})});h();ze();We();me();Rg();F();de();mt();ho();Xt();var vh=N({name:"flipHorizontal",trackEvent:{category:"element"},perform:(e,t,r,o)=>({elements:Go(a2(e,o.scene.getNonDeletedElementsMap(),t,"horizontal"),t,o),appState:t,commitToHistory:!0}),keyTest:e=>e.shiftKey&&e.code===ue.H,contextItemLabel:"labels.flipHorizontal"}),Th=N({name:"flipVertical",trackEvent:{category:"element"},perform:(e,t,r,o)=>({elements:Go(a2(e,o.scene.getNonDeletedElementsMap(),t,"vertical"),t,o),appState:t,commitToHistory:!0}),keyTest:e=>e.shiftKey&&e.code===ue.V&&!e[S.CTRL_OR_CMD],contextItemLabel:"labels.flipVertical"}),a2=(e,t,r,o)=>{let n=pe(be(e),r,{includeBoundTextElement:!0,includeElementsInFrames:!0}),i=WC(n,e,t,r,o),a=J(i);return e.map(l=>a.get(l.id)||l)},WC=(e,t,r,o,n)=>{let{minX:i,minY:a,maxX:l,maxY:s}=pr(e);return Pg(r,e,r,"nw",!0,n==="horizontal"?l:i,n==="horizontal"?a:s),Ro(o)?xs(e,t,r):ys(e,r),e};h();de();ze();oi();me();W();var Il=N({name:"copy",trackEvent:{category:"element"},perform:async(e,t,r,o)=>{let n=o.scene.getSelectedElements({selectedElementIds:t.selectedElementIds,includeBoundTextElement:!0,includeElementsInFrames:!0});try{await Zd(n,o.files,r)}catch(i){return{commitToHistory:!1,appState:{...t,errorMessage:i.message}}}return{commitToHistory:!1}},contextItemLabel:"labels.copy",keyTest:void 0}),Sh=N({name:"paste",trackEvent:{category:"element"},perform:async(e,t,r,o)=>{let n;try{n=await IE()}catch(i){return i.name==="AbortError"||i.name==="NotAllowedError"?!1:(console.error(`actionPaste ${i.name}: ${i.message}`),Nn?{commitToHistory:!1,appState:{...t,errorMessage:b("hints.firefox_clipboard_write")}}:{commitToHistory:!1,appState:{...t,errorMessage:b("errors.asyncPasteFailedOnRead")}})}try{o.pasteFromClipboard(TE({types:n}))}catch(i){return console.error(i),{commitToHistory:!1,appState:{...t,errorMessage:b("errors.asyncPasteFailedOnParse")}}}return{commitToHistory:!1}},contextItemLabel:"labels.paste",keyTest:void 0}),Bm=N({name:"cut",trackEvent:{category:"element"},perform:(e,t,r,o)=>(Il.perform(e,t,r,o),Ys.perform(e,t,null,o)),contextItemLabel:"labels.cut",keyTest:e=>e[S.CTRL_OR_CMD]&&e.key===S.X}),Om=N({name:"copyAsSvg",trackEvent:{category:"element"},perform:async(e,t,r,o)=>{if(!o.canvas)return{commitToHistory:!1};let{exportedElements:n,exportingFrame:i}=da(e,t,!0);try{return await ma("clipboard-svg",n,t,o.files,{...t,exportingFrame:i,name:o.getName()}),{commitToHistory:!1}}catch(a){return console.error(a),{appState:{...t,errorMessage:a.message},commitToHistory:!1}}},predicate:e=>Xd&&e.length>0,contextItemLabel:"labels.copyAsSvg"}),Fm=N({name:"copyAsPng",trackEvent:{category:"element"},perform:async(e,t,r,o)=>{if(!o.canvas)return{commitToHistory:!1};let n=o.scene.getSelectedElements({selectedElementIds:t.selectedElementIds,includeBoundTextElement:!0,includeElementsInFrames:!0}),{exportedElements:i,exportingFrame:a}=da(e,t,!0);try{return await ma("clipboard",i,t,o.files,{...t,exportingFrame:a,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")})}},commitToHistory:!1}}catch(l){return console.error(l),{appState:{...t,errorMessage:l.message},commitToHistory:!1}}},predicate:e=>sl&&e.length>0,contextItemLabel:"labels.copyAsPng",keyTest:e=>e.code===ue.C&&e.altKey&&e.shiftKey}),Hm=N({name:"copyText",trackEvent:{category:"element"},perform:(e,t,r,o)=>{let i=o.scene.getSelectedElements({selectedElementIds:t.selectedElementIds,includeBoundTextElement:!0}).reduce((a,l)=>(G(l)&&a.push(l.text),a),[]).join(`
|
|
59
58
|
|
|
60
|
-
`);return Tn(i),{commitToHistory:!1}},predicate:(e,t,r,o)=>wm&&o.scene.getSelectedElements({selectedElementIds:t.selectedElementIds,includeBoundTextElement:!0}).some(z),contextItemLabel:"labels.copyText"})});var gu,k3=y(()=>{"use strict";h();me();We();X();gu=N({name:"gridMode",viewMode:!0,trackEvent:{category:"canvas",predicate:e=>!e.gridSize},perform(e,t){return{appState:{...t,gridSize:this.checked(t)?null:nn,objectsSnapModeEnabled:!1},commitToHistory:!1}},checked:e=>e.gridSize!==null,predicate:(e,t,r)=>typeof r.gridModeEnabled>"u",contextItemLabel:"labels.showGrid",keyTest:e=>e[S.CTRL_OR_CMD]&&e.code===de.QUOTE})});var Wl,A3=y(()=>{"use strict";h();me();We();Wl=N({name:"zenMode",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,r)=>typeof r.zenModeEnabled>"u",contextItemLabel:"buttons.zenMode",keyTest:e=>!e[S.CTRL_OR_CMD]&&e.altKey&&e.code===de.Z})});var mf,M3=y(()=>{"use strict";h();me();We();mf=N({name:"objectsSnapMode",viewMode:!0,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,r)=>typeof r.objectsSnapModeEnabled>"u",contextItemLabel:"buttons.objectsSnapMode",keyTest:e=>!e[S.CTRL_OR_CMD]&&e.altKey&&e.code===de.S})});var vi,uf=y(()=>{"use strict";h();We();me();vi=N({name:"stats",viewMode:!0,trackEvent:{category:"menu"},perform(e,t){return{appState:{...t,showStats:!this.checked(t)},commitToHistory:!1}},checked:e=>e.showStats,contextItemLabel:"stats.title",keyTest:e=>!e[S.CTRL_OR_CMD]&&e.altKey&&e.code===de.SLASH})});var pf,gf,A8,M8,L3,hf=y(()=>{"use strict";h();X();ue();Ve();pt();Cm();ae();W();We();pf=N({name:"unbindText",contextItemLabel:"labels.unbindText",trackEvent:{category:"element"},predicate:(e,t,r,o)=>o.scene.getSelectedElements(t).some(i=>pr(i)),perform:(e,t,r,o)=>(o.scene.getSelectedElements(t).forEach(i=>{let a=le(i);if(a){let{width:l,height:c,baseline:s}=_r(a.originalText,_e(a),a.lineHeight),d=r2(i.id);Sm(i.id);let{x:m,y:u}=Cl(i,a);B(a,{containerId:null,width:l,height:c,baseline:s,text:a.originalText,x:m,y:u}),B(i,{boundElements:i.boundElements?.filter(p=>p.id!==a.id),height:d||i.height})}}),{elements:e,appState:t,commitToHistory:!0})}),gf=N({name:"bindText",contextItemLabel:"labels.bindText",trackEvent:{category:"element"},predicate:(e,t,r,o)=>{let n=o.scene.getSelectedElements(t);if(n.length===2){let i=z(n[0])||z(n[1]),a;if(Fo(n[0])?a=n[0]:Fo(n[1])&&(a=n[1]),i&&a&&le(a)===null)return!0}return!1},perform:(e,t,r,o)=>{let n=o.scene.getSelectedElements(t),i,a;z(n[0])&&Fo(n[1])?(i=n[0],a=n[1]):(i=n[1],a=n[0]),B(i,{containerId:a.id,verticalAlign:ht.MIDDLE,textAlign:$n.CENTER}),B(a,{boundElements:(a.boundElements||[]).concat({type:"text",id:i.id})});let l=a.height;return Gt(i,a),Sl(a.id,l),{elements:A8(e,a,i),appState:{...t,selectedElementIds:{[a.id]:!0}},commitToHistory:!0}}}),A8=(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),o},M8=(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),o},L3=N({name:"wrapTextInContainer",contextItemLabel:"labels.createContainerFromText",trackEvent:{category:"element"},predicate:(e,t,r,o)=>{let n=o.scene.getSelectedElements(t),i=n.every(a=>z(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(z(l)){let c=Pr({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:Ho("rectangle")?st.ADAPTIVE_RADIUS:st.PROPORTIONAL_RADIUS}:null,opacity:100,locked:!1,x:l.x-ut,y:l.y-ut,width:In(l.width,"rectangle"),height:In(l.height,"rectangle"),groupIds:l.groupIds,frameId:l.frameId});if(l.boundElements?.length){let s=l.boundElements.filter(m=>m.type==="arrow").map(m=>m.id);i.filter(m=>s.includes(m.id)).forEach(m=>{let u=m.startBinding,p=m.endBinding;u?.elementId===l.id&&(u={...u,elementId:c.id}),p?.elementId===l.id&&(p={...p,elementId:c.id}),(u||p)&&B(m,{startBinding:u,endBinding:p},!1)})}B(l,{containerId:c.id,verticalAlign:ht.MIDDLE,boundElements:null,textAlign:$n.CENTER},!1),Gt(l,c),i=M8([...i,c],c,l),a[c.id]=!0}return{elements:i,appState:{...t,selectedElementIds:a},commitToHistory:!0}}})});var _3,ff,P3,bf=y(()=>{"use strict";h();Ve();ae();me();W();We();_3=e=>e.every(t=>!t.locked),ff=N({name:"toggleElementLock",trackEvent:{category:"element"},predicate:(e,t,r,o)=>!o.scene.getSelectedElements(t).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=_3(n),a=Ce(n);return{elements:e.map(l=>a.has(l.id)?Q(l,{locked:i}):l),appState:{...t,selectedLinearElement:i?null:t.selectedLinearElement},commitToHistory:!0}},contextItemLabel:(e,t,r)=>{let o=r.scene.getSelectedElements({selectedElementIds:t.selectedElementIds,includeBoundTextElement:!1});return o.length===1&&!J(o[0])?o[0].locked?"labels.elementLock.unlock":"labels.elementLock.lock":_3(o)?"labels.elementLock.lockAll":"labels.elementLock.unlockAll"},keyTest:(e,t,r,o)=>e.key.toLocaleLowerCase()===S.L&&e[S.CTRL_OR_CMD]&&e.shiftKey&&o.scene.getSelectedElements({selectedElementIds:t.selectedElementIds,includeBoundTextElement:!1}).length>0}),P3=N({name:"unlockAllElements",trackEvent:{category:"canvas"},viewMode:!1,predicate:e=>e.some(t=>t.locked),perform:(e,t)=>{let r=e.filter(o=>o.locked);return{elements:e.map(o=>o.locked?Q(o,{locked:!1}):o),appState:{...t,selectedElementIds:Object.fromEntries(r.map(o=>[o.id,!0]))},commitToHistory:!0}},contextItemLabel:"labels.elementLock.unlockAll"})});var xf,D3=y(()=>{"use strict";h();ar();ae();We();xf=N({name:"toggleLinearEditor",trackEvent:{category:"element"},predicate:(e,t,r,o)=>{let n=o.scene.getSelectedElements(t);return!!(n.length===1&&te(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 K(n,o.scene);return{appState:{...t,editingLinearElement:i},commitToHistory:!1}},contextItemLabel:(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"}})});var Dn=y(()=>{"use strict";h();Uh();zv();Gv();Vv();Wg();Xs();Yv();bc();a3();s3();d3();g3();h3();x3();I3();C3();df();k3();A3();M3();uf();hf();$d();bf();D3()});import{jsx as O3}from"react/jsx-runtime";var R3,N3,B3,F3=y(()=>{"use strict";h();se();Lt();Y();me();Ve();ko();W();X();R3=(e,t,r)=>{if(!t.multiElement&&!t.resizingElement&&!t.editingElement&&!t.draggingElement){let n=r();if(n===null)return{commitToHistory:!1};let i=Ce(e),a=n.elements,l=Ce(a),c=e.filter(d=>!l.has(d.id)),s=a.map(d=>Q(i.get(d.id)||d,d)).concat(c.map(d=>Q(d,{isDeleted:!0})));return hl(s,c),{elements:s,appState:{...t,...n.appState},commitToHistory:!1,syncHistory:!0}}return{commitToHistory:!1}},N3=e=>({name:"undo",trackEvent:{category:"history"},perform:(t,r)=>R3(t,r,()=>e.undoOnce()),keyTest:t=>t[S.CTRL_OR_CMD]&&t.key.toLowerCase()===S.Z&&!t.shiftKey,PanelComponent:({updateData:t,data:r})=>O3(ne,{type:"button",icon:VE,"aria-label":f("buttons.undo"),onClick:t,size:r?.size||"medium"}),commitToHistory:()=>!1}),B3=e=>({name:"redo",trackEvent:{category:"history"},perform:(t,r)=>R3(t,r,()=>e.redoOnce()),keyTest:t=>t[S.CTRL_OR_CMD]&&t.shiftKey&&t.key.toLowerCase()===S.Z||qc&&t.ctrlKey&&!t.shiftKey&&t.key===S.Y,PanelComponent:({updateData:t,data:r})=>O3(ne,{type:"button",icon:YE,"aria-label":f("buttons.redo"),onClick:t,size:r?.size||"medium"}),commitToHistory:()=>!1})});import{jsx as L8}from"react/jsx-runtime";var Ef,hu,H3=y(()=>{"use strict";h();Qr();Ef=(e,t,r,o,n,i)=>{if(e.trackEvent)try{typeof e.trackEvent=="object"&&(!e.trackEvent.predicate||e.trackEvent.predicate(r,o,i))&&Ee(e.trackEvent.category,e.trackEvent.action||e.name,`${t} (${n.device.editor.isMobile?"mobile":"desktop"})`)}catch(a){console.error("error while logging action:",a)}},hu=class{actions={};updater;getAppState;getElementsIncludingDeleted;app;constructor(t,r,o,n){this.updater=i=>{if(i&&"then"in 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((c,s)=>(s.keyPriority||0)-(c.keyPriority||0)).filter(c=>(c.name in r?r[c.name]:!0)&&c.keyTest&&c.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 Ef(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();Ef(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(),c=s=>{Ef(n,"ui",l,a,this.app,s),this.updater(n.perform(this.getElementsIncludingDeleted(),this.getAppState(),s,this.app))};return L8(i,{elements:this.getElementsIncludingDeleted(),appState:this.getAppState(),updateData:c,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)}}});import{atom as _8,useAtom as P8}from"jotai";import{useEffect as D8,useState as R8}from"react";var yf,z3,G3,fu,xc=y(()=>{"use strict";h();Yt();_t();_n();yf=_8(new Map),z3=async e=>await Rl({elements:e,appState:{exportBackground:!1,viewBackgroundColor:oe.white},files:null,renderEmbeddables:!1}),G3=(e,t,r)=>{let[o,n]=R8();return D8(()=>{if(t)if(e){let i=r.get(e);i?n(i):(async()=>{let a=await z3(t);a.querySelector(".style-fonts")?.remove(),a&&(r.set(e,a),n(a))})()}else(async()=>{let i=await z3(t);n(i)})()},[e,t,r,n]),o},fu=()=>{let[e]=P8(yf,Be);return{clearLibraryCache:()=>e.clear(),deleteItemsFromLibraryCache:o=>{o.forEach(n=>e.delete(n))},svgCache:e}}});import{atom as N8}from"jotai";import{useEffect as B8,useRef as O8}from"react";var Sa,wf,F8,U3,vf,W3,bu,Tf,H8,Ec=y(()=>{"use strict";h();vr();ac();_t();yt();$a();Y();X();xc();W();Sa=N8({status:"loaded",isInitialized:!0,libraryItems:[]}),wf=e=>Vr(e),F8=(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)),U3=(e,t)=>{let r=[];for(let o of t)F8(e,o)&&r.push(o);return[...r,...e]},vf=class{lastLibraryItems=[];isInitialized=!1;app;constructor(t){this.app=t}updateQueue=[];getLastUpdateTask=()=>this.updateQueue[this.updateQueue.length-1];notifyListeners=()=>{if(this.updateQueue.length>0)mr.set(Sa,{status:"loading",libraryItems:this.lastLibraryItems,isInitialized:this.isInitialized});else{this.isInitialized=!0,mr.set(Sa,{status:"loaded",libraryItems:this.lastLibraryItems,isInitialized:this.isInitialized});try{this.app.props.onLibraryChange?.(wf(this.lastLibraryItems))}catch(t){console.error(t)}}};destroy=()=>{this.isInitialized=!1,this.updateQueue=[],this.lastLibraryItems=[],mr.set(yf,new Map)};resetLibrary=()=>this.setLibrary([]);getLatestLibrary=()=>new Promise(async t=>{try{let r=await(this.getLastUpdateTask()||this.lastLibraryItems);this.updateQueue.length>0?t(this.getLatestLibrary()):t(wf(r))}catch{return t(this.lastLibraryItems)}});updateLibrary=async({libraryItems:t,prompt:r=!1,merge:o=!1,openLibraryMenu:n=!1,defaultStatus:i="unpublished"})=>(n&&this.app.setState({openSidebar:{name:Bo.name,tab:us}}),this.setLibrary(()=>new Promise(async(a,l)=>{try{let c=await(typeof t=="function"&&!(t instanceof Blob)?t(this.lastLibraryItems):t),s;c instanceof Blob?s=await Eh(c,i):s=ic(c,i),!r||window.confirm(f("alerts.confirmAddLibrary",{numShapes:s.length}))?(r&&this.app.focusContainer(),a(o?U3(this.lastLibraryItems,s):s)):l(new ni)}catch(c){l(c)}})));setLibrary=t=>{let r=new Promise(async(o,n)=>{try{await this.getLastUpdateTask(),typeof t=="function"&&(t=t(this.lastLibraryItems)),this.lastLibraryItems=wf(await t),o(this.lastLibraryItems)}catch(i){n(i)}}).catch(o=>{if(o.name==="AbortError")return console.warn("Library update aborted by user"),this.lastLibraryItems;throw o}).finally(()=>{this.updateQueue=this.updateQueue.filter(o=>o!==r),this.notifyListeners()});return this.updateQueue.push(r),this.notifyListeners(),r}},W3=vf,bu=e=>{let r=Math.ceil(Math.sqrt(e.length)),o=[],n=p=>e.slice(p*r,p*r+r).reduce((b,E)=>{let{height:w}=wr(E.elements);return Math.max(b,w)},0),i=p=>{let g=0,b=0,E=0;for(let w of e){if(g%r===0&&(b=0),b===p){let{width:v}=wr(w.elements);E=Math.max(E,v)}g++,b++}return E},a=0,l=0,c=0,s=0,d=0,m=0,u=0;for(let p of e){d&&d%r===0&&(l+=c+50,a=0,m=0,u++),m===0&&(c=n(u)),s=i(m);let{minX:g,minY:b,width:E,height:w}=wr(p.elements),v=(s-E)/2,T=(c-w)/2;o.push(...p.elements.map(k=>({...k,x:k.x+a+v-g,y:k.y+l+T-b}))),a+=s+50,d++,m++}return o},Tf=()=>{let e=new URLSearchParams(window.location.hash.slice(1)).get(nd.addLibrary)||new URLSearchParams(window.location.search).get(od.addLibrary),t=e?new URLSearchParams(window.location.hash.slice(1)).get("token"):null;return e?{libraryUrl:e,idToken:t}:null},H8=({excalidrawAPI:e,getInitialLibraryItems:t})=>{let r=O8(t);B8(()=>{if(!e)return;let o=async({libraryUrl:a,idToken:l})=>{let c=new Promise(async(d,m)=>{try{let p=await(await fetch(decodeURIComponent(a))).blob();d(p)}catch(u){m(u)}}),s=l!==e.id;await(s&&document.hidden?new Promise(d=>{window.addEventListener("focus",()=>d(),{once:!0})}):null);try{await e.updateLibrary({libraryItems:c,prompt:s,merge:!0,defaultStatus:"published",openLibraryMenu:!0})}catch(d){throw d}finally{if(window.location.hash.includes(nd.addLibrary)){let d=new URLSearchParams(window.location.hash.slice(1));d.delete(nd.addLibrary),window.history.replaceState({},ss,`#${d.toString()}`)}else if(window.location.search.includes(od.addLibrary)){let d=new URLSearchParams(window.location.search);d.delete(od.addLibrary),window.history.replaceState({},ss,`?${d.toString()}`)}}},n=a=>{a.preventDefault();let l=Tf();l&&(a.stopImmediatePropagation(),window.history.replaceState({},"",a.oldURL),o(l))};r.current&&e.updateLibrary({libraryItems:r.current()});let i=Tf();return i&&o(i),window.addEventListener("hashchange",n),()=>{window.removeEventListener("hashchange",n)}},[e])}});var If,Sf,V3,Y3=y(()=>{"use strict";h();If=e=>{let t=Array.from(e.values());return{x:V3(t,r=>r.x)/t.length,y:V3(t,r=>r.y)/t.length}},Sf=([e,t])=>Math.hypot(e.x-t.x,e.y-t.y),V3=(e,t)=>e.reduce((r,o)=>r+t(o),0)});var z8,Cf,K3,$3=y(()=>{"use strict";h();ae();dn();z8=e=>({selectedElementIds:e.selectedElementIds,selectedGroupIds:e.selectedGroupIds,viewBackgroundColor:e.viewBackgroundColor,editingLinearElement:e.editingLinearElement,editingGroupId:e.editingGroupId,name:e.name}),Cf=class{elementCache=new Map;recording=!0;stateHistory=[];redoStack=[];lastEntry=null;hydrateHistoryEntry({appState:t,elements:r}){return{appState:JSON.parse(t),elements:r.map(o=>{let n=this.elementCache.get(o.id)?.get(o.versionNonce);if(!n)throw new Error(`Element not found: ${o.id}:${o.versionNonce}`);return n})}}dehydrateHistoryEntry({appState:t,elements:r}){return{appState:JSON.stringify(t),elements:r.map(o=>{this.elementCache.has(o.id)||this.elementCache.set(o.id,new Map);let n=this.elementCache.get(o.id);return n.has(o.versionNonce)||n.set(o.versionNonce,cn(o)),{id:o.id,versionNonce:o.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,r)=>this.dehydrateHistoryEntry({appState:z8(t),elements:r.reduce((o,n)=>{if(te(n)&&t.multiElement&&t.multiElement.id===n.id){if(t.multiElement&&t.multiElement.id===n.id&&n.points.length<2)return o;o.push({...n,points:n.lastCommittedPoint!==n.points[n.points.length-1]?n.points.slice(0,-1):n.points})}else o.push(n);return o},[])});shouldCreateEntry(t){let{lastEntry:r}=this;if(!r||t.elements.length!==r.elements.length)return!0;for(let n=t.elements.length-1;n>-1;n--){let i=t.elements[n],a=r.elements[n];if(!i||!a||i.id!==a.id||i.versionNonce!==a.versionNonce)return!0}let o;for(o in t.appState)if(!(o==="editingLinearElement"&&t.appState[o]?.elementId===r.appState[o]?.elementId)&&!(o==="selectedElementIds"||o==="selectedGroupIds")&&t.appState[o]!==r.appState[o])return!0;return!1}pushEntry(t,r){let o=this.generateEntry(t,r),n=this.hydrateHistoryEntry(o);if(n){if(!this.shouldCreateEntry(n))return;this.stateHistory.push(o),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(),r=this.stateHistory[this.stateHistory.length-1];return t!==void 0?(this.redoStack.push(t),this.hydrateHistoryEntry(r)):null}setCurrentState(t,r){this.lastEntry=this.hydrateHistoryEntry(this.generateEntry(t,r))}resumeRecording(){this.recording=!0}record(t,r){this.recording&&(this.pushEntry(t,r),this.recording=!1)}},K3=Cf});var kf,X3,Af=y(()=>{"use strict";h();se();me();kf=[{icon:xE,value:"selection",key:S.V,numericKey:S[1],fillable:!0},{icon:EE,value:"rectangle",key:S.R,numericKey:S[2],fillable:!0},{icon:yE,value:"diamond",key:S.D,numericKey:S[3],fillable:!0},{icon:wE,value:"ellipse",key:S.O,numericKey:S[4],fillable:!0},{icon:vE,value:"arrow",key:S.A,numericKey:S[5],fillable:!0},{icon:TE,value:"line",key:S.L,numericKey:S[6],fillable:!0},{icon:Xa,value:"freedraw",key:[S.P,S.X],numericKey:S[7],fillable:!1},{icon:SE,value:"text",key:S.T,numericKey:S[8],fillable:!1},{icon:CE,value:"image",key:null,numericKey:S[9],fillable:!1},{icon:kE,value:"eraser",key:S.E,numericKey:S[0],fillable:!1}],X3=e=>kf.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 Z3=y(()=>{});var G8,Rn,xu=y(()=>{"use strict";h();X();Y();W();G8={toggleTheme:[_("Shift+Alt+D")],saveScene:[_("CtrlOrCmd+S")],loadScene:[_("CtrlOrCmd+O")],clearCanvas:[_("CtrlOrCmd+Delete")],imageExport:[_("CtrlOrCmd+Shift+E")],cut:[_("CtrlOrCmd+X")],copy:[_("CtrlOrCmd+C")],paste:[_("CtrlOrCmd+V")],copyStyles:[_("CtrlOrCmd+Alt+C")],pasteStyles:[_("CtrlOrCmd+Alt+V")],selectAll:[_("CtrlOrCmd+A")],deleteSelectedElements:[_("Delete")],duplicateSelection:[_("CtrlOrCmd+D"),_(`Alt+${f("helpDialog.drag")}`)],sendBackward:[_("CtrlOrCmd+[")],bringForward:[_("CtrlOrCmd+]")],sendToBack:[rr?_("CtrlOrCmd+Alt+["):_("CtrlOrCmd+Shift+[")],bringToFront:[rr?_("CtrlOrCmd+Alt+]"):_("CtrlOrCmd+Shift+]")],copyAsPng:[_("Shift+Alt+C")],copyAsSvg:[],group:[_("CtrlOrCmd+G")],ungroup:[_("CtrlOrCmd+Shift+G")],gridMode:[_("CtrlOrCmd+'")],zenMode:[_("Alt+Z")],objectsSnapMode:[_("Alt+S")],stats:[_("Alt+/")],addToLibrary:[],flipHorizontal:[_("Shift+H")],flipVertical:[_("Shift+V")],viewMode:[_("Alt+R")],hyperlink:[_("CtrlOrCmd+K")],toggleElementLock:[_("CtrlOrCmd+Shift+L")]},Rn=e=>{let t=G8[e];return t&&t.length>0?t[0]:""}});import U8 from"clsx";import W8 from"react";import{jsx as Vl,jsxs as V8}from"react/jsx-runtime";var lr,j3,q3=y(()=>{"use strict";h();Bg();Y();Z3();xu();be();lr="separator",j3=W8.memo(({actionManager:e,items:t,top:r,left:o,onClose:n})=>{let i=al(),a=mi(),l=t.reduce((c,s)=>(s&&(s===lr||!s.predicate||s.predicate(a,i,e.app.props,e.app))&&c.push(s),c),[]);return Vl(um,{onCloseRequest:()=>{n()},top:r,left:o,fitInViewport:!0,offsetLeft:i.offsetLeft,offsetTop:i.offsetTop,viewportWidth:i.width,viewportHeight:i.height,children:Vl("ul",{className:"context-menu",onContextMenu:c=>c.preventDefault(),children:l.map((c,s)=>{if(c===lr)return!l[s-1]||l[s-1]===lr?null:Vl("hr",{className:"context-menu-item-separator"},s);let d=c.name,m="";return c.contextItemLabel&&(typeof c.contextItemLabel=="function"?m=f(c.contextItemLabel(a,i,e.app)):m=f(c.contextItemLabel)),Vl("li",{"data-testid":d,onClick:()=>{n(()=>{e.executeAction(c,"contextMenu")})},children:V8("button",{className:U8("context-menu-item",{dangerous:d==="deleteSelectedElements",checkmark:c.checked?.(i)}),children:[Vl("div",{className:"context-menu-item__label",children:m}),Vl("kbd",{className:"context-menu-item__shortcut",children:d?Rn(d):""})]})},s)})})})})});var J3=y(()=>{});import{forwardRef as Q3}from"react";import eT from"clsx";import{jsx as tT}from"react/jsx-runtime";var Y8,K8,Bt,Ca=y(()=>{"use strict";h();J3();Y8=Q3(({children:e,gap:t,align:r,justifyContent:o,className:n,style:i},a)=>tT("div",{className:eT("Stack Stack_horizontal",n),style:{"--gap":t,alignItems:r,justifyContent:o,...i},ref:a,children:e})),K8=Q3(({children:e,gap:t,align:r,justifyContent:o,className:n,style:i},a)=>tT("div",{className:eT("Stack Stack_vertical",n),style:{"--gap":t,justifyItems:r,justifyContent:o,...i},ref:a,children:e})),Bt={Row:Y8,Col:K8}});var rT=y(()=>{});import $8 from"clsx";import{jsx as X8}from"react/jsx-runtime";var oT,nT,iT=y(()=>{"use strict";h();be();oT=({className:e="",children:t,onToggle:r,title:o,...n})=>{let i=De(),a=$8(`dropdown-menu-button ${e}`,"zen-mode-transition",{"dropdown-menu-button--mobile":i.editor.isMobile}).trim();return X8("button",{"data-prevent-outside-click":!0,className:a,onClick:r,type:"button","data-testid":"dropdown-menu-button",title:o,...n,children:t})},nT=oT;oT.displayName="DropdownMenuTrigger"});import Z8,{useContext as j8}from"react";var Mf,Eu,yu,wu=y(()=>{"use strict";h();X();W();Mf=Z8.createContext({}),Eu=(e="",t=!1)=>`dropdown-menu-item dropdown-menu-item-base ${e} ${t?"dropdown-menu-item--selected":""}`.trim(),yu=(e,t)=>{let r=j8(Mf);return Xn(e,o=>{let n=new CustomEvent("menu.itemSelect",{bubbles:!0,cancelable:!0});t?.(n),n.defaultPrevented||r.onSelect?.(n)})}});import{Fragment as J8,jsx as Lf,jsxs as Q8}from"react/jsx-runtime";var q8,vu,_f=y(()=>{"use strict";h();be();q8=({icon:e,shortcut:t,children:r})=>{let o=De();return Q8(J8,{children:[Lf("div",{className:"dropdown-menu-item__icon",children:e}),Lf("div",{className:"dropdown-menu-item__text",children:r}),t&&!o.editor.isMobile&&Lf("div",{className:"dropdown-menu-item__shortcut",children:t})]})},vu=q8});import{jsx as Pf}from"react/jsx-runtime";var Df,aT,Lo,Rf=y(()=>{"use strict";h();wu();_f();Df=({icon:e,onSelect:t,children:r,shortcut:o,className:n,selected:i,...a})=>{let l=yu(a.onClick,t);return Pf("button",{...a,onClick:l,type:"button",className:Eu(n,i),title:a.title??a["aria-label"],children:Pf(vu,{icon:e,shortcut:o,children:r})})};Df.displayName="DropdownMenuItem";aT=({children:e})=>Pf("div",{style:{display:"inline-flex",marginLeft:"auto",padding:"2px 4px",background:"pink",borderRadius:6,fontSize:9,color:"black",fontFamily:"Cascadia, monospace"},children:e});aT.displayName="DropdownMenuItemBadge";Df.Badge=aT;Lo=Df});import{jsx as eL}from"react/jsx-runtime";var lT,sT,cT=y(()=>{"use strict";h();lT=()=>eL("div",{style:{height:"1px",backgroundColor:"var(--default-border-color)",margin:".5rem 0"}}),sT=lT;lT.displayName="DropdownMenuSeparator"});import{jsx as tL,jsxs as rL}from"react/jsx-runtime";var dT,mT,uT=y(()=>{"use strict";h();dT=({children:e,className:t="",style:r,title:o})=>rL("div",{className:`dropdown-menu-group ${t}`,style:r,children:[o&&tL("p",{className:"dropdown-menu-group-title",children:o}),e]}),mT=dT;dT.displayName="DropdownMenuGroup"});var pT=y(()=>{});import oL from"react";import nL from"clsx";import{jsx as iL}from"react/jsx-runtime";var Ut,Ti=y(()=>{"use strict";h();pT();Ut=oL.forwardRef(({children:e,padding:t,className:r,style:o},n)=>iL("div",{className:nL("Island",r),style:{"--padding":t,...o},ref:n,children:e}))});import aL from"clsx";import{useRef as lL}from"react";import{jsx as Tu}from"react/jsx-runtime";var gT,hT,fT=y(()=>{"use strict";h();Ti();be();Ca();wu();sm();gT=({children:e,onClickOutside:t,className:r="",onSelect:o,style:n})=>{let i=De(),a=lL(null);yl(a,()=>{t?.()});let l=aL(`dropdown-menu ${r}`,{"dropdown-menu--mobile":i.editor.isMobile}).trim();return Tu(Mf.Provider,{value:{onSelect:o},children:Tu("div",{ref:a,className:l,style:n,"data-testid":"dropdown-menu",children:i.editor.isMobile?Tu(Bt.Col,{className:"dropdown-menu-container",children:e}):Tu(Ut,{className:"dropdown-menu-container",padding:2,style:{zIndex:2},children:e})})})};gT.displayName="DropdownMenuContent";hT=gT});import{jsx as bT}from"react/jsx-runtime";var xT,Yl,Nf=y(()=>{"use strict";h();_f();wu();xT=({icon:e,shortcut:t,href:r,children:o,onSelect:n,className:i="",selected:a,...l})=>{let c=yu(l.onClick,n);return bT("a",{...l,href:r,target:"_blank",rel:"noreferrer",className:Eu(i,a),title:l.title??l["aria-label"],onClick:c,children:bT(vu,{icon:e,shortcut:t,children:o})})},Yl=xT;xT.displayName="DropdownMenuItemLink"});import{jsx as cL}from"react/jsx-runtime";var sL,ET,yT=y(()=>{"use strict";h();sL=({children:e,className:t="",selected:r,...o})=>cL("div",{...o,className:`dropdown-menu-item-base dropdown-menu-item-custom ${t} ${r?"dropdown-menu-item--selected":""}`.trim(),children:e}),ET=sL});import Iu from"react";var wT,vT,TT=y(()=>{"use strict";h();wT=e=>{let t=Iu.Children.toArray(e).find(r=>Iu.isValidElement(r)&&typeof r.type!="string"&&r?.type.displayName&&r.type.displayName==="DropdownMenuTrigger");return t||null},vT=e=>{let t=Iu.Children.toArray(e).find(r=>Iu.isValidElement(r)&&typeof r.type!="string"&&r?.type.displayName&&r.type.displayName==="DropdownMenuContent");return t||null}});var IT=y(()=>{});import{Fragment as dL,jsxs as mL}from"react/jsx-runtime";var Nn,Ne,yc=y(()=>{"use strict";h();iT();Rf();cT();uT();fT();Nf();yT();TT();IT();Nn=({children:e,open:t})=>{let r=wT(e),o=vT(e);return mL(dL,{children:[r,t&&o]})};Nn.Trigger=nT;Nn.Content=hT;Nn.Item=Lo;Nn.ItemLink=Yl;Nn.ItemCustom=ET;Nn.Group=mT;Nn.Separator=sT;Ne=Nn;Nn.displayName="DropdownMenu"});import Bf from"react";import Zo from"tunnel-rat";var Of,rt,ST,Hr=y(()=>{"use strict";h();Of=Bf.createContext(null),rt=()=>Bf.useContext(Of),ST=()=>Bf.useMemo(()=>({MainMenuTunnel:Zo(),WelcomeScreenMenuHintTunnel:Zo(),WelcomeScreenToolbarHintTunnel:Zo(),WelcomeScreenHelpHintTunnel:Zo(),WelcomeScreenCenterTunnel:Zo(),FooterCenterTunnel:Zo(),DefaultSidebarTriggerTunnel:Zo(),DefaultSidebarTabTriggersTunnel:Zo(),OverwriteConfirmDialogTunnel:Zo(),TTDDialogTriggerTunnel:Zo(),jotaiScope:Symbol()}),[])});import{useState as uL}from"react";import Ff from"clsx";import{Fragment as Ii,jsx as lt,jsxs as vt}from"react/jsx-runtime";var Su,Cu,CT,kT,AT,MT,ku=y(()=>{"use strict";h();ue();Y();be();Ze();Af();W();Ca();Lt();Ys();Qr();ae();Dn();ai();pt();rT();yc();se();me();Hr();Su=({appState:e,elements:t,renderAction:r})=>{let o=ma(ce(t),e),n=!1;o.length===2&&(pr(o[0])||pr(o[1]))&&(n=!0);let i=!!e.editingElement,a=De(),l=document.documentElement.getAttribute("dir")==="rtl",c=wn(e.activeTool.type)&&!or(e.currentItemBackgroundColor)||o.some(u=>wn(u.type)&&!or(u.backgroundColor)),s=wn(e.activeTool.type)||o.some(u=>wn(u.type)),d=o.length===1||n,m=o[0]?.type||null;for(let u of o)if(u.type!==m){m=null;break}return vt("div",{className:"panelColumn",children:[lt("div",{children:(Vs(e.activeTool.type)&&e.activeTool.type!=="image"&&m!=="image"&&m!=="frame"&&m!=="magicframe"||o.some(u=>Vs(u.type)))&&r("changeStrokeColor")}),s&<("div",{children:r("changeBackgroundColor")}),c&&r("changeFillStyle"),(pm(e.activeTool.type)||o.some(u=>pm(u.type)))&&r("changeStrokeWidth"),(e.activeTool.type==="freedraw"||o.some(u=>u.type==="freedraw"))&&r("changeStrokeShape"),(gm(e.activeTool.type)||o.some(u=>gm(u.type)))&&vt(Ii,{children:[r("changeStrokeStyle"),r("changeSloppiness")]}),(wl(e.activeTool.type)||o.some(u=>wl(u.type)))&<(Ii,{children:r("changeRoundness")}),(e.activeTool.type==="text"||o.some(z))&&vt(Ii,{children:[r("changeFontSize"),r("changeFontFamily"),(e.activeTool.type==="text"||l2(o))&&r("changeTextAlign")]}),a2(o)&&r("changeVerticalAlign"),(da(e.activeTool.type)||o.some(u=>da(u.type)))&<(Ii,{children:r("changeArrowhead")}),r("changeOpacity"),vt("fieldset",{children:[lt("legend",{children:f("labels.layers")}),vt("div",{className:"buttonList",children:[r("sendToBack"),r("sendBackward"),r("bringToFront"),r("bringForward")]})]}),o.length>1&&!n&&vt("fieldset",{children:[lt("legend",{children:f("labels.align")}),vt("div",{className:"buttonList",children:[l?vt(Ii,{children:[r("alignRight"),r("alignHorizontallyCentered"),r("alignLeft")]}):vt(Ii,{children:[r("alignLeft"),r("alignHorizontallyCentered"),r("alignRight")]}),o.length>2&&r("distributeHorizontally"),lt("div",{style:{flexBasis:"100%",height:0}}),vt("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&&vt("fieldset",{children:[lt("legend",{children:f("labels.actions")}),vt("div",{className:"buttonList",children:[!a.editor.isMobile&&r("duplicateSelection"),!a.editor.isMobile&&r("deleteSelectedElements"),r("group"),r("ungroup"),d&&r("hyperlink")]})]})]})},Cu=({activeTool:e,appState:t,app:r,UIOptions:o})=>{let[n,i]=uL(!1),a=e.type==="frame",l=e.type==="laser",c=e.type==="embeddable",{TTDDialogTriggerTunnel:s}=rt();return vt(Ii,{children:[kf.map(({value:d,icon:m,key:u,numericKey:p,fillable:g},b)=>{if(o.tools?.[d]===!1)return null;let E=f(`toolBar.${d}`),w=u&&Ba(typeof u=="string"?u:u[0]),v=w?`${w} ${f("helpDialog.or")} ${p}`:`${p}`;return lt(ne,{className:Ff("Shape",{fillable:g}),type:"radio",icon:m,checked:e.type===d,name:"editor-current-shape",title:`${Ba(E)} \u2014 ${v}`,keyBindingLabel:p||w,"aria-label":Ba(E),"aria-keyshortcuts":v,"data-testid":`toolbar-${d}`,onPointerDown:({pointerType:T})=>{!t.penDetected&&T==="pen"&&r.togglePenMode(!0)},onChange:({pointerType:T})=>{t.activeTool.type!==d&&Ee("toolbar",d,"ui"),d==="image"?r.setActiveTool({type:d,insertOnCanvasDirectly:T!=="mouse"}):r.setActiveTool({type:d})}},d)}),lt("div",{className:"App-toolbar__divider"}),vt(Ne,{open:n,children:[lt(Ne.Trigger,{className:Ff("App-toolbar__extra-tools-trigger",{"App-toolbar__extra-tools-trigger--selected":a||c||l&&!r.props.isCollaborating}),onToggle:()=>i(!n),title:f("toolBar.extraTools"),children:K0}),vt(Ne.Content,{onClickOutside:()=>i(!1),onSelect:()=>i(!1),className:"App-toolbar__extra-tools-dropdown",children:[lt(Ne.Item,{onSelect:()=>r.setActiveTool({type:"frame"}),icon:$0,shortcut:S.F.toLocaleUpperCase(),"data-testid":"toolbar-frame",selected:a,children:f("toolBar.frame")}),lt(Ne.Item,{onSelect:()=>r.setActiveTool({type:"embeddable"}),icon:LE,"data-testid":"toolbar-embeddable",selected:c,children:f("toolBar.embeddable")}),lt(Ne.Item,{onSelect:()=>r.setActiveTool({type:"laser"}),icon:Fd,"data-testid":"toolbar-laser",selected:l,shortcut:S.K.toLocaleUpperCase(),children:f("toolBar.laser")}),lt("div",{style:{margin:"6px 0",fontSize:14,fontWeight:600},children:"Generate"}),r.props.aiEnabled!==!1&<(s.Out,{}),lt(Ne.Item,{onSelect:()=>r.setOpenDialog({name:"ttd",tab:"mermaid"}),icon:X0,"data-testid":"toolbar-embeddable",children:f("toolBar.mermaidToExcalidraw")}),r.props.aiEnabled!==!1&&vt(Ii,{children:[vt(Ne.Item,{onSelect:()=>r.onMagicframeToolSelect(),icon:Qa,"data-testid":"toolbar-magicframe",children:[f("toolBar.magicframe"),lt(Ne.Item.Badge,{children:"AI"})]}),lt(Ne.Item,{onSelect:()=>{Ee("ai","open-settings","d2c"),r.setOpenDialog({name:"settings",source:"settings",tab:"diagram-to-code"})},icon:Cs,"data-testid":"toolbar-magicSettings",children:f("toolBar.magicSettings")})]})]})]})]})},CT=({renderAction:e,zoom:t})=>lt(Bt.Col,{gap:1,className:"zoom-actions",children:vt(Bt.Row,{align:"center",children:[e("zoomOut"),e("resetZoom"),e("zoomIn")]})}),kT=({renderAction:e,className:t})=>vt("div",{className:`undo-redo-buttons ${t}`,children:[lt("div",{className:"undo-button-container",children:lt(Rr,{label:f("buttons.undo"),children:e("undo")})}),lt("div",{className:"redo-button-container",children:vt(Rr,{label:f("buttons.redo"),children:[" ",e("redo")]})})]}),AT=({actionManager:e,showExitZenModeBtn:t})=>lt("button",{className:Ff("disable-zen-mode",{"disable-zen-mode--visible":t}),onClick:()=>e.executeAction(Wl),children:f("buttons.exitZenMode")}),MT=({renderAction:e,className:t})=>lt("div",{className:`finalize-button ${t}`,children:e("finalize",{size:"small"})})});import{useCallback as pL,useState as gL}from"react";var LT,_T=y(()=>{"use strict";h();LT=()=>{let[e,t]=gL(null),r=pL(o=>t(o),[]);return[e,r]}});var PT=y(()=>{});var DT=y(()=>{});import{createPortal as hL}from"react-dom";import fL from"clsx";import{jsx as RT,jsxs as bL}from"react/jsx-runtime";var NT,BT=y(()=>{"use strict";h();DT();me();Rg();NT=e=>{let{closeOnClickOutside:t=!0}=e,r=lm({className:"excalidraw-modal-container"});if(!r)return null;let o=n=>{n.key===S.ESCAPE&&(n.nativeEvent.stopImmediatePropagation(),n.stopPropagation(),e.onCloseRequest())};return hL(bL("div",{className:fL("Modal",e.className),role:"dialog","aria-modal":"true",onKeyDown:o,"aria-labelledby":e.labelledBy,"data-prevent-outside-click":!0,children:[RT("div",{className:"Modal__background",onClick:t?e.onCloseRequest:void 0}),RT("div",{className:"Modal__content",style:{"--max-width":`${e.maxWidth}px`},tabIndex:0,children:e.children})]}),r)}});import{jsx as EL}from"react/jsx-runtime";var xL,OT,FT=y(()=>{"use strict";h();X();Y();xL=({theme:e,id:t,libraryReturnUrl:r})=>{let o=r||window.location.origin+window.location.pathname;return EL("a",{className:"library-menu-browse-button",href:`${I.VITE_APP_LIBRARY_URL}?target=${window.name||"_blank"}&referrer=${o}&useHash=true&token=${t}&theme=${e}&version=${Ki.excalidrawLibrary}`,target:"_excalidraw_libraries",children:f("labels.libraries")})},OT=xL});import yL from"clsx";import{jsx as wL,jsxs as vL}from"react/jsx-runtime";var Au,Hf=y(()=>{"use strict";h();FT();Au=({libraryReturnUrl:e,theme:t,id:r,style:o,children:n,className:i})=>vL("div",{className:yL("library-menu-control-buttons",i),style:o,children:[wL(OT,{id:r,libraryReturnUrl:e,theme:t}),n]})});import Mu from"react";var TL,IL,SL,CL,kL,AL,sr,Kl=y(()=>{"use strict";h();Y();TL=/({{[\w-]+}})|(<[\w-]+>)|(<\/[\w-]+>)/g,IL=/{{([\w-]+)}}/,SL=/<([\w-]+)>/,CL=/<\/([\w-]+)>/,kL=(e,t)=>{let r=[{name:"",children:[]}];return e.split(TL).filter(Boolean).forEach(o=>{let n=o.match(SL),i=o.match(CL),a=o.match(IL);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 c=r.pop(),s=Mu.createElement(Mu.Fragment,{},...c.children),d=t[c.name];typeof d=="function"&&r[r.length-1].children.push(d(s))}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},AL=({i18nKey:e,children:t,...r})=>{let{t:o}=Pt();return Mu.createElement(Mu.Fragment,{},...kL(o(e),r))},sr=AL});var HT=y(()=>{});var zT=y(()=>{});import ML from"clsx";import{jsx as Lu,jsxs as _L}from"react/jsx-runtime";var LL,$l,zf=y(()=>{"use strict";h();zT();Wn();LL=({label:e,onClick:t,className:r,children:o,actionType:n,type:i="button",isLoading:a,...l})=>{let c=n?`Dialog__action-button--${n}`:"";return _L("button",{className:ML("Dialog__action-button",c,r),type:i,"aria-label":e,onClick:t,...l,children:[o&&Lu("div",{style:a?{visibility:"hidden"}:{},children:o}),Lu("div",{style:a?{visibility:"hidden"}:{},children:e}),a&&Lu("div",{style:{position:"absolute",inset:0},children:Lu(tr,{})})]})},$l=LL});import{useSetAtom as PL}from"jotai";import{jsx as GT,jsxs as UT}from"react/jsx-runtime";var DL,_u,Gf=y(()=>{"use strict";h();Y();co();HT();zf();wc();be();_t();DL=e=>{let{onConfirm:t,onCancel:r,children:o,confirmText:n=f("buttons.confirm"),cancelText:i=f("buttons.cancel"),className:a="",...l}=e,c=$e(),s=PL(Xl,Be),{container:d}=Nt();return UT(gt,{onCloseRequest:r,size:"small",...l,className:`confirm-dialog ${a}`,children:[o,UT("div",{className:"confirm-dialog-buttons",children:[GT($l,{label:i,onClick:()=>{c({openMenu:null}),s(!1),r(),d?.focus()}}),GT($l,{label:n,onClick:()=>{c({openMenu:null}),s(!1),t(),d?.focus()},actionType:"danger"})]})]})},_u=DL});var Tr,vc=y(()=>{"use strict";h();Tr=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 WT=y(()=>{});import{useCallback as RL,useEffect as Wf,useRef as VT,useState as Uf}from"react";import Pu from"open-color";import{jsx as ye,jsxs as qt}from"react/jsx-runtime";var NL,BL,OL,YT,KT=y(()=>{"use strict";h();co();Y();Kl();_n();X();vr();W();zf();se();Lt();vc();WT();NL=async e=>{let o=Math.round(8),n=Math.max(Math.round(128/64),2),i=hx(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=Pu.white,l.fillRect(0,0,a.width,a.height);for(let[c,s]of e.entries()){let d=await wi({elements:s.elements,files:null,maxWidthOrHeight:128}),{width:m,height:u}=d,p=Math.floor(c/6)*(128+o*2),g=c%6*(128+o*2);l.drawImage(d,g+(128-m)/2+o,p+(128-u)/2+o),l.lineWidth=n,l.strokeStyle=Pu.gray[4],l.strokeRect(g+o/2,p+o/2,128+o,128+o)}return await cc(new File([await Mn(a)],"preview",{type:Z.png}),{outputType:Z.jpg,maxWidthOrHeight:5e3})},BL=({libItem:e,appState:t,index:r,onChange:o,onRemove:n})=>{let i=VT(null),a=VT(null);return Wf(()=>{let l=i.current;l&&(async()=>{let c=await Rl({elements:e.elements,appState:{...t,viewBackgroundColor:Pu.white,exportBackground:!0},files:null});l.innerHTML=c.outerHTML})()},[e.elements,t]),qt("div",{className:"single-library-item",children:[e.status==="published"&&ye("span",{className:"single-library-item-status",children:f("labels.statusPublished")}),ye("div",{ref:i,className:"single-library-item__svg"}),ye(ne,{"aria-label":f("buttons.remove"),type:"button",icon:Jr,className:"single-library-item--remove",onClick:n.bind(null,e.id),title:f("buttons.remove")}),qt("div",{style:{display:"flex",margin:"0.8rem 0",width:"100%",fontSize:"14px",fontWeight:500,flexDirection:"column"},children:[qt("label",{style:{display:"flex",justifyContent:"space-between",flexDirection:"column"},children:[qt("div",{style:{padding:"0.5em 0"},children:[ye("span",{style:{fontWeight:500,color:Pu.gray[6]},children:f("publishDialog.itemName")}),ye("span",{"aria-hidden":"true",className:"required",children:"*"})]}),ye("input",{type:"text",ref:a,style:{width:"80%",padding:"0.2rem"},defaultValue:e.name,placeholder:"Item name",onChange:l=>{o(l.target.value,r)}})]}),ye("span",{className:"error",children:e.error})]})]})},OL=({onClose:e,libraryItems:t,appState:r,onSuccess:o,onError:n,updateItemsInStorage:i,onRemove:a})=>{let[l,c]=Uf({authorName:"",githubHandle:"",name:"",description:"",twitterHandle:"",website:""}),[s,d]=Uf(!1);Wf(()=>{let T=Tr.get(Wr.PUBLISH_LIBRARY);T&&c(T)},[]);let[m,u]=Uf(t.slice());Wf(()=>{u(t.slice())},[t]);let p=T=>{c({...l,[T.target.name]:T.target.value})},g=async T=>{T.preventDefault(),d(!0);let k=[],M=!1;if(m.forEach(O=>{let P="";O.name||(P=f("publishDialog.errors.required"),M=!0),k.push({...O,error:P})}),M){u(k),d(!1);return}let A=await NL(m),D={type:Kt.excalidrawLibrary,version:Ki.excalidrawLibrary,source:ms,libraryItems:m},R=JSON.stringify(D,null,2),H=new Blob([R],{type:"application/json"}),C=new FormData;C.append("excalidrawLib",H),C.append("previewImage",A),C.append("previewImageType",A.type),C.append("title",l.name),C.append("authorName",l.authorName),C.append("githubHandle",l.githubHandle),C.append("name",l.name),C.append("description",l.description),C.append("twitterHandle",l.twitterHandle),C.append("website",l.website),fetch(`${I.VITE_APP_LIBRARY_BACKEND}/submit`,{method:"post",body:C}).then(O=>O.ok?O.json().then(({url:P})=>{Tr.delete(Wr.PUBLISH_LIBRARY),o({url:P,authorName:l.authorName,items:m})}):O.json().catch(()=>{throw new Error(O.statusText||"something went wrong")}).then(P=>{throw new Error(P.message||O.statusText||"something went wrong")}),O=>{console.error(O),n(O),d(!1)}).catch(O=>{console.error(O),n(O),d(!1)})},b=()=>{let T=[];return m.forEach((k,M)=>{T.push(ye("div",{className:"single-library-item-wrapper",children:ye(BL,{libItem:k,appState:r,index:M,onChange:(A,D)=>{let R=m.slice();R[D].name=A,u(R)},onRemove:a})},M))}),ye("div",{className:"selected-library-items",children:T})},E=RL(()=>{i(m),Tr.set(Wr.PUBLISH_LIBRARY,l),e()},[m,e,i,l]),w=!!t.length,v=t.some(T=>T.status==="published");return ye(gt,{onCloseRequest:E,title:f("publishDialog.title"),className:"publish-library",children:w?qt("form",{onSubmit:g,children:[ye("div",{className:"publish-library-note",children:ye(sr,{i18nKey:"publishDialog.noteDescription",link:T=>ye("a",{href:"https://libraries.excalidraw.com",target:"_blank",rel:"noopener noreferrer",children:T})})}),ye("span",{className:"publish-library-note",children:ye(sr,{i18nKey:"publishDialog.noteGuidelines",link:T=>ye("a",{href:"https://github.com/excalidraw/excalidraw-libraries#guidelines",target:"_blank",rel:"noopener noreferrer",children:T})})}),ye("div",{className:"publish-library-note",children:f("publishDialog.noteItems")}),v&&ye("span",{className:"publish-library-note publish-library-warning",children:f("publishDialog.republishWarning")}),b(),qt("div",{className:"publish-library__fields",children:[qt("label",{children:[qt("div",{children:[ye("span",{children:f("publishDialog.libraryName")}),ye("span",{"aria-hidden":"true",className:"required",children:"*"})]}),ye("input",{type:"text",name:"name",required:!0,value:l.name,onChange:p,placeholder:f("publishDialog.placeholder.libraryName")})]}),qt("label",{style:{alignItems:"flex-start"},children:[qt("div",{children:[ye("span",{children:f("publishDialog.libraryDesc")}),ye("span",{"aria-hidden":"true",className:"required",children:"*"})]}),ye("textarea",{name:"description",rows:4,required:!0,value:l.description,onChange:p,placeholder:f("publishDialog.placeholder.libraryDesc")})]}),qt("label",{children:[qt("div",{children:[ye("span",{children:f("publishDialog.authorName")}),ye("span",{"aria-hidden":"true",className:"required",children:"*"})]}),ye("input",{type:"text",name:"authorName",required:!0,value:l.authorName,onChange:p,placeholder:f("publishDialog.placeholder.authorName")})]}),qt("label",{children:[ye("span",{children:f("publishDialog.githubUsername")}),ye("input",{type:"text",name:"githubHandle",value:l.githubHandle,onChange:p,placeholder:f("publishDialog.placeholder.githubHandle")})]}),qt("label",{children:[ye("span",{children:f("publishDialog.twitterUsername")}),ye("input",{type:"text",name:"twitterHandle",value:l.twitterHandle,onChange:p,placeholder:f("publishDialog.placeholder.twitterHandle")})]}),qt("label",{children:[ye("span",{children:f("publishDialog.website")}),ye("input",{type:"text",name:"website",pattern:"https?://.+",title:f("publishDialog.errors.website"),value:l.website,onChange:p,placeholder:f("publishDialog.placeholder.website")})]}),ye("span",{className:"publish-library-note",children:ye(sr,{i18nKey:"publishDialog.noteLicense",link:T=>ye("a",{href:"https://github.com/excalidraw/excalidraw-libraries/blob/main/LICENSE",target:"_blank",rel:"noopener noreferrer",children:T})})})]}),qt("div",{className:"publish-library__buttons",children:[ye($l,{label:f("buttons.cancel"),onClick:E,"data-testid":"cancel-clear-canvas-button"}),ye($l,{type:"submit",label:f("buttons.submit"),actionType:"primary",isLoading:s})]})]}):ye("p",{style:{padding:"1em",textAlign:"center",fontWeight:500},children:f("publishDialog.atleastOneLibItem")})})},YT=OL});import{useCallback as FL,useState as Vf}from"react";import{useAtom as Yf}from"jotai";import HL from"clsx";import{jsx as Ir,jsxs as Du}from"react/jsx-runtime";var zL,GL,Kf,$T=y(()=>{"use strict";h();Y();Kl();_t();be();Ln();Ec();se();Lt();kn();W();Gf();KT();co();yc();wc();zt();xc();zL=(e,t)=>e.filter(r=>t.includes(r.id)),GL=({setAppState:e,selectedItems:t,library:r,onRemoveFromLibrary:o,resetLibrary:n,onSelectItems:i,appState:a,className:l})=>{let[c]=Yf(Sa,Be),[s,d]=Yf(Xl,Be),m=()=>{let C=t.length?f("alerts.removeItemsFromsLibrary",{count:t.length}):f("alerts.resetLibrary"),O=t.length?f("confirmDialog.removeItemsFromLib"):f("confirmDialog.resetLibrary");return Ir(_u,{onConfirm:()=>{t.length?o():n(),p(!1)},onCancel:()=>{p(!1)},title:O,children:Ir("p",{children:C})})},[u,p]=Vf(!1),g=!!t.length,b=g?c.libraryItems.filter(C=>t.includes(C.id)):c.libraryItems,E=g?f("buttons.remove"):f("buttons.resetLibrary"),[w,v]=Vf(!1),[T,k]=Vf(null),M=FL(()=>Du(gt,{onCloseRequest:()=>k(null),title:f("publishSuccessDialog.title"),className:"publish-library-success",size:"small",children:[Ir("p",{children:Ir(sr,{i18nKey:"publishSuccessDialog.content",authorName:T.authorName,link:C=>Ir("a",{href:T?.url,target:"_blank",rel:"noopener noreferrer",children:C})})}),Ir(ne,{type:"button",title:f("buttons.close"),"aria-label":f("buttons.close"),label:f("buttons.close"),onClick:()=>k(null),"data-testid":"publish-library-success-close",className:"publish-library-success-close"})]}),[k,T]),A=(C,O)=>{v(!1),k({url:C.url,authorName:C.authorName});let P=O.slice();P.forEach(G=>{t.includes(G.id)&&(G.status="published")}),r.setLibrary(P)},D=async()=>{try{await r.updateLibrary({libraryItems:Al({description:"Excalidraw library files"}),merge:!0,openLibraryMenu:!0})}catch(C){if(C?.name==="AbortError"){console.warn(C);return}e({errorMessage:f("errors.importLibraryError")})}},R=async()=>{let C=g?b:await r.getLatestLibrary();av(C).catch(ud).catch(O=>{e({errorMessage:O.message})})},H=()=>Du(Ne,{open:s,children:[Ir(Ne.Trigger,{onToggle:()=>d(!s),children:mE}),Du(Ne.Content,{onClickOutside:()=>d(!1),onSelect:()=>d(!1),className:"library-menu",children:[!g&&Ir(Ne.Item,{onSelect:D,icon:ja,"data-testid":"lib-dropdown--load",children:f("buttons.load")}),!!b.length&&Ir(Ne.Item,{onSelect:R,icon:Rd,"data-testid":"lib-dropdown--export",children:f("buttons.export")}),!!b.length&&Ir(Ne.Item,{onSelect:()=>p(!0),icon:ii,children:E}),g&&Ir(Ne.Item,{icon:G0,onSelect:()=>v(!0),"data-testid":"lib-dropdown--remove",children:f("buttons.publishLibrary")})]})]});return Du("div",{className:HL("library-menu-dropdown-container",l),children:[H(),t.length>0&&Ir("div",{className:"library-actions-counter",children:t.length}),u&&m(),w&&Ir(YT,{onClose:()=>v(!1),libraryItems:zL(c.libraryItems,t),appState:a,onSuccess:C=>A(C,c.libraryItems),onError:C=>window.alert(C),updateItemsInStorage:()=>r.setLibrary(c.libraryItems),onRemove:C=>i(t.filter(O=>O!==C))}),T&&M()]})},Kf=({selectedItems:e,onSelectItems:t,className:r})=>{let{library:o}=ro(),{clearLibraryCache:n,deleteItemsFromLibraryCache:i}=fu(),a=He(),l=$e(),[c]=Yf(Sa,Be),s=async m=>{let u=m.filter(p=>!e.includes(p.id));o.setLibrary(u).catch(()=>{l({errorMessage:f("alerts.errorRemovingFromLibrary")})}),i(e),t([])};return Ir(GL,{appState:a,setAppState:l,selectedItems:e,onSelectItems:t,library:o,onRemoveFromLibrary:()=>s(c.libraryItems),resetLibrary:()=>{o.resetLibrary(),n()},className:r})}});var XT=y(()=>{});import ZT from"clsx";import{memo as UL,useEffect as WL,useRef as VL,useState as YL}from"react";import{jsx as Ru,jsxs as KL}from"react/jsx-runtime";var jT,qT,JT=y(()=>{"use strict";h();be();XT();au();se();xc();jT=UL(({id:e,elements:t,isPending:r,onClick:o,selected:n,onToggle:i,onDrag:a,svgCache:l})=>{let c=VL(null),s=G3(e,t,l);WL(()=>{let g=c.current;if(g)return s&&(g.innerHTML=s.outerHTML),()=>{g.innerHTML=""}},[s]);let[d,m]=YL(!1),u=De().editor.isMobile,p=r&&Ru("div",{className:"library-unit__adder",children:dE});return KL("div",{className:ZT("library-unit",{"library-unit__active":t,"library-unit--hover":t&&d,"library-unit--selected":n,"library-unit--skeleton":!s}),onMouseEnter:()=>m(!0),onMouseLeave:()=>m(!1),children:[Ru("div",{className:ZT("library-unit__dragger",{"library-unit__pulse":!!r}),ref:c,draggable:!!t,onClick:t||r?g=>{e&&g.shiftKey?i(e,g):o(e)}:void 0,onDragStart:g=>{if(!e){g.preventDefault();return}m(!1),a(e,g)}}),p,e&&t&&(d||u||n)&&Ru(Ta,{checked:n,onChange:(g,b)=>i(e,b),className:"library-unit__checkbox"})]})}),qT=()=>Ru("div",{className:"library-unit library-unit--skeleton"})});import $L,{useCallback as XL}from"react";function ZL(){return[!1,XL(t=>t(),[])]}var QT,e5=y(()=>{"use strict";h();QT=$L.useTransition||ZL});import{memo as jL,useEffect as qL,useState as JL}from"react";import{Fragment as QL,jsx as Nu}from"react/jsx-runtime";var $f,Bu,t5=y(()=>{"use strict";h();JT();e5();$f=({children:e})=>Nu("div",{className:"library-menu-items-container__grid",children:e}),Bu=jL(({items:e,onItemSelectToggle:t,onItemDrag:r,isItemSelected:o,onClick:n,svgCache:i,itemsRenderedPerBatch:a})=>{let[,l]=QT(),[c,s]=JL(0);return qL(()=>{c<e.length&&l(()=>{s(c+a)})},[c,e.length,l,a]),Nu(QL,{children:e.map((d,m)=>m<c?Nu(jT,{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):Nu(qT,{},m))})})});import{useEffect as e7}from"react";import{atom as t7,useAtom as r7}from"jotai";import o7 from"lodash.throttle";var n7,r5,o5=y(()=>{"use strict";h();n7=t7(0),r5=e=>{let[t,r]=r7(n7);return e7(()=>{let{current:o}=e;if(!o)return;let n=o7(()=>{let{scrollTop:i}=o;r(i)},200);return o.addEventListener("scroll",n),()=>{n.cancel(),o.removeEventListener("scroll",n)}},[e,r]),t}});var n5=y(()=>{});import{useCallback as Zl,useEffect as i7,useMemo as i5,useRef as a7,useState as l7}from"react";import{Fragment as a5,jsx as Sr,jsxs as jl}from"react/jsx-runtime";function Xf({isLoading:e,libraryItems:t,onAddToLibrary:r,onInsertLibraryItems:o,pendingElements:n,theme:i,id:a,libraryReturnUrl:l,onSelectItems:c,selectedItems:s}){let d=a7(null),m=r5(d);i7(()=>{m>0&&d.current?.scrollTo(0,m)},[]);let{svgCache:u}=fu(),p=i5(()=>t.filter(C=>C.status!=="published"),[t]),g=i5(()=>t.filter(C=>C.status==="published"),[t]),b=!t.length&&!n.length,E=!n.length&&!p.length&&!g.length,[w,v]=l7(null),T=Zl((C,O)=>{let P=!s.includes(C),G=[...p,...g];if(P){if(O.shiftKey&&w){let j=G.findIndex(q=>q.id===w),V=G.findIndex(q=>q.id===C);if(j===-1||V===-1){c([...s,C]);return}let pe=Ce(s),Se=G.reduce((q,Ge,Ae)=>((Ae>=j&&Ae<=V||pe.has(Ge.id))&&q.push(Ge.id),q),[]);c(Se)}else c([...s,C]);v(C)}else v(null),c(s.filter(j=>j!==C))},[w,c,g,s,p]),k=Zl(C=>{let O;return s.includes(C)?O=t.filter(P=>s.includes(P.id)):O=t.filter(P=>P.id===C),O.map(P=>({...P,elements:Ad(P.elements,{randomizeSeed:!0})}))},[t,s]),M=Zl((C,O)=>{O.dataTransfer.setData(Z.excalidrawlib,Wm(k(C)))},[k]),A=Zl(C=>C?s.includes(C):!1,[s]),D=Zl(()=>{r(n)},[n,r]),R=Zl(C=>{C&&o(k(C))},[k,o]),H=u.size>=t.length?c7:s7;return jl("div",{className:"library-menu-items-container",style:n.length||p.length||g.length?{justifyContent:"flex-start"}:{borderBottom:0},children:[!E&&Sr(Kf,{selectedItems:s,onSelectItems:c,className:"library-menu-dropdown-container--in-heading"}),jl(Bt.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:[jl(a5,{children:[!E&&Sr("div",{className:"library-menu-items-container__header",children:f("labels.personalLib")}),e&&Sr("div",{style:{position:"absolute",top:"var(--container-padding-y)",right:"var(--container-padding-x)",transform:"translateY(50%)"},children:Sr(tr,{})}),!n.length&&!p.length?jl("div",{className:"library-menu-items__no-items",children:[Sr("div",{className:"library-menu-items__no-items__label",children:f("library.noItems")}),Sr("div",{className:"library-menu-items__no-items__hint",children:g.length>0?f("library.hint_emptyPrivateLibrary"):f("library.hint_emptyLibrary")})]}):jl($f,{children:[n.length>0&&Sr(Bu,{itemsRenderedPerBatch:H,items:[{id:null,elements:n}],onItemSelectToggle:T,onItemDrag:M,onClick:D,isItemSelected:A,svgCache:u}),Sr(Bu,{itemsRenderedPerBatch:H,items:p,onItemSelectToggle:T,onItemDrag:M,onClick:R,isItemSelected:A,svgCache:u})]})]}),jl(a5,{children:[(g.length>0||n.length>0||p.length>0)&&Sr("div",{className:"library-menu-items-container__header library-menu-items-container__header--excal",children:f("labels.excalidrawLib")}),g.length>0?Sr($f,{children:Sr(Bu,{itemsRenderedPerBatch:H,items:g,onItemSelectToggle:T,onItemDrag:M,onClick:R,isItemSelected:A,svgCache:u})}):p.length>0?Sr("div",{style:{margin:"1rem 0",display:"flex",flexDirection:"column",alignItems:"center",justifyContent:"center",width:"100%",fontSize:".9rem"},children:f("library.noItems")}):null]}),b&&Sr(Au,{style:{padding:"16px 0",width:"100%"},id:a,libraryReturnUrl:l,theme:i,children:Sr(Kf,{selectedItems:s,onSelectItems:c})})]})]})}var s7,c7,l5=y(()=>{"use strict";h();Ln();Y();W();Ca();X();Wn();dn();Hf();$T();t5();o5();xc();n5();s7=17,c7=64});var s5=y(()=>{});import{useState as d7,useCallback as jf,useMemo as m5,useRef as Zf}from"react";import{atom as m7,useAtom as u7}from"jotai";import{jsx as Si,jsxs as d5}from"react/jsx-runtime";var Xl,c5,p7,g7,u5,wc=y(()=>{"use strict";h();Ec();Y();yo();l5();Qr();_t();Wn();be();Ze();zt();s5();Hf();W();X();Xl=m7(!1),c5=({children:e})=>Si("div",{className:"layer-ui__library",children:e}),p7=({onInsertLibraryItems:e,pendingElements:t,onAddToLibrary:r,setAppState:o,libraryReturnUrl:n,library:i,id:a,theme:l,selectedItems:c,onSelectItems:s})=>{let[d]=u7(Sa,Be),m=jf(g=>{(async(E,w)=>{Ee("element","addToLibrary","ui");for(let T of sd)if(E.some(k=>k.type===T))return o({errorMessage:f(`errors.libraryElementTypeError.${T}`)});let v=[{status:"unpublished",elements:E,id:Mt(),created:Date.now()},...w];r(),i.setLibrary(v).catch(()=>{o({errorMessage:f("alerts.errorAddingToLibrary")})})})(g,d.libraryItems)},[r,i,o,d.libraryItems]),u=m5(()=>d.libraryItems,[d]);if(d.status==="loading"&&!d.isInitialized)return Si(c5,{children:Si("div",{className:"layer-ui__library-message",children:d5("div",{children:[Si(tr,{size:"2em"}),Si("span",{children:f("labels.libraryLoadingMessage")})]})})});let p=d.libraryItems.length>0||t.length>0;return d5(c5,{children:[Si(Xf,{isLoading:d.status==="loading",libraryItems:u,onAddToLibrary:m,onInsertLibraryItems:e,pendingElements:t,id:a,libraryReturnUrl:n,theme:l,onSelectItems:s,selectedItems:c}),p&&Si(Au,{className:"library-menu-control-buttons--at-bottom",style:{padding:"16px 12px 0 12px"},id:a,libraryReturnUrl:n,theme:l})]})},g7=(e,t)=>{let r=()=>ge(t,e,{includeBoundTextElement:!0,includeElementsInFrames:!0}),o=Zf(r()),n=Zf(e),i=Zf(t);return(!bt(e.selectedElementIds,n.current.selectedElementIds)||!bt(t,i.current))&&(o.current=r(),n.current=e,i.current=t),o.current},u5=()=>{let{library:e,id:t,onInsertElements:r}=ro(),o=li(),n=He(),i=$e(),a=mi(),[l,c]=d7([]),s=m5(()=>e,[e]),d=g7(n,a),m=jf(p=>{r(bu(p))},[r]),u=jf(()=>{i({selectedElementIds:{},selectedGroupIds:{},activeEmbeddable:null})},[i]);return Si(p7,{pendingElements:d,onInsertLibraryItems:m,onAddToLibrary:u,setAppState:i,libraryReturnUrl:o.libraryReturnUrl,library:s,id:t,theme:n.theme,selectedItems:l,onSelectItems:c})}});import h7 from"clsx";import{useEffect as f7,useState as b7}from"react";import{useSetAtom as x7}from"jotai";import{jsx as Tc,jsxs as y7}from"react/jsx-runtime";function E7(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,co=y(()=>{"use strict";h();_T();Y();be();me();PT();se();Ti();BT();W();wc();_t();gt=e=>{let[t,r]=LT(),[o]=b7(document.activeElement),{id:n}=Nt(),i=De().viewport.isMobile;f7(()=>{if(!t)return;let s=gs(t);s.length>0&&e.autofocus!==!1&&(s[1]||s[0]).focus();let d=m=>{if(m.key===S.TAB){let u=gs(t),{activeElement:p}=document,g=u.findIndex(b=>b===p);g===0&&m.shiftKey?(u[u.length-1].focus(),m.preventDefault()):g===u.length-1&&!m.shiftKey&&(u[0].focus(),m.preventDefault())}};return t.addEventListener("keydown",d),()=>t.removeEventListener("keydown",d)},[t,e.autofocus]);let a=$e(),l=x7(Xl,Be),c=()=>{a({openMenu:null}),l(!1),o.focus(),e.onCloseRequest()};return Tc(NT,{className:h7("Dialog",e.className,{"Dialog--fullscreen":i}),labelledBy:"dialog-title",maxWidth:E7(e.size),onCloseRequest:c,closeOnClickOutside:e.closeOnClickOutside,children:y7(Ut,{ref:r,children:[e.title&&Tc("h2",{id:`${n}-dialog-title`,className:"Dialog__title",children:Tc("span",{className:"Dialog__titleContent",children:e.title})}),Tc("button",{className:"Dialog__close",onClick:c,title:f("buttons.close"),"aria-label":f("buttons.close"),children:i?i0:Jr}),Tc("div",{className:"Dialog__content",children:e.children})]})})}});import w7,{useState as v7}from"react";import{Fragment as T7,jsx as qf}from"react/jsx-runtime";var p5,g5=y(()=>{"use strict";h();Y();co();be();p5=({children:e,onClose:t})=>{let[r,o]=v7(!!e),{container:n}=Nt(),i=w7.useCallback(()=>{o(!1),t&&t(),n?.focus()},[t,n]);return qf(T7,{children:r&&qf(gt,{size:"small",onCloseRequest:i,title:f("errorDialog.title"),children:qf("div",{style:{whiteSpace:"pre-wrap"},children:e})})})}});var h5=y(()=>{});import I7 from"clsx";import{jsx as f5,jsxs as S7}from"react/jsx-runtime";var b5,x5=y(()=>{"use strict";h();h5();b5=function({onChange:e,value:t,choices:r,name:o}){return f5("div",{className:"RadioGroup",children:r.map(n=>S7("div",{className:I7("RadioGroup__choice",{active:n.value===t}),children:[f5("input",{name:o,type:"radio",checked:n.value===t,onChange:()=>e(n.value)}),n.label]},n.label))})}});var E5=y(()=>{});import C7 from"clsx";import{jsx as y5}from"react/jsx-runtime";var Ic,w5=y(()=>{"use strict";h();E5();Ic=({title:e,name:t,checked:r,onChange:o,disabled:n=!1})=>y5("div",{className:C7("Switch",{toggled:r,disabled:n}),children:y5("input",{name:t,id:t,title:e,type:"checkbox",checked:r,disabled:n,onChange:()=>o(!r),onKeyDown:i=>{i.key===" "&&o(!r)}})})});var v5=y(()=>{});var T5=y(()=>{});import{forwardRef as k7}from"react";import A7 from"clsx";import{jsx as M7,jsxs as L7}from"react/jsx-runtime";var jo,Sc=y(()=>{"use strict";h();T5();jo=k7(({children:e,startIcon:t,onClick:r,label:o,variant:n="filled",color:i="primary",size:a="medium",fullWidth:l,className:c},s)=>L7("button",{className:A7("ExcButton",`ExcButton--color-${i}`,`ExcButton--variant-${n}`,`ExcButton--size-${a}`,{"ExcButton--fullWidth":l},c),onClick:r,type:"button","aria-label":o,ref:s,children:[t&&M7("div",{className:"ExcButton__icon","aria-hidden":!0,children:t}),n!=="icon"&&(e??o)]}))});import{useEffect as _7,useRef as P7,useState as Ci}from"react";import{jsx as ot,jsxs as ki}from"react/jsx-runtime";var D7,R7,N7,Cc,I5,S5=y(()=>{"use strict";h();bc();gi();X();vr();kn();Y();Ze();_n();se();co();x5();w5();ai();v5();be();Sc();W();Fl();D7="filter"in document.createElement("canvas").getContext("2d"),R7=()=>ki("div",{children:[ot("h3",{children:f("canvasError.cannotShowPreview")}),ot("p",{children:ot("span",{children:f("canvasError.canvasTooBig")})}),ki("em",{children:["(",f("canvasError.canvasTooBigTip"),")"]})]}),N7=({appStateSnapshot:e,elementsSnapshot:t,files:r,actionManager:o,onExportImage:n})=>{let i=ze(t,e),a=li(),[l,c]=Ci(e.name),[s,d]=Ci(i),[m,u]=Ci(e.exportBackground),[p,g]=Ci(e.exportWithDarkMode),[b,E]=Ci(e.exportEmbedScene),[w,v]=Ci(e.exportScale),T=P7(null),[k,M]=Ci(null),{exportedElements:A,exportingFrame:D}=wa(t,e,s);return _7(()=>{let R=T.current;if(!R)return;let H=R.offsetWidth,C=R.offsetHeight;H&&wi({elements:A,appState:{...e,name:l,exportBackground:m,exportWithDarkMode:p,exportScale:w,exportEmbedScene:b},files:r,exportPadding:bo,maxWidthOrHeight:Math.max(H,C),exportingFrame:D}).then(O=>(M(null),Mn(O).then(()=>{R.replaceChildren(O)}))).catch(O=>{console.error(O),M(O)})},[e,r,A,D,l,m,p,w,b]),ki("div",{className:"ImageExportModal",children:[ot("h3",{children:f("imageExportDialog.header")}),ki("div",{className:"ImageExportModal__preview",children:[ot("div",{className:"ImageExportModal__preview__canvas",ref:T,children:k&&ot(R7,{})}),ot("div",{className:"ImageExportModal__preview__filename",children:!bi&&ot("input",{type:"text",className:"TextInput",value:l,style:{width:"30ch"},disabled:typeof a.name<"u"||e.viewModeEnabled,onChange:R=>{c(R.target.value),o.executeAction(qh,"ui",R.target.value)}})})]}),ki("div",{className:"ImageExportModal__settings",children:[ot("h3",{children:f("imageExportDialog.header")}),i&&ot(Cc,{label:f("imageExportDialog.label.onlySelected"),name:"exportOnlySelected",children:ot(Ic,{name:"exportOnlySelected",checked:s,onChange:R=>{d(R)}})}),ot(Cc,{label:f("imageExportDialog.label.withBackground"),name:"exportBackgroundSwitch",children:ot(Ic,{name:"exportBackgroundSwitch",checked:m,onChange:R=>{u(R),o.executeAction(Jh,"ui",R)}})}),D7&&ot(Cc,{label:f("imageExportDialog.label.darkMode"),name:"exportDarkModeSwitch",children:ot(Ic,{name:"exportDarkModeSwitch",checked:p,onChange:R=>{g(R),o.executeAction(n3,"ui",R)}})}),ot(Cc,{label:f("imageExportDialog.label.embedScene"),tooltip:f("imageExportDialog.tooltip.embedScene"),name:"exportEmbedSwitch",children:ot(Ic,{name:"exportEmbedSwitch",checked:b,onChange:R=>{E(R),o.executeAction(lu,"ui",R)}})}),ot(Cc,{label:f("imageExportDialog.label.scale"),name:"exportScale",children:ot(b5,{name:"exportScale",value:w,onChange:R=>{v(R),o.executeAction(o3,"ui",R)},choices:Na.map(R=>({value:R,label:`${R}\xD7`}))})}),ki("div",{className:"ImageExportModal__settings__buttons",children:[ot(jo,{className:"ImageExportModal__settings__buttons__button",label:f("imageExportDialog.title.exportToPng"),onClick:()=>n(td.png,A,{exportingFrame:D}),startIcon:og,children:f("imageExportDialog.button.exportToPng")}),ot(jo,{className:"ImageExportModal__settings__buttons__button",label:f("imageExportDialog.title.exportToSvg"),onClick:()=>n(td.svg,A,{exportingFrame:D}),startIcon:og,children:f("imageExportDialog.button.exportToSvg")}),(Tl||Vn)&&ot(jo,{className:"ImageExportModal__settings__buttons__button",label:f("imageExportDialog.title.copyPngToClipboard"),onClick:()=>n(td.clipboard,A,{exportingFrame:D}),startIcon:Od,children:f("imageExportDialog.button.copyPngToClipboard")})]})]})]})},Cc=({label:e,children:t,tooltip:r,name:o})=>ki("div",{className:"ImageExportModal__settings__setting",title:e,children:[ki("label",{htmlFor:o,className:"ImageExportModal__settings__setting__label",children:[e,r&&ot(Rr,{label:r,long:!0,children:W0})]}),ot("div",{className:"ImageExportModal__settings__setting__content",children:t})]}),I5=({elements:e,appState:t,files:r,actionManager:o,onExportImage:n,onCloseRequest:i})=>{let[{appStateSnapshot:a,elementsSnapshot:l}]=Ci(()=>({appStateSnapshot:Vr(t),elementsSnapshot:Vr(e)}));return ot(gt,{onCloseRequest:i,size:"wide",title:!1,children:ot(N7,{elementsSnapshot:l,appStateSnapshot:a,files:r,actionManager:o,onExportImage:n})})}});var C5=y(()=>{});import B7 from"clsx";import{jsx as O7}from"react/jsx-runtime";var Ou,Jf=y(()=>{"use strict";h();C5();Ou=({children:e,side:t,className:r})=>O7("div",{className:B7("FixedSideContainer",`FixedSideContainer_side_${t}`,r),children:e})});var k5=y(()=>{});import{jsx as A5}from"react/jsx-runtime";var F7,Fu,Qf=y(()=>{"use strict";h();Y();ae();W();Ar();k5();F7=({appState:e,isMobile:t,device:r,app:o})=>{let{activeTool:n,isResizing:i,isRotating:a,lastPointerDownWith:l}=e,c=e.multiElement!==null;if(e.openSidebar&&!r.editor.canFitSidebar)return null;if($r(e))return f("hints.eraserRevert");if(n.type==="arrow"||n.type==="line")return c?f("hints.linearElementMulti"):f("hints.linearElement");if(n.type==="freedraw")return f("hints.freeDraw");if(n.type==="text")return f("hints.text");if(n.type==="embeddable")return f("hints.embeddable");if(e.activeTool.type==="image"&&e.pendingImageElementId)return f("hints.placeImage");let s=o.scene.getSelectedElements(e);if(i&&l==="mouse"&&s.length===1){let d=s[0];return te(d)&&d.points.length===2?f("hints.lockAngle"):Yr(d)?f("hints.resizeImage"):f("hints.resize")}if(a&&l==="mouse")return f("hints.rotate");if(s.length===1&&z(s[0]))return f("hints.text_selected");if(e.editingElement&&z(e.editingElement))return f("hints.text_editing");if(n.type==="selection"){if(e.draggingElement?.type==="selection"&&!s.length&&!e.editingElement&&!e.editingLinearElement)return f("hints.deepBoxSelect");if(e.gridSize&&e.draggingElement)return f("hints.disableSnapping");if(!s.length&&!t)return f("hints.canvasPanning");if(s.length===1){if(te(s[0]))return e.editingLinearElement?e.editingLinearElement.selectedPointsIndices?f("hints.lineEditor_pointSelected"):f("hints.lineEditor_nothingSelected"):f("hints.lineEditor_info");if(!e.draggingElement&&Fo(s[0]))return f("hints.bindTextToElement")}}return null},Fu=({appState:e,isMobile:t,device:r,app:o})=>{let n=F7({appState:e,isMobile:t,device:r,app:o});return n?(n=_(n),A5("div",{className:"HintViewer",children:A5("span",{children:n})})):null}});import H7 from"clsx";import{jsx as L5,jsxs as G7}from"react/jsx-runtime";var z7,M5,Hu,e1=y(()=>{"use strict";h();pn();se();z7="medium",M5={CHECKED:gE,UNCHECKED:pE},Hu=e=>G7("label",{className:H7("ToolIcon ToolIcon__lock",`ToolIcon_size_${z7}`,{"is-mobile":e.isMobile}),title:`${e.title} \u2014 Q`,children:[L5("input",{className:"ToolIcon_type_checkbox",type:"checkbox",name:e.name,onChange:e.onChange,checked:e.checked,"aria-label":e.title,"data-testid":"toolbar-lock"}),L5("div",{className:"ToolIcon__icon",children:e.checked?M5.CHECKED:M5.UNCHECKED})]})});import{Fragment as U7,jsx as _5,jsxs as W7}from"react/jsx-runtime";var Ai,zu=y(()=>{"use strict";h();Y();be();Ai=({heading:e,children:t,...r})=>{let{id:o}=Nt(),n=_5("h2",{className:"visually-hidden",id:`${o}-${e}-title`,children:f(`headings.${e}`)});return _5("section",{...r,"aria-labelledby":`${o}-${e}-title`,children:typeof t=="function"?t(n):W7(U7,{children:[n,t]})})}});import V7 from"clsx";import{jsx as P5,jsxs as K7}from"react/jsx-runtime";var Y7,Gu,t1=y(()=>{"use strict";h();pn();se();Y7="medium",Gu=e=>e.penDetected?K7("label",{className:V7("ToolIcon ToolIcon__penMode",`ToolIcon_size_${Y7}`,{"is-mobile":e.isMobile}),title:`${e.title}`,children:[P5("input",{className:"ToolIcon_type_checkbox",type:"checkbox",name:e.name,onChange:e.onChange,checked:e.checked,"aria-label":e.title}),P5("div",{className:"ToolIcon__icon",children:IE})]}):null});var D5=y(()=>{});import{Fragment as R5,jsx as Je,jsxs as zr}from"react/jsx-runtime";var Uu,r1=y(()=>{"use strict";h();yt();Y();Ze();se();Ti();D5();Uu=e=>{let t=we(e.elements),r=ma(e.elements,e.appState),o=we(r);return Je("div",{className:"Stats",children:zr(Ut,{padding:2,children:[Je("div",{className:"close",onClick:e.onClose,children:Jr}),Je("h3",{children:f("stats.title")}),Je("table",{children:zr("tbody",{children:[Je("tr",{children:Je("th",{colSpan:2,children:f("stats.scene")})}),zr("tr",{children:[Je("td",{children:f("stats.elements")}),Je("td",{children:e.elements.length})]}),zr("tr",{children:[Je("td",{children:f("stats.width")}),Je("td",{children:Math.round(t[2])-Math.round(t[0])})]}),zr("tr",{children:[Je("td",{children:f("stats.height")}),Je("td",{children:Math.round(t[3])-Math.round(t[1])})]}),r.length===1&&Je("tr",{children:Je("th",{colSpan:2,children:f("stats.element")})}),r.length>1&&zr(R5,{children:[Je("tr",{children:Je("th",{colSpan:2,children:f("stats.selected")})}),zr("tr",{children:[Je("td",{children:f("stats.elements")}),Je("td",{children:r.length})]})]}),r.length>0&&zr(R5,{children:[zr("tr",{children:[Je("td",{children:"x"}),Je("td",{children:Math.round(o[0])})]}),zr("tr",{children:[Je("td",{children:"y"}),Je("td",{children:Math.round(o[1])})]}),zr("tr",{children:[Je("td",{children:f("stats.width")}),Je("td",{children:Math.round(o[2]-o[0])})]}),zr("tr",{children:[Je("td",{children:f("stats.height")}),Je("td",{children:Math.round(o[3]-o[1])})]})]}),r.length===1&&zr("tr",{children:[Je("td",{children:f("stats.angle")}),Je("td",{children:`${Math.round(r[0].angle*180/Math.PI)}\xB0`})]}),e.renderCustomStats?.(e.elements,e.appState)]})})]})})}});import $7 from"clsx";import{jsx as X7}from"react/jsx-runtime";var Wu,o1=y(()=>{"use strict";h();pn();Lt();se();me();Wu=e=>X7(ne,{className:$7("Shape",{fillable:!1}),type:"radio",icon:U0,name:"editor-current-shape",checked:e.checked,title:`${e.title} \u2014 H`,keyBindingLabel:e.isMobile?void 0:S.H.toLocaleUpperCase(),"aria-label":`${e.title} \u2014 H`,"aria-keyshortcuts":S.H,"data-testid":"toolbar-hand",onChange:()=>e.onChange?.()})});import{Fragment as Z7,jsx as Ot,jsxs as Mi}from"react/jsx-runtime";var N5,B5=y(()=>{"use strict";h();Y();Ca();ue();Jf();Ti();Qf();Ze();ku();zu();Qd();e1();t1();r1();Dn();o1();Ar();Hr();N5=({appState:e,elements:t,actionManager:r,setAppState:o,onLockToggle:n,onHandToolToggle:i,onPenModeToggle:a,renderTopRightUI:l,renderCustomStats:c,renderSidebars:s,device:d,renderWelcomeScreen:m,UIOptions:u,app:p})=>{let{WelcomeScreenCenterTunnel:g,MainMenuTunnel:b,DefaultSidebarTriggerTunnel:E}=rt(),w=()=>Mi(Ou,{side:"top",className:"App-top-bar",children:[m&&Ot(g.Out,{}),Ot(Ai,{heading:"shapes",children:T=>Ot(Bt.Col,{gap:4,align:"center",children:Mi(Bt.Row,{gap:1,className:"App-toolbar-container",children:[Mi(Ut,{padding:1,className:"App-toolbar App-toolbar--mobile",children:[T,Ot(Bt.Row,{gap:1,children:Ot(Cu,{appState:e,activeTool:e.activeTool,UIOptions:u,app:p})})]}),l&&l(!0,e),Mi("div",{className:"mobile-misc-tools-container",children:[!e.viewModeEnabled&&Ot(E.Out,{}),Ot(Gu,{checked:e.penMode,onChange:()=>a(null),title:f("toolBar.penMode"),isMobile:!0,penDetected:e.penDetected}),Ot(Hu,{checked:e.activeTool.locked,onChange:n,title:f("toolBar.lock"),isMobile:!0}),Ot(Wu,{checked:Eo(e),onChange:()=>i(),title:f("toolBar.hand"),isMobile:!0})]})]})})}),Ot(Fu,{appState:e,isMobile:!0,device:d,app:p})]}),v=()=>e.viewModeEnabled?Ot("div",{className:"App-toolbar-content",children:Ot(b.Out,{})}):Mi("div",{className:"App-toolbar-content",children:[Ot(b.Out,{}),r.renderAction("toggleEditMenu"),r.renderAction("undo"),r.renderAction("redo"),r.renderAction(e.multiElement?"finalize":"duplicateSelection"),r.renderAction("deleteSelectedElements")]});return Mi(Z7,{children:[s(),!e.viewModeEnabled&&w(),!e.openMenu&&e.showStats&&Ot(Uu,{appState:e,setAppState:o,elements:t,onClose:()=>{r.executeAction(vi)},renderCustomStats:c}),Ot("div",{className:"App-bottom-bar",style:{marginBottom:Go+Mo*2,marginLeft:Go+Mo*2,marginRight:Go+Mo*2},children:Mi(Ut,{padding:0,children:[e.openMenu==="shape"&&!e.viewModeEnabled&&ya(e,t)?Ot(Ai,{className:"App-mobile-menu",heading:"selectedShapeActions",children:Ot(Su,{appState:e,elements:t,renderAction:r.renderAction})}):null,Mi("footer",{className:"App-toolbar",children:[v(),e.scrolledOutside&&!e.openMenu&&!e.openSidebar&&Ot("button",{className:"scroll-back-to-content",onClick:()=>{o(T=>({...Ko(t,T)}))},children:f("buttons.scrollBackToContent")})]})]})})]})}});var O5=y(()=>{});import j7 from"open-color";import q7,{useLayoutEffect as J7,useRef as Q7,useState as e_}from"react";import{jsx as kc,jsxs as t_}from"react/jsx-runtime";var F5,H5,z5=y(()=>{"use strict";h();Qr();Zg();Y();mc();be();co();O5();F5=e=>{let t=Q7(null),[r,o]=e_(null);return J7(()=>{if(!e.spreadsheet)return;let n=Jw(e.chartType,e.spreadsheet,0,0);o(n);let i,a=t.current;return(async()=>(i=await Dl(n,{exportBackground:!1,viewBackgroundColor:j7.white},null),i.querySelector(".style-fonts")?.remove(),a.replaceChildren(),a.appendChild(i),e.selected&&a.parentNode.focus()))(),()=>{a.replaceChildren()}},[e.spreadsheet,e.chartType,e.selected]),kc("button",{className:"ChartPreview",onClick:()=>{r&&e.onClick(e.chartType,r)},children:kc("div",{ref:t})})},H5=({setAppState:e,appState:t,onClose:r})=>{let{onInsertElements:o}=ro(),n=q7.useCallback(()=>{r&&r()},[r]),i=(a,l)=>{o(l),Ee("paste","chart",a),e({currentChartType:a,pasteDialog:{shown:!1,data:null}})};return kc(gt,{size:"small",onCloseRequest:n,title:f("labels.pasteCharts"),className:"PasteChartDialog",autofocus:!1,children:t_("div",{className:"container",children:[kc(F5,{chartType:"bar",spreadsheet:t.pasteDialog.data,selected:t.currentChartType==="bar",onClick:i}),kc(F5,{chartType:"line",spreadsheet:t.pasteDialog.data,selected:t.currentChartType==="line",onClick:i})]})})}});var G5=y(()=>{});import r_ from"react";import{Fragment as W5,jsx as U,jsxs as mo}from"react/jsx-runtime";function*i_(e,t){let r=!0;for(let o of e)r||(yield t),r=!1,yield o}var o_,n_,n1,a_,$,l_,U5,V5=y(()=>{"use strict";h();Y();me();co();W();G5();se();gi();X();o_=()=>mo("div",{className:"HelpDialog__header",children:[mo("a",{className:"HelpDialog__btn",href:"https://docs.excalidraw.com",target:"_blank",rel:"noopener noreferrer",children:[f("helpDialog.documentation"),U("div",{className:"HelpDialog__link-icon",children:Nd})]}),mo("a",{className:"HelpDialog__btn",href:"https://blog.excalidraw.com",target:"_blank",rel:"noopener noreferrer",children:[f("helpDialog.blog"),U("div",{className:"HelpDialog__link-icon",children:Nd})]}),mo("a",{className:"HelpDialog__btn",href:"https://github.com/excalidraw/excalidraw/issues",target:"_blank",rel:"noopener noreferrer",children:[f("helpDialog.github"),U("div",{className:"HelpDialog__link-icon",children:Nd})]})]}),n_=e=>mo(W5,{children:[U("h3",{children:e.title}),U("div",{className:"HelpDialog__islands-container",children:e.children})]}),n1=e=>mo("div",{className:`HelpDialog__island ${e.className}`,children:[U("h4",{className:"HelpDialog__island-title",children:e.caption}),U("div",{className:"HelpDialog__island-content",children:e.children})]});a_=e=>e.replace(/\b[a-z]\b/,t=>t.toUpperCase()),$=({label:e,shortcuts:t,isOr:r=!0})=>{let o=t.map(n=>(n.endsWith("++")?[...n.slice(0,-2).split("+"),"+"]:n.split("+")).map(a=>U(l_,{children:a_(a)},a)));return mo("div",{className:"HelpDialog__shortcut",children:[U("div",{children:e}),U("div",{className:"HelpDialog__key-container",children:[...i_(o,r?f("helpDialog.or"):null)]})]})},l_=e=>U("kbd",{className:"HelpDialog__key",...e}),U5=({onClose:e})=>{let t=r_.useCallback(()=>{e&&e()},[e]);return U(W5,{children:mo(gt,{onCloseRequest:t,title:f("helpDialog.title"),className:"HelpDialog",children:[U(o_,{}),mo(n_,{title:f("helpDialog.shortcuts"),children:[mo(n1,{className:"HelpDialog__island--tools",caption:f("helpDialog.tools"),children:[U($,{label:f("toolBar.hand"),shortcuts:[S.H]}),U($,{label:f("toolBar.selection"),shortcuts:[S.V,S[1]]}),U($,{label:f("toolBar.rectangle"),shortcuts:[S.R,S[2]]}),U($,{label:f("toolBar.diamond"),shortcuts:[S.D,S[3]]}),U($,{label:f("toolBar.ellipse"),shortcuts:[S.O,S[4]]}),U($,{label:f("toolBar.arrow"),shortcuts:[S.A,S[5]]}),U($,{label:f("toolBar.line"),shortcuts:[S.L,S[6]]}),U($,{label:f("toolBar.freedraw"),shortcuts:[S.P,S[7]]}),U($,{label:f("toolBar.text"),shortcuts:[S.T,S[8]]}),U($,{label:f("toolBar.image"),shortcuts:[S[9]]}),U($,{label:f("toolBar.eraser"),shortcuts:[S.E,S[0]]}),U($,{label:f("toolBar.frame"),shortcuts:[S.F]}),U($,{label:f("toolBar.laser"),shortcuts:[S.K]}),U($,{label:f("labels.eyeDropper"),shortcuts:[S.I,"Shift+S","Shift+G"]}),U($,{label:f("helpDialog.editLineArrowPoints"),shortcuts:[_("CtrlOrCmd+Enter")]}),U($,{label:f("helpDialog.editText"),shortcuts:[_("Enter")]}),U($,{label:f("helpDialog.textNewLine"),shortcuts:[_("Enter"),_("Shift+Enter")]}),U($,{label:f("helpDialog.textFinish"),shortcuts:[_("Esc"),_("CtrlOrCmd+Enter")]}),U($,{label:f("helpDialog.curvedArrow"),shortcuts:["A",f("helpDialog.click"),f("helpDialog.click"),f("helpDialog.click")],isOr:!1}),U($,{label:f("helpDialog.curvedLine"),shortcuts:["L",f("helpDialog.click"),f("helpDialog.click"),f("helpDialog.click")],isOr:!1}),U($,{label:f("toolBar.lock"),shortcuts:[S.Q]}),U($,{label:f("helpDialog.preventBinding"),shortcuts:[_("CtrlOrCmd")]}),U($,{label:f("toolBar.link"),shortcuts:[_("CtrlOrCmd+K")]})]}),mo(n1,{className:"HelpDialog__island--view",caption:f("helpDialog.view"),children:[U($,{label:f("buttons.zoomIn"),shortcuts:[_("CtrlOrCmd++")]}),U($,{label:f("buttons.zoomOut"),shortcuts:[_("CtrlOrCmd+-")]}),U($,{label:f("buttons.resetZoom"),shortcuts:[_("CtrlOrCmd+0")]}),U($,{label:f("helpDialog.zoomToFit"),shortcuts:["Shift+1"]}),U($,{label:f("helpDialog.zoomToSelection"),shortcuts:["Shift+2"]}),U($,{label:f("helpDialog.movePageUpDown"),shortcuts:["PgUp/PgDn"]}),U($,{label:f("helpDialog.movePageLeftRight"),shortcuts:["Shift+PgUp/PgDn"]}),U($,{label:f("buttons.zenMode"),shortcuts:[_("Alt+Z")]}),U($,{label:f("buttons.objectsSnapMode"),shortcuts:[_("Alt+S")]}),U($,{label:f("labels.showGrid"),shortcuts:[_("CtrlOrCmd+'")]}),U($,{label:f("labels.viewMode"),shortcuts:[_("Alt+R")]}),U($,{label:f("labels.toggleTheme"),shortcuts:[_("Alt+Shift+D")]}),U($,{label:f("stats.title"),shortcuts:[_("Alt+/")]})]}),mo(n1,{className:"HelpDialog__island--editor",caption:f("helpDialog.editor"),children:[U($,{label:f("labels.moveCanvas"),shortcuts:[_(`Space+${f("helpDialog.drag")}`),_(`Wheel+${f("helpDialog.drag")}`)],isOr:!0}),U($,{label:f("buttons.clearReset"),shortcuts:[_("CtrlOrCmd+Delete")]}),U($,{label:f("labels.delete"),shortcuts:[_("Delete")]}),U($,{label:f("labels.cut"),shortcuts:[_("CtrlOrCmd+X")]}),U($,{label:f("labels.copy"),shortcuts:[_("CtrlOrCmd+C")]}),U($,{label:f("labels.paste"),shortcuts:[_("CtrlOrCmd+V")]}),U($,{label:f("labels.pasteAsPlaintext"),shortcuts:[_("CtrlOrCmd+Shift+V")]}),U($,{label:f("labels.selectAll"),shortcuts:[_("CtrlOrCmd+A")]}),U($,{label:f("labels.multiSelect"),shortcuts:[_(`Shift+${f("helpDialog.click")}`)]}),U($,{label:f("helpDialog.deepSelect"),shortcuts:[_(`CtrlOrCmd+${f("helpDialog.click")}`)]}),U($,{label:f("helpDialog.deepBoxSelect"),shortcuts:[_(`CtrlOrCmd+${f("helpDialog.drag")}`)]}),(Tl||Vn)&&U($,{label:f("labels.copyAsPng"),shortcuts:[_("Shift+Alt+C")]}),U($,{label:f("labels.copyStyles"),shortcuts:[_("CtrlOrCmd+Alt+C")]}),U($,{label:f("labels.pasteStyles"),shortcuts:[_("CtrlOrCmd+Alt+V")]}),U($,{label:f("labels.sendToBack"),shortcuts:[rr?_("CtrlOrCmd+Alt+["):_("CtrlOrCmd+Shift+[")]}),U($,{label:f("labels.bringToFront"),shortcuts:[rr?_("CtrlOrCmd+Alt+]"):_("CtrlOrCmd+Shift+]")]}),U($,{label:f("labels.sendBackward"),shortcuts:[_("CtrlOrCmd+[")]}),U($,{label:f("labels.bringForward"),shortcuts:[_("CtrlOrCmd+]")]}),U($,{label:f("labels.alignTop"),shortcuts:[_("CtrlOrCmd+Shift+Up")]}),U($,{label:f("labels.alignBottom"),shortcuts:[_("CtrlOrCmd+Shift+Down")]}),U($,{label:f("labels.alignLeft"),shortcuts:[_("CtrlOrCmd+Shift+Left")]}),U($,{label:f("labels.alignRight"),shortcuts:[_("CtrlOrCmd+Shift+Right")]}),U($,{label:f("labels.duplicateSelection"),shortcuts:[_("CtrlOrCmd+D"),_(`Alt+${f("helpDialog.drag")}`)]}),U($,{label:f("helpDialog.toggleElementLock"),shortcuts:[_("CtrlOrCmd+Shift+L")]}),U($,{label:f("buttons.undo"),shortcuts:[_("CtrlOrCmd+Z")]}),U($,{label:f("buttons.redo"),shortcuts:qc?[_("CtrlOrCmd+Y"),_("CtrlOrCmd+Shift+Z")]:[_("CtrlOrCmd+Shift+Z")]}),U($,{label:f("labels.group"),shortcuts:[_("CtrlOrCmd+G")]}),U($,{label:f("labels.ungroup"),shortcuts:[_("CtrlOrCmd+Shift+G")]}),U($,{label:f("labels.flipHorizontal"),shortcuts:[_("Shift+H")]}),U($,{label:f("labels.flipVertical"),shortcuts:[_("Shift+V")]}),U($,{label:f("labels.showStroke"),shortcuts:[_("S")]}),U($,{label:f("labels.showBackground"),shortcuts:[_("G")]}),U($,{label:f("labels.decreaseFontSize"),shortcuts:[_("CtrlOrCmd+Shift+<")]}),U($,{label:f("labels.increaseFontSize"),shortcuts:[_("CtrlOrCmd+Shift+>")]})]})]})]})})}});var Y5=y(()=>{});import l1 from"react";import K5 from"clsx";import*as Jl from"@radix-ui/react-popover";import{jsx as Li,jsxs as ql}from"react/jsx-runtime";var i1,s_,c_,a1,d_,Vu,s1=y(()=>{"use strict";h();Y5();ai();be();Ti();se();Y();W();i1=3,s_=8,c_=({shouldWrap:e,children:t,clientId:r,username:o})=>e?Li(Rr,{label:o||"Unknown user",children:t},r):Li(l1.Fragment,{children:t},r),a1=({actionManager:e,collaborator:t,clientId:r,withName:o=!1,shouldWrapWithTooltip:n=!1,isBeingFollowed:i})=>{let a={clientId:r,collaborator:t,withName:o,isBeingFollowed:i},l=e.renderAction("goToCollaborator",a);return Li(c_,{clientId:r,username:t.username,shouldWrap:n,children:l},r)},d_=["avatarUrl","id","socketId","username"],Vu=l1.memo(({className:e,mobile:t,collaborators:r,userToFollow:o})=>{let n=Wt(),i=new Map;r.forEach((p,g)=>{let b=p.id||g;i.set(b,{...p,socketId:g})});let a=Array.from(i).filter(([p,g])=>g.username?.trim()),[l,c]=l1.useState("");if(a.length===0)return null;let d=l.trim().toLowerCase()?a.filter(([,p])=>p.username?.toLowerCase().includes(l)):a,u=a.slice(0,i1).map(([p,g])=>a1({actionManager:n,collaborator:g,clientId:p,shouldWrapWithTooltip:!0,isBeingFollowed:g.socketId===o}));return t?Li("div",{className:K5("UserList UserList_mobile",e),children:a.map(([p,g])=>a1({actionManager:n,collaborator:g,clientId:p,shouldWrapWithTooltip:!0,isBeingFollowed:g.socketId===o}))}):ql("div",{className:K5("UserList",e),children:[u,a.length>i1&&ql(Jl.Root,{onOpenChange:p=>{p||c("")},children:[ql(Jl.Trigger,{className:"UserList__more",children:["+",a.length-i1]}),Li(Jl.Content,{style:{zIndex:2,width:"13rem",textAlign:"left"},align:"end",sideOffset:10,children:ql(Ut,{style:{overflow:"hidden"},children:[a.length>=s_&&ql("div",{className:"UserList__search-wrapper",children:[J0,Li("input",{className:"UserList__search",type:"text",placeholder:f("userList.search.placeholder"),value:l,onChange:p=>{c(p.target.value)}})]}),ql("div",{className:"dropdown-menu UserList__collaborators",children:[d.length===0&&Li("div",{className:"UserList__collaborators__empty",children:f("userList.search.empty")}),Li("div",{className:"UserList__hint",children:f("userList.hint.text")}),d.map(([p,g])=>a1({actionManager:n,collaborator:g,clientId:p,withName:!0,isBeingFollowed:g.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;for(let[r,o]of e.collaborators){let n=t.collaborators.get(r);if(!n||!bt(o,n,d_))return!1}return!0})});var $5=y(()=>{});import c1 from"open-color";import{jsx as m_}from"react/jsx-runtime";var d1,X5=y(()=>{"use strict";h();$5();d1=({children:e,color:t})=>m_("div",{className:"Card",style:{"--card-color":t==="primary"?"var(--color-primary)":c1[t][7],"--card-color-darker":t==="primary"?"var(--color-primary-darker)":c1[t][8],"--card-color-darkest":t==="primary"?"var(--color-primary-darkest)":c1[t][9]},children:e})});var Z5=y(()=>{});import u_ from"react";import{Fragment as g_,jsx as _o,jsxs as Yu}from"react/jsx-runtime";var p_,j5,q5=y(()=>{"use strict";h();Y();co();se();Lt();bc();X5();Z5();kn();Qr();W();p_=({elements:e,appState:t,setAppState:r,files:o,actionManager:n,exportOpts:i,canvas:a,onCloseRequest:l})=>{let{onExportToBackend:c}=i;return _o("div",{className:"ExportDialog ExportDialog--json",children:Yu("div",{className:"ExportDialog-cards",children:[i.saveFileToDisk&&Yu(d1,{color:"lime",children:[_o("div",{className:"Card-icon",children:UE}),_o("h2",{children:f("exportDialog.disk_title")}),Yu("div",{className:"Card-details",children:[f("exportDialog.disk_details"),!bi&&n.renderAction("changeProjectName")]}),_o(ne,{className:"Card-button",type:"button",title:f("exportDialog.disk_button"),"aria-label":f("exportDialog.disk_button"),showAriaLabel:!0,onClick:()=>{n.executeAction(fc,"ui")}})]}),c&&Yu(d1,{color:"pink",children:[_o("div",{className:"Card-icon",children:Bd}),_o("h2",{children:f("exportDialog.link_title")}),_o("div",{className:"Card-details",children:f("exportDialog.link_details")}),_o(ne,{className:"Card-button",type:"button",title:f("exportDialog.link_button"),"aria-label":f("exportDialog.link_button"),showAriaLabel:!0,onClick:async()=>{try{Ee("export","link",`ui (${yx()})`),await c(e,t,o,a),l()}catch(s){r({errorMessage:s.message})}}})]}),i.renderCustomUI&&i.renderCustomUI(e,t,o,a)]})})},j5=({elements:e,appState:t,files:r,actionManager:o,exportOpts:n,canvas:i,setAppState:a})=>{let l=u_.useCallback(()=>{a({openDialog:null})},[a]);return _o(g_,{children:t.openDialog?.name==="jsonExport"&&_o(gt,{onCloseRequest:l,title:f("buttons.export"),children:_o(p_,{elements:e,appState:t,setAppState:a,files:r,actionManager:o,onCloseRequest:l,exportOpts:n,canvas:i})})})}});import{jsx as h_}from"react/jsx-runtime";var J5,Q5=y(()=>{"use strict";h();Y();se();J5=e=>h_("button",{className:"help-icon",onClick:e.onClick,type:"button",title:`${f("helpDialog.title")} \u2014 ?`,"aria-label":f("helpDialog.title"),children:Za})});import Ku from"clsx";import{jsx as qo,jsxs as m1}from"react/jsx-runtime";var e6,t6,r6=y(()=>{"use strict";h();Dn();ku();be();Hr();Q5();zu();Ca();e6=({appState:e,actionManager:t,showExitZenModeBtn:r,renderWelcomeScreen:o})=>{let{FooterCenterTunnel:n,WelcomeScreenHelpHintTunnel:i}=rt(),a=De(),l=!e.viewModeEnabled&&e.multiElement&&a.isTouchScreen;return m1("footer",{role:"contentinfo",className:"layer-ui__wrapper__footer App-menu App-menu_bottom",children:[qo("div",{className:Ku("layer-ui__wrapper__footer-left zen-mode-transition",{"layer-ui__wrapper__footer-left--transition-left":e.zenModeEnabled}),children:qo(Bt.Col,{gap:2,children:m1(Ai,{heading:"canvasActions",children:[qo(CT,{renderAction:t.renderAction,zoom:e.zoom}),!e.viewModeEnabled&&qo(kT,{renderAction:t.renderAction,className:Ku("zen-mode-transition",{"layer-ui__wrapper__footer-left--transition-bottom":e.zenModeEnabled})}),l&&qo(MT,{renderAction:t.renderAction,className:Ku("zen-mode-transition",{"layer-ui__wrapper__footer-left--transition-left":e.zenModeEnabled})})]})})}),qo(n.Out,{}),qo("div",{className:Ku("layer-ui__wrapper__footer-right zen-mode-transition",{"transition-right":e.zenModeEnabled}),children:m1("div",{style:{position:"relative"},children:[o&&qo(i.Out,{}),qo(J5,{onClick:()=>t.executeAction(Ia)})]})}),qo(AT,{actionManager:t,showExitZenModeBtn:r})]})},t6=e6;e6.displayName="Footer"});import f_ from"react";var $u,u1=y(()=>{"use strict";h();$u=f_.createContext({})});var o6=y(()=>{});import b_ from"clsx";import{jsx as x_}from"react/jsx-runtime";var Jo,Ql=y(()=>{"use strict";h();W();o6();Jo=({type:e="button",onSelect:t,selected:r,children:o,className:n="",...i})=>x_("button",{onClick:Xn(i.onClick,a=>{t()}),type:e,className:b_("excalidraw-button",n,{selected:r}),...i,children:o})});import E_ from"clsx";import{useContext as y_}from"react";import{jsx as p1,jsxs as n6}from"react/jsx-runtime";var g1,i6=y(()=>{"use strict";h();Y();be();u1();se();ai();Ql();g1=({children:e,className:t})=>{let r=De(),o=y_($u),n=!!(r.editor.canFitSidebar&&o.shouldRenderDockButton);return n6("div",{className:E_("sidebar__header",t),"data-testid":"sidebar-header",children:[e,n6("div",{className:"sidebar__header__buttons",children:[n&&p1(Rr,{label:f("labels.sidebarLock"),children:p1(Jo,{onSelect:()=>o.onDock?.(!o.docked),selected:!!o.docked,className:"sidebar__dock","data-testid":"sidebar-dock","aria-label":f("labels.sidebarLock"),children:uE})}),p1(Jo,{"data-testid":"sidebar-close",className:"sidebar__close",onSelect:o.onCloseRequest,"aria-label":f("buttons.close"),children:Jr})]})]})};g1.displayName="SidebarHeader"});var a6=y(()=>{});import w_ from"clsx";import{jsx as h1,jsxs as l6}from"react/jsx-runtime";var f1,s6=y(()=>{"use strict";h();be();zt();a6();f1=({name:e,tab:t,icon:r,title:o,children:n,onToggle:i,className:a,style:l})=>{let c=$e(),s=He();return l6("label",{title:o,className:"sidebar-trigger__label-element",children:[h1("input",{className:"ToolIcon_type_checkbox",type:"checkbox",onChange:d=>{document.querySelector(".layer-ui__wrapper")?.classList.remove("animate");let m=d.target.checked;c({openSidebar:m?{name:e,tab:t}:null}),i?.(m)},checked:s.openSidebar?.name===e,"aria-label":o,"aria-keyshortcuts":"0"}),l6("div",{className:w_("sidebar-trigger",a),style:l,children:[r&&h1("div",{children:r}),n&&h1("div",{className:"sidebar-trigger__label",children:n})]})]})};f1.displayName="SidebarTrigger"});import*as c6 from"@radix-ui/react-tabs";import{jsx as v_}from"react/jsx-runtime";var b1,d6=y(()=>{"use strict";h();b1=({children:e,...t})=>v_(c6.List,{className:"sidebar-triggers",...t,children:e});b1.displayName="SidebarTabTriggers"});import*as u6 from"@radix-ui/react-tabs";import{jsx as m6}from"react/jsx-runtime";var x1,p6=y(()=>{"use strict";h();x1=({children:e,tab:t,onSelect:r,...o})=>m6(u6.Trigger,{value:t,asChild:!0,onSelect:r,children:m6("button",{type:"button",className:"excalidraw-button sidebar-tab-trigger",...o,children:e})});x1.displayName="SidebarTabTrigger"});import*as g6 from"@radix-ui/react-tabs";import{jsx as T_}from"react/jsx-runtime";var E1,h6=y(()=>{"use strict";h();zt();be();E1=({children:e,...t})=>{let r=He(),o=$e();if(!r.openSidebar)return null;let{name:n}=r.openSidebar;return T_(g6.Root,{className:"sidebar-tabs-root",value:r.openSidebar.tab,onValueChange:i=>o(a=>({...a,openSidebar:{...a.openSidebar,name:n,tab:i}})),...t,children:e})};E1.displayName="SidebarTabs"});import*as f6 from"@radix-ui/react-tabs";import{jsx as I_}from"react/jsx-runtime";var y1,b6=y(()=>{"use strict";h();y1=({tab:e,children:t,...r})=>I_(f6.Content,{...r,value:e,children:t});y1.displayName="SidebarTab"});var x6=y(()=>{});import{useEffect as w6,useLayoutEffect as v6,useRef as w1,useState as S_,forwardRef as T6,useImperativeHandle as C_,useCallback as E6}from"react";import{atom as k_,useSetAtom as A_}from"jotai";import M_ from"clsx";import{jsx as y6}from"react/jsx-runtime";import{createElement as L_}from"react";var Ac,I6,Bn,Mc=y(()=>{"use strict";h();Ti();_t();u1();i6();be();W();me();X();s6();d6();p6();h6();b6();zt();sm();x6();Ac=k_(!1),I6=T6(({name:e,children:t,onDock:r,docked:o,className:n,...i},a)=>{I.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=$e(),c=A_(Ac,Be);v6(()=>(c(!!o),()=>{c(!1)}),[c,o]);let s=w1({});s.current.onCloseRequest=()=>{l({openSidebar:null})},s.current.onDock=p=>r?.(p),s.current=Fa(s.current,{docked:o,shouldRenderDockButton:!!r&&o!=null});let d=w1(null);C_(a,()=>d.current);let m=De(),u=E6(()=>{document.querySelector(".Dialog")||l({openSidebar:null})},[l]);return yl(d,E6(p=>{p.target.closest(".sidebar-trigger")||(!o||!m.editor.canFitSidebar)&&u()},[u,o,m.editor.canFitSidebar])),w6(()=>{let p=g=>{g.key===S.ESCAPE&&(!o||!m.editor.canFitSidebar)&&u()};return document.addEventListener("keydown",p),()=>{document.removeEventListener("keydown",p)}},[u,o,m.editor.canFitSidebar]),y6(Ut,{...i,className:M_("sidebar",{"sidebar--docked":o},n),ref:d,children:y6($u.Provider,{value:s.current,children:t})})});I6.displayName="SidebarInner";Bn=Object.assign(T6((e,t)=>{let r=He(),{onStateChange:o}=e,n=w1(r.openSidebar);w6(()=>{(!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]=S_(!1);return v6(()=>(a(!0),()=>a(!1)),[]),i&&r.openSidebar?.name===e.name?L_(I6,{...e,ref:t,key:e.name}):null}),{Header:g1,TabTriggers:b1,TabTrigger:x1,Tabs:E1,Tab:y1,Trigger:f1});Bn.displayName="Sidebar"});var S6=y(()=>{});import{atom as __,useAtom as P_}from"jotai";import{jsx as R_,jsxs as D_}from"react/jsx-runtime";var Lc,C6,Xu=y(()=>{"use strict";h();Dn();Y();_t();be();Gf();Lc=__(null),C6=()=>{let[e,t]=P_(Lc,Be),r=Wt();return e&&e==="clearCanvas"?R_(_u,{onConfirm:()=>{r.executeAction(Ks),t(null)},onCancel:()=>t(null),title:f("clearCanvasDialog.title"),children:D_("p",{className:"clear-canvas__content",children:[" ",f("alerts.clearReset")]})}):null}});import{atom as N_}from"jotai";async function k6({title:e,description:t,actionLabel:r,color:o}){return new Promise(n=>{mr.set(v1,{active:!0,onConfirm:()=>n(!0),onClose:()=>n(!1),onReject:()=>n(!1),title:e,description:t,actionLabel:r,color:o})})}var v1,T1=y(()=>{"use strict";h();_t();v1=N_({active:!1})});var I1={};Cb(I1,{ChangeCanvasBackground:()=>R6,ClearCanvas:()=>P6,Export:()=>N6,Help:()=>_6,LiveCollaborationTrigger:()=>O6,LoadScene:()=>A6,SaveAsImage:()=>L6,SaveToActiveFile:()=>M6,Socials:()=>B6,ToggleTheme:()=>D6});import B_ from"clsx";import{useSetAtom as O_}from"jotai";import{Fragment as F_,jsx as Jt,jsxs as F6}from"react/jsx-runtime";var A6,M6,L6,_6,P6,D6,R6,N6,B6,O6,H6=y(()=>{"use strict";h();xu();Y();be();se();se();Rf();Nf();Dn();S6();Xu();_t();zt();T1();Kl();A6=()=>{let{t:e}=Pt(),t=Wt(),r=mi();return t.isActionEnabled(Hl)?Jt(Lo,{icon:ja,onSelect:async()=>{(!r.length||await k6({title:e("overwriteConfirm.modal.loadFromFile.title"),actionLabel:e("overwriteConfirm.modal.loadFromFile.button"),color:"warning",description:Jt(sr,{i18nKey:"overwriteConfirm.modal.loadFromFile.description",bold:n=>Jt("strong",{children:n}),br:()=>Jt("br",{})})}))&&t.executeAction(Hl)},"data-testid":"load-button",shortcut:Rn("loadScene"),"aria-label":e("buttons.load"),children:e("buttons.load")}):null};A6.displayName="LoadScene";M6=()=>{let{t:e}=Pt(),t=Wt();return t.isActionEnabled(su)?Jt(Lo,{shortcut:Rn("saveScene"),"data-testid":"save-button",onSelect:()=>t.executeAction(su),icon:FE,"aria-label":`${e("buttons.save")}`,children:`${e("buttons.save")}`}):null};M6.displayName="SaveToActiveFile";L6=()=>{let e=$e(),{t}=Pt();return Jt(Lo,{icon:GE,"data-testid":"image-export-button",onSelect:()=>e({openDialog:{name:"imageExport"}}),shortcut:Rn("imageExport"),"aria-label":t("buttons.exportImage"),children:t("buttons.exportImage")})};L6.displayName="SaveAsImage";_6=()=>{let{t:e}=Pt(),t=Wt();return Jt(Lo,{"data-testid":"help-menu-item",icon:Za,onSelect:()=>t.executeAction(Ia),shortcut:"?","aria-label":e("helpDialog.title"),children:e("helpDialog.title")})};_6.displayName="Help";P6=()=>{let{t:e}=Pt(),t=O_(Lc,Be);return Wt().isActionEnabled(Ks)?Jt(Lo,{icon:ii,onSelect:()=>t("clearCanvas"),"data-testid":"clear-canvas-button","aria-label":e("buttons.clearReset"),children:e("buttons.clearReset")}):null};P6.displayName="ClearCanvas";D6=()=>{let{t:e}=Pt(),t=He(),r=Wt();return r.isActionEnabled(xm)?Jt(Lo,{onSelect:o=>(o.preventDefault(),r.executeAction(xm)),icon:t.theme==="dark"?DE:PE,"data-testid":"toggle-dark-mode",shortcut:Rn("toggleTheme"),"aria-label":t.theme==="dark"?e("buttons.lightMode"):e("buttons.darkMode"),children:t.theme==="dark"?e("buttons.lightMode"):e("buttons.darkMode")}):null};D6.displayName="ToggleTheme";R6=()=>{let{t:e}=Pt(),t=He(),r=Wt(),o=li();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}=Pt(),t=$e();return Jt(Lo,{icon:Rd,onSelect:()=>{t({openDialog:{name:"jsonExport"}})},"data-testid":"json-export-button","aria-label":e("buttons.export"),children:e("buttons.export")})};N6.displayName="Export";B6=()=>F6(F_,{children:[Jt(Yl,{icon:RE,href:"https://github.com/excalidraw/excalidraw","aria-label":"GitHub",children:"GitHub"}),Jt(Yl,{icon:NE,href:"https://discord.gg/UexuTaE","aria-label":"Discord",children:"Discord"}),Jt(Yl,{icon:BE,href:"https://twitter.com/excalidraw","aria-label":"Twitter",children:"Twitter"})]});B6.displayName="Socials";O6=({onSelect:e,isCollaborating:t})=>{let{t:r}=Pt();return Jt(Lo,{"data-testid":"collab-button",icon:qa,className:B_({"active-collab":t}),onSelect:e,children:r("labels.liveCollaboration")})};O6.displayName="LiveCollaborationTrigger"});import{atom as H_,useAtom as z_}from"jotai";import{useLayoutEffect as G_,useRef as U_}from"react";import{jsx as W_}from"react/jsx-runtime";var On,_c=y(()=>{"use strict";h();Hr();On=(e,t)=>{let r=H_(0),o=n=>{let{jotaiScope:i}=rt(),[,a]=z_(r,i),l=U_({preferHost:!1,counter:0});return G_(()=>{let c=l.current;return a(s=>{let d=s+1;return c.counter=d,d}),()=>{a(s=>{let d=s-1;return c.counter=d,d||(c.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:W_(t,{...n})};return o.displayName=e,o}});import{jsx as Zu,jsxs as S1}from"react/jsx-runtime";var V_,cr,C1=y(()=>{"use strict";h();be();yc();H6();s1();Y();se();_c();W();Hr();zt();V_=Object.assign(On("MainMenu",({children:e,onSelect:t})=>{let{MainMenuTunnel:r}=rt(),o=De(),n=He(),i=$e(),a=o.editor.isMobile?void 0:()=>i({openMenu:null});return Zu(r.In,{children:S1(Ne,{open:n.openMenu==="canvas",children:[Zu(Ne.Trigger,{onToggle:()=>{i({openMenu:n.openMenu==="canvas"?null:"canvas"})},"data-testid":"main-menu-trigger",className:"main-menu-trigger",children:Dd}),S1(Ne.Content,{onClickOutside:a,onSelect:Xn(t,()=>{i({openMenu:null})}),children:[e,o.editor.isMobile&&n.collaborators.size>0&&S1("fieldset",{className:"UserList-Wrapper",children:[Zu("legend",{children:f("labels.collaborators")}),Zu(Vu,{mobile:!0,collaborators:n.collaborators,userToFollow:n.userToFollow?.socketId||null})]})]})]})})}),{Trigger:Ne.Trigger,Item:Ne.Item,ItemLink:Ne.ItemLink,ItemCustom:Ne.ItemCustom,Group:Ne.Group,Separator:Ne.Separator,DefaultItems:I1}),cr=V_});import{jsx as es,jsxs as $_}from"react/jsx-runtime";var ju,Y_,K_,k1,z6=y(()=>{"use strict";h();Sc();be();Dn();Y();bc();ju=({title:e,children:t,actionLabel:r,onClick:o})=>$_("div",{className:"OverwriteConfirm__Actions__Action",children:[es("h4",{children:e}),es("div",{className:"OverwriteConfirm__Actions__Action__content",children:t}),es(jo,{variant:"outlined",color:"muted",label:r,size:"large",fullWidth:!0,onClick:o})]}),Y_=()=>{let{t:e}=Pt(),t=Wt(),r=$e();return es(ju,{title:e("overwriteConfirm.action.exportToImage.title"),actionLabel:e("overwriteConfirm.action.exportToImage.button"),onClick:()=>{t.executeAction(lu,"ui",!0),r({openDialog:{name:"imageExport"}})},children:e("overwriteConfirm.action.exportToImage.description")})},K_=()=>{let{t:e}=Pt(),t=Wt();return es(ju,{title:e("overwriteConfirm.action.saveToDisk.title"),actionLabel:e("overwriteConfirm.action.saveToDisk.button"),onClick:()=>{t.executeAction(fc,"ui")},children:e("overwriteConfirm.action.saveToDisk.description")})},k1=Object.assign(({children:e})=>es("div",{className:"OverwriteConfirm__Actions",children:e}),{ExportToImage:Y_,SaveToDisk:K_})});var G6=y(()=>{});import{useAtom as X_}from"jotai";import{jsx as _i,jsxs as U6}from"react/jsx-runtime";var qu,W6=y(()=>{"use strict";h();Hr();_t();co();_c();T1();Sc();se();z6();G6();qu=Object.assign(On("OverwriteConfirmDialog",({children:e})=>{let{OverwriteConfirmDialogTunnel:t}=rt(),[r,o]=X_(v1,Be);if(!r.active)return null;let n=()=>{r.onClose(),o(a=>({...a,active:!1}))},i=()=>{r.onConfirm(),o(a=>({...a,active:!1}))};return _i(t.In,{children:_i(gt,{onCloseRequest:n,title:!1,size:916,children:U6("div",{className:"OverwriteConfirm",children:[_i("h3",{children:r.title}),U6("div",{className:`OverwriteConfirm__Description OverwriteConfirm__Description--color-${r.color}`,children:[_i("div",{className:"OverwriteConfirm__Description__icon",children:V0}),_i("div",{children:r.description}),_i("div",{className:"OverwriteConfirm__Description__spacer"}),_i(jo,{color:r.color,size:"large",label:r.actionLabel,onClick:i})]}),_i(k1,{children:e})]})})})}),{Actions:k1,Action:ju})});import Z_ from"clsx";import{jsx as Pi,jsxs as V6}from"react/jsx-runtime";import{createElement as j_}from"react";var Y6,K6,Ju,A1=y(()=>{"use strict";h();X();Hr();zt();Y();W();be();_c();wc();Mc();Y6=On("DefaultSidebarTrigger",e=>{let{DefaultSidebarTriggerTunnel:t}=rt();return Pi(t.In,{children:Pi(Bn.Trigger,{...e,className:"default-sidebar-trigger",name:Bo.name})})});Y6.displayName="DefaultSidebarTrigger";K6=({children:e,...t})=>{let{DefaultSidebarTabTriggersTunnel:r}=rt();return Pi(r.In,{children:Pi(Bn.TabTriggers,{...t,children:e})})};K6.displayName="DefaultTabTriggers";Ju=Object.assign(On("DefaultSidebar",({children:e,className:t,onDock:r,docked:o,...n})=>{let i=He(),a=$e(),{DefaultSidebarTabTriggersTunnel:l}=rt();return j_(Bn,{...n,name:"default",key:"default",className:Z_("default-sidebar",t),docked:o??i.defaultSidebarDockedPreference,onDock:r===!1||!r&&o!=null?void 0:Xn(r,c=>{a({defaultSidebarDockedPreference:c})})},V6(Bn.Tabs,{children:[V6(Bn.Header,{children:[n.__fallback&&Pi("div",{style:{color:"var(--color-primary)",fontSize:"1.2em",fontWeight:"bold",textOverflow:"ellipsis",overflow:"hidden",whiteSpace:"nowrap",paddingRight:"1em"},children:f("toolBar.library")}),Pi(l.Out,{})]}),Pi(Bn.Tab,{tab:us,children:Pi(u5,{})}),e]}))}),{Trigger:Y6,TabTriggers:K6})});var $6=y(()=>{});var X6=y(()=>{});import q_ from"clsx";import{jsx as Z6,jsxs as Q_}from"react/jsx-runtime";var J_,j6,q6=y(()=>{"use strict";h();pn();se();J_="small",j6=e=>Q_("label",{className:q_("ToolIcon ToolIcon__LaserPointer",`ToolIcon_size_${J_}`,{"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:Fd})]})});var J6=y(()=>{});import{forwardRef as eP,useRef as tP,useImperativeHandle as rP,useLayoutEffect as oP,useState as nP}from"react";import M1 from"clsx";import{jsx as L1,jsxs as Q6}from"react/jsx-runtime";var eI,tI=y(()=>{"use strict";h();J6();Ql();se();eI=eP(({value:e,onChange:t,label:r,fullWidth:o,placeholder:n,readonly:i,selectOnRender:a,onKeyDown:l,isRedacted:c=!1},s)=>{let d=tP(null);rP(s,()=>d.current),oP(()=>{a&&d.current?.select()},[a]);let[m,u]=nP(!1);return Q6("div",{className:M1("ExcTextField",{"ExcTextField--fullWidth":o}),onClick:()=>{d.current?.focus()},children:[L1("div",{className:"ExcTextField__label",children:r}),Q6("div",{className:M1("ExcTextField__input",{"ExcTextField__input--readonly":i}),children:[L1("input",{className:M1({"is-redacted":e&&c&&!m}),readOnly:i,value:e,placeholder:n,ref:d,onChange:p=>t?.(p.target.value),onKeyDown:l}),c&&L1(Jo,{onSelect:()=>u(!m),style:{border:0,userSelect:"none"},children:m?j0:Hd})]})]})})});import{jsx as iP}from"react/jsx-runtime";var ts,_1=y(()=>{"use strict";h();ts=({icon:e})=>iP("span",{style:{width:"1em",margin:"0 0.5ex 0 0.5ex",display:"inline-block",lineHeight:0,verticalAlign:"middle"},children:e})});import{jsx as aP}from"react/jsx-runtime";var rs,rI=y(()=>{"use strict";h();rs=e=>aP("p",{className:"excalidraw__paragraph",style:e.style,children:e.children})});var oI=y(()=>{});import*as iI from"@radix-ui/react-tabs";import{useRef as nI}from"react";import{jsx as lP}from"react/jsx-runtime";var aI,Qu,P1=y(()=>{"use strict";h();be();W();aI=e=>{let t=$e(),r=nI(null),o=nI(0);return lP(iI.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"&&hs(["text-to-diagram","diagram-to-code"],n)?t({openDialog:{name:e.dialog,tab:n,source:"settings"}}):e.dialog==="ttd"&&hs(["text-to-diagram","mermaid"],n)&&t({openDialog:{name:e.dialog,tab:n}})},children:e.children})};aI.displayName="TTDDialogTabs";Qu=aI});import*as lI from"@radix-ui/react-tabs";import{jsx as sP}from"react/jsx-runtime";var os,D1=y(()=>{"use strict";h();os=({tab:e,children:t,...r})=>sP(lI.Content,{...r,value:e,children:t});os.displayName="TTDDialogTab"});import{useState as sI}from"react";import{jsx as Cr,jsxs as Pc}from"react/jsx-runtime";var cI,dI=y(()=>{"use strict";h();co();tI();se();Sc();au();me();zt();_1();rI();oI();P1();D1();cI=e=>{let[t,r]=sI(e.openAIKey||""),[o,n]=sI(e.isPersisted),i=He(),a=()=>{e.onConfirm(t.trim(),o)};return i.openDialog?.name!=="settings"?null:Cr(gt,{onCloseRequest:()=>{e.onClose(),e.onConfirm(t.trim(),o)},title:Pc("div",{style:{display:"flex"},children:["Wireframe to Code (AI)"," ",Cr("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:Cr(Qu,{dialog:"settings",tab:i.openDialog.tab,children:Pc(os,{tab:"diagram-to-code",children:[Pc(rs,{children:["For the diagram-to-code feature we use"," ",Cr(ts,{icon:Cs}),"OpenAI."]}),Pc(rs,{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"," ",Cr("a",{href:"https://platform.openai.com/login?launch",rel:"noopener noreferrer",target:"_blank",children:"OpenAI account"}),", add a small credit (5 USD minimum), and"," ",Cr("a",{href:"https://platform.openai.com/api-keys",rel:"noopener noreferrer",target:"_blank",children:"generate your own API key"}),"."]}),Cr(rs,{children:"Your OpenAI key does not leave the browser, and you can also set your own limit in your OpenAI account dashboard if needed."}),Cr(eI,{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===S.ENTER&&a()}),Cr(rs,{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."}),Cr(Ta,{checked:o,onChange:n,children:"Persist API key in browser storage"}),Pc(rs,{children:["Once API key is set, you can use the ",Cr(ts,{icon:Qa})," ","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"," ",Cr("b",{children:"AI Settings"})," ",Cr(ts,{icon:Cs}),"."]}),Cr(jo,{className:"MagicSettings__confirm",size:"large",label:"Confirm",onClick:a})]})})})}});var mI=y(()=>{});var cP,ep,Dc,tp,R1=y(()=>{"use strict";h();X();Om();vr();vc();cP=({canvasRef:e,setError:t})=>{let r=e.current;if(!r)return;let o=r.parentElement;o&&(o.style.background="",t(null),r.replaceChildren())},ep=async({canvasRef:e,mermaidToExcalidrawLib:t,mermaidDefinition:r,setError:o,data:n})=>{let i=e.current,a=i?.parentElement;if(!(!i||!a)){if(!r){cP({canvasRef:e,setError:o});return}try{let l=await t.api,c;try{c=await l.parseMermaidToExcalidraw(r,{fontSize:Ct})}catch{c=await l.parseMermaidToExcalidraw(r.replace(/"/g,"'"),{fontSize:Ct})}let{elements:s,files:d}=c;o(null),n.current={elements:Rc(s,{regenerateIds:!0}),files:d};let m=await wi({elements:n.current.elements,files:n.current.files,exportPadding:bo,maxWidthOrHeight:Math.max(a.offsetWidth,a.offsetHeight)*window.devicePixelRatio});await Mn(m),a.style.background="var(--default-bg-color)",i.replaceChildren(m)}catch(l){throw a.style.background="var(--default-bg-color)",r&&o(l),l}}},Dc=e=>{Tr.set(Wr.MERMAID_TO_EXCALIDRAW,e)},tp=({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&&Dc(r))}});import{jsx as dP}from"react/jsx-runtime";var rp,N1=y(()=>{"use strict";h();rp=({children:e})=>dP("div",{className:"ttd-dialog-panels",children:e})});import uI from"clsx";import{jsx as B1,jsxs as Nc}from"react/jsx-runtime";var ns,O1=y(()=>{"use strict";h();Ql();Wn();ns=({label:e,children:t,panelAction:r,panelActionDisabled:o=!1,onTextSubmitInProgess:n,renderTopRight:i,renderSubmitShortcut:a,renderBottomRight:l})=>Nc("div",{className:"ttd-dialog-panel",children:[Nc("div",{className:"ttd-dialog-panel__header",children:[B1("label",{children:e}),i?.()]}),t,Nc("div",{className:uI("ttd-dialog-panel-button-container",{invisible:!r}),style:{display:"flex",alignItems:"center"},children:[Nc(Jo,{className:"ttd-dialog-panel-button",onSelect:r?r.action:()=>{},disabled:o||n,children:[Nc("div",{className:uI({invisible:n}),children:[r?.label,r?.icon&&B1("span",{children:r.icon})]}),n&&B1(tr,{})]}),!o&&!n&&a?.(),l?.()]})]})});import{useEffect as mP,useRef as pI}from"react";import{jsx as uP}from"react/jsx-runtime";var op,F1=y(()=>{"use strict";h();X();me();op=({input:e,placeholder:t,onChange:r,onKeyboardSubmit:o})=>{let n=pI(null),i=pI(o);return i.current=o,mP(()=>{if(!i.current)return;let a=n.current;if(a){let l=c=>{c[S.CTRL_OR_CMD]&&c.key===S.ENTER&&(c.preventDefault(),i.current?.())};return a.addEventListener("keydown",l),()=>{a.removeEventListener("keydown",l)}}},[]),uP("textarea",{className:"ttd-dialog-input",onChange:r,value:e,placeholder:t,autoFocus:!0,ref:n})}});import{jsx as np,jsxs as gI}from"react/jsx-runtime";var pP,ip,H1=y(()=>{"use strict";h();Wn();pP=({error:e})=>gI("div",{"data-testid":"ttd-dialog-output-error",className:"ttd-dialog-output-error",children:["Error! ",np("p",{children:e})]}),ip=({error:e,canvasRef:t,loaded:r})=>gI("div",{className:"ttd-dialog-output-wrapper",children:[e&&np(pP,{error:e.message}),r?np("div",{ref:t,style:{opacity:e?"0.15":1},className:"ttd-dialog-output-canvas-container"}):np(tr,{size:"2rem"})]})});import{jsx as hI,jsxs as gP}from"react/jsx-runtime";var ap,z1=y(()=>{"use strict";h();W();ap=()=>gP("div",{className:"ttd-dialog-submit-shortcut",children:[hI("div",{className:"ttd-dialog-submit-shortcut__key",children:_("CtrlOrCmd")}),hI("div",{className:"ttd-dialog-submit-shortcut__key",children:_("Enter")})]})});import{useState as fI,useRef as bI,useEffect as xI,useDeferredValue as hP}from"react";import{Fragment as xP,jsx as Qo,jsxs as yI}from"react/jsx-runtime";var fP,EI,bP,wI,vI=y(()=>{"use strict";h();be();se();mI();Y();Kl();R1();N1();O1();F1();H1();vc();X();W();z1();fP=`flowchart TD
|
|
59
|
+
`);try{Sn(i)}catch{throw new Error(b("errors.copyToSystemClipboardFailed"))}return{commitToHistory:!1}},predicate:(e,t,r,o)=>Xd&&o.scene.getSelectedElements({selectedElementIds:t.selectedElementIds,includeBoundTextElement:!0}).some(G),contextItemLabel:"labels.copyText"});h();de();ze();W();var zm=N({name:"gridMode",viewMode:!0,trackEvent:{category:"canvas",predicate:e=>!e.gridSize},perform(e,t){return{appState:{...t,gridSize:this.checked(t)?null:tn,objectsSnapModeEnabled:!1},commitToHistory:!1}},checked:e=>e.gridSize!==null,predicate:(e,t,r)=>typeof r.gridModeEnabled>"u",contextItemLabel:"labels.showGrid",keyTest:e=>e[S.CTRL_OR_CMD]&&e.code===ue.QUOTE});h();de();ze();var Cl=N({name:"zenMode",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,r)=>typeof r.zenModeEnabled>"u",contextItemLabel:"buttons.zenMode",keyTest:e=>!e[S.CTRL_OR_CMD]&&e.altKey&&e.code===ue.Z});h();de();ze();var Ih=N({name:"objectsSnapMode",viewMode:!0,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,r)=>typeof r.objectsSnapModeEnabled>"u",contextItemLabel:"buttons.objectsSnapMode",keyTest:e=>!e[S.CTRL_OR_CMD]&&e.altKey&&e.code===ue.S});h();ze();de();var di=N({name:"stats",viewMode:!0,trackEvent:{category:"menu"},perform(e,t){return{appState:{...t,showStats:!this.checked(t)},commitToHistory:!1}},checked:e=>e.showStats,contextItemLabel:"stats.title",keyTest:e=>!e[S.CTRL_OR_CMD]&&e.altKey&&e.code===ue.SLASH});h();W();me();He();lt();cd();oe();F();ze();var Ch=N({name:"unbindText",contextItemLabel:"labels.unbindText",trackEvent:{category:"element"},predicate:(e,t,r,o)=>o.scene.getSelectedElements(t).some(i=>cr(i)),perform:(e,t,r,o)=>{let n=o.scene.getSelectedElements(t),i=o.scene.getNonDeletedElementsMap();return n.forEach(a=>{let l=ae(a,i);if(l){let{width:s,height:c}=fo(l.originalText,Be(l),l.lineHeight),d=sx(a.id);sd(a.id);let{x:m,y:p}=$a(a,l,i);B(l,{containerId:null,width:s,height:c,text:l.originalText,x:m,y:p}),B(a,{boundElements:a.boundElements?.filter(u=>u.id!==l.id),height:d||a.height})}}),{elements:e,appState:t,commitToHistory:!0}}}),kh=N({name:"bindText",contextItemLabel:"labels.bindText",trackEvent:{category:"element"},predicate:(e,t,r,o)=>{let n=o.scene.getSelectedElements(t);if(n.length===2){let i=G(n[0])||G(n[1]),a;if(_o(n[0])?a=n[0]:_o(n[1])&&(a=n[1]),i&&a&&ae(a,o.scene.getNonDeletedElementsMap())===null)return!0}return!1},perform:(e,t,r,o)=>{let n=o.scene.getSelectedElements(t),i,a;G(n[0])&&_o(n[1])?(i=n[0],a=n[1]):(i=n[1],a=n[0]),B(i,{containerId:a.id,verticalAlign:gt.MIDDLE,textAlign:Fn.CENTER}),B(a,{boundElements:(a.boundElements||[]).concat({type:"text",id:i.id})});let l=a.height;return zt(i,a,o.scene.getNonDeletedElementsMap()),Ki(a.id,l),{elements:VC(e,a,i),appState:{...t,selectedElementIds:{[a.id]:!0}},commitToHistory:!0}}}),VC=(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),o},YC=(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),o},l2=N({name:"wrapTextInContainer",contextItemLabel:"labels.createContainerFromText",trackEvent:{category:"element"},predicate:(e,t,r,o)=>{let n=o.scene.getSelectedElements(t),i=n.every(a=>G(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(G(l)){let s=Ar({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:Do("rectangle")?tt.ADAPTIVE_RADIUS:tt.PROPORTIONAL_RADIUS}:null,opacity:100,locked:!1,x:l.x-pt,y:l.y-pt,width:mn(l.width,"rectangle"),height:mn(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)&&B(m,{startBinding:p,endBinding:u},!1)})}B(l,{containerId:s.id,verticalAlign:gt.MIDDLE,boundElements:null,textAlign:Fn.CENTER},!1),zt(l,s,o.scene.getNonDeletedElementsMap()),i=YC([...i,s],s,l),a[s.id]=!0}return{elements:i,appState:{...t,selectedElementIds:a},commitToHistory:!0}}});h();h();F();ks();He();de();W();mt();import{useCallback as s2,useEffect as KC,useLayoutEffect as $C,useRef as XC,useState as ZC}from"react";import jC from"clsx";We();Xn();Xa();oe();Hd();import{jsx as Qs,jsxs as c2}from"react/jsx-runtime";var Lh=320,d2=85,Ah=5,qC=42,JC=500,Mh=!1,Gm=new Map,m2=({element:e,elementsMap:t,setAppState:r,onLinkOpen:o,setToast:n,updateEmbedValidationStatus:i})=>{let a=Al(),l=kl(),s=e.link||"",[c,d]=ZC(s),m=XC(null),p=a.showHyperlinkPopup==="editor",u=s2(()=>{if(!m.current)return;let T=tr(m.current.value)||null;if(!e.link&&T&&xe("hyperlink","create"),xt(e)){if(a.activeEmbeddable?.element===e&&r({activeEmbeddable:null}),!T){B(e,{link:null}),i(e,!1);return}if(!qa(T,l.validateEmbeddable))T&&n({message:b("toast.unableToEmbed"),closable:!0}),e.link&&Gm.set(e.id,e.link),B(e,{link:T}),i(e,!1);else{let{width:w,height:I}=e,k=xn(T);k?.error instanceof URIError&&n({message:b("toast.unrecognizedLinkFormat"),closable:!0});let C=k?k.intrinsicSize.w/k.intrinsicSize.h:1,D=Gm.get(e.id)!==e.link;B(e,{...D?{width:k?.type==="video"?w>I?w:I*C:w,height:k?.type==="video"&&w>I?w/C:I}:{},link:T}),i(e,!0),Gm.has(e.id)&&Gm.delete(e.id)}}else B(e,{link:T})},[e,n,l.validateEmbeddable,a.activeEmbeddable,r,i]);$C(()=>()=>{u()},[u]),KC(()=>{let T=null,w=I=>{if(p)return;T&&clearTimeout(T),e4(e,t,a,[I.clientX,I.clientY])&&(T=window.setTimeout(()=>{r({showHyperlinkPopup:!1})},JC))};return window.addEventListener("pointermove",w,!1),()=>{window.removeEventListener("pointermove",w,!1),T&&clearTimeout(T)}},[a,e,p,r,t]);let g=s2(()=>{xe("hyperlink","delete"),B(e,{link:null}),p&&(m.current.value=""),r({showHyperlinkPopup:!1})},[r,e,p]),f=()=>{xe("hyperlink","edit","popup-ui"),r({showHyperlinkPopup:"editor"})},{x:E,y}=p2(e,a,t);return a.contextMenu||a.draggingElement||a.resizingElement||a.isRotating||a.openMenu||a.viewModeEnabled?null:c2("div",{className:"excalidraw-hyperlinkContainer",style:{top:`${y}px`,left:`${E}px`,width:Lh,padding:Ah},onClick:()=>{!e.link&&!p&&r({showHyperlinkPopup:"editor"})},children:[p?Qs("input",{className:jC("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[S.CTRL_OR_CMD]&&T.key===S.K&&T.preventDefault(),(T.key===S.ENTER||T.key===S.ESCAPE)&&(u(),r({showHyperlinkPopup:"info"}))}}):e.link?Qs("a",{href:tr(e.link||""),className:"excalidraw-hyperlinkContainer-link",target:Ed(e.link)?"_self":"_blank",onClick:T=>{if(e.link&&o){let w=Kc("excalidraw-link",T.nativeEvent);o({...e,link:tr(e.link)},w),w.defaultPrevented&&T.preventDefault()}},rel:"noopener noreferrer",children:e.link}):Qs("div",{className:"excalidraw-hyperlinkContainer-link",children:b("labels.link.empty")}),c2("div",{className:"excalidraw-hyperlinkContainer__buttons",children:[!p&&Qs(ne,{type:"button",title:b("buttons.edit"),"aria-label":b("buttons.edit"),label:b("buttons.edit"),onClick:f,className:"excalidraw-hyperlinkContainer--edit",icon:ul}),s&&!xt(e)&&Qs(ne,{type:"button",title:b("buttons.remove"),"aria-label":b("buttons.remove"),label:b("buttons.remove"),onClick:g,className:"excalidraw-hyperlinkContainer--remove",icon:ii})]})]})},p2=(e,t,r)=>{let[o,n]=j(e,r),{x:i,y:a}=Mt({sceneX:o+e.width/2,sceneY:n},t),l=i-t.offsetLeft-Lh/2,s=a-t.offsetTop-d2;return{x:l,y:s}},Ph=(e,t)=>{let r=pe(e,t);return r[0].link?xt(r[0])?"labels.link.editEmbed":"labels.link.edit":xt(r[0])?"labels.link.createEmbed":"labels.link.create"},ec=null,u2=(e,t,r)=>{ec&&clearTimeout(ec),ec=window.setTimeout(()=>QC(e,t,r),Fb)},QC=(e,t,r)=>{if(!e.link)return;let o=wl();o.classList.add("excalidraw-tooltip--visible"),o.style.maxWidth="20rem",o.textContent=e.link;let[n,i,a,l]=j(e,r),[s,c,d,m]=Ns([n,i,a,l],e.angle,t),p=Mt({sceneX:s,sceneY:c},t);uh(o,{left:p.x,top:p.y,width:d,height:m},"top"),xe("hyperlink","tooltip","link-icon"),Mh=!0},g2=()=>{ec&&clearTimeout(ec),Mh&&(Mh=!1,wl().classList.remove("excalidraw-tooltip--visible"))},e4=(e,t,r,[o,n])=>{let{x:i,y:a}=Oe({clientX:o,clientY:n},r),l=15/r.zoom.value;if(Ha(e,t,[i,a],l,null))return!1;let[s,c,d]=j(e,t);if(i>=s&&i<=d&&a>=c-d2&&a<=c)return!1;let{x:m,y:p}=p2(e,r,t);return!(o>=m-l&&o<=m+Lh+Ah*2+l&&n>=p-l&&n<=p+l+Ah*2+qC)};oe();de();We();F();ze();import{jsx as t4}from"react/jsx-runtime";var _h=N({name:"hyperlink",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[S.CTRL_OR_CMD]&&e.key===S.K,contextItemLabel:(e,t)=>Ph(e,t),predicate:(e,t)=>pe(e,t).length===1,PanelComponent:({elements:e,appState:t,updateData:r})=>{let o=pe(e,t);return t4(ne,{type:"button",icon:fm,"aria-label":b(Ph(e,t)),title:`${xt(e[0])?b("labels.link.labelEmbed"):b("labels.link.label")} - ${_("CtrlOrCmd+K")}`,onClick:()=>r(null),selected:o.length===1&&!!o[0].link})}});h();He();oe();de();F();ze();var h2=e=>e.every(t=>!t.locked),Dh=N({name:"toggleElementLock",trackEvent:{category:"element"},predicate:(e,t,r,o)=>!o.scene.getSelectedElements(t).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=h2(n),a=J(n);return{elements:e.map(l=>a.has(l.id)?te(l,{locked:i}):l),appState:{...t,selectedLinearElement:i?null:t.selectedLinearElement},commitToHistory:!0}},contextItemLabel:(e,t,r)=>{let o=r.scene.getSelectedElements({selectedElementIds:t.selectedElementIds,includeBoundTextElement:!1});return o.length===1&&!X(o[0])?o[0].locked?"labels.elementLock.unlock":"labels.elementLock.lock":h2(o)?"labels.elementLock.lockAll":"labels.elementLock.unlockAll"},keyTest:(e,t,r,o)=>e.key.toLocaleLowerCase()===S.L&&e[S.CTRL_OR_CMD]&&e.shiftKey&&o.scene.getSelectedElements({selectedElementIds:t.selectedElementIds,includeBoundTextElement:!1}).length>0}),f2=N({name:"unlockAllElements",trackEvent:{category:"canvas"},viewMode:!1,predicate:e=>e.some(t=>t.locked),perform:(e,t)=>{let r=e.filter(o=>o.locked);return{elements:e.map(o=>o.locked?te(o,{locked:!1}):o),appState:{...t,selectedElementIds:Object.fromEntries(r.map(o=>[o.id,!0]))},commitToHistory:!0}},contextItemLabel:"labels.elementLock.unlockAll"});h();$t();oe();ze();var Rh=N({name:"toggleLinearEditor",trackEvent:{category:"element"},predicate:(e,t,r,o)=>{let n=o.scene.getSelectedElements(t);return!!(n.length===1&&ee(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 V(n);return{appState:{...t,editingLinearElement:i},commitToHistory:!1}},contextItemLabel:(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"}});h();de();He();ho();F();W();import{jsx as y2}from"react/jsx-runtime";var b2=(e,t,r)=>{if(!t.multiElement&&!t.resizingElement&&!t.editingElement&&!t.draggingElement){let n=r();if(n===null)return{commitToHistory:!1};let i=J(e),a=n.elements,l=J(a),s=e.filter(d=>!l.has(d.id)),c=a.map(d=>te(i.get(d.id)||d,d)).concat(s.map(d=>te(d,{isDeleted:!0})));return Va(c,s),{elements:c,appState:{...t,...n.appState},commitToHistory:!1,syncHistory:!0}}return{commitToHistory:!1}},x2=e=>({name:"undo",trackEvent:{category:"history"},perform:(t,r)=>b2(t,r,()=>e.undoOnce()),keyTest:t=>t[S.CTRL_OR_CMD]&&t.key.toLowerCase()===S.Z&&!t.shiftKey,PanelComponent:({updateData:t,data:r})=>y2(ne,{type:"button",icon:V0,"aria-label":b("buttons.undo"),onClick:t,size:r?.size||"medium"}),commitToHistory:()=>!1}),E2=e=>({name:"redo",trackEvent:{category:"history"},perform:(t,r)=>b2(t,r,()=>e.redoOnce()),keyTest:t=>t[S.CTRL_OR_CMD]&&t.shiftKey&&t.key.toLowerCase()===S.Z||Mc&&t.ctrlKey&&!t.shiftKey&&t.key===S.Y,PanelComponent:({updateData:t,data:r})=>y2(ne,{type:"button",icon:Y0,"aria-label":b("buttons.redo"),onClick:t,size:r?.size||"medium"}),commitToHistory:()=>!1});h();F();import{jsx as r4}from"react/jsx-runtime";var Nh=(e,t,r,o,n,i)=>{if(e.trackEvent)try{typeof e.trackEvent=="object"&&(!e.trackEvent.predicate||e.trackEvent.predicate(r,o,i))&&xe(e.trackEvent.category,e.trackEvent.action||e.name,`${t} (${n.device.editor.isMobile?"mobile":"desktop"})`)}catch(a){console.error("error while logging action:",a)}},Um=class{actions={};updater;getAppState;getElementsIncludingDeleted;app;constructor(t,r,o,n){this.updater=i=>{if(Lo(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 Nh(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();Nh(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=>{Nh(n,"ui",l,a,this.app,c),this.updater(n.perform(this.getElementsIncludingDeleted(),this.getAppState(),c,this.app))};return r4(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)}};ze();Sr();oi();W();h();gr();tl();import{atom as l4}from"jotai";mt();Ji();W();import{useEffect as T2,useRef as S2}from"react";h();Vt();import{atom as o4,useAtom as n4}from"jotai";import{useEffect as i4,useState as a4}from"react";ra();var Bh=o4(new Map),w2=async e=>await cl({elements:e,appState:{exportBackground:!1,viewBackgroundColor:ie.white},files:null,renderEmbeddables:!1}),v2=(e,t,r)=>{let[o,n]=a4();return i4(()=>{if(t)if(e){let i=r.get(e);i?n(i):(async()=>{let a=await w2(t);a.querySelector(".style-fonts")?.remove(),a&&(r.set(e,a),n(a))})()}else(async()=>{let i=await w2(t);n(i)})()},[e,t,r,n]),o},Wm=()=>{let[e]=n4(Bh,Pe);return{clearLibraryCache:()=>e.clear(),deleteItemsFromLibraryCache:o=>{o.forEach(n=>e.delete(n))},svgCache:e}};F();h();var qr=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=[]}};h();F();var Vm=class{jobs=[];running=!1;tick(){if(this.running)return;let t=this.jobs.shift();t?(this.running=!0,t.promise.resolve(es(t.jobFactory,...t.args).finally(()=>{this.running=!1,this.tick()}))):this.running=!1}push(t,...r){let o=Yc();return this.jobs.push({jobFactory:t,promise:o,args:r}),this.tick(),o}};me();var C2=new qr,ha=l4({status:"loaded",isInitialized:!1,libraryItems:[]}),tc=e=>Po(e),s4=(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)),k2=(e,t)=>{let r=[];for(let o of t)s4(e,o)&&r.push(o);return[...r,...e]},A2=(e,t)=>{let r=J(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=J(e);for(let i of t)n.has(i.id)||o.addedItems.set(i.id,i);return o},Oh=class{currLibraryItems=[];prevLibraryItems=tc(this.currLibraryItems);app;constructor(t){this.app=t}updateQueue=[];getLastUpdateTask=()=>this.updateQueue[this.updateQueue.length-1];notifyListeners=()=>{if(this.updateQueue.length>0)sr.set(ha,t=>({status:"loading",libraryItems:this.currLibraryItems,isInitialized:t.isInitialized}));else{sr.set(ha,{status:"loaded",libraryItems:this.currLibraryItems,isInitialized:!0});try{let t=this.prevLibraryItems;this.prevLibraryItems=tc(this.currLibraryItems);let r=tc(this.currLibraryItems);this.app.props.onLibraryChange?.(r),C2.trigger(A2(t,r),r)}catch(t){console.error(t)}}};destroy=()=>{this.updateQueue=[],this.currLibraryItems=[],sr.set(Bh,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(tc(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:Ao.name,tab:jl}}),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 ag(s,i):c=Qi(s,i),!r||window.confirm(b("alerts.confirmAddLibrary",{numShapes:c.length}))?(r&&this.app.focusContainer(),a(o?k2(this.currLibraryItems,c):c)):l(new Oo)}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=tc(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}},M2=Oh,$m=e=>{let r=Math.ceil(Math.sqrt(e.length)),o=[],n=u=>e.slice(u*r,u*r+r).reduce((f,E)=>{let{height:y}=pr(E.elements);return Math.max(f,y)},0),i=u=>{let g=0,f=0,E=0;for(let y of e){if(g%r===0&&(f=0),f===u){let{width:T}=pr(y.elements);E=Math.max(E,T)}g++,f++}return E},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:g,minY:f,width:E,height:y}=pr(u.elements),T=(c-E)/2,w=(s-y)/2;o.push(...u.elements.map(I=>({...I,x:I.x+a+T-g,y:I.y+l+w-f}))),a+=c+50,d++,m++}return o},Fh=()=>{let e=new URLSearchParams(window.location.hash.slice(1)).get(Nc.addLibrary)||new URLSearchParams(window.location.search).get(Rc.addLibrary),t=e?new URLSearchParams(window.location.hash.slice(1)).get("token"):null;return e?{libraryUrl:e,idToken:t}:null},Ml=class e{static queue=new Vm;static async getLibraryItems(t,r,o=!0){let n=()=>new Promise(async(i,a)=>{try{let l=await t.load({source:r});i(Qi(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)}},rc=0,Ym=0,Km=e=>Fg(e.map(t=>`${t.id}:${Og(t.elements)}`).sort().join()),I2=async(e,t)=>{try{return Ym++,await Ml.run(e,async r=>{let o=J(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=Km(i);return a!==rc&&await e.save({libraryItems:i}),rc=a,i})}finally{Ym--}},c4=e=>{let{excalidrawAPI:t}=e,r=S2(e);r.current=e;let o=S2(!1);T2(()=>{if(!t)return;o.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(Nc.addLibrary)){let m=new URLSearchParams(window.location.hash.slice(1));m.delete(Nc.addLibrary),window.history.replaceState({},Kl,`#${m.toString()}`)}else if(window.location.search.includes(Rc.addLibrary)){let m=new URLSearchParams(window.location.search);m.delete(Rc.addLibrary),window.history.replaceState({},Kl,`?${m.toString()}`)}}},i=l=>{l.preventDefault();let s=Fh();s&&(l.stopImmediatePropagation(),window.history.replaceState({},"",l.oldURL),n(s))},a=Fh();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=Yc();s?c.resolve(es(s.load).then(async d=>{let m=null;try{if(!d)return Ml.getLibraryItems(l,"load");m=Qi(d.libraryItems||[],"published");let p=await I2(l,A2([],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}`),Ml.getLibraryItems(l,"load")))):c.resolve(es(Ml.getLibraryItems,l,"load")),t.updateLibrary({libraryItems:c.then(d=>{let m=d||[];return rc=Km(m),m}),merge:!0}).finally(()=>{o.current=!0})}return window.addEventListener("hashchange",i),()=>{window.removeEventListener("hashchange",i)}},[t]),T2(()=>{let n=C2.on(async(a,l)=>{let s=o.current,c="adapter"in r.current&&r.current.adapter||null;try{c&&rc!==Km(l)&&await I2(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=>{Ym&&i1(a)};return window.addEventListener("beforeunload",i),()=>{window.removeEventListener("beforeunload",i),n(),rc=0,Ym=0}},[])};tl();me();ho();$t();He();fn();oe();h();var Hh=e=>{let t=Array.from(e.values());return{x:L2(t,r=>r.x)/t.length,y:L2(t,r=>r.y)/t.length}},zh=([e,t])=>Math.hypot(e.x-t.x,e.y-t.y),L2=(e,t)=>e.reduce((r,o)=>r+t(o),0);Ir();h();oe();fn();var d4=e=>({selectedElementIds:e.selectedElementIds,selectedGroupIds:e.selectedGroupIds,viewBackgroundColor:e.viewBackgroundColor,editingLinearElement:e.editingLinearElement,editingGroupId:e.editingGroupId,name:e.name}),Gh=class{elementCache=new Map;recording=!0;stateHistory=[];redoStack=[];lastEntry=null;hydrateHistoryEntry({appState:t,elements:r}){return{appState:JSON.parse(t),elements:r.map(o=>{let n=this.elementCache.get(o.id)?.get(o.versionNonce);if(!n)throw new Error(`Element not found: ${o.id}:${o.versionNonce}`);return n})}}dehydrateHistoryEntry({appState:t,elements:r}){return{appState:JSON.stringify(t),elements:r.map(o=>{this.elementCache.has(o.id)||this.elementCache.set(o.id,new Map);let n=this.elementCache.get(o.id);return n.has(o.versionNonce)||n.set(o.versionNonce,hn(o)),{id:o.id,versionNonce:o.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,r)=>this.dehydrateHistoryEntry({appState:d4(t),elements:r.reduce((o,n)=>{if(ee(n)&&t.multiElement&&t.multiElement.id===n.id){if(t.multiElement&&t.multiElement.id===n.id&&n.points.length<2)return o;o.push({...n,points:n.lastCommittedPoint!==n.points[n.points.length-1]?n.points.slice(0,-1):n.points})}else o.push(n);return o},[])});shouldCreateEntry(t){let{lastEntry:r}=this;if(!r||t.elements.length!==r.elements.length)return!0;for(let n=t.elements.length-1;n>-1;n--){let i=t.elements[n],a=r.elements[n];if(!i||!a||i.id!==a.id||i.versionNonce!==a.versionNonce)return!0}let o;for(o in t.appState)if(!(o==="editingLinearElement"&&t.appState[o]?.elementId===r.appState[o]?.elementId)&&!(o==="selectedElementIds"||o==="selectedGroupIds")&&t.appState[o]!==r.appState[o])return!0;return!1}pushEntry(t,r){let o=this.generateEntry(t,r),n=this.hydrateHistoryEntry(o);if(n){if(!this.shouldCreateEntry(n))return;this.stateHistory.push(o),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(),r=this.stateHistory[this.stateHistory.length-1];return t!==void 0?(this.redoStack.push(t),this.hydrateHistoryEntry(r)):null}setCurrentState(t,r){this.lastEntry=this.hydrateHistoryEntry(this.generateEntry(t,r))}resumeRecording(){this.recording=!0}record(t,r){this.recording&&(this.pushEntry(t,r),this.recording=!1)}},P2=Gh;de();na();Ht();We();nn();pm();h();de();var Uh=[{icon:x0,value:"selection",key:S.V,numericKey:S[1],fillable:!0},{icon:E0,value:"rectangle",key:S.R,numericKey:S[2],fillable:!0},{icon:y0,value:"diamond",key:S.D,numericKey:S[3],fillable:!0},{icon:w0,value:"ellipse",key:S.O,numericKey:S[4],fillable:!0},{icon:v0,value:"arrow",key:S.A,numericKey:S[5],fillable:!0},{icon:T0,value:"line",key:S.L,numericKey:S[6],fillable:!0},{icon:ul,value:"freedraw",key:[S.P,S.X],numericKey:S[7],fillable:!1},{icon:I0,value:"text",key:S.T,numericKey:S[8],fillable:!1},{icon:C0,value:"image",key:null,numericKey:S[9],fillable:!1},{icon:k0,value:"eraser",key:S.E,numericKey:S[0],fillable:!1}],_2=e=>Uh.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;F();ks();h();import p4 from"clsx";h();W();F();var m4={toggleTheme:[_("Shift+Alt+D")],saveScene:[_("CtrlOrCmd+S")],loadScene:[_("CtrlOrCmd+O")],clearCanvas:[_("CtrlOrCmd+Delete")],imageExport:[_("CtrlOrCmd+Shift+E")],cut:[_("CtrlOrCmd+X")],copy:[_("CtrlOrCmd+C")],paste:[_("CtrlOrCmd+V")],copyStyles:[_("CtrlOrCmd+Alt+C")],pasteStyles:[_("CtrlOrCmd+Alt+V")],selectAll:[_("CtrlOrCmd+A")],deleteSelectedElements:[_("Delete")],duplicateSelection:[_("CtrlOrCmd+D"),_(`Alt+${b("helpDialog.drag")}`)],sendBackward:[_("CtrlOrCmd+[")],bringForward:[_("CtrlOrCmd+]")],sendToBack:[qt?_("CtrlOrCmd+Alt+["):_("CtrlOrCmd+Shift+[")],bringToFront:[qt?_("CtrlOrCmd+Alt+]"):_("CtrlOrCmd+Shift+]")],copyAsPng:[_("Shift+Alt+C")],copyAsSvg:[],group:[_("CtrlOrCmd+G")],ungroup:[_("CtrlOrCmd+Shift+G")],gridMode:[_("CtrlOrCmd+'")],zenMode:[_("Alt+Z")],objectsSnapMode:[_("Alt+S")],stats:[_("Alt+/")],addToLibrary:[],flipHorizontal:[_("Shift+H")],flipVertical:[_("Shift+V")],viewMode:[_("Alt+R")],hyperlink:[_("CtrlOrCmd+K")],toggleElementLock:[_("CtrlOrCmd+Shift+L")]},kn=e=>{let t=m4[e];return t&&t.length>0?t[0]:""};import u4 from"react";import{jsx as Ll,jsxs as g4}from"react/jsx-runtime";var rr="separator",D2=u4.memo(({actionManager:e,items:t,top:r,left:o,onClose:n})=>{let i=Al(),a=si(),l=t.reduce((s,c)=>(c&&(c===rr||!c.predicate||c.predicate(a,i,e.app.props,e.app))&&s.push(c),s),[]);return Ll(km,{onCloseRequest:()=>{n()},top:r,left:o,fitInViewport:!0,offsetLeft:i.offsetLeft,offsetTop:i.offsetTop,viewportWidth:i.width,viewportHeight:i.height,children:Ll("ul",{className:"context-menu",onContextMenu:s=>s.preventDefault(),children:l.map((s,c)=>{if(s===rr)return!l[c-1]||l[c-1]===rr?null:Ll("hr",{className:"context-menu-item-separator"},c);let d=s.name,m="";return s.contextItemLabel&&(typeof s.contextItemLabel=="function"?m=b(s.contextItemLabel(a,i,e.app)):m=b(s.contextItemLabel)),Ll("li",{"data-testid":d,onClick:()=>{n(()=>{e.executeAction(s,"contextMenu")})},children:g4("button",{className:p4("context-menu-item",{dangerous:d==="deleteSelectedElements",checkmark:s.checked?.(i)}),children:[Ll("div",{className:"context-menu-item__label",children:m}),Ll("kbd",{className:"context-menu-item__shortcut",children:d?kn(d):""})]})},c)})})})});h();W();me();import uc from"clsx";import ZM from"react";We();F();h();import{useState as O4}from"react";We();F();h();import{forwardRef as R2}from"react";import N2 from"clsx";import{jsx as B2}from"react/jsx-runtime";var h4=R2(({children:e,gap:t,align:r,justifyContent:o,className:n,style:i},a)=>B2("div",{className:N2("Stack Stack_horizontal",n),style:{"--gap":t,alignItems:r,justifyContent:o,...i},ref:a,children:e})),f4=R2(({children:e,gap:t,align:r,justifyContent:o,className:n,style:i},a)=>B2("div",{className:N2("Stack Stack_vertical",n),style:{"--gap":t,justifyItems:r,justifyContent:o,...i},ref:a,children:e})),Dt={Row:h4,Col:f4};ms();oe();import Zh from"clsx";lt();h();h();import b4 from"clsx";import{jsx as x4}from"react/jsx-runtime";var O2=({className:e="",children:t,onToggle:r,title:o,...n})=>{let i=ke(),a=b4(`dropdown-menu-button ${e}`,"zen-mode-transition",{"dropdown-menu-button--mobile":i.editor.isMobile}).trim();return x4("button",{"data-prevent-outside-click":!0,className:a,onClick:r,type:"button","data-testid":"dropdown-menu-button",title:o,...n,children:t})},F2=O2;O2.displayName="DropdownMenuTrigger";h();h();W();F();import E4,{useContext as y4}from"react";var Wh=E4.createContext({}),Xm=(e="",t=!1)=>`dropdown-menu-item dropdown-menu-item-base ${e} ${t?"dropdown-menu-item--selected":""}`.trim(),Zm=(e,t)=>{let r=y4(Wh);return Hn(e,o=>{let n=new CustomEvent("menu.itemSelect",{bubbles:!0,cancelable:!0});t?.(n),n.defaultPrevented||r.onSelect?.(n)})};h();import{Fragment as v4,jsx as Vh,jsxs as T4}from"react/jsx-runtime";var w4=({icon:e,shortcut:t,children:r})=>{let o=ke();return T4(v4,{children:[Vh("div",{className:"dropdown-menu-item__icon",children:e}),Vh("div",{className:"dropdown-menu-item__text",children:r}),t&&!o.editor.isMobile&&Vh("div",{className:"dropdown-menu-item__shortcut",children:t})]})},jm=w4;import{jsx as Yh}from"react/jsx-runtime";var Kh=({icon:e,onSelect:t,children:r,shortcut:o,className:n,selected:i,...a})=>{let l=Zm(a.onClick,t);return Yh("button",{...a,onClick:l,type:"button",className:Xm(n,i),title:a.title??a["aria-label"],children:Yh(jm,{icon:e,shortcut:o,children:r})})};Kh.displayName="DropdownMenuItem";var H2=({children:e})=>Yh("div",{style:{display:"inline-flex",marginLeft:"auto",padding:"2px 4px",background:"pink",borderRadius:6,fontSize:9,color:"black",fontFamily:"Cascadia, monospace"},children:e});H2.displayName="DropdownMenuItemBadge";Kh.Badge=H2;var To=Kh;h();import{jsx as S4}from"react/jsx-runtime";var z2=()=>S4("div",{style:{height:"1px",backgroundColor:"var(--default-border-color)",margin:".5rem 0"}}),G2=z2;z2.displayName="DropdownMenuSeparator";h();import{jsx as I4,jsxs as C4}from"react/jsx-runtime";var U2=({children:e,className:t="",style:r,title:o})=>C4("div",{className:`dropdown-menu-group ${t}`,style:r,children:[o&&I4("p",{className:"dropdown-menu-group-title",children:o}),e]}),W2=U2;U2.displayName="DropdownMenuGroup";h();h();import k4 from"react";import A4 from"clsx";import{jsx as M4}from"react/jsx-runtime";var Ut=k4.forwardRef(({children:e,padding:t,className:r,style:o},n)=>M4("div",{className:A4("Island",r),style:{"--padding":t,...o},ref:n,children:e}));import L4 from"clsx";import{useEffect as P4,useRef as _4}from"react";de();W();import{jsx as qm}from"react/jsx-runtime";var V2=({children:e,onClickOutside:t,className:r="",onSelect:o,style:n})=>{let i=ke(),a=_4(null),l=Sm({onClickOutside:t});yl(a,()=>{l.onClickOutside?.()}),P4(()=>{let c=d=>{d.key===S.ESCAPE&&(d.stopImmediatePropagation(),l.onClickOutside?.())};return document.addEventListener("keydown",c,{capture:!0}),()=>{document.removeEventListener("keydown",c)}},[l]);let s=L4(`dropdown-menu ${r}`,{"dropdown-menu--mobile":i.editor.isMobile}).trim();return qm(Wh.Provider,{value:{onSelect:o},children:qm("div",{ref:a,className:s,style:n,"data-testid":"dropdown-menu",children:i.editor.isMobile?qm(Dt.Col,{className:"dropdown-menu-container",children:e}):qm(Ut,{className:"dropdown-menu-container",padding:2,style:{zIndex:2},children:e})})})};V2.displayName="DropdownMenuContent";var Y2=V2;h();import{jsx as K2}from"react/jsx-runtime";var $2=({icon:e,shortcut:t,href:r,children:o,onSelect:n,className:i="",selected:a,...l})=>{let s=Zm(l.onClick,n);return K2("a",{...l,href:r,target:"_blank",rel:"noreferrer",className:Xm(i,a),title:l.title??l["aria-label"],onClick:s,children:K2(jm,{icon:e,shortcut:t,children:o})})},Pl=$2;$2.displayName="DropdownMenuItemLink";h();import{jsx as R4}from"react/jsx-runtime";var D4=({children:e,className:t="",selected:r,...o})=>R4("div",{...o,className:`dropdown-menu-item-base dropdown-menu-item-custom ${t} ${r?"dropdown-menu-item--selected":""}`.trim(),children:e}),X2=D4;h();import Jm from"react";var Z2=e=>{let t=Jm.Children.toArray(e).find(r=>Jm.isValidElement(r)&&typeof r.type!="string"&&r?.type.displayName&&r.type.displayName==="DropdownMenuTrigger");return t||null},j2=e=>{let t=Jm.Children.toArray(e).find(r=>Jm.isValidElement(r)&&typeof r.type!="string"&&r?.type.displayName&&r.type.displayName==="DropdownMenuContent");return t||null};import{Fragment as N4,jsxs as B4}from"react/jsx-runtime";var An=({children:e,open:t})=>{let r=Z2(e),o=j2(e);return B4(N4,{children:[r,t&&o]})};An.Trigger=F2;An.Content=Y2;An.Item=To;An.ItemLink=Pl;An.ItemCustom=X2;An.Group=W2;An.Separator=G2;var Le=An;An.displayName="DropdownMenu";de();h();import $h from"react";import Yo from"tunnel-rat";var Xh=$h.createContext(null),Qe=()=>$h.useContext(Xh),q2=()=>$h.useMemo(()=>({MainMenuTunnel:Yo(),WelcomeScreenMenuHintTunnel:Yo(),WelcomeScreenToolbarHintTunnel:Yo(),WelcomeScreenHelpHintTunnel:Yo(),WelcomeScreenCenterTunnel:Yo(),FooterCenterTunnel:Yo(),DefaultSidebarTriggerTunnel:Yo(),DefaultSidebarTabTriggersTunnel:Yo(),OverwriteConfirmDialogTunnel:Yo(),TTDDialogTriggerTunnel:Yo(),jotaiScope:Symbol()}),[]);import{Fragment as mi,jsx as ot,jsxs as ft}from"react/jsx-runtime";var Qm=({appState:e,elementsMap:t,renderAction:r})=>{let o=la(t,e),n=!1;o.length===2&&(cr(o[0])||cr(o[1]))&&(n=!0);let i=!!e.editingElement,a=ke(),l=document.documentElement.getAttribute("dir")==="rtl",s=an(e.activeTool.type)&&!Jt(e.currentItemBackgroundColor)||o.some(p=>an(p.type)&&!Jt(p.backgroundColor)),c=an(e.activeTool.type)||o.some(p=>an(p.type)),d=o.length===1||n,m=o[0]?.type||null;for(let p of o)if(p.type!==m){m=null;break}return ft("div",{className:"panelColumn",children:[ot("div",{children:(ds(e.activeTool.type)&&e.activeTool.type!=="image"&&m!=="image"&&m!=="frame"&&m!=="magicframe"||o.some(p=>ds(p.type)))&&r("changeStrokeColor")}),c&&ot("div",{children:r("changeBackgroundColor")}),s&&r("changeFillStyle"),(qc(e.activeTool.type)||o.some(p=>qc(p.type)))&&r("changeStrokeWidth"),(e.activeTool.type==="freedraw"||o.some(p=>p.type==="freedraw"))&&r("changeStrokeShape"),(Jc(e.activeTool.type)||o.some(p=>Jc(p.type)))&&ft(mi,{children:[r("changeStrokeStyle"),r("changeSloppiness")]}),(_a(e.activeTool.type)||o.some(p=>_a(p.type)))&&ot(mi,{children:r("changeRoundness")}),(e.activeTool.type==="text"||o.some(G))&&ft(mi,{children:[r("changeFontSize"),r("changeFontFamily"),(e.activeTool.type==="text"||hx(o,t))&&r("changeTextAlign")]}),gx(o,t)&&r("changeVerticalAlign"),(Fi(e.activeTool.type)||o.some(p=>Fi(p.type)))&&ot(mi,{children:r("changeArrowhead")}),r("changeOpacity"),ft("fieldset",{children:[ot("legend",{children:b("labels.layers")}),ft("div",{className:"buttonList",children:[r("sendToBack"),r("sendBackward"),r("bringToFront"),r("bringForward")]})]}),o.length>1&&!n&&ft("fieldset",{children:[ot("legend",{children:b("labels.align")}),ft("div",{className:"buttonList",children:[l?ft(mi,{children:[r("alignRight"),r("alignHorizontallyCentered"),r("alignLeft")]}):ft(mi,{children:[r("alignLeft"),r("alignHorizontallyCentered"),r("alignRight")]}),o.length>2&&r("distributeHorizontally"),ot("div",{style:{flexBasis:"100%",height:0}}),ft("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&&ft("fieldset",{children:[ot("legend",{children:b("labels.actions")}),ft("div",{className:"buttonList",children:[!a.editor.isMobile&&r("duplicateSelection"),!a.editor.isMobile&&r("deleteSelectedElements"),r("group"),r("ungroup"),d&&r("hyperlink")]})]})]})},ep=({activeTool:e,appState:t,app:r,UIOptions:o})=>{let[n,i]=O4(!1),a=e.type==="frame",l=e.type==="laser",s=e.type==="embeddable",{TTDDialogTriggerTunnel:c}=Qe();return ft(mi,{children:[Uh.map(({value:d,icon:m,key:p,numericKey:u,fillable:g},f)=>{if(o.tools?.[d]===!1)return null;let E=b(`toolBar.${d}`),y=p&&ka(typeof p=="string"?p:p[0]),T=y?`${y} ${b("helpDialog.or")} ${u}`:`${u}`;return ot(ne,{className:Zh("Shape",{fillable:g}),type:"radio",icon:m,checked:e.type===d,name:"editor-current-shape",title:`${ka(E)} \u2014 ${T}`,keyBindingLabel:u||y,"aria-label":ka(E),"aria-keyshortcuts":T,"data-testid":`toolbar-${d}`,onPointerDown:({pointerType:w})=>{!t.penDetected&&w==="pen"&&r.togglePenMode(!0)},onChange:({pointerType:w})=>{t.activeTool.type!==d&&xe("toolbar",d,"ui"),d==="image"?r.setActiveTool({type:d,insertOnCanvasDirectly:w!=="mouse"}):r.setActiveTool({type:d})}},d)}),ot("div",{className:"App-toolbar__divider"}),ft(Le,{open:n,children:[ft(Le.Trigger,{className:Zh("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:[$y,r.props.aiEnabled!==!1&&ot("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"})]}),ft(Le.Content,{onClickOutside:()=>i(!1),onSelect:()=>i(!1),className:"App-toolbar__extra-tools-dropdown",children:[ot(Le.Item,{onSelect:()=>r.setActiveTool({type:"frame"}),icon:Xy,shortcut:S.F.toLocaleUpperCase(),"data-testid":"toolbar-frame",selected:a,children:b("toolBar.frame")}),ot(Le.Item,{onSelect:()=>r.setActiveTool({type:"embeddable"}),icon:L0,"data-testid":"toolbar-embeddable",selected:s,children:b("toolBar.embeddable")}),ot(Le.Item,{onSelect:()=>r.setActiveTool({type:"laser"}),icon:Em,"data-testid":"toolbar-laser",selected:l,shortcut:S.K.toLocaleUpperCase(),children:b("toolBar.laser")}),ot("div",{style:{margin:"6px 0",fontSize:14,fontWeight:600},children:"Generate"}),r.props.aiEnabled!==!1&&ot(c.Out,{}),ot(Le.Item,{onSelect:()=>r.setOpenDialog({name:"ttd",tab:"mermaid"}),icon:Zy,"data-testid":"toolbar-embeddable",children:b("toolBar.mermaidToExcalidraw")}),r.props.aiEnabled!==!1&&ft(mi,{children:[ft(Le.Item,{onSelect:()=>r.onMagicframeToolSelect(),icon:bl,"data-testid":"toolbar-magicframe",children:[b("toolBar.magicframe"),ot(Le.Item.Badge,{children:"AI"})]}),ot(Le.Item,{onSelect:()=>{xe("ai","open-settings","d2c"),r.setOpenDialog({name:"settings",source:"settings",tab:"diagram-to-code"})},icon:Vs,"data-testid":"toolbar-magicSettings",children:b("toolBar.magicSettings")})]})]})]})]})},J2=({renderAction:e,zoom:t})=>ot(Dt.Col,{gap:1,className:"zoom-actions",children:ft(Dt.Row,{align:"center",children:[e("zoomOut"),e("resetZoom"),e("zoomIn")]})}),Q2=({renderAction:e,className:t})=>ft("div",{className:`undo-redo-buttons ${t}`,children:[ot("div",{className:"undo-button-container",children:ot(_r,{label:b("buttons.undo"),children:e("undo")})}),ot("div",{className:"redo-button-container",children:ft(_r,{label:b("buttons.redo"),children:[" ",e("redo")]})})]}),ev=({actionManager:e,showExitZenModeBtn:t})=>ot("button",{className:Zh("disable-zen-mode",{"disable-zen-mode--visible":t}),onClick:()=>e.executeAction(Cl),children:b("buttons.exitZenMode")}),tv=({renderAction:e,className:t})=>ot("div",{className:`finalize-button ${t}`,children:e("finalize",{size:"small"})});h();import Kk,{useState as $k}from"react";h();import zk from"clsx";import{useEffect as Gk,useState as Uk}from"react";h();import{useCallback as F4,useState as H4}from"react";var rv=()=>{let[e,t]=H4(null),r=F4(o=>t(o),[]);return[e,r]};de();h();de();import{createPortal as z4}from"react-dom";import G4 from"clsx";import{jsx as ov,jsxs as U4}from"react/jsx-runtime";var nv=e=>{let{closeOnClickOutside:t=!0}=e,r=Tm({className:"excalidraw-modal-container"});if(!r)return null;let o=n=>{n.key===S.ESCAPE&&(n.nativeEvent.stopImmediatePropagation(),n.stopPropagation(),e.onCloseRequest())};return z4(U4("div",{className:G4("Modal",e.className),role:"dialog","aria-modal":"true",onKeyDown:o,"aria-labelledby":e.labelledBy,"data-prevent-outside-click":!0,children:[ov("div",{className:"Modal__background",onClick:t?e.onCloseRequest:void 0}),ov("div",{className:"Modal__content",style:{"--max-width":`${e.maxWidth}px`},tabIndex:0,children:e.children})]}),r)};F();import{useSetAtom as Wk}from"jotai";h();import{useState as Nk,useCallback as nf,useMemo as Ev,useRef as of}from"react";co();h();vn();import{useCallback as Rl,useEffect as Lk,useMemo as hv,useRef as Pk,useState as _k}from"react";F();W();fn();h();h();W();import{jsx as V4}from"react/jsx-runtime";var W4=({theme:e,id:t,libraryReturnUrl:r})=>{let o=r||window.location.origin+window.location.pathname;return V4("a",{className:"library-menu-browse-button",href:`${v.VITE_APP_LIBRARY_URL}?target=${window.name||"_blank"}&referrer=${o}&useHash=true&token=${t}&theme=${e}&version=${Ri.excalidrawLibrary}`,target:"_excalidraw_libraries",children:b("labels.libraries")})},iv=W4;import Y4 from"clsx";import{jsx as K4,jsxs as $4}from"react/jsx-runtime";var tp=({libraryReturnUrl:e,theme:t,id:r,style:o,children:n,className:i})=>$4("div",{className:Y4("library-menu-control-buttons",i),style:o,children:[K4(iv,{id:r,libraryReturnUrl:e,theme:t}),n]});h();import{useCallback as ck,useState as Jh}from"react";h();import rp from"react";var X4=/({{[\w-]+}})|(<[\w-]+>)|(<\/[\w-]+>)/g,Z4=/{{([\w-]+)}}/,j4=/<([\w-]+)>/,q4=/<\/([\w-]+)>/,J4=(e,t)=>{let r=[{name:"",children:[]}];return e.split(X4).filter(Boolean).forEach(o=>{let n=o.match(j4),i=o.match(q4),a=o.match(Z4);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=rp.createElement(rp.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},Q4=({i18nKey:e,children:t,...r})=>{let{t:o}=St();return rp.createElement(rp.Fragment,{},...J4(o(e),r))},or=Q4;vn();En();F();import{useAtom as Qh}from"jotai";h();h();import ek from"clsx";import{jsx as op,jsxs as rk}from"react/jsx-runtime";var tk=({label:e,onClick:t,className:r,children:o,actionType:n,type:i="button",isLoading:a,...l})=>{let s=n?`Dialog__action-button--${n}`:"";return rk("button",{className:ek("Dialog__action-button",s,r),type:i,"aria-label":e,onClick:t,...l,children:[o&&op("div",{style:a?{visibility:"hidden"}:{},children:o}),op("div",{style:a?{visibility:"hidden"}:{},children:e}),a&&op("div",{style:{position:"absolute",inset:0},children:op(Bt,{})})]})},_l=tk;import{useSetAtom as ok}from"jotai";import{jsx as av,jsxs as lv}from"react/jsx-runtime";var nk=e=>{let{onConfirm:t,onCancel:r,children:o,confirmText:n=b("buttons.confirm"),cancelText:i=b("buttons.cancel"),className:a="",...l}=e,s=Ve(),c=ok(Dl,Pe),{container:d}=_t();return lv(ut,{onCloseRequest:r,size:"small",...l,className:`confirm-dialog ${a}`,children:[o,lv("div",{className:"confirm-dialog-buttons",children:[av(_l,{label:i,onClick:()=>{s({openMenu:null}),c(!1),r(),d?.focus()}}),av(_l,{label:n,onClick:()=>{s({openMenu:null}),c(!1),t(),d?.focus()},actionType:"danger"})]})]})},np=nk;h();import{useCallback as ik,useEffect as qh,useRef as sv,useState as jh}from"react";import ip from"open-color";ra();W();gr();F();h();var br=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}`)}}};import{jsx as Ee,jsxs as Zt}from"react/jsx-runtime";var ak=async e=>{let o=Math.round(8),n=Math.max(Math.round(128/64),2),i=r1(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=ip.white,l.fillRect(0,0,a.width,a.height);for(let[s,c]of e.entries()){let d=await ni({elements:c.elements,files:null,maxWidthOrHeight:128}),{width:m,height:p}=d,u=Math.floor(s/6)*(128+o*2),g=s%6*(128+o*2);l.drawImage(d,g+(128-m)/2+o,u+(128-p)/2+o),l.lineWidth=n,l.strokeStyle=ip.gray[4],l.strokeRect(g+o/2,u+o/2,128+o,128+o)}return await Ds(new File([await wn(a)],"preview",{type:$.png}),{outputType:$.jpg,maxWidthOrHeight:5e3})},lk=({libItem:e,appState:t,index:r,onChange:o,onRemove:n})=>{let i=sv(null),a=sv(null);return qh(()=>{let l=i.current;l&&(async()=>{let s=await cl({elements:e.elements,appState:{...t,viewBackgroundColor:ip.white,exportBackground:!0},files:null});l.innerHTML=s.outerHTML})()},[e.elements,t]),Zt("div",{className:"single-library-item",children:[e.status==="published"&&Ee("span",{className:"single-library-item-status",children:b("labels.statusPublished")}),Ee("div",{ref:i,className:"single-library-item__svg"}),Ee(ne,{"aria-label":b("buttons.remove"),type:"button",icon:Yr,className:"single-library-item--remove",onClick:n.bind(null,e.id),title:b("buttons.remove")}),Zt("div",{style:{display:"flex",margin:"0.8rem 0",width:"100%",fontSize:"14px",fontWeight:500,flexDirection:"column"},children:[Zt("label",{style:{display:"flex",justifyContent:"space-between",flexDirection:"column"},children:[Zt("div",{style:{padding:"0.5em 0"},children:[Ee("span",{style:{fontWeight:500,color:ip.gray[6]},children:b("publishDialog.itemName")}),Ee("span",{"aria-hidden":"true",className:"required",children:"*"})]}),Ee("input",{type:"text",ref:a,style:{width:"80%",padding:"0.2rem"},defaultValue:e.name,placeholder:"Item name",onChange:l=>{o(l.target.value,r)}})]}),Ee("span",{className:"error",children:e.error})]})]})},sk=({onClose:e,libraryItems:t,appState:r,onSuccess:o,onError:n,updateItemsInStorage:i,onRemove:a})=>{let[l,s]=jh({authorName:"",githubHandle:"",name:"",description:"",twitterHandle:"",website:""}),[c,d]=jh(!1);qh(()=>{let w=br.get(Br.PUBLISH_LIBRARY);w&&s(w)},[]);let[m,p]=jh(t.slice());qh(()=>{p(t.slice())},[t]);let u=w=>{s({...l,[w.target.name]:w.target.value})},g=async w=>{w.preventDefault(),d(!0);let I=[],k=!1;if(m.forEach(M=>{let A="";M.name||(A=b("publishDialog.errors.required"),k=!0),I.push({...M,error:A})}),k){p(I),d(!1);return}let C=await ak(m),D={type:Yt.excalidrawLibrary,version:Ri.excalidrawLibrary,source:Zl,libraryItems:m},R=JSON.stringify(D,null,2),z=new Blob([R],{type:"application/json"}),L=new FormData;L.append("excalidrawLib",z),L.append("previewImage",C),L.append("previewImageType",C.type),L.append("title",l.name),L.append("authorName",l.authorName),L.append("githubHandle",l.githubHandle),L.append("name",l.name),L.append("description",l.description),L.append("twitterHandle",l.twitterHandle),L.append("website",l.website),fetch(`${v.VITE_APP_LIBRARY_BACKEND}/submit`,{method:"post",body:L}).then(M=>M.ok?M.json().then(({url:A})=>{br.delete(Br.PUBLISH_LIBRARY),o({url:A,authorName:l.authorName,items:m})}):M.json().catch(()=>{throw new Error(M.statusText||"something went wrong")}).then(A=>{throw new Error(A.message||M.statusText||"something went wrong")}),M=>{console.error(M),n(M),d(!1)}).catch(M=>{console.error(M),n(M),d(!1)})},f=()=>{let w=[];return m.forEach((I,k)=>{w.push(Ee("div",{className:"single-library-item-wrapper",children:Ee(lk,{libItem:I,appState:r,index:k,onChange:(C,D)=>{let R=m.slice();R[D].name=C,p(R)},onRemove:a})},k))}),Ee("div",{className:"selected-library-items",children:w})},E=ik(()=>{i(m),br.set(Br.PUBLISH_LIBRARY,l),e()},[m,e,i,l]),y=!!t.length,T=t.some(w=>w.status==="published");return Ee(ut,{onCloseRequest:E,title:b("publishDialog.title"),className:"publish-library",children:y?Zt("form",{onSubmit:g,children:[Ee("div",{className:"publish-library-note",children:Ee(or,{i18nKey:"publishDialog.noteDescription",link:w=>Ee("a",{href:"https://libraries.excalidraw.com",target:"_blank",rel:"noopener noreferrer",children:w})})}),Ee("span",{className:"publish-library-note",children:Ee(or,{i18nKey:"publishDialog.noteGuidelines",link:w=>Ee("a",{href:"https://github.com/excalidraw/excalidraw-libraries#guidelines",target:"_blank",rel:"noopener noreferrer",children:w})})}),Ee("div",{className:"publish-library-note",children:b("publishDialog.noteItems")}),T&&Ee("span",{className:"publish-library-note publish-library-warning",children:b("publishDialog.republishWarning")}),f(),Zt("div",{className:"publish-library__fields",children:[Zt("label",{children:[Zt("div",{children:[Ee("span",{children:b("publishDialog.libraryName")}),Ee("span",{"aria-hidden":"true",className:"required",children:"*"})]}),Ee("input",{type:"text",name:"name",required:!0,value:l.name,onChange:u,placeholder:b("publishDialog.placeholder.libraryName")})]}),Zt("label",{style:{alignItems:"flex-start"},children:[Zt("div",{children:[Ee("span",{children:b("publishDialog.libraryDesc")}),Ee("span",{"aria-hidden":"true",className:"required",children:"*"})]}),Ee("textarea",{name:"description",rows:4,required:!0,value:l.description,onChange:u,placeholder:b("publishDialog.placeholder.libraryDesc")})]}),Zt("label",{children:[Zt("div",{children:[Ee("span",{children:b("publishDialog.authorName")}),Ee("span",{"aria-hidden":"true",className:"required",children:"*"})]}),Ee("input",{type:"text",name:"authorName",required:!0,value:l.authorName,onChange:u,placeholder:b("publishDialog.placeholder.authorName")})]}),Zt("label",{children:[Ee("span",{children:b("publishDialog.githubUsername")}),Ee("input",{type:"text",name:"githubHandle",value:l.githubHandle,onChange:u,placeholder:b("publishDialog.placeholder.githubHandle")})]}),Zt("label",{children:[Ee("span",{children:b("publishDialog.twitterUsername")}),Ee("input",{type:"text",name:"twitterHandle",value:l.twitterHandle,onChange:u,placeholder:b("publishDialog.placeholder.twitterHandle")})]}),Zt("label",{children:[Ee("span",{children:b("publishDialog.website")}),Ee("input",{type:"text",name:"website",pattern:"https?://.+",title:b("publishDialog.errors.website"),value:l.website,onChange:u,placeholder:b("publishDialog.placeholder.website")})]}),Ee("span",{className:"publish-library-note",children:Ee(or,{i18nKey:"publishDialog.noteLicense",link:w=>Ee("a",{href:"https://github.com/excalidraw/excalidraw-libraries/blob/main/LICENSE",target:"_blank",rel:"noopener noreferrer",children:w})})})]}),Zt("div",{className:"publish-library__buttons",children:[Ee(_l,{label:b("buttons.cancel"),onClick:E,"data-testid":"cancel-clear-canvas-button"}),Ee(_l,{type:"submit",label:b("buttons.submit"),actionType:"primary",isLoading:c})]})]}):Ee("p",{style:{padding:"1em",textAlign:"center",fontWeight:500},children:b("publishDialog.atleastOneLibItem")})})},cv=sk;import dk from"clsx";import{jsx as xr,jsxs as ap}from"react/jsx-runtime";var mk=(e,t)=>e.filter(r=>t.includes(r.id)),pk=({setAppState:e,selectedItems:t,library:r,onRemoveFromLibrary:o,resetLibrary:n,onSelectItems:i,appState:a,className:l})=>{let[s]=Qh(ha,Pe),[c,d]=Qh(Dl,Pe),m=()=>{let L=t.length?b("alerts.removeItemsFromsLibrary",{count:t.length}):b("alerts.resetLibrary"),M=t.length?b("confirmDialog.removeItemsFromLib"):b("confirmDialog.resetLibrary");return xr(np,{onConfirm:()=>{t.length?o():n(),u(!1)},onCancel:()=>{u(!1)},title:M,children:xr("p",{children:L})})},[p,u]=Jh(!1),g=!!t.length,f=g?s.libraryItems.filter(L=>t.includes(L.id)):s.libraryItems,E=g?b("buttons.remove"):b("buttons.resetLibrary"),[y,T]=Jh(!1),[w,I]=Jh(null),k=ck(()=>ap(ut,{onCloseRequest:()=>I(null),title:b("publishSuccessDialog.title"),className:"publish-library-success",size:"small",children:[xr("p",{children:xr(or,{i18nKey:"publishSuccessDialog.content",authorName:w.authorName,link:L=>xr("a",{href:w?.url,target:"_blank",rel:"noopener noreferrer",children:L})})}),xr(ne,{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]),C=(L,M)=>{T(!1),I({url:L.url,authorName:L.authorName});let A=M.slice();A.forEach(H=>{t.includes(H.id)&&(H.status="published")}),r.setLibrary(A)},D=async()=>{try{await r.updateLibrary({libraryItems:Ja({description:"Excalidraw library files"}),merge:!0,openLibraryMenu:!0})}catch(L){if(L?.name==="AbortError"){console.warn(L);return}e({errorMessage:b("errors.importLibraryError")})}},R=async()=>{let L=g?f:await r.getLatestLibrary();aE(L).catch(Vc).catch(M=>{e({errorMessage:M.message})})},z=()=>ap(Le,{open:c,children:[xr(Le.Trigger,{onToggle:()=>d(!c),children:m0}),ap(Le.Content,{onClickOutside:()=>d(!1),onSelect:()=>d(!1),className:"library-menu",children:[!g&&xr(Le.Item,{onSelect:D,icon:hl,"data-testid":"lib-dropdown--load",children:b("buttons.load")}),!!f.length&&xr(Le.Item,{onSelect:R,icon:gm,"data-testid":"lib-dropdown--export",children:b("buttons.export")}),!!f.length&&xr(Le.Item,{onSelect:()=>u(!0),icon:ii,children:E}),g&&xr(Le.Item,{icon:Uy,onSelect:()=>T(!0),"data-testid":"lib-dropdown--remove",children:b("buttons.publishLibrary")})]})]});return ap("div",{className:dk("library-menu-dropdown-container",l),children:[z(),t.length>0&&xr("div",{className:"library-actions-counter",children:t.length}),p&&m(),y&&xr(cv,{onClose:()=>T(!1),libraryItems:mk(s.libraryItems,t),appState:a,onSuccess:L=>C(L,s.libraryItems),onError:L=>window.alert(L),updateItemsInStorage:()=>r.setLibrary(s.libraryItems),onRemove:L=>i(t.filter(M=>M!==L))}),w&&k()]})},ef=({selectedItems:e,onSelectItems:t,className:r})=>{let{library:o}=$r(),{clearLibraryCache:n,deleteItemsFromLibraryCache:i}=Wm(),a=Ne(),l=Ve(),[s]=Qh(ha,Pe),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 xr(pk,{appState:a,setAppState:l,selectedItems:e,onSelectItems:t,library:o,onRemoveFromLibrary:()=>c(s.libraryItems),resetLibrary:()=>{o.resetLibrary(),n()},className:r})};h();import{memo as wk,useEffect as vk,useState as Tk}from"react";h();import dv from"clsx";import{memo as uk,useEffect as gk,useRef as hk,useState as fk}from"react";import{jsx as lp,jsxs as bk}from"react/jsx-runtime";var mv=uk(({id:e,elements:t,isPending:r,onClick:o,selected:n,onToggle:i,onDrag:a,svgCache:l})=>{let s=hk(null),c=v2(e,t,l);gk(()=>{let g=s.current;if(g)return c&&(g.innerHTML=c.outerHTML),()=>{g.innerHTML=""}},[c]);let[d,m]=fk(!1),p=ke().editor.isMobile,u=r&&lp("div",{className:"library-unit__adder",children:d0});return bk("div",{className:dv("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:[lp("div",{className:dv("library-unit__dragger",{"library-unit__pulse":!!r}),ref:s,draggable:!!t,onClick:t||r?g=>{e&&g.shiftKey?i(e,g):o(e)}:void 0,onDragStart:g=>{if(!e){g.preventDefault();return}m(!1),a(e,g)}}),u,e&&t&&(d||p||n)&&lp(pa,{checked:n,onChange:(g,f)=>i(e,f),className:"library-unit__checkbox"})]})}),pv=()=>lp("div",{className:"library-unit library-unit--skeleton"});h();import xk,{useCallback as Ek}from"react";function yk(){return[!1,Ek(t=>t(),[])]}var uv=xk.useTransition||yk;import{Fragment as Sk,jsx as sp}from"react/jsx-runtime";var tf=({children:e})=>sp("div",{className:"library-menu-items-container__grid",children:e}),cp=wk(({items:e,onItemSelectToggle:t,onItemDrag:r,isItemSelected:o,onClick:n,svgCache:i,itemsRenderedPerBatch:a})=>{let[,l]=uv(),[s,c]=Tk(0);return vk(()=>{s<e.length&&l(()=>{c(s+a)})},[s,e.length,l,a]),sp(Sk,{children:e.map((d,m)=>m<s?sp(mv,{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):sp(pv,{},m))})});h();import{useEffect as Ik}from"react";import{atom as Ck,useAtom as kk}from"jotai";import Ak from"lodash.throttle";var Mk=Ck(0),gv=e=>{let[t,r]=kk(Mk);return Ik(()=>{let{current:o}=e;if(!o)return;let n=Ak(()=>{let{scrollTop:i}=o;r(i)},200);return o.addEventListener("scroll",n),()=>{n.cancel(),o.removeEventListener("scroll",n)}},[e,r]),t};import{Fragment as fv,jsx as Er,jsxs as Nl}from"react/jsx-runtime";var Dk=17,Rk=64;function rf({isLoading:e,libraryItems:t,onAddToLibrary:r,onInsertLibraryItems:o,pendingElements:n,theme:i,id:a,libraryReturnUrl:l,onSelectItems:s,selectedItems:c}){let d=Pk(null),m=gv(d);Lk(()=>{m>0&&d.current?.scrollTo(0,m)},[]);let{svgCache:p}=Wm(),u=hv(()=>t.filter(L=>L.status!=="published"),[t]),g=hv(()=>t.filter(L=>L.status==="published"),[t]),f=!t.length&&!n.length,E=!n.length&&!u.length&&!g.length,[y,T]=_k(null),w=Rl((L,M)=>{let A=!c.includes(L),H=[...u,...g];if(A){if(M.shiftKey&&y){let q=H.findIndex(se=>se.id===y),Y=H.findIndex(se=>se.id===L);if(q===-1||Y===-1){s([...c,L]);return}let Q=J(c),fe=H.reduce((se,ce,Ye)=>((Ye>=q&&Ye<=Y||Q.has(ce.id))&&se.push(ce.id),se),[]);s(fe)}else s([...c,L]);T(L)}else T(null),s(c.filter(q=>q!==L))},[y,s,g,c,u]),I=Rl(L=>{let M;return c.includes(L)?M=t.filter(A=>c.includes(A.id)):M=t.filter(A=>A.id===L),M.map(A=>({...A,elements:Cd(A.elements,{randomizeSeed:!0})}))},[t,c]),k=Rl((L,M)=>{M.dataTransfer.setData($.excalidrawlib,Nd(I(L)))},[I]),C=Rl(L=>L?c.includes(L):!1,[c]),D=Rl(()=>{r(n)},[n,r]),R=Rl(L=>{L&&o(I(L))},[I,o]),z=p.size>=t.length?Rk:Dk;return Nl("div",{className:"library-menu-items-container",style:n.length||u.length||g.length?{justifyContent:"flex-start"}:{borderBottom:0},children:[!E&&Er(ef,{selectedItems:c,onSelectItems:s,className:"library-menu-dropdown-container--in-heading"}),Nl(Dt.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:[Nl(fv,{children:[!E&&Er("div",{className:"library-menu-items-container__header",children:b("labels.personalLib")}),e&&Er("div",{style:{position:"absolute",top:"var(--container-padding-y)",right:"var(--container-padding-x)",transform:"translateY(50%)"},children:Er(Bt,{})}),!n.length&&!u.length?Nl("div",{className:"library-menu-items__no-items",children:[Er("div",{className:"library-menu-items__no-items__label",children:b("library.noItems")}),Er("div",{className:"library-menu-items__no-items__hint",children:g.length>0?b("library.hint_emptyPrivateLibrary"):b("library.hint_emptyLibrary")})]}):Nl(tf,{children:[n.length>0&&Er(cp,{itemsRenderedPerBatch:z,items:[{id:null,elements:n}],onItemSelectToggle:w,onItemDrag:k,onClick:D,isItemSelected:C,svgCache:p}),Er(cp,{itemsRenderedPerBatch:z,items:u,onItemSelectToggle:w,onItemDrag:k,onClick:R,isItemSelected:C,svgCache:p})]})]}),Nl(fv,{children:[(g.length>0||n.length>0||u.length>0)&&Er("div",{className:"library-menu-items-container__header library-menu-items-container__header--excal",children:b("labels.excalidrawLib")}),g.length>0?Er(tf,{children:Er(cp,{itemsRenderedPerBatch:z,items:g,onItemSelectToggle:w,onItemDrag:k,onClick:R,isItemSelected:C,svgCache:p})}):u.length>0?Er("div",{style:{margin:"1rem 0",display:"flex",flexDirection:"column",alignItems:"center",justifyContent:"center",width:"100%",fontSize:".9rem"},children:b("library.noItems")}):null]}),f&&Er(tp,{style:{padding:"16px 0",width:"100%"},id:a,libraryReturnUrl:l,theme:i,children:Er(ef,{selectedItems:c,onSelectItems:s})})]})]})}import{atom as Bk,useAtom as Ok}from"jotai";We();F();W();import{jsx as pi,jsxs as xv}from"react/jsx-runtime";var Dl=Bk(!1),bv=({children:e})=>pi("div",{className:"layer-ui__library",children:e}),Fk=({onInsertLibraryItems:e,pendingElements:t,onAddToLibrary:r,setAppState:o,libraryReturnUrl:n,library:i,id:a,theme:l,selectedItems:s,onSelectItems:c})=>{let[d]=Ok(ha,Pe),m=nf(g=>{(async(E,y)=>{xe("element","addToLibrary","ui");for(let w of Hc)if(E.some(I=>I.type===w))return o({errorMessage:b(`errors.libraryElementTypeError.${w}`)});let T=[{status:"unpublished",elements:E,id:At(),created:Date.now()},...y];r(),i.setLibrary(T).catch(()=>{o({errorMessage:b("alerts.errorAddingToLibrary")})})})(g,d.libraryItems)},[r,i,o,d.libraryItems]),p=Ev(()=>d.libraryItems,[d]);if(d.status==="loading"&&!d.isInitialized)return pi(bv,{children:pi("div",{className:"layer-ui__library-message",children:xv("div",{children:[pi(Bt,{size:"2em"}),pi("span",{children:b("labels.libraryLoadingMessage")})]})})});let u=d.libraryItems.length>0||t.length>0;return xv(bv,{children:[pi(rf,{isLoading:d.status==="loading",libraryItems:p,onAddToLibrary:m,onInsertLibraryItems:e,pendingElements:t,id:a,libraryReturnUrl:n,theme:l,onSelectItems:c,selectedItems:s}),u&&pi(tp,{className:"library-menu-control-buttons--at-bottom",style:{padding:"16px 12px 0 12px"},id:a,libraryReturnUrl:n,theme:l})]})},Hk=(e,t)=>{let r=()=>pe(t,e,{includeBoundTextElement:!0,includeElementsInFrames:!0}),o=of(r()),n=of(e),i=of(t);return(!bt(e.selectedElementIds,n.current.selectedElementIds)||!bt(t,i.current))&&(o.current=r(),n.current=e,i.current=t),o.current},yv=()=>{let{library:e,id:t,onInsertElements:r}=$r(),o=kl(),n=Ne(),i=Ve(),a=si(),[l,s]=Nk([]),c=Ev(()=>e,[e]),d=Hk(n,a),m=nf(u=>{r($m(u))},[r]),p=nf(()=>{i({selectedElementIds:{},selectedGroupIds:{},activeEmbeddable:null})},[i]);return pi(Fk,{pendingElements:d,onInsertLibraryItems:m,onAddToLibrary:p,setAppState:i,libraryReturnUrl:o.libraryReturnUrl,library:c,id:t,theme:n.theme,selectedItems:l,onSelectItems:s})};import{jsx as oc,jsxs as Yk}from"react/jsx-runtime";function Vk(e){if(e&&typeof e=="number")return e;switch(e){case"small":return 550;case"wide":return 1024;case"regular":default:return 800}}var ut=e=>{let[t,r]=rv(),[o]=Uk(document.activeElement),{id:n}=_t(),i=ke().viewport.isMobile;Gk(()=>{if(!t)return;let c=Jl(t);c.length>0&&e.autofocus!==!1&&(c[1]||c[0]).focus();let d=m=>{if(m.key===S.TAB){let p=Jl(t),{activeElement:u}=document,g=p.findIndex(f=>f===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=Ve(),l=Wk(Dl,Pe),s=()=>{a({openMenu:null}),l(!1),o.focus(),e.onCloseRequest()};return oc(nv,{className:zk("Dialog",e.className,{"Dialog--fullscreen":i}),labelledBy:"dialog-title",maxWidth:Vk(e.size),onCloseRequest:s,closeOnClickOutside:e.closeOnClickOutside,children:Yk(Ut,{ref:r,children:[e.title&&oc("h2",{id:`${n}-dialog-title`,className:"Dialog__title",children:oc("span",{className:"Dialog__titleContent",children:e.title})}),oc("button",{className:"Dialog__close",onClick:s,title:b("buttons.close"),"aria-label":b("buttons.close"),children:i?ay:Yr}),oc("div",{className:"Dialog__content",children:e.children})]})})};import{Fragment as Xk,jsx as af}from"react/jsx-runtime";var wv=({children:e,onClose:t})=>{let[r,o]=$k(!!e),{container:n}=_t(),i=Kk.useCallback(()=>{o(!1),t&&t(),n?.focus()},[t,n]);return af(Xk,{children:r&&af(ut,{size:"small",onCloseRequest:i,title:b("errorDialog.title"),children:af("div",{style:{whiteSpace:"pre-wrap"},children:e})})})};h();import{useEffect as rA,useRef as oA,useState as ui}from"react";oi();W();gr();En();We();ra();h();import Zk from"clsx";import{jsx as vv,jsxs as jk}from"react/jsx-runtime";var Tv=function({onChange:e,value:t,choices:r,name:o}){return vv("div",{className:"RadioGroup",children:r.map(n=>jk("div",{className:Zk("RadioGroup__choice",{active:n.value===t}),children:[vv("input",{name:o,type:"radio",checked:n.value===t,onChange:()=>e(n.value)}),n.label]},n.label))})};h();import qk from"clsx";import{jsx as Sv}from"react/jsx-runtime";var nc=({title:e,name:t,checked:r,onChange:o,disabled:n=!1})=>Sv("div",{className:qk("Switch",{toggled:r,disabled:n}),children:Sv("input",{name:t,id:t,title:e,type:"checkbox",checked:r,disabled:n,onChange:()=>o(!r),onKeyDown:i=>{i.key===" "&&o(!r)}})});h();import{forwardRef as Jk,useState as Qk}from"react";import eA from"clsx";Ji();F();import{jsx as lf,jsxs as tA}from"react/jsx-runtime";var Ko=Jk(({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]=Qk(!1),p=async u=>{let g=r?.(u);if(Lo(g))try{m(!0),await g}catch(f){if(f instanceof Oo)console.warn(f);else throw f}finally{m(!1)}};return lf("button",{className:eA("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:tA("div",{className:"ExcButton__contents",children:[d&&lf(Bt,{}),t&&lf("div",{className:"ExcButton__icon","aria-hidden":!0,children:t}),n!=="icon"&&(e??o)]})})});F();import{jsx as et,jsxs as gi}from"react/jsx-runtime";var nA="filter"in document.createElement("canvas").getContext("2d"),iA=()=>gi("div",{children:[et("h3",{children:b("canvasError.cannotShowPreview")}),et("p",{children:et("span",{children:b("canvasError.canvasTooBig")})}),gi("em",{children:["(",b("canvasError.canvasTooBigTip"),")"]})]}),aA=({appStateSnapshot:e,elementsSnapshot:t,files:r,actionManager:o,onExportImage:n,name:i})=>{let a=Re(t,e),[l,s]=ui(i),[c,d]=ui(a),[m,p]=ui(e.exportBackground),[u,g]=ui(e.exportWithDarkMode),[f,E]=ui(e.exportEmbedScene),[y,T]=ui(e.exportScale),w=oA(null),[I,k]=ui(null),{exportedElements:C,exportingFrame:D}=da(t,e,c);return rA(()=>{let R=w.current;if(!R)return;let z=R.offsetWidth,L=R.offsetHeight;z&&ni({elements:C,appState:{...e,name:l,exportBackground:m,exportWithDarkMode:u,exportScale:y,exportEmbedScene:f},files:r,exportPadding:ao,maxWidthOrHeight:Math.max(z,L),exportingFrame:D}).then(M=>(k(null),wn(M).then(()=>{R.replaceChildren(M)}).catch(A=>{throw A.name==="CANVAS_POSSIBLY_TOO_BIG"?new Error(b("canvasError.canvasTooBig")):A}))).catch(M=>{console.error(M),k(M)})},[e,r,C,D,l,m,u,y,f]),gi("div",{className:"ImageExportModal",children:[et("h3",{children:b("imageExportDialog.header")}),gi("div",{className:"ImageExportModal__preview",children:[et("div",{className:"ImageExportModal__preview__canvas",ref:w,children:I&&et(iA,{})}),et("div",{className:"ImageExportModal__preview__filename",children:!Jn&&et("input",{type:"text",className:"TextInput",value:l,style:{width:"30ch"},onChange:R=>{s(R.target.value),o.executeAction(gh,"ui",R.target.value)}})})]}),gi("div",{className:"ImageExportModal__settings",children:[et("h3",{children:b("imageExportDialog.header")}),a&&et(ic,{label:b("imageExportDialog.label.onlySelected"),name:"exportOnlySelected",children:et(nc,{name:"exportOnlySelected",checked:c,onChange:R=>{d(R)}})}),et(ic,{label:b("imageExportDialog.label.withBackground"),name:"exportBackgroundSwitch",children:et(nc,{name:"exportBackgroundSwitch",checked:m,onChange:R=>{p(R),o.executeAction(hh,"ui",R)}})}),nA&&et(ic,{label:b("imageExportDialog.label.darkMode"),name:"exportDarkModeSwitch",children:et(nc,{name:"exportDarkModeSwitch",checked:u,onChange:R=>{g(R),o.executeAction(Zw,"ui",R)}})}),et(ic,{label:b("imageExportDialog.label.embedScene"),tooltip:b("imageExportDialog.tooltip.embedScene"),name:"exportEmbedSwitch",children:et(nc,{name:"exportEmbedSwitch",checked:f,onChange:R=>{E(R),o.executeAction(_m,"ui",R)}})}),et(ic,{label:b("imageExportDialog.label.scale"),name:"exportScale",children:et(Tv,{name:"exportScale",value:y,onChange:R=>{T(R),o.executeAction(Xw,"ui",R)},choices:Ca.map(R=>({value:R,label:`${R}\xD7`}))})}),gi("div",{className:"ImageExportModal__settings__buttons",children:[et(Ko,{className:"ImageExportModal__settings__buttons__button",label:b("imageExportDialog.title.exportToPng"),onClick:()=>n(_c.png,C,{exportingFrame:D}),icon:Kg,children:b("imageExportDialog.button.exportToPng")}),et(Ko,{className:"ImageExportModal__settings__buttons__button",label:b("imageExportDialog.title.exportToSvg"),onClick:()=>n(_c.svg,C,{exportingFrame:D}),icon:Kg,children:b("imageExportDialog.button.exportToSvg")}),(sl||Nn)&&et(Ko,{className:"ImageExportModal__settings__buttons__button",label:b("imageExportDialog.title.copyPngToClipboard"),onClick:()=>n(_c.clipboard,C,{exportingFrame:D}),icon:xm,children:b("imageExportDialog.button.copyPngToClipboard")})]})]})]})},ic=({label:e,children:t,tooltip:r,name:o})=>gi("div",{className:"ImageExportModal__settings__setting",title:e,children:[gi("label",{htmlFor:o,className:"ImageExportModal__settings__setting__label",children:[e,r&&et(_r,{label:r,long:!0,children:Vy})]}),et("div",{className:"ImageExportModal__settings__setting__content",children:t})]}),Iv=({elements:e,appState:t,files:r,actionManager:o,onExportImage:n,onCloseRequest:i,name:a})=>{let[{appStateSnapshot:l,elementsSnapshot:s}]=ui(()=>({appStateSnapshot:Po(t),elementsSnapshot:Po(e)}));return et(ut,{onCloseRequest:i,size:"wide",title:!1,children:et(aA,{elementsSnapshot:s,appStateSnapshot:l,files:r,actionManager:o,onExportImage:n,name:a})})};h();import lA from"clsx";import{jsx as sA}from"react/jsx-runtime";var dp=({children:e,side:t,className:r})=>sA("div",{className:lA("FixedSideContainer",`FixedSideContainer_side_${t}`,r),children:e});h();oe();F();Sr();import{jsx as Cv}from"react/jsx-runtime";var cA=({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(ur(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 ee(d)&&d.points.length===2?b("hints.lockAngle"):Or(d)?b("hints.resizeImage"):b("hints.resize")}if(a&&l==="mouse")return b("hints.rotate");if(c.length===1&&G(c[0]))return b("hints.text_selected");if(e.editingElement&&G(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(ee(c[0]))return e.editingLinearElement?e.editingLinearElement.selectedPointsIndices?b("hints.lineEditor_pointSelected"):b("hints.lineEditor_nothingSelected"):b("hints.lineEditor_info");if(!e.draggingElement&&_o(c[0]))return b("hints.bindTextToElement")}}return null},mp=({appState:e,isMobile:t,device:r,app:o})=>{let n=cA({appState:e,isMobile:t,device:r,app:o});return n?(n=_(n),Cv("div",{className:"HintViewer",children:Cv("span",{children:n})})):null};h();import dA from"clsx";import{jsx as Av,jsxs as pA}from"react/jsx-runtime";var mA="medium",kv={CHECKED:g0,UNCHECKED:u0},pp=e=>pA("label",{className:dA("ToolIcon ToolIcon__lock",`ToolIcon_size_${mA}`,{"is-mobile":e.isMobile}),title:`${e.title} \u2014 Q`,children:[Av("input",{className:"ToolIcon_type_checkbox",type:"checkbox",name:e.name,onChange:e.onChange,checked:e.checked,"aria-label":e.title,"data-testid":"toolbar-lock"}),Av("div",{className:"ToolIcon__icon",children:e.checked?kv.CHECKED:kv.UNCHECKED})]});h();me();We();h();import{Fragment as uA,jsx as Mv,jsxs as gA}from"react/jsx-runtime";var hi=({heading:e,children:t,...r})=>{let{id:o}=_t(),n=Mv("h2",{className:"visually-hidden",id:`${o}-${e}-title`,children:b(`headings.${e}`)});return Mv("section",{...r,"aria-labelledby":`${o}-${e}-title`,children:typeof t=="function"?t(n):gA(uA,{children:[n,t]})})};h();me();F();var So=4,$o=6,Lv="rgba(0,0,0,0.3)",Pv=(e,t,r,o)=>{if(!e.length)return{horizontal:null,vertical:null};let[n,i,a,l]=ye(e),s=t/o.zoom.value,c=r/o.zoom.value,d=t-s,m=r-c,p={top:parseInt(ql("sat"))||0,bottom:parseInt(ql("sab"))||0,left:parseInt(ql("sal"))||0,right:parseInt(ql("sar"))||0},u=Qo().rtl,g=-o.scrollX+d/2+p.left,f=-o.scrollY+m/2+p.top,E=g+s-p.right,y=f+c-p.bottom,T=Math.min(n,g),w=Math.min(i,f),I=Math.max(a,E),k=Math.max(l,y);return{horizontal:g===T&&E===I?null:{x:Math.max(p.left,So)+(g-T)/(I-T)*t,y:r-$o-Math.max(So,p.bottom),width:(E-g)/(I-T)*t-Math.max(So*2,p.left+p.right),height:$o},vertical:f===w&&y===k?null:{x:u?Math.max(p.left,So):t-$o-Math.max(p.right,So),y:(f-w)/(k-w)*r+Math.max(p.top,So),width:$o,height:(y-f)/(k-w)*r-Math.max(So*2,p.top+p.bottom)}}},sf=(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}};h();import hA from"clsx";import{jsx as _v,jsxs as bA}from"react/jsx-runtime";var fA="medium",up=e=>e.penDetected?bA("label",{className:hA("ToolIcon ToolIcon__penMode",`ToolIcon_size_${fA}`,{"is-mobile":e.isMobile}),title:`${e.title}`,children:[_v("input",{className:"ToolIcon_type_checkbox",type:"checkbox",name:e.name,onChange:e.onChange,checked:e.checked,"aria-label":e.title}),_v("div",{className:"ToolIcon__icon",children:S0})]}):null;h();mt();We();import{Fragment as Dv,jsx as Xe,jsxs as Dr}from"react/jsx-runtime";var gp=e=>{let t=ye(e.elements),r=la(e.elements,e.appState),o=ye(r);return Xe("div",{className:"Stats",children:Dr(Ut,{padding:2,children:[Xe("div",{className:"close",onClick:e.onClose,children:Yr}),Xe("h3",{children:b("stats.title")}),Xe("table",{children:Dr("tbody",{children:[Xe("tr",{children:Xe("th",{colSpan:2,children:b("stats.scene")})}),Dr("tr",{children:[Xe("td",{children:b("stats.elements")}),Xe("td",{children:e.elements.length})]}),Dr("tr",{children:[Xe("td",{children:b("stats.width")}),Xe("td",{children:Math.round(t[2])-Math.round(t[0])})]}),Dr("tr",{children:[Xe("td",{children:b("stats.height")}),Xe("td",{children:Math.round(t[3])-Math.round(t[1])})]}),r.length===1&&Xe("tr",{children:Xe("th",{colSpan:2,children:b("stats.element")})}),r.length>1&&Dr(Dv,{children:[Xe("tr",{children:Xe("th",{colSpan:2,children:b("stats.selected")})}),Dr("tr",{children:[Xe("td",{children:b("stats.elements")}),Xe("td",{children:r.length})]})]}),r.length>0&&Dr(Dv,{children:[Dr("tr",{children:[Xe("td",{children:"x"}),Xe("td",{children:Math.round(o[0])})]}),Dr("tr",{children:[Xe("td",{children:"y"}),Xe("td",{children:Math.round(o[1])})]}),Dr("tr",{children:[Xe("td",{children:b("stats.width")}),Xe("td",{children:Math.round(o[2]-o[0])})]}),Dr("tr",{children:[Xe("td",{children:b("stats.height")}),Xe("td",{children:Math.round(o[3]-o[1])})]})]}),r.length===1&&Dr("tr",{children:[Xe("td",{children:b("stats.angle")}),Xe("td",{children:`${Math.round(r[0].angle*180/Math.PI)}\xB0`})]}),e.renderCustomStats?.(e.elements,e.appState)]})})]})})};h();import xA from"clsx";de();import{jsx as EA}from"react/jsx-runtime";var hp=e=>EA(ne,{className:xA("Shape",{fillable:!1}),type:"radio",icon:Wy,name:"editor-current-shape",checked:e.checked,title:`${e.title} \u2014 H`,keyBindingLabel:e.isMobile?void 0:S.H.toLocaleUpperCase(),"aria-label":`${e.title} \u2014 H`,"aria-keyshortcuts":S.H,"data-testid":"toolbar-hand",onChange:()=>e.onChange?.()});Sr();import{Fragment as yA,jsx as Rt,jsxs as fi}from"react/jsx-runtime";var Rv=({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})=>{let{WelcomeScreenCenterTunnel:g,MainMenuTunnel:f,DefaultSidebarTriggerTunnel:E}=Qe(),y=()=>fi(dp,{side:"top",className:"App-top-bar",children:[m&&Rt(g.Out,{}),Rt(hi,{heading:"shapes",children:w=>Rt(Dt.Col,{gap:4,align:"center",children:fi(Dt.Row,{gap:1,className:"App-toolbar-container",children:[fi(Ut,{padding:1,className:"App-toolbar App-toolbar--mobile",children:[w,Rt(Dt.Row,{gap:1,children:Rt(ep,{appState:e,activeTool:e.activeTool,UIOptions:p,app:u})})]}),l&&l(!0,e),fi("div",{className:"mobile-misc-tools-container",children:[!e.viewModeEnabled&&Rt(E.Out,{}),Rt(up,{checked:e.penMode,onChange:()=>a(null),title:b("toolBar.penMode"),isMobile:!0,penDetected:e.penDetected}),Rt(pp,{checked:e.activeTool.locked,onChange:n,title:b("toolBar.lock"),isMobile:!0}),Rt(hp,{checked:xo(e),onChange:()=>i(),title:b("toolBar.hand"),isMobile:!0})]})]})})}),Rt(mp,{appState:e,isMobile:!0,device:d,app:u})]}),T=()=>e.viewModeEnabled?Rt("div",{className:"App-toolbar-content",children:Rt(f.Out,{})}):fi("div",{className:"App-toolbar-content",children:[Rt(f.Out,{}),r.renderAction("toggleEditMenu"),r.renderAction("undo"),r.renderAction("redo"),r.renderAction(e.multiElement?"finalize":"duplicateSelection"),r.renderAction("deleteSelectedElements")]});return fi(yA,{children:[c(),!e.viewModeEnabled&&y(),!e.openMenu&&e.showStats&&Rt(gp,{appState:e,setAppState:o,elements:t,onClose:()=>{r.executeAction(di)},renderCustomStats:s}),Rt("div",{className:"App-bottom-bar",style:{marginBottom:$o+So*2,marginLeft:$o+So*2,marginRight:$o+So*2},children:fi(Ut,{padding:0,children:[e.openMenu==="shape"&&!e.viewModeEnabled&&ia(e,t)?Rt(hi,{className:"App-mobile-menu",heading:"selectedShapeActions",children:Rt(Qm,{appState:e,elementsMap:u.scene.getNonDeletedElementsMap(),renderAction:r.renderAction})}):null,fi("footer",{className:"App-toolbar",children:[T(),e.scrolledOutside&&!e.openMenu&&!e.openSidebar&&Rt("button",{className:"scroll-back-to-content",onClick:()=>{o(w=>({...Ho(t,w)}))},children:b("buttons.scrollBackToContent")})]})]})})]})};h();import wA from"open-color";import vA,{useLayoutEffect as TA,useRef as SA,useState as IA}from"react";Eg();Fs();import{jsx as ac,jsxs as CA}from"react/jsx-runtime";var Nv=e=>{let t=SA(null),[r,o]=IA(null);return TA(()=>{if(!e.spreadsheet)return;let n=vE(e.chartType,e.spreadsheet,0,0);o(n);let i,a=t.current;return(async()=>(i=await il(n,{exportBackground:!1,viewBackgroundColor:wA.white},null),i.querySelector(".style-fonts")?.remove(),a.replaceChildren(),a.appendChild(i),e.selected&&a.parentNode.focus()))(),()=>{a.replaceChildren()}},[e.spreadsheet,e.chartType,e.selected]),ac("button",{className:"ChartPreview",onClick:()=>{r&&e.onClick(e.chartType,r)},children:ac("div",{ref:t})})},Bv=({setAppState:e,appState:t,onClose:r})=>{let{onInsertElements:o}=$r(),n=vA.useCallback(()=>{r&&r()},[r]),i=(a,l)=>{o(l),xe("paste","chart",a),e({currentChartType:a,pasteDialog:{shown:!1,data:null}})};return ac(ut,{size:"small",onCloseRequest:n,title:b("labels.pasteCharts"),className:"PasteChartDialog",autofocus:!1,children:CA("div",{className:"container",children:[ac(Nv,{chartType:"bar",spreadsheet:t.pasteDialog.data,selected:t.currentChartType==="bar",onClick:i}),ac(Nv,{chartType:"line",spreadsheet:t.pasteDialog.data,selected:t.currentChartType==="line",onClick:i})]})})};h();import kA from"react";de();F();oi();W();import{Fragment as Fv,jsx as U,jsxs as Jr}from"react/jsx-runtime";var AA=()=>Jr("div",{className:"HelpDialog__header",children:[Jr("a",{className:"HelpDialog__btn",href:"https://docs.excalidraw.com",target:"_blank",rel:"noopener noreferrer",children:[b("helpDialog.documentation"),U("div",{className:"HelpDialog__link-icon",children:hm})]}),Jr("a",{className:"HelpDialog__btn",href:"https://blog.excalidraw.com",target:"_blank",rel:"noopener noreferrer",children:[b("helpDialog.blog"),U("div",{className:"HelpDialog__link-icon",children:hm})]}),Jr("a",{className:"HelpDialog__btn",href:"https://github.com/excalidraw/excalidraw/issues",target:"_blank",rel:"noopener noreferrer",children:[b("helpDialog.github"),U("div",{className:"HelpDialog__link-icon",children:hm})]})]}),MA=e=>Jr(Fv,{children:[U("h3",{children:e.title}),U("div",{className:"HelpDialog__islands-container",children:e.children})]}),cf=e=>Jr("div",{className:`HelpDialog__island ${e.className}`,children:[U("h4",{className:"HelpDialog__island-title",children:e.caption}),U("div",{className:"HelpDialog__island-content",children:e.children})]});function*LA(e,t){let r=!0;for(let o of e)r||(yield t),r=!1,yield o}var PA=e=>e.replace(/\b[a-z]\b/,t=>t.toUpperCase()),K=({label:e,shortcuts:t,isOr:r=!0})=>{let o=t.map(n=>(n.endsWith("++")?[...n.slice(0,-2).split("+"),"+"]:n.split("+")).map(a=>U(_A,{children:PA(a)},a)));return Jr("div",{className:"HelpDialog__shortcut",children:[U("div",{children:e}),U("div",{className:"HelpDialog__key-container",children:[...LA(o,r?b("helpDialog.or"):null)]})]})},_A=e=>U("kbd",{className:"HelpDialog__key",...e}),Ov=({onClose:e})=>{let t=kA.useCallback(()=>{e&&e()},[e]);return U(Fv,{children:Jr(ut,{onCloseRequest:t,title:b("helpDialog.title"),className:"HelpDialog",children:[U(AA,{}),Jr(MA,{title:b("helpDialog.shortcuts"),children:[Jr(cf,{className:"HelpDialog__island--tools",caption:b("helpDialog.tools"),children:[U(K,{label:b("toolBar.hand"),shortcuts:[S.H]}),U(K,{label:b("toolBar.selection"),shortcuts:[S.V,S[1]]}),U(K,{label:b("toolBar.rectangle"),shortcuts:[S.R,S[2]]}),U(K,{label:b("toolBar.diamond"),shortcuts:[S.D,S[3]]}),U(K,{label:b("toolBar.ellipse"),shortcuts:[S.O,S[4]]}),U(K,{label:b("toolBar.arrow"),shortcuts:[S.A,S[5]]}),U(K,{label:b("toolBar.line"),shortcuts:[S.L,S[6]]}),U(K,{label:b("toolBar.freedraw"),shortcuts:[S.P,S[7]]}),U(K,{label:b("toolBar.text"),shortcuts:[S.T,S[8]]}),U(K,{label:b("toolBar.image"),shortcuts:[S[9]]}),U(K,{label:b("toolBar.eraser"),shortcuts:[S.E,S[0]]}),U(K,{label:b("toolBar.frame"),shortcuts:[S.F]}),U(K,{label:b("toolBar.laser"),shortcuts:[S.K]}),U(K,{label:b("labels.eyeDropper"),shortcuts:[S.I,"Shift+S","Shift+G"]}),U(K,{label:b("helpDialog.editLineArrowPoints"),shortcuts:[_("CtrlOrCmd+Enter")]}),U(K,{label:b("helpDialog.editText"),shortcuts:[_("Enter")]}),U(K,{label:b("helpDialog.textNewLine"),shortcuts:[_("Enter"),_("Shift+Enter")]}),U(K,{label:b("helpDialog.textFinish"),shortcuts:[_("Esc"),_("CtrlOrCmd+Enter")]}),U(K,{label:b("helpDialog.curvedArrow"),shortcuts:["A",b("helpDialog.click"),b("helpDialog.click"),b("helpDialog.click")],isOr:!1}),U(K,{label:b("helpDialog.curvedLine"),shortcuts:["L",b("helpDialog.click"),b("helpDialog.click"),b("helpDialog.click")],isOr:!1}),U(K,{label:b("toolBar.lock"),shortcuts:[S.Q]}),U(K,{label:b("helpDialog.preventBinding"),shortcuts:[_("CtrlOrCmd")]}),U(K,{label:b("toolBar.link"),shortcuts:[_("CtrlOrCmd+K")]})]}),Jr(cf,{className:"HelpDialog__island--view",caption:b("helpDialog.view"),children:[U(K,{label:b("buttons.zoomIn"),shortcuts:[_("CtrlOrCmd++")]}),U(K,{label:b("buttons.zoomOut"),shortcuts:[_("CtrlOrCmd+-")]}),U(K,{label:b("buttons.resetZoom"),shortcuts:[_("CtrlOrCmd+0")]}),U(K,{label:b("helpDialog.zoomToFit"),shortcuts:["Shift+1"]}),U(K,{label:b("helpDialog.zoomToSelection"),shortcuts:["Shift+2"]}),U(K,{label:b("helpDialog.movePageUpDown"),shortcuts:["PgUp/PgDn"]}),U(K,{label:b("helpDialog.movePageLeftRight"),shortcuts:["Shift+PgUp/PgDn"]}),U(K,{label:b("buttons.zenMode"),shortcuts:[_("Alt+Z")]}),U(K,{label:b("buttons.objectsSnapMode"),shortcuts:[_("Alt+S")]}),U(K,{label:b("labels.showGrid"),shortcuts:[_("CtrlOrCmd+'")]}),U(K,{label:b("labels.viewMode"),shortcuts:[_("Alt+R")]}),U(K,{label:b("labels.toggleTheme"),shortcuts:[_("Alt+Shift+D")]}),U(K,{label:b("stats.title"),shortcuts:[_("Alt+/")]})]}),Jr(cf,{className:"HelpDialog__island--editor",caption:b("helpDialog.editor"),children:[U(K,{label:b("labels.moveCanvas"),shortcuts:[_(`Space+${b("helpDialog.drag")}`),_(`Wheel+${b("helpDialog.drag")}`)],isOr:!0}),U(K,{label:b("buttons.clearReset"),shortcuts:[_("CtrlOrCmd+Delete")]}),U(K,{label:b("labels.delete"),shortcuts:[_("Delete")]}),U(K,{label:b("labels.cut"),shortcuts:[_("CtrlOrCmd+X")]}),U(K,{label:b("labels.copy"),shortcuts:[_("CtrlOrCmd+C")]}),U(K,{label:b("labels.paste"),shortcuts:[_("CtrlOrCmd+V")]}),U(K,{label:b("labels.pasteAsPlaintext"),shortcuts:[_("CtrlOrCmd+Shift+V")]}),U(K,{label:b("labels.selectAll"),shortcuts:[_("CtrlOrCmd+A")]}),U(K,{label:b("labels.multiSelect"),shortcuts:[_(`Shift+${b("helpDialog.click")}`)]}),U(K,{label:b("helpDialog.deepSelect"),shortcuts:[_(`CtrlOrCmd+${b("helpDialog.click")}`)]}),U(K,{label:b("helpDialog.deepBoxSelect"),shortcuts:[_(`CtrlOrCmd+${b("helpDialog.drag")}`)]}),(sl||Nn)&&U(K,{label:b("labels.copyAsPng"),shortcuts:[_("Shift+Alt+C")]}),U(K,{label:b("labels.copyStyles"),shortcuts:[_("CtrlOrCmd+Alt+C")]}),U(K,{label:b("labels.pasteStyles"),shortcuts:[_("CtrlOrCmd+Alt+V")]}),U(K,{label:b("labels.sendToBack"),shortcuts:[qt?_("CtrlOrCmd+Alt+["):_("CtrlOrCmd+Shift+[")]}),U(K,{label:b("labels.bringToFront"),shortcuts:[qt?_("CtrlOrCmd+Alt+]"):_("CtrlOrCmd+Shift+]")]}),U(K,{label:b("labels.sendBackward"),shortcuts:[_("CtrlOrCmd+[")]}),U(K,{label:b("labels.bringForward"),shortcuts:[_("CtrlOrCmd+]")]}),U(K,{label:b("labels.alignTop"),shortcuts:[_("CtrlOrCmd+Shift+Up")]}),U(K,{label:b("labels.alignBottom"),shortcuts:[_("CtrlOrCmd+Shift+Down")]}),U(K,{label:b("labels.alignLeft"),shortcuts:[_("CtrlOrCmd+Shift+Left")]}),U(K,{label:b("labels.alignRight"),shortcuts:[_("CtrlOrCmd+Shift+Right")]}),U(K,{label:b("labels.duplicateSelection"),shortcuts:[_("CtrlOrCmd+D"),_(`Alt+${b("helpDialog.drag")}`)]}),U(K,{label:b("helpDialog.toggleElementLock"),shortcuts:[_("CtrlOrCmd+Shift+L")]}),U(K,{label:b("buttons.undo"),shortcuts:[_("CtrlOrCmd+Z")]}),U(K,{label:b("buttons.redo"),shortcuts:Mc?[_("CtrlOrCmd+Y"),_("CtrlOrCmd+Shift+Z")]:[_("CtrlOrCmd+Shift+Z")]}),U(K,{label:b("labels.group"),shortcuts:[_("CtrlOrCmd+G")]}),U(K,{label:b("labels.ungroup"),shortcuts:[_("CtrlOrCmd+Shift+G")]}),U(K,{label:b("labels.flipHorizontal"),shortcuts:[_("Shift+H")]}),U(K,{label:b("labels.flipVertical"),shortcuts:[_("Shift+V")]}),U(K,{label:b("labels.showStroke"),shortcuts:[_("S")]}),U(K,{label:b("labels.showBackground"),shortcuts:[_("G")]}),U(K,{label:b("labels.decreaseFontSize"),shortcuts:[_("CtrlOrCmd+Shift+<")]}),U(K,{label:b("labels.increaseFontSize"),shortcuts:[_("CtrlOrCmd+Shift+>")]})]})]})]})})};h();import pf from"react";import Hv from"clsx";import*as Ol from"@radix-ui/react-popover";F();import{jsx as bi,jsxs as Bl}from"react/jsx-runtime";var df=3,DA=8,RA=({shouldWrap:e,children:t,clientId:r,username:o})=>e?bi(_r,{label:o||"Unknown user",children:t},r):bi(pf.Fragment,{children:t},r),mf=({actionManager:e,collaborator:t,clientId:r,withName:o=!1,shouldWrapWithTooltip:n=!1,isBeingFollowed:i})=>{let a={clientId:r,collaborator:t,withName:o,isBeingFollowed:i},l=e.renderAction("goToCollaborator",a);return bi(RA,{clientId:r,username:t.username,shouldWrap:n,children:l},r)},NA=["avatarUrl","id","socketId","username"],fp=pf.memo(({className:e,mobile:t,collaborators:r,userToFollow:o})=>{let n=Wt(),i=new Map;r.forEach((u,g)=>{let f=u.id||g;i.set(f,{...u,socketId:g})});let a=Array.from(i).filter(([u,g])=>g.username?.trim()),[l,s]=pf.useState("");if(a.length===0)return null;let d=l.trim().toLowerCase()?a.filter(([,u])=>u.username?.toLowerCase().includes(l)):a,p=a.slice(0,df).map(([u,g])=>mf({actionManager:n,collaborator:g,clientId:u,shouldWrapWithTooltip:!0,isBeingFollowed:g.socketId===o}));return t?bi("div",{className:Hv("UserList UserList_mobile",e),children:a.map(([u,g])=>mf({actionManager:n,collaborator:g,clientId:u,shouldWrapWithTooltip:!0,isBeingFollowed:g.socketId===o}))}):Bl("div",{className:Hv("UserList",e),children:[p,a.length>df&&Bl(Ol.Root,{onOpenChange:u=>{u||s("")},children:[Bl(Ol.Trigger,{className:"UserList__more",children:["+",a.length-df]}),bi(Ol.Content,{style:{zIndex:2,width:"13rem",textAlign:"left"},align:"end",sideOffset:10,children:Bl(Ut,{style:{overflow:"hidden"},children:[a.length>=DA&&Bl("div",{className:"UserList__search-wrapper",children:[Qy,bi("input",{className:"UserList__search",type:"text",placeholder:b("userList.search.placeholder"),value:l,onChange:u=>{s(u.target.value)}})]}),Bl("div",{className:"dropdown-menu UserList__collaborators",children:[d.length===0&&bi("div",{className:"UserList__collaborators__empty",children:b("userList.search.empty")}),bi("div",{className:"UserList__hint",children:b("userList.hint.text")}),d.map(([u,g])=>mf({actionManager:n,collaborator:g,clientId:u,withName:!0,isBeingFollowed:g.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;for(let[r,o]of e.collaborators){let n=t.collaborators.get(r);if(!n||!bt(o,n,NA))return!1}return!0});h();import OA from"react";h();import uf from"open-color";import{jsx as BA}from"react/jsx-runtime";var gf=({children:e,color:t})=>BA("div",{className:"Card",style:{"--card-color":t==="primary"?"var(--color-primary)":uf[t][7],"--card-color-darker":t==="primary"?"var(--color-primary-darker)":uf[t][8],"--card-color-darkest":t==="primary"?"var(--color-primary-darkest)":uf[t][9]},children:e});En();F();import{Fragment as HA,jsx as Io,jsxs as bp}from"react/jsx-runtime";var FA=({elements:e,appState:t,setAppState:r,files:o,actionManager:n,exportOpts:i,canvas:a,onCloseRequest:l})=>{let{onExportToBackend:s}=i;return Io("div",{className:"ExportDialog ExportDialog--json",children:bp("div",{className:"ExportDialog-cards",children:[i.saveFileToDisk&&bp(gf,{color:"lime",children:[Io("div",{className:"Card-icon",children:U0}),Io("h2",{children:b("exportDialog.disk_title")}),bp("div",{className:"Card-details",children:[b("exportDialog.disk_details"),!Jn&&n.renderAction("changeProjectName")]}),Io(ne,{className:"Card-button",type:"button",title:b("exportDialog.disk_button"),"aria-label":b("exportDialog.disk_button"),showAriaLabel:!0,onClick:()=>{n.executeAction(Js,"ui")}})]}),s&&bp(gf,{color:"pink",children:[Io("div",{className:"Card-icon",children:fm}),Io("h2",{children:b("exportDialog.link_title")}),Io("div",{className:"Card-details",children:b("exportDialog.link_details")}),Io(ne,{className:"Card-button",type:"button",title:b("exportDialog.link_button"),"aria-label":b("exportDialog.link_button"),showAriaLabel:!0,onClick:async()=>{try{xe("export","link",`ui (${s1()})`),await s(e,t,o),l()}catch(c){r({errorMessage:c.message})}}})]}),i.renderCustomUI&&i.renderCustomUI(e,t,o,a)]})})},zv=({elements:e,appState:t,files:r,actionManager:o,exportOpts:n,canvas:i,setAppState:a})=>{let l=OA.useCallback(()=>{a({openDialog:null})},[a]);return Io(HA,{children:t.openDialog?.name==="jsonExport"&&Io(ut,{onCloseRequest:l,title:b("buttons.export"),children:Io(FA,{elements:e,appState:t,setAppState:a,files:r,actionManager:o,onCloseRequest:l,exportOpts:n,canvas:i})})})};h();import xp from"clsx";h();import{jsx as zA}from"react/jsx-runtime";var Gv=e=>zA("button",{className:"help-icon",onClick:e.onClick,type:"button",title:`${b("helpDialog.title")} \u2014 ?`,"aria-label":b("helpDialog.title"),children:gl});import{jsx as Xo,jsxs as hf}from"react/jsx-runtime";var Uv=({appState:e,actionManager:t,showExitZenModeBtn:r,renderWelcomeScreen:o})=>{let{FooterCenterTunnel:n,WelcomeScreenHelpHintTunnel:i}=Qe(),a=ke(),l=!e.viewModeEnabled&&e.multiElement&&a.isTouchScreen;return hf("footer",{role:"contentinfo",className:"layer-ui__wrapper__footer App-menu App-menu_bottom",children:[Xo("div",{className:xp("layer-ui__wrapper__footer-left zen-mode-transition",{"layer-ui__wrapper__footer-left--transition-left":e.zenModeEnabled}),children:Xo(Dt.Col,{gap:2,children:hf(hi,{heading:"canvasActions",children:[Xo(J2,{renderAction:t.renderAction,zoom:e.zoom}),!e.viewModeEnabled&&Xo(Q2,{renderAction:t.renderAction,className:xp("zen-mode-transition",{"layer-ui__wrapper__footer-left--transition-bottom":e.zenModeEnabled})}),l&&Xo(tv,{renderAction:t.renderAction,className:xp("zen-mode-transition",{"layer-ui__wrapper__footer-left--transition-left":e.zenModeEnabled})})]})})}),Xo(n.Out,{}),Xo("div",{className:xp("layer-ui__wrapper__footer-right zen-mode-transition",{"transition-right":e.zenModeEnabled}),children:hf("div",{style:{position:"relative"},children:[o&&Xo(i.Out,{}),Xo(Gv,{onClick:()=>t.executeAction(ua)})]})}),Xo(ev,{actionManager:t,showExitZenModeBtn:r})]})},Wv=Uv;Uv.displayName="Footer";h();import{useEffect as Qv,useLayoutEffect as e3,useRef as Sf,useState as jA,forwardRef as t3,useImperativeHandle as qA,useCallback as qv}from"react";import{atom as JA,useSetAtom as QA}from"jotai";h();import GA from"react";var Ep=GA.createContext({});h();import VA from"clsx";import{useContext as YA}from"react";h();F();import UA from"clsx";import{jsx as WA}from"react/jsx-runtime";var Zo=({type:e="button",onSelect:t,selected:r,children:o,className:n="",...i})=>WA("button",{onClick:Hn(i.onClick,a=>{t()}),type:e,className:UA("excalidraw-button",n,{selected:r}),...i,children:o});import{jsx as ff,jsxs as Vv}from"react/jsx-runtime";var bf=({children:e,className:t})=>{let r=ke(),o=YA(Ep),n=!!(r.editor.canFitSidebar&&o.shouldRenderDockButton);return Vv("div",{className:VA("sidebar__header",t),"data-testid":"sidebar-header",children:[e,Vv("div",{className:"sidebar__header__buttons",children:[n&&ff(_r,{label:b("labels.sidebarLock"),children:ff(Zo,{onSelect:()=>o.onDock?.(!o.docked),selected:!!o.docked,className:"sidebar__dock","data-testid":"sidebar-dock","aria-label":b("labels.sidebarLock"),children:p0})}),ff(Zo,{"data-testid":"sidebar-close",className:"sidebar__close",onSelect:o.onCloseRequest,"aria-label":b("buttons.close"),children:Yr})]})]})};bf.displayName="SidebarHeader";import eM from"clsx";F();de();W();h();import KA from"clsx";import{jsx as xf,jsxs as Yv}from"react/jsx-runtime";var Ef=({name:e,tab:t,icon:r,title:o,children:n,onToggle:i,className:a,style:l})=>{let s=Ve(),c=Ne();return Yv("label",{title:o,className:"sidebar-trigger__label-element",children:[xf("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"}),Yv("div",{className:KA("sidebar-trigger",a),style:l,children:[r&&xf("div",{children:r}),n&&xf("div",{className:"sidebar-trigger__label",children:n})]})]})};Ef.displayName="SidebarTrigger";h();import*as Kv from"@radix-ui/react-tabs";import{jsx as $A}from"react/jsx-runtime";var yf=({children:e,...t})=>$A(Kv.List,{className:"sidebar-triggers",...t,children:e});yf.displayName="SidebarTabTriggers";h();import*as Xv from"@radix-ui/react-tabs";import{jsx as $v}from"react/jsx-runtime";var wf=({children:e,tab:t,onSelect:r,...o})=>$v(Xv.Trigger,{value:t,asChild:!0,onSelect:r,children:$v("button",{type:"button",className:"excalidraw-button sidebar-tab-trigger",...o,children:e})});wf.displayName="SidebarTabTrigger";h();import*as Zv from"@radix-ui/react-tabs";import{jsx as XA}from"react/jsx-runtime";var vf=({children:e,...t})=>{let r=Ne(),o=Ve();if(!r.openSidebar)return null;let{name:n}=r.openSidebar;return XA(Zv.Root,{className:"sidebar-tabs-root",value:r.openSidebar.tab,onValueChange:i=>o(a=>({...a,openSidebar:{...a.openSidebar,name:n,tab:i}})),...t,children:e})};vf.displayName="SidebarTabs";h();import*as jv from"@radix-ui/react-tabs";import{jsx as ZA}from"react/jsx-runtime";var Tf=({tab:e,children:t,...r})=>ZA(jv.Content,{...r,value:e,children:t});Tf.displayName="SidebarTab";import{jsx as Jv}from"react/jsx-runtime";import{createElement as tM}from"react";var lc=JA(!1),r3=t3(({name:e,children:t,onDock:r,docked:o,className:n,...i},a)=>{v.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=Ve(),s=QA(lc,Pe);e3(()=>(s(!!o),()=>{s(!1)}),[s,o]);let c=Sf({});c.current.onCloseRequest=()=>{l({openSidebar:null})},c.current.onDock=u=>r?.(u),c.current=La(c.current,{docked:o,shouldRenderDockButton:!!r&&o!=null});let d=Sf(null);qA(a,()=>d.current);let m=ke(),p=qv(()=>{document.querySelector(".Dialog")||l({openSidebar:null})},[l]);return yl(d,qv(u=>{u.target.closest(".sidebar-trigger")||(!o||!m.editor.canFitSidebar)&&p()},[p,o,m.editor.canFitSidebar])),Qv(()=>{let u=g=>{g.key===S.ESCAPE&&(!o||!m.editor.canFitSidebar)&&p()};return document.addEventListener("keydown",u),()=>{document.removeEventListener("keydown",u)}},[p,o,m.editor.canFitSidebar]),Jv(Ut,{...i,className:eM("sidebar",{"sidebar--docked":o},n),ref:d,children:Jv(Ep.Provider,{value:c.current,children:t})})});r3.displayName="SidebarInner";var Mn=Object.assign(t3((e,t)=>{let r=Ne(),{onStateChange:o}=e,n=Sf(r.openSidebar);Qv(()=>{(!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]=jA(!1);return e3(()=>(a(!0),()=>a(!1)),[]),i&&r.openSidebar?.name===e.name?tM(r3,{...e,ref:t,key:e.name}):null}),{Header:bf,TabTriggers:yf,TabTrigger:wf,Tabs:vf,Tab:Tf,Trigger:Ef});Mn.displayName="Sidebar";import{Provider as jM,useAtom as qM,useAtomValue as JM}from"jotai";h();var Cf={};bb(Cf,{ChangeCanvasBackground:()=>m3,ClearCanvas:()=>c3,Export:()=>p3,Help:()=>s3,LiveCollaborationTrigger:()=>g3,LoadScene:()=>i3,SaveAsImage:()=>l3,SaveToActiveFile:()=>a3,Socials:()=>u3,ToggleTheme:()=>d3});h();import lM from"clsx";import{useSetAtom as sM}from"jotai";h();import{atom as rM,useAtom as oM}from"jotai";import{jsx as iM,jsxs as nM}from"react/jsx-runtime";var sc=rM(null),o3=()=>{let[e,t]=oM(sc,Pe),r=Wt();return e&&e==="clearCanvas"?iM(np,{onConfirm:()=>{r.executeAction(Zs),t(null)},onCancel:()=>t(null),title:b("clearCanvasDialog.title"),children:nM("p",{className:"clear-canvas__content",children:[" ",b("alerts.clearReset")]})}):null};h();import{atom as aM}from"jotai";var If=aM({active:!1});async function n3({title:e,description:t,actionLabel:r,color:o}){return new Promise(n=>{sr.set(If,{active:!0,onConfirm:()=>n(!0),onClose:()=>n(!1),onReject:()=>n(!1),title:e,description:t,actionLabel:r,color:o})})}import{Fragment as cM,jsx as jt,jsxs as h3}from"react/jsx-runtime";var i3=()=>{let{t:e}=St(),t=Wt(),r=si();return t.isActionEnabled(vl)?jt(To,{icon:hl,onSelect:async()=>{(!r.length||await n3({title:e("overwriteConfirm.modal.loadFromFile.title"),actionLabel:e("overwriteConfirm.modal.loadFromFile.button"),color:"warning",description:jt(or,{i18nKey:"overwriteConfirm.modal.loadFromFile.description",bold:n=>jt("strong",{children:n}),br:()=>jt("br",{})})}))&&t.executeAction(vl)},"data-testid":"load-button",shortcut:kn("loadScene"),"aria-label":e("buttons.load"),children:e("buttons.load")}):null};i3.displayName="LoadScene";var a3=()=>{let{t:e}=St(),t=Wt();return t.isActionEnabled(Dm)?jt(To,{shortcut:kn("saveScene"),"data-testid":"save-button",onSelect:()=>t.executeAction(Dm),icon:F0,"aria-label":`${e("buttons.save")}`,children:`${e("buttons.save")}`}):null};a3.displayName="SaveToActiveFile";var l3=()=>{let e=Ve(),{t}=St();return jt(To,{icon:G0,"data-testid":"image-export-button",onSelect:()=>e({openDialog:{name:"imageExport"}}),shortcut:kn("imageExport"),"aria-label":t("buttons.exportImage"),children:t("buttons.exportImage")})};l3.displayName="SaveAsImage";var s3=()=>{let{t:e}=St(),t=Wt();return jt(To,{"data-testid":"help-menu-item",icon:gl,onSelect:()=>t.executeAction(ua),shortcut:"?","aria-label":e("helpDialog.title"),children:e("helpDialog.title")})};s3.displayName="Help";var c3=()=>{let{t:e}=St(),t=sM(sc,Pe);return Wt().isActionEnabled(Zs)?jt(To,{icon:ii,onSelect:()=>t("clearCanvas"),"data-testid":"clear-canvas-button","aria-label":e("buttons.clearReset"),children:e("buttons.clearReset")}):null};c3.displayName="ClearCanvas";var d3=()=>{let{t:e}=St(),t=Ne(),r=Wt();return r.isActionEnabled(Lm)?jt(To,{onSelect:o=>(o.preventDefault(),r.executeAction(Lm)),icon:t.theme==="dark"?D0:_0,"data-testid":"toggle-dark-mode",shortcut:kn("toggleTheme"),"aria-label":t.theme==="dark"?e("buttons.lightMode"):e("buttons.darkMode"),children:t.theme==="dark"?e("buttons.lightMode"):e("buttons.darkMode")}):null};d3.displayName="ToggleTheme";var m3=()=>{let{t:e}=St(),t=Ne(),r=Wt(),o=kl();return t.viewModeEnabled||!o.UIOptions.canvasActions.changeViewBackgroundColor?null:h3("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")})]})};m3.displayName="ChangeCanvasBackground";var p3=()=>{let{t:e}=St(),t=Ve();return jt(To,{icon:gm,onSelect:()=>{t({openDialog:{name:"jsonExport"}})},"data-testid":"json-export-button","aria-label":e("buttons.export"),children:e("buttons.export")})};p3.displayName="Export";var u3=()=>{let{t:e}=St();return h3(cM,{children:[jt(Pl,{icon:R0,href:"https://github.com/excalidraw/excalidraw","aria-label":"GitHub",children:"GitHub"}),jt(Pl,{icon:B0,href:"https://x.com/excalidraw","aria-label":"X",children:e("labels.followUs")}),jt(Pl,{icon:N0,href:"https://discord.gg/UexuTaE","aria-label":"Discord",children:e("labels.discordChat")})]})};u3.displayName="Socials";var g3=({onSelect:e,isCollaborating:t})=>{let{t:r}=St();return jt(To,{"data-testid":"collab-button",icon:bm,className:lM({"active-collab":t}),onSelect:e,children:r("labels.liveCollaboration")})};g3.displayName="LiveCollaborationTrigger";h();import{atom as dM,useAtom as mM}from"jotai";import{useLayoutEffect as pM,useRef as uM}from"react";import{jsx as gM}from"react/jsx-runtime";var Ln=(e,t)=>{let r=dM(0),o=n=>{let{jotaiScope:i}=Qe(),[,a]=mM(r,i),l=uM({preferHost:!1,counter:0});return pM(()=>{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:gM(t,{...n})};return o.displayName=e,o};F();import{jsx as yp,jsxs as kf}from"react/jsx-runtime";var hM=Object.assign(Ln("MainMenu",({children:e,onSelect:t})=>{let{MainMenuTunnel:r}=Qe(),o=ke(),n=Ne(),i=Ve(),a=o.editor.isMobile?void 0:()=>i({openMenu:null});return yp(r.In,{children:kf(Le,{open:n.openMenu==="canvas",children:[yp(Le.Trigger,{onToggle:()=>{i({openMenu:n.openMenu==="canvas"?null:"canvas"})},"data-testid":"main-menu-trigger",className:"main-menu-trigger",children:um}),kf(Le.Content,{onClickOutside:a,onSelect:Hn(t,()=>{i({openMenu:null})}),children:[e,o.editor.isMobile&&n.collaborators.size>0&&kf("fieldset",{className:"UserList-Wrapper",children:[yp("legend",{children:b("labels.collaborators")}),yp(fp,{mobile:!0,collaborators:n.collaborators,userToFollow:n.userToFollow?.socketId||null})]})]})]})})}),{Trigger:Le.Trigger,Item:Le.Item,ItemLink:Le.ItemLink,ItemCustom:Le.ItemCustom,Group:Le.Group,Separator:Le.Separator,DefaultItems:Cf}),nr=hM;h();import{useAtom as EM}from"jotai";h();import{jsx as Fl,jsxs as xM}from"react/jsx-runtime";var wp=({title:e,children:t,actionLabel:r,onClick:o})=>xM("div",{className:"OverwriteConfirm__Actions__Action",children:[Fl("h4",{children:e}),Fl("div",{className:"OverwriteConfirm__Actions__Action__content",children:t}),Fl(Ko,{variant:"outlined",color:"muted",label:r,size:"large",fullWidth:!0,onClick:o})]}),fM=()=>{let{t:e}=St(),t=Wt(),r=Ve();return Fl(wp,{title:e("overwriteConfirm.action.exportToImage.title"),actionLabel:e("overwriteConfirm.action.exportToImage.button"),onClick:()=>{t.executeAction(_m,"ui",!0),r({openDialog:{name:"imageExport"}})},children:e("overwriteConfirm.action.exportToImage.description")})},bM=()=>{let{t:e}=St(),t=Wt();return Fl(wp,{title:e("overwriteConfirm.action.saveToDisk.title"),actionLabel:e("overwriteConfirm.action.saveToDisk.button"),onClick:()=>{t.executeAction(Js,"ui")},children:e("overwriteConfirm.action.saveToDisk.description")})},Af=Object.assign(({children:e})=>Fl("div",{className:"OverwriteConfirm__Actions",children:e}),{ExportToImage:fM,SaveToDisk:bM});import{jsx as xi,jsxs as f3}from"react/jsx-runtime";var vp=Object.assign(Ln("OverwriteConfirmDialog",({children:e})=>{let{OverwriteConfirmDialogTunnel:t}=Qe(),[r,o]=EM(If,Pe);if(!r.active)return null;let n=()=>{r.onClose(),o(a=>({...a,active:!1}))},i=()=>{r.onConfirm(),o(a=>({...a,active:!1}))};return xi(t.In,{children:xi(ut,{onCloseRequest:n,title:!1,size:916,children:f3("div",{className:"OverwriteConfirm",children:[xi("h3",{children:r.title}),f3("div",{className:`OverwriteConfirm__Description OverwriteConfirm__Description--color-${r.color}`,children:[xi("div",{className:"OverwriteConfirm__Description__icon",children:Yy}),xi("div",{children:r.description}),xi("div",{className:"OverwriteConfirm__Description__spacer"}),xi(Ko,{color:r.color,size:"large",label:r.actionLabel,onClick:i})]}),xi(Af,{children:e})]})})})}),{Actions:Af,Action:wp});Sr();h();W();import yM from"clsx";F();import{jsx as Ei,jsxs as b3}from"react/jsx-runtime";import{createElement as wM}from"react";var x3=Ln("DefaultSidebarTrigger",e=>{let{DefaultSidebarTriggerTunnel:t}=Qe();return Ei(t.In,{children:Ei(Mn.Trigger,{...e,className:"default-sidebar-trigger",name:Ao.name})})});x3.displayName="DefaultSidebarTrigger";var E3=({children:e,...t})=>{let{DefaultSidebarTabTriggersTunnel:r}=Qe();return Ei(r.In,{children:Ei(Mn.TabTriggers,{...t,children:e})})};E3.displayName="DefaultTabTriggers";var Tp=Object.assign(Ln("DefaultSidebar",({children:e,className:t,onDock:r,docked:o,...n})=>{let i=Ne(),a=Ve(),{DefaultSidebarTabTriggersTunnel:l}=Qe();return wM(Mn,{...n,name:"default",key:"default",className:yM("default-sidebar",t),docked:o??i.defaultSidebarDockedPreference,onDock:r===!1||!r&&o!=null?void 0:Hn(r,s=>{a({defaultSidebarDockedPreference:s})})},b3(Mn.Tabs,{children:[b3(Mn.Header,{children:[n.__fallback&&Ei("div",{style:{color:"var(--color-primary)",fontSize:"1.2em",fontWeight:"bold",textOverflow:"ellipsis",overflow:"hidden",whiteSpace:"nowrap",paddingRight:"1em"},children:b("toolBar.library")}),Ei(l.Out,{})]}),Ei(Mn.Tab,{tab:jl,children:Ei(yv,{})}),e]}))}),{Trigger:x3,TabTriggers:E3});He();uo();nn();h();import vM from"clsx";import{jsx as y3,jsxs as SM}from"react/jsx-runtime";var TM="small",w3=e=>SM("label",{className:vM("ToolIcon ToolIcon__LaserPointer",`ToolIcon_size_${TM}`,{"is-mobile":e.isMobile}),title:`${e.title}`,children:[y3("input",{className:"ToolIcon_type_checkbox",type:"checkbox",name:e.name,onChange:e.onChange,checked:e.checked,"aria-label":e.title,"data-testid":"toolbar-LaserPointer"}),y3("div",{className:"ToolIcon__icon",children:Em})]});h();import{useState as A3}from"react";h();import{forwardRef as IM,useRef as CM,useImperativeHandle as kM,useLayoutEffect as AM,useState as MM}from"react";import Mf from"clsx";import{jsx as Lf,jsxs as v3}from"react/jsx-runtime";var T3=IM(({onChange:e,label:t,fullWidth:r,placeholder:o,readonly:n,selectOnRender:i,onKeyDown:a,isRedacted:l=!1,...s},c)=>{let d=CM(null);kM(c,()=>d.current),AM(()=>{i&&d.current?.select()},[i]);let[m,p]=MM(!1);return v3("div",{className:Mf("ExcTextField",{"ExcTextField--fullWidth":r}),onClick:()=>{d.current?.focus()},children:[Lf("div",{className:"ExcTextField__label",children:t}),v3("div",{className:Mf("ExcTextField__input",{"ExcTextField__input--readonly":n}),children:[Lf("input",{className:Mf({"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&&Lf(Zo,{onSelect:()=>p(!m),style:{border:0,userSelect:"none"},children:m?qy:ym})]})]})});de();h();import{jsx as LM}from"react/jsx-runtime";var Hl=({icon:e})=>LM("span",{style:{width:"1em",margin:"0 0.5ex 0 0.5ex",display:"inline-block",lineHeight:0,verticalAlign:"middle"},children:e});h();import{jsx as PM}from"react/jsx-runtime";var zl=e=>PM("p",{className:"excalidraw__paragraph",style:e.style,children:e.children});h();import*as I3 from"@radix-ui/react-tabs";import{useRef as S3}from"react";F();import{jsx as _M}from"react/jsx-runtime";var C3=e=>{let t=Ve(),r=S3(null),o=S3(0);return _M(I3.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"&&Ql(["text-to-diagram","diagram-to-code"],n)?t({openDialog:{name:e.dialog,tab:n,source:"settings"}}):e.dialog==="ttd"&&Ql(["text-to-diagram","mermaid"],n)&&t({openDialog:{name:e.dialog,tab:n}})},children:e.children})};C3.displayName="TTDDialogTabs";var Sp=C3;h();import*as k3 from"@radix-ui/react-tabs";import{jsx as DM}from"react/jsx-runtime";var Gl=({tab:e,children:t,...r})=>DM(k3.Content,{...r,value:e,children:t});Gl.displayName="TTDDialogTab";import{jsx as yr,jsxs as cc}from"react/jsx-runtime";var M3=e=>{let[t,r]=A3(e.openAIKey||""),[o,n]=A3(e.isPersisted),i=Ne(),a=()=>{e.onConfirm(t.trim(),o)};return i.openDialog?.name!=="settings"?null:yr(ut,{onCloseRequest:()=>{e.onClose(),e.onConfirm(t.trim(),o)},title:cc("div",{style:{display:"flex"},children:["Wireframe to Code (AI)"," ",yr("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:yr(Sp,{dialog:"settings",tab:i.openDialog.tab,children:cc(Gl,{tab:"diagram-to-code",children:[cc(zl,{children:["For the diagram-to-code feature we use"," ",yr(Hl,{icon:Vs}),"OpenAI."]}),cc(zl,{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"," ",yr("a",{href:"https://platform.openai.com/login?launch",rel:"noopener noreferrer",target:"_blank",children:"OpenAI account"}),", add a small credit (5 USD minimum), and"," ",yr("a",{href:"https://platform.openai.com/api-keys",rel:"noopener noreferrer",target:"_blank",children:"generate your own API key"}),"."]}),yr(zl,{children:"Your OpenAI key does not leave the browser, and you can also set your own limit in your OpenAI account dashboard if needed."}),yr(T3,{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===S.ENTER&&a()}),yr(zl,{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."}),yr(pa,{checked:o,onChange:n,children:"Persist API key in browser storage"}),cc(zl,{children:["Once API key is set, you can use the ",yr(Hl,{icon:bl})," ","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"," ",yr("b",{children:"AI Settings"})," ",yr(Hl,{icon:Vs}),"."]}),yr(Ko,{className:"MagicSettings__confirm",size:"large",label:"Confirm",onClick:a})]})})})};h();h();import{useState as R3,useRef as N3,useEffect as B3,useDeferredValue as zM}from"react";h();W();gr();var RM=({canvasRef:e,setError:t})=>{let r=e.current;if(!r)return;let o=r.parentElement;o&&(o.style.background="",t(null),r.replaceChildren())},Ip=async({canvasRef:e,mermaidToExcalidrawLib:t,mermaidDefinition:r,setError:o,data:n})=>{let i=e.current,a=i?.parentElement;if(!(!i||!a)){if(!r){RM({canvasRef:e,setError:o});return}try{let l=await t.api,s;try{s=await l.parseMermaidToExcalidraw(r,{fontSize:It})}catch{s=await l.parseMermaidToExcalidraw(r.replace(/"/g,"'"),{fontSize:It})}let{elements:c,files:d}=s;o(null),n.current={elements:mc(c,{regenerateIds:!0}),files:d};let m=await ni({elements:n.current.elements,files:n.current.files,exportPadding:ao,maxWidthOrHeight:Math.max(a.offsetWidth,a.offsetHeight)*window.devicePixelRatio});try{await wn(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}}},dc=e=>{br.set(Br.MERMAID_TO_EXCALIDRAW,e)},Cp=({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&&dc(r))};h();import{jsx as NM}from"react/jsx-runtime";var kp=({children:e})=>NM("div",{className:"ttd-dialog-panels",children:e});h();import L3 from"clsx";import{jsx as Pf,jsxs as pc}from"react/jsx-runtime";var Ul=({label:e,children:t,panelAction:r,panelActionDisabled:o=!1,onTextSubmitInProgess:n,renderTopRight:i,renderSubmitShortcut:a,renderBottomRight:l})=>pc("div",{className:"ttd-dialog-panel",children:[pc("div",{className:"ttd-dialog-panel__header",children:[Pf("label",{children:e}),i?.()]}),t,pc("div",{className:L3("ttd-dialog-panel-button-container",{invisible:!r}),style:{display:"flex",alignItems:"center"},children:[pc(Zo,{className:"ttd-dialog-panel-button",onSelect:r?r.action:()=>{},disabled:o||n,children:[pc("div",{className:L3({invisible:n}),children:[r?.label,r?.icon&&Pf("span",{children:r.icon})]}),n&&Pf(Bt,{})]}),!o&&!n&&a?.(),l?.()]})]});h();W();de();import{useEffect as BM,useRef as P3}from"react";import{jsx as OM}from"react/jsx-runtime";var Ap=({input:e,placeholder:t,onChange:r,onKeyboardSubmit:o})=>{let n=P3(null),i=P3(o);return i.current=o,BM(()=>{if(!i.current)return;let a=n.current;if(a){let l=s=>{s[S.CTRL_OR_CMD]&&s.key===S.ENTER&&(s.preventDefault(),i.current?.())};return a.addEventListener("keydown",l),()=>{a.removeEventListener("keydown",l)}}},[]),OM("textarea",{className:"ttd-dialog-input",onChange:r,value:e,placeholder:t,autoFocus:!0,ref:n})};h();import{jsx as Mp,jsxs as _3}from"react/jsx-runtime";var FM=({error:e})=>_3("div",{"data-testid":"ttd-dialog-output-error",className:"ttd-dialog-output-error",children:["Error! ",Mp("p",{children:e})]}),Lp=({error:e,canvasRef:t,loaded:r})=>_3("div",{className:"ttd-dialog-output-wrapper",children:[e&&Mp(FM,{error:e.message}),r?Mp("div",{ref:t,style:{opacity:e?"0.15":1},className:"ttd-dialog-output-canvas-container"}):Mp(Bt,{size:"2rem"})]});W();F();h();F();import{jsx as D3,jsxs as HM}from"react/jsx-runtime";var Pp=()=>HM("div",{className:"ttd-dialog-submit-shortcut",children:[D3("div",{className:"ttd-dialog-submit-shortcut__key",children:_("CtrlOrCmd")}),D3("div",{className:"ttd-dialog-submit-shortcut__key",children:_("Enter")})]});import{Fragment as WM,jsx as jo,jsxs as F3}from"react/jsx-runtime";var GM=`flowchart TD
|
|
61
60
|
A[Christmas] -->|Get money| B(Go shopping)
|
|
62
61
|
B --> C{Let me think}
|
|
63
62
|
C -->|One| D[Laptop]
|
|
64
63
|
C -->|Two| E[iPhone]
|
|
65
|
-
C -->|Three| F[Car]`,
|
|
66
|
-
TTD mermaid definition render errror: ${C.message}`,"color: yellow"),Ee("ai","mermaid parse failed","ttd"),M(new Error("Generated an invalid diagram :(. You may also try a different prompt."))}}catch(A){let D=A.message;(!D||D==="Failed to fetch")&&(D="Request failed"),M(new Error(D))}finally{u(!1)}},E=U1(b);E.current=b;let[w,v]=sp({loaded:!1,api:import("@excalidraw/mermaid-to-excalidraw")});yP(()=>{(async()=>{await w.api,v(D=>({...D,loaded:!0}))})()},[w.api]);let T=U1({elements:[],files:null}),[k,M]=sp(null);return dr(gt,{className:"ttd-dialog",onCloseRequest:()=>{r.setOpenDialog(null)},size:1200,title:!1,...t,autofocus:!1,children:Di(Qu,{dialog:"ttd",tab:e,children:["__fallback"in t&&t.__fallback?dr("p",{className:"dialog-mermaid-title",children:f("mermaid.title")}):Di(G1,{children:[dr(lp,{tab:"text-to-diagram",children:Di("div",{style:{display:"flex",alignItems:"center"},children:[f("labels.textToDiagram"),dr("div",{style:{display:"flex",alignItems:"center",justifyContent:"center",padding:"1px 6px",marginLeft:"10px",fontSize:10,borderRadius:"12px",background:"pink",color:"#000"},children:"AI Beta"})]})}),dr(lp,{tab:"mermaid",children:"Mermaid"})]}),dr(os,{className:"ttd-dialog-content",tab:"mermaid",children:dr(wI,{mermaidToExcalidrawLib:w})}),!("__fallback"in t)&&Di(os,{className:"ttd-dialog-content",tab:"text-to-diagram",children:[dr("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."}),Di(rp,{children:[dr(ns,{label:f("labels.prompt"),panelAction:{action:b,label:"Generate",icon:Ja},onTextSubmitInProgess:m,panelActionDisabled:s.length>is||p?.rateLimitRemaining===0,renderTopRight:()=>p?Di("div",{className:"ttd-dialog-rate-limit",style:{fontSize:12,marginLeft:"auto",color:p.rateLimitRemaining===0?"var(--color-danger)":void 0},children:[p.rateLimitRemaining," requests left today"]}):null,renderSubmitShortcut:()=>dr(ap,{}),renderBottomRight:()=>{if(typeof i?.generatedResponse=="string")return Di("div",{className:"excalidraw-link",style:{marginLeft:"auto",fontSize:14},onClick:()=>{typeof i?.generatedResponse=="string"&&(Dc(i.generatedResponse),o({openDialog:{name:"ttd",tab:"mermaid"}}))},children:["View as Mermaid",dr(ts,{icon:Ja})]});let A=s.length/is;return A>.8?Di("div",{style:{marginLeft:"auto",fontSize:12,fontFamily:"monospace",color:A>1?"var(--color-danger)":void 0},children:["Length: ",s.length,"/",is]}):null},children:dr(op,{onChange:d,input:l,placeholder:"Describe what you want to see...",onKeyboardSubmit:()=>{E.current()}})}),dr(ns,{label:"Preview",panelAction:{action:()=>{console.info("Panel action clicked"),tp({app:r,data:T})},label:"Insert",icon:Ja},children:dr(ip,{canvasRef:n,error:k,loaded:w.loaded})})]})]})]})})})});import Bc from"clsx";import IP from"react";import{Provider as SP,useAtom as CP,useAtomValue as kP}from"jotai";import{Fragment as PI,jsx as re,jsxs as Gr}from"react/jsx-runtime";var AP,MP,LP,_I,_P,DI,RI=y(()=>{"use strict";h();X();ue();Y();Ze();W();ku();g5();S5();Jf();Qf();Ti();_p();e1();B5();z5();zu();V5();Ca();s1();q5();t1();Qr();be();r1();uf();r6();Mc();_t();C1();Xu();W6();o1();Ar();Hr();se();zt();A1();Us();$6();X6();Ve();Io();Er();q6();dI();Y1();AP=({UIOptions:e})=>Gr(cr,{__fallback:!0,children:[re(cr.DefaultItems.LoadScene,{}),re(cr.DefaultItems.SaveToActiveFile,{}),e.canvasActions.export&&re(cr.DefaultItems.Export,{}),e.canvasActions.saveAsImage&&re(cr.DefaultItems.SaveAsImage,{}),re(cr.DefaultItems.Help,{}),re(cr.DefaultItems.ClearCanvas,{}),re(cr.Separator,{}),re(cr.Group,{title:"Excalidraw links",children:re(cr.DefaultItems.Socials,{})}),re(cr.Separator,{}),re(cr.DefaultItems.ToggleTheme,{}),re(cr.DefaultItems.ChangeCanvasBackground,{})]}),MP=()=>Gr(qu,{__fallback:!0,children:[re(qu.Actions.SaveToDisk,{}),re(qu.Actions.ExportToImage,{})]}),LP=({actionManager:e,appState:t,files:r,setAppState:o,elements:n,canvas:i,onLockToggle:a,onHandToolToggle:l,onPenModeToggle:c,showExitZenModeBtn:s,renderTopRightUI:d,renderCustomStats:m,UIOptions:u,onExportImage:p,renderWelcomeScreen:g,children:b,app:E,isCollaborating:w,openAIKey:v,isOpenAIKeyPersisted:T,onOpenAIAPIKeyChange:k,onMagicSettingsConfirm:M})=>{let A=De(),D=ST(),[R,H]=CP(di,Be),C=()=>u.canvasActions.export?re(j5,{elements:n,appState:t,files:r,actionManager:e,exportOpts:u.canvasActions.export,canvas:i,setAppState:o}):null,O=()=>!u.canvasActions.saveAsImage||t.openDialog?.name!=="imageExport"?null:re(I5,{elements:n,appState:t,files:r,actionManager:e,onExportImage:p,onCloseRequest:()=>o({openDialog:null})}),P=()=>Gr("div",{style:{position:"relative"},children:[re(D.MainMenuTunnel.Out,{}),g&&re(D.WelcomeScreenMenuHintTunnel.Out,{})]}),G=()=>re(Ai,{heading:"selectedShapeActions",className:Bc("selected-shape-actions zen-mode-transition",{"transition-left":t.zenModeEnabled}),children:re(Ut,{className:Qc.SHAPE_ACTIONS_MENU,padding:2,style:{maxHeight:`${t.height-166}px`},children:re(Su,{appState:t,elements:n,renderAction:e.renderAction})})}),j=()=>{let q=ya(t,n);return re(Ou,{side:"top",children:Gr("div",{className:"App-menu App-menu_top",children:[Gr(Bt.Col,{gap:6,className:Bc("App-menu_top__left"),children:[P(),q&&G()]}),!t.viewModeEnabled&&re(Ai,{heading:"shapes",className:"shapes-section",children:Ge=>Gr("div",{style:{position:"relative"},children:[g&&re(D.WelcomeScreenToolbarHintTunnel.Out,{}),re(Bt.Col,{gap:4,align:"start",children:Gr(Bt.Row,{gap:1,className:Bc("App-toolbar-container",{"zen-mode":t.zenModeEnabled}),children:[Gr(Ut,{padding:1,className:Bc("App-toolbar",{"zen-mode":t.zenModeEnabled}),children:[re(Fu,{appState:t,isMobile:A.editor.isMobile,device:A,app:E}),Ge,Gr(Bt.Row,{gap:1,children:[re(Gu,{zenModeEnabled:t.zenModeEnabled,checked:t.penMode,onChange:()=>c(null),title:f("toolBar.penMode"),penDetected:t.penDetected}),re(Hu,{checked:t.activeTool.locked,onChange:a,title:f("toolBar.lock")}),re("div",{className:"App-toolbar__divider"}),re(Wu,{checked:Eo(t),onChange:()=>l(),title:f("toolBar.hand"),isMobile:!0}),re(Cu,{appState:t,activeTool:t.activeTool,UIOptions:u,app:E})]})]}),w&&re(Ut,{style:{marginLeft:8,alignSelf:"center",height:"fit-content"},children:re(j6,{title:f("toolBar.laser"),checked:t.activeTool.type===ft.laser,onChange:()=>E.setActiveTool({type:ft.laser}),isMobile:!0})})]})})]})}),Gr("div",{className:Bc("layer-ui__wrapper__top-right zen-mode-transition",{"transition-right":t.zenModeEnabled}),children:[t.collaborators.size>0&&re(Vu,{collaborators:t.collaborators,userToFollow:t.userToFollow?.socketId||null}),d?.(A.editor.isMobile,t),!t.viewModeEnabled&&(!pe||t.openSidebar?.name!==Bo.name)&&re(D.DefaultSidebarTriggerTunnel.Out,{})]})]})})},V=()=>re(Ju,{__fallback:!0,onDock:q=>{Ee("sidebar",`toggleDock (${q?"dock":"undock"})`,`(${A.editor.isMobile?"mobile":"desktop"})`)}}),pe=kP(Ac,Be),Se=Gr(PI,{children:[b,re(AP,{UIOptions:u}),re(Ju.Trigger,{__fallback:!0,icon:cE,title:Ba(f("toolBar.library")),onToggle:q=>{q&&Ee("sidebar",`${Bo.name} (open)`,`button (${A.editor.isMobile?"mobile":"desktop"})`)},tab:Bo.defaultTab,children:f("toolBar.library")}),re(MP,{}),t.openDialog?.name==="ttd"&&re(V1,{__fallback:!0}),t.isLoading&&re(cd,{delay:250}),t.errorMessage&&re(p5,{onClose:()=>o({errorMessage:null}),children:t.errorMessage}),R&&!A.editor.isMobile&&re(Cw,{colorPickerType:R.colorPickerType,onCancel:()=>{H(null)},onChange:(q,Ge,Ae,{altKey:It})=>{if(!(q!=="elementBackground"&&q!=="elementStroke"))if(Ae.length){for(let Ke of Ae)B(Ke,{[It&&R.swapPreviewOnAlt?q==="elementBackground"?"strokeColor":"backgroundColor":q==="elementBackground"?"backgroundColor":"strokeColor"]:Ge},!1),Te.delete(Ke);xe.getScene(Ae[0])?.informMutation()}else o(q==="elementBackground"?{currentItemBackgroundColor:Ge}:{currentItemStrokeColor:Ge})},onSelect:(q,Ge)=>{H(Ae=>Ae?.keepOpenOnAlt&&Ge.altKey?Ae:null),R?.onSelect?.(q,Ge)}}),t.openDialog?.name==="help"&&re(U5,{onClose:()=>{o({openDialog:null})}}),t.openDialog?.name==="settings"&&re(cI,{openAIKey:v,isPersisted:T,onChange:k,onConfirm:(q,Ge)=>{let Ae=t.openDialog?.name==="settings"?t.openDialog?.source:"settings";o({openDialog:null},()=>{M(q,Ge,Ae)})},onClose:()=>{o({openDialog:null})}}),re(C6,{}),re(D.OverwriteConfirmDialogTunnel.Out,{}),O(),C(),t.pasteDialog.shown&&re(H5,{setAppState:o,appState:t,onClose:()=>o({pasteDialog:{shown:!1,data:null}})}),A.editor.isMobile&&re(N5,{app:E,appState:t,elements:n,actionManager:e,renderJSONExportDialog:C,renderImageExportDialog:O,setAppState:o,onLockToggle:a,onHandToolToggle:l,onPenModeToggle:c,renderTopRightUI:d,renderCustomStats:m,renderSidebars:V,device:A,renderWelcomeScreen:g,UIOptions:u}),!A.editor.isMobile&&Gr(PI,{children:[Gr("div",{className:"layer-ui__wrapper",style:t.openSidebar&&pe&&A.editor.canFitSidebar?{width:`calc(100% - ${Qb}px)`}:{},children:[g&&re(D.WelcomeScreenCenterTunnel.Out,{}),j(),re(t6,{appState:t,actionManager:e,showExitZenModeBtn:s,renderWelcomeScreen:g}),t.showStats&&re(Uu,{appState:t,setAppState:o,elements:n,onClose:()=>{e.executeAction(vi)},renderCustomStats:m}),t.scrolledOutside&&re("button",{className:"scroll-back-to-content",onClick:()=>{o(q=>({...Ko(n,q)}))},children:f("buttons.scrollBackToContent")})]}),V()]})]});return re(Dg.Provider,{value:t,children:re(SP,{scope:D.jotaiScope,children:re(Of.Provider,{value:D,children:Se})})})},_I=e=>{let{suggestedBindings:t,startBoundElement:r,cursorButton:o,scrollX:n,scrollY:i,...a}=e;return a},_P=(e,t)=>{if(e.children!==t.children)return!1;let{canvas:r,appState:o,...n}=e,{canvas:i,appState:a,...l}=t;return bt(_I(o),_I(a),{selectedElementIds:bt,selectedGroupIds:bt})&&bt(n,l)},DI=IP.memo(LP,_P)});var NI=y(()=>{});import{useCallback as PP,useEffect as DP,useRef as RP}from"react";import{jsx as BI,jsxs as BP}from"react/jsx-runtime";var NP,OI,FI=y(()=>{"use strict";h();se();NI();Lt();NP=5e3,OI=({message:e,onClose:t,closable:r=!1,duration:o=NP})=>{let n=RP(0),i=o!==1/0,a=PP(()=>{i&&(n.current=window.setTimeout(()=>t(),o))},[t,o,i]);return DP(()=>{if(i)return a(),()=>clearTimeout(n.current)},[a,e,o,i]),BP("div",{className:"Toast",onMouseEnter:i?()=>clearTimeout(n?.current):void 0,onMouseLeave:i?a:void 0,children:[BI("p",{className:"Toast__message",children:e}),r&&BI(ne,{icon:Jr,"aria-label":"close",type:"icon",onClick:t,className:"close"})]})}});var K1,HI=y(()=>{"use strict";h();me();We();K1=N({name:"viewMode",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,r)=>typeof r.viewModeEnabled>"u",contextItemLabel:"labels.viewMode",keyTest:e=>!e[S.CTRL_OR_CMD]&&e.altKey&&e.code===de.R})});var cp,zI=y(()=>{"use strict";h();ue();Ve();ae();W();Io();cp=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=>z(o)&&!ke(o)?(Te.delete(o),r=!0,Q(o,{...Ya(o)})):o),r&&this.onSceneUpdated()};loadFontsForElements=async t=>{let r=await Promise.all([...new Set(t.filter(o=>z(o)).map(o=>o.fontFamily))].map(o=>{let n=_e({fontFamily:o,fontSize:16});if(!document.fonts?.check?.(n))return document.fonts?.load?.(n)}));this.onFontsLoaded(r.flat().filter(Boolean))}}});var GI,UI,WI,H1e,z1e,VI=y(()=>{"use strict";h();ue();br();br();me();W();Va();We();ae();GI=(e,t)=>{let r=t.scene.getSelectedElements(e);return r.length===1&&J(r[0])},UI=N({name:"selectAllElementsInFrame",trackEvent:{category:"canvas"},perform:(e,t,r,o)=>{let n=o.scene.getSelectedElements(t).at(0)||null;if(J(n)){let i=Fr(ce(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}},contextItemLabel:"labels.selectAllElementsInFrame",predicate:(e,t,r,o)=>GI(t,o)}),WI=N({name:"removeAllElementsFromFrame",trackEvent:{category:"history"},perform:(e,t,r,o)=>{let n=o.scene.getSelectedElements(t).at(0)||null;return J(n)?{elements:Ah(e,n,t),appState:{...t,selectedElementIds:{[n.id]:!0}},commitToHistory:!0}:{elements:e,appState:t,commitToHistory:!1}},contextItemLabel:"labels.removeAllElementsFromFrame",predicate:(e,t,r,o)=>GI(t,o)}),H1e=N({name:"updateFrameRendering",viewMode:!0,trackEvent:{category:"canvas"},perform:(e,t)=>({elements:e,appState:{...t,frameRendering:{...t.frameRendering,enabled:!t.frameRendering.enabled}},commitToHistory:!1}),contextItemLabel:"labels.updateFrameRendering",checked:e=>e.frameRendering.enabled}),z1e=N({name:"setFrameAsActiveTool",trackEvent:{category:"toolbar"},perform:(e,t,r,o)=>{let n=Xe(t,{type:"frame"});return Lr(o.interactiveCanvas,{...t,activeTool:n}),{elements:e,appState:{...t,activeTool:Xe(t,{type:"frame"})},commitToHistory:!1}},keyTest:e=>!e[S.CTRL_OR_CMD]&&!e.shiftKey&&!e.altKey&&e.key.toLocaleLowerCase()===S.F})});var OP,YI,dp,uo,Fn,FP,Oc,XI,ZI,KI,jI,as,qI,dt,$I,$1,HP,zP,JI,QI,eS,tS,rS=y(()=>{"use strict";h();X();yt();ae();gr();me();Zt();ti();OP=8,YI=99999,dp=e=>OP/e,uo=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}},Fn=({event:e,appState:t,selectedElements:r})=>e?t.objectsSnapModeEnabled&&!e[S.CTRL_OR_CMD]||!t.objectsSnapModeEnabled&&e[S.CTRL_OR_CMD]&&t.gridSize===null:r.length===1&&r[0].type==="arrow"?!1:t.objectsSnapModeEnabled,FP=(e,t,r=.01)=>Math.abs(e-t)<=r,Oc=(e,{omitCenter:t,boundingBoxCorners:r,dragOffset:o}={omitCenter:!1,boundingBoxCorners:!1})=>{let n=[];if(e.length===1){let i=e[0],[a,l,c,s,d,m]=ee(i);o&&(a+=o.x,c+=o.x,d+=o.x,l+=o.y,s+=o.y,m+=o.y);let u=(c-a)/2,p=(s-l)/2;if((i.type==="diamond"||i.type==="ellipse")&&!r){let g=Fe([a,l+p],[d,m],i.angle),b=Fe([a+u,l],[d,m],i.angle),E=Fe([c,l+p],[d,m],i.angle),w=Fe([a+u,s],[d,m],i.angle);n=t?[g,b,E,w]:[g,b,E,w,[d,m]]}else{let g=Fe([a,l],[d,m],i.angle),b=Fe([c,l],[d,m],i.angle),E=Fe([a,s],[d,m],i.angle),w=Fe([c,s],[d,m],i.angle);n=t?[g,b,E,w]:[g,b,E,w,[d,m]]}}else if(e.length>1){let[i,a,l,c]=Nm(e,o??{x:0,y:0}),s=l-i,d=c-a,m=[i,a],u=[l,a],p=[i,c],g=[l,c],b=[i+s/2,a+d/2];n=t?[m,u,p,g]:[m,u,p,g,b]}return n.map(i=>[dt(i[0]),dt(i[1])])},XI=(e,t,r)=>{let o=t.filter(n=>J(n)).map(n=>n.id);return Lh(e,t,r).filter(n=>!(n.frameId&&o.includes(n.frameId)))},ZI=(e,t,r)=>{let o=XI(e,t,r),n=ea(o).filter(d=>!(d.length===1&&ke(d[0]))).map(d=>we(d).map(m=>dt(m))),i=n.sort((d,m)=>d[0]-m[0]),a=[],l=0;e:for(let d=0;d<i.length;d++){let m=i[d];for(let u=d+1;u<i.length;u++){if(++l>YI)break e;let p=i[u],[,g,b,E]=m,[w,v,,T]=p;b<w&&rc([g,E],[v,T])&&a.push({startBounds:m,endBounds:p,startSide:[[b,g],[b,E]],endSide:[[w,v],[w,T]],length:w-b,overlap:oc([g,E],[v,T])})}}let c=n.sort((d,m)=>d[1]-m[1]),s=[];l=0;e:for(let d=0;d<c.length;d++){let m=c[d];for(let u=d+1;u<c.length;u++){if(++l>YI)break e;let p=c[u],[g,,b,E]=m,[w,v,T]=p;E<v&&rc([g,b],[w,T])&&s.push({startBounds:m,endBounds:p,startSide:[[g,E],[b,E]],endSide:[[w,v],[T,v]],length:v-E,overlap:oc([g,b],[w,T])})}}return{horizontalGaps:a,verticalGaps:s}},KI=(e,t,r,o,n,i,a)=>{if(!Fn({appState:r,event:o,selectedElements:e}))return[];if(e.length===0)return[];let l=uo.getVisibleGaps();if(l){let{horizontalGaps:c,verticalGaps:s}=l,[d,m,u,p]=Nm(e,t).map(E=>dt(E)),g=(d+u)/2,b=(m+p)/2;for(let E of c){if(!rc([m,p],E.overlap))continue;let w=E.startSide[0][0]+E.length/2,v=dt(w-g);if(E.length>u-d&&Math.abs(v)<=a.x){Math.abs(v)<a.x&&(n.length=0),a.x=Math.abs(v);let C={type:"gap",direction:"center_horizontal",gap:E,offset:v};n.push(C);continue}let[,,k]=E.endBounds,M=d-k,A=dt(E.length-M);if(Math.abs(A)<=a.x){Math.abs(A)<a.x&&(n.length=0),a.x=Math.abs(A);let C={type:"gap",direction:"side_right",gap:E,offset:A};n.push(C);continue}let[D,,,]=E.startBounds,R=D-u,H=dt(R-E.length);if(Math.abs(H)<=a.x){Math.abs(H)<a.x&&(n.length=0),a.x=Math.abs(H);let C={type:"gap",direction:"side_left",gap:E,offset:H};n.push(C);continue}}for(let E of s){if(!rc([d,u],E.overlap))continue;let w=E.startSide[0][1]+E.length/2,v=dt(w-b);if(E.length>p-m&&Math.abs(v)<=a.y){Math.abs(v)<a.y&&(i.length=0),a.y=Math.abs(v);let C={type:"gap",direction:"center_vertical",gap:E,offset:v};i.push(C);continue}let[,k,,]=E.startBounds,M=k-p,A=dt(M-E.length);if(Math.abs(A)<=a.y){Math.abs(A)<a.y&&(i.length=0),a.y=Math.abs(A);let C={type:"gap",direction:"side_top",gap:E,offset:A};i.push(C);continue}let[,,,D]=E.endBounds,R=dt(m-D),H=E.length-R;if(Math.abs(H)<=a.y){Math.abs(H)<a.y&&(i.length=0),a.y=Math.abs(H);let C={type:"gap",direction:"side_bottom",gap:E,offset:H};i.push(C);continue}}}},jI=(e,t,r)=>{let o=XI(e,t,r);return ea(o).filter(n=>!(n.length===1&&ke(n[0]))).flatMap(n=>Oc(n))},as=(e,t,r,o,n,i,a)=>{if(!Fn({appState:r,event:o,selectedElements:e})||e.length===0&&t.length===0)return[];let l=uo.getReferenceSnapPoints();if(l)for(let c of t)for(let s of l){let d=s[0]-c[0],m=s[1]-c[1];Math.abs(d)<=a.x&&(Math.abs(d)<a.x&&(n.length=0),n.push({type:"point",points:[c,s],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:[c,s],offset:m}),a.y=Math.abs(m))}},qI=(e,t,r,o)=>{if(!Fn({appState:r,event:o,selectedElements:e})||e.length===0)return{snapOffset:{x:0,y:0},snapLines:[]};t.x=dt(t.x),t.y=dt(t.y);let n=[],i=[],a=dp(r.zoom.value),l={x:a,y:a},c=Oc(e,{dragOffset:t});as(e,c,r,o,n,i,l),KI(e,t,r,o,n,i,l);let s={x:n[0]?.offset??0,y:i[0]?.offset??0};l.x=0,l.y=0,n.length=0,i.length=0;let d={x:dt(t.x+s.x),y:dt(t.y+s.y)};as(e,Oc(e,{dragOffset:d}),r,o,n,i,l),KI(e,d,r,o,n,i,l);let m=$1(n,i),u=zP(e,d,[...n,...i].filter(p=>p.type==="gap"));return{snapOffset:s,snapLines:[...m,...u]}},dt=e=>Math.round(e*10**6)/10**6,$I=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())},$1=(e,t)=>{let r={},o={};if(e.length>0){for(let n of e)if(n.type==="point"){let i=dt(n.points[0][0]);r[i]||(r[i]=[]),r[i].push(...n.points.map(a=>[dt(a[0]),dt(a[1])]))}}if(t.length>0){for(let n of t)if(n.type==="point"){let i=dt(n.points[0][1]);o[i]||(o[i]=[]),o[i].push(...n.points.map(a=>[dt(a[0]),dt(a[1])]))}}return Object.entries(r).map(([n,i])=>({type:"points",points:$I(i.map(a=>[Number(n),a[1]]).sort((a,l)=>a[1]-l[1]))})).concat(Object.entries(o).map(([n,i])=>({type:"points",points:$I(i.map(a=>[a[0],Number(n)]).sort((a,l)=>a[0]-l[0]))})))},HP=e=>{let t=new Map;for(let r of e){let o=r.points.flat().map(n=>[dt(n)]).join(",");t.has(o)||t.set(o,r)}return Array.from(t.values())},zP=(e,t,r)=>{let[o,n,i,a]=Nm(e,t),l=[];for(let c of r){let[s,d,m,u]=c.gap.startBounds,[p,g,b,E]=c.gap.endBounds,w=oc([n,a],c.gap.overlap),v=oc([o,i],c.gap.overlap);switch(c.direction){case"center_horizontal":{if(w){let T=(w[0]+w[1])/2;l.push({type:"gap",direction:"horizontal",points:[[c.gap.startSide[0][0],T],[o,T]]},{type:"gap",direction:"horizontal",points:[[i,T],[c.gap.endSide[0][0],T]]})}break}case"center_vertical":{if(v){let T=(v[0]+v[1])/2;l.push({type:"gap",direction:"vertical",points:[[T,c.gap.startSide[0][1]],[T,n]]},{type:"gap",direction:"vertical",points:[[T,a],[T,c.gap.endSide[0][1]]]})}break}case"side_right":{if(w){let T=(w[0]+w[1])/2;l.push({type:"gap",direction:"horizontal",points:[[m,T],[p,T]]},{type:"gap",direction:"horizontal",points:[[b,T],[o,T]]})}break}case"side_left":{if(w){let T=(w[0]+w[1])/2;l.push({type:"gap",direction:"horizontal",points:[[i,T],[s,T]]},{type:"gap",direction:"horizontal",points:[[m,T],[p,T]]})}break}case"side_top":{if(v){let T=(v[0]+v[1])/2;l.push({type:"gap",direction:"vertical",points:[[T,a],[T,d]]},{type:"gap",direction:"vertical",points:[[T,u],[T,g]]})}break}case"side_bottom":{if(v){let T=(v[0]+v[1])/2;l.push({type:"gap",direction:"vertical",points:[[T,u],[T,g]]},{type:"gap",direction:"vertical",points:[[T,E],[T,n]]})}break}}}return HP(l.map(c=>({...c,points:c.points.map(s=>[dt(s[0]),dt(s[1])])})))},JI=(e,t,r,o,n,i)=>{if(!Fn({event:o,selectedElements:e,appState:r})||e.length===0||e.length===1&&!FP(e[0].angle,0))return{snapOffset:{x:0,y:0},snapLines:[]};let[a,l,c,s]=we(t);i&&(i.includes("e")?c+=n.x:i.includes("w")&&(a+=n.x),i.includes("n")?l+=n.y:i.includes("s")&&(s+=n.y));let d=[];if(i)switch(i){case"e":{d.push([c,l],[c,s]);break}case"w":{d.push([a,l],[a,s]);break}case"n":{d.push([a,l],[c,l]);break}case"s":{d.push([a,s],[c,s]);break}case"ne":{d.push([c,l]);break}case"nw":{d.push([a,l]);break}case"se":{d.push([c,s]);break}case"sw":{d.push([a,s]);break}}let m=dp(r.zoom.value),u={x:m,y:m},p=[],g=[];as(t,d,r,o,p,g,u);let b={x:p[0]?.offset??0,y:g[0]?.offset??0};u.x=0,u.y=0,p.length=0,g.length=0;let[E,w,v,T]=we(e).map(A=>dt(A));as(e,[[E,w],[E,T],[v,w],[v,T]],r,o,p,g,u);let M=$1(p,g);return{snapOffset:b,snapLines:M}},QI=(e,t,r,o,n)=>{if(!Fn({event:r,selectedElements:[e],appState:t}))return{snapOffset:{x:0,y:0},snapLines:[]};let i=[[o.x+n.x,o.y+n.y]],a=dp(t.zoom.value),l={x:a,y:a},c=[],s=[];as([e],i,t,r,c,s,l);let d={x:c[0]?.offset??0,y:s[0]?.offset??0};l.x=0,l.y=0,c.length=0,s.length=0;let m=Oc([e],{boundingBoxCorners:!0,omitCenter:!0});as([e],m,t,r,c,s,l);let u=$1(c,s);return{snapOffset:d,snapLines:u}},eS=(e,t,r,o)=>{if(!Fn({event:o,selectedElements:[],appState:t}))return{originOffset:{x:0,y:0},snapLines:[]};let n=Lh(e,[],t),i=dp(t.zoom.value),a={x:i,y:i},l=[],c=[];for(let s of n){let d=Oc([s]);for(let m of d){let u=m[0]-r.x;Math.abs(u)<=Math.abs(a.x)&&(Math.abs(u)<Math.abs(a.x)&&(c.length=0),c.push({type:"pointer",points:[m,[m[0],r.y]],direction:"vertical"}),a.x=u);let p=m[1]-r.y;Math.abs(p)<=Math.abs(a.y)&&(Math.abs(p)<Math.abs(a.y)&&(l.length=0),l.push({type:"pointer",points:[m,[r.x,m[1]]],direction:"horizontal"}),a.y=p)}}return{originOffset:{x:c.length>0?c[0].points[0][0]-r.x:0,y:l.length>0?l[0].points[0][1]-r.y:0},snapLines:[...c,...l]}},tS=e=>e===ft.rectangle||e===ft.ellipse||e===ft.diamond||e===ft.frame||e===ft.magicframe||e===ft.image});import{jsx as po,jsxs as oS}from"react/jsx-runtime";var GP,nS,iS=y(()=>{"use strict";h();Kl();GP=()=>oS("div",{"data-testid":"brave-measure-text-error",children:[po("p",{children:po(sr,{i18nKey:"errors.brave_measure_text_error.line1",bold:e=>po("span",{style:{fontWeight:600},children:e})})}),po("p",{children:po(sr,{i18nKey:"errors.brave_measure_text_error.line2",bold:e=>po("span",{style:{fontWeight:600},children:e})})}),po("p",{children:po(sr,{i18nKey:"errors.brave_measure_text_error.line3",link:e=>po("a",{href:"http://docs.excalidraw.com/docs/@excalidraw/excalidraw/faq#turning-off-aggresive-block-fingerprinting-in-brave-browser",children:e})})}),po("p",{children:po(sr,{i18nKey:"errors.brave_measure_text_error.line4",issueLink:e=>po("a",{href:"https://github.com/excalidraw/excalidraw/issues/new",children:e}),discordLink:e=>oS("a",{href:"https://discord.gg/UexuTaE",children:[e,"."]})})})]}),nS=GP});var mp,Ri,UP,aS,X1,Rc,Z1=y(()=>{"use strict";h();X();ue();ko();dn();pt();W();ec();yo();mp={width:100,height:0},Ri=100,UP=(e,t)=>{let r=Rt({x:0,y:0,textAlign:$n.CENTER,verticalAlign:ht.MIDDLE,...t,containerId:e.id,strokeColor:t.strokeColor||e.strokeColor});return Object.assign(e,{boundElements:(e.boundElements||[]).concat({type:"text",id:r.id})}),Gt(r,e),[e,r]},aS=(e,t,r,o)=>{let n,i;if(Object.assign(e,{startBinding:e?.startBinding||null,endBinding:e.endBinding||null}),t){let s=t?.width??Ri,d=t?.height??Ri,m;t.id&&(m=o.getElement(t.id),m||console.error(`No element for start binding with id ${t.id} found`));let u=t.x||e.x-s,p=t.y||e.y-d/2,g=m?m.type:t.type;if(g){if(g==="text"){let b="";m&&m.type==="text"?b=m.text:t.type==="text"&&(b=t.text),b||console.error(`No text found for start binding text element for ${e.id}`),n=Rt({x:u,y:p,type:"text",...m,...t,text:b}),Object.assign(n,{x:t.x||e.x-n.width,y:t.y||e.y-n.height/2})}else switch(g){case"rectangle":case"ellipse":case"diamond":{n=Pr({x:u,y:p,width:s,height:d,...m,...t,type:g});break}default:Zn(e,`Unhandled element start type "${t.type}"`,!0)}gl(e,n,"start")}}if(r){let s=r?.height??Ri,d=r?.width??Ri,m;r.id&&(m=o.getElement(r.id),m||console.error(`No element for end binding with id ${r.id} found`));let u=r.x||e.x+e.width,p=r.y||e.y-s/2,g=m?m.type:r.type;if(g){if(g==="text"){let b="";m&&m.type==="text"?b=m.text:r.type==="text"&&(b=r.text),b||console.error(`No text found for end binding text element for ${e.id}`),i=Rt({x:u,y:p,type:"text",...m,...r,text:b}),Object.assign(i,{y:r.y||e.y-i.height/2})}else switch(g){case"rectangle":case"ellipse":case"diamond":{i=Pr({x:u,y:p,width:d,height:s,...m,...r,type:g});break}default:Zn(e,`Unhandled element end type "${g}"`,!0)}gl(e,i,"end")}}let a=e.points.length-1,l=.5,c=Vr(e.points);return e.points[a][0]>e.points[a-1][0]&&(c[0][0]=l,c[a][0]-=l),e.points[a][0]<e.points[a-1][0]&&(c[0][0]=-l,c[a][0]+=l),e.points[a][1]>e.points[a-1][1]&&(c[0][1]=l,c[a][1]-=l),e.points[a][1]<e.points[a-1][1]&&(c[0][1]=-l,c[a][1]+=l),Object.assign(e,{points:c}),{linearElement:e,startBoundElement:n,endBoundElement:i}},X1=class{excalidrawElements=new Map;add=t=>{t&&this.excalidrawElements.set(t.id,t)};getElements=()=>Array.from(this.excalidrawElements.values());getElement=t=>this.excalidrawElements.get(t)},Rc=(e,t)=>{if(!e)return[];let r=Vr(e),o=new X1,n=new Map,i=new Map;for(let a of r){let l,c=a.id;switch(t?.regenerateIds!==!1&&Object.assign(a,{id:Mt()}),a.type){case"rectangle":case"ellipse":case"diamond":{let d=a?.label?.text&&a.width===void 0?0:a?.width||Ri,m=a?.label?.text&&a.height===void 0?0:a?.height||Ri;l=Pr({...a,width:d,height:m});break}case"line":{let d=a.width||mp.width,m=a.height||mp.height;l=qr({width:d,height:m,points:[[0,0],[d,m]],...a});break}case"arrow":{let d=a.width||mp.width,m=a.height||mp.height;l=qr({width:d,height:m,endArrowhead:"arrow",points:[[0,0],[d,m]],...a}),Object.assign(l,Rm(l.points));break}case"text":{let d=a?.fontFamily||Ft,m=a?.fontSize||Ct,u=a?.lineHeight||Dr(d),p=a.text??"",g=ri(p),b=_r(g,_e({fontFamily:d,fontSize:m}),u);l=Rt({width:b.width,height:b.height,fontFamily:d,fontSize:m,...a});break}case"image":{l=ws({width:a?.width||Ri,height:a?.height||Ri,...a});break}case"frame":{l=kd({x:0,y:0,...a});break}case"magicframe":{l=ys({x:0,y:0,...a});break}case"freedraw":case"iframe":case"embeddable":{l=a;break}default:l=a,Zn(a,`Unhandled element type "${a.type}"`,!0)}o.getElement(l.id)?console.error(`Duplicate id found for ${l.id}`):(o.add(l),n.set(l.id,a),c&&i.set(c,l.id))}for(let[a,l]of n){let c=o.getElement(a);switch(l.type){case"rectangle":case"ellipse":case"diamond":case"arrow":{if(l.label?.text){let[s,d]=UP(c,l?.label);if(o.add(s),o.add(d),s.type==="arrow"){let m=l.type==="arrow"?l?.start:void 0,u=l.type==="arrow"?l?.end:void 0;if(m&&m.id){let E=i.get(m.id);E&&Object.assign(m,{id:E})}if(u&&u.id){let E=i.get(u.id);E&&Object.assign(u,{id:E})}let{linearElement:p,startBoundElement:g,endBoundElement:b}=aS(s,m,u,o);s=p,o.add(p),o.add(g),o.add(b)}}else switch(l.type){case"arrow":{let{start:s,end:d}=l;if(s&&s.id){let g=i.get(s.id);Object.assign(s,{id:g})}if(d&&d.id){let g=i.get(d.id);Object.assign(d,{id:g})}let{linearElement:m,startBoundElement:u,endBoundElement:p}=aS(c,s,d,o);o.add(m),o.add(u),o.add(p);break}}break}}}for(let[a,l]of n){if(l.type!=="frame"&&l.type!=="magicframe")continue;let c=o.getElement(a);if(!c)throw new Error(`Excalidraw element with id ${a} doesn't exist`);let s=[];l.children.forEach(w=>{let v=i.get(w);if(!v)throw new Error(`Element with ${w} wasn't mapped correctly`);let T=o.getElement(v);if(!T)throw new Error(`Frame element with id ${v} doesn't exist`);Object.assign(T,{frameId:c.id}),T?.boundElements?.forEach(k=>{let M=o.getElement(k.id);if(!M)throw new Error(`Bound element with id ${k.id} doesn't exist`);Object.assign(M,{frameId:c.id}),s.push(M)}),s.push(T)});let[d,m,u,p]=we(s),g=10;d=d-g,m=m-g,u=u+g,p=p+g;let b=Math.max(c?.width,u-d),E=Math.max(c?.height,p-m);Object.assign(c,{x:d,y:m,width:b,height:E})}return o.getElements()}});import WP,{useEffect as VP,useRef as YP}from"react";import{jsx as XP}from"react/jsx-runtime";var KP,lS,$P,j1,sS=y(()=>{"use strict";h();sl();W();X();Y();KP=e=>{let t=YP(!1);return VP(()=>{if(!t.current){t.current=!0;return}let r={},o={},n={},i={},a={};e.appState.collaborators.forEach((c,s)=>{if(c.selectedElementIds)for(let d of Object.keys(c.selectedElementIds))d in n||(n[d]=[]),n[d].push(s);c.pointer&&(c.username&&(i[s]=c.username),c.userState&&(a[s]=c.userState),o[s]=Dt({sceneX:c.pointer.x,sceneY:c.pointer.y},e.appState),r[s]=c.button)});let l=e.containerRef?.current&&getComputedStyle(e.containerRef.current).getPropertyValue("--color-selection")||"#6965db";Iy({canvas:e.canvas,elements:e.elements,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},callback:e.renderInteractiveSceneCallback},fd())}),XP("canvas",{className:"excalidraw__canvas interactive",style:{width:e.appState.width,height:e.appState.height,cursor:e.appState.viewModeEnabled?Me.GRAB:Me.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:f("labels.drawingCanvas")})},lS=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}),$P=(e,t)=>e.selectionNonce!==t.selectionNonce||e.versionNonce!==t.versionNonce||e.scale!==t.scale||e.elements!==t.elements||e.visibleElements!==t.visibleElements||e.selectedElements!==t.selectedElements?!1:bt(lS(e.appState),lS(t.appState)),j1=WP.memo(KP,$P)});import ZP,{useEffect as jP,useRef as cS}from"react";import{jsx as QP}from"react/jsx-runtime";var qP,dS,JP,q1,mS=y(()=>{"use strict";h();sl();W();qP=e=>{let t=cS(null),r=cS(!1);return jP(()=>{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,c=e.appState.height*e.scale;n.width!==l&&(n.width=l),n.height!==c&&(n.height=c),Jd({canvas:n,rc:e.rc,scale:e.scale,elements:e.elements,visibleElements:e.visibleElements,appState:e.appState,renderConfig:e.renderConfig},fd())}),QP("div",{className:"excalidraw__canvas-wrapper",ref:t})},dS=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,viewBackgroundColor:e.viewBackgroundColor,exportScale:e.exportScale,selectedElementsAreBeingDragged:e.selectedElementsAreBeingDragged,gridSize:e.gridSize,frameRendering:e.frameRendering,selectedElementIds:e.selectedElementIds,frameToHighlight:e.frameToHighlight,editingGroupId:e.editingGroupId}),JP=(e,t)=>e.versionNonce!==t.versionNonce||e.scale!==t.scale||e.elements!==t.elements||e.visibleElements!==t.visibleElements?!1:bt(dS(e.appState),dS(t.appState))&&bt(e.renderConfig,t.renderConfig),q1=ZP.memo(qP,JP)});var uS=y(()=>{"use strict";h();sS();mS()});var Fc,pS=y(()=>{"use strict";h();Ea();ae();sl();W();Fc=class{scene;constructor(t){this.scene=t}getRenderableElements=(()=>{let t=({elements:o,zoom:n,offsetLeft:i,offsetTop:a,scrollX:l,scrollY:c,height:s,width:d})=>o.filter(m=>xa(m,d,s,{zoom:n,offsetLeft:i,offsetTop:a,scrollX:l,scrollY:c})),r=({editingElement:o,elements:n,pendingImageElementId:i})=>n.filter(a=>Yr(a)&&i===a.id?!1:!o||o.type!=="text"||a.id!==o.id);return wx(({zoom:o,offsetLeft:n,offsetTop:i,scrollX:a,scrollY:l,height:c,width:s,editingElement:d,pendingImageElementId:m,versionNonce:u})=>{let p=this.scene.getNonDeletedElements(),g=r({elements:p,editingElement:d,pendingImageElementId:m}),b=t({elements:g,zoom:o,offsetLeft:n,offsetTop:i,scrollX:a,scrollY:l,height:c,width:s});return{canvasElements:g,visibleElements:b}})})();destroy(){Cy(),this.getRenderableElements.clear()}}});var gS=y(()=>{});import{useEffect as eD,useRef as tD}from"react";import{jsx as hS}from"react/jsx-runtime";var fS,bS=y(()=>{"use strict";h();gS();fS=({manager:e})=>{let t=tD(null);return eD(()=>(t.current&&e.start(t.current),()=>{e.stop()}),[e]),hS("div",{className:"LaserToolOverlay",children:hS("svg",{ref:t,className:"LaserToolOverlayCanvas"})})}});import{LaserPointer as xS}from"@excalidraw/laser-pointer";function oD(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)} ${up(n[0],i[0]).toFixed(2)},${up(n[1],i[1]).toFixed(2)} T`;for(let l=2,c=r-1;l<c;l++)o=e[l],n=e[l+1],a+=`${up(o[0],n[0]).toFixed(2)},${up(o[1],n[1]).toFixed(2)} `;return t&&(a+="Z"),a}function ES(e){return 1-Math.pow(1-e,3)}function J1(){return{currentPath:void 0,finishedPaths:[],lastPoint:[-1e4,-1e4],svg:document.createElementNS("http://www.w3.org/2000/svg","path")}}function yS(){return xS.constants.cornerDetectionMaxAngle=70,new xS({simplify:0,streamline:.4,sizeMapping:e=>{let t=Q1,r=rD,o=Math.max(0,1-(performance.now()-e.pressure)/t),n=(r-Math.min(r,e.totalLength-e.currentIndex))/r;return Math.min(ES(n),ES(o))}})}var Q1,rD,up,pp,wS=y(()=>{"use strict";h();W();Es();Q1=1e3,rD=50,up=(e,t)=>(e+t)/2;pp=class{constructor(t){this.app=t;this.ownState=J1()}ownState;collaboratorsState=new Map;rafId;isDrawing=!1;container;destroy(){this.stop(),this.isDrawing=!1,this.ownState=J1(),this.collaboratorsState=new Map}startPath(t,r){this.ownState.currentPath=yS(),this.ownState.currentPath.addPoint([t,r,performance.now()]),this.updatePath(this.ownState)}addPointToPath(t,r){this.ownState.currentPath&&(this.ownState.currentPath?.addPoint([t,r,performance.now()]),this.updatePath(this.ownState))}endPath(){this.ownState.currentPath&&(this.ownState.currentPath.close(),this.ownState.finishedPaths.push(this.ownState.currentPath),this.updatePath(this.ownState))}updatePath(t){this.isDrawing=!0,this.isRunning||this.start()}isRunning=!1;start(t){t&&(this.container=t,this.container.appendChild(this.ownState.svg)),this.stop(),this.isRunning=!0,this.loop()}stop(){this.isRunning=!1,this.rafId&&cancelAnimationFrame(this.rafId),this.rafId=void 0}loop(){this.rafId=requestAnimationFrame(this.loop.bind(this)),this.updateCollabolatorsState(),this.isDrawing?this.update():this.isRunning=!1}draw(t){let r=t.getStrokeOutline(t.options.size/this.app.state.zoom.value).map(([o,n])=>{let i=Dt({sceneX:o,sceneY:n},this.app.state);return[i.x,i.y]});return oD(r,!0)}updateCollabolatorsState(){if(!(!this.container||!this.app.state.collaborators.size))for(let[t,r]of this.app.state.collaborators.entries()){if(!this.collaboratorsState.has(t)){let n=J1();this.container.appendChild(n.svg),this.collaboratorsState.set(t,n),this.updatePath(n)}let o=this.collaboratorsState.get(t);r.pointer&&r.pointer.tool==="laser"&&(r.button==="down"&&o.currentPath===void 0&&(o.lastPoint=[r.pointer.x,r.pointer.y],o.currentPath=yS(),o.currentPath.addPoint([r.pointer.x,r.pointer.y,performance.now()]),this.updatePath(o)),r.button==="down"&&o.currentPath!==void 0&&(r.pointer.x!==o.lastPoint[0]||r.pointer.y!==o.lastPoint[1])&&(o.lastPoint=[r.pointer.x,r.pointer.y],o.currentPath.addPoint([r.pointer.x,r.pointer.y,performance.now()]),this.updatePath(o)),r.button==="up"&&o.currentPath!==void 0&&(o.lastPoint=[r.pointer.x,r.pointer.y],o.currentPath.addPoint([r.pointer.x,r.pointer.y,performance.now()]),o.currentPath.close(),o.finishedPaths.push(o.currentPath),o.currentPath=void 0,this.updatePath(o)))}}update(){if(!this.container)return;let t=!1;for(let[o,n]of this.collaboratorsState.entries()){if(!this.app.state.collaborators.has(o)){n.svg.remove(),this.collaboratorsState.delete(o);continue}n.finishedPaths=n.finishedPaths.filter(a=>{let l=a.originalPoints[a.originalPoints.length-1];return!(l&&l[2]<performance.now()-Q1)});let i=n.finishedPaths.map(a=>this.draw(a)).join(" ");n.currentPath&&(i+=` ${this.draw(n.currentPath)}`),i.trim()&&(t=!0),n.svg.setAttribute("d",i),n.svg.setAttribute("fill",Ji(o))}this.ownState.finishedPaths=this.ownState.finishedPaths.filter(o=>{let n=o.originalPoints[o.originalPoints.length-1];return!(n&&n[2]<performance.now()-Q1)});let r=this.ownState.finishedPaths.map(o=>this.draw(o)).join(" ");this.ownState.currentPath&&(r+=` ${this.draw(this.ownState.currentPath)}`),r=r.trim(),r&&(t=!0),this.ownState.svg.setAttribute("d",r),this.ownState.svg.setAttribute("fill","red"),t||(this.isDrawing=!1)}}});var en,vS=y(()=>{"use strict";h();en=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 TS=y(()=>{});import{jsx as aD}from"react/jsx-runtime";var nD,iD,eb,IS=y(()=>{"use strict";h();W();ue();be();TS();nD=5,iD=(e,t)=>{let[r,o]=ee(e),{x:n,y:i}=Dt({sceneX:r+e.width,sceneY:o},t),a=n-t.offsetLeft+10,l=i-t.offsetTop;return{x:a,y:l}},eb=({children:e,element:t})=>{let r=al();if(r.contextMenu||r.draggingElement||r.resizingElement||r.isRotating||r.openMenu||r.viewModeEnabled)return null;let{x:o,y:n}=iD(t,r);return aD("div",{className:"excalidraw-canvas-buttons",style:{top:`${n}px`,left:`${o}px`,padding:nD},children:e})}});async function SS({image:e,apiKey:t,text:r,theme:o="light"}){let n={model:"gpt-4-vision-preview",max_tokens:4096,temperature:.1,messages:[{role:"system",content:lD},{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 lD,CS=y(()=>{"use strict";h();lD=`You are a skilled front-end developer who builds interactive prototypes from wireframes, and is an expert at CSS Grid and Flex design.
|
|
64
|
+
C -->|Three| F[Car]`,O3=Ni(dc,300),UM=({mermaidToExcalidrawLib:e})=>{let[t,r]=R3(()=>br.get(Br.MERMAID_TO_EXCALIDRAW)||GM),o=zM(t.trim()),[n,i]=R3(null),a=N3(null),l=N3({elements:[],files:null}),s=$r();B3(()=>{Ip({canvasRef:a,data:l,mermaidToExcalidrawLib:e,setError:i,mermaidDefinition:o}).catch(()=>{}),O3(o)},[o,e]),B3(()=>()=>{O3.flush()},[]);let c=()=>{Cp({app:s,data:l,text:t,shouldSaveMermaidDataToStorage:!0})};return F3(WM,{children:[jo("div",{className:"ttd-dialog-desc",children:jo(or,{i18nKey:"mermaid.description",flowchartLink:d=>jo("a",{href:"https://mermaid.js.org/syntax/flowchart.html",children:d}),sequenceLink:d=>jo("a",{href:"https://mermaid.js.org/syntax/sequenceDiagram.html",children:d}),classLink:d=>jo("a",{href:"https://mermaid.js.org/syntax/classDiagram.html",children:d})})}),F3(kp,{children:[jo(Ul,{label:b("mermaid.syntax"),children:jo(Ap,{input:t,placeholder:"Write Mermaid diagram defintion here...",onChange:d=>r(d.target.value),onKeyboardSubmit:()=>{c()}})}),jo(Ul,{label:b("mermaid.preview"),panelAction:{action:()=>{c()},label:b("mermaid.button"),icon:fl},renderSubmitShortcut:()=>jo(Pp,{}),children:jo(Lp,{canvasRef:a,loaded:e.loaded,error:n})})]})]})},H3=UM;import{useEffect as YM,useRef as Df,useState as Dp}from"react";h();import*as z3 from"@radix-ui/react-tabs";import{jsx as VM}from"react/jsx-runtime";var _f=({children:e,...t})=>VM(z3.List,{className:"ttd-dialog-triggers",...t,children:e});_f.displayName="TTDDialogTabTriggers";h();import*as U3 from"@radix-ui/react-tabs";import{jsx as G3}from"react/jsx-runtime";var _p=({children:e,tab:t,onSelect:r,...o})=>G3(U3.Trigger,{value:t,asChild:!0,onSelect:r,children:G3("button",{type:"button",className:"ttd-dialog-tab-trigger",...o,children:e})});_p.displayName="TTDDialogTabTrigger";F();import{atom as V3,useAtom as W3}from"jotai";import{jsx as ir,jsxs as yi}from"react/jsx-runtime";var Rf=3,Wl=1e3,KM=V3(null),$M=V3(null),Nf=e=>{let t=Ne();return t.openDialog?.name!=="ttd"?null:ir(XM,{...e,tab:t.openDialog.tab})},XM=Ln("TTDDialogBase",({tab:e,...t})=>{let r=$r(),o=Ve(),n=Df(null),[i,a]=W3($M),[l,s]=Dp(i?.prompt??""),c=l.trim(),d=C=>{s(C.target.value),a(D=>({generatedResponse:D?.generatedResponse??null,prompt:C.target.value}))},[m,p]=Dp(!1),[u,g]=W3(KM),f=async()=>{if(c.length>Wl||c.length<Rf||m||u?.rateLimitRemaining===0||"__fallback"in t){c.length<Rf&&k(new Error(`Prompt is too short (min ${Rf} characters)`)),c.length>Wl&&k(new Error(`Prompt is too long (max ${Wl} characters)`));return}try{p(!0),xe("ai","generate","ttd");let{generatedResponse:C,error:D,rateLimit:R,rateLimitRemaining:z}=await t.onTextSubmit(c);if(typeof C=="string"&&a(L=>({generatedResponse:C,prompt:L?.prompt??null})),su(R)&&su(z)&&g({rateLimit:R,rateLimitRemaining:z}),D){k(D);return}if(!C){k(new Error("Generation failed"));return}try{await Ip({canvasRef:n,data:w,mermaidToExcalidrawLib:y,setError:k,mermaidDefinition:C}),xe("ai","mermaid parse success","ttd")}catch(L){console.info(`%cTTD mermaid render errror: ${L.message}`,"color: red"),console.info(`>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>
|
|
65
|
+
TTD mermaid definition render errror: ${L.message}`,"color: yellow"),xe("ai","mermaid parse failed","ttd"),k(new Error("Generated an invalid diagram :(. You may also try a different prompt."))}}catch(C){let D=C.message;(!D||D==="Failed to fetch")&&(D="Request failed"),k(new Error(D))}finally{p(!1)}},E=Df(f);E.current=f;let[y,T]=Dp({loaded:!1,api:import("@excalidraw/mermaid-to-excalidraw")});YM(()=>{(async()=>{await y.api,T(D=>({...D,loaded:!0}))})()},[y.api]);let w=Df({elements:[],files:null}),[I,k]=Dp(null);return ir(ut,{className:"ttd-dialog",onCloseRequest:()=>{r.setOpenDialog(null)},size:1200,title:!1,...t,autofocus:!1,children:yi(Sp,{dialog:"ttd",tab:e,children:["__fallback"in t&&t.__fallback?ir("p",{className:"dialog-mermaid-title",children:b("mermaid.title")}):yi(_f,{children:[ir(_p,{tab:"text-to-diagram",children:yi("div",{style:{display:"flex",alignItems:"center"},children:[b("labels.textToDiagram"),ir("div",{style:{display:"flex",alignItems:"center",justifyContent:"center",padding:"1px 6px",marginLeft:"10px",fontSize:10,borderRadius:"12px",background:"pink",color:"#000"},children:"AI Beta"})]})}),ir(_p,{tab:"mermaid",children:"Mermaid"})]}),ir(Gl,{className:"ttd-dialog-content",tab:"mermaid",children:ir(H3,{mermaidToExcalidrawLib:y})}),!("__fallback"in t)&&yi(Gl,{className:"ttd-dialog-content",tab:"text-to-diagram",children:[ir("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."}),yi(kp,{children:[ir(Ul,{label:b("labels.prompt"),panelAction:{action:f,label:"Generate",icon:fl},onTextSubmitInProgess:m,panelActionDisabled:c.length>Wl||u?.rateLimitRemaining===0,renderTopRight:()=>u?yi("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:()=>ir(Pp,{}),renderBottomRight:()=>{if(typeof i?.generatedResponse=="string")return yi("div",{className:"excalidraw-link",style:{marginLeft:"auto",fontSize:14},onClick:()=>{typeof i?.generatedResponse=="string"&&(dc(i.generatedResponse),o({openDialog:{name:"ttd",tab:"mermaid"}}))},children:["View as Mermaid",ir(Hl,{icon:fl})]});let C=c.length/Wl;return C>.8?yi("div",{style:{marginLeft:"auto",fontSize:12,fontFamily:"monospace",color:C>1?"var(--color-danger)":void 0},children:["Length: ",c.length,"/",Wl]}):null},children:ir(Ap,{onChange:d,input:l,placeholder:"Describe what you want to see...",onKeyboardSubmit:()=>{E.current()}})}),ir(Ul,{label:"Preview",panelAction:{action:()=>{console.info("Panel action clicked"),Cp({app:r,data:w})},label:"Insert",icon:fl},children:ir(Lp,{canvasRef:n,error:I,loaded:y.loaded})})]})]})]})})});import{Fragment as K3,jsx as re,jsxs as Rr}from"react/jsx-runtime";var QM=({UIOptions:e})=>Rr(nr,{__fallback:!0,children:[re(nr.DefaultItems.LoadScene,{}),re(nr.DefaultItems.SaveToActiveFile,{}),e.canvasActions.export&&re(nr.DefaultItems.Export,{}),e.canvasActions.saveAsImage&&re(nr.DefaultItems.SaveAsImage,{}),re(nr.DefaultItems.Help,{}),re(nr.DefaultItems.ClearCanvas,{}),re(nr.Separator,{}),re(nr.Group,{title:"Excalidraw links",children:re(nr.DefaultItems.Socials,{})}),re(nr.Separator,{}),re(nr.DefaultItems.ToggleTheme,{}),re(nr.DefaultItems.ChangeCanvasBackground,{})]}),eL=()=>Rr(vp,{__fallback:!0,children:[re(vp.Actions.SaveToDisk,{}),re(vp.Actions.ExportToImage,{})]}),tL=({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:g,children:f,app:E,isCollaborating:y,openAIKey:T,isOpenAIKeyPersisted:w,onOpenAIAPIKeyChange:I,onMagicSettingsConfirm:k})=>{let C=ke(),D=q2(),[R,z]=qM(li,Pe),L=()=>p.canvasActions.export?re(zv,{elements:n,appState:t,files:r,actionManager:e,exportOpts:p.canvasActions.export,canvas:i,setAppState:o}):null,M=()=>!p.canvasActions.saveAsImage||t.openDialog?.name!=="imageExport"?null:re(Iv,{elements:n,appState:t,files:r,actionManager:e,onExportImage:u,onCloseRequest:()=>o({openDialog:null}),name:E.getName()}),A=()=>Rr("div",{style:{position:"relative"},children:[re(D.MainMenuTunnel.Out,{}),g&&re(D.WelcomeScreenMenuHintTunnel.Out,{})]}),H=()=>re(hi,{heading:"selectedShapeActions",className:uc("selected-shape-actions zen-mode-transition",{"transition-left":t.zenModeEnabled}),children:re(Ut,{className:Lc.SHAPE_ACTIONS_MENU,padding:2,style:{maxHeight:`${t.height-166}px`},children:re(Qm,{appState:t,elementsMap:E.scene.getNonDeletedElementsMap(),renderAction:e.renderAction})})}),q=()=>{let se=ia(t,n);return re(dp,{side:"top",children:Rr("div",{className:"App-menu App-menu_top",children:[Rr(Dt.Col,{gap:6,className:uc("App-menu_top__left"),children:[A(),se&&H()]}),!t.viewModeEnabled&&re(hi,{heading:"shapes",className:"shapes-section",children:ce=>Rr("div",{style:{position:"relative"},children:[g&&re(D.WelcomeScreenToolbarHintTunnel.Out,{}),re(Dt.Col,{gap:4,align:"start",children:Rr(Dt.Row,{gap:1,className:uc("App-toolbar-container",{"zen-mode":t.zenModeEnabled}),children:[Rr(Ut,{padding:1,className:uc("App-toolbar",{"zen-mode":t.zenModeEnabled}),children:[re(mp,{appState:t,isMobile:C.editor.isMobile,device:C,app:E}),ce,Rr(Dt.Row,{gap:1,children:[re(up,{zenModeEnabled:t.zenModeEnabled,checked:t.penMode,onChange:()=>s(null),title:b("toolBar.penMode"),penDetected:t.penDetected}),re(pp,{checked:t.activeTool.locked,onChange:a,title:b("toolBar.lock")}),re("div",{className:"App-toolbar__divider"}),re(hp,{checked:xo(t),onChange:()=>l(),title:b("toolBar.hand"),isMobile:!0}),re(ep,{appState:t,activeTool:t.activeTool,UIOptions:p,app:E})]})]}),y&&re(Ut,{style:{marginLeft:8,alignSelf:"center",height:"fit-content"},children:re(w3,{title:b("toolBar.laser"),checked:t.activeTool.type===ht.laser,onChange:()=>E.setActiveTool({type:ht.laser}),isMobile:!0})})]})})]})}),Rr("div",{className:uc("layer-ui__wrapper__top-right zen-mode-transition",{"transition-right":t.zenModeEnabled}),children:[t.collaborators.size>0&&re(fp,{collaborators:t.collaborators,userToFollow:t.userToFollow?.socketId||null}),d?.(C.editor.isMobile,t),!t.viewModeEnabled&&(!Q||t.openSidebar?.name!==Ao.name)&&re(D.DefaultSidebarTriggerTunnel.Out,{})]})]})})},Y=()=>re(Tp,{__fallback:!0,onDock:se=>{xe("sidebar",`toggleDock (${se?"dock":"undock"})`,`(${C.editor.isMobile?"mobile":"desktop"})`)}}),Q=JM(lc,Pe),fe=Rr(K3,{children:[f,re(QM,{UIOptions:p}),re(Tp.Trigger,{__fallback:!0,icon:c0,title:ka(b("toolBar.library")),onToggle:se=>{se&&xe("sidebar",`${Ao.name} (open)`,`button (${C.editor.isMobile?"mobile":"desktop"})`)},tab:Ao.defaultTab,children:b("toolBar.library")}),re(eL,{}),t.openDialog?.name==="ttd"&&re(Nf,{__fallback:!0}),t.isLoading&&re(Gc,{delay:250}),t.errorMessage&&re(wv,{onClose:()=>o({errorMessage:null}),children:t.errorMessage}),R&&!C.editor.isMobile&&re(kw,{colorPickerType:R.colorPickerType,onCancel:()=>{z(null)},onChange:(se,ce,Ye,{altKey:Nt})=>{if(!(se!=="elementBackground"&&se!=="elementStroke"))if(Ye.length){for(let vt of Ye)B(vt,{[Nt&&R.swapPreviewOnAlt?se==="elementBackground"?"strokeColor":"backgroundColor":se==="elementBackground"?"backgroundColor":"strokeColor"]:ce},!1),Te.delete(vt);rt.getScene(Ye[0])?.informMutation()}else o(se==="elementBackground"?{currentItemBackgroundColor:ce}:{currentItemStrokeColor:ce})},onSelect:(se,ce)=>{z(Ye=>Ye?.keepOpenOnAlt&&ce.altKey?Ye:null),R?.onSelect?.(se,ce)}}),t.openDialog?.name==="help"&&re(Ov,{onClose:()=>{o({openDialog:null})}}),t.openDialog?.name==="settings"&&re(M3,{openAIKey:T,isPersisted:w,onChange:I,onConfirm:(se,ce)=>{let Ye=t.openDialog?.name==="settings"?t.openDialog?.source:"settings";o({openDialog:null},()=>{k(se,ce,Ye)})},onClose:()=>{o({openDialog:null})}}),re(o3,{}),re(D.OverwriteConfirmDialogTunnel.Out,{}),M(),L(),t.pasteDialog.shown&&re(Bv,{setAppState:o,appState:t,onClose:()=>o({pasteDialog:{shown:!1,data:null}})}),C.editor.isMobile&&re(Rv,{app:E,appState:t,elements:n,actionManager:e,renderJSONExportDialog:L,renderImageExportDialog:M,setAppState:o,onLockToggle:a,onHandToolToggle:l,onPenModeToggle:s,renderTopRightUI:d,renderCustomStats:m,renderSidebars:Y,device:C,renderWelcomeScreen:g,UIOptions:p}),!C.editor.isMobile&&Rr(K3,{children:[Rr("div",{className:"layer-ui__wrapper",style:t.openSidebar&&Q&&C.editor.canFitSidebar?{width:`calc(100% - ${Wb}px)`}:{},children:[g&&re(D.WelcomeScreenCenterTunnel.Out,{}),q(),re(Wv,{appState:t,actionManager:e,showExitZenModeBtn:c,renderWelcomeScreen:g}),t.showStats&&re(gp,{appState:t,setAppState:o,elements:n,onClose:()=>{e.executeAction(di)},renderCustomStats:m}),t.scrolledOutside&&re("button",{className:"scroll-back-to-content",onClick:()=>{o(se=>({...Ho(n,se)}))},children:b("buttons.scrollBackToContent")})]}),Y()]})]});return re(ah.Provider,{value:t,children:re(jM,{scope:D.jotaiScope,children:re(Xh.Provider,{value:D,children:fe})})})},Y3=e=>{let{suggestedBindings:t,startBoundElement:r,cursorButton:o,scrollX:n,scrollY:i,...a}=e;return a},rL=(e,t)=>{if(e.children!==t.children)return!1;let{canvas:r,appState:o,...n}=e,{canvas:i,appState:a,...l}=t;return bt(Y3(o),Y3(a),{selectedElementIds:bt,selectedGroupIds:bt})&&bt(n,l)},$3=ZM.memo(tL,rL);h();import{useCallback as oL,useEffect as nL,useRef as iL}from"react";import{jsx as X3,jsxs as lL}from"react/jsx-runtime";var aL=5e3,Z3=({message:e,onClose:t,closable:r=!1,duration:o=aL,style:n})=>{let i=iL(0),a=o!==1/0,l=oL(()=>{a&&(i.current=window.setTimeout(()=>t(),o))},[t,o,a]);return nL(()=>{if(a)return l(),()=>clearTimeout(i.current)},[l,e,o,a]),lL("div",{className:"Toast",onMouseEnter:a?()=>clearTimeout(i?.current):void 0,onMouseLeave:a?l:void 0,style:n,children:[X3("p",{className:"Toast__message",children:e}),r&&X3(ne,{icon:Yr,"aria-label":"close",type:"icon",onClick:t,className:"close"})]})};h();de();ze();var Bf=N({name:"viewMode",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,r)=>typeof r.viewModeEnabled>"u",contextItemLabel:"labels.viewMode",keyTest:e=>!e[S.CTRL_OR_CMD]&&e.altKey&&e.code===ue.R});gr();mg();En();lt();Xn();import QL from"lodash.throttle";Xa();Oa();h();me();He();lt();oe();F();uo();var Rp=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=>G(o)&&!Me(o)?(Te.delete(o),r=!0,te(o,{...ja(o,st(o,this.scene.getNonDeletedElementsMap()),this.scene.getNonDeletedElementsMap())})):o),r&&this.onSceneUpdated()};loadFontsForElements=async t=>{let r=await Promise.all([...new Set(t.filter(o=>G(o)).map(o=>o.fontFamily))].map(o=>{let n=Be({fontFamily:o,fontSize:16});if(!document.fonts?.check?.(n))return document.fonts?.load?.(n)}));this.onFontsLoaded(r.flat().filter(Boolean))}};Xt();Un();h();me();Xt();Xt();de();F();Za();ze();oe();var j3=(e,t)=>{let r=t.scene.getSelectedElements(e);return r.length===1&&X(r[0])},q3=N({name:"selectAllElementsInFrame",trackEvent:{category:"canvas"},perform:(e,t,r,o)=>{let n=o.scene.getSelectedElements(t).at(0)||null;if(X(n)){let i=Mr(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}},contextItemLabel:"labels.selectAllElementsInFrame",predicate:(e,t,r,o)=>j3(t,o)}),J3=N({name:"removeAllElementsFromFrame",trackEvent:{category:"history"},perform:(e,t,r,o)=>{let n=o.scene.getSelectedElements(t).at(0)||null;return X(n)?{elements:Ig(e,n),appState:{...t,selectedElementIds:{[n.id]:!0}},commitToHistory:!0}:{elements:e,appState:t,commitToHistory:!1}},contextItemLabel:"labels.removeAllElementsFromFrame",predicate:(e,t,r,o)=>j3(t,o)}),Bue=N({name:"updateFrameRendering",viewMode:!0,trackEvent:{category:"canvas"},perform:(e,t)=>({elements:e,appState:{...t,frameRendering:{...t.frameRendering,enabled:!t.frameRendering.enabled}},commitToHistory:!1}),contextItemLabel:"labels.updateFrameRendering",checked:e=>e.frameRendering.enabled}),Oue=N({name:"setFrameAsActiveTool",trackEvent:{category:"toolbar"},perform:(e,t,r,o)=>{let n=Ke(t,{type:"frame"});return kr(o.interactiveCanvas,{...t,activeTool:n}),{elements:e,appState:{...t,activeTool:Ke(t,{type:"frame"})},commitToHistory:!1}},keyTest:e=>!e[S.CTRL_OR_CMD]&&!e.shiftKey&&!e.altKey&&e.key.toLocaleLowerCase()===S.F});Ji();h();W();mt();oe();Ir();de();Ht();Un();var sL=8,Q3=99999,Np=e=>sL/e,Qr=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}},Pn=({event:e,appState:t,selectedElements:r})=>e?t.objectsSnapModeEnabled&&!e[S.CTRL_OR_CMD]||!t.objectsSnapModeEnabled&&e[S.CTRL_OR_CMD]&&t.gridSize===null:r.length===1&&r[0].type==="arrow"?!1:t.objectsSnapModeEnabled,cL=(e,t,r=.01)=>Math.abs(e-t)<=r,gc=(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]=j(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")&&!o){let f=Fe([l,s+g],[m,p],a.angle),E=Fe([l+u,s],[m,p],a.angle),y=Fe([c,s+g],[m,p],a.angle),T=Fe([l+u,d],[m,p],a.angle);i=r?[f,E,y,T]:[f,E,y,T,[m,p]]}else{let f=Fe([l,s],[m,p],a.angle),E=Fe([c,s],[m,p],a.angle),y=Fe([l,d],[m,p],a.angle),T=Fe([c,d],[m,p],a.angle);i=r?[f,E,y,T]:[f,E,y,T,[m,p]]}}else if(e.length>1){let[a,l,s,c]=hd(e,n??{x:0,y:0}),d=s-a,m=c-l,p=[a,l],u=[s,l],g=[a,c],f=[s,c],E=[a+d/2,l+m/2];i=r?[p,u,g,f]:[p,u,g,f,E]}return i.map(a=>[ct(a[0]),ct(a[1])])},rT=(e,t,r,o)=>{let n=t.filter(i=>X(i)).map(i=>i.id);return Hg(e,t,r,o).filter(i=>!(i.frameId&&n.includes(i.frameId)))},oT=(e,t,r,o)=>{let n=rT(e,t,r,o),i=ji(n,o).filter(m=>!(m.length===1&&Me(m[0]))).map(m=>ye(m).map(p=>ct(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>Q3)break e;let g=a[u],[,f,E,y]=p,[T,w,,I]=g;E<T&&ls([f,y],[w,I])&&l.push({startBounds:p,endBounds:g,startSide:[[E,f],[E,y]],endSide:[[T,w],[T,I]],length:T-E,overlap:ss([f,y],[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>Q3)break e;let g=c[u],[f,,E,y]=p,[T,w,I]=g;y<w&&ls([f,E],[T,I])&&d.push({startBounds:p,endBounds:g,startSide:[[f,y],[E,y]],endSide:[[T,w],[I,w]],length:w-y,overlap:ss([f,E],[T,I])})}}return{horizontalGaps:l,verticalGaps:d}},eT=(e,t,r,o,n,i,a)=>{if(!Pn({appState:r,event:o,selectedElements:e}))return[];if(e.length===0)return[];let l=Qr.getVisibleGaps();if(l){let{horizontalGaps:s,verticalGaps:c}=l,[d,m,p,u]=hd(e,t).map(E=>ct(E)),g=(d+p)/2,f=(m+u)/2;for(let E of s){if(!ls([m,u],E.overlap))continue;let y=E.startSide[0][0]+E.length/2,T=ct(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 L={type:"gap",direction:"center_horizontal",gap:E,offset:T};n.push(L);continue}let[,,I]=E.endBounds,k=d-I,C=ct(E.length-k);if(Math.abs(C)<=a.x){Math.abs(C)<a.x&&(n.length=0),a.x=Math.abs(C);let L={type:"gap",direction:"side_right",gap:E,offset:C};n.push(L);continue}let[D,,,]=E.startBounds,R=D-p,z=ct(R-E.length);if(Math.abs(z)<=a.x){Math.abs(z)<a.x&&(n.length=0),a.x=Math.abs(z);let L={type:"gap",direction:"side_left",gap:E,offset:z};n.push(L);continue}}for(let E of c){if(!ls([d,p],E.overlap))continue;let y=E.startSide[0][1]+E.length/2,T=ct(y-f);if(E.length>u-m&&Math.abs(T)<=a.y){Math.abs(T)<a.y&&(i.length=0),a.y=Math.abs(T);let L={type:"gap",direction:"center_vertical",gap:E,offset:T};i.push(L);continue}let[,I,,]=E.startBounds,k=I-u,C=ct(k-E.length);if(Math.abs(C)<=a.y){Math.abs(C)<a.y&&(i.length=0),a.y=Math.abs(C);let L={type:"gap",direction:"side_top",gap:E,offset:C};i.push(L);continue}let[,,,D]=E.endBounds,R=ct(m-D),z=E.length-R;if(Math.abs(z)<=a.y){Math.abs(z)<a.y&&(i.length=0),a.y=Math.abs(z);let L={type:"gap",direction:"side_bottom",gap:E,offset:z};i.push(L);continue}}}},nT=(e,t,r,o)=>{let n=rT(e,t,r,o);return ji(n,o).filter(i=>!(i.length===1&&Me(i[0]))).flatMap(i=>gc(i,o))},Vl=(e,t,r,o,n,i,a)=>{if(!Pn({appState:r,event:o,selectedElements:e})||e.length===0&&t.length===0)return[];let l=Qr.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))}},iT=(e,t,r,o,n)=>{let i=pe(e,r);if(!Pn({appState:r,event:o,selectedElements:i})||i.length===0)return{snapOffset:{x:0,y:0},snapLines:[]};t.x=ct(t.x),t.y=ct(t.y);let a=[],l=[],s=Np(r.zoom.value),c={x:s,y:s},d=gc(i,n,{dragOffset:t});Vl(i,d,r,o,a,l,c),eT(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:ct(t.x+m.x),y:ct(t.y+m.y)};Vl(i,gc(i,n,{dragOffset:p}),r,o,a,l,c),eT(i,p,r,o,a,l,c);let u=Of(a,l),g=mL(i,p,[...a,...l].filter(f=>f.type==="gap"));return{snapOffset:m,snapLines:[...u,...g]}},ct=e=>Math.round(e*10**6)/10**6,tT=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())},Of=(e,t)=>{let r={},o={};if(e.length>0){for(let n of e)if(n.type==="point"){let i=ct(n.points[0][0]);r[i]||(r[i]=[]),r[i].push(...n.points.map(a=>[ct(a[0]),ct(a[1])]))}}if(t.length>0){for(let n of t)if(n.type==="point"){let i=ct(n.points[0][1]);o[i]||(o[i]=[]),o[i].push(...n.points.map(a=>[ct(a[0]),ct(a[1])]))}}return Object.entries(r).map(([n,i])=>({type:"points",points:tT(i.map(a=>[Number(n),a[1]]).sort((a,l)=>a[1]-l[1]))})).concat(Object.entries(o).map(([n,i])=>({type:"points",points:tT(i.map(a=>[a[0],Number(n)]).sort((a,l)=>a[0]-l[0]))})))},dL=e=>{let t=new Map;for(let r of e){let o=r.points.flat().map(n=>[ct(n)]).join(",");t.has(o)||t.set(o,r)}return Array.from(t.values())},mL=(e,t,r)=>{let[o,n,i,a]=hd(e,t),l=[];for(let s of r){let[c,d,m,p]=s.gap.startBounds,[u,g,f,E]=s.gap.endBounds,y=ss([n,a],s.gap.overlap),T=ss([o,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],[o,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:[[f,w],[o,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 dL(l.map(s=>({...s,points:s.points.map(c=>[ct(c[0]),ct(c[1])])})))},aT=(e,t,r,o,n,i)=>{if(!Pn({event:o,selectedElements:e,appState:r})||e.length===0||e.length===1&&!cL(e[0].angle,0))return{snapOffset:{x:0,y:0},snapLines:[]};let[a,l,s,c]=ye(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=Np(r.zoom.value),p={x:m,y:m},u=[],g=[];Vl(t,d,r,o,u,g,p);let f={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]=ye(e).map(C=>ct(C));Vl(e,[[E,y],[E,w],[T,y],[T,w]],r,o,u,g,p);let k=Of(u,g);return{snapOffset:f,snapLines:k}},lT=(e,t,r,o,n,i)=>{if(!Pn({event:r,selectedElements:[e],appState:t}))return{snapOffset:{x:0,y:0},snapLines:[]};let a=[[o.x+n.x,o.y+n.y]],l=Np(t.zoom.value),s={x:l,y:l},c=[],d=[];Vl([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=gc([e],i,{boundingBoxCorners:!0,omitCenter:!0});Vl([e],p,t,r,c,d,s);let u=Of(c,d);return{snapOffset:m,snapLines:u}},sT=(e,t,r,o,n)=>{if(!Pn({event:o,selectedElements:[],appState:t}))return{originOffset:{x:0,y:0},snapLines:[]};let i=Hg(e,[],t,n),a=Np(t.zoom.value),l={x:a,y:a},s=[],c=[];for(let d of i){let m=gc([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 g=p[1]-r.y;Math.abs(g)<=Math.abs(l.y)&&(Math.abs(g)<Math.abs(l.y)&&(s.length=0),s.push({type:"pointer",points:[p,[r.x,p[1]]],direction:"horizontal"}),l.y=g)}}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]}},cT=e=>e===ht.rectangle||e===ht.ellipse||e===ht.diamond||e===ht.frame||e===ht.magicframe||e===ht.image;h();import{jsx as eo,jsxs as dT}from"react/jsx-runtime";var pL=()=>dT("div",{"data-testid":"brave-measure-text-error",children:[eo("p",{children:eo(or,{i18nKey:"errors.brave_measure_text_error.line1",bold:e=>eo("span",{style:{fontWeight:600},children:e})})}),eo("p",{children:eo(or,{i18nKey:"errors.brave_measure_text_error.line2",bold:e=>eo("span",{style:{fontWeight:600},children:e})})}),eo("p",{children:eo(or,{i18nKey:"errors.brave_measure_text_error.line3",link:e=>eo("a",{href:"http://docs.excalidraw.com/docs/@excalidraw/excalidraw/faq#turning-off-aggresive-block-fingerprinting-in-brave-browser",children:e})})}),eo("p",{children:eo(or,{i18nKey:"errors.brave_measure_text_error.line4",issueLink:e=>eo("a",{href:"https://github.com/excalidraw/excalidraw/issues/new",children:e}),discordLink:e=>dT("a",{href:"https://discord.gg/UexuTaE",children:[e,"."]})})})]}),mT=pL;h();W();me();ho();fn();lt();F();ns();co();var Bp={width:100,height:0},wi=100,uL=(e,t,r)=>{let o=Lt({x:0,y:0,textAlign:Fn.CENTER,verticalAlign:gt.MIDDLE,...t,containerId:e.id,strokeColor:t.strokeColor||e.strokeColor});return Object.assign(e,{boundElements:(e.boundElements||[]).concat({type:"text",id:o.id})}),zt(o,e,r),[e,o]},pT=(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??wi,m=t?.height??wi,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,g=t.y||e.y-m/2,f=p?p.type:t.type;if(f){if(f==="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=Lt({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(f){case"rectangle":case"ellipse":case"diamond":{i=Ar({x:u,y:g,width:d,height:m,...p,...t,type:f});break}default:zn(e,`Unhandled element start type "${t.type}"`,!0)}Wa(e,i,"start",n)}}if(r){let d=r?.height??wi,m=r?.width??wi,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,g=r.y||e.y-d/2,f=p?p.type:r.type;if(f){if(f==="text"){let E="";p&&p.type==="text"?E=p.text:r.type==="text"&&(E=r.text),E||console.error(`No text found for end binding text element for ${e.id}`),a=Lt({x:u,y:g,type:"text",...p,...r,text:E}),Object.assign(a,{y:r.y||e.y-a.height/2})}else switch(f){case"rectangle":case"ellipse":case"diamond":{a=Ar({x:u,y:g,width:m,height:d,...p,...r,type:f});break}default:zn(e,`Unhandled element end type "${f}"`,!0)}Wa(e,a,"end",n)}}let l=e.points.length-1,s=.5,c=Po(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}},Ff=class{excalidrawElements=new Map;add=t=>{t&&this.excalidrawElements.set(t.id,t)};getElements=()=>Array.from(this.excalidrawElements.values());getElementsMap=()=>so(this.excalidrawElements);getElement=t=>this.excalidrawElements.get(t)},mc=(e,t)=>{if(!e)return[];let r=Po(e),o=new Ff,n=new Map,i=new Map;for(let l of r){let s,c=l.id;switch(t?.regenerateIds!==!1&&Object.assign(l,{id:At()}),l.type){case"rectangle":case"ellipse":case"diamond":{let m=l?.label?.text&&l.width===void 0?0:l?.width||wi,p=l?.label?.text&&l.height===void 0?0:l?.height||wi;s=Ar({...l,width:m,height:p});break}case"line":{let m=l.width||Bp.width,p=l.height||Bp.height;s=Ur({width:m,height:p,points:[[0,0],[m,p]],...l});break}case"arrow":{let m=l.width||Bp.width,p=l.height||Bp.height;s=Ur({width:m,height:p,endArrowhead:"arrow",points:[[0,0],[m,p]],...l}),Object.assign(s,Zc(s.points));break}case"text":{let m=l?.fontFamily||Ot,p=l?.fontSize||It,u=l?.lineHeight||Tr(m),g=l.text??"",f=Zn(g),E=fo(f,Be({fontFamily:m,fontSize:p}),u);s=Lt({width:E.width,height:E.height,fontFamily:m,fontSize:p,...l});break}case"image":{s=Is({width:l?.width||wi,height:l?.height||wi,...l});break}case"frame":{s=Id({x:0,y:0,...l});break}case"magicframe":{s=Ss({x:0,y:0,...l});break}case"freedraw":case"iframe":case"embeddable":{s=l;break}default:s=l,zn(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]=uL(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 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:f,endBoundElement:E}=pT(d,p,u,o,a);d=g,o.add(g),o.add(f),o.add(E)}}else switch(s.type){case"arrow":{let{start:d,end:m}=s;if(d&&d.id){let f=i.get(d.id);Object.assign(d,{id:f})}if(m&&m.id){let f=i.get(m.id);Object.assign(m,{id:f})}let{linearElement:p,startBoundElement:u,endBoundElement:g}=pT(c,d,m,o,a);o.add(p),o.add(u),o.add(g);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(T=>{let w=i.get(T);if(!w)throw new Error(`Element with ${T} 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(k=>{let C=o.getElement(k.id);if(!C)throw new Error(`Bound element with id ${k.id} doesn't exist`);Object.assign(C,{frameId:c.id}),d.push(C)}),d.push(I)});let[m,p,u,g]=ye(d),f=10;m=m-f,p=p-f,u=u+f,g=g+f;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 o.getElements()};h();h();F();W();import AL,{useEffect as ML,useRef as LL}from"react";h();F();import{unstable_batchedUpdates as uT}from"react-dom";import{version as gL}from"react";var nt=e=>t=>{uT(e,t)},Op=e=>Ma(t=>{uT(e,t)}),Fp=(()=>{let e;try{let r=gL.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})();h();me();h();var Hf=(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()};ln();Ir();Oa();F();h();W();h();var hL="#ff6b6b",fL="#ff0000",gT=1,hT=2,fT=(e,t)=>{if(!t.snapLines.length)return;let r=t.theme==="light"||t.zenModeEnabled?hL:fL,o=(t.zenModeEnabled?gT*1.5:gT)/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,xL(n,e,t)):n.type==="gap"?(e.lineWidth=o,e.strokeStyle=r,EL(n.points[0],n.points[1],n.direction,t,e)):n.type==="points"&&(e.lineWidth=o,e.strokeStyle=r,bL(n,e,t));e.restore()},bL=(e,t,r)=>{if(!r.zenModeEnabled){let o=e.points[0],n=e.points[e.points.length-1];to(o,n,t)}for(let o of e.points)bT(o,r,t)},xL=(e,t,r)=>{bT(e.points[0],r,t),r.zenModeEnabled||to(e.points[0],e.points[1],t)},bT=([e,t],r,o)=>{o.save();let n=(r.zenModeEnabled?hT*1.5:hT)/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()},to=(e,t,r)=>{r.beginPath(),r.lineTo(...e),r.lineTo(...t),r.stroke()},EL=(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||to([e[0],e[1]-i],[e[0],e[1]+i],n),to([s[0]-l,s[1]-a],[s[0]-l,s[1]+a],n),to([s[0]+l,s[1]-a],[s[0]+l,s[1]+a],n),o.zenModeEnabled||(to([t[0],t[1]-i],[t[0],t[1]+i],n),to(e,t,n))}else{let s=[e[0],(e[1]+t[1])/2];o.zenModeEnabled||to([e[0]-i,e[1]],[e[0]+i,e[1]],n),to([s[0]-a,s[1]-l],[s[0]+a,s[1]-l],n),to([s[0]-a,s[1]+l],[s[0]+a,s[1]+l],n),o.zenModeEnabled||(to([t[0]-i,t[1]],[t[0]+i,t[1]],n),to(e,t,n))}};Xn();$t();gg();oe();import _n from"open-color";var yL=(e,t,r)=>{let{elementId:o,hoverPointIndex:n}=t.selectedLinearElement;if(t.editingLinearElement?.selectedPointsIndices?.includes(n))return;let i=V.getElement(o,r);if(!i)return;let a=V.getPointAtIndexGlobalCoordinates(i,n,r);e.save(),e.translate(t.scrollX,t.scrollY),Gf(a,e,t),e.restore()},Gf=(e,t,r)=>{t.fillStyle="rgba(105, 101, 219, 0.4)",Bs(t,e[0],e[1],V.POINT_HANDLE_SIZE/r.zoom.value,!1)},hc=(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()},wL=(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()},Hp=(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)"),Bs(e,r[0],r[1],o/t.zoom.value,!i)},vL=(e,t,r,o,n,i)=>{e.beginPath(),e.ellipse(o,n,t/2,r/2,i,0,Math.PI*2),e.stroke()},TL=(e,t,r)=>{let[o,n,i,a]=j(t,r),l=i-o,s=a-n,c=za(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":hc(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,g=m*p/l;wL(e,l+u*2,s+g*2,o+l/2,n+s/2,t.angle);break;case"ellipse":vL(e,l+m*2,s+m*2,o+l/2,n+s/2,t.angle);break}},SL=(e,t,r)=>{let[o,n,i]=t,a=za(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]=V.getPointAtIndexGlobalCoordinates(o,s,r);Bs(e,c,d,a)})},ET=(e,t,r,o=_i*2)=>{let{angle:n,elementX1:i,elementY1:a,elementX2:l,elementY2:s,selectionColors:c,cx:d,cy:m,dashed:p,activeEmbeddable:u}=r,g=l-i,f=s-a,E=o/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 I=0;I<w;++I)e.strokeStyle=c[I],p&&e.setLineDash([y,T+(y+T)*(w-1)]),e.lineDashOffset=(y+T)*I,hc(e,i-E,a-E,g+E*2,f+E*2,d,m,n);e.restore()},IL=(e,t,r,o)=>{let n=Array.isArray(r)?SL:TL;e.save(),e.translate(t.scrollX,t.scrollY),n(e,r,o),e.restore()},CL=(e,t,r,o)=>{let[n,i,a,l]=j(r,o),s=a-n,c=l-i;e.strokeStyle="rgb(0,118,255)",e.lineWidth=Ue.strokeWidth/t.zoom.value,e.save(),e.translate(t.scrollX,t.scrollY),hc(e,n,i,s,c,n+s/2,i+c/2,r.angle,!1,Ue.radius/t.zoom.value),e.restore()},kL=(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]=ye(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=Ze(r,l);return i(s)};Object.entries(xd(n,t)).filter(([l,s])=>s).map(([l,s])=>l).map(l=>a(l)).concat(o.map(l=>i([l]))).forEach(l=>ET(e,t,l))},zf=(e,t,r,o)=>{if(!t.selectedLinearElement)return;e.save(),e.translate(t.scrollX,t.scrollY),e.lineWidth=1/t.zoom.value;let n=V.getPointsGlobalCoordinates(r,o),{POINT_HANDLE_SIZE:i}=V,a=t.editingLinearElement?i:i/2;n.forEach((s,c)=>{let d=!!t.editingLinearElement?.selectedPointsIndices?.includes(c);Hp(e,t,s,a,d)}),V.getEditorMidPoints(r,o,t).filter(s=>s!==null).forEach(s=>{t?.selectedLinearElement?.segmentMidPointHoveredCoords&&V.arePointsEqual(s,t.selectedLinearElement.segmentMidPointHoveredCoords)?t.editingLinearElement?(Hp(e,t,s,a,!1),Gf(s,e,t)):(Gf(s,e,t),Hp(e,t,s,a,!1)):(t.editingLinearElement||n.length===2)&&Hp(e,t,s,i/2,!1,!0)}),e.restore()},xT=(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"?Bs(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()):hc(e,l,s,c,d,l+c/2,s+d/2,n,!0),e.restore()}})},yT=({canvas:e,elementsMap:t,visibleElements:r,selectedElements:o,scale:n,appState:i,renderConfig:a})=>{if(e===null)return{atLeastOneVisibleElement:!1,elementsMap:t};let[l,s]=zd(e,n),c=Gd({canvas:e,scale:n,normalizedWidth:l,normalizedHeight:s});c.save(),c.scale(i.zoom.value,i.zoom.value);let d;if(r.forEach(u=>{i.editingLinearElement?.elementId===u.id&&u&&(d=u)}),d&&zf(c,i,d,t),i.selectionElement)try{qE(i.selectionElement,c,i)}catch(u){console.error(u)}i.isBindingEnabled&&i.suggestedBindings.filter(u=>u!=null).forEach(u=>{IL(c,i,u,t)}),i.frameToHighlight&&CL(c,i,i.frameToHighlight,t),i.elementsToHighlight&&kL(c,i,i.elementsToHighlight);let m=o.some(u=>X(u));if(o.length===1&&i.editingLinearElement?.elementId===o[0].id&&zf(c,i,o[0],t),i.selectedLinearElement&&i.selectedLinearElement.hoverPointIndex>=0&&yL(c,i,t),!i.multiElement&&!i.editingLinearElement){let u=Ba(o,i);o.length===1&&ee(o[0])&&i.selectedLinearElement?.elementId===o[0].id&&!o[0].locked&&zf(c,i,o[0],t);let f=a.selectionColor||_n.black;if(u){let E=J(o),y=[];for(let w of t.values()){let I=[];if(E.has(w.id)&&!bd(i,w)&&I.push(f),a.remoteSelectedElementIds[w.id]&&I.push(...a.remoteSelectedElementIds[w.id].map(k=>ga(k))),I.length){let[k,C,D,R,z,L]=j(w,t,!0);y.push({angle:w.angle,elementX1:k,elementY1:C,elementX2:D,elementY2:R,selectionColors:I,dashed:!!a.remoteSelectedElementIds[w.id],cx:z,cy:L,activeEmbeddable:i.activeEmbeddable?.element===w&&i.activeEmbeddable.state==="active"})}}let T=w=>{let I=Ze(t,w),[k,C,D,R]=ye(I);y.push({angle:0,elementX1:k,elementX2:D,elementY1:C,elementY2:R,selectionColors:[_n.black],dashed:!0,cx:k+(D-k)/2,cy:C+(R-C)/2,activeEmbeddable:!1})};for(let w of un(i))T(w);i.editingGroupId&&T(i.editingGroupId),y.forEach(w=>ET(c,i,w))}if(c.save(),c.translate(i.scrollX,i.scrollY),o.length===1){c.fillStyle=_n.white;let E=hs(o[0],i.zoom,t,"mouse");!i.viewModeEnabled&&u&&xT(c,a,i,E,o[0].angle)}else if(o.length>1&&!i.isRotating){let E=_i*2/i.zoom.value;c.fillStyle=_n.white;let[y,T,w,I]=ye(o),k=c.getLineDash();c.setLineDash([2/i.zoom.value]);let C=c.lineWidth;c.lineWidth=1/i.zoom.value,c.strokeStyle=f,hc(c,y-E,T-E,w-y+E*2,I-T+E*2,(y+w)/2,(T+I)/2,0),c.lineWidth=C,c.setLineDash(k);let D=Na([y,T,w,I,(y+w)/2,(T+I)/2],0,i.zoom,"mouse",m?W1:gs);o.some(R=>!R.locked)&&xT(c,a,i,D,0)}c.restore()}fT(c,i),c.restore();for(let u in a.remotePointerViewportCoords){let{x:g,y:f}=a.remotePointerViewportCoords[u];g-=i.offsetLeft,f-=i.offsetTop;let E=11,y=14,T=g<0||g>l-E||f<0||f>s-y;g=Math.max(g,0),g=Math.min(g,l-E),f=Math.max(f,0),f=Math.min(f,s-y);let w=ga(u);c.save(),c.strokeStyle=w,c.fillStyle=w;let I=a.remotePointerUserStates[u],k=T||I==="idle"||I==="away";k&&(c.globalAlpha=.3),a.remotePointerButton&&a.remotePointerButton[u]==="down"&&(c.beginPath(),c.arc(g,f,15,0,2*Math.PI,!1),c.lineWidth=3,c.strokeStyle="#ffffff88",c.stroke(),c.closePath(),c.beginPath(),c.arc(g,f,15,0,2*Math.PI,!1),c.lineWidth=1,c.strokeStyle=w,c.stroke(),c.closePath()),c.fillStyle=_n.white,c.strokeStyle=_n.white,c.lineWidth=6,c.lineJoin="round",c.beginPath(),c.moveTo(g,f),c.lineTo(g+0,f+14),c.lineTo(g+4,f+9),c.lineTo(g+11,f+8),c.closePath(),c.stroke(),c.fill(),c.fillStyle=w,c.strokeStyle=w,c.lineWidth=2,c.lineJoin="round",c.beginPath(),k?(c.moveTo(g-1,f-1),c.lineTo(g-1,f+15),c.lineTo(g+5,f+10),c.lineTo(g+12,f+9),c.closePath(),c.fill()):(c.moveTo(g,f),c.lineTo(g+0,f+14),c.lineTo(g+4,f+9),c.lineTo(g+11,f+8),c.closePath(),c.fill(),c.stroke());let C=a.remotePointerUsernames[u]||"";if(!T&&C){c.font="600 12px sans-serif";let D=g+E/2,R=f+y+2,z=5,L=3,M=c.measureText(C),A=M.actualBoundingBoxDescent+M.actualBoundingBoxAscent,H=Math.max(A,12),q=D-1,Y=R-1,Q=M.width+2+z*2+2,fe=H+2+L*2+2;c.roundRect?(c.beginPath(),c.roundRect(q,Y,Q,fe,8),c.fillStyle=w,c.fill(),c.strokeStyle=_n.white,c.stroke()):Hf(c,q,Y,Q,fe,8,_n.white),c.fillStyle=_n.black,c.fillText(C,D+z+1,R+L+M.actualBoundingBoxAscent+Math.floor((H-A)/2)+2)}c.restore(),c.closePath()}let p;return a.renderScrollbars&&(p=Pv(r,l,s,i),c.save(),c.fillStyle=Lv,c.strokeStyle="rgba(255,255,255,0.8)",[p.horizontal,p.vertical].forEach(u=>{u&&Hf(c,u.x,u.y,u.width,u.height,$o/2)}),c.restore()),{scrollBars:p,atLeastOneVisibleElement:r.length>0,elementsMap:t}},Uf=Ma(e=>{let t=yT(e);e.callback?.(t)},{trailing:!0}),wT=(e,t)=>{if(t){Uf(e);return}let r=yT(e);return e.callback(r),r};import{jsx as DL}from"react/jsx-runtime";var PL=e=>{let t=LL(!1);return ML(()=>{if(!t.current){t.current=!0;return}let r={},o={},n={},i={},a={};e.appState.collaborators.forEach((s,c)=>{if(s.selectedElementIds)for(let d of Object.keys(s.selectedElementIds))d in n||(n[d]=[]),n[d].push(c);s.pointer&&(s.username&&(i[c]=s.username),s.userState&&(a[c]=s.userState),o[c]=Mt({sceneX:s.pointer.x,sceneY:s.pointer.y},e.appState),r[c]=s.button)});let l=e.containerRef?.current&&getComputedStyle(e.containerRef.current).getPropertyValue("--color-selection")||"#6965db";wT({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},callback:e.renderInteractiveSceneCallback},Fp())}),DL("canvas",{className:"excalidraw__canvas interactive",style:{width:e.appState.width,height:e.appState.height,cursor:e.appState.viewModeEnabled?Se.GRAB:Se.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")})},vT=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}),_L=(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:bt(vT(e.appState),vT(t.appState)),Wf=AL.memo(PL,_L);h();Vd();F();import RL,{useEffect as NL,useRef as TT}from"react";import{jsx as FL}from"react/jsx-runtime";var BL=e=>{let t=TT(null),r=TT(!1);return NL(()=>{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),Wd({canvas:n,rc:e.rc,scale:e.scale,elementsMap:e.elementsMap,allElementsMap:e.allElementsMap,visibleElements:e.visibleElements,appState:e.appState,renderConfig:e.renderConfig},Fp())}),FL("div",{className:"excalidraw__canvas-wrapper",ref:t})},ST=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,viewBackgroundColor:e.viewBackgroundColor,exportScale:e.exportScale,selectedElementsAreBeingDragged:e.selectedElementsAreBeingDragged,gridSize:e.gridSize,frameRendering:e.frameRendering,selectedElementIds:e.selectedElementIds,frameToHighlight:e.frameToHighlight,editingGroupId:e.editingGroupId}),OL=(e,t)=>e.versionNonce!==t.versionNonce||e.scale!==t.scale||e.elementsMap!==t.elementsMap||e.visibleElements!==t.visibleElements?!1:bt(ST(e.appState),ST(t.appState))&&bt(e.renderConfig,t.renderConfig),Vf=RL.memo(BL,OL);h();na();oe();Vd();F();var fc=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())oa(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=so(new Map);for(let l of o)Or(l)&&i===l.id||(!n||n.type!=="text"||l.id!==n.id)&&a.set(l.id,l);return a};return c1(({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(),g=r({elements:u,editingElement:d,pendingImageElementId:m}),f=t({elementsMap:g,zoom:o,offsetLeft:n,offsetTop:i,scrollX:a,scrollY:l,height:s,width:c});return{elementsMap:g,visibleElements:f}})})();destroy(){Uf.cancel(),hg.cancel(),this.getRenderableElements.clear()}};uo();h();import{useEffect as HL,useRef as zL}from"react";import{jsx as IT}from"react/jsx-runtime";var CT=({trails:e})=>{let t=zL(null);return HL(()=>{if(t.current)for(let r of e)r.start(t.current);return()=>{for(let r of e)r.stop()}},e),IT("div",{className:"SVGLayer",children:IT("svg",{ref:t})})};Za();h();F();me();import{jsx as WL}from"react/jsx-runtime";var GL=5,UL=(e,t,r)=>{let[o,n]=j(e,r),{x:i,y:a}=Mt({sceneX:o+e.width,sceneY:n},t),l=i-t.offsetLeft+10,s=a-t.offsetTop;return{x:l,y:s}},Yf=({children:e,element:t,elementsMap:r})=>{let o=Al();if(o.contextMenu||o.draggingElement||o.resizingElement||o.isRotating||o.openMenu||o.viewModeEnabled)return null;let{x:n,y:i}=UL(t,o,r);return WL("div",{className:"excalidraw-canvas-buttons",style:{top:`${i}px`,left:`${n}px`,padding:GL},children:e})};h();var VL=`You are a skilled front-end developer who builds interactive prototypes from wireframes, and is an expert at CSS Grid and Flex design.
|
|
67
66
|
Your role is to transform low-fidelity wireframes into working front-end HTML code.
|
|
68
67
|
|
|
69
68
|
YOU MUST FOLLOW FOLLOWING RULES:
|
|
@@ -83,7 +82,8 @@ If the wireframes, diagrams, or text is unclear or unreadable, refer to provided
|
|
|
83
82
|
|
|
84
83
|
Your goal is a production-ready prototype that brings the wireframes to life.
|
|
85
84
|
|
|
86
|
-
Please output JUST THE HTML file containing your best attempt at implementing the provided wireframes.`});import sD from"clsx";import{jsx as kS,jsxs as dD}from"react/jsx-runtime";var cD,gp,AS=y(()=>{"use strict";h();pn();cD="small",gp=e=>dD("label",{className:sD("ToolIcon ToolIcon__MagicButton",`ToolIcon_size_${cD}`,{"is-mobile":e.isMobile}),title:`${e.title}`,children:[kS("input",{className:"ToolIcon_type_checkbox",type:"checkbox",name:e.name,onChange:e.onChange,checked:e.checked,"aria-label":e.title}),kS("div",{className:"ToolIcon__icon",children:e.icon})]})});var MS=y(()=>{});import{jsx as hp,jsxs as LS}from"react/jsx-runtime";var mD,_S,PS=y(()=>{"use strict";h();se();MS();mD=({height:e,width:t,userToFollow:r,onDisconnect:o})=>hp("div",{style:{position:"relative"},children:hp("div",{className:"follow-mode",style:{width:t,height:e},children:LS("div",{className:"follow-mode__badge",children:[LS("div",{className:"follow-mode__badge__label",children:["Following"," ",hp("span",{className:"follow-mode__badge__username",title:r.username,children:r.username})]}),hp("button",{onClick:o,className:"follow-mode__disconnect-btn",children:Jr})]})})}),_S=mD});import tn,{useContext as Bi}from"react";import{flushSync as tb}from"react-dom";import uD from"roughjs/bin/rough";import DS from"clsx";import{nanoid as pD}from"nanoid";import gD from"lodash.throttle";import{Fragment as hD,jsx as Ye,jsxs as fp}from"react/jsx-runtime";var OS,FS,HS,sb,cb,db,mb,ub,pb,ro,li,De,Nt,mi,al,$e,Wt,RS,Hc,rb,ka,zc,ob,nb,Ni,Gc,ib,ab,NS,BS,Uc,Re,lb,zS,be=y(()=>{"use strict";h();Dn();F3();H3();We();Qr();Ar();gi();X();Fl();Ec();ac();ue();ko();ar();Ve();dn();ae();Y3();gr();$3();Y();me();Ea();Zt();Ze();Er();hm();Af();W();Ts();q3();RI();FI();HI();vr();Ih();kn();pt();na();$d();ol();ml();bf();zI();br();ti();df();VI();Xs();_t();Xu();$a();rS();hf();iS();Us();Z1();Mc();uS();pS();Io();bS();wS();Va();vS();IS();CS();_n();Yt();AS();se();vc();PS();OS=tn.createContext(null),FS=tn.createContext(null),HS={viewport:{isMobile:!1,isLandscape:!1},editor:{isMobile:!1,canFitSidebar:!1},isTouchScreen:!1},sb=tn.createContext(HS);sb.displayName="DeviceContext";cb=tn.createContext({container:null,id:null});cb.displayName="ExcalidrawContainerContext";db=tn.createContext([]);db.displayName="ExcalidrawElementsContext";mb=tn.createContext({...$t(),width:0,height:0,offsetLeft:0,offsetTop:0});mb.displayName="ExcalidrawAppStateContext";ub=tn.createContext(()=>{console.warn("Uninitialized ExcalidrawSetAppStateContext context!")});ub.displayName="ExcalidrawSetAppStateContext";pb=tn.createContext(null);pb.displayName="ExcalidrawActionManagerContext";ro=()=>Bi(OS),li=()=>Bi(FS),De=()=>Bi(sb),Nt=()=>Bi(cb),mi=()=>Bi(db),al=()=>Bi(mb),$e=()=>Bi(ub),Wt=()=>Bi(pb),RS=typeof window<"u"&&"ResizeObserver"in window,Hc=!1,rb=0,ka=!1,zc=!1,ob=!1,nb={horizontal:null,vertical:null},Ni=0,Gc=!1,ib=new Map,ab=!1,NS=0,BS=!1,Uc=null,Re={pointers:new Map,lastCenter:null,initialDistance:null,initialScale:null},lb=class e extends tn.Component{canvas;interactiveCanvas=null;rc;unmounted=!1;actionManager;device=HS;excalidrawContainerRef=tn.createRef();scene;renderer;fonts;resizeObserver;nearestScrollableContainer;library;libraryItemsFromStorage;id;history;excalidrawContainerValue;files={};imageCache=new Map;iFrameRefs=new Map;hitLinkElement;lastPointerDownEvent=null;lastPointerUpEvent=null;lastPointerMoveEvent=null;lastViewportPosition={x:0,y:0};laserPathManager=new pp(this);onChangeEmitter=new en;onPointerDownEmitter=new en;onPointerUpEmitter=new en;onUserFollowEmitter=new en;onScrollChangeEmitter=new en;missingPointerEventCleanupEmitter=new en;onRemoveEventListenersEmitter=new en;constructor(t){super(t);let r=$t(),{excalidrawAPI:o,viewModeEnabled:n=!1,zenModeEnabled:i=!1,gridModeEnabled:a=!1,objectsSnapModeEnabled:l=!1,theme:c=r.theme,name:s=r.name}=t;if(this.state={...r,theme:c,isLoading:!0,...this.getCanvasOffsets(),viewModeEnabled:n,zenModeEnabled:i,objectsSnapModeEnabled:l,gridSize:a?nn:null,name:s,width:window.innerWidth,height:window.innerHeight},this.id=pD(),this.library=new W3(this),this.actionManager=new hu(this.syncActionResult,()=>this.state,()=>this.scene.getElementsIncludingDeleted(),this),this.scene=new xe,this.canvas=document.createElement("canvas"),this.rc=uD.canvas(this.canvas),this.renderer=new Fc(this.scene),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,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,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 cp({scene:this.scene,onSceneUpdated:this.onSceneUpdated}),this.history=new K3,this.actionManager.registerAll(Td),this.actionManager.registerAction(N3(this.history)),this.actionManager.registerAction(B3(this.history))}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(cs).includes(n)&&ib.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),Kr(t)))return;let r=this.getHTMLIFrameElement(t);if(r?.contentWindow){if(r.src.includes("youtube")){let o=ib.get(t.id);switch(o||(ib.set(t.id,cs.UNSTARTED),r.contentWindow.postMessage(JSON.stringify({event:"listening",id:t.id}),"*")),o){case cs.PLAYING:case cs.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}updateEmbeddables=()=>{let t=new Set,r=!1;this.scene.getNonDeletedElements().filter(o=>{if(At(o)){if(t.add(o.id),o.validated==null){r=!0;let n=Ka(o.link,this.props.validateEmbeddable);B(o,{validated:n},!1),Te.delete(o)}}else Kr(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=>At(i)&&!!i.validated||Kr(i));return Ye(hD,{children:n.map(i=>{let{x:a,y:l}=Dt({sceneX:i.x,sceneY:i.y},this.state),c;if(Kr(i)){c=null;let u=(i.customData?.generationData??this.magicGenerations.get(i.id))||{status:"error",message:"No generation data",code:"ERR_NO_GENERATION_DATA"};if(u.status==="done"){let p=u.html;c={intrinsicSize:{w:i.width,h:i.height},type:"document",srcdoc:()=>p}}else if(u.status==="pending")c={intrinsicSize:{w:i.width,h:i.height},type:"document",srcdoc:()=>ra(`
|
|
85
|
+
Please output JUST THE HTML file containing your best attempt at implementing the provided wireframes.`;async function kT({image:e,apiKey:t,text:r,theme:o="light"}){let n={model:"gpt-4-vision-preview",max_tokens:4096,temperature:.1,messages:[{role:"system",content:VL},{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}ra();Vt();h();import YL from"clsx";import{jsx as AT,jsxs as $L}from"react/jsx-runtime";var KL="small",zp=e=>$L("label",{className:YL("ToolIcon ToolIcon__MagicButton",`ToolIcon_size_${KL}`,{"is-mobile":e.isMobile}),title:`${e.title}`,children:[AT("input",{className:"ToolIcon_type_checkbox",type:"checkbox",name:e.name,onChange:e.onChange,checked:e.checked,"aria-label":e.title}),AT("div",{className:"ToolIcon__icon",children:e.icon})]});h();import{jsx as Kf,jsxs as MT}from"react/jsx-runtime";var XL=({height:e,width:t,userToFollow:r,onDisconnect:o})=>Kf("div",{className:"follow-mode",style:{width:t,height:e},children:MT("div",{className:"follow-mode__badge",children:[MT("div",{className:"follow-mode__badge__label",children:["Following"," ",Kf("span",{className:"follow-mode__badge__username",title:r.username,children:r.username})]}),Kf("button",{onClick:o,className:"follow-mode__disconnect-btn",children:Yr})]})}),LT=XL;h();var Gp=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}};h();F();W();import{LaserPointer as ZL}from"@excalidraw/laser-pointer";var fa=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(_e,"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 ZL(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=Mt({sceneX:n,sceneY:i},r);return[a.x,a.y]});return d1(o,!0)}};h();F();var Up=class{constructor(t,r){this.animationFrameHandler=t;this.app=r;this.animationFrameHandler.register(this,this.onFrame.bind(this)),this.localTrail=new fa(t,r,{...this.getTrailOptions(),fill:()=>"red"})}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(rn(i),rn(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 fa(this.animationFrameHandler,this.app,{...this.getTrailOptions(),fill:()=>ga(t)}),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))}}};ln();h();de();F();nn();oe();W();He();lt();$t();oi();cd();var jL=(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)`},PT=({id:e,onChange:t,onSubmit:r,getViewportCoords:o,element:n,canvas:i,excalidrawContainer:a,app:l})=>{let s=(A,H)=>{if(!H.style.fontFamily||!H.style.fontSize)return!1;let q=H.style.fontFamily.replace(/"/g,"");return Aa({fontFamily:A.fontFamily})!==q||`${A.fontSize}px`!==H.style.fontSize},c=()=>{let A=l.state,H=rt.getScene(n)?.getElement(e);if(!H)return;let{textAlign:q,verticalAlign:Y}=H,Q=l.scene.getNonDeletedElementsMap();if(H&&G(H)){let fe=H.x,se=H.y,ce=st(H,l.scene.getNonDeletedElementsMap()),Ye=H.width,Nt=H.height,vt=H.width,je=H.height;if(ce&&H.containerId){if(we(ce)){let Tt=V.getBoundTextElementPosition(ce,H,Q);fe=Tt.x,se=Tt.y}let Nr=s(H,d),Jo;if(Nr?Jo=Ki(ce.id,ce.height):(Jo=Yi[ce.id],Jo||(Jo=Ki(ce.id,ce.height))),Ye=mr(ce,H),Nt=$i(ce,H),!we(ce)&&je>Nt){let Tt=mn(je,ce.type);B(ce,{height:Tt});return}else if(!we(ce)&&ce.height>Jo.height&&je<Nt){let Tt=mn(je,ce.type);B(ce,{height:Tt})}else{let{y:Tt}=$a(ce,H,Q);se=Tt}}let[oo,Ii]=o(fe,se),ar=d.selectionStart,Dn=d.selectionEnd,Ci=d.value.length;if(ar===Dn&&Dn!==Ci){let Nr=Ci-Dn;d.selectionStart=d.value.length-Nr,d.selectionEnd=d.value.length-Nr}ce||(Ye=(A.width-8-oo)/A.zoom.value,vt=Math.min(vt,Ye));let ki=(A.height-Ii)/A.zoom.value;Object.assign(d.style,{font:Be(H),lineHeight:H.lineHeight,width:`${vt}px`,height:`${je}px`,left:`${oo}px`,top:`${Ii}px`,transform:jL(vt,je,ux(H,ce),A,Ye,ki),textAlign:q,verticalAlign:Y,color:H.strokeColor,opacity:H.opacity/100,filter:"var(--theme-filter)",maxHeight:`${ki}px`}),d.scrollTop=0,wr()&&(d.style.fontFamily=Aa(H)),B(H,{x:fe,y:se})}},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";Me(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 H=await jd(A,!0);if(!H.text)return;let q=Zn(H.text);if(!q)return;let Y=st(n,l.scene.getNonDeletedElementsMap()),Q=Be({fontSize:l.state.currentItemFontSize,fontFamily:l.state.currentItemFontFamily});if(Y){let fe=ae(Y,l.scene.getNonDeletedElementsMap()),se=qn(`${d.value}${q}`,Q,mr(Y,fe)),ce=Ts(se,Q);d.style.width=`${ce}px`}},d.oninput=()=>{t(Zn(d.value))}),d.onkeydown=A=>{if(!A.shiftKey&&Am.keyTest(A))A.preventDefault(),l.actionManager.executeAction(Am),c();else if(!A.shiftKey&&Mm.keyTest(A))A.preventDefault(),l.actionManager.executeAction(Mm),c();else if(mh.keyTest(A))l.actionManager.executeAction(mh);else if(ph.keyTest(A))l.actionManager.executeAction(ph);else if(A.key===S.ESCAPE)A.preventDefault(),I=!0,k();else if(A.key===S.ENTER&&A[S.CTRL_OR_CMD]){if(A.preventDefault(),A.isComposing||A.keyCode===229)return;I=!0,k()}else if(A.key===S.TAB||A[S.CTRL_OR_CMD]&&(A.code===ue.BRACKET_LEFT||A.code===ue.BRACKET_RIGHT)){if(A.preventDefault(),A.isComposing)return;A.shiftKey||A.code===ue.BRACKET_LEFT?y():E(),d.dispatchEvent(new Event("input"))}};let u=4,g=" ".repeat(u),f=new RegExp(`^ {1,${u}}`),E=()=>{let{selectionStart:A,selectionEnd:H}=d,q=T(),Y=d.value;q.forEach(Q=>{let fe=Y.slice(0,Q),se=Y.slice(Q);Y=`${fe}${g}${se}`}),d.value=Y,d.selectionStart=A+u,d.selectionEnd=H+u*q.length},y=()=>{let{selectionStart:A,selectionEnd:H}=d,q=T(),Y=[],Q=d.value;q.forEach(fe=>{let se=Q.slice(fe,fe+u).match(f);if(se){let ce=Q.slice(0,fe),Ye=Q.slice(fe+se[0].length);Q=`${ce}${Ye}`,Y.push(fe)}}),d.value=Q,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,H-u*Y.length))},T=()=>{let{selectionStart:A,selectionEnd:H,value:q}=d,Y=q.slice(0,A).match(/[^\n]*$/)[0].length;return A=A-Y,q.slice(A,H).split(`
|
|
86
|
+
`).reduce((fe,se,ce,Ye)=>fe.concat(ce?fe[ce-1]+Ye[ce-1].length+1:A),[]).reverse()},w=A=>{A.preventDefault(),A.stopPropagation()},I=!1,k=()=>{C();let A=rt.getScene(n)?.getElement(n.id);if(!A)return;let H=d.value,q=st(A,l.scene.getNonDeletedElementsMap());if(q){if(H=A.text,d.value.trim()){let Y=pn(q);!Y||Y!==n.id?B(q,{boundElements:(q.boundElements||[]).concat({type:"text",id:n.id})}):we(q)&&Eo(q)}else B(q,{boundElements:q.boundElements?.filter(Y=>!G(Y))});zt(A,q,l.scene.getNonDeletedElementsMap())}r({text:H,viaKeyboard:I,originalText:d.value})},C=()=>{L||(L=!0,d.onblur=null,d.oninput=null,d.onkeydown=null,M&&M.disconnect(),window.removeEventListener("resize",c),window.removeEventListener("wheel",w,!0),window.removeEventListener("pointerdown",R),window.removeEventListener("pointerup",D),window.removeEventListener("blur",k),window.removeEventListener("beforeunload",k),z(),d.remove())},D=A=>{window.removeEventListener("pointerup",D);let H=A?.target,q=H instanceof HTMLElement&&H.classList.contains("active-color");setTimeout(()=>{if(d.onblur=k,q){let Y=(fe,se)=>{fe.find(Ye=>Ye.removedNodes.length>0&&Ye.removedNodes[0].dataset?.radixPopperContentWrapper!==void 0)&&(setTimeout(()=>{d.focus()}),se.disconnect())};new MutationObserver(Y).observe(document.querySelector(".excalidraw-container"),{childList:!0})}q||d.focus()})},R=A=>{let H=A.target instanceof HTMLElement&&A.target.classList.contains("active-color");((A.target instanceof HTMLElement||A.target instanceof SVGElement)&&A.target.closest(`.${Lc.SHAPE_ACTIONS_MENU}`)&&!Mo(A.target)||H)&&(d.onblur=null,window.addEventListener("pointerup",D),window.addEventListener("blur",k))},z=rt.getScene(n).addCallback(()=>{c(),!!document.activeElement?.closest(".color-picker-content")||d.focus()}),L=!1;d.select(),D();let M=null;i&&"ResizeObserver"in window?(M=new window.ResizeObserver(()=>{c()}),M.observe(i)):window.addEventListener("resize",c),window.addEventListener("pointerdown",R),window.addEventListener("wheel",w,{passive:!1,capture:!0}),window.addEventListener("beforeunload",k),a?.querySelector(".excalidraw-textEditorContainer").appendChild(d)};Hd();import{Fragment as t8,jsx as Ge,jsxs as Vp}from"react/jsx-runtime";var BT=qo.createContext(null),OT=qo.createContext(null),FT={viewport:{isMobile:!1,isLandscape:!1},editor:{isMobile:!1,canFitSidebar:!1},isTouchScreen:!1},Qf=qo.createContext(FT);Qf.displayName="DeviceContext";var eb=qo.createContext({container:null,id:null});eb.displayName="ExcalidrawContainerContext";var tb=qo.createContext([]);tb.displayName="ExcalidrawElementsContext";var rb=qo.createContext({...er(),width:0,height:0,offsetLeft:0,offsetTop:0});rb.displayName="ExcalidrawAppStateContext";var ob=qo.createContext(()=>{console.warn("Uninitialized ExcalidrawSetAppStateContext context!")});ob.displayName="ExcalidrawSetAppStateContext";var nb=qo.createContext(null);nb.displayName="ExcalidrawActionManagerContext";var $r=()=>Ti(BT),kl=()=>Ti(OT),ke=()=>Ti(Qf),_t=()=>Ti(eb),si=()=>Ti(tb),Al=()=>Ti(rb),Ve=()=>Ti(ob),Wt=()=>Ti(nb),DT=typeof window<"u"&&"ResizeObserver"in window,bc=!1,Xf=0,ba=!1,xc=!1,Zf=!1,jf={horizontal:null,vertical:null},vi=0,Ec=!1,qf=new Map,Wp=!1,RT=0,NT=!1,yc=null,Ae={pointers:new Map,lastCenter:null,initialDistance:null,initialScale:null},Jf=class e extends qo.Component{canvas;interactiveCanvas=null;rc;unmounted=!1;actionManager;device=FT;excalidrawContainerRef=qo.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 Gp;laserTrails=new Up(this.animationFrameHandler,this);eraserTrail=new fa(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(rn(i),rn(n))},fill:()=>this.state.theme===qe.LIGHT?"rgba(0, 0, 0, 0.2)":"rgba(255, 255, 255, 0.2)"});onChangeEmitter=new qr;onPointerDownEmitter=new qr;onPointerUpEmitter=new qr;onUserFollowEmitter=new qr;onScrollChangeEmitter=new qr;missingPointerEventCleanupEmitter=new qr;onRemoveEventListenersEmitter=new qr;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")}-${nu()}`}=t;if(this.state={...r,theme:s,isLoading:!0,...this.getCanvasOffsets(),viewModeEnabled:n,zenModeEnabled:i,objectsSnapModeEnabled:l,gridSize:a?tn:null,name:c,width:window.innerWidth,height:window.innerHeight},this.id=JL(),this.library=new M2(this),this.actionManager=new Um(this.syncActionResult,()=>this.state,()=>this.scene.getElementsIncludingDeleted(),this),this.scene=new rt,this.canvas=document.createElement("canvas"),this.rc=qL.canvas(this.canvas),this.renderer=new fc(this.scene),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,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 Rp({scene:this.scene,onSceneUpdated:this.onSceneUpdated}),this.history=new P2,this.actionManager.registerAll(wd),this.actionManager.registerAction(x2(this.history)),this.actionManager.registerAction(E2(this.history))}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($l).includes(n)&&qf.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),Fr(t)))return;let r=this.getHTMLIFrameElement(t);if(r?.contentWindow){if(r.src.includes("youtube")){let o=qf.get(t.id);switch(o||(qf.set(t.id,$l.UNSTARTED),r.contentWindow.postMessage(JSON.stringify({event:"listening",id:t.id}),"*")),o){case $l.PLAYING:case $l.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),Te.delete(t)};updateEmbeddables=()=>{let t=new Set,r=!1;this.scene.getNonDeletedElements().filter(o=>{if(xt(o)){if(t.add(o.id),!this.embedsValidationStatus.has(o.id)){r=!0;let n=qa(o.link,this.props.validateEmbeddable);this.updateEmbedValidationStatus(o,n)}}else Fr(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=>xt(i)&&this.embedsValidationStatus.get(i.id)===!0||Fr(i));return Ge(t8,{children:n.map(i=>{let{x:a,y:l}=Mt({sceneX:i.x,sceneY:i.y},this.state),s=oa(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(Fr(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 f=g.html;m={intrinsicSize:{w:i.width,h:i.height},type:"document",srcdoc:()=>f}}else if(g.status==="pending")m={intrinsicSize:{w:i.width,h:i.height},type:"document",srcdoc:()=>qi(`
|
|
87
87
|
<style>
|
|
88
88
|
html, body {
|
|
89
89
|
width: 100%;
|
|
@@ -155,7 +155,7 @@ Please output JUST THE HTML file containing your best attempt at implementing th
|
|
|
155
155
|
</svg>
|
|
156
156
|
</div>
|
|
157
157
|
<div>Generating...</div>
|
|
158
|
-
`)};else{let
|
|
158
|
+
`)};else{let f;g.code==="ERR_GENERATION_INTERRUPTED"?f="Generation was interrupted...":f=g.message||"Generation failed",m={intrinsicSize:{w:i.width,h:i.height},type:"document",srcdoc:()=>qi(`
|
|
159
159
|
<style>
|
|
160
160
|
html, body {
|
|
161
161
|
height: 100%;
|
|
@@ -165,7 +165,7 @@ Please output JUST THE HTML file containing your best attempt at implementing th
|
|
|
165
165
|
flex-direction: column;
|
|
166
166
|
align-items: center;
|
|
167
167
|
justify-content: center;
|
|
168
|
-
color: ${
|
|
168
|
+
color: ${ie.red[3]};
|
|
169
169
|
}
|
|
170
170
|
h1, h3 {
|
|
171
171
|
margin-top: 0;
|
|
@@ -173,10 +173,10 @@ Please output JUST THE HTML file containing your best attempt at implementing th
|
|
|
173
173
|
}
|
|
174
174
|
</style>
|
|
175
175
|
<h1>Error!</h1>
|
|
176
|
-
<h3>${
|
|
177
|
-
`)}}}else c=un(Ud(i.link||""));let s=xa(i,r,o,this.state),d=this.state.activeEmbeddable?.element===i&&this.state.activeEmbeddable?.state==="active",m=this.state.activeEmbeddable?.element===i&&this.state.activeEmbeddable?.state==="hover";return Ye("div",{className:DS("excalidraw__embeddable-container",{"is-hovered":m}),style:{transform:s?`translate(${a-this.state.offsetLeft}px, ${l-this.state.offsetTop}px) scale(${t})`:"none",display:s?"block":"none",opacity:i.opacity/100,"--embeddable-radius":`${hi(Math.min(i.width,i.height),i)}px`},children:fp("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:d?Wi.enabled:Wi.disabled},children:[m&&Ye("div",{className:"excalidraw__embeddable-hint",children:f("buttons.embeddableInteractionButton")}),Ye("div",{className:"excalidraw__embeddable__outer",style:{padding:`${i.strokeWidth}px`},children:(At(i)?this.props.renderEmbeddable?.(i,this.state):null)??Ye("iframe",{ref:u=>this.cacheEmbeddableRef(i,u),className:"excalidraw__embeddable",srcDoc:c?.type==="document"?c.srcdoc(this.state.theme):void 0,src:c?.type!=="document"?c?.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:"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=Ue({clientX:n.x,clientY:n.y},this.state),a=Ue({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==="dark",r=0,o=0;return this.scene.getNonDeletedFramesLikes().map(n=>{if(jn(n)?r++:o++,!xa(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}))return null;let{x:i,y:a}=Dt({sceneX:n.x,sceneY:n.y},this.state),l=6,c=()=>{n.name?.trim()===""&&B(n,{name:null}),this.setState({editingFrame:null})},s,d=$m(n,jn(n)?r:o);if(n.id===this.state.editingFrame){let m=d;s=Ye("input",{autoFocus:!0,value:m,onChange:u=>{B(n,{name:u.target.value})},onBlur:()=>c(),onKeyDown:u=>{(u.key===S.ESCAPE||u.key===S.ENTER)&&c()},style:{background:this.state.viewBackgroundColor,filter:t?Da:"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 s=d;return Ye("div",{id:this.getFrameNameDOMId(n),style:{position:"absolute",bottom:`${this.state.height+Qe.nameOffsetY-a+this.state.offsetTop}px`,left:`${i-this.state.offsetLeft}px`,zIndex:2,fontSize:Qe.nameFontSize,color:t?Qe.nameColorDarkTheme:Qe.nameColorLightTheme,lineHeight:Qe.nameLineHeight,width:"max-content",maxWidth:`${n.width}px`,overflow:n.id===this.state.editingFrame?"visible":"hidden",whiteSpace:"nowrap",textOverflow:"ellipsis",cursor:Me.MOVE,pointerEvents:this.state.viewModeEnabled?Wi.disabled:Wi.enabled},onPointerDown:m=>this.handleCanvasPointerDown(m),onWheel:m=>this.handleWheel(m),onContextMenu:this.handleCanvasContextMenu,onDoubleClick:()=>{this.setState({editingFrame:n.id})},children:s},n.id)})};render(){let t=this.scene.getSelectedElements(this.state),{renderTopRightUI:r,renderCustomStats:o}=this.props,n=this.scene.getVersionNonce(),{canvasElements: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.state.editingElement&&te(this.state.editingElement))&&(this.state.selectionElement||this.state.draggingElement||this.state.resizingElement||this.state.activeTool.type==="laser"&&this.state.cursorButton==="down"||this.state.editingElement&&!z(this.state.editingElement)),c=t[0];return Ye("div",{className:DS("excalidraw excalidraw-container",{"excalidraw--view-mode":this.state.viewModeEnabled,"excalidraw--mobile":this.device.editor.isMobile}),style:{"--ui-pointerEvents":l?Wi.disabled:Wi.enabled},ref:this.excalidrawContainerRef,onDrop:this.handleAppOnDrop,tabIndex:0,onKeyDown:this.props.handleKeyboardGlobally?void 0:this.onKeyDown,children:Ye(OS.Provider,{value:this,children:Ye(FS.Provider,{value:this.props,children:Ye(cb.Provider,{value:this.excalidrawContainerValue,children:Ye(sb.Provider,{value:this.device,children:Ye(ub.Provider,{value:this.setAppState,children:Ye(mb.Provider,{value:this.state,children:fp(db.Provider,{value:this.scene.getNonDeletedElements(),children:[fp(pb.Provider,{value:this.actionManager,children:[Ye(DI,{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:rn().code,renderTopRightUI:r,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,children:this.props.children}),Ye("div",{className:"excalidraw-textEditorContainer"}),Ye("div",{className:"excalidraw-contextMenuContainer"}),Ye("div",{className:"excalidraw-eye-dropper-container"}),Ye(fS,{manager:this.laserPathManager}),t.length===1&&this.state.showHyperlinkPopup&&Ye(ay,{element:c,setAppState:this.setAppState,onLinkOpen:this.props.onLinkOpen,setToast:this.setToast},c.id),this.props.aiEnabled!==!1&&t.length===1&&Xi(c)&&Ye(eb,{element:c,children:Ye(gp,{title:f("labels.convertToCode"),icon:Qa,checked:!1,onChange:()=>this.onMagicFrameGenerate(c,"button")})}),t.length===1&&Kr(c)&&c.customData?.generationData?.status==="done"&&fp(eb,{element:c,children:[Ye(gp,{title:f("labels.copySource"),icon:Od,checked:!1,onChange:()=>this.onIframeSrcCopy(c)}),Ye(gp,{title:"Enter fullscreen",icon:Z0,checked:!1,onChange:()=>{let s=this.getHTMLIFrameElement(c);if(s)try{s.requestFullscreen(),this.setState({activeEmbeddable:{element:c,state:"active"},selectedElementIds:{[c.id]:!0},draggingElement:null,selectionElement:null})}catch(d){console.warn(d),this.setState({errorMessage:"Couldn't enter fullscreen"})}}})]}),this.state.toast!==null&&Ye(OI,{message:this.state.toast.message,onClose:()=>this.setToast(null),duration:this.state.toast.duration,closable:this.state.toast.closable}),this.state.contextMenu&&Ye(j3,{items:this.state.contextMenu.items,top:this.state.contextMenu.top,left:this.state.contextMenu.left,actionManager:this.actionManager,onClose:s=>{this.setState({contextMenu:null},()=>{this.focusContainer(),s?.()})}}),Ye(q1,{canvas:this.canvas,rc:this.rc,elements:i,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}}),Ye(j1,{containerRef:this.excalidrawContainerRef,canvas:this.interactiveCanvas,elements: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&&Ye(_S,{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)=>{Ee("export",t,"ui");let n=await va(t,r,this.state,this.files,{exportBackground:this.state.exportBackground,name:this.state.name,viewBackgroundColor:this.state.viewBackgroundColor,exportingFrame:o.exportingFrame}).catch(ud).catch(i=>{console.error(i),this.setState({errorMessage:i.message})});this.state.exportEmbedScene&&n&&_l(n)&&this.setState({fileHandle:n})};magicGenerations=new Map;updateMagicGeneration=({frameElement:t,data:r})=>{r.status==="pending"?B(t,{customData:{generationData:void 0}},!1):B(t,{customData:{generationData:r}},!1),this.magicGenerations.set(t.id,r),this.onSceneUpdated()};getTextFromElements(t){return t.reduce((o,n)=>(z(n)&&o.push(n.text),o),[]).join(`
|
|
176
|
+
<h3>${f}</h3>
|
|
177
|
+
`)}}}else m=xn(yd(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 Ge("div",{className:_T("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:Cg(i,Pt(i,this.scene.getNonDeletedElementsMap()),this.elementsPendingErasure),"--embeddable-radius":`${mo(Math.min(i.width,i.height),i)}px`},children:Vp("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?Li.enabled:Li.disabled},children:[u&&Ge("div",{className:"excalidraw__embeddable-hint",children:b("buttons.embeddableInteractionButton")}),Ge("div",{className:"excalidraw__embeddable__outer",style:{padding:`${i.strokeWidth}px`},children:(xt(i)?this.props.renderEmbeddable?.(i,this.state):null)??Ge("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:"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=Oe({clientX:n.x,clientY:n.y},this.state),a=Oe({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==="dark",r=0,o=0;return this.scene.getNonDeletedFramesLikes().map(n=>{if(Gn(n)?r++:o++,!oa(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}=Mt({sceneX:n.x,sceneY:n.y},this.state),l=6,s=()=>{B(n,{name:n.name?.trim()||null}),this.setState({editingFrame:null})},c,d=Kd(n,Gn(n)?r:o);if(n.id===this.state.editingFrame){let m=d;c=Ge("input",{autoFocus:!0,value:m,onChange:p=>{B(n,{name:p.target.value})},onFocus:p=>p.target.select(),onBlur:()=>s(),onKeyDown:p=>{(p.key===S.ESCAPE||p.key===S.ENTER)&&s()},style:{background:this.state.viewBackgroundColor,filter:t?Sa:"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 Ge("div",{id:this.getFrameNameDOMId(n),style:{position:"absolute",bottom:`${this.state.height+Ue.nameOffsetY-a+this.state.offsetTop}px`,left:`${i-this.state.offsetLeft}px`,zIndex:2,fontSize:Ue.nameFontSize,color:t?Ue.nameColorDarkTheme:Ue.nameColorLightTheme,lineHeight:Ue.nameLineHeight,width:"max-content",maxWidth:`${n.width}px`,overflow:n.id===this.state.editingFrame?"visible":"hidden",whiteSpace:"nowrap",textOverflow:"ellipsis",cursor:Se.MOVE,pointerEvents:this.state.viewModeEnabled?Li.disabled:Li.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&&ee(this.state.editingElement))&&(this.state.selectionElement||this.state.draggingElement||this.state.resizingElement||this.state.activeTool.type==="laser"&&this.state.cursorButton==="down"||this.state.editingElement&&!G(this.state.editingElement)),c=t[0];return Ge("div",{className:_T("excalidraw excalidraw-container",{"excalidraw--view-mode":this.state.viewModeEnabled,"excalidraw--mobile":this.device.editor.isMobile}),style:{"--ui-pointerEvents":s?Li.disabled:Li.enabled},ref:this.excalidrawContainerRef,onDrop:this.handleAppOnDrop,tabIndex:0,onKeyDown:this.props.handleKeyboardGlobally?void 0:this.onKeyDown,onPointerEnter:this.toggleOverscrollBehavior,onPointerLeave:this.toggleOverscrollBehavior,children:Ge(BT.Provider,{value:this,children:Ge(OT.Provider,{value:this.props,children:Ge(eb.Provider,{value:this.excalidrawContainerValue,children:Ge(Qf.Provider,{value:this.device,children:Ge(ob.Provider,{value:this.setAppState,children:Ge(rb.Provider,{value:this.state,children:Vp(tb.Provider,{value:this.scene.getNonDeletedElements(),children:[Vp(nb.Provider,{value:this.actionManager,children:[Ge($3,{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:Qo().code,renderTopRightUI:r,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,children:this.props.children}),Ge("div",{className:"excalidraw-textEditorContainer"}),Ge("div",{className:"excalidraw-contextMenuContainer"}),Ge("div",{className:"excalidraw-eye-dropper-container"}),Ge(CT,{trails:[this.laserTrails,this.eraserTrail]}),t.length===1&&this.state.showHyperlinkPopup&&Ge(m2,{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&&Bi(c)&&Ge(Yf,{element:c,elementsMap:i,children:Ge(zp,{title:b("labels.convertToCode"),icon:bl,checked:!1,onChange:()=>this.onMagicFrameGenerate(c,"button")})}),t.length===1&&Fr(c)&&c.customData?.generationData?.status==="done"&&Vp(Yf,{element:c,elementsMap:i,children:[Ge(zp,{title:b("labels.copySource"),icon:xm,checked:!1,onChange:()=>this.onIframeSrcCopy(c)}),Ge(zp,{title:"Enter fullscreen",icon:jy,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&&Ge(Z3,{message:this.state.toast.message,onClose:()=>this.setToast(null),duration:this.state.toast.duration,closable:this.state.toast.closable}),this.state.contextMenu&&Ge(D2,{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?.()})}}),Ge(Vf,{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}}),Ge(Wf,{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&&Ge(LT,{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)=>{xe("export",t,"ui");let n=await ma(t,r,this.state,this.files,{exportBackground:this.state.exportBackground,name:this.getName(),viewBackgroundColor:this.state.viewBackgroundColor,exportingFrame:o.exportingFrame}).catch(Vc).catch(i=>{console.error(i),this.setState({errorMessage:i.message})});this.state.exportEmbedScene&&n&&ol(n)&&this.setState({fileHandle:n})};magicGenerations=new Map;updateMagicGeneration=({frameElement:t,data:r})=>{r.status==="pending"?B(t,{customData:{generationData:void 0}},!1):B(t,{customData:{generationData:r}},!1),this.magicGenerations.set(t.id,r),this.onSceneUpdated()};getTextFromElements(t){return t.reduce((o,n)=>(G(n)&&o.push(n.text),o),[]).join(`
|
|
178
178
|
|
|
179
|
-
`)}async onMagicFrameGenerate(t,r){if(!this.OPENAI_KEY){this.setState({openDialog:{name:"settings",tab:"diagram-to-code",source:"generation"}}),Ee("ai","generate (missing key)","d2c");return}let o=ha({elements:this.scene.getNonDeletedElements(),bounds:t,type:"overlap"}).filter(m=>!Xi(m));if(!o.length){r==="button"?(this.setState({errorMessage:"Cannot generate from an empty frame"}),Ee("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 Xm({elements:this.scene.getNonDeletedElements(),appState:{...this.state,exportBackground:!0,viewBackgroundColor:this.state.viewBackgroundColor},exportingFrame:t,files:this.files}),a=await zm(i),l=this.getTextFromElements(o);Ee("ai","generate (start)","d2c");let c=await SS({image:a,apiKey:this.OPENAI_KEY,text:l,theme:this.state.theme});if(!c.ok){Ee("ai","generate (failed)","d2c"),console.error(c.error),this.updateMagicGeneration({frameElement:n,data:{status:"error",code:"ERR_OAI",message:c.error?.message||"Unknown error during generation"}});return}if(Ee("ai","generate (success)","d2c"),c.choices[0].message.content==null){this.updateMagicGeneration({frameElement:n,data:{status:"error",code:"ERR_OAI",message:"Nothing genereated :("}});return}let s=c.choices[0].message.content,d=s.slice(s.indexOf("<!DOCTYPE html>"),s.indexOf("</html>")+7);this.updateMagicGeneration({frameElement:n,data:{status:"done",html:d}})}onIframeSrcCopy(t){t.customData?.generationData?.status==="done"&&(Tn(t.customData.generationData.html),this.setToast({message:"copied to clipboard",closable:!1,duration:1500}))}OPENAI_KEY=Tr.get(Wr.OAI_API_KEY);OPENAI_KEY_IS_PERSISTED=Tr.has(Wr.OAI_API_KEY)||!1;onOpenAIKeyChange=(t,r)=>{if(this.OPENAI_KEY=t||null,r){let o=Tr.set(Wr.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"}):Xi(n[0])||this.setActiveTool({type:"magicframe"})};onMagicframeToolSelect=()=>{if(!this.OPENAI_KEY){this.setState({openDialog:{name:"settings",tab:"diagram-to-code",source:"tool"}}),Ee("ai","tool-select (missing key)","d2c");return}let t=this.scene.getSelectedElements({selectedElementIds:this.state.selectedElementIds});if(t.length===0)this.setActiveTool({type:ft.magicframe}),Ee("ai","tool-select (empty-selection)","d2c");else{let r=t.length===1&&Xi(t[0])&&t[0];if(!r&&t.some(n=>J(n)||n.frameId)){this.setActiveTool({type:ft.magicframe});return}Ee("ai","tool-select (existing selection)","d2c");let o;if(r)o=r;else{let[n,i,a,l]=we(t),c=50;o=ys({...Qe,x:n-c,y:i-c,width:a-n+c*2,height:l-i+c*2,opacity:100,locked:!1}),this.scene.addNewElement(o);for(let s of t)B(s,{frameId:o.id});this.setState({selectedElementIds:{[o.id]:!0}})}this.onMagicFrameGenerate(o,"upstream")}};openEyeDropper=({type:t})=>{mr.set(di,{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},commitToHistory:!0}):this.syncActionResult({appState:{...this.state,currentItemBackgroundColor:r},commitToHistory:!0}):this.updateScene({elements:this.scene.getElementsIncludingDeleted().map(a=>this.state.selectedElementIds[a.id]?Q(a,{[n?"strokeColor":"backgroundColor"]:r}):a)})},keepOpenOnAlt:!1})};syncActionResult=it(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&&pc(o)&&(r=o)}),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||r||this.state.contextMenu){t.commitToHistory&&this.history.resumeRecording();let o=t?.appState?.viewModeEnabled||!1,n=t?.appState?.zenModeEnabled||!1,i=t?.appState?.gridSize||null,a=t?.appState?.theme||this.props.theme||nt.LIGHT,l=t?.appState?.name??this.state.name,c=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?nn:null),typeof this.props.name<"u"&&(l=this.props.name),r=r||t.appState?.editingElement||null,r?.isDeleted&&(r=null),this.setState(s=>Object.assign(t.appState||{},{contextMenu:null,editingElement:r,viewModeEnabled:o,zenModeEnabled:n,gridSize:i,theme:a,name:l,errorMessage:c}),()=>{t.syncHistory&&this.history.setCurrentState(this.state,this.scene.getElementsIncludingDeleted())})}});onBlur=it(()=>{ka=!1,this.setState({isBindingEnabled:!0})});onUnload=()=>{this.onBlur()};disableEvent=t=>{t.preventDefault()};resetHistory=()=>{this.history.clear()};resetScene=it(t=>{this.scene.replaceAllElements([]),this.setState(r=>({...$t(),isLoading:t?.resetLoadingState?!1:r.isLoading,theme:this.state.theme})),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=xi(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,...Ko(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.resetHistory(),this.syncActionResult({...r,commitToHistory:!0})};isMobileBreakpoint=(t,r)=>t<Zb||r<qb&&t<jb;refreshViewportBreakpoints=()=>{if(!this.excalidrawContainerRef.current)return;let{clientWidth:r,clientHeight:o}=document.body,n=this.device.viewport,i=Fa(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:Jb,i=this.device.editor,a=Fa(i,{isMobile:this.isMobileBreakpoint(r,o),canFitSidebar:r>n});return i!==a?(this.device={...this.device,editor:a},!0):!1};async componentDidMount(){if(console.log("HELLO IS"),this.unmounted=!1,this.excalidrawContainerValue.container=this.excalidrawContainerRef.current,I.MODE===Sp.TEST||I.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}})}this.scene.addCallback(this.onSceneUpdated),this.addEventListeners(),this.props.autoFocus&&this.excalidrawContainerRef.current&&this.focusContainer(),kr()||(this.refreshViewportBreakpoints(),this.refreshEditorBreakpoints()),RS&&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),zb()&&!c2()&&this.setState({errorMessage:Ye(nS,{})})}componentWillUnmount(){this.renderer.destroy(),this.scene=new xe,this.renderer=new Fc(this.scene),this.files={},this.imageCache.clear(),this.resizeObserver?.disconnect(),this.unmounted=!0,this.removeEventListeners(),this.scene.destroy(),this.library.destroy(),this.laserPathManager.destroy(),this.onChangeEmitter.clear(),Te.destroy(),uo.destroy(),clearTimeout(Ni),ze.clearCache(),Ht.clearCache(),Ni=0}onResize=it(()=>{this.scene.getElementsIncludingDeleted().forEach(t=>Te.delete(t)),this.refreshViewportBreakpoints(),this.updateDOMRect(),RS||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(mt(document,"keydown",this.onKeyDown,!1)),this.onRemoveEventListenersEmitter.once(mt(this.excalidrawContainerRef.current,"wheel",this.onWheel,{passive:!1}),mt(window,"message",this.onWindowMessage,!1),mt(document,"pointerup",this.removePointer),mt(document,"copy",this.onCopy),mt(document,"keyup",this.onKeyUp,{passive:!0}),mt(document,"mousemove",this.updateCurrentCursorPosition),mt(document.fonts,"loadingdone",t=>{let r=t.fontfaces;this.fonts.onFontsLoaded(r)}),mt(document,"gesturestart",this.onGestureStart,!1),mt(document,"gesturechange",this.onGestureChange,!1),mt(document,"gestureend",this.onGestureEnd,!1),mt(window,"focus",()=>{this.maybeCleanupAfterMissingPointerUp(null)})),!this.state.viewModeEnabled&&(this.onRemoveEventListenersEmitter.once(mt(document,"fullscreenchange",this.onFullscreenChange),mt(document,"paste",this.pasteFromClipboard),mt(document,"cut",this.onCut),mt(window,"resize",this.onResize,!1),mt(window,"unload",this.onUnload,!1),mt(window,"blur",this.onBlur,!1),mt(this.excalidrawContainerRef.current,"dragover",this.disableEvent,!1),mt(this.excalidrawContainerRef.current,"drop",this.disableEvent,!1)),this.props.detectScroll&&this.onRemoveEventListenersEmitter.once(mt(fx(this.excalidrawContainerRef.current),"scroll",this.onScroll)))}componentDidUpdate(t,r){this.updateEmbeddables(),!this.state.showWelcomeScreen&&!this.scene.getElementsIncludingDeleted().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(),(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&&$r(this.state)&&this.setState({activeTool:Xe(this.state,{type:"selection"})}),this.state.activeTool.type==="eraser"&&r.theme!==this.state.theme&&jp(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(),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?nn:null}),this.props.name&&t.name!==this.props.name&&this.setState({name:this.props.name}),this.excalidrawContainerRef.current?.classList.toggle("theme--dark",this.state.theme==="dark"),this.state.editingLinearElement&&!this.state.selectedElementIds[this.state.editingLinearElement.elementId]&&setTimeout(()=>{this.state.editingLinearElement&&this.actionManager.executeAction(lo)}),this.state.editingElement?.isDeleted&&this.setState({editingElement:null}),this.state.selectedLinearElement&&!this.state.selectedElementIds[this.state.selectedLinearElement.elementId]&&this.setState({selectedLinearElement:null});let{multiElement:n}=r;r.activeTool!==this.state.activeTool&&n!=null&&Uo(this.state)&&Et(n,!1)&&Bs(n,this.state,this.scene,xo(K.getPointAtIndexGlobalCoordinates(n,-1))),this.history.record(this.state,this.scene.getElementsIncludingDeleted()),this.state.isLoading||(this.props.onChange?.(this.scene.getElementsIncludingDeleted(),this.state,this.files),this.onChangeEmitter.trigger(this.scene.getElementsIncludingDeleted(),this.state,this.files))}renderInteractiveSceneCallback=({atLeastOneVisibleElement:t,scrollBars:r,elements:o})=>{r&&(nb=r);let n=z(this.state.editingElement)?!1:!t&&o.length>0;this.state.scrolledOutside!==n&&this.setState({scrolledOutside:n}),this.scheduleImageRefresh()};onScroll=$i(()=>{let{offsetTop:t,offsetLeft:r}=this.getCanvasOffsets();this.setState(o=>o.offsetLeft===r&&o.offsetTop===t?null:{offsetTop:t,offsetLeft:r})},$b);onCut=it(t=>{!this.excalidrawContainerRef.current?.contains(document.activeElement)||Oo(t.target)||(this.actionManager.executeAction(du,"keyboard",t),t.preventDefault(),t.stopPropagation())});onCopy=it(t=>{!this.excalidrawContainerRef.current?.contains(document.activeElement)||Oo(t.target)||(this.actionManager.executeAction(Ul,"keyboard",t),t.preventDefault(),t.stopPropagation())});static resetTapTwice(){Hc=!1}onTouchStart=t=>{if(Hb&&t.preventDefault(),!Hc){Hc=!0,clearTimeout(rb),rb=window.setTimeout(e.resetTapTwice,Yb);return}if(Hc&&t.touches.length===1){let r=t.touches[0];this.handleCanvasDoubleClick({clientX:r.clientX,clientY:r.clientY}),Hc=!1,clearTimeout(rb)}t.touches.length===2&&this.setState({selectedElementIds:Pe({},this.state),activeEmbeddable:null})};onTouchEnd=t=>{this.resetContextMenuTimer(),t.touches.length>0?this.setState({previousSelectedElementIds:{},selectedElementIds:Pe(this.state.previousSelectedElementIds,this.state)}):Re.pointers.clear()};pasteFromClipboard=it(async t=>{let r=!!ab,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)||Oo(o)))return;let{x:a,y:l}=Ue({clientX:this.lastViewportPosition.x,clientY:this.lastViewportPosition.y},this.state),c=t?.clipboardData?.files[0],s=await Tm(t,r);if(!c&&!r){if(s.mixedContent)return this.addElementsFromMixedContentPaste(s.mixedContent,{isPlainPaste:r,sceneX:a,sceneY:l});if(s.text){let d=s.text.trim();d.startsWith("<svg")&&d.endsWith("</svg>")&&(c=yh(d))}}if(Ei(c)&&!s.spreadsheet){if(!this.isToolSupported("image")){this.setState({errorMessage:f("errors.imageToolNotSupported")});return}let d=this.createImageElement({sceneX:a,sceneY:l});this.insertImageElement(d,c),this.initializeImageDimensions(d),this.setState({selectedElementIds:Pe({[d.id]:!0},this.state)});return}if(this.props.onPaste)try{if(await this.props.onPaste(s,t)===!1)return}catch(d){console.error(d)}if(s.errorMessage)this.setState({errorMessage:s.errorMessage});else if(s.spreadsheet&&!r)this.setState({pasteDialog:{data:s.spreadsheet,shown:!0}});else if(s.elements){let d=s.programmaticAPI?Rc(s.elements):s.elements;this.addElementsFromPasteOrLibrary({elements:d,files:s.files||null,position:"cursor",retainSeed:r})}else if(s.text){let d=iE(s.text);if(!r&&Ka(d,this.props.validateEmbeddable)&&(/^(http|https):\/\/[^\s/$.?#].[^\s]*$/.test(d)||un(d)?.type==="video")){let m=this.insertEmbeddableElement({sceneX:a,sceneY:l,link:ir(d)});m&&this.setState({selectedElementIds:{[m.id]:!0}});return}this.addTextFromPaste(s.text,r)}this.setActiveTool({type:"selection"}),t?.preventDefault()});addElementsFromPasteOrLibrary=t=>{let r=nc(t.elements,null,void 0),[o,n,i,a]=we(r),l=kt(o,i)/2,c=kt(n,a)/2,s=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:u}=Ue({clientX:s,clientY:d},this.state),p=m-l,g=u-c,[b,E]=wt(p,g,this.state.gridSize),w=Ad(r.map(k=>Q(k,{x:k.x+b-o,y:k.y+E-n})),{randomizeSeed:!t.retainSeed}),v=[...this.scene.getElementsIncludingDeleted(),...w];this.scene.replaceAllElements(v),w.forEach(k=>{if(z(k)&&ke(k)){let M=je(k);Gt(k,M)}}),t.files&&(this.files={...this.files,...t.files}),this.history.resumeRecording();let T=ba(w);this.setState({...this.state,openSidebar:this.state.openSidebar&&this.device.editor.canFitSidebar&&mr.get(Ac)?this.state.openSidebar:null,...Ht({editingGroupId:null,selectedElementIds:T.reduce((k,M)=>(ke(M)||(k[M.id]=!0),k),{})},this.scene.getNonDeletedElements(),this.state,this)},()=>{t.files&&this.addNewImagesToImageCache()}),this.setActiveTool({type:"selection"}),t.fitToContent&&this.scrollToContent(w,{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 ov(m)}}catch(u){return{errorMessage:u.message}}})),l=n,c=!1,s={};for(let m of a)if(m.file){let u=this.createImageElement({sceneX:o,sceneY:l}),p=await this.insertImageElement(u,m.file);p&&(c||(c=!0,l-=p.height/2),B(p,{y:l},!1),l=u.y+u.height+25,s[u.id]=!0)}this.setState({selectedElementIds:Pe(s,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(`
|
|
179
|
+
`)}async onMagicFrameGenerate(t,r){if(!this.OPENAI_KEY){this.setState({openDialog:{name:"settings",tab:"diagram-to-code",source:"generation"}}),xe("ai","generate (missing key)","d2c");return}let o=al(this.scene.getNonDeletedElements(),t).filter(m=>!Bi(m));if(!o.length){r==="button"?(this.setState({errorMessage:"Cannot generate from an empty frame"}),xe("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 Jd({elements:this.scene.getNonDeletedElements(),appState:{...this.state,exportBackground:!0,viewBackgroundColor:this.state.viewBackgroundColor},exportingFrame:t,files:this.files}),a=await _d(i),l=this.getTextFromElements(o);xe("ai","generate (start)","d2c");let s=await kT({image:a,apiKey:this.OPENAI_KEY,text:l,theme:this.state.theme});if(!s.ok){xe("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(xe("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"&&(Sn(t.customData.generationData.html),this.setToast({message:"copied to clipboard",closable:!1,duration:1500}))}OPENAI_KEY=br.get(Br.OAI_API_KEY);OPENAI_KEY_IS_PERSISTED=br.has(Br.OAI_API_KEY)||!1;onOpenAIKeyChange=(t,r)=>{if(this.OPENAI_KEY=t||null,r){let o=br.set(Br.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"}):Bi(n[0])||this.setActiveTool({type:"magicframe"})};onMagicframeToolSelect=()=>{if(!this.OPENAI_KEY){this.setState({openDialog:{name:"settings",tab:"diagram-to-code",source:"tool"}}),xe("ai","tool-select (missing key)","d2c");return}let t=this.scene.getSelectedElements({selectedElementIds:this.state.selectedElementIds});if(t.length===0)this.setActiveTool({type:ht.magicframe}),xe("ai","tool-select (empty-selection)","d2c");else{let r=t.length===1&&Bi(t[0])&&t[0];if(!r&&t.some(n=>X(n)||n.frameId)){this.setActiveTool({type:ht.magicframe});return}xe("ai","tool-select (existing selection)","d2c");let o;if(r)o=r;else{let[n,i,a,l]=ye(t),s=50;o=Ss({...Ue,x:n-s,y:i-s,width:a-n+s*2,height:l-i+s*2,opacity:100,locked:!1}),this.scene.addNewElement(o);for(let c of t)B(c,{frameId:o.id});this.setState({selectedElementIds:{[o.id]:!0}})}this.onMagicFrameGenerate(o,"upstream")}};openEyeDropper=({type:t})=>{sr.set(li,{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},commitToHistory:!0}):this.syncActionResult({appState:{...this.state,currentItemBackgroundColor:r},commitToHistory:!0}):this.updateScene({elements:this.scene.getElementsIncludingDeleted().map(a=>this.state.selectedElementIds[a.id]?te(a,{[n?"strokeColor":"backgroundColor"]:r}):a)})},keepOpenOnAlt:!1})};syncActionResult=nt(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&&os(o)&&(r=o)}),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||r||this.state.contextMenu){t.commitToHistory&&this.history.resumeRecording();let o=t?.appState?.viewModeEnabled||!1,n=t?.appState?.zenModeEnabled||!1,i=t?.appState?.gridSize||null,a=t?.appState?.theme||this.props.theme||qe.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?tn: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}),()=>{t.syncHistory&&this.history.setCurrentState(this.state,this.scene.getElementsIncludingDeleted())})}});onBlur=nt(()=>{ba=!1,this.setState({isBindingEnabled:!0})});onUnload=()=>{this.onBlur()};disableEvent=t=>{t.preventDefault()};resetHistory=()=>{this.history.clear()};resetScene=nt(t=>{this.scene.replaceAllElements([]),this.setState(r=>({...er(),isLoading:t?.resetLoadingState?!1:r.isLoading,theme:this.state.theme})),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=Qn(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,...Ho(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.resetHistory(),this.syncActionResult({...r,commitToHistory:!0})};isMobileBreakpoint=(t,r)=>t<Hb||r<Gb&&t<zb;refreshViewportBreakpoints=()=>{if(!this.excalidrawContainerRef.current)return;let{clientWidth:r,clientHeight:o}=document.body,n=this.device.viewport,i=La(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:Ub,i=this.device.editor,a=La(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,v.MODE===Jp.TEST||v.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}})}this.scene.addCallback(this.onSceneUpdated),this.addEventListeners(),this.props.autoFocus&&this.excalidrawContainerRef.current&&this.focusContainer(),wr()||(this.refreshViewportBreakpoints(),this.refreshEditorBreakpoints()),DT&&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),Lb()&&!bx()&&this.setState({errorMessage:Ge(mT,{})})}componentWillUnmount(){this.renderer.destroy(),this.scene=new rt,this.renderer=new fc(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(),Te.destroy(),Qr.destroy(),clearTimeout(vi),Re.clearCache(),Gt.clearCache(),vi=0,document.documentElement.style.overscrollBehaviorX=""}onResize=nt(()=>{this.scene.getElementsIncludingDeleted().forEach(t=>Te.delete(t)),this.refreshViewportBreakpoints(),this.updateDOMRect(),DT||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(dt(document,"keydown",this.onKeyDown,!1)),this.onRemoveEventListenersEmitter.once(dt(this.excalidrawContainerRef.current,"wheel",this.onWheel,{passive:!1}),dt(window,"message",this.onWindowMessage,!1),dt(document,"pointerup",this.removePointer),dt(document,"copy",this.onCopy),dt(document,"keyup",this.onKeyUp,{passive:!0}),dt(document,"mousemove",this.updateCurrentCursorPosition),dt(document.fonts,"loadingdone",t=>{let r=t.fontfaces;this.fonts.onFontsLoaded(r)}),dt(document,"gesturestart",this.onGestureStart,!1),dt(document,"gesturechange",this.onGestureChange,!1),dt(document,"gestureend",this.onGestureEnd,!1),dt(window,"focus",()=>{this.maybeCleanupAfterMissingPointerUp(null)})),!this.state.viewModeEnabled&&(this.onRemoveEventListenersEmitter.once(dt(document,"fullscreenchange",this.onFullscreenChange),dt(document,"paste",this.pasteFromClipboard),dt(document,"cut",this.onCut),dt(window,"resize",this.onResize,!1),dt(window,"unload",this.onUnload,!1),dt(window,"blur",this.onBlur,!1),dt(this.excalidrawContainerRef.current,"dragover",this.disableEvent,!1),dt(this.excalidrawContainerRef.current,"drop",this.disableEvent,!1)),this.props.detectScroll&&this.onRemoveEventListenersEmitter.once(dt(o1(this.excalidrawContainerRef.current),"scroll",this.onScroll)))}componentDidUpdate(t,r){this.updateEmbeddables();let o=this.scene.getElementsIncludingDeleted(),n=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(),(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&&ur(this.state)&&this.setState({activeTool:Ke(this.state,{type:"selection"})}),this.state.activeTool.type==="eraser"&&r.theme!==this.state.theme&&Xu(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(),ur(r)&&!ur(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?tn:null}),this.excalidrawContainerRef.current?.classList.toggle("theme--dark",this.state.theme==="dark"),this.state.editingLinearElement&&!this.state.selectedElementIds[this.state.editingLinearElement.elementId]&&setTimeout(()=>{this.state.editingLinearElement&&this.actionManager.executeAction(Zr)}),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}=r;r.activeTool!==this.state.activeTool&&a!=null&&Ro(this.state)&&Et(a,!1)&&Es(a,this.state,this.scene,lo(V.getPointAtIndexGlobalCoordinates(a,-1,n)),n),this.history.record(this.state,o),this.state.isLoading||(this.props.onChange?.(o,this.state,this.files),this.onChangeEmitter.trigger(o,this.state,this.files))}renderInteractiveSceneCallback=({atLeastOneVisibleElement:t,scrollBars:r,elementsMap:o})=>{r&&(jf=r);let n=G(this.state.editingElement)?!1:!t&&o.size>0;this.state.scrolledOutside!==n&&this.setState({scrolledOutside:n}),this.scheduleImageRefresh()};onScroll=Ni(()=>{let{offsetTop:t,offsetLeft:r}=this.getCanvasOffsets();this.setState(o=>o.offsetLeft===r&&o.offsetTop===t?null:{offsetTop:t,offsetLeft:r})},Ob);onCut=nt(t=>{!this.excalidrawContainerRef.current?.contains(document.activeElement)||Mo(t.target)||(this.actionManager.executeAction(Bm,"keyboard",t),t.preventDefault(),t.stopPropagation())});onCopy=nt(t=>{!this.excalidrawContainerRef.current?.contains(document.activeElement)||Mo(t.target)||(this.actionManager.executeAction(Il,"keyboard",t),t.preventDefault(),t.stopPropagation())});static resetTapTwice(){bc=!1}onTouchStart=t=>{if(Mb&&t.preventDefault(),!bc){bc=!0,clearTimeout(Xf),Xf=window.setTimeout(e.resetTapTwice,Nb);return}if(bc&&t.touches.length===1){let r=t.touches[0];this.handleCanvasDoubleClick({clientX:r.clientX,clientY:r.clientY}),bc=!1,clearTimeout(Xf)}t.touches.length===2&&this.setState({selectedElementIds:Ce({},this.state),activeEmbeddable:null})};onTouchEnd=t=>{this.resetContextMenuTimer(),t.touches.length>0?this.setState({previousSelectedElementIds:{},selectedElementIds:Ce(this.state.previousSelectedElementIds,this.state)}):Ae.pointers.clear()};pasteFromClipboard=nt(async t=>{let r=!!Wp,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)||Mo(o)))return;let{x:a,y:l}=Oe({clientX:this.lastViewportPosition.x,clientY:this.lastViewportPosition.y},this.state),s=t?.clipboardData?.files[0],c=await jd(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=lg(d))}}if(ei(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:Ce({[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?mc(c.elements):c.elements;this.addElementsFromPasteOrLibrary({elements:d,files:c.files||null,position:"cursor",retainSeed:r})}else if(c.text){let d=Xc(c.text).split(/\n+/).map(p=>p.trim()).filter(Boolean),m=d.map(p=>Nx(p)).filter(p=>qa(p,this.props.validateEmbeddable)&&(/^(http|https):\/\/[^\s/$.?#].[^\s]*$/.test(p)||xn(p)?.type==="video"));if(!Wp&&m.length>0&&m.length===d.length){let p=[];for(let u of m){let g=p[p.length-1],f=this.insertEmbeddableElement({sceneX:g?g.x+g.width+20:a,sceneY:l,link:tr(u)});f&&p.push(f)}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=Ls(t.elements,null,void 0),[o,n,i,a]=ye(r),l=Ct(o,i)/2,s=Ct(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}=Oe({clientX:c,clientY:d},this.state),u=m-l,g=p-s,[f,E]=yt(u,g,this.state.gridSize),y=Cd(r.map(k=>te(k,{x:k.x+f-o,y:k.y+E-n})),{randomizeSeed:!t.retainSeed}),T=[...this.scene.getElementsIncludingDeleted(),...y],w=this.getTopLayerFrameAtSceneCoords({x:m,y:p});if(w){let k=UE(y,w);Gs(T,k,w)}this.scene.replaceAllElements(T),y.forEach(k=>{if(G(k)&&Me(k)){let C=st(k,this.scene.getElementsMapIncludingDeleted());zt(k,C,this.scene.getElementsMapIncludingDeleted())}}),t.files&&(this.files={...this.files,...t.files}),this.history.resumeRecording();let I=aa(y);this.setState({...this.state,openSidebar:this.state.openSidebar&&this.device.editor.canFitSidebar&&sr.get(lc)?this.state.openSidebar:null,...Gt({editingGroupId:null,selectedElementIds:I.reduce((k,C)=>(Me(C)||(k[C.id]=!0),k),{})},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: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 oE(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),B(u,{y:l},!1),l=p.y+p.height+25,c[p.id]=!0)}this.setState({selectedElementIds:Ce(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(`
|
|
180
180
|
|
|
181
|
-
`),r)}}addTextFromPaste(t,r=!1){let{x:o,y:n}=
|
|
182
|
-
`),s=c.reduce((m,u,p)=>{let g=u.trim(),b=Dr(i.fontFamily);if(g.length){let E=this.getTopLayerFrameAtSceneCoords({x:o,y:l}),w=Rt({...i,x:o,y:l,text:g,lineHeight:b,frameId:E?E.id:null});m.push(w),l+=w.height+a}else c[p-1]?.trim()&&(l+=pa(i.fontSize,b)+a);return m},[]);if(s.length===0)return;let d=s[0].frameId;d?this.scene.insertElementsAtIndex(s,this.scene.getElementIndex(d)):this.scene.replaceAllElements([...this.scene.getElementsIncludingDeleted(),...s]),this.setState({selectedElementIds:Pe(Object.fromEntries(s.map(m=>[m.id,!0])),this.state)}),!r&&s.length>1&&BS===!1&&!this.device.editor.isMobile&&(this.setToast({message:f("toast.pasteAsSingleElement",{shortcut:_("CtrlOrCmd+Shift+V")}),duration:5e3}),BS=!0),this.history.resumeRecording()}setAppState=(t,r)=>{this.setState(t,r)};removePointer=t=>{Ni&&this.resetContextMenuTimer(),Re.pointers.delete(t.pointerId)};toggleLock=(t="ui")=>{this.state.activeTool.locked||Ee("toolbar","toggleLock",`${t} (${this.device.editor.isMobile?"mobile":"desktop"})`),this.setState(r=>({activeTool:{...r.activeTool,...Xe(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(Kw)};zoomCanvas=t=>{this.setState({...vn({viewportX:this.state.width/2+this.state.offsetLeft,viewportY:this.state.height/2+this.state.offsetTop,nextZoom:$o(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}=$s({targetElements:o,appState:this.state,fitToViewport:!!r?.fitToViewport,viewportZoomFactor:r?.viewportZoomFactor});n=l.zoom,i=l.scrollX,a=l.scrollY}else{let l=Ko(o,this.state);i=l.scrollX,a=l.scrollY}if(r?.animate){let l=this.state.scrollX,c=this.state.scrollY,s=this.state.zoom.value,d=gx({fromValues:{scrollX:l,scrollY:c,zoom:s},toValues:{scrollX:i,scrollY:a,zoom:n.value},interpolateValue:(m,u,p,g)=>{if(g==="zoom")return m*Math.pow(u/m,md(p))},onStep:({scrollX:m,scrollY:u,zoom:p})=>{this.setState({scrollX:m,scrollY:u,zoom:{value:p}})},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,ss,window.location.pathname)}}catch(t){this.setState({errorMessage:t.message})}};addFiles=it(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=>{ur(o)&&r.has(o.fileId)&&(this.imageCache.delete(o.fileId),Te.delete(o))}),this.scene.informMutation(),this.addNewImagesToImageCache()});updateScene=it(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:r,force:o})=>{let n;return o===void 0?n=this.state.openSidebar?.name===t?null:t:n=o?t:null,this.setState({openSidebar:n?{name:n,tab:r}:null}),!!n};updateCurrentCursorPosition=it(t=>{this.lastViewportPosition.x=t.clientX,this.lastViewportPosition.y=t.clientY});onKeyDown=it(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[S.CTRL_OR_CMD]&&t.key.toLowerCase()===S.V&&(ab=t.shiftKey,clearTimeout(NS),NS=window.setTimeout(()=>{ab=!1},100)),t[S.CTRL_OR_CMD]&&Oo(t.target)&&(t.code===de.MINUS||t.code===de.EQUAL)){t.preventDefault();return}if(Oo(t.target)&&t.key!==S.ESCAPE||el(t.key)&&Pp(t.target))return;if(t.key===S.QUESTION_MARK){this.setState({openDialog:{name:"help"}});return}else if(t.key.toLowerCase()===S.E&&t.shiftKey&&t[S.CTRL_OR_CMD]){t.preventDefault(),this.setState({openDialog:{name:"imageExport"}});return}if(t.key===S.PAGE_UP||t.key===S.PAGE_DOWN){let i=(t.shiftKey?this.state.width:this.state.height)/this.state.zoom.value;t.key===S.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[S.CTRL_OR_CMD]&&this.state.isBindingEnabled&&this.setState({isBindingEnabled:!1}),el(t.key)){let i=this.state.gridSize&&(t.shiftKey?Ip:this.state.gridSize)||(t.shiftKey?Gb:Ip),a=0,l=0;t.key===S.ARROW_LEFT?a=-i:t.key===S.ARROW_RIGHT?a=i:t.key===S.ARROW_UP?l=-i:t.key===S.ARROW_DOWN&&(l=i);let c=this.scene.getSelectedElements({selectedElementIds:this.state.selectedElementIds,includeBoundTextElement:!0,includeElementsInFrames:!0});c.forEach(s=>{B(s,{x:s.x+a,y:s.y+l}),Co(s,{simultaneouslyUpdated:c})}),this.maybeSuggestBindingForAll(c),t.preventDefault()}else if(t.key===S.ENTER){let i=this.scene.getSelectedElements(this.state);if(i.length===1){let a=i[0];if(t[S.CTRL_OR_CMD])te(a)&&(!this.state.editingLinearElement||this.state.editingLinearElement.elementId!==i[0].id)&&(this.history.resumeRecording(),this.setState({editingLinearElement:new K(a,this.scene)}));else if(z(a)||s2(a)){let l;z(a)||(l=a);let c=_m(a,this.state),s=c.x,d=c.y;this.startTextEditing({sceneX:s,sceneY:d,container:l}),t.preventDefault();return}else J(a)&&this.setState({editingFrame:a.id})}}else if(!t.ctrlKey&&!t.altKey&&!t.metaKey&&this.state.draggingElement===null){let i=X3(t.key);i?(this.state.activeTool.type!==i&&Ee("toolbar",i,`keyboard (${this.device.editor.isMobile?"mobile":"desktop"})`),this.setActiveTool({type:i}),t.stopPropagation()):t.key===S.Q&&(this.toggleLock("keyboard"),t.stopPropagation())}if(t.key===S.SPACE&&Re.pointers.size===0&&(ka=!0,Oe(this.interactiveCanvas,Me.GRAB),t.preventDefault()),(t.key===S.G||t.key===S.S)&&!t.altKey&&!t[S.CTRL_OR_CMD]){let i=this.scene.getSelectedElements(this.state);if(this.state.activeTool.type==="selection"&&!i.length)return;t.key===S.G&&(wn(this.state.activeTool.type)||i.some(a=>wn(a.type)))&&(this.setState({openPopup:"elementBackground"}),t.stopPropagation()),t.key===S.S&&(this.setState({openPopup:"elementStroke"}),t.stopPropagation())}if(t.key===S.K&&!t.altKey&&!t[S.CTRL_OR_CMD]){this.state.activeTool.type==="laser"?this.setActiveTool({type:"selection"}):this.setActiveTool({type:"laser"});return}t[S.CTRL_OR_CMD]&&(t.key===S.BACKSPACE||t.key===S.DELETE)&&mr.set(Lc,"clearCanvas");let r=t.key.toLocaleLowerCase(),o=r===S.S&&t.shiftKey,n=t.key===S.I||r===S.G&&t.shiftKey;(o||n)&&this.openEyeDropper({type:o?"stroke":"background"})});onWheel=it(t=>{!(t.target instanceof HTMLCanvasElement)&&t.ctrlKey&&t.preventDefault()});onKeyUp=it(t=>{if(t.key===S.SPACE&&(this.state.viewModeEnabled?Oe(this.interactiveCanvas,Me.GRAB):this.state.activeTool.type==="selection"?Mr(this.interactiveCanvas):(Lr(this.interactiveCanvas,this.state),this.setState({selectedElementIds:Pe({},this.state),selectedGroupIds:{},editingGroupId:null,activeEmbeddable:null})),ka=!1),!t[S.CTRL_OR_CMD]&&!this.state.isBindingEnabled&&this.setState({isBindingEnabled:!0}),el(t.key)){let r=this.scene.getSelectedElements(this.state);Uo(this.state)?Ns(r):Os(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 r=Xe(this.state,t);r.type==="hand"?Oe(this.interactiveCanvas,Me.GRAB):ka||Lr(this.interactiveCanvas,this.state),ux(document.activeElement)&&this.focusContainer(),fs(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};return r.type!=="selection"?{...o,activeTool:r,selectedElementIds:Pe({},o),selectedGroupIds:Pe({},o),editingGroupId:null,multiElement:null,...n}:{...o,activeTool:r,...n}})};setOpenDialog=t=>{this.setState({openDialog:t})};setCursor=t=>{Oe(this.interactiveCanvas,t)};resetCursor=()=>{Mr(this.interactiveCanvas)};isTouchScreenMultiTouchGesture=()=>Re.pointers.size>=2;onGestureStart=it(t=>{t.preventDefault(),this.isTouchScreenMultiTouchGesture()&&this.setState({selectedElementIds:Pe({},this.state),activeEmbeddable:null}),Re.initialScale=this.state.zoom.value});onGestureChange=it(t=>{if(t.preventDefault(),this.isTouchScreenMultiTouchGesture())return;let r=Re.initialScale;r&&this.setState(o=>({...vn({viewportX:this.lastViewportPosition.x,viewportY:this.lastViewportPosition.y,nextZoom:$o(r*t.scale)},o)}))});onGestureEnd=it(t=>{t.preventDefault(),this.isTouchScreenMultiTouchGesture()&&this.setState({previousSelectedElementIds:{},selectedElementIds:Pe(this.state.previousSelectedElementIds,this.state)}),Re.initialScale=null});handleTextWysiwyg(t,{isExistingElement:r=!1}){let o=(n,i,a)=>{this.scene.replaceAllElements([...this.scene.getElementsIncludingDeleted().map(l=>l.id===t.id&&z(l)?Jp(l,{text:n,isDeleted:a,originalText:i}):l)])};jg({id:t.id,canvas:this.canvas,getViewportCoords:(n,i)=>{let{x:a,y:l}=Dt({sceneX:n,sceneY:i},this.state);return[a-this.state.offsetLeft,l-this.state.offsetTop]},onChange:it(n=>{o(n,n,!1),pc(t)&&Co(t)}),onSubmit:it(({text:n,viaKeyboard:i,originalText:a})=>{let l=!n.trim();if(o(n,a,l),!l&&i){let c=t.containerId?t.containerId:t.id;this.setState(s=>({selectedElementIds:Pe({...s.selectedElementIds,[c]:!0},s)}))}l&&hl(this.scene.getNonDeletedElements(),[t]),(!l||r)&&this.history.resumeRecording(),this.setState({draggingElement:null,editingElement:null}),this.state.activeTool.locked&&Lr(this.interactiveCanvas,this.state),this.focusContainer()}),element:t,excalidrawContainer:this.excalidrawContainerRef.current,app:this}),this.deselectElements(),o(t.text,t.originalText,!1)}deselectElements(){this.setState({selectedElementIds:Pe({},this.state),selectedGroupIds:{},editingGroupId:null,activeEmbeddable:null})}getTextElementAtPosition(t,r){let o=this.getElementAtPosition(t,r,{includeBoundTextElement:!0});return o&&z(o)&&!o.isDeleted?o: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 Rs(i,this.state,this.frameNameBoundsCache,t,r)?n[n.length-2]:i}return n.length===1?n[0]:null}getElementsAtPosition(t,r,o=!1,n=!1){let i=o&&n?this.scene.getNonDeletedElements():this.scene.getNonDeletedElements().filter(a=>(n||!a.locked)&&(o||!(z(a)&&a.containerId)));return Hg(i,a=>pl(a,this.state,this.frameNameBoundsCache,t,r)).filter(a=>{let l=jt(a);return l&&this.state.frameRendering.enabled&&this.state.frameRendering.clip?kh({x:t,y:r},l):!0})}startTextEditing=({sceneX:t,sceneY:r,insertAtParentCenter:o=!0,container:n})=>{let i=!1,a=o&&this.getTextWysiwygSnappedToCenterPosition(t,r,this.state,n);n&&a&&(le(n)||(i=!0));let l=null,c=this.scene.getSelectedElements(this.state);c.length===1?z(c[0])?l=c[0]:n?l=le(c[0]):l=this.getTextElementAtPosition(t,r):l=this.getTextElementAtPosition(t,r);let s=l?.fontFamily||this.state.currentItemFontFamily,d=l?.lineHeight||Dr(s),m=this.state.currentItemFontSize;if(!l&&i&&n&&!ve(n)){let b=Lm(_e({fontSize:m,fontFamily:s}),d),E=Mm(m,d),w=Math.max(n.height,E),v=Math.max(n.width,b);B(n,{height:w,width:v}),t=n.x+v/2,r=n.y+w/2,a&&(a=this.getTextWysiwygSnappedToCenterPosition(t,r,this.state,n))}let u=this.getTopLayerFrameAtSceneCoords({x:t,y:r}),p=l||Rt({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:s,textAlign:a?"center":this.state.currentItemTextAlign,verticalAlign:a?ht.MIDDLE:Vi,containerId:i?n?.id:void 0,groupIds:n?.groupIds??[],lineHeight:d,angle:n?.angle??0,frameId:u?u.id:null});if(!l&&i&&n&&B(n,{boundElements:(n.boundElements||[]).concat({type:"text",id:p.id})}),this.setState({editingElement:p}),!l)if(n&&i){let g=this.scene.getElementIndex(n.id);this.scene.insertElementAtIndex(p,g+1)}else this.scene.addNewElement(p);this.setState({editingElement:p}),this.handleTextWysiwyg(p,{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&&te(r[0])){if(t[S.CTRL_OR_CMD]&&(!this.state.editingLinearElement||this.state.editingLinearElement.elementId!==r[0].id)){this.history.resumeRecording(),this.setState({editingLinearElement:new K(r[0],this.scene)});return}else if(this.state.editingLinearElement&&this.state.editingLinearElement.elementId===r[0].id)return}Mr(this.interactiveCanvas);let{x:o,y:n}=Ue(t,this.state);if(ln(this.state).length>0){let a=this.getElementAtPosition(o,n),l=a&&Kx(a,this.state.selectedGroupIds);if(l){this.setState(c=>({...c,...Ht({editingGroupId:l,selectedElementIds:{[a.id]:!0}},this.scene.getNonDeletedElements(),c,this)}));return}}if(Mr(this.interactiveCanvas),!t[S.CTRL_OR_CMD]&&!this.state.viewModeEnabled){let a=this.getElementAtPosition(o,n);if(nr(a)){this.setState({activeEmbeddable:{element:a,state:"active"}});return}let l=oh(this.scene.getNonDeletedElements(),this.state,o,n);if(l&&(pr(l)||!or(l.backgroundColor)||aa(l,this.state,this.frameNameBoundsCache,[o,n]))){let c=_m(l,this.state);o=c.x,n=c.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&&Kd(i,this.state,[t.x,t.y],this.device.editor.isMobile)))};redirectToLink=(t,r)=>{let o=ct(this.lastPointerDownEvent.clientX,this.lastPointerDownEvent.clientY,this.lastPointerUpEvent.clientX,this.lastPointerUpEvent.clientY);if(!this.hitLinkElement||r&&o>on||!r&&o!==0)return;let n=Ue(this.lastPointerDownEvent,this.state),i=Kd(this.hitLinkElement,this.state,[n.x,n.y],this.device.editor.isMobile),a=Ue(this.lastPointerUpEvent,this.state),l=Kd(this.hitLinkElement,this.state,[a.x,a.y],this.device.editor.isMobile);if(i&&l){let c=this.hitLinkElement.link;if(c){c=ir(c);let s;if(this.props.onLinkOpen&&(s=gd("excalidraw-link",t.nativeEvent),this.props.onLinkOpen({...this.hitLinkElement,link:c},s)),!s?.defaultPrevented){let d=Gd(c)?"_self":"_blank",m=window.open(void 0,d);m&&(m.opener=null,m.location=c)}}}};getTopLayerFrameAtSceneCoords=t=>{let r=this.scene.getNonDeletedFramesLikes().filter(o=>kh(t,o));return r.length?r[r.length-1]:null};handleCanvasPointerMove=t=>{this.savePointer(t.clientX,t.clientY,this.state.cursorButton),this.lastPointerMoveEvent=t.nativeEvent,Re.pointers.has(t.pointerId)&&Re.pointers.set(t.pointerId,{x:t.clientX,y:t.clientY});let r=Re.initialScale;if(Re.pointers.size===2&&Re.lastCenter&&r&&Re.initialDistance){let u=If(Re.pointers),p=u.x-Re.lastCenter.x,g=u.y-Re.lastCenter.y;Re.lastCenter=u;let b=Sf(Array.from(Re.pointers.values())),E=this.state.activeTool.type==="freedraw"&&this.state.penMode?1:b/Re.initialDistance,w=E?$o(r*E):this.state.zoom.value;this.setState(v=>{let T=vn({viewportX:u.x,viewportY:u.y,nextZoom:w},v);this.translateCanvas({zoom:T.zoom,scrollX:T.scrollX+p/w,scrollY:T.scrollY+g/w,shouldCacheIgnoreZoom:!0})}),this.resetShouldCacheIgnoreZoomDebounced()}else Re.lastCenter=Re.initialDistance=Re.initialScale=null;if(ka||zc||ob||Eo(this.state))return;let n=nu(nb,t.clientX-this.state.offsetLeft,t.clientY-this.state.offsetTop).isOverEither;!this.state.draggingElement&&!this.state.multiElement&&(n?Mr(this.interactiveCanvas):Lr(this.interactiveCanvas,this.state));let i=Ue(t,this.state),{x:a,y:l}=i;if(!this.state.draggingElement&&tS(this.state.activeTool.type)){let{originOffset:u,snapLines:p}=eS(this.scene.getNonDeletedElements(),this.state,{x:a,y:l},t);this.setState(g=>{let b=bd(g.snapLines,p),E=g.originSnapOffset?bd(g.originSnapOffset,u):u;return g.snapLines===b&&g.originSnapOffset===E?null:{snapLines:b,originSnapOffset:E}})}else this.state.draggingElement||this.setState(u=>u.snapLines.length?{snapLines:[]}:null);if(this.state.editingLinearElement&&!this.state.editingLinearElement.isDragging){let u=K.handlePointerMove(t,a,l,this.state);u&&u!==this.state.editingLinearElement&&tb(()=>{this.setState({editingLinearElement:u})}),u?.lastUncommittedPoint!=null?this.maybeSuggestBindingAtCursor(i):tb(()=>{this.setState({suggestedBindings:[]})})}if(Op(this.state.activeTool.type)){let{draggingElement:u}=this.state;Et(u,!1)?this.maybeSuggestBindingsForLinearElementAtCoords(u,[i],this.state.startBoundElement):this.maybeSuggestBindingAtCursor(i)}if(this.state.multiElement){let{multiElement:u}=this.state,{x:p,y:g}=u,{points:b,lastCommittedPoint:E}=u,w=b[b.length-1];if(Lr(this.interactiveCanvas,this.state),w===E)ct(a-p,l-g,w[0],w[1])>=Pa?B(u,{points:[...b,[a-p,l-g]]}):Oe(this.interactiveCanvas,Me.POINTER);else if(b.length>2&&E&&ct(a-p,l-g,E[0],E[1])<Pa)Oe(this.interactiveCanvas,Me.POINTER),B(u,{points:b.slice(0,-1)});else{let[v,T]=wt(a,l,t[S.CTRL_OR_CMD]?null:this.state.gridSize),[k,M]=u?.lastCommittedPoint??[0,0],A=v-p-k,D=T-g-M;oa(t)&&({width:A,height:D}=bl(k+p,M+g,v,T)),xr(b,this.state.zoom.value)&&Oe(this.interactiveCanvas,Me.POINTER),B(u,{points:[...b.slice(0,-1),[k+A,M+D]]})}return}if(!!t.buttons||this.state.activeTool.type!=="selection"&&this.state.activeTool.type!=="text"&&this.state.activeTool.type!=="eraser")return;let s=this.scene.getNonDeletedElements(),d=this.scene.getSelectedElements(this.state);if(d.length===1&&!n&&!this.state.editingLinearElement){let u=Qm(s,this.state,a,l,this.state.zoom,t.pointerType);if(u&&u.transformHandleType){Oe(this.interactiveCanvas,tu(u));return}}else if(d.length>1&&!n){let u=eu(we(d),a,l,this.state.zoom,t.pointerType);if(u){Oe(this.interactiveCanvas,tu({transformHandleType:u}));return}}let m=this.getElementAtPosition(i.x,i.y);this.hitLinkElement=this.getElementLinkAtPosition(i,m),!$r(this.state)&&(this.hitLinkElement&&!this.state.selectedElementIds[this.hitLinkElement.id]?(Oe(this.interactiveCanvas,Me.POINTER),sy(this.hitLinkElement,this.state)):(cy(),m&&(m.link||At(m))&&this.state.selectedElementIds[m.id]&&!this.state.contextMenu&&!this.state.showHyperlinkPopup?this.setState({showHyperlinkPopup:"info"}):this.state.activeTool.type==="text"?Oe(this.interactiveCanvas,z(m)?Me.TEXT:Me.CROSSHAIR):this.state.viewModeEnabled?Oe(this.interactiveCanvas,Me.GRAB):n?Oe(this.interactiveCanvas,Me.AUTO):this.state.selectedLinearElement?this.handleHoverSelectedLinearElement(this.state.selectedLinearElement,a,l):t[S.CTRL_OR_CMD]?Oe(this.interactiveCanvas,Me.AUTO):(m||this.isHittingCommonBoundingBoxOfSelectedElements(i,d))&&!m?.locked&&(m&&nr(m)&&this.isIframeLikeElementCenter(m,t,a,l)?(Oe(this.interactiveCanvas,Me.POINTER),this.setState({activeEmbeddable:{element:m,state:"hover"}})):(Oe(this.interactiveCanvas,Me.MOVE),this.state.activeEmbeddable?.state==="hover"&&this.setState({activeEmbeddable:null})))))};handleEraser=(t,r,o)=>{let n=m=>{m.forEach(u=>{u.locked||(i.push(u.id),t.altKey?r.elementIdsToErase[u.id]&&r.elementIdsToErase[u.id].erase&&(r.elementIdsToErase[u.id].erase=!1):r.elementIdsToErase[u.id]||(r.elementIdsToErase[u.id]={erase:!0,opacity:u.opacity}))})},i=[],a=ct(r.lastCoords.x,r.lastCoords.y,o.x,o.y),l=10/this.state.zoom.value,c={...r.lastCoords},s=0;for(;s<=a;){let m=this.getElementsAtPosition(c.x,c.y);if(n(m),s===a)break;s=Math.min(s+l,a);let u=s/a,p=(1-u)*c.x+u*o.x,g=(1-u)*c.y+u*o.y;c.x=p,c.y=g}let d=this.scene.getElementsIncludingDeleted().map(m=>{let u=ke(m)&&i.includes(m.containerId)?m.containerId:m.id;if(i.includes(u))if(t.altKey){if(r.elementIdsToErase[u]&&r.elementIdsToErase[u].erase===!1)return Q(m,{opacity:r.elementIdsToErase[u].opacity})}else return Q(m,{opacity:ox});return m});this.scene.replaceAllElements(d),r.lastCoords.x=o.x,r.lastCoords.y=o.y};handleTouchMove=t=>{Gc=!0};handleHoverSelectedLinearElement(t,r,o){let n=K.getElement(t.elementId),i=le(n);if(n)if(this.state.selectedLinearElement){let a=-1,l=null;aa(n,this.state,this.frameNameBoundsCache,[r,o])?(a=K.getPointIndexUnderCursor(n,this.state.zoom,r,o),l=K.getSegmentMidpointHitCoords(t,{x:r,y:o},this.state),a>=0||l?Oe(this.interactiveCanvas,Me.POINTER):Oe(this.interactiveCanvas,Me.MOVE)):dl([n],this.state)&&Rs(n,this.state,this.frameNameBoundsCache,r,o)?Oe(this.interactiveCanvas,Me.MOVE):i&&pl(i,this.state,this.frameNameBoundsCache,r,o)&&Oe(this.interactiveCanvas,Me.MOVE),this.state.selectedLinearElement.hoverPointIndex!==a&&this.setState({selectedLinearElement:{...this.state.selectedLinearElement,hoverPointIndex:a}}),K.arePointsEqual(this.state.selectedLinearElement.segmentMidPointHoveredCoords,l)||this.setState({selectedLinearElement:{...this.state.selectedLinearElement,segmentMidPointHoveredCoords:l}})}else Oe(this.interactiveCanvas,Me.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 s=this.state.draggingElement;this.updateScene({...s.points.length<10?{elements:this.scene.getElementsIncludingDeleted().filter(d=>d.id!==s.id)}:{},appState:{draggingElement:null,editingElement:null,startBoundElement:null,suggestedBindings:[],selectedElementIds:Pe(Object.keys(this.state.selectedElementIds).filter(d=>d!==s.id).reduce((d,m)=>(d[m]=this.state.selectedElementIds[m],d),{}),this.state)}});return}let r=document.getSelection();if(r?.anchorNode&&r.removeAllRanges(),this.maybeOpenContextMenuAfterPointerDownOnTouchDevices(t),!this.state.penDetected&&t.pointerType==="pen"&&this.setState(s=>({penMode:!0,penDetected:!0})),!this.device.isTouchScreen&&["pen","touch"].includes(t.pointerType)&&(this.device=Fa(this.device,{isTouchScreen:!0})),zc||(this.lastPointerDownEvent=t,this.handleCanvasPanUsingWheelOrSpaceDrag(t)))return;if(this.setState({lastPointerDownWith:t.pointerType,cursorButton:"down"}),this.savePointer(t.clientX,t.clientY,"down"),t.button===Yn.ERASER&&this.state.activeTool.type!==ft.eraser){this.setState({activeTool:Xe(this.state,{type:ft.eraser,lastActiveToolBeforeEraser:this.state.activeTool})},()=>{this.handleCanvasPointerDown(t);let s=()=>{d(),m?.(),$r(this.state)&&this.setState({activeTool:Xe(this.state,{...this.state.activeTool.lastActiveTool||{type:ft.selection},lastActiveToolBeforeEraser:null})})},d=mt(window,"pointerup",s,{once:!0}),m;requestAnimationFrame(()=>{m=this.missingPointerEventCleanupEmitter.once(s)})});return}if(t.button!==Yn.MAIN&&t.button!==Yn.TOUCH&&t.button!==Yn.ERASER||Re.pointers.size>1)return;let o=this.initialPointerDownState(t);if(this.setState({selectedElementsAreBeingDragged:!1}),this.handleDraggingScrollBar(t,o)||(this.clearSelectionIfNotUsingSelection(),this.updateBindingEnabledOnPointerMove(t),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"){Oe(this.interactiveCanvas,Me.CROSSHAIR);let s=this.state.pendingImageElementId&&this.scene.getElement(this.state.pendingImageElementId);if(!s)return;this.setState({draggingElement:s,editingElement:s,pendingImageElementId:null,multiElement:null});let{x:d,y:m}=Ue(t,this.state),u=this.getTopLayerFrameAtSceneCoords({x:d,y:m});B(s,{x:d,y:m,frameId:u?u.id:null})}else this.state.activeTool.type==="freedraw"?this.handleFreeDrawElementOnPointerDown(t,this.state.activeTool.type,o):this.state.activeTool.type==="custom"?Lr(this.interactiveCanvas,this.state):this.state.activeTool.type===ft.frame||this.state.activeTool.type===ft.magicframe?this.createFrameElementOnPointerDown(o,this.state.activeTool.type):this.state.activeTool.type==="laser"?this.laserPathManager.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);let i=this.onPointerMoveFromPointerDownHandler(o),a=this.onPointerUpFromPointerDownHandler(o),l=this.onKeyDownFromPointerDownHandler(o),c=this.onKeyUpFromPointerDownHandler(o);this.missingPointerEventCleanupEmitter.once(s=>a(s||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",c),o.eventListeners.onMove=i,o.eventListeners.onUp=a,o.eventListeners.onKeyUp=c,o.eventListeners.onKeyDown=l)};handleCanvasPointerUp=t=>{this.removePointer(t),this.lastPointerUpEvent=t;let r=Ue({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(nr(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&&nr(this.hitLinkElement)&&!mg(this.hitLinkElement,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"&&(Gc=!1,Ni?Gc=!0:Ni=window.setTimeout(()=>{Ni=0,Gc||this.handleCanvasContextMenu(t)},Kb))};resetContextMenuTimer=()=>{clearTimeout(Ni),Ni=0,Gc=!1};maybeCleanupAfterMissingPointerUp=t=>{Uc?.(),this.missingPointerEventCleanupEmitter.trigger(t).clear()};handleCanvasPanUsingWheelOrSpaceDrag=t=>{if(!(Re.pointers.size<=1&&(t.button===Yn.WHEEL||t.button===Yn.MAIN&&ka||Eo(this.state)||this.state.viewModeEnabled))||z(this.state.editingElement))return!1;zc=!0,t.preventDefault();let r=!1,o=/Linux/.test(window.navigator.platform);Oe(this.interactiveCanvas,Me.GRABBING);let{clientX:n,clientY:i}=t,a=pd(c=>{let s=n-c.clientX,d=i-c.clientY;if(n=c.clientX,i=c.clientY,o&&!r&&(Math.abs(s)>1||Math.abs(d)>1)){r=!0;let m=p=>{document.body.removeEventListener("paste",m),p.stopPropagation()},u=()=>{setTimeout(()=>{document.body.removeEventListener("paste",m),window.removeEventListener("pointerup",u)},100)};document.body.addEventListener("paste",m),window.addEventListener("pointerup",u)}this.translateCanvas({scrollX:this.state.scrollX-s/this.state.zoom.value,scrollY:this.state.scrollY-d/this.state.zoom.value})}),l=it(Uc=()=>{Uc=null,zc=!1,ka||(this.state.viewModeEnabled?Oe(this.interactiveCanvas,Me.GRAB):Lr(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){Re.pointers.set(t.pointerId,{x:t.clientX,y:t.clientY}),Re.pointers.size===2&&(Re.lastCenter=If(Re.pointers),Re.initialScale=this.state.zoom.value,Re.initialDistance=Sf(Array.from(Re.pointers.values())))}initialPointerDownState(t){let r=Ue(t,this.state),o=this.scene.getSelectedElements(this.state),[n,i,a,l]=we(o);return{origin:r,withCmdOrCtrl:t[S.CTRL_OR_CMD],originInGrid:xo(wt(r.x,r.y,t[S.CTRL_OR_CMD]?null:this.state.gridSize)),scrollbars:nu(nb,t.clientX-this.state.offsetLeft,t.clientY-this.state.offsetTop),lastCoords:{...r},originalElements:this.scene.getNonDeletedElements().reduce((c,s)=>(c.set(s.id,cn(s)),c),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},elementIdsToErase:{}}}handleDraggingScrollBar(t,r){if(!(r.scrollbars.isOverEither&&!this.state.multiElement))return!1;ob=!0,r.lastCoords.x=t.clientX,r.lastCoords.y=t.clientY;let o=pd(i=>{i.target instanceof HTMLElement&&this.handlePointerMoveOverScrollbars(i,r)}),n=it(()=>{Uc=null,ob=!1,Lr(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 Uc=n,window.addEventListener("pointermove",o),window.addEventListener("pointerup",n),!0}clearSelectionIfNotUsingSelection=()=>{this.state.activeTool.type!=="selection"&&this.setState({selectedElementIds:Pe({},this.state),selectedGroupIds:{},editingGroupId:null,activeEmbeddable:null})};handleSelectionOnPointerDown=(t,r)=>{if(this.state.activeTool.type==="selection"){let o=this.scene.getNonDeletedElements(),n=this.scene.getSelectedElements(this.state);if(n.length===1&&!this.state.editingLinearElement){let i=Qm(o,this.state,r.origin.x,r.origin.y,this.state.zoom,t.pointerType);i!=null&&(this.setState({resizingElement:i.element}),r.resize.handleType=i.transformHandleType)}else n.length>1&&(r.resize.handleType=eu(we(n),r.origin.x,r.origin.y,this.state.zoom,t.pointerType));if(r.resize.handleType)r.resize.isResizing=!0,r.resize.offset=xo(Oh(r.resize.handleType,n,r.origin.x,r.origin.y)),n.length===1&&te(n[0])&&n[0].points.length===2&&(r.resize.arrowDirection=Fh(r.resize.handleType,n[0]));else{if(this.state.selectedLinearElement){let l=this.state.editingLinearElement||this.state.selectedLinearElement,c=K.handlePointerDown(t,this.state,this.history,r.origin,l);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 i=r.hit.element,a=r.hit.allHitElements.some(l=>this.isASelectedElement(l));if((i===null||!a)&&!t.shiftKey&&!r.hit.hasHitCommonBoundingBoxOfSelectedElements&&this.clearSelection(i),this.state.editingLinearElement)this.setState({selectedElementIds:Pe({[this.state.editingLinearElement.elementId]:!0},this.state)});else if(i!=null){if(t[S.CTRL_OR_CMD])return this.state.selectedElementIds[i.id]||(r.hit.wasAddedToSelection=!0),this.setState(l=>({...Yx(l,i),previousSelectedElementIds:this.state.selectedElementIds})),!1;this.state.selectedElementIds[i.id]||(this.state.editingGroupId&&!Qi(i,this.state.editingGroupId)&&this.setState({selectedElementIds:Pe({},this.state),selectedGroupIds:{},editingGroupId:null,activeEmbeddable:null}),!a&&!r.hit.hasHitCommonBoundingBoxOfSelectedElements&&(this.setState(l=>{let c={...l.selectedElementIds,[i.id]:!0},s=[];if(Object.keys(l.selectedElementIds).forEach(d=>{let m=this.scene.getElement(d);m&&s.push(m)}),J(i))Fr(s,i.id).forEach(d=>{delete c[d.id]});else if(i.frameId)c[i.frameId]&&delete c[i.id];else{let d=i.groupIds,m=new Set(d.flatMap(u=>at(this.scene.getNonDeletedElements(),u)).filter(u=>J(u)).map(u=>u.id));m.size>0&&s.forEach(u=>{u.frameId&&m.has(u.frameId)&&(delete c[u.id],u.groupIds.flatMap(p=>at(this.scene.getNonDeletedElements(),p)).forEach(p=>{delete c[p.id]}))})}return{...Ht({editingGroupId:l.editingGroupId,selectedElementIds:c},this.scene.getNonDeletedElements(),l,this),showHyperlinkPopup:i.link||At(i)?"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=10/this.state.zoom.value,[n,i,a,l]=we(r);return t.x>n-o&&t.x<a+o&&t.y>i-o&&t.y<l+o}handleTextOnPointerDown=(t,r)=>{if(z(this.state.editingElement))return;let o=r.origin.x,n=r.origin.y,i=this.getElementAtPosition(o,n,{includeBoundTextElement:!0}),a=oh(this.scene.getNonDeletedElements(),this.state,o,n);pr(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}),Mr(this.interactiveCanvas),this.state.activeTool.locked||this.setState({activeTool:Xe(this.state,{type:"selection"})})};handleFreeDrawElementOnPointerDown=(t,r,o)=>{let[n,i]=wt(o.origin.x,o.origin.y,null),a=this.getTopLayerFrameAtSceneCoords({x:n,y:i}),l=rE({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:Pe(m,d)}});let c=l.simulatePressure?l.pressures:[...l.pressures,t.pressure];B(l,{points:[[0,0]],pressures:c});let s=Wo(o.origin,this.scene);this.scene.addNewElement(l),this.setState({draggingElement:l,editingElement:l,startBoundElement:s,suggestedBindings:[]})};insertIframeElement=({sceneX:t,sceneY:r,width:o,height:n})=>{let[i,a]=wt(t,r,this.lastPointerDownEvent?.[S.CTRL_OR_CMD]?null:this.state.gridSize),l=eE({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.replaceAllElements([...this.scene.getElementsIncludingDeleted(),l]),l};insertEmbeddableElement=({sceneX:t,sceneY:r,link:o})=>{let[n,i]=wt(t,r,this.lastPointerDownEvent?.[S.CTRL_OR_CMD]?null:this.state.gridSize),a=un(o);if(!a)return;a.warning&&this.setToast({message:a.warning,closable:!0});let l=qp({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,validated:null});return this.scene.replaceAllElements([...this.scene.getElementsIncludingDeleted(),l]),l};createImageElement=({sceneX:t,sceneY:r,addToFrameUnderCursor:o=!0})=>{let[n,i]=wt(t,r,this.lastPointerDownEvent?.[S.CTRL_OR_CMD]?null:this.state.gridSize),a=o?this.getTopLayerFrameAtSceneCoords({x:n,y:i}):null;return ws({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"&&xr(n.points,this.state.zoom.value)){B(n,{lastCommittedPoint:n.points[n.points.length-1]}),this.actionManager.executeAction(lo);return}let{x:i,y:a,lastCommittedPoint:l}=n;if(n.points.length>1&&l&&ct(o.origin.x-i,o.origin.y-a,l[0],l[1])<Pa){this.actionManager.executeAction(lo);return}this.setState(c=>({selectedElementIds:Pe({...c.selectedElementIds,[n.id]:!0},c)})),B(n,{lastCommittedPoint:n.points[n.points.length-1]}),Oe(this.interactiveCanvas,Me.POINTER)}else{let[n,i]=wt(o.origin.x,o.origin.y,t[S.CTRL_OR_CMD]?null:this.state.gridSize),a=this.getTopLayerFrameAtSceneCoords({x:n,y:i}),{currentItemStartArrowhead:l,currentItemEndArrowhead:c}=this.state,[s,d]=r==="arrow"?[l,c]:[null,null],m=qr({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:st.PROPORTIONAL_RADIUS}:null,startArrowhead:s,endArrowhead:d,locked:!1,frameId:a?a.id:null});this.setState(p=>{let g={...p.selectedElementIds};return delete g[m.id],{selectedElementIds:Pe(g,p)}}),B(m,{points:[...m.points,[0,0]]});let u=Wo(o.origin,this.scene);this.scene.addNewElement(m),this.setState({draggingElement:m,editingElement:m,startBoundElement:u,suggestedBindings:[]})}};getCurrentItemRoundness(t){return this.state.currentItemRoundness==="round"?{type:Ho(t)?st.ADAPTIVE_RADIUS:st.PROPORTIONAL_RADIUS}:null}createGenericElementOnPointerDown=(t,r)=>{let[o,n]=wt(r.origin.x,r.origin.y,this.lastPointerDownEvent?.[S.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=qp({type:"embeddable",validated:null,...a}):l=Pr({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,r)=>{let[o,n]=wt(t.origin.x,t.origin.y,this.lastPointerDownEvent?.[S.CTRL_OR_CMD]?null:this.state.gridSize),i={x:o,y:n,opacity:this.state.currentItemOpacity,locked:!1,...Qe},a=r===ft.magicframe?ys(i):kd(i);this.scene.replaceAllElements([...this.scene.getElementsIncludingDeleted(),a]),this.setState({multiElement:null,draggingElement:a,editingElement:a})};maybeCacheReferenceSnapPoints(t,r,o=!1){Fn({event:t,appState:this.state,selectedElements:r})&&(o||!uo.getReferenceSnapPoints())&&uo.setReferenceSnapPoints(jI(this.scene.getNonDeletedElements(),r,this.state))}maybeCacheVisibleGaps(t,r,o=!1){Fn({event:t,appState:this.state,selectedElements:r})&&(o||!uo.getVisibleGaps())&&uo.setVisibleGaps(ZI(this.scene.getNonDeletedElements(),r,this.state))}onKeyDownFromPointerDownHandler(t){return it(r=>{this.maybeHandleResize(t,r)||this.maybeDragNewGenericElement(t,r)})}onKeyUpFromPointerDownHandler(t){return it(r=>{r.key===S.ALT&&r.preventDefault(),!this.maybeHandleResize(t,r)&&this.maybeDragNewGenericElement(t,r)})}onPointerMoveFromPointerDownHandler(t){return pd(r=>{if(t.drag.offset===null&&(t.drag.offset=xo(Gh(this.scene.getSelectedElements(this.state),t.origin.x,t.origin.y))),!(r.target instanceof HTMLElement)||this.handlePointerMoveOverScrollbars(r,t))return;let n=Ue(r,this.state);if($r(this.state)){this.handleEraser(r,t,n);return}this.state.activeTool.type==="laser"&&this.laserPathManager.addPointToPath(n.x,n.y);let[i,a]=wt(n.x,n.y,r[S.CTRL_OR_CMD]?null:this.state.gridSize);if(!t.drag.hasOccurred&&(this.state.activeTool.type==="arrow"||this.state.activeTool.type==="line")&&ct(n.x,n.y,t.origin.x,t.origin.y)<on)return;if(t.resize.isResizing&&(t.lastCoords.x=n.x,t.lastCoords.y=n.y,this.maybeHandleResize(t,r)))return!0;if(this.state.selectedLinearElement){let d=this.state.editingLinearElement||this.state.selectedLinearElement;if(K.shouldAddMidpoint(this.state.selectedLinearElement,n,this.state)){let u=K.addMidpoint(this.state.selectedLinearElement,n,this.state,!r[S.CTRL_OR_CMD]);if(!u)return;tb(()=>{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(d.pointerDownState.segmentMidpoint.value!==null&&!d.pointerDownState.segmentMidpoint.added)return;if(K.handlePointDragging(r,this.state,n.x,n.y,(u,p)=>{this.maybeSuggestBindingsForLinearElementAtCoords(u,p)},d)){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 l=t.hit.allHitElements.some(d=>this.isASelectedElement(d)),c=this.state.editingLinearElement&&r.shiftKey&&this.state.editingLinearElement.elementId===t.hit.element?.id;if((l||t.hit.hasHitCommonBoundingBoxOfSelectedElements)&&!c){let d=this.scene.getSelectedElements(this.state);if(d.every(p=>p.locked))return;let m=d.find(p=>J(p)),u=this.getTopLayerFrameAtSceneCoords(n);if(this.setState({frameToHighlight:u&&!m?u:null}),t.drag.hasOccurred=!0,this.setState({selectedElementsAreBeingDragged:!0}),d.length>0&&!t.withCmdOrCtrl&&!this.state.editingElement&&this.state.activeEmbeddable?.state!=="active"){let p={x:n.x-t.origin.x,y:n.y-t.origin.y},g=[...t.originalElements.values()],b=r.shiftKey;if(b){let v=Math.abs(p.x),T=Math.abs(p.y),k=b&&v<T,M=b&&v>T;k&&(p.x=0),M&&(p.y=0)}this.maybeCacheVisibleGaps(r,d),this.maybeCacheReferenceSnapPoints(r,d);let{snapOffset:E,snapLines:w}=qI(ge(g,this.state),p,this.state,r);if(this.setState({snapLines:w}),!this.state.editingFrame&&zh(t,d,p,this.state,this.scene,E,r[S.CTRL_OR_CMD]?null:this.state.gridSize),this.maybeSuggestBindingForAll(d),r.altKey&&!t.hit.hasBeenDuplicated){t.hit.hasBeenDuplicated=!0;let v=[],T=[],k=new Map,M=new Map,A=t.hit.element,D=new Set(this.scene.getSelectedElements({selectedElementIds:this.state.selectedElementIds,includeBoundTextElement:!0,includeElementsInFrames:!0}).map(C=>C.id)),R=this.scene.getElementsIncludingDeleted();for(let C of R)if(D.has(C.id)||C.id===A?.id&&t.hit.wasAddedToSelection){let O=vs(this.state.editingGroupId,k,C),P=t.originalElements.get(C.id);B(O,{x:P.x,y:P.y}),t.originalElements.set(O.id,O),v.push(O),T.push(C),M.set(C.id,O.id)}else v.push(C);let H=[...v,...T];Am(v,T,M),nm(H,T,M,"duplicatesServeAsOld"),Zm(H,T,M),this.scene.replaceAllElements(H),this.maybeCacheVisibleGaps(r,d,!0),this.maybeCacheReferenceSnapPoints(r,d,!0)}return}}let s=this.state.draggingElement;if(s){if(s.type==="freedraw"){let d=s.points,m=n.x-s.x,u=n.y-s.y,p=d.length>0&&d[d.length-1];if(!(p&&p[0]===m&&p[1]===u)){let b=s.simulatePressure?s.pressures:[...s.pressures,r.pressure];B(s,{points:[...d,[m,u]],pressures:b})}}else if(te(s)){t.drag.hasOccurred=!0,this.setState({selectedElementsAreBeingDragged:!0});let d=s.points,m=i-s.x,u=a-s.y;oa(r)&&d.length===2&&({width:m,height:u}=bl(s.x,s.y,n.x,n.y)),d.length===1?B(s,{points:[...d,[m,u]]}):d.length===2&&B(s,{points:[...d.slice(0,-1),[m,u]]}),Et(s,!1)&&this.maybeSuggestBindingsForLinearElementAtCoords(s,[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 d=this.scene.getNonDeletedElements();if(this.state.editingLinearElement)K.handleBoxSelection(r,this.state,this.setState.bind(this));else{let m=!0;!r.shiftKey&&ze(d,this.state)&&(t.withCmdOrCtrl&&t.hit.element?this.setState(p=>Ht({...p,selectedElementIds:{[t.hit.element.id]:!0}},this.scene.getNonDeletedElements(),p,this)):m=!1);let u=Ol(d,s);this.setState(p=>{let g={...m&&p.selectedElementIds,...u.reduce((b,E)=>(b[E.id]=!0,b),{})};return t.hit.element&&(u.length?delete g[t.hit.element.id]:g[t.hit.element.id]=!0),p=m?p:{...p,selectedGroupIds:{},editingGroupId:null},{...Ht({editingGroupId:p.editingGroupId,selectedElementIds:g},this.scene.getNonDeletedElements(),p,this),selectedLinearElement:u.length===1&&te(u[0])?new K(u[0],this.scene):null,showHyperlinkPopup:u.length===1&&(u[0].link||At(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 it(r=>{this.removePointer(r),t.eventListeners.onMove&&t.eventListeners.onMove.flush();let{draggingElement:o,resizingElement:n,multiElement:i,activeTool:a,isResizing:l,isRotating:c}=this.state;if(this.setState(u=>({isResizing:!1,isRotating:!1,resizingElement:null,selectionElement:null,frameToHighlight:null,elementsToHighlight:null,cursorButton:"up",editingElement:i||z(this.state.editingElement)?this.state.editingElement:null,snapLines:bd(u.snapLines,[]),originSnapOffset:null})),uo.setReferenceSnapPoints(null),uo.setVisibleGaps(null),this.savePointer(r.clientX,r.clientY,"up"),this.setState({selectedElementsAreBeingDragged:!1}),this.state.editingLinearElement)if(!t.boxSelection.hasOccurred&&t.hit?.element?.id!==this.state.editingLinearElement.elementId)this.actionManager.executeAction(lo);else{let u=K.handlePointerUp(r,this.state.editingLinearElement,this.state);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=K.handlePointerUp(r,this.state.selectedLinearElement,this.state),{startBindingElement:p,endBindingElement:g}=u,b=this.scene.getElement(u.elementId);Et(b)&&xn(b,p,g),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.onPointerUpEmitter.trigger(this.state.activeTool,t,r),o?.type==="freedraw"){let u=Ue(r,this.state),p=o.points,g=u.x-o.x,b=u.y-o.y;g===p[0][0]&&b===p[0][1]&&(b+=1e-4,g+=1e-4);let E=o.simulatePressure?[]:[...o.pressures,r.pressure];B(o,{points:[...p,[g,b]],pressures:E,lastCommittedPoint:[g,b]}),this.actionManager.executeAction(lo);return}if(Yr(o)){let u=o;try{this.initializeImageDimensions(u),this.setState({selectedElementIds:Pe({[u.id]:!0},this.state)},()=>{this.actionManager.executeAction(lo)})}catch(p){console.error(p),this.scene.replaceAllElements(this.scene.getElementsIncludingDeleted().filter(g=>g.id!==u.id)),this.actionManager.executeAction(lo)}return}if(te(o)){o.points.length>1&&this.history.resumeRecording();let u=Ue(r,this.state);!t.drag.hasOccurred&&o&&!i?(B(o,{points:[...o.points,[u.x-o.x,u.y-o.y]]}),this.setState({multiElement:o,editingElement:this.state.draggingElement})):t.drag.hasOccurred&&!i&&(Uo(this.state)&&Et(o,!1)&&Bs(o,this.state,this.scene,u),this.setState({suggestedBindings:[],startBoundElement:null}),a.locked?this.setState(p=>({draggingElement:null})):(Mr(this.interactiveCanvas),this.setState(p=>({draggingElement:null,activeTool:Xe(this.state,{type:"selection"}),selectedElementIds:Pe({...p.selectedElementIds,[o.id]:!0},p),selectedLinearElement:new K(o,this.scene)}))));return}if(a.type!=="selection"&&o&&ao(o)){this.scene.replaceAllElements(this.scene.getElementsIncludingDeleted().filter(u=>u.id!==o.id)),this.setState({draggingElement:null});return}if(o){if(t.drag.hasOccurred){let u=Ue(r,this.state);if(this.state.selectedLinearElement&&this.state.selectedLinearElement.isDragging){let p=this.scene.getElement(this.state.selectedLinearElement.elementId);if(p?.frameId){let g=jt(p);g&&p&&(si(p,g)||(B(p,{groupIds:[]}),this.scene.replaceAllElements(Bl(this.scene.getElementsIncludingDeleted(),[p],this.state))))}}else{let p=this.getTopLayerFrameAtSceneCoords(u),g=this.scene.getSelectedElements(this.state),b=this.scene.getElementsIncludingDeleted(),E=w=>{if(w.length>0){for(let v of w){let T=v.groupIds.indexOf(this.state.editingGroupId);B(v,{groupIds:v.groupIds.slice(0,T)},!1)}b.forEach(v=>{v.groupIds.length&&at(b,v.groupIds[v.groupIds.length-1]).length<2&&B(v,{groupIds:[]},!1)}),this.setState({editingGroupId:null})}};if(p&&!this.state.selectedElementIds[p.id]){let w=g.filter(v=>v.frameId!==p.id&&ia(v,b,this.state));this.state.editingGroupId&&E(w),b=jm(b,w,p)}else if(!p&&this.state.editingGroupId){let w=g.filter(v=>v.frameId&&!ia(v,b,this.state));E(w)}b=Xo(b,this.state,this),this.scene.replaceAllElements(b)}}if(J(o)){let u=yv(this.scene.getElementsIncludingDeleted(),o);this.scene.replaceAllElements(jm(this.scene.getElementsIncludingDeleted(),u,o))}B(o,lc(o))}if(n&&this.history.resumeRecording(),n&&ao(n)&&this.scene.replaceAllElements(this.scene.getElementsIncludingDeleted().filter(u=>u.id!==n.id)),t.resize.isResizing){let u=Xo(this.scene.getElementsIncludingDeleted(),this.state,this),p=this.scene.getSelectedElements(this.state).filter(g=>J(g));for(let g of p)u=qm(u,Nl(this.scene.getElementsIncludingDeleted(),g,this.state),g,this.state);this.scene.replaceAllElements(u)}let s=t.hit.element;this.state.selectedLinearElement?.elementId!==s?.id&&te(s)&&this.scene.getSelectedElements(this.state).length===1&&this.setState({selectedLinearElement:new K(s,this.scene)});let d=this.lastPointerDownEvent,m=this.lastPointerUpEvent||this.lastPointerMoveEvent;if($r(this.state)&&d&&m){if(ct(d.clientX,d.clientY,m.clientX,m.clientY)===0){let p=Ue({clientX:m.clientX,clientY:m.clientY},this.state);this.getElementsAtPosition(p.x,p.y).forEach(b=>t.elementIdsToErase[b.id]={erase:!0,opacity:b.opacity})}this.eraseElements(t);return}else Object.keys(t.elementIdsToErase).length&&this.restoreReadyToEraseElements(t);if(s&&!t.drag.hasOccurred&&!t.hit.wasAddedToSelection&&(!this.state.editingLinearElement||!t.boxSelection.hasOccurred)&&(r.shiftKey&&!this.state.editingLinearElement?this.state.selectedElementIds[s.id]?Wa(this.state,s)?this.setState(u=>{let p={...u.selectedElementIds};for(let g of s.groupIds.flatMap(b=>at(this.scene.getNonDeletedElements(),b)))delete p[g.id];return{selectedGroupIds:{...u.selectedElementIds,...s.groupIds.map(g=>({[g]:!1})).reduce((g,b)=>({...g,...b}),{})},selectedElementIds:Pe(p,u)}}):this.state.selectedLinearElement?.isDragging||this.setState(u=>{let p={...u.selectedElementIds};delete p[s.id];let g=ge(this.scene.getNonDeletedElements(),{selectedElementIds:p});return{...Ht({editingGroupId:u.editingGroupId,selectedElementIds:p},this.scene.getNonDeletedElements(),u,this),selectedLinearElement:g.length===1&&te(g[0])?new K(g[0],this.scene):u.selectedLinearElement}}):s.frameId&&this.state.selectedElementIds[s.frameId]?this.setState(u=>{let p={...u.selectedElementIds,[s.id]:!0};return delete p[s.frameId],(this.scene.getElement(s.frameId)?.groupIds??[]).flatMap(g=>at(this.scene.getNonDeletedElements(),g)).forEach(g=>{delete p[g.id]}),{...Ht({editingGroupId:u.editingGroupId,selectedElementIds:p},this.scene.getNonDeletedElements(),u,this),showHyperlinkPopup:s.link||At(s)?"info":!1}}):this.setState(u=>({selectedElementIds:Pe({...u.selectedElementIds,[s.id]:!0},u)})):this.setState(u=>({...Ht({editingGroupId:u.editingGroupId,selectedElementIds:{[s.id]:!0}},this.scene.getNonDeletedElements(),u,this),selectedLinearElement:te(s)&&u.selectedLinearElement?.elementId!==s.id?new K(s,this.scene):u.selectedLinearElement}))),!t.drag.hasOccurred&&!this.state.isResizing&&(s&&Rs(s,this.state,this.frameNameBoundsCache,t.origin.x,t.origin.y)||!s&&t.hit.hasHitCommonBoundingBoxOfSelectedElements)){this.state.editingLinearElement?this.setState({editingLinearElement:null}):this.setState({selectedElementIds:Pe({},this.state),selectedGroupIds:{},editingGroupId:null,activeEmbeddable:null});return}if(!a.locked&&a.type!=="freedraw"&&o&&o.type!=="selection"&&this.setState(u=>({selectedElementIds:Pe({...u.selectedElementIds,[o.id]:!0},u),showHyperlinkPopup:At(o)&&!o.link?"editor":u.showHyperlinkPopup})),(a.type!=="selection"||ze(this.scene.getNonDeletedElements(),this.state))&&this.history.resumeRecording(),(t.drag.hasOccurred||l||c)&&(Uo(this.state)?Ns:Os)(this.scene.getSelectedElements(this.state)),a.type==="laser"){this.laserPathManager.endPath();return}!a.locked&&a.type!=="freedraw"?(Mr(this.interactiveCanvas),this.setState({draggingElement:null,suggestedBindings:[],activeTool:Xe(this.state,{type:"selection"})})):this.setState({draggingElement:null,suggestedBindings:[]}),s&&this.lastPointerUpEvent&&this.lastPointerDownEvent&&this.lastPointerUpEvent.timeStamp-this.lastPointerDownEvent.timeStamp<300&&Re.pointers.size<=1&&nr(s)&&this.isIframeLikeElementCenter(s,this.lastPointerUpEvent,t.origin.x,t.origin.y)&&this.handleEmbeddableCenterClick(s)})}restoreReadyToEraseElements=t=>{let r=this.scene.getElementsIncludingDeleted().map(o=>t.elementIdsToErase[o.id]&&t.elementIdsToErase[o.id].erase?Q(o,{opacity:t.elementIdsToErase[o.id].opacity}):ke(o)&&t.elementIdsToErase[o.containerId]&&t.elementIdsToErase[o.containerId].erase?Q(o,{opacity:t.elementIdsToErase[o.containerId].opacity}):o.frameId&&t.elementIdsToErase[o.frameId]&&t.elementIdsToErase[o.frameId].erase?Q(o,{opacity:t.elementIdsToErase[o.frameId].opacity}):o);this.scene.replaceAllElements(r)};eraseElements=t=>{let r=this.scene.getElementsIncludingDeleted().map(o=>t.elementIdsToErase[o.id]&&t.elementIdsToErase[o.id].erase?Q(o,{isDeleted:!0}):ke(o)&&t.elementIdsToErase[o.containerId]&&t.elementIdsToErase[o.containerId].erase?Q(o,{isDeleted:!0}):o.frameId&&t.elementIdsToErase[o.frameId]&&t.elementIdsToErase[o.frameId].erase?Q(o,{isDeleted:!0}):o);this.history.resumeRecording(),this.scene.replaceAllElements(r)};initializeImage=async({imageFile:t,imageElement:r,showCursorImagePreview:o=!1})=>{if(!Ei(t))throw new Error(f("errors.unsupportedFileType"));let n=t.type;if(Oe(this.interactiveCanvas,"wait"),n===Z.svg)try{t=yh(await sv(await t.text()),t.name)}catch(s){throw console.warn(s),new Error(f("errors.svgImageInsertError"))}let i=await(this.props.generateIdForFile?.(t)||tv(t));if(!i)throw console.warn("Couldn't generate file id or the supplied `generateIdForFile` didn't resolve to one."),new Error(f("errors.imageInsertError"));if(!this.files[i]?.dataURL){try{t=await cc(t,{maxWidthOrHeight:ex})}catch(s){console.error("Error trying to resizing image file on insertion",s)}if(t.size>Ap)throw new Error(f("errors.fileTooBig",{maxSize:`${Math.trunc(Ap/1024/1024)}MB`}))}if(o){let s=this.files[i]?.dataURL,d=s&&rv(s);this.setImagePreviewCursor(d||t)}let l=this.files[i]?.dataURL||await zm(t),c=B(r,{fileId:i},!1);return new Promise(async(s,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([c])),m?.image instanceof Promise&&await m.image,this.state.pendingImageElementId!==c.id&&this.state.draggingElement?.id!==c.id&&this.initializeImageDimensions(c,!0),s(c)}catch(m){console.error(m),d(new Error(f("errors.imageInsertError")))}finally{o||Mr(this.interactiveCanvas)}})};insertImageElement=async(t,r,o)=>{if(!this.isToolSupported("image")){this.setState({errorMessage:f("errors.imageToolNotSupported")});return}this.scene.addNewElement(t);try{return await this.initializeImage({imageFile:r,imageElement:t,showCursorImagePreview:o})}catch(n){return B(t,{isDeleted:!0}),this.actionManager.executeAction(lo),this.setState({errorMessage:n.message||f("errors.imageInsertError")}),null}};setImagePreviewCursor=async t=>{let o=await cc(t,{maxWidthOrHeight:96}),n=await zm(o);if(t.type===Z.svg){let i=await Th(n),a=Math.min(i.height,96),l=a*(i.width/i.height);l>96&&(l=96,a=l*(i.height/i.width));let c=document.createElement("canvas");c.height=a,c.width=l,c.getContext("2d").drawImage(i,0,0,l,a),n=c.toDataURL(Z.svg)}this.state.pendingImageElementId&&Oe(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}=Ue({clientX:r,clientY:o},this.state),a=await Al({description:"Image",extensions:Object.keys(ds)}),l=this.createImageElement({sceneX:n,sceneY:i,addToFrameUnderCursor:!1});t?(this.insertImageElement(l,a),this.initializeImageDimensions(l),this.setState({selectedElementIds:Pe({[l.id]:!0},this.state)},()=>{this.actionManager.executeAction(lo)})):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:Xe(this.state,{type:"selection"})},()=>{this.actionManager.executeAction(lo)})}};initializeImageDimensions=(t,r=!1)=>{let o=ur(t)&&this.imageCache.get(t.fileId)?.image;if(!o||o instanceof Promise){if(t.width<on/this.state.zoom.value&&t.height<on/this.state.zoom.value){let n=100/this.state.zoom.value;B(t,{x:t.x-n/2,y:t.y-n/2,width:n,height:n})}return}if(r||t.width<on/this.state.zoom.value&&t.height<on/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),c=t.x+t.width/2-l/2,s=t.y+t.height/2-a/2;B(t,{x:c,y:s,width:l,height:a})}};updateImageCache=async(t,r=this.files)=>{let{updatedFiles:o,erroredFiles:n}=await Vm({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)&&Te.delete(i);return n.size&&this.scene.replaceAllElements(this.scene.getElementsIncludingDeleted().map(i=>ur(i)&&n.has(i.fileId)?Q(i,{status:"error"}):i)),{updatedFiles:o,erroredFiles:n}};addNewImagesToImageCache=async(t=Ym(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=gD(()=>{this.addNewImagesToImageCache()},Vb);updateBindingEnabledOnPointerMove=t=>{let r=Xy(t);this.state.isBindingEnabled!==r&&this.setState({isBindingEnabled:r})};maybeSuggestBindingAtCursor=t=>{let r=Wo(t,this.scene);this.setState({suggestedBindings:r!=null?[r]:[]})};maybeSuggestBindingsForLinearElementAtCoords=(t,r,o)=>{if(!r.length)return;let n=r.reduce((i,a)=>{let l=Wo(a,this.scene);return l!=null&&!wg(t,o?.id,l)&&i.push(l),i},[]);this.setState({suggestedBindings:n})};maybeSuggestBindingForAll(t){if(t.length>50)return;let r=jy(t);this.setState({suggestedBindings:r})}clearSelection(t){this.setState(r=>({selectedElementIds:Pe({},r),activeEmbeddable:null,selectedGroupIds:{},editingGroupId:r.editingGroupId&&t!=null&&Qi(t,r.editingGroupId)?r.editingGroupId:null})),this.setState({selectedElementIds:Pe({},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 nv(t),{x:n,y:i}=Ue(t,this.state);try{if(Ei(r)&&this.isToolSupported("image")){if(r?.type===Z.png||r?.type===Z.svg)try{let c=await Pl(r,this.state,this.scene.getElementsIncludingDeleted(),o);this.syncActionResult({...c,appState:{...c.appState||this.state,isLoading:!1},replaceFiles:!0,commitToHistory:!0});return}catch(c){if(c.name!=="EncodingError")throw c}let l=this.createImageElement({sceneX:n,sceneY:i});this.insertImageElement(l,r),this.initializeImageDimensions(l),this.setState({selectedElementIds:Pe({[l.id]:!0},this.state)});return}}catch(l){return this.setState({isLoading:!1,errorMessage:l.message})}let a=t.dataTransfer.getData(Z.excalidrawlib);if(a&&typeof a=="string"){try{let l=xh(a);this.addElementsFromPasteOrLibrary({elements:bu(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&&Ka(l,this.props.validateEmbeddable)&&(/^(http|https):\/\/[^\s/$.?#].[^\s]*$/.test(l)||un(l)?.type==="video")){let c=this.insertEmbeddableElement({sceneX:n,sceneY:i,link:ir(l)});c&&this.setState({selectedElementIds:{[c.id]:!0}})}}};loadFileToCanvas=async(t,r)=>{t=await dc(t);try{let o=await Hm(t,this.state,this.scene.getElementsIncludingDeleted(),r);o.type===Z.excalidraw?(this.setState({isLoading:!0}),this.syncActionResult({...o.data,appState:{...o.data.appState||this.state,isLoading:!1},replaceFiles:!0,commitToHistory:!0})):o.type===Z.excalidrawlib&&await this.library.updateLibrary({libraryItems:t,merge:!0,openLibraryMenu:!0}).catch(n=>{console.error(n),this.setState({errorMessage:f("errors.importLibraryError")})})}catch(o){if(o instanceof vo&&o.code==="IMAGE_NOT_CONTAINS_SCENE_DATA"&&!this.isToolSupported("image")){this.setState({isLoading:!1,errorMessage:f("errors.imageToolNotSupported")});return}this.setState({isLoading:!1,errorMessage:o.message})}};handleCanvasContextMenu=t=>{if(t.preventDefault(),("pointerType"in t.nativeEvent&&t.nativeEvent.pointerType==="touch"||"pointerType"in t.nativeEvent&&t.nativeEvent.pointerType==="pen"&&t.button!==Yn.SECONDARY)&&this.state.activeTool.type!=="selection")return;let{x:r,y:o}=Ue(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",c=this.excalidrawContainerRef.current,{top:s,left:d}=c.getBoundingClientRect(),m=t.clientX-d,u=t.clientY-s;Ee("contextMenu","openContextMenu",l),this.setState({...n&&!this.state.selectedElementIds[n.id]?{...this.state,...Ht({editingGroupId:this.state.editingGroupId,selectedElementIds:{[n.id]:!0}},this.scene.getNonDeletedElements(),this.state,this),selectedLinearElement:te(n)?new K(n,this.scene):null}:this.state,showHyperlinkPopup:!1},()=>{this.setState({contextMenu:{top:u,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")ou(o,this.state.activeTool.type,t.origin.x,t.origin.y,n.x,n.y,kt(t.origin.x,n.x),kt(t.origin.y,n.y),tl(r),zd(r));else{let[i,a]=wt(n.x,n.y,r[S.CTRL_OR_CMD]?null:this.state.gridSize),l=ur(o)&&this.imageCache.get(o.fileId)?.image,c=l&&!(l instanceof Promise)?l.width/l.height:null;this.maybeCacheReferenceSnapPoints(r,[o]);let{snapOffset:s,snapLines:d}=QI(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});i+=s.x,a+=s.y,this.setState({snapLines:d}),ou(o,this.state.activeTool.type,t.originInGrid.x,t.originInGrid.y,i,a,kt(t.originInGrid.x,i),kt(t.originInGrid.y,a),Yr(o)?!tl(r):tl(r),zd(r),c,this.state.originSnapOffset),this.maybeSuggestBindingForAll([o]),(this.state.activeTool.type===ft.frame||this.state.activeTool.type===ft.magicframe)&&this.setState({elementsToHighlight:Nl(this.scene.getNonDeletedElements(),o,this.state)})}};maybeHandleResize=(t,r)=>{let o=this.scene.getSelectedElements(this.state),n=o.filter(d=>J(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,c]=wt(a.x-t.resize.offset.x,a.y-t.resize.offset.y,r[S.CTRL_OR_CMD]?null:this.state.gridSize),s=new Map;if(n.forEach(d=>{Fr(this.scene.getNonDeletedElements(),d.id).forEach(u=>{s.set(d.id+u.id,{x:u.x-d.x,y:u.y-d.y})})}),!this.state.selectedElementsAreBeingDragged){let[d,m]=wt(a.x,a.y,r[S.CTRL_OR_CMD]?null:this.state.gridSize),u={x:d-t.originInGrid.x,y:m-t.originInGrid.y},p=[...t.originalElements.values()];this.maybeCacheReferenceSnapPoints(r,o);let{snapOffset:g,snapLines:b}=JI(o,ge(p,this.state),this.state,r,u,i);l+=g.x,c+=g.y,this.setState({snapLines:b})}if(Rh(t,i,o,t.resize.arrowDirection,oa(r),zd(r),o.length===1&&Yr(o[0])?!tl(r):tl(r),l,c,t.resize.center.x,t.resize.center.y,this.state)){this.maybeSuggestBindingForAll(o);let d=new Set;return n.forEach(m=>{Nl(this.scene.getNonDeletedElements(),m,this.state).forEach(u=>d.add(u))}),this.setState({elementsToHighlight:[...d]}),!0}return!1};getContextMenuItems=t=>{let r=[];return r.push(uu,mu),t==="canvas"?this.state.viewModeEnabled?[...r,gu,Wl,K1,vi]:[cf,lr,uu,mu,pu,lr,Xh,P3,lr,gu,mf,Wl,K1,vi]:(r.push(pu),this.state.viewModeEnabled?[Ul,...r]:[du,Ul,cf,UI,WI,lr,...r,lr,Qh,ef,lr,tf,pf,gf,L3,rf,lr,af,lr,Vh,Yh,Kh,$h,lr,lf,sf,lr,xf,dg,Zh,ff,lr,gc])};handleWheel=it(t=>{if(t.preventDefault(),zc)return;let{deltaX:r,deltaY:o}=t;if(t.metaKey||t.ctrlKey){let n=Math.sign(o),i=Yi*100,a=Math.abs(o),l=o;a>i&&(l=i*n);let c=this.state.zoom.value-l/100;c+=Math.log10(Math.max(1,this.state.zoom.value))*-n*Math.min(1,a/20),this.translateCanvas(s=>({...vn({viewportX:this.lastViewportPosition.x,viewportY:this.lastViewportPosition.y,nextZoom:$o(c)},s),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=_m(n,o);if(l&&(i=l.x,a=l.y),Math.hypot(t-i,r-a)<Ub){let{x:d,y:m}=Dt({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}=Ue({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:Re.pointers})};resetShouldCacheIgnoreZoomDebounced=$i(()=>{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:c,offsetTop:s,offsetLeft:d}=this.state;if(o===l&&n===c&&i===d&&a===s){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=Ma.find(r=>r.code===this.props.langCode)||Ro;await $c(t),this.setAppState({})}};(I.MODE===Sp.TEST||I.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)}}}));zS=lb});var GS=y(()=>{});var US=y(()=>{});var WS=y(()=>{});var fD,VS,YS=y(()=>{"use strict";h();fD=()=>{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)})},VS=fD});var KS=y(()=>{});import bD from"clsx";import{jsx as $S}from"react/jsx-runtime";var XS,xD,ZS=y(()=>{"use strict";h();Hr();KS();zt();XS=({children:e})=>{let{FooterCenterTunnel:t}=rt(),r=He();return $S(t.In,{children:$S("div",{className:bD("footer-center zen-mode-transition",{"layer-ui__wrapper__footer-left--transition-bottom":r.zenModeEnabled}),children:e})})},xD=XS;XS.displayName="FooterCenter"});var jS=y(()=>{});import{jsx as Oi,jsxs as JS}from"react/jsx-runtime";var ED,yD,qS,QS=y(()=>{"use strict";h();jS();ED=()=>Oi("svg",{viewBox:"0 0 40 40",fill:"none",xmlns:"http://www.w3.org/2000/svg",className:"ExcalidrawLogo-icon",children:Oi("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"})}),yD=()=>JS("svg",{viewBox:"0 0 450 55",xmlns:"http://www.w3.org/2000/svg",fill:"none",className:"ExcalidrawLogo-text",children:[Oi("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)"}),Oi("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)"}),Oi("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)"}),Oi("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)"})]}),qS=({style:e,size:t="small",withText:r})=>JS("div",{className:`ExcalidrawLogo is-${t}`,style:e,children:[Oi(ED,{}),r&&Oi(yD,{})]})});import{Fragment as rC,jsx as Tt,jsxs as gb}from"react/jsx-runtime";var hb,Wc,eC,go,fb,bb,xb,Eb,yb,tC,oC=y(()=>{"use strict";h();Dn();xu();Y();be();Hr();se();zt();QS();hb=({icon:e,shortcut:t,children:r})=>{let o=De();return gb(rC,{children:[Tt("div",{className:"welcome-screen-menu-item__icon",children:e}),Tt("div",{className:"welcome-screen-menu-item__text",children:r}),t&&!o.editor.isMobile&&Tt("div",{className:"welcome-screen-menu-item__shortcut",children:t})]})};hb.displayName="WelcomeScreenMenuItemContent";Wc=({onSelect:e,children:t,icon:r,shortcut:o,className:n="",...i})=>Tt("button",{...i,type:"button",className:`welcome-screen-menu-item ${n}`,onClick:e,children:Tt(hb,{icon:r,shortcut:o,children:t})});Wc.displayName="WelcomeScreenMenuItem";eC=({children:e,href:t,icon:r,shortcut:o,className:n="",...i})=>Tt("a",{...i,className:`welcome-screen-menu-item ${n}`,href:t,target:"_blank",rel:"noreferrer",children:Tt(hb,{icon:r,shortcut:o,children:e})});eC.displayName="WelcomeScreenMenuItemLink";go=({children:e})=>{let{WelcomeScreenCenterTunnel:t}=rt();return Tt(t.In,{children:Tt("div",{className:"welcome-screen-center",children:e||gb(rC,{children:[Tt(fb,{}),Tt(bb,{children:f("welcomeScreen.defaults.center_heading")}),gb(xb,{children:[Tt(yb,{}),Tt(Eb,{})]})]})})})};go.displayName="Center";fb=({children:e})=>Tt("div",{className:"welcome-screen-center__logo virgil welcome-screen-decor",children:e||Tt(qS,{withText:!0})});fb.displayName="Logo";bb=({children:e})=>Tt("div",{className:"welcome-screen-center__heading welcome-screen-decor virgil",children:e});bb.displayName="Heading";xb=({children:e})=>Tt("div",{className:"welcome-screen-menu",children:e});xb.displayName="Menu";Eb=()=>{let e=Wt();return Tt(Wc,{onSelect:()=>e.executeAction(Ia),shortcut:"?",icon:Za,children:f("helpDialog.title")})};Eb.displayName="MenuItemHelp";yb=()=>{let e=He(),t=Wt();return e.viewModeEnabled?null:Tt(Wc,{onSelect:()=>t.executeAction(Hl),shortcut:Rn("loadScene"),icon:ja,children:f("buttons.load")})};yb.displayName="MenuItemLoadScene";tC=({onSelect:e})=>{let{t}=Pt();return Tt(Wc,{shortcut:null,onSelect:e,icon:qa,children:t("labels.liveCollaboration")})};tC.displayName="MenuItemLiveCollaborationTrigger";go.Logo=fb;go.Heading=bb;go.Menu=xb;go.MenuItem=Wc;go.MenuItemLink=eC;go.MenuItemHelp=Eb;go.MenuItemLoadScene=yb;go.MenuItemLiveCollaborationTrigger=tC});import{jsx as ls,jsxs as wb}from"react/jsx-runtime";var bp,xp,Ep,nC=y(()=>{"use strict";h();Y();Hr();se();bp=({children:e})=>{let{WelcomeScreenMenuHintTunnel:t}=rt();return ls(t.In,{children:wb("div",{className:"virgil welcome-screen-decor welcome-screen-decor-hint welcome-screen-decor-hint--menu",children:[hE,ls("div",{className:"welcome-screen-decor-hint__label",children:e||f("welcomeScreen.defaults.menuHint")})]})})};bp.displayName="MenuHint";xp=({children:e})=>{let{WelcomeScreenToolbarHintTunnel:t}=rt();return ls(t.In,{children:wb("div",{className:"virgil welcome-screen-decor welcome-screen-decor-hint welcome-screen-decor-hint--toolbar",children:[ls("div",{className:"welcome-screen-decor-hint__label",children:e||f("welcomeScreen.defaults.toolbarHint")}),bE]})})};xp.displayName="ToolbarHint";Ep=({children:e})=>{let{WelcomeScreenHelpHintTunnel:t}=rt();return ls(t.In,{children:wb("div",{className:"virgil welcome-screen-decor welcome-screen-decor-hint welcome-screen-decor-hint--help",children:[ls("div",{children:e||f("welcomeScreen.defaults.helpHint")}),fE]})})};Ep.displayName="HelpHint"});var iC=y(()=>{});import{Fragment as aC,jsx as Vc,jsxs as vD}from"react/jsx-runtime";var yp,wD,lC=y(()=>{"use strict";h();oC();nC();iC();yp=e=>Vc(aC,{children:e.children||vD(aC,{children:[Vc(go,{}),Vc(bp,{}),Vc(xp,{}),Vc(Ep,{})]})});yp.displayName="WelcomeScreen";yp.Center=go;yp.Hints={MenuHint:bp,ToolbarHint:xp,HelpHint:Ep};wD=yp});var sC=y(()=>{});import TD from"clsx";import{jsx as SD,jsxs as CD}from"react/jsx-runtime";var cC,ID,dC=y(()=>{"use strict";h();Y();se();Ql();sC();zt();cC=({isCollaborating:e,onSelect:t,...r})=>{let o=He();return CD(Jo,{...r,className:TD("collab-button",{active:e}),type:"button",onSelect:t,style:{position:"relative"},title:f("labels.liveCollaboration"),children:[qa,o.collaborators.size>0&&SD("div",{className:"CollabButton-collaborators",children:o.collaborators.size})]})},ID=cC;cC.displayName="LiveCollaborationTrigger"});import{jsx as mC,jsxs as kD}from"react/jsx-runtime";var uC,pC=y(()=>{"use strict";h();Hr();yc();be();se();Y();Qr();uC=({children:e,icon:t})=>{let{TTDDialogTriggerTunnel:r}=rt(),o=$e();return mC(r.In,{children:kD(Ne.Item,{onSelect:()=>{Ee("ai","dialog open","ttd"),o({openDialog:{name:"ttd",tab:"text-to-diagram"}})},icon:t??q0,children:[e??f("labels.textToDiagram"),mC(Ne.Item.Badge,{children:"AI"})]})})};uC.displayName="TTDDialogTrigger"});import AD,{useEffect as MD}from"react";import{Provider as LD}from"jotai";import{jsx as vb}from"react/jsx-runtime";var _D,PD,DD,Om=y(()=>{h();ax();be();W();GS();US();WS();YS();Y();X();_t();ZS();C1();lC();dC();ue();Y();ac();_n();Ln();vr();ae();X();Ve();Ec();W();Mc();Ql();be();A1();Y1();pC();ol();Xs();Z1();yt();Ar();Zt();ae();nl();VS();_D=e=>{let{onChange:t,initialData:r,excalidrawAPI:o,isCollaborating:n=!1,onPointerUpdate:i,renderTopRightUI:a,langCode:l=Ro.code,viewModeEnabled:c,zenModeEnabled:s,gridModeEnabled:d,libraryReturnUrl:m,theme:u,name:p,renderCustomStats:g,onPaste:b,detectScroll:E=!0,handleKeyboardGlobally:w=!1,onLibraryChange:v,autoFocus:T=!1,generateIdForFile:k,onLinkOpen:M,onPointerDown:A,onScrollChange:D,children:R,validateEmbeddable:H,renderEmbeddable:C,aiEnabled:O}=e,P=e.UIOptions?.canvasActions,G={...e.UIOptions,canvasActions:{...kp.canvasActions,...P},tools:{image:e.UIOptions?.tools?.image??!0}};return P?.export&&(G.canvasActions.export.saveFileToDisk=P.export?.saveFileToDisk??kp.canvasActions.export.saveFileToDisk),G.canvasActions.toggleTheme===null&&typeof u>"u"&&(G.canvasActions.toggleTheme=!0),MD(()=>{let j=V=>{typeof V.scale=="number"&&V.scale!==1&&V.preventDefault()};return document.addEventListener("touchmove",j,{passive:!1}),()=>{document.removeEventListener("touchmove",j)}},[]),vb(LD,{unstable_createStore:()=>mr,scope:Be,children:vb(ix,{langCode:l,theme:u,children:vb(zS,{onChange:t,initialData:r,excalidrawAPI:o,isCollaborating:n,onPointerUpdate:i,renderTopRightUI:a,langCode:l,viewModeEnabled:c,zenModeEnabled:s,gridModeEnabled:d,libraryReturnUrl:m,theme:u,name:p,renderCustomStats:g,UIOptions:G,onPaste:b,detectScroll:E,handleKeyboardGlobally:w,onLibraryChange:v,autoFocus:T,generateIdForFile:k,onLinkOpen:M,onPointerDown:A,onScrollChange:D,validateEmbeddable:H,renderEmbeddable:C,aiEnabled:O!==!1,children:R})})})},PD=(e,t)=>{if(e.children!==t.children)return!1;let{initialData:r,UIOptions:o={},...n}=e,{initialData:i,UIOptions:a={},...l}=t,c=Object.keys(o),s=Object.keys(a);return c.length!==s.length?!1:c.every(m=>m==="canvasActions"?Object.keys(o.canvasActions).every(p=>p==="export"&&o?.canvasActions?.export&&a?.canvasActions?.export?o.canvasActions.export.saveFileToDisk===a.canvasActions.export.saveFileToDisk:o?.canvasActions?.[p]===a?.canvasActions?.[p]):o[m]===a[m])&&bt(n,l)},DD=AD.memo(_D,PD);DD.displayName="Excalidraw"});Om();export{Jo as Button,Ju as DefaultSidebar,DD as Excalidraw,St as FONT_FAMILY,xD as Footer,ID as LiveCollaborationTrigger,Z as MIME_TYPES,cr as MainMenu,Bn as Sidebar,nt as THEME,V1 as TTDDialog,uC as TTDDialogTrigger,wD as WelcomeScreen,wo as bumpVersion,Rc as convertToExcalidrawElements,Ro as defaultLang,Xm as exportToBlob,wi as exportToCanvas,FM as exportToClipboard,Rl as exportToSvg,we as getCommonBounds,$t as getDefaultAppState,io as getElementBounds,nh as getFreeDrawSvgPath,ce as getNonDeletedElements,XM as getSceneVersion,cM as getVisibleSceneBounds,ve as isArrowElement,za as isExcalidrawElement,xt as isFreeDrawElement,ao as isInvisiblySmallElement,te as isLinearElement,z as isTextElement,kl as isValueInRange,Ma as languages,Pl as loadFromBlob,Eh as loadLibraryFromBlob,Hm as loadSceneOrLibraryFromBlob,U3 as mergeLibraryItems,B as mutateElement,Q as newElementWith,ir as normalizeLink,Tf as parseLibraryTokensFromUrl,xi as restore,U2 as restoreAppState,nc as restoreElements,ic as restoreLibraryItems,Fe as rotatePoint,Dt as sceneCoordsToViewportCoords,yi as serializeAsJSON,Wm as serializeLibraryAsJSON,De as useDevice,H8 as useHandleLibrary,Pt as useI18n,Ue as viewportCoordsToSceneCoords,Yw as zoomToFitBounds};
|
|
181
|
+
`),r)}}addTextFromPaste(t,r=!1){let{x:o,y:n}=Oe({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:Pi,locked:!1},a=10,l=n,s=r?[t]:t.split(`
|
|
182
|
+
`),c=s.reduce((m,p,u)=>{let g=p.trim(),f=Tr(i.fontFamily);if(g.length){let E=this.getTopLayerFrameAtSceneCoords({x:o,y:l}),y=Lt({...i,x:o,y:l,text:g,lineHeight:f,frameId:E?E.id:null});m.push(y),l+=y.height+a}else s[u-1]?.trim()&&(l+=jn(i.fontSize,f)+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:Ce(Object.fromEntries(c.map(m=>[m.id,!0])),this.state)}),!r&&c.length>1&&NT===!1&&!this.device.editor.isMobile&&(this.setToast({message:b("toast.pasteAsSingleElement",{shortcut:_("CtrlOrCmd+Shift+V")}),duration:5e3}),NT=!0),this.history.resumeRecording()}setAppState=(t,r)=>{this.setState(t,r)};removePointer=t=>{vi&&this.resetContextMenuTimer(),Ae.pointers.delete(t.pointerId)};toggleLock=(t="ui")=>{this.state.activeTool.locked||xe("toolbar","toggleLock",`${t} (${this.device.editor.isMobile?"mobile":"desktop"})`),this.setState(r=>({activeTool:{...r.activeTool,...Ke(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(Gw)};zoomCanvas=t=>{this.setState({...In({viewportX:this.state.width/2+this.state.offsetLeft,viewportY:this.state.height/2+this.state.offsetTop,nextZoom:Uo(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}=js({targetElements:o,appState:this.state,fitToViewport:!!r?.fitToViewport,viewportZoomFactor:r?.viewportZoomFactor});n=l.zoom,i=l.scrollX,a=l.scrollY}else{let l=Ho(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=t1({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,rn(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,Kl,window.location.pathname)}}catch(t){this.setState({errorMessage:t.message})}};addFiles=nt(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=>{Qt(o)&&r.has(o.fileId)&&(this.imageCache.delete(o.fileId),Te.delete(o))}),this.scene.informMutation(),this.addNewImagesToImageCache()});updateScene=nt(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:r,force:o})=>{let n;return o===void 0?n=this.state.openSidebar?.name===t?null:t:n=o?t:null,this.setState({openSidebar:n?{name:n,tab:r}:null}),!!n};updateCurrentCursorPosition=nt(t=>{this.lastViewportPosition.x=t.clientX,this.lastViewportPosition.y=t.clientY});onKeyDown=nt(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[S.CTRL_OR_CMD]&&t.key.toLowerCase()===S.V&&(Wp=t.shiftKey,clearTimeout(RT),RT=window.setTimeout(()=>{Wp=!1},100)),t[S.CTRL_OR_CMD]&&Mo(t.target)&&(t.code===ue.MINUS||t.code===ue.EQUAL)){t.preventDefault();return}if(Mo(t.target)&&t.key!==S.ESCAPE||Ga(t.key)&&iu(t.target))return;if(t.key===S.QUESTION_MARK){this.setState({openDialog:{name:"help"}});return}else if(t.key.toLowerCase()===S.E&&t.shiftKey&&t[S.CTRL_OR_CMD]){t.preventDefault(),this.setState({openDialog:{name:"imageExport"}});return}if(t.key===S.PAGE_UP||t.key===S.PAGE_DOWN){let i=(t.shiftKey?this.state.width:this.state.height)/this.state.zoom.value;t.key===S.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[S.CTRL_OR_CMD]&&this.state.isBindingEnabled&&this.setState({isBindingEnabled:!1}),Ga(t.key)){let i=this.state.gridSize&&(t.shiftKey?qp:this.state.gridSize)||(t.shiftKey?Pb:qp),a=0,l=0;t.key===S.ARROW_LEFT?a=-i:t.key===S.ARROW_RIGHT?a=i:t.key===S.ARROW_UP?l=-i:t.key===S.ARROW_DOWN&&(l=i);let s=this.scene.getSelectedElements({selectedElementIds:this.state.selectedElementIds,includeBoundTextElement:!0,includeElementsInFrames:!0});s.forEach(c=>{B(c,{x:c.x+a,y:c.y+l}),go(c,this.scene.getNonDeletedElementsMap(),{simultaneouslyUpdated:s})}),this.maybeSuggestBindingForAll(s),t.preventDefault()}else if(t.key===S.ENTER){let i=this.scene.getSelectedElements(this.state);if(i.length===1){let a=i[0];if(t[S.CTRL_OR_CMD])ee(a)&&(!this.state.editingLinearElement||this.state.editingLinearElement.elementId!==i[0].id)&&(this.history.resumeRecording(),this.setState({editingLinearElement:new V(a)}));else if(G(a)||fx(a)){let l;G(a)||(l=a);let s=gd(a,this.state,this.scene.getNonDeletedElementsMap()),c=s.x,d=s.y;this.startTextEditing({sceneX:c,sceneY:d,container:l}),t.preventDefault();return}else X(a)&&this.setState({editingFrame:a.id})}}else if(!t.ctrlKey&&!t.altKey&&!t.metaKey&&this.state.draggingElement===null){let i=_2(t.key);i?(this.state.activeTool.type!==i&&xe("toolbar",i,`keyboard (${this.device.editor.isMobile?"mobile":"desktop"})`),this.setActiveTool({type:i}),t.stopPropagation()):t.key===S.Q&&(this.toggleLock("keyboard"),t.stopPropagation())}if(t.key===S.SPACE&&Ae.pointers.size===0&&(ba=!0,De(this.interactiveCanvas,Se.GRAB),t.preventDefault()),(t.key===S.G||t.key===S.S)&&!t.altKey&&!t[S.CTRL_OR_CMD]){let i=this.scene.getSelectedElements(this.state);if(this.state.activeTool.type==="selection"&&!i.length)return;t.key===S.G&&(an(this.state.activeTool.type)||i.some(a=>an(a.type)))&&(this.setState({openPopup:"elementBackground"}),t.stopPropagation()),t.key===S.S&&(this.setState({openPopup:"elementStroke"}),t.stopPropagation())}if(t.key===S.K&&!t.altKey&&!t[S.CTRL_OR_CMD]){this.state.activeTool.type==="laser"?this.setActiveTool({type:"selection"}):this.setActiveTool({type:"laser"});return}t[S.CTRL_OR_CMD]&&(t.key===S.BACKSPACE||t.key===S.DELETE)&&sr.set(sc,"clearCanvas");let r=t.key.toLocaleLowerCase(),o=r===S.S&&t.shiftKey,n=t.key===S.I||r===S.G&&t.shiftKey;(o||n)&&this.openEyeDropper({type:o?"stroke":"background"})});onWheel=nt(t=>{!(t.target instanceof HTMLCanvasElement)&&t.ctrlKey&&t.preventDefault()});onKeyUp=nt(t=>{if(t.key===S.SPACE&&(this.state.viewModeEnabled?De(this.interactiveCanvas,Se.GRAB):this.state.activeTool.type==="selection"?Cr(this.interactiveCanvas):(kr(this.interactiveCanvas,this.state),this.setState({selectedElementIds:Ce({},this.state),selectedGroupIds:{},editingGroupId:null,activeEmbeddable:null})),ba=!1),!t[S.CTRL_OR_CMD]&&!this.state.isBindingEnabled&&this.setState({isBindingEnabled:!0}),Ga(t.key)){let r=this.scene.getSelectedElements(this.state),o=this.scene.getNonDeletedElementsMap();Ro(this.state)?xs(r,this.scene.getNonDeletedElements(),o):ys(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=Ke(this.state,t);r.type==="hand"?De(this.interactiveCanvas,Se.GRAB):ba||kr(this.interactiveCanvas,this.state),Qb(document.activeElement)&&this.focusContainer(),ts(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};return r.type!=="selection"?{...o,activeTool:r,selectedElementIds:Ce({},o),selectedGroupIds:Ce({},o),editingGroupId:null,multiElement:null,...n}:{...o,activeTool:r,...n}})};setOpenDialog=t=>{this.setState({openDialog:t})};setCursor=t=>{De(this.interactiveCanvas,t)};resetCursor=()=>{Cr(this.interactiveCanvas)};isTouchScreenMultiTouchGesture=()=>Ae.pointers.size>=2;getName=()=>this.state.name||this.props.name||`${b("labels.untitled")}-${nu()}`;onGestureStart=nt(t=>{t.preventDefault(),this.isTouchScreenMultiTouchGesture()&&this.setState({selectedElementIds:Ce({},this.state),activeEmbeddable:null}),Ae.initialScale=this.state.zoom.value});onGestureChange=nt(t=>{if(t.preventDefault(),this.isTouchScreenMultiTouchGesture())return;let r=Ae.initialScale;r&&this.setState(o=>({...In({viewportX:this.lastViewportPosition.x,viewportY:this.lastViewportPosition.y,nextZoom:Uo(r*t.scale)},o)}))});onGestureEnd=nt(t=>{t.preventDefault(),this.isTouchScreenMultiTouchGesture()&&this.setState({previousSelectedElementIds:{},selectedElementIds:Ce(this.state.previousSelectedElementIds,this.state)}),Ae.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&&G(s)?ju(s,st(s,o),o,{text:i,isDeleted:l,originalText:a}):s)])};PT({id:t.id,canvas:this.canvas,getViewportCoords:(i,a)=>{let{x:l,y:s}=Mt({sceneX:i,sceneY:a},this.state);return[l-this.state.offsetLeft,s-this.state.offsetTop]},onChange:nt(i=>{n(i,i,!1),os(t)&&go(t,o)}),onSubmit:nt(({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:Ce({...d.selectedElementIds,[c]:!0},d)}))}s&&Va(this.scene.getNonDeletedElements(),[t]),(!s||r)&&this.history.resumeRecording(),this.setState({draggingElement:null,editingElement:null}),this.state.activeTool.locked&&kr(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:Ce({},this.state),selectedGroupIds:{},editingGroupId:null,activeEmbeddable:null})}getTextElementAtPosition(t,r){let o=this.getElementAtPosition(t,r,{includeBoundTextElement:!0});return o&&G(o)&&!o.isDeleted?o: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 bs(i,this.state,this.frameNameBoundsCache,t,r,this.scene.getNonDeletedElementsMap())?n[n.length-2]:i}return n.length===1?n[0]:null}getElementsAtPosition(t,r,o=!1,n=!1){let i=o&&n?this.scene.getNonDeletedElements():this.scene.getNonDeletedElements().filter(l=>(n||!l.locked)&&(o||!(G(l)&&l.containerId))),a=this.scene.getNonDeletedElementsMap();return fu(i,l=>Fa(l,this.state,this.frameNameBoundsCache,t,r,a)).filter(l=>{let s=Pt(l,a);return s&&this.state.frameRendering.enabled&&this.state.frameRendering.clip?Sg({x:t,y:r},s,a):!0})}startTextEditing=({sceneX:t,sceneY:r,insertAtParentCenter:o=!0,container:n})=>{let i=!1,a=o&&this.getTextWysiwygSnappedToCenterPosition(t,r,this.state,n);n&&a&&(ae(n,this.scene.getNonDeletedElementsMap())||(i=!0));let l=null,s=this.scene.getSelectedElements(this.state);s.length===1?G(s[0])?l=s[0]:n?l=ae(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||Tr(c),m=this.state.currentItemFontSize;if(!l&&i&&n&&!we(n)){let f=ud(Be({fontSize:m,fontFamily:c}),d),E=pd(m,d),y=Math.max(n.height,E),T=Math.max(n.width,f);B(n,{height:y,width:T}),t=n.x+T/2,r=n.y+y/2,a&&(a=this.getTextWysiwygSnappedToCenterPosition(t,r,this.state,n))}let p=this.getTopLayerFrameAtSceneCoords({x:t,y:r}),u=l||Lt({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?gt.MIDDLE:Pi,containerId:i?n?.id:void 0,groupIds:n?.groupIds??[],lineHeight:d,angle:n?.angle??0,frameId:p?p.id:null});if(!l&&i&&n&&B(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 r=this.scene.getSelectedElements(this.state);if(r.length===1&&ee(r[0])){if(t[S.CTRL_OR_CMD]&&(!this.state.editingLinearElement||this.state.editingLinearElement.elementId!==r[0].id)){this.history.resumeRecording(),this.setState({editingLinearElement:new V(r[0])});return}else if(this.state.editingLinearElement&&this.state.editingLinearElement.elementId===r[0].id)return}Cr(this.interactiveCanvas);let{x:o,y:n}=Oe(t,this.state);if(un(this.state).length>0){let a=this.getElementAtPosition(o,n),l=a&&Tx(a,this.state.selectedGroupIds);if(l){this.setState(s=>({...s,...Gt({editingGroupId:l,selectedElementIds:{[a.id]:!0}},this.scene.getNonDeletedElements(),s,this)}));return}}if(Cr(this.interactiveCanvas),!t[S.CTRL_OR_CMD]&&!this.state.viewModeEnabled){let a=this.getElementAtPosition(o,n);if(Ft(a)){this.setState({activeEmbeddable:{element:a,state:"active"}});return}let l=zu(this.scene.getNonDeletedElements(),this.state,o,n,this.scene.getNonDeletedElementsMap());if(l&&(cr(l)||!Jt(l.backgroundColor)||Ui(l,this.state,this.frameNameBoundsCache,[o,n],this.scene.getNonDeletedElementsMap()))){let s=gd(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&&Fd(i,this.scene.getNonDeletedElementsMap(),this.state,[t.x,t.y],this.device.editor.isMobile)))};redirectToLink=(t,r)=>{let o=at(this.lastPointerDownEvent.clientX,this.lastPointerDownEvent.clientY,this.lastPointerUpEvent.clientX,this.lastPointerUpEvent.clientY);if(!this.hitLinkElement||r&&o>en||!r&&o!==0)return;let n=Oe(this.lastPointerDownEvent,this.state),i=this.scene.getNonDeletedElementsMap(),a=Fd(this.hitLinkElement,i,this.state,[n.x,n.y],this.device.editor.isMobile),l=Oe(this.lastPointerUpEvent,this.state),s=Fd(this.hitLinkElement,i,this.state,[l.x,l.y],this.device.editor.isMobile);if(a&&s){let c=this.hitLinkElement.link;if(c){c=tr(c);let d;if(this.props.onLinkOpen&&(d=Kc("excalidraw-link",t.nativeEvent),this.props.onLinkOpen({...this.hitLinkElement,link:c},d)),!d?.defaultPrevented){let m=Ed(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=>Sg(t,n,r));return o.length?o[o.length-1]:null};handleCanvasPointerMove=t=>{this.savePointer(t.clientX,t.clientY,this.state.cursorButton),this.lastPointerMoveEvent=t.nativeEvent,Ae.pointers.has(t.pointerId)&&Ae.pointers.set(t.pointerId,{x:t.clientX,y:t.clientY});let r=Ae.initialScale;if(Ae.pointers.size===2&&Ae.lastCenter&&r&&Ae.initialDistance){let p=Hh(Ae.pointers),u=p.x-Ae.lastCenter.x,g=p.y-Ae.lastCenter.y;Ae.lastCenter=p;let f=zh(Array.from(Ae.pointers.values())),E=this.state.activeTool.type==="freedraw"&&this.state.penMode?1:f/Ae.initialDistance,y=E?Uo(r*E):this.state.zoom.value;this.setState(T=>{let w=In({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 Ae.lastCenter=Ae.initialDistance=Ae.initialScale=null;if(ba||xc||Zf||xo(this.state))return;let n=sf(jf,t.clientX-this.state.offsetLeft,t.clientY-this.state.offsetTop).isOverEither;!this.state.draggingElement&&!this.state.multiElement&&(n?Cr(this.interactiveCanvas):kr(this.interactiveCanvas,this.state));let i=Oe(t,this.state),{x:a,y:l}=i;if(!this.state.draggingElement&&cT(this.state.activeTool.type)){let{originOffset:p,snapLines:u}=sT(this.scene.getNonDeletedElements(),this.state,{x:a,y:l},t,this.scene.getNonDeletedElementsMap());this.setState(g=>{let f=$c(g.snapLines,u),E=g.originSnapOffset?$c(g.originSnapOffset,p):p;return g.snapLines===f&&g.originSnapOffset===E?null:{snapLines:f,originSnapOffset:E}})}else this.state.draggingElement||this.setState(p=>p.snapLines.length?{snapLines:[]}:null);if(this.state.editingLinearElement&&!this.state.editingLinearElement.isDragging){let p=V.handlePointerMove(t,a,l,this.state,this.scene.getNonDeletedElementsMap());p&&p!==this.state.editingLinearElement&&$f(()=>{this.setState({editingLinearElement:p})}),p?.lastUncommittedPoint!=null?this.maybeSuggestBindingAtCursor(i):$f(()=>{this.setState({suggestedBindings:[]})})}if(cu(this.state.activeTool.type)){let{draggingElement:p}=this.state;Et(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:f,lastCommittedPoint:E}=p,y=f[f.length-1];if(kr(this.interactiveCanvas,this.state),y===E)at(a-u,l-g,y[0],y[1])>=Ta?B(p,{points:[...f,[a-u,l-g]]}):De(this.interactiveCanvas,Se.POINTER);else if(f.length>2&&E&&at(a-u,l-g,E[0],E[1])<Ta)De(this.interactiveCanvas,Se.POINTER),B(p,{points:f.slice(0,-1)});else{let[T,w]=yt(a,l,t[S.CTRL_OR_CMD]?null:this.state.gridSize),[I,k]=p?.lastCommittedPoint??[0,0],C=T-u-I,D=w-g-k;Wi(t)&&({width:C,height:D}=Ka(I+u,k+g,T,w)),dr(f,this.state.zoom.value)&&De(this.interactiveCanvas,Se.POINTER),B(p,{points:[...f.slice(0,-1),[I+C,k+D]]})}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=lm(c,this.state,a,l,this.state.zoom,t.pointerType,this.scene.getNonDeletedElementsMap());if(p&&p.transformHandleType){De(this.interactiveCanvas,cm(p));return}}else if(d.length>1&&!n){let p=sm(ye(d),a,l,this.state.zoom,t.pointerType);if(p){De(this.interactiveCanvas,cm({transformHandleType:p}));return}}let m=this.getElementAtPosition(i.x,i.y);this.hitLinkElement=this.getElementLinkAtPosition(i,m),!ur(this.state)&&(this.hitLinkElement&&!this.state.selectedElementIds[this.hitLinkElement.id]?(De(this.interactiveCanvas,Se.POINTER),u2(this.hitLinkElement,this.state,this.scene.getNonDeletedElementsMap())):(g2(),m&&(m.link||xt(m))&&this.state.selectedElementIds[m.id]&&!this.state.contextMenu&&!this.state.showHyperlinkPopup?this.setState({showHyperlinkPopup:"info"}):this.state.activeTool.type==="text"?De(this.interactiveCanvas,G(m)?Se.TEXT:Se.CROSSHAIR):this.state.viewModeEnabled?De(this.interactiveCanvas,Se.GRAB):n?De(this.interactiveCanvas,Se.AUTO):this.state.selectedLinearElement?this.handleHoverSelectedLinearElement(this.state.selectedLinearElement,a,l):t[S.CTRL_OR_CMD]?De(this.interactiveCanvas,Se.AUTO):(m||this.isHittingCommonBoundingBoxOfSelectedElements(i,d))&&!m?.locked&&(m&&Ft(m)&&this.isIframeLikeElementCenter(m,t,a,l)?(De(this.interactiveCanvas,Se.POINTER),this.setState({activeEmbeddable:{element:m,state:"hover"}})):(De(this.interactiveCanvas,Se.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 g=u.groupIds.at(-1);if(!i.has(g)){i.add(g);let f=Ze(a,g);for(let E of f)t.altKey?this.elementsPendingErasure.delete(E.id):this.elementsPendingErasure.add(E.id)}}}},s=at(r.lastCoords.x,r.lastCoords.y,o.x,o.y),c=10/this.state.zoom.value,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,g=(1-u)*d.x+u*o.x,f=(1-u)*d.y+u*o.y;d.x=g,d.y=f}if(r.lastCoords.x=o.x,r.lastCoords.y=o.y,n){for(let p of this.scene.getNonDeletedElements())Me(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=>{Ec=!0};handleHoverSelectedLinearElement(t,r,o){let n=this.scene.getNonDeletedElementsMap(),i=V.getElement(t.elementId,n),a=ae(i,n);if(i)if(this.state.selectedLinearElement){let l=-1,s=null;Ui(i,this.state,this.frameNameBoundsCache,[r,o],n)?(l=V.getPointIndexUnderCursor(i,n,this.state.zoom,r,o),s=V.getSegmentMidpointHitCoords(t,{x:r,y:o},this.state,this.scene.getNonDeletedElementsMap()),l>=0||s?De(this.interactiveCanvas,Se.POINTER):De(this.interactiveCanvas,Se.MOVE)):Ba([i],this.state)&&bs(i,this.state,this.frameNameBoundsCache,r,o,n)?De(this.interactiveCanvas,Se.MOVE):a&&Fa(a,this.state,this.frameNameBoundsCache,r,o,this.scene.getNonDeletedElementsMap())&&De(this.interactiveCanvas,Se.MOVE),this.state.selectedLinearElement.hoverPointIndex!==l&&this.setState({selectedLinearElement:{...this.state.selectedLinearElement,hoverPointIndex:l}}),V.arePointsEqual(this.state.selectedLinearElement.segmentMidPointHoveredCoords,s)||this.setState({selectedLinearElement:{...this.state.selectedLinearElement,segmentMidPointHoveredCoords:s}})}else De(this.interactiveCanvas,Se.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:Ce(Object.keys(this.state.selectedElementIds).filter(d=>d!==c.id).reduce((d,m)=>(d[m]=this.state.selectedElementIds[m],d),{}),this.state)}});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=La(this.device,{isTouchScreen:!0})),xc||(this.lastPointerDownEvent=t,this.handleCanvasPanUsingWheelOrSpaceDrag(t)))return;if(this.setState({lastPointerDownWith:t.pointerType,cursorButton:"down"}),this.savePointer(t.clientX,t.clientY,"down"),t.button===Bn.ERASER&&this.state.activeTool.type!==ht.eraser){this.setState({activeTool:Ke(this.state,{type:ht.eraser,lastActiveToolBeforeEraser:this.state.activeTool})},()=>{this.handleCanvasPointerDown(t);let c=()=>{d(),m?.(),ur(this.state)&&this.setState({activeTool:Ke(this.state,{...this.state.activeTool.lastActiveTool||{type:ht.selection},lastActiveToolBeforeEraser:null})})},d=dt(window,"pointerup",c,{once:!0}),m;requestAnimationFrame(()=>{m=this.missingPointerEventCleanupEmitter.once(c)})});return}if(t.button!==Bn.MAIN&&t.button!==Bn.TOUCH&&t.button!==Bn.ERASER||Ae.pointers.size>1)return;let o=this.initialPointerDownState(t);if(this.setState({selectedElementsAreBeingDragged:!1}),this.handleDraggingScrollBar(t,o)||(this.clearSelectionIfNotUsingSelection(),this.updateBindingEnabledOnPointerMove(t),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"){De(this.interactiveCanvas,Se.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}=Oe(t,this.state),p=this.getTopLayerFrameAtSceneCoords({x:d,y:m});B(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"?kr(this.interactiveCanvas,this.state):this.state.activeTool.type===ht.frame||this.state.activeTool.type===ht.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=Oe({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(Ft(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&&Ft(this.hitLinkElement)&&!ug(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"&&(Ec=!1,vi?Ec=!0:vi=window.setTimeout(()=>{vi=0,Ec||this.handleCanvasContextMenu(t)},Bb))};resetContextMenuTimer=()=>{clearTimeout(vi),vi=0,Ec=!1};maybeCleanupAfterMissingPointerUp=t=>{yc?.(),this.missingPointerEventCleanupEmitter.trigger(t).clear()};handleCanvasPanUsingWheelOrSpaceDrag=t=>{if(!(Ae.pointers.size<=1&&(t.button===Bn.WHEEL||t.button===Bn.MAIN&&ba||xo(this.state)||this.state.viewModeEnabled))||G(this.state.editingElement))return!1;xc=!0,t.preventDefault();let r=!1,o=typeof window===void 0?!1:/Linux/.test(window.navigator.platform);De(this.interactiveCanvas,Se.GRABBING);let{clientX:n,clientY:i}=t,a=Op(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=nt(yc=()=>{yc=null,xc=!1,ba||(this.state.viewModeEnabled?De(this.interactiveCanvas,Se.GRAB):kr(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){Ae.pointers.set(t.pointerId,{x:t.clientX,y:t.clientY}),Ae.pointers.size===2&&(Ae.lastCenter=Hh(Ae.pointers),Ae.initialScale=this.state.zoom.value,Ae.initialDistance=zh(Array.from(Ae.pointers.values())))}initialPointerDownState(t){let r=Oe(t,this.state),o=this.scene.getSelectedElements(this.state),[n,i,a,l]=ye(o);return{origin:r,withCmdOrCtrl:t[S.CTRL_OR_CMD],originInGrid:lo(yt(r.x,r.y,t[S.CTRL_OR_CMD]?null:this.state.gridSize)),scrollbars:sf(jf,t.clientX-this.state.offsetLeft,t.clientY-this.state.offsetTop),lastCoords:{...r},originalElements:this.scene.getNonDeletedElements().reduce((s,c)=>(s.set(c.id,hn(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;Zf=!0,r.lastCoords.x=t.clientX,r.lastCoords.y=t.clientY;let o=Op(i=>{i.target instanceof HTMLElement&&this.handlePointerMoveOverScrollbars(i,r)}),n=nt(()=>{yc=null,Zf=!1,kr(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 yc=n,window.addEventListener("pointermove",o),window.addEventListener("pointerup",n),!0}clearSelectionIfNotUsingSelection=()=>{this.state.activeTool.type!=="selection"&&this.setState({selectedElementIds:Ce({},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){let a=lm(o,this.state,r.origin.x,r.origin.y,this.state.zoom,t.pointerType,this.scene.getNonDeletedElementsMap());a!=null&&(this.setState({resizingElement:a.element}),r.resize.handleType=a.transformHandleType)}else i.length>1&&(r.resize.handleType=sm(ye(i),r.origin.x,r.origin.y,this.state.zoom,t.pointerType));if(r.resize.handleType)r.resize.isResizing=!0,r.resize.offset=lo(_g(r.resize.handleType,i,n,r.origin.x,r.origin.y)),i.length===1&&ee(i[0])&&i[0].points.length===2&&(r.resize.arrowDirection=Dg(r.resize.handleType,i[0]));else{if(this.state.selectedLinearElement){let s=this.state.editingLinearElement||this.state.selectedLinearElement,c=V.handlePointerDown(t,this.state,this.history,r.origin,s,this.scene.getNonDeletedElements(),n);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:Ce({[this.state.editingLinearElement.elementId]:!0},this.state)});else if(a!=null){if(t[S.CTRL_OR_CMD])return this.state.selectedElementIds[a.id]||(r.hit.wasAddedToSelection=!0),this.setState(s=>({...vx(s,a),previousSelectedElementIds:this.state.selectedElementIds})),!1;this.state.selectedElementIds[a.id]||(this.state.editingGroupId&&!Zi(a,this.state.editingGroupId)&&this.setState({selectedElementIds:Ce({},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)}),X(a))Mr(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=>Ze(this.scene.getNonDeletedElements(),u)).filter(u=>X(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=>Ze(this.scene.getNonDeletedElements(),g)).forEach(g=>{delete c[g.id]}))})}return{...Gt({editingGroupId:s.editingGroupId,selectedElementIds:c},this.scene.getNonDeletedElements(),s,this),showHyperlinkPopup:a.link||xt(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=10/this.state.zoom.value,[n,i,a,l]=ye(r);return t.x>n-o&&t.x<a+o&&t.y>i-o&&t.y<l+o}handleTextOnPointerDown=(t,r)=>{if(G(this.state.editingElement))return;let o=r.origin.x,n=r.origin.y,i=this.getElementAtPosition(o,n,{includeBoundTextElement:!0}),a=zu(this.scene.getNonDeletedElements(),this.state,o,n,this.scene.getNonDeletedElementsMap());cr(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}),Cr(this.interactiveCanvas),this.state.activeTool.locked||this.setState({activeTool:Ke(this.state,{type:"selection"})})};handleFreeDrawElementOnPointerDown=(t,r,o)=>{let[n,i]=yt(o.origin.x,o.origin.y,null),a=this.getTopLayerFrameAtSceneCoords({x:n,y:i}),l=_x({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:Ce(m,d)}});let s=l.simulatePressure?l.pressures:[...l.pressures,t.pressure];B(l,{points:[[0,0]],pressures:s});let c=No(o.origin,this.scene.getNonDeletedElements(),this.scene.getNonDeletedElementsMap());this.scene.addNewElement(l),this.setState({draggingElement:l,editingElement:l,startBoundElement:c,suggestedBindings:[]})};insertIframeElement=({sceneX:t,sceneY:r,width:o,height:n})=>{let[i,a]=yt(t,r,this.lastPointerDownEvent?.[S.CTRL_OR_CMD]?null:this.state.gridSize),l=Lx({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.replaceAllElements([...this.scene.getElementsIncludingDeleted(),l]),l};insertEmbeddableElement=({sceneX:t,sceneY:r,link:o})=>{let[n,i]=yt(t,r,this.lastPointerDownEvent?.[S.CTRL_OR_CMD]?null:this.state.gridSize),a=xn(o);if(!a)return;a.error instanceof URIError&&this.setToast({message:b("toast.unrecognizedLinkFormat"),closable:!0});let l=Zu({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.replaceAllElements([...this.scene.getElementsIncludingDeleted(),l]),l};createImageElement=({sceneX:t,sceneY:r,addToFrameUnderCursor:o=!0})=>{let[n,i]=yt(t,r,this.lastPointerDownEvent?.[S.CTRL_OR_CMD]?null:this.state.gridSize),a=o?this.getTopLayerFrameAtSceneCoords({x:n,y:i}):null;return Is({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"&&dr(n.points,this.state.zoom.value)){B(n,{lastCommittedPoint:n.points[n.points.length-1]}),this.actionManager.executeAction(Zr);return}let{x:i,y:a,lastCommittedPoint:l}=n;if(n.points.length>1&&l&&at(o.origin.x-i,o.origin.y-a,l[0],l[1])<Ta){this.actionManager.executeAction(Zr);return}this.setState(s=>({selectedElementIds:Ce({...s.selectedElementIds,[n.id]:!0},s)})),B(n,{lastCommittedPoint:n.points[n.points.length-1]}),De(this.interactiveCanvas,Se.POINTER)}else{let[n,i]=yt(o.origin.x,o.origin.y,t[S.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=Ur({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:tt.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:Ce(g,u)}}),B(m,{points:[...m.points,[0,0]]});let p=No(o.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:Do(t)?tt.ADAPTIVE_RADIUS:tt.PROPORTIONAL_RADIUS}:null}createGenericElementOnPointerDown=(t,r)=>{let[o,n]=yt(r.origin.x,r.origin.y,this.lastPointerDownEvent?.[S.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=Zu({type:"embeddable",...a}):l=Ar({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,r)=>{let[o,n]=yt(t.origin.x,t.origin.y,this.lastPointerDownEvent?.[S.CTRL_OR_CMD]?null:this.state.gridSize),i={x:o,y:n,opacity:this.state.currentItemOpacity,locked:!1,...Ue},a=r===ht.magicframe?Ss(i):Id(i);this.scene.replaceAllElements([...this.scene.getElementsIncludingDeleted(),a]),this.setState({multiElement:null,draggingElement:a,editingElement:a})};maybeCacheReferenceSnapPoints(t,r,o=!1){Pn({event:t,appState:this.state,selectedElements:r})&&(o||!Qr.getReferenceSnapPoints())&&Qr.setReferenceSnapPoints(nT(this.scene.getNonDeletedElements(),r,this.state,this.scene.getNonDeletedElementsMap()))}maybeCacheVisibleGaps(t,r,o=!1){Pn({event:t,appState:this.state,selectedElements:r})&&(o||!Qr.getVisibleGaps())&&Qr.setVisibleGaps(oT(this.scene.getNonDeletedElements(),r,this.state,this.scene.getNonDeletedElementsMap()))}onKeyDownFromPointerDownHandler(t){return nt(r=>{this.maybeHandleResize(t,r)||this.maybeDragNewGenericElement(t,r)})}onKeyUpFromPointerDownHandler(t){return nt(r=>{r.key===S.ALT&&r.preventDefault(),!this.maybeHandleResize(t,r)&&this.maybeDragNewGenericElement(t,r)})}onPointerMoveFromPointerDownHandler(t){return Op(r=>{if(t.drag.offset===null&&(t.drag.offset=lo(Bg(this.scene.getSelectedElements(this.state),t.origin.x,t.origin.y))),!(r.target instanceof HTMLElement)||this.handlePointerMoveOverScrollbars(r,t))return;let n=Oe(r,this.state);if(ur(this.state)){this.handleEraser(r,t,n);return}this.state.activeTool.type==="laser"&&this.laserTrails.addPointToPath(n.x,n.y);let[i,a]=yt(n.x,n.y,r[S.CTRL_OR_CMD]?null:this.state.gridSize);if(!t.drag.hasOccurred&&(this.state.activeTool.type==="arrow"||this.state.activeTool.type==="line")&&at(n.x,n.y,t.origin.x,t.origin.y)<en)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(V.shouldAddMidpoint(this.state.selectedLinearElement,n,this.state,l)){let u=V.addMidpoint(this.state.selectedLinearElement,n,this.state,!r[S.CTRL_OR_CMD],l);if(!u)return;$f(()=>{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(V.handlePointDragging(r,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&&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(g=>g.locked))return;let p=m.find(g=>X(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},f=[...t.originalElements.values()],E=r.shiftKey;if(E){let w=Math.abs(g.x),I=Math.abs(g.y),k=E&&w<I,C=E&&w>I;k&&(g.x=0),C&&(g.y=0)}this.maybeCacheVisibleGaps(r,m),this.maybeCacheReferenceSnapPoints(r,m);let{snapOffset:y,snapLines:T}=iT(f,g,this.state,r,this.scene.getNonDeletedElementsMap());if(this.setState({snapLines:T}),!this.state.editingFrame&&Ng(t,m,g,this.state,this.scene,y,r[S.CTRL_OR_CMD]?null:this.state.gridSize),this.maybeSuggestBindingForAll(m),r.altKey&&!t.hit.hasBeenDuplicated){t.hit.hasBeenDuplicated=!0;let w=[],I=[],k=new Map,C=new Map,D=t.hit.element,R=new Set(this.scene.getSelectedElements({selectedElementIds:this.state.selectedElementIds,includeBoundTextElement:!0,includeElementsInFrames:!0}).map(M=>M.id)),z=this.scene.getElementsIncludingDeleted();for(let M of z)if(R.has(M.id)||M.id===D?.id&&t.hit.wasAddedToSelection){let A=Cs(this.state.editingGroupId,k,M),H=t.originalElements.get(M.id);B(A,{x:H.x,y:H.y}),t.originalElements.set(A.id,A),w.push(A),I.push(M),C.set(M.id,A.id)}else w.push(M);let L=[...w,...I];dd(w,I,C),ld(L,I,C,"duplicatesServeAsOld"),em(L,I,C),this.scene.replaceAllElements(L),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,g=m.length>0&&m[m.length-1];if(!(g&&g[0]===p&&g[1]===u)){let E=d.simulatePressure?d.pressures:[...d.pressures,r.pressure];B(d,{points:[...m,[p,u]],pressures:E})}}else if(ee(d)){t.drag.hasOccurred=!0,this.setState({selectedElementsAreBeingDragged:!0});let m=d.points,p=i-d.x,u=a-d.y;Wi(r)&&m.length===2&&({width:p,height:u}=Ka(d.x,d.y,n.x,n.y)),m.length===1?B(d,{points:[...m,[p,u]]}):m.length===2&&B(d,{points:[...m.slice(0,-1),[p,u]]}),Et(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)V.handleBoxSelection(r,this.state,this.setState.bind(this),this.scene.getNonDeletedElementsMap());else{let p=!0;!r.shiftKey&&Re(m,this.state)&&(t.withCmdOrCtrl&&t.hit.element?this.setState(g=>Gt({...g,selectedElementIds:{[t.hit.element.id]:!0}},this.scene.getNonDeletedElements(),g,this)):p=!1);let u=pl(m,d,this.scene.getNonDeletedElementsMap());this.setState(g=>{let f={...p&&g.selectedElementIds,...u.reduce((E,y)=>(E[y.id]=!0,E),{})};return t.hit.element&&(u.length?delete f[t.hit.element.id]:f[t.hit.element.id]=!0),g=p?g:{...g,selectedGroupIds:{},editingGroupId:null},{...Gt({editingGroupId:g.editingGroupId,selectedElementIds:f},this.scene.getNonDeletedElements(),g,this),selectedLinearElement:u.length===1&&ee(u[0])?new V(u[0]):null,showHyperlinkPopup:u.length===1&&(u[0].link||xt(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 nt(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||G(this.state.editingElement)?this.state.editingElement:null,snapLines:$c(u.snapLines,[]),originSnapOffset:null})),Qr.setReferenceSnapPoints(null),Qr.setVisibleGaps(null),this.savePointer(r.clientX,r.clientY,"up"),this.setState({selectedElementsAreBeingDragged:!1});let c=this.scene.getNonDeletedElementsMap();if(this.state.editingLinearElement)if(!t.boxSelection.hasOccurred&&t.hit?.element?.id!==this.state.editingLinearElement.elementId)this.actionManager.executeAction(Zr);else{let u=V.handlePointerUp(r,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=V.handlePointerUp(r,this.state.selectedLinearElement,this.state,this.scene.getNonDeletedElements(),c),{startBindingElement:g,endBindingElement:f}=u,E=this.scene.getElement(u.elementId);Et(E)&&cn(E,g,f,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=Oe(r,this.state),g=o.points,f=u.x-o.x,E=u.y-o.y;f===g[0][0]&&E===g[0][1]&&(E+=1e-4,f+=1e-4);let y=o.simulatePressure?[]:[...o.pressures,r.pressure];B(o,{points:[...g,[f,E]],pressures:y,lastCommittedPoint:[f,E]}),this.actionManager.executeAction(Zr);return}if(Or(o)){let u=o;try{this.initializeImageDimensions(u),this.setState({selectedElementIds:Ce({[u.id]:!0},this.state)},()=>{this.actionManager.executeAction(Zr)})}catch(g){console.error(g),this.scene.replaceAllElements(this.scene.getElementsIncludingDeleted().filter(f=>f.id!==u.id)),this.actionManager.executeAction(Zr)}return}if(ee(o)){o.points.length>1&&this.history.resumeRecording();let u=Oe(r,this.state);!t.drag.hasOccurred&&o&&!i?(B(o,{points:[...o.points,[u.x-o.x,u.y-o.y]]}),this.setState({multiElement:o,editingElement:this.state.draggingElement})):t.drag.hasOccurred&&!i&&(Ro(this.state)&&Et(o,!1)&&Es(o,this.state,this.scene,u,c),this.setState({suggestedBindings:[],startBoundElement:null}),a.locked?this.setState(g=>({draggingElement:null})):(Cr(this.interactiveCanvas),this.setState(g=>({draggingElement:null,activeTool:Ke(this.state,{type:"selection"}),selectedElementIds:Ce({...g.selectedElementIds,[o.id]:!0},g),selectedLinearElement:new V(o)}))));return}if(a.type!=="selection"&&o&&Wr(o)){this.scene.replaceAllElements(this.scene.getElementsIncludingDeleted().filter(u=>u.id!==o.id)),this.setState({draggingElement:null});return}if(o){if(t.drag.hasOccurred){let u=Oe(r,this.state);if(this.state.selectedLinearElement&&this.state.selectedLinearElement.isDragging){let g=this.scene.getElement(this.state.selectedLinearElement.elementId);if(g?.frameId){let f=Pt(g,c);f&&g&&(zo(g,f,this.scene.getNonDeletedElementsMap())||(B(g,{groupIds:[]}),ml([g],this.scene.getNonDeletedElementsMap()),this.scene.informMutation()))}}else{let g=this.getTopLayerFrameAtSceneCoords(u),f=this.scene.getSelectedElements(this.state),E=this.scene.getElementsMapIncludingDeleted(),y=T=>{if(T.length>0){for(let w of T){let I=w.groupIds.indexOf(this.state.editingGroupId);B(w,{groupIds:w.groupIds.slice(0,I)},!1)}E.forEach(w=>{w.groupIds.length&&Ze(E,w.groupIds[w.groupIds.length-1]).length<2&&B(w,{groupIds:[]},!1)}),this.setState({editingGroupId:null})}};if(g&&!this.state.selectedElementIds[g.id]){let T=f.filter(w=>w.frameId!==g.id&&ea(w,E,this.state));this.state.editingGroupId&&y(T),E=Gs(E,T,g)}else if(!g&&this.state.editingGroupId){let T=f.filter(w=>w.frameId&&!ea(w,E,this.state));y(T)}E=Go(E,this.state,this),this.scene.replaceAllElements(E)}}if(X(o)){let u=GE(this.scene.getElementsIncludingDeleted(),o,this.scene.getNonDeletedElementsMap());this.scene.replaceAllElements(Gs(this.scene.getElementsMapIncludingDeleted(),u,o))}B(o,Ps(o))}if(n&&this.history.resumeRecording(),n&&Wr(n)&&this.scene.replaceAllElements(this.scene.getElementsIncludingDeleted().filter(u=>u.id!==n.id)),t.resize.isResizing){let u=Go(this.scene.getElementsIncludingDeleted(),this.state,this),g=this.scene.getSelectedElements(this.state).filter(f=>X(f));for(let f of g)u=tm(u,dl(this.scene.getElementsIncludingDeleted(),f,this.state,c),f,this);this.scene.replaceAllElements(u)}let d=t.hit.element;this.state.selectedLinearElement?.elementId!==d?.id&&ee(d)&&this.scene.getSelectedElements(this.state).length===1&&this.setState({selectedLinearElement:new V(d)});let m=this.lastPointerDownEvent,p=this.lastPointerUpEvent||this.lastPointerMoveEvent;if(ur(this.state)&&m&&p){if(this.eraserTrail.endPath(),at(m.clientX,m.clientY,p.clientX,p.clientY)===0){let g=Oe({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)&&(r.shiftKey&&!this.state.editingLinearElement?this.state.selectedElementIds[d.id]?bd(this.state,d)?this.setState(u=>{let g={...u.selectedElementIds};for(let f of d.groupIds.flatMap(E=>Ze(this.scene.getNonDeletedElements(),E)))delete g[f.id];return{selectedGroupIds:{...u.selectedElementIds,...d.groupIds.map(f=>({[f]:!1})).reduce((f,E)=>({...f,...E}),{})},selectedElementIds:Ce(g,u)}}):this.state.selectedLinearElement?.isDragging||this.setState(u=>{let g={...u.selectedElementIds};delete g[d.id];let f=pe(this.scene.getNonDeletedElements(),{selectedElementIds:g});return{...Gt({editingGroupId:u.editingGroupId,selectedElementIds:g},this.scene.getNonDeletedElements(),u,this),selectedLinearElement:f.length===1&&ee(f[0])?new V(f[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(f=>Ze(this.scene.getNonDeletedElements(),f)).forEach(f=>{delete g[f.id]}),{...Gt({editingGroupId:u.editingGroupId,selectedElementIds:g},this.scene.getNonDeletedElements(),u,this),showHyperlinkPopup:d.link||xt(d)?"info":!1}}):this.setState(u=>({selectedElementIds:Ce({...u.selectedElementIds,[d.id]:!0},u)})):this.setState(u=>({...Gt({editingGroupId:u.editingGroupId,selectedElementIds:{[d.id]:!0}},this.scene.getNonDeletedElements(),u,this),selectedLinearElement:ee(d)&&u.selectedLinearElement?.elementId!==d.id?new V(d):u.selectedLinearElement}))),!t.drag.hasOccurred&&!this.state.isResizing&&(d&&bs(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:Ce({},this.state),selectedGroupIds:{},editingGroupId:null,activeEmbeddable:null});return}if(!a.locked&&a.type!=="freedraw"&&o&&o.type!=="selection"&&this.setState(u=>({selectedElementIds:Ce({...u.selectedElementIds,[o.id]:!0},u),showHyperlinkPopup:xt(o)&&!o.link?"editor":u.showHyperlinkPopup})),(a.type!=="selection"||Re(this.scene.getNonDeletedElements(),this.state))&&this.history.resumeRecording(),(t.drag.hasOccurred||l||s)&&(Ro(this.state)?xs(this.scene.getSelectedElements(this.state),this.scene.getNonDeletedElements(),c):ys(this.scene.getSelectedElements(this.state),c)),a.type==="laser"){this.laserTrails.endPath();return}!a.locked&&a.type!=="freedraw"?(Cr(this.interactiveCanvas),this.setState({draggingElement:null,suggestedBindings:[],activeTool:Ke(this.state,{type:"selection"})})):this.setState({draggingElement:null,suggestedBindings:[]}),d&&this.lastPointerUpEvent&&this.lastPointerDownEvent&&this.lastPointerUpEvent.timeStamp-this.lastPointerDownEvent.timeStamp<300&&Ae.pointers.size<=1&&Ft(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)||Me(o)&&this.elementsPendingErasure.has(o.containerId)?(t=!0,te(o,{isDeleted:!0})):o);this.elementsPendingErasure=new Set,t&&(this.history.resumeRecording(),this.scene.replaceAllElements(r))};initializeImage=async({imageFile:t,imageElement:r,showCursorImagePreview:o=!1})=>{if(!ei(t))throw new Error(b("errors.unsupportedFileType"));let n=t.type;if(De(this.interactiveCanvas,"wait"),n===$.svg)try{t=lg(await sE(await t.text()),t.name)}catch(c){throw console.warn(c),new Error(b("errors.svgImageInsertError"))}let i=await(this.props.generateIdForFile?.(t)||tE(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 Ds(t,{maxWidthOrHeight:Vb})}catch(c){console.error("Error trying to resizing image file on insertion",c)}if(t.size>tu)throw new Error(b("errors.fileTooBig",{maxSize:`${Math.trunc(tu/1024/1024)}MB`}))}if(o){let c=this.files[i]?.dataURL,d=c&&rE(c);this.setImagePreviewCursor(d||t)}let l=this.files[i]?.dataURL||await _d(t),s=B(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||Cr(this.interactiveCanvas)}})};insertImageElement=async(t,r,o)=>{if(!this.isToolSupported("image")){this.setState({errorMessage:b("errors.imageToolNotSupported")});return}this.scene.addNewElement(t);try{return await this.initializeImage({imageFile:r,imageElement:t,showCursorImagePreview:o})}catch(n){return B(t,{isDeleted:!0}),this.actionManager.executeAction(Zr),this.setState({errorMessage:n.message||b("errors.imageInsertError")}),null}};setImagePreviewCursor=async t=>{let o;try{o=await Ds(t,{maxWidthOrHeight:96})}catch(i){throw i.cause==="UNSUPPORTED"?new Error(b("errors.unsupportedFileType")):i}let n=await _d(o);if(t.type===$.svg){let i=await dg(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($.svg)}this.state.pendingImageElementId&&De(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}=Oe({clientX:r,clientY:o},this.state),a=await Ja({description:"Image",extensions:Object.keys(Xl)}),l=this.createImageElement({sceneX:n,sceneY:i,addToFrameUnderCursor:!1});t?(this.insertImageElement(l,a),this.initializeImageDimensions(l),this.setState({selectedElementIds:Ce({[l.id]:!0},this.state)},()=>{this.actionManager.executeAction(Zr)})):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:Ke(this.state,{type:"selection"})},()=>{this.actionManager.executeAction(Zr)})}};initializeImageDimensions=(t,r=!1)=>{let o=Qt(t)&&this.imageCache.get(t.fileId)?.image;if(!o||o instanceof Promise){if(t.width<en/this.state.zoom.value&&t.height<en/this.state.zoom.value){let n=100/this.state.zoom.value;B(t,{x:t.x-n/2,y:t.y-n/2,width:n,height:n})}return}if(r||t.width<en/this.state.zoom.value&&t.height<en/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;B(t,{x:s,y:c,width:l,height:a})}};updateImageCache=async(t,r=this.files)=>{let{updatedFiles:o,erroredFiles:n}=await Bd({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)&&Te.delete(i);return n.size&&this.scene.replaceAllElements(this.scene.getElementsIncludingDeleted().map(i=>Qt(i)&&n.has(i.fileId)?te(i,{status:"error"}):i)),{updatedFiles:o,erroredFiles:n}};addNewImagesToImageCache=async(t=Od(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=QL(()=>{this.addNewImagesToImageCache()},Rb);updateBindingEnabledOnPointerMove=t=>{let r=ox(t);this.state.isBindingEnabled!==r&&this.setState({isBindingEnabled:r})};maybeSuggestBindingAtCursor=t=>{let r=No(t,this.scene.getNonDeletedElements(),this.scene.getNonDeletedElementsMap());this.setState({suggestedBindings:r!=null?[r]:[]})};maybeSuggestBindingsForLinearElementAtCoords=(t,r,o)=>{if(!r.length)return;let n=r.reduce((i,a)=>{let l=No(a,this.scene.getNonDeletedElements(),this.scene.getNonDeletedElementsMap());return l!=null&&!Nu(t,o?.id,l)&&i.push(l),i},[]);this.setState({suggestedBindings:n})};maybeSuggestBindingForAll(t){if(t.length>50)return;let r=ix(t,this.scene.getNonDeletedElements(),this.scene.getNonDeletedElementsMap());this.setState({suggestedBindings:r})}clearSelection(t){this.setState(r=>({selectedElementIds:Ce({},r),activeEmbeddable:null,selectedGroupIds:{},editingGroupId:r.editingGroupId&&t!=null&&Zi(t,r.editingGroupId)?r.editingGroupId:null})),this.setState({selectedElementIds:Ce({},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 nE(t),{x:n,y:i}=Oe(t,this.state);try{if(ei(r)&&this.isToolSupported("image")){if(r?.type===$.png||r?.type===$.svg)try{let s=await nl(r,this.state,this.scene.getElementsIncludingDeleted(),o);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,r),this.initializeImageDimensions(l),this.setState({selectedElementIds:Ce({[l.id]:!0},this.state)});return}}catch(l){return this.setState({isLoading:!1,errorMessage:l.message})}let a=t.dataTransfer.getData($.excalidrawlib);if(a&&typeof a=="string"){try{let l=ig(a);this.addElementsFromPasteOrLibrary({elements:$m(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&&qa(l,this.props.validateEmbeddable)&&(/^(http|https):\/\/[^\s/$.?#].[^\s]*$/.test(l)||xn(l)?.type==="video")){let s=this.insertEmbeddableElement({sceneX:n,sceneY:i,link:tr(l)});s&&this.setState({selectedElementIds:{[s.id]:!0}})}}};loadFileToCanvas=async(t,r)=>{t=await Rs(t);try{let o;try{o=await Pd(t,this.state,this.scene.getElementsIncludingDeleted(),r)}catch(n){let i=n instanceof yo;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(!o)return;o.type===$.excalidraw?(this.setState({isLoading:!0}),this.syncActionResult({...o.data,appState:{...o.data.appState||this.state,isLoading:!1},replaceFiles:!0,commitToHistory:!0})):o.type===$.excalidrawlib&&await this.library.updateLibrary({libraryItems:t,merge:!0,openLibraryMenu:!0}).catch(n=>{console.error(n),this.setState({errorMessage:b("errors.importLibraryError")})})}catch(o){this.setState({isLoading:!1,errorMessage:o.message})}};handleCanvasContextMenu=t=>{if(t.preventDefault(),("pointerType"in t.nativeEvent&&t.nativeEvent.pointerType==="touch"||"pointerType"in t.nativeEvent&&t.nativeEvent.pointerType==="pen"&&t.button!==Bn.SECONDARY)&&this.state.activeTool.type!=="selection")return;let{x:r,y:o}=Oe(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;xe("contextMenu","openContextMenu",l),this.setState({...n&&!this.state.selectedElementIds[n.id]?{...this.state,...Gt({editingGroupId:this.state.editingGroupId,selectedElementIds:{[n.id]:!0}},this.scene.getNonDeletedElements(),this.state,this),selectedLinearElement:ee(n)?new V(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")mm(o,this.state.activeTool.type,t.origin.x,t.origin.y,n.x,n.y,Ct(t.origin.x,n.x),Ct(t.origin.y,n.y),Ua(r),id(r));else{let[i,a]=yt(n.x,n.y,r[S.CTRL_OR_CMD]?null:this.state.gridSize),l=Qt(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}=lT(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}),mm(o,this.state.activeTool.type,t.originInGrid.x,t.originInGrid.y,i,a,Ct(t.originInGrid.x,i),Ct(t.originInGrid.y,a),Or(o)?!Ua(r):Ua(r),id(r),s,this.state.originSnapOffset),this.maybeSuggestBindingForAll([o]),(this.state.activeTool.type===ht.frame||this.state.activeTool.type===ht.magicframe)&&this.setState({elementsToHighlight:dl(this.scene.getNonDeletedElements(),o,this.state,this.scene.getNonDeletedElementsMap())})}};maybeHandleResize=(t,r)=>{let o=this.scene.getSelectedElements(this.state),n=o.filter(d=>X(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]=yt(a.x-t.resize.offset.x,a.y-t.resize.offset.y,r[S.CTRL_OR_CMD]?null:this.state.gridSize),c=new Map;if(n.forEach(d=>{Mr(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]=yt(a.x,a.y,r[S.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:g,snapLines:f}=aT(o,pe(u,this.state),this.state,r,p,i);l+=g.x,s+=g.y,this.setState({snapLines:f})}if(Mg(t.originalElements,i,o,this.scene.getElementsMapIncludingDeleted(),Wi(r),id(r),o.length===1&&Or(o[0])?!Ua(r):Ua(r),l,s,t.resize.center.x,t.resize.center.y)){this.maybeSuggestBindingForAll(o);let d=new Set;return n.forEach(m=>{dl(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(Fm,Om),t==="canvas"?this.state.viewModeEnabled?[...r,zm,Cl,Bf,di]:[Sh,rr,Fm,Om,Hm,rr,Jg,f2,rr,zm,Ih,Cl,Bf,di]:(r.push(Hm),this.state.viewModeEnabled?[Il,...r]:[Bm,Il,Sh,q3,J3,rr,...r,rr,fh,bh,rr,xh,Ch,kh,l2,Eh,rr,wh,rr,Xg,Zg,jg,qg,rr,vh,Th,rr,Rh,_h,Qg,Dh,rr,Ys])};handleWheel=nt(t=>{if(t.preventDefault(),xc)return;let{deltaX:r,deltaY:o}=t;if(t.metaKey||t.ctrlKey){let n=Math.sign(o),i=Di*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=>({...In({viewportX:this.lastViewportPosition.x,viewportY:this.lastViewportPosition.y,nextZoom:Uo(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=gd(n,o,this.scene.getNonDeletedElementsMap());if(l&&(i=l.x,a=l.y),Math.hypot(t-i,r-a)<_b){let{x:d,y:m}=Mt({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}=Oe({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:Ae.pointers})};resetShouldCacheIgnoreZoomDebounced=Ni(()=>{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=ya.find(r=>r.code===this.props.langCode)||Co;await Ic(t),this.setAppState({})}},e8=()=>{(v.MODE===Jp.TEST||v.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)}}}))};e8();var HT=Jf;F();h();var r8=()=>{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)})},zT=r8;W();import{Provider as f8}from"jotai";h();import o8 from"clsx";import{jsx as GT}from"react/jsx-runtime";var UT=({children:e})=>{let{FooterCenterTunnel:t}=Qe(),r=Ne();return GT(t.In,{children:GT("div",{className:o8("footer-center zen-mode-transition",{"layer-ui__wrapper__footer-left--transition-bottom":r.zenModeEnabled}),children:e})})},n8=UT;UT.displayName="FooterCenter";h();h();h();import{jsx as Si,jsxs as VT}from"react/jsx-runtime";var i8=()=>Si("svg",{viewBox:"0 0 40 40",fill:"none",xmlns:"http://www.w3.org/2000/svg",className:"ExcalidrawLogo-icon",children:Si("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"})}),a8=()=>VT("svg",{viewBox:"0 0 450 55",xmlns:"http://www.w3.org/2000/svg",fill:"none",className:"ExcalidrawLogo-text",children:[Si("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)"}),Si("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)"}),Si("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)"}),Si("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)"})]}),WT=({style:e,size:t="small",withText:r})=>VT("div",{className:`ExcalidrawLogo is-${t}`,style:e,children:[Si(i8,{}),r&&Si(a8,{})]});import{Fragment as $T,jsx as wt,jsxs as ib}from"react/jsx-runtime";var ab=({icon:e,shortcut:t,children:r})=>{let o=ke();return ib($T,{children:[wt("div",{className:"welcome-screen-menu-item__icon",children:e}),wt("div",{className:"welcome-screen-menu-item__text",children:r}),t&&!o.editor.isMobile&&wt("div",{className:"welcome-screen-menu-item__shortcut",children:t})]})};ab.displayName="WelcomeScreenMenuItemContent";var wc=({onSelect:e,children:t,icon:r,shortcut:o,className:n="",...i})=>wt("button",{...i,type:"button",className:`welcome-screen-menu-item ${n}`,onClick:e,children:wt(ab,{icon:r,shortcut:o,children:t})});wc.displayName="WelcomeScreenMenuItem";var YT=({children:e,href:t,icon:r,shortcut:o,className:n="",...i})=>wt("a",{...i,className:`welcome-screen-menu-item ${n}`,href:t,target:"_blank",rel:"noreferrer",children:wt(ab,{icon:r,shortcut:o,children:e})});YT.displayName="WelcomeScreenMenuItemLink";var ro=({children:e})=>{let{WelcomeScreenCenterTunnel:t}=Qe();return wt(t.In,{children:wt("div",{className:"welcome-screen-center",children:e||ib($T,{children:[wt(lb,{}),wt(sb,{children:b("welcomeScreen.defaults.center_heading")}),ib(cb,{children:[wt(mb,{}),wt(db,{})]})]})})})};ro.displayName="Center";var lb=({children:e})=>wt("div",{className:"welcome-screen-center__logo virgil welcome-screen-decor",children:e||wt(WT,{withText:!0})});lb.displayName="Logo";var sb=({children:e})=>wt("div",{className:"welcome-screen-center__heading welcome-screen-decor virgil",children:e});sb.displayName="Heading";var cb=({children:e})=>wt("div",{className:"welcome-screen-menu",children:e});cb.displayName="Menu";var db=()=>{let e=Wt();return wt(wc,{onSelect:()=>e.executeAction(ua),shortcut:"?",icon:gl,children:b("helpDialog.title")})};db.displayName="MenuItemHelp";var mb=()=>{let e=Ne(),t=Wt();return e.viewModeEnabled?null:wt(wc,{onSelect:()=>t.executeAction(vl),shortcut:kn("loadScene"),icon:hl,children:b("buttons.load")})};mb.displayName="MenuItemLoadScene";var KT=({onSelect:e})=>{let{t}=St();return wt(wc,{shortcut:null,onSelect:e,icon:bm,children:t("labels.liveCollaboration")})};KT.displayName="MenuItemLiveCollaborationTrigger";ro.Logo=lb;ro.Heading=sb;ro.Menu=cb;ro.MenuItem=wc;ro.MenuItemLink=YT;ro.MenuItemHelp=db;ro.MenuItemLoadScene=mb;ro.MenuItemLiveCollaborationTrigger=KT;h();import{jsx as Yl,jsxs as pb}from"react/jsx-runtime";var Yp=({children:e})=>{let{WelcomeScreenMenuHintTunnel:t}=Qe();return Yl(t.In,{children:pb("div",{className:"virgil welcome-screen-decor welcome-screen-decor-hint welcome-screen-decor-hint--menu",children:[h0,Yl("div",{className:"welcome-screen-decor-hint__label",children:e||b("welcomeScreen.defaults.menuHint")})]})})};Yp.displayName="MenuHint";var Kp=({children:e})=>{let{WelcomeScreenToolbarHintTunnel:t}=Qe();return Yl(t.In,{children:pb("div",{className:"virgil welcome-screen-decor welcome-screen-decor-hint welcome-screen-decor-hint--toolbar",children:[Yl("div",{className:"welcome-screen-decor-hint__label",children:e||b("welcomeScreen.defaults.toolbarHint")}),b0]})})};Kp.displayName="ToolbarHint";var $p=({children:e})=>{let{WelcomeScreenHelpHintTunnel:t}=Qe();return Yl(t.In,{children:pb("div",{className:"virgil welcome-screen-decor welcome-screen-decor-hint welcome-screen-decor-hint--help",children:[Yl("div",{children:e||b("welcomeScreen.defaults.helpHint")}),f0]})})};$p.displayName="HelpHint";import{Fragment as XT,jsx as vc,jsxs as s8}from"react/jsx-runtime";var Xp=e=>vc(XT,{children:e.children||s8(XT,{children:[vc(ro,{}),vc(Yp,{}),vc(Kp,{}),vc($p,{})]})});Xp.displayName="WelcomeScreen";Xp.Center=ro;Xp.Hints={MenuHint:Yp,ToolbarHint:Kp,HelpHint:$p};var l8=Xp;h();import c8 from"clsx";import{jsx as m8,jsxs as p8}from"react/jsx-runtime";var ZT=({isCollaborating:e,onSelect:t,...r})=>{let o=Ne(),n=o.width<830;return p8(Zo,{...r,className:c8("collab-button",{active:e}),type:"button",onSelect:t,style:{position:"relative",width:n?void 0:"auto"},title:b("labels.liveCollaboration"),children:[n?$0:b("labels.share"),o.collaborators.size>0&&m8("div",{className:"CollabButton-collaborators",children:o.collaborators.size})]})},d8=ZT;ZT.displayName="LiveCollaborationTrigger";me();tl();ra();vn();gr();ln();oe();W();He();F();h();import{jsx as jT,jsxs as u8}from"react/jsx-runtime";var qT=({children:e,icon:t})=>{let{TTDDialogTriggerTunnel:r}=Qe(),o=Ve();return jT(r.In,{children:u8(Le.Item,{onSelect:()=>{xe("ai","dialog open","ttd"),o({openDialog:{name:"ttd",tab:"text-to-diagram"}})},icon:t??Jy,children:[e??b("labels.textToDiagram"),jT(Le.Item.Badge,{children:"AI"})]})})};qT.displayName="TTDDialogTrigger";Xa();mt();vg();import{jsx as ub}from"react/jsx-runtime";zT();var b8=e=>{let{onChange:t,initialData:r,excalidrawAPI:o,isCollaborating:n=!1,onPointerUpdate:i,renderTopRightUI:a,langCode:l=Co.code,viewModeEnabled:s,zenModeEnabled:c,gridModeEnabled:d,libraryReturnUrl:m,theme:p,name:u,renderCustomStats:g,onPaste:f,detectScroll:E=!0,handleKeyboardGlobally:y=!1,onLibraryChange:T,autoFocus:w=!1,generateIdForFile:I,onLinkOpen:k,onPointerDown:C,onPointerUp:D,onScrollChange:R,children:z,validateEmbeddable:L,renderEmbeddable:M,aiEnabled:A}=e,H=e.UIOptions?.canvasActions,q={...e.UIOptions,canvasActions:{...eu.canvasActions,...H},tools:{image:e.UIOptions?.tools?.image??!0}};return H?.export&&(q.canvasActions.export.saveFileToDisk=H.export?.saveFileToDisk??eu.canvasActions.export.saveFileToDisk),q.canvasActions.toggleTheme===null&&typeof p>"u"&&(q.canvasActions.toggleTheme=!0),h8(()=>{(async()=>{await import("canvas-roundrect-polyfill")})();let Q=fe=>{typeof fe.scale=="number"&&fe.scale!==1&&fe.preventDefault()};return document.addEventListener("touchmove",Q,{passive:!1}),()=>{document.removeEventListener("touchmove",Q)}},[]),ub(f8,{unstable_createStore:()=>sr,scope:Pe,children:ub(Zb,{langCode:l,theme:p,children:ub(HT,{onChange:t,initialData:r,excalidrawAPI:o,isCollaborating:n,onPointerUpdate:i,renderTopRightUI:a,langCode:l,viewModeEnabled:s,zenModeEnabled:c,gridModeEnabled:d,libraryReturnUrl:m,theme:p,name:u,renderCustomStats:g,UIOptions:q,onPaste:f,detectScroll:E,handleKeyboardGlobally:y,onLibraryChange:T,autoFocus:w,generateIdForFile:I,onLinkOpen:k,onPointerDown:C,onPointerUp:D,onScrollChange:R,validateEmbeddable:L,renderEmbeddable:M,aiEnabled:A!==!1,children:z})})})},x8=(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])&&bt(n,l)},E8=g8.memo(b8,x8);E8.displayName="Excalidraw";export{Zo as Button,Tp as DefaultSidebar,E8 as Excalidraw,it as FONT_FAMILY,n8 as Footer,d8 as LiveCollaborationTrigger,$ as MIME_TYPES,nr as MainMenu,tt as ROUNDNESS,Mn as Sidebar,qe as THEME,Nf as TTDDialog,qT as TTDDialogTrigger,l8 as WelcomeScreen,Eo as bumpVersion,mc as convertToExcalidrawElements,Co as defaultLang,AE as elementPartiallyOverlapsWithOrContainsBBox,wg as elementsOverlappingBBox,Jd as exportToBlob,ni as exportToCanvas,TS as exportToClipboard,cl as exportToSvg,ye as getCommonBounds,Ad as getFreeDrawSvgPath,Km as getLibraryItemsHash,be as getNonDeletedElements,YS as getSceneVersion,I6 as getVisibleSceneBounds,Og as hashElementsVersion,Fg as hashString,yg as isElementInsideBBox,Wr as isInvisiblySmallElement,ee as isLinearElement,ya as languages,nl as loadFromBlob,ag as loadLibraryFromBlob,Pd as loadSceneOrLibraryFromBlob,k2 as mergeLibraryItems,B as mutateElement,te as newElementWith,tr as normalizeLink,Fh as parseLibraryTokensFromUrl,Qn as restore,Ux as restoreAppState,Ls as restoreElements,Qi as restoreLibraryItems,Mt as sceneCoordsToViewportCoords,ti as serializeAsJSON,Nd as serializeLibraryAsJSON,ke as useDevice,c4 as useHandleLibrary,St as useI18n,Oe as viewportCoordsToSceneCoords,zw as zoomToFitBounds};
|