@chaibuilder/sdk 4.0.0-beta.3 → 4.0.0-beta.31
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/README.md +72 -50
- package/dist/{2SSKDMRQ-BnsZi3K3.cjs → 2SSKDMRQ-BksFOLpD.cjs} +1 -1
- package/dist/{2SSKDMRQ-CnSDkQcy.js → 2SSKDMRQ-gmj-yWTy.js} +2 -2
- package/dist/{AP7HFJJL-B31839PG.cjs → AP7HFJJL-CO-deD_p.cjs} +1 -1
- package/dist/{AP7HFJJL-CymCmW14.js → AP7HFJJL-kVgc0R61.js} +1 -1
- package/dist/IconPicker-BJHUCDn4.cjs +1 -0
- package/dist/{IconPicker-B1rWC-Ex.js → IconPicker-D_GRfhwS.js} +8 -7
- package/dist/STRINGS-BExFecZW.js +8 -0
- package/dist/STRINGS-FNnfjF5H.cjs +1 -0
- package/dist/{WDYDFRGG-BUVnbAci.js → WDYDFRGG-C9_E3QW0.js} +2 -2
- package/dist/{WDYDFRGG-BxhOCHc3.cjs → WDYDFRGG-KPpWFul_.cjs} +1 -1
- package/dist/{actions-registery-CZ1w0NKa.js → actions-registery-Bj-j1k5i.js} +2668 -2585
- package/dist/actions-registery-Cy1lqUVI.cjs +481 -0
- package/dist/actions.cjs +1 -1
- package/dist/actions.d.ts +0 -158
- package/dist/actions.js +3 -3
- package/dist/active-in-another-tab-1GoKTVcF.js +35 -0
- package/dist/active-in-another-tab-iEd5fZD0.cjs +1 -0
- package/dist/{add-new-language-page-WmlCnytQ.js → add-new-language-page-B3GUvWdP.js} +54 -53
- package/dist/add-new-language-page-Cq8R42Ro.cjs +1 -0
- package/dist/{add-new-page-VW2wAYZp.js → add-new-page-C5HlQfzy.js} +2 -2
- package/dist/{add-new-page-soZ8GAkN.cjs → add-new-page-DiHnECAR.cjs} +1 -1
- package/dist/ai-panel-content-BPpawv4D.cjs +1 -0
- package/dist/{ai-panel-content-D_o7Q_A-.js → ai-panel-content-tExD3yhH.js} +12 -11
- package/dist/ai-panel-default-lang-C6N4wUUF.cjs +3 -0
- package/dist/ai-panel-default-lang-DnYLHSaS.js +317 -0
- package/dist/ai-panel-other-lang-C65lVVtZ.cjs +1 -0
- package/dist/ai-panel-other-lang-D1pCJluY.js +132 -0
- package/dist/{ai-prompt-input-Bhc0ds7X.js → ai-prompt-input-B2q30bhR.js} +59 -62
- package/dist/ai-prompt-input-Dws5BHhQ.cjs +1 -0
- package/dist/{ai-translation-prompt-CZ55HQmo.js → ai-translation-prompt-Dnn6i_t3.js} +2 -2
- package/dist/ai-translation-prompt-DnwG2BmF.cjs +1 -0
- package/dist/apply-binding-9XSrYzAE.cjs +1 -0
- package/dist/{apply-binding-6iwlED02.js → apply-binding-chfbBKi2.js} +238 -225
- package/dist/change-password-modal-C0MMizgl.js +137 -0
- package/dist/change-password-modal-LKtYY-8V.cjs +1 -0
- package/dist/code-display-BR-gij5j.cjs +1 -0
- package/dist/{code-display-DhD_RBcg.js → code-display-DdWcOQ_i.js} +1 -1
- package/dist/code-editor-CWOmKcUc.js +57 -0
- package/dist/code-editor-Cim6jQVF.cjs +1 -0
- package/dist/continue-editing-in-this-client-Dd6nKIvX.cjs +1 -0
- package/dist/{continue-editing-in-this-client-CS2aQ7yY.js → continue-editing-in-this-client-oxYWGWON.js} +10 -9
- package/dist/core-BWQrViOY.cjs +1 -0
- package/dist/core-QlWEXm1d.js +53 -0
- package/dist/core.cjs +1 -1
- package/dist/core.d.ts +275 -105
- package/dist/core.js +59 -28
- package/dist/{css-import-modal-Byg6wV0O.js → css-import-modal-6bMTRlCg.js} +11 -9
- package/dist/css-import-modal-CXulmaB4.cjs +13 -0
- package/dist/delete-page-D0tdn6VW.cjs +1 -0
- package/dist/delete-page-LnzR01A8.js +71 -0
- package/dist/design-token-usage-D-hrcKz1.cjs +1 -0
- package/dist/{design-token-usage-xQs6SlaJ.js → design-token-usage-lf7N_uOk.js} +33 -32
- package/dist/{digital-asset-manager-DbtwzxRz.js → digital-asset-manager-DJhRhLGC.js} +6 -5
- package/dist/digital-asset-manager-eCJHNSjj.cjs +1 -0
- package/dist/{duplicate-page-BR7Dlo9d.js → duplicate-page-CXzYy7vx.js} +20 -19
- package/dist/duplicate-page-ChSp1TYN.cjs +1 -0
- package/dist/dynamic-page-selector-btGtkyyv.cjs +1 -0
- package/dist/{dynamic-page-selector-Cb5r_W8s.js → dynamic-page-selector-r5IR9_7k.js} +12 -11
- package/dist/fonts/bungee/Bungee-Regular.woff2 +0 -0
- package/dist/fonts/dm_sans/dm-sans-variable.woff2 +0 -0
- package/dist/fonts/geist/Geist-VariableFont_wght.ttf +0 -0
- package/dist/fonts/geist/Geist-VariableFont_wght.woff2 +0 -0
- package/dist/fonts/geist/geist-variable.woff2 +0 -0
- package/dist/fonts/geist-mono/GeistMono-VariableFont_wght.woff2 +0 -0
- package/dist/fonts/inter/inter-latin.woff2 +0 -0
- package/dist/fonts/inter/inter-variable.woff2 +1449 -0
- package/dist/fonts/lato/lato-variable.woff2 +0 -0
- package/dist/fonts/lavishly_yours/lavishly-yours.woff2 +11 -0
- package/dist/fonts/merriweather/merriweather-variable.woff2 +11 -0
- package/dist/fonts/montserrat/montserrat-variable.woff2 +0 -0
- package/dist/fonts/nunito_sans/nunito-sans-variable.woff2 +11 -0
- package/dist/fonts/open_sans/open-sans-variable.woff2 +0 -0
- package/dist/fonts/oswald/oswald-variable.woff2 +0 -0
- package/dist/fonts/playfair_display/playfair-display-variable.woff2 +11 -0
- package/dist/fonts/poppins/poppins-variable.woff2 +0 -0
- package/dist/fonts/raleway/raleway-variable.woff2 +0 -0
- package/dist/fonts/roboto/roboto-variable.woff2 +11 -0
- package/dist/fonts/source_sans_3/source-sans-3-variable.woff2 +11 -0
- package/dist/fonts/ubuntu/ubuntu-variable.woff2 +0 -0
- package/dist/fonts-B3UYxuJI.js +25 -0
- package/dist/fonts-D5fTqvSS.cjs +1 -0
- package/dist/get-chai-builder-tailwind-config-7CxFxEYL.cjs +1 -0
- package/dist/{get-chai-builder-tailwind-config-DjoVOuAf.js → get-chai-builder-tailwind-config-DC4sDOYK.js} +8 -8
- package/dist/{get-chai-builder-theme-Dl72X7cz.cjs → get-chai-builder-theme-B5RkBTsB.cjs} +1 -1
- package/dist/{get-chai-builder-theme-BYtp20KD.js → get-chai-builder-theme-BpuwSLeS.js} +1 -1
- package/dist/{image-editor-G-K28aTS.cjs → image-editor-BdW476J8.cjs} +1 -1
- package/dist/{image-editor-DV8kUKhl.js → image-editor-CilPMtAC.js} +1 -1
- package/dist/index-CAhDwfHE.cjs +5 -0
- package/dist/{index-Ct7ElCGK.js → index-DsQXiNA_.js} +5888 -6282
- package/dist/index-DtMksfXx.js +4932 -0
- package/dist/index-mPCp0j2h.cjs +160 -0
- package/dist/json-diff-viewer-BkrnLb3B.cjs +8 -0
- package/dist/{json-diff-viewer-krslPepD.js → json-diff-viewer-D3N3w3Ax.js} +100 -97
- package/dist/{lang-panel-BwIewMyw.js → lang-panel-BAaaP4Qc.js} +15 -14
- package/dist/lang-panel-BjDRrpwN.cjs +1 -0
- package/dist/library-blocks/bento/agency-showcase/agency-showcase.html +175 -0
- package/dist/library-blocks/bento/agency-showcase/agency-showcase.webp +0 -0
- package/dist/library-blocks/bento/creative-portfolio/creative-portfolio.html +116 -0
- package/dist/library-blocks/bento/creative-portfolio/creative-portfolio.webp +0 -0
- package/dist/library-blocks/bento/product-features/product-features.html +159 -0
- package/dist/library-blocks/bento/product-features/product-features.webp +0 -0
- package/dist/library-blocks/bento/saas-dashboard/saas-dashboard.html +182 -0
- package/dist/library-blocks/bento/saas-dashboard/saas-dashboard.webp +0 -0
- package/dist/library-blocks/bento/startup-metrics/startup-metrics.html +170 -0
- package/dist/library-blocks/bento/startup-metrics/startup-metrics.webp +0 -0
- package/dist/library-blocks/blocks-list.json +149 -0
- package/dist/library-blocks/feature/agency-services/agency-services.html +194 -0
- package/dist/library-blocks/feature/agency-services/agency-services.webp +0 -0
- package/dist/library-blocks/feature/consulting-firm/consulting-firm.html +219 -0
- package/dist/library-blocks/feature/consulting-firm/consulting-firm.webp +0 -0
- package/dist/library-blocks/feature/design-studio/design-studio.html +190 -0
- package/dist/library-blocks/feature/design-studio/design-studio.webp +0 -0
- package/dist/library-blocks/feature/freelancer-toolkit/freelancer-toolkit.html +195 -0
- package/dist/library-blocks/feature/freelancer-toolkit/freelancer-toolkit.webp +0 -0
- package/dist/library-blocks/feature/marketing-agency/marketing-agency.html +212 -0
- package/dist/library-blocks/feature/marketing-agency/marketing-agency.webp +0 -0
- package/dist/library-blocks/footer/creative-agency/creative-agency.html +64 -0
- package/dist/library-blocks/footer/creative-agency/creative-agency.webp +0 -0
- package/dist/library-blocks/footer/minimal-portfolio/minimal-portfolio.html +106 -0
- package/dist/library-blocks/footer/minimal-portfolio/minimal-portfolio.webp +0 -0
- package/dist/library-blocks/footer/saas-startup/saas-startup.html +117 -0
- package/dist/library-blocks/footer/saas-startup/saas-startup.webp +0 -0
- package/dist/library-blocks/hero/creative-agency/creative-agency.html +117 -0
- package/dist/library-blocks/hero/creative-agency/creative-agency.webp +0 -0
- package/dist/library-blocks/hero/developer-focused/developer-focused.html +124 -0
- package/dist/library-blocks/hero/developer-focused/developer-focused.webp +0 -0
- package/dist/library-blocks/hero/minimal-saas/minimal-saas.html +98 -0
- package/dist/library-blocks/hero/minimal-saas/minimal-saas.webp +0 -0
- package/dist/library-blocks/hero/portfolio-showcase/portfolio-showcase.html +148 -0
- package/dist/library-blocks/hero/portfolio-showcase/portfolio-showcase.webp +0 -0
- package/dist/library-blocks/hero/startup-landing/startup-landing.html +130 -0
- package/dist/library-blocks/hero/startup-landing/startup-landing.webp +0 -0
- package/dist/library-blocks/navbar/creative-agency/creative-agency.html +139 -0
- package/dist/library-blocks/navbar/creative-agency/creative-agency.webp +0 -0
- package/dist/library-blocks/navbar/minimal-portfolio/minimal-portfolio.html +164 -0
- package/dist/library-blocks/navbar/minimal-portfolio/minimal-portfolio.webp +0 -0
- package/dist/library-blocks/navbar/saas-startup/saas-startup.html +129 -0
- package/dist/library-blocks/navbar/saas-startup/saas-startup.webp +0 -0
- package/dist/manage-design-tokens-BknGNAKE.cjs +1 -0
- package/dist/manage-design-tokens-Co5677WS.js +428 -0
- package/dist/manage-design-tokens-modal-9qpcb-EC.js +161 -0
- package/dist/manage-design-tokens-modal-BcgdwEXE.cjs +1 -0
- package/dist/{mark-as-template-D295ZQtU.js → mark-as-template-DNHYNjI9.js} +17 -16
- package/dist/mark-as-template-IYRjta97.cjs +1 -0
- package/dist/{nested-path-selector-content-CKYYK-C5.js → nested-path-selector-content-Be-pbnVl.js} +24 -23
- package/dist/nested-path-selector-content-CWmPgU-L.cjs +1 -0
- package/dist/no-language-page-content-8_J6y-cm.cjs +1 -0
- package/dist/{no-language-page-content-BvqRBP6y.js → no-language-page-content-C-ltY7bj.js} +10 -9
- package/dist/{no-language-page-dialog-BcEoqyQB.cjs → no-language-page-dialog-BOZZZzqx.cjs} +1 -1
- package/dist/{no-language-page-dialog-PjNqTUpl.js → no-language-page-dialog-D5NXpDHi.js} +2 -2
- package/dist/{page-creator-DiOITEMw.js → page-creator-BuHHnqiQ.js} +242 -241
- package/dist/page-creator-wtbae2U7.cjs +1 -0
- package/dist/{page-lock-BdYmCks0.cjs → page-lock-DN4iJc-V.cjs} +1 -1
- package/dist/{page-lock-Bfbs6RgL.js → page-lock-pPGlTxj7.js} +2 -2
- package/dist/page-locked-dialog-B_vdgv24.cjs +1 -0
- package/dist/{page-locked-dialog-B6MKTRfY.js → page-locked-dialog-Bl-ojgIW.js} +26 -23
- package/dist/page-manager-new-5W5M9_ue.cjs +1 -0
- package/dist/page-manager-new-Bg8H6yrg.js +418 -0
- package/dist/page-manager-search-and-filter-CDXunXNd.cjs +1 -0
- package/dist/{page-manager-search-and-filter-CM0UMb6U.js → page-manager-search-and-filter-CyfO7O96.js} +20 -19
- package/dist/{page-revisions-content-NH9JK4Ey.js → page-revisions-content-B-egQgoZ.js} +131 -117
- package/dist/page-revisions-content-BKT8S9_g.cjs +1 -0
- package/dist/pages.cjs +1 -1
- package/dist/pages.d.ts +300 -97
- package/dist/pages.js +22 -19
- package/dist/plugin-BSjgGgwo.js +248 -0
- package/dist/plugin-DHpuZZXz.cjs +22 -0
- package/dist/{publish-pages-content-D9aixMN5.js → publish-pages-content-D2B_ScCQ.js} +71 -70
- package/dist/publish-pages-content-WJHTVYnx.cjs +1 -0
- package/dist/register-chai-top-bar-D6GjnauV.js +237 -0
- package/dist/register-chai-top-bar-DyW9GPzV.cjs +1 -0
- package/dist/render.cjs +2 -2
- package/dist/render.d.ts +22 -20
- package/dist/render.js +125 -118
- package/dist/rte-widget-modal-CC1KcrAT.cjs +1 -0
- package/dist/{rte-widget-modal-DOJEXLIf.js → rte-widget-modal-c3T09VeO.js} +10 -9
- package/dist/runtime-client.cjs +1 -0
- package/dist/runtime-client.d.ts +158 -0
- package/dist/runtime-client.js +32 -0
- package/dist/runtime.cjs +11 -1
- package/dist/runtime.d.ts +159 -114
- package/dist/runtime.js +107 -42
- package/dist/save-to-lib-CiM0wiIr.cjs +1 -0
- package/dist/{save-to-lib-eiOc_SSN.js → save-to-lib-dT1NDd5w.js} +156 -149
- package/dist/sdk.css +1 -1
- package/dist/{selected-block-display-CBFePS19.js → selected-block-display-BQndDPcY.js} +40 -39
- package/dist/selected-block-display-BgqcPsXI.cjs +16 -0
- package/dist/seo-panel-DXZvGYEM.cjs +2 -0
- package/dist/{seo-panel-C1-iMOR1.js → seo-panel-Z93Zf_bz.js} +23 -22
- package/dist/{shared-json-ld-B4PxAM_0.js → shared-json-ld-Ct68RlWD.js} +100 -99
- package/dist/shared-json-ld-DwvUDGAS.cjs +1 -0
- package/dist/{slug-input-AwNJs9im.js → slug-input-CAqkFZBq.js} +9 -8
- package/dist/slug-input-Curnt2n3.cjs +1 -0
- package/dist/supabase-actions.cjs +1 -1
- package/dist/supabase-actions.d.ts +40 -1
- package/dist/supabase-actions.js +231 -192
- package/dist/{take-over-request-C4FeDtN_.js → take-over-request-C6ngP1QR.js} +15 -14
- package/dist/take-over-request-D6y2HcDr.cjs +1 -0
- package/dist/theme-panel-footer-CGZL2F7R.js +26 -0
- package/dist/theme-panel-footer-IgGj-_OA.cjs +1 -0
- package/dist/translation-warning-modal-B876S5yp.cjs +1 -0
- package/dist/{translation-warning-modal-B64YqlbI.js → translation-warning-modal-kRcfrPgo.js} +11 -10
- package/dist/types.cjs +1 -0
- package/dist/types.d.ts +743 -0
- package/dist/types.js +1 -0
- package/dist/{unmark-as-template-CZ9sQp_P.js → unmark-as-template-DeeWUTco.js} +12 -11
- package/dist/unmark-as-template-f1dl_YTz.cjs +1 -0
- package/dist/unpublish-page-DEPFjGuu.cjs +1 -0
- package/dist/unpublish-page-U_79Pwc0.js +28 -0
- package/dist/unpublished-partials-modal-CEFXp1D1.cjs +1 -0
- package/dist/unpublished-partials-modal-Ts5ZhAK9.js +41 -0
- package/dist/utils.cjs +1 -1
- package/dist/utils.d.ts +8 -5
- package/dist/utils.js +2 -2
- package/dist/web-blocks.cjs +1 -1
- package/dist/web-blocks.js +341 -332
- package/dist/{web-preview-Djy6WIyj.js → web-preview-CoT8r96b.js} +2 -2
- package/dist/web-preview-DTDoIE-c.cjs +1 -0
- package/package.json +36 -31
- package/dist/IconPicker-DREyo007.cjs +0 -1
- package/dist/actions-registery-YnFmU21O.cjs +0 -418
- package/dist/active-in-another-tab-B47YjQGN.cjs +0 -1
- package/dist/active-in-another-tab-CyjngVA6.js +0 -34
- package/dist/add-new-language-page-88xzrUy8.cjs +0 -1
- package/dist/ai-panel-content-7zCil042.cjs +0 -1
- package/dist/ai-panel-default-lang-COYaxNwn.cjs +0 -3
- package/dist/ai-panel-default-lang-DnElspF0.js +0 -341
- package/dist/ai-panel-other-lang-CkynNlAU.cjs +0 -1
- package/dist/ai-panel-other-lang-Dp0E9_Hx.js +0 -162
- package/dist/ai-prompt-input-CThbVp0_.cjs +0 -1
- package/dist/ai-translation-prompt-C2kJQFDX.cjs +0 -1
- package/dist/apply-binding-KKp5PnpZ.cjs +0 -1
- package/dist/code-display-BnqzqzoP.cjs +0 -1
- package/dist/code-editor-DRIAnNbb.js +0 -50
- package/dist/code-editor-o3___nu2.cjs +0 -1
- package/dist/continue-editing-in-this-client-CtMYsk-A.cjs +0 -1
- package/dist/core-BoRDjj4h.cjs +0 -1
- package/dist/core-yvI6kCyw.js +0 -56
- package/dist/css-import-modal-CyqkXWCO.cjs +0 -13
- package/dist/delete-design-token-BRZZiWtQ.js +0 -40
- package/dist/delete-design-token-DkVs1oBf.cjs +0 -1
- package/dist/delete-page-BzyX9TN-.js +0 -70
- package/dist/delete-page-DxX7PFIE.cjs +0 -1
- package/dist/design-token-usage-CAHzEGgJ.cjs +0 -1
- package/dist/digital-asset-manager--uO8Agia.cjs +0 -1
- package/dist/duplicate-page-CaNAbXwV.cjs +0 -1
- package/dist/dynamic-page-selector-Cxk_gjni.cjs +0 -1
- package/dist/fonts/GeistMonoVF.woff +0 -0
- package/dist/fonts/GeistVF.woff +0 -0
- package/dist/fonts-B-Xt29pe.cjs +0 -1
- package/dist/fonts-DRly3Wzd.js +0 -78
- package/dist/get-chai-builder-tailwind-config-B9rCyiQo.cjs +0 -1
- package/dist/index-B-rSiAp_.cjs +0 -1
- package/dist/index-DF5DEvqb.cjs +0 -160
- package/dist/index-Dxfyt4d4.js +0 -39
- package/dist/index-WQwzsC7A.cjs +0 -5
- package/dist/index-ZuacEL1j.js +0 -4732
- package/dist/json-diff-viewer-D7z4zNvv.cjs +0 -8
- package/dist/lang-panel-DT96k1xg.cjs +0 -1
- package/dist/manage-design-tokens-Caz_20VK.js +0 -240
- package/dist/manage-design-tokens-CrmLe7UT.cjs +0 -1
- package/dist/mark-as-template-W3LmpiqN.cjs +0 -1
- package/dist/nested-path-selector-content-CoS_d3dc.cjs +0 -1
- package/dist/no-language-page-content-DkfeMl90.cjs +0 -1
- package/dist/page-creator-C4gc5NSC.cjs +0 -1
- package/dist/page-locked-dialog-B1FAtK92.cjs +0 -1
- package/dist/page-manager-new-CHDueBDk.cjs +0 -1
- package/dist/page-manager-new-CzX22g2n.js +0 -394
- package/dist/page-manager-search-and-filter-DkkRIH86.cjs +0 -1
- package/dist/page-revisions-content-ChY-4f2V.cjs +0 -1
- package/dist/plugin-3ZKK6RXm.js +0 -245
- package/dist/plugin-C6rgJDNQ.cjs +0 -22
- package/dist/publish-pages-content-x-JuSFJ9.cjs +0 -1
- package/dist/rte-widget-modal-BaHIuEjF.cjs +0 -1
- package/dist/save-to-lib-Cgpxw8-g.cjs +0 -1
- package/dist/selected-block-display-BgRY82CT.cjs +0 -16
- package/dist/seo-panel-DfAb8U7W.cjs +0 -2
- package/dist/shared-json-ld-DzG398hr.cjs +0 -1
- package/dist/slug-input-C_ijLQ_X.cjs +0 -1
- package/dist/take-over-request-BNxcjY2j.cjs +0 -1
- package/dist/theme-panel-footer-Cq9pljro.cjs +0 -1
- package/dist/theme-panel-footer-uBQqSJXm.js +0 -25
- package/dist/translation-warning-modal-BZAcwM2_.cjs +0 -1
- package/dist/unmark-as-template-EVvk0vmp.cjs +0 -1
- package/dist/unpublish-page-D4VwOlxc.js +0 -27
- package/dist/unpublish-page-bdSmwAVQ.cjs +0 -1
- package/dist/web-preview-Cio70gk5.cjs +0 -1
|
@@ -0,0 +1,160 @@
|
|
|
1
|
+
"use strict";var qc=Object.defineProperty;var Kc=(t,e,n)=>e in t?qc(t,e,{enumerable:!0,configurable:!0,writable:!0,value:n}):t[e]=n;var wt=(t,e,n)=>Kc(t,typeof e!="symbol"?e+"":e,n);const a=require("react/jsx-runtime"),B=require("./register-chai-top-bar-DyW9GPzV.cjs"),d=require("lodash-es"),Yc=require("@radix-ui/react-dropdown-menu"),k=require("@radix-ui/react-icons"),g=require("react"),K=require("./core-BWQrViOY.cjs"),j=require("jotai"),q=require("./STRINGS-FNnfjF5H.cjs"),qo=require("@rjsf/utils"),ke=require("./common-functions-B3a4xKt_.cjs"),Ne=require("jotai/utils"),ve=require("@react-hookz/web"),Qe=require("./plugin-DHpuZZXz.cjs"),Xc=require("tree-model"),Jc=require("undo-manager"),F=require("react-i18next"),Zc=require("@radix-ui/react-dialog"),pe=require("./apply-binding-9XSrYzAE.cjs"),Sr=require("class-variance-authority"),Qc=require("@radix-ui/react-tooltip"),De=require("cmdk"),ed=require("@radix-ui/react-popover"),mt=require("i18next"),td=require("@tiptap/extension-text-style"),nd=require("@tiptap/extension-highlight"),sd=require("@tiptap/extension-link"),rd=require("@tiptap/extension-placeholder"),od=require("@tiptap/extension-text-align"),ad=require("@tiptap/extension-underline"),ns=require("@tiptap/react"),id=require("@tiptap/starter-kit"),Fa=require("clsx"),za=require("tailwind-merge"),ld=require("react-colorful"),lr=require("react-dom"),cd=require("@rjsf/core"),dd=require("@rjsf/validator-ajv8"),ud=require("@radix-ui/react-accordion"),Ha=require("fuse.js"),pd=require("@radix-ui/react-hover-card"),fd=require("@radix-ui/react-label"),hd=require("react-autosuggest"),ce=require("sonner"),md=require("@radix-ui/react-scroll-area"),gd=require("@radix-ui/react-tabs"),xd=require("@radix-ui/react-select"),bd=require("@radix-ui/react-alert-dialog"),yd=require("react-arborist"),kd=require("@radix-ui/react-separator"),vd=require("@radix-ui/react-switch"),wd=require("@radix-ui/react-slider"),Nr=require("./fonts-D5fTqvSS.cjs");require("nanoid");const Ko=require("himalaya");require("@mhsdesign/jit-browser-tailwindcss");const Cd=require("@tailwindcss/aspect-ratio"),jd=require("@tailwindcss/container-queries"),Sd=require("@tailwindcss/forms"),Nd=require("@tailwindcss/typography"),Je=require("react-hotkeys-hook"),Ed=require("./get-chai-builder-tailwind-config-7CxFxEYL.cjs"),At=require("react-error-boundary"),Vn=require("framer-motion"),Us=require("@floating-ui/dom"),Yo=require("@floating-ui/react-dom"),Ad=require("react-wrap-balancer");function Re(t){const e=Object.create(null,{[Symbol.toStringTag]:{value:"Module"}});if(t){for(const n in t)if(n!=="default"){const s=Object.getOwnPropertyDescriptor(t,n);Object.defineProperty(e,n,s.get?s:{enumerable:!0,get:()=>t[n]})}}return e.default=t,Object.freeze(e)}const xe=Re(Yc),D=Re(g),ae=Re(Zc),Jt=Re(Qc),wn=Re(ed),Pt=Re(ud),ys=Re(pd),Va=Re(fd),It=Re(md),$t=Re(gd),ge=Re(xd),Pe=Re(bd),Wa=Re(kd),cr=Re(vd),fn=Re(wd);function Lt({className:t,...e}){return a.jsx("div",{className:B.cn("animate-pulse rounded-md bg-primary/10",t),...e})}const Er=({className:t="h-full w-full",onClick:e=d.noop})=>a.jsx("svg",{className:t,viewBox:"0 0 256 256",fill:"currentColor",onClick:e,children:a.jsx("path",{d:"m198.39 128.986-52.16-19.216-19.216-52.16a16 16 0 0 0-30.028 0L77.77 109.77l-52.16 19.216a16 16 0 0 0 0 30.028l52.16 19.216 19.216 52.16a16 16 0 0 0 30.028 0l19.216-52.16 52.16-19.216a16 16 0 0 0 0-30.028m-57.69 34.23a15.97 15.97 0 0 0-9.483 9.483l-19.22 52.152-19.214-52.15a15.97 15.97 0 0 0-9.482-9.484l-52.152-19.22 52.15-19.214a15.97 15.97 0 0 0 9.484-9.482l19.22-52.152 19.214 52.15a15.97 15.97 0 0 0 9.482 9.484l52.152 19.22ZM144 40a8 8 0 0 1 8-8h16V16a8 8 0 0 1 16 0v16h16a8 8 0 0 1 0 16h-16v16a8 8 0 0 1-16 0V48h-16a8 8 0 0 1-8-8m104 48a8 8 0 0 1-8 8h-8v8a8 8 0 0 1-16 0v-8h-8a8 8 0 0 1 0-16h8v-8a8 8 0 0 1 16 0v8h8a8 8 0 0 1 8 8"})}),tt=xe.Root,nt=xe.Trigger,Id=D.forwardRef(({className:t,inset:e,children:n,...s},r)=>a.jsxs(xe.SubTrigger,{ref:r,className:B.cn("flex cursor-default select-none items-center gap-2 rounded-sm px-2 py-1.5 text-sm outline-none focus:bg-accent data-[state=open]:bg-accent [&_svg]:pointer-events-none [&_svg]:size-4 [&_svg]:shrink-0",e&&"pl-8",t),...s,children:[n,a.jsx(k.ChevronRightIcon,{className:"ml-auto h-4 w-4"})]}));Id.displayName=xe.SubTrigger.displayName;const _d=D.forwardRef(({className:t,...e},n)=>a.jsx(xe.SubContent,{ref:n,className:B.cn("z-50 min-w-[8rem] origin-[--radix-dropdown-menu-content-transform-origin] overflow-hidden rounded-md border bg-popover p-1 text-popover-foreground shadow-lg data-[state=open]:animate-in data-[state=closed]:animate-out data-[state=closed]:fade-out-0 data-[state=open]:fade-in-0 data-[state=closed]:zoom-out-95 data-[state=open]:zoom-in-95 data-[side=bottom]:slide-in-from-top-2 data-[side=left]:slide-in-from-right-2 data-[side=right]:slide-in-from-left-2 data-[side=top]:slide-in-from-bottom-2",t),...e}));_d.displayName=xe.SubContent.displayName;const Ue=D.forwardRef(({className:t,sideOffset:e=4,...n},s)=>a.jsx(xe.Portal,{children:a.jsx(xe.Content,{ref:s,sideOffset:e,className:B.cn("z-50 max-h-[var(--radix-dropdown-menu-content-available-height)] min-w-[8rem] overflow-y-auto overflow-x-hidden rounded-md border bg-popover p-1 text-popover-foreground shadow-md","origin-[--radix-dropdown-menu-content-transform-origin] data-[state=open]:animate-in data-[state=closed]:animate-out data-[state=closed]:fade-out-0 data-[state=open]:fade-in-0 data-[state=closed]:zoom-out-95 data-[state=open]:zoom-in-95 data-[side=bottom]:slide-in-from-top-2 data-[side=left]:slide-in-from-right-2 data-[side=right]:slide-in-from-left-2 data-[side=top]:slide-in-from-bottom-2",t),...n})}));Ue.displayName=xe.Content.displayName;const de=D.forwardRef(({className:t,inset:e,...n},s)=>a.jsx(xe.Item,{ref:s,className:B.cn("relative flex cursor-default select-none items-center gap-2 rounded-sm px-2 py-1.5 text-sm outline-none transition-colors focus:bg-accent focus:text-accent-foreground data-[disabled]:pointer-events-none data-[disabled]:opacity-50 [&>svg]:size-4 [&>svg]:shrink-0",e&&"pl-8",t),...n}));de.displayName=xe.Item.displayName;const Ga=D.forwardRef(({className:t,children:e,checked:n,...s},r)=>a.jsxs(xe.CheckboxItem,{ref:r,className:B.cn("relative flex cursor-default select-none items-center rounded-sm py-1.5 pl-8 pr-2 text-sm outline-none transition-colors focus:bg-accent focus:text-accent-foreground data-[disabled]:pointer-events-none data-[disabled]:opacity-50",t),checked:n,...s,children:[a.jsx("span",{className:"absolute left-2 flex h-3.5 w-3.5 items-center justify-center",children:a.jsx(xe.ItemIndicator,{children:a.jsx(k.CheckIcon,{className:"h-4 w-4"})})}),e]}));Ga.displayName=xe.CheckboxItem.displayName;const Td=D.forwardRef(({className:t,children:e,...n},s)=>a.jsxs(xe.RadioItem,{ref:s,className:B.cn("relative flex cursor-default select-none items-center rounded-sm py-1.5 pl-8 pr-2 text-sm outline-none transition-colors focus:bg-accent focus:text-accent-foreground data-[disabled]:pointer-events-none data-[disabled]:opacity-50",t),...n,children:[a.jsx("span",{className:"absolute left-2 flex h-3.5 w-3.5 items-center justify-center",children:a.jsx(xe.ItemIndicator,{children:a.jsx(k.CircleIcon,{className:"h-2 w-2 fill-current"})})}),e]}));Td.displayName=xe.RadioItem.displayName;const Ua=D.forwardRef(({className:t,inset:e,...n},s)=>a.jsx(xe.Label,{ref:s,className:B.cn("px-2 py-1.5 text-sm font-semibold",e&&"pl-8",t),...n}));Ua.displayName=xe.Label.displayName;const Ar=D.forwardRef(({className:t,...e},n)=>a.jsx(xe.Separator,{ref:n,className:B.cn("-mx-1 my-1 h-px bg-muted",t),...e}));Ar.displayName=xe.Separator.displayName;const Y={OPEN_ADD_BLOCK:"OPEN_ADD_BLOCK",CLOSE_ADD_BLOCK:"CLOSE_ADD_BLOCK",GOTO_BLOCK_SETTINGS:"GOTO_BLOCK_SETTINGS",OPEN_AI_PANEL:"OPEN_AI_PANEL",CLEAR_CANVAS_SELECTION:"CLEAR_CANVAS_SELECTION",CANVAS_BLOCK_SELECTED:"CANVAS_BLOCK_SELECTED",CANVAS_BLOCK_STYLE_SELECTED:"CANVAS_BLOCK_STYLE_SELECTED",OPEN_EXPORT_CODE:"OPEN_EXPORT_CODE"},et=(t,e)=>{if(!t)return!0;const n=K.getRegisteredChaiBlock(t);return n&&n.canAcceptBlock?n.canAcceptBlock(e):!1},ss=t=>{const e=K.getRegisteredChaiBlock(t);return e?d.has(e,"canAcceptBlock"):!1},Bd=(t,e)=>{const n=K.getRegisteredChaiBlock(e);return n&&n.canBeNested?n.canBeNested(t):!0},Ir=t=>{const e=K.getRegisteredChaiBlock(t);return e&&e.canDuplicate?e.canDuplicate():!0},_r=t=>{const e=K.getRegisteredChaiBlock(t);return e&&e.canDelete?e.canDelete():!0};class Rd{constructor(){wt(this,"subscribers",new Map)}subscribe(e,n){return this.subscribers.has(e)||this.subscribers.set(e,new Set),this.subscribers.get(e).add(n),()=>{const s=this.subscribers.get(e);s&&(s.delete(n),s.size===0&&this.subscribers.delete(e))}}publish(e,n){const s=this.subscribers.get(e);s&&s.forEach(r=>r(n))}}const re=new Rd;function qa(t,e,n){const s=d.filter(t,o=>o._parent===e),r=[];for(let o=0;o<s.length;o++)if(d.filter(t,{_parent:s[o]._id}).length>0){const i=ke.generateUUID();r.push({...s[o],oldId:s[o]._id,_id:i,_parent:n}),r.push(d.flatten(qa(t,s[o]._id,i)))}else r.push({...s[o],oldId:s[o]._id,_id:ke.generateUUID(),_parent:n});return d.flatten(r)}function Tr(t){const e={};t.forEach(s=>{e[s._id]={...s,children:[]}});const n=[];return t.forEach(s=>{if(s._parent){const r=e[s._parent];r&&r.children.push(e[s._id])}else n.push(e[s._id])}),n}const dr=(t,e,n=null)=>{let s=d.find(t,{_id:e});s={...s,oldId:s._id,_id:ke.generateUUID()},n!==(s==null?void 0:s._parent)&&(s={...s,_parent:n});const r=[s];return d.filter(t,{_parent:e}).length>0&&r.push(d.flatten(qa(t,e,s._id))),d.flatten(r)},Se=j.atom([]);Se.debugLabel="presentBlocksAtom";const Ka=j.atom(t=>{const e=t(Se);return Tr([...e])});Ka.debugLabel="treeDSBlocks";const In=Ne.splitAtom(Se);In.debugLabel="pageBlocksAtomsAtom";const Pd=j.atom("");Pd.debugLabel="builderActivePageAtom";const Ld=j.atom(-1);Ld.debugLabel="destinationDropIndexAtom";const Ya=j.atom([]);Ya.debugLabel="buildingBlocksAtom";const Md=j.atom(t=>{const e=t(Ya);return d.filter(e,n=>d.has(n,"blockId"))});Md.debugLabel="globalBlocksAtom";const Qt=j.atom([]);Qt.debugLabel="structureErrorsAtom";const Br=j.atom(!0);Br.debugLabel="structureValidationValidAtom";const Rr=j.atom(!1);Rr.debugLabel="hasStructureErrorsAtom";const Pr=j.atom(!1);Pr.debugLabel="hasStructureWarningsAtom";const Xa=j.atom(t=>t(Qt).filter(n=>n.severity==="error").length);Xa.debugLabel="structureErrorCountAtom";const Ja=j.atom(t=>t(Qt).filter(n=>n.severity==="warning").length);Ja.debugLabel="structureWarningCountAtom";const Za=j.atom(t=>{const e=t(Qt),n={};return e.forEach(s=>{s.blockId&&(n[s.blockId]||(n[s.blockId]=[]),n[s.blockId].push(s))}),n});Za.debugLabel="structureErrorsByBlockAtom";const We=j.getDefaultStore(),Dd=()=>We.get(Se),$=(t,e)=>{const n=j.useAtomValue($r);return g.useMemo(()=>d.get(n,t,e),[n,t,e])},Qa=j.atom("");Qa.debugLabel="selectedLanguageAtom";const _e=()=>{const t=$("languages",[]),e=$("fallbackLang","en"),[n,s]=j.useAtom(Qa),r=o=>{s(e===o?"":o)};return{languages:t==null?void 0:t.filter(o=>o!==e),fallbackLang:e,selectedLang:n,setSelectedLang:r}},ks=j.atom([]);ks.debugLabel="selectedBlockIdsAtom";const Lr=j.atom(t=>{const e=t(Se),n=t(ks);return d.map(d.filter(e,({_id:s})=>d.includes(n,s)),s=>({...s}))});Lr.debugLabel="selectedBlocksAtom";const vs=j.atom(t=>{const e=t(Lr);if(e.length!==0&&e.length===1)return e[0]});vs.debugLabel="selectedBlockAtom";const J=()=>j.useAtomValue(vs),Od=t=>d.get(t,"_parent",null),$d=j.atom(t=>{const e=t(Lr),n=d.map(e,Od);return d.filter(t(Se),s=>d.includes(n,s._id))});$d.debugLabel="selectedBlocksParentsAtom";const ei=j.atom(()=>!1);ei.debugLabel="selectedBlockFlexChildAtom";const ti=j.atom(()=>!1);ti.debugLabel="selectedBlockGridChildAtom";const Mr=j.atom("");Mr.debugLabel="styleStateAtom";const ni=Ne.atomWithStorage("styleBreakpoint","xs");ni.debugLabel="styleBreakpointAtom";const Fd=()=>({flexChild:j.useAtomValue(ei),gridChild:j.useAtomValue(ti)}),zd=j.atom(t=>{const e=t(vs),n=t(Se);let s=e;const r=[e];do{const o=n.find(({_id:i})=>i===(s==null?void 0:s._parent));s=o,o&&r.push(o)}while(s!=null&&s._parent);return r}),Hd=()=>d.compact(j.useAtomValue(zd)),U=()=>{const[t,e]=j.useAtom(ks),n=g.useCallback(s=>{e(r=>d.includes(r,s)?d.without(r,s):[...r,s])},[e]);return[t,e,n]},si=(t,e,n)=>{const s=K.getRegisteredChaiBlock(d.get(n,"_type",""));if(!s)return t;const r={...t};return d.forEach(d.keys(t),o=>{if(d.includes(d.get(s,"i18nProps",[]),o)&&!d.isEmpty(e)){const i=`${o}-${e}`;d.set(r,i,t[o]),d.unset(r,o)}}),r},st=()=>{const{updateBlocks:t}=Ee(),{selectedLang:e}=_e(),n=J();return g.useCallback((s,r,o)=>{const i=si(r,e,n);t(s,i,o)},[e,n,t])},Vd=()=>{const{updateMultipleBlocksProps:t}=Ee();return g.useCallback(e=>{t(e)},[t])},Wd=()=>{const{updateBlocksRuntime:t}=Ee();return g.useCallback(async(e,n,s=30)=>{const r=d.keys(d.omit(n,["_id"]));for(const o of r){const i=n[o];if(d.isString(i)){const l=d.chunk(i.split(""),12);let c="";t([e],{[o]:""});for(let u=0;u<l.length;u++)c+=l[u].join(""),t([e],{[o]:c}),await new Promise(p=>setTimeout(p,s))}}},[t])},ri=()=>{const{updateMultipleBlocksProps:t}=Ee(),e=Wd();return g.useCallback(async n=>{for(const s of n)await e(s._id,s);t(n)},[e,t])},Dr=()=>{const{updateBlocksRuntime:t}=Ee(),{selectedLang:e}=_e(),n=J();return g.useCallback((s,r)=>{const o=si(r,e,n);t(s,o)},[e,n,t])},Or=j.atom({});Or.debugLabel="blockRepeaterDataAtom";const oi=()=>j.useAtom(Or),Gd=(t,e,n,s)=>{const[r,o]=g.useState({status:"idle",props:{},error:void 0}),i=Dr(),l=$("getBlockAsyncProps",async h=>({})),c=j.useSetAtom(Or),u=JSON.stringify([t==null?void 0:t._id,...d.values(d.pick(t,n??[]))]),p=(t==null?void 0:t._type)==="Repeater"&&d.startsWith(t.repeaterItems,`{{${q.COLLECTION_PREFIX}`),f=(t==null?void 0:t._type)!=="Repeater"&&e==="live";return g.useEffect(()=>{if(e==="mock"){if(d.isFunction(s)){o(x=>({...x,status:"loading",props:{}}));const h=s({block:t});if(!qo.isObject(h))throw new Error("mockDataProvider should return an object");o(x=>({...x,status:"loaded",props:h}))}return}e==="live"&&(!p&&!f||(o(h=>({...h,status:"loading",props:{}})),l({block:t}).then((h={})=>{p?(c(x=>({...x,[t._id]:{status:"loaded",props:d.get(h,"items",[]),repeaterItems:t.repeaterItems}})),o(x=>({...x,status:"loaded",props:{totalItems:d.get(h,"totalItems")}})),i([t._id],{totalItems:d.get(h,"totalItems")})):o(x=>({...x,status:"loaded",props:qo.isObject(h)?h:{}}))}).catch(h=>{p?(c(x=>({...x,[t._id]:{status:"error",error:h,props:[]}})),o(x=>({...x,status:"error",error:h,props:{}}))):o(x=>({...x,status:"error",error:h,props:{}}))})))},[t==null?void 0:t._id,u,p,f,s,e]),{$loading:d.get(r,"status")==="loading",...t?d.get(r,"props",{}):{}}},$r=j.atom(null);$r.debugLabel="chaiBuilderPropsAtom";const Ud=j.atom({});Ud.debugLabel="chaiExternalDataAtom";const qd=j.atom({});qd.debugLabel="chaiRjsfFieldsAtom";const Kd=j.atom({});Kd.debugLabel="chaiRjsfWidgetsAtom";const Yd=j.atom({});Yd.debugLabel="chaiRjsfTemplatesAtom";const Fr=j.atom({});Fr.debugLabel="chaiPageExternalDataAtom";const en=j.atom({});en.debugLabel="chaiDesignTokensAtom";const tn=()=>{const[t]=oi(),e=g.useMemo(()=>{const s={};return Object.entries(t).forEach(([r,o])=>{o.status==="loaded"&&o.repeaterItems&&(s[o.repeaterItems.replace("}}",`/${r}`).replace("{{","")]=o.props)}),s},[t]);return{...j.useAtomValue(Fr),...e}},ws=j.atom(0),ai=j.atom({isOpen:!1,blockId:null}),Cs=j.atom({}),Xd=j.atom({}),ii=t=>d.filter(t.map(e=>e._type==="PartialBlock"||e._type==="GlobalBlock"?d.get(e,"partialBlockId",d.get(e,"globalBlock","")):null),Boolean);function li(t,e,n,s=new Set){if(t===e)return!0;if(s.has(e))return!1;s.add(e);const r=n[e]||[];for(const o of r)if(o===t||li(t,o,n,s))return!0;return!1}function ur(t,e,n=new Set){if(n.has(t))return 0;n.add(t);const s=e[t]||[];return s.length===0?1:1+Math.max(...s.map(r=>ur(r,e,new Set(n))))}const Jd=[{name:"no-nested-div-in-p",description:"Prevents div elements from being nested inside paragraph elements",validate:(t,e)=>{const n=[],s=(r,o=!1)=>{r.forEach(i=>{const l=i._type==="Paragraph";i._type==="Box"&&o&&n.push({id:`div-in-paragraph-${i._id}`,message:"Box (div) cannot be nested inside Paragraph elements",severity:"error",blockId:i._id}),i.children&&i.children.length>0&&s(i.children,l)})};return s(e),n}},{name:"no-interactive-nesting",description:"Prevents interactive elements (links, buttons with href) from being nested inside other interactive elements",validate:(t,e)=>{const n=[],s=(o,i=!1,l=[])=>{o.forEach(c=>{const u=[...l,c._id],p=c._type==="Link",f=c._type==="Button"&&c.link&&c.link.href&&c.link.href.trim()!=="",m=p||f;if(m&&i){const h=p?"Link":"Button with href";n.push({id:`nested-interactive-tree-${c._id}`,message:`${h} cannot be nested inside another interactive element (link or button with href)`,severity:"error",blockId:c._id})}c.children&&c.children.length>0&&s(c.children,m,u)})},r=o=>{o.filter(l=>l._type==="Link"||l._type==="Button"&&l.link&&l.link.href&&l.link.href.trim()!=="").forEach(l=>{if(l._parent){const c=o.find(m=>m._id===l._parent),u=c&&c._type==="Link",p=c&&c._type==="Button"&&c.link&&c.link.href&&c.link.href.trim()!=="";if(u||p){const m=l._type==="Link"?"Link":"Button with href",h=u?"Link":"Button with href";n.push({id:`nested-interactive-parent-${l._id}`,message:`${m} cannot be nested inside ${h}`,severity:"error",blockId:l._id})}let f=c;for(;f&&f._parent;){const m=o.find(h=>h._id===f._parent);if(m){const h=m._type==="Link",x=m._type==="Button"&&m.link&&m.link.href&&m.link.href.trim()!=="";if(h||x){const b=l._type==="Link"?"Link":"Button with href",y=h?"Link":"Button with href";n.push({id:`nested-interactive-ancestor-${l._id}`,message:`${b} cannot be nested inside ${y}`,severity:"error",blockId:l._id});break}}f=m}}})};return s(e),r(t),n}},{name:"listitem-in-list",description:"Ensures ListItems are only inside List containers",validate:(t,e)=>{const n=[],s=(r,o=null)=>{r.forEach(i=>{i._type==="ListItem"&&o!=="List"&&n.push({id:`listitem-outside-list-${i._id}`,message:"List Item must be inside a List container",severity:"error",blockId:i._id}),i.children&&i.children.length>0&&s(i.children,i._type)})};return s(e),n}},{name:"table-cell-structure",description:"Validates proper table hierarchy (TableCell -> TableRow -> TableHead/Body -> Table)",validate:(t,e)=>{const n=[],s=(r,o=[])=>{r.forEach(i=>{const l=[...o,i._type];if(i._type==="TableCell"){const c=l.includes("TableRow"),u=l.includes("TableHead")||l.includes("TableBody"),p=l.includes("Table");(!c||!u||!p)&&n.push({id:`table-cell-structure-${i._id}`,message:"Table Cell must be inside a Table Row, which must be inside Table Head/Body, which must be inside a Table",severity:"error",blockId:i._id})}i._type==="TableRow"&&!l.slice(0,-1).includes("Table")&&n.push({id:`table-row-outside-table-${i._id}`,message:"Table Row must be inside a Table (Table Head or Table Body)",severity:"error",blockId:i._id}),(i._type==="TableHead"||i._type==="TableBody")&&!l.slice(0,-1).includes("Table")&&n.push({id:`table-section-outside-table-${i._id}`,message:"Table Head/Body must be inside a Table",severity:"error",blockId:i._id}),i.children&&i.children.length>0&&s(i.children,l)})};return s(e),n}},{name:"no-nested-buttons",description:"Prevents buttons from being nested inside other buttons",validate:(t,e)=>{const n=[],s=(r,o=!1)=>{r.forEach(i=>{const l=i._type==="Button";l&&o&&n.push({id:`nested-button-${i._id}`,message:"Button cannot be nested inside another button",severity:"error",blockId:i._id}),i.children&&i.children.length>0&&s(i.children,l)})};return s(e),n}},{name:"no-nested-paragraphs",description:"Prevents paragraph elements from being nested inside other paragraph elements at any level",validate:(t,e)=>{const n=[],s=(r,o=[])=>{r.forEach(i=>{const l=i._type==="Paragraph";if(l&&o.length>0&&n.push({id:`nested-paragraph-${i._id}`,message:"Paragraph cannot be nested inside another paragraph",severity:"error",blockId:i._id}),i.children&&i.children.length>0){const c=l?[...o,i._id]:o;s(i.children,c)}})};return s(e),n}},{name:"heading-structure",description:"Checks for proper heading hierarchy and warns about skipped levels",validate:(t,e)=>{const n=[],s=[],r=(o,i=[])=>{o.forEach(l=>{if(l._type==="Heading"){const c=l.tag||"h2",u=parseInt(c.replace("h",""))||2;s.push({level:u,blockId:l._id,path:[...i,l._id]})}l.children&&l.children.length>0&&r(l.children,[...i,l._id])})};r(e);for(let o=1;o<s.length;o++){const i=s[o],l=s[o-1];i.level>l.level+1&&n.push({id:`heading-level-skip-${i.blockId}`,message:`Heading level skipped: h${l.level} followed by h${i.level}. Consider using h${l.level+1}`,severity:"warning",blockId:i.blockId})}return n}}],Zd=[{name:"image-alt-text",description:"Warns if images are missing alt text",validate:(t,e)=>{const n=[],s=r=>{r.forEach(o=>{o._type==="Image"&&!o.alt&&n.push({id:`image-missing-alt-${o._id}`,message:"Image should have alt text for accessibility",severity:"warning",blockId:o._id}),o.children&&o.children.length>0&&s(o.children)})};return s(e),n}},{name:"button-accessibility",description:"Ensures buttons have accessible labels",validate:(t,e)=>{const n=[],s=r=>{r.forEach(o=>{o._type==="Button"&&(o.content||o.children&&o.children.length>0||n.push({id:`button-no-label-${o._id}`,message:"Button should have accessible content (text or icon)",severity:"warning",blockId:o._id})),o.children&&o.children.length>0&&s(o.children)})};return s(e),n}}];class Qd{constructor(){wt(this,"rules",[...Jd])}addRule(e){this.rules.push(e)}removeRule(e){const n=this.rules.findIndex(s=>s.name===e);return n>-1?(this.rules.splice(n,1),!0):!1}getRules(){return[...this.rules]}enableAccessibilityRules(){this.rules.push(...Zd)}getRuleNames(){return this.rules.map(e=>e.name)}}const qs=new Qd,zr=(t={})=>{const e=$("flags.validateStructure",!0),n=j.useSetAtom(Qt),s=j.useSetAtom(Br),r=j.useSetAtom(Rr),o=j.useSetAtom(Pr),i=g.useCallback(c=>{const u=c;if(!e||!u||u.length===0)return;const p=Tr(u),f=[];let m=qs.getRules();t.enableAccessibilityRules&&(qs.enableAccessibilityRules(),m=qs.getRules()),t.customRules&&t.customRules.length>0&&m.push(...t.customRules),m.forEach(y=>{try{const v=y.validate(u,p);f.push(...v)}catch(v){console.error(`Error running structure rule "${y.name}":`,v)}});const h=f.filter(y=>y.severity==="error").length>0,x=f.filter(y=>y.severity==="warning").length>0,b=!h;n(f),s(b),r(h),o(x)},[e,t,n,s,r,o]);return ve.useDebouncedCallback(i,[e,t,n,s,r,o],1e3)},eu=["hover","focus","focus-within","focus-visible","active","visited","target","first","last","only","odd","even","first-of-type","last-of-type","only-of-type","empty","disabled","checked","indeterminate","default","required","valid","invalid","in-range","out-of-range","placeholder-shown","autofill","read-only","open","before","after","first-letter","first-line","marker","selection","file","placeholder","hs-collapse-open","hs-accordion-active"],pr={bodyFont:"Arial",headingFont:"Arial",roundedCorners:5,primaryColor:"#570df8",secondaryColor:"#f002b8",bodyBgDarkColor:"#031022",bodyBgLightColor:"#fcfcfc",bodyTextDarkColor:"#ffffff",bodyTextLightColor:"#000000"},tu=j.atom(pr);j.atom(null);const nu=()=>{const[t,e]=j.useAtom(tu);return[d.isObject(t)?{...pr,...t}:pr,e]},su=j.atom(null),ru=()=>({currentPage:j.useAtomValue(su)}),ou=d.memoize(t=>{const e=K.getRegisteredChaiBlock(t),n=d.get(e,"schema.properties",{});return d.compact(Object.keys(n).map(s=>d.get(n[s],"builderProp",!1)||d.get(n[s],"runtime",!1)?s:null))}),au=()=>{const[t]=nu(),{currentPage:e}=ru(),[n]=Z();return g.useCallback(()=>{const s=d.map(n,r=>d.omit(r,ou(r._type)));return{currentPage:e,blocks:s}},[t,e,n])},ci=j.atom(!1),di=()=>j.useAtom(ci),Ve=()=>{const t=$("permissions",null);return{hasPermission:g.useCallback(n=>t?t.includes(n):!0,[t])}},iu=(t=Qe.defaultThemeOptions)=>{const e=Qe.defaultThemeValues;return t.fontFamily&&(e.fontFamily=Object.entries(t.fontFamily).reduce((n,[s,r])=>({...n,[s.replace("font-","")]:r}),e.fontFamily)),e.borderRadius=t.borderRadius,t.colors&&(e.colors=t.colors.reduce((n,s)=>(Object.entries(s.items).forEach(([r,o])=>{r in n&&(n[r]=o)}),n),e.colors)),e},lu=j.atom({}),_n=()=>{const t=nn(),e=g.useMemo(()=>iu(t),[t]),n=$("theme",{}),[s,r]=j.useAtom(lu);return[g.useMemo(()=>({...e,...!d.isEmpty(n)&&n,...!d.isEmpty(s)&&s}),[e,n,s]),r]},nn=()=>{const t=$("themeOptions",n=>n);return g.useMemo(()=>t(Qe.defaultThemeOptions),[t])},cu=j.atom("block"),ui=()=>j.useAtom(cu),du=j.atom("settings"),pi=()=>j.useAtom(du),js=j.atom("SAVED");js.debugLabel="builderSaveStateAtom";const uu=(t,e)=>e?t.some(n=>{if(!(n!=null&&n._type)||n._type==="PartialBlock")return!1;try{const s=K.getRegisteredChaiBlock(n._type);return s?(d.has(s,"i18nProps")?s.i18nProps??[]:[]).some(o=>{const i=`${o}-${e}`;return!n[i]||d.isEmpty(n[i])}):!1}catch(s){return console.warn(`Failed to get block definition for type: ${n._type}`,s),!1}}):!1,sn=()=>{const[t,e]=j.useAtom(js),n=$("onSave",async N=>{}),s=$("onSaveStateChange",d.noop),r=au(),[o]=_n(),{hasPermission:i}=Ve(),{selectedLang:l,fallbackLang:c}=_e(),[u]=di(),p=j.useAtomValue(en),f=j.useAtomValue(Cs),m=zr(),[,h]=j.useAtom(ws),x=()=>{const N=r();return!l||l===c?!1:uu(N.blocks||[],l)},b=g.useCallback(N=>{const E=new Set,_=ii(N);for(;_.length>0;){const S=_.shift();if(E.has(S))continue;E.add(S);const A=f[S];(A==null?void 0:A.status)==="loaded"&&A.dependencies.length>0&&_.push(...A.dependencies)}return[...E]},[f]),y=g.useCallback(N=>{const E=JSON.stringify(N),_=/pageType:[^:]+:([a-f0-9-]{36})/gi,S=[];let A;for(;(A=_.exec(E))!==null;)A[1]&&S.push(A[1]);return d.compact([...new Set(S)])},[]),v=g.useCallback(N=>!N&&(!i("save_page")||!u)||!N&&t==="SAVED",[i,u,t]);return{savePage:ve.useThrottledCallback(async(N=!1,E=!1)=>{if(v(E))return;const _=r();return _!=null&&_.blocks&&m(_.blocks),e("SAVING"),s("SAVING"),h(0),await n({autoSave:N,blocks:_.blocks,theme:o,needTranslations:x(),designTokens:p,partialIds:b(_.blocks||[]),linkPageIds:y(_.blocks||[])}),setTimeout(()=>{e("SAVED"),s("SAVED")},100),!0},[v,r,e,p,o,h,n,s,u,m,b,y],3e3),savePageAsync:async(N=!1)=>{if(v(N))return;e("SAVING"),s("SAVING");const E=r();return h(0),await n({autoSave:!0,blocks:E.blocks,theme:o,needTranslations:x(),designTokens:p,partialIds:b(E.blocks||[]),linkPageIds:y(E.blocks||[])}),setTimeout(()=>{e("SAVED"),s("SAVED")},100),!0},saveState:t,setSaveState:e,needTranslations:x}},pu=()=>{const{savePage:t,saveState:e}=sn(),n=$("autoSave",!0),s=$("autoSaveActionsCount",10),[r]=j.useAtom(ws);g.useEffect(()=>{n&&(e==="SAVED"||e==="SAVING"||r>=s&&t(!0))},[n,t,e,r,s])},Hr=()=>{const[,t]=j.useAtom(ws),{setSaveState:e}=sn();return g.useCallback(()=>{t(n=>n+1),e(n=>n!=="UNSAVED"?"UNSAVED":n)},[t,e])};function fu(t,e,n,s){const r=[...e];let o=[...t];if(n){const u=t.find(p=>p._id===n);if(u&&u.content!==void 0&&u.content!==""&&!t.some(f=>f._parent===n)){const m={_id:ke.generateUUID(),_parent:n,_type:"Text",content:u.content};Object.keys(u).forEach(h=>{h.startsWith("content-")&&(m[h]=u[h])}),r.unshift(m),o=o.map(h=>{if(h._id===n){const x={...h,content:""};return Object.keys(x).forEach(b=>{b.startsWith("content-")&&(x[b]="")}),x}return h})}}let i=o.filter(u=>!u._parent);n&&(i=o.filter(u=>u._parent===n));const l=s!==void 0&&!isNaN(s)&&s>-1?Math.min(s,i.length):i.length;let c=o.length;for(let u=0,p=0;u<o.length;u++)if(n!==void 0?o[u]._parent===n:!o[u]._parent){if(p===l){c=u;break}p++}return!n&&s!==void 0&&s>=i.length&&(c=o.length),[...o.slice(0,c),...r,...o.slice(c)]}function hu(t){return Tr(t)}function mu(t){let e=[];return t.walk(n=>(delete n.model.children,e.push(n.model),!0)),e}function Xo(t,e){return t.first(n=>n.model._id===e)||null}function gu(t,e,n,s){var u,p;const r=Xo(t,e),o=Xo(t,n);if(!r||!o)return!1;o.children||(o.model.children=[]);let i=(u=o==null?void 0:o.children)==null?void 0:u.findIndex(f=>f.model._id===e);r.drop(),i=Math.max(i,0);const c=(((p=r==null?void 0:r.model)==null?void 0:p._parent)||"root")===n&&i<=s?s-1:s;try{o.addChildAtIndex(r,c)}catch(f){return console.error("Error adding child to parent:",f),!1}return!0}function xu(t,e){if(!e||!e._parent)return t;const n=e._parent,s=t.find(o=>o._id===n);if(!s)return t;const r=t.filter(o=>o._parent===n);if(r.length===2){const o=r.find(i=>i._id!==e._id);if(o&&o._type==="Text"&&"content"in s)return t.map(l=>{if(l._id===n){const c={...l,content:o.content};return Object.keys(o).forEach(u=>{u.startsWith("content-")&&(c[u]=o[u])}),c}return l}).filter(l=>l._id!==o._id)}return t}function bu(t,e,n){if(!n||n==="root")return t;const s=t.find(r=>r._id===n);if(!s)return t;if(s.content!==void 0&&s.content!==""&&!t.some(o=>o._parent===n&&o._id!==e._id)){const i={_id:ke.generateUUID(),_parent:n,_type:"Text",content:s.content};Object.keys(s).forEach(u=>{u.startsWith("content-")&&(i[u]=s[u])});const l=t.map(u=>{if(u._id===n){const p={...u,content:""};return Object.keys(p).forEach(f=>{f.startsWith("content-")&&(p[f]="")}),p}return u}),c=l.findIndex(u=>u._id===e._id);return c!==-1?[...l.slice(0,c),i,...l.slice(c)]:[i,...l]}return t}function yu(t,e,n,s){if(!e)return t;const r=t.find(u=>u._id===e);if(!r)return t;let o=xu(t,r);const i=n||"root",c=new Xc().parse({_id:"root",children:hu(o)});if(gu(c,e,i,s)){let u=mu(c);const p=u.find(f=>f._id===e);return p&&(p._parent=i==="root"?null:i),u.shift(),n&&(u=bu(u,r,n)),u}return o}const hn=new BroadcastChannel("chaibuilder"),fi=()=>{const t=$("pageId","chaibuilder_page");return{postMessage:ve.useDebouncedCallback(n=>hn.postMessage({...n,pageId:t}),[t],200)}},ku=()=>{const[,t]=Z(),e=$("pageId","chaibuilder_page"),{updateBlocksProps:n}=hi();g.useEffect(()=>(hn.onmessageerror=s=>{console.log("error",s)},hn.onmessage=s=>{s.data.type==="blocks-updated"&&s.data.pageId===e&&t(s.data.blocks),s.data.type==="blocks-props-updated"&&s.data.pageId===e&&n(s.data.blocks)},()=>{hn.onmessage=null,hn.onmessageerror=null}),[t,e])},Vr=(t,e)=>{let n=[...t],s=[];e.forEach(l=>{const c=n.find(f=>f._id===l);if(!c||!c._parent)return;const u=c._parent,p=n.filter(f=>f._parent===u);if(p.length===2){const f=p.find(m=>m._id!==l);if(f&&f._type==="Text"){const m=n.find(h=>h._id===u);m&&"content"in m&&(n=n.map(h=>{if(h._id===u){const x={...h,content:f.content};return Object.keys(f).forEach(b=>{b.startsWith("content-")&&(x[b]=f[b])}),x}return h}),s.push(f._id))}}});const r=[...e,...s],o=[],i=d.filter(n,l=>d.includes(r,l._id)||d.includes(r,l._parent)?(o.push(l._id),!1):!0);return d.isEmpty(o)?i:Vr(i,o)},Ss=()=>{const[t]=Z(),[e,n]=U(),{setNewBlocks:s}=Ee(),{hasPermission:r}=Ve();return g.useCallback(o=>{var l;if(!r(Q.DELETE_BLOCK))return;const i=((l=d.find(t,{_id:o[0]}))==null?void 0:l._parent)||null;s(Vr(t,o)),setTimeout(()=>n(i?[i]:[]),200)},[t,n,e,r])},vu=j.atom(null,(t,e,{id:n,props:s})=>{const r=t(In),o=d.find(r,i=>t(i)._id===n);return o?e(o,{...t(o),...s}):null}),wu=()=>j.useSetAtom(vu),Cu=t=>Ne.useAtomCallback(g.useCallback((e,n,s)=>{const r=e(t);if(!r||!r.length)return console.warn("No blocks available in splitAtoms"),null;const o=d.find(r,i=>e(i)._id===(d.isString(s)?s:e(s)._id));return o||(console.warn(`Block with id ${s} not found`),null)},[t]),{store:We}),hi=()=>{const[,t]=Z(),{postMessage:e}=fi(),n=wu(),s=zr(),r=Hr();return{setNewBlocks:o=>{t(o),e({type:"blocks-updated",blocks:o})},addBlocks:(o,i,l)=>{t(c=>{const u=fu(c,o,i,l);return e({type:"blocks-updated",blocks:u}),s(u),r(),u})},removeBlocks:o=>{t(i=>{const l=Vr(i,o);return e({type:"blocks-updated",blocks:l}),s(l),r(),l})},moveBlocks:(o,i,l)=>{t(c=>{let u=[...c];for(let p=0;p<o.length;p++)u=yu(u,o[p],i,l);return d.each(o,p=>{const f=d.find(u,m=>m._id===p);f&&n({id:p,props:{_parent:f._parent||null}})}),e({type:"blocks-updated",blocks:u}),s(u),r(),u})},updateBlocksProps:o=>{o.forEach(i=>{const l=d.omit(i,"_id");n({id:i._id,props:l})}),e({type:"blocks-props-updated",blocks:o}),r()}}},Ke=new Jc;Ke.setLimit(50);const ju=j.atom({canUndo:!1,canRedo:!1}),Tn=()=>{const[,t]=j.useAtom(js),[e,n]=j.useAtom(ju),s=$("onSaveStateChange",d.noop),r=g.useCallback(()=>{const u={canUndo:Ke.hasUndo(),canRedo:Ke.hasRedo()};n(u),t("UNSAVED"),s("UNSAVED")},[n,t,s]);g.useEffect(()=>(Ke.setCallback(r),()=>{Ke.setCallback(d.noop)}),[r]);const o=g.useCallback(u=>{Ke.add(u),r()},[r]),i=g.useCallback(()=>{Ke.undo(),r()},[r]),l=g.useCallback(()=>{Ke.redo(),r()},[r]),c=g.useCallback(()=>{Ke.clear(),n({canUndo:!1,canRedo:!1})},[n]);return g.useMemo(()=>({add:o,undo:i,redo:l,hasUndo:()=>e.canUndo,hasRedo:()=>e.canRedo,clear:c}),[o,i,l,e.canUndo,e.canRedo,c])},Z=()=>j.useAtom(Se),Ee=()=>{const{add:t}=Tn(),{setNewBlocks:e,addBlocks:n,removeBlocks:s,moveBlocks:r,updateBlocksProps:o}=hi();return{moveBlocks:(h,x,b)=>{const y=We.get(Se),v=d.map(h,I=>{const E=y.find(A=>A._id===I)._parent||null,S=y.filter(A=>E?A._parent===E:!A._parent).map(A=>A._id).indexOf(I);return{_id:I,oldParent:E,oldPosition:S}}),w=v.find(({_id:I})=>I===h[0]);w&&w.oldParent===x&&w.oldPosition===b||(r(h,x??null,b),t({undo:()=>d.each(v,({_id:I,oldParent:N,oldPosition:E})=>{r([I],N??null,E)}),redo:()=>r(h,x??null,b)}))},addBlocks:(h,x,b)=>{n(h,x,b),t({undo:()=>s(d.map(h,"_id")),redo:()=>n(h,x,b)})},removeBlocks:h=>{var w;const x=We.get(Se),b=(w=d.first(h))==null?void 0:w._parent,v=x.filter(I=>b?I._parent===b:!I._parent).indexOf(d.first(h));s(d.map(h,"_id")),t({undo:()=>n(h,b??void 0,v),redo:()=>s(d.map(h,"_id"))})},updateBlocks:(h,x,b)=>{const y=We.get(Se);let v=[];if(b)v=d.map(h,w=>({_id:w,...b}));else{const w=d.keys(x);v=d.map(h,I=>{const N=y.find(_=>_._id===I),E={_id:I};return d.each(w,_=>E[_]=N[_]),E})}o(d.map(h,w=>({_id:w,...x}))),t({undo:()=>o(v),redo:()=>o(d.map(h,w=>({_id:w,...x})))})},updateBlocksRuntime:(h,x)=>{o(d.map(h,b=>({_id:b,...x})))},setNewBlocks:h=>{const x=We.get(Se);e(h),t({undo:()=>e(x),redo:()=>e(h)})},updateMultipleBlocksProps:h=>{const x=We.get(Se);let b=[];b=d.map(h,y=>{const v=d.keys(y),w=x.find(N=>N._id===y._id),I={};return d.each(v,N=>I[N]=w==null?void 0:w[N]),I}),o(h),t({undo:()=>o(b),redo:()=>o(h)})}}},Su=({block:t,children:e})=>{const{t:n}=F.useTranslation(),[s]=Z(),{hasPermission:r}=Ve(),o=d.get(t,"_id"),i=d.get(t,"_parent"),l=d.filter(s,f=>i?d.get(f,"_parent")===i:!d.get(f,"_parent")),c=ss(d.get(t,"_type","")),u=d.findIndex(l,{_id:o}),p=f=>{if(f==="CHILD")re.publish(Y.OPEN_ADD_BLOCK,t);else{const m={_id:i||"",position:l==null?void 0:l.length};f==="BEFORE"?m.position=Math.max(u,0):f==="AFTER"&&(m.position=u+1),re.publish(Y.OPEN_ADD_BLOCK,m)}};return r(Q.ADD_BLOCK)?a.jsxs(tt,{children:[a.jsx(nt,{children:e}),a.jsxs(Ue,{className:"border border-blue-500 bg-primary text-white shadow-2xl",children:[c&&a.jsx(de,{className:"cursor-pointer text-xs",onClick:()=>p("CHILD"),children:n("Add inside")}),a.jsx(de,{className:"cursor-pointer text-xs",onClick:()=>p("BEFORE"),children:n("Add before")}),a.jsx(de,{className:"cursor-pointer text-xs",onClick:()=>p("AFTER"),children:n("Add after")})]})]}):null},Ns=j.atom(null),Bn=j.atom({isVisible:!1,isValid:!1,position:"inside",placeholderOrientation:"horizontal",isEmpty:!1,top:0,left:0,width:0,height:0});let qt=!1;const Wr=t=>{qt=t},Gr=j.atom(0),Nu=j.atom(!1);Nu.debugLabel="readOnlyModeAtom";const Eu=j.atom("online");Eu.debugLabel="networkModeAtom";j.atom("");const Au=j.atom(!1);Au.debugLabel="editLayerNameAtom";const Iu=j.atom("");Iu.debugLabel="activeLanguageAtom";const _u=j.atom("");_u.debugLabel="primaryLanguageAtom";const Es=j.atom(null);Es.debugLabel="canvasIframeAtom";const Tu=j.atom("outline");Tu.debugLabel="activePanelAtom";const mi=j.atom("");mi.debugLabel="showPredefinedBlockCategoryAtom";const Bu=j.atom(!1);Bu.debugLabel="draggingFlagAtom";const Ur=j.atom(null);Ur.debugLabel="treeRefAtom";const Ru=j.atom({});Ru.debugLabel="canvasSettingsAtom";const gi=j.atom(!1);gi.debugLabel="aiAssistantActiveAtom";const Pu=j.atom(!1);Pu.debugLabel="codeEditorOpenAtom";const Lu=Ne.atomWithStorage("codeEditorHeight",500);Lu.debugLabel="codeEditorHeightAtom";const Mu=j.atom([]);Mu.debugLabel="xShowBlocksAtom";const qr=Ne.atomWithStorage("_selectedLibrary",null);qr.debugLabel="selectedLibraryAtom";const Kr=j.atom(!0);Kr.debugLabel="dataBindingActiveAtom";const rn=()=>j.useAtom(Es);let se=null,lt=null;function Du(t,e){const n=t.getAttribute("data-block-name"),s=t.getAttribute("data-block-type"),r=n||s||"Container",o=e.createElement("div");return o.className="chai-drag-parent-label",o.textContent=r,o.className="absolute top-0 -left-0.5 -translate-x-0.5 -translate-y-full -mt-1 bg-green-500/95 text-white px-2 py-1 text-xs font-semibold font-sans leading-tight whitespace-nowrap shadow-lg z-[999999] pointer-events-none select-none",o}function Ks(){lt&<.parentNode&&(lt.parentNode.removeChild(lt),lt=null)}const Yr=()=>{const[t]=rn(),e=g.useMemo(()=>{var r;return(t==null?void 0:t.contentDocument)||((r=t==null?void 0:t.contentWindow)==null?void 0:r.document)},[t]),n=g.useCallback(r=>{if(!e)return;let o=null;if(!r){se&&(se.style.outline="",se.style.outlineOffset="",se.style.backgroundColor="",se.style.position="",se=null),Ks();return}typeof r!="string"?o=r:o=e.querySelector(`[data-block-id="${r}"]`),!(o===se&<&<.parentNode)&&(se&&se!==o&&(se.style.outline="",se.style.outlineOffset="",se.style.backgroundColor="",se.style.position=""),Ks(),o?(o.style.outline="2px dashed rgba(34, 197, 94, 1)",o.style.outlineOffset="2px",o.style.backgroundColor="rgba(34, 197, 94, 0.05)",window.getComputedStyle(o).position==="static"&&(o.style.position="relative"),lt=Du(o,e),o.appendChild(lt),se=o):se=null)},[e]),s=g.useCallback(()=>{se&&(se.style.outline="",se.style.outlineOffset="",se.style.backgroundColor="",window.getComputedStyle(se).position==="relative"&&se.style.position==="relative"&&(se.style.position=""),se=null),Ks()},[]);return{highlightParent:n,clearParentHighlight:s,lastDragHighlighted:se}},Ou=()=>{const[,t]=j.useAtom(Ns),[,e]=j.useAtom(Bn),[n]=rn(),{clearParentHighlight:s}=Yr(),[r,o]=j.useAtom(Gr),i=n==null?void 0:n.contentDocument;return g.useCallback(()=>{t(null),e({isVisible:!1,isValid:!1,position:"inside",placeholderOrientation:"horizontal",isEmpty:!1,top:0,left:0,width:0,height:0}),$u(i),s(),i&&i.querySelectorAll("[data-dragging]").forEach(c=>{c.removeAttribute("data-dragging")}),Wr(!1),o(r+1)},[t,e,i,s,r,o])};function $u(t){if(!t)return;t.querySelectorAll("[data-drop-target]").forEach(n=>n.removeAttribute("data-drop-target"))}function Mt(t,e=null){const n=window.getComputedStyle(t),s=e?window.getComputedStyle(e):null,r=n.display,o=s?s.display:null;if(r==="flex"||r==="inline-flex"){const i=n.flexDirection;return i==="column"||i==="column-reverse"?"vertical":"horizontal"}else if(r==="grid"){const i=n.gridAutoFlow,l=n.gridTemplateColumns;return i.includes("column")||l&&l!=="none"&&l!==""&&!l.includes("calc")&&l.split(" ").length<=1?"vertical":"horizontal"}else if(o==="inline-block"||o==="inline")return"horizontal";return"vertical"}const Fu=["Heading","Text","Image","Paragraph","Icon","Input","Radio","Checkbox","Select","CustomHTML","TextArea","Divider","Repeater","Video"];function zu(t){try{return Fu.includes(t)}catch{return!1}}const Ze={MIN_EDGE_ZONE:10,MAX_EDGE_ZONE:30,EDGE_ZONE_PERCENTAGE:.2,GAP_THRESHOLD:8,MIN_SIZE_FOR_EDGE_ZONES:50,PARENT_EDGE_PROXIMITY:20};function Jo(t){try{if(t<Ze.MIN_SIZE_FOR_EDGE_ZONES)return 0;const e=t*Ze.EDGE_ZONE_PERCENTAGE;return Math.max(Ze.MIN_EDGE_ZONE,Math.min(Ze.MAX_EDGE_ZONE,e))}catch{return Ze.MIN_EDGE_ZONE}}function gt(t){try{const e=[],n=t.children;for(let s=0;s<n.length;s++){const r=n[s];r.hasAttribute("data-block-id")&&e.push(r)}return e}catch{return[]}}function Xn(t){try{return gt(t).length>0}catch{return!1}}function Hu(t,e,n,s){try{const r=gt(t);if(r.length<2)return null;const o=Uu(r,e,n,s);if(o){const i=Xr(r,o,s);i.sort((l,c)=>{const u=l.getBoundingClientRect(),p=c.getBoundingClientRect();return s==="vertical"?u.top-p.top:u.left-p.left});for(let l=0;l<i.length-1;l++){const c=i[l],u=i[l+1],p=c.getBoundingClientRect(),f=u.getBoundingClientRect();if(s==="vertical"){const m=p.bottom,h=f.top,x=h-m,b=n>=m&&n<=h,y=e>=Math.min(p.left,f.left)&&e<=Math.max(p.right,f.right);if(b&&y&&x>=Ze.GAP_THRESHOLD)return{before:c,after:u}}else{const m=p.right,h=f.left,x=h-m,b=e>=m&&e<=h,y=n>=Math.min(p.top,f.top)&&n<=Math.max(p.bottom,f.bottom);if(b&&y&&x>=Ze.GAP_THRESHOLD)return{before:c,after:u}}}}for(let i=0;i<r.length-1;i++){const l=r[i],c=r[i+1],u=l.getBoundingClientRect(),p=c.getBoundingClientRect();if(s==="vertical"){const f=u.bottom,m=p.top,h=m-f,x=n>=f&&n<=m,b=e>=Math.min(u.left,p.left)&&e<=Math.max(u.right,p.right);if(x&&b&&h>=Ze.GAP_THRESHOLD)return{before:l,after:c}}else{const f=u.right,m=p.left,h=m-f,x=e>=f&&e<=m,b=n>=Math.min(u.top,p.top)&&n<=Math.max(u.bottom,p.bottom);if(x&&b&&h>=Ze.GAP_THRESHOLD)return{before:l,after:c}}}return null}catch{return null}}function Vu(t,e,n,s){try{const r=t.getBoundingClientRect(),o=Ze.PARENT_EDGE_PROXIMITY;if(s==="vertical"){if(n<=r.top+o)return"start";if(n>=r.bottom-o)return"end"}else{if(e<=r.left+o)return"start";if(e>=r.right-o)return"end"}return null}catch{return null}}function Wu(t,e,n,s,r){const o=t.getBoundingClientRect();if(r==="vertical"){const l=(n-o.top)/o.height,c=Jo(o.height),u=c/o.height;return s?c>0&&l<u?{position:"before",confidence:1-l/u}:c>0&&l>1-u?{position:"after",confidence:(l-(1-u))/u}:{position:"inside",confidence:1-Math.abs(l-.5)*2}:l<.5?{position:"before",confidence:1-l*2}:{position:"after",confidence:(l-.5)*2}}else{const l=(e-o.left)/o.width,c=Jo(o.width),u=c/o.width;return s?c>0&&l<u?{position:"before",confidence:1-l/u}:c>0&&l>1-u?{position:"after",confidence:(l-(1-u))/u}:{position:"inside",confidence:1-Math.abs(l-.5)*2}:l<.5?{position:"before",confidence:1-l*2}:{position:"after",confidence:(l-.5)*2}}}function Gu(t,e,n,s,r){var I,N,E,_;const o=t.getAttribute("data-block-id"),i=t.getAttribute("data-block-type")||"Box";if(!o)return null;let l=t.parentElement;for(;l&&!l.hasAttribute("data-block-id");)l=l.parentElement;const c=o==="canvas"?o:l==null?void 0:l.getAttribute("data-block-id"),u=l?Mt(l):"vertical",p=Mt(t),f=zu(i),m=!f&&et(i,s),h=((I=r.defaultView)==null?void 0:I.scrollY)||0,x=((N=r.defaultView)==null?void 0:N.scrollX)||0;if(o==="canvas"&&Xn(t)){const S=gt(t),A=S[S.length-1];if(A){const C=A.getBoundingClientRect(),T=t.getBoundingClientRect(),P=window.getComputedStyle(t),R=parseFloat(P.paddingLeft)||0,O=parseFloat(P.paddingRight)||0,H=T.width-R-O,G=T.left+x+R;return{position:"after",placeholderOrientation:"horizontal",rect:{top:C.bottom+h,left:G,width:H,height:4},targetElement:A,targetBlockId:A.getAttribute("data-block-id"),targetParentId:"canvas",isEmpty:!1,confidence:1}}}if(m&&!f&&Xn(t)){const S=Hu(t,e,n,p);if(S){const A=S.before.getBoundingClientRect(),C=S.after.getBoundingClientRect(),T=t.getBoundingClientRect(),P=window.getComputedStyle(t),R=parseFloat(P.paddingLeft)||0,O=parseFloat(P.paddingRight)||0,H=gt(t),G=Xr(H,S.before,p);let me=0;if(G.forEach(ie=>{const ne=ie.getBoundingClientRect();ne.height>me&&(me=ne.height)}),p==="vertical"){const ie=T.width-R-O,ne=T.left+x+R;return{position:"after",placeholderOrientation:"horizontal",rect:{top:A.bottom+h,left:ne,width:ie,height:4},targetElement:S.before,targetBlockId:S.before.getAttribute("data-block-id"),targetParentId:o,isGapZone:!0,confidence:1}}else{const ie=A.top+h,ne=me>0?me:Math.max(A.height,C.height);return{position:"after",placeholderOrientation:"vertical",rect:{top:ie,left:A.right+x,width:4,height:ne},targetElement:S.before,targetBlockId:S.before.getAttribute("data-block-id"),targetParentId:o,isGapZone:!0,confidence:1}}}}if(l&&c){const S=Vu(l,e,n,u);if(S){const A=l.getBoundingClientRect(),C=window.getComputedStyle(l),T=parseFloat(C.paddingLeft)||0,P=parseFloat(C.paddingRight)||0,R=parseFloat(C.paddingTop)||0,O=parseFloat(C.paddingBottom)||0,H=((E=r.defaultView)==null?void 0:E.scrollY)||0,G=((_=r.defaultView)==null?void 0:_.scrollX)||0,me=u==="vertical"?"horizontal":"vertical",ie=xi(l);if(S==="start"){const ne=gt(l)[0];if(ne){const we=ne.getBoundingClientRect();if(u==="vertical"){const Oe=A.width-T-P,W=A.left+G+T;return{position:"before",placeholderOrientation:me,rect:{top:we.top+H-2,left:W,width:Oe,height:4},targetElement:ne,targetBlockId:ne.getAttribute("data-block-id"),targetParentId:c,confidence:.9}}else{const Oe=A.top+H+R,W=ie.maxHeight>0?ie.maxHeight:A.height-R-O;return{position:"before",placeholderOrientation:me,rect:{top:Oe,left:we.left+G-2,width:4,height:W},targetElement:ne,targetBlockId:ne.getAttribute("data-block-id"),targetParentId:c,confidence:.9}}}}else{const ne=gt(l),we=ne[ne.length-1];if(we){const Oe=we.getBoundingClientRect();if(u==="vertical"){const W=A.width-T-P,$e=A.left+G+T;return{position:"after",placeholderOrientation:me,rect:{top:Oe.bottom+H-2,left:$e,width:W,height:4},targetElement:we,targetBlockId:we.getAttribute("data-block-id"),targetParentId:c,confidence:.9}}else{const W=A.top+H+R,$e=ie.maxHeight>0?ie.maxHeight:A.height-R-O;return{position:"after",placeholderOrientation:me,rect:{top:W,left:Oe.right+G-2,width:4,height:$e},targetElement:we,targetBlockId:we.getAttribute("data-block-id"),targetParentId:c,confidence:.9}}}}}}let b=Wu(t,e,n,m,u);if(f&&b.position==="inside"){const S=t.getBoundingClientRect();u==="vertical"?b={position:(n-S.top)/S.height<.5?"before":"after",confidence:b.confidence}:b={position:(e-S.left)/S.width<.5?"before":"after",confidence:b.confidence}}let y;b.position==="inside"?y=p==="vertical"?"horizontal":"vertical":y=u==="vertical"?"horizontal":"vertical";const v=qu(t,l,b.position,y,r),w=b.position==="inside"?o:c;return{position:b.position,placeholderOrientation:y,rect:v,targetElement:t,targetBlockId:o,targetParentId:w??"",isEmpty:b.position==="inside"&&!Xn(t),confidence:b.confidence}}function Uu(t,e,n,s){if(t.length===0)return null;const r=t.filter(l=>{const c=l.getBoundingClientRect();return s==="vertical"?n>=c.top&&n<=c.bottom:e>=c.left&&e<=c.right});if(r.length===0){const l=new Map;t.forEach(p=>{const f=p.getBoundingClientRect(),m=Math.round(s==="vertical"?f.top:f.left);l.has(m)||l.set(m,[]),l.get(m).push(p)});let c=null,u=1/0;l.forEach((p,f)=>{const m=Math.abs(s==="vertical"?n-f:e-f);m<u&&(u=m,c=p)}),c&&r.push(c)}if(r.length===0)return null;let o=r[0],i=1/0;return r.forEach(l=>{const c=l.getBoundingClientRect(),u=c.left+c.width/2,p=c.top+c.height/2,f=Math.sqrt(Math.pow(e-u,2)+Math.pow(n-p,2));f<i&&(i=f,o=l)}),o}function xi(t){const e=gt(t);if(e.length===0)return{maxWidth:0,maxHeight:0};let n=0,s=0;return e.forEach(r=>{const o=r.getBoundingClientRect();o.width>n&&(n=o.width),o.height>s&&(s=o.height)}),{maxWidth:n,maxHeight:s}}function Xr(t,e,n){const s=e.getBoundingClientRect(),r=5;return t.filter(o=>{const i=o.getBoundingClientRect();return n==="vertical"?Math.abs(i.top-s.top)<=r:Math.abs(i.left-s.left)<=r})}function qu(t,e,n,s,r){var R,O;const o=t.getBoundingClientRect(),i=window.getComputedStyle(t),l=((R=r.defaultView)==null?void 0:R.scrollY)||0,c=((O=r.defaultView)==null?void 0:O.scrollX)||0,u=parseFloat(i.marginTop)||0,p=parseFloat(i.marginBottom)||0,f=parseFloat(i.marginLeft)||0,m=parseFloat(i.marginRight)||0,h=parseFloat(i.paddingTop)||0,x=parseFloat(i.paddingBottom)||0,b=parseFloat(i.paddingLeft)||0,y=parseFloat(i.paddingRight)||0,v=e==null?void 0:e.getBoundingClientRect(),w=e&&parseFloat(window.getComputedStyle(e).paddingLeft)||0,I=e&&parseFloat(window.getComputedStyle(e).paddingRight)||0,N=e&&parseFloat(window.getComputedStyle(e).paddingTop)||0,E=e&&parseFloat(window.getComputedStyle(e).paddingBottom)||0,_=e?xi(e):{maxHeight:0},S=e?Mt(e):"vertical",A=e?gt(e):[],C=Xr(A,t,S);let T=0,P=0;if(C.forEach(H=>{const G=H.getBoundingClientRect();G.height>T&&(T=G.height),G.width>P&&(P=G.width)}),n==="before")if(s==="horizontal"){const H=v?v.width-w-I:o.width,G=v?v.left+c+w:o.left+c;return{top:o.top+l-u-2,left:G,width:H,height:4}}else{const H=o.top+l,G=S==="horizontal"&&T>0?T:_.maxHeight>0?_.maxHeight:v?v.height-N-E:o.height;return{top:H,left:o.left+c-f-2,width:4,height:G}}else if(n==="after")if(s==="horizontal"){const H=v?v.width-w-I:o.width,G=v?v.left+c+w:o.left+c;return{top:o.bottom+l+p-2,left:G,width:H,height:4}}else{const H=o.top+l,G=S==="horizontal"&&T>0?T:_.maxHeight>0?_.maxHeight:v?v.height-N-E:o.height;return{top:H,left:o.right+c+m-2,width:4,height:G}}else return Xn(t)?Mt(t)==="vertical"?{top:o.bottom+l-x-2,left:o.left+c+b,width:o.width-b-y,height:4}:{top:o.top+l+h,left:o.right+c-y-2,width:4,height:o.height-h-x}:{top:o.top+l+h,left:o.left+c+b,width:o.width-b-y,height:Math.max(o.height-h-x,20)}}const Ku=100,xt=()=>{const[t]=Z(),[,e]=U(),{addBlocks:n}=Ee(),s=g.useCallback((o,i,l)=>{for(let m=0;m<o.length;m++){const{_id:h}=o[m];o[m]._id=ke.generateUUID();const x=d.filter(o,{_parent:h});for(let b=0;b<x.length;b++)x[b]._parent=o[m]._id}const c=d.first(o);let u,p;return i&&(u=d.find(t,{_id:i}),o[0]._parent=i,d.forEach(o,m=>{m!=null&&m._parent||(m._parent=i)}),p=i),!(u?et(u==null?void 0:u._type,c._type):!0)&&u&&(o[0]._parent=u._parent,p=u._parent),n(o,p??void 0,l),e([c._id]),c},[n,t,e]);return{addCoreBlock:g.useCallback((o,i,l)=>{if(d.has(o,"blocks")){const b=o.blocks;return s(b,i??void 0,l)}const c=ke.generateUUID(),u=K.getDefaultBlockProps(o.type),p={_type:o.type,_id:c,...u,...d.has(o,"_name")&&{_name:o._name},...d.has(o,"partialBlockId")&&{partialBlockId:o.partialBlockId}};let f,m;return i&&(f=d.find(t,{_id:i}),p._parent=i,m=i),!et(f==null?void 0:f._type,p._type)&&f&&(p._parent=f._parent,m=f._parent),n([p],m??void 0,l),setTimeout(()=>e([p._id]),Ku),p},[n,s,t,e]),addPredefinedBlock:s}};let at=null;const rt=()=>{const[t]=j.useAtom(Es),e=g.useMemo(()=>{var r;return(t==null?void 0:t.contentDocument)||((r=t==null?void 0:t.contentWindow)==null?void 0:r.document)},[t]),n=g.useCallback(r=>{if(e)if(at&&at.removeAttribute("data-highlighted"),typeof r!="string")r.setAttribute("data-highlighted","true"),at=r;else if(typeof r=="string"){const o=e.querySelector(`[data-block-id="${r}"]`);o&&(o.setAttribute("data-highlighted","true"),at=o)}else at=null},[e]),s=g.useCallback(()=>{at&&(at.removeAttribute("data-highlighted"),at=null)},[]);return{highlightBlock:n,clearHighlight:s,lastHighlighted:at}},rs=4,Yu=()=>{const[t]=j.useAtom(Cs);return g.useMemo(()=>{const e={};return Object.entries(t).forEach(([n,s])=>{e[n]=s.dependencies}),e},[t])},bi=()=>{const t=$("pageId",""),e=Yu();return g.useCallback(n=>{if(!t)return{canAdd:!0};if(t===n)return{canAdd:!1,reason:"Cannot add a partial inside itself"};if(li(t,n,e))return{canAdd:!1,reason:"Adding this partial would create a circular reference"};const s=ur(t,e),r=ur(n,e);return Math.max(s,1+r)>rs?{canAdd:!1,reason:`Maximum nesting depth (${rs} levels) would be exceeded`}:{canAdd:!0}},[t,e])},yi=()=>{const[t,e]=g.useState(!1),[n,s]=g.useState(null),[r,o]=j.useAtom(Xd),i=$("getPartialBlocks",async()=>({})),l=g.useCallback(async()=>{e(!0),s(null);try{const c=await i();o(c),e(!1)}catch(c){s(c instanceof Error?c.message:"Failed to fetch partial blocks"),e(!1)}},[i,o]);return g.useEffect(()=>{l()},[]),{data:r,isLoading:t,refetch:l,error:n}},As=()=>{const[t,e]=j.useAtom(Cs),n=g.useCallback(r=>d.get(t,`${r}.blocks`,[]),[t]),s=g.useCallback(()=>e({}),[e]);return{getPartialBlocks:n,reset:s}},Xu=()=>{const[t]=Z(),[e,n]=j.useAtom(Cs),s=$("getPartialBlockBlocks",async c=>[]),r=g.useRef(new Set),o=g.useMemo(()=>t.filter(c=>c._type==="PartialBlock"||c._type==="GlobalBlock").map(c=>d.get(c,"partialBlockId",d.get(c,"globalBlock",""))).filter(Boolean),[t]),i=g.useMemo(()=>{const c=[];return Object.values(e).forEach(u=>{u.status==="loaded"&&c.push(...u.dependencies)}),c},[e]),l=g.useMemo(()=>[...new Set([...o,...i])],[o,i]);g.useEffect(()=>{const c=l.filter(u=>{const p=e[u],f=r.current.has(u);return(!p||p.status==="idle")&&!f});c.length!==0&&(c.forEach(u=>r.current.add(u)),n(u=>{const p={};return c.forEach(f=>{p[f]={blocks:[],dependencies:[],status:"loading"}}),{...u,...p}}),Promise.all(c.map(async u=>{try{const p=await s(u),f=ii(p);n(m=>({...m,[u]:{blocks:p,dependencies:f,status:"loaded"}}))}catch(p){n(f=>({...f,[u]:{blocks:[],dependencies:[],status:"error",error:p instanceof Error?p.message:"Failed to fetch"}}))}finally{r.current.delete(u)}})))},[l,e,n,s])},Rn=j.atom([]);Rn.debugLabel="selectedStylingBlocksAtom";const Ae=()=>j.useAtom(Rn),Ju=()=>{const[t,e]=j.useAtom(Ns),[n,s]=j.useAtom(Bn),[r]=Z(),[o]=rn(),{addCoreBlock:i}=xt(),{moveBlocks:l}=Ee(),[,c]=U(),[,u]=Ae(),{clearHighlight:p}=rt(),{clearParentHighlight:f}=Yr(),[m,h]=j.useAtom(Gr),x=st(),b=bi(),y=o==null?void 0:o.contentDocument;return g.useCallback(v=>{if(v.preventDefault(),v.stopPropagation(),Wr(!1),Qu(y),Zo(y),f(),s({isVisible:!1,isValid:!1,position:"inside",placeholderOrientation:"horizontal",isEmpty:!1,top:0,left:0,width:0,height:0}),setTimeout(()=>{f(),Zo(y),s({isVisible:!1,isValid:!1,position:"inside",placeholderOrientation:"horizontal",isEmpty:!1,top:0,left:0,width:0,height:0})},50),!t)return;if(!n.isValid||!n.targetBlockId){f();return}e(null);const w=n.targetBlockId,I=n.targetParentId;if(!w)return;const{parentId:N,index:E,replaceImageUrl:_}=Zu(r,w,I,n.position,t),S=t._id!==void 0;if(_&&ki(t)){x([w],{image:d.get(t,"blocks.0.image")}),setTimeout(()=>{h(m+1)},50);return}if(S)l([t._id],N===null?void 0:N,E),p(),u([]),c([t._id]);else{const A=t._type||t.type,C=t!=null&&t.blocks?d.isFunction(t==null?void 0:t.blocks)?K.syncBlocksWithDefaultProps(t==null?void 0:t.blocks()):t==null?void 0:t.blocks:null;if(A==="PartialBlock"){const T=t.partialBlockId||"",{canAdd:P,reason:R}=b(T);if(!P){ce.toast.error(R||"Cannot add this partial block");return}i({blocks:[{_type:A,_id:"partial-block",partialBlockId:t.partialBlockId}]},N,E)}else i((C==null?void 0:C.length)>0?{blocks:[...C]}:{type:A},N,E)}setTimeout(()=>{h(m+1)},50)},[t,n,r,y,i,l,e,s,f,p,c,u,m,h,x,b])},ki=t=>{var o,i;const e=d.has(t,"blocks"),n=t==null?void 0:t.blocks,s=(n==null?void 0:n.length)===1&&((o=n==null?void 0:n[0])==null?void 0:o._type)==="Image",r=!((i=n==null?void 0:n[0])!=null&&i._id);return e&&s&&r};function Zu(t,e,n,s,r){var o,i;try{if(e===n&&((o=r==null?void 0:r.blocks)==null?void 0:o.length)===1&&d.get(r,"blocks.0._type")==="Image"&&((i=d.find(t,{_id:e}))==null?void 0:i._type)==="Image")return{parentId:"",index:-1,replaceImageUrl:!0};if(e==="canvas"||s==="inside"&&e==="canvas")return{parentId:null,index:d.filter(t,h=>!(h!=null&&h._parent)).length};if(s==="inside"){const m=d.filter(t,{_parent:e});return{parentId:e,index:m.length}}const l=!n||n==="canvas",c=l?void 0:n,u=d.filter(t,m=>l?!(m!=null&&m._parent):(m==null?void 0:m._parent)===c),p=u.findIndex(m=>m._id===e);if(p===-1)return{parentId:l?null:n,index:u.length};const f=s==="before"?p:p+1;return{parentId:l?null:n,index:f}}catch{return{parentId:null,index:d.filter(t,c=>!(c!=null&&c._parent)).length}}}function Zo(t){if(!t)return;t.querySelectorAll("[data-drop-target]").forEach(n=>n.removeAttribute("data-drop-target"))}function Qu(t){if(!t)return;t.querySelectorAll("[data-dragging]").forEach(n=>{n.removeAttribute("data-dragging")})}function vi(t,e,n){if(!t||!e)return!1;if(t===e)return!0;const s=n.find(o=>o._id===t);if(!s)return!1;let r=s;for(;r._parent;){if(r._parent===e)return!0;const o=n.find(i=>i._id===r._parent);if(!o)break;r=o}return!1}function wi(t,e,n){return!t||!e?!0:!vi(e,t,n)}function ep(t,e,n){if(!t)return!0;const s=n.find(o=>o._id===e);if(!s)return!0;const r=s._parent;return wi(t,r,n)}const tp=["Heading","Text","Image","Paragraph","Icon","Input","Radio","Checkbox","Select","CustomHTML","TextArea","Divider","Repeater","Video"],ft={EDGE_ZONE:50,MAX_SCROLL_SPEED:10,MIN_SCROLL_SPEED:10},np=()=>{const[t]=j.useAtom(Ns),[e]=rn(),[,n]=j.useAtom(Bn),{clearParentHighlight:s,highlightParent:r}=Yr(),[o]=Z(),i=e==null?void 0:e.contentDocument,l=g.useRef(null),c=g.useRef(0),u=g.useCallback(f=>{if(!(i!=null&&i.defaultView))return;const m=i.defaultView,h=m.innerHeight,x=m.scrollY,b=i.documentElement.scrollHeight;c.current=f;const y=f,v=h-f;let w=!1,I=null,N=0;if(y<ft.EDGE_ZONE&&x>0?(w=!0,I="up",N=y):v<ft.EDGE_ZONE&&x+h<b&&(w=!0,I="down",N=v),!w&&l.current!==null){cancelAnimationFrame(l.current),l.current=null;return}if(w&&I){const E=1-N/ft.EDGE_ZONE,_=ft.MIN_SCROLL_SPEED+(ft.MAX_SCROLL_SPEED-ft.MIN_SCROLL_SPEED)*E,S=()=>{if(!qt||!m){l.current=null;return}const A=I==="up"?-_:_;m.scrollBy(0,A);const C=m.scrollY,T=C>0,P=C+h<b,R=c.current,O=h-c.current;I==="up"&&T&&R<ft.EDGE_ZONE||I==="down"&&P&&O<ft.EDGE_ZONE?l.current=requestAnimationFrame(S):l.current=null};l.current===null&&(l.current=requestAnimationFrame(S))}},[i]);g.useEffect(()=>()=>{l.current!==null&&(cancelAnimationFrame(l.current),l.current=null)},[]),g.useEffect(()=>{!qt&&l.current!==null&&(cancelAnimationFrame(l.current),l.current=null)},[qt]);const p=g.useCallback(d.throttle(f=>{if(!qt||!t)return;s();const m=sp(f),{element:h,targetBlockId:x,targetParentId:b}=m;if(!h||!x)return;const y=t._id;if(y&&(x===y||vi(x,y,o)))return;const v=t._type||t.type;if(!v)return;const w=f.clientX,I=f.clientY;if(u(I),!i)return;const N=Gu(h,w,I,v,i);if(!N)return;const E=h.getAttribute("data-block-type")||"Box";let _=!1;const S=tp.includes(E);if(E==="Image"&&v==="Image"&&ki(t)){r(x),n({isVisible:!0,isValid:!0,position:N.position,placeholderOrientation:N.placeholderOrientation,isEmpty:!0,top:h.offsetTop,left:N.rect.left,width:h.clientWidth,height:h.clientHeight,targetBlockId:N.targetBlockId,targetParentId:N.targetBlockId});return}if(N.position==="inside"){if(S||y&&!wi(y,x,o))return;_=et(E,v)}else{let C=h.parentElement,T="Box";for(;C&&!C.hasAttribute("data-block-id");)C=C.parentElement;if(C&&(T=C.getAttribute("data-block-type")||"Box"),y&&!ep(y,x,o))return;_=et(T,v)}if(!_)return;r(N.targetParentId);const A=N.targetParentId||b||void 0;n({isVisible:!0,isValid:!0,position:N.position,placeholderOrientation:N.placeholderOrientation,isEmpty:N.isEmpty??!1,top:N.rect.top,left:N.rect.left,width:N.rect.width,height:N.rect.height,targetBlockId:N.targetBlockId,targetParentId:A}),rp(i),N.targetElement.setAttribute("data-drop-target","true")},300),[i,t,n,s,r,o,u]);return g.useCallback(f=>{f.preventDefault(),f.stopPropagation(),p(f)},[p])};function sp(t){let e=t.target;for(;e&&!e.hasAttribute("data-block-id");)e=e.parentElement;if(!e)return{element:null,targetBlockId:null,targetBlockType:null,targetParentId:null,targetParentType:null,orientation:"vertical"};const n=e.getAttribute("data-block-id"),s=e.getAttribute("data-block-type")||"Box";let r=e.parentElement;for(;r&&!r.hasAttribute("data-block-id");)r=r.parentElement;const o=(r==null?void 0:r.getAttribute("data-block-id"))||null,i=(r==null?void 0:r.getAttribute("data-block-type"))||"Box",l=Mt(e);return{element:e,targetBlockId:n,targetBlockType:s,targetParentId:o,targetParentType:i,orientation:l}}function rp(t){if(!t)return;t.querySelectorAll("[data-drop-target]").forEach(n=>n.removeAttribute("data-drop-target"))}function op(t){var o;const e=document.createElement("div");e.className="absolute -top-[1000px] -left-[1000px] pl-3 pr-1 py-1 bg-white/60 border border-blue-400/30 rounded shadow-md flex items-center gap-1.5 font-sans pointer-events-none z-[9999] scale-90";const n=t.type||t._type||"Box",s=document.createElement("div");s.className="w-3 h-3 flex items-center justify-center text-blue-600";try{n==="Image"?s.innerHTML='<svg class="w-3 h-3" fill="currentColor" viewBox="0 0 0.72 0.72"><path d="M.57.12H.15a.09.09 0 0 0-.09.09v.3A.09.09 0 0 0 .15.6h.42A.09.09 0 0 0 .66.51v-.3A.09.09 0 0 0 .57.12M.15.54A.03.03 0 0 1 .12.51V.437L.219.338a.03.03 0 0 1 .042 0L.462.54ZM.6.51a.03.03 0 0 1-.03.03H.547L.433.425.459.399a.03.03 0 0 1 .042 0L.6.498Zm0-.097L.544.357a.09.09 0 0 0-.127 0L.391.383.305.297a.09.09 0 0 0-.127 0L.12.353V.21A.03.03 0 0 1 .15.18h.42A.03.03 0 0 1 .6.21Z"/></svg>':s.innerHTML=((o=document.querySelector(`[data-add-core-block-icon="${n}"]`))==null?void 0:o.outerHTML)||'<svg class="w-3 h-3" fill="currentColor" viewBox="0 0 20 20"><path d="M3 4a1 1 0 011-1h12a1 1 0 011 1v12a1 1 0 01-1 1H4a1 1 0 01-1-1V4z"/></svg>'}catch{s.textContent=""}const r=document.createElement("span");return r.className="text-[10px] font-medium text-blue-600 whitespace-nowrap",r.textContent=t.label||t.type||t._name||t._type||"Block",e.appendChild(s),e.appendChild(r),document.body.appendChild(e),e}function Qo(t){t&&t.parentNode&&t.parentNode.removeChild(t)}const ap=()=>{const[,t]=U(),[,e]=Ae(),{clearHighlight:n}=rt(),[,s]=j.useAtom(Ns),[,r]=j.useAtom(Bn),o=g.useRef(null);return g.useCallback((i,l,c=!0)=>{var p;o.current&&(Qo(o.current),o.current=null);const u=c?d.pick(l,["type","blocks","partialBlockId"]):l;if(s(u),i.dataTransfer.setData("text/plain",JSON.stringify({block:u})),i.dataTransfer.effectAllowed="move",!c&&l._id){const f=(p=document.getElementById("canvas-iframe"))==null?void 0:p.contentDocument;if(f){const m=f.querySelector(`[data-block-id="${l._id}"]`);m&&setTimeout(()=>{if(m){const x=m.getBoundingClientRect().height;Mt(m==null?void 0:m.parentElement)==="vertical"&&x>200&&(m.style.height="max-content",m.style.maxHeight="max-content",m.style.minHeight="0",m.style.overflow="hidden",m.innerHTML="<div class='flex items-center justify-center w-full h-full outline-[1px] outline-dashed font-medium outline-gray-500 bg-gray-500/10 py-4 text-transparent'>-</div>",m.style.opacity="0.4"),m.style.opacity="0.4",m.setAttribute("data-dragging","true")}},0)}}if(l!=null&&l._type||l!=null&&l.type){const f=op(l);o.current=f,i.dataTransfer.setDragImage(f,0,0),setTimeout(()=>{o.current&&(Qo(o.current),o.current=null)},50)}t([]),n(),e([]),re.publish(Y.CLOSE_ADD_BLOCK),Wr(!0),r({isVisible:!0,isValid:!0,position:"inside",placeholderOrientation:"horizontal",isEmpty:!0,top:0,left:0,width:0,height:0,targetBlockId:"canvas",targetParentId:void 0})},[t,n,s,r])},on=()=>{const t=ap(),e=np(),n=Ju(),s=Ou();return{onDragStart:t,onDragOver:e,onDrop:n,onDragEnd:s,isDragging:qt}},ip=()=>{const[t]=j.useAtom(Bn);return t},Ye=()=>{const{dragAndDrop:t}=$("flags",{dragAndDrop:!0});return t};let Ci,ji;typeof document<"u"&&(Ci=document);typeof window<"u"&&(ji=window);const Si=g.createContext({document:Ci,window:ji}),Xe=()=>g.useContext(Si),{Provider:lp,Consumer:u0}=Si,cp=[{ControlIcon:k.PinTopIcon,dir:"VERTICAL",key:"UP"},{ControlIcon:k.PinBottomIcon,dir:"VERTICAL",key:"DOWN"},{ControlIcon:k.PinLeftIcon,dir:"HORIZONTAL",key:"LEFT"},{ControlIcon:k.PinRightIcon,dir:"HORIZONTAL",key:"RIGHT"}],dp=(t,e,n)=>{try{if(!t||!n)return"VERTICAL";const s=`[data-block-id='${t}']`,r=n==null?void 0:n.querySelector(s);if(r){const o=n==null?void 0:n.querySelector(`[data-block-id='${e}']`);return Mt(r,o).toUpperCase()}return"VERTICAL"}catch{return"VERTICAL"}},Ni=(t,e,n)=>!!(t&&(n==="UP"||n==="LEFT")||e&&(n==="DOWN"||n==="RIGHT")),up=(t,e)=>{const[n]=Z(),{document:s}=Xe(),{moveBlocks:r}=Ee(),o=d.get(t,"_id"),i=d.get(t,"_parent"),l=d.filter(n,x=>i?d.get(x,"_parent")===i:!d.get(x,"_parent")),c=(l==null?void 0:l.length)<=1,u=d.findIndex(l,{_id:o}),p=u<=0,f=u+1===(l==null?void 0:l.length),m=dp(i,o,s),h=g.useCallback(x=>{Ni(p,f,x)||c||(x==="UP"||x==="LEFT"?r([o],i||void 0,u-1):(x==="DOWN"||x==="RIGHT")&&r([o],i||void 0,u+2),e())},[p,f,c,u,o,i,e]);return Je.useHotkeys("shift+up, shift+down, shift+left, shift+right",({key:x})=>{var b;h((b=x==null?void 0:x.replace("Arrow",""))==null?void 0:b.toUpperCase())},{document:s},[h]),{isOnlyChild:c,isFirstBlock:p,isLastBlock:f,moveBlock:h,orientation:m}},pp=({block:t,updateFloatingBar:e})=>{const{isOnlyChild:n,isFirstBlock:s,isLastBlock:r,moveBlock:o,orientation:i}=up(t,e);return n?null:a.jsx(a.Fragment,{children:cp.map(({ControlIcon:l,dir:c,key:u})=>i!==c||Ni(s,r,u)?null:a.jsx(l,{onClick:()=>o(u),className:"rounded p-px hover:bg-white hover:text-blue-500"},u))})},Jr=()=>{const[t]=Z(),[,e]=U(),{addBlocks:n}=Ee();return g.useCallback((s,r=null)=>{const o=[];d.each(s,i=>{const l=t.find(m=>m._id===i);r?r==="root"&&(r=null):r=(l==null?void 0:l._parent)??null;const p=d.filter(t,m=>d.isString(r)?m._parent===r:!m._parent).indexOf(l)+1,f=dr(t,i,r);n(f,r??void 0,p),o.push(d.get(f,"0._id",""))}),e(o)},[t,e])},fp=j.atom(""),Ei=()=>j.useAtom(fp),Ai=j.atom("");Ai.debugLabel="inlineEditingActiveAtom";const Ii=j.atom(0);Ii.debugLabel="inlineEditingItemIndexAtom";const Ft=()=>{const[t,e]=j.useAtom(Ai),[n,s]=j.useAtom(Ii);return{editingBlockId:t,editingItemIndex:n,setEditingBlockId:e,setEditingItemIndex:s}},_i=j.atom("outline");_i.debugLabel="sidebarActivePanelAtom";const Is=()=>j.useAtom(_i),hp=({blockId:t,className:e})=>{const n=()=>{t&&re.publish(Y.GOTO_BLOCK_SETTINGS,t)};return a.jsx(k.GearIcon,{className:e,onClick:n})},mp=j.atom(0),Ti=j.atom(0);function Zr(t){if(t.getAttribute("data-block-id")==="canvas")return null;if(t.getAttribute("data-block-id")||t.getAttribute("data-block-parent"))return t;const e=t.closest("[data-block-id]");return(e==null?void 0:e.getAttribute("data-block-id"))==="canvas"?null:e}const gp=["Heading","Paragraph","Text","Link","Span","Button"],xp=t=>{var e;return(t==null?void 0:t.getAttribute("data-block-type"))==="RichText"||((e=t==null?void 0:t.parentElement)==null?void 0:e.getAttribute("data-block-type"))==="RichText"},Bi=t=>t?d.some(t.children,e=>{const n=e;return n.hasAttribute("data-block-id")||Bi(n)}):!1,bp=(t,e)=>{if(xp(t))return!0;const n=t==null?void 0:t.getAttribute("data-block-type");return n?gp.includes(n):!1},yp=()=>{const{editingBlockId:t,setEditingBlockId:e,setEditingItemIndex:n}=Ft();return g.useCallback(s=>{var l;if(s==null||s.preventDefault(),s==null||s.stopPropagation(),t)return;const r=Zr(s.target);if(!r||!bp(r)||Bi(r))return;const o=r.getAttribute("data-block-id");if(!o)return;const i=r.closest('[data-block-type="Repeater"]');i?(l=i==null?void 0:i.childNodes)==null||l.forEach((c,u)=>{c.contains(r)&&n(u)}):n(-1),e(o)},[t,e,n])},kp=()=>{const{editingBlockId:t}=Ft(),{clearHighlight:e}=rt(),[,n]=Ae(),[s]=j.useAtom(Ti);return g.useCallback(r=>{if(t)return;r.stopPropagation();const o=Zr(r.target);if(!o){e(),n([]),re.publish(Y.CANVAS_BLOCK_SELECTED,[]);return}if(s!==2){if(o!=null&&o.getAttribute("data-block-id")&&(o==null?void 0:o.getAttribute("data-block-id"))==="container"){re.publish(Y.CLEAR_CANVAS_SELECTION);return}if(o!=null&&o.getAttribute("data-block-parent")){const i=o.getAttribute("data-style-prop"),l=o.getAttribute("data-style-id"),c=o.getAttribute("data-block-parent");re.publish(Y.CANVAS_BLOCK_STYLE_SELECTED,{blockId:c,styleId:l,styleProp:i})}else if(o!=null&&o.getAttribute("data-block-id")){const i=o.getAttribute("data-block-id");re.publish(Y.CANVAS_BLOCK_SELECTED,i==="canvas"?[]:[i])}e()}},[t,s,e,n])},vp=()=>{const{editingBlockId:t}=Ft(),{highlightBlock:e}=rt();return ve.useThrottledCallback(n=>{if(t)return;const s=Zr(n.target);s&&e(s)},[t,e],100)},wp=()=>{const{clearHighlight:t}=rt();return g.useCallback(()=>t(),[t])},Cp=({children:t})=>{const e=yp(),n=kp(),s=vp(),r=wp();return a.jsx("div",{"data-block-id":"canvas",id:"canvas",onClick:n,onDoubleClick:e,onMouseMove:s,onMouseLeave:r,className:"relative h-full max-w-full p-px",children:t})},Ri=(t,e)=>t.querySelector(`[data-block-id="${e}"]`),jp=(t,e)=>t.querySelector(`[data-style-id="${e}"]`),Sp=()=>{const t=J(),{document:e}=Xe(),[n]=Ae(),[s,r]=g.useState([]),[,o]=g.useState([]),{onDragStart:i,onDragEnd:l,isDragging:c}=on(),[u,p]=g.useState(null),f=Ye(),m=(h,x=0)=>{const{top:b}=h.getBoundingClientRect();return b+x>=0&&b-x<=window.innerHeight};return g.useEffect(()=>{var h;if(t!=null&&t._id&&t.type!=="Multiple"&&e){const x=Ri(e,t._id);x&&(m(x)||(h=e.defaultView)==null||h.scrollTo({top:x.offsetTop,behavior:"smooth"}),r([x]))}},[t==null?void 0:t._id,t==null?void 0:t.type,e]),g.useEffect(()=>{if(!d.isEmpty(n)&&e){const h=jp(e,d.first(n).id);o(h?[h]:[null])}else o([null])},[n,e]),a.jsx("div",{onDragEnd:()=>{p(null),l()},draggable:f&&!!t,onDragStart:h=>{p(s==null?void 0:s[0]),i(h,t,!1)},children:t&&a.jsx(Np,{block:t,isDragging:c&&!!u,selectedBlockElement:s[0]||(c?u:null)})})},Np=({block:t,isDragging:e,selectedBlockElement:n})=>{const s=Ss(),r=Jr(),[,o]=U(),[,i]=Ei(),[,l]=Ae(),{hasPermission:c}=Ve(),{editingBlockId:u}=Ft(),{document:p}=Xe(),f=Ye(),m=$("flags.gotoSettings",!1),h=$("flags.ai",!1),{floatingStyles:x,refs:b,update:y}=Yo.useFloating({placement:"top-start",middleware:[Yo.shift({boundary:p==null?void 0:p.body,limiter:Us.limitShift({offset:8,mainAxis:!0,crossAxis:!0})}),Us.flip({boundary:p==null?void 0:p.body,fallbackPlacements:["bottom-start","top-end","bottom-end","inside"]}),Us.size({boundary:p==null?void 0:p.body,apply({availableWidth:N,availableHeight:E,elements:_}){Object.assign(_.floating.style,{maxWidth:`${Math.max(200,N)}px`,maxHeight:`${Math.max(100,E)}px`})}})],elements:{reference:n}});ve.useResizeObserver(n,()=>y(),n!==null),ve.useResizeObserver(p==null?void 0:p.body,()=>y(),(p==null?void 0:p.body)!==null);const v=d.get(t,"_parent",null),w=d.isEmpty(d.get(t,"_name",""))?d.get(t,"_type",""):d.get(t,"_name","");g.useEffect(()=>{let N=null;return n?(N=setTimeout(()=>y(),500),()=>{N&&clearTimeout(N)}):(y(),()=>{N&&clearTimeout(N)})},[n,t==null?void 0:t._id]);const[,I]=Is();return!e&&(!n||!t||u)?null:a.jsx(a.Fragment,{children:a.jsx("div",{role:"button",tabIndex:0,ref:b.setFloating,style:x,onClick:N=>{N.stopPropagation(),N.preventDefault()},onMouseEnter:N=>{N.stopPropagation(),i(null)},onKeyDown:N=>N.stopPropagation(),className:`isolate z-[999] flex h-6 items-center justify-between bg-blue-500 py-2 text-xs text-white ${e?"opacity-0":""}`,children:a.jsxs(a.Fragment,{children:[a.jsxs("div",{className:"flex items-center",children:[f&&a.jsx(k.DragHandleDots2Icon,{className:"flex-shrink-0 cursor-grab rounded p-0.5 hover:bg-white/20 active:cursor-grabbing"}),v&&a.jsx(k.ArrowUpIcon,{className:"flex-shrink-0 rounded p-0.5 hover:bg-white/20",onClick:()=>{l([]),o([v])}})]}),a.jsx("div",{className:`w-full ${f?"cursor-grab active:cursor-grabbing":""}`,children:a.jsx("div",{className:"mr-10 w-full items-center space-x-1 px-1 leading-tight",children:w})}),a.jsxs("div",{className:"flex items-center gap-1 pl-1 pr-1.5",children:[c(Q.ADD_BLOCK)&&h&&a.jsx(Er,{className:"h-4 w-4 rounded hover:bg-white hover:text-blue-500",onClick:()=>{I("chai-chat-panel"),re.publish(Y.OPEN_AI_PANEL)}}),m&&a.jsx(hp,{blockId:t==null?void 0:t._id,className:"h-4 w-4 rounded p-px hover:bg-white hover:text-blue-500"}),!f&&a.jsx(Su,{block:t,children:a.jsx(k.PlusIcon,{className:"h-4 w-4 rounded p-px hover:bg-white hover:text-blue-500"})}),Ir(d.get(t,"_type",""))&&c(Q.ADD_BLOCK)?a.jsx(k.CopyIcon,{className:"h-4 w-4 rounded p-px hover:bg-white hover:text-blue-500",onClick:()=>r([t==null?void 0:t._id])}):null,_r(d.get(t,"_type",""))&&c(Q.DELETE_BLOCK)?a.jsx(k.TrashIcon,{className:"h-4 w-4 rounded p-px hover:bg-white hover:text-blue-500",onClick:()=>s([t==null?void 0:t._id])}):null,c(Q.MOVE_BLOCK)&&a.jsx(pp,{block:t,updateFloatingBar:y})]})]})})})},Pi=`<!doctype html>
|
|
2
|
+
<html lang="en" dir="__HTML_DIR__" class="scroll-smooth h-full overflow-y-auto">
|
|
3
|
+
<head>
|
|
4
|
+
<meta charset="UTF-8">
|
|
5
|
+
<meta name="viewport" content="width=device-width, initial-scale=1.0">
|
|
6
|
+
<script src="https://cdn.tailwindcss.com/3.4.17?plugins=forms@0.5.9,typography@0.5.15,aspect-ratio@0.4.2"><\/script>
|
|
7
|
+
<style>
|
|
8
|
+
html { height: 100%; overflow:auto; }
|
|
9
|
+
body { height: 100%; }
|
|
10
|
+
.air-highlight{ outline: 1px solid #42a1fc !important; outline-offset: -1px;}
|
|
11
|
+
.air-highlight-multi{ outline: 1px solid #29e503 !important; outline-offset: -1px;}
|
|
12
|
+
body{ -webkit-touch-callout: none; -webkit-user-select: none; -khtml-user-select: none;
|
|
13
|
+
-moz-user-select: none;-ms-user-select: none; user-select: none; }
|
|
14
|
+
html{
|
|
15
|
+
-ms-overflow-style: none; /* IE and Edge */
|
|
16
|
+
scrollbar-width: none; /* Firefox */
|
|
17
|
+
}
|
|
18
|
+
/** IMPORTANT: Make fields content editable in SAFARI */
|
|
19
|
+
[contenteditable] {-webkit-user-select: text;user-select: text;}
|
|
20
|
+
|
|
21
|
+
html::-webkit-scrollbar { width: 0 !important }
|
|
22
|
+
.aspect-auto{aspect-ratio: auto;}
|
|
23
|
+
.aspect-square{aspect-ratio: 1/1;}
|
|
24
|
+
.aspect-video{aspect-ratio: 16/9;}
|
|
25
|
+
.dragging [data-dnd="leaf"] { pointer-events: none; } .dragging [data-dnd="leaf"] * { pointer-events: none; }
|
|
26
|
+
.dragging [data-dnd="ignore"], .dragging [data-dnd="ignore"] * { pointer-events: none; }
|
|
27
|
+
a{ pointer-events: none !important; }
|
|
28
|
+
[contenteditable="true"], [contenteditable="true"] * { cursor: text !important; }
|
|
29
|
+
[contenteditable="true"] {
|
|
30
|
+
outline: none;
|
|
31
|
+
box-shadow: 0 0 0px 4px rgba(36, 150, 255, 0.2);
|
|
32
|
+
-webkit-user-select: text;
|
|
33
|
+
-moz-user-select: text;
|
|
34
|
+
user-select: text;
|
|
35
|
+
}
|
|
36
|
+
.frame-root .frame-content { height: 100%; }
|
|
37
|
+
[data-drop="yes"] { outline: 2px dashed orange !important; outline-offset: -2px }
|
|
38
|
+
[data-dnd="yes"] { pointer-events: auto !important}
|
|
39
|
+
[data-dnd="no"],[data-block-type="GlobalBlock"],[data-block-type="PartialBlock"] > * { pointer-events: none !important; }
|
|
40
|
+
[data-block-type="GlobalBlock"],[data-block-type="PartialBlock"] { position: relative !important; }
|
|
41
|
+
.partial-overlay { pointer-events: auto !important; }
|
|
42
|
+
[data-dnd-dragged="yes"] { opacity: 0.6; pointer-events: none; }
|
|
43
|
+
[data-dnd-dragged="no"] { opacity: 1; pointer-events: auto !important; }
|
|
44
|
+
[force-show] { display: block !important; }
|
|
45
|
+
[data-cut-block="yes"] { pointer-events: none !important; display: none !important; }
|
|
46
|
+
</style>
|
|
47
|
+
<style id="highlighted-block">
|
|
48
|
+
[data-highlighted]{
|
|
49
|
+
outline: 1px solid #42a1fc !important; outline-offset: -1px;
|
|
50
|
+
}
|
|
51
|
+
</style>
|
|
52
|
+
<style>
|
|
53
|
+
.react-colorful {
|
|
54
|
+
height: 120px !important;
|
|
55
|
+
width: 180px !important;
|
|
56
|
+
}
|
|
57
|
+
.react-colorful > div {
|
|
58
|
+
margin-bottom: 4px;
|
|
59
|
+
}
|
|
60
|
+
.react-colorful__saturation {
|
|
61
|
+
border-radius: 4px !important;
|
|
62
|
+
}
|
|
63
|
+
.react-colorful__hue,
|
|
64
|
+
.react-colorful__alpha {
|
|
65
|
+
height: 12px !important;
|
|
66
|
+
border-radius: 4px !important;
|
|
67
|
+
}
|
|
68
|
+
.react-colorful__pointer {
|
|
69
|
+
width: 16px !important;
|
|
70
|
+
height: 16px !important;
|
|
71
|
+
border: 1.5px solid #fff !important;
|
|
72
|
+
cursor: pointer !important;
|
|
73
|
+
z-index: 10002 !important;
|
|
74
|
+
}
|
|
75
|
+
#active-inline-editing-element{outline: 2px solid #00c951;}
|
|
76
|
+
</style>
|
|
77
|
+
<style type="text/tailwindcss">
|
|
78
|
+
@layer utilities {
|
|
79
|
+
.rte {
|
|
80
|
+
h1 {
|
|
81
|
+
@apply text-2xl;
|
|
82
|
+
}
|
|
83
|
+
h2 {
|
|
84
|
+
@apply text-xl;
|
|
85
|
+
}
|
|
86
|
+
h3 {
|
|
87
|
+
@apply text-lg;
|
|
88
|
+
}
|
|
89
|
+
h4 {
|
|
90
|
+
@apply text-base;
|
|
91
|
+
}
|
|
92
|
+
h5 {
|
|
93
|
+
@apply text-sm;
|
|
94
|
+
}
|
|
95
|
+
h6 {
|
|
96
|
+
@apply text-xs;
|
|
97
|
+
}
|
|
98
|
+
p {
|
|
99
|
+
&:empty {
|
|
100
|
+
@apply h-4;
|
|
101
|
+
}
|
|
102
|
+
}
|
|
103
|
+
ul {
|
|
104
|
+
@apply list-disc pl-6 text-base;
|
|
105
|
+
}
|
|
106
|
+
ol {
|
|
107
|
+
@apply list-decimal pl-6 text-base;
|
|
108
|
+
}
|
|
109
|
+
li > p {
|
|
110
|
+
@apply m-0;
|
|
111
|
+
}
|
|
112
|
+
blockquote {
|
|
113
|
+
@apply pl-4 text-base;
|
|
114
|
+
p {
|
|
115
|
+
@apply pl-4 text-base;
|
|
116
|
+
}
|
|
117
|
+
}
|
|
118
|
+
}
|
|
119
|
+
}
|
|
120
|
+
</style>
|
|
121
|
+
</head>
|
|
122
|
+
<body class="font-body antialiased h-full">
|
|
123
|
+
<div class="frame-root h-full"></div>
|
|
124
|
+
</body>
|
|
125
|
+
</html>`;class Ep extends g.Component{componentDidMount(){this.props.contentDidMount()}componentDidUpdate(){this.props.contentDidUpdate()}render(){return g.Children.only(this.props.children)}}class Li extends g.Component{constructor(n,s){super(n,s);wt(this,"setRef",n=>{this.nodeRef.current=n;const{forwardedRef:s}=this.props;typeof s=="function"?s(n):s&&(s.current=n)});wt(this,"handleLoad",()=>{clearInterval(this.loadCheck),this.state.iframeLoaded||this.setState({iframeLoaded:!0})});wt(this,"loadCheck",()=>setInterval(()=>{this.handleLoad()},500));this._isMounted=!1,this.nodeRef=g.createRef(),this.state={iframeLoaded:!1}}componentDidMount(){this._isMounted=!0,this.getDoc()&&this.nodeRef.current.contentWindow.addEventListener("DOMContentLoaded",this.handleLoad)}componentWillUnmount(){this._isMounted=!1,this.nodeRef.current.removeEventListener("DOMContentLoaded",this.handleLoad)}getDoc(){return this.nodeRef.current?this.nodeRef.current.contentDocument:null}getMountTarget(){const n=this.getDoc();return this.props.mountTarget?n.querySelector(this.props.mountTarget):n.body.children[0]}renderFrameContents(){if(!this._isMounted)return null;const n=this.getDoc();if(!n)return null;const s=this.props.contentDidMount,r=this.props.contentDidUpdate,o=n.defaultView||n.parentView,i=a.jsx(Ep,{contentDidMount:s,contentDidUpdate:r,children:a.jsx(lp,{value:{document:n,window:o},children:a.jsx("div",{className:"frame-content",children:this.props.children})})}),l=this.getMountTarget();return[lr.createPortal(this.props.head,this.getDoc().head),lr.createPortal(i,l)]}render(){const n={...this.props,srcDoc:this.props.initialContent,children:void 0};return delete n.head,delete n.initialContent,delete n.mountTarget,delete n.contentDidMount,delete n.contentDidUpdate,delete n.forwardedRef,a.jsx("iframe",{...n,ref:this.setRef,onLoad:this.handleLoad,children:this.state.iframeLoaded&&this.renderFrameContents()})}}wt(Li,"defaultProps",{style:{},head:null,children:void 0,mountTarget:void 0,contentDidMount:()=>{},contentDidUpdate:()=>{},initialContent:'<!DOCTYPE html><html><head></head><body><div class="frame-root"></div></body></html>'});const Mi=g.forwardRef((t,e)=>a.jsx(Li,{...t,forwardedRef:e})),Di=j.atom([]),_s=()=>{const[t,e]=j.useAtom(Di),n=j.useSetAtom(Oi),s=g.useCallback(r=>{e(r),n([])},[e,n]);return[t,s]},Oi=j.atom([]),$i=()=>{const[t]=Z(),[e,n]=j.useAtom(Oi),s=j.useSetAtom(Di),{getPartialBlocks:r}=As(),o=$("flags.copyPaste",!0),i=g.useCallback(c=>c.some(u=>dr(t,u,null).some(f=>f._type==="PartialBlock"||f._type==="GlobalBlock")),[t]),l=g.useCallback(async(c,u=!1)=>{try{if(d.isEmpty(c))return;n(c),s([]);const p={_chai_copied_blocks:c.flatMap(f=>{const m=dr(t,f,null);if(!u)return m;let h=[];for(const x of m)if(x._type==="PartialBlock"||x._type==="GlobalBlock"){let b=r(x.partialBlockId);x._parent&&(b==null?void 0:b.length)>0&&(b=b.map(y=>(d.isEmpty(y._parent)&&d.set(y,"_parent",x._parent),y))),h=[...h,...b]}else h.push(x);return h})};if(!o)return;if(!navigator.clipboard){ce.toast.error("Clipboard not available.");return}ce.toast.promise(navigator.clipboard.writeText(JSON.stringify(p)),{success:"Blocks copied successfully",error:"Failed to copy blocks to clipboard"})}catch(p){ce.toast.error("Failed to copy blocks to clipboard"),console.error("Failed to copy blocks to clipboard:",p)}},[n,s,t]);return[e,l,i]},Ys=()=>navigator.userAgent.toLowerCase().includes("firefox"),Ap=()=>{const[t]=Z();return(e,n)=>{var o;const s=((o=d.find(t,{_id:n}))==null?void 0:o._type)||null,r=d.first(e.map(i=>{var l;return(l=d.find(t,{_id:i}))==null?void 0:l._type}));return et(s,r)}},Ip=()=>{const t=j.useAtomValue(Se),{moveBlocks:e}=Ee();return g.useCallback((n,s)=>{const r=Array.isArray(s)?s[0]:s;if(s==="root"){const o=t==null?void 0:t.filter(i=>!i._parent);e(n,void 0,(o==null?void 0:o.length)||0)}else{const o=t==null?void 0:t.filter(i=>i._parent===r);e(n,r,(o==null?void 0:o.length)||0)}},[e,t])},Qr=()=>{const[t,e]=_s(),n=Ip(),{addPredefinedBlock:s}=xt(),r=Ap();return{canPaste:g.useCallback(async i=>{if(t.length>0)return r(t,i);if(Ys())return!1;try{const l=await navigator.clipboard.readText();if(l){const c=JSON.parse(l);return d.has(c,"_chai_copied_blocks")}}catch{return!1}return!1},[r,t]),pasteBlocks:g.useCallback(async i=>{const l=Array.isArray(i)?i[0]:i;if(!d.isEmpty(t)){n(t,i),e([]),Ys()||await navigator.clipboard.writeText("");return}if(Ys()){ce.toast.error("Paste is not supported in Firefox");return}if(!(navigator!=null&&navigator.permissions)){ce.toast.error("Cannot check clipboard permissions.");return}try{if((await navigator.permissions.query({name:"clipboard-read"})).state==="denied"){ce.toast.error("Clipboard paste permission denied. Please allow clipboard access.");return}}catch{ce.toast.error("Failed to check clipboard permissions. Please allow clipboard access.");return}ce.toast.promise(async()=>{const c=await navigator.clipboard.readText();if(c){const u=JSON.parse(c);if(d.has(u,"_chai_copied_blocks"))s(u._chai_copied_blocks,l==="root"?null:l);else throw new Error("Nothing to paste")}else throw new Error("Nothing to paste")},{success:()=>"Blocks pasted successfully",error:()=>"Nothing to paste"})},[t,n,e,s])}},Fi=t=>{const[e,n]=U(),s=J(),r=Ss(),o=Jr(),{undo:i,redo:l}=Tn(),[,c]=_s(),[,u]=$i(),{canPaste:p,pasteBlocks:f}=Qr(),m=t?{document:t}:{};Je.useHotkeys("ctrl+z,meta+z",h=>{h.preventDefault(),Ke.hasUndo()&&i()},{...m,preventDefault:!0},[i]),Je.useHotkeys("ctrl+y,meta+y",h=>{h.preventDefault(),Ke.hasRedo()&&l()},{...m,preventDefault:!0},[l]),Je.useHotkeys("ctrl+x,meta+x",h=>{const x=window.getSelection();x&&x.toString().length>0||(h.preventDefault(),d.isEmpty(e)||c(e))},{...m,enabled:!d.isEmpty(e)},[e,c]),Je.useHotkeys("ctrl+c,meta+c",h=>{const x=window.getSelection();x&&x.toString().length>0||(h.preventDefault(),u(e))},{...m,enabled:!d.isEmpty(e)},[e,u]),Je.useHotkeys("ctrl+v,meta+v",async()=>{await p(e[0])&&f(e)},{...m,enabled:!d.isEmpty(e),preventDefault:!0},[e,p,f]),Je.useHotkeys("esc",()=>n([]),m,[n]),Je.useHotkeys("ctrl+d,meta+d",()=>o(e),{...m,enabled:!d.isEmpty(e),preventDefault:!0},[e,o]),Je.useHotkeys("del, backspace",h=>{h.preventDefault(),_r(d.get(s,"_type",""))&&r(e)},m,[e,r])},_p=()=>{const{document:t}=Xe();return Fi(t),null},Tp=()=>{const{t}=F.useTranslation(),{hasPermission:e}=Ve(),n=e(Q.ADD_BLOCK),s=Ye();return n?a.jsxs("div",{id:"add-block-bottom",className:"group relative w-full cursor-pointer py-2",children:[a.jsx("br",{}),!s&&a.jsx("div",{role:"button",onClick:()=>re.publish(Y.OPEN_ADD_BLOCK),className:"block h-1 rounded bg-primary opacity-0 duration-200 group-hover:opacity-100",children:a.jsxs("div",{className:"absolute left-1/2 flex -translate-x-1/2 -translate-y-1/2 transform items-center gap-x-1 rounded-full bg-primary px-3 py-1 text-xs leading-tight text-white hover:bg-primary",children:[a.jsx(k.PlusIcon,{className:"size-2.5 stroke-[3]"})," ",t("Add block")]})}),a.jsx("br",{}),a.jsx("br",{}),a.jsx("br",{}),a.jsx("br",{})]}):null},eo=({theme:t})=>{const e=g.useMemo(()=>Qe.getChaiThemeCssVariables({theme:t}),[t]);return a.jsx("style",{id:"chai-theme",dangerouslySetInnerHTML:{__html:e}})},zi=Ne.atomWithStorage("darkMode",!1),an=()=>{const[t,e]=j.useAtom(zi);return[t,e]},Bp=()=>{const[t]=_n(),e=nn(),[n]=an(),{document:s,window:r}=Xe();return g.useEffect(()=>{n?s==null||s.documentElement.classList.add("dark"):s==null||s.documentElement.classList.remove("dark")},[n,s]),g.useEffect(()=>{!r||!r.tailwind||(r.tailwind.config={darkMode:"class",theme:{extend:{container:{center:!0,padding:"1rem",screens:{"2xl":"1400px"}},...Qe.getChaiThemeOptions(e)}},plugins:[Nd,Sd,Cd,jd,Qe.plugin(function({addBase:o,theme:i}){o({"h1,h2,h3,h4,h5,h6":{fontFamily:i("fontFamily.heading")},body:{fontFamily:i("fontFamily.body"),color:i("colors.foreground"),backgroundColor:i("colors.background")}})})]})},[t,e,r]),a.jsxs(a.Fragment,{children:[a.jsx(eo,{theme:t}),a.jsx(Lp,{}),a.jsx(Pp,{}),a.jsx(Rp,{})]})},Rp=()=>{const[t]=Ae(),[e]=U(),n=g.useMemo(()=>`${d.map(t,({id:s})=>`[data-style-id="${s}"]`).join(",")}{
|
|
126
|
+
outline: 1px solid ${e.length>0?"#42a1fc":"#de8f09"} !important; outline-offset: -1px;
|
|
127
|
+
}`,[t,e]);return a.jsx("style",{id:"selected-styling-blocks",dangerouslySetInnerHTML:{__html:n}})},Pp=()=>{const[t]=U(),e=g.useMemo(()=>`${d.map(t,n=>`[data-block-id="${n}"]`).join(",")}{
|
|
128
|
+
outline: 1px solid #42a1fc !important; outline-offset: -1px;
|
|
129
|
+
}`,[t]);return a.jsx("style",{id:"selected-blocks",dangerouslySetInnerHTML:{__html:e}})},Lp=()=>{const[t]=_n(),e=Nr.useRegisteredFonts(),n=g.useMemo(()=>{const{heading:o,body:i}={heading:d.get(t,"fontFamily.heading"),body:d.get(t,"fontFamily.body")};return e.filter(l=>l.family===o||l.family===i)},[t==null?void 0:t.fontFamily,e]),s=g.useMemo(()=>Qe.getThemeFontsUrls(d.filter(n,o=>d.has(o,"url"))),[n]),r=g.useMemo(()=>Qe.getThemeCustomFontFace(d.filter(n,o=>d.has(o,"src"))),[n]);return a.jsxs(a.Fragment,{children:[s.map((o,i)=>a.jsx("link",{rel:"stylesheet",href:o},`google-font-${i}`)),a.jsx("style",{id:"chai-custom-fonts",dangerouslySetInnerHTML:{__html:r}})]})},Mp=({children:t,onMount:e,onResize:n})=>{const[,s]=U(),[,r]=Ae(),o=g.useRef(null),i=ve.useDebouncedCallback(()=>{const{clientWidth:c}=o.current;n(c)},[o.current],100);ve.useResizeObserver(o.current,i,o.current!==null),g.useEffect(()=>{const{clientWidth:c}=o.current;e(c)},[]);const l=g.useCallback(()=>{s([]),r([])},[s,r]);return a.jsx("div",{id:"main-content",onClick:l,className:"h-full w-full border-l-4 border-r-4 pb-0",ref:o,children:t})},Dp=()=>{const[,t]=U(),{onDragStart:e,onDragEnd:n}=on(),[s]=Z(),r=g.useRef(null),[o,i]=j.useAtom(mp),[l,c]=j.useAtom(Ti),u=g.useCallback(m=>{var v;if(m.button!==0)return;const h=Date.now(),x=h-o;if(x<400&&x>0){c(2);return}i(h);const y=(v=m.target.closest("[data-block-id]"))==null?void 0:v.getAttribute("data-block-id");y&&(t([y]),r.current=y)},[t,o,i,l,c]),p=g.useCallback(m=>{if(!r.current)return;const h=d.find(s,{_id:r.current});h&&e(m,h,!1)},[s,e]),f=g.useCallback(()=>{n(),r.current=null},[n]);return{onMouseDown:u,onDragStart:p,onDragEnd:f}},Op=()=>{const[t]=Z();return g.useCallback((e,n)=>d.isEmpty(n)?{}:Object.entries(n).reduce((s,[r,o])=>{const i=[];let l=d.find(t,{_id:e});for(;l;)i.push(l),l=d.find(t,{_id:l._parent});const c=d.find(i,{_type:o.block});return c&&(s[r]=d.get(c,d.get(o,"prop"),null)),s},{}),[t])},$p=j.atom("edit"),Hi=()=>{const[t,e]=j.useAtom($p);return{mode:t,setMode:e}},Fp=({children:t,block:e})=>{const n=g.useMemo(()=>K.getRegisteredChaiBlock(e._type),[e._type]),s=d.get(n,"dataProviderDependencies"),r=d.get(n,"dataProvider"),o=d.get(n,"dataProviderMode","mock"),i=Gd(e,o,s,r);return t(i)},zp=()=>a.jsx("div",{className:"flex min-h-[100px] items-center justify-center bg-red-50 p-2 text-center text-red-500",children:"Something went wrong."});function be(...t){return za.twMerge(Fa.clsx(t))}Ne.atomWithStorage("chai-builder-blocks",[]);const Hp=Ne.atomWithStorage("chai-builder-theme",Qe.defaultThemeValues);Ne.atomWithStorage("chai-builder-design-tokens",{});Ne.atomWithStorage("chai-builder-ai-context","");const fr=({editor:t,trigger:e,content:n,from:s,menuRef:r})=>{const{document:o}=Xe(),[i,l]=g.useState({left:void 0,right:void 0,top:void 0,bottom:void 0}),[c,u]=g.useState(!1),p=g.useRef(null);if(g.useEffect(()=>{var v,w;if(!c){l({left:void 0,right:void 0,top:void 0,bottom:void 0});return}const f=(v=p.current)==null?void 0:v.getBoundingClientRect();if(!f||!o)return;const m=(w=r.current)==null?void 0:w.getBoundingClientRect();if(!m)return;let h=f.left,x=f.bottom+4,b,y;(m==null?void 0:m.left)+(m==null?void 0:m.width)+50>=o.body.offsetWidth&&(h=void 0,b=o.body.offsetWidth-(f==null?void 0:f.right)),x+202>=o.body.clientHeight&&(x=void 0,y=o.body.clientHeight-f.bottom+m.height),l({left:h,top:x,right:b,bottom:y})},[c]),s==="canvas"){const f=()=>{u(!1),t&&(t==null||t.view.focus(),t==null||t.chain().focus().run())};return a.jsxs(a.Fragment,{children:[a.jsx("div",{ref:p,onClick:()=>u(m=>!m),className:"cursor-pointer",children:e}),c&&(i.left!==void 0||i.top!==void 0||i.right!==void 0||i.bottom!==void 0)&&lr.createPortal(a.jsx("div",{id:"chaibuilder-rte-dropdown-menu-content",onClick:f,className:"fixed inset-0 left-0 top-0 z-[10001] h-full w-screen",children:a.jsx("div",{onClick:m=>m.stopPropagation(),className:"absolute rounded-md border border-gray-500 bg-white p-1.5 text-xs shadow-2xl",style:Object.assign({},{left:i.left,top:i.top,right:i.right,bottom:i.bottom}),children:typeof n=="function"?n(f):n})}),o.body,"chaibuilder-rte-dropdown-menu")]})}return a.jsx(a.Fragment,{children:a.jsxs(tt,{open:c,onOpenChange:u,children:[a.jsx(nt,{className:"relative outline-none",asChild:!0,children:e}),a.jsx(Ue,{className:"z-50 rounded-md border bg-white p-1 text-xs shadow-xl",children:c&&(typeof n=="function"?n(()=>u(!1)):n)})]})})},Vp=(t,e,n)=>{const s=n==="settings",r=typeof e=="boolean"?e:e.some(o=>t.isActive(o));return{"rounded p-1":!0,"hover:bg-blue-900 hover:text-blue-100":!r&&!s,"hover:bg-blue-100 hover:text-blue-900":!r&&s,"bg-blue-500 text-white":r&&s,"bg-white text-blue-500":r&&!s}},ea=({themeColors:t,onClose:e,color:n,onChange:s,onRemove:r})=>a.jsxs(a.Fragment,{children:[a.jsx("div",{className:"flex w-[180px] flex-wrap gap-1 pb-2",children:(t==null?void 0:t.length)>0&&d.uniq(t).map(o=>{var i;return a.jsx("button",{className:be("h-4 w-4 cursor-pointer rounded-full border border-gray-900 shadow duration-200 hover:scale-105 hover:shadow-xl",{"border-2":o===n}),style:{backgroundColor:o},onClick:()=>{s(o),e()},title:(i=o||"#000000")==null?void 0:i.toUpperCase()},o)})}),a.jsx(ld.HexAlphaColorPicker,{color:n,onChange:s,style:{width:"200px",height:"200px"}}),a.jsxs("div",{className:"mt-1 flex items-center justify-between gap-1",children:[a.jsx(B.Input,{type:"text",value:n||"#000000f2",onChange:o=>s(o.target.value,!0),className:"!h-5 !w-[105px] rounded-sm !p-0 text-center font-light uppercase text-gray-600 outline-none ring-0 focus:ring-0",placeholder:"#000000"}),a.jsxs("button",{className:"flex h-4 w-max cursor-pointer items-center gap-x-1 rounded-full bg-transparent px-1 text-red-600 shadow-none duration-200 hover:bg-red-100",onClick:()=>{r(),e()},title:"Remove",children:[a.jsx(k.Cross1Icon,{className:"h-3 w-3"})," Remove"]})]})]}),Wp=({textColor:t,highlightColor:e,onChangeTextColor:n,onChangeHighlightColor:s,onRemoveTextColor:r,onRemoveHighlightColor:o,onClose:i})=>{const[l]=an(),[c]=j.useAtom(Hp),u=(c==null?void 0:c.colors)||{},p=Object.values(u).map(h=>d.get(h,l?"1":"0")),[f,m]=g.useState("TEXT");return a.jsxs("div",{id:"rte-widget-color-picker",className:"px-1",children:[a.jsxs("div",{className:"mb-2 flex items-center justify-between rounded-md border bg-muted",children:[a.jsx("div",{className:`w-full cursor-pointer rounded p-0.5 text-center ${f==="TEXT"?"bg-blue-500 text-white":"hover:bg-blue-100 hover:text-blue-500"}`,onClick:()=>m("TEXT"),children:"Text Color"}),a.jsx("div",{className:`w-full cursor-pointer rounded p-0.5 text-center ${f==="HIGHLIGHT"?"bg-blue-500 text-white":"hover:bg-blue-100 hover:text-blue-500"}`,onClick:()=>m("HIGHLIGHT"),children:"Highlight Color"})]}),f==="TEXT"?a.jsx(ea,{themeColors:p,onClose:i,onChange:n,color:t,onRemove:r}):a.jsx(ea,{themeColors:p,onClose:i,onChange:s,color:e,onRemove:o})]})},Gp=({editor:t,from:e,menuRef:n})=>{var w,I;const s=(w=t==null?void 0:t.getAttributes("textStyle"))==null?void 0:w.color,r=(I=t==null?void 0:t.getAttributes("highlight"))==null?void 0:I.color,[o,i]=g.useState(s||"#000000F2"),[l,c]=g.useState(r||"#00000057"),[u,p]=ve.useDebouncedState(o,150),[f,m]=ve.useDebouncedState(l,150),h=(N,E)=>{E?(i(N),p(N)):(t==null||t.chain().setColor(N).run(),i(N))},x=(N,E)=>{E?(c(N),m(N)):(t==null||t.chain().setHighlight({color:N}).run(),c(N))},b=()=>{t==null||t.chain().unsetColor().run(),i("#000000F2")},y=()=>{t==null||t.chain().unsetHighlight().run()};g.useEffect(()=>{r&&c(r)},[r]),g.useEffect(()=>{f!=null&&f.includes("#")&&(f==null?void 0:f.length)>=3&&(t==null||t.chain().setHighlight({color:f}).run())},[f]),g.useEffect(()=>{u!=null&&u.includes("#")&&(u==null?void 0:u.length)>=3&&(t==null||t.chain().setColor(u).run())},[u]);const v=!!s;return a.jsx(fr,{editor:t,from:e,menuRef:n,trigger:a.jsxs("div",{className:be("relative flex items-center",Vp(t,v,e)),title:"Text Color",children:[a.jsx("div",{className:"h-4 w-4 rounded-full",style:{backgroundColor:s||(e==="canvas"?"#FFFFFF":"#000000")}}),a.jsx(k.CaretDownIcon,{className:"h-3 w-3 opacity-50"})]}),content:N=>a.jsx(Wp,{textColor:o,highlightColor:l,onChangeTextColor:h,onChangeHighlightColor:x,onRemoveTextColor:b,onRemoveHighlightColor:y,onClose:N})})},Le=(t,e,n)=>{const s=n==="settings",r=typeof e=="boolean"?e:e.some(o=>t.isActive(o));return{"rounded p-1":!0,"hover:bg-blue-900 hover:text-blue-100":!r&&!s,"hover:bg-blue-100 hover:text-blue-900":!r&&s,"bg-blue-500 text-white":r&&s,"bg-white text-blue-500":r&&!s}},Vi=({editor:t,from:e="settings",onExpand:n})=>{const s=g.useRef(null);if(!t)return null;const r=()=>{const i=window.prompt("URL");i&&t.chain().focus().extendMarkRange("link").setLink({href:i}).run()},o=()=>{t.chain().focus().unsetLink().run()};return a.jsxs("div",{ref:s,id:"chai-rich-text-menu-bar",className:be("mb-1 flex flex-wrap gap-0.5 rounded-t-md border-b border-border bg-gray-50 p-1",{"mb-0 rounded-md border-none bg-blue-500 text-white":e==="canvas"}),children:[a.jsx("button",{type:"button",onClick:()=>t.chain().focus().toggleBold().run(),className:be("",Le(t,["bold"],e)),title:"Bold",children:a.jsx(k.FontBoldIcon,{className:"h-4 w-4"})}),a.jsx("button",{type:"button",onClick:()=>t.chain().focus().toggleItalic().run(),className:be("",Le(t,["italic"],e)),title:"Italic",children:a.jsx(k.FontItalicIcon,{className:"h-4 w-4"})}),a.jsx("button",{type:"button",onClick:()=>t.chain().focus().toggleUnderline().run(),className:be("",Le(t,["underline"],e)),title:"Underline",children:a.jsx(k.UnderlineIcon,{className:"h-4 w-4"})}),a.jsx("button",{type:"button",onClick:()=>t.chain().focus().toggleStrike().run(),className:be("",Le(t,["strike"],e)),title:"Strike",children:a.jsx(k.StrikethroughIcon,{className:"h-4 w-4"})}),a.jsx("div",{className:"mx-1 h-5 w-px self-center bg-border"}),a.jsx(Gp,{editor:t,from:e,menuRef:s}),a.jsx("div",{className:"mx-1 h-5 w-px self-center bg-border"}),a.jsx(fr,{editor:t,menuRef:s,from:e,trigger:a.jsxs("button",{type:"button",className:be("flex items-center",Le(t,["bulletList","orderedList"],e)),title:"Bullet List",children:[a.jsx(k.ListBulletIcon,{className:"h-4 w-4"}),a.jsx(k.CaretDownIcon,{className:"h-3 w-3 opacity-50"})]}),content:i=>a.jsxs(a.Fragment,{children:[a.jsxs("div",{onClick:()=>{t.chain().focus().toggleBulletList().run(),i()},className:be("flex cursor-pointer items-center gap-x-1 outline-none hover:outline-none",Le(t,["bulletList"],e)),children:[a.jsx(k.ListBulletIcon,{className:"h-4 w-4"})," Unordered List"]}),a.jsxs("div",{onClick:()=>{t.chain().focus().toggleOrderedList().run(),i()},className:be("flex cursor-pointer items-center gap-x-1 outline-none hover:outline-none",Le(t,["orderedList"],e)),children:[a.jsx(k.ValueIcon,{className:"h-4 w-4"}),"Ordered List"]})]})}),a.jsx(fr,{editor:t,menuRef:s,from:e,trigger:a.jsxs("button",{type:"button",className:be("flex items-center",Le(t,t.isActive({textAlign:"center"})||t.isActive({textAlign:"right"}),e)),title:"Text Alignment",children:[t.isActive({textAlign:"center"})?a.jsx(k.TextAlignCenterIcon,{className:"h-4 w-4"}):t.isActive({textAlign:"right"})?a.jsx(k.TextAlignRightIcon,{className:"h-4 w-4"}):a.jsx(k.TextAlignLeftIcon,{className:"h-4 w-4"}),a.jsx(k.CaretDownIcon,{className:"h-3 w-3 opacity-50"})]}),content:i=>a.jsxs(a.Fragment,{children:[a.jsxs("div",{onClick:()=>{t.chain().focus().setTextAlign("left").run(),i()},className:be("flex cursor-pointer items-center gap-x-1 outline-none hover:outline-none",Le(t,t.isActive({textAlign:"left"}),e)),children:[a.jsx(k.TextAlignLeftIcon,{className:"h-4 w-4"})," Align Left"]}),a.jsxs("div",{onClick:()=>{t.chain().focus().setTextAlign("center").run(),i()},className:be("flex cursor-pointer items-center gap-x-1 outline-none hover:outline-none",Le(t,t.isActive({textAlign:"center"}),e)),children:[a.jsx(k.TextAlignCenterIcon,{className:"h-4 w-4"})," Align Center"]}),a.jsxs("div",{onClick:()=>{t.chain().focus().setTextAlign("right").run(),i()},className:be("flex cursor-pointer items-center gap-x-1 outline-none hover:outline-none",Le(t,t.isActive({textAlign:"right"}),e)),children:[a.jsx(k.TextAlignRightIcon,{className:"h-4 w-4"})," Align Right"]})]})}),t.isActive("link")?a.jsx("button",{type:"button",onClick:o,className:be("",Le(t,["link"],e)),title:"Remove Link",disabled:!t.isActive("link"),children:a.jsx(k.LinkBreak2Icon,{className:"h-3.5 w-3.5"})}):a.jsx("button",{type:"button",onClick:r,className:be("",Le(t,["link"],e)),title:"Add Link",children:a.jsx(k.Link2Icon,{className:"h-3.5 w-3.5"})}),n&&a.jsxs(a.Fragment,{children:[a.jsx("div",{className:"mx-1 h-5 w-px self-center bg-border"}),a.jsx("button",{type:"button",onClick:n,className:be("",Le(t,!1,e)),title:"Open in full screen mode",children:a.jsx(k.EnterFullScreenIcon,{className:"h-3.5 w-3.5"})})]})]})};function Ce(t){this.content=t}Ce.prototype={constructor:Ce,find:function(t){for(var e=0;e<this.content.length;e+=2)if(this.content[e]===t)return e;return-1},get:function(t){var e=this.find(t);return e==-1?void 0:this.content[e+1]},update:function(t,e,n){var s=n&&n!=t?this.remove(n):this,r=s.find(t),o=s.content.slice();return r==-1?o.push(n||t,e):(o[r+1]=e,n&&(o[r]=n)),new Ce(o)},remove:function(t){var e=this.find(t);if(e==-1)return this;var n=this.content.slice();return n.splice(e,2),new Ce(n)},addToStart:function(t,e){return new Ce([t,e].concat(this.remove(t).content))},addToEnd:function(t,e){var n=this.remove(t).content.slice();return n.push(t,e),new Ce(n)},addBefore:function(t,e,n){var s=this.remove(e),r=s.content.slice(),o=s.find(t);return r.splice(o==-1?r.length:o,0,e,n),new Ce(r)},forEach:function(t){for(var e=0;e<this.content.length;e+=2)t(this.content[e],this.content[e+1])},prepend:function(t){return t=Ce.from(t),t.size?new Ce(t.content.concat(this.subtract(t).content)):this},append:function(t){return t=Ce.from(t),t.size?new Ce(this.subtract(t).content.concat(t.content)):this},subtract:function(t){var e=this;t=Ce.from(t);for(var n=0;n<t.content.length;n+=2)e=e.remove(t.content[n]);return e},toObject:function(){var t={};return this.forEach(function(e,n){t[e]=n}),t},get size(){return this.content.length>>1}};Ce.from=function(t){if(t instanceof Ce)return t;var e=[];if(t)for(var n in t)e.push(n,t[n]);return new Ce(e)};function Wi(t,e,n){for(let s=0;;s++){if(s==t.childCount||s==e.childCount)return t.childCount==e.childCount?null:n;let r=t.child(s),o=e.child(s);if(r==o){n+=r.nodeSize;continue}if(!r.sameMarkup(o))return n;if(r.isText&&r.text!=o.text){for(let i=0;r.text[i]==o.text[i];i++)n++;return n}if(r.content.size||o.content.size){let i=Wi(r.content,o.content,n+1);if(i!=null)return i}n+=r.nodeSize}}function Gi(t,e,n,s){for(let r=t.childCount,o=e.childCount;;){if(r==0||o==0)return r==o?null:{a:n,b:s};let i=t.child(--r),l=e.child(--o),c=i.nodeSize;if(i==l){n-=c,s-=c;continue}if(!i.sameMarkup(l))return{a:n,b:s};if(i.isText&&i.text!=l.text){let u=0,p=Math.min(i.text.length,l.text.length);for(;u<p&&i.text[i.text.length-u-1]==l.text[l.text.length-u-1];)u++,n--,s--;return{a:n,b:s}}if(i.content.size||l.content.size){let u=Gi(i.content,l.content,n-1,s-1);if(u)return u}n-=c,s-=c}}class M{constructor(e,n){if(this.content=e,this.size=n||0,n==null)for(let s=0;s<e.length;s++)this.size+=e[s].nodeSize}nodesBetween(e,n,s,r=0,o){for(let i=0,l=0;l<n;i++){let c=this.content[i],u=l+c.nodeSize;if(u>e&&s(c,r+l,o||null,i)!==!1&&c.content.size){let p=l+1;c.nodesBetween(Math.max(0,e-p),Math.min(c.content.size,n-p),s,r+p)}l=u}}descendants(e){this.nodesBetween(0,this.size,e)}textBetween(e,n,s,r){let o="",i=!0;return this.nodesBetween(e,n,(l,c)=>{let u=l.isText?l.text.slice(Math.max(e,c)-c,n-c):l.isLeaf?r?typeof r=="function"?r(l):r:l.type.spec.leafText?l.type.spec.leafText(l):"":"";l.isBlock&&(l.isLeaf&&u||l.isTextblock)&&s&&(i?i=!1:o+=s),o+=u},0),o}append(e){if(!e.size)return this;if(!this.size)return e;let n=this.lastChild,s=e.firstChild,r=this.content.slice(),o=0;for(n.isText&&n.sameMarkup(s)&&(r[r.length-1]=n.withText(n.text+s.text),o=1);o<e.content.length;o++)r.push(e.content[o]);return new M(r,this.size+e.size)}cut(e,n=this.size){if(e==0&&n==this.size)return this;let s=[],r=0;if(n>e)for(let o=0,i=0;i<n;o++){let l=this.content[o],c=i+l.nodeSize;c>e&&((i<e||c>n)&&(l.isText?l=l.cut(Math.max(0,e-i),Math.min(l.text.length,n-i)):l=l.cut(Math.max(0,e-i-1),Math.min(l.content.size,n-i-1))),s.push(l),r+=l.nodeSize),i=c}return new M(s,r)}cutByIndex(e,n){return e==n?M.empty:e==0&&n==this.content.length?this:new M(this.content.slice(e,n))}replaceChild(e,n){let s=this.content[e];if(s==n)return this;let r=this.content.slice(),o=this.size+n.nodeSize-s.nodeSize;return r[e]=n,new M(r,o)}addToStart(e){return new M([e].concat(this.content),this.size+e.nodeSize)}addToEnd(e){return new M(this.content.concat(e),this.size+e.nodeSize)}eq(e){if(this.content.length!=e.content.length)return!1;for(let n=0;n<this.content.length;n++)if(!this.content[n].eq(e.content[n]))return!1;return!0}get firstChild(){return this.content.length?this.content[0]:null}get lastChild(){return this.content.length?this.content[this.content.length-1]:null}get childCount(){return this.content.length}child(e){let n=this.content[e];if(!n)throw new RangeError("Index "+e+" out of range for "+this);return n}maybeChild(e){return this.content[e]||null}forEach(e){for(let n=0,s=0;n<this.content.length;n++){let r=this.content[n];e(r,s,n),s+=r.nodeSize}}findDiffStart(e,n=0){return Wi(this,e,n)}findDiffEnd(e,n=this.size,s=e.size){return Gi(this,e,n,s)}findIndex(e){if(e==0)return Wn(0,e);if(e==this.size)return Wn(this.content.length,e);if(e>this.size||e<0)throw new RangeError(`Position ${e} outside of fragment (${this})`);for(let n=0,s=0;;n++){let r=this.child(n),o=s+r.nodeSize;if(o>=e)return o==e?Wn(n+1,o):Wn(n,s);s=o}}toString(){return"<"+this.toStringInner()+">"}toStringInner(){return this.content.join(", ")}toJSON(){return this.content.length?this.content.map(e=>e.toJSON()):null}static fromJSON(e,n){if(!n)return M.empty;if(!Array.isArray(n))throw new RangeError("Invalid input for Fragment.fromJSON");return new M(n.map(e.nodeFromJSON))}static fromArray(e){if(!e.length)return M.empty;let n,s=0;for(let r=0;r<e.length;r++){let o=e[r];s+=o.nodeSize,r&&o.isText&&e[r-1].sameMarkup(o)?(n||(n=e.slice(0,r)),n[n.length-1]=o.withText(n[n.length-1].text+o.text)):n&&n.push(o)}return new M(n||e,s)}static from(e){if(!e)return M.empty;if(e instanceof M)return e;if(Array.isArray(e))return this.fromArray(e);if(e.attrs)return new M([e],e.nodeSize);throw new RangeError("Can not convert "+e+" to a Fragment"+(e.nodesBetween?" (looks like multiple versions of prosemirror-model were loaded)":""))}}M.empty=new M([],0);const Xs={index:0,offset:0};function Wn(t,e){return Xs.index=t,Xs.offset=e,Xs}function as(t,e){if(t===e)return!0;if(!(t&&typeof t=="object")||!(e&&typeof e=="object"))return!1;let n=Array.isArray(t);if(Array.isArray(e)!=n)return!1;if(n){if(t.length!=e.length)return!1;for(let s=0;s<t.length;s++)if(!as(t[s],e[s]))return!1}else{for(let s in t)if(!(s in e)||!as(t[s],e[s]))return!1;for(let s in e)if(!(s in t))return!1}return!0}class ee{constructor(e,n){this.type=e,this.attrs=n}addToSet(e){let n,s=!1;for(let r=0;r<e.length;r++){let o=e[r];if(this.eq(o))return e;if(this.type.excludes(o.type))n||(n=e.slice(0,r));else{if(o.type.excludes(this.type))return e;!s&&o.type.rank>this.type.rank&&(n||(n=e.slice(0,r)),n.push(this),s=!0),n&&n.push(o)}}return n||(n=e.slice()),s||n.push(this),n}removeFromSet(e){for(let n=0;n<e.length;n++)if(this.eq(e[n]))return e.slice(0,n).concat(e.slice(n+1));return e}isInSet(e){for(let n=0;n<e.length;n++)if(this.eq(e[n]))return!0;return!1}eq(e){return this==e||this.type==e.type&&as(this.attrs,e.attrs)}toJSON(){let e={type:this.type.name};for(let n in this.attrs){e.attrs=this.attrs;break}return e}static fromJSON(e,n){if(!n)throw new RangeError("Invalid input for Mark.fromJSON");let s=e.marks[n.type];if(!s)throw new RangeError(`There is no mark type ${n.type} in this schema`);let r=s.create(n.attrs);return s.checkAttrs(r.attrs),r}static sameSet(e,n){if(e==n)return!0;if(e.length!=n.length)return!1;for(let s=0;s<e.length;s++)if(!e[s].eq(n[s]))return!1;return!0}static setFrom(e){if(!e||Array.isArray(e)&&e.length==0)return ee.none;if(e instanceof ee)return[e];let n=e.slice();return n.sort((s,r)=>s.type.rank-r.type.rank),n}}ee.none=[];class is extends Error{}class V{constructor(e,n,s){this.content=e,this.openStart=n,this.openEnd=s}get size(){return this.content.size-this.openStart-this.openEnd}insertAt(e,n){let s=qi(this.content,e+this.openStart,n);return s&&new V(s,this.openStart,this.openEnd)}removeBetween(e,n){return new V(Ui(this.content,e+this.openStart,n+this.openStart),this.openStart,this.openEnd)}eq(e){return this.content.eq(e.content)&&this.openStart==e.openStart&&this.openEnd==e.openEnd}toString(){return this.content+"("+this.openStart+","+this.openEnd+")"}toJSON(){if(!this.content.size)return null;let e={content:this.content.toJSON()};return this.openStart>0&&(e.openStart=this.openStart),this.openEnd>0&&(e.openEnd=this.openEnd),e}static fromJSON(e,n){if(!n)return V.empty;let s=n.openStart||0,r=n.openEnd||0;if(typeof s!="number"||typeof r!="number")throw new RangeError("Invalid input for Slice.fromJSON");return new V(M.fromJSON(e,n.content),s,r)}static maxOpen(e,n=!0){let s=0,r=0;for(let o=e.firstChild;o&&!o.isLeaf&&(n||!o.type.spec.isolating);o=o.firstChild)s++;for(let o=e.lastChild;o&&!o.isLeaf&&(n||!o.type.spec.isolating);o=o.lastChild)r++;return new V(e,s,r)}}V.empty=new V(M.empty,0,0);function Ui(t,e,n){let{index:s,offset:r}=t.findIndex(e),o=t.maybeChild(s),{index:i,offset:l}=t.findIndex(n);if(r==e||o.isText){if(l!=n&&!t.child(i).isText)throw new RangeError("Removing non-flat range");return t.cut(0,e).append(t.cut(n))}if(s!=i)throw new RangeError("Removing non-flat range");return t.replaceChild(s,o.copy(Ui(o.content,e-r-1,n-r-1)))}function qi(t,e,n,s){let{index:r,offset:o}=t.findIndex(e),i=t.maybeChild(r);if(o==e||i.isText)return s&&!s.canReplace(r,r,n)?null:t.cut(0,e).append(n).append(t.cut(e));let l=qi(i.content,e-o-1,n,i);return l&&t.replaceChild(r,i.copy(l))}function Up(t,e,n){if(n.openStart>t.depth)throw new is("Inserted content deeper than insertion position");if(t.depth-n.openStart!=e.depth-n.openEnd)throw new is("Inconsistent open depths");return Ki(t,e,n,0)}function Ki(t,e,n,s){let r=t.index(s),o=t.node(s);if(r==e.index(s)&&s<t.depth-n.openStart){let i=Ki(t,e,n,s+1);return o.copy(o.content.replaceChild(r,i))}else if(n.content.size)if(!n.openStart&&!n.openEnd&&t.depth==s&&e.depth==s){let i=t.parent,l=i.content;return Tt(i,l.cut(0,t.parentOffset).append(n.content).append(l.cut(e.parentOffset)))}else{let{start:i,end:l}=qp(n,t);return Tt(o,Xi(t,i,l,e,s))}else return Tt(o,ls(t,e,s))}function Yi(t,e){if(!e.type.compatibleContent(t.type))throw new is("Cannot join "+e.type.name+" onto "+t.type.name)}function hr(t,e,n){let s=t.node(n);return Yi(s,e.node(n)),s}function _t(t,e){let n=e.length-1;n>=0&&t.isText&&t.sameMarkup(e[n])?e[n]=t.withText(e[n].text+t.text):e.push(t)}function bn(t,e,n,s){let r=(e||t).node(n),o=0,i=e?e.index(n):r.childCount;t&&(o=t.index(n),t.depth>n?o++:t.textOffset&&(_t(t.nodeAfter,s),o++));for(let l=o;l<i;l++)_t(r.child(l),s);e&&e.depth==n&&e.textOffset&&_t(e.nodeBefore,s)}function Tt(t,e){return t.type.checkContent(e),t.copy(e)}function Xi(t,e,n,s,r){let o=t.depth>r&&hr(t,e,r+1),i=s.depth>r&&hr(n,s,r+1),l=[];return bn(null,t,r,l),o&&i&&e.index(r)==n.index(r)?(Yi(o,i),_t(Tt(o,Xi(t,e,n,s,r+1)),l)):(o&&_t(Tt(o,ls(t,e,r+1)),l),bn(e,n,r,l),i&&_t(Tt(i,ls(n,s,r+1)),l)),bn(s,null,r,l),new M(l)}function ls(t,e,n){let s=[];if(bn(null,t,n,s),t.depth>n){let r=hr(t,e,n+1);_t(Tt(r,ls(t,e,n+1)),s)}return bn(e,null,n,s),new M(s)}function qp(t,e){let n=e.depth-t.openStart,r=e.node(n).copy(t.content);for(let o=n-1;o>=0;o--)r=e.node(o).copy(M.from(r));return{start:r.resolveNoCache(t.openStart+n),end:r.resolveNoCache(r.content.size-t.openEnd-n)}}class Cn{constructor(e,n,s){this.pos=e,this.path=n,this.parentOffset=s,this.depth=n.length/3-1}resolveDepth(e){return e==null?this.depth:e<0?this.depth+e:e}get parent(){return this.node(this.depth)}get doc(){return this.node(0)}node(e){return this.path[this.resolveDepth(e)*3]}index(e){return this.path[this.resolveDepth(e)*3+1]}indexAfter(e){return e=this.resolveDepth(e),this.index(e)+(e==this.depth&&!this.textOffset?0:1)}start(e){return e=this.resolveDepth(e),e==0?0:this.path[e*3-1]+1}end(e){return e=this.resolveDepth(e),this.start(e)+this.node(e).content.size}before(e){if(e=this.resolveDepth(e),!e)throw new RangeError("There is no position before the top-level node");return e==this.depth+1?this.pos:this.path[e*3-1]}after(e){if(e=this.resolveDepth(e),!e)throw new RangeError("There is no position after the top-level node");return e==this.depth+1?this.pos:this.path[e*3-1]+this.path[e*3].nodeSize}get textOffset(){return this.pos-this.path[this.path.length-1]}get nodeAfter(){let e=this.parent,n=this.index(this.depth);if(n==e.childCount)return null;let s=this.pos-this.path[this.path.length-1],r=e.child(n);return s?e.child(n).cut(s):r}get nodeBefore(){let e=this.index(this.depth),n=this.pos-this.path[this.path.length-1];return n?this.parent.child(e).cut(0,n):e==0?null:this.parent.child(e-1)}posAtIndex(e,n){n=this.resolveDepth(n);let s=this.path[n*3],r=n==0?0:this.path[n*3-1]+1;for(let o=0;o<e;o++)r+=s.child(o).nodeSize;return r}marks(){let e=this.parent,n=this.index();if(e.content.size==0)return ee.none;if(this.textOffset)return e.child(n).marks;let s=e.maybeChild(n-1),r=e.maybeChild(n);if(!s){let l=s;s=r,r=l}let o=s.marks;for(var i=0;i<o.length;i++)o[i].type.spec.inclusive===!1&&(!r||!o[i].isInSet(r.marks))&&(o=o[i--].removeFromSet(o));return o}marksAcross(e){let n=this.parent.maybeChild(this.index());if(!n||!n.isInline)return null;let s=n.marks,r=e.parent.maybeChild(e.index());for(var o=0;o<s.length;o++)s[o].type.spec.inclusive===!1&&(!r||!s[o].isInSet(r.marks))&&(s=s[o--].removeFromSet(s));return s}sharedDepth(e){for(let n=this.depth;n>0;n--)if(this.start(n)<=e&&this.end(n)>=e)return n;return 0}blockRange(e=this,n){if(e.pos<this.pos)return e.blockRange(this);for(let s=this.depth-(this.parent.inlineContent||this.pos==e.pos?1:0);s>=0;s--)if(e.pos<=this.end(s)&&(!n||n(this.node(s))))return new cs(this,e,s);return null}sameParent(e){return this.pos-this.parentOffset==e.pos-e.parentOffset}max(e){return e.pos>this.pos?e:this}min(e){return e.pos<this.pos?e:this}toString(){let e="";for(let n=1;n<=this.depth;n++)e+=(e?"/":"")+this.node(n).type.name+"_"+this.index(n-1);return e+":"+this.parentOffset}static resolve(e,n){if(!(n>=0&&n<=e.content.size))throw new RangeError("Position "+n+" out of range");let s=[],r=0,o=n;for(let i=e;;){let{index:l,offset:c}=i.content.findIndex(o),u=o-c;if(s.push(i,l,r+c),!u||(i=i.child(l),i.isText))break;o=u-1,r+=c+1}return new Cn(n,s,o)}static resolveCached(e,n){let s=ta.get(e);if(s)for(let o=0;o<s.elts.length;o++){let i=s.elts[o];if(i.pos==n)return i}else ta.set(e,s=new Kp);let r=s.elts[s.i]=Cn.resolve(e,n);return s.i=(s.i+1)%Yp,r}}class Kp{constructor(){this.elts=[],this.i=0}}const Yp=12,ta=new WeakMap;class cs{constructor(e,n,s){this.$from=e,this.$to=n,this.depth=s}get start(){return this.$from.before(this.depth+1)}get end(){return this.$to.after(this.depth+1)}get parent(){return this.$from.node(this.depth)}get startIndex(){return this.$from.index(this.depth)}get endIndex(){return this.$to.indexAfter(this.depth)}}const Xp=Object.create(null);let Bt=class mr{constructor(e,n,s,r=ee.none){this.type=e,this.attrs=n,this.marks=r,this.content=s||M.empty}get children(){return this.content.content}get nodeSize(){return this.isLeaf?1:2+this.content.size}get childCount(){return this.content.childCount}child(e){return this.content.child(e)}maybeChild(e){return this.content.maybeChild(e)}forEach(e){this.content.forEach(e)}nodesBetween(e,n,s,r=0){this.content.nodesBetween(e,n,s,r,this)}descendants(e){this.nodesBetween(0,this.content.size,e)}get textContent(){return this.isLeaf&&this.type.spec.leafText?this.type.spec.leafText(this):this.textBetween(0,this.content.size,"")}textBetween(e,n,s,r){return this.content.textBetween(e,n,s,r)}get firstChild(){return this.content.firstChild}get lastChild(){return this.content.lastChild}eq(e){return this==e||this.sameMarkup(e)&&this.content.eq(e.content)}sameMarkup(e){return this.hasMarkup(e.type,e.attrs,e.marks)}hasMarkup(e,n,s){return this.type==e&&as(this.attrs,n||e.defaultAttrs||Xp)&&ee.sameSet(this.marks,s||ee.none)}copy(e=null){return e==this.content?this:new mr(this.type,this.attrs,e,this.marks)}mark(e){return e==this.marks?this:new mr(this.type,this.attrs,this.content,e)}cut(e,n=this.content.size){return e==0&&n==this.content.size?this:this.copy(this.content.cut(e,n))}slice(e,n=this.content.size,s=!1){if(e==n)return V.empty;let r=this.resolve(e),o=this.resolve(n),i=s?0:r.sharedDepth(n),l=r.start(i),u=r.node(i).content.cut(r.pos-l,o.pos-l);return new V(u,r.depth-i,o.depth-i)}replace(e,n,s){return Up(this.resolve(e),this.resolve(n),s)}nodeAt(e){for(let n=this;;){let{index:s,offset:r}=n.content.findIndex(e);if(n=n.maybeChild(s),!n)return null;if(r==e||n.isText)return n;e-=r+1}}childAfter(e){let{index:n,offset:s}=this.content.findIndex(e);return{node:this.content.maybeChild(n),index:n,offset:s}}childBefore(e){if(e==0)return{node:null,index:0,offset:0};let{index:n,offset:s}=this.content.findIndex(e);if(s<e)return{node:this.content.child(n),index:n,offset:s};let r=this.content.child(n-1);return{node:r,index:n-1,offset:s-r.nodeSize}}resolve(e){return Cn.resolveCached(this,e)}resolveNoCache(e){return Cn.resolve(this,e)}rangeHasMark(e,n,s){let r=!1;return n>e&&this.nodesBetween(e,n,o=>(s.isInSet(o.marks)&&(r=!0),!r)),r}get isBlock(){return this.type.isBlock}get isTextblock(){return this.type.isTextblock}get inlineContent(){return this.type.inlineContent}get isInline(){return this.type.isInline}get isText(){return this.type.isText}get isLeaf(){return this.type.isLeaf}get isAtom(){return this.type.isAtom}toString(){if(this.type.spec.toDebugString)return this.type.spec.toDebugString(this);let e=this.type.name;return this.content.size&&(e+="("+this.content.toStringInner()+")"),Ji(this.marks,e)}contentMatchAt(e){let n=this.type.contentMatch.matchFragment(this.content,0,e);if(!n)throw new Error("Called contentMatchAt on a node with invalid content");return n}canReplace(e,n,s=M.empty,r=0,o=s.childCount){let i=this.contentMatchAt(e).matchFragment(s,r,o),l=i&&i.matchFragment(this.content,n);if(!l||!l.validEnd)return!1;for(let c=r;c<o;c++)if(!this.type.allowsMarks(s.child(c).marks))return!1;return!0}canReplaceWith(e,n,s,r){if(r&&!this.type.allowsMarks(r))return!1;let o=this.contentMatchAt(e).matchType(s),i=o&&o.matchFragment(this.content,n);return i?i.validEnd:!1}canAppend(e){return e.content.size?this.canReplace(this.childCount,this.childCount,e.content):this.type.compatibleContent(e.type)}check(){this.type.checkContent(this.content),this.type.checkAttrs(this.attrs);let e=ee.none;for(let n=0;n<this.marks.length;n++){let s=this.marks[n];s.type.checkAttrs(s.attrs),e=s.addToSet(e)}if(!ee.sameSet(e,this.marks))throw new RangeError(`Invalid collection of marks for node ${this.type.name}: ${this.marks.map(n=>n.type.name)}`);this.content.forEach(n=>n.check())}toJSON(){let e={type:this.type.name};for(let n in this.attrs){e.attrs=this.attrs;break}return this.content.size&&(e.content=this.content.toJSON()),this.marks.length&&(e.marks=this.marks.map(n=>n.toJSON())),e}static fromJSON(e,n){if(!n)throw new RangeError("Invalid input for Node.fromJSON");let s;if(n.marks){if(!Array.isArray(n.marks))throw new RangeError("Invalid mark data for Node.fromJSON");s=n.marks.map(e.markFromJSON)}if(n.type=="text"){if(typeof n.text!="string")throw new RangeError("Invalid text node in JSON");return e.text(n.text,s)}let r=M.fromJSON(e,n.content),o=e.nodeType(n.type).create(n.attrs,r,s);return o.type.checkAttrs(o.attrs),o}};Bt.prototype.text=void 0;class ds extends Bt{constructor(e,n,s,r){if(super(e,n,null,r),!s)throw new RangeError("Empty text nodes are not allowed");this.text=s}toString(){return this.type.spec.toDebugString?this.type.spec.toDebugString(this):Ji(this.marks,JSON.stringify(this.text))}get textContent(){return this.text}textBetween(e,n){return this.text.slice(e,n)}get nodeSize(){return this.text.length}mark(e){return e==this.marks?this:new ds(this.type,this.attrs,this.text,e)}withText(e){return e==this.text?this:new ds(this.type,this.attrs,e,this.marks)}cut(e=0,n=this.text.length){return e==0&&n==this.text.length?this:this.withText(this.text.slice(e,n))}eq(e){return this.sameMarkup(e)&&this.text==e.text}toJSON(){let e=super.toJSON();return e.text=this.text,e}}function Ji(t,e){for(let n=t.length-1;n>=0;n--)e=t[n].type.name+"("+e+")";return e}class Dt{constructor(e){this.validEnd=e,this.next=[],this.wrapCache=[]}static parse(e,n){let s=new Jp(e,n);if(s.next==null)return Dt.empty;let r=Zi(s);s.next&&s.err("Unexpected trailing text");let o=rf(sf(r));return of(o,s),o}matchType(e){for(let n=0;n<this.next.length;n++)if(this.next[n].type==e)return this.next[n].next;return null}matchFragment(e,n=0,s=e.childCount){let r=this;for(let o=n;r&&o<s;o++)r=r.matchType(e.child(o).type);return r}get inlineContent(){return this.next.length!=0&&this.next[0].type.isInline}get defaultType(){for(let e=0;e<this.next.length;e++){let{type:n}=this.next[e];if(!(n.isText||n.hasRequiredAttrs()))return n}return null}compatible(e){for(let n=0;n<this.next.length;n++)for(let s=0;s<e.next.length;s++)if(this.next[n].type==e.next[s].type)return!0;return!1}fillBefore(e,n=!1,s=0){let r=[this];function o(i,l){let c=i.matchFragment(e,s);if(c&&(!n||c.validEnd))return M.from(l.map(u=>u.createAndFill()));for(let u=0;u<i.next.length;u++){let{type:p,next:f}=i.next[u];if(!(p.isText||p.hasRequiredAttrs())&&r.indexOf(f)==-1){r.push(f);let m=o(f,l.concat(p));if(m)return m}}return null}return o(this,[])}findWrapping(e){for(let s=0;s<this.wrapCache.length;s+=2)if(this.wrapCache[s]==e)return this.wrapCache[s+1];let n=this.computeWrapping(e);return this.wrapCache.push(e,n),n}computeWrapping(e){let n=Object.create(null),s=[{match:this,type:null,via:null}];for(;s.length;){let r=s.shift(),o=r.match;if(o.matchType(e)){let i=[];for(let l=r;l.type;l=l.via)i.push(l.type);return i.reverse()}for(let i=0;i<o.next.length;i++){let{type:l,next:c}=o.next[i];!l.isLeaf&&!l.hasRequiredAttrs()&&!(l.name in n)&&(!r.type||c.validEnd)&&(s.push({match:l.contentMatch,type:l,via:r}),n[l.name]=!0)}}return null}get edgeCount(){return this.next.length}edge(e){if(e>=this.next.length)throw new RangeError(`There's no ${e}th edge in this content match`);return this.next[e]}toString(){let e=[];function n(s){e.push(s);for(let r=0;r<s.next.length;r++)e.indexOf(s.next[r].next)==-1&&n(s.next[r].next)}return n(this),e.map((s,r)=>{let o=r+(s.validEnd?"*":" ")+" ";for(let i=0;i<s.next.length;i++)o+=(i?", ":"")+s.next[i].type.name+"->"+e.indexOf(s.next[i].next);return o}).join(`
|
|
130
|
+
`)}}Dt.empty=new Dt(!0);class Jp{constructor(e,n){this.string=e,this.nodeTypes=n,this.inline=null,this.pos=0,this.tokens=e.split(/\s*(?=\b|\W|$)/),this.tokens[this.tokens.length-1]==""&&this.tokens.pop(),this.tokens[0]==""&&this.tokens.shift()}get next(){return this.tokens[this.pos]}eat(e){return this.next==e&&(this.pos++||!0)}err(e){throw new SyntaxError(e+" (in content expression '"+this.string+"')")}}function Zi(t){let e=[];do e.push(Zp(t));while(t.eat("|"));return e.length==1?e[0]:{type:"choice",exprs:e}}function Zp(t){let e=[];do e.push(Qp(t));while(t.next&&t.next!=")"&&t.next!="|");return e.length==1?e[0]:{type:"seq",exprs:e}}function Qp(t){let e=nf(t);for(;;)if(t.eat("+"))e={type:"plus",expr:e};else if(t.eat("*"))e={type:"star",expr:e};else if(t.eat("?"))e={type:"opt",expr:e};else if(t.eat("{"))e=ef(t,e);else break;return e}function na(t){/\D/.test(t.next)&&t.err("Expected number, got '"+t.next+"'");let e=Number(t.next);return t.pos++,e}function ef(t,e){let n=na(t),s=n;return t.eat(",")&&(t.next!="}"?s=na(t):s=-1),t.eat("}")||t.err("Unclosed braced range"),{type:"range",min:n,max:s,expr:e}}function tf(t,e){let n=t.nodeTypes,s=n[e];if(s)return[s];let r=[];for(let o in n){let i=n[o];i.isInGroup(e)&&r.push(i)}return r.length==0&&t.err("No node type or group '"+e+"' found"),r}function nf(t){if(t.eat("(")){let e=Zi(t);return t.eat(")")||t.err("Missing closing paren"),e}else if(/\W/.test(t.next))t.err("Unexpected token '"+t.next+"'");else{let e=tf(t,t.next).map(n=>(t.inline==null?t.inline=n.isInline:t.inline!=n.isInline&&t.err("Mixing inline and block content"),{type:"name",value:n}));return t.pos++,e.length==1?e[0]:{type:"choice",exprs:e}}}function sf(t){let e=[[]];return r(o(t,0),n()),e;function n(){return e.push([])-1}function s(i,l,c){let u={term:c,to:l};return e[i].push(u),u}function r(i,l){i.forEach(c=>c.to=l)}function o(i,l){if(i.type=="choice")return i.exprs.reduce((c,u)=>c.concat(o(u,l)),[]);if(i.type=="seq")for(let c=0;;c++){let u=o(i.exprs[c],l);if(c==i.exprs.length-1)return u;r(u,l=n())}else if(i.type=="star"){let c=n();return s(l,c),r(o(i.expr,c),c),[s(c)]}else if(i.type=="plus"){let c=n();return r(o(i.expr,l),c),r(o(i.expr,c),c),[s(c)]}else{if(i.type=="opt")return[s(l)].concat(o(i.expr,l));if(i.type=="range"){let c=l;for(let u=0;u<i.min;u++){let p=n();r(o(i.expr,c),p),c=p}if(i.max==-1)r(o(i.expr,c),c);else for(let u=i.min;u<i.max;u++){let p=n();s(c,p),r(o(i.expr,c),p),c=p}return[s(c)]}else{if(i.type=="name")return[s(l,void 0,i.value)];throw new Error("Unknown expr type")}}}}function Qi(t,e){return e-t}function sa(t,e){let n=[];return s(e),n.sort(Qi);function s(r){let o=t[r];if(o.length==1&&!o[0].term)return s(o[0].to);n.push(r);for(let i=0;i<o.length;i++){let{term:l,to:c}=o[i];!l&&n.indexOf(c)==-1&&s(c)}}}function rf(t){let e=Object.create(null);return n(sa(t,0));function n(s){let r=[];s.forEach(i=>{t[i].forEach(({term:l,to:c})=>{if(!l)return;let u;for(let p=0;p<r.length;p++)r[p][0]==l&&(u=r[p][1]);sa(t,c).forEach(p=>{u||r.push([l,u=[]]),u.indexOf(p)==-1&&u.push(p)})})});let o=e[s.join(",")]=new Dt(s.indexOf(t.length-1)>-1);for(let i=0;i<r.length;i++){let l=r[i][1].sort(Qi);o.next.push({type:r[i][0],next:e[l.join(",")]||n(l)})}return o}}function of(t,e){for(let n=0,s=[t];n<s.length;n++){let r=s[n],o=!r.validEnd,i=[];for(let l=0;l<r.next.length;l++){let{type:c,next:u}=r.next[l];i.push(c.name),o&&!(c.isText||c.hasRequiredAttrs())&&(o=!1),s.indexOf(u)==-1&&s.push(u)}o&&e.err("Only non-generatable nodes ("+i.join(", ")+") in a required position (see https://prosemirror.net/docs/guide/#generatable)")}}function el(t){let e=Object.create(null);for(let n in t){let s=t[n];if(!s.hasDefault)return null;e[n]=s.default}return e}function tl(t,e){let n=Object.create(null);for(let s in t){let r=e&&e[s];if(r===void 0){let o=t[s];if(o.hasDefault)r=o.default;else throw new RangeError("No value supplied for attribute "+s)}n[s]=r}return n}function nl(t,e,n,s){for(let r in e)if(!(r in t))throw new RangeError(`Unsupported attribute ${r} for ${n} of type ${r}`);for(let r in t){let o=t[r];o.validate&&o.validate(e[r])}}function sl(t,e){let n=Object.create(null);if(e)for(let s in e)n[s]=new lf(t,s,e[s]);return n}class us{constructor(e,n,s){this.name=e,this.schema=n,this.spec=s,this.markSet=null,this.groups=s.group?s.group.split(" "):[],this.attrs=sl(e,s.attrs),this.defaultAttrs=el(this.attrs),this.contentMatch=null,this.inlineContent=null,this.isBlock=!(s.inline||e=="text"),this.isText=e=="text"}get isInline(){return!this.isBlock}get isTextblock(){return this.isBlock&&this.inlineContent}get isLeaf(){return this.contentMatch==Dt.empty}get isAtom(){return this.isLeaf||!!this.spec.atom}isInGroup(e){return this.groups.indexOf(e)>-1}get whitespace(){return this.spec.whitespace||(this.spec.code?"pre":"normal")}hasRequiredAttrs(){for(let e in this.attrs)if(this.attrs[e].isRequired)return!0;return!1}compatibleContent(e){return this==e||this.contentMatch.compatible(e.contentMatch)}computeAttrs(e){return!e&&this.defaultAttrs?this.defaultAttrs:tl(this.attrs,e)}create(e=null,n,s){if(this.isText)throw new Error("NodeType.create can't construct text nodes");return new Bt(this,this.computeAttrs(e),M.from(n),ee.setFrom(s))}createChecked(e=null,n,s){return n=M.from(n),this.checkContent(n),new Bt(this,this.computeAttrs(e),n,ee.setFrom(s))}createAndFill(e=null,n,s){if(e=this.computeAttrs(e),n=M.from(n),n.size){let i=this.contentMatch.fillBefore(n);if(!i)return null;n=i.append(n)}let r=this.contentMatch.matchFragment(n),o=r&&r.fillBefore(M.empty,!0);return o?new Bt(this,e,n.append(o),ee.setFrom(s)):null}validContent(e){let n=this.contentMatch.matchFragment(e);if(!n||!n.validEnd)return!1;for(let s=0;s<e.childCount;s++)if(!this.allowsMarks(e.child(s).marks))return!1;return!0}checkContent(e){if(!this.validContent(e))throw new RangeError(`Invalid content for node ${this.name}: ${e.toString().slice(0,50)}`)}checkAttrs(e){nl(this.attrs,e,"node",this.name)}allowsMarkType(e){return this.markSet==null||this.markSet.indexOf(e)>-1}allowsMarks(e){if(this.markSet==null)return!0;for(let n=0;n<e.length;n++)if(!this.allowsMarkType(e[n].type))return!1;return!0}allowedMarks(e){if(this.markSet==null)return e;let n;for(let s=0;s<e.length;s++)this.allowsMarkType(e[s].type)?n&&n.push(e[s]):n||(n=e.slice(0,s));return n?n.length?n:ee.none:e}static compile(e,n){let s=Object.create(null);e.forEach((o,i)=>s[o]=new us(o,n,i));let r=n.spec.topNode||"doc";if(!s[r])throw new RangeError("Schema is missing its top node type ('"+r+"')");if(!s.text)throw new RangeError("Every schema needs a 'text' type");for(let o in s.text.attrs)throw new RangeError("The text node type should not have attributes");return s}}function af(t,e,n){let s=n.split("|");return r=>{let o=r===null?"null":typeof r;if(s.indexOf(o)<0)throw new RangeError(`Expected value of type ${s} for attribute ${e} on type ${t}, got ${o}`)}}class lf{constructor(e,n,s){this.hasDefault=Object.prototype.hasOwnProperty.call(s,"default"),this.default=s.default,this.validate=typeof s.validate=="string"?af(e,n,s.validate):s.validate}get isRequired(){return!this.hasDefault}}class to{constructor(e,n,s,r){this.name=e,this.rank=n,this.schema=s,this.spec=r,this.attrs=sl(e,r.attrs),this.excluded=null;let o=el(this.attrs);this.instance=o?new ee(this,o):null}create(e=null){return!e&&this.instance?this.instance:new ee(this,tl(this.attrs,e))}static compile(e,n){let s=Object.create(null),r=0;return e.forEach((o,i)=>s[o]=new to(o,r++,n,i)),s}removeFromSet(e){for(var n=0;n<e.length;n++)e[n].type==this&&(e=e.slice(0,n).concat(e.slice(n+1)),n--);return e}isInSet(e){for(let n=0;n<e.length;n++)if(e[n].type==this)return e[n]}checkAttrs(e){nl(this.attrs,e,"mark",this.name)}excludes(e){return this.excluded.indexOf(e)>-1}}class cf{constructor(e){this.linebreakReplacement=null,this.cached=Object.create(null);let n=this.spec={};for(let r in e)n[r]=e[r];n.nodes=Ce.from(e.nodes),n.marks=Ce.from(e.marks||{}),this.nodes=us.compile(this.spec.nodes,this),this.marks=to.compile(this.spec.marks,this);let s=Object.create(null);for(let r in this.nodes){if(r in this.marks)throw new RangeError(r+" can not be both a node and a mark");let o=this.nodes[r],i=o.spec.content||"",l=o.spec.marks;if(o.contentMatch=s[i]||(s[i]=Dt.parse(i,this.nodes)),o.inlineContent=o.contentMatch.inlineContent,o.spec.linebreakReplacement){if(this.linebreakReplacement)throw new RangeError("Multiple linebreak nodes defined");if(!o.isInline||!o.isLeaf)throw new RangeError("Linebreak replacement nodes must be inline leaf nodes");this.linebreakReplacement=o}o.markSet=l=="_"?null:l?ra(this,l.split(" ")):l==""||!o.inlineContent?[]:null}for(let r in this.marks){let o=this.marks[r],i=o.spec.excludes;o.excluded=i==null?[o]:i==""?[]:ra(this,i.split(" "))}this.nodeFromJSON=r=>Bt.fromJSON(this,r),this.markFromJSON=r=>ee.fromJSON(this,r),this.topNodeType=this.nodes[this.spec.topNode||"doc"],this.cached.wrappings=Object.create(null)}node(e,n=null,s,r){if(typeof e=="string")e=this.nodeType(e);else if(e instanceof us){if(e.schema!=this)throw new RangeError("Node type from different schema used ("+e.name+")")}else throw new RangeError("Invalid node type: "+e);return e.createChecked(n,s,r)}text(e,n){let s=this.nodes.text;return new ds(s,s.defaultAttrs,e,ee.setFrom(n))}mark(e,n){return typeof e=="string"&&(e=this.marks[e]),e.create(n)}nodeType(e){let n=this.nodes[e];if(!n)throw new RangeError("Unknown node type: "+e);return n}}function ra(t,e){let n=[];for(let s=0;s<e.length;s++){let r=e[s],o=t.marks[r],i=o;if(o)n.push(o);else for(let l in t.marks){let c=t.marks[l];(r=="_"||c.spec.group&&c.spec.group.split(" ").indexOf(r)>-1)&&n.push(i=c)}if(!i)throw new SyntaxError("Unknown mark type: '"+e[s]+"'")}return n}function df(t){return t.tag!=null}function uf(t){return t.style!=null}class Kt{constructor(e,n){this.schema=e,this.rules=n,this.tags=[],this.styles=[];let s=this.matchedStyles=[];n.forEach(r=>{if(df(r))this.tags.push(r);else if(uf(r)){let o=/[^=]*/.exec(r.style)[0];s.indexOf(o)<0&&s.push(o),this.styles.push(r)}}),this.normalizeLists=!this.tags.some(r=>{if(!/^(ul|ol)\b/.test(r.tag)||!r.node)return!1;let o=e.nodes[r.node];return o.contentMatch.matchType(o)})}parse(e,n={}){let s=new aa(this,n,!1);return s.addAll(e,ee.none,n.from,n.to),s.finish()}parseSlice(e,n={}){let s=new aa(this,n,!0);return s.addAll(e,ee.none,n.from,n.to),V.maxOpen(s.finish())}matchTag(e,n,s){for(let r=s?this.tags.indexOf(s)+1:0;r<this.tags.length;r++){let o=this.tags[r];if(hf(e,o.tag)&&(o.namespace===void 0||e.namespaceURI==o.namespace)&&(!o.context||n.matchesContext(o.context))){if(o.getAttrs){let i=o.getAttrs(e);if(i===!1)continue;o.attrs=i||void 0}return o}}}matchStyle(e,n,s,r){for(let o=r?this.styles.indexOf(r)+1:0;o<this.styles.length;o++){let i=this.styles[o],l=i.style;if(!(l.indexOf(e)!=0||i.context&&!s.matchesContext(i.context)||l.length>e.length&&(l.charCodeAt(e.length)!=61||l.slice(e.length+1)!=n))){if(i.getAttrs){let c=i.getAttrs(n);if(c===!1)continue;i.attrs=c||void 0}return i}}}static schemaRules(e){let n=[];function s(r){let o=r.priority==null?50:r.priority,i=0;for(;i<n.length;i++){let l=n[i];if((l.priority==null?50:l.priority)<o)break}n.splice(i,0,r)}for(let r in e.marks){let o=e.marks[r].spec.parseDOM;o&&o.forEach(i=>{s(i=ia(i)),i.mark||i.ignore||i.clearMark||(i.mark=r)})}for(let r in e.nodes){let o=e.nodes[r].spec.parseDOM;o&&o.forEach(i=>{s(i=ia(i)),i.node||i.ignore||i.mark||(i.node=r)})}return n}static fromSchema(e){return e.cached.domParser||(e.cached.domParser=new Kt(e,Kt.schemaRules(e)))}}const rl={address:!0,article:!0,aside:!0,blockquote:!0,canvas:!0,dd:!0,div:!0,dl:!0,fieldset:!0,figcaption:!0,figure:!0,footer:!0,form:!0,h1:!0,h2:!0,h3:!0,h4:!0,h5:!0,h6:!0,header:!0,hgroup:!0,hr:!0,li:!0,noscript:!0,ol:!0,output:!0,p:!0,pre:!0,section:!0,table:!0,tfoot:!0,ul:!0},pf={head:!0,noscript:!0,object:!0,script:!0,style:!0,title:!0},ol={ol:!0,ul:!0},jn=1,gr=2,yn=4;function oa(t,e,n){return e!=null?(e?jn:0)|(e==="full"?gr:0):t&&t.whitespace=="pre"?jn|gr:n&~yn}class Gn{constructor(e,n,s,r,o,i){this.type=e,this.attrs=n,this.marks=s,this.solid=r,this.options=i,this.content=[],this.activeMarks=ee.none,this.match=o||(i&yn?null:e.contentMatch)}findWrapping(e){if(!this.match){if(!this.type)return[];let n=this.type.contentMatch.fillBefore(M.from(e));if(n)this.match=this.type.contentMatch.matchFragment(n);else{let s=this.type.contentMatch,r;return(r=s.findWrapping(e.type))?(this.match=s,r):null}}return this.match.findWrapping(e.type)}finish(e){if(!(this.options&jn)){let s=this.content[this.content.length-1],r;if(s&&s.isText&&(r=/[ \t\r\n\u000c]+$/.exec(s.text))){let o=s;s.text.length==r[0].length?this.content.pop():this.content[this.content.length-1]=o.withText(o.text.slice(0,o.text.length-r[0].length))}}let n=M.from(this.content);return!e&&this.match&&(n=n.append(this.match.fillBefore(M.empty,!0))),this.type?this.type.create(this.attrs,n,this.marks):n}inlineContext(e){return this.type?this.type.inlineContent:this.content.length?this.content[0].isInline:e.parentNode&&!rl.hasOwnProperty(e.parentNode.nodeName.toLowerCase())}}class aa{constructor(e,n,s){this.parser=e,this.options=n,this.isOpen=s,this.open=0,this.localPreserveWS=!1;let r=n.topNode,o,i=oa(null,n.preserveWhitespace,0)|(s?yn:0);r?o=new Gn(r.type,r.attrs,ee.none,!0,n.topMatch||r.type.contentMatch,i):s?o=new Gn(null,null,ee.none,!0,null,i):o=new Gn(e.schema.topNodeType,null,ee.none,!0,null,i),this.nodes=[o],this.find=n.findPositions,this.needsBlock=!1}get top(){return this.nodes[this.open]}addDOM(e,n){e.nodeType==3?this.addTextNode(e,n):e.nodeType==1&&this.addElement(e,n)}addTextNode(e,n){let s=e.nodeValue,r=this.top,o=r.options&gr?"full":this.localPreserveWS||(r.options&jn)>0,{schema:i}=this.parser;if(o==="full"||r.inlineContext(e)||/[^ \t\r\n\u000c]/.test(s)){if(o)if(o==="full")s=s.replace(/\r\n?/g,`
|
|
131
|
+
`);else if(i.linebreakReplacement&&/[\r\n]/.test(s)&&this.top.findWrapping(i.linebreakReplacement.create())){let l=s.split(/\r?\n|\r/);for(let c=0;c<l.length;c++)c&&this.insertNode(i.linebreakReplacement.create(),n,!0),l[c]&&this.insertNode(i.text(l[c]),n,!/\S/.test(l[c]));s=""}else s=s.replace(/\r?\n|\r/g," ");else if(s=s.replace(/[ \t\r\n\u000c]+/g," "),/^[ \t\r\n\u000c]/.test(s)&&this.open==this.nodes.length-1){let l=r.content[r.content.length-1],c=e.previousSibling;(!l||c&&c.nodeName=="BR"||l.isText&&/[ \t\r\n\u000c]$/.test(l.text))&&(s=s.slice(1))}s&&this.insertNode(i.text(s),n,!/\S/.test(s)),this.findInText(e)}else this.findInside(e)}addElement(e,n,s){let r=this.localPreserveWS,o=this.top;(e.tagName=="PRE"||/pre/.test(e.style&&e.style.whiteSpace))&&(this.localPreserveWS=!0);let i=e.nodeName.toLowerCase(),l;ol.hasOwnProperty(i)&&this.parser.normalizeLists&&ff(e);let c=this.options.ruleFromNode&&this.options.ruleFromNode(e)||(l=this.parser.matchTag(e,this,s));e:if(c?c.ignore:pf.hasOwnProperty(i))this.findInside(e),this.ignoreFallback(e,n);else if(!c||c.skip||c.closeParent){c&&c.closeParent?this.open=Math.max(0,this.open-1):c&&c.skip.nodeType&&(e=c.skip);let u,p=this.needsBlock;if(rl.hasOwnProperty(i))o.content.length&&o.content[0].isInline&&this.open&&(this.open--,o=this.top),u=!0,o.type||(this.needsBlock=!0);else if(!e.firstChild){this.leafFallback(e,n);break e}let f=c&&c.skip?n:this.readStyles(e,n);f&&this.addAll(e,f),u&&this.sync(o),this.needsBlock=p}else{let u=this.readStyles(e,n);u&&this.addElementByRule(e,c,u,c.consuming===!1?l:void 0)}this.localPreserveWS=r}leafFallback(e,n){e.nodeName=="BR"&&this.top.type&&this.top.type.inlineContent&&this.addTextNode(e.ownerDocument.createTextNode(`
|
|
132
|
+
`),n)}ignoreFallback(e,n){e.nodeName=="BR"&&(!this.top.type||!this.top.type.inlineContent)&&this.findPlace(this.parser.schema.text("-"),n,!0)}readStyles(e,n){let s=e.style;if(s&&s.length)for(let r=0;r<this.parser.matchedStyles.length;r++){let o=this.parser.matchedStyles[r],i=s.getPropertyValue(o);if(i)for(let l=void 0;;){let c=this.parser.matchStyle(o,i,this,l);if(!c)break;if(c.ignore)return null;if(c.clearMark?n=n.filter(u=>!c.clearMark(u)):n=n.concat(this.parser.schema.marks[c.mark].create(c.attrs)),c.consuming===!1)l=c;else break}}return n}addElementByRule(e,n,s,r){let o,i;if(n.node)if(i=this.parser.schema.nodes[n.node],i.isLeaf)this.insertNode(i.create(n.attrs),s,e.nodeName=="BR")||this.leafFallback(e,s);else{let c=this.enter(i,n.attrs||null,s,n.preserveWhitespace);c&&(o=!0,s=c)}else{let c=this.parser.schema.marks[n.mark];s=s.concat(c.create(n.attrs))}let l=this.top;if(i&&i.isLeaf)this.findInside(e);else if(r)this.addElement(e,s,r);else if(n.getContent)this.findInside(e),n.getContent(e,this.parser.schema).forEach(c=>this.insertNode(c,s,!1));else{let c=e;typeof n.contentElement=="string"?c=e.querySelector(n.contentElement):typeof n.contentElement=="function"?c=n.contentElement(e):n.contentElement&&(c=n.contentElement),this.findAround(e,c,!0),this.addAll(c,s),this.findAround(e,c,!1)}o&&this.sync(l)&&this.open--}addAll(e,n,s,r){let o=s||0;for(let i=s?e.childNodes[s]:e.firstChild,l=r==null?null:e.childNodes[r];i!=l;i=i.nextSibling,++o)this.findAtPoint(e,o),this.addDOM(i,n);this.findAtPoint(e,o)}findPlace(e,n,s){let r,o;for(let i=this.open,l=0;i>=0;i--){let c=this.nodes[i],u=c.findWrapping(e);if(u&&(!r||r.length>u.length+l)&&(r=u,o=c,!u.length))break;if(c.solid){if(s)break;l+=2}}if(!r)return null;this.sync(o);for(let i=0;i<r.length;i++)n=this.enterInner(r[i],null,n,!1);return n}insertNode(e,n,s){if(e.isInline&&this.needsBlock&&!this.top.type){let o=this.textblockFromContext();o&&(n=this.enterInner(o,null,n))}let r=this.findPlace(e,n,s);if(r){this.closeExtra();let o=this.top;o.match&&(o.match=o.match.matchType(e.type));let i=ee.none;for(let l of r.concat(e.marks))(o.type?o.type.allowsMarkType(l.type):la(l.type,e.type))&&(i=l.addToSet(i));return o.content.push(e.mark(i)),!0}return!1}enter(e,n,s,r){let o=this.findPlace(e.create(n),s,!1);return o&&(o=this.enterInner(e,n,s,!0,r)),o}enterInner(e,n,s,r=!1,o){this.closeExtra();let i=this.top;i.match=i.match&&i.match.matchType(e);let l=oa(e,o,i.options);i.options&yn&&i.content.length==0&&(l|=yn);let c=ee.none;return s=s.filter(u=>(i.type?i.type.allowsMarkType(u.type):la(u.type,e))?(c=u.addToSet(c),!1):!0),this.nodes.push(new Gn(e,n,c,r,null,l)),this.open++,s}closeExtra(e=!1){let n=this.nodes.length-1;if(n>this.open){for(;n>this.open;n--)this.nodes[n-1].content.push(this.nodes[n].finish(e));this.nodes.length=this.open+1}}finish(){return this.open=0,this.closeExtra(this.isOpen),this.nodes[0].finish(!!(this.isOpen||this.options.topOpen))}sync(e){for(let n=this.open;n>=0;n--){if(this.nodes[n]==e)return this.open=n,!0;this.localPreserveWS&&(this.nodes[n].options|=jn)}return!1}get currentPos(){this.closeExtra();let e=0;for(let n=this.open;n>=0;n--){let s=this.nodes[n].content;for(let r=s.length-1;r>=0;r--)e+=s[r].nodeSize;n&&e++}return e}findAtPoint(e,n){if(this.find)for(let s=0;s<this.find.length;s++)this.find[s].node==e&&this.find[s].offset==n&&(this.find[s].pos=this.currentPos)}findInside(e){if(this.find)for(let n=0;n<this.find.length;n++)this.find[n].pos==null&&e.nodeType==1&&e.contains(this.find[n].node)&&(this.find[n].pos=this.currentPos)}findAround(e,n,s){if(e!=n&&this.find)for(let r=0;r<this.find.length;r++)this.find[r].pos==null&&e.nodeType==1&&e.contains(this.find[r].node)&&n.compareDocumentPosition(this.find[r].node)&(s?2:4)&&(this.find[r].pos=this.currentPos)}findInText(e){if(this.find)for(let n=0;n<this.find.length;n++)this.find[n].node==e&&(this.find[n].pos=this.currentPos-(e.nodeValue.length-this.find[n].offset))}matchesContext(e){if(e.indexOf("|")>-1)return e.split(/\s*\|\s*/).some(this.matchesContext,this);let n=e.split("/"),s=this.options.context,r=!this.isOpen&&(!s||s.parent.type==this.nodes[0].type),o=-(s?s.depth+1:0)+(r?0:1),i=(l,c)=>{for(;l>=0;l--){let u=n[l];if(u==""){if(l==n.length-1||l==0)continue;for(;c>=o;c--)if(i(l-1,c))return!0;return!1}else{let p=c>0||c==0&&r?this.nodes[c].type:s&&c>=o?s.node(c-o).type:null;if(!p||p.name!=u&&!p.isInGroup(u))return!1;c--}}return!0};return i(n.length-1,this.open)}textblockFromContext(){let e=this.options.context;if(e)for(let n=e.depth;n>=0;n--){let s=e.node(n).contentMatchAt(e.indexAfter(n)).defaultType;if(s&&s.isTextblock&&s.defaultAttrs)return s}for(let n in this.parser.schema.nodes){let s=this.parser.schema.nodes[n];if(s.isTextblock&&s.defaultAttrs)return s}}}function ff(t){for(let e=t.firstChild,n=null;e;e=e.nextSibling){let s=e.nodeType==1?e.nodeName.toLowerCase():null;s&&ol.hasOwnProperty(s)&&n?(n.appendChild(e),e=n):s=="li"?n=e:s&&(n=null)}}function hf(t,e){return(t.matches||t.msMatchesSelector||t.webkitMatchesSelector||t.mozMatchesSelector).call(t,e)}function ia(t){let e={};for(let n in t)e[n]=t[n];return e}function la(t,e){let n=e.schema.nodes;for(let s in n){let r=n[s];if(!r.allowsMarkType(t))continue;let o=[],i=l=>{o.push(l);for(let c=0;c<l.edgeCount;c++){let{type:u,next:p}=l.edge(c);if(u==e||o.indexOf(p)<0&&i(p))return!0}};if(i(r.contentMatch))return!0}}const al=65535,il=Math.pow(2,16);function mf(t,e){return t+e*il}function ca(t){return t&al}function gf(t){return(t-(t&al))/il}const ll=1,cl=2,Jn=4,dl=8;class da{constructor(e,n,s){this.pos=e,this.delInfo=n,this.recover=s}get deleted(){return(this.delInfo&dl)>0}get deletedBefore(){return(this.delInfo&(ll|Jn))>0}get deletedAfter(){return(this.delInfo&(cl|Jn))>0}get deletedAcross(){return(this.delInfo&Jn)>0}}class ze{constructor(e,n=!1){if(this.ranges=e,this.inverted=n,!e.length&&ze.empty)return ze.empty}recover(e){let n=0,s=ca(e);if(!this.inverted)for(let r=0;r<s;r++)n+=this.ranges[r*3+2]-this.ranges[r*3+1];return this.ranges[s*3]+n+gf(e)}mapResult(e,n=1){return this._map(e,n,!1)}map(e,n=1){return this._map(e,n,!0)}_map(e,n,s){let r=0,o=this.inverted?2:1,i=this.inverted?1:2;for(let l=0;l<this.ranges.length;l+=3){let c=this.ranges[l]-(this.inverted?r:0);if(c>e)break;let u=this.ranges[l+o],p=this.ranges[l+i],f=c+u;if(e<=f){let m=u?e==c?-1:e==f?1:n:n,h=c+r+(m<0?0:p);if(s)return h;let x=e==(n<0?c:f)?null:mf(l/3,e-c),b=e==c?cl:e==f?ll:Jn;return(n<0?e!=c:e!=f)&&(b|=dl),new da(h,b,x)}r+=p-u}return s?e+r:new da(e+r,0,null)}touches(e,n){let s=0,r=ca(n),o=this.inverted?2:1,i=this.inverted?1:2;for(let l=0;l<this.ranges.length;l+=3){let c=this.ranges[l]-(this.inverted?s:0);if(c>e)break;let u=this.ranges[l+o],p=c+u;if(e<=p&&l==r*3)return!0;s+=this.ranges[l+i]-u}return!1}forEach(e){let n=this.inverted?2:1,s=this.inverted?1:2;for(let r=0,o=0;r<this.ranges.length;r+=3){let i=this.ranges[r],l=i-(this.inverted?o:0),c=i+(this.inverted?0:o),u=this.ranges[r+n],p=this.ranges[r+s];e(l,l+u,c,c+p),o+=p-u}}invert(){return new ze(this.ranges,!this.inverted)}toString(){return(this.inverted?"-":"")+JSON.stringify(this.ranges)}static offset(e){return e==0?ze.empty:new ze(e<0?[0,-e,0]:[0,0,e])}}ze.empty=new ze([]);const Js=Object.create(null);class Te{getMap(){return ze.empty}merge(e){return null}static fromJSON(e,n){if(!n||!n.stepType)throw new RangeError("Invalid input for Step.fromJSON");let s=Js[n.stepType];if(!s)throw new RangeError(`No step type ${n.stepType} defined`);return s.fromJSON(e,n)}static jsonID(e,n){if(e in Js)throw new RangeError("Duplicate use of step JSON ID "+e);return Js[e]=n,n.prototype.jsonID=e,n}}class ye{constructor(e,n){this.doc=e,this.failed=n}static ok(e){return new ye(e,null)}static fail(e){return new ye(null,e)}static fromReplace(e,n,s,r){try{return ye.ok(e.replace(n,s,r))}catch(o){if(o instanceof is)return ye.fail(o.message);throw o}}}function no(t,e,n){let s=[];for(let r=0;r<t.childCount;r++){let o=t.child(r);o.content.size&&(o=o.copy(no(o.content,e,o))),o.isInline&&(o=e(o,n,r)),s.push(o)}return M.fromArray(s)}class Ct extends Te{constructor(e,n,s){super(),this.from=e,this.to=n,this.mark=s}apply(e){let n=e.slice(this.from,this.to),s=e.resolve(this.from),r=s.node(s.sharedDepth(this.to)),o=new V(no(n.content,(i,l)=>!i.isAtom||!l.type.allowsMarkType(this.mark.type)?i:i.mark(this.mark.addToSet(i.marks)),r),n.openStart,n.openEnd);return ye.fromReplace(e,this.from,this.to,o)}invert(){return new jt(this.from,this.to,this.mark)}map(e){let n=e.mapResult(this.from,1),s=e.mapResult(this.to,-1);return n.deleted&&s.deleted||n.pos>=s.pos?null:new Ct(n.pos,s.pos,this.mark)}merge(e){return e instanceof Ct&&e.mark.eq(this.mark)&&this.from<=e.to&&this.to>=e.from?new Ct(Math.min(this.from,e.from),Math.max(this.to,e.to),this.mark):null}toJSON(){return{stepType:"addMark",mark:this.mark.toJSON(),from:this.from,to:this.to}}static fromJSON(e,n){if(typeof n.from!="number"||typeof n.to!="number")throw new RangeError("Invalid input for AddMarkStep.fromJSON");return new Ct(n.from,n.to,e.markFromJSON(n.mark))}}Te.jsonID("addMark",Ct);class jt extends Te{constructor(e,n,s){super(),this.from=e,this.to=n,this.mark=s}apply(e){let n=e.slice(this.from,this.to),s=new V(no(n.content,r=>r.mark(this.mark.removeFromSet(r.marks)),e),n.openStart,n.openEnd);return ye.fromReplace(e,this.from,this.to,s)}invert(){return new Ct(this.from,this.to,this.mark)}map(e){let n=e.mapResult(this.from,1),s=e.mapResult(this.to,-1);return n.deleted&&s.deleted||n.pos>=s.pos?null:new jt(n.pos,s.pos,this.mark)}merge(e){return e instanceof jt&&e.mark.eq(this.mark)&&this.from<=e.to&&this.to>=e.from?new jt(Math.min(this.from,e.from),Math.max(this.to,e.to),this.mark):null}toJSON(){return{stepType:"removeMark",mark:this.mark.toJSON(),from:this.from,to:this.to}}static fromJSON(e,n){if(typeof n.from!="number"||typeof n.to!="number")throw new RangeError("Invalid input for RemoveMarkStep.fromJSON");return new jt(n.from,n.to,e.markFromJSON(n.mark))}}Te.jsonID("removeMark",jt);class St extends Te{constructor(e,n){super(),this.pos=e,this.mark=n}apply(e){let n=e.nodeAt(this.pos);if(!n)return ye.fail("No node at mark step's position");let s=n.type.create(n.attrs,null,this.mark.addToSet(n.marks));return ye.fromReplace(e,this.pos,this.pos+1,new V(M.from(s),0,n.isLeaf?0:1))}invert(e){let n=e.nodeAt(this.pos);if(n){let s=this.mark.addToSet(n.marks);if(s.length==n.marks.length){for(let r=0;r<n.marks.length;r++)if(!n.marks[r].isInSet(s))return new St(this.pos,n.marks[r]);return new St(this.pos,this.mark)}}return new Sn(this.pos,this.mark)}map(e){let n=e.mapResult(this.pos,1);return n.deletedAfter?null:new St(n.pos,this.mark)}toJSON(){return{stepType:"addNodeMark",pos:this.pos,mark:this.mark.toJSON()}}static fromJSON(e,n){if(typeof n.pos!="number")throw new RangeError("Invalid input for AddNodeMarkStep.fromJSON");return new St(n.pos,e.markFromJSON(n.mark))}}Te.jsonID("addNodeMark",St);class Sn extends Te{constructor(e,n){super(),this.pos=e,this.mark=n}apply(e){let n=e.nodeAt(this.pos);if(!n)return ye.fail("No node at mark step's position");let s=n.type.create(n.attrs,null,this.mark.removeFromSet(n.marks));return ye.fromReplace(e,this.pos,this.pos+1,new V(M.from(s),0,n.isLeaf?0:1))}invert(e){let n=e.nodeAt(this.pos);return!n||!this.mark.isInSet(n.marks)?this:new St(this.pos,this.mark)}map(e){let n=e.mapResult(this.pos,1);return n.deletedAfter?null:new Sn(n.pos,this.mark)}toJSON(){return{stepType:"removeNodeMark",pos:this.pos,mark:this.mark.toJSON()}}static fromJSON(e,n){if(typeof n.pos!="number")throw new RangeError("Invalid input for RemoveNodeMarkStep.fromJSON");return new Sn(n.pos,e.markFromJSON(n.mark))}}Te.jsonID("removeNodeMark",Sn);class Fe extends Te{constructor(e,n,s,r=!1){super(),this.from=e,this.to=n,this.slice=s,this.structure=r}apply(e){return this.structure&&xr(e,this.from,this.to)?ye.fail("Structure replace would overwrite content"):ye.fromReplace(e,this.from,this.to,this.slice)}getMap(){return new ze([this.from,this.to-this.from,this.slice.size])}invert(e){return new Fe(this.from,this.from+this.slice.size,e.slice(this.from,this.to))}map(e){let n=e.mapResult(this.from,1),s=e.mapResult(this.to,-1);return n.deletedAcross&&s.deletedAcross?null:new Fe(n.pos,Math.max(n.pos,s.pos),this.slice,this.structure)}merge(e){if(!(e instanceof Fe)||e.structure||this.structure)return null;if(this.from+this.slice.size==e.from&&!this.slice.openEnd&&!e.slice.openStart){let n=this.slice.size+e.slice.size==0?V.empty:new V(this.slice.content.append(e.slice.content),this.slice.openStart,e.slice.openEnd);return new Fe(this.from,this.to+(e.to-e.from),n,this.structure)}else if(e.to==this.from&&!this.slice.openStart&&!e.slice.openEnd){let n=this.slice.size+e.slice.size==0?V.empty:new V(e.slice.content.append(this.slice.content),e.slice.openStart,this.slice.openEnd);return new Fe(e.from,this.to,n,this.structure)}else return null}toJSON(){let e={stepType:"replace",from:this.from,to:this.to};return this.slice.size&&(e.slice=this.slice.toJSON()),this.structure&&(e.structure=!0),e}static fromJSON(e,n){if(typeof n.from!="number"||typeof n.to!="number")throw new RangeError("Invalid input for ReplaceStep.fromJSON");return new Fe(n.from,n.to,V.fromJSON(e,n.slice),!!n.structure)}}Te.jsonID("replace",Fe);class Me extends Te{constructor(e,n,s,r,o,i,l=!1){super(),this.from=e,this.to=n,this.gapFrom=s,this.gapTo=r,this.slice=o,this.insert=i,this.structure=l}apply(e){if(this.structure&&(xr(e,this.from,this.gapFrom)||xr(e,this.gapTo,this.to)))return ye.fail("Structure gap-replace would overwrite content");let n=e.slice(this.gapFrom,this.gapTo);if(n.openStart||n.openEnd)return ye.fail("Gap is not a flat range");let s=this.slice.insertAt(this.insert,n.content);return s?ye.fromReplace(e,this.from,this.to,s):ye.fail("Content does not fit in gap")}getMap(){return new ze([this.from,this.gapFrom-this.from,this.insert,this.gapTo,this.to-this.gapTo,this.slice.size-this.insert])}invert(e){let n=this.gapTo-this.gapFrom;return new Me(this.from,this.from+this.slice.size+n,this.from+this.insert,this.from+this.insert+n,e.slice(this.from,this.to).removeBetween(this.gapFrom-this.from,this.gapTo-this.from),this.gapFrom-this.from,this.structure)}map(e){let n=e.mapResult(this.from,1),s=e.mapResult(this.to,-1),r=this.from==this.gapFrom?n.pos:e.map(this.gapFrom,-1),o=this.to==this.gapTo?s.pos:e.map(this.gapTo,1);return n.deletedAcross&&s.deletedAcross||r<n.pos||o>s.pos?null:new Me(n.pos,s.pos,r,o,this.slice,this.insert,this.structure)}toJSON(){let e={stepType:"replaceAround",from:this.from,to:this.to,gapFrom:this.gapFrom,gapTo:this.gapTo,insert:this.insert};return this.slice.size&&(e.slice=this.slice.toJSON()),this.structure&&(e.structure=!0),e}static fromJSON(e,n){if(typeof n.from!="number"||typeof n.to!="number"||typeof n.gapFrom!="number"||typeof n.gapTo!="number"||typeof n.insert!="number")throw new RangeError("Invalid input for ReplaceAroundStep.fromJSON");return new Me(n.from,n.to,n.gapFrom,n.gapTo,V.fromJSON(e,n.slice),n.insert,!!n.structure)}}Te.jsonID("replaceAround",Me);function xr(t,e,n){let s=t.resolve(e),r=n-e,o=s.depth;for(;r>0&&o>0&&s.indexAfter(o)==s.node(o).childCount;)o--,r--;if(r>0){let i=s.node(o).maybeChild(s.indexAfter(o));for(;r>0;){if(!i||i.isLeaf)return!0;i=i.firstChild,r--}}return!1}function xf(t,e,n){return(e==0||t.canReplace(e,t.childCount))&&(n==t.childCount||t.canReplace(0,n))}function ln(t){let n=t.parent.content.cutByIndex(t.startIndex,t.endIndex);for(let s=t.depth,r=0,o=0;;--s){let i=t.$from.node(s),l=t.$from.index(s)+r,c=t.$to.indexAfter(s)-o;if(s<t.depth&&i.canReplace(l,c,n))return s;if(s==0||i.type.spec.isolating||!xf(i,l,c))break;l&&(r=1),c<i.childCount&&(o=1)}return null}function ul(t,e,n=null,s=t){let r=bf(t,e),o=r&&yf(s,e);return o?r.map(ua).concat({type:e,attrs:n}).concat(o.map(ua)):null}function ua(t){return{type:t,attrs:null}}function bf(t,e){let{parent:n,startIndex:s,endIndex:r}=t,o=n.contentMatchAt(s).findWrapping(e);if(!o)return null;let i=o.length?o[0]:e;return n.canReplaceWith(s,r,i)?o:null}function yf(t,e){let{parent:n,startIndex:s,endIndex:r}=t,o=n.child(s),i=e.contentMatch.findWrapping(o.type);if(!i)return null;let c=(i.length?i[i.length-1]:e).contentMatch;for(let u=s;c&&u<r;u++)c=c.matchType(n.child(u).type);return!c||!c.validEnd?null:i}function dt(t,e,n=1,s){let r=t.resolve(e),o=r.depth-n,i=s&&s[s.length-1]||r.parent;if(o<0||r.parent.type.spec.isolating||!r.parent.canReplace(r.index(),r.parent.childCount)||!i.type.validContent(r.parent.content.cutByIndex(r.index(),r.parent.childCount)))return!1;for(let u=r.depth-1,p=n-2;u>o;u--,p--){let f=r.node(u),m=r.index(u);if(f.type.spec.isolating)return!1;let h=f.content.cutByIndex(m,f.childCount),x=s&&s[p+1];x&&(h=h.replaceChild(0,x.type.create(x.attrs)));let b=s&&s[p]||f;if(!f.canReplace(m+1,f.childCount)||!b.type.validContent(h))return!1}let l=r.indexAfter(o),c=s&&s[0];return r.node(o).canReplaceWith(l,l,c?c.type:r.node(o+1).type)}function zt(t,e){let n=t.resolve(e),s=n.index();return pl(n.nodeBefore,n.nodeAfter)&&n.parent.canReplace(s,s+1)}function kf(t,e){e.content.size||t.type.compatibleContent(e.type);let n=t.contentMatchAt(t.childCount),{linebreakReplacement:s}=t.type.schema;for(let r=0;r<e.childCount;r++){let o=e.child(r),i=o.type==s?t.type.schema.nodes.text:o.type;if(n=n.matchType(i),!n||!t.type.allowsMarks(o.marks))return!1}return n.validEnd}function pl(t,e){return!!(t&&e&&!t.isLeaf&&kf(t,e))}function Ts(t,e,n=-1){let s=t.resolve(e);for(let r=s.depth;;r--){let o,i,l=s.index(r);if(r==s.depth?(o=s.nodeBefore,i=s.nodeAfter):n>0?(o=s.node(r+1),l++,i=s.node(r).maybeChild(l)):(o=s.node(r).maybeChild(l-1),i=s.node(r+1)),o&&!o.isTextblock&&pl(o,i)&&s.node(r).canReplace(l,l+1))return e;if(r==0)break;e=n<0?s.before(r):s.after(r)}}function so(t,e,n=e,s=V.empty){if(e==n&&!s.size)return null;let r=t.resolve(e),o=t.resolve(n);return vf(r,o,s)?new Fe(e,n,s):new wf(r,o,s).fit()}function vf(t,e,n){return!n.openStart&&!n.openEnd&&t.start()==e.start()&&t.parent.canReplace(t.index(),e.index(),n.content)}class wf{constructor(e,n,s){this.$from=e,this.$to=n,this.unplaced=s,this.frontier=[],this.placed=M.empty;for(let r=0;r<=e.depth;r++){let o=e.node(r);this.frontier.push({type:o.type,match:o.contentMatchAt(e.indexAfter(r))})}for(let r=e.depth;r>0;r--)this.placed=M.from(e.node(r).copy(this.placed))}get depth(){return this.frontier.length-1}fit(){for(;this.unplaced.size;){let u=this.findFittable();u?this.placeNodes(u):this.openMore()||this.dropNode()}let e=this.mustMoveInline(),n=this.placed.size-this.depth-this.$from.depth,s=this.$from,r=this.close(e<0?this.$to:s.doc.resolve(e));if(!r)return null;let o=this.placed,i=s.depth,l=r.depth;for(;i&&l&&o.childCount==1;)o=o.firstChild.content,i--,l--;let c=new V(o,i,l);return e>-1?new Me(s.pos,e,this.$to.pos,this.$to.end(),c,n):c.size||s.pos!=this.$to.pos?new Fe(s.pos,r.pos,c):null}findFittable(){let e=this.unplaced.openStart;for(let n=this.unplaced.content,s=0,r=this.unplaced.openEnd;s<e;s++){let o=n.firstChild;if(n.childCount>1&&(r=0),o.type.spec.isolating&&r<=s){e=s;break}n=o.content}for(let n=1;n<=2;n++)for(let s=n==1?e:this.unplaced.openStart;s>=0;s--){let r,o=null;s?(o=Zs(this.unplaced.content,s-1).firstChild,r=o.content):r=this.unplaced.content;let i=r.firstChild;for(let l=this.depth;l>=0;l--){let{type:c,match:u}=this.frontier[l],p,f=null;if(n==1&&(i?u.matchType(i.type)||(f=u.fillBefore(M.from(i),!1)):o&&c.compatibleContent(o.type)))return{sliceDepth:s,frontierDepth:l,parent:o,inject:f};if(n==2&&i&&(p=u.findWrapping(i.type)))return{sliceDepth:s,frontierDepth:l,parent:o,wrap:p};if(o&&u.matchType(o.type))break}}}openMore(){let{content:e,openStart:n,openEnd:s}=this.unplaced,r=Zs(e,n);return!r.childCount||r.firstChild.isLeaf?!1:(this.unplaced=new V(e,n+1,Math.max(s,r.size+n>=e.size-s?n+1:0)),!0)}dropNode(){let{content:e,openStart:n,openEnd:s}=this.unplaced,r=Zs(e,n);if(r.childCount<=1&&n>0){let o=e.size-n<=n+r.size;this.unplaced=new V(mn(e,n-1,1),n-1,o?n-1:s)}else this.unplaced=new V(mn(e,n,1),n,s)}placeNodes({sliceDepth:e,frontierDepth:n,parent:s,inject:r,wrap:o}){for(;this.depth>n;)this.closeFrontierNode();if(o)for(let b=0;b<o.length;b++)this.openFrontierNode(o[b]);let i=this.unplaced,l=s?s.content:i.content,c=i.openStart-e,u=0,p=[],{match:f,type:m}=this.frontier[n];if(r){for(let b=0;b<r.childCount;b++)p.push(r.child(b));f=f.matchFragment(r)}let h=l.size+e-(i.content.size-i.openEnd);for(;u<l.childCount;){let b=l.child(u),y=f.matchType(b.type);if(!y)break;u++,(u>1||c==0||b.content.size)&&(f=y,p.push(fl(b.mark(m.allowedMarks(b.marks)),u==1?c:0,u==l.childCount?h:-1)))}let x=u==l.childCount;x||(h=-1),this.placed=gn(this.placed,n,M.from(p)),this.frontier[n].match=f,x&&h<0&&s&&s.type==this.frontier[this.depth].type&&this.frontier.length>1&&this.closeFrontierNode();for(let b=0,y=l;b<h;b++){let v=y.lastChild;this.frontier.push({type:v.type,match:v.contentMatchAt(v.childCount)}),y=v.content}this.unplaced=x?e==0?V.empty:new V(mn(i.content,e-1,1),e-1,h<0?i.openEnd:e-1):new V(mn(i.content,e,u),i.openStart,i.openEnd)}mustMoveInline(){if(!this.$to.parent.isTextblock)return-1;let e=this.frontier[this.depth],n;if(!e.type.isTextblock||!Qs(this.$to,this.$to.depth,e.type,e.match,!1)||this.$to.depth==this.depth&&(n=this.findCloseLevel(this.$to))&&n.depth==this.depth)return-1;let{depth:s}=this.$to,r=this.$to.after(s);for(;s>1&&r==this.$to.end(--s);)++r;return r}findCloseLevel(e){e:for(let n=Math.min(this.depth,e.depth);n>=0;n--){let{match:s,type:r}=this.frontier[n],o=n<e.depth&&e.end(n+1)==e.pos+(e.depth-(n+1)),i=Qs(e,n,r,s,o);if(i){for(let l=n-1;l>=0;l--){let{match:c,type:u}=this.frontier[l],p=Qs(e,l,u,c,!0);if(!p||p.childCount)continue e}return{depth:n,fit:i,move:o?e.doc.resolve(e.after(n+1)):e}}}}close(e){let n=this.findCloseLevel(e);if(!n)return null;for(;this.depth>n.depth;)this.closeFrontierNode();n.fit.childCount&&(this.placed=gn(this.placed,n.depth,n.fit)),e=n.move;for(let s=n.depth+1;s<=e.depth;s++){let r=e.node(s),o=r.type.contentMatch.fillBefore(r.content,!0,e.index(s));this.openFrontierNode(r.type,r.attrs,o)}return e}openFrontierNode(e,n=null,s){let r=this.frontier[this.depth];r.match=r.match.matchType(e),this.placed=gn(this.placed,this.depth,M.from(e.create(n,s))),this.frontier.push({type:e,match:e.contentMatch})}closeFrontierNode(){let n=this.frontier.pop().match.fillBefore(M.empty,!0);n.childCount&&(this.placed=gn(this.placed,this.frontier.length,n))}}function mn(t,e,n){return e==0?t.cutByIndex(n,t.childCount):t.replaceChild(0,t.firstChild.copy(mn(t.firstChild.content,e-1,n)))}function gn(t,e,n){return e==0?t.append(n):t.replaceChild(t.childCount-1,t.lastChild.copy(gn(t.lastChild.content,e-1,n)))}function Zs(t,e){for(let n=0;n<e;n++)t=t.firstChild.content;return t}function fl(t,e,n){if(e<=0)return t;let s=t.content;return e>1&&(s=s.replaceChild(0,fl(s.firstChild,e-1,s.childCount==1?n-1:0))),e>0&&(s=t.type.contentMatch.fillBefore(s).append(s),n<=0&&(s=s.append(t.type.contentMatch.matchFragment(s).fillBefore(M.empty,!0)))),t.copy(s)}function Qs(t,e,n,s,r){let o=t.node(e),i=r?t.indexAfter(e):t.index(e);if(i==o.childCount&&!n.compatibleContent(o.type))return null;let l=s.fillBefore(o.content,!0,i);return l&&!Cf(n,o.content,i)?l:null}function Cf(t,e,n){for(let s=n;s<e.childCount;s++)if(!t.allowsMarks(e.child(s).marks))return!0;return!1}class kn extends Te{constructor(e,n,s){super(),this.pos=e,this.attr=n,this.value=s}apply(e){let n=e.nodeAt(this.pos);if(!n)return ye.fail("No node at attribute step's position");let s=Object.create(null);for(let o in n.attrs)s[o]=n.attrs[o];s[this.attr]=this.value;let r=n.type.create(s,null,n.marks);return ye.fromReplace(e,this.pos,this.pos+1,new V(M.from(r),0,n.isLeaf?0:1))}getMap(){return ze.empty}invert(e){return new kn(this.pos,this.attr,e.nodeAt(this.pos).attrs[this.attr])}map(e){let n=e.mapResult(this.pos,1);return n.deletedAfter?null:new kn(n.pos,this.attr,this.value)}toJSON(){return{stepType:"attr",pos:this.pos,attr:this.attr,value:this.value}}static fromJSON(e,n){if(typeof n.pos!="number"||typeof n.attr!="string")throw new RangeError("Invalid input for AttrStep.fromJSON");return new kn(n.pos,n.attr,n.value)}}Te.jsonID("attr",kn);class ps extends Te{constructor(e,n){super(),this.attr=e,this.value=n}apply(e){let n=Object.create(null);for(let r in e.attrs)n[r]=e.attrs[r];n[this.attr]=this.value;let s=e.type.create(n,e.content,e.marks);return ye.ok(s)}getMap(){return ze.empty}invert(e){return new ps(this.attr,e.attrs[this.attr])}map(e){return this}toJSON(){return{stepType:"docAttr",attr:this.attr,value:this.value}}static fromJSON(e,n){if(typeof n.attr!="string")throw new RangeError("Invalid input for DocAttrStep.fromJSON");return new ps(n.attr,n.value)}}Te.jsonID("docAttr",ps);let Nn=class extends Error{};Nn=function t(e){let n=Error.call(this,e);return n.__proto__=t.prototype,n};Nn.prototype=Object.create(Error.prototype);Nn.prototype.constructor=Nn;Nn.prototype.name="TransformError";const er=Object.create(null);class X{constructor(e,n,s){this.$anchor=e,this.$head=n,this.ranges=s||[new jf(e.min(n),e.max(n))]}get anchor(){return this.$anchor.pos}get head(){return this.$head.pos}get from(){return this.$from.pos}get to(){return this.$to.pos}get $from(){return this.ranges[0].$from}get $to(){return this.ranges[0].$to}get empty(){let e=this.ranges;for(let n=0;n<e.length;n++)if(e[n].$from.pos!=e[n].$to.pos)return!1;return!0}content(){return this.$from.doc.slice(this.from,this.to,!0)}replace(e,n=V.empty){let s=n.content.lastChild,r=null;for(let l=0;l<n.openEnd;l++)r=s,s=s.lastChild;let o=e.steps.length,i=this.ranges;for(let l=0;l<i.length;l++){let{$from:c,$to:u}=i[l],p=e.mapping.slice(o);e.replaceRange(p.map(c.pos),p.map(u.pos),l?V.empty:n),l==0&&ha(e,o,(s?s.isInline:r&&r.isTextblock)?-1:1)}}replaceWith(e,n){let s=e.steps.length,r=this.ranges;for(let o=0;o<r.length;o++){let{$from:i,$to:l}=r[o],c=e.mapping.slice(s),u=c.map(i.pos),p=c.map(l.pos);o?e.deleteRange(u,p):(e.replaceRangeWith(u,p,n),ha(e,s,n.isInline?-1:1))}}static findFrom(e,n,s=!1){let r=e.parent.inlineContent?new oe(e):Ut(e.node(0),e.parent,e.pos,e.index(),n,s);if(r)return r;for(let o=e.depth-1;o>=0;o--){let i=n<0?Ut(e.node(0),e.node(o),e.before(o+1),e.index(o),n,s):Ut(e.node(0),e.node(o),e.after(o+1),e.index(o)+1,n,s);if(i)return i}return null}static near(e,n=1){return this.findFrom(e,n)||this.findFrom(e,-n)||new Ge(e.node(0))}static atStart(e){return Ut(e,e,0,0,1)||new Ge(e)}static atEnd(e){return Ut(e,e,e.content.size,e.childCount,-1)||new Ge(e)}static fromJSON(e,n){if(!n||!n.type)throw new RangeError("Invalid input for Selection.fromJSON");let s=er[n.type];if(!s)throw new RangeError(`No selection type ${n.type} defined`);return s.fromJSON(e,n)}static jsonID(e,n){if(e in er)throw new RangeError("Duplicate use of selection JSON ID "+e);return er[e]=n,n.prototype.jsonID=e,n}getBookmark(){return oe.between(this.$anchor,this.$head).getBookmark()}}X.prototype.visible=!0;class jf{constructor(e,n){this.$from=e,this.$to=n}}let pa=!1;function fa(t){!pa&&!t.parent.inlineContent&&(pa=!0,console.warn("TextSelection endpoint not pointing into a node with inline content ("+t.parent.type.name+")"))}class oe extends X{constructor(e,n=e){fa(e),fa(n),super(e,n)}get $cursor(){return this.$anchor.pos==this.$head.pos?this.$head:null}map(e,n){let s=e.resolve(n.map(this.head));if(!s.parent.inlineContent)return X.near(s);let r=e.resolve(n.map(this.anchor));return new oe(r.parent.inlineContent?r:s,s)}replace(e,n=V.empty){if(super.replace(e,n),n==V.empty){let s=this.$from.marksAcross(this.$to);s&&e.ensureMarks(s)}}eq(e){return e instanceof oe&&e.anchor==this.anchor&&e.head==this.head}getBookmark(){return new Bs(this.anchor,this.head)}toJSON(){return{type:"text",anchor:this.anchor,head:this.head}}static fromJSON(e,n){if(typeof n.anchor!="number"||typeof n.head!="number")throw new RangeError("Invalid input for TextSelection.fromJSON");return new oe(e.resolve(n.anchor),e.resolve(n.head))}static create(e,n,s=n){let r=e.resolve(n);return new this(r,s==n?r:e.resolve(s))}static between(e,n,s){let r=e.pos-n.pos;if((!s||r)&&(s=r>=0?1:-1),!n.parent.inlineContent){let o=X.findFrom(n,s,!0)||X.findFrom(n,-s,!0);if(o)n=o.$head;else return X.near(n,s)}return e.parent.inlineContent||(r==0?e=n:(e=(X.findFrom(e,-s,!0)||X.findFrom(e,s,!0)).$anchor,e.pos<n.pos!=r<0&&(e=n))),new oe(e,n)}}X.jsonID("text",oe);class Bs{constructor(e,n){this.anchor=e,this.head=n}map(e){return new Bs(e.map(this.anchor),e.map(this.head))}resolve(e){return oe.between(e.resolve(this.anchor),e.resolve(this.head))}}class te extends X{constructor(e){let n=e.nodeAfter,s=e.node(0).resolve(e.pos+n.nodeSize);super(e,s),this.node=n}map(e,n){let{deleted:s,pos:r}=n.mapResult(this.anchor),o=e.resolve(r);return s?X.near(o):new te(o)}content(){return new V(M.from(this.node),0,0)}eq(e){return e instanceof te&&e.anchor==this.anchor}toJSON(){return{type:"node",anchor:this.anchor}}getBookmark(){return new ro(this.anchor)}static fromJSON(e,n){if(typeof n.anchor!="number")throw new RangeError("Invalid input for NodeSelection.fromJSON");return new te(e.resolve(n.anchor))}static create(e,n){return new te(e.resolve(n))}static isSelectable(e){return!e.isText&&e.type.spec.selectable!==!1}}te.prototype.visible=!1;X.jsonID("node",te);class ro{constructor(e){this.anchor=e}map(e){let{deleted:n,pos:s}=e.mapResult(this.anchor);return n?new Bs(s,s):new ro(s)}resolve(e){let n=e.resolve(this.anchor),s=n.nodeAfter;return s&&te.isSelectable(s)?new te(n):X.near(n)}}class Ge extends X{constructor(e){super(e.resolve(0),e.resolve(e.content.size))}replace(e,n=V.empty){if(n==V.empty){e.delete(0,e.doc.content.size);let s=X.atStart(e.doc);s.eq(e.selection)||e.setSelection(s)}else super.replace(e,n)}toJSON(){return{type:"all"}}static fromJSON(e){return new Ge(e)}map(e){return new Ge(e)}eq(e){return e instanceof Ge}getBookmark(){return Sf}}X.jsonID("all",Ge);const Sf={map(){return this},resolve(t){return new Ge(t)}};function Ut(t,e,n,s,r,o=!1){if(e.inlineContent)return oe.create(t,n);for(let i=s-(r>0?0:1);r>0?i<e.childCount:i>=0;i+=r){let l=e.child(i);if(l.isAtom){if(!o&&te.isSelectable(l))return te.create(t,n-(r<0?l.nodeSize:0))}else{let c=Ut(t,l,n+r,r<0?l.childCount:0,r,o);if(c)return c}n+=l.nodeSize*r}return null}function ha(t,e,n){let s=t.steps.length-1;if(s<e)return;let r=t.steps[s];if(!(r instanceof Fe||r instanceof Me))return;let o=t.mapping.maps[s],i;o.forEach((l,c,u,p)=>{i==null&&(i=p)}),t.setSelection(X.near(t.doc.resolve(i),n))}function ma(t,e){return!e||!t?t:t.bind(e)}class Un{constructor(e,n,s){this.name=e,this.init=ma(n.init,s),this.apply=ma(n.apply,s)}}new Un("doc",{init(t){return t.doc||t.schema.topNodeType.createAndFill()},apply(t){return t.doc}}),new Un("selection",{init(t,e){return t.selection||X.atStart(e.doc)},apply(t){return t.selection}}),new Un("storedMarks",{init(t){return t.storedMarks||null},apply(t,e,n,s){return s.selection.$cursor?t.storedMarks:null}}),new Un("scrollToSelection",{init(){return 0},apply(t,e){return t.scrolledIntoView?e+1:e}});function hl(t,e,n){for(let s in t){let r=t[s];r instanceof Function?r=r.bind(e):s=="handleDOMEvents"&&(r=hl(r,e,{})),n[s]=r}return n}class Ht{constructor(e){this.spec=e,this.props={},e.props&&hl(e.props,this,this.props),this.key=e.key?e.key.key:ml("plugin")}getState(e){return e[this.key]}}const tr=Object.create(null);function ml(t){return t in tr?t+"$"+ ++tr[t]:(tr[t]=0,t+"$")}class Vt{constructor(e="key"){this.key=ml(e)}get(e){return e.config.pluginsByKey[this.key]}getState(e){return e[this.key]}}const oo=(t,e)=>t.selection.empty?!1:(e&&e(t.tr.deleteSelection().scrollIntoView()),!0);function gl(t,e){let{$cursor:n}=t.selection;return!n||(e?!e.endOfTextblock("backward",t):n.parentOffset>0)?null:n}const xl=(t,e,n)=>{let s=gl(t,n);if(!s)return!1;let r=ao(s);if(!r){let i=s.blockRange(),l=i&&ln(i);return l==null?!1:(e&&e(t.tr.lift(i,l).scrollIntoView()),!0)}let o=r.nodeBefore;if(Nl(t,r,e,-1))return!0;if(s.parent.content.size==0&&(Zt(o,"end")||te.isSelectable(o)))for(let i=s.depth;;i--){let l=so(t.doc,s.before(i),s.after(i),V.empty);if(l&&l.slice.size<l.to-l.from){if(e){let c=t.tr.step(l);c.setSelection(Zt(o,"end")?X.findFrom(c.doc.resolve(c.mapping.map(r.pos,-1)),-1):te.create(c.doc,r.pos-o.nodeSize)),e(c.scrollIntoView())}return!0}if(i==1||s.node(i-1).childCount>1)break}return o.isAtom&&r.depth==s.depth-1?(e&&e(t.tr.delete(r.pos-o.nodeSize,r.pos).scrollIntoView()),!0):!1},Nf=(t,e,n)=>{let s=gl(t,n);if(!s)return!1;let r=ao(s);return r?bl(t,r,e):!1},Ef=(t,e,n)=>{let s=kl(t,n);if(!s)return!1;let r=io(s);return r?bl(t,r,e):!1};function bl(t,e,n){let s=e.nodeBefore,r=s,o=e.pos-1;for(;!r.isTextblock;o--){if(r.type.spec.isolating)return!1;let p=r.lastChild;if(!p)return!1;r=p}let i=e.nodeAfter,l=i,c=e.pos+1;for(;!l.isTextblock;c++){if(l.type.spec.isolating)return!1;let p=l.firstChild;if(!p)return!1;l=p}let u=so(t.doc,o,c,V.empty);if(!u||u.from!=o||u instanceof Fe&&u.slice.size>=c-o)return!1;if(n){let p=t.tr.step(u);p.setSelection(oe.create(p.doc,o)),n(p.scrollIntoView())}return!0}function Zt(t,e,n=!1){for(let s=t;s;s=e=="start"?s.firstChild:s.lastChild){if(s.isTextblock)return!0;if(n&&s.childCount!=1)return!1}return!1}const yl=(t,e,n)=>{let{$head:s,empty:r}=t.selection,o=s;if(!r)return!1;if(s.parent.isTextblock){if(n?!n.endOfTextblock("backward",t):s.parentOffset>0)return!1;o=ao(s)}let i=o&&o.nodeBefore;return!i||!te.isSelectable(i)?!1:(e&&e(t.tr.setSelection(te.create(t.doc,o.pos-i.nodeSize)).scrollIntoView()),!0)};function ao(t){if(!t.parent.type.spec.isolating)for(let e=t.depth-1;e>=0;e--){if(t.index(e)>0)return t.doc.resolve(t.before(e+1));if(t.node(e).type.spec.isolating)break}return null}function kl(t,e){let{$cursor:n}=t.selection;return!n||(e?!e.endOfTextblock("forward",t):n.parentOffset<n.parent.content.size)?null:n}const vl=(t,e,n)=>{let s=kl(t,n);if(!s)return!1;let r=io(s);if(!r)return!1;let o=r.nodeAfter;if(Nl(t,r,e,1))return!0;if(s.parent.content.size==0&&(Zt(o,"start")||te.isSelectable(o))){let i=so(t.doc,s.before(),s.after(),V.empty);if(i&&i.slice.size<i.to-i.from){if(e){let l=t.tr.step(i);l.setSelection(Zt(o,"start")?X.findFrom(l.doc.resolve(l.mapping.map(r.pos)),1):te.create(l.doc,l.mapping.map(r.pos))),e(l.scrollIntoView())}return!0}}return o.isAtom&&r.depth==s.depth-1?(e&&e(t.tr.delete(r.pos,r.pos+o.nodeSize).scrollIntoView()),!0):!1},wl=(t,e,n)=>{let{$head:s,empty:r}=t.selection,o=s;if(!r)return!1;if(s.parent.isTextblock){if(n?!n.endOfTextblock("forward",t):s.parentOffset<s.parent.content.size)return!1;o=io(s)}let i=o&&o.nodeAfter;return!i||!te.isSelectable(i)?!1:(e&&e(t.tr.setSelection(te.create(t.doc,o.pos)).scrollIntoView()),!0)};function io(t){if(!t.parent.type.spec.isolating)for(let e=t.depth-1;e>=0;e--){let n=t.node(e);if(t.index(e)+1<n.childCount)return t.doc.resolve(t.after(e+1));if(n.type.spec.isolating)break}return null}const Af=(t,e)=>{let n=t.selection,s=n instanceof te,r;if(s){if(n.node.isTextblock||!zt(t.doc,n.from))return!1;r=n.from}else if(r=Ts(t.doc,n.from,-1),r==null)return!1;if(e){let o=t.tr.join(r);s&&o.setSelection(te.create(o.doc,r-t.doc.resolve(r).nodeBefore.nodeSize)),e(o.scrollIntoView())}return!0},If=(t,e)=>{let n=t.selection,s;if(n instanceof te){if(n.node.isTextblock||!zt(t.doc,n.to))return!1;s=n.to}else if(s=Ts(t.doc,n.to,1),s==null)return!1;return e&&e(t.tr.join(s).scrollIntoView()),!0},_f=(t,e)=>{let{$from:n,$to:s}=t.selection,r=n.blockRange(s),o=r&&ln(r);return o==null?!1:(e&&e(t.tr.lift(r,o).scrollIntoView()),!0)},Cl=(t,e)=>{let{$head:n,$anchor:s}=t.selection;return!n.parent.type.spec.code||!n.sameParent(s)?!1:(e&&e(t.tr.insertText(`
|
|
133
|
+
`).scrollIntoView()),!0)};function lo(t){for(let e=0;e<t.edgeCount;e++){let{type:n}=t.edge(e);if(n.isTextblock&&!n.hasRequiredAttrs())return n}return null}const Tf=(t,e)=>{let{$head:n,$anchor:s}=t.selection;if(!n.parent.type.spec.code||!n.sameParent(s))return!1;let r=n.node(-1),o=n.indexAfter(-1),i=lo(r.contentMatchAt(o));if(!i||!r.canReplaceWith(o,o,i))return!1;if(e){let l=n.after(),c=t.tr.replaceWith(l,l,i.createAndFill());c.setSelection(X.near(c.doc.resolve(l),1)),e(c.scrollIntoView())}return!0},jl=(t,e)=>{let n=t.selection,{$from:s,$to:r}=n;if(n instanceof Ge||s.parent.inlineContent||r.parent.inlineContent)return!1;let o=lo(r.parent.contentMatchAt(r.indexAfter()));if(!o||!o.isTextblock)return!1;if(e){let i=(!s.parentOffset&&r.index()<r.parent.childCount?s:r).pos,l=t.tr.insert(i,o.createAndFill());l.setSelection(oe.create(l.doc,i+1)),e(l.scrollIntoView())}return!0},Sl=(t,e)=>{let{$cursor:n}=t.selection;if(!n||n.parent.content.size)return!1;if(n.depth>1&&n.after()!=n.end(-1)){let o=n.before();if(dt(t.doc,o))return e&&e(t.tr.split(o).scrollIntoView()),!0}let s=n.blockRange(),r=s&&ln(s);return r==null?!1:(e&&e(t.tr.lift(s,r).scrollIntoView()),!0)};function Bf(t){return(e,n)=>{let{$from:s,$to:r}=e.selection;if(e.selection instanceof te&&e.selection.node.isBlock)return!s.parentOffset||!dt(e.doc,s.pos)?!1:(n&&n(e.tr.split(s.pos).scrollIntoView()),!0);if(!s.depth)return!1;let o=[],i,l,c=!1,u=!1;for(let h=s.depth;;h--)if(s.node(h).isBlock){c=s.end(h)==s.pos+(s.depth-h),u=s.start(h)==s.pos-(s.depth-h),l=lo(s.node(h-1).contentMatchAt(s.indexAfter(h-1))),o.unshift(c&&l?{type:l}:null),i=h;break}else{if(h==1)return!1;o.unshift(null)}let p=e.tr;(e.selection instanceof oe||e.selection instanceof Ge)&&p.deleteSelection();let f=p.mapping.map(s.pos),m=dt(p.doc,f,o.length,o);if(m||(o[0]=l?{type:l}:null,m=dt(p.doc,f,o.length,o)),!m)return!1;if(p.split(f,o.length,o),!c&&u&&s.node(i).type!=l){let h=p.mapping.map(s.before(i)),x=p.doc.resolve(h);l&&s.node(i-1).canReplaceWith(x.index(),x.index()+1,l)&&p.setNodeMarkup(p.mapping.map(s.before(i)),l)}return n&&n(p.scrollIntoView()),!0}}const Rf=Bf(),Pf=(t,e)=>{let{$from:n,to:s}=t.selection,r,o=n.sharedDepth(s);return o==0?!1:(r=n.before(o),e&&e(t.tr.setSelection(te.create(t.doc,r))),!0)};function Lf(t,e,n){let s=e.nodeBefore,r=e.nodeAfter,o=e.index();return!s||!r||!s.type.compatibleContent(r.type)?!1:!s.content.size&&e.parent.canReplace(o-1,o)?(n&&n(t.tr.delete(e.pos-s.nodeSize,e.pos).scrollIntoView()),!0):!e.parent.canReplace(o,o+1)||!(r.isTextblock||zt(t.doc,e.pos))?!1:(n&&n(t.tr.join(e.pos).scrollIntoView()),!0)}function Nl(t,e,n,s){let r=e.nodeBefore,o=e.nodeAfter,i,l,c=r.type.spec.isolating||o.type.spec.isolating;if(!c&&Lf(t,e,n))return!0;let u=!c&&e.parent.canReplace(e.index(),e.index()+1);if(u&&(i=(l=r.contentMatchAt(r.childCount)).findWrapping(o.type))&&l.matchType(i[0]||o.type).validEnd){if(n){let h=e.pos+o.nodeSize,x=M.empty;for(let v=i.length-1;v>=0;v--)x=M.from(i[v].create(null,x));x=M.from(r.copy(x));let b=t.tr.step(new Me(e.pos-1,h,e.pos,h,new V(x,1,0),i.length,!0)),y=b.doc.resolve(h+2*i.length);y.nodeAfter&&y.nodeAfter.type==r.type&&zt(b.doc,y.pos)&&b.join(y.pos),n(b.scrollIntoView())}return!0}let p=o.type.spec.isolating||s>0&&c?null:X.findFrom(e,1),f=p&&p.$from.blockRange(p.$to),m=f&&ln(f);if(m!=null&&m>=e.depth)return n&&n(t.tr.lift(f,m).scrollIntoView()),!0;if(u&&Zt(o,"start",!0)&&Zt(r,"end")){let h=r,x=[];for(;x.push(h),!h.isTextblock;)h=h.lastChild;let b=o,y=1;for(;!b.isTextblock;b=b.firstChild)y++;if(h.canReplace(h.childCount,h.childCount,b.content)){if(n){let v=M.empty;for(let I=x.length-1;I>=0;I--)v=M.from(x[I].copy(v));let w=t.tr.step(new Me(e.pos-x.length,e.pos+o.nodeSize,e.pos+y,e.pos+o.nodeSize-y,new V(v,x.length,0),0,!0));n(w.scrollIntoView())}return!0}}return!1}function El(t){return function(e,n){let s=e.selection,r=t<0?s.$from:s.$to,o=r.depth;for(;r.node(o).isInline;){if(!o)return!1;o--}return r.node(o).isTextblock?(n&&n(e.tr.setSelection(oe.create(e.doc,t<0?r.start(o):r.end(o)))),!0):!1}}const Mf=El(-1),Df=El(1);function Of(t,e=null){return function(n,s){let{$from:r,$to:o}=n.selection,i=r.blockRange(o),l=i&&ul(i,t,e);return l?(s&&s(n.tr.wrap(i,l).scrollIntoView()),!0):!1}}function ga(t,e=null){return function(n,s){let r=!1;for(let o=0;o<n.selection.ranges.length&&!r;o++){let{$from:{pos:i},$to:{pos:l}}=n.selection.ranges[o];n.doc.nodesBetween(i,l,(c,u)=>{if(r)return!1;if(!(!c.isTextblock||c.hasMarkup(t,e)))if(c.type==t)r=!0;else{let p=n.doc.resolve(u),f=p.index();r=p.parent.canReplaceWith(f,f+1,t)}})}if(!r)return!1;if(s){let o=n.tr;for(let i=0;i<n.selection.ranges.length;i++){let{$from:{pos:l},$to:{pos:c}}=n.selection.ranges[i];o.setBlockType(l,c,t,e)}s(o.scrollIntoView())}return!0}}function co(...t){return function(e,n,s){for(let r=0;r<t.length;r++)if(t[r](e,n,s))return!0;return!1}}co(oo,xl,yl);co(oo,vl,wl);co(Cl,jl,Sl,Rf);typeof navigator<"u"?/Mac|iP(hone|[oa]d)/.test(navigator.platform):typeof os<"u"&&os.platform&&os.platform()=="darwin";function $f(t,e=null){return function(n,s){let{$from:r,$to:o}=n.selection,i=r.blockRange(o);if(!i)return!1;let l=s?n.tr:null;return Ff(l,i,t,e)?(s&&s(l.scrollIntoView()),!0):!1}}function Ff(t,e,n,s=null){let r=!1,o=e,i=e.$from.doc;if(e.depth>=2&&e.$from.node(e.depth-1).type.compatibleContent(n)&&e.startIndex==0){if(e.$from.index(e.depth-1)==0)return!1;let c=i.resolve(e.start-2);o=new cs(c,c,e.depth),e.endIndex<e.parent.childCount&&(e=new cs(e.$from,i.resolve(e.$to.end(e.depth)),e.depth)),r=!0}let l=ul(o,n,s,e);return l?(t&&zf(t,e,l,r,n),!0):!1}function zf(t,e,n,s,r){let o=M.empty;for(let p=n.length-1;p>=0;p--)o=M.from(n[p].type.create(n[p].attrs,o));t.step(new Me(e.start-(s?2:0),e.end,e.start,e.end,new V(o,0,0),n.length,!0));let i=0;for(let p=0;p<n.length;p++)n[p].type==r&&(i=p+1);let l=n.length-i,c=e.start+n.length-(s?2:0),u=e.parent;for(let p=e.startIndex,f=e.endIndex,m=!0;p<f;p++,m=!1)!m&&dt(t.doc,c,l)&&(t.split(c,l),c+=2*l),c+=u.child(p).nodeSize;return t}function Hf(t){return function(e,n){let{$from:s,$to:r}=e.selection,o=s.blockRange(r,i=>i.childCount>0&&i.firstChild.type==t);return o?n?s.node(o.depth-1).type==t?Vf(e,n,t,o):Wf(e,n,o):!0:!1}}function Vf(t,e,n,s){let r=t.tr,o=s.end,i=s.$to.end(s.depth);o<i&&(r.step(new Me(o-1,i,o,i,new V(M.from(n.create(null,s.parent.copy())),1,0),1,!0)),s=new cs(r.doc.resolve(s.$from.pos),r.doc.resolve(i),s.depth));const l=ln(s);if(l==null)return!1;r.lift(s,l);let c=r.doc.resolve(r.mapping.map(o,-1)-1);return zt(r.doc,c.pos)&&c.nodeBefore.type==c.nodeAfter.type&&r.join(c.pos),e(r.scrollIntoView()),!0}function Wf(t,e,n){let s=t.tr,r=n.parent;for(let h=n.end,x=n.endIndex-1,b=n.startIndex;x>b;x--)h-=r.child(x).nodeSize,s.delete(h-1,h+1);let o=s.doc.resolve(n.start),i=o.nodeAfter;if(s.mapping.map(n.end)!=n.start+o.nodeAfter.nodeSize)return!1;let l=n.startIndex==0,c=n.endIndex==r.childCount,u=o.node(-1),p=o.index(-1);if(!u.canReplace(p+(l?0:1),p+1,i.content.append(c?M.empty:M.from(r))))return!1;let f=o.pos,m=f+i.nodeSize;return s.step(new Me(f-(l?1:0),m+(c?1:0),f+1,m-1,new V((l?M.empty:M.from(r.copy(M.empty))).append(c?M.empty:M.from(r.copy(M.empty))),l?0:1,c?0:1),l?0:1)),e(s.scrollIntoView()),!0}function Gf(t){return function(e,n){let{$from:s,$to:r}=e.selection,o=s.blockRange(r,u=>u.childCount>0&&u.firstChild.type==t);if(!o)return!1;let i=o.startIndex;if(i==0)return!1;let l=o.parent,c=l.child(i-1);if(c.type!=t)return!1;if(n){let u=c.lastChild&&c.lastChild.type==l.type,p=M.from(u?t.create():null),f=new V(M.from(t.create(null,M.from(l.type.create(null,p)))),u?3:1,0),m=o.start,h=o.end;n(e.tr.step(new Me(m-(u?3:1),h,m,h,f,1,!0)).scrollIntoView())}return!0}}function Al(t){const{state:e,transaction:n}=t;let{selection:s}=n,{doc:r}=n,{storedMarks:o}=n;return{...e,apply:e.apply.bind(e),applyTransaction:e.applyTransaction.bind(e),plugins:e.plugins,schema:e.schema,reconfigure:e.reconfigure.bind(e),toJSON:e.toJSON.bind(e),get storedMarks(){return o},get selection(){return s},get doc(){return r},get tr(){return s=n.selection,r=n.doc,o=n.storedMarks,n}}}class Uf{constructor(e){this.editor=e.editor,this.rawCommands=this.editor.extensionManager.commands,this.customState=e.state}get hasCustomState(){return!!this.customState}get state(){return this.customState||this.editor.state}get commands(){const{rawCommands:e,editor:n,state:s}=this,{view:r}=n,{tr:o}=s,i=this.buildProps(o);return Object.fromEntries(Object.entries(e).map(([l,c])=>[l,(...p)=>{const f=c(...p)(i);return!o.getMeta("preventDispatch")&&!this.hasCustomState&&r.dispatch(o),f}]))}get chain(){return()=>this.createChain()}get can(){return()=>this.createCan()}createChain(e,n=!0){const{rawCommands:s,editor:r,state:o}=this,{view:i}=r,l=[],c=!!e,u=e||o.tr,p=()=>(!c&&n&&!u.getMeta("preventDispatch")&&!this.hasCustomState&&i.dispatch(u),l.every(m=>m===!0)),f={...Object.fromEntries(Object.entries(s).map(([m,h])=>[m,(...b)=>{const y=this.buildProps(u,n),v=h(...b)(y);return l.push(v),f}])),run:p};return f}createCan(e){const{rawCommands:n,state:s}=this,r=!1,o=e||s.tr,i=this.buildProps(o,r);return{...Object.fromEntries(Object.entries(n).map(([c,u])=>[c,(...p)=>u(...p)({...i,dispatch:void 0})])),chain:()=>this.createChain(o,r)}}buildProps(e,n=!0){const{rawCommands:s,editor:r,state:o}=this,{view:i}=r,l={tr:e,editor:r,view:i,state:Al({state:o,transaction:e}),dispatch:n?()=>{}:void 0,chain:()=>this.createChain(e,n),can:()=>this.createCan(e),get commands(){return Object.fromEntries(Object.entries(s).map(([c,u])=>[c,(...p)=>u(...p)(l)]))}};return l}}function Nt(t,e,n){return t.config[e]===void 0&&t.parent?Nt(t.parent,e,n):typeof t.config[e]=="function"?t.config[e].bind({...n,parent:t.parent?Nt(t.parent,e,n):null}):t.config[e]}function qf(t){const e=t.filter(r=>r.type==="extension"),n=t.filter(r=>r.type==="node"),s=t.filter(r=>r.type==="mark");return{baseExtensions:e,nodeExtensions:n,markExtensions:s}}function Ie(t,e){if(typeof t=="string"){if(!e.nodes[t])throw Error(`There is no node type named '${t}'. Maybe you forgot to add the extension?`);return e.nodes[t]}return t}function Kf(t){return typeof t=="function"}function xn(t,e=void 0,...n){return Kf(t)?e?t.bind(e)(...n):t(...n):t}function Yf(t){return Object.prototype.toString.call(t)==="[object RegExp]"}function Xf(t){return Object.prototype.toString.call(t).slice(8,-1)}function qn(t){return Xf(t)!=="Object"?!1:t.constructor===Object&&Object.getPrototypeOf(t)===Object.prototype}function Il(t,e){const n={...t};return qn(t)&&qn(e)&&Object.keys(e).forEach(s=>{qn(e[s])&&qn(t[s])?n[s]=Il(t[s],e[s]):n[s]=e[s]}),n}class qe{constructor(e={}){this.type="extension",this.name="extension",this.parent=null,this.child=null,this.config={name:this.name,defaultOptions:{}},this.config={...this.config,...e},this.name=this.config.name,e.defaultOptions&&Object.keys(e.defaultOptions).length>0&&console.warn(`[tiptap warn]: BREAKING CHANGE: "defaultOptions" is deprecated. Please use "addOptions" instead. Found in extension: "${this.name}".`),this.options=this.config.defaultOptions,this.config.addOptions&&(this.options=xn(Nt(this,"addOptions",{name:this.name}))),this.storage=xn(Nt(this,"addStorage",{name:this.name,options:this.options}))||{}}static create(e={}){return new qe(e)}configure(e={}){const n=this.extend({...this.config,addOptions:()=>Il(this.options,e)});return n.name=this.name,n.parent=this.parent,n}extend(e={}){const n=new qe({...this.config,...e});return n.parent=this,this.child=n,n.name=e.name?e.name:n.parent.name,e.defaultOptions&&Object.keys(e.defaultOptions).length>0&&console.warn(`[tiptap warn]: BREAKING CHANGE: "defaultOptions" is deprecated. Please use "addOptions" instead. Found in extension: "${n.name}".`),n.options=xn(Nt(n,"addOptions",{name:n.name})),n.storage=xn(Nt(n,"addStorage",{name:n.name,options:n.options})),n}}function Jf(t,e,n){const{from:s,to:r}=e,{blockSeparator:o=`
|
|
134
|
+
|
|
135
|
+
`,textSerializers:i={}}=n||{};let l="";return t.nodesBetween(s,r,(c,u,p,f)=>{var m;c.isBlock&&u>s&&(l+=o);const h=i==null?void 0:i[c.type.name];if(h)return p&&(l+=h({node:c,pos:u,parent:p,index:f,range:e})),!1;c.isText&&(l+=(m=c==null?void 0:c.text)===null||m===void 0?void 0:m.slice(Math.max(s,u)-u,r-u))}),l}function Zf(t){return Object.fromEntries(Object.entries(t.nodes).filter(([,e])=>e.spec.toText).map(([e,n])=>[e,n.spec.toText]))}qe.create({name:"clipboardTextSerializer",addOptions(){return{blockSeparator:void 0}},addProseMirrorPlugins(){return[new Ht({key:new Vt("clipboardTextSerializer"),props:{clipboardTextSerializer:()=>{const{editor:t}=this,{state:e,schema:n}=t,{doc:s,selection:r}=e,{ranges:o}=r,i=Math.min(...o.map(p=>p.$from.pos)),l=Math.max(...o.map(p=>p.$to.pos)),c=Zf(n);return Jf(s,{from:i,to:l},{...this.options.blockSeparator!==void 0?{blockSeparator:this.options.blockSeparator}:{},textSerializers:c})}}})]}});const Qf=()=>({editor:t,view:e})=>(requestAnimationFrame(()=>{var n;t.isDestroyed||(e.dom.blur(),(n=window==null?void 0:window.getSelection())===null||n===void 0||n.removeAllRanges())}),!0),eh=(t=!1)=>({commands:e})=>e.setContent("",t),th=()=>({state:t,tr:e,dispatch:n})=>{const{selection:s}=e,{ranges:r}=s;return n&&r.forEach(({$from:o,$to:i})=>{t.doc.nodesBetween(o.pos,i.pos,(l,c)=>{if(l.type.isText)return;const{doc:u,mapping:p}=e,f=u.resolve(p.map(c)),m=u.resolve(p.map(c+l.nodeSize)),h=f.blockRange(m);if(!h)return;const x=ln(h);if(l.type.isTextblock){const{defaultType:b}=f.parent.contentMatchAt(f.index());e.setNodeMarkup(h.start,b)}(x||x===0)&&e.lift(h,x)})}),!0},nh=t=>e=>t(e),sh=()=>({state:t,dispatch:e})=>jl(t,e),rh=(t,e)=>({editor:n,tr:s})=>{const{state:r}=n,o=r.doc.slice(t.from,t.to);s.deleteRange(t.from,t.to);const i=s.mapping.map(e);return s.insert(i,o.content),s.setSelection(new oe(s.doc.resolve(Math.max(i-1,0)))),!0},oh=()=>({tr:t,dispatch:e})=>{const{selection:n}=t,s=n.$anchor.node();if(s.content.size>0)return!1;const r=t.selection.$anchor;for(let o=r.depth;o>0;o-=1)if(r.node(o).type===s.type){if(e){const l=r.before(o),c=r.after(o);t.delete(l,c).scrollIntoView()}return!0}return!1},ah=t=>({tr:e,state:n,dispatch:s})=>{const r=Ie(t,n.schema),o=e.selection.$anchor;for(let i=o.depth;i>0;i-=1)if(o.node(i).type===r){if(s){const c=o.before(i),u=o.after(i);e.delete(c,u).scrollIntoView()}return!0}return!1},ih=t=>({tr:e,dispatch:n})=>{const{from:s,to:r}=t;return n&&e.delete(s,r),!0},lh=()=>({state:t,dispatch:e})=>oo(t,e),ch=()=>({commands:t})=>t.keyboardShortcut("Enter"),dh=()=>({state:t,dispatch:e})=>Tf(t,e);function fs(t,e,n={strict:!0}){const s=Object.keys(e);return s.length?s.every(r=>n.strict?e[r]===t[r]:Yf(e[r])?e[r].test(t[r]):e[r]===t[r]):!0}function _l(t,e,n={}){return t.find(s=>s.type===e&&fs(Object.fromEntries(Object.keys(n).map(r=>[r,s.attrs[r]])),n))}function xa(t,e,n={}){return!!_l(t,e,n)}function Tl(t,e,n){var s;if(!t||!e)return;let r=t.parent.childAfter(t.parentOffset);if((!r.node||!r.node.marks.some(p=>p.type===e))&&(r=t.parent.childBefore(t.parentOffset)),!r.node||!r.node.marks.some(p=>p.type===e)||(n=n||((s=r.node.marks[0])===null||s===void 0?void 0:s.attrs),!_l([...r.node.marks],e,n)))return;let i=r.index,l=t.start()+r.offset,c=i+1,u=l+r.node.nodeSize;for(;i>0&&xa([...t.parent.child(i-1).marks],e,n);)i-=1,l-=t.parent.child(i).nodeSize;for(;c<t.parent.childCount&&xa([...t.parent.child(c).marks],e,n);)u+=t.parent.child(c).nodeSize,c+=1;return{from:l,to:u}}function bt(t,e){if(typeof t=="string"){if(!e.marks[t])throw Error(`There is no mark type named '${t}'. Maybe you forgot to add the extension?`);return e.marks[t]}return t}const uh=(t,e={})=>({tr:n,state:s,dispatch:r})=>{const o=bt(t,s.schema),{doc:i,selection:l}=n,{$from:c,from:u,to:p}=l;if(r){const f=Tl(c,o,e);if(f&&f.from<=u&&f.to>=p){const m=oe.create(i,f.from,f.to);n.setSelection(m)}}return!0},ph=t=>e=>{const n=typeof t=="function"?t(e):t;for(let s=0;s<n.length;s+=1)if(n[s](e))return!0;return!1};function Bl(t){return t instanceof oe}function Et(t=0,e=0,n=0){return Math.min(Math.max(t,e),n)}function fh(t,e=null){if(!e)return null;const n=X.atStart(t),s=X.atEnd(t);if(e==="start"||e===!0)return n;if(e==="end")return s;const r=n.from,o=s.to;return e==="all"?oe.create(t,Et(0,r,o),Et(t.content.size,r,o)):oe.create(t,Et(e,r,o),Et(e,r,o))}function hh(){return navigator.platform==="Android"||/android/i.test(navigator.userAgent)}function uo(){return["iPad Simulator","iPhone Simulator","iPod Simulator","iPad","iPhone","iPod"].includes(navigator.platform)||navigator.userAgent.includes("Mac")&&"ontouchend"in document}const mh=(t=null,e={})=>({editor:n,view:s,tr:r,dispatch:o})=>{e={scrollIntoView:!0,...e};const i=()=>{(uo()||hh())&&s.dom.focus(),requestAnimationFrame(()=>{n.isDestroyed||(s.focus(),e!=null&&e.scrollIntoView&&n.commands.scrollIntoView())})};if(s.hasFocus()&&t===null||t===!1)return!0;if(o&&t===null&&!Bl(n.state.selection))return i(),!0;const l=fh(r.doc,t)||n.state.selection,c=n.state.selection.eq(l);return o&&(c||r.setSelection(l),c&&r.storedMarks&&r.setStoredMarks(r.storedMarks),i()),!0},gh=(t,e)=>n=>t.every((s,r)=>e(s,{...n,index:r})),xh=(t,e)=>({tr:n,commands:s})=>s.insertContentAt({from:n.selection.from,to:n.selection.to},t,e),Rl=t=>{const e=t.childNodes;for(let n=e.length-1;n>=0;n-=1){const s=e[n];s.nodeType===3&&s.nodeValue&&/^(\n\s\s|\n)$/.test(s.nodeValue)?t.removeChild(s):s.nodeType===1&&Rl(s)}return t};function Kn(t){const e=`<body>${t}</body>`,n=new window.DOMParser().parseFromString(e,"text/html").body;return Rl(n)}function En(t,e,n){if(t instanceof Bt||t instanceof M)return t;n={slice:!0,parseOptions:{},...n};const s=typeof t=="object"&&t!==null,r=typeof t=="string";if(s)try{if(Array.isArray(t)&&t.length>0)return M.fromArray(t.map(l=>e.nodeFromJSON(l)));const i=e.nodeFromJSON(t);return n.errorOnInvalidContent&&i.check(),i}catch(o){if(n.errorOnInvalidContent)throw new Error("[tiptap error]: Invalid JSON content",{cause:o});return console.warn("[tiptap warn]: Invalid content.","Passed value:",t,"Error:",o),En("",e,n)}if(r){if(n.errorOnInvalidContent){let i=!1,l="";const c=new cf({topNode:e.spec.topNode,marks:e.spec.marks,nodes:e.spec.nodes.append({__tiptap__private__unknown__catch__all__node:{content:"inline*",group:"block",parseDOM:[{tag:"*",getAttrs:u=>(i=!0,l=typeof u=="string"?u:u.outerHTML,null)}]}})});if(n.slice?Kt.fromSchema(c).parseSlice(Kn(t),n.parseOptions):Kt.fromSchema(c).parse(Kn(t),n.parseOptions),n.errorOnInvalidContent&&i)throw new Error("[tiptap error]: Invalid HTML content",{cause:new Error(`Invalid element found: ${l}`)})}const o=Kt.fromSchema(e);return n.slice?o.parseSlice(Kn(t),n.parseOptions).content:o.parse(Kn(t),n.parseOptions)}return En("",e,n)}function bh(t,e,n){const s=t.steps.length-1;if(s<e)return;const r=t.steps[s];if(!(r instanceof Fe||r instanceof Me))return;const o=t.mapping.maps[s];let i=0;o.forEach((l,c,u,p)=>{i===0&&(i=p)}),t.setSelection(X.near(t.doc.resolve(i),n))}const yh=t=>!("type"in t),kh=(t,e,n)=>({tr:s,dispatch:r,editor:o})=>{var i;if(r){n={parseOptions:o.options.parseOptions,updateSelection:!0,applyInputRules:!1,applyPasteRules:!1,...n};let l;const c=y=>{o.emit("contentError",{editor:o,error:y,disableCollaboration:()=>{o.storage.collaboration&&(o.storage.collaboration.isDisabled=!0)}})},u={preserveWhitespace:"full",...n.parseOptions};if(!n.errorOnInvalidContent&&!o.options.enableContentCheck&&o.options.emitContentError)try{En(e,o.schema,{parseOptions:u,errorOnInvalidContent:!0})}catch(y){c(y)}try{l=En(e,o.schema,{parseOptions:u,errorOnInvalidContent:(i=n.errorOnInvalidContent)!==null&&i!==void 0?i:o.options.enableContentCheck})}catch(y){return c(y),!1}let{from:p,to:f}=typeof t=="number"?{from:t,to:t}:{from:t.from,to:t.to},m=!0,h=!0;if((yh(l)?l:[l]).forEach(y=>{y.check(),m=m?y.isText&&y.marks.length===0:!1,h=h?y.isBlock:!1}),p===f&&h){const{parent:y}=s.doc.resolve(p);y.isTextblock&&!y.type.spec.code&&!y.childCount&&(p-=1,f+=1)}let b;if(m){if(Array.isArray(e))b=e.map(y=>y.text||"").join("");else if(e instanceof M){let y="";e.forEach(v=>{v.text&&(y+=v.text)}),b=y}else typeof e=="object"&&e&&e.text?b=e.text:b=e;s.insertText(b,p,f)}else b=l,s.replaceWith(p,f,b);n.updateSelection&&bh(s,s.steps.length-1,-1),n.applyInputRules&&s.setMeta("applyInputRules",{from:p,text:b}),n.applyPasteRules&&s.setMeta("applyPasteRules",{from:p,text:b})}return!0},vh=()=>({state:t,dispatch:e})=>Af(t,e),wh=()=>({state:t,dispatch:e})=>If(t,e),Ch=()=>({state:t,dispatch:e})=>xl(t,e),jh=()=>({state:t,dispatch:e})=>vl(t,e),Sh=()=>({state:t,dispatch:e,tr:n})=>{try{const s=Ts(t.doc,t.selection.$from.pos,-1);return s==null?!1:(n.join(s,2),e&&e(n),!0)}catch{return!1}},Nh=()=>({state:t,dispatch:e,tr:n})=>{try{const s=Ts(t.doc,t.selection.$from.pos,1);return s==null?!1:(n.join(s,2),e&&e(n),!0)}catch{return!1}},Eh=()=>({state:t,dispatch:e})=>Nf(t,e),Ah=()=>({state:t,dispatch:e})=>Ef(t,e);function Pl(){return typeof navigator<"u"?/Mac/.test(navigator.platform):!1}function Ih(t){const e=t.split(/-(?!$)/);let n=e[e.length-1];n==="Space"&&(n=" ");let s,r,o,i;for(let l=0;l<e.length-1;l+=1){const c=e[l];if(/^(cmd|meta|m)$/i.test(c))i=!0;else if(/^a(lt)?$/i.test(c))s=!0;else if(/^(c|ctrl|control)$/i.test(c))r=!0;else if(/^s(hift)?$/i.test(c))o=!0;else if(/^mod$/i.test(c))uo()||Pl()?i=!0:r=!0;else throw new Error(`Unrecognized modifier name: ${c}`)}return s&&(n=`Alt-${n}`),r&&(n=`Ctrl-${n}`),i&&(n=`Meta-${n}`),o&&(n=`Shift-${n}`),n}const _h=t=>({editor:e,view:n,tr:s,dispatch:r})=>{const o=Ih(t).split(/-(?!$)/),i=o.find(u=>!["Alt","Ctrl","Meta","Shift"].includes(u)),l=new KeyboardEvent("keydown",{key:i==="Space"?" ":i,altKey:o.includes("Alt"),ctrlKey:o.includes("Ctrl"),metaKey:o.includes("Meta"),shiftKey:o.includes("Shift"),bubbles:!0,cancelable:!0}),c=e.captureTransaction(()=>{n.someProp("handleKeyDown",u=>u(n,l))});return c==null||c.steps.forEach(u=>{const p=u.map(s.mapping);p&&r&&s.maybeStep(p)}),!0};function po(t,e,n={}){const{from:s,to:r,empty:o}=t.selection,i=e?Ie(e,t.schema):null,l=[];t.doc.nodesBetween(s,r,(f,m)=>{if(f.isText)return;const h=Math.max(s,m),x=Math.min(r,m+f.nodeSize);l.push({node:f,from:h,to:x})});const c=r-s,u=l.filter(f=>i?i.name===f.node.type.name:!0).filter(f=>fs(f.node.attrs,n,{strict:!1}));return o?!!u.length:u.reduce((f,m)=>f+m.to-m.from,0)>=c}const Th=(t,e={})=>({state:n,dispatch:s})=>{const r=Ie(t,n.schema);return po(n,r,e)?_f(n,s):!1},Bh=()=>({state:t,dispatch:e})=>Sl(t,e),Rh=t=>({state:e,dispatch:n})=>{const s=Ie(t,e.schema);return Hf(s)(e,n)},Ph=()=>({state:t,dispatch:e})=>Cl(t,e);function Ll(t,e){return e.nodes[t]?"node":e.marks[t]?"mark":null}function ba(t,e){const n=typeof e=="string"?[e]:e;return Object.keys(t).reduce((s,r)=>(n.includes(r)||(s[r]=t[r]),s),{})}const Lh=(t,e)=>({tr:n,state:s,dispatch:r})=>{let o=null,i=null;const l=Ll(typeof t=="string"?t:t.name,s.schema);return l?(l==="node"&&(o=Ie(t,s.schema)),l==="mark"&&(i=bt(t,s.schema)),r&&n.selection.ranges.forEach(c=>{s.doc.nodesBetween(c.$from.pos,c.$to.pos,(u,p)=>{o&&o===u.type&&n.setNodeMarkup(p,void 0,ba(u.attrs,e)),i&&u.marks.length&&u.marks.forEach(f=>{i===f.type&&n.addMark(p,p+u.nodeSize,i.create(ba(f.attrs,e)))})})}),!0):!1},Mh=()=>({tr:t,dispatch:e})=>(e&&t.scrollIntoView(),!0),Dh=()=>({tr:t,dispatch:e})=>{if(e){const n=new Ge(t.doc);t.setSelection(n)}return!0},Oh=()=>({state:t,dispatch:e})=>yl(t,e),$h=()=>({state:t,dispatch:e})=>wl(t,e),Fh=()=>({state:t,dispatch:e})=>Pf(t,e),zh=()=>({state:t,dispatch:e})=>Df(t,e),Hh=()=>({state:t,dispatch:e})=>Mf(t,e);function Vh(t,e,n={},s={}){return En(t,e,{slice:!1,parseOptions:n,errorOnInvalidContent:s.errorOnInvalidContent})}const Wh=(t,e=!1,n={},s={})=>({editor:r,tr:o,dispatch:i,commands:l})=>{var c,u;const{doc:p}=o;if(n.preserveWhitespace!=="full"){const f=Vh(t,r.schema,n,{errorOnInvalidContent:(c=s.errorOnInvalidContent)!==null&&c!==void 0?c:r.options.enableContentCheck});return i&&o.replaceWith(0,p.content.size,f).setMeta("preventUpdate",!e),!0}return i&&o.setMeta("preventUpdate",!e),l.insertContentAt({from:0,to:p.content.size},t,{parseOptions:n,errorOnInvalidContent:(u=s.errorOnInvalidContent)!==null&&u!==void 0?u:r.options.enableContentCheck})};function Gh(t,e){const n=bt(e,t.schema),{from:s,to:r,empty:o}=t.selection,i=[];o?(t.storedMarks&&i.push(...t.storedMarks),i.push(...t.selection.$head.marks())):t.doc.nodesBetween(s,r,c=>{i.push(...c.marks)});const l=i.find(c=>c.type.name===n.name);return l?{...l.attrs}:{}}function Uh(t){for(let e=0;e<t.edgeCount;e+=1){const{type:n}=t.edge(e);if(n.isTextblock&&!n.hasRequiredAttrs())return n}return null}function qh(t,e){for(let n=t.depth;n>0;n-=1){const s=t.node(n);if(e(s))return{pos:n>0?t.before(n):0,start:t.start(n),depth:n,node:s}}}function fo(t){return e=>qh(e.$from,t)}function Zn(t,e,n){return Object.fromEntries(Object.entries(n).filter(([s])=>{const r=t.find(o=>o.type===e&&o.name===s);return r?r.attribute.keepOnSplit:!1}))}function Kh(t,e,n={}){const{empty:s,ranges:r}=t.selection,o=e?bt(e,t.schema):null;if(s)return!!(t.storedMarks||t.selection.$from.marks()).filter(f=>o?o.name===f.type.name:!0).find(f=>fs(f.attrs,n,{strict:!1}));let i=0;const l=[];if(r.forEach(({$from:f,$to:m})=>{const h=f.pos,x=m.pos;t.doc.nodesBetween(h,x,(b,y)=>{if(!b.isText&&!b.marks.length)return;const v=Math.max(h,y),w=Math.min(x,y+b.nodeSize),I=w-v;i+=I,l.push(...b.marks.map(N=>({mark:N,from:v,to:w})))})}),i===0)return!1;const c=l.filter(f=>o?o.name===f.mark.type.name:!0).filter(f=>fs(f.mark.attrs,n,{strict:!1})).reduce((f,m)=>f+m.to-m.from,0),u=l.filter(f=>o?f.mark.type!==o&&f.mark.type.excludes(o):!0).reduce((f,m)=>f+m.to-m.from,0);return(c>0?c+u:c)>=i}function ya(t,e){const{nodeExtensions:n}=qf(e),s=n.find(i=>i.name===t);if(!s)return!1;const r={name:s.name,options:s.options,storage:s.storage},o=xn(Nt(s,"group",r));return typeof o!="string"?!1:o.split(" ").includes("list")}function Ml(t,{checkChildren:e=!0,ignoreWhitespace:n=!1}={}){var s;if(n){if(t.type.name==="hardBreak")return!0;if(t.isText)return/^\s*$/m.test((s=t.text)!==null&&s!==void 0?s:"")}if(t.isText)return!t.text;if(t.isAtom||t.isLeaf)return!1;if(t.content.childCount===0)return!0;if(e){let r=!0;return t.content.forEach(o=>{r!==!1&&(Ml(o,{ignoreWhitespace:n,checkChildren:e})||(r=!1))}),r}return!1}function Yh(t,e,n){var s;const{selection:r}=e;let o=null;if(Bl(r)&&(o=r.$cursor),o){const l=(s=t.storedMarks)!==null&&s!==void 0?s:o.marks();return!!n.isInSet(l)||!l.some(c=>c.type.excludes(n))}const{ranges:i}=r;return i.some(({$from:l,$to:c})=>{let u=l.depth===0?t.doc.inlineContent&&t.doc.type.allowsMarkType(n):!1;return t.doc.nodesBetween(l.pos,c.pos,(p,f,m)=>{if(u)return!1;if(p.isInline){const h=!m||m.type.allowsMarkType(n),x=!!n.isInSet(p.marks)||!p.marks.some(b=>b.type.excludes(n));u=h&&x}return!u}),u})}const Xh=(t,e={})=>({tr:n,state:s,dispatch:r})=>{const{selection:o}=n,{empty:i,ranges:l}=o,c=bt(t,s.schema);if(r)if(i){const u=Gh(s,c);n.addStoredMark(c.create({...u,...e}))}else l.forEach(u=>{const p=u.$from.pos,f=u.$to.pos;s.doc.nodesBetween(p,f,(m,h)=>{const x=Math.max(h,p),b=Math.min(h+m.nodeSize,f);m.marks.find(v=>v.type===c)?m.marks.forEach(v=>{c===v.type&&n.addMark(x,b,c.create({...v.attrs,...e}))}):n.addMark(x,b,c.create(e))})});return Yh(s,n,c)},Jh=(t,e)=>({tr:n})=>(n.setMeta(t,e),!0),Zh=(t,e={})=>({state:n,dispatch:s,chain:r})=>{const o=Ie(t,n.schema);let i;return n.selection.$anchor.sameParent(n.selection.$head)&&(i=n.selection.$anchor.parent.attrs),o.isTextblock?r().command(({commands:l})=>ga(o,{...i,...e})(n)?!0:l.clearNodes()).command(({state:l})=>ga(o,{...i,...e})(l,s)).run():(console.warn('[tiptap warn]: Currently "setNode()" only supports text block nodes.'),!1)},Qh=t=>({tr:e,dispatch:n})=>{if(n){const{doc:s}=e,r=Et(t,0,s.content.size),o=te.create(s,r);e.setSelection(o)}return!0},em=t=>({tr:e,dispatch:n})=>{if(n){const{doc:s}=e,{from:r,to:o}=typeof t=="number"?{from:t,to:t}:t,i=oe.atStart(s).from,l=oe.atEnd(s).to,c=Et(r,i,l),u=Et(o,i,l),p=oe.create(s,c,u);e.setSelection(p)}return!0},tm=t=>({state:e,dispatch:n})=>{const s=Ie(t,e.schema);return Gf(s)(e,n)};function ka(t,e){const n=t.storedMarks||t.selection.$to.parentOffset&&t.selection.$from.marks();if(n){const s=n.filter(r=>e==null?void 0:e.includes(r.type.name));t.tr.ensureMarks(s)}}const nm=({keepMarks:t=!0}={})=>({tr:e,state:n,dispatch:s,editor:r})=>{const{selection:o,doc:i}=e,{$from:l,$to:c}=o,u=r.extensionManager.attributes,p=Zn(u,l.node().type.name,l.node().attrs);if(o instanceof te&&o.node.isBlock)return!l.parentOffset||!dt(i,l.pos)?!1:(s&&(t&&ka(n,r.extensionManager.splittableMarks),e.split(l.pos).scrollIntoView()),!0);if(!l.parent.isBlock)return!1;const f=c.parentOffset===c.parent.content.size,m=l.depth===0?void 0:Uh(l.node(-1).contentMatchAt(l.indexAfter(-1)));let h=f&&m?[{type:m,attrs:p}]:void 0,x=dt(e.doc,e.mapping.map(l.pos),1,h);if(!h&&!x&&dt(e.doc,e.mapping.map(l.pos),1,m?[{type:m}]:void 0)&&(x=!0,h=m?[{type:m,attrs:p}]:void 0),s){if(x&&(o instanceof oe&&e.deleteSelection(),e.split(e.mapping.map(l.pos),1,h),m&&!f&&!l.parentOffset&&l.parent.type!==m)){const b=e.mapping.map(l.before()),y=e.doc.resolve(b);l.node(-1).canReplaceWith(y.index(),y.index()+1,m)&&e.setNodeMarkup(e.mapping.map(l.before()),m)}t&&ka(n,r.extensionManager.splittableMarks),e.scrollIntoView()}return x},sm=(t,e={})=>({tr:n,state:s,dispatch:r,editor:o})=>{var i;const l=Ie(t,s.schema),{$from:c,$to:u}=s.selection,p=s.selection.node;if(p&&p.isBlock||c.depth<2||!c.sameParent(u))return!1;const f=c.node(-1);if(f.type!==l)return!1;const m=o.extensionManager.attributes;if(c.parent.content.size===0&&c.node(-1).childCount===c.indexAfter(-1)){if(c.depth===2||c.node(-3).type!==l||c.index(-2)!==c.node(-2).childCount-1)return!1;if(r){let v=M.empty;const w=c.index(-1)?1:c.index(-2)?2:3;for(let A=c.depth-w;A>=c.depth-3;A-=1)v=M.from(c.node(A).copy(v));const I=c.indexAfter(-1)<c.node(-2).childCount?1:c.indexAfter(-2)<c.node(-3).childCount?2:3,N={...Zn(m,c.node().type.name,c.node().attrs),...e},E=((i=l.contentMatch.defaultType)===null||i===void 0?void 0:i.createAndFill(N))||void 0;v=v.append(M.from(l.createAndFill(null,E)||void 0));const _=c.before(c.depth-(w-1));n.replace(_,c.after(-I),new V(v,4-w,0));let S=-1;n.doc.nodesBetween(_,n.doc.content.size,(A,C)=>{if(S>-1)return!1;A.isTextblock&&A.content.size===0&&(S=C+1)}),S>-1&&n.setSelection(oe.near(n.doc.resolve(S))),n.scrollIntoView()}return!0}const h=u.pos===c.end()?f.contentMatchAt(0).defaultType:null,x={...Zn(m,f.type.name,f.attrs),...e},b={...Zn(m,c.node().type.name,c.node().attrs),...e};n.delete(c.pos,u.pos);const y=h?[{type:l,attrs:x},{type:h,attrs:b}]:[{type:l,attrs:x}];if(!dt(n.doc,c.pos,2))return!1;if(r){const{selection:v,storedMarks:w}=s,{splittableMarks:I}=o.extensionManager,N=w||v.$to.parentOffset&&v.$from.marks();if(n.split(c.pos,2,y).scrollIntoView(),!N||!r)return!0;const E=N.filter(_=>I.includes(_.type.name));n.ensureMarks(E)}return!0},nr=(t,e)=>{const n=fo(i=>i.type===e)(t.selection);if(!n)return!0;const s=t.doc.resolve(Math.max(0,n.pos-1)).before(n.depth);if(s===void 0)return!0;const r=t.doc.nodeAt(s);return n.node.type===(r==null?void 0:r.type)&&zt(t.doc,n.pos)&&t.join(n.pos),!0},sr=(t,e)=>{const n=fo(i=>i.type===e)(t.selection);if(!n)return!0;const s=t.doc.resolve(n.start).after(n.depth);if(s===void 0)return!0;const r=t.doc.nodeAt(s);return n.node.type===(r==null?void 0:r.type)&&zt(t.doc,s)&&t.join(s),!0},rm=(t,e,n,s={})=>({editor:r,tr:o,state:i,dispatch:l,chain:c,commands:u,can:p})=>{const{extensions:f,splittableMarks:m}=r.extensionManager,h=Ie(t,i.schema),x=Ie(e,i.schema),{selection:b,storedMarks:y}=i,{$from:v,$to:w}=b,I=v.blockRange(w),N=y||b.$to.parentOffset&&b.$from.marks();if(!I)return!1;const E=fo(_=>ya(_.type.name,f))(b);if(I.depth>=1&&E&&I.depth-E.depth<=1){if(E.node.type===h)return u.liftListItem(x);if(ya(E.node.type.name,f)&&h.validContent(E.node.content)&&l)return c().command(()=>(o.setNodeMarkup(E.pos,h),!0)).command(()=>nr(o,h)).command(()=>sr(o,h)).run()}return!n||!N||!l?c().command(()=>p().wrapInList(h,s)?!0:u.clearNodes()).wrapInList(h,s).command(()=>nr(o,h)).command(()=>sr(o,h)).run():c().command(()=>{const _=p().wrapInList(h,s),S=N.filter(A=>m.includes(A.type.name));return o.ensureMarks(S),_?!0:u.clearNodes()}).wrapInList(h,s).command(()=>nr(o,h)).command(()=>sr(o,h)).run()},om=(t,e={},n={})=>({state:s,commands:r})=>{const{extendEmptyMarkRange:o=!1}=n,i=bt(t,s.schema);return Kh(s,i,e)?r.unsetMark(i,{extendEmptyMarkRange:o}):r.setMark(i,e)},am=(t,e,n={})=>({state:s,commands:r})=>{const o=Ie(t,s.schema),i=Ie(e,s.schema),l=po(s,o,n);let c;return s.selection.$anchor.sameParent(s.selection.$head)&&(c=s.selection.$anchor.parent.attrs),l?r.setNode(i,c):r.setNode(o,{...c,...n})},im=(t,e={})=>({state:n,commands:s})=>{const r=Ie(t,n.schema);return po(n,r,e)?s.lift(r):s.wrapIn(r,e)},lm=()=>({state:t,dispatch:e})=>{const n=t.plugins;for(let s=0;s<n.length;s+=1){const r=n[s];let o;if(r.spec.isInputRules&&(o=r.getState(t))){if(e){const i=t.tr,l=o.transform;for(let c=l.steps.length-1;c>=0;c-=1)i.step(l.steps[c].invert(l.docs[c]));if(o.text){const c=i.doc.resolve(o.from).marks();i.replaceWith(o.from,o.to,t.schema.text(o.text,c))}else i.delete(o.from,o.to)}return!0}}return!1},cm=()=>({tr:t,dispatch:e})=>{const{selection:n}=t,{empty:s,ranges:r}=n;return s||e&&r.forEach(o=>{t.removeMark(o.$from.pos,o.$to.pos)}),!0},dm=(t,e={})=>({tr:n,state:s,dispatch:r})=>{var o;const{extendEmptyMarkRange:i=!1}=e,{selection:l}=n,c=bt(t,s.schema),{$from:u,empty:p,ranges:f}=l;if(!r)return!0;if(p&&i){let{from:m,to:h}=l;const x=(o=u.marks().find(y=>y.type===c))===null||o===void 0?void 0:o.attrs,b=Tl(u,c,x);b&&(m=b.from,h=b.to),n.removeMark(m,h,c)}else f.forEach(m=>{n.removeMark(m.$from.pos,m.$to.pos,c)});return n.removeStoredMark(c),!0},um=(t,e={})=>({tr:n,state:s,dispatch:r})=>{let o=null,i=null;const l=Ll(typeof t=="string"?t:t.name,s.schema);return l?(l==="node"&&(o=Ie(t,s.schema)),l==="mark"&&(i=bt(t,s.schema)),r&&n.selection.ranges.forEach(c=>{const u=c.$from.pos,p=c.$to.pos;let f,m,h,x;n.selection.empty?s.doc.nodesBetween(u,p,(b,y)=>{o&&o===b.type&&(h=Math.max(y,u),x=Math.min(y+b.nodeSize,p),f=y,m=b)}):s.doc.nodesBetween(u,p,(b,y)=>{y<u&&o&&o===b.type&&(h=Math.max(y,u),x=Math.min(y+b.nodeSize,p),f=y,m=b),y>=u&&y<=p&&(o&&o===b.type&&n.setNodeMarkup(y,void 0,{...b.attrs,...e}),i&&b.marks.length&&b.marks.forEach(v=>{if(i===v.type){const w=Math.max(y,u),I=Math.min(y+b.nodeSize,p);n.addMark(w,I,i.create({...v.attrs,...e}))}}))}),m&&(f!==void 0&&n.setNodeMarkup(f,void 0,{...m.attrs,...e}),i&&m.marks.length&&m.marks.forEach(b=>{i===b.type&&n.addMark(h,x,i.create({...b.attrs,...e}))}))}),!0):!1},pm=(t,e={})=>({state:n,dispatch:s})=>{const r=Ie(t,n.schema);return Of(r,e)(n,s)},fm=(t,e={})=>({state:n,dispatch:s})=>{const r=Ie(t,n.schema);return $f(r,e)(n,s)};var hm=Object.freeze({__proto__:null,blur:Qf,clearContent:eh,clearNodes:th,command:nh,createParagraphNear:sh,cut:rh,deleteCurrentNode:oh,deleteNode:ah,deleteRange:ih,deleteSelection:lh,enter:ch,exitCode:dh,extendMarkRange:uh,first:ph,focus:mh,forEach:gh,insertContent:xh,insertContentAt:kh,joinBackward:Ch,joinDown:wh,joinForward:jh,joinItemBackward:Sh,joinItemForward:Nh,joinTextblockBackward:Eh,joinTextblockForward:Ah,joinUp:vh,keyboardShortcut:_h,lift:Th,liftEmptyBlock:Bh,liftListItem:Rh,newlineInCode:Ph,resetAttributes:Lh,scrollIntoView:Mh,selectAll:Dh,selectNodeBackward:Oh,selectNodeForward:$h,selectParentNode:Fh,selectTextblockEnd:zh,selectTextblockStart:Hh,setContent:Wh,setMark:Xh,setMeta:Jh,setNode:Zh,setNodeSelection:Qh,setTextSelection:em,sinkListItem:tm,splitBlock:nm,splitListItem:sm,toggleList:rm,toggleMark:om,toggleNode:am,toggleWrap:im,undoInputRule:lm,unsetAllMarks:cm,unsetMark:dm,updateAttributes:um,wrapIn:pm,wrapInList:fm});qe.create({name:"commands",addCommands(){return{...hm}}});qe.create({name:"drop",addProseMirrorPlugins(){return[new Ht({key:new Vt("tiptapDrop"),props:{handleDrop:(t,e,n,s)=>{this.editor.emit("drop",{editor:this.editor,event:e,slice:n,moved:s})}}})]}});qe.create({name:"editable",addProseMirrorPlugins(){return[new Ht({key:new Vt("editable"),props:{editable:()=>this.editor.options.editable}})]}});const mm=new Vt("focusEvents");qe.create({name:"focusEvents",addProseMirrorPlugins(){const{editor:t}=this;return[new Ht({key:mm,props:{handleDOMEvents:{focus:(e,n)=>{t.isFocused=!0;const s=t.state.tr.setMeta("focus",{event:n}).setMeta("addToHistory",!1);return e.dispatch(s),!1},blur:(e,n)=>{t.isFocused=!1;const s=t.state.tr.setMeta("blur",{event:n}).setMeta("addToHistory",!1);return e.dispatch(s),!1}}}})]}});qe.create({name:"keymap",addKeyboardShortcuts(){const t=()=>this.editor.commands.first(({commands:i})=>[()=>i.undoInputRule(),()=>i.command(({tr:l})=>{const{selection:c,doc:u}=l,{empty:p,$anchor:f}=c,{pos:m,parent:h}=f,x=f.parent.isTextblock&&m>0?l.doc.resolve(m-1):f,b=x.parent.type.spec.isolating,y=f.pos-f.parentOffset,v=b&&x.parent.childCount===1?y===f.pos:X.atStart(u).from===m;return!p||!h.type.isTextblock||h.textContent.length||!v||v&&f.parent.type.name==="paragraph"?!1:i.clearNodes()}),()=>i.deleteSelection(),()=>i.joinBackward(),()=>i.selectNodeBackward()]),e=()=>this.editor.commands.first(({commands:i})=>[()=>i.deleteSelection(),()=>i.deleteCurrentNode(),()=>i.joinForward(),()=>i.selectNodeForward()]),s={Enter:()=>this.editor.commands.first(({commands:i})=>[()=>i.newlineInCode(),()=>i.createParagraphNear(),()=>i.liftEmptyBlock(),()=>i.splitBlock()]),"Mod-Enter":()=>this.editor.commands.exitCode(),Backspace:t,"Mod-Backspace":t,"Shift-Backspace":t,Delete:e,"Mod-Delete":e,"Mod-a":()=>this.editor.commands.selectAll()},r={...s},o={...s,"Ctrl-h":t,"Alt-Backspace":t,"Ctrl-d":e,"Ctrl-Alt-Backspace":e,"Alt-Delete":e,"Alt-d":e,"Ctrl-a":()=>this.editor.commands.selectTextblockStart(),"Ctrl-e":()=>this.editor.commands.selectTextblockEnd()};return uo()||Pl()?o:r},addProseMirrorPlugins(){return[new Ht({key:new Vt("clearDocument"),appendTransaction:(t,e,n)=>{if(t.some(b=>b.getMeta("composition")))return;const s=t.some(b=>b.docChanged)&&!e.doc.eq(n.doc),r=t.some(b=>b.getMeta("preventClearDocument"));if(!s||r)return;const{empty:o,from:i,to:l}=e.selection,c=X.atStart(e.doc).from,u=X.atEnd(e.doc).to;if(o||!(i===c&&l===u)||!Ml(n.doc))return;const m=n.tr,h=Al({state:n,transaction:m}),{commands:x}=new Uf({editor:this.editor,state:h});if(x.clearNodes(),!!m.steps.length)return m}})]}});qe.create({name:"paste",addProseMirrorPlugins(){return[new Ht({key:new Vt("tiptapPaste"),props:{handlePaste:(t,e,n)=>{this.editor.emit("paste",{editor:this.editor,event:e,slice:n})}}})]}});qe.create({name:"tabindex",addProseMirrorPlugins(){return[new Ht({key:new Vt("tabindex"),props:{attributes:()=>this.editor.isEditable?{tabindex:"0"}:{}}})]}});const gm=qe.create({name:"color",addOptions(){return{types:["textStyle"]}},addGlobalAttributes(){return[{types:this.options.types,attributes:{color:{default:null,parseHTML:t=>{var e;return(e=t.style.color)===null||e===void 0?void 0:e.replace(/['"]+/g,"")},renderHTML:t=>t.color?{style:`color: ${t.color}`}:{}}}}]},addCommands(){return{setColor:t=>({chain:e})=>e().setMark("textStyle",{color:t}).run(),unsetColor:()=>({chain:t})=>t().setMark("textStyle",{color:null}).removeEmptyTextStyle().run()}}}),Dl=({blockId:t,value:e="",onUpdate:n=()=>{},onBlur:s=()=>{},placeholder:r="",from:o="settings",style:i={}})=>ns.useEditor({extensions:[id,td,gm.configure({types:["textStyle"]}),nd.configure({multicolor:!0}),sd.configure({openOnClick:!1,HTMLAttributes:{class:"underline"}}),od.configure({types:["heading","paragraph"],alignments:["left","center","right"],defaultAlignment:"left"}),ad,rd.configure({placeholder:r||"Enter text here",emptyEditorClass:"cursor-text before:content-[attr(data-placeholder)] before:absolute before:opacity-50 before:pointer-events-none"})],content:e||"",onUpdate:n,onBlur:s,editorProps:{attributes:{...i?{style:i}:{},class:o!=="canvas"?"text-sm p-1 px-2 rte":"rte"}}},[t]);function xm(t){let e=t;for(;e;){if(e.style&&e.style.textAlign)return e.style.textAlign;const n=window.getComputedStyle(e).textAlign;if(n&&n!=="start"&&n!=="initial"&&n!=="inherit")return n;e=e.parentElement}return null}const bm=g.memo(({blockContent:t,editingElement:e,onClose:n,onChange:s,onEscape:r})=>{const{document:o}=Xe(),i=Dl({value:t,blockId:"active-inline-editing-element",placeholder:"Enter text here",onUpdate:({editor:u})=>s((u==null?void 0:u.getHTML())||""),onBlur:({editor:u,event:p})=>{if(!o)return;const f=p==null?void 0:p.relatedTarget,m=o.querySelector(".ProseMirror"),h=o.querySelector(".tippy-box"),x=o.querySelector("#chai-rich-text-menu-bar"),b=m==null?void 0:m.contains(f),y=h==null?void 0:h.contains(f),v=x==null?void 0:x.contains(f),w=window.document.getElementById("rte-widget-color-picker");if(!b&&!y&&!v&&!w){const I=(u==null?void 0:u.getHTML())||"";n(I)}},from:"canvas"});g.useEffect(()=>{var p,f;const u=xm(e);u&&((p=i==null?void 0:i.commands)==null||p.setTextAlign(u)),(f=i==null?void 0:i.commands)==null||f.focus(),i==null||i.emit("focus",{editor:i,event:new FocusEvent("focus"),transaction:[]})},[e,i]);const l=g.useMemo(()=>{var f;const u="max-w-none shadow-none outline outline-[2px] [&_*]:shadow-none";if(!e)return u;const p=((f=e==null?void 0:e.className)==null?void 0:f.replace("sr-only",""))||"";return`${u} ${p}`},[e]),c=u=>{u.key==="Escape"&&r(u)};return i&&a.jsxs("div",{onKeyDown:c,onClick:u=>u.stopPropagation(),className:"relative",children:[a.jsx(ns.BubbleMenu,{editor:i,shouldShow:()=>i&&(i==null?void 0:i.isFocused),tippyOptions:{duration:100,arrow:!0,hideOnClick:!1},className:"w-max",children:a.jsx(Vi,{editor:i,from:"canvas"})}),a.jsx(ns.EditorContent,{id:"active-inline-editing-element",onKeyDown:c,value:t,editor:i,className:l})]})}),ym=g.memo(({editingElement:t,blockContent:e,onClose:n,editorRef:s,onChange:r,onEscape:o})=>{const{document:i,window:l}=Xe();g.useEffect(()=>{if(!(!i||!l))if(s.current){s.current.innerHTML=e,s.current.focus();const m=i.createRange(),h=l.getSelection();m.selectNodeContents(s.current),m.collapse(!1),h==null||h.removeAllRanges(),h==null||h.addRange(m),s.current.focus()}else n()},[e,i,s,n,l]);const c=g.useMemo(()=>{var h;const m=((h=t==null?void 0:t.tagName)==null?void 0:h.toLowerCase())||"div";return m==="button"?"div":m},[t]),u=g.useCallback(m=>{(m.key==="Enter"||m.key==="Escape")&&o(m)},[o]),p=g.useCallback(()=>{n()},[n]),f=g.useMemo(()=>{var m;return{id:"active-inline-editing-element",contentEditable:!0,className:`${((m=t==null?void 0:t.className)==null?void 0:m.replace("sr-only",""))||""} outline outline-[2px] outline-green-500 shadow-none empty:before:content-[attr(data-placeholder)] empty:before:text-gray-400 empty:before:absolute empty:before:pointer-events-none empty:before:select-none empty:before:inset-0 empty:before:z-0 relative min-h-[1em]`,style:d.cloneDeep(t==null?void 0:t.style)||{},onInput:h=>{const x=h.target;x&&(x.innerText.trim()===""?(x.setAttribute("data-placeholder","Enter text here"),x.children.length>0&&x.children[0].remove()):h.target.removeAttribute("data-placeholder"),r(h.target.innerText))},onClick:h=>{h.stopPropagation(),h.preventDefault()}}},[t==null?void 0:t.className,t==null?void 0:t.style,r]);return a.jsx(a.Fragment,{children:g.createElement(c,{ref:s,onBlur:p,onKeyDown:u,...f})})}),km=g.memo(({block:t,children:e})=>{const n="content",{document:s}=Xe(),{editingBlockId:r,editingItemIndex:o,setEditingBlockId:i,setEditingItemIndex:l}=Ft(),[c,u]=g.useState(null),p=g.useRef(null),{clearHighlight:f}=rt(),m=st(),{selectedLang:h}=_e(),[,x]=U(),b=g.useRef(null),y=r,{blockContent:v,blockType:w}=g.useMemo(()=>{var P;const S=t._type;let A=t[n];const C=K.getRegisteredChaiBlock(t._type);return h&&((P=C==null?void 0:C.i18nProps)==null?void 0:P.includes(n))&&d.has(t,`${n}-${h}`)&&(A=d.get(t,`${n}-${h}`)),{blockContent:A,blockType:S}},[t,h]),I=g.useCallback(S=>{var C;const A=S||((C=p.current)==null?void 0:C.innerText);m([y],{[n]:A}),u(null),i(""),l(-1),x([]),y&&setTimeout(()=>x([y]),100)},[m,y,i,l,x]),N=ve.useDebouncedCallback(S=>{m([y],{[n]:S})},[y,t,m,h],1e3),E=g.useCallback(S=>{S.preventDefault(),y&&(b.current=y),I(),setTimeout(()=>{const A=b.current;b.current=null,A&&x([A])},100)},[y,I,x]);g.useEffect(()=>{var T;if(!y||!s)return;const S=`[data-block-id="${y}"]`,A=o>=0?`[data-block-index="${o}"]`:"",C=s.querySelector(`${S}${A}`);C&&((T=C==null?void 0:C.classList)==null||T.add("sr-only"),g.startTransition(()=>u(C)))},[y,w,s,o]);const _=g.useMemo(()=>c?(f(),["RichText","Paragraph"].includes(w)?a.jsx(bm,{blockContent:v,editingElement:c,onChange:N,onClose:I,onEscape:E}):a.jsx(ym,{editorRef:p,blockContent:v,editingElement:c,onClose:I,onChange:N,onEscape:E})):null,[c,f,w,v,I,N,E]);return a.jsxs(a.Fragment,{children:[_,e]})},(t,e)=>t.block._id===e.block._id&&t.block.content===e.block.content),Ol=g.createContext({index:-1,key:""}),va=g.createContext(0),vm=["Box","Repeater","GlobalBlock","PartialBlock","Heading","Text","RichText","Span","Image","Button","Paragraph","Link","Video","Audio","Icon","List","ListItem","CustomScript","CustomHTML"],wm=({asyncProps:t,blockAtom:e,children:n})=>{const{editingBlockId:s,editingItemIndex:r}=Ft(),[o]=j.useAtom(e),i=g.useMemo(()=>K.getRegisteredChaiBlock(o._type),[o._type]),{selectedLang:l,fallbackLang:c}=_e(),u=Op(),p=tn(),[f]=j.useAtom(Kr),m=d.get(i,"component",null),{index:h,key:x}=g.useContext(Ol),{mode:b}=Hi(),y=j.useAtomValue(en),v=Ye(),w=b==="edit",I=Dp(),N=g.useMemo(()=>f?pe.applyBindingToBlockProps(pe.applyLanguage(o,l,i),p,{index:h,key:x}):pe.applyLanguage(o,l,i),[o,l,i,p,f,h,x]),E=g.useMemo(()=>pe.getBlockTagAttributes(o,!0,y),[o,pe.getBlockTagAttributes,y]),_=g.useMemo(()=>u(o._id,pe.getBlockRuntimeProps(o._type)),[o._id,o._type,u,pe.getBlockRuntimeProps]),S=g.useMemo(()=>{const O={"data-block-id":o._id,"data-block-type":o._type,"data-block-index":h};return w&&v?{...O,draggable:!s,onMouseDown:I.onMouseDown,onDragStart:I.onDragStart,onDragEnd:I.onDragEnd}:O},[o._id,o._type,h,w,v,I,s]),A=g.useMemo(()=>({blockProps:S,inBuilder:b==="edit",lang:l||c,pageData:p,...N,...E,..._,...t}),[b,S,l,c,N,E,_,t]),C=g.useMemo(()=>!vm.includes(o._type),[o._type]),T=g.useMemo(()=>d.get(o,"_show",!0),[o]);if(d.isNull(m)||!T)return null;let P=a.jsx(g.Suspense,{children:g.createElement(m,{...A,children:n({_id:o._id,_type:o._type,...d.isArray(N.repeaterItems)?{repeaterItems:pe.applyLimit(N.repeaterItems,o),$repeaterItemsKey:N.$repeaterItemsKey}:{},...o.partialBlockId?{partialBlockId:o.partialBlockId}:"",...o.globalBlock?{partialBlockId:o.globalBlock}:""})})});const R=s===o._id&&(r===h||h<0)?a.jsx(km,{block:o,children:P}):P;return C?a.jsx(At.ErrorBoundary,{fallbackRender:zp,children:R}):R},Cm=({children:t,partialBlockId:e})=>{const n=$("gotoPage",d.noop),{saveState:s}=sn(),{selectedLang:r,fallbackLang:o}=_e(),i=g.useCallback(l=>{if(l.stopPropagation(),s!=="SAVED"){ce.toast.error("You have unsaved changes. Please save the page first.");return}n({pageId:e,lang:r||o})},[s,n,e,r,o]);return a.jsxs(a.Fragment,{children:[t,a.jsx("div",{className:"partial-overlay group absolute inset-0 z-50",children:a.jsx("div",{onDoubleClick:i,className:"flex h-full w-full items-center justify-center bg-black/10 opacity-0 transition-opacity duration-300 ease-in-out group-hover:opacity-100 group-hover:backdrop-opacity-85",children:a.jsx("p",{className:"rounded-md bg-white px-2 py-1 text-xs",children:"Partial block. Double click to edit."})})})]})},jm=()=>a.jsx("div",{className:"flex items-center justify-center rounded-md border border-destructive bg-destructive/10 p-4 text-center text-sm text-destructive",children:a.jsxs("p",{children:["Maximum partial nesting depth (",rs," levels) exceeded"]})}),Sm=({partialBlockId:t})=>{const{getPartialBlocks:e}=As(),n=g.useContext(va),s=g.useMemo(()=>e(t),[e,t]),r=g.useMemo(()=>Ne.splitAtom(j.atom(s)),[s]);return n>=rs?a.jsx(jm,{}):d.isEmpty(s)?null:a.jsx(va.Provider,{value:n+1,children:a.jsx(Cm,{partialBlockId:t,children:a.jsx(hs,{splitAtoms:r,blocks:s,type:"PartialBlock"})})})},hs=({blocks:t,parent:e=null,splitAtoms:n=void 0,type:s=""})=>{const r=Cu(n);let o=g.useMemo(()=>d.filter(t,l=>d.has(l,"_id")&&(d.isEmpty(e)?!l._parent:l._parent===e)),[t,e]);const i=g.useCallback(l=>d.filter(t,c=>c._parent===l).length>0,[t]);return(s==="Heading"||s==="Paragraph"||s==="Link")&&(o=pe.adjustSpacingInContentBlocks(o)),d.map(o,l=>{const c=r(l._id);return c?a.jsx(Fp,{block:l,children:u=>a.jsx(wm,{blockAtom:c,asyncProps:u,children:({_id:p,_type:f,partialBlockId:m,repeaterItems:h,$repeaterItemsKey:x})=>f==="Repeater"?d.isArray(h)&&h.map((b,y)=>a.jsx(Ol.Provider,{value:{index:y,key:x},children:a.jsx(hs,{splitAtoms:n,blocks:t,parent:l._id,type:f})},`${p}-${y}`)):f==="GlobalBlock"||f==="PartialBlock"?a.jsx(j.Provider,{store:We,children:a.jsx(Sm,{partialBlockId:m})}):i(p)?a.jsx(hs,{splitAtoms:n,blocks:t,parent:l._id,type:f}):null})},l._id):null})},Nm=()=>{const[t]=Z();return a.jsx(hs,{splitAtoms:In,blocks:t})},Em=()=>{const[t]=Z(),[e]=j.useAtom(Gr),n=d.isEmpty(t)?null:a.jsx(Nm,{},e);return a.jsx(a.Fragment,{children:n})},Am=Ne.atomWithStorage("canvasZoom",100),$l=()=>j.useAtom(Am),Im=()=>j.useAtom(ni),Fl=Ne.atomWithStorage("canvasWidth",800),_m=Ne.atomWithStorage("canvasDisplayWidth",800),zl=j.atom(t=>{const e=t(Fl);return ke.getBreakpointValue(e).toLowerCase()}),ms=()=>{const[t,e]=j.useAtom(Fl),n=j.useAtomValue(zl),[s,r]=Im();return g.useEffect(()=>{s!=="xs"&&r(n)},[n,s,r]),[t,n,e]},ho=()=>{const[t,e]=j.useAtom(_m);return[t,e]},Tm=t=>{const[e]=ho(),[,n]=$l(),s=$("htmlDir","ltr"),[r,o]=g.useState({}),i=g.useCallback(()=>{const{width:l,height:c}=t;if(l<e){const u=parseFloat((l/e).toFixed(2).toString());let p={};const f=c*u,m=l*u;c&&(p={height:100+(c-f)/f*100+"%",width:100+(l-m)/m*100+"%"}),o({position:"relative",top:0,transform:`scale(${u})`,transformOrigin:s==="rtl"?"top right":"top left",...p,maxWidth:"none"}),n(u*100)}else o({}),n(100)},[e,t,s,n]);return g.useEffect(()=>{i()},[e,t,n,i]),r};function Yt(t,e){g.useEffect(()=>{const n=re.subscribe(t,e);return()=>n()},[t,e])}const Bm=()=>{const[,t]=U(),[e,n]=Ae(),{document:s}=Xe(),{clearHighlight:r}=rt(),[o]=U(),[i]=j.useAtom(Ur);return g.useEffect(()=>{setTimeout(()=>{if(!d.isEmpty(e))return;const l=Ri(s,d.first(o));if(l){const c=l.getAttribute("data-style-prop");if(c){const u=l.getAttribute("data-style-id"),p=l.getAttribute("data-block-parent");n([{id:u,prop:c,blockId:p}])}}},100)},[s,o,n,e]),g.useEffect(()=>()=>r(),[r]),Yt(Y.CANVAS_BLOCK_SELECTED,l=>{l&&(!d.isEmpty(l)&&!d.includes(o,d.first(l))&&(i==null||i.closeAll()),t(l))}),Yt(Y.CANVAS_BLOCK_STYLE_SELECTED,l=>{if(!l)return;const{blockId:c,styleId:u,styleProp:p}=l;c&&(d.includes(o,c)||i==null||i.closeAll(),n([{id:u,prop:p,blockId:c}]),t([c]))}),Yt(Y.CLEAR_CANVAS_SELECTION,()=>{r(),t([]),n([])}),null},Rm=()=>{const[t]=ho(),[,e]=Ei(),n=g.useRef(null),s=g.useRef(null),[r,o]=g.useState({width:0,height:0}),i=Tm(r),[,l]=rn(),c=$("loading",!1),u=$("htmlDir","ltr"),{onDragOver:p,onDrop:f,onDragEnd:m}=on(),h=ip(),x=g.useCallback(y=>{o(v=>({...v,width:y}))},[o]);g.useEffect(()=>{if(!s.current)return;const{clientWidth:y,clientHeight:v}=s.current;o({width:y,height:v})},[s,t]);const b=g.useMemo(()=>{let y=Pi;return y=y.replace("__HTML_DIR__",u),y},[u]);return a.jsx(Mp,{onMount:x,onResize:x,children:a.jsx("div",{onMouseLeave:()=>setTimeout(()=>e(""),300),className:"relative mx-auto h-full w-full overflow-hidden",onDragOver:p,onDrop:f,onDragEnd:m,ref:s,children:a.jsxs(Mi,{contentDidMount:()=>l(n.current),ref:n,id:"canvas-iframe",style:{...i,...d.isEmpty(i)?{width:`${t}px`}:{}},className:"relative mx-auto box-content h-full w-full max-w-full shadow-lg transition-all duration-300 ease-linear",initialContent:b,children:[a.jsx(_p,{}),a.jsx(Sp,{}),a.jsx(Bp,{}),a.jsxs(Ad.Provider,{children:[a.jsxs(Cp,{children:[c?a.jsx("div",{className:"h-full p-4",children:a.jsx(Lt,{className:"h-full"})}):a.jsx(Em,{}),a.jsx(Tp,{})]}),a.jsx(Bm,{})]}),h.isVisible&&a.jsx("div",{id:"placeholder",className:`pointer-events-none absolute z-[99999] max-w-full transition-all duration-150 ${h.isEmpty?"bg-purple-500/10 outline-dashed outline-2 -outline-offset-2 outline-purple-500":"rounded-full bg-green-500"}`,style:{top:h.top,left:h.left,width:h.width,height:h.height}})]})})})},vn=()=>{const{t}=F.useTranslation();return a.jsx("div",{className:"h-full w-full rounded-md bg-red-200 p-4 text-red-500",children:a.jsxs("div",{className:"flex h-full w-full flex-col items-center justify-center",children:[a.jsx("p",{className:"font-semibold",children:t("Oops! Something went wrong.")}),a.jsx("p",{children:t("Please try again.")})]})})},Pm=j.atom(null),mo=()=>j.useAtom(Pm),Lm=g.lazy(()=>Promise.resolve().then(()=>require("./code-editor-Cim6jQVF.cjs"))),Hl=()=>{const[t]=mo(),e=$("onError",d.noop);return a.jsx("div",{className:"flex h-full max-h-full w-full flex-1 flex-col",children:a.jsxs("div",{className:"relative flex h-full max-h-full flex-col overflow-hidden bg-gray-100/40",children:[a.jsx(g.Suspense,{fallback:a.jsx(Lt,{className:"h-full"}),children:a.jsx(At.ErrorBoundary,{fallback:a.jsx(vn,{}),onError:e,children:a.jsx(Rm,{})})}),t?a.jsx(g.Suspense,{fallback:a.jsx(Lt,{className:"h-full"}),children:a.jsx(Lm,{})}):null]})})},Ot={ab:"Abkhazian",aa:"Afar",af:"Afrikaans",ak:"Akan",sq:"Albanian",am:"Amharic",ar:"Arabic",an:"Aragonese",hy:"Armenian",as:"Assamese",av:"Avaric",ae:"Avestan",ay:"Aymara",az:"Azerbaijani",bm:"Bambara",ba:"Bashkir",eu:"Basque",be:"Belarusian",bn:"Bengali",bh:"Bihari",bi:"Bislama",bs:"Bosnian",br:"Breton",bg:"Bulgarian",my:"Burmese",ca:"Catalan",ch:"Chamorro",ce:"Chechen",ny:"Chichewa",zh:"Chinese","zh-Hans":"Chinese (Simplified)","zh-Hant":"Chinese (Traditional)",cv:"Chuvash",kw:"Cornish",co:"Corsican",cr:"Cree",hr:"Croatian",cs:"Czech",da:"Danish",dv:"Maldivian",nl:"Dutch",dz:"Dzongkha",en:"English",eo:"Esperanto",et:"Estonian",ee:"Ewe",fo:"Faroese",fj:"Fijian",fi:"Finnish",fr:"French",ff:"Fula, Pular",gl:"Galician",gd:"Gaelic (Scottish)",gv:"Manx",ka:"Georgian",de:"German",el:"Greek",kl:"Kalaallisut",gn:"Guarani",gu:"Gujarati",ht:"Haitian Creole",ha:"Hausa",he:"Hebrew",hz:"Herero",hi:"Hindi",ho:"Hiri Motu",hu:"Hungarian",is:"Icelandic",io:"Ido",ig:"Igbo",id:"Indonesian",ia:"Interlingua",ie:"Interlingue",iu:"Inuktitut",ik:"Inupiak",ga:"Irish",it:"Italian",ja:"Japanese",jv:"Javanese",kn:"Kannada",kr:"Kanuri",ks:"Kashmiri",kk:"Kazakh",km:"Khmer",ki:"Kikuyu",rw:"Kinyarwanda",rn:"Kirundi",ky:"Kyrgyz",kv:"Komi",kg:"Kongo",ko:"Korean",ku:"Kurdish",kj:"Kwanyama",lo:"Lao",la:"Latin",lv:"Latvian",li:"Limburgish",ln:"Lingala",lt:"Lithuanian",lu:"Luga-Katanga",lg:"Luganda, Ganda",lb:"Luxembourgish",mk:"Macedonian",mg:"Malagasy",ms:"Malay",ml:"Malayalam",mt:"Maltese",mi:"Maori",mr:"Marathi",mh:"Marshallese",mo:"Moldavian",mn:"Mongolian",na:"Nauru",nv:"Navajo",ng:"Ndonga",nd:"Northern Ndebele",ne:"Nepali",no:"Norwegian",nb:"Norwegian bokmål",nn:"Norwegian nynorsk",ii:"Sichuan Yi",oc:"Occitan",oj:"Ojibwe",cu:"Old Church Slavonic",or:"Oriya",om:"Oromo",os:"Ossetian",pi:"Pāli",ps:"Pashto, Pushto",fa:"Persian (Farsi)",pl:"Polish",pt:"Portuguese",pa:"Punjabi (Eastern)",qu:"Quechua",rm:"Romansh",ro:"Romanian",ru:"Russian",se:"Sami",sm:"Samoan",sg:"Sango",sa:"Sanskrit",sr:"Serbian",sh:"Serbo-Croatian",st:"Sesotho",tn:"Setswana",sn:"Shona",sd:"Sindhi",si:"Sinhalese",ss:"Swati",sk:"Slovak",sl:"Slovenian",so:"Somali",nr:"Southern Ndebele",es:"Spanish",su:"Sundanese",sw:"Swahili (Kiswahili)",sv:"Swedish",tl:"Tagalog",ty:"Tahitian",tg:"Tajik",ta:"Tamil",tt:"Tatar",te:"Telugu",th:"Thai",bo:"Tibetan",ti:"Tigrinya",to:"Tonga",ts:"Tsonga",tr:"Turkish",tk:"Turkmen",tw:"Twi",ug:"Uyghur",uk:"Ukrainian",ur:"Urdu",uz:"Uzbek",ve:"Venda",vi:"Vietnamese",vo:"Volapük",wa:"Wallon",cy:"Welsh",wo:"Wolof",fy:"Western Frisian",xh:"Xhosa",yi:"Yiddish",yo:"Yoruba",za:"Zhuang, Chuang",zu:"Zulu"},Mm=({id:t,placeholder:e})=>{const{t:n}=F.useTranslation(),[,s]=mo(),{selectedLang:r}=_e(),o=J(),i=t.replace("root.",""),l=K.getRegisteredChaiBlock(o==null?void 0:o._type),u=d.includes(d.get(l,"i18nProps",[]),i)&&r?`${i}-${r}`:i,p=d.get(o,u,""),f=g.useMemo(()=>d.get(Ot,r,r),[r]),m=()=>{const h=o==null?void 0:o._id;s({blockId:h,blockProp:u,placeholder:e,initialCode:p})};return a.jsxs("div",{className:"mt-2 flex flex-col gap-y-1",children:[a.jsxs("label",{htmlFor:t,children:["HTML Code",f&&a.jsxs("small",{className:"text-[9px] text-zinc-400",children:[" ",f]})]}),a.jsx("button",{onClick:m,className:"w-[90%] max-w-full cursor-default truncate text-pretty rounded border border-border bg-background p-2 text-left text-[10px]",children:p.trim().length>0?p.substring(0,46):e||"Eg: <script>console.log('Hello, world!');<\/script>"}),a.jsx(B.Button,{onClick:m,size:"sm",variant:"outline",className:"w-fit",children:n("Open code editor")})]})},Dm=({id:t,value:e,onChange:n,onBlur:s})=>{const r=$("collections",[]),o=J(),i=d.get(o,"repeaterItems","").replace(/\{\{(.*)\}\}/g,"$1").replace(q.COLLECTION_PREFIX,""),l=d.find(r,{id:i}),c=t==="root.filter"?"filters":"sorts",u=d.get(l,c,[]);return a.jsx("div",{children:a.jsxs("select",{value:e,onChange:p=>n(p.target.value),onBlur:p=>s(t,p.target.value),children:[a.jsx("option",{value:"",children:"Select"}),u.map(p=>a.jsx("option",{value:p.id,children:p.name},p.id))]})})},Om=g.lazy(()=>Promise.resolve().then(()=>require("./IconPicker-BJHUCDn4.cjs")).then(t=>({default:t.IconPicker}))),$m=t=>{try{let e=t.replace(/<svg([^>]*)\sheight="[^"]*"([^>]*)>/gi,"<svg$1$2>").replace(/<svg([^>]*)\swidth="[^"]*"([^>]*)>/gi,"<svg$1$2>");return e=e.replace(/>\s+</g,"><"),e=e.replace(/\n/g,"").replace(/\s{2,}/g," "),e=e.replace(/\s+=/g,"=").replace(/=\s+/g,"="),e=e.replace(/<!--[\s\S]*?-->/g,""),e.trim()}catch{return t}},Fm=({value:t,onChange:e,id:n})=>{const{t:s}=F.useTranslation(),[r,o]=g.useState(t||"");g.useEffect(()=>{o(t||"")},[t]);const i=l=>{o(l);const c=$m(l);e(c)};return a.jsxs("div",{className:"mt-1 flex flex-col gap-2",id:"icon-picker-field",children:[a.jsxs("div",{className:"flex items-center gap-x-2",children:[a.jsx("div",{className:"flex h-12 w-12 items-center justify-center overflow-hidden rounded-lg border bg-gray-50",children:r?a.jsx("div",{className:"h-6 w-6",dangerouslySetInnerHTML:{__html:r}}):a.jsx("span",{className:"text-xs text-gray-400",children:"SVG"})}),a.jsx("textarea",{id:n,autoCapitalize:"off",autoCorrect:"off",spellCheck:"false",value:r,onChange:l=>i(l.target.value),placeholder:s("SVG_code"),rows:2,className:"no-scrollbar w-full rounded-md border border-border bg-background px-3 py-1.5 text-xs shadow-sm transition-colors placeholder:text-muted-foreground focus-visible:outline-none focus-visible:ring-1 focus-visible:ring-ring disabled:cursor-not-allowed disabled:opacity-50"})]}),a.jsxs("div",{className:"flex items-center gap-2",children:[a.jsx(g.Suspense,{fallback:a.jsx("div",{className:"text-xs text-muted-foreground",children:"Loading..."}),children:a.jsx(Om,{onSelectIcon:i})}),a.jsx("p",{className:"text-xs text-muted-foreground",children:s("Paste SVG_code")})]})]})},Pn=ae.Root,Vl=ae.Trigger,zm=ae.Portal,Wl=D.forwardRef(({className:t,...e},n)=>a.jsx(ae.Overlay,{ref:n,className:B.cn("fixed inset-0 z-50 bg-black/80 data-[state=open]:animate-in data-[state=closed]:animate-out data-[state=closed]:fade-out-0 data-[state=open]:fade-in-0",t),...e}));Wl.displayName=ae.Overlay.displayName;const cn=D.forwardRef(({className:t,children:e,...n},s)=>a.jsxs(zm,{children:[a.jsx(Wl,{}),a.jsxs(ae.Content,{ref:s,className:B.cn("fixed left-[50%] top-[50%] z-50 grid w-full max-w-lg translate-x-[-50%] translate-y-[-50%] gap-4 border bg-background p-6 shadow-lg duration-200 data-[state=open]:animate-in data-[state=closed]:animate-out data-[state=closed]:fade-out-0 data-[state=open]:fade-in-0 data-[state=closed]:zoom-out-95 data-[state=open]:zoom-in-95 data-[state=closed]:slide-out-to-left-1/2 data-[state=closed]:slide-out-to-top-[48%] data-[state=open]:slide-in-from-left-1/2 data-[state=open]:slide-in-from-top-[48%] sm:rounded-lg",t),...n,children:[e,a.jsxs(ae.Close,{className:"absolute right-4 top-4 rounded-sm opacity-70 ring-offset-background transition-opacity hover:opacity-100 focus:outline-none focus:ring-2 focus:ring-ring focus:ring-offset-2 disabled:pointer-events-none data-[state=open]:bg-accent data-[state=open]:text-muted-foreground",children:[a.jsx(k.Cross1Icon,{className:"h-4 w-4"}),a.jsx("span",{className:"sr-only",children:"Close"})]})]})]}));cn.displayName=ae.Content.displayName;const Ln=({className:t,...e})=>a.jsx("div",{className:B.cn("flex flex-col space-y-1.5 text-center sm:text-left",t),...e});Ln.displayName="DialogHeader";const Gl=({className:t,...e})=>a.jsx("div",{className:B.cn("flex flex-col-reverse sm:flex-row sm:justify-end sm:space-x-2",t),...e});Gl.displayName="DialogFooter";const dn=D.forwardRef(({className:t,...e},n)=>a.jsx(ae.Title,{ref:n,className:B.cn("text-lg font-semibold leading-none tracking-tight",t),...e}));dn.displayName=ae.Title.displayName;const Ul=D.forwardRef(({className:t,...e},n)=>a.jsx(ae.Description,{ref:n,className:B.cn("text-sm text-muted-foreground",t),...e}));Ul.displayName=ae.Description.displayName;const Qn=({assetId:t,children:e,onSelect:n,mode:s="image"})=>{const[r,o]=g.useState(!1),i=B.useMediaManagerComponent(),l=(...c)=>{n.call(void 0,...c),o(!1)};return a.jsxs(Pn,{open:r,onOpenChange:c=>o(c),children:[a.jsx(Vl,{asChild:!0,children:e}),a.jsxs(cn,{className:"flex max-h-[90vh] max-w-7xl border-border md:w-fit",children:[a.jsx(dn,{className:"sr-only",children:"Media Manager"}),a.jsx("div",{className:"h-full w-full",children:i?a.jsx(i,{close:()=>o(!1),onSelect:l,mode:s,assetId:t}):null})]})]})};Qn.displayName="MediaManagerModal";const Yn="data:image/svg+xml;base64,PHN2ZyB3aWR0aD0iNTAwIiBoZWlnaHQ9IjQwMCIgeG1sbnM9Imh0dHA6Ly93d3cudzMub3JnLzIwMDAvc3ZnIj48cmVjdCB3aWR0aD0iMTAwJSIgaGVpZ2h0PSIxMDAlIiBmaWxsPSIjZjNmNGY2Ii8+PHRleHQgeD0iNTAlIiB5PSI1MCUiIGZvbnQtZmFtaWx5PSJBcmlhbCwgc2Fucy1zZXJpZiIgZm9udC1zaXplPSIxNiIgZmlsbD0iI2Q1ZDdkYSIgdGV4dC1hbmNob3I9Im1pZGRsZSIgZHk9Ii4zZW0iPkltYWdlIFBsYWNlaG9sZGVyPC90ZXh0Pjwvc3ZnPg==",Hm=t=>{var r;if(!t||d.startsWith(t,"data"))return"";const e=((r=t.split("/").pop())==null?void 0:r.split("?")[0])||"";return[".jpg",".jpeg",".png",".gif",".webp",".svg",".bmp",".ico",".avif"].some(o=>e.toLowerCase().endsWith(o))?e:""},Vm=({value:t,onChange:e,id:n,onBlur:s,uiSchema:r})=>{const{t:o}=F.useTranslation(),{selectedLang:i}=_e(),l=J(),c=st(),u=tn(),p=(r==null?void 0:r["ui:allowEmpty"])===!0,f=n.split(".").pop()||"",m=i?`_${f}Id-${i}`:`_${f}Id`,h=d.isEmpty(i)&&(l==null?void 0:l._type)==="Image"&&d.has(l,"assetId"),x=d.get(l,m,h?l==null?void 0:l.assetId:""),b=g.useMemo(()=>{if(!t||!l||!/\{\{.*?\}\}/.test(t))return t;const E={...l,[f]:t},_=pe.applyBindingToBlockProps(E,u,{index:-1,key:""});return d.get(_,f,t)},[t,l,u,f]),y=!!x||b!==Yn&&b!=="",v=N=>{const E=d.isArray(N)?d.first(N):N;if(E){e(E==null?void 0:E.url);const _=E==null?void 0:E.width,S=E==null?void 0:E.height,A=m.includes("mobile");if(l!=null&&l._id){const C={..._&&{[A?"mobileWidth":"width"]:_},...S&&{[A?"mobileHeight":"height"]:S},...E.description&&{alt:E.description}};if(d.set(C,m,E.id),d.isEmpty(C))return;c([l._id],C)}}},w=g.useCallback(()=>{if(e(p?"":Yn),l!=null&&l._id){const E={},_=m.includes("mobile");d.set(E,m,""),d.set(E,_?"mobileWidth":"width",""),d.set(E,_?"mobileHeight":"height",""),c([l._id],E)}},[l,e,c,m,p]),I=Hm(b);return a.jsxs("div",{className:"mt-1.5 flex items-start gap-x-3",children:[b?a.jsxs("div",{className:"group relative",children:[a.jsx("img",{src:b,className:"h-14 w-14 overflow-hidden rounded-md border border-border object-cover transition duration-200 "+(x&&x!==""?"cursor-pointer group-hover:blur-sm":""),alt:""}),y&&a.jsx("button",{type:"button",onClick:w,className:"absolute -right-2 -top-2 z-20 rounded-full bg-destructive p-1 text-destructive-foreground hover:bg-destructive/90",children:a.jsx(k.Cross1Icon,{className:"h-3 w-3"})}),x&&x!==""&&a.jsx(Qn,{onSelect:v,assetId:x,children:a.jsx("button",{type:"button",className:"absolute inset-0 z-10 flex cursor-pointer items-center justify-center bg-black/10 opacity-0 transition duration-200 group-hover:bg-black/30 group-hover:opacity-100",children:a.jsx(k.Pencil2Icon,{className:"h-4 w-4 text-white"})})})]}):a.jsx(Qn,{onSelect:v,mode:"image",assetId:x,children:a.jsx("div",{className:"h-14 w-14 cursor-pointer rounded-md border border-border bg-[radial-gradient(#AAA,transparent_1px)] duration-300 [background-size:10px_10px]"})}),a.jsxs("div",{className:"flex w-3/5 flex-col",children:[a.jsxs(a.Fragment,{children:[a.jsx("p",{className:"max-w-[250px] truncate pr-2 text-xs text-gray-400",children:I}),a.jsx(Qn,{onSelect:v,assetId:"",children:a.jsx("small",{className:"mb-1 h-6 w-full cursor-pointer rounded-md bg-secondary px-1 py-1 text-center text-xs text-secondary-foreground hover:bg-secondary/80",children:!d.isEmpty(b)&&b!==Yn?o("Replace image"):o("Choose image")})}),a.jsx("div",{className:"text-center text-xs text-gray-400",children:"OR"})]}),a.jsx("input",{id:n,autoCapitalize:"off",autoCorrect:"off",spellCheck:"false",type:"url",className:"h-6 text-xs",placeholder:o("Enter image URL"),value:t===Yn?"":t,onBlur:({target:{value:N}})=>s(n,N),onChange:N=>e(N.target.value)})]})]})},Wm=Sr.cva("inline-flex items-center rounded-md border px-2.5 py-0.5 text-xs font-semibold transition-colors focus:outline-none focus:ring-2 focus:ring-ring focus:ring-offset-2",{variants:{variant:{default:"border-transparent bg-primary text-primary-foreground shadow hover:bg-primary/80",secondary:"border-transparent bg-secondary text-secondary-foreground hover:bg-secondary/80",destructive:"border-transparent bg-destructive text-destructive-foreground shadow hover:bg-destructive/80",outline:"text-foreground"}},defaultVariants:{variant:"default"}});function Rs({className:t,variant:e,...n}){return a.jsx("div",{className:B.cn(Wm({variant:e}),t),...n})}const gs=Jt.Provider,fe=Jt.Root,he=Jt.Trigger,ue=D.forwardRef(({className:t,sideOffset:e=4,...n},s)=>a.jsx(Jt.Portal,{children:a.jsx(Jt.Content,{ref:s,sideOffset:e,className:B.cn("z-50 origin-[--radix-tooltip-content-transform-origin] overflow-hidden rounded-md bg-primary px-3 py-1.5 text-xs text-primary-foreground animate-in fade-in-0 zoom-in-95 data-[state=closed]:animate-out data-[state=closed]:fade-out-0 data-[state=closed]:zoom-out-95 data-[side=bottom]:slide-in-from-top-2 data-[side=left]:slide-in-from-right-2 data-[side=right]:slide-in-from-left-2 data-[side=top]:slide-in-from-bottom-2",t),...n})}));ue.displayName=Jt.Content.displayName;const go=D.forwardRef(({className:t,...e},n)=>a.jsx(De.Command,{ref:n,className:B.cn("flex h-full w-full flex-col overflow-hidden rounded-md bg-popover text-popover-foreground",t),...e}));go.displayName=De.Command.displayName;const xo=D.forwardRef(({className:t,...e},n)=>a.jsxs("div",{className:"flex items-center border-b px-3","cmdk-input-wrapper":"",children:[a.jsx(k.MagnifyingGlassIcon,{className:"mr-2 h-4 w-4 shrink-0 opacity-50"}),a.jsx(De.Command.Input,{ref:n,className:B.cn("flex h-10 w-full rounded-md bg-transparent py-3 text-sm outline-none placeholder:text-muted-foreground disabled:cursor-not-allowed disabled:opacity-50",t),...e})]}));xo.displayName=De.Command.Input.displayName;const bo=D.forwardRef(({className:t,...e},n)=>a.jsx(De.Command.List,{ref:n,className:B.cn("max-h-[300px] overflow-y-auto overflow-x-hidden",t),...e}));bo.displayName=De.Command.List.displayName;const yo=D.forwardRef((t,e)=>a.jsx(De.Command.Empty,{ref:e,className:"py-6 text-center text-sm",...t}));yo.displayName=De.Command.Empty.displayName;const ko=D.forwardRef(({className:t,...e},n)=>a.jsx(De.Command.Group,{ref:n,className:B.cn("overflow-hidden p-1 text-foreground [&_[cmdk-group-heading]]:px-2 [&_[cmdk-group-heading]]:py-1.5 [&_[cmdk-group-heading]]:text-xs [&_[cmdk-group-heading]]:font-medium [&_[cmdk-group-heading]]:text-muted-foreground",t),...e}));ko.displayName=De.Command.Group.displayName;const Gm=D.forwardRef(({className:t,...e},n)=>a.jsx(De.Command.Separator,{ref:n,className:B.cn("-mx-1 h-px bg-border",t),...e}));Gm.displayName=De.Command.Separator.displayName;const xs=D.forwardRef(({className:t,...e},n)=>a.jsx(De.Command.Item,{ref:n,className:B.cn("relative flex cursor-default select-none items-center gap-2 rounded-sm px-2 py-1.5 text-sm outline-none data-[disabled=true]:pointer-events-none data-[selected=true]:bg-accent data-[selected=true]:text-accent-foreground data-[disabled=true]:opacity-50 [&_svg]:pointer-events-none [&_svg]:size-4 [&_svg]:shrink-0",t),...e}));xs.displayName=De.Command.Item.displayName;const vo=wn.Root,wo=wn.Trigger,Ps=D.forwardRef(({className:t,align:e="center",sideOffset:n=4,...s},r)=>a.jsx(wn.Portal,{children:a.jsx(wn.Content,{ref:r,align:e,sideOffset:n,className:B.cn("z-50 w-72 origin-[--radix-popover-content-transform-origin] rounded-md border bg-popover p-4 text-popover-foreground shadow-md outline-none data-[state=open]:animate-in data-[state=closed]:animate-out data-[state=closed]:fade-out-0 data-[state=open]:fade-in-0 data-[state=closed]:zoom-out-95 data-[state=open]:zoom-in-95 data-[side=bottom]:slide-in-from-top-2 data-[side=left]:slide-in-from-right-2 data-[side=right]:slide-in-from-left-2 data-[side=top]:slide-in-from-bottom-2",t),...s})}));Ps.displayName=wn.Content.displayName;const Um=({data:t,onSelect:e,dataType:n})=>{const[s,r]=g.useState([]),[o,i]=g.useState(t),l=f=>Array.isArray(f)?"array":typeof f=="object"&&f!==null?"object":"value",c=g.useCallback(f=>{const m=h=>n==="value"?h==="value"||h==="object":n==="array"?h==="array":h===n;f.type==="object"?(r(h=>[...h,f.key]),i(f.value)):m(f.type)&&e([...s,f.key].join("."),n)},[s,e,n]),u=g.useCallback(()=>{if(s.length>0){const f=s.slice(0,-1);r(f),i(f.reduce((m,h)=>m[h],t))}},[s,t]),p=g.useMemo(()=>o?Object.entries(o).map(([f,m])=>({key:f,value:m,type:l(m)})).filter(f=>!d.startsWith(f.key,q.REPEATER_PREFIX)&&f.key.includes("/")?!1:n==="value"?f.type==="value"||f.type==="object":n==="array"?f.type==="array"||f.type==="object":n==="object"?f.type==="object":!0):[],[o,n]);return a.jsxs(go,{className:"fields-command",children:[a.jsx(xo,{className:"border-none",placeholder:"Search..."}),a.jsxs(bo,{children:[a.jsx(yo,{children:mt.t("No option found.")}),a.jsxs(ko,{children:[s.length>0&&a.jsxs(xs,{onSelect:u,className:"flex items-center text-sm",children:[a.jsx(k.ChevronLeftIcon,{className:"mr-2 h-4 w-4"}),mt.t("Back")]}),p.map(f=>a.jsxs(xs,{value:f.key,disabled:!1,onSelect:()=>c(f),className:"flex items-center justify-between",children:[a.jsxs("span",{className:"flex items-center gap-x-2",children:[d.startsWith(f.key,q.REPEATER_PREFIX)?a.jsx(k.LoopIcon,{}):d.startsWith(f.key,q.COLLECTION_PREFIX)?a.jsx(k.IdCardIcon,{}):null,d.startsWith(f.key,q.REPEATER_PREFIX)?mt.t("Repeater Data"):d.startsWith(f.key,q.COLLECTION_PREFIX)?f.key.replace(q.COLLECTION_PREFIX,""):f.key]}),a.jsxs("div",{className:"flex items-center gap-2",children:[n==="object"&&f.type==="object"&&a.jsx(B.Button,{size:"sm",variant:"ghost",className:"h-6 px-2 hover:bg-primary hover:text-primary-foreground",onClick:m=>{m.stopPropagation(),e([...s,f.key].join("."),n)},children:mt.t("Select")}),f.type==="object"&&a.jsx("div",{className:"cursor-pointer rounded p-1 hover:bg-muted",children:a.jsx(k.ChevronRightIcon,{className:"h-4 w-4 opacity-50"})})]})]},f.key))]})]})]})};function Co({data:t,onSelect:e,dataType:n="value"}){const[s,r]=g.useState(!1),o=$("collections",[]),i=g.useMemo(()=>n==="array"?{...o.map(c=>c.id).reduce((c,u)=>({...c,[q.COLLECTION_PREFIX+u]:[]}),{}),...t}:t,[t,o,n]);return a.jsxs(vo,{open:s,onOpenChange:r,children:[a.jsxs(fe,{children:[a.jsx(he,{asChild:!0,children:a.jsx(wo,{asChild:!0,children:a.jsx(B.Button,{size:"sm",variant:"ghost",className:"h-5 rounded-sm px-1 py-0 text-[9px] text-muted-foreground",role:"combobox","aria-expanded":s,children:a.jsx("svg",{xmlns:"http://www.w3.org/2000/svg",width:"24px",height:"24px",viewBox:"0 0 24 24",fill:"none",children:a.jsx("path",{d:"M9.5 5H9C7.89543 5 7 5.89543 7 7V9C7 10 6.4 12 4 12C5 12 7 12.6 7 15V17.0002C7 18.1048 7.89543 19 9 19H9.5M14.5 5H15C16.1046 5 17 5.89543 17 7V9C17 10 17.6 12 20 12C19 12 17 12.6 17 15V17.0002C17 18.1048 16.1046 19 15 19H14.5",stroke:"#000000",strokeLinecap:"round",strokeLinejoin:"round",strokeWidth:"2"})})})})}),a.jsx(ue,{children:mt.t("Add field")})]}),a.jsx(Ps,{className:"z-[1000]! relative mr-3 w-[300px] p-0",children:a.jsx(Um,{data:i,onSelect:(l,c)=>{e(l,c),r(!1)},dataType:n})})]})}const ql=({schema:t,onChange:e,id:n,formData:s})=>{const r=tn(),o=$("flags.dataBinding",!0),i=Hd(),l=J(),c=g.useMemo(()=>{if(i.length===1)return"";const f=i.find(x=>x._type==="Repeater"),h=d.get(f,"repeaterItems","").replace(/\{\{(.*)\}\}/g,"$1");return`${q.REPEATER_PREFIX}${d.startsWith(h,q.COLLECTION_PREFIX)?`${h}/${f==null?void 0:f._id}`:h}`},[i]),u=g.useMemo(()=>d.first(d.get(r,c.replace(q.REPEATER_PREFIX,""),[])),[c,r]),p=g.useCallback((f,m)=>{if(f=d.isEmpty(c)?f:f.replace(`${c}`,"$index"),m==="array"||m==="object"){e(`{{${f}}}`,{},n);return}const h=v=>/[.,!?;:]/.test(v),x=(v,w,I)=>{let N="",E="";const _=w>0?v[w-1]:"",S=w<v.length?v[w]:"";return w>0&&(_==="."||!h(_)&&_!==" ")&&(N=" "),w<v.length&&!h(S)&&S!==" "&&(E=" "),{text:N+I+E,prefixLength:N.length,suffixLength:E.length}},b=document.getElementById(n);if(!b)return;const y=document.getElementById(`chai-rte-${n}`)||document.getElementById(`chai-rte-modal-${n}`);if(y&&(y.querySelector(".ProseMirror")||y.__chaiRTE)){const v=y.__chaiRTE;if(v){const w=`{{${f}}}`;v.commands.focus();const{from:I,to:N}=v.state.selection;if(I!==N)v.chain().deleteSelection().insertContent(w).run();else{const{state:_}=v,S=_.selection.from,A=_.doc.textBetween(Math.max(0,S-1),S),C=_.doc.textBetween(S,Math.min(S+1,_.doc.content.size));let T="";S>0&&A!==" "&&!h(A)&&(T=" ");let P="";C&&C!==" "&&!h(C)&&(P=" "),v.chain().insertContent(T+w+P).run()}setTimeout(()=>e(v.getHTML(),{},n),100);return}}else{const v=b,w=v.selectionStart||0,I=v.value||"",N=v.selectionEnd||w;if(N>w){const C=`{{${f}}}`,{text:T}=x(I,w,C),P=I.slice(0,w)+T+I.slice(N);e(P,{},n);return}const _=`{{${f}}}`,{text:S}=x(I,w,_),A=I.slice(0,w)+S+I.slice(w);e(A,{},n)}},[n,e,s,l==null?void 0:l._id,c]);return o?a.jsx(Co,{data:{...u&&{[c]:u},...r},onSelect:p,dataType:t.binding==="array"?"array":"value"}):null},qm=t=>{const{id:e,classNames:n,label:s,children:r,errors:o,help:i,hidden:l,required:c,schema:u,formData:p,onChange:f}=t,{selectedLang:m,fallbackLang:h,languages:x}=_e(),b=g.useMemo(()=>d.isEmpty(x)?"":d.isEmpty(m)?h:m,[x,m,h]),y=g.useMemo(()=>d.get(Ot,b,b),[b]),v=tn(),w=J(),I=K.useRegisteredChaiBlocks(),N=g.useMemo(()=>d.get(I,[w==null?void 0:w._type,"i18nProps"],[]),[I,w==null?void 0:w._type]),[E,_]=g.useState(null);if(l)return null;if(u.type==="boolean")return a.jsx("div",{className:n,children:r});const A=N==null?void 0:N.includes(e.replace("root.",""));if(u.type==="array"){const P=E===e;return a.jsxs("div",{className:`${n} relative`,children:[u.title&&a.jsx("div",{className:"flex items-center justify-between gap-1",children:a.jsxs("label",{htmlFor:e,onClick:()=>_(P?null:e),className:"flex cursor-pointer items-center gap-x-1 py-1 leading-tight duration-200 hover:bg-slate-100",children:[P?a.jsx(k.ChevronDownIcon,{className:"h-3 w-3"}):a.jsx(k.ChevronRightIcon,{className:"h-3 w-3"}),a.jsx(k.ListBulletIcon,{className:"h-3 w-3"}),a.jsx("span",{className:"leading-tight",children:s})," ",a.jsx(Rs,{className:"m-0 bg-gray-200 px-2 leading-tight text-gray-500 hover:bg-gray-200 hover:text-gray-500",children:a.jsx("span",{className:"text-[9px] font-medium text-slate-600",children:p==null?void 0:p.length})}),u.description&&a.jsx(gs,{children:a.jsxs(fe,{children:[a.jsx(he,{asChild:!0,children:a.jsx(k.InfoCircledIcon,{className:"h-3 w-3 text-muted-foreground/70",onClick:R=>R.stopPropagation(),onMouseDown:R=>R.stopPropagation()})}),a.jsx(ue,{className:"max-w-xs",children:u.description})]})})]})}),(p==null?void 0:p.length)===0?a.jsx("div",{className:"h-0 overflow-hidden",children:r}):a.jsxs("div",{className:`${P?"pt-0.5":"h-0 overflow-hidden"}`,children:[r,o,i]})]})}const C=e.replace("root.",""),T=N.includes(C)&&!d.isEmpty(m)&&d.isEmpty(p);return a.jsxs("div",{className:n,children:[u.title&&a.jsxs("div",{className:"flex items-center justify-between",children:[a.jsxs("div",{className:"flex items-center gap-2",children:[a.jsxs("label",{htmlFor:e,className:u.type==="object"?"pb-2":"",children:[s," ",A&&a.jsxs("small",{className:"text-[9px] text-zinc-400",children:[" ",y]}),c&&u.type!=="object"?" *":null]}),u.description&&a.jsx(gs,{children:a.jsxs(fe,{children:[a.jsx(he,{asChild:!0,children:a.jsx(k.InfoCircledIcon,{className:"h-3 w-3 text-muted-foreground/70"})}),a.jsx(ue,{className:"max-w-xs",children:u.description})]})})]}),!u.enum&&!u.oneOf&&v&&a.jsxs("span",{className:"flex items-center space-x-1",children:[T?a.jsxs(fe,{children:[a.jsx(he,{asChild:!0,children:a.jsxs("svg",{xmlns:"http://www.w3.org/2000/svg",width:"24",height:"24",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor","stroke-width":"2","stroke-linecap":"round","stroke-linejoin":"round",className:"lucide lucide-triangle-alert-icon lucide-triangle-alert h-3 w-3 text-orange-400",children:[a.jsx("path",{d:"m21.73 18-8-14a2 2 0 0 0-3.48 0l-8 14A2 2 0 0 0 4 21h16a2 2 0 0 0 1.73-3"}),a.jsx("path",{d:"M12 9v4"}),a.jsx("path",{d:"M12 17h.01"})]})}),a.jsxs(ue,{className:"max-w-xs",children:["No translation provided. ",a.jsx("br",{}),"Using default language value."]})]}):null,a.jsx(ql,{schema:u,onChange:P=>{f(P,p,e)},id:e,formData:p})]})]}),r,o,i]})},Km=({href:t,pageTypes:e,onChange:n})=>{var A;const{t:s}=F.useTranslation(),r=$("searchPageTypeItems",(C,T)=>[]),[o,i]=g.useState(!1),[l,c]=g.useState(!1),[u,p]=g.useState("page"),[f,m]=g.useState(""),[h,x]=g.useState([]),[b,y]=g.useState(-1),v=g.useRef(null),w=(A=e==null?void 0:e.find(C=>C.key===u))==null?void 0:A.name;g.useEffect(()=>{if(m(""),x([]),y(-1),c(!1),!t||o||!d.startsWith(t,"pageType:"))return;const C=d.split(t,":"),T=d.get(C,1,"page")||"page";p(T),(async()=>{const P=await r(T,[d.get(C,2,"page")]);P&&Array.isArray(P)&&m(d.get(P,[0,"name"],""))})()},[t]);const I=ve.useDebouncedCallback(async C=>{if(d.isEmpty(C))x([]);else{const T=await r(u,C);x(T)}i(!1),y(-1)},[u],300),N=C=>{const T=["pageType",u,C.primaryPage??C.id];T[1]&&(n(T.join(":")),m(C.name),c(!1),x([]),y(-1))},E=C=>{switch(C.key){case"ArrowDown":C.preventDefault(),y(T=>T<h.length-1?T+1:T);break;case"ArrowUp":C.preventDefault(),y(T=>T>0?T-1:T);break;case"Enter":if(C.preventDefault(),h.length===0)return;b>=0&&N(h[b]);break;case"Escape":C.preventDefault(),_();break}};g.useEffect(()=>{if(b>=0&&v.current){const C=v.current.children[b];C==null||C.scrollIntoView({block:"nearest"})}},[b]);const _=()=>{m(""),x([]),y(-1),c(!1),n("")},S=C=>{m(C),c(!d.isEmpty(C)),i(!0),I(C)};return a.jsxs("div",{children:[a.jsx("select",{name:"pageType",value:u,onChange:C=>p(C.target.value),children:d.map(e,C=>a.jsx("option",{value:C.key,children:C.name},C.key))}),u&&a.jsxs("div",{className:"group relative mt-2 flex items-center",children:[a.jsx("input",{type:"text",value:f,onChange:C=>S(C.target.value),onKeyDown:E,placeholder:s(`Search ${w??""}`),className:"w-full rounded-md border border-gray-300 p-2 pr-16"}),a.jsx("div",{className:"absolute bottom-2 right-2 top-3 flex items-center gap-1.5",children:f&&a.jsx("button",{onClick:_,className:"text-gray-400 hover:text-gray-600",title:s("Clear search"),children:a.jsx(k.Cross1Icon,{className:"h-4 w-4"})})})]}),(o||!d.isEmpty(h)||l&&d.isEmpty(h))&&a.jsx("div",{className:"absolute z-40 mt-2 max-h-40 w-full max-w-[250px] overflow-y-auto rounded-md border border-border bg-background shadow-lg",children:o?a.jsxs("div",{className:"space-y-1 p-2",children:[a.jsx("div",{className:"h-6 w-full animate-pulse rounded bg-gray-200"}),a.jsx("div",{className:"h-6 w-full animate-pulse rounded bg-gray-200"})]}):l&&d.isEmpty(h)?a.jsxs("div",{className:"flex items-center justify-center p-4 text-sm text-gray-500",children:[s("No results found for"),' "',f,'"']}):a.jsx("ul",{ref:v,children:d.map(h==null?void 0:h.slice(0,20),(C,T)=>a.jsxs("li",{onClick:()=>N(C),className:`cursor-pointer p-2 text-xs ${t!=null&&t.includes(C.id)?"bg-blue-200":T===b?"bg-gray-100":"hover:bg-gray-100"}`,children:[C.name," ",C.slug&&a.jsxs("small",{className:"font-light text-gray-500",children:["( ",C.slug," )"]}),C.lang&&a.jsx("small",{className:"ml-1 rounded bg-gray-200 px-1 py-0.5 text-[10px] font-medium text-gray-600",children:C.lang})]},C.id))})})]})},Ym=({schema:t,formData:e,onChange:n,name:s})=>{const{t:r}=F.useTranslation(),{type:o="pageType",href:i="",target:l="self"}=e??{},c=$("pageTypes",[]),{selectedLang:u,fallbackLang:p,languages:f}=_e(),m=g.useMemo(()=>d.isEmpty(f)?"":d.isEmpty(u)?p:u,[f,u,p]),h=g.useMemo(()=>d.get(Ot,m,m),[m]),x=o==="pageType"&&d.isEmpty(c)?"url":o;return a.jsxs("div",{children:[a.jsxs("span",{className:"flex items-center justify-between gap-x-2 text-xs font-medium",children:[a.jsxs("span",{children:[(t==null?void 0:t.title)??"Link",a.jsx("span",{className:"pl-1 text-[9px] text-zinc-400",children:h})]}),a.jsx(ql,{schema:t,onChange:b=>{n({...e,href:b,...x==="pageType"?{type:"url"}:{}})},id:`root.${s}.href`,formData:e})]}),a.jsxs("div",{className:"flex flex-col gap-y-1.5",children:[a.jsx("select",{name:"type",value:o,onChange:b=>n({...e,type:b.target.value}),children:d.map([...d.isEmpty(c)?[]:[{const:"pageType",title:r("Goto Page")}],{const:"url",title:r("Open URL")},{const:"email",title:r("Compose Email")},{const:"telephone",title:r("Call Phone")},{const:"scroll",title:r("Scroll to element")}],b=>a.jsx("option",{value:b.const,children:b.title},b.const))}),x==="pageType"&&!d.isEmpty(c)?a.jsx(Km,{href:i,pageTypes:c,onChange:b=>n({...e,href:b})}):null,a.jsx("input",{id:`root.${s}.href`,autoCapitalize:"off",autoCorrect:"off",spellCheck:"false",name:"href",type:"text",className:x==="pageType"?"!hidden":"",value:i,onChange:b=>n({...e,href:b.target.value}),placeholder:r(o==="url"?"Enter URL":o==="scroll"?"#ElementID":"Enter details")}),x==="url"&&a.jsxs("div",{className:"flex items-center gap-x-2 text-muted-foreground",children:[a.jsx("input",{id:`root.${s}.target`,autoCapitalize:"off",autoCorrect:"off",spellCheck:"false",type:"checkbox",checked:l==="_blank",className:"!w-fit cursor-pointer rounded-md border border-border",onChange:()=>n({...e,target:l==="_blank"?"_self":"_blank"})}),a.jsx("span",{className:"pt-1 text-xs",children:r("Open in new tab")})]})]})]})},Xm=({value:t,onChange:e})=>{var o;if(!t)return a.jsxs("div",{className:"mt-1 flex items-center gap-2 rounded-md border border-gray-200 bg-gray-50 px-2 py-1.5 text-xs text-gray-500 text-gray-600",children:[a.jsx(k.FileIcon,{className:"h-4 w-4"})," Choose a collection"]});const n=`{{${q.COLLECTION_PREFIX}`,s=t==null?void 0:t.startsWith(n);let r=t;return s&&(r=(o=t==null?void 0:t.replace(n,""))==null?void 0:o.replace("}}","")),a.jsx("div",{className:"mt-1 flex flex-col gap-1",children:a.jsxs("div",{className:"flex items-center justify-between gap-2 rounded-md border border-blue-200 bg-blue-50 px-2 py-1 text-xs text-blue-600",children:[a.jsxs("span",{className:"flex max-w-[200px] items-center gap-2",children:[" ",s?a.jsx(k.IdCardIcon,{className:"h-3 min-h-3 w-3 min-w-3"}):null,a.jsxs(fe,{delayDuration:500,children:[a.jsx(he,{asChild:!0,children:a.jsx("span",{className:"cursor-default truncate",children:r})}),a.jsx(ue,{side:"left",hidden:r.length<50,children:r})]})]}),a.jsxs(fe,{children:[a.jsx(he,{asChild:!0,children:a.jsx(B.Button,{variant:"ghost",size:"icon",className:"h-5 w-5 rounded-full bg-gray-200 text-gray-900 hover:bg-gray-300",onClick:()=>e(""),children:a.jsx(k.Cross1Icon,{className:"h-4 w-4"})})}),a.jsx(ue,{side:"left",children:"Remove binding"})]})]})})},Kl=j.atom(t=>{var i;const e=t(Se),n=t(ks),s=n.length===1?n[0]:null;if(!s)return null;const r=d.find(e,{_id:s});if(!r)return null;let o=r._parent;for(;o;){const l=d.find(e,{_id:o});if(!l)return null;if((i=K.getRegisteredChaiBlock(l._type))!=null&&i.wrapper)return l;o=l._parent}return null});Kl.debugLabel="wrapperBlockAtom";const jo=()=>j.useAtomValue(Kl),Jm=()=>{const t=J(),e=jo(),{addCoreBlock:n}=xt();if(!t&&!e)return null;const s=(t==null?void 0:t._type)==="Row"?t:e;return a.jsx("div",{className:"pt-1",children:a.jsxs("button",{type:"button",className:"duratiom-300 flex items-center gap-x-1 rounded border border-gray-400 bg-gray-100 px-4 py-1 text-[11px] font-medium leading-tight hover:bg-slate-200",onClick:()=>n({type:"Column",styles:"#styles:,"},s==null?void 0:s._id),children:[a.jsx(k.PlusIcon,{className:"h-4 w-4"})," Add Column"]})})},Zm=g.lazy(()=>Promise.resolve().then(()=>require("./rte-widget-modal-CC1KcrAT.cjs"))),Qm=({blockId:t,id:e,placeholder:n,value:s,onChange:r,onBlur:o})=>{const i=g.useRef(null),[l,c]=g.useState(!1),u=Dl({blockId:t,value:s,placeholder:n,onBlur:({editor:m})=>{const h=m==null?void 0:m.getHTML();o(e,h)},onUpdate:({editor:m})=>{const h=m==null?void 0:m.getHTML();r(h)}});g.useEffect(()=>{i.current&&u&&(i.current.__chaiRTE=u)},[t,u]);const p=()=>{c(!1)},f=a.jsxs("div",{id:`chai-rte-${e}`,ref:i,className:"mt-1 rounded-md border border-input",children:[a.jsx(Vi,{editor:u,onExpand:()=>c(!0)}),a.jsx(ns.EditorContent,{editor:u,id:e,placeholder:n,className:`overflow-auto ${l?"max-h-[500px] min-h-[400px]":"max-h-[200px] min-h-[100px]"}`},e)]});return a.jsxs(a.Fragment,{children:[l&&a.jsx(g.Suspense,{fallback:a.jsx("div",{children:"Loading..."}),children:a.jsx(Zm,{isOpen:l,onClose:p,editor:u,rteElement:f})}),l?a.jsx("div",{children:"Open in modal"}):a.jsx("div",{className:"relative",children:f})]})},eg=t=>{const{editingBlockId:e}=Ft(),[n,s]=g.useState(null),r=J(),o=r==null?void 0:r._id;return g.useEffect(()=>{s(o)},[o]),n&&n!==e?a.jsx(Qm,{...t,blockId:n},n):null},tg=({formData:t,onChange:e})=>{const[n]=Z(),s=J(),r=jo(),{addCoreBlock:o}=xt(),[,i]=U(),l=(s==null?void 0:s._type)==="Slider"?s:r,c=d.find(n,{_parent:l==null?void 0:l._id,_type:"Slides"}),u=d.filter(n,{_parent:c==null?void 0:c._id,_type:"Slide"}),p=(t==null?void 0:t.currentSlide)||d.get(u,"0._id");if(g.useEffect(()=>{(s==null?void 0:s._type)==="Slide"&&(t==null?void 0:t.currentSlide)!==(s==null?void 0:s._id)&&e({...t,currentSlide:s==null?void 0:s._id})},[s]),g.useEffect(()=>{u!=null&&u.length&&!d.find(u,{_id:t==null?void 0:t.currentSlide})&&e({...t,currentSlide:d.get(u,"0._id")})},[t,u]),!s&&!r||!c)return null;const f=()=>{const x=d.findIndex(u,{_id:p});if(x>-1){const b=(x+1)%u.length,y=d.get(u,[b,"_id"]);if(!y)return;e({...t,currentSlide:y}),i([y])}},m=()=>{const x=d.findIndex(u,{_id:p});if(x>-1){const b=(x-1+u.length)%u.length,y=d.get(u,[b,"_id"]);if(!y)return;e({...t,currentSlide:y}),i([y])}},h=()=>{const x=o({styles:"#styles:,h-full w-full min-w-full",type:"Slide"},c==null?void 0:c._id),b=x==null?void 0:x._id;b&&(e({...t,currentSlide:b}),i([b]))};return a.jsxs("div",{className:"space-y-1.5 px-2",children:[a.jsxs("div",{className:"flex items-center gap-x-2 pb-2 text-[12px]",children:[a.jsx("button",{onClick:m,className:"rounded bg-gray-200 p-1.5 hover:opacity-80",children:a.jsx(k.ChevronLeftIcon,{className:"h-3 w-3"})}),a.jsx("div",{className:"whitespace-nowrap text-center text-[10px] text-slate-500",children:p?a.jsxs("span",{className:"",children:[a.jsxs("b",{className:"text-[12px]",children:[" ",d.findIndex(u,{_id:p})+1]}),"/",u.length]}):"-"}),a.jsx("button",{onClick:f,className:"rounded bg-gray-200 p-1.5 hover:opacity-80",children:a.jsx(k.ChevronRightIcon,{className:"h-3 w-3"})}),a.jsxs("button",{onClick:h,className:"flex w-full items-center justify-center gap-x-1 rounded bg-gray-200 p-1.5 text-xs font-medium leading-tight hover:opacity-80",children:[a.jsx(k.PlusCircledIcon,{className:"h-3 w-3"}),"Add Slide"]})]}),a.jsxs("div",{className:"flex items-center gap-x-2 leading-tight",children:[a.jsx("input",{type:"checkbox",checked:!!(t!=null&&t.showSlideButton),onChange:()=>e({...t,showSlideButton:!(t!=null&&t.showSlideButton)}),className:"cursor-pointer"}),a.jsx("label",{htmlFor:"autoplay",className:"mt-0.5 text-[12px]",children:"Show Slide Buttons"})]}),a.jsxs("div",{className:"flex items-center gap-x-2 leading-tight",children:[a.jsx("input",{type:"checkbox",checked:!!(t!=null&&t.showSlideNavbar),onChange:()=>e({...t,showSlideNavbar:!(t!=null&&t.showSlideNavbar)}),className:"cursor-pointer"}),a.jsx("label",{htmlFor:"autoplay",className:"mt-0.5 text-[12px]",children:"Show Slide Navbar"})]}),a.jsx("div",{children:a.jsxs("div",{className:"flex flex-col",children:[a.jsxs("div",{className:"flex items-center gap-x-2 leading-tight",children:[a.jsx("input",{type:"checkbox",checked:!!(t!=null&&t.autoplay),onChange:()=>e({...t,autoplay:!(t!=null&&t.autoplay)}),className:"cursor-pointer"}),a.jsx("label",{htmlFor:"autoplay",className:"mt-0.5 text-[12px]",children:"Autoplay slides"})]}),(t==null?void 0:t.autoplay)&&a.jsxs("div",{className:"pt-0.5 leading-tight",children:[a.jsxs("label",{htmlFor:"interval",className:"whitespace-nowrap text-[9px]",children:["Autoplay Interval ",a.jsx("span",{className:"font-light opacity-80",children:"(in seconds)"})]}),a.jsx("input",{type:"number",id:"interval",name:"interval",placeholder:"0",value:t==null?void 0:t.autoplayInterval,className:"text-xs",pattern:"[0-9]*",onChange:x=>{let b=x.target.value;b.length&&(b=b.replace("-","")),e({...t,autoplayInterval:b})}})]})]})})]})},ng=({formData:t,onChange:e})=>{const n=d.get(t,"srcsets",[])||[],s=(i,l)=>{const c=i.target.name,u=i.target.value;e({srcsets:d.map(n,(p,f)=>f===l?{...p,[c]:u}:p)})},r=()=>{e({srcsets:[...n,{}]})},o=i=>{e({srcsets:d.reject(n,(l,c)=>parseInt(c)===i)})};return a.jsxs("div",{children:[a.jsxs("div",{className:"flex items-center justify-between pb-2",children:[a.jsx("label",{children:"Responsive Video (optional)"}),a.jsx("button",{type:"button",onClick:r,className:"flex items-center gap-x-1 rounded-md border border-blue-500 bg-blue-100 px-2 py-px text-xs text-blue-600 hover:opacity-80",children:a.jsx(k.PlusIcon,{className:"h-3 w-3"})})]}),a.jsx("div",{className:"space-y-2",children:n.length===0?a.jsx("div",{className:"rounded border border-dashed border-gray-200 p-2 text-xs italic text-gray-500",children:"Add additional sources to create responsive videos"}):d.map(n,(i,l)=>a.jsxs("div",{className:"group relative space-y-1.5 rounded border border-gray-200 px-2 pb-1.5",children:[a.jsx("button",{type:"button",onClick:()=>o(l),className:"absolute -right-px -top-0 -translate-y-1/2 rounded-full bg-red-100 p-1 opacity-0 hover:bg-red-200 group-hover:opacity-100",children:a.jsx(k.Cross1Icon,{className:"h-2.5 w-2.5 text-red-500"})}),a.jsxs("div",{className:"flex items-center gap-x-2 rounded border",children:[a.jsx("label",{className:"flex !h-6 h-full w-1/4 items-center justify-center bg-gray-200 px-2 !text-[10px] !font-medium",children:"Width"}),a.jsx("input",{name:"width",placeholder:"Enter width (in px)",type:"number",value:d.get(i,"width"),onChange:c=>s(c,l),className:"!placeholder:text-gray-100 !mt-0 !rounded-none !border-0 !p-0 !text-xs"})]}),a.jsxs("div",{className:"flex items-center gap-x-2 rounded border",children:[a.jsx("label",{className:"flex !h-6 h-full w-1/4 items-center justify-center bg-gray-200 px-2 !text-[10px] !font-medium",children:"URL"}),a.jsx("input",{name:"url",placeholder:"Enter url",className:"!mt-0 !rounded-none !border-0 !p-0 !text-xs !shadow-none",value:d.get(i,"url",""),onChange:c=>s(c,l)})]})]},l))})]})},sg=t=>a.jsx("button",{...t,className:"duration absolute right-2 top-2 cursor-pointer text-blue-400 hover:text-blue-500",children:a.jsxs("div",{className:"flex items-center gap-x-0.5 text-[11px] leading-tight",children:[a.jsx(k.PlusIcon,{className:"h-3 w-3"})," ",a.jsx("span",{children:"Add"})]})}),wa=g.memo(({blockId:t,schema:e,uiSchema:n,formData:s,onChange:r})=>{const{selectedLang:o}=_e(),i=B.useChaiBlockSettingComponents("widget"),l=B.useChaiBlockSettingComponents("field"),c=B.useChaiBlockSettingComponents("template"),u=ve.useThrottledCallback(async({formData:p},f)=>{d.get(p,f)===void 0&&d.set(p,f,""),r({formData:p},f)},[r,o],400);return a.jsx(cd,{widgets:{richtext:eg,icon:Fm,image:Vm,code:Mm,colCount:Jm,collectionSelect:Dm,repeaterBinding:Xm,...i},fields:{link:Ym,slider:tg,sources:ng,...l},templates:{FieldTemplate:qm,ButtonTemplates:{AddButton:sg},...c},idSeparator:".",autoComplete:"off",omitExtraData:!1,liveOmit:!1,liveValidate:!1,validator:dd,uiSchema:n,schema:e,formData:s,onChange:({formData:p},f)=>{if(!f||t!==(p==null?void 0:p._id))return;const m=d.take(f.split("."),2).join(".").replace("root.","");u({formData:p},m)}},o)}),Ca=(t,e,n)=>{const s=d.cloneDeep(t);return d.forEach(d.keys(t),r=>{d.includes(d.get(n,"i18nProps",[]),r)&&!d.isEmpty(e)&&(s[r]=d.get(t,`${r}-${e}`))}),s};function br(){const{selectedLang:t}=_e(),e=J(),n=Dr(),s=st(),r=K.getRegisteredChaiBlock(e==null?void 0:e._type),o=Ca(e,t,r),[i,l]=g.useState(o),[c,u]=g.useState(!1),p=jo(),f=K.getRegisteredChaiBlock(p==null?void 0:p._type),m=Ca(p,t,f),h=({formData:E},_,S)=>{_&&(i==null?void 0:i._id)===e._id&&s([e._id],{[_]:d.get(E,_)},S)},x=g.useCallback(d.debounce(({formData:E},_,S)=>{h({formData:E},_,S),l(E)},1500),[e==null?void 0:e._id,t]),b=({formData:E},_)=>{_&&(n([e._id],{[_]:d.get(E,_)}),x({formData:E},_,{[_]:d.get(i,_)}))},y=({formData:E},_)=>{_&&(n([p._id],{[_]:d.get(E,_)}),x({formData:E},_,{[_]:d.get(i,_)}))},{schema:v,uiSchema:w}=g.useMemo(()=>{const E=e==null?void 0:e._type;if(!E)return{schema:{},uiSchema:{}};try{const{schema:_,uiSchema:S}=K.getBlockFormSchemas(E);if(E==="Repeater"){const A=d.get(e,"repeaterItems","");d.startsWith(A,`{{${q.COLLECTION_PREFIX}`)?(d.set(S,"filter",{"ui:widget":"collectionSelect"}),d.set(S,"sort",{"ui:widget":"collectionSelect"})):(d.set(S,"filter",{"ui:widget":"hidden"}),d.set(S,"sort",{"ui:widget":"hidden"}))}return{schema:_,uiSchema:S}}catch{return{schema:{},uiSchema:{}}}},[e]),{wrapperSchema:I,wrapperUiSchema:N}=g.useMemo(()=>{if(!p||!(p!=null&&p._type))return{wrapperSchema:{},wrapperUiSchema:{}};const E=p==null?void 0:p._type,{schema:_={},uiSchema:S={}}=K.getBlockFormSchemas(E);return{wrapperSchema:_,wrapperUiSchema:S}},[p]);return a.jsxs("div",{className:"no-scrollbar overflow-x-hidden px-px",children:[!d.isEmpty(p)&&a.jsxs("div",{className:"mb-4 rounded border bg-zinc-100 px-1",children:[a.jsxs("div",{onClick:()=>u(E=>!E),className:"flex cursor-pointer items-center gap-x-1 py-2 text-xs font-medium leading-tight hover:bg-slate-100",children:[c?a.jsx(k.ChevronDownIcon,{className:"h-4 w-4 text-slate-400"}):a.jsx(k.ChevronRightIcon,{className:"h-4 w-4 text-slate-400"}),d.startCase(p._type)," settings"," ",p._name&&a.jsxs("span",{className:"text-[11px] font-light text-slate-400",children:["(",p._name,")"]})]}),a.jsx("div",{className:c?"h-auto":"invisible h-0",children:a.jsx(wa,{blockId:p==null?void 0:p._id,onChange:y,formData:m,schema:I,uiSchema:N})})]}),d.isEmpty(v)?null:a.jsx(wa,{blockId:e==null?void 0:e._id,onChange:b,formData:o,schema:v,uiSchema:w})]})}const Yl=Pt.Root,So=D.forwardRef(({className:t,...e},n)=>a.jsx(Pt.Item,{ref:n,className:B.cn("border-b",t),...e}));So.displayName="AccordionItem";const No=D.forwardRef(({className:t,children:e,...n},s)=>a.jsx(Pt.Header,{className:"flex",children:a.jsxs(Pt.Trigger,{ref:s,className:B.cn("flex flex-1 items-center justify-between py-4 text-sm font-medium transition-all hover:underline text-left [&[data-state=open]>svg]:rotate-180",t),...n,children:[e,a.jsx(k.ChevronDownIcon,{className:"h-4 w-4 shrink-0 text-muted-foreground transition-transform duration-200"})]})}));No.displayName=Pt.Trigger.displayName;const Eo=D.forwardRef(({className:t,children:e,...n},s)=>a.jsx(Pt.Content,{ref:s,className:"overflow-hidden text-sm data-[state=closed]:animate-accordion-up data-[state=open]:animate-accordion-down",...n,children:a.jsx("div",{className:B.cn("pb-4 pt-0",t),children:e})}));Eo.displayName=Pt.Content.displayName;const rg=j.atom(null,(t,e,{blockIds:n,fullClasses:s})=>{const r=d.first(t(Rn)),o=d.filter(t(In),i=>n.includes(t(i)._id));return d.map(o,i=>{const l=t(i),c=s;let{classes:u,baseClasses:p}=pe.getSplitChaiClasses(d.get(l,r.prop,`${q.STYLES_KEY},`));return d.each(c,f=>{const m=f.replace(/[.*+?^${}()|[\]\\]/g,"\\$&"),h=new RegExp(`(^|\\s)${m}(?=\\s|$)`,"g");u=u.replace(h," ").replace(/\s+/g," ").trim();const x=d.first(f.split(":"));d.includes(["2xl","xl","lg","md","sm"],x)&&c.push(f.split(":").pop().trim())}),d.each(c,f=>{const m=f.replace(/[.*+?^${}()|[\]\\]/g,"\\$&"),h=new RegExp(`(^|\\s)${m}(?=\\s|$)`,"g");p=p.replace(h," ").replace(/\s+/g," ").trim()}),{ids:[l._id],props:{[r.prop]:`${q.STYLES_KEY}${p},${u}`}}})}),og=t=>{const e=Object.keys(t).filter(s=>typeof t[s]=="string"&&t[s].startsWith(q.STYLES_KEY)),n={};return e.forEach(s=>{n[s]=`${q.STYLES_KEY},`}),{ids:[t._id],props:n}},ag=()=>{const{updateBlocks:t,updateBlocksRuntime:e}=Ee();return g.useCallback((n,s=!1)=>{const{ids:r,props:o}=og(n);s?t(r,o):e(r,o)},[t,e])},Ao=()=>{const{updateBlocks:t,updateBlocksRuntime:e}=Ee(),n=j.useSetAtom(rg);return g.useCallback((s,r,o=!1)=>{const i=n({blockIds:s,fullClasses:r});o?t(s,i[0].props):e(s,i[0].props)},[n])},Xl=()=>{const t=J(),e=st(),n=g.useCallback(i=>K.getDefaultBlockProps(i)||{},[]),s=g.useCallback(i=>Object.keys(i).filter(l=>typeof i[l]=="string"&&i[l].startsWith("#styles:")),[]),r=g.useCallback(i=>{if(!t)return;const c=n(t._type)[i]??"#styles:,";e([t._id],{[i]:c})},[t,n,e]);return{resetAll:g.useCallback(()=>{if(!t)return;const i=s(t);if(i.length===0)return;const l=n(t._type),c=d.pick(l,i);e([t._id],c)},[t,s,n,e]),reset:r}},ig=()=>{var h;const t=J(),[e,n]=Ae(),s=Ao(),[r]=U(),{t:o}=F.useTranslation(),{reset:i}=Xl();if(!t)return null;const l=Object.keys(t).filter(x=>typeof t[x]=="string"&&t[x].startsWith("#styles:")),c=!d.isEmpty(l)&&l.length>1,u=d.get(t,(h=e[0])==null?void 0:h.prop,""),{classes:p=""}=pe.getSplitChaiClasses(u)||{},f=p?p.split(" ").filter(x=>!d.isEmpty(x)):[],m=x=>d.find(e,b=>b.prop===x);return a.jsx(a.Fragment,{children:c&&a.jsxs("div",{className:"flex flex-wrap gap-1",children:[a.jsxs("label",{htmlFor:"block-styling-props",className:"py-1 text-xs",children:[o("Style element"),":"]}),a.jsx("div",{className:"flex flex-wrap gap-2",children:d.map(l,x=>a.jsxs(Rs,{className:"flex cursor-pointer items-center gap-1 pr-1",variant:m(x)?"default":"secondary",onClick:()=>{n([{id:`${x}-${t._id}`,blockId:t._id,prop:x}])},children:[d.startCase(x),a.jsxs(tt,{children:[a.jsx(nt,{asChild:!0,children:a.jsx("button",{type:"button",className:"ml-1 rounded-sm p-0.5 hover:bg-blue-300 hover:text-blue-600",onClick:b=>b.stopPropagation(),children:a.jsx(k.DotsVerticalIcon,{className:"h-3 w-3"})})}),a.jsxs(Ue,{side:"bottom",className:"border-border text-xs",children:[a.jsx(de,{className:"text-xs",onClick:()=>{i(x)},children:o("Reset style")}),a.jsx(de,{className:"text-xs",onClick:()=>{s(r,f,!0)},children:o("Clear styles")})]})]})]},x))}),a.jsx("div",{className:"my-2 h-[1px] w-full bg-border"})]})})},Jl=g.createContext({setDragData:()=>{}}),ja=(t,e)=>{t=t.toLowerCase();let n=t.trim().replace(/ |\+/g,"");if((n==="auto"||n==="none")&&e.includes(n))return{value:"",unit:n};const s=e.length?new RegExp(e.join("|"),"g"):/XXXXXX/g;n=n.replace(s,"");const r=t.match(s),o=r&&r.length>1,i=!d.isEmpty(n)&&Number.isNaN(Number(n));return o||i?{error:"Invalid value"}:r&&(r[0]==="auto"||r[0]==="none")?{value:r[0],unit:""}:{value:n,unit:r?r[0]:""}},lg=t=>{const e=t.startsWith("-")?"-":"",n=t.split("-").pop();if(["auto","none"].includes(n))return{value:"",unit:n};if(n==="px")return{value:"1",unit:"px"};if(n==="screen")return{value:"100",unit:t.indexOf("w-")!==-1?"vw":"vh"};if(n==="full")return{value:"100",unit:"%"};if(d.includes(t,"skew-"))return{value:`${e}${n}`,unit:"deg"};if(d.includes(t,"rotate-"))return{value:`${e}${n}`,unit:"deg"};if(d.includes(t,"opacity-"))return{value:`${n/100}`,unit:"-"};if(d.includes(t,"duration-")||d.includes(t,"delay-"))return{value:`${n}`,unit:"ms"};if(d.includes(t,"translate-")&&!n.includes("/"))return{value:`${e}${`${n/4}`}`,unit:"rem"};if(d.includes(t,"scale-"))return{value:`${e}${`${n/100}`}`,unit:"-"};if(d.startsWith(t,"border")){const s=t.match(/border-?(x|y|t|r|b|l)?\d+/g);if(s)return{value:s[0].split("-").pop(),unit:"px"};if(t.match(/border-?(x|y|t|r|b|l)?/g))return{value:"1",unit:"px"}}if(d.startsWith(t,"max-w-")){if(t==="max-w-screen-sm")return{value:"640",unit:"px"};if(t==="max-w-screen-md")return{value:"768",unit:"px"};if(t==="max-w-screen-lg")return{value:"1024",unit:"px"};if(t==="max-w-screen-xl")return{value:"1280",unit:"px"};if(t==="max-w-screen-2xl")return{value:"1536",unit:"px"};if(n==="xs")return{value:"320",unit:"px"};if(n==="sm")return{value:"384",unit:"px"};if(n==="md")return{value:"448",unit:"px"};if(n==="lg")return{value:"512",unit:"px"};if(n==="xl")return{value:"576",unit:"px"};if(n==="2xl")return{value:"672",unit:"px"};if(n==="3xl")return{value:"768",unit:"px"};if(n==="4xl")return{value:"896",unit:"px"};if(n==="5xl")return{value:"1024",unit:"px"};if(n==="6xl")return{value:"1152",unit:"px"};if(n==="7xl")return{value:"1280",unit:"px"};if(n==="prose")return{value:"65",unit:"ch"}}if(d.startsWith(t,"text-")){if(n==="xs")return{value:"12",unit:"px"};if(n==="sm")return{value:"14",unit:"px"};if(n==="base")return{value:"16",unit:"px"};if(n==="lg")return{value:"18",unit:"px"};if(n==="xl")return{value:"20",unit:"px"};if(n==="2xl")return{value:"24",unit:"px"};if(n==="3xl")return{value:"30",unit:"px"};if(n==="4xl")return{value:"36",unit:"px"};if(n==="5xl")return{value:"48",unit:"px"};if(n==="6xl")return{value:"60",unit:"px"};if(n==="7xl")return{value:"72",unit:"px"};if(n==="8xl")return{value:"96",unit:"px"};if(n==="9xl")return{value:"128",unit:"px"}}if(d.startsWith(t,"leading-")){if(n==="none")return{value:"1",unit:"-"};if(n==="tight")return{value:"1.25",unit:"-"};if(n==="snug")return{value:"1.375",unit:"-"};if(n==="normal")return{value:"1.5",unit:"-"};if(n==="relaxed")return{value:"1.625",unit:"-"};if(n==="loose")return{value:"2",unit:"-"}}if(d.startsWith(t,"tracking-")){if(n==="tighter")return{value:"-0.05",unit:"em"};if(n==="tight")return{value:"-0.025",unit:"em"};if(n==="normal")return{value:"0",unit:"em"};if(n==="wide")return{value:"0.025",unit:"em"};if(n==="wider")return{value:"0.05",unit:"em"};if(n==="widest")return{value:"0.1",unit:"em"}}if(["max","min","fit"].includes(n))return{value:t,unit:"class"};if(n.includes("/")){const[s,r]=d.map(n.split("/"),o=>parseInt(o,10));return{value:e+(s/r*100).toFixed(2).replace(".00",""),unit:"%"}}return d.isNumber(parseFloat(n))?{value:`${e+parseFloat(n)*4}`,unit:"px"}:{value:n,unit:"class"}},Zl=t=>{if(d.isEmpty(t))return{value:"",unit:""};const e=t.match(/\[.*\]/g);if(e===null)return cg(t);const n=d.get(e,"0","").replace(/\[|\]/g,""),s=t.startsWith("-")?"-":"",r=d.first(n.match(/\d+.\d+|\d+/g));return{value:`${s}${r}`,unit:n.replace(r,"")}},cg=t=>d.isEmpty(t)?{value:"",unit:""}:lg(t),dg=({unit:t,currentValue:e,onDrag:n,onDragEnd:s,onDragStart:r,negative:o,cssProperty:i})=>{const{setDragData:l}=g.useContext(Jl);return a.jsx("button",{type:"button",onMouseDown:c=>{const u={onDrag:n,onDragEnd:s,dragging:!0,dragStartY:c.pageY,dragStartValue:`${e}`,dragUnit:t,negative:o,cssProperty:i};r(u),l(u)},color:void 0,className:"relative z-50 ml-1 hidden h-6 cursor-row-resize rounded bg-background/70 px-2 group-hover:inline",children:a.jsx(k.RowSpacingIcon,{})})},ug=({onSelect:t,current:e,units:n})=>a.jsx("div",{"data-theme":"light",className:"-m-[7px] -mx-[13px] flex w-9 flex-col",children:n.map(s=>a.jsx(B.Button,{className:"h-max rounded-none px-1 py-1 text-right text-[11px] hover:bg-blue-400",color:e===s?"primary":void 0,size:"sm",onClick:r=>{r.stopPropagation(),t(s)},children:s},s))}),Sa=50,pg=t=>{const[e,n]=g.useState(!1),[s,r]=g.useState(""),{currentClass:o,onChange:i,classPrefix:l,cssProperty:c,units:u,negative:p}=t,[f,m]=g.useState(c!=null&&c.toLowerCase().includes("width")?"%":u[0]),[h,x]=g.useState(!1),[b,y]=g.useState(""),[v,w]=g.useState(!1),[I,N]=g.useState(!1);g.useEffect(()=>{const{value:C,unit:T}=Zl(o);if(T===""){r(C),m(c!=null&&c.toLowerCase().includes("width")?"%":d.first(u));return}m(T),r(T==="class"||d.isEmpty(C)?"":C)},[o,c,u]);const E=ve.useThrottledCallback(C=>i(C),[i],Sa),_=ve.useThrottledCallback(C=>i(C,!1),[i],Sa),S=g.useCallback((C=!1)=>{const T=ja(`${s}`,u);if(d.get(T,"error",!1)){x(!0);return}const P=d.get(T,"unit")!==""?d.get(T,"unit"):f;if(P==="auto"||P==="none"){E(`${l}${P}`);return}if(d.get(T,"value")==="")return;const O=`${d.get(T,"value","").startsWith("-")?"-":""}${l}[${d.get(T,"value","").replace("-","")}${P==="-"?"":P}]`;C?_(O):E(O)},[E,_,s,f,l,u]),A=g.useCallback(C=>{const T=ja(`${s}`,u);if(d.get(T,"error",!1)){x(!0);return}if(C==="auto"||C==="none"){E(`${l}${C}`);return}if(d.get(T,"value")==="")return;const P=d.get(T,"unit")!==""?d.get(T,"unit"):C,O=`${d.get(T,"value","").startsWith("-")?"-":""}${l}[${d.get(T,"value","").replace("-","")}${P==="-"?"":P}]`;E(O)},[E,s,l,u]);return a.jsx("div",{className:"flex w-full flex-col",children:a.jsx("div",{className:"flex items-center justify-start",children:f==="class"?a.jsxs(a.Fragment,{children:[a.jsx("input",{className:"h-6 w-24 rounded border border-foreground/20 bg-background px-2 py-0.5 text-sm focus-visible:outline-0",readOnly:!0,value:o}),a.jsxs(fe,{children:[a.jsx(he,{asChild:!0,children:a.jsx("button",{type:"button",className:"invisible ml-3 mt-1 text-blue-600 group-hover:visible",children:a.jsx(k.InfoCircledIcon,{})})}),a.jsx(ue,{children:"Current value is using a Tailwind preset class."})]})]}):a.jsxs("div",{className:`group relative flex items-center ${v?"z-auto":""}`,children:[a.jsxs("div",{className:"flex items-center rounded-md border border-border",children:[["none","auto"].indexOf(f)!==-1?null:a.jsx("input",{readOnly:f==="class",onKeyPress:C=>{C.key==="Enter"&&S()},onKeyDown:C=>{if(C.keyCode!==38&&C.keyCode!==40)return;C.preventDefault(),N(!0);const T=d.parseInt(C.target.value);let P=d.isNaN(T)?0:T;C.keyCode===38&&(P+=1),C.keyCode===40&&(P-=1);const R=`${P}`,H=`${R.startsWith("-")?"-":""}${l}[${R.replace("-","")}${f==="-"?"":f}]`;_(H)},onKeyUp:C=>{I&&(C.preventDefault(),N(!1))},onBlur:()=>S(),onChange:C=>{x(!1),r(C.target.value)},onClick:C=>{var T;(T=C==null?void 0:C.target)==null||T.select(),n(!1)},value:v?b:s,className:"h-6 w-14 rounded rounded-r-none border border-transparent bg-background pl-2 text-sm focus-visible:outline-0".concat(" ",h?"border-red-500 text-red-500":"border-foreground/20")}),a.jsxs(fe,{open:e,delayDuration:100,children:[a.jsx(he,{asChild:!0,children:a.jsxs("button",{type:"button",onClick:()=>n(!e),className:"flex h-6 cursor-pointer items-center gap-x-1 rounded rounded-l-none bg-background p-px px-1 text-[11px] uppercase",children:[a.jsx("span",{className:`inline-block ${u.length===1?"px-2 font-semibold":""}`,children:f}),u.length>1?a.jsx(k.TriangleDownIcon,{}):null]})}),a.jsx(ue,{className:"bg-background",children:a.jsx(ug,{units:u,current:f,onSelect:C=>{n(!1),m(C),A(C)}})})]})]}),["none","auto"].indexOf(f)!==-1||v?null:a.jsx(dg,{onDragStart:()=>w(!0),onDragEnd:C=>{if(y(()=>""),w(!1),d.isEmpty(C))return;const T=`${C}`,R=`${T.startsWith("-")?"-":""}${l}[${T.replace("-","")}${f==="-"?"":f}]`;E(R)},onDrag:C=>{if(d.isEmpty(C))return;y(C);const T=`${C}`,R=`${T.startsWith("-")?"-":""}${l}[${T.replace("-","")}${f==="-"?"":f}]`;_(R)},currentValue:s,unit:f,negative:p,cssProperty:c})]})})})},Mn=g.createContext({canReset:!1,canChange:!0}),fg=({children:t,canReset:e=!1,canChange:n=!0})=>a.jsx(Mn.Provider,{value:{canReset:e,canChange:n},children:t}),rr=[0,1,2,3,4,5,6,7,8,9,10,11,12,14,16,20,24,28,32,36,40,44,48,52,56,60,64,72,80,96],L={columns:[...d.range(1,13),"auto","3xs","2xs","xs","sm","md","lg","xl",...d.map(d.range(2,8),t=>`${t}xl`)],breakAfter:["auto","avoid","all","avoid-page","page","left","right","column"],breakInside:["auto","avoid","avoid-page","avoid-column"],display:["block","flex","grid","inline-block","inline","hidden"],objectFit:["contain","cover","fill","none","scale-down"],objectPosition:["bottom","center","left","left-bottom","left-top","right","right-bottom","right-top","top"],overflow:["auto","hidden","clip","visible","scroll"],overscroll:["auto","contain","none"],trbl:[0,"px","0.5",1,1.5,2,2.5,3,3.5,...d.range(4,13),14,16,20,24,28,32,36,40,44,48,52,56,60,64,72,80,96,"auto","1/2","1/3","2/3","1/4","2/4","3/4","full"],flexBasis:[...rr,"auto","px","0.5","1.5","2.5","3.5","1/2","1/3","2/3","1/4","2/4","3/4","1/5","2/5","3/5","4/5","1/6","2/6","3/6","4/6","5/6","1/12","2/12","3/12","4/12","5/12","6/12","7/12","8/12","9/12","10/12","11/12","full"],padding:[...rr,"px","0.5","1.5","2.5","3.5"],margin:["auto",...rr,"px","0.5","1.5","2.5","3.5"],scale:[0,50,75,90,95,100,105,110,125,150],origin:["center","top","top-right","right","bottom-right","bottom","bottom-left","left","top-left"],blendEffect:["normal","multiply","screen","overlay","darken","lighten","color-dodge","color-burn","hard-light","soft-light","difference","exclusion","hue","saturation","color","luminosity"],borderWidth:[0,2,4,8],borderRadius:["global","none","sm","md","lg","xl","2xl","3xl","full"],indent:[0,"px","0.5",1,1.5,2,2.5,3,3.5,...d.range(4,13),14,16,20,24,28,32,36,40,44,48,52,56,60,64,72,80,96],maxHeight:[0,"px","0.5",1,1.5,2,2.5,3,3.5,...d.range(4,13),14,16,20,24,28,32,36,40,44,48,52,56,60,64,72,80,96,"full","screen","min","max","fit"],space:[0,"px","0.5",1,1.5,2,2.5,3,3.5,...d.range(4,13),14,16,20,24,28,32,36,40,44,48,52,56,60,64,72,80,96,"px","reverse"],width:["0","px","0.5","1","1.5","2","2.5","3","3.5","4","5","6","7","8","9","10","11","12","14","16","20","24","28","32","36","40","44","48","52","56","60","64","72","80","96","auto","1/2","1/3","2/3","1/4","2/4","3/4","1/5","2/5","3/5","4/5","1/6","2/6","3/6","4/6","5/6","1/12","2/12","3/12","4/12","5/12","6/12","7/12","8/12","9/12","10/12","11/12"],maxWidth:["0","none","xs","sm","md","lg","xl","2xl","3xl","4xl","5xl","6xl","7xl","full","min","max","fit","prose","screen-sm","screen-md","screen-lg","screen-xl","screen-2xl"],height:["0","px","0.5","1","1.5","2","2.5","3","3.5","4","5","6","7","8","9","10","11","12","14","16","20","24","28","32","36","40","44","48","52","56","60","64","72","80","96","auto","1/2","1/3","2/3","1/4","2/4","3/4","1/5","2/5","3/5","4/5","1/6","2/6","3/6","4/6","5/6","full","screen","min","max","fit"]},Xt={textColor:{classes:[],regExp:"text-(black|transparent|current|white|__THEME_COLORS_REGEXP__|\\S+-\\d+)"},aspectRatio:{classes:["aspect-auto","aspect-square","aspect-video"],regExp:"aspect-(auto|square|video)"},container:{classes:["container"],regExp:"container"},columns:{classes:d.map(L.columns,t=>`columns-${t}`),regExp:"columns-(auto|[0-9]xl|[0-9]xs|xs|sm|md|lg|xl|\\d+)"},breakAfter:{classes:d.map(L.breakAfter,t=>`break-after-${t}`),regExp:"break-after-\\S+"},breakBefore:{classes:d.map(L.breakAfter,t=>`break-before-${t}`),regExp:"break-before-\\S+"},breakInside:{classes:d.map(L.breakInside,t=>`break-inside-${t}`),regExp:"break-inside-\\S+"},boxDecoration:{classes:["box-decoration-clone","box-decoration-slice"],regExp:"box-decoration-\\S+"},boxSizing:{classes:["box-border","box-content"],regExp:"box-(border|content)"},flexDirection:{classes:["flex-row","flex-row-reverse","flex-col","flex-col-reverse"],regExp:"flex-(row|row-reverse|col|col-reverse)"},flexWrap:{classes:["flex-wrap","flex-wrap-reverse","flex-nowrap"],regExp:"flex-(wrap|wrap-reverse|nowrap)"},flexGrowShrink:{classes:["flex-1","flex-auto","flex-initial","flex-none"],regExp:"flex-1|flex-auto|flex-initial|flex-none"},gridColumns:{classes:d.map([...d.range(0,13),"none"],t=>`grid-cols-${t}`),regExp:"grid-cols-(\\d+|none)"},gridFlow:{classes:["grid-flow-row","grid-flow-col","grid-flow-row-dense","grid-flow-col-dense"],regExp:"grid-flow-(row|col|row-dense|col-dense)"},outlineStyle:{classes:d.map(["none","dashed","dotted","double","hidden"],t=>`outline-${t}`),regExp:"outline-(none|dashed|dotted|double|hidden)"},borderStyle:{classes:d.map(["solid","dashed","dotted","double","hidden","none"],t=>`border-${t}`),regExp:"border-(solid|dashed|dotted|double|hidden|none)"},overflow:{classes:d.map(L.overflow,t=>`overflow-${t}`),regExp:`overflow-(${L.overflow.join("|")})`},overflowX:{classes:d.map(L.overflow,t=>`overflow-x-${t}`),regExp:`overflow-x-(${L.overflow.join("|")})`},overflowY:{classes:d.map(L.overflow,t=>`overflow-y-${t}`),regExp:`overflow-y-(${L.overflow.join("|")})`},gridRows:{classes:d.map([1,2,3,4,5,6,"none"],t=>`grid-rows-${t}`),regExp:"grid-rows-(\\d|none)"},display:{classes:d.map(L.display,t=>t.toString()),regExp:`(${L.display.join("|")})`},float:{classes:["float-right","float-left","float-none"],regExp:"float-\\S+"},clear:{classes:["clear-right","clear-left","clear-none","clear-both"],regExp:"clear-\\S+"},isolation:{classes:["isolate","isolation-auto"],regExp:"isolate|isolation-auto"},objectFit:{classes:d.map(L.objectFit,t=>`object-${t}`),regExp:"object-(contain|cover|fill|none|scale-down)"},objectPosition:{classes:d.map(L.objectPosition,t=>`object-${t}`),regExp:`object-(${L.objectPosition.join("|")})`},overscroll:{classes:d.map(L.overscroll,t=>`overscroll-${t}`),regExp:`overscroll-(${L.overscroll.join("|")})`},overscrollX:{classes:d.map(L.overscroll,t=>`overscroll-x-${t}`),regExp:`overscroll-x-(${L.overscroll.join("|")})`},overscrollY:{classes:d.map(L.overscroll,t=>`overscroll-y-${t}`),regExp:`overscroll-y-(${L.overscroll.join("|")})`},inset:{classes:d.map(L.trbl,t=>`inset-${t}`),regExp:"-?inset-(px|\\d\\/\\d|\\d\\.\\d|\\d+|full|auto|\\[.*\\])"},insetX:{classes:d.map(L.trbl,t=>`inset-x-${t}`),regExp:"-?inset-x-(px|\\d\\/\\d|\\d\\.\\d|\\d+|full|auto|\\[.*\\])"},insetY:{classes:d.map(L.trbl,t=>`inset-y-${t}`),regExp:"-?inset-y-(px|\\d\\/\\d|\\d\\.\\d|\\d+|full|auto|\\[.*\\])"},top:{classes:d.map(L.trbl,t=>`top-${t}`),regExp:"-?top-(px|\\d\\/\\d|\\d\\.\\d|\\d+|full|auto|\\[.*\\])"},topX:{classes:d.map(L.trbl,t=>`top-x-${t}`),regExp:"-?top-x-(px|\\d\\/\\d|\\d\\.\\d|\\d+|full|auto|\\[.*\\])"},topY:{classes:d.map(L.trbl,t=>`top-y-${t}`),regExp:"-?top-y-(px|\\d\\/\\d|\\d\\.\\d|\\d+|full|auto|\\[.*\\])"},right:{classes:d.map(L.trbl,t=>`right-${t}`),regExp:"-?right-(px|\\d\\/\\d|\\d\\.\\d|\\d+|full|auto|\\[.*\\])"},rightX:{classes:d.map(L.trbl,t=>`right-x-${t}`),regExp:"-?right-x-(px|\\d\\/\\d|\\d\\.\\d|\\d+|full|auto|\\[.*\\])"},rightY:{classes:d.map(L.trbl,t=>`right-y-${t}`),regExp:"-?right-y-(px|\\d\\/\\d|\\d\\.\\d|\\d+|full|auto|\\[.*\\])"},bottom:{classes:d.map(L.trbl,t=>`bottom-${t}`),regExp:"-?bottom-(px|\\d\\/\\d|\\d\\.\\d|\\d+|full|auto|\\[.*\\])"},bottomX:{classes:d.map(L.trbl,t=>`bottom-x-${t}`),regExp:"-?bottom-x-(px|\\d\\/\\d|\\d\\.\\d|\\d+|full|auto|\\[.*\\])"},bottomY:{classes:d.map(L.trbl,t=>`bottom-y-${t}`),regExp:"-?bottom-y-(px|\\d\\/\\d|\\d\\.\\d|\\d+|full|auto|\\[.*\\])"},left:{classes:d.map(L.trbl,t=>`left-${t}`),regExp:"-?left-(px|\\d\\/\\d|\\d\\.\\d|\\d+|full|auto|\\[.*\\])"},leftX:{classes:d.map(L.trbl,t=>`left-x-${t}`),regExp:"-?left-x-(px|\\d\\/\\d|\\d\\.\\d|\\d+|full|auto|\\[.*\\])"},leftY:{classes:d.map(L.trbl,t=>`left-y-${t}`),regExp:"-?left-y-(px|\\d\\/\\d|\\d\\.\\d|\\d+|full|auto|\\[.*\\])"},visibility:{classes:["visible","invisible"],regExp:"invisible|visible"},zIndex:{classes:d.map(["0",10,20,30,40,50,"auto"],t=>`z-${t}`),regExp:"-?z-(\\d+|auto|\\[.*\\])"},flexBasis:{classes:d.map(L.flexBasis,t=>`basis-${t}`),regExp:"basis-(\\d+|\\S+)"},flexGrow:{classes:["grow","grow-0"],regExp:"grow(-0)?"},flexShrink:{classes:["shrink","shrink-0"],regExp:"shrink(-0)?"},gridColSpan:{classes:["col-auto",...d.map(d.range(1,13),t=>`col-span-${t}`),"col-span-full"],regExp:"col-(auto|span-(\\d+|full))"},gridColStart:{classes:[...d.map(d.range(1,14),t=>`col-start-${t}`),"col-start-auto"],regExp:"col-start-(\\d+|auto)"},gridColEnd:{classes:[...d.map(d.range(1,14),t=>`col-end-${t}`),"col-end-auto"],regExp:"col-end-(\\d+|auto)"},gridRowSpan:{classes:["row-auto",...d.map(d.range(1,7),t=>`row-span-${t}`),"row-span-full"],regExp:"row-(auto|span-(\\d+|full))"},gridRowStart:{classes:[...d.map(d.range(1,8),t=>`row-start-${t}`),"row-start-auto"],regExp:"row-start-(\\d+|auto)"},gridRowEnd:{classes:[...d.map(d.range(1,8),t=>`row-end-${t}`),"row-end-auto"],regExp:"row-end-(\\d+|auto)"},gridAutoColumns:{classes:["auto-cols-auto","auto-cols-min","auto-cols-max","auto-cols-fr"],regExp:"auto-cols-(auto|min|max|fr)"},gridAutoRows:{classes:["auto-rows-auto","auto-rows-min","auto-rows-max","auto-rows-fr"],regExp:"auto-rows-(auto|min|max|fr)"},gap:{classes:d.map(L.indent,t=>`gap-${t}`),regExp:"gap-(px|\\d.\\d|\\d|\\[.*\\])"},gapX:{classes:d.map(L.indent,t=>`gap-x-${t}`),regExp:"gap-x-(px|\\d.\\d|\\d|\\[.*\\])"},gapY:{classes:d.map(L.indent,t=>`gap-y-${t}`),regExp:"gap-y-(px|\\d.\\d|\\d|\\[.*\\])"},justifyContent:{classes:["justify-start","justify-end","justify-center","justify-between","justify-around","justify-evenly"],regExp:"justify-(start|end|center|between|around|evenly)"},justifyItems:{classes:["justify-items-start","justify-items-end","justify-items-center","justify-items-stretch"],regExp:"justify-items-(start|end|center|stretch)"},justifySelf:{classes:["justify-self-auto","justify-self-start","justify-self-end","justify-self-center","justify-self-stretch"],regExp:"justify-self-(auto|start|end|center|stretch)"},placeContent:{classes:["place-content-center","place-content-start","place-content-end","place-content-between","place-content-around","place-content-evenly","place-content-stretch"],regExp:"place-content-(center|start|end|between|around|evenly|stretch)"},placeItems:{classes:["place-items-start","place-items-end","place-items-center","place-items-stretch"],regExp:"place-items-(start|end|center|stretch)"},placeSelf:{classes:["place-self-auto","place-self-start","place-self-end","place-self-center","place-self-stretch"],regExp:"place-self-(auto|start|end|center|stretch)"},alignContent:{classes:["content-center","content-start","content-end","content-between","content-around","content-evenly"],regExp:"content-(center|start|end|between|around|evenly)"},alignItems:{classes:["items-start","items-end","items-center","items-baseline","items-stretch"],regExp:"items-(start|end|center|baseline|stretch)"},alignSelf:{classes:["self-auto","self-start","self-end","self-center","self-stretch","self-baseline"],regExp:"self-(auto|start|end|center|stretch|baseline)"},backgroundClip:{classes:["bg-clip-border","bg-clip-padding","bg-clip-content","bg-clip-text"],regExp:"bg-clip-(border|padding|content|text)"},dropShadow:{classes:d.map(["sm","md","lg","xl","2xl","none"],t=>`drop-shadow-${t}`),regExp:"drop-shadow-(sm|md|lg|xl|2xl|none)"},backdropBlur:{classes:d.map(["none","sm","md","lg","xl","2xl","3xl"],t=>`backdrop-blur-${t}`),regExp:"backdrop-blur-(none|sm|md|lg|xl|2xl|3xl)"},backdropBrightness:{classes:d.map([0,50,75,90,95,100,105,110,125,150,200],t=>`backdrop-brightness-${t}`),regExp:"backdrop-brightness-(\\d+)"},backdropContrast:{classes:d.map([0,50,75,100,125,150,200],t=>`backdrop-contrast-${t}`),regExp:"backdrop-contrast-(\\d+)"},backdropGrayScale:{classes:["backdrop-grayscale-0","backdrop-grayscale"],regExp:"backdrop-grayscale(-0)?"},backdropHueRotate:{classes:d.map([0,15,30,60,90,180],t=>`backdrop-hue-rotate-${t}`),regExp:"-?backdrop-hue-rotate-(\\d+)"},backdropInvert:{classes:["backdrop-invert-0","backdrop-invert"],regExp:"backdrop-invert(-0)?"},backdropOpacity:{classes:d.map([0,5,10,20,25,30,40,50,60,70,75,80,90,95,100],t=>`backdrop-opacity-${t}`),regExp:"backdrop-opacity-(\\d+)"},backdropSaturate:{classes:d.map([0,50,100,150,200],t=>`backdrop-saturate-${t}`),regExp:"backdrop-saturate-(\\d+)"},backdropSepia:{classes:["backdrop-sepia-0, backdrop-sepia"],regExp:"backdrop-sepia(-0)?"},backgroundOrigin:{classes:["bg-origin-border","bg-origin-padding","bg-origin-content"],regExp:"bg-origin-(border|padding|content)"},transformOrigin:{classes:d.map(L.origin,t=>`origin-${t}`),regExp:"origin-(\\d+|\\S+)"},padding:{classes:d.map(L.padding,t=>`p-${t}`),regExp:"p-(\\d+|\\S+|\\[.*\\])"},paddingX:{classes:d.map(L.padding,t=>`px-${t}`),regExp:"px-(\\d+|\\S+|\\[.*\\])"},paddingY:{classes:d.map(L.padding,t=>`py-${t}`),regExp:"py-(\\d+|\\S+|\\[.*\\])"},paddingTop:{classes:d.map(L.padding,t=>`pt-${t}`),regExp:"pt-(\\d+|\\S+|\\[.*\\])"},paddingRight:{classes:d.map(L.padding,t=>`pr-${t}`),regExp:"pr-(\\d+|\\S+|\\[.*\\])"},paddingBottom:{classes:d.map(L.padding,t=>`pb-${t}`),regExp:"pb-(\\d+|\\S+|\\[.*\\])"},paddingLeft:{classes:d.map(L.padding,t=>`pl-${t}`),regExp:"pl-(\\d+|\\S+|\\[.*\\])"},textDecorationStyle:{classes:["decoration-solid","decoration-double","decoration-dotted","decoration-dashed","decoration-wavy"],regExp:"decoration-(solid|double|dotted|dashed|wavy)"},textDecorationThickness:{classes:d.map(["auto","from-font","0",1,2,4,8],t=>`decoration-${t}`),regExp:"decoration-(auto|from-font|\\d+|\\S+)"},fromColor:{classes:[],regExp:"from-(black|transparent|current|white|__THEME_COLORS_REGEXP__|\\S+-\\d+)"},margin:{classes:d.map(L.margin,t=>`m-${t}`),regExp:"-?m-(\\d+|\\S+|\\[.*\\])"},marginX:{classes:d.map(L.margin,t=>`mx-${t}`),regExp:"-?mx-(\\d+|\\S+|\\[.*\\])"},marginY:{classes:d.map(L.margin,t=>`my-${t}`),regExp:"-?my-(\\d+|\\S+|\\[.*\\])"},marginTop:{classes:d.map(L.margin,t=>`mt-${t}`),regExp:"-?mt-(\\d+|\\S+|\\[.*\\])"},marginRight:{classes:d.map(L.margin,t=>`mr-${t}`),regExp:"-?mr-(\\d+|\\S+|\\[.*\\])"},marginBottom:{classes:d.map(L.margin,t=>`mb-${t}`),regExp:"-?mb-(\\d+|\\S+|\\[.*\\])"},marginLeft:{classes:d.map(L.margin,t=>`ml-${t}`),regExp:"-?ml-(\\d+|\\S+|\\[.*\\])"},spaceX:{classes:d.map(L.space,t=>`space-x-${t}`),regExp:"-?space-x-(\\d+|\\S+|\\[.*\\])"},spaceY:{classes:d.map(L.space,t=>`space-y-${t}`),regExp:"-?space-y-(\\d+|\\S+|\\[.*\\])"},boxShadow:{classes:d.map(["sm","md","lg","xl","2xl","inner","none"],t=>`shadow-${t}`),regExp:"shadow-(sm|md|lg|xl|2xl|inner|none)"},minWidth:{classes:["min-w-0","min-w-full","min-w-min","min-w-max","min-w-fit"],regExp:"min-w-(\\d+|\\S+|\\[.*\\])"},maxWidth:{classes:d.map(L.maxWidth,t=>`max-w-${t}`),regExp:"max-w-(\\d+|\\S+|\\[.*\\])"},width:{classes:d.map([...L.width,"full","screen","min","max","fit"],t=>`w-${t}`),regExp:"w-(\\d+.\\d+|\\d+|px|auto|full|screen|min|max|fit|\\[.*\\])$"},minHeight:{classes:["min-h-0","min-h-full","min-h-screen","min-h-min","min-h-max","min-h-fit"],regExp:"min-h-(\\d+|\\S+|\\[.*\\])"},maxHeight:{classes:d.map(L.maxHeight,t=>`max-h-${t}`),regExp:"max-h-(\\d+|\\S+|\\[.*\\])"},height:{classes:d.map(L.height,t=>`h-${t}`),regExp:"h-(\\d+.\\d+|\\d+|px|auto|full|screen|min|max|fit|\\[.*\\])"},fontFamily:{classes:["font-heading","font-body","font-sans","font-serif","font-mono"],regExp:"font-(heading|body|sans|serif|mono)"},textAlign:{classes:["text-left","text-center","text-right","text-justify"],regExp:"text-(left|center|right|justify)"},textOverflow:{classes:["truncate","text-ellipsis","text-clip"],regExp:"truncate|text-ellipsis|text-clip"},verticalAlign:{classes:["align-baseline","align-top","align-middle","align-bottom","align-text-top","align-text-bottom","align-sub","align-super"],regExp:"align-(baseline|top|middle|bottom|text-top|text-bottom|sub|super)"},fontSize:{classes:["text-xs","text-sm","text-base","text-lg","text-xl","text-2xl","text-3xl","text-4xl","text-5xl","text-6xl","text-7xl","text-8xl","text-9xl"],regExp:"text-(\\d+|\\S+|\\[.*\\])"},fontSmoothing:{classes:["antialiased","subpixel-antialiased"],regExp:"antialiased|subpixel-antialiased"},fontStyle:{classes:["italic","not-italic"],regExp:"not-italic|italic"},fontWeight:{classes:["font-thin","font-extralight","font-light","font-normal","font-medium","font-semibold","font-bold","font-extrabold","font-black"],regExp:"font-(thin|extralight|light|normal|medium|semibold|bold|extrabold|black)"},fontVariantNum:{classes:["normal-nums","ordinal","diagonal-fractions","stacked-fractions","tabular-nums","oldstyle-nums","proportional-nums","lining-nums","slashed-zero"],regExp:"normal-nums|ordinal|diagonal-fractions|stacked-fractions|tabular-nums|oldstyle-nums|proportional-nums|lining-nums|slashed-zero"},letterSpacing:{classes:["tracking-tighter","tracking-tight","tracking-normal","tracking-wide","tracking-wider","tracking-widest"],regExp:"-?tracking-(tighter|tight|normal|wide|wider|widest|\\[.*\\])"},lineHeight:{classes:["leading-none","leading-tight","leading-snug","leading-normal","leading-relaxed","leading-loose","leading-3","leading-4","leading-5","leading-6","leading-7","leading-8","leading-9","leading-10"],regExp:"leading-(none|tight|snug|normal|relaxed|loose|\\[.*\\]|\\d+)"},listStyleType:{classes:["list-none","list-disc","list-decimal"],regExp:"list-(none|disc|decimal)"},listStylePosition:{classes:["list-inside","list-outside"],regExp:"list-(inside|outside)"},textUnderlineOffset:{classes:["underline-offset-auto","underline-offset-0","underline-offset-1","underline-offset-2","underline-offset-4","underline-offset-8"],regExp:"underline-offset-(auto|\\d+|\\S+)"},textDecoration:{classes:["underline","overline","line-through","no-underline"],regExp:"underline|overline|line-through|no-underline"},textDecorationColor:{classes:[],regExp:"decoration-(black|transparent|current|white|__THEME_COLORS_REGEXP__|\\S+-\\d+)"},textTransform:{classes:["uppercase","lowercase","capitalize","normal-case"],regExp:"uppercase|lowercase|capitalize|normal-case"},textIndent:{classes:d.map(L.indent,t=>`indent-${t}`),regExp:"-?indent-(\\d+|\\S+)"},whitespace:{classes:["whitespace-normal","whitespace-nowrap","whitespace-pre","whitespace-pre-line","whitespace-pre-wrap"],regExp:"whitespace-(normal|nowrap|pre|pre-line|pre-wrap)"},wordBreak:{classes:["break-normal","break-words","break-all"],regExp:"break-(normal|words|all)"},content:{classes:["content-none"],regExp:"content-none"},backgroundAttachment:{classes:d.map(["fixed","local","scroll"],t=>`bg-${t}`),regExp:"bg-(fixed|local|scroll)"},backgroundColor:{classes:[],regExp:"bg-(black|transparent|current|white|__THEME_COLORS_REGEXP__|\\S+-\\d+)"},backgroundPosition:{classes:["bg-bottom","bg-center","bg-left","bg-left-bottom","bg-left-top","bg-right","bg-right-bottom","bg-right-top","bg-top"],regExp:"bg-(bottom|center|left|left-bottom|left-top|right|right-bottom|right-top|top)"},backgroundRepeat:{classes:["bg-repeat","bg-repeat-x","bg-repeat-y","bg-no-repeat","bg-repeat-round","bg-repeat-space"],regExp:"bg-(repeat|repeat-x|repeat-y|no-repeat|repeat-round|repeat-space)"},backgroundSize:{classes:["bg-auto","bg-cover","bg-contain"],regExp:"bg-(auto|cover|contain)"},backgroundGradient:{classes:["bg-gradient-none","bg-gradient-to-t","bg-gradient-to-tr","bg-gradient-to-r","bg-gradient-to-br","bg-gradient-to-b","bg-gradient-to-bl","bg-gradient-to-l","bg-gradient-to-tl"],regExp:"bg-gradient-(none|to-(t|tr|r|br|b|bl|l|tl))"},viaColor:{classes:[],regExp:"via-(black|transparent|current|white|__THEME_COLORS_REGEXP__|\\S+-\\d+)"},toColor:{classes:[],regExp:"to-(black|transparent|current|white|__THEME_COLORS_REGEXP__|\\S+-\\d+)"},position:{classes:["static","fixed","absolute","relative","sticky"],regExp:"(static|fixed|absolute|relative|sticky)"},borderRadiusTopLeft:{classes:["rounded-tl",...d.map(L.borderRadius,t=>`rounded-tl-${t}`)],regExp:"rounded-tl-?(\\d+|\\S+)?"},borderRadiusTopRight:{classes:["rounded-tr",...d.map(L.borderRadius,t=>`rounded-tr-${t}`)],regExp:"rounded-tr-?(\\d+|\\S+)?"},borderRadiusBottomRight:{classes:["rounded-br",...d.map(L.borderRadius,t=>`rounded-br-${t}`)],regExp:"rounded-br-?(\\d+|\\S+)?"},borderRadiusBottomLeft:{classes:["rounded-bl",...d.map(L.borderRadius,t=>`rounded-bl-${t}`)],regExp:"rounded-bl-?(\\d+|\\S+)?"},borderRadiusTop:{classes:["rounded-t",...d.map(L.borderRadius,t=>`rounded-t-${t}`)],regExp:"rounded-t-?(\\d+|\\S+)?"},borderRadiusRight:{classes:["rounded-r",...d.map(L.borderRadius,t=>`rounded-r-${t}`)],regExp:"rounded-r-?(\\d+|\\S+)?"},borderRadiusBottom:{classes:["rounded-b",...d.map(L.borderRadius,t=>`rounded-b-${t}`)],regExp:"rounded-b-?(\\d+|\\S+)?"},borderRadiusLeft:{classes:["rounded-l",...d.map(L.borderRadius,t=>`rounded-l-${t}`)],regExp:`(rounded-l-(${L.borderRadius.join("|")})|rounded-l$)`},borderRadius:{classes:["rounded",...d.map(L.borderRadius,t=>`rounded-${t}`)],regExp:`(rounded-(${L.borderRadius.join("|")}$)|rounded)`},borderX:{classes:["border-x",...d.map(L.borderWidth,t=>`border-x-${t}`)],regExp:"border-x-?(\\d+|\\S+|\\[.*\\])?"},borderY:{classes:["border-y",...d.map(L.borderWidth,t=>`border-y-${t}`)],regExp:"border-y-?(\\d+|\\S+|\\[.*\\])?"},borderTop:{classes:["border-t",...d.map(L.borderWidth,t=>`border-t-${t}`)],regExp:"border-t-?(\\d+|\\S+|\\[.*\\])?"},borderRight:{classes:["border-r",...d.map(L.borderWidth,t=>`border-r-${t}`)],regExp:"border-r-?(\\d+|\\S+|\\[.*\\])?"},borderBottom:{classes:["border-b",...d.map(L.borderWidth,t=>`border-b-${t}`)],regExp:"border-b-?(\\d+|\\S+|\\[.*\\])?"},borderLeft:{classes:["border-l",...d.map(L.borderWidth,t=>`border-l-${t}`)],regExp:"border-l-?(\\d+|\\S+|\\[.*\\])?"},borderColor:{classes:[],regExp:"^border-(black|transparent|current|white|__THEME_COLORS_REGEXP__|\\w+-\\d+|\\[#[0-9a-fA-F]+\\])$"},border:{classes:["border",...d.map(L.borderWidth,t=>`border-${t}`)],regExp:"^border(-\\d+|\\[\\d+px\\])?$"},order:{classes:d.map([...d.range(0,13),"first","last","none"],t=>`order-${t}`),regExp:"-?order-(\\d+|first|last|none)"},divideXWidth:{classes:d.map(["0",2,4,8],t=>`divide-x-${t}`),regExp:"divide-x-(\\d+|\\[.*\\])"},divideYWidth:{classes:d.map(["0",2,4,8],t=>`divide-y-${t}`),regExp:"divide-y-(\\d+|\\[.*\\])"},divideColor:{classes:[],regExp:"divide-(black|transparent|current|white|__THEME_COLORS_REGEXP__|\\S+-\\d+)"},divideStyle:{classes:d.map(["solid","dashed","dotted","double","none"],t=>`divide-${t}`),regExp:"divide-(solid|dashed|dotted|double|none)"},outlineWidth:{classes:d.map([0,1,2,4,8],t=>`outline-${t}`),regExp:"outline-(\\d+)"},outlineOffset:{classes:d.map([0,1,2,4,8],t=>`outline-offset-${t}`),regExp:"outline-offset-(\\d+)"},outlineColor:{classes:[],regExp:"outline-(black|transparent|current|white|__THEME_COLORS_REGEXP__|\\S+-\\d+)"},ringWidth:{classes:d.map([0,1,2,4,8,"inset"],t=>`ring-${t}`),regExp:"ring-(\\d+|inset)"},ringOffsetWidth:{classes:d.map([0,1,2,4,8],t=>`ring-offset-${t}`),regExp:"ring-offset-(\\d+)"},ringOffsetColor:{classes:[],regExp:"ring-offset-(black|transparent|current|white|__THEME_COLORS_REGEXP__|\\S+-\\d+)"},ringColor:{classes:[],regExp:"ring-(black|transparent|current|white|__THEME_COLORS_REGEXP__|\\S+-\\d+)"},boxShadowColor:{classes:[],regExp:"shadow-(black|transparent|current|white|__THEME_COLORS_REGEXP__|\\S+-\\d+)"},opacity:{classes:d.map([0,5,10,20,25,30,40,50,60,70,75,80,90,95,100],t=>`opacity-${t}`),regExp:"opacity-(\\d+|\\[.*\\])"},mixBlendMode:{classes:d.map(L.blendEffect,t=>`mix-blend-${t}`),regExp:"mix-blend-(\\d+|\\S+)"},bgBlendMode:{classes:d.map(L.blendEffect,t=>`bg-blend-${t}`),regExp:"bg-blend-(\\d+|\\S+)"},blur:{classes:d.map(["none","sm","md","lg","xl","2xl","3xl"],t=>`blur-${t}`),regExp:"blur-(none|sm|md|lg|xl|2xl|3xl)"},brightness:{classes:d.map([0,50,75,90,95,100,105,110,125,150,200],t=>`brightness-${t}`),regExp:"brightness-(\\d+)"},contrast:{classes:d.map([0,50,75,100,125,150,200],t=>`contrast-${t}`),regExp:"contrast-(\\d+)"},grayScale:{classes:["grayscale-0","grayscale"],regExp:"grayscale(-0)?"},hueRotate:{classes:d.map([0,15,30,60,90,180],t=>`hue-rotate-${t}`),regExp:"-?hue-rotate-(\\d+)"},invert:{classes:["invert-0","invert"],regExp:"invert(-0)?"},saturate:{classes:d.map([0,50,100,150,200],t=>`saturate-${t}`),regExp:"saturate-(\\d+)"},sepia:{classes:["sepia-0","sepia"],regExp:"sepia(-0)?"},transition:{classes:["transition-none","transition-all","transition-colors","transition-opacity","transition-shadow","transition-transform"],regExp:"transition-(none|all|colors|opacity|shadow|transform)"},duration:{classes:d.map([75,100,150,200,300,500,700,1e3],t=>`duration-${t}`),regExp:"duration-(\\d+|\\[.*\\])"},transitionEase:{classes:["ease-linear","ease-in","ease-out","ease-in-out"],regExp:"eas(e-linear|e-in|e-out|e-in-out)"},transitionDelay:{classes:d.map([75,100,150,200,300,500,700,1e3],t=>`delay-${t}`),regExp:"delay-(\\d+|\\[.*\\])"},animation:{classes:["animate-none","animate-spin","animate-ping"],regExp:"animate-(none|spin|ping)"},scaleX:{classes:d.map(L.scale,t=>`scale-x-${t}`),regExp:"-?scale-x-(\\d+|\\S+|\\[.*\\])"},scaleY:{classes:d.map(L.scale,t=>`scale-y-${t}`),regExp:"-?scale-y-(\\d+|\\S+|\\[.*\\])"},scale:{classes:d.map(L.scale,t=>`scale-${t}`),regExp:"-?scale-(\\d+|\\S+|\\[.*\\])"},rotate:{classes:d.map([0,1,2,3,6,12,45,90,180],t=>`rotate-${t}`),regExp:"-?rotate-(\\d+|\\S+|\\[.*\\])"},translateX:{classes:d.map([0,"px","0.5",1],t=>`translate-x-${t}`),regExp:"-?translate-x-(\\d+|\\S+|\\[.*\\])"},translateY:{classes:d.map([0,"px","0.5",1],t=>`translate-y-${t}`),regExp:"-?translate-y-(\\d+|\\S+|\\[.*\\])"},skewX:{classes:d.map([0,1,2,3,6,12],t=>`skew-x-${t}`),regExp:"-?skew-x-(\\d+|\\S+|\\[.*\\])"},skewY:{classes:d.map([0,1,2,3,6,12],t=>`skew-y-${t}`),regExp:"-?skew-y-(\\d+|\\S+|\\[.*\\])"},accentColor:{classes:[],regExp:"accent-(black|transparent|current|white|__THEME_COLORS_REGEXP__|\\S+-\\d+)"},appearance:{classes:["appearance-none"],regExp:"appearance-none"},cursor:{classes:["cursor-auto","cursor-default","cursor-pointer","cursor-wait","cursor-text","cursor-move","cursor-help","cursor-not-allowed"],regExp:"cursor-(auto|default|pointer|wait|text|move|help|not-allowed)"},caretColor:{classes:[],regExp:"caret-(black|transparent|current|white|__THEME_COLORS_REGEXP__|\\S+-\\d+)"},pointerEvents:{classes:["pointer-events-none","pointer-events-auto"],regExp:"pointer-events-(none|auto)"},userSelect:{classes:["select-none","select-text","select-all","select-auto"],regExp:"select-(none|text|all|auto)"},fill:{classes:[],regExp:"caret-(black|transparent|current|white|__THEME_COLORS_REGEXP__|\\S+-\\d+)"},stroke:{classes:[],regExp:"caret-(black|transparent|current|white|__THEME_COLORS_REGEXP__|\\S+-\\d+)"},strokeWidth:{classes:["stroke-0","stroke-1","stroke-2"],regExp:"stroke-(\\d+|\\[.*\\])"}},hg={backgroundColor:"bg",textColor:"text",borderColor:"border",boxShadowColor:"shadow",outlineColor:"outline",divideColor:"divide",fromColor:"from",viaColor:"via",toColor:"to",ringColor:"ring",ringOffsetColor:"ring-offset"},mg=["current","inherit","transparent","black","white"],gg=["slate","gray","zinc","neutral","stone","red","orange","amber","yellow","lime","green","emerald","teal","cyan","sky","blue","indigo","violet","purple","fuchsia","pink","rose"],xg=["50","100","200","300","400","500","600","700","800","900"],yr=d.map(d.values(hg),t=>t),bg=d.flattenDeep([...d.map(mg,t=>d.flatten(d.map(yr,e=>`${e}-${t}`))),...d.map(gg,t=>d.flattenDeep(d.map(yr,e=>d.flattenDeep(d.map(xg,n=>`${e}-${t}-${n}`)))))]),yg=d.map(d.flattenDeep(d.values(Xt).map(t=>t.classes).concat(bg)),t=>({name:t})),kg=()=>{const t=nn(),e=g.useMemo(()=>{let n=[];if(t.colors){const s=d.flattenDeep(d.map(t.colors,({items:r})=>d.keys(r)));n=d.flattenDeep(d.map(s,r=>d.flatten(d.map(yr,o=>`${o}-${r}`))))}return t.fontFamily&&(n=[...n,...d.map(d.keys(t.fontFamily),s=>`${s}`)]),d.map(n,s=>({name:s}))},[t]);return g.useMemo(()=>new Ha([...yg,...e],{isCaseSensitive:!1,threshold:.2,minMatchCharLength:2,keys:["name"]}),[e])},Ls=()=>{const t=nn(),e=g.useMemo(()=>{if(t.colors){const r=d.flattenDeep(d.map(t.colors,({items:o})=>d.keys(o)));d.each(Xt,(o,i)=>{d.set(Xt,`${i}.regExp`,o.regExp.replace("__THEME_COLORS_REGEXP__",r.join("|")))})}return Xt},[t]),n=g.useCallback((r,o)=>{const i=d.get(e,`${r}.regExp`,"");return o.match(new RegExp(i))},[e]),s=g.useCallback((r,o=[])=>d.get(e,`${r}.classes`,o),[e]);return{match:n,getClasses:s}},Ql=({label:t,property:e,onChange:n})=>{const{getClasses:s}=Ls(),r=s(e),o=Dn(e),i=g.useMemo(()=>d.get(o,"cls",""),[o]),{canChange:l}=g.useContext(Mn),c=/\[.*\]/g.test(i);return a.jsx("div",{className:t?"w-full rounded":"grow",children:c?a.jsxs("div",{className:"flex items-center",children:[a.jsx(B.Input,{className:"w-[70%] rounded py-1",readOnly:!0,value:i}),a.jsxs(fe,{delayDuration:100,children:[a.jsx(he,{asChild:!0,children:a.jsx("button",{type:"button",className:"invisible ml-3 mt-1 text-blue-600 group-hover:visible",children:a.jsx(k.InfoCircledIcon,{})})}),a.jsx(ue,{children:"Current value is using a Tailwind arbitrary value."})]})]}):a.jsx(kr,{rounded:t,onChange:u=>n(u,e),selected:i,options:r,disabled:!l})})};function kr({selected:t,onChange:e,rounded:n=!1,options:s,disabled:r=!1}){const o=t.replace(/.*:/g,"").trim(),{undo:i,redo:l}=Tn();return a.jsxs("select",{disabled:!s.length||r,className:`${n?"rounded-md border border-border":"border-0"} disable:bg-gray-500 h-full w-full truncate rounded bg-background px-2 py-1 text-xs outline-none disabled:cursor-not-allowed`,onChange:c=>e(c.target.value),onKeyDown:c=>{c.ctrlKey&&(c.key==="z"&&i(),c.key==="y"&&l())},value:o,children:[a.jsx("option",{className:"bg-transparent",value:""}),s.map((c,u)=>a.jsx("option",{className:"bg-transparent",value:c,children:c},`option-${u}`))]})}const vg={backgroundColor:"bg",textColor:"text",borderColor:"border",boxShadowColor:"shadow",outlineColor:"outline",divideColor:"divide",fromColor:"from",viaColor:"via",toColor:"to",ringColor:"ring",ringOffsetColor:"ring-offset"},wg=({property:t,onChange:e})=>{const n=Dn(t),s=g.useMemo(()=>d.get(n,"cls",""),[n]),{canChange:r}=g.useContext(Mn),[o,i]=g.useState([]),[l,c]=g.useState({color:"",shade:""}),u=s.split("-"),p=d.get(u,"1",""),f=d.get(u,"2",""),m=g.useCallback(b=>{["current","inherit","transparent","black","white"].includes(b)?(i([]),c({color:b})):(i(["50","100","200","300","400","500","600","700","800","900"]),c(y=>({...y,color:b,shade:y.shade?y.shade:"500"})))},[i,c]);g.useEffect(()=>{if(["current","inherit","transparent","black","white"].includes(p))return i([]);i(["50","100","200","300","400","500","600","700","800","900"])},[p]);const h=g.useCallback(b=>{c({color:p,shade:b})},[p]);g.useEffect(()=>{c({color:"",shade:""})},[n]);const{match:x}=Ls();return g.useEffect(()=>{const y=`${d.get(vg,t,"")}-${l.color}${l.shade?`-${l.shade}`:""}`;x(t,y)&&e(y,t)},[x,l,e,t]),a.jsxs("div",{className:"flex flex-row divide-x divide-solid divide-border rounded-lg border border-transparent text-xs",children:[a.jsx("div",{className:"grow text-center",children:a.jsx(kr,{disabled:!r,rounded:!0,selected:p,onChange:m,options:["current","transparent","primary","secondary","black","white","slate","gray","zinc","neutral","stone","red","orange","amber","yellow","lime","green","emerald","teal","cyan","sky","blue","indigo","violet","purple","fuchsia","pink","rose"]})}),a.jsx("button",{type:"button",className:"grow text-center",children:a.jsx(kr,{rounded:!0,selected:f,disabled:!p||!r,onChange:h,options:o})})]})},ec={"not-italic":()=>a.jsx("svg",{width:"16",height:"16",viewBox:"0 0 16 16",fill:"none",xmlns:"http://www.w3.org/2000/svg",children:a.jsx("path",{fillRule:"evenodd",clipRule:"evenodd",d:"M9 3H11V5H9V11H11V13H5V11H7V5H5V3H9Z",fill:"white"})}),visible:k.EyeOpenIcon,invisible:k.EyeClosedIcon,hidden:k.EyeClosedIcon,gap:k.BorderAllIcon,gapX:k.WidthIcon,gapY:k.HeightIcon,spaceX:k.WidthIcon,spaceY:k.HeightIcon,overscroll:k.BorderAllIcon,overscrollX:k.WidthIcon,overscrollY:k.HeightIcon,overflow:k.BorderAllIcon,overflowX:k.WidthIcon,overflowY:k.HeightIcon,top:k.ArrowUpIcon,right:k.ArrowRightIcon,bottom:k.ArrowDownIcon,left:k.ArrowLeftIcon,inset:k.BorderAllIcon,insetX:k.WidthIcon,insetY:k.HeightIcon,border:k.BorderAllIcon,borderX:k.WidthIcon,borderY:k.HeightIcon,borderTop:k.ArrowUpIcon,borderRight:k.ArrowRightIcon,borderBottom:k.ArrowDownIcon,borderLeft:k.ArrowLeftIcon,borderRadius:k.BorderAllIcon,borderRadiusX:k.WidthIcon,borderRadiusY:k.HeightIcon,borderRadiusTop:k.ArrowUpIcon,borderRadiusRight:k.ArrowRightIcon,borderRadiusBottom:k.ArrowDownIcon,borderRadiusLeft:k.ArrowLeftIcon,borderRadiusTopLeft:k.ArrowTopLeftIcon,borderRadiusTopRight:k.ArrowTopRightIcon,borderRadiusBottomRight:k.ArrowBottomRightIcon,borderRadiusBottomLeft:k.ArrowBottomLeftIcon,divideXWidth:k.WidthIcon,divideYWidth:k.HeightIcon,scale:k.BorderAllIcon,scaleX:k.WidthIcon,scaleY:k.HeightIcon,skewX:k.WidthIcon,skewY:k.HeightIcon,translateX:k.WidthIcon,translateY:k.HeightIcon,padding:k.BorderAllIcon,paddingX:k.WidthIcon,paddingY:k.HeightIcon,paddingTop:k.ArrowUpIcon,paddingRight:k.ArrowRightIcon,paddingBottom:k.ArrowDownIcon,paddingLeft:k.ArrowLeftIcon,margin:k.BorderAllIcon,marginX:k.WidthIcon,marginY:k.HeightIcon,marginTop:k.ArrowUpIcon,marginRight:k.ArrowRightIcon,marginBottom:k.ArrowDownIcon,marginLeft:k.ArrowLeftIcon,textLeft:k.AlignLeftIcon,textCenter:k.AlignCenterHorizontallyIcon,textRight:k.AlignRightIcon,textJustify:k.StretchHorizontallyIcon,italic:k.FontItalicIcon,underline:k.UnderlineIcon,overline:k.OverlineIcon,uppercase:k.LetterCaseUppercaseIcon,block:()=>a.jsxs("svg",{width:"16",height:"16",viewBox:"0 0 16 16",fill:"none",xmlns:"http://www.w3.org/2000/svg",children:[a.jsx("path",{opacity:"0.6",fillRule:"evenodd",clipRule:"evenodd",d:"M2 2H14V14H2V2ZM1 1H15V15H1V1Z",fill:"currentColor"}),a.jsx("path",{fillRule:"evenodd",clipRule:"evenodd",d:"M7 4H4V12H7V4ZM9 4H12V12H9V4Z",fill:"currentColor"})]}),"float-right":()=>a.jsxs("svg",{width:"16",height:"16",viewBox:"0 0 16 16",fill:"none",xmlns:"http://www.w3.org/2000/svg",children:[a.jsx("path",{d:"M8 4H16V12H8V4Z",fill:"currentColor"}),a.jsx("path",{opacity:"0.6",fillRule:"evenodd",clipRule:"evenodd",d:"M0 4H6V6H0V4ZM0 7H6V9H0V7ZM4 10H0V12H4V10Z",fill:"currentColor"})]}),"float-left":()=>a.jsxs("svg",{width:"16",height:"16",viewBox:"0 0 16 16",fill:"none",xmlns:"http://www.w3.org/2000/svg",children:[a.jsx("path",{d:"M0 4H8V12H0V4Z",fill:"currentColor"}),a.jsx("path",{opacity:"0.6",fillRule:"evenodd",clipRule:"evenodd",d:"M10 4H16V6H10V4ZM10 7H16V9H10V7ZM14 10H10V12H14V10Z",fill:"currentColor"})]}),"float-none":k.Cross2Icon,fixed:()=>a.jsxs("svg",{width:"16",height:"16",viewBox:"0 0 16 16",fill:"none",xmlns:"http://www.w3.org/2000/svg",children:[a.jsx("path",{opacity:"0.6",fillRule:"evenodd",clipRule:"evenodd",d:"M15 2H14V4H13V5H14V6H15V2ZM10 5V4H9V2H1V8H2V5H10ZM7 4V3H5V4H7ZM4 4V3H2V4H4ZM1 13H7V14H1V13Z",fill:"currentColor"}),a.jsx("path",{fillRule:"evenodd",clipRule:"evenodd",d:"M11 2H10V3H11V6H12V3H13V2H11ZM2 9H1V12H2V11H7V10H2V9ZM15 7H8V14H15V7Z",fill:"currentColor"})]}),absolute:()=>a.jsxs("svg",{width:"16",height:"16",viewBox:"0 0 16 16",fill:"none",xmlns:"http://www.w3.org/2000/svg",children:[a.jsx("path",{opacity:"0.6",fillRule:"evenodd",clipRule:"evenodd",d:"M14 2H15V6H14V2ZM9 3V2H1V8H2V3H9ZM7 13H1V14H7V13Z",fill:"currentColor"}),a.jsx("path",{fillRule:"evenodd",clipRule:"evenodd",d:"M11 2H10V3H11V6H12V3H13V2H11ZM2 9H1V12H2V11H7V10H2V9ZM15 7H8V14H15V7Z",fill:"currentColor"})]}),relative:()=>a.jsx("svg",{width:"16",height:"16",viewBox:"0 0 16 16",fill:"none",xmlns:"http://www.w3.org/2000/svg",children:a.jsx("path",{fillRule:"evenodd",clipRule:"evenodd",d:"M11 2H9V3H11V6H12V3H14V2H11ZM2 8H1V13H2V11H7V10H2V8ZM15 7H8V14H15V7Z",fill:"currentColor"})}),sticky:()=>a.jsxs("svg",{width:"16",height:"16",viewBox:"0 0 16 16",fill:"none",xmlns:"http://www.w3.org/2000/svg",children:[a.jsx("path",{d:"M12.9998 7C13.6558 7 14.2937 6.78498 14.8158 6.38787C15.338 5.99076 15.7156 5.43345 15.8908 4.80128C16.066 4.16912 16.0292 3.49694 15.7859 2.8877C15.5427 2.27846 15.1065 1.76573 14.5441 1.42804C13.9817 1.09034 13.3241 0.946293 12.672 1.01795C12.02 1.08961 11.4094 1.37303 10.9337 1.8248C10.4581 2.27658 10.1436 2.8718 10.0385 3.51932C9.93341 4.16685 10.0434 4.83097 10.3518 5.41L6.88176 8.88C6.80034 8.96122 6.73572 9.05769 6.69158 9.16388C6.64744 9.27008 6.62465 9.38393 6.62451 9.49894C6.62437 9.61395 6.64689 9.72785 6.69077 9.83416C6.73465 9.94046 6.79904 10.0371 6.88026 10.1185C6.96149 10.1999 7.05795 10.2645 7.16415 10.3087C7.27035 10.3528 7.3842 10.3756 7.4992 10.3758C7.61421 10.3759 7.72812 10.3534 7.83442 10.3095C7.94072 10.2656 8.03734 10.2012 8.11876 10.12L11.5888 6.648C12.0088 6.873 12.4888 7 12.9988 7H12.9998Z",fill:"currentColor"}),a.jsx("path",{opacity:"0.6",fillRule:"evenodd",clipRule:"evenodd",d:"M9.535 2H1V14H15V7.465C14.69 7.645 14.355 7.783 14 7.875V13H2V5H9.126C8.86504 3.98486 9.01223 2.90789 9.536 2H9.535ZM7 3V4H5V3H7ZM4 3V4H2V3H4Z",fill:"currentColor"})]}),static:k.Cross1Icon},Cg=({property:t,onChange:e})=>{const{getClasses:n}=Ls(),s=n(t),{canChange:r}=g.useContext(Mn),o=Dn(t),i=g.useMemo(()=>d.get(o,"cls",""),[o]);return a.jsx("div",{className:"flex grow flex-wrap gap-1",children:d.map(s,l=>a.jsxs(fe,{children:[a.jsx(he,{asChild:!0,children:a.jsx("button",{type:"button",disabled:!r,onClick:()=>e(l,t),className:`cursor-pointer rounded border border-border p-1 disabled:cursor-not-allowed ${i===l?"bg-primary text-white":"disabled:bg-gray-600 disabled:text-gray-400"}`,children:g.createElement(d.get(ec,l,k.BoxIcon))})}),a.jsx(ue,{children:d.startCase(d.toLower(l))})]}))})},jg=({property:t,onChange:e})=>{const{canReset:n,canChange:s}=g.useContext(Mn),r=Dn(t),o=g.useMemo(()=>d.get(r,"cls",""),[r]),{getClasses:i}=Ls(),l=i(t,[""]),c=l.indexOf(o)>-1?l.indexOf(o):0,u=/\[.*\]/g.test(o);return a.jsx("div",{className:"flex flex-row divide-x divide-solid divide-border rounded border border-border text-xs",children:u?a.jsx("div",{className:"px-2 py-[5px]",children:o}):a.jsxs(a.Fragment,{children:[a.jsx("button",{type:"button",className:"hover:bg-bg-gray-700 box-border w-2/12 rounded-bl rounded-tl bg-background px-1 text-center disabled:cursor-not-allowed disabled:bg-gray-600",disabled:!s&&(!n||c-1<0),onClick:()=>e(d.nth(l,c-1),t),children:a.jsx("span",{className:"flex items-center justify-center",children:a.jsx(k.MinusIcon,{className:!s&&(!n||c-1<0)?"text-gray-500":"text-black/60 dark:text-white/60"})})}),a.jsx("div",{className:"w-8/12 text-center",children:a.jsx(Ql,{label:!1,property:t,onChange:e})}),a.jsx("button",{type:"button",className:"hover:bg-bg-gray-700 w-2/12 rounded-br rounded-tr bg-background px-1 text-center disabled:cursor-not-allowed disabled:bg-gray-600",disabled:!s&&(!n||c+1>=l.length),onClick:()=>e(d.nth(l,c+1),t),children:a.jsx("span",{className:"flex items-center justify-center",children:a.jsx(k.PlusIcon,{className:!s&&(!n||c+1>=l.length)?"text-gray-500":"text-black/60 dark:text-white/60"})})})]})})};function Sg(t){if(d.isEmpty(t.trim()))return"";const e=t.match(/sm:|md:|lg:|xl:|2xl:/g);return d.get(e,0,"xs").replace(":","")}function Ng(t){const e=d.map(eu,s=>`${s}:`).join("|"),n=new RegExp(e,"g");return d.get(n.exec(t.trim()),0,"").replace(":","")}function Eg(t){return t.trim().split(":").pop()||""}const or={};function Ag(t){if(d.isEmpty(t))return"";if(or[t])return or[t];let e="";for(const n in Xt){const s=d.get(Xt,`${n}.regExp`,"");if(new RegExp(s,"g").test(t)){e=n,or[t]=e;break}}return e}function Ms(t){return d.isEmpty(t)?null:{dark:d.startsWith(t,"dark:"),mq:Sg(t),mod:Ng(t),cls:Eg(t),fullCls:t,property:Ag(t)}}function Ig(t){let e="";return t.dark&&(e+="dark:"),t.mq.toLowerCase()!=="xs"&&(e+=`${t.mq}:`),t.mod&&(e+=`${t.mod}:`),e+=t.cls,e}function tc(t){t=t.replace(/\s+/g," ");const e=t.split(" ").map(Ms).filter(s=>s!==null),n=["xs","sm","md","lg","xl","2xl"];return e.sort((s,r)=>n.indexOf(s.mq)-n.indexOf(r.mq)).map(s=>s.fullCls).join(" ")}function nc(t){if(t=t.replace(/\s+/g," "),!t)return"";const e=["xs","sm","md","lg","xl","2xl"],n=t.split(" ").map(Ms).filter(r=>r!==null);let s=t;if(n.length===1)return n[0].fullCls;for(const r of n){const o=r.property,i=e.indexOf(r.mq);for(let l=i+1;l<e.length;l++){const c=e[l],u=n.find(p=>p.property===o&&p.mq===c);if(u&&u.cls===r.cls)s=s.replace(u.fullCls,"");else if(u&&u.cls!==r.cls)break}}return s.replace(/\s+/g," ").trim()}const _g=j.atom(null,(t,e,{blockIds:n,newClasses:s})=>{const r=d.filter(t(In),i=>n.includes(t(i)._id)),o=d.first(t(Rn));return d.map(r,i=>{const l=t(i),c=d.get(l,o.prop,`${q.STYLES_KEY},`),{classes:u}=pe.getSplitChaiClasses(c);return{ids:[l._id],props:{[o.prop]:`${q.STYLES_KEY},${tc(nc(za.twMerge(u,s)))}`}}})}),sc=()=>{const t=j.useSetAtom(_g),{updateBlocks:e,updateBlocksRuntime:n}=Ee();return g.useCallback((s,r,o=!1)=>{const i=t({blockIds:s,newClasses:r});if(!o){n(s,i[0].props);return}e(s,i[0].props)},[t,e,n])},Tg=t=>{const e=["xs","sm","md","lg","xl","2xl"],n=e.indexOf(t);return n===-1?["xs"]:e.slice(0,n+1)},Bg=j.atom(t=>{const e=d.first(t(Rn)),n=t(vs);if(!e||e.blockId!==d.get(n,"_id",null))return[];const s=d.get(n,e.prop,`${q.STYLES_KEY},`),{classes:r}=pe.getSplitChaiClasses(s);return d.filter(d.map(r.trim().split(" "),Ms),o=>!d.isNull(o))}),Na={xs:0,sm:1,md:2,lg:3,xl:4,"2xl":5},Rg=j.atom(t=>{const e=t(zl),n=t(Mr),s=t(zi),r=Tg(e);let o=d.filter(t(Bg),{mod:n});return d.startsWith(n,"_")||(o=d.filter(o,i=>r.includes(i.mq))),o=o.sort((i,l)=>Na[i.mq]-Na[l.mq]),s||(o=d.filter(o,{dark:!1})),o}),Ds=()=>j.useAtomValue(Rg),Pg=()=>j.useAtom(Mr),Dn=t=>{const e=Ds();return d.findLast(e,{property:t})},Lg=(t,e)=>{const n={xs:0,sm:1,md:2,lg:3,xl:4,"2xl":5};return n[d.get(t,"mq","xs")]<=n[e]},Mg={width:"w-",height:"h-",minWidth:"min-w-",minHeight:"min-h-",maxWidth:"max-w-",maxHeight:"max-h-",zIndex:"z-",gap:"gap-",gapX:"gap-x-",gapY:"gap-y-",margin:"m-",marginX:"mx-",marginY:"my-",marginTop:"mt-",marginBottom:"mb-",marginLeft:"ml-",marginRight:"mr-",padding:"p-",paddingX:"px-",paddingY:"py-",paddingTop:"pt-",paddingBottom:"pb-",paddingLeft:"pl-",paddingRight:"pr-",spaceX:"space-x-",spaceY:"space-y-",border:"border-",borderTop:"border-t-",borderBottom:"border-b-",borderLeft:"border-l-",borderRight:"border-r-",borderX:"border-x-",borderY:"border-y-",borderRadius:"rounded-",borderRadiusTop:"rounded-t-",borderRadiusRight:"rounded-r-",borderRadiusBottom:"rounded-b-",borderRadiusLeft:"rounded-l-",borderRadiusTopLeft:"rounded-tl-",borderRadiusTopRight:"rounded-tr-",borderRadiusBottomRight:"rounded-br-",borderRadiusBottomLeft:"rounded-bl-",fontSize:"text-",lineHeight:"leading-",letterSpacing:"tracking-",textIndent:"indent-",rotate:"rotate-",duration:"duration-",transitionDelay:"delay-",scale:"scale-",scaleX:"scale-x-",scaleY:"scale-y-",translateX:"translate-x-",translateY:"translate-y-",skewX:"skew-x-",skewY:"skew-y-",top:"top-",bottom:"bottom-",left:"left-",right:"right-",inset:"inset-",insetX:"inset-x-",insetY:"inset-y-",opacity:"opacity-",flexBasis:"basis-"},Ea={xs:"",sm:"640px",md:"768px",lg:"1024px",xl:"1280px","2xl":"1536px"},Dg=t=>`${t.toUpperCase()} ${Ea[t]?`(${Ea[t]} & up)`:""}`,bs=t=>{const{t:e}=F.useTranslation(),{type:n="icons",label:s,property:r,onEmitChange:o=()=>{},units:i,negative:l=!1}=t,[c]=an(),[u]=Pg(),[,p]=ms(),f=Dn(r),m=sc(),h=Ao(),[x]=U(),b=g.useMemo(()=>d.get(f,"fullCls",""),[f]),y=g.useCallback((_,S=!0)=>{const A={dark:c,mq:p,mod:u,cls:_};(c||u!=="")&&(A.mq="xs");const C=Ig(A);m(x,[C],S)},[x,c,p,u,r,m]),v=g.useCallback(()=>{h(x,[b],!0)},[x,b,h]),w=g.useMemo(()=>Lg(f,p),[f,p]);g.useEffect(()=>{o(w,f)},[w,o,f]);const[,,I]=ms(),N=g.useCallback(_=>{I({xs:400,sm:640,md:800,lg:1024,xl:1420,"2xl":1920}[_])},[I]),E=d.get(f,"dark",null)===c&&d.get(f,"mod",null)===u&&d.get(f,"mq",null)===p;return a.jsx(fg,{canChange:w,canReset:f&&E,children:a.jsxs("div",{className:"group flex flex-row items-center py-2 first:pt-0 last:pb-0",children:[a.jsx("div",{className:"relative w-[70px] truncate text-xs text-foreground",children:a.jsx("span",{className:`text-[11px] ${f&&!E?"text-foreground":""}`,children:e(s)})}),a.jsxs("div",{className:"flex flex-row items-center",children:[a.jsxs("div",{className:"w-[150px]",children:[n==="arbitrary"?a.jsx(pg,{currentClass:d.get(f,"cls",""),classPrefix:d.get(Mg,r,""),units:i||[],onChange:y,negative:l,cssProperty:r}):null,n==="icons"&&a.jsx(Cg,{property:r,onChange:y}),n==="range"&&a.jsx(jg,{property:r,onChange:y}),n==="color"&&a.jsx(wg,{property:r,onChange:y}),n==="dropdown"&&a.jsx(Ql,{label:s,property:r,onChange:y})]}),a.jsx("div",{className:`w-[30px] cursor-pointer ${b?"visible":"invisible"}`,children:E?a.jsx("button",{type:"button",onClick:()=>v(),title:"Reset",className:"flex px-1.5 text-xs",children:a.jsx(k.CrossCircledIcon,{className:"h-5 w-5 text-blue-500 hover:opacity-80"})}):w&&f?a.jsxs(fe,{delayDuration:100,children:[a.jsx(he,{asChild:!0,children:a.jsx("button",{type:"button",className:"invisible ml-3 mt-1 rounded-full bg-primary text-white group-hover:visible",children:a.jsx(k.InfoCircledIcon,{})})}),a.jsx(ue,{children:a.jsx("div",{className:"text-right",children:a.jsxs("div",{children:["Current style is set at ",a.jsxs("span",{className:"font-bold",children:[Dg(d.get(f,"mq")),c&&!f.dark?"(Light mode)":""]}),a.jsx("br",{}),a.jsxs("button",{type:"button",onClick:()=>N(d.get(f,"mq")),className:"block w-full cursor-default text-right font-semibold text-blue-500",children:["Switch to ",d.get(f,"mq").toUpperCase()]})]})})})]}):null})]})]})})},Og=["px","%","em","rem","ch","vh","vw"],vr=({label:t,options:e,borderB:n=!1,borderT:s=!1,type:r="arbitrary",units:o=Og,negative:i=!1})=>{const{t:l}=F.useTranslation(),[c,u]=g.useState(e[0].key),p=Ds(),f=g.useCallback(m=>d.map(p,"property").includes(m),[p]);return a.jsxs("div",{className:`mb-2 border-border py-2 first:pt-0 last:pb-0 ${n?"border-b":""} ${s?"border-t":""}`,children:[a.jsxs("div",{className:"flex flex-row text-xs",children:[t&&a.jsx("span",{className:"relative w-[70px] flex-none text-xs text-foreground",children:l(t)}),a.jsx("div",{className:"mb-3 flex grow flex-row flex-wrap gap-x-px",children:e.map(({label:m,key:h},x)=>a.jsx("div",{className:"first:rounded-l last:rounded-r",children:a.jsxs(fe,{children:[a.jsx(he,{asChild:!0,children:a.jsxs("button",{type:"button",onClick:()=>u(h),className:`relative cursor-pointer rounded-full p-1 text-[8px] ${h===c?"bg-[#3E57F0] text-white":"text-gray-600 dark:text-gray-300"}`,children:[g.createElement("div",{className:f(h)?"-bottom-1.5 absolute bg-[#3E57F0] h-[2px] left-0 w-full":""}),g.createElement(d.get(ec,h,k.BoxIcon),{className:"text-inherit w-3 h-3"})]})}),a.jsx(ue,{children:d.startCase(d.toLower(m))})]})},`option-${x}`))})]}),a.jsx("div",{className:"mt-0 flex items-center",children:a.jsx(bs,{type:r,units:[...o],label:"",property:c,negative:i})})]})},Aa=({heading:t,items:e})=>{const{t:n}=F.useTranslation(),s=Ds(),r=g.useMemo(()=>{const o=c=>d.flatten(c.map(u=>u.styleType==="multiple"?d.map(u.options,"key"):u.property)),i=d.flatten(e.map(c=>c.styleType==="accordion"?o(c.items):c.styleType==="multiple"?d.map(c.options,"key"):c.property)),l=d.map(s,"property");return d.intersection(i,l).length>0},[s,e]);return a.jsxs("details",{children:[a.jsx("summary",{className:"my-px cursor-default rounded-md bg-gray-50 p-px px-2 text-[11px] text-foreground dark:bg-gray-800",children:a.jsxs("div",{className:"inline",children:[d.startCase(n(t.toLowerCase())),r?a.jsx("span",{className:`ml-1 mr-2 inline-block h-[8px] w-[8px] rounded-full ${r?"bg-primary":"bg-gray-300"}`}):null]})}),a.jsx("div",{className:"p-2",children:e.map(o=>o.styleType==="multiple"?a.jsx(vr,{...o},o.label):a.jsx(bs,{...o},o.label))})]})},$g=g.createContext({}),ar=({section:t,showAccordian:e})=>{const{t:n}=F.useTranslation(),s=Ds(),r=g.useCallback((i=[])=>{const l={};for(let u=0;u<s.length;u++)l[s[u].property]=s[u].cls;let c=!0;for(const u in i)if(!d.has(l,u)||l[u]!==i[u]){c=!1;break}return c},[s]),o=g.useMemo(()=>({}),[]);return a.jsx($g.Provider,{value:o,children:e?a.jsxs(So,{value:t.heading,className:"border-none",children:[a.jsx(No,{className:"border-slate-150 border-t py-2 text-xs",children:a.jsx("div",{className:"flex items-center py-2",children:a.jsx("div",{className:"flex items-center gap-x-2 text-xs font-medium",children:d.startCase(n(t.heading))})})}),a.jsx(Eo,{className:"py-2",children:t.items.map(i=>d.has(i,"component")?g.createElement(i.component,{key:i.label}):d.has(i,"styleType")?i.styleType==="multiple"?a.jsx(vr,{...i},i.label+"multiple-choices"):i.styleType==="accordion"&&r(i==null?void 0:i.conditions)?a.jsx(Aa,{...i},i.label+"nested-options"):null:a.jsx(bs,{...i},i.label+"block-style"))})]}):a.jsx("div",{className:"py-2",children:t.items.map((i,l)=>d.has(i,"component")?g.createElement(i.component,{key:i.label}):d.has(i,"styleType")?i.styleType==="multiple"?a.jsx(vr,{...i},i.label+"multiple-choices"+l):i.styleType==="accordion"&&r(i==null?void 0:i.conditions)?a.jsx(Aa,{...i},i.label+"nested-options"+l):null:a.jsx(bs,{...i},i.label+"block-style"+l))})})},rc=ys.Root,oc=ys.Trigger,Io=D.forwardRef(({className:t,align:e="center",sideOffset:n=4,...s},r)=>a.jsx(ys.Content,{ref:r,align:e,sideOffset:n,className:B.cn("z-50 w-64 origin-[--radix-hover-card-content-transform-origin] rounded-md border bg-popover p-4 text-popover-foreground shadow-md outline-none data-[state=open]:animate-in data-[state=closed]:animate-out data-[state=closed]:fade-out-0 data-[state=open]:fade-in-0 data-[state=closed]:zoom-out-95 data-[state=open]:zoom-in-95 data-[side=bottom]:slide-in-from-top-2 data-[side=left]:slide-in-from-right-2 data-[side=right]:slide-in-from-left-2 data-[side=top]:slide-in-from-bottom-2",t),...s}));Io.displayName=ys.Content.displayName;const Fg=Ne.atomWithStorage("selectedBreakpoints",["XS","MD","XL"]),zg=()=>{const[t,e]=j.useAtom(Fg);return[t,e]},Ia=({landscape:t=!1,className:e=""})=>a.jsx("svg",{className:ke.cn("h-3 w-3",t?"rotate-90":"",e),stroke:"currentColor",fill:"currentColor",strokeWidth:"0",viewBox:"0 0 448 512",xmlns:"http://www.w3.org/2000/svg",children:a.jsx("path",{d:"M400 0H48C21.5 0 0 21.5 0 48v416c0 26.5 21.5 48 48 48h352c26.5 0 48-21.5 48-48V48c0-26.5-21.5-48-48-48zM224 480c-17.7 0-32-14.3-32-32s14.3-32 32-32 32 14.3 32 32-14.3 32-32 32zm176-108c0 6.6-5.4 12-12 12H60c-6.6 0-12-5.4-12-12V60c0-6.6 5.4-12 12-12h328c6.6 0 12 5.4 12 12v312z"})}),wr=[{title:"Mobile (Base)",content:"Styles set here are applied to all screen unless edited at higher breakpoint",breakpoint:"xs",icon:a.jsx(k.MobileIcon,{className:"h-4 w-4"}),width:400},{title:"Mobile landscape (SM)",content:"Styles set here are applied at 640px and up unless edited at higher breakpoint",breakpoint:"sm",icon:a.jsx(k.MobileIcon,{className:"h-4 w-4 rotate-90"}),width:640},{title:"Tablet (MD)",content:"Styles set here are applied at 768px and up",breakpoint:"md",icon:a.jsx(Ia,{}),width:800},{title:"Tablet Landscape (LG)",content:"Styles set here are applied at 1024px and up unless edited at higher breakpoint",breakpoint:"lg",icon:a.jsx(Ia,{landscape:!0}),width:1024},{title:"Desktop (XL)",content:"Styles set here are applied at 1280px and up unless edited at higher breakpoint",breakpoint:"xl",icon:a.jsx(k.LaptopIcon,{className:"h-4 w-4"}),width:1420},{title:"Large Desktop (2XL)",content:"Styles set here are applied at 1536px and up",breakpoint:"2xl",icon:a.jsx(k.DesktopIcon,{className:"h-4 w-4"}),width:1920}],_a=({canvas:t=!1,openDelay:e=400,tooltip:n=!0,title:s,content:r,currentBreakpoint:o,breakpoint:i,width:l,icon:c,onClick:u,buttonClass:p="",activeButtonClass:f=""})=>{const{t:m}=F.useTranslation();return n?a.jsxs(rc,{openDelay:e,children:[a.jsx(oc,{asChild:!0,children:a.jsx(B.Button,{onClick:()=>u(l),size:"sm",className:ke.cn("h-7 w-7 rounded-md p-1",i===o?f:p),variant:i===o?"outline":"ghost",children:c})}),a.jsx(Io,{className:"w-fit max-w-52 border-border",children:a.jsx("div",{className:"flex justify-between space-x-4",children:a.jsxs("div",{className:"space-y-1",children:[a.jsx("h4",{className:"text-sm font-semibold",children:m(s)}),t&&a.jsx("p",{className:"text-xs",children:m(r)})]})})})]}):a.jsx(B.Button,{onClick:()=>u(l),size:"sm",className:"h-7 w-7 rounded-md p-1",variant:i===o?"outline":"ghost",children:c})},_o=({openDelay:t=400,canvas:e=!1,tooltip:n=!0,buttonClass:s="",activeButtonClass:r=""})=>{const[o,,i]=ms(),[l,c]=ho(),[u,p]=zg(),f=u,m=p,{t:h}=F.useTranslation(),x=$("breakpoints",wr),b=w=>{f.includes(w)?f.length>2&&m(f.filter(I=>I!==w)):m(I=>[...I,w])},y=w=>{e||i(w),c(w)},v=ke.getBreakpointValue(e?l:o).toLowerCase();return x.length<4?a.jsx("div",{className:"flex items-center rounded-md",children:d.map(x,w=>g.createElement(_a,{canvas:e,...w,onClick:y,key:w.breakpoint,currentBreakpoint:v}))}):a.jsxs("div",{className:"flex w-full items-center justify-between rounded-md",children:[a.jsx("div",{className:"flex items-center",children:d.map(x.filter(w=>d.includes(f,d.toUpper(w.breakpoint))),w=>g.createElement(_a,{canvas:e,openDelay:t,tooltip:n,...w,onClick:y,key:w.breakpoint,currentBreakpoint:v,buttonClass:s,activeButtonClass:r}))}),a.jsxs(tt,{children:[a.jsx(nt,{asChild:!0,children:a.jsx("span",{className:"cursor-pointer rounded-md p-1 hover:bg-background",children:a.jsx(k.ChevronDownIcon,{className:"scale-90 transform"})})}),a.jsxs(Ue,{className:"w-56 border-border text-xs",children:[a.jsx(Ua,{children:h("Screen sizes")}),a.jsx(Ar,{}),d.map(x,w=>a.jsx(Ga,{disabled:w.breakpoint==="xs",onCheckedChange:()=>b(d.toUpper(w.breakpoint)),checked:d.includes(f,d.toUpper(w.breakpoint)),onSelect:I=>I.preventDefault(),children:h(w.title)},w.breakpoint))]})]})]})};function Hg(){const[,t]=ms(),{t:e}=F.useTranslation(),n=g.useMemo(()=>{const s=wr.find(r=>r.breakpoint===t);return(s==null?void 0:s.content)??""},[t,wr]);return a.jsxs(a.Fragment,{children:[a.jsxs("div",{className:"sticky top-0 z-10 flex items-center justify-start bg-muted px-2 py-1 shadow-sm",children:[a.jsxs("p",{className:"text-xs text-muted-foreground",children:[e("Screen")," "]}),a.jsx(_o,{openDelay:1e3,tooltip:!1})]}),a.jsx("div",{className:"mb-2 flex items-center justify-between rounded-md rounded-t-none border border-border p-1",children:a.jsx("p",{className:"flex flex-1 items-center space-x-2 text-[10px] text-foreground",children:a.jsxs("span",{className:"text-xs text-foreground",children:[a.jsx("span",{className:"rounded-md bg-muted px-1 py-px text-xs font-bold uppercase text-muted-foreground",children:t==="xs"?"Base":t})," ",e(n)]})})})]})}const Vg=Sr.cva("text-sm font-medium leading-none peer-disabled:cursor-not-allowed peer-disabled:opacity-70"),ut=D.forwardRef(({className:t,...e},n)=>a.jsx(Va.Root,{ref:n,className:B.cn(Vg(),t),...e}));ut.displayName=Va.Root.displayName;const Cr=({className:t=""})=>a.jsx(k.TokensIcon,{className:t}),Wg=g.lazy(()=>Promise.resolve().then(()=>require("./manage-design-tokens-modal-BcgdwEXE.cjs")));function To({from:t="default",classFromProps:e,onAddNew:n,onRemove:s}){var Vs;const r=g.useRef(null),[o,i]=g.useState(""),[l,c]=g.useState(!1),[u,p]=g.useState(-1),f=g.useRef(!1),[m,h]=g.useState(!1),x=kg(),{t:b}=F.useTranslation(),[y]=Ae(),v=J(),w=sc(),I=Ao(),[N]=U(),[E,_]=g.useState(""),S=j.useAtomValue(en),A=(Vs=d.first(y))==null?void 0:Vs.prop,{classes:C}=pe.getSplitChaiClasses(d.get(v,A,"")),P=(t==="default"?C:e??"").split(" ").filter(z=>!d.isEmpty(z)),R=g.useMemo(()=>[...P].sort((z,le)=>{const Be=z.startsWith(q.DESIGN_TOKEN_PREFIX),ot=le.startsWith(q.DESIGN_TOKEN_PREFIX);return Be&&!ot?-1:!Be&&ot?1:0}),[P]),O=$("flags.copyPaste",!0),H=z=>{if(z.startsWith(q.DESIGN_TOKEN_PREFIX)){const le=S[z];return le?le.name:z}return z},G=z=>{const le=Object.entries(S).find(([,Be])=>Be.name===z);return le?`${le[0]}`:z},me=()=>{const z=E.trim().replace(/ +(?= )/g,"").split(" ").map(G);t==="designToken"?d.isFunction(n)&&n(z):w(N,z,!0),_("")},[ie,ne]=g.useState([]),we=$("flags.designTokens",!0),Oe=({value:z})=>{const le=z.trim().toLowerCase(),Be=le.match(/.+:/g);let ot=[],Ws=[];if(we&&(le===""?Ws=Object.entries(S).map(([pt,pn])=>({name:pn.name,id:`${pt}`,isDesignToken:!0})):Ws=Object.entries(S).filter(([,pt])=>pt.name.toLowerCase().includes(le)).map(([pt,pn])=>({name:pn.name,id:`${pt}`,isDesignToken:!0}))),Be&&Be.length>0){const[pt]=Be,pn=le.replace(pt,"");ot=x.search(pn).map(Gs=>({...Gs,item:{...Gs.item,name:pt+Gs.item.name}}))}else ot=x.search(le);const Uc=[...Ws,...d.map(ot,"item")];return ne(Uc)},W=()=>{ne([])},$e=z=>z.name,yt=z=>a.jsxs("div",{className:"flex items-center gap-2 rounded-md p-1",children:[z.isDesignToken&&a.jsx(Cr,{className:"h-4 w-4 text-gray-600"}),a.jsx("span",{children:z.name})]}),Wt=g.useMemo(()=>({ref:r,autoComplete:"off",autoCorrect:"off",autoCapitalize:"off",spellCheck:!1,placeholder:b("Enter classes separated by space"),value:E,onFocus:z=>{setTimeout(()=>{z.target&&z.target.select()},0)},onKeyDown:z=>{if(z.key==="Enter"&&E.trim()!==""){if(f.current){f.current=!1;return}z.preventDefault(),me()}if(z.key==="Tab"&&ie.length>0){z.preventDefault();const le=new KeyboardEvent("keydown",{key:"ArrowDown",code:"ArrowDown",keyCode:40,bubbles:!0});z.target.dispatchEvent(le)}},onChange:(z,{newValue:le})=>_(le),className:`w-full rounded-md text-xs px-2 hover:outline-0 bg-background border-border ${t==="default"?"py-1":"py-1.5"}`}),[E,b,r,ie.length]),kt=z=>{const le=o.trim().replace(/ +(?= )/g,"").split(" ").map(G);I(N,[z],!0),w(N,le,!0),i(""),p(-1)},vt=()=>{if(navigator.clipboard===void 0){ce.toast.error(b("Clipboard not supported"));return}navigator.clipboard.writeText(P.join(" ")),ce.toast.success(b("Classes copied to clipboard")),c(!0),setTimeout(()=>c(!1),2e3)};return a.jsxs("div",{className:`flex w-full flex-col gap-y-1.5 pb-4 ${t==="designToken"?"border-none":"border-b border-border"}`,children:[a.jsx("div",{className:"flex items-center justify-between gap-x-2",children:a.jsxs("div",{className:"flex w-full items-center justify-between gap-x-2 text-muted-foreground",children:[a.jsxs("span",{className:"flex items-center gap-x-1",children:[a.jsx("span",{children:t==="designToken"?a.jsx(ut,{className:"text-sm font-medium leading-tight text-gray-900 peer-disabled:cursor-not-allowed peer-disabled:opacity-70",children:b("Token Classes")}):b(we?"Styles":"Classes")}),O&&a.jsxs(fe,{children:[a.jsx(he,{asChild:!0,children:l?a.jsx(k.CheckIcon,{className:"rounded-full border border-green-500 bg-green-500/10 text-green-500"}):a.jsx(k.CopyIcon,{onClick:vt,className:"cursor-pointer"})}),a.jsx(ue,{children:a.jsx("p",{children:b("Copy classes to clipboard")})})]})]}),we&&t==="default"&&a.jsx(B.Button,{variant:"link",className:"underline",onClick:()=>h(!0),children:b("Design Tokens")})]})}),a.jsxs("div",{className:"relative flex items-center gap-x-3",children:[a.jsx("div",{className:"relative flex w-full items-center gap-x-3",children:a.jsx(hd,{suggestions:ie,onSuggestionsFetchRequested:Oe,onSuggestionsClearRequested:W,getSuggestionValue:$e,renderSuggestion:yt,inputProps:Wt,onSuggestionSelected:(z,{suggestionValue:le})=>{f.current=!0;const ot=[G(le)];t==="designToken"?d.isFunction(n)&&n(ot):w(N,ot,!0),_("")},containerProps:{className:"relative h-8 w-full gap-y-1 py-1 border-border text-xs"},theme:{suggestion:"bg-transparent",suggestionHighlighted:"!bg-gray-300 dark:!bg-gray-800 cursor-pointer",suggestionsContainerOpen:"absolute bg-background no-scrollbar z-50 max-h-[230px] overflow-y-auto w-full border border-border rounded-md"}})}),a.jsx(B.Button,{variant:"outline",className:`border-border ${t==="default"?"h-6":"mt-1 h-7"}`,onClick:me,disabled:E.trim()==="",size:"sm",children:a.jsx(k.PlusIcon,{})})]}),a.jsx("div",{className:"flex w-full flex-wrap gap-2 overflow-x-hidden",children:R.map((z,le)=>u===le?a.jsx("input",{ref:r,value:o,onChange:Be=>i(Be.target.value),onBlur:()=>{kt(z)},onKeyDown:Be=>{Be.key==="Enter"&&kt(z)},onFocus:Be=>{setTimeout(()=>{Be.target.select()},0)},className:"group relative flex max-w-[260px] cursor-default items-center gap-x-1 truncate break-words rounded border border-border bg-gray-200 p-px px-1.5 pr-2 text-[11px] text-gray-600 hover:border-gray-300 dark:border-gray-700 dark:bg-gray-800 dark:text-gray-300"},z):a.jsx("div",{className:"group relative flex max-w-[260px] items-center",children:a.jsxs("button",{onDoubleClick:()=>{_(H(z)),t==="default"?I(N,[z],!0):(d.isFunction(s)&&s(z),_(z)),setTimeout(()=>{r.current&&r.current.focus()},10)},className:"flex h-max cursor-default items-center gap-x-1 truncate break-words rounded bg-gray-200 py-px pl-0.5 pr-1 text-[11px] text-gray-600 dark:bg-gray-800 dark:text-gray-300",children:[a.jsxs("div",{className:"z-10 flex h-full w-max items-center justify-center",children:[a.jsx(k.Cross2Icon,{onClick:()=>{t==="default"?I(N,[z],!0):d.isFunction(s)&&s(z)},className:"hidden h-max w-3.5 cursor-pointer rounded bg-gray-100 p-0.5 text-red-500 hover:bg-gray-50 group-hover:block"}),z.startsWith(q.DESIGN_TOKEN_PREFIX)?a.jsx(Cr,{className:"text-[rgba(55, 65, 81, 0.4)] h-3.5 w-3.5 group-hover:hidden"}):a.jsxs("svg",{className:"h-3.5 w-3.5 group-hover:hidden",fill:"rgba(55, 65, 81, 0.4)",viewBox:"0 0 24 24",xmlns:"http://www.w3.org/2000/svg",xmlSpace:"preserve",children:[a.jsx("g",{id:"SVGRepo_bgCarrier",strokeWidth:"0"}),a.jsx("g",{id:"SVGRepo_tracerCarrier",strokeLinecap:"round",strokeLinejoin:"round"}),a.jsx("g",{id:"SVGRepo_iconCarrier",children:a.jsx("path",{fillRule:"evenodd",clipRule:"evenodd",d:"M12 6.036c-2.667 0-4.333 1.325-5 3.976 1-1.325 2.167-1.822 3.5-1.491.761.189 1.305.738 1.906 1.345C13.387 10.855 14.522 12 17 12c2.667 0 4.333-1.325 5-3.976-1 1.325-2.166 1.822-3.5 1.491-.761-.189-1.305-.738-1.907-1.345-.98-.99-2.114-2.134-4.593-2.134zM7 12c-2.667 0-4.333 1.325-5 3.976 1-1.326 2.167-1.822 3.5-1.491.761.189 1.305.738 1.907 1.345.98.989 2.115 2.134 4.594 2.134 2.667 0 4.333-1.325 5-3.976-1 1.325-2.167 1.822-3.5 1.491-.761-.189-1.305-.738-1.906-1.345C10.613 13.145 9.478 12 7 12z"})})]})]}),a.jsx("div",{children:H(z)})]})},z))}),a.jsx(g.Suspense,{fallback:null,children:a.jsx(Wg,{open:m,onOpenChange:h})})]})}const je=["px","%","em","rem","ch","vh","vw"],Gg={heading:"flex.heading",items:[{type:"arbitrary",label:"flex.basis",units:je,property:"flexBasis"},{type:"range",label:"flex.order",property:"order"},{type:"dropdown",label:"flex.flex",property:"flexGrowShrink"},{type:"dropdown",label:"flex.grow",property:"flexGrow"},{type:"dropdown",label:"flex.shrink",property:"flexShrink"}]},Ug={heading:"grid.heading",items:[{type:"range",label:"grid.col_span",property:"gridColSpan"},{type:"range",label:"grid.col_start",property:"gridColStart"},{type:"range",label:"grid.col_end",property:"gridColEnd"},{type:"range",label:"grid.row_span",property:"gridRowSpan"},{type:"range",label:"grid.row_start",property:"gridRowStart"},{type:"range",label:"grid.row_end",property:"gridRowEnd"},{type:"range",label:"grid.order",property:"order"}]},qg=[{heading:"Styles",items:[{component:To},{component:Hg},{type:"arbitrary",label:"layout.width",units:je.concat("auto"),property:"width"},{type:"arbitrary",label:"layout.height",units:je.concat("auto"),property:"height"},{styleType:"multiple",label:"layout.margin",negative:!0,units:[...je,"auto"],options:[{key:"margin",label:"layout.margin_all"},{key:"marginX",label:"layout.margin_lr"},{key:"marginY",label:"layout.margin_tb"},{key:"marginTop",label:"layout.margin_top"},{key:"marginRight",label:"layout.margin_right"},{key:"marginBottom",label:"layout.margin_bottom"},{key:"marginLeft",label:"layout.margin_left"}]},{styleType:"multiple",label:"layout.padding",options:[{key:"padding",label:"layout.padding_all"},{key:"paddingX",label:"layout.padding_lr"},{key:"paddingY",label:"layout.padding_tb"},{key:"paddingTop",label:"layout.padding_top"},{key:"paddingRight",label:"layout.padding_right"},{key:"paddingBottom",label:"layout.padding_bottom"},{key:"paddingLeft",label:"layout.padding_left"}]},{styleType:"accordion",heading:"typography.heading",items:[{type:"dropdown",property:"textAlign",label:"typography.align"},{type:"dropdown",property:"fontFamily",label:"typography.font"},{type:"arbitrary",property:"fontSize",label:"typography.size",units:je},{type:"arbitrary",property:"lineHeight",label:"typography.height",units:je.concat("-")},{type:"range",property:"fontWeight",label:"typography.weight"},{type:"color",property:"textColor",label:"typography.color"}]},{styleType:"accordion",heading:"background.heading",items:[{type:"color",label:"background.bgcolor",property:"backgroundColor"},{type:"dropdown",label:"background.attachment",property:"backgroundAttachment"},{type:"dropdown",label:"background.clipping",property:"backgroundClip"},{type:"dropdown",label:"background.origin",property:"backgroundOrigin"},{type:"dropdown",label:"background.position",property:"backgroundPosition"},{type:"dropdown",label:"background.repeat",property:"backgroundRepeat"},{type:"dropdown",label:"background.size",property:"backgroundSize"}]}]}];je.concat("auto"),je.concat("auto"),[...je],je.concat("auto"),je.concat("auto"),je.concat("auto"),je.concat("auto"),je.concat("-");const Kg={px:1,"%":1,em:100,rem:100,ch:1,vw:1,vh:1,"-":1,deg:1,ms:.1};function jr(){const{flexChild:t,gridChild:e}=Fd(),[n]=Ae(),[s,r]=g.useState(""),[o,i]=g.useState({onDrag:u=>u,onDragEnd:u=>u,dragStartY:0,dragging:!1,dragStartValue:0,dragUnit:"",negative:!1,cssProperty:""}),l=ve.useThrottledCallback(u=>{const p=!d.get(o,"negative",!1),f=d.get(o,"cssProperty","");let m=parseFloat(o.dragStartValue);m=isNaN(m)?0:m;let h=Kg[o.dragUnit];(d.startsWith(f,"scale")||f==="opacity")&&(h=10);let b=(o.dragStartY-u.pageY)/h+m;p&&b<0&&(b=0),f==="opacity"&&b>1&&(b=1),o.onDrag(`${b}`),r(`${b}`)},[o],50),c=g.useCallback(()=>{setTimeout(()=>o.onDragEnd(`${s}`),100),i({onDrag:u=>u,onDragEnd:u=>u,dragStartY:0,dragging:!1,dragStartValue:0,dragUnit:"",negative:!1,cssProperty:""})},[o,s,i]);return d.isEmpty(n)?null:a.jsxs(Jl.Provider,{value:{setDragData:i},children:[o.dragging?a.jsx("div",{onMouseMove:l,onMouseUp:()=>c(),className:"absolute inset-0 z-30 cursor-row-resize bg-gray-300/10"}):null,a.jsxs("div",{className:"flex flex-col",children:[a.jsx(ig,{}),a.jsxs(Yl,{defaultValue:["Styles"],type:"multiple",className:"w-full",children:[t&&a.jsx(ar,{section:Gg,showAccordian:t||e}),e&&a.jsx(ar,{section:Ug,showAccordian:t||e}),qg.map(u=>a.jsx(ar,{section:u,showAccordian:t||e},u.heading))]})]})]})}const An=D.forwardRef(({className:t,children:e,...n},s)=>a.jsxs(It.Root,{ref:s,className:B.cn("relative overflow-hidden",t),...n,children:[a.jsx(It.Viewport,{className:"h-full w-full rounded-[inherit]",children:e}),a.jsx(ac,{}),a.jsx(It.Corner,{})]}));An.displayName=It.Root.displayName;const ac=D.forwardRef(({className:t,orientation:e="vertical",...n},s)=>a.jsx(It.ScrollAreaScrollbar,{ref:s,orientation:e,className:B.cn("flex touch-none select-none transition-colors",e==="vertical"&&"h-full w-2.5 border-l border-l-transparent p-[1px]",e==="horizontal"&&"h-2.5 flex-col border-t border-t-transparent p-[1px]",t),...n,children:a.jsx(It.ScrollAreaThumb,{className:"relative flex-1 rounded-full bg-border"})}));ac.displayName=It.ScrollAreaScrollbar.displayName;const Os=$t.Root,On=D.forwardRef(({className:t,...e},n)=>a.jsx($t.List,{ref:n,className:B.cn("inline-flex h-9 items-center justify-center rounded-lg bg-muted p-1 text-muted-foreground",t),...e}));On.displayName=$t.List.displayName;const He=D.forwardRef(({className:t,...e},n)=>a.jsx($t.Trigger,{ref:n,className:B.cn("inline-flex items-center justify-center whitespace-nowrap rounded-md px-3 py-1 text-sm font-medium ring-offset-background transition-all focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-ring focus-visible:ring-offset-2 disabled:pointer-events-none disabled:opacity-50 data-[state=active]:bg-background data-[state=active]:text-foreground data-[state=active]:shadow",t),...e}));He.displayName=$t.Trigger.displayName;const ct=D.forwardRef(({className:t,...e},n)=>a.jsx($t.Content,{ref:n,className:B.cn("mt-2 ring-offset-background focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-ring focus-visible:ring-offset-2",t),...e}));ct.displayName=$t.Content.displayName;const Yg=({block:t,disabled:e,parentId:n,position:s})=>{const{type:r,icon:o,label:i,disabledReason:l}=t,c=e||t.disabled,{addCoreBlock:u,addPredefinedBlock:p}=xt(),f=()=>{if(d.has(t,"blocks")){const y=d.isFunction(t.blocks)?t.blocks():t.blocks;p(K.syncBlocksWithDefaultProps(y),n||null,s)}else u(t,n||null,s);re.publish(Y.CLOSE_ADD_BLOCK)},m=Ye(),{t:h}=F.useTranslation(),{onDragStart:x,onDragEnd:b}=on();return a.jsx(a.Fragment,{children:a.jsxs(fe,{children:[a.jsx(he,{asChild:!0,children:a.jsxs("button",{disabled:c,onClick:f,type:"button",onDragStart:y=>!c&&x(y,{...t,label:i,icon:o}),onDragEnd:b,draggable:m&&!c,className:`${d.kebabCase(`chai-block-${r}`)} ${m&&!c?"cursor-grab active:cursor-grabbing":"cursor-pointer"} space-y-2 rounded-lg border border-border p-3 text-center hover:bg-slate-300/50 disabled:cursor-not-allowed disabled:bg-gray-100 disabled:text-gray-400 dark:border-gray-700 dark:text-white dark:hover:bg-slate-800/50 dark:disabled:bg-gray-900 dark:disabled:text-foreground ${c?"opacity-50":""}`,children:[g.createElement(o||k.BoxIcon,{className:"w-4 h-4 mx-auto","data-add-core-block-icon":r}),a.jsx("p",{className:"truncate text-xs",children:d.capitalize(h(i||r))})]})}),a.jsx(ue,{children:a.jsx("p",{children:c&&l?l:h(i||r)})})]})})},ic=({parentId:t,position:e,gridCols:n="grid-cols-2",disableBlockGroupsSidebar:s=!1})=>{const r=K.useRegisteredChaiBlocks(),o=d.groupBy(r,"category"),i=d.uniq(d.map(o.core,"group"));return a.jsx(bc,{gridCols:n,parentId:t,position:e,groups:i,blocks:o.core,disableBlockGroupsSidebar:s})},Bo=D.forwardRef(({className:t,...e},n)=>a.jsx("div",{ref:n,className:B.cn("rounded-xl border bg-card text-card-foreground shadow",t),...e}));Bo.displayName="Card";const Ro=D.forwardRef(({className:t,...e},n)=>a.jsx("div",{ref:n,className:B.cn("flex flex-col space-y-1.5 p-6",t),...e}));Ro.displayName="CardHeader";const lc=D.forwardRef(({className:t,...e},n)=>a.jsx("div",{ref:n,className:B.cn("font-semibold leading-none tracking-tight",t),...e}));lc.displayName="CardTitle";const cc=D.forwardRef(({className:t,...e},n)=>a.jsx("div",{ref:n,className:B.cn("text-sm text-muted-foreground",t),...e}));cc.displayName="CardDescription";const Po=D.forwardRef(({className:t,...e},n)=>a.jsx("div",{ref:n,className:B.cn("p-6 pt-0",t),...e}));Po.displayName="CardContent";const Lo=D.forwardRef(({className:t,...e},n)=>a.jsx("div",{ref:n,className:B.cn("flex items-center p-6 pt-0",t),...e}));Lo.displayName="CardFooter";const $n=D.forwardRef(({className:t,...e},n)=>a.jsx("textarea",{className:B.cn("flex min-h-[60px] w-full rounded-md border border-input bg-transparent px-3 py-2 text-base shadow-sm placeholder:text-muted-foreground focus-visible:outline-none focus-visible:ring-1 focus-visible:ring-ring disabled:cursor-not-allowed disabled:opacity-50 md:text-sm",t),ref:n,...e}));$n.displayName="Textarea";const dc=({parentId:t,position:e,fromSidebar:n})=>{const{t:s}=F.useTranslation(),[r,o]=g.useState(""),{addPredefinedBlock:i}=xt(),[l,c]=g.useState(!1),u=async()=>{c(!0);const p=await B.getPreImportHTML(r),f=pe.getBlocksFromHTML(p);i([...f],t,e),o(""),c(!1),re.publish(Y.CLOSE_ADD_BLOCK)};return a.jsxs(Bo,{className:`border-border/0 p-0 shadow-none ${n?"w-full":"max-w-full"}`,children:[a.jsx(Ro,{className:n?"p-0":"p-3",children:a.jsx(cc,{className:n?"text-xs":"",children:s("Use HTML snippets from Tailwind CSS component libraries")})}),a.jsx(Po,{className:`space-y-2 py-0 ${n?"p-0":"px-3"}`,children:a.jsxs("div",{className:"space-y-1",children:[a.jsx(ut,{htmlFor:"current",className:"text-sm",children:s("Tailwind HTML snippet")}),a.jsx($n,{onChange:p=>o(p.target.value),rows:12,value:r,placeholder:s("Enter your code snippet here"),className:"resize-none overflow-x-auto whitespace-pre bg-background font-mono text-xs font-normal"})]})}),a.jsx(Lo,{className:"flex flex-col justify-end p-3",children:a.jsx(B.Button,{disabled:r.trim()===""||l,onClick:()=>u(),size:"sm",className:"w-fit",children:l?a.jsxs(a.Fragment,{children:[a.jsx(k.CircleIcon,{className:"mr-2 h-4 w-4 animate-spin"})," ",s("Importing...")]}):s("Import HTML")})})]})},$s=ge.Root,Mo=ge.Value,Fn=D.forwardRef(({className:t,children:e,...n},s)=>a.jsxs(ge.Trigger,{ref:s,className:B.cn("flex h-9 w-full items-center justify-between whitespace-nowrap rounded-md border border-input bg-transparent px-3 py-2 text-sm shadow-sm ring-offset-background focus:outline-none focus:ring-1 focus:ring-ring disabled:cursor-not-allowed disabled:opacity-50 data-[placeholder]:text-muted-foreground [&>span]:line-clamp-1",t),...n,children:[e,a.jsx(ge.Icon,{asChild:!0,children:a.jsx(k.ChevronDownIcon,{className:"h-4 w-4 opacity-50"})})]}));Fn.displayName=ge.Trigger.displayName;const uc=D.forwardRef(({className:t,...e},n)=>a.jsx(ge.ScrollUpButton,{ref:n,className:B.cn("flex cursor-default items-center justify-center py-1",t),...e,children:a.jsx(k.ChevronUpIcon,{className:"h-4 w-4"})}));uc.displayName=ge.ScrollUpButton.displayName;const pc=D.forwardRef(({className:t,...e},n)=>a.jsx(ge.ScrollDownButton,{ref:n,className:B.cn("flex cursor-default items-center justify-center py-1",t),...e,children:a.jsx(k.ChevronDownIcon,{className:"h-4 w-4"})}));pc.displayName=ge.ScrollDownButton.displayName;const zn=D.forwardRef(({className:t,children:e,position:n="popper",...s},r)=>a.jsx(ge.Portal,{children:a.jsxs(ge.Content,{ref:r,className:B.cn("relative z-50 max-h-[--radix-select-content-available-height] min-w-[8rem] origin-[--radix-select-content-transform-origin] overflow-y-auto overflow-x-hidden rounded-md border bg-popover text-popover-foreground shadow-md data-[state=open]:animate-in data-[state=closed]:animate-out data-[state=closed]:fade-out-0 data-[state=open]:fade-in-0 data-[state=closed]:zoom-out-95 data-[state=open]:zoom-in-95 data-[side=bottom]:slide-in-from-top-2 data-[side=left]:slide-in-from-right-2 data-[side=right]:slide-in-from-left-2 data-[side=top]:slide-in-from-bottom-2",n==="popper"&&"data-[side=bottom]:translate-y-1 data-[side=left]:-translate-x-1 data-[side=right]:translate-x-1 data-[side=top]:-translate-y-1",t),position:n,...s,children:[a.jsx(uc,{}),a.jsx(ge.Viewport,{className:B.cn("p-1",n==="popper"&&"h-[var(--radix-select-trigger-height)] w-full min-w-[var(--radix-select-trigger-width)]"),children:e}),a.jsx(pc,{})]})}));zn.displayName=ge.Content.displayName;const Xg=D.forwardRef(({className:t,...e},n)=>a.jsx(ge.Label,{ref:n,className:B.cn("px-2 py-1.5 text-sm font-semibold",t),...e}));Xg.displayName=ge.Label.displayName;const Hn=D.forwardRef(({className:t,children:e,...n},s)=>a.jsxs(ge.Item,{ref:s,className:B.cn("relative flex w-full cursor-default select-none items-center rounded-sm py-1.5 pl-2 pr-8 text-sm outline-none focus:bg-accent focus:text-accent-foreground data-[disabled]:pointer-events-none data-[disabled]:opacity-50",t),...n,children:[a.jsx("span",{className:"absolute right-2 flex h-3.5 w-3.5 items-center justify-center",children:a.jsx(ge.ItemIndicator,{children:a.jsx(k.CheckIcon,{className:"h-4 w-4"})})}),a.jsx(ge.ItemText,{children:e})]}));Hn.displayName=ge.Item.displayName;const Jg=D.forwardRef(({className:t,...e},n)=>a.jsx(ge.Separator,{ref:n,className:B.cn("-mx-1 my-1 h-px bg-muted",t),...e}));Jg.displayName=ge.Separator.displayName;const Zg=({defaultValue:t="",onValueChange:e,options:n,placeholder:s="Select",className:r="",height:o=""})=>{const[i,l]=g.useState(t),c=u=>{const p=u.target.value;l(p),e(p)};return a.jsx("div",{className:ke.cn("relative inline-block w-full",r),children:a.jsxs("select",{className:ke.cn("mt-1 flex w-full rounded-md border border-border bg-background px-3 py-1 text-sm text-foreground shadow-sm transition-colors file:border-0 file:bg-transparent file:text-sm file:font-medium placeholder:text-muted-foreground focus-visible:outline-none focus-visible:ring-1 focus-visible:ring-ring disabled:cursor-not-allowed disabled:opacity-50",o),value:i,onChange:c,children:[a.jsx("option",{value:"",disabled:!0,children:s}),n.map(u=>a.jsx("option",{value:u.value,children:u.label},u.value))]})})};function Qg({uiLibraries:t,library:e,setLibrary:n}){const{t:s}=F.useTranslation();return e?a.jsxs("div",{className:"h-12",children:[a.jsx("p",{className:"text-xs font-bold text-gray-500",children:s("Choose library")}),a.jsx(Zg,{className:"mb-1",options:t.map(r=>({value:r.id,label:r.name})),defaultValue:e,onValueChange:r=>n(r)})]}):null}const fc=j.atom({}),hc=t=>{const[e,n]=j.useAtom(fc),s=g.useMemo(()=>(t==null?void 0:t.getBlocksList)||(()=>[]),[t]),r=d.get(e,`${t==null?void 0:t.id}.blocks`,null),o=d.get(e,`${t==null?void 0:t.id}.loading`,"idle"),i=d.get(e,`${t==null?void 0:t.id}.error`,!1),l=g.useRef("idle");g.useEffect(()=>{(async()=>{if(t&&!(o==="complete"||l.current==="loading")){l.current="loading",n(u=>({...u,[t==null?void 0:t.id]:{loading:"loading",blocks:[],error:!1}}));try{const u=await s(t);l.current="idle",n(p=>({...p,[t==null?void 0:t.id]:{loading:"complete",blocks:u||[],error:!1}}))}catch{l.current="idle",n(u=>({...u,[t==null?void 0:t.id]:{loading:"complete",blocks:[],error:!0}}))}}})()},[t,r,o,l,n,s]);const c=g.useCallback(u=>{n(p=>({...p,[u]:{loading:"idle",blocks:[],error:!1}}))},[n]);return{data:r||[],isLoading:o==="loading",isError:i,resetLibrary:c}},ex=()=>j.useAtom(qr),mc=({block:t,html:e,blocks:n,children:s,onDragStart:r,onDragEnd:o,draggable:i,className:l="",type:c="Box"})=>{const{onDragStart:u,onDragEnd:p}=on(),f=Ye(),[,m]=U(),{clearHighlight:h}=rt(),x=i!==void 0?i:f,b=async v=>{try{if(r){r(v);return}let w=null;if(c==="Image"){if(!(t!=null&&t.image))return;w={type:"Image",blocks:[{_type:"Image",styles:"#styles:,w-full h-full object-cover",image:t==null?void 0:t.image,alt:(t==null?void 0:t.alt)||"",_name:(t==null?void 0:t.name)||"Image"}]}}else if(e){const I=typeof e=="function"?await e():e,N=pe.getBlocksFromHTML(I);if(d.isEmpty(N))return;w={type:"Box",blocks:N,name:d.get(N,"0._type","Block")}}else if(n){const I=typeof n=="function"?await n():n;if(d.isEmpty(I))return;w={type:"Box",blocks:I,name:d.get(I,"0._type","Block")}}else if(t){const I=typeof t=="function"?await t():t;w=typeof I=="object"?d.omit(I,["component","icon"]):I}if(!w)return;u(v,w,!0),setTimeout(()=>{m([]),h()},200)}catch(w){console.error("Error in ChaiDraggableBlock drag start:",w)}},y=v=>{o?o(v):p()};return a.jsx("div",{draggable:x,onDragStart:b,onDragEnd:y,className:`${x?"cursor-grab active:cursor-grabbing":""} ${l}`.trim(),children:s})};function gc({value:t,setValue:e}){const{t:n}=F.useTranslation();return a.jsx("div",{className:"flex py-2",children:a.jsxs("div",{className:"relative flex w-full max-w-md items-center rounded border px-2",children:[a.jsxs("div",{className:"flex w-full items-center gap-x-2",children:[a.jsx(k.MagnifyingGlassIcon,{className:"h-5 w-5 flex-shrink-0 stroke-[1px] text-muted-foreground"}),a.jsx(B.Input,{placeholder:n("Search blocks..."),value:t,onChange:s=>e(s.target.value),className:"w-full flex-1 border-none p-0 leading-tight outline-none"})]}),t&&a.jsx("button",{onClick:()=>e(""),className:"absolute right-2.5 top-2.5 text-muted-foreground hover:text-foreground",children:a.jsx(k.Cross1Icon,{className:"h-3.5 w-3.5"})})]})})}const Ta=({block:t,library:e,parentId:n=void 0,position:s=-1})=>{const[r,o]=g.useState(!1),i=g.useMemo(()=>(e==null?void 0:e.getBlock)||(()=>[]),[e]),{addCoreBlock:l,addPredefinedBlock:c}=xt(),u=d.get(t,"name",d.get(t,"label")),p=d.get(t,"description",""),{onDragStart:f,onDragEnd:m}=on(),h=Ye(),x=g.useCallback(async y=>{if(y.stopPropagation(),d.has(t,"component")){l(t,n,s),re.publish(Y.CLOSE_ADD_BLOCK);return}o(!0);let v=await i({library:e,block:t});typeof v=="string"&&(v=pe.getBlocksFromHTML(v)),d.isEmpty(v)||c(K.syncBlocksWithDefaultProps(v),n,s),re.publish(Y.CLOSE_ADD_BLOCK),setTimeout(()=>o(!1),1e3)},[l,c,t,i,e,n,s]),b=async y=>{if(!h)return;let v=await i({library:e,block:t});typeof v=="string"&&(v=pe.getBlocksFromHTML(v)),f(y,{type:"Box",blocks:v,name:u},!0)};return a.jsxs(fe,{children:[a.jsx(he,{asChild:!0,children:a.jsx(mc,{draggable:h,onDragStart:b,onDragEnd:m,children:a.jsxs("div",{onClick:r?()=>{}:x,className:Fa("relative mt-2 overflow-hidden rounded-md border border-border duration-200 hover:border-blue-500 hover:shadow-xl",h?"":"cursor-pointer"),children:[r&&a.jsxs("div",{className:"absolute flex h-full w-full items-center justify-center bg-black/70",children:[a.jsx(k.ReloadIcon,{className:"h-4 w-4 animate-spin text-white"}),a.jsx("span",{className:"pl-2 text-sm text-white",children:"Adding..."})]}),t.preview?a.jsx("img",{src:t.preview,className:"min-h-[45px] w-full rounded-md",alt:u}):a.jsxs("div",{className:"flex h-fit w-full flex-col items-center justify-center gap-1 rounded-md border border-border p-6 py-10 text-center",children:[a.jsx("p",{className:"font-medium text-gray-800",children:u}),p&&a.jsx("p",{className:"text-sm text-gray-600",children:p})]})]})})}),a.jsx(ue,{children:a.jsx("div",{className:"max-w-xs",children:a.jsx("p",{className:"font-medium",children:u})})})]})},tx=({parentId:t,position:e,fromSidebar:n})=>{const[s,r]=ex(),o=B.useChaiLibraries(),i=o.find(R=>R.id===s)||d.first(o),{data:l,isLoading:c,isError:u,resetLibrary:p}=hc(i),[f,m]=g.useState(""),[h,x]=g.useState([]),b=g.useRef(null);g.useEffect(()=>{l&&Array.isArray(l)&&l.length>0&&(b.current=new Ha(l,{keys:["name","label","description","group"],threshold:.4,ignoreLocation:!0}))},[l]),g.useEffect(()=>{if(!f.trim()||!b.current){x([]);return}const R=b.current.search(f).map(O=>O.item);x(R)},[f]);const y=f.trim()&&!d.isEmpty(h)?h:l||[],v=d.groupBy(y,"group"),[w,I]=g.useState(null);g.useEffect(()=>{if(d.isEmpty(d.keys(v))){I(null);return}if(!w||!v[w]){I(d.first(d.keys(v))||null);return}},[v,w]);const N=d.get(v,w||"",[]),E=g.useRef(null),{t:_}=F.useTranslation(),S=g.useRef(null);g.useEffect(()=>{var O;const R=(O=S.current)==null?void 0:O.querySelector("[data-radix-scroll-area-viewport]");R&&R.scrollTo({top:0,behavior:"smooth"})},[i,w]);const A=R=>{E.current&&(clearTimeout(E.current),E.current=null),E.current=setTimeout(()=>{E.current&&I(R)},400)},C=()=>{i!=null&&i.id&&p(i.id)};if(c)return a.jsxs("div",{className:"mt-4 grid h-full w-full grid-cols-12 gap-2",children:[a.jsx(Lt,{className:"col-span-3 h-full"}),a.jsx(Lt,{className:"col-span-9 h-full"})]});const T=d.filter(N,(R,O)=>O%2===0),P=d.filter(N,(R,O)=>O%2===1);return a.jsx(a.Fragment,{children:a.jsxs("div",{className:"flex h-full max-h-full flex-col",children:[a.jsx(gc,{value:f,setValue:m}),a.jsx("div",{className:"relative flex h-full max-h-full flex-1 overflow-hidden bg-background",children:a.jsxs("div",{className:`flex h-full flex-1 pt-2 ${n?"flex-col":""}`,children:[a.jsxs("div",{className:`flex max-h-full min-w-60 flex-col gap-1 ${n?"pb-2":"w-60 max-w-60 px-1 pr-2"}`,children:[a.jsx(Qg,{library:i==null?void 0:i.id,setLibrary:r,uiLibraries:o}),a.jsxs("div",{className:"mt-2 flex h-full max-h-full w-full flex-1 flex-col",children:[a.jsx("span",{className:"text-xs font-bold text-gray-500",children:_("Groups")}),!n&&a.jsx("hr",{className:"mt-1 border-border"}),a.jsx("div",{className:`no-scrollbar mt-2 h-full max-h-full flex-1 overflow-y-auto ${n?"":"pb-20"}`,children:d.isEmpty(v)?a.jsx("div",{className:"mt-4 flex flex-col items-center justify-center gap-3 p-4 text-center",children:f?a.jsx("p",{className:"text-sm",children:_("No matching blocks found")}):u?a.jsxs(a.Fragment,{children:[a.jsx("p",{className:"text-sm",children:_("Failed to load the UI library. Try again")}),a.jsxs(B.Button,{onClick:C,variant:"outline",size:"sm",className:"gap-2",children:[a.jsx(k.ReloadIcon,{className:"h-4 w-4"}),_("Retry")]})]}):a.jsx("p",{className:"text-sm",children:_("This library is empty")})}):n?a.jsxs($s,{value:w??"",onValueChange:I,children:[a.jsx(Fn,{className:"w-full",children:a.jsx(Mo,{placeholder:_("Select a group")})}),a.jsx(zn,{children:d.map(v,(R,O)=>a.jsx(Hn,{value:O,children:d.capitalize(_(O.toLowerCase()))},O))})]}):d.map(v,(R,O)=>a.jsxs("div",{onMouseEnter:()=>A(O),onMouseLeave:()=>E.current&&clearTimeout(E.current),role:"button",onClick:()=>I(O),className:B.cn("flex w-full cursor-pointer items-center justify-between rounded-md p-2 text-sm text-foreground transition-all ease-in-out hover:bg-gray-200 dark:hover:bg-gray-800",O===w?"bg-primary text-primary-foreground hover:bg-primary/80":""),children:[a.jsx("span",{children:d.capitalize(_(O.toLowerCase()))}),a.jsx(k.CaretRightIcon,{className:"ml-2 h-5 w-5"})]},O))})]})]}),a.jsx("div",{className:`flex h-full max-h-full w-full flex-col border-border ${n?"":"border-l"}`,children:a.jsxs(An,{ref:S,onMouseEnter:()=>E.current&&clearTimeout(E.current),className:"z-10 flex h-full max-h-full w-full flex-col gap-2 transition-all ease-linear",children:[d.isEmpty(N)&&!d.isEmpty(v)?a.jsx("div",{className:"flex h-full flex-col items-center justify-center p-6 text-center",children:a.jsx("p",{className:"text-sm",children:_("No blocks found in this group")})}):a.jsxs("div",{className:`grid w-full gap-2 ${n?"grid-cols-1 pb-20":"grid-cols-2 px-2"}`,children:[a.jsx("div",{className:"flex flex-col gap-1",children:T.map((R,O)=>a.jsx(Ta,{parentId:t,position:e,block:R,library:i},`block-${O}`))}),a.jsx("div",{className:"flex flex-col gap-1",children:P.map((R,O)=>a.jsx(Ta,{parentId:t,position:e,block:R,library:i},`block-second-${O}`))})]}),a.jsx("br",{}),a.jsx("br",{}),a.jsx("br",{})]})})]})})]})})},xc=({parentId:t,position:e,fromSidebar:n})=>a.jsx(tx,{parentId:t,position:e,fromSidebar:n}),nx=j.atom({blocks:[],groups:[],isLoading:!0,error:null}),sx=j.atom(!1),Ba=t=>{if(!t)return"";let e=t.replace(/[-_]/g," ");return e=e.replace(/([a-z])([A-Z])/g,"$1 $2"),e.split(" ").map(n=>n.charAt(0).toUpperCase()+n.slice(1).toLowerCase()).join(" ")},rx=({parentId:t,position:e,gridCols:n="grid-cols-2",disableBlockGroupsSidebar:s=!1})=>{const{data:r,isLoading:o,refetch:i,error:l}=yi(),[c,u]=j.useAtom(nx),[p,f]=j.useAtom(sx),m=bi();g.useEffect(()=>{if(!p||Object.keys(c.blocks).length===0)if(l)u({blocks:[],groups:[],isLoading:!1,error:l}),f(!0);else if(!o&&Object.keys(r||{}).length>0){const b=Object.entries(r).map(([v,w])=>{const I=w,N=I.type||"partial",E=Ba(N);return{type:"PartialBlock",label:Ba(I.name||v),description:I.description||"",icon:k.FrameIcon,group:E,category:"partial",partialBlockId:v,_name:I.name}}),y=d.uniq(d.map(b,"group"));u({blocks:b,groups:y,isLoading:!1,error:null}),f(!0)}else o?u(b=>({...b,isLoading:!0,error:null})):!o&&Object.keys(r||{}).length===0&&(u({blocks:[],groups:[],isLoading:!1,error:"No partial blocks available"}),f(!0))},[o,r,p,f,u,c.blocks,l]);const h=()=>{u(b=>({...b,isLoading:!0,error:null})),f(!1),i()},x=g.useMemo(()=>c.blocks.map(b=>{const{canAdd:y,reason:v}=m(b.partialBlockId);return{...b,disabled:!y,disabledReason:v}}),[c.blocks,m]);return c.isLoading?a.jsx("div",{className:"flex items-center justify-center p-8 text-center text-muted-foreground",children:"Loading partial blocks..."}):c.error||c.blocks.length===0?a.jsxs("div",{className:"flex flex-col items-center justify-center gap-4 p-8 text-center text-muted-foreground",children:[a.jsx("p",{children:c.error||"No partial blocks available"}),a.jsx("button",{onClick:h,className:"rounded-md bg-primary px-3 py-1 text-sm text-primary-foreground hover:bg-primary/90",children:"Refresh"})]}):a.jsx(bc,{gridCols:n,parentId:t,position:e,groups:c.groups,blocks:x,disableBlockGroupsSidebar:s})},Ra=["basic","typography","media","layout","form","advanced","other"],bc=({groups:t,blocks:e,parentId:n,position:s,gridCols:r="grid-cols-4",disableBlockGroupsSidebar:o})=>{var P;const{t:i}=F.useTranslation(),[l]=Z(),[c,u]=g.useState(""),p=g.useRef(null),[f]=j.useAtom(yc),m=(P=d.find(l,R=>R._id===n))==null?void 0:P._type,[h,x]=g.useState("all"),[b,y]=g.useState(null),v=g.useRef(null),w=$("flags.dragAndDrop",!0);g.useEffect(()=>{const R=setTimeout(()=>{var O;(O=p.current)==null||O.focus()},0);return()=>clearTimeout(R)},[f]),g.useEffect(()=>{c&&(x("all"),y(null))},[c]),g.useEffect(()=>(v.current=d.debounce(R=>{x(R)},500),()=>{v.current&&v.current.cancel()}),[]);const I=g.useCallback(R=>{y(R),v.current&&v.current(R)},[]),N=g.useCallback(()=>{y(null),v.current&&v.current.cancel()},[]),E=g.useCallback(R=>{v.current&&v.current.cancel(),x(R),y(null)},[]),_=g.useMemo(()=>c?d.values(e).filter(R=>{var O,H;return(((O=R.label)==null?void 0:O.toLowerCase())+" "+((H=R.type)==null?void 0:H.toLowerCase())).includes(c.toLowerCase())}):e,[e,c]),S=g.useMemo(()=>c?t.filter(R=>d.reject(d.filter(d.values(_),{group:R}),{hidden:!0}).length>0):t.filter(R=>d.reject(d.filter(d.values(e),{group:R}),{hidden:!0}).length>0),[e,_,t,c]),A=g.useMemo(()=>d.sortBy(S,R=>Ra.indexOf(R)===-1?99:Ra.indexOf(R)),[S]),C=g.useMemo(()=>h==="all"?_:d.filter(d.values(_),{group:h}),[_,h]),T=g.useMemo(()=>h==="all"?A:[h],[A,h]);return a.jsxs("div",{className:"mx-auto flex h-full w-full flex-col",children:[a.jsx(gc,{value:c,setValue:u}),a.jsxs("div",{className:"sticky top-10 flex h-[calc(100%-48px)] overflow-hidden pt-2",children:[!o&&A.length>0&&a.jsx("div",{className:"w-1/4 min-w-[120px] border-r border-border",children:a.jsx(An,{className:"h-full",children:a.jsxs("div",{className:"space-y-1",children:[a.jsx("button",{onClick:()=>E("all"),onMouseEnter:()=>I("all"),onMouseLeave:N,className:`w-full rounded-md px-2 py-1.5 text-left text-sm font-medium ${h==="all"||b==="all"?"bg-primary text-primary-foreground":"hover:bg-primary/50 hover:text-primary-foreground"}`,children:i("All")},"sidebar-all"),A.map(R=>a.jsx("button",{onClick:()=>E(R),onMouseEnter:()=>I(R),onMouseLeave:N,className:`w-full rounded-md px-2 py-1.5 text-left text-sm ${h===R||b===R?"bg-primary text-primary-foreground":"hover:bg-primary/50 hover:text-primary-foreground"}`,children:d.capitalize(i(R.toLowerCase()))},`sidebar-${R}`))]})})}),a.jsx("div",{className:`h-full flex-1 overflow-hidden ${!o&&A.length>0?"w-3/4":"w-full"}`,children:a.jsx(An,{id:"add-blocks-scroll-area",className:"no-scrollbar h-full",children:S.length===0&&c?a.jsx("div",{className:"flex flex-col items-center justify-center p-8 text-center text-muted-foreground",children:a.jsxs("p",{children:[i("No blocks found matching"),' "',c,'"']})}):a.jsx("div",{className:`${o?"p-0":"p-4"} space-y-6`,children:T.map((R,O)=>a.jsxs("div",{className:"space-y-3",children:[a.jsx("h3",{className:"px-1 text-sm font-medium",children:d.capitalize(i(R.toLowerCase()))}),a.jsx("div",{className:"grid gap-2 "+r,children:d.reject(h==="all"?d.filter(d.values(C),{group:R}):d.values(C),{hidden:!0}).map((H,G)=>a.jsx(Yg,{parentId:n,position:s,block:H,disabled:!w&&(!et(m,H.type)||!Bd(m,H.type))},H.type+"-"+O+"-"+G))})]},R))})})})]})]})},yc=Ne.atomWithStorage("__add_block_tab","library"),Do=({className:t,showHeading:e=!0,parentId:n=void 0,position:s=-1,fromSidebar:r=!1})=>{const{t:o}=F.useTranslation(),[i,l]=j.useAtom(yc),[,c]=j.useAtom(mi),u=$("flags.importHtml",!0),{data:p}=yi(),f=Object.keys(p||{}).length>0,{hasPermission:m}=Ve();g.useEffect(()=>{i==="partials"&&!f&&l("library")},[i,f,l]);const h=g.useCallback(()=>{re.publish(Y.CLOSE_ADD_BLOCK)},[]),x=B.useChaiAddBlockTabs(),b=u&&m(Q.IMPORT_HTML),v=B.useChaiLibraries().length>0;return g.useEffect(()=>{i==="library"&&!v&&l("core")},[i,v,l]),a.jsxs("div",{className:ke.cn("flex h-full w-full flex-col overflow-hidden",t),children:[e?a.jsxs("div",{className:"mb-2 flex flex-col justify-between rounded-md bg-background/30 p-1",children:[a.jsx("h1",{className:"flex flex-col items-baseline px-1 text-xl font-semibold xl:flex-col",children:o("Add block")}),a.jsx("span",{className:"p-0 text-xs font-light leading-3 opacity-80 xl:pl-1",children:o(i==="html"?"Enter or paste TailwindCSS HTML snippet":"Click to add block to page")})]}):null,a.jsxs(Os,{onValueChange:w=>{c(""),l(w)},value:i,className:"flex h-full max-h-full flex-col overflow-hidden",children:[a.jsxs(On,{className:`flex items-center ${r?"h-max w-max justify-start p-1":"w-full"}`,children:[v&&a.jsx(He,{value:"library",className:r?"h-5 px-2 text-xs":"",children:o("Library")}),a.jsx(He,{value:"core",className:r?"h-5 px-2 text-xs":"",children:o("Blocks")}),f&&a.jsx(He,{value:"partials",className:r?"h-5 px-2 text-xs":"",children:o("Partials")}),b?a.jsx(He,{value:"html",className:r?"h-5 px-2 text-xs":"",children:o("Import")}):null,d.map(x,w=>a.jsx(He,{value:w.id,className:r?"h-5 px-2 text-xs":"",children:g.createElement(w.tab)},`tab-add-block-${w.id}`))]}),a.jsx(ct,{value:"core",className:"h-full max-h-full flex-1 pb-20",children:a.jsx("div",{className:"h-full max-h-full overflow-hidden",children:a.jsx("div",{className:"h-full w-full",children:a.jsx(ic,{gridCols:r?"grid-cols-2":"grid-cols-4",parentId:n,position:s,disableBlockGroupsSidebar:r})})})}),v&&a.jsx(ct,{value:"library",className:"h-full max-h-full flex-1 pb-20",children:a.jsx(xc,{fromSidebar:r,parentId:n,position:s})}),f&&a.jsx(ct,{value:"partials",className:"h-full max-h-full flex-1 pb-20",children:a.jsx("div",{className:"h-full max-h-full overflow-hidden",children:a.jsx("div",{className:"h-full w-full",children:a.jsx(rx,{gridCols:r?"grid-cols-2":"grid-cols-4",parentId:n,position:s,disableBlockGroupsSidebar:r})})})}),b?a.jsx(ct,{value:"html",className:"h-full max-h-full flex-1 pb-20 ",children:a.jsx(dc,{parentId:n,position:s,fromSidebar:r})}):null,d.map(x,w=>a.jsx(ct,{value:w.id,children:g.createElement(w.tabContent,{close:h,parentId:n,position:s})},`panel-add-block-${w.id}`))]})]})},ox={display:"flex",alignItems:"center",zIndex:1},ax=g.memo(function({top:e,left:n}){const s={position:"absolute",pointerEvents:"none",top:e+"px",left:n+"px",right:0};return a.jsx("div",{style:{...ox,...s},children:a.jsx("div",{className:"h-0.5 flex-1 rounded-[1px] bg-green-500"})})}),Pa="h-3 w-3 flex-shrink-0",Oo=t=>{const e=K.useRegisteredChaiBlocks(),n=d.get(e,[t.type,"icon"]);return n?g.createElement(n,{className:Pa}):a.jsx(k.SquareIcon,{className:Pa})},ix=g.memo(function({children:e,isDragging:n}){return n?a.jsx("div",{className:"pointer-events-none fixed left-0 top-0 z-[100] h-full w-full",children:e}):null}),lx=g.memo(({id:t,isDragging:e,mouse:n})=>{const[s]=Z(),r=g.useMemo(()=>s.find(i=>i._id===t),[s,t]),o=g.useMemo(()=>({transform:`translate(${(n==null?void 0:n.x)-10}px, ${(n==null?void 0:n.y)-10}px)`}),[n]);return n?a.jsx("div",{children:a.jsx(ix,{isDragging:e,children:a.jsx("div",{className:"pointer-events-none absolute z-50 rounded border border-border bg-gray-100/80 font-semibold text-blue-600 shadow-md dark:border-gray-700 dark:bg-gray-800",style:o,children:a.jsxs("button",{type:"button",className:"flex !cursor-grab items-center p-0.5","aria-label":`Type: ${r==null?void 0:r._type}`,children:[a.jsx("div",{className:"-mt-0.5 h-3 w-3",children:a.jsx(Oo,{type:r==null?void 0:r._type})}),a.jsx("div",{className:"ml-2 truncate text-[11px]",children:(r==null?void 0:r._name)||(r==null?void 0:r._type)})]})})})}):a.jsx("div",{className:"hidden"})}),cx=[{key:"ArrowDown",command:"selectNext"},{key:"ArrowUp",command:"selectPrev"},{key:"ArrowLeft",command:"selectParent",when:"isLeaf || isClosed"},{key:"ArrowLeft",command:"close",when:"isOpen"},{key:"ArrowRight",command:"open",when:"isClosed"},{key:"ArrowRight",command:"selectNext",when:"isOpen"},{key:"Home",command:"selectFirst"},{key:"End",command:"selectLast"}];function dx(t){t.firstNode&&t.select(t.firstNode.id)}function ux(t){t.lastNode&&t.select(t.lastNode.id)}function px(t){const e=t.selectedNodes[0].next||t.firstNode;t.select(e.id)}function fx(t){const e=t.selectedNodes[0].prev||t.lastNode;t.select(e.id)}const hx=(t,e)=>{const n=t.selectedNodes[0],s=(n==null?void 0:n.parent)||null;s&&e&&t.select(s.id)},mx=(t,e)=>{const n=t.selectedNodes[0];n.isInternal&&e&&n.open()},gx=(t,e)=>{const n=t.selectedNodes[0];n.isInternal&&e&&n.close()},$o=Pe.Root,kc=Pe.Trigger,xx=Pe.Portal,vc=D.forwardRef(({className:t,...e},n)=>a.jsx(Pe.Overlay,{className:B.cn("fixed inset-0 z-50 bg-black/80 data-[state=open]:animate-in data-[state=closed]:animate-out data-[state=closed]:fade-out-0 data-[state=open]:fade-in-0",t),...e,ref:n}));vc.displayName=Pe.Overlay.displayName;const Fs=D.forwardRef(({className:t,...e},n)=>a.jsxs(xx,{children:[a.jsx(vc,{}),a.jsx(Pe.Content,{ref:n,className:B.cn("fixed left-[50%] top-[50%] z-50 grid w-full max-w-lg translate-x-[-50%] translate-y-[-50%] gap-4 border bg-background p-6 shadow-lg duration-200 data-[state=open]:animate-in data-[state=closed]:animate-out data-[state=closed]:fade-out-0 data-[state=open]:fade-in-0 data-[state=closed]:zoom-out-95 data-[state=open]:zoom-in-95 data-[state=closed]:slide-out-to-left-1/2 data-[state=closed]:slide-out-to-top-[48%] data-[state=open]:slide-in-from-left-1/2 data-[state=open]:slide-in-from-top-[48%] sm:rounded-lg",t),...e})]}));Fs.displayName=Pe.Content.displayName;const zs=({className:t,...e})=>a.jsx("div",{className:B.cn("flex flex-col space-y-2 text-center sm:text-left",t),...e});zs.displayName="AlertDialogHeader";const Fo=({className:t,...e})=>a.jsx("div",{className:B.cn("flex flex-col-reverse sm:flex-row sm:justify-end sm:space-x-2",t),...e});Fo.displayName="AlertDialogFooter";const Hs=D.forwardRef(({className:t,...e},n)=>a.jsx(Pe.Title,{ref:n,className:B.cn("text-lg font-semibold",t),...e}));Hs.displayName=Pe.Title.displayName;const zo=D.forwardRef(({className:t,...e},n)=>a.jsx(Pe.Description,{ref:n,className:B.cn("text-sm text-muted-foreground",t),...e}));zo.displayName=Pe.Description.displayName;const Ho=D.forwardRef(({className:t,...e},n)=>a.jsx(Pe.Action,{ref:n,className:B.cn(B.buttonVariants(),t),...e}));Ho.displayName=Pe.Action.displayName;const Vo=D.forwardRef(({className:t,...e},n)=>a.jsx(Pe.Cancel,{ref:n,className:B.cn(B.buttonVariants({variant:"outline"}),"mt-2 sm:mt-0",t),...e}));Vo.displayName=Pe.Cancel.displayName;const wc=({children:t})=>{const{t:e}=F.useTranslation(),{setNewBlocks:n}=Ee(),[,s]=U(),[,r]=Ae(),o=g.useCallback(()=>{n([]),s([]),r([])},[n]);return a.jsx("div",{className:"flex items-center",children:a.jsxs($o,{children:[a.jsx(kc,{asChild:!0,children:t||a.jsxs(B.Button,{size:"sm",variant:"ghost",className:"flex items-center",children:[a.jsx(k.EraserIcon,{})," ",e("Clear")]})}),a.jsxs(Fs,{className:"border-border",children:[a.jsxs(zs,{children:[a.jsx(Hs,{className:"text-foreground",children:e("Clear whole canvas?")}),a.jsx(zo,{children:e("Are you sure you want to clear the page?")})]}),a.jsxs(Fo,{children:[a.jsx(Vo,{className:"text-foreground",children:e("Cancel")}),a.jsx(Ho,{onClick:o,children:e("Yes")})]})]})]})})},bx=()=>{const t=J(),{t:e}=F.useTranslation(),[,n]=j.useAtom(ai),s=B.useSaveToLibraryComponent(),r=()=>{t&&n({isOpen:!0,blockId:t._id})};return s?a.jsxs(de,{className:"flex items-center gap-x-4 text-xs",onClick:r,children:[a.jsx(k.CheckIcon,{className:"h-4 w-4"})," ",t!=null&&t._libBlockId?e("Update library block"):e("Save to library")]}):null},yx=()=>{const{t}=F.useTranslation(),e=J(),n=st(),s=()=>{e&&n([e._id],{_libBlockId:null})};return a.jsxs(de,{onClick:s,className:"flex items-center gap-x-4 text-xs",children:[a.jsx(k.LinkBreak2Icon,{className:"h-4 w-4"})," ",t("Unlink from library")]})},La=()=>{const{t}=F.useTranslation(),[e]=U();return $("flags.exportCode",!1)?a.jsxs(de,{className:"flex items-center gap-x-4 text-xs",onClick:()=>re.publish(Y.OPEN_EXPORT_CODE,e),children:[a.jsx(k.DownloadIcon,{})," ",t("Export")]}):null},Ma=({isFromBody:t=!1})=>{const[e]=Z(),[n]=U(),{pasteBlocks:s}=Qr(),[,r,o]=$i(),{t:i}=F.useTranslation(),l=J(),c=$("flags.copyPaste",!0),u=g.useCallback(()=>{var m;const f=(t?(m=e==null?void 0:e.filter(h=>!(h!=null&&h._parent)))==null?void 0:m.map(h=>h==null?void 0:h._id):n).map(h=>{const x=e.find(b=>b._id===h);return{id:h,data:x}});o(f.map(h=>h.id))?ce.toast.warning("Partial blocks detected. Clone partial blocks?",{cancel:{label:i("No"),onClick:()=>{r(f.map(h=>h.id)),ce.toast.dismiss()}},action:{label:i("Yes"),onClick:()=>{r(f.map(h=>h.id),!0),ce.toast.dismiss()}},position:"top-center"}):r(f.map(h=>h.id))},[n,e,r,o]);return a.jsxs(a.Fragment,{children:[c&&a.jsxs(de,{disabled:!Ir(l==null?void 0:l._type),onClick:u,className:"flex items-center gap-x-4 text-xs",children:[a.jsx(k.CopyIcon,{})," ",i("Copy")]}),c&&a.jsxs(de,{className:"flex items-center gap-x-4 text-xs",onClick:()=>{s(n)},children:[a.jsx(k.CardStackIcon,{})," ",i("Paste")]})]})},kx=()=>{const[t]=U(),[,e]=_s(),{t:n}=F.useTranslation(),s=$("flags.copyPaste",!0);return a.jsx(a.Fragment,{children:s&&a.jsxs(de,{className:"flex items-center gap-x-4 text-xs",onClick:()=>e(t),children:[a.jsx(k.ScissorsIcon,{})," ",n("Cut")]})})},vx=()=>{const[t]=U(),e=Ss(),n=J(),{t:s}=F.useTranslation();return a.jsxs(de,{disabled:!_r(n==null?void 0:n._type),className:"flex items-center gap-x-4 text-xs",onClick:()=>e(t),children:[a.jsx(k.TrashIcon,{})," ",s("Remove")]})},wx=({node:t})=>{const{t:e}=F.useTranslation();return a.jsxs(de,{onClick:n=>{n.stopPropagation(),t.edit(),t.deselect()},className:"flex items-center gap-x-4 text-xs",children:[a.jsx(k.Pencil2Icon,{className:"h-4 w-4"})," ",e("Rename")]})},Cx=({node:t})=>{const{t:e}=F.useTranslation(),[n]=U(),s=Jr(),r=J(),{hasPermission:o}=Ve(),{librarySite:i}=$("flags",{librarySite:!1}),l=Ye(),c=g.useCallback(()=>{s(n)},[n,s]),u=g.useMemo(()=>d.has(r,"_libBlockId")&&!d.isEmpty(r._libBlockId),[r==null?void 0:r._libBlockId]);return t==="BODY"?a.jsx(Ue,{side:"bottom",className:"border-border text-xs",children:o(Q.ADD_BLOCK)&&a.jsxs(a.Fragment,{children:[a.jsxs(de,{disabled:!1,className:"flex items-center gap-x-4 text-xs",onClick:()=>re.publish(Y.OPEN_ADD_BLOCK,r),children:[a.jsx(k.PlusIcon,{className:"h-3.5 w-3.5"})," ",e("Add block")]}),o(Q.ADD_BLOCK)&&a.jsx(Ma,{isFromBody:!0}),a.jsx(La,{}),a.jsx(de,{disabled:!1,onClick:p=>p.preventDefault(),className:"flex items-center gap-x-4 text-xs",children:a.jsx(wc,{children:a.jsxs("div",{className:"flex items-center gap-x-4 text-xs",children:[a.jsx(k.EraserIcon,{})," ",e("Clear canvas")]})})})]})}):a.jsxs(Ue,{side:"bottom",className:"border-border text-xs",children:[o(Q.ADD_BLOCK)&&a.jsxs(a.Fragment,{children:[!l&&a.jsxs(de,{disabled:!ss(r==null?void 0:r._type),className:"flex items-center gap-x-4 text-xs",onClick:()=>re.publish(Y.OPEN_ADD_BLOCK,r),children:[a.jsx(k.PlusIcon,{className:"h-3.5 w-3.5"})," ",e("Add block")]}),a.jsxs(de,{disabled:!Ir(r==null?void 0:r._type),className:"flex items-center gap-x-4 text-xs",onClick:c,children:[a.jsx(k.CardStackPlusIcon,{})," ",e("Duplicate")]})]}),a.jsx(wx,{node:t}),o(Q.MOVE_BLOCK)&&a.jsx(kx,{}),o(Q.ADD_BLOCK)&&a.jsx(Ma,{}),u&&i&&a.jsx(yx,{}),o(Q.CREATE_LIBRARY_BLOCK)&&i&&a.jsx(bx,{}),a.jsx(La,{}),o(Q.DELETE_BLOCK)&&a.jsx(vx,{})]})},Cc=({children:t,id:e,node:n})=>{const[,s]=U();return a.jsx(a.Fragment,{children:a.jsxs(tt,{onOpenChange:r=>{r&&s([e])},children:[a.jsx(nt,{children:t}),a.jsx(Cx,{node:n})]})})},Q={ADD_BLOCK:"add_block",DELETE_BLOCK:"delete_block",EDIT_BLOCK:"edit_block",MOVE_BLOCK:"move_block",EDIT_THEME:"edit_theme",SAVE_PAGE:"save_page",EDIT_STYLES:"edit_styles",IMPORT_HTML:"import_html",CREATE_LIBRARY_BLOCK:"create_library_block",CREATE_LIBRARY_GROUP:"create_library_group",EDIT_LIBRARY_BLOCK:"edit_library_block",DELETE_LIBRARY_BLOCK:"delete_library_block"};Object.values(Q);const jc=()=>{const[t]=j.useAtom(Qt),[e]=j.useAtom(Br),[n]=j.useAtom(Rr),[s]=j.useAtom(Pr),[r]=j.useAtom(Xa),[o]=j.useAtom(Ja),[i]=j.useAtom(Za);return{errors:t,isValid:e,hasErrors:n,hasWarnings:s,errorCount:r,warningCount:o,errorsByBlock:i,getBlockErrors:l=>i[l]||[],getErrorsBySeverity:l=>t.filter(c=>c.severity===l),getErrorMessages:()=>t.map(l=>l.message),getErrorMessagesBySeverity:l=>t.filter(c=>c.severity===l).map(c=>c.message),getAllErrorMessages:()=>({errors:t.filter(l=>l.severity==="error").map(l=>l.message),warnings:t.filter(l=>l.severity==="warning").map(l=>l.message)})}},jx=({node:t})=>{var e,n;return a.jsx("input",{autoFocus:!0,className:be("ml-2 !h-4 w-full rounded-sm border border-border bg-background px-1 text-[11px] leading-tight outline-none",t.isSelected?"text-black dark:text-white":""),type:"text",defaultValue:((e=t.data)==null?void 0:e._name)||((n=t.data)==null?void 0:n._type),onFocus:s=>s.currentTarget.select(),onBlur:s=>t.submit(s.currentTarget.value),onKeyDown:s=>{s.key==="Enter"&&t.submit(s.currentTarget.value)}})},Sx=j.atom(null),ir=t=>{var e;return t!=null&&t._name?t._name:(t==null?void 0:t._type)==="Box"&&(t!=null&&t.tag)&&(t==null?void 0:t.tag)!=="div"?d.startCase(t.tag):((e=t==null?void 0:t._type)==null?void 0:e.split("/").pop())||""},Nx=(t,e)=>t.length>e?t.substring(0,e)+"...":t,Ex=g.memo(({node:t,style:e,dragHandle:n})=>{var we,Oe;const{t:s}=F.useTranslation(),r=st(),[o]=j.useAtom(Es),{hasPermission:i}=Ve();let l=null;const c=t.children&&t.children.length>0,{highlightBlock:u,clearHighlight:p}=rt(),f=Ye(),{id:m,data:h,isSelected:x,willReceiveDrop:b,isDragging:y,isEditing:v,handleClick:w}=t,I=jc(),N=g.useMemo(()=>I.getBlockErrors(m),[I,m]),E=d.get(h,"_show",!0),_=W=>{W.stopPropagation(),E&&t.toggle()},S=W=>{W.isInternal&&(l=W.isOpen,W.isOpen&&W.close())},A=W=>{W.isInternal&&l!==null&&(l?W.open():W.close(),l=null)},[C,T]=j.useAtom(Sx),P=()=>{var W,$e;R(),(W=t.parent)!=null&&W.isSelected||T(($e=t==null?void 0:t.parent)==null?void 0:$e.id)},R=()=>{T(null)},O=W=>{R(),W.stopPropagation(),!t.isOpen&&E&&t.toggle(),w(W)};g.useEffect(()=>{const W=setTimeout(()=>{b&&!t.isOpen&&!y&&E&&t.toggle()},500);return()=>clearTimeout(W)},[b,t,y]);const H=(W,$e)=>{var z;const yt=o.contentDocument||((z=o.contentWindow)==null?void 0:z.document),Wt=yt==null?void 0:yt.querySelector(`[data-block-id=${W}]`);Wt&&Wt.setAttribute("data-drop",$e);const kt=Wt.getBoundingClientRect(),vt=o.getBoundingClientRect();!(kt.top>=vt.top&&kt.left>=vt.left&&kt.bottom<=vt.bottom&&kt.right<=vt.right)&&yt&&(yt.documentElement.scrollTop=Wt.offsetTop-vt.top)},G=W=>{R();const $e=d.get(t,"parent.id");$e!=="__REACT_ARBORIST_INTERNAL_ROOT__"?re.publish(Y.OPEN_ADD_BLOCK,{_id:$e,position:W}):re.publish(Y.OPEN_ADD_BLOCK,{position:W})};if(m===q.ROOT_TEMP_KEY)return a.jsxs("div",{className:"group relative mt-2 w-full cursor-pointer",children:[a.jsx("br",{}),i(Q.ADD_BLOCK)&&a.jsx("div",{role:"button",onClick:()=>G(-1),className:"h-1 rounded bg-primary opacity-0 duration-200 group-hover:opacity-100",children:a.jsxs("div",{className:"absolute left-1/2 top-1/2 flex -translate-x-1/2 -translate-y-1/2 transform items-center gap-x-1 rounded-full bg-primary px-3 py-1 text-[9px] leading-tight text-white hover:bg-primary",children:[a.jsx(k.PlusIcon,{className:"w-2.4 h-2.5 stroke-[5] text-white"})," ",s("Add block")]})}),a.jsx("br",{})]});const{librarySite:me}=$("flags",{librarySite:!1}),ie=g.useMemo(()=>me&&d.has(h,"_libBlockId")&&!d.isEmpty(h._libBlockId)&&(i(Q.CREATE_LIBRARY_BLOCK)||i(Q.EDIT_LIBRARY_BLOCK)),[h,i,me]),ne=g.useMemo(()=>(h==null?void 0:h._type)==="PartialBlock"||(h==null?void 0:h._type)==="GlobalBlock",[h]);return a.jsx("div",{className:"w-full",children:a.jsxs("div",{onMouseEnter:()=>u(m),onMouseLeave:()=>p(),onClick:O,style:e,"data-node-id":m,ref:n,onDragStart:()=>S(t),onDragEnd:()=>A(t),onDragOver:W=>{W.preventDefault(),H(m,"yes")},onDragLeave:W=>{W.preventDefault(),H(m,"no")},onDrop:W=>{W.preventDefault(),H(m,"no")},children:[i(Q.ADD_BLOCK)&&!f&&(t==null?void 0:t.rowIndex)!==null&&(t==null?void 0:t.rowIndex)!==void 0&&(t==null?void 0:t.rowIndex)>0&&(((we=t.parent)==null?void 0:we.isOpen)&&ss(d.get(t,"parent.data._type"))||((Oe=t==null?void 0:t.parent)==null?void 0:Oe.id)==="__REACT_ARBORIST_INTERNAL_ROOT__")&&a.jsx("div",{className:"group relative ml-5 h-full w-full cursor-pointer",children:a.jsx("div",{onClick:W=>{W.stopPropagation(),G(t.childIndex)},onMouseEnter:P,onMouseLeave:R,className:"absolute -top-0.5 h-0.5 w-[90%] rounded bg-primary/80 opacity-0 delay-200 duration-200 group-hover:opacity-100",children:a.jsx("div",{className:"absolute left-1/2 top-1/2 flex h-4 w-4 -translate-x-1/2 -translate-y-1/2 transform items-center justify-center rounded-full bg-primary/80 p-1 outline outline-2 outline-white hover:bg-primary/80",children:a.jsx(k.PlusIcon,{className:"h-2 w-2 stroke-[2] text-white"})})})}),a.jsxs("div",{className:be("group flex w-full cursor-pointer items-center justify-between space-x-px !rounded p-1 py-0 outline-none",x?"bg-primary/20":"hover:bg-primary/10",b&&et(h._type,"Icon")?"bg-green-200":"",(t==null?void 0:t.id)===C?"bg-primary/10":"",y&&"opacity-20",E?"":"line-through opacity-50",ie&&x&&"bg-primary/20 text-primary"),children:[a.jsxs("div",{className:"flex items-center",children:[a.jsx("div",{className:`flex h-4 w-4 rotate-0 transform cursor-pointer items-center justify-center transition-transform duration-100 ${t.isOpen?"rotate-90":""}`,children:c&&a.jsx("button",{onClick:_,type:"button",children:a.jsx(k.ChevronRightIcon,{className:"h-3 w-3"})})}),a.jsxs("div",{className:be("leading-1 flex items-center",ie&&"text-orange-600/90",ie&&x&&"text-orange-800",ne&&"text-purple-600/90",ne&&x&&"text-purple-800"),children:[N.length>0?a.jsx("div",{className:"text-red-500",children:a.jsx(k.ExclamationTriangleIcon,{className:"h-3 w-3"})}):a.jsx(Oo,{type:h==null?void 0:h._type}),v?a.jsx(jx,{node:t}):a.jsx("div",{className:"ml-1.5 flex items-center gap-x-1 truncate text-[13px]",onDoubleClick:W=>{W.stopPropagation(),t.edit(),t.deselect()},children:a.jsx("span",{title:ir(h).length>17?ir(h):"",children:Nx(ir(h),17)})})]})]}),a.jsxs("div",{className:"invisible flex items-center space-x-1.5 pr-px group-hover:visible",children:[ss(h==null?void 0:h._type)&&E&&i(Q.ADD_BLOCK)?a.jsxs(fe,{children:[a.jsx(he,{onClick:()=>re.publish(Y.OPEN_ADD_BLOCK,{_id:m}),className:"cursor-pointer rounded bg-transparent p-px hover:bg-primary/10",asChild:!0,children:a.jsx(k.PlusIcon,{className:"h-4 w-4"})}),a.jsx(ue,{className:"isolate z-[9999]",side:"bottom",children:s("Add block inside")})]}):null,a.jsxs(fe,{children:[a.jsx(he,{onClick:W=>{W.stopPropagation(),r([m],{_show:!E}),t.isOpen&&t.toggle()},className:"cursor-pointer rounded bg-transparent p-0.5 hover:bg-primary/10",asChild:!0,children:E?a.jsx(k.EyeClosedIcon,{className:"h-4 w-4"}):a.jsx(k.EyeOpenIcon,{className:"h-4 w-4"})}),a.jsx(ue,{className:"isolate z-[9999] text-xs",side:"bottom",children:s(E?"Hide the block from page":"Show the block on page")})]}),a.jsx(Cc,{node:t,id:m,children:a.jsx("div",{className:"cursor-pointer rounded bg-transparent p-px hover:bg-primary/10",children:a.jsx(k.DotsVerticalIcon,{className:"h-3 w-3"})})})]})]})]})})}),Sc=(t,e)=>{const n=d.filter(t,{_parent:e});if(n.length===0)return[];const s=[...n];return n.forEach(r=>{s.push(...Sc(t,r==null?void 0:r._id))}),s},Ax=()=>{const[t,e]=j.useAtom(ai),{t:n}=F.useTranslation(),[s]=Z(),r=()=>e({isOpen:!1,blockId:null}),o=B.useSaveToLibraryComponent(),i=g.useMemo(()=>{if(!t.blockId)return[];const l=d.find(s,{_id:t.blockId});return l==null||delete l._parent,[l,...Sc(s,l==null?void 0:l._id)]},[t.blockId,s]);return a.jsx(Pn,{open:t.isOpen,onOpenChange:l=>!l&&r(),children:a.jsxs(cn,{className:"p-4 sm:max-w-[450px]",children:[a.jsx(Ln,{className:"pb-2",children:a.jsx(dn,{children:n("Save to Library")})}),o&&!d.isEmpty(t.blockId)&&a.jsx(o,{blockId:t.blockId,blocks:i,close:r})]})})},Ix=({parentContext:t,setParentContext:e})=>{const{t:n}=F.useTranslation(),{canPaste:s,pasteBlocks:r}=Qr(),o=$("flags.copyPaste",!0);return g.useEffect(()=>{s("root")||e(null)},[s("root")]),!t||!s("root")||!o?null:a.jsx("div",{className:"absolute inset-0",children:a.jsxs(tt,{open:!0,onOpenChange:()=>e(null),children:[a.jsx(nt,{className:"hidden"}),a.jsx(Ue,{className:"absolute w-28 p-1 text-xs",style:{top:t.y,left:t.x},children:a.jsxs(de,{className:"flex items-center gap-x-4 text-xs",onClick:()=>{r("root"),e(null)},children:[a.jsx(k.CardStackIcon,{})," ",n("Paste")]})})]})})},_x=()=>{const[t]=Z();return(e,n)=>{if(!n)return!!d.first(e.map(i=>{var l;return(l=d.find(t,{_id:i}))==null?void 0:l._type}));const s=d.find(t,{_id:n});if(!s)return!1;const r=d.first(e.map(o=>{var i;return(i=d.find(t,{_id:o}))==null?void 0:i._type}));return r?et(s._type,r):!1}},Nc=()=>{const[t]=j.useAtom(Ka),[e,n]=U(),[s]=_s(),r=st(),[,o]=Ae(),{moveBlocks:i}=Ee(),l=_x(),c=g.useRef(null),[,u]=j.useAtom(Ur),{t:p}=F.useTranslation(),[f,m]=g.useState(null),h=()=>{n([]),o([])},x=g.useMemo(()=>{const S=(C,T)=>C.filter(P=>!T.includes(P._id)).map(P=>({...P,children:P.children?S(P.children,T):[]}));return[...S(t,s),{_type:q.ROOT_TEMP_KEY,_id:q.ROOT_TEMP_KEY,children:[]}]},[t,s]),b=({id:S,name:A,node:C})=>{r([S],{_name:A},C.data._name)},y=({dragIds:S,parentId:A,index:C})=>{l(S,A)&&i(S,A??void 0,C)},v=S=>{if(S.length===0)return;const A=S[0]?S[0].id:"";o([]),n([A])},w=S=>{var T;S.preventDefault(),f&&m(null);const A=S.target,C=A.getAttribute("data-node-id")||((T=A.closest("[data-node-id]"))==null?void 0:T.getAttribute("data-node-id"));C?(o([]),n([C])):(o([]),n([]),m({x:S.clientX,y:S.clientY}))},I=ve.useDebouncedCallback(({parentNode:S,dragNodes:A})=>{var C;return(S==null?void 0:S.data._type)===q.ROOT_TEMP_KEY||!et(S==null?void 0:S.data._type,(C=A[0])==null?void 0:C.data._type)},[],300),N=(S,A)=>{if(!S)return!0;const C={isLeaf:!A.isInternal,isClosed:!A.isOpen,isOpen:A.isOpen};try{let T=S;return Object.keys(C).forEach(P=>{const R=new RegExp(`\\b${P}\\b`,"g");T=T.replace(R,String(C[P]))}),new Function(`return ${T}`)()}catch{return console.warn("Invalid condition expression:",S),!1}},E=S=>{if(!c.current)return;const A=c.current,C=A.selectedNodes[0];if(!C)return;n([C.id]),o([]);const T=!C.isInternal,P=!C.isOpen,R=C.isOpen,O=cx.find(H=>H.key===S.key&&(!H.when||N(H.when,C)));if(O)switch(S.preventDefault(),O.command){case"selectNext":px(A);break;case"selectPrev":fx(A);break;case"selectParent":hx(A,T||P);break;case"close":gx(A,R);break;case"open":mx(A,P);break;case"selectFirst":dx(A);break;case"selectLast":ux(A);break}};g.useEffect(()=>{const S=()=>{c.current&&u(c.current)};S();const A=new MutationObserver(S);return A.observe(document.body,{childList:!0,subtree:!0}),()=>A.disconnect()},[u]);const{hasPermission:_}=Ve();return d.isEmpty(t)?a.jsx("div",{children:a.jsx("div",{className:"mt-10 flex h-full w-full items-center justify-center p-8",children:a.jsxs("div",{className:"flex flex-col items-center space-y-6 text-center",children:[a.jsx("div",{className:"rounded-full bg-muted p-6",children:a.jsx(k.StackIcon,{className:"h-12 w-12 text-muted-foreground"})}),a.jsxs("div",{className:"space-y-2",children:[a.jsx("h3",{className:"text-lg font-semibold text-foreground",children:p("This page is empty")}),a.jsx("p",{className:"max-w-sm text-sm text-muted-foreground",children:p("Get started by adding your first block to begin building your page")})]}),_(Q.ADD_BLOCK)&&a.jsxs(B.Button,{onClick:()=>re.publish(Y.OPEN_ADD_BLOCK),className:"bg-primary shadow-sm hover:bg-primary/90",size:"sm",children:[a.jsx(k.PlusIcon,{className:"h-4 w-4"}),p("Add Block")]})]})})}):a.jsxs(a.Fragment,{children:[a.jsx("div",{className:ke.cn("flex h-full select-none flex-col space-y-1"),onClick:()=>h(),children:a.jsxs("div",{id:"outline-view ",className:"no-scrollbar h-full overflow-y-auto text-sm",onKeyDown:S=>{c.current&&!c.current.isEditing&&E(S)},children:[a.jsxs("div",{className:"mb-2 flex items-center justify-end gap-x-1 pb-2 text-sm text-muted-foreground",children:[a.jsxs(fe,{children:[a.jsx(he,{asChild:!0,children:a.jsx(B.Button,{className:"h-fit p-1",onClick:()=>{var S;return(S=c==null?void 0:c.current)==null?void 0:S.openAll()},variant:"ghost",size:"sm",children:a.jsx(k.DoubleArrowDownIcon,{className:"h-2 w-2"})})}),a.jsx(ue,{className:"isolate z-[9999]",children:p("Expand all")})]}),a.jsxs(fe,{children:[a.jsx(he,{asChild:!0,children:a.jsx(B.Button,{className:"h-fit p-1",onClick:()=>{var S;return(S=c==null?void 0:c.current)==null?void 0:S.closeAll()},variant:"ghost",size:"sm",children:a.jsx(k.DoubleArrowUpIcon,{className:"h-2 w-2"})})}),a.jsx(ue,{className:"isolate z-[9999]",children:p("Collapse all")})]})]}),a.jsx("div",{className:"group relative z-30 ml-5 w-full cursor-pointer",children:a.jsx("div",{onClick:()=>re.publish(Y.OPEN_ADD_BLOCK,{position:0}),className:"h-1 w-[90%] rounded bg-primary opacity-0 duration-200 group-hover:opacity-100",children:a.jsx("div",{className:"absolute left-[45%] top-1/2 flex h-4 w-4 -translate-x-1/2 -translate-y-1/2 transform items-center justify-center rounded-full bg-primary p-1 outline outline-2 outline-white hover:bg-primary",children:a.jsx(k.PlusIcon,{className:"h-3 w-3 stroke-[3] text-white"})})})}),a.jsx("div",{children:a.jsx("div",{role:"treeitem","aria-level":0,"aria-selected":!0,"aria-expanded":!1,onClick:()=>n([]),className:"flex h-full items-center border-b border-transparent",children:a.jsxs("div",{className:ke.cn("group flex w-full cursor-pointer items-center justify-between space-x-px !rounded p-1 py-0 outline-none",e.length===0?"bg-primary/20":""),children:[a.jsxs("div",{className:"leading-1 flex items-center",children:[a.jsx(k.CardStackIcon,{className:"h-3 w-3 flex-shrink-0 rotate-180"}),a.jsx("div",{className:"ml-1.5 flex items-center gap-x-1 truncate text-[13px]",children:"Body"})]}),a.jsx(Cc,{node:"BODY",id:"BODY",children:a.jsx("div",{className:"hidden cursor-pointer rounded bg-transparent p-px hover:bg-primary/10 group-hover:block",children:a.jsx(k.DotsVerticalIcon,{className:"h-3 w-3"})})})]})})}),a.jsx(yd.Tree,{ref:c,height:window.innerHeight-160,className:"no-scrollbar !h-full max-w-full space-y-1 !overflow-y-auto !overflow-x-hidden",rowClassName:"flex items-center h-full border-b border-transparent",selection:e[0]||"",onRename:b,openByDefault:!1,onMove:y,data:[...x],renderCursor:ax,onSelect:v,childrenAccessor:S=>S.children,width:"100%",rowHeight:25,renderDragPreview:lx,indent:10,onContextMenu:w,disableDrop:I,idAccessor:"_id",children:Ex})]})}),a.jsx(Ax,{}),a.jsx(Ix,{parentContext:f,setParentContext:m})]})},Rt=D.forwardRef(({className:t,orientation:e="horizontal",decorative:n=!0,...s},r)=>a.jsx(Wa.Root,{ref:r,decorative:n,orientation:e,className:B.cn("shrink-0 bg-border",e==="horizontal"?"h-[1px] w-full":"h-full w-[1px]",t),...s}));Rt.displayName=Wa.Root.displayName;const un=D.forwardRef(({className:t,thumbClassName:e,...n},s)=>a.jsx(cr.Root,{className:B.cn("peer inline-flex h-5 w-9 shrink-0 cursor-pointer items-center rounded-full border-2 border-transparent shadow-sm transition-colors focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-ring focus-visible:ring-offset-2 focus-visible:ring-offset-background disabled:cursor-not-allowed disabled:opacity-50 data-[state=checked]:bg-primary data-[state=unchecked]:bg-input",t),...n,ref:s,children:a.jsx(cr.Thumb,{className:B.cn("pointer-events-none block h-4 w-4 rounded-full bg-background shadow-lg ring-0 transition-transform",e,"data-[state=checked]:translate-x-3 data-[state=unchecked]:translate-x-0")})}));un.displayName=cr.Root.displayName;const Ec=D.forwardRef(({className:t,...e},n)=>a.jsxs(fn.Root,{ref:n,className:B.cn("relative flex w-full touch-none select-none items-center",t),...e,children:[a.jsx(fn.Track,{className:"relative h-1.5 w-full grow overflow-hidden rounded-full bg-neutral-300",children:a.jsx(fn.Range,{className:"absolute h-full bg-neutral-900"})}),a.jsx(fn.Thumb,{className:"block h-4 w-4 rounded-full border border-neutral-900 bg-neutral-900 shadow transition-colors focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-neutral-900 disabled:pointer-events-none disabled:opacity-50"})]}));Ec.displayName=fn.Root.displayName;const Tx=({value:t,onChange:e,disabled:n})=>{const[s,r]=g.useState(t),o=ve.useThrottledCallback(e,[t],200,!0);return a.jsx(Ec,{min:0,step:1,max:50,disabled:n,value:[Number(s.replace("px",""))],onValueChange:i=>{r(i[0].toString()+"px"),o(i[0].toString())},className:"flex-1 cursor-pointer"})},Bx=({value:t,onChange:e})=>{const n=d.debounce(s=>e(s),200);return a.jsx("div",{className:"relative flex h-6 w-6 cursor-pointer rounded-lg border border-border",style:{backgroundColor:t},children:a.jsx("input",{type:"color",value:t.startsWith("#")?t:"#000000",onChange:s=>{const r=s.target.value;/^#[0-9A-F]{6}$/i.test(r)&&n(r)},className:"absolute inset-0 h-full w-full cursor-pointer rounded-lg border-0 opacity-0"})})},Rx=({label:t,value:e,onChange:n})=>{const s=Nr.useRegisteredFonts(),{t:r}=F.useTranslation();return g.useEffect(()=>{s.some(o=>o.family===e)||n(s[0].family)},[e,n]),a.jsxs("div",{className:"space-y-0.5",children:[a.jsx(ut,{className:"mb-1 block text-xs text-gray-600",children:r(d.startCase(t))}),a.jsxs($s,{value:e,onValueChange:n,children:[a.jsx(Fn,{className:"h-8 w-full text-xs text-black",children:a.jsx(Mo,{placeholder:r("Select font")})}),a.jsx(zn,{children:s.map(o=>a.jsx(Hn,{value:o.family,children:o.family},o.family))})]})]})},Px={fontFamily:{heading:"Poppins",body:"Poppins"},borderRadius:"6px",colors:{background:["#ffffff","#0a0a0a"],foreground:["#0a0a0a","#fafafa"],primary:["#171717","#e5e5e5"],"primary-foreground":["#fafafa","#171717"],secondary:["#f5f5f5","#262626"],"secondary-foreground":["#171717","#fafafa"],muted:["#f5f5f5","#262626"],"muted-foreground":["#737373","#a1a1a1"],accent:["#f5f5f5","#404040"],"accent-foreground":["#171717","#fafafa"],destructive:["#e7000b","#ff6467"],"destructive-foreground":["#ffffff","#fafafa"],border:["#e5e5e5","#282828"],input:["#e5e5e5","#343434"],ring:["#a1a1a1","#737373"],card:["#ffffff","#171717"],"card-foreground":["#0a0a0a","#fafafa"],popover:["#ffffff","#262626"],"popover-foreground":["#0a0a0a","#fafafa"]}},Lx={fontFamily:{heading:"Poppins",body:"Poppins"},borderRadius:"4px",colors:{background:["#ffffff","#000000"],foreground:["#0f1419","#e7e9ea"],primary:["#1e9df1","#1c9cf0"],"primary-foreground":["#ffffff","#ffffff"],secondary:["#0f1419","#f0f3f4"],"secondary-foreground":["#ffffff","#0f1419"],muted:["#e5e5e6","#181818"],"muted-foreground":["#0f1419","#72767a"],accent:["#e3ecf6","#061622"],"accent-foreground":["#1e9df1","#1c9cf0"],destructive:["#f4212e","#f4212e"],"destructive-foreground":["#ffffff","#ffffff"],border:["#e1eaef","#242628"],input:["#f7f9fa","#22303c"],ring:["#1da1f2","#1da1f2"],card:["#f7f8f8","#17181c"],"card-foreground":["#0f1419","#d9d9d9"],popover:["#ffffff","#000000"],"popover-foreground":["#0f1419","#e7e9ea"]}},Mx={fontFamily:{heading:"Geist",body:"Geist"},borderRadius:"4px",colors:{background:["#fdf6e3","#002b36"],foreground:["#073642","#93a1a1"],primary:["#d33682","#d33682"],"primary-foreground":["#ffffff","#ffffff"],secondary:["#2aa198","#2aa198"],"secondary-foreground":["#ffffff","#ffffff"],muted:["#93a1a1","#586e75"],"muted-foreground":["#073642","#93a1a1"],accent:["#cb4b16","#cb4b16"],"accent-foreground":["#ffffff","#ffffff"],destructive:["#dc322f","#dc322f"],"destructive-foreground":["#ffffff","#ffffff"],border:["#839496","#586e75"],input:["#839496","#586e75"],ring:["#d33682","#d33682"],card:["#eee8d5","#073642"],"card-foreground":["#073642","#93a1a1"],popover:["#eee8d5","#073642"],"popover-foreground":["#073642","#93a1a1"]}},Dx={fontFamily:{heading:"Poppins",body:"Poppins"},borderRadius:"6px",colors:{background:["#faf9f5","#262624"],foreground:["#3d3929","#c3c0b6"],primary:["#c96442","#d97757"],"primary-foreground":["#ffffff","#ffffff"],secondary:["#e9e6dc","#faf9f5"],"secondary-foreground":["#535146","#30302e"],muted:["#ede9de","#1b1b19"],"muted-foreground":["#83827d","#b7b5a9"],accent:["#e9e6dc","#1a1915"],"accent-foreground":["#28261b","#f5f4ee"],destructive:["#141413","#ef4444"],"destructive-foreground":["#ffffff","#ffffff"],border:["#dad9d4","#3e3e38"],input:["#b4b2a7","#52514a"],ring:["#c96442","#d97757"],card:["#faf9f5","#262624"],"card-foreground":["#141413","#faf9f5"],popover:["#ffffff","#30302e"],"popover-foreground":["#28261b","#e5e5e2"]}},Ox={fontFamily:{heading:"Inter",body:"Inter"},borderRadius:"6px",colors:{background:["#fff9f5","#2a2024"],foreground:["#3d3436","#f2e9e4"],primary:["#ff7e5f","#ff7e5f"],"primary-foreground":["#ffffff","#ffffff"],secondary:["#ffedea","#463a41"],"secondary-foreground":["#b35340","#f2e9e4"],muted:["#fff0eb","#392f35"],"muted-foreground":["#78716c","#d7c6bc"],accent:["#feb47b","#feb47b"],"accent-foreground":["#3d3436","#2a2024"],destructive:["#e63946","#e63946"],"destructive-foreground":["#ffffff","#ffffff"],border:["#ffe0d6","#463a41"],input:["#ffe0d6","#463a41"],ring:["#ff7e5f","#ff7e5f"],card:["#ffffff","#392f35"],"card-foreground":["#3d3436","#f2e9e4"],popover:["#ffffff","#392f35"],"popover-foreground":["#3d3436","#f2e9e4"]}},$x=g.lazy(()=>Promise.resolve().then(()=>require("./css-import-modal-CXulmaB4.cjs")).then(t=>({default:t.CssImportModal}))),Ac="chai-builder-previous-theme",Fx=[{shadcn_default:Px},{twitter_theme:Lx},{solarized_theme:Mx},{claude_theme:Dx},{supabase_theme:Ox}],zx=t=>{if(!(typeof window>"u"))try{localStorage.setItem(Ac,JSON.stringify(t))}catch(e){console.warn("Failed to save previous theme to localStorage:",e)}},Hx=()=>{if(!(typeof window>"u"))try{localStorage.removeItem(Ac)}catch(t){console.warn("Failed to clear previous theme from localStorage:",t)}},Ic=D.memo(({className:t=""})=>{const[e,n]=an(),[s,r]=D.useState(""),[o,i]=D.useState(!1),l=$("themePresets",{}),c=$("themePanelComponent",null),{hasPermission:u}=Ve(),p=$("flags.importTheme",!0),f=$("flags.darkMode",!1),m=Hr(),h=Nr.useRegisteredFonts();(!l||l.length===0)&&Fx.map(C=>{l.push(C)});const[x,b]=_n(),y=nn(),{t:v}=F.useTranslation(),w=D.useCallback(C=>{const T={...x};zx(T),b(C),m(),ce.toast.success("Theme updated",{action:{label:a.jsxs("span",{className:"flex items-center gap-2",children:[a.jsx(k.ResetIcon,{className:"h-4 w-4"})," Undo"]}),onClick:()=>{b(T),Hx(),ce.toast.dismiss()}},closeButton:!0,duration:15e3})},[x,b,m]),I=()=>{const C=l.find(T=>Object.keys(T)[0]===s);if(C){const T=Object.values(C)[0];T&&typeof T=="object"&&"fontFamily"in T&&"borderRadius"in T&&"colors"in T?(w(T),r(""),m()):console.error("Invalid preset structure:",T)}else console.error("Preset not found:",s)},N=C=>{w(C),r(""),m()},E=ve.useDebouncedCallback((C,T)=>{b(()=>({...x,fontFamily:{...x.fontFamily,[C.replace(/font-/g,"")]:T}})),m()},[x,m],200),_=D.useCallback(C=>{b(()=>({...x,borderRadius:`${C}px`})),m()},[x,m]),S=ve.useDebouncedCallback((C,T)=>{b(()=>{const P=d.get(x,`colors.${C}`);return e?d.set(P,1,T):d.set(P,0,T),m(),{...x,colors:{...x.colors,[C]:P}}})},[x,m],200),A=C=>a.jsx("div",{className:"grid grid-cols-1",children:Object.entries(C.items).map(([T])=>{const P=d.get(x,`colors.${T}.${e?1:0}`);return P?a.jsxs("div",{id:`theme-${T}`,className:"mt-1 flex items-center gap-x-2",children:[a.jsx(Bx,{value:P,onChange:R=>S(T,R)}),a.jsx(ut,{className:"text-xs font-normal leading-tight",children:T.split(/(?=[A-Z])/).join(" ").replace(/-/g," ").split(" ").map(R=>R.charAt(0).toUpperCase()+R.slice(1)).join(" ")+(!T.toLowerCase().includes("foreground")&&!T.toLowerCase().includes("border")&&!T.toLowerCase().includes("input")&&!T.toLowerCase().includes("ring")&&!T.toLowerCase().includes("background")?" Background":"")})]},T):null})});return u("edit_theme")?a.jsxs("div",{className:"relative w-full",children:[a.jsxs("div",{className:ke.cn("no-scrollbar h-full w-full overflow-y-auto",t),children:[l.length>0&&a.jsxs("div",{className:"mx-0 my-2 flex flex-col gap-1 py-2",children:[a.jsxs("div",{className:"flex w-full items-center justify-between",children:[a.jsx(ut,{className:"text-sm",children:v("Presets")}),a.jsx("div",{className:"flex gap-2",children:p&&a.jsxs(B.Button,{className:"px-1",variant:"link",size:"sm",onClick:()=>i(!0),children:[a.jsx(k.UploadIcon,{className:"h-4 w-4"}),v("Import theme")]})})]}),a.jsxs("div",{className:"flex items-center gap-2 px-0",children:[a.jsx("div",{className:"w-[70%]",children:a.jsxs($s,{value:s,onValueChange:r,children:[a.jsx(Fn,{className:"h-9 w-full text-sm",children:a.jsx(Mo,{placeholder:v("Select preset")})}),a.jsx(zn,{children:Array.isArray(l)&&l.map(C=>{const T=Object.keys(C)[0],P=T.replaceAll("_"," ");return a.jsx(Hn,{value:T,children:d.capitalize(P)},T)})})]})}),a.jsx("div",{className:"w-[25%]",children:a.jsx(B.Button,{className:"w-full text-sm",disabled:!s,onClick:I,children:v("Apply")})})]})]}),a.jsx(Rt,{}),a.jsxs("div",{className:ke.cn("my-2 space-y-3",t),children:[h.length>0?a.jsxs(a.Fragment,{children:[a.jsxs("div",{className:"flex items-center gap-2",children:[a.jsx(k.TextIcon,{className:"h-3 w-3 text-gray-600"}),a.jsx("span",{className:"text-xs font-medium text-gray-700",children:v("Typography")})]}),(y==null?void 0:y.fontFamily)&&a.jsx("div",{className:"space-y-2",children:Object.entries(y.fontFamily).map(([C,T])=>a.jsx(Rx,{label:C,value:x.fontFamily[C.replace(/font-/g,"")]||T[Object.keys(T)[0]],onChange:P=>E(C,P)},C))}),a.jsx(Rt,{})]}):"",(y==null?void 0:y.borderRadius)&&a.jsxs("div",{className:"space-y-0.5",children:[a.jsxs("div",{className:"flex items-center justify-between",children:[a.jsxs("div",{className:"flex items-center gap-2",children:[a.jsx(k.CornerTopRightIcon,{className:"h-3 w-3 text-gray-600"}),a.jsx("span",{className:"text-xs font-medium text-gray-700",children:v("Border Radius")})]}),a.jsx(Rs,{variant:"secondary",className:"text-xs",children:x.borderRadius})]}),a.jsx("div",{className:"flex items-center gap-4 py-2",children:a.jsx(Tx,{value:x.borderRadius,onChange:_})})]}),a.jsx(Rt,{}),(y==null?void 0:y.colors)&&a.jsxs("div",{className:"space-y-3",children:[a.jsxs("div",{className:"flex items-center justify-between",children:[a.jsxs("div",{className:"flex items-center gap-2",children:[a.jsx(k.MixerHorizontalIcon,{className:"h-3 w-3 text-gray-600"}),a.jsx("span",{className:"text-xs font-medium text-gray-700",children:v("Colors")})]}),f&&a.jsxs("div",{className:"flex items-center gap-2",children:[a.jsx(k.SunIcon,{className:"h-4 w-4"}),a.jsx(un,{checked:e,onCheckedChange:C=>n(C),"aria-label":v("Toggle dark mode"),className:"mx-1"}),a.jsx(k.MoonIcon,{className:"h-4 w-4"})]})]}),a.jsx("div",{className:"space-y-2",children:y.colors.map(C=>a.jsx("div",{children:A(C)},C.group))})]}),a.jsx(g.Suspense,{fallback:a.jsx("div",{children:v("Loading...")}),children:o&&p&&a.jsx($x,{open:o,onOpenChange:i,onImport:N})})]}),a.jsx("br",{}),a.jsx("br",{}),a.jsx("br",{}),a.jsx("br",{})]}),c&&a.jsx("div",{className:"absolute bottom-4 w-full",children:D.createElement(c)})]}):a.jsx("div",{className:"relative w-full",children:a.jsx("div",{className:ke.cn("no-scrollbar h-full w-full overflow-y-auto text-center",t),children:a.jsx("div",{className:"mt-10 h-full items-center justify-center gap-2 text-muted-foreground",children:a.jsx("p",{className:"text-sm",children:v("You don't have permission to edit the theme. Please contact your administrator to get access.")})})})})}),Vx="Core",Wx="Import",Gx="Breakpoints",Ux="Clear",qx="Cancel",Kx="Yes",Yx="Preview",Xx="Settings",Jx="Style",Zx="Enter SVG code here",Qx="Remove",eb="Choose",tb="Cut",nb="Copy",sb="Paste",rb="Delete",ob="classes",ab="Theme",ib="Outline",lb="Copied",cb="Stop",db="Edit",ub="Tag",pb="Value",fb="URL",hb="Images",mb="Library",gb="Blocks",xb="Basic",bb="Media",yb="Advanced",kb="Form",vb="Groups",wb="Accordions",Cb="Buttons",jb="Layouts",Sb="FAQ",Nb="Hero",Eb="Features",Ab="Footer",Ib="Navbar",_b="Icons",Tb="Testimonials",Bb="Blog",Rb="Saved",Pb="Unsaved",Lb="Randomize",Mb="Classes",Db="All",Ob="Undo",$b="Redo",Fb="Duplicate",zb="Close",Hb="Selected",Vb="Select",Wb="Attributes",Gb="apply",Ub="presets",qb="Orientation",Kb="Color",Yb="Upload",Xb="Apply",Jb="Back",Zb="Insert",Qb="Rename",ey="Partials",ty="Happy",ny="Sad",sy="Retry",ry="Canvas is empty",oy="Presets",ay="No",iy="Saving",ly={heading_font:"Heading Font",body_font:"Body Font",rounded_corner:"Rounded Corners",primary:"Primary",secondary:"Secondary",background:"Background",text_color:"Text Color",background_dark_mode:"Background (Dark Mode)",text_color_dark_mode:"Text Color (Dark Mode)"},cy={box:"box",tag:"Tag",div:"div",level:"Level",header:"header",footer:"footer",section:"section",article:"article",aside:"aside",main:"main",nav:"navigation",figure:"figure",details:"details",summary:"summary",dialog:"dialog",strike:"strike",caption:"caption",legend:"legend",figcaption:"figure caption",mark:"mark",background_image:"Background Image",label:"Label",default:"default",icon_size:"Icon Size",icon_position:"Icon Position",start:"Start",end:"End",button:"Button",custom_html:"Custom HTML",html_code:"HTML Code",default_snippet:"The HTML snippet goes here...",placeholder:"Enter custom HTML code here",custom_script:"Custom Script",dark_mode:"Dark Mode",divider:"Divider",empty_box:"Empty Box",heading:"Heading",image:"Image",alt:"Alt",width:"Width",height:"Height",video:"Video",span:"Span",content:"Content",icon:"Icon",richtext:"Rich Text",list:"List",list_type:"List Type",listitem:"List Item",link:"Link",list_item:"List Item",none:"None",disc:"Disc",number:"Number",paragraph:"Paragraph",lightbox_link:"Lightbox Link",href:"Link",type:"Type",iframe:"iframe",inline:"inline",ajax:"ajax",autoplay:"Video autoplay",max_width:"Max Width",backdrop_color:"Background Color",gallery_name:"Gallery Name",slot:"Slot",empty_slot:"Empty Slot",text:"Text",video_url:"Video URL",controls:"Show Controls",loop:"Loop",muted:"Muted",checkbox:"Checkbox",required:"Required",checked:"Checked",submit_button:"Submit Button",form:"Form",submit_url:"Submit URL",error_message:"Error Message",success_message:"Success Message",input:"Input",value:"Value",show_label:"Show Label",field_name:"Field Name",radio:"Radio",multiple:"Multiple",options:"Options",select:"Select",multiple_choice:"Multiple Choice",textarea:"Textarea",rows:"Rows"},dy="Add",uy="Save",py="Screen",fy={"Add block":"Add Block","Add Block":"Add Block","Add blocks":"Add blocks","Add inside":"Add inside","Add before":"Add before","Add after":"Add after","Add block inside":"Add block inside","Add field":"Add field","Enter or paste TailwindCSS HTML snippet":"Enter or paste TailwindCSS HTML snippet","Click to add block to page":"Click to add block to page",Core:Vx,"Custom Blocks":"Custom Blocks","UI Library":"UI Library",Import:Wx,"Use HTML snippets from Tailwind CSS component libraries":"Use HTML snippets from Tailwind CSS component libraries","Tailwind HTML snippet":"Tailwind HTML snippet","Enter your code snippet here":"Enter your code snippet here","Import HTML":"Import HTML","Imported HTML Note":"NOTE: Imported html will be added to the currently selected block. If no block is selected, the html will be added to the page.","Dark Mode":"Dark Mode","This page has no blocks. Add a block by clicking the + button":"This page has no blocks. Add a block by clicking the + button","This page is empty":"This page is empty","Please select a block to edit settings or styles":"Please select a block to edit settings or styles","Please select a block to Ask AI":"Please select a block to ask AI","Please select a styling block":"Please select a styling block","Drop your block here":"Drop your block here","Use setting":"Use setting","Mobile (XS)":"Mobile (XS)","Styles set here are applied to all screen unless edited at higher breakpoint":"Styles set here are applied to all screen unless edited at higher breakpoint","Mobile landscape (SM)":"Mobile landscape (SM)","Styles set here are applied at 640px and up unless edited at higher breakpoint":"Styles set here are applied at 640px and up unless edited at higher breakpoint","Tablet (MD)":"Tablet (MD)","Styles set here are applied at 768px and up":"Styles set here are applied at 768px and up","Tablet Landscape (LG)":"Tablet Landscape (LG)","Styles set here are applied at 1024px and up unless edited at higher breakpoint":"Styles set here are applied at 1024px and up unless edited at higher breakpoint","Desktop (XL)":"Desktop (XL)","Styles set here are applied at 1280px and up unless edited at higher breakpoint":"Styles set here are applied at 1280px and up unless edited at higher breakpoint","Large Desktop (2XL)":"Large Desktop (2XL)","Styles set here are applied at 1536px and up":"Styles set here are applied at 1536px and up",Breakpoints:Gx,Clear:Ux,"Clear whole canvas?":"Clear whole canvas?","Are you sure you want to clear the whole canvas?":"Are you sure you want to clear the whole canvas?",Cancel:qx,Yes:Kx,Preview:Yx,Settings:Xx,Styling:Jx,SVG_code:Zx,"Paste SVG_code":"Choose icon or paste SVG code","Enter Key":"Enter Key","Data Provider":"Data Provider","Remove Provider Confirmation":"Are you sure you want to remove <span class='text-blue-500'>{name}</span> provider?","Your data provider will be removed from this page and all added data binding will be not visible on blocks.":"Your data provider will be removed from this page and all added data binding will be not visible on blocks.",Remove:Qx,"You have no data providers registered. Please add a data provider to your project.":"You have no data providers registered. Please add a data provider to your project.","Learn more":"Learn more","Add data providers:":"Add data providers:","Select a provider":"Select a provider",Choose:eb,"Page data providers:":"Page data providers:","View Data":"View Data","Mark as Global":"Mark as Global","Note: Global blocks are single instances. Editing global blocks will be reflected on all pages using these blocks.":"Note: Global blocks are single instances. Editing global blocks will be reflected on all pages using these blocks.","Global blocks are indicated with":"Global blocks are indicated with","Global blocks are available under 'Global' category":"Global blocks are available under 'Global' category","Enter global block name":"Enter global block name","Eg: Header, Footer":"Eg: Header, Footer","{length} blocks selected.":"{length} blocks selected.",Cut:tb,Copy:nb,Paste:sb,Delete:rb,"Clear Selection":"Clear Selection","This is dev mode. Visit":"This is dev mode. Visit","to see page preview":"to see page preview",classes:ob,Theme:ab,Outline:ib,"Not supported":"Not supported","Please use Chrome, Firefox or Safari":"Please use Chrome, Firefox or Safari","Download Complete":"Download complete",Copied:lb,"Enter Classes":"Add classes or design tokens (space-separated)","Ask AI":"Ask AI","Edit with AI":"Edit with AI","Generating... Please wait...":"Generating... Please wait...","Saving... Please wait...":"Saving... Please wait...","Deleting... Please wait...":"Deleting... Please wait...",Stop:cb,"E.g.: This page is about an AI assistant app called Chai Studio. It allows users to create beautiful webpages and edit content with AI":"E.g.: This page is about an AI assistant app called Chai Studio. It allows users to create beautiful webpages and edit content with AI.","Ask AI to edit styles":"Ask AI to edit styles","Ask AI to edit content":"Ask AI to edit content","AI Context":"AI Context","Select Block for AI":"Select a block to edit with AI","Select Block to Edit":"Please select a block to edit",Edit:db,"Describe this page. E.g.: This page is about...":"Describe this page. E.g.: This page is about...",Tag:ub,Value:pb,"Background Image":"Background Image","Enter image URL":"Enter image URL","Enter URL":"Enter URL",URL:fb,"Replace image":"Replace image","Choose image":"Choose image",Images:hb,Library:mb,Blocks:gb,Basic:xb,Media:bb,Advanced:yb,Form:kb,"Choose Icon or SVG":"Choose an icon or enter SVG",Groups:vb,"UI Libraries":"UI Libraries",Accordions:wb,Buttons:Cb,Layouts:jb,"Choose Library":"Choose library","No Library Found":"No library found.",FAQ:Sb,Hero:Nb,Features:Eb,Footer:Ab,Navbar:Ib,Icons:_b,Testimonials:Tb,Blog:Bb,"Remove context":"Remove context","Yes, Delete":"Yes, Delete","AI Context Updated":"AI Context Updated","You can now ask AI to edit your content.":"You can now ask AI to edit your content.",Saved:Rb,Unsaved:Pb,"Saving...":"Saving...","Improve writing":"Improve writing","Replace placeholder content":"Replace placeholder content","Discard current placeholder content and replace with meaningful relevant content.":"Discard current placeholder content and replace with meaningful relevant content.","Fix grammar":"Fix grammar","Fix grammar in all text elements. Ensuring the text is grammatically correct and free of errors.":"Fix grammar in all text elements. Ensuring the text is grammatically correct and free of errors.","Make longer":"Make longer","Make all text elements longer.":"Make all text elements longer.","Make shorter":"Make shorter","Make all text elements shorter.":"Make all text elements shorter.","Add emojis":"Add emojis","Add emojis to text elements if relevant.":"Add emojis to text elements if relevant.",Randomize:Lb,"Randomize all text elements.":"Randomize all text elements.","Edit Block":"Edit Block","AI Assistant":"AI Assistant","Theme Config":{"Heading Font":"Heading Font","Body Font":"Body Font","Rounded Corner":"Rounded Corners",Primary:"Primary",Secondary:"Secondary",Background:"Background","Text Color":"Text Color","Background Dark Mode":"Background (Dark Mode)","Text Color Dark Mode":"Text Color (Dark Mode)","Reset styles":"Reset styles"},"Copy classes to clipboard":"Copy classes to clipboard","Classes copied to clipboard":"Classes copied to clipboard",Classes:Mb,All:Db,"Enter classes separated by space":"Add classes or design tokens (space-separated)","Show hidden blocks":"Show hidden blocks","Expand all":"Expand all","Collapse all":"Collapse all","Choose library":"Choose library","Close Preview":"Close Preview",Error:"Error","Failed to copy template":"Failed to copy template","Total tokens used":"Total tokens used","Updated AI Context":"Updated AI Context","You can now Ask AI to edit your content":"You can now Ask AI to edit your content","Tell about this page eg this page is about":"Tell about this page eg this page is about..","Delete Context":"Delete Context","Keyboard shortcuts":"Keyboard shortcuts",Undo:Ob,Redo:$b,Duplicate:Fb,"Deselect blocks":"Deselect blocks","Delete block":"Delete block","Save page":"Save page","Scripts will be only executed in preview and live mode.":"Scripts will be only executed in preview and live mode.","HTML Code Editor |":"HTML Code Editor |",Close:zb,"Coming soon":"Coming soon",Selected:Hb,Select:Vb,"Choose Builder Layout":"Choose Builder Layout","Single side panel":"Single side panel","Suitable for smaller screens. Bigger canvas size.":"Suitable for smaller screens. Bigger canvas size.","Dual side panel":"Dual side panel","Suitable for larger screens. Smaller canvas size.":"Suitable for larger screens. Smaller canvas size.","Dual side panel advanced":"Dual side panel advanced","Suitable for heavy styling & block editing. Setting are always visible.":"Suitable for heavy styling & block editing. Setting are always visible.","Block Settings":"Block Settings","Visibility settings":"Visibility settings","Show on canvas":"Show on canvas",Attributes:Wb,"Apply Presets":"Apply Presets",apply:Gb,presets:Ub,"Global presets":"Global presets",Orientation:qb,Color:Kb,"Please select an image":"Please select an image","click to upload":"click to upload","SVG, PNG, JPG or GIF (Max. 2mb)":"SVG, PNG, JPG or GIF (Max. 2mb)","Uploading...":"Uploading...",Upload:Yb,"Something went wrong":"Something went wrong","Fetching...":"Fetching...","No images found":"No images found","It looks like you haven't uploaded any images yet. Start by clicking the upload button above.":"It looks like you haven't uploaded any images yet. Start by clicking the upload button above.","Open Code Editor":"Open Code Editor","Clear search":"Clear search","No results found for":"No results found for","Search {{pageTypeName}}":"Search {{pageTypeName}}","Goto Page":"Goto Page","Open URL":"Open URL","Compose Email":"Compose Email","Call Phone":"Call Phone","Scroll to element":"Scroll to element","#ElementID":"#ElementID","Enter details":"Enter details","Open in new tab":"Open in new tab",Apply:Xb,Back:Jb,Insert:Zb,Rename:Qb,"Unlink from library":"Unlink from library","Save to Library":"Save to Library","No blocks found in this group":"No blocks found in this group","No blocks found matching":"No blocks found matching","No matching blocks found":"No matching blocks found","Search blocks...":"Search blocks...",Partials:ey,Happy:ty,Sad:ny,"Importing...":"Importing...","Failed to load the UI library. Try again":"Failed to load the UI library. Try again",Retry:sy,"Oops! Something went wrong.":"Oops! Something went wrong.","Please try again.":"Please try again.","No option found.":"No option found.","Clipboard not supported":"Clipboard not supported","Are you sure you want to clear the page?":"Are you sure you want to clear the page?",canvas_empty:ry,Presets:oy,"Reset style":"Reset style","Reset styles":"Reset styles","Clear styles":"Clear styles","Open code editor":"Open code editor","Style element":"Style element","Repeater Data":"Repeater Data","Toggle Data Binding":"Toggle Data Binding",No:ay,Saving:iy,"Screen sizes":"Screen sizes","Theme Settings":"Theme Settings","Import CSS Theme":"Import CSS Theme","Import theme":"Import theme","Import Theme":"Import Theme","CSS Variables":"CSS Variables","You don't have permission to edit settings or styles":"You don't have permission to edit settings or styles","Please contact your administrator to get access":"Please contact your administrator to get access","flex.heading":"Flex Child","flex.basis":"Basis","flex.order":"Order","flex.flex":"Flex","flex.grow":"Grow","flex.shrink":"Shrink","grid.heading":"Grid Child","grid.col_span":"Col Span","grid.col_start":"Col Start","grid.col_end":"Col End","grid.row_span":"Row Span","grid.row_start":"Row Start","grid.row_end":"Row End","grid.order":"Order","layout.heading":"Layout","layout.width":"Width","layout.height":"Height","layout.margin":"Margin","layout.margin_all":"All","layout.margin_lr":"Left-Right","layout.margin_tb":"Top-Bottom","layout.margin_top":"Top","layout.margin_right":"Right","layout.margin_bottom":"Bottom","layout.margin_left":"Left","layout.padding":"Padding","layout.padding_all":"All","layout.padding_lr":"Left-Right","layout.padding_tb":"Top-Bottom","layout.padding_top":"Top","layout.padding_right":"Right","layout.padding_bottom":"Bottom","layout.padding_left":"Left","layout.space_bt":"Space Bt.","layout.space_lr":"Left-Right","layout.space_tb":"Top-Bottom","size.heading":"Size","size.min_width_height":"Min width & height","size.min_width":"Min Width","size.min_height":"Min Height","size.max_width_height":"Max width & height","size.max_width":"Max Width","size.max_height":"Max Height","size.object_options_aspect_ratio":"Object options & aspect ratio","size.aspect":"Aspect","size.fit":"Fit","size.position":"Position","display.heading":"Display","display.display":"Display","display.flex_options":"Flex options","display.flex_direction":"Direction","display.flex_wrap":"Wrap","display.justify_content":"Justify","display.align_content":"Content","display.align_items":"Items","display.gap":"Gap","display.gap_all":"All","display.gap_lr":"Left-Right","display.gap_tb":"Top-Bottom","display.grid_options":"Grid options","display.grid_columns":"Columns","display.grid_rows":"Rows","display.grid_auto_flow":"Auto Flow","display.grid_auto_cols":"Auto Cols","display.grid_auto_rows":"Auto Rows","display.visibility_opacity":"Visibility & Opacity","display.visibility":"Visibility","display.opacity":"Opacity","position.heading":"Position","position.position":"Position","position.options":"Position options","position.direction":"Direction","position.top":"Top","position.right":"Right","position.bottom":"Bottom","position.left":"Left","position.inset":"Inset","position.all":"All","position.lr":"Left Right","position.tb":"Top Bottom","position.z_index":"Z-Index","position.float_clear":"Float & Clear","position.float":"Float","position.clear":"Clear","position.overflow_overscroll":"Overflow & Overscroll","position.overflow":"Overflow","position.overscroll":"Overscroll","typography.heading":"Typography","typography.font":"Font","typography.size":"Size","typography.height":"Height","typography.weight":"Weight","typography.color":"Color","typography.alignments":"Alignments","typography.align":"Align","typography.valign":"V. Align","typography.spacing_decoration_more":"Spacing, decoration & more","typography.spacing":"Spacing","typography.decoration":"Decoration","typography.thickness":"Thickness","typography.transform":"Transform","typography.whitespace_breaks":"White space & breaks","typography.whitespace":"Whitespace","typography.wordbreak":"Wordbreak","background.heading":"Background","background.bgcolor":"Bg. Color","background.position_size_more":"Position, Size & more","background.attachment":"Attachment","background.clipping":"Clipping","background.origin":"Origin","background.position":"Position","background.repeat":"Repeat","background.size":"Size","background.gradient":"Gradient","background.gradient_colors":"Gradient colors","background.from_color":"From","background.via_color":"Via","background.to_color":"To","border.heading":"Border & Outline","border.width":"Width","border.all":"All","border.lr":"Left Right","border.tb":"Top bottom","border.top":"Top","border.right":"Right","border.bottom":"Bottom","border.left":"Left","border.corners":"Corners","border.top_left":"Top Left","border.top_right":"Top right","border.bottom_right":"Bottom right","border.bottom_left":"Bottom left","border.color":"Color","border.style":"Style","border.divide_options":"Divide options","border.divide_color":"Color","border.divide_style":"Style","border.outline_styling":"Outline styling","border.outline_width":"Width","border.outline_offset":"Offset","border.outline_style":"Style","border.ring_options":"Ring options","border.ring_width":"Width","border.ring_color":"Color","border.ring_offset_width":"Offset","border.ring_offset_color":"Off. color","effect.heading":"Effect & Animation","effect.shadow":"Shadow","effect.color":"Color","effect.cursor":"Cursor","effect.blend_cursor":"Blend & Cursor","effect.mix_blend":"Mix Blend","effect.bg_blend":"Bg. Blend","effect.transform":"Transform","effect.origin":"Origin","effect.scale":"Scale","effect.all":"All","effect.lr":"Left-Right","effect.tb":"Top-Bottom","effect.skew":"Skew","effect.translate":"Translate","effect.rotate":"Rotate","effect.animation":"Animation","effect.transition":"Transition","effect.easing":"Easing","effect.duration":"Duration","effect.delay":"Delay","classes.heading":"Classes",theme_config:ly,web_blocks:cy,"Export Code":"Export Code","Exporting {{count}} blocks":"Exporting {{count}} blocks","Exporting all blocks":"Exporting all blocks","Export code copied!":"Export code copied!","Failed to copy export code":"Failed to copy export code","Export code downloaded successfully!":"Export code downloaded successfully!","Failed to generate export HTML":"Failed to generate export HTML","Enter value":"Enter value","Attribute keys cannot start with @":"Attribute keys cannot start with @","Enter key":"Enter key",Add:dy,Save:uy,Screen:py};mt.use(F.initReactI18next).init({resources:{en:{translation:fy}},lng:"en",fallbackLng:"en",interpolation:{escapeValue:!1}});function hy(t,e,n){n.push(d.find(t,{_id:e}));const s=d.filter(t,{_parent:e});for(const r of s)n.push(..._c(r._id,t));return n}const _c=(t,e)=>{let n=[];return n=d.flattenDeep([...n,...hy(e,t,n)]),n},my=(t,e,n)=>d.compact(t.map(s=>{const r=["_id","_type","_parent"],o=d.pick(s,r),i=K.getRegisteredChaiBlock(s._type),l={},c=d.get(i,"aiProps",[]);for(const u in s)if(!r.includes(u)&&c.includes(u)){const p=d.get(s,`${u}-${e}`,""),f=d.get(s,u,"");l[u]=d.isString(p)&&p.trim()||f,n&&(l[u]=f)}return d.isEmpty(l)?!1:(d.has(o,"_parent")&&d.isEmpty(o._parent)&&delete o._parent,{...o,...l})})),gy=(t,e,n)=>!e||n!=="content"?t:`${t}. Generate content in ${d.get(Ot,e,e)} language.`,xy=j.atom(!1),Tc=()=>{const[t,e]=j.useAtom(xy),[n,s]=g.useState(null),r=$("askAiCallBack",d.noop),o=ri(),i=Vd(),[l]=Z(),{selectedLang:c,fallbackLang:u}=_e(),p=c.length?c:u,f=(m,h)=>{const x=d.cloneDeep(h.find(b=>b._id===m));for(const b in x){const y=x[b];if(typeof y=="string"&&d.startsWith(y,q.STYLES_KEY)){const{baseClasses:v,classes:w}=pe.getSplitChaiClasses(y);x[b]=d.compact(d.flattenDeep([v,w])).join(" ")}else b!=="_id"&&delete x[b]}return x};return{askAi:g.useCallback(async(m,h,x,b)=>{if(r){e(!0),s(null);try{const y=c===u?"":c,v=x.toLowerCase().includes("translate the content"),w=m==="content"?my(d.cloneDeep(_c(h,l)),c,v):[f(h,l)],I=await r(m,gy(x,p,m),w,y);if(I===void 0)return;const{blocks:N,error:E}=I;if(E){s(E);return}if(m==="styles"){const _=N.map(S=>{for(const A in S)A!=="_id"&&(S[A]=`${q.STYLES_KEY},${S[A]}`);return S});i(_)}else o(N);b&&b(I)}catch(y){s(y)}finally{e(!1),b&&b()}}},[r,e,c,u,l,p,i,o]),loading:t,error:n}};function by({onClick:t}){const{loading:e}=Tc(),{t:n}=F.useTranslation(),{selectedLang:s,fallbackLang:r}=_e(),i=[...[{name:n("Improve writing"),icon:k.Pencil2Icon,prompt:n("Improving writing in all text elements. Replacing placeholder content with meaningful relevant content.")},{name:n("Replace placeholder content"),icon:k.LoopIcon,prompt:n("Discard current placeholder content and replace with meaningful relevant content.")},{name:n("Fix grammar"),icon:k.CheckIcon,prompt:n("Fix grammar in all text elements. Ensuring the text is grammatically correct and free of errors.")},{name:n("Make longer"),icon:k.ArrowUpIcon,prompt:n("Make all text elements longer.")},{name:n("Make shorter"),icon:k.ArrowDownIcon,prompt:n("Make all text elements shorter.")},{name:n("Add emojis"),icon:k.FaceIcon,prompt:n("Add emojis to text elements if relevant.")},{name:n("Randomize"),icon:k.ShuffleIcon,prompt:n("Randomize all text elements.")}]];return s&&s!==r&&i.splice(0,0,{name:n("Translate to {{lang}}",{lang:d.get(Ot,s,s)}),icon:k.ChatBubbleIcon,prompt:n("Translate the content to {{lang}}. Maintain same tone, style and length.",{lang:d.get(Ot,s,s)})}),a.jsx("div",{className:e?"pointer-events-none opacity-50":"",children:a.jsx("ul",{className:"space-y-1",children:i.map(({name:l,icon:c,subMenus:u,prompt:p})=>u?a.jsxs(vo,{children:[a.jsx(wo,{asChild:!0,children:a.jsxs("li",{className:"flex cursor-pointer items-center space-x-2 rounded p-1 pl-2 text-sm hover:bg-gray-100 dark:hover:bg-gray-800",children:[a.jsx(c,{className:"h-4 w-4"}),a.jsx("span",{children:l})]},l)}),a.jsx(Ps,{side:"right",children:a.jsx("ul",{children:a.jsx("li",{children:n("Happy")})})})]}):a.jsxs("li",{onClick:()=>t(p),className:"flex cursor-pointer items-center space-x-2 rounded p-1 text-xs hover:bg-primary/10 hover:text-primary dark:hover:bg-gray-800",children:[a.jsx(c,{className:"h-3.5 w-3.5"}),a.jsx("span",{children:n(l)})]},l))})})}const Bc=({blockId:t})=>{const{t:e}=F.useTranslation(),{askAi:n,loading:s,error:r}=Tc(),[o,i]=g.useState(""),l=g.useRef(null),c=g.useRef(null),u=J();g.useEffect(()=>{var f;(f=l.current)==null||f.focus()},[]);const p=()=>{r||i("")};return a.jsx("div",{className:"",children:t?a.jsxs("div",{className:"",children:[a.jsx("label",{className:"text-xs font-medium text-gray-500",children:e("Selected block")}),u&&a.jsxs("div",{className:"flex items-center gap-x-1 rounded border border-primary/20 bg-primary/10 p-1.5 text-xs text-primary",children:[a.jsx(Oo,{type:u._type})," ",a.jsx("p",{className:"truncate whitespace-nowrap leading-none",children:u._name||u._type})]}),a.jsx("br",{}),a.jsx("label",{className:"text-xs font-medium text-gray-500",children:e("Quick actions")}),a.jsx("div",{className:"rounded border p-2 text-sm",children:a.jsx(by,{onClick:f=>{c.current&&clearTimeout(c.current),n("content",t,f,p)}})}),a.jsx("br",{}),a.jsx("label",{className:"text-xs font-medium text-gray-500",children:e("Ask AI")}),a.jsxs("div",{className:"rounded border p-2 text-xs focus-within:border-gray-300",children:[a.jsx($n,{ref:l,value:o,onChange:f=>i(f.target.value),placeholder:e("Ask AI to edit content"),className:"w-full resize-none border-none p-0 text-xs shadow-none outline-none",rows:3,onKeyDown:f=>{f.key==="Enter"&&(f.preventDefault(),c.current&&clearTimeout(c.current),n("content",t,o,p))}}),a.jsxs("div",{className:"flex items-center justify-end",children:[s&&a.jsx(B.Button,{variant:"destructive",onClick:()=>stop(),className:"hidden h-4 w-4",size:"icon",children:a.jsx(k.StopIcon,{className:"h-4 w-4"})}),a.jsx(B.Button,{onClick:()=>{c.current&&clearTimeout(c.current),n("content",t,o,p)},variant:"default",className:"h-7 w-7",disabled:s||o.trim().length<1,size:"icon",children:s?a.jsx(k.ReloadIcon,{className:"h-4 w-4 animate-spin"}):a.jsx(k.ArrowTopRightIcon,{className:"h-4 w-4"})})]})]}),a.jsx("div",{className:"max-w-full pt-2",children:r&&a.jsx("p",{className:"break-words rounded border border-red-500 bg-red-100 p-1 text-xs text-red-500",children:r.message})})]}):a.jsx("div",{className:"p-4 text-center",children:a.jsxs("div",{className:"space-y-4 rounded-xl p-4 text-muted-foreground",children:[a.jsx(Er,{className:"mx-auto h-7 w-7 text-muted-foreground"}),a.jsx("h1",{children:e("Please select a block to Ask AI")})]})})})},Rc=()=>{const[t]=U();return a.jsx("div",{className:"no-scrollbar mt-2 flex-1 overflow-y-auto",children:a.jsx(Bc,{blockId:d.first(t)})})};function Pc(){const[t,e]=an();return a.jsxs("div",{className:"flex items-center",children:[t?a.jsx(k.MoonIcon,{className:"size-4 shrink-0"}):a.jsx(k.SunIcon,{className:"size-4 shrink-0"}),a.jsx(un,{id:"dark-mode-switch",checked:t,onCheckedChange:()=>{e(!t)},className:`${t?"bg-violet-600":"bg-violet-300"} relative ml-2 inline-flex h-[20px] w-[32px] shrink-0 cursor-pointer rounded-full border-2 border-transparent transition-colors duration-200 ease-in-out focus:outline-none focus-visible:ring-2 focus-visible:ring-white focus-visible:ring-opacity-75`,children:a.jsx("span",{"aria-hidden":"true",className:`${t?"translate-x-5":"translate-x-0"} pointer-events-none -mt-px inline-block h-[18px] w-[20px] transform rounded-full bg-white shadow-lg ring-0 transition duration-200 ease-in-out`})})]})}const Lc=()=>{const{hasUndo:t,hasRedo:e,undo:n,redo:s}=Tn();return a.jsxs("div",{className:"flex items-center",children:[a.jsx(B.Button,{disabled:!t(),size:"sm",onClick:n,className:"rounded-full",variant:"ghost",children:a.jsx(k.ResetIcon,{})}),a.jsx(B.Button,{disabled:!e(),onClick:s,size:"sm",className:"rounded-full",variant:"ghost",children:a.jsx(k.ResetIcon,{className:"rotate-180 scale-y-[-1] transform"})})]})},Mc=ae.Root,yy=ae.Trigger,ky=ae.Portal,Dc=D.forwardRef(({className:t,...e},n)=>a.jsx(ae.Overlay,{className:B.cn("fixed inset-0 z-50 bg-black/80 data-[state=open]:animate-in data-[state=closed]:animate-out data-[state=closed]:fade-out-0 data-[state=open]:fade-in-0",t),...e,ref:n}));Dc.displayName=ae.Overlay.displayName;const vy=Sr.cva("fixed z-50 gap-4 bg-background p-6 shadow-lg transition ease-in-out data-[state=closed]:duration-300 data-[state=open]:duration-500 data-[state=open]:animate-in data-[state=closed]:animate-out",{variants:{side:{top:"inset-x-0 top-0 border-b data-[state=closed]:slide-out-to-top data-[state=open]:slide-in-from-top",bottom:"inset-x-0 bottom-0 border-t data-[state=closed]:slide-out-to-bottom data-[state=open]:slide-in-from-bottom",left:"inset-y-0 left-0 h-full w-3/4 border-r data-[state=closed]:slide-out-to-left data-[state=open]:slide-in-from-left sm:max-w-sm",right:"inset-y-0 right-0 h-full w-3/4 border-l data-[state=closed]:slide-out-to-right data-[state=open]:slide-in-from-right sm:max-w-sm"}},defaultVariants:{side:"right"}}),Wo=D.forwardRef(({side:t="right",className:e,children:n,...s},r)=>a.jsxs(ky,{children:[a.jsx(Dc,{}),a.jsxs(ae.Content,{ref:r,className:B.cn(vy({side:t}),e),...s,children:[a.jsxs(ae.Close,{className:"absolute right-4 top-4 rounded-sm opacity-70 ring-offset-background transition-opacity hover:opacity-100 focus:outline-none focus:ring-2 focus:ring-ring focus:ring-offset-2 disabled:pointer-events-none data-[state=open]:bg-secondary",children:[a.jsx(k.Cross1Icon,{className:"h-4 w-4"}),a.jsx("span",{className:"sr-only",children:"Close"})]}),n]})]}));Wo.displayName=ae.Content.displayName;const Go=({className:t,...e})=>a.jsx("div",{className:B.cn("flex flex-col space-y-2 text-center sm:text-left",t),...e});Go.displayName="SheetHeader";const Uo=D.forwardRef(({className:t,...e},n)=>a.jsx(ae.Title,{ref:n,className:B.cn("text-lg font-semibold text-foreground",t),...e}));Uo.displayName=ae.Title.displayName;const Oc=D.forwardRef(({className:t,...e},n)=>a.jsx(ae.Description,{ref:n,className:B.cn("text-sm text-muted-foreground",t),...e}));Oc.displayName=ae.Description.displayName;const $c=()=>{const{t}=F.useTranslation(),[e,n]=g.useState(null),[s,r]=g.useState(-1),[o,i]=g.useState(!1),l=Ye(),[,c]=Is();return Yt(Y.OPEN_ADD_BLOCK,u=>{l?c("add-block"):(n(u?u._id:null),r((u==null?void 0:u.position)??-1),i(!0))}),Yt(Y.CLOSE_ADD_BLOCK,()=>{n(null),r(-1),i(!1)}),a.jsx($o,{open:o,onOpenChange:()=>o?i(!1):"",children:a.jsxs(Fs,{className:"max-w-5xl overflow-hidden border-border",children:[a.jsxs(zs,{className:"flex flex-row items-center justify-between",children:[a.jsx(Hs,{className:"text-foreground",children:t("Add blocks")}),a.jsx("button",{onClick:()=>i(!1),className:"text-gray-500 hover:text-gray-600 dark:text-gray-400 dark:hover:text-gray-300",children:a.jsx(k.Cross2Icon,{className:"h-6 w-6"})})]}),a.jsx("div",{className:"no-scrollbar h-[500px] max-h-full overflow-hidden",children:a.jsx(Do,{parentId:e??"",position:s,showHeading:!1})})]})})},wy=g.memo(function({preloadedAttributes:e=[],onAttributesChange:n}){const[s,r]=g.useState([]),[o,i]=g.useState(""),[l,c]=g.useState(""),[u,p]=g.useState(null),[f,m]=g.useState(""),h=g.useRef(null),x=g.useRef(null),b=tn(),{t:y}=F.useTranslation();g.useEffect(()=>{r(e)},[e]);const v=()=>{if(o.startsWith("@")){m(y("Attribute keys cannot start with @"));return}if(o){const S=[...s,{key:o,value:l}];n==null||n(S),r(s),i(""),c(""),m("")}},w=S=>{const A=s.filter((C,T)=>T!==S);n==null||n(A),r(A)},I=S=>{p(S),i(s[S].key),c(s[S].value)},N=()=>{if(o.startsWith("@")){m(y("Attribute keys cannot start with @"));return}if(u!==null&&o){const S=[...s];S[u]={key:o,value:l},n==null||n(S),r(S),p(null),i(""),c(""),m("")}},E=S=>{S.key==="Enter"&&!S.shiftKey&&(S.preventDefault(),u!==null?N():v())},_=g.useCallback(S=>{const A=P=>/[.,!?;:]/.test(P),C=(P,R,O)=>{let H="",G="";const me=R>0?P[R-1]:"",ie=R<P.length?P[R]:"";return R>0&&(me==="."||!A(me)&&me!==" ")&&(H=" "),R<P.length&&!A(ie)&&ie!==" "&&(G=" "),{text:H+O+G,prefixLength:H.length,suffixLength:G.length}},T=x.current;if(T){const P=T.selectionStart||0,R=T.value||"",O=T.selectionEnd||P;if(O>P){const ne=`{{${S}}}`,{text:we}=C(R,P,ne),Oe=R.slice(0,P)+we+R.slice(O);c(Oe);return}const G=`{{${S}}}`,{text:me}=C(R,P,G),ie=R.slice(0,P)+me+R.slice(P);c(ie)}},[]);return a.jsxs("div",{className:"flex max-h-full flex-1 flex-col",children:[a.jsxs("form",{onSubmit:S=>{S.preventDefault(),u!==null?N():v()},className:"space-y-3",children:[a.jsxs("div",{className:"flex flex-col gap-y-1",children:[a.jsxs("div",{className:"w-full",children:[a.jsx(ut,{htmlFor:"attrKey",className:"text-[11px] font-normal leading-tight text-slate-600",children:y("Key")}),a.jsx(B.Input,{autoCapitalize:"off",autoCorrect:"off",spellCheck:"false",id:"attrKey",ref:h,value:o,onChange:S=>i(S.target.value),placeholder:y("Enter key"),className:"py-0 text-xs font-normal leading-tight placeholder:text-slate-400"})]}),a.jsxs("div",{className:"w-full",children:[a.jsxs("div",{className:"flex items-center justify-between",children:[a.jsx(ut,{htmlFor:"attrValue",className:"text-[11px] font-normal text-slate-600",children:y("Value")}),!d.isEmpty(b)&&a.jsx(Co,{data:b,onSelect:_})]}),a.jsx($n,{autoCapitalize:"off",autoCorrect:"off",spellCheck:"false",id:"attrValue",ref:x,value:l,onChange:S=>c(S.target.value),onKeyDown:E,placeholder:y("Enter value"),className:"text-xs font-normal leading-tight placeholder:text-slate-400"})]})]}),a.jsx("div",{className:"flex justify-end",children:a.jsx(B.Button,{type:"submit",disabled:!o.length,variant:"default",size:"sm",className:"h-8 w-24 text-xs",children:y(u!==null?"Save":"Add")})}),f&&a.jsx("p",{className:"text-xs text-red-500",children:f})]}),a.jsx("div",{className:"space-y-1 py-4",children:s.map((S,A)=>a.jsxs("div",{className:"flex items-center justify-between rounded border p-2 text-sm",children:[a.jsxs("div",{className:"flex flex-col text-xs leading-tight",children:[a.jsx("span",{className:"truncate text-[12px] font-light text-muted-foreground",children:S.key}),a.jsx("span",{className:"max-w-[200px] text-wrap font-normal",children:S.value.toString()})]}),a.jsxs("div",{className:"flex-shrink-0 text-slate-400",children:[a.jsx(B.Button,{variant:"ghost",size:"icon",className:"h-6 w-6",onClick:()=>I(A),children:a.jsx(k.Pencil2Icon,{className:"h-3 w-3"})}),a.jsx(B.Button,{variant:"ghost",size:"icon",className:"h-6 w-6",onClick:()=>w(A),children:a.jsx(k.Cross1Icon,{className:"h-3 w-3"})})]})]},A))})]})}),Fc=D.memo(()=>{const t=J(),[e,n]=g.useState([]),[s]=Ae(),r=st(),o=`${d.get(s,"0.prop")}_attrs`;D.useEffect(()=>{const l=d.map(d.get(t,o),(c,u)=>({key:u,value:c}));d.isEmpty(l)?n([]):n(l)},[d.get(t,o)]);const i=D.useCallback((l=[])=>{if(!t)return;const c={};d.forEach(l,u=>{d.isEmpty(u.key)||d.set(c,u.key,u.value)}),r([d.get(t,"_id")],{[o]:c})},[t,r,o]);return a.jsx("div",{className:"flex-col gap-y-2",children:a.jsx("div",{className:"flex flex-col",children:a.jsx("div",{children:a.jsx(wy,{preloadedAttributes:e,onAttributesChange:i})})})})}),Cy=()=>{const[t]=$l();return a.jsxs("div",{className:"flex w-12 cursor-not-allowed items-center justify-center gap-x-1 space-x-0 font-medium text-gray-400",children:[a.jsx(k.ZoomInIcon,{className:"h-3.5 w-3.5 flex-shrink-0"})," ",a.jsxs("div",{className:"text-xs leading-3",children:[d.round(t,0),"%"]})]})},jy=()=>{const{hasErrors:t,hasWarnings:e,errorCount:n,warningCount:s,errors:r}=jc(),[,o]=U(),{t:i}=F.useTranslation();if(!t&&!e)return null;const l=()=>t?"text-red-500":e?"text-orange-500":"text-gray-500",c=()=>t?a.jsx(k.ExclamationTriangleIcon,{className:"h-4 w-4"}):e?a.jsx(k.InfoCircledIcon,{className:"h-4 w-4"}):null,u=()=>t&&e?`${n} error${n>1?"s":""}, ${s} warning${s>1?"s":""}`:t?`${n} error${n>1?"s":""}`:e?`${s} warning${s>1?"s":""}`:"";return a.jsxs(tt,{children:[a.jsx(nt,{asChild:!0,children:a.jsxs("div",{className:`ml-2 flex cursor-pointer items-center gap-2 ${l()}`,children:[c(),a.jsx("span",{className:"text-xs font-medium",children:u()})]})}),a.jsx(Ue,{side:"bottom",className:"max-w-xs p-2",align:"end",children:a.jsxs("div",{className:"space-y-2",children:[a.jsx("h4",{className:"text-sm font-semibold",children:i("Invalid structure")}),r.length===0?a.jsx("p",{className:"text-xs",children:i("No validation issues found.")}):a.jsxs("div",{className:"space-y-1",children:[r.slice(0,5).map(p=>a.jsxs("div",{onClick:()=>{p.blockId&&o([p.blockId])},className:`cursor-pointer rounded p-2 text-xs transition-opacity hover:opacity-80 ${p.severity==="error"?"border border-red-200 bg-red-50 text-red-700":"border border-orange-200 bg-orange-50 text-orange-700"}`,children:[a.jsx("div",{className:"font-medium",children:p.severity==="error"?"Error:":"Warning:"}),a.jsx("div",{children:p.message})]},p.id)),r.length>5&&a.jsxs("p",{className:"text-xs italic text-gray-500",children:["... and ",r.length-5," more issues"]})]})]})})]})},Sy=()=>{const t=$("flags.darkMode",!1),e=$("flags.dataBinding",!0),[n,s]=j.useAtom(Kr),{t:r}=F.useTranslation(),o=t,i=e;return a.jsxs("div",{className:"flex h-10 items-center justify-between border-b border-border bg-background/70 px-2 shadow-xl",children:[a.jsx("div",{className:"flex h-full space-x-2",children:o?a.jsx(Pc,{}):null}),a.jsxs("div",{className:"flex h-full items-center space-x-2",children:[a.jsx(_o,{canvas:!0,openDelay:400}),a.jsx(Rt,{orientation:"vertical"}),a.jsx(Cy,{}),a.jsx(Rt,{orientation:"vertical"}),a.jsx(Lc,{})]}),a.jsxs("div",{className:"flex h-full items-center",children:[i?a.jsxs(tt,{children:[a.jsx(nt,{asChild:!0,children:a.jsx(B.Button,{size:"sm",variant:"ghost",className:"h-7 w-7 rounded-md p-1",children:a.jsx(k.DotsHorizontalIcon,{className:"h-4 w-4"})})}),a.jsx(Ue,{className:"w-56 border-border text-xs",children:a.jsxs(de,{className:"flex items-center gap-2",onSelect:l=>l.preventDefault(),children:[a.jsx(k.LightningBoltIcon,{className:"h-4 w-4 text-gray-500"}),a.jsx("span",{className:"flex-1",children:r("Data Binding")}),a.jsx(un,{checked:n,onCheckedChange:()=>s(!n)})]})})]}):null,a.jsx(jy,{}),a.jsx(wc,{})]})]})},Gt=()=>null,Da=()=>{const{resetAll:t}=Xl(),e=J(),[n]=Ae(),s=ag(),{t:r}=F.useTranslation();return!e||d.isEmpty(n)?null:a.jsxs(tt,{children:[a.jsx(nt,{asChild:!0,children:a.jsx("div",{className:"inline-flex rounded-sm p-0.5 hover:bg-gray-300",onClick:o=>o.stopPropagation(),children:a.jsx(k.DotsVerticalIcon,{className:"h-3 w-3"})})}),a.jsxs(Ue,{side:"bottom",className:"border-border text-xs",children:[a.jsxs(de,{className:"flex items-center gap-1 text-xs",onClick:()=>{t()},children:[a.jsx(k.ResetIcon,{className:"h-3 w-3"}),r("Reset styles")]}),a.jsxs(de,{className:"text-xs",onClick:()=>{e&&s(e,!0)},children:[a.jsx(k.Cross2Icon,{className:"h-3 w-3"}),r("Clear styles")]})]})]})};function Oa(){const{t}=F.useTranslation(),[e,n]=g.useState(!0),[s]=Ae();return d.isEmpty(s)?null:a.jsxs(a.Fragment,{children:[a.jsxs("div",{onClick:()=>n(!e),className:"flex cursor-pointer items-center justify-between border-t border-border py-3 text-xs font-medium hover:underline",children:[a.jsx("span",{children:t("Attributes")}),a.jsx("span",{children:a.jsx(k.ChevronDownIcon,{className:"h-4 w-4 text-gray-500 "+(e?"rotate-180":"")})})]}),e&&a.jsx(Fc,{})]})}const Ny=({partialBlockId:t})=>{const e=$("gotoPage",d.noop),{saveState:n}=sn(),{selectedLang:s,fallbackLang:r}=_e(),o=g.useCallback(i=>{if(i.stopPropagation(),n!=="SAVED"){ce.toast.error("You have unsaved changes. Please save the page first.");return}e({pageId:t,lang:s||r})},[n,e,t,s,r]);return a.jsx(a.Fragment,{children:a.jsx("div",{className:"hidden",children:a.jsx("div",{onDoubleClick:o,className:"h-full w-full items-center justify-center",children:a.jsx("p",{className:"rounded-md bg-white px-2 py-1 text-xs",children:"Partial block. Double click to edit."})})})})},Ey=()=>{const t=J(),{t:e}=F.useTranslation(),n=$("onError",d.noop),{hasPermission:s}=Ve();let r=!s(Q.EDIT_BLOCK);const o=!s(Q.EDIT_STYLES),[i,l]=pi();if(t&&t._type==="PartialBlock")return a.jsx(Ny,{partialBlockId:t.partialBlockId});if(d.isNull(t))return a.jsx("div",{className:"p-4 text-center",children:a.jsxs("div",{className:"space-y-4 rounded-xl p-4 text-muted-foreground",children:[a.jsx(k.MixerHorizontalIcon,{className:"mx-auto text-3xl"}),a.jsx("h1",{children:e("Please select a block to edit settings or styles")})]})});if(r&&o)return a.jsx("div",{className:"p-4 text-center",children:a.jsxs("div",{className:"space-y-4 rounded-xl p-4 text-muted-foreground",children:[a.jsx(k.MixerHorizontalIcon,{className:"mx-auto text-3xl"}),a.jsx("h1",{children:e("You don't have permission to edit settings or styles")}),a.jsx("p",{children:e("Please contact your administrator to get access")})]})});if(o)return a.jsx(At.ErrorBoundary,{fallback:a.jsx(vn,{}),onError:n,children:a.jsxs("div",{className:"no-scrollbar h-full max-h-min w-full overflow-y-auto",children:[a.jsx(br,{},t==null?void 0:t._id),a.jsx("br",{}),a.jsx("br",{})]})});if(r)return a.jsx(At.ErrorBoundary,{fallback:a.jsx(vn,{}),onError:n,children:a.jsxs("div",{className:"no-scrollbar h-full max-h-min w-full overflow-y-auto overflow-x-hidden",children:[a.jsx("div",{className:"flex w-full items-center justify-end",children:a.jsx(Da,{})}),a.jsx(jr,{}),a.jsx(Oa,{}),a.jsx("br",{}),a.jsx("br",{}),a.jsx("br",{})]})});const u=p=>{(p==="settings"||p==="styles")&&l(p)};return a.jsx(At.ErrorBoundary,{fallback:a.jsx(vn,{}),onError:n,children:a.jsxs(Os,{value:i,onValueChange:u,className:"flex flex-1 flex-col",children:[a.jsx("div",{className:"flex items-center justify-between",children:a.jsxs(On,{className:"grid h-auto w-full grid-cols-2 p-1 py-1",children:[a.jsx(He,{value:"settings",className:"text-xs",children:e("Settings")}),a.jsx(He,{value:"styles",className:"text-xs",children:a.jsxs("div",{className:"flex w-full items-center justify-between",children:[a.jsx("span",{className:"w-[90%] text-center",children:e("Styling")}),a.jsx("span",{className:"w-[10%]",children:a.jsx(Da,{})})]})})]})}),a.jsxs(ct,{value:"settings",className:"no-scrollbar h-full max-h-min overflow-y-auto",children:[a.jsx(br,{},t==null?void 0:t._id),a.jsx("br",{}),a.jsx("br",{})]}),a.jsxs(ct,{value:"styles",className:"no-scrollbar h-full max-h-min max-w-full overflow-y-auto overflow-x-hidden",children:[a.jsx(jr,{}),a.jsx(Oa,{}),a.jsx("br",{}),a.jsx("br",{}),a.jsx("br",{})]})]})})},Ay=g.lazy(()=>Promise.resolve().then(()=>require("./manage-design-tokens-BknGNAKE.cjs"))),ht=280,Iy=({isActive:t,show:e})=>a.jsx(B.Button,{variant:t?"default":"ghost",size:"icon",onClick:e,children:a.jsx(k.StackIcon,{className:"h-5 w-5"})}),_y=({isActive:t,show:e})=>Ye()&&a.jsx(B.Button,{variant:t?"default":"ghost",size:"icon",onClick:e,children:a.jsx(k.PlusCircledIcon,{className:"h-5 w-5"})}),Ty=({isActive:t,show:e})=>$("flags.ai",!1)?a.jsx(B.Button,{variant:t?"default":"ghost",size:"icon",onClick:e,children:a.jsx(Er,{})}):null;B.registerChaiSidebarPanel("add-block",{button:_y,label:"Add Blocks",position:"top",isInternal:!0,width:ht,panel:()=>a.jsx(Do,{showHeading:!1,fromSidebar:!0,parentId:void 0,position:-1})});B.registerChaiSidebarPanel("chai-chat-panel",{button:Ty,label:"Ask AI",position:"top",isInternal:!0,width:ht,panel:()=>a.jsx("div",{className:"",children:a.jsx(Rc,{})})});B.registerChaiSidebarPanel("outline",{button:Iy,label:"Outline",position:"top",isInternal:!0,width:ht,panel:()=>a.jsx("div",{className:"-mt-8",children:a.jsx(Nc,{})})});const By=()=>{const t=B.useTopBarComponent(),[e,n]=Is(),s=g.useRef("outline"),[r,o]=g.useState(ht),[i,l]=ui(),[,c]=pi(),u=B.useChaiSidebarPanels("top"),p=B.useChaiSidebarPanels("bottom"),f=d.reverse([...p??[]]),m=g.useCallback(A=>{A.preventDefault()},[]),h=g.useMemo(()=>[u].flat(),[u]),x=g.useCallback(A=>{console.log("handleMenuItemClick",A,e),n(e===A?null:A)},[e,n]),{t:b}=F.useTranslation(),y=g.useMemo(()=>[...u,...p],[u,p]),v=$("htmlDir","ltr"),w=d.find(y,{id:e})??d.first(y),I=d.get(w,"width",ht);g.useEffect(()=>{if(e!==null){const A=d.find(y,{id:e});A&&d.get(A,"view","standard")==="standard"&&(s.current=e,o(d.get(A,"width",ht)))}},[e,y]);const N=g.useMemo(()=>{if(e===null)return 0;const A=d.find(y,{id:e});return d.get(A,"view","standard")==="standard"?I:r},[e,I,r,y]),E=g.useCallback(()=>{n(s.current)},[n,e]),_=g.useCallback(()=>{n("outline")},[n]);g.useEffect(()=>{e!==null&&!d.find(y,{id:e})&&n("outline")},[e,y]);const S=g.useCallback(A=>{x(A)},[x]);return a.jsx("div",{dir:v,className:"h-screen max-h-full w-screen overflow-x-hidden bg-background text-foreground",children:a.jsxs(gs,{children:[a.jsxs("div",{onContextMenu:m,className:"flex h-full max-h-full flex-col bg-background text-foreground",children:[a.jsx("div",{className:"flex h-[50px] w-screen items-center border-b border-border",children:a.jsx(g.Suspense,{children:a.jsx(t,{})})}),a.jsxs("main",{className:"relative flex h-[calc(100vh-56px)] max-w-full flex-1 flex-row",children:[a.jsxs("div",{id:"sidebar",className:"flex w-12 flex-col items-center justify-between border-r border-border py-2",children:[a.jsx("div",{className:"flex flex-col gap-y-1",children:h.map((A,C)=>a.jsxs(fe,{children:[a.jsx(he,{asChild:!0,children:g.createElement(d.get(A,"button",Gt),{position:"top",panelId:A.id,isActive:e===A.id,show:()=>S(A.id)})}),a.jsx(ue,{side:"right",children:a.jsx("p",{children:b(A.label)})})]},"button-top-"+C))}),a.jsx("div",{className:"flex flex-col space-y-1"}),a.jsx("div",{className:"flex flex-col",children:f==null?void 0:f.map((A,C)=>a.jsxs(fe,{children:[a.jsx(he,{asChild:!0,children:g.createElement(d.get(A,"button",Gt),{position:"bottom",panelId:A.id,isActive:e===A.id,show:()=>S(A.id)})}),a.jsx(ue,{side:"right",children:a.jsx("p",{children:b(A.label)})})]},"button-bottom-"+C))})]}),a.jsx(Vn.motion.div,{id:"left-panel",className:"h-full max-h-full border-r border-border",initial:{width:N},animate:{width:N},transition:{duration:.3,ease:"easeInOut"},children:e!==null&&d.get(w,"view","standard")==="standard"&&a.jsxs("div",{className:"no-scrollbar flex h-full flex-col overflow-hidden px-3 py-2",children:[a.jsx("div",{className:`absolute top-2 flex h-10 items-center space-x-1 py-2 text-base font-bold ${d.get(w,"isInternal",!1)?"":"w-64"}`,children:a.jsx("span",{children:b(d.get(w,"label",""))})}),a.jsx("div",{className:"no-scrollbar h-full max-h-full overflow-y-auto pt-10",children:a.jsx(g.Suspense,{fallback:a.jsx("div",{children:"Loading..."}),children:g.createElement(d.get(w,"panel",Gt),{})})})]})}),a.jsxs("div",{id:"canvas-container",className:"flex h-full max-h-full flex-1 flex-col bg-slate-800/20",children:[a.jsx(Sy,{}),a.jsx(g.Suspense,{children:a.jsx(Hl,{})})]}),a.jsx(Vn.motion.div,{id:"right-panel",className:"h-full max-h-full border-l border-border",initial:{width:e==="ai"?0:ht},animate:{width:e==="ai"?0:ht},transition:{duration:.3,ease:"easeInOut"},children:a.jsx("div",{className:"no-scrollbar overflow h-full max-h-full overflow-hidden",children:a.jsxs("div",{className:"flex h-full max-h-full flex-col overflow-hidden p-3",children:[a.jsx("h2",{className:"-mt-1 flex items-center space-x-1 text-base font-bold",children:a.jsx("div",{className:"flex grow items-center gap-2",children:a.jsx("div",{className:"flex w-full items-center justify-between gap-2",children:i==="ai"?a.jsx(a.Fragment,{children:a.jsxs("div",{className:"flex items-center gap-2",children:[a.jsx(k.LightningBoltIcon,{className:"rtl:ml-2"})," ",b("AI Assistant")]})}):i==="design-tokens"?a.jsxs("div",{className:"mb-1 flex w-full items-center justify-between gap-2",children:[a.jsxs("span",{className:"flex items-center gap-2",children:[a.jsx(Cr,{className:"h-4 w-4 text-gray-600"}),b("Design Tokens")]}),a.jsx(B.Button,{onClick:()=>{c("styles"),l("block")},variant:"ghost",size:"icon",className:"text-xs",children:a.jsx(k.Cross1Icon,{className:"h-4 w-4 rtl:ml-2"})})]}):i==="theme"?a.jsxs("div",{className:"flex w-full items-center justify-between gap-2",children:[a.jsxs("span",{className:"flex items-center gap-2",children:[a.jsx(k.MixerHorizontalIcon,{className:"h-4 w-4 text-gray-600"}),b("Theme Settings")]}),a.jsx(B.Button,{onClick:()=>l("block"),variant:"ghost",size:"icon",className:"text-xs",children:a.jsx(k.Cross1Icon,{className:"h-4 w-4 rtl:ml-2"})})]}):null})})}),a.jsx("div",{className:"flex h-full max-h-full w-full",children:a.jsx(g.Suspense,{fallback:a.jsx("div",{children:"Loading..."}),children:i==="ai"?a.jsx(Rc,{}):i==="design-tokens"?a.jsx(g.Suspense,{fallback:a.jsx("div",{className:"h-1/2 w-full animate-pulse"}),children:a.jsx(Ay,{})}):i==="theme"?a.jsx(Ic,{}):a.jsx(Ey,{})})})]})})})]})]}),a.jsx($c,{}),e!==null&&d.get(w,"view")==="drawer"&&a.jsx(Mc,{open:!0,onOpenChange:()=>E(),children:a.jsxs(Wo,{side:"left",className:"flex flex-col gap-0 p-0 sm:max-w-full",style:{width:`${I}px`},children:[a.jsx(Go,{className:"border-b border-border px-2 py-2.5",children:a.jsxs(Uo,{className:"flex items-center gap-2",children:[a.jsx("span",{className:"inline-block",children:d.get(w,"icon",null)}),a.jsx("span",{children:b(d.get(w,"label",""))})]})}),a.jsx("div",{className:"h-full max-h-full overflow-y-auto p-4",children:a.jsx(g.Suspense,{fallback:a.jsx("div",{children:"Loading..."}),children:g.createElement(d.get(w,"panel",Gt),{close:_})})})]})})," ",e!==null&&d.get(w,"view")==="modal"&&a.jsx(Pn,{open:!0,onOpenChange:()=>E(),children:a.jsxs(cn,{className:"gap-0 p-0",style:{maxWidth:`${I}px`},children:[a.jsx(Ln,{className:"border-b border-border px-2 py-3.5",children:a.jsxs(dn,{className:"flex items-center gap-2",children:[a.jsx("span",{className:"inline-block",children:d.get(w,"icon",null)}),a.jsx("span",{children:b(d.get(w,"label",""))})]})}),a.jsx("div",{className:"max-h-[70vh] overflow-y-auto p-4",children:a.jsx(g.Suspense,{fallback:a.jsx("div",{children:"Loading..."}),children:g.createElement(d.get(w,"panel",Gt),{close:_})})})]})}),e!==null&&d.get(w,"view")==="overlay"&&a.jsx(Vn.motion.div,{className:"absolute bottom-0 left-12 right-0 top-0 z-50",initial:{opacity:0},animate:{opacity:1},exit:{opacity:0},transition:{duration:.3},children:a.jsx("div",{className:"h-full w-full",children:a.jsxs(Vn.motion.div,{className:"flex h-full w-full flex-col bg-background",initial:{y:-20,opacity:0},animate:{y:0,opacity:1},exit:{y:20,opacity:0},transition:{duration:.3,delay:.1},children:[a.jsxs("div",{className:"flex h-[50px] items-center justify-between border-b border-border p-4",children:[a.jsxs("div",{className:"-ml-2 flex items-center gap-2 text-lg font-bold",children:[a.jsx("span",{className:"rtl:ml-2 rtl:inline-block",children:d.get(w,"icon",null)}),a.jsx("span",{children:b(d.get(w,"label",""))})]}),a.jsx(B.Button,{onClick:()=>E(),variant:"ghost",size:"icon",className:"",children:a.jsx(k.Cross1Icon,{className:"h-5 w-5"})})]}),a.jsx("div",{className:"flex-1 overflow-y-auto p-4",children:a.jsx(g.Suspense,{fallback:a.jsx("div",{children:"Loading..."}),children:g.createElement(d.get(w,"panel",Gt),{close:_})})})]})})})]})})},Ry=j.atom(!1),Py=()=>{const[t,e]=j.useAtom(Ry);return[t,e]},Ly=()=>{const[t,e]=Py(),{t:n}=F.useTranslation(),s=$("previewComponent",null);return t?a.jsxs("div",{className:ke.cn("fixed inset-0 z-[999] bg-background",t?"block":"hidden"),children:[a.jsxs(B.Button,{size:"sm",className:"absolute right-0 top-0 m-4 space-x-2",onClick:()=>e(!1),children:[a.jsx(k.EyeClosedIcon,{}),a.jsx("span",{children:n("Close Preview")})]}),a.jsx("div",{children:s?a.jsx(g.Suspense,{fallback:a.jsx(Lt,{className:"h-96 w-full"}),children:g.createElement(s)}):null})]}):null},My=({featureKey:t,options:e})=>{const n=B.useToggleChaiFeatureFlag(t),s=B.useChaiFeatureFlag(t);return a.jsxs("div",{className:"flex items-center space-x-3 rounded-md p-2 transition-colors hover:bg-gray-50 dark:hover:bg-gray-800",children:[a.jsx(un,{checked:s,onCheckedChange:n}),a.jsxs("div",{className:"flex-1",children:[a.jsx("p",{className:"text-sm font-medium text-gray-900 dark:text-gray-100",children:e.key}),e.description&&a.jsx("p",{className:"mt-0.5 text-xs text-gray-500 dark:text-gray-400",children:e.description})]})]})},Dy=Ne.atomWithStorage("show-feature-flag",null),Oy=({close:t,position:e,updatePosition:n})=>{const s=B.useChaiFeatureFlags(),[r,o]=g.useState(""),[i,l]=g.useState(!1),[c,u]=g.useState({x:0,y:0}),p=g.useMemo(()=>{if(!r.trim())return s;const x=r.toLowerCase();return Object.fromEntries(Object.entries(s).filter(([b,y])=>{var v;return(b==null?void 0:b.toLowerCase().includes(x))||((v=y==null?void 0:y.description)==null?void 0:v.toLowerCase().includes(x))}))},[s,r]),f=x=>{l(!0),u({x:x.clientX-e.x,y:x.clientY-e.y})},m=x=>{if(!i)return;const b=x.clientX-c.x,y=x.clientY-c.y,v=x.currentTarget,w=v.offsetWidth,I=v.offsetHeight,N=window.innerWidth-w,E=window.innerHeight-I,_=Math.max(0,Math.min(b,N)),S=Math.max(0,Math.min(y,E));n(_,S)},h=()=>{l(!1)};return g.useEffect(()=>{const x=()=>{i&&l(!1)};return window.addEventListener("mouseup",x),()=>window.removeEventListener("mouseup",x)},[i]),!e||e.x<0||e.y<0?null:a.jsxs("div",{onMouseDown:f,onMouseMove:m,onMouseUp:h,className:"fixed z-[9999999] select-none rounded-md border border-gray-300 bg-white p-3 shadow-2xl",style:{left:e.x,top:e.y,cursor:i?"grabbing":"grab",userSelect:"none"},children:[a.jsxs("div",{className:"relative sticky top-0 rounded-t-lg bg-white",children:[a.jsxs("div",{className:"mb-3 flex items-center justify-between",children:[a.jsxs("div",{children:[a.jsxs("h3",{className:"flex items-center gap-x-2 text-base font-semibold text-gray-900 dark:text-gray-100",children:[a.jsx(k.DragHandleDots2Icon,{})," Feature Flags"]}),a.jsxs("p",{className:"text-xs text-gray-400 dark:text-gray-400",children:["Toggle experimental features (",a.jsx("span",{className:"font-mono",children:"Ctrl+Shift+1"})," to toggle)"]})]}),a.jsx(B.Button,{variant:"ghost",size:"sm",onClick:t,className:"absolute -right-2 -top-2 p-1 text-gray-500 hover:text-gray-700 dark:text-gray-400 dark:hover:text-gray-200",children:a.jsx(k.Cross1Icon,{className:"h-4 w-4"})})]}),a.jsxs("div",{className:"relative",children:[a.jsx(k.MagnifyingGlassIcon,{className:"absolute left-2.5 top-2.5 h-4 w-4 text-gray-400"}),a.jsx(B.Input,{type:"search",placeholder:"Search features...",className:"w-full pl-8",value:r,onChange:x=>o(x.target.value),autoFocus:!0})]})]}),a.jsx("div",{className:"max-h-96 overflow-y-auto py-2",children:Object.keys(p).length>0?a.jsx("div",{className:"space-y-1",children:Object.entries(p).map(([x,b])=>a.jsx(My,{featureKey:x,options:b},x))}):a.jsx("div",{className:"py-8 text-center",children:a.jsxs("p",{className:"text-sm text-gray-500 dark:text-gray-400",children:['No features found matching "',r,'"']})})})]})},$y=()=>{const[t,e]=j.useAtom(Dy);return Je.useHotkeys("ctrl+shift+1,meta+shift+1",()=>e(n=>n?{...n,show:!n.show}:{x:0,y:0,show:!0}),{enableOnFormTags:!0}),t!=null&&t.show?a.jsx(Oy,{position:t,close:()=>e(n=>n?{...n,show:!1}:null),updatePosition:(n,s)=>e(r=>r?{...r,x:n,y:s,show:r.show}:{x:n,y:s,show:!0})}):null},Fy=t=>{},zy=["data-block-index","draggable","data-drop","data-style-id","data-block-parent","data-style-prop","data-highlighted"],Hy=["Box","Button","Checkbox","Divider","EmptyBox","Form","FormButton","Heading","Image","Input","Label","LineBreak","Link","List","ListItem","Paragraph","Radio","RichText","Select","Span","Text","TextArea","Video"],zc=t=>t.type==="element"&&["script","style","link"].includes(t.tagName||"")||t.type==="comment"?null:t.type==="text"?t:t.type==="element"&&t.attributes&&t.attributes.find(e=>e.key==="id"&&e.value==="add-block-bottom")?null:(t.type==="element"&&t.attributes&&(t.attributes=t.attributes.filter(e=>!zy.includes(e.key))),t.children&&(t.children=t.children.map(zc).filter(e=>e!==null)),t),es=(t,e,n={})=>{var o,i,l,c,u,p;if(t.type!=="element"||!t.attributes)return t;if(t.tagName==="span"&&t.attributes.find(m=>m.key==="role"&&m.value==="link")){t.tagName="a",t.attributes=t.attributes.filter(x=>x.key!=="role");const m=(o=t.attributes.find(x=>x.key==="data-block-id"))==null?void 0:o.value,h=e==null?void 0:e.find(x=>(x==null?void 0:x._id)===m);if(h!=null&&h.link&&((l=(i=h==null?void 0:h.link)==null?void 0:i.href)==null?void 0:l.length)>0){const x=(c=h==null?void 0:h.link)==null?void 0:c.href,b=(u=h==null?void 0:h.link)==null?void 0:u.target;t.attributes.push({key:"href",value:x}),typeof b=="string"&&b.length>0&&t.attributes.push({key:"target",value:b})}}const s=t.attributes.find(f=>f.key==="data-block-type"),r=t.attributes.find(f=>f.key==="data-block-id");if(s){const f=s.value;if(Hy.includes(f)||(p=n==null?void 0:n.additionalCoreBlocks)!=null&&p.includes(f))t.attributes=t.attributes.filter(m=>m.key!=="data-block-type"),t.children&&(t.children=t.children.map(m=>es(m,e,n)));else{const m=`chai-${d.kebabCase(f)}`;t.tagName=m,t.attributes=[],t.attributes.push({key:"chai-type",value:f});const h=K.getRegisteredChaiBlock(f),x=e.find(b=>b._id===(r==null?void 0:r.value));if(x&&t.attributes.push(...Object.entries(x).filter(([b])=>!["_id","_type","_parent","_index","_name"].includes(b)).map(([b,y])=>({key:b,value:typeof y=="string"?y:JSON.stringify(y)}))),h&&(h!=null&&h.description)&&t.attributes.push({key:"about-this-component",value:h.description}),h){if(h.canMove){const b=typeof h.canMove=="function"?h.canMove():h.canMove;t.attributes.push({key:"can-move",value:String(b)})}if(h.canDelete){const b=typeof h.canDelete=="function"?h.canDelete():h.canDelete;t.attributes.push({key:"can-delete",value:String(b)})}}f==="Icon"&&(t.attributes=t.attributes.filter(b=>b.key!=="icon")),h&&h.canAcceptBlock?t.children&&(t.children=t.children.map(b=>es(b,e,n))):t.children=[]}}else t.children&&(t.children=t.children.map(f=>es(f,e,n)));return r&&t.attributes.push({key:"bid",value:r.value}),t.attributes=t.attributes.filter(f=>f.key!=="data-block-type"&&f.key!=="data-block-id"),t},Hc=()=>{const[t]=rn();return g.useCallback(e=>{var u,p;if(!t)return"";const n=e!=null&&e.blockId?`[data-block-id="${e.blockId}"]`:"#canvas",s=(p=(u=t.contentDocument)==null?void 0:u.querySelector(n))==null?void 0:p[n==="#canvas"?"innerHTML":"outerHTML"];if(!s)return"";const o=Ko.parse(s).map(zc).filter(f=>f!==null),i=Dd(),l=o.map(f=>es(f,i,e));let c=Ko.stringify(l);return c=c.replace(/#styles:,/g,"#styles:"),c.replace(/\s+/g," ").trim()},[t])};function $a(t){const e={class:"className",for:"htmlFor",tabindex:"tabIndex",readonly:"readOnly",maxlength:"maxLength",minlength:"minLength",autocomplete:"autoComplete",autofocus:"autoFocus",autoplay:"autoPlay",formaction:"formAction",formenctype:"formEncType",formmethod:"formMethod",formnovalidate:"formNoValidate",formtarget:"formTarget",novalidate:"noValidate",crossorigin:"crossOrigin",datetime:"dateTime",rowspan:"rowSpan",colspan:"colSpan",usemap:"useMap",frameborder:"frameBorder",allowfullscreen:"allowFullScreen"};if(e[t.toLowerCase()])return e[t.toLowerCase()];const n={"accent-height":"accentHeight","alignment-baseline":"alignmentBaseline","arabic-form":"arabicForm","baseline-shift":"baselineShift","cap-height":"capHeight","clip-path":"clipPath","clip-rule":"clipRule","color-interpolation":"colorInterpolation","color-interpolation-filters":"colorInterpolationFilters","color-profile":"colorProfile","color-rendering":"colorRendering","dominant-baseline":"dominantBaseline","enable-background":"enableBackground","fill-opacity":"fillOpacity","fill-rule":"fillRule","flood-color":"floodColor","flood-opacity":"floodOpacity","font-family":"fontFamily","font-size":"fontSize","font-size-adjust":"fontSizeAdjust","font-stretch":"fontStretch","font-style":"fontStyle","font-variant":"fontVariant","font-weight":"fontWeight","glyph-name":"glyphName","glyph-orientation-horizontal":"glyphOrientationHorizontal","glyph-orientation-vertical":"glyphOrientationVertical","horiz-adv-x":"horizAdvX","horiz-origin-x":"horizOriginX","image-rendering":"imageRendering","letter-spacing":"letterSpacing","lighting-color":"lightingColor","marker-end":"markerEnd","marker-mid":"markerMid","marker-start":"markerStart","overline-position":"overlinePosition","overline-thickness":"overlineThickness","paint-order":"paintOrder","panose-1":"panose1","pointer-events":"pointerEvents","rendering-intent":"renderingIntent","shape-rendering":"shapeRendering","stop-color":"stopColor","stop-opacity":"stopOpacity","strikethrough-position":"strikethroughPosition","strikethrough-thickness":"strikethroughThickness","stroke-dasharray":"strokeDasharray","stroke-dashoffset":"strokeDashoffset","stroke-linecap":"strokeLinecap","stroke-linejoin":"strokeLinejoin","stroke-miterlimit":"strokeMiterlimit","stroke-opacity":"strokeOpacity","stroke-width":"strokeWidth","text-anchor":"textAnchor","text-decoration":"textDecoration","text-rendering":"textRendering","underline-position":"underlinePosition","underline-thickness":"underlineThickness","unicode-bidi":"unicodeBidi","unicode-range":"unicodeRange","units-per-em":"unitsPerEm","v-alphabetic":"vAlphabetic","v-hanging":"vHanging","v-ideographic":"vIdeographic","v-mathematical":"vMathematical","vector-effect":"vectorEffect","vert-adv-y":"vertAdvY","vert-origin-x":"vertOriginX","vert-origin-y":"vertOriginY","word-spacing":"wordSpacing","writing-mode":"writingMode","x-height":"xHeight"};return n[t]?n[t]:t}function ts(t,e=0){var u;if(Array.isArray(t)){if(t.length===0)return"";if(t.length===1)return ts(t[0],e);const p=" ".repeat(e);let f=`${p}<>
|
|
136
|
+
`;for(const m of t)f+=ts(m,e+1);return f+=`${p}</>
|
|
137
|
+
`,f}const n=" ".repeat(e);if(t.nodeType===Node.TEXT_NODE){const p=(u=t.textContent)==null?void 0:u.trim();return p?`${n}${p}
|
|
138
|
+
`:""}if(t.nodeType!==Node.ELEMENT_NODE)return"";const s=t.tagName.toLowerCase();if(["img","br","hr","input","meta","link","area","base","col","embed","source","track","wbr"].includes(s)){const p=[];for(const m of t.attributes)if(m.name.startsWith("on")&&m.name!=="on"){const h=m.name.toLowerCase().replace(/on(\w)/,(x,b)=>"on"+b.toUpperCase());p.push(`${h}={${m.value}}`)}else if(m.name==="style"&&m.value){const h=m.value.split(";").reduce((x,b)=>{const[y,v]=b.split(":").map(w=>w.trim());if(y&&v){const w=y.replace(/-([a-z])/g,I=>I[1].toUpperCase());x[w]=v.replace(/['"]/g,"")}return x},{});p.push(`style={${JSON.stringify(h)}}`)}else{const h=$a(m.name);p.push(`${h}="${m.value}"`)}const f=p.length>0?` ${p.join(" ")}`:"";return`${n}<${s}${f} />
|
|
139
|
+
`}let o=`${n}<${s}`;const i=[];for(const p of t.attributes)if(p.name.startsWith("on")&&p.name!=="on"){const f=p.name.toLowerCase().replace(/on(\w)/,(m,h)=>"on"+h.toUpperCase());i.push(`${f}={${p.value}}`)}else if(p.name==="style"&&p.value){const f=p.value.split(";").reduce((m,h)=>{const[x,b]=h.split(":").map(y=>y.trim());if(x&&b){const y=x.replace(/-([a-z])/g,v=>v[1].toUpperCase());m[y]=b.replace(/['"]/g,"")}return m},{});i.push(`style={${JSON.stringify(f)}}`)}else{const f=$a(p.name);i.push(`${f}="${p.value}"`)}i.length>0&&(o+=" "+i.join(" "));const l=Array.from(t.childNodes);if(!l.some(p=>{var f;return p.nodeType===Node.TEXT_NODE?(f=p.textContent)==null?void 0:f.trim():!0}))o+=` />
|
|
140
|
+
`;else{o+=`>
|
|
141
|
+
`;for(const p of l)o+=ts(p,e+1);o+=`${n}</${s}>
|
|
142
|
+
`}return o}function Vy(t){if(!t)return"";let e="",n=0;const s=" ";return t=t.replace(/>\s+</g,"><").trim(),t.split(/(<\/?[^>]+>)/g).filter(o=>o.trim()).forEach(o=>{o.match(/^<\/\w/)?(n=Math.max(0,n-1),e+=s.repeat(n)+o+`
|
|
143
|
+
`):o.match(/\/>$/)?e+=s.repeat(n)+o+`
|
|
144
|
+
`:o.match(/^<\w[^>]*[^\/]>$/)?(e+=s.repeat(n)+o+`
|
|
145
|
+
`,n++):o.trim()&&(e+=s.repeat(n)+o.trim()+`
|
|
146
|
+
`)}),e.trim()}const Wy=g.lazy(()=>Promise.resolve().then(()=>require("./code-display-BR-gij5j.cjs")));async function Gy(t){try{const e=document.createElement("div");e.innerHTML=t;const n=Array.from(e.children);return{jsx:ts(n.length===1?n[0]:n),html:e.innerHTML}}catch{return{html:t,jsx:t}}}const Uy=async({selectedBlock:t,html:e,isTypeScript:n=!1})=>{let s=(t==null?void 0:t._name)||(t==null?void 0:t._type)||"Component";s=d.camelCase(s).replace(/^./,u=>u.toUpperCase());const r=" ";let{jsx:o,html:i}=await Gy(e);return o=o==null?void 0:o.split(`
|
|
147
|
+
`).join(`
|
|
148
|
+
${r}${r}`),o=`${n?`import React from 'react';
|
|
149
|
+
|
|
150
|
+
`:""}export const ${s}${n?": React.FC":""} = () => {
|
|
151
|
+
${r}return (
|
|
152
|
+
${r}${r}${o==null?void 0:o.trimEnd()}
|
|
153
|
+
${r})
|
|
154
|
+
}`,{jsx:o,html:Vy(i),componentName:s}},qy=({tab:t})=>{var v;const{t:e}=F.useTranslation(),[n,s]=g.useState({html:"",jsx:""}),r=J(),o=Hc(),[i,l]=g.useState(""),[c,u]=g.useState(!1),p=()=>{switch(t){case"js":return`${i}.jsx`;case"ts":return`${i}.tsx`;case"html":return`${i}.html`;case"tailwind":return"tailwind.config.js"}},f=()=>{switch(t){case"js":case"ts":return"javascript";case"html":return"HTML";case"tailwind":return"JSON"}},m=g.useCallback(async()=>{if(r)try{u(!1);let w=o({blockId:r==null?void 0:r._id,additionalCoreBlocks:["Icon"]});w=w.replace(/\s*bid=["'][^"']*["']/g,"");const I=t==="ts",{jsx:N,html:E,componentName:_}=await Uy({selectedBlock:r,html:w,isTypeScript:I});s({html:E||"",jsx:N}),l(_),u(!0)}catch{const w="<div>Export failed. Close the modal and try again.</div>";s({html:w,jsx:w}),ce.toast.error(e("Failed to generate export HTML"))}},[e,t,r,o]);g.useEffect(()=>{m()},[m,t]);const h=g.useCallback(async w=>{try{navigator.clipboard.writeText(w),ce.toast.success(e("Export code copied!"))}catch{ce.toast.error(e("Failed to copy export code"))}},[e]),x=w=>{const I=new Blob([w],{type:"text/jsx"}),N=URL.createObjectURL(I),E=document.createElement("a");E.href=N,E.download=p()??"",document.body.appendChild(E),E.click(),URL.revokeObjectURL(N),document.body.removeChild(E),ce.toast.success(e("Export code downloaded successfully!"))},b=a.jsxs("span",{children:["Download ",a.jsx("span",{className:"font-mono text-xs font-light text-gray-300",children:p()})]}),y=g.useMemo(()=>{const w={extend:Ed.shadcnTheme()},I=JSON.stringify(w,null,2);return`{
|
|
155
|
+
// Your tailwind config ...
|
|
156
|
+
|
|
157
|
+
"theme": ${I==null?void 0:I.split(`
|
|
158
|
+
`).join(`
|
|
159
|
+
`)},
|
|
160
|
+
}`},[]);return((v=n==null?void 0:n.jsx)==null?void 0:v.length)>0&&c?a.jsx(Wy,{onCopy:h,code:t==="tailwind"?y:t==="html"?n.html:n.jsx,language:f()||"",downloadText:b,onDownload:x},t):a.jsx("div",{className:"flex h-[620px] w-full items-center justify-center p-4",children:"Generating code..."})},Vc=()=>{const{t}=F.useTranslation(),[e,n]=g.useState(!1),{setMode:s}=Hi(),[r,o]=g.useState("js"),i=g.useCallback(async()=>{o("js"),s("view"),n(!0)},[o,s,n]);Yt(Y.OPEN_EXPORT_CODE,i);const l=async()=>{s("edit"),await new Promise(c=>setTimeout(c,300)),n(!1)};return a.jsx(Pn,{open:e,onOpenChange:l,children:a.jsxs(cn,{className:"max-w-5xl overflow-hidden border-border",children:[a.jsxs(Ln,{className:"flex flex-row items-center justify-between",children:[a.jsx(dn,{className:"text-foreground",children:t("Export Code")}),a.jsx(Os,{defaultValue:"js",onValueChange:o,children:a.jsxs(On,{children:[a.jsx(He,{value:"js",children:"Javascript"}),a.jsx(He,{value:"ts",children:"Typescript"}),a.jsx(He,{value:"html",children:"HTML"}),a.jsx(He,{value:"tailwind",children:"Tailwind config"})]})}),a.jsx("div",{})]}),a.jsx("div",{className:"flex min-h-[400px] flex-col gap-4",children:e&&a.jsx(g.Suspense,{fallback:a.jsx("div",{className:"flex h-[400px] items-center justify-center text-muted-foreground",children:"Loading code editor..."}),children:a.jsx(At.ErrorBoundary,{fallback:a.jsx("div",{children:"Something went wrong"}),children:a.jsx(qy,{tab:r})})})})]})})},Ky=()=>{const t=$("smallScreenComponent",null);return a.jsx("section",{className:"fixed inset-0 z-[99999] flex h-screen w-screen items-center justify-center bg-white xl:hidden",children:t?g.createElement(t):a.jsx("div",{className:"flex h-full w-full items-center justify-center bg-[linear-gradient(to_right,#f3f4f6_1px,transparent_1px),linear-gradient(to_bottom,#f3f4f6_1px,transparent_1px)] bg-[size:10px_10px] py-12 sm:py-16 lg:py-20",children:a.jsx("div",{className:"mx-auto max-w-7xl px-4 sm:px-6 lg:px-8",children:a.jsxs("div",{className:"mx-auto max-w-md space-y-6 text-center",children:[a.jsx("img",{src:"https://ucarecdn.com/fbfc3b05-cb73-4e99-92a2-3a367b7c36cd/",alt:"Chai Builder",className:"mx-auto h-20 w-20 rounded-full shadow-lg transition-transform duration-300 hover:scale-105"}),a.jsxs("div",{className:"space-y-4",children:[a.jsx("h2",{className:"text-5xl font-bold tracking-tight text-gray-900",children:"Screen too small"}),a.jsxs("p",{className:"mx-auto max-w-sm text-sm leading-7 text-gray-600",children:["Please view this page on greater than ",a.jsx("strong",{className:"font-medium",children:"1280px"})," screen width for the best experience."]})]}),a.jsx("div",{className:"pt-4",children:a.jsxs("div",{className:"inline-flex items-center rounded-full bg-gray-100 px-4 py-2 text-sm text-gray-700",children:[a.jsx("svg",{className:"mr-2 h-5 w-5",fill:"none",stroke:"currentColor",viewBox:"0 0 24 24",children:a.jsx("path",{strokeLinecap:"round",strokeLinejoin:"round",strokeWidth:"2",d:"M12 9v2m0 4h.01m-6.938 4h13.856c1.54 0 2.502-1.667 1.732-3L13.732 4c-.77-1.333-2.694-1.333-3.464 0L3.34 16c-.77 1.333.192 3 1.732 3z"})}),"Minimum width: 1280px"]})})]})})})})},Yy=()=>{const{clear:t}=Tn(),[,e]=U(),{clearHighlight:n}=rt(),[,s]=Ae(),[,r]=j.useAtom(gi),{reset:o}=As(),{setSaveState:i}=sn(),[,l]=oi(),[,c]=j.useAtom(ws);return()=>{l({}),e([]),s([]),n(),t(),r(!1),o(),i("SAVED"),c(0)}},Xy=(t,e)=>{const n=[];let s=d.find(t,{_id:e}),r=d.get(s,"_parent","");for(;d.isString(r)&&!d.isEmpty(r);)n.push(s==null?void 0:s._parent),s=d.find(t,{_id:r}),r=s==null?void 0:s._parent;return d.flatten(n)},Jy=j.atom([]),Zy=()=>{const[t]=U(),e=j.useAtomValue(Se),[,n]=j.useAtom(Jy);g.useEffect(()=>{let s=[];const r=d.first(t);d.isString(r)&&(s=[r,...Xy(e,r)]),n(s)},[t,e,n])},Qy=t=>{const[,e]=Z(),n=Yy(),[s]=j.useAtom(js);j.useAtom(qr),Fi(),Zy(),pu(),Xu(),ku();const{postMessage:r}=fi(),[,o]=j.useAtom(ci),i=zr();return g.useEffect(()=>{We.set($r,d.omit(t,["blocks","translations","pageExternalData","globalStyles"]))},[t]),g.useEffect(()=>{We.set(Fr,t.pageExternalData||{})},[t.pageExternalData]),g.useEffect(()=>{We.set(en,t.designTokens||{})},[t.designTokens]),g.useEffect(()=>{o(!1),setTimeout(()=>{const l=K.syncBlocksWithDefaultProps(t.blocks||[]);e(l),l&&l.length>0&&r({type:"blocks-updated",blocks:l}),n(),o(!0),i(l)},400)},[t.blocks]),g.useEffect(()=>{mt.changeLanguage(t.locale||"en")},[t.locale]),g.useEffect(()=>{Fy(t.debugLogs??!1)},[t.debugLogs]),g.useEffect(()=>{t.translations&&d.each(t.translations,(l,c)=>{mt.addResourceBundle(c,"translation",l,!0,!0)})},[t.translations]),g.useEffect(()=>(s!=="SAVED"?window.onbeforeunload=()=>"":window.onbeforeunload=null,()=>{window.onbeforeunload=null}),[s]),null},e0=t=>{const e=g.useMemo(()=>t.layout||By,[t.layout]),n=$("builderTheme",Qe.defaultThemeValues),s=$("flags.exportCode",!1);return a.jsxs(a.Fragment,{children:[t.children,a.jsx(eo,{theme:n}),a.jsx(e,{}),s&&a.jsx(Vc,{})]})},t0=t=>{const e=t.onError||d.noop;return a.jsx("div",{className:"h-screen w-screen",children:a.jsxs(At.ErrorBoundary,{fallback:a.jsx(vn,{}),onError:e,children:[a.jsx(Ky,{}),a.jsx(e0,{...t}),a.jsx(Qy,{...t}),a.jsx(Ly,{}),a.jsx(ce.Toaster,{richColors:!0}),a.jsx($y,{})]})})},n0=({baseUrl:t="https://chaibuilder-sdk.vercel.app"}={})=>({name:"Chai Library",description:"",getBlocksList:async e=>{try{const n=await fetch(`${t}/library-blocks/blocks-list.json`);return n.ok?(await n.json()).map(r=>{var o;return{...r,preview:(o=r.preview)!=null&&o.startsWith("http")?r.preview:`${t}${r.preview}`}}):(console.error("Failed to fetch blocks list:",n.status,n.statusText),[])}catch(n){return console.error("Error fetching blocks list:",n),[]}},getBlock:async({block:e})=>{try{const n=await fetch(`${t}/${e.id}.html?raw`);return n.ok?await n.text():(console.error(`Failed to fetch block "${e.id}" from "${t}/${e.id}.html?raw": ${n.status} ${n.statusText}`),`<!-- Error loading block "${e.id}": ${n.status} ${n.statusText} -->`)}catch(n){return console.error(`Error fetching block "${e.id}" from "${t}/${e.id}.html?raw":`,n),`<!-- Error loading block "${e.id}" -->`}}}),s0=(t,e)=>t.map(n=>{const s=K.getRegisteredChaiBlock(n._type);if(!s)return n;const r=s.i18nProps;if(!r)return n;const o=d.filter(e,{_type:n._type}),i=d.pick(n,r);return d.each(i,(l,c)=>{const u=d.find(o,p=>{var h;const f=typeof p[c]=="string"?(h=p[c])==null?void 0:h.trim().toLowerCase():JSON.stringify(p[c]),m=typeof l=="string"?l.trim().toLowerCase():JSON.stringify(l);return f===m});if(u){const p=d.filter(Object.keys(u),m=>d.startsWith(m,`${c}-`)),f=d.pick(u,p);n={...n,...f}}}),n}),r0=()=>{const[t]=Z();return g.useCallback(e=>{const n=pe.getBlocksFromHTML(e),s=pe.mergeBlocksWithExisting(n,t);return s0(s,t)},[t])},Wc=(t,e)=>{const n=t.filter(r=>r._parent===e),s=n.flatMap(r=>Wc(t,r._id));return[...n,...s]},o0=(t,e)=>{const n=e.find(r=>r._id===t);if(!n)return[];const s=Wc(e,t);return[n,...s]},a0=()=>{const t=J(),[e]=Z();return g.useCallback((n="")=>{const s=t!=null&&t._id?o0(t._id,e):e;return s?d.compact(s.map(r=>{const o=K.getRegisteredChaiBlock(r._type);if(!o)return null;const i=(o==null?void 0:o.i18nProps)??[];if(i.length===0)return null;const l=n==="ALL"?Object.keys(r).filter(u=>i.find(p=>u.startsWith(p))):i.map(u=>n?`${u}-${n}`:u),c=d.pick(r,["_id"]);return d.each(l,u=>{c[u]=d.get(r,u,d.get(r,u.replace(`-${n}`,"")))}),c})):[]},[t==null?void 0:t._id,e])},Gc=(t,e)=>{const n=t.filter(o=>o._parent===e),s=n.map(o=>o._id),r=n.flatMap(o=>Gc(t,o._id));return[...s,...r]},i0=(t,e,n)=>{const s=d.find(t,{_id:e});if(!s)return t;const r=t.findIndex(f=>f._id===e),o=Gc(t,e),i=new Set([e,...o]),l=t.filter(f=>!i.has(f._id)),c=new Set(n.map(f=>f._id)),u=n.map(f=>!f._parent||!c.has(f._parent)?{...f,_parent:s._parent}:f);return[...l.slice(0,r),...u,...l.slice(r)]},l0=()=>{const[,t]=U(),{setNewBlocks:e}=Ee(),{hasPermission:n}=Ve();return g.useCallback((s,r)=>{if(!n(Q.EDIT_BLOCK))return;const o=We.get(Se),i=s?i0(o,s,r):r;e(i),r.length>0&&setTimeout(()=>t([r[0]._id]),200)},[t,e,n])};if(typeof window>"u")throw new Error("@chaibuilder/sdk is only supported in the browser. Avoid using it in the server side.");exports.AIUserPrompt=Bc;exports.Accordion=Yl;exports.AccordionContent=Eo;exports.AccordionItem=So;exports.AccordionTrigger=No;exports.AddBlocksDialog=$c;exports.AddBlocksPanel=Do;exports.AlertDialog=$o;exports.AlertDialogAction=Ho;exports.AlertDialogCancel=Vo;exports.AlertDialogContent=Fs;exports.AlertDialogDescription=zo;exports.AlertDialogFooter=Fo;exports.AlertDialogHeader=zs;exports.AlertDialogTitle=Hs;exports.AlertDialogTrigger=kc;exports.Badge=Rs;exports.BlockAttributesEditor=Fc;exports.BlockSettings=br;exports.BlockStyling=jr;exports.Breakpoints=_o;exports.CanvasArea=Hl;exports.Card=Bo;exports.CardContent=Po;exports.CardFooter=Lo;exports.CardHeader=Ro;exports.CardTitle=lc;exports.ChaiBuilderEditor=t0;exports.ChaiDraggableBlock=mc;exports.ChaiFrame=Mi;exports.Command=go;exports.CommandEmpty=yo;exports.CommandGroup=ko;exports.CommandInput=xo;exports.CommandItem=xs;exports.CommandList=bo;exports.CssThemeVariables=eo;exports.DarkMode=Pc;exports.DefaultChaiBlocks=ic;exports.Dialog=Pn;exports.DialogContent=cn;exports.DialogDescription=Ul;exports.DialogFooter=Gl;exports.DialogHeader=Ln;exports.DialogTitle=dn;exports.DialogTrigger=Vl;exports.DropdownMenu=tt;exports.DropdownMenuContent=Ue;exports.DropdownMenuItem=de;exports.DropdownMenuSeparator=Ar;exports.DropdownMenuTrigger=nt;exports.ExportCodeModal=Vc;exports.HoverCard=rc;exports.HoverCardContent=Io;exports.HoverCardTrigger=oc;exports.IframeInitialContent=Pi;exports.ImportHTML=dc;exports.LANGUAGES=Ot;exports.Label=ut;exports.ListTree=Nc;exports.ManualClasses=To;exports.NestedPathSelector=Co;exports.PERMISSIONS=Q;exports.Popover=vo;exports.PopoverContent=Ps;exports.PopoverTrigger=wo;exports.ScrollArea=An;exports.Select=$s;exports.SelectContent=zn;exports.SelectItem=Hn;exports.SelectTrigger=Fn;exports.Separator=Rt;exports.Sheet=Mc;exports.SheetContent=Wo;exports.SheetDescription=Oc;exports.SheetHeader=Go;exports.SheetTitle=Uo;exports.SheetTrigger=yy;exports.Skeleton=Lt;exports.Switch=un;exports.Tabs=Os;exports.TabsContent=ct;exports.TabsList=On;exports.TabsTrigger=He;exports.Textarea=$n;exports.ThemeConfigPanel=Ic;exports.Tooltip=fe;exports.TooltipContent=ue;exports.TooltipProvider=gs;exports.TooltipTrigger=he;exports.UILibrariesPanel=xc;exports.UndoRedo=Lc;exports.chaiDesignTokensAtom=en;exports.constructClassObject=Ms;exports.defaultChaiLibrary=n0;exports.getClassValueAndUnit=Zl;exports.libraryBlocksAtom=fc;exports.orderClassesByBreakpoint=tc;exports.removeDuplicateClasses=nc;exports.useAddBlock=xt;exports.useBlocksHtmlForAi=Hc;exports.useBlocksStore=Z;exports.useBuilderProp=$;exports.useCodeEditor=mo;exports.useDarkMode=an;exports.useFrame=Xe;exports.useHtmlToBlocks=r0;exports.useI18nBlocks=a0;exports.useIncrementActionsCount=Hr;exports.useIsPageLoaded=di;exports.useLanguages=_e;exports.useLibraryBlocks=hc;exports.usePageExternalData=tn;exports.usePartialBlocksStore=As;exports.usePermissions=Ve;exports.useRemoveBlocks=Ss;exports.useReplaceBlock=l0;exports.useRightPanel=ui;exports.useSavePage=sn;exports.useSelectedBlock=J;exports.useSelectedBlockIds=U;exports.useSidebarActivePanel=Is;exports.useStreamMultipleBlocksProps=ri;exports.useTheme=_n;exports.useThemeOptions=nn;exports.useUpdateBlocksProps=st;exports.useUpdateBlocksPropsRealtime=Dr;
|