@marimo-team/islands 0.19.10-dev2 → 0.19.10-dev21
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/dist/{ConnectedDataExplorerComponent-BAeQ8DWw.js → ConnectedDataExplorerComponent-CkXO-pKy.js} +6 -6
- package/dist/{react-plotly-BuRa9xtI.js → Plot-CmsrWWji.js} +72 -286
- package/dist/{any-language-editor-D0UQItkS.js → any-language-editor-t_VsTNa-.js} +16 -16
- package/dist/apl-C1bki_dE.js +4 -0
- package/dist/{arc-CEWBr4jc.js → arc-9nABupDE.js} +2 -2
- package/dist/{architectureDiagram-VXUJARFQ-DPPYVq8H.js → architectureDiagram-VXUJARFQ-DmJQhcJb.js} +6 -6
- package/dist/asciiarmor-BdlkCCRr.js +4 -0
- package/dist/asn1-CvE30hox.js +4 -0
- package/dist/{blockDiagram-VD42YOAC-BA5N05Y9.js → blockDiagram-VD42YOAC-CRofISJs.js} +10 -10
- package/dist/brainfuck-BalwWy1a.js +4 -0
- package/dist/{c4Diagram-YG6GDRKO-DJLzuGJJ.js → c4Diagram-YG6GDRKO-Deqoag4I.js} +4 -4
- package/dist/{channel-Dob5kWXR.js → channel-CMsnebrL.js} +1 -1
- package/dist/{chunk-4BX2VUAB-DZQibjKA.js → chunk-4BX2VUAB-WmXmzRBr.js} +1 -1
- package/dist/{chunk-55IACEB6-C3BASkh4.js → chunk-55IACEB6-irYMvHJu.js} +1 -1
- package/dist/{chunk-5FQGJX7Z-BEb20Lzt.js → chunk-5FQGJX7Z-pOElJy8t.js} +2 -2
- package/dist/{chunk-ABZYJK2D-BXTC53mt.js → chunk-ABZYJK2D-BGWvKte3.js} +2 -2
- package/dist/{chunk-ATLVNIR6-BJDjUR_c.js → chunk-ATLVNIR6-BYZB6C5T.js} +2 -2
- package/dist/{chunk-B4BG7PRW-DzmUUpfH.js → chunk-B4BG7PRW-CwYUp6Uj.js} +7 -7
- package/dist/{chunk-CVBHYZKI-Dhc_e3rA.js → chunk-CVBHYZKI-Bb2XMuXJ.js} +1 -1
- package/dist/{chunk-DI55MBZ5-gTd3J8Tu.js → chunk-DI55MBZ5-Gyro6dvN.js} +6 -6
- package/dist/{chunk-EXTU4WIE-DyoOs5QX.js → chunk-EXTU4WIE-BlA7aWEw.js} +2 -2
- package/dist/{chunk-FMBD7UC4-geNUIndh.js → chunk-FMBD7UC4-C0DZU_4q.js} +1 -1
- package/dist/{chunk-HN2XXSSU-CqPwpolw.js → chunk-HN2XXSSU-BsB4dtgF.js} +1 -1
- package/dist/{chunk-JA3XYJ7Z-BGnAIbOP.js → chunk-JA3XYJ7Z-Cm-pccR-.js} +3 -3
- package/dist/{chunk-JZLCHNYA-CIRgweVQ.js → chunk-JZLCHNYA-CoLqqXMe.js} +6 -6
- package/dist/{chunk-MI3HLSF2-DOJkNER1.js → chunk-MI3HLSF2-DeDZS-tQ.js} +1 -1
- package/dist/{chunk-N4CR4FBY-DKSvXAIS.js → chunk-N4CR4FBY-ByLbY9L-.js} +7 -7
- package/dist/{chunk-QN33PNHL-B6zC8BTi.js → chunk-QN33PNHL-eodIiY9F.js} +2 -2
- package/dist/{chunk-QXUST7PY-C7750n_u.js → chunk-QXUST7PY-CuJlDW6A.js} +10 -10
- package/dist/{chunk-QZHKN3VN-BF_oGUlG.js → chunk-QZHKN3VN-Diy_Cdek.js} +1 -1
- package/dist/{chunk-S3R3BYOJ-CBkH6JZZ.js → chunk-S3R3BYOJ-CwDGYMVf.js} +3 -3
- package/dist/{chunk-TZMSLE5B-DObGL7xi.js → chunk-TZMSLE5B-DFDr5FCr.js} +2 -2
- package/dist/classDiagram-2ON5EDUG-BDBX9etk.js +30 -0
- package/dist/classDiagram-v2-WZHVMYZB-Bzj_L_BF.js +30 -0
- package/dist/{clike-B1zispTy.js → clike-B90WKs4D.js} +1 -1
- package/dist/clojure-CUC2I1hM.js +4 -0
- package/dist/cmake-8PcMxXnB.js +4 -0
- package/dist/cobol-DkkkDz5v.js +4 -0
- package/dist/{code-block-37QAKDTI-u5kgjqmr.js → code-block-37QAKDTI-zh5AeoJo.js} +1 -1
- package/dist/coffeescript-CCupxOZf.js +4 -0
- package/dist/commonlisp-DhUfGX6b.js +4 -0
- package/dist/{cose-bilkent-S5V4N54A-CO4ORQHF.js → cose-bilkent-S5V4N54A-BK1nIR2J.js} +1 -1
- package/dist/crystal-DSaw6rFQ.js +4 -0
- package/dist/css-D4QDewkG.js +4 -0
- package/dist/cypher-CrYVqw_F.js +4 -0
- package/dist/d-Cr3H3pPx.js +4 -0
- package/dist/{dagre-6UL2VRFP-C2C2XxsB.js → dagre-6UL2VRFP-r2rSdJYL.js} +9 -9
- package/dist/{data-grid-overlay-editor-BXqtz1ia.js → data-grid-overlay-editor-BVFT970w.js} +2 -2
- package/dist/{diagram-PSM6KHXK-DHBY-94p.js → diagram-PSM6KHXK-BpxVUe9U.js} +10 -10
- package/dist/{diagram-QEK2KX5R-CgMshOwn.js → diagram-QEK2KX5R-q3dHUcp6.js} +5 -5
- package/dist/{diagram-S2PKOQOG-F1KPva3Y.js → diagram-S2PKOQOG-MDBKrxSC.js} +5 -5
- package/dist/diff-ODiZJGls.js +4 -0
- package/dist/dist-4YNZxwMI.js +8 -0
- package/dist/dist-7nR3r2kG.js +5 -0
- package/dist/{dist-CBA36Nuy.js → dist-B2-r9y-0.js} +109 -109
- package/dist/dist-B2gkyT3r.js +5 -0
- package/dist/{dist--JwRU9u5.js → dist-B4tYJP_i.js} +2 -2
- package/dist/{dist-DA1J6LvO.js → dist-B5ATpkxy.js} +2 -2
- package/dist/dist-B8G3I6vJ.js +8 -0
- package/dist/{dist-DKnxaCRl.js → dist-B94MxrQS.js} +2 -2
- package/dist/dist-BJ96Ykfp.js +8 -0
- package/dist/dist-BKLIWGw4.js +5 -0
- package/dist/{dist-l0KayR2-.js → dist-BLwfpZD-.js} +2 -2
- package/dist/{dist-C_Kw_Kc0.js → dist-BYmtF1W6.js} +2 -2
- package/dist/{dist-Cpj5BHNP.js → dist-BbBnU4tG.js} +1 -1
- package/dist/dist-Bf3ou00A.js +6 -0
- package/dist/{dist-CITQGRtG.js → dist-BfactX3G.js} +4 -4
- package/dist/{dist-CsN7lsea.js → dist-BoAHOW2l.js} +2 -2
- package/dist/{dist-BcXuIt-h.js → dist-Bsv_ARko.js} +4 -4
- package/dist/dist-BvkKXuPm.js +5 -0
- package/dist/{dist-DsqQCNKw.js → dist-C2-m5aEk.js} +119 -119
- package/dist/dist-C6NJ3n6r.js +5 -0
- package/dist/{dist-DIVeCGlI.js → dist-CC9VUnXd.js} +1 -1
- package/dist/{dist-BKGWAN8J.js → dist-CE43BRmt.js} +1 -1
- package/dist/{dist-COp5dkis.js → dist-CJrHMxlI.js} +31 -31
- package/dist/{dist-BbQ-5HAA.js → dist-CPTE45iS.js} +1 -1
- package/dist/{dist-9trj4p6n.js → dist-CcOGT46m.js} +27 -27
- package/dist/dist-CecLPYY5.js +5 -0
- package/dist/{dist-BSMZYwqW.js → dist-Cgf353Ki.js} +1 -1
- package/dist/dist-Ch0SwRzK.js +5 -0
- package/dist/{dist-C6p7UKkB.js → dist-CkEUrAus.js} +2 -2
- package/dist/{dist-MFzhAmKV.js → dist-CmZYrgd_.js} +1 -1
- package/dist/{dist-b7Sc3Tj8.js → dist-Crk9ejOy.js} +4 -4
- package/dist/dist-D6eWHiFh.js +6 -0
- package/dist/dist-DCQ710Bv.js +5 -0
- package/dist/{dist-r6N_0WG-.js → dist-DOil6y-3.js} +4 -4
- package/dist/{dist-CPd_adhw.js → dist-Dc1SFk5I.js} +2 -2
- package/dist/dist-Dit9tk8a.js +1242 -0
- package/dist/{dist-B7NoEgR4.js → dist-DqJdzAYM.js} +2 -2
- package/dist/dist-P_pkS5f-.js +8 -0
- package/dist/{dist--Em7gfgX.js → dist-T4g7Sr6e.js} +3 -3
- package/dist/{dist-BhBtK2sL.js → dist-glA_fIK_.js} +2 -2
- package/dist/{dist-9J8_3DZN.js → dist-iiugPhCC.js} +1 -1
- package/dist/{dist-D7jHtwN8.js → dist-r8ecBV-v.js} +135 -65
- package/dist/{dist-BlRm4v0e.js → dist-yVJ4xE5n.js} +5 -5
- package/dist/{dockerfile-BBT_Ira6.js → dockerfile-D1Q_4uCN.js} +1 -1
- package/dist/dtd-C-t2Rk7F.js +4 -0
- package/dist/dylan-B4ctBLGp.js +4 -0
- package/dist/ecl-DqWfymni.js +4 -0
- package/dist/eiffel-DjBKKAr7.js +4 -0
- package/dist/elm--fxeC0FV.js +4 -0
- package/dist/{erDiagram-Q2GNP2WA-18gGng8V.js → erDiagram-Q2GNP2WA-CX1XdqVD.js} +13 -13
- package/dist/erlang-CaKXCX6H.js +4 -0
- package/dist/{esm-CgRNPmz8.js → esm-BAS2d2Ad.js} +1503 -1536
- package/dist/{factor-DdqWbSyy.js → factor--4HHM8Rw.js} +1 -1
- package/dist/factor-DlLO5EFS.js +4 -0
- package/dist/{flowDiagram-NV44I4VS-iHFiHYe0.js → flowDiagram-NV44I4VS-BCj-ONTw.js} +15 -15
- package/dist/forth-rOO6LVj_.js +4 -0
- package/dist/fortran-CUg15VGR.js +4 -0
- package/dist/{ganttDiagram-JELNMOA3-D7GixxiF.js → ganttDiagram-JELNMOA3-D1l5ewiQ.js} +8 -8
- package/dist/gas-BMRJspiW.js +4 -0
- package/dist/gherkin-DRxzijZU.js +4 -0
- package/dist/{gitGraphDiagram-NY62KEGX-CJFHytRK.js → gitGraphDiagram-NY62KEGX-KdZh0iiW.js} +5 -5
- package/dist/{glide-data-editor-BYwb17Bf.js → glide-data-editor-2RvcPqmc.js} +75 -76
- package/dist/groovy-BmrQ8pUP.js +4 -0
- package/dist/haskell-BuaYfKOz.js +4 -0
- package/dist/haxe-DcH9eA0a.js +5 -0
- package/dist/idl-DGlcm4Ls.js +4 -0
- package/dist/{infoDiagram-WHAUD3N6-B5Lkh3A9.js → infoDiagram-WHAUD3N6-PSH7lQ0D.js} +3 -3
- package/dist/javascript-CeTk7rzr.js +4 -0
- package/dist/{journeyDiagram-XKPGCS4Q-CV_9R9iP.js → journeyDiagram-XKPGCS4Q-BrTAxQ1J.js} +5 -5
- package/dist/julia-BoP_q1gm.js +4 -0
- package/dist/{kanban-definition-3W4ZIXB7-Dp21D5Ym.js → kanban-definition-3W4ZIXB7-BoYCDp_9.js} +10 -10
- package/dist/{katex-CX2BKujk.js → katex-DaGuLbVh.js} +1 -1
- package/dist/{line-LK_5q2B9.js → line-Bc27KE1D.js} +3 -3
- package/dist/{linear-vWf1Qj0e.js → linear-Bnc6E9kA.js} +4 -4
- package/dist/livescript-B7IMN-ba.js +4 -0
- package/dist/{loader-B0KEFFi-.js → loader-C0-eIoas.js} +1 -1
- package/dist/lua-q1InavKb.js +4 -0
- package/dist/main.js +207 -204
- package/dist/mathematica-DvR8-_EI.js +4 -0
- package/dist/mbox-7h5MNBS_.js +4 -0
- package/dist/{mermaid-4DMBBIKO-BhDCqnO1.js → mermaid-4DMBBIKO-BmJdHPwx.js} +1 -1
- package/dist/{mermaid-B__BZSXU.js → mermaid-C2cSe5YL.js} +40 -40
- package/dist/{mhchem-w1tkUnWr.js → mhchem-B_tiMbKF.js} +1 -1
- package/dist/{mindmap-definition-VGOIOE7T-B_5mfdYp.js → mindmap-definition-VGOIOE7T-CmRjsKEt.js} +12 -12
- package/dist/mirc-D-XM8A5c.js +4 -0
- package/dist/mllike-BQGkkbmf.js +6 -0
- package/dist/modelica-D_yRj_WU.js +4 -0
- package/dist/mscgen-B-rltAjp.js +6 -0
- package/dist/mumps-2kh8TU2b.js +4 -0
- package/dist/{nsis-CunMjZ_n.js → nsis-B6EN9LWI.js} +1 -1
- package/dist/nsis-CtusEqwb.js +4 -0
- package/dist/ntriples-BdAXw6zV.js +4 -0
- package/dist/{number-overlay-editor-D-4WQAGX.js → number-overlay-editor-DKVJgXpp.js} +1 -1
- package/dist/octave-CsNFmVp5.js +4 -0
- package/dist/{ordinal-IlASfRja.js → ordinal-DLLbwLkP.js} +1 -1
- package/dist/oz-odIXCrKd.js +4 -0
- package/dist/pascal-B9Mfk3Fo.js +4 -0
- package/dist/perl-C48inLcz.js +4 -0
- package/dist/{pieDiagram-ADFJNKIX-B-DGEopK.js → pieDiagram-ADFJNKIX-CtxQlnsU.js} +10 -10
- package/dist/pig-uwRtAssU.js +4 -0
- package/dist/powershell-CXqlca-i.js +4 -0
- package/dist/{precisionRound-CGLoV26P.js → precisionRound-Duzbr5ur.js} +1 -1
- package/dist/properties-D6Zu1rpK.js +4 -0
- package/dist/protobuf-BlNNWZaR.js +4 -0
- package/dist/pug-DytcK7bv.js +4 -0
- package/dist/{pug-Dr-sA_9V.js → pug-xrm7jQ2R.js} +1 -1
- package/dist/puppet-lJ8Ok3iY.js +4 -0
- package/dist/python-cMaF7kUp.js +4 -0
- package/dist/q-Dgt2HYQh.js +4 -0
- package/dist/{quadrantDiagram-AYHSOK5B-M_yRSIZn.js → quadrantDiagram-AYHSOK5B-DllnB2Hl.js} +4 -4
- package/dist/r-Bm4S4awf.js +4 -0
- package/dist/react-vega-1ub36dPZ.js +9 -0
- package/dist/{react-vega-DLFvGrpJ.js → react-vega-CCNu2JE0.js} +18 -18
- package/dist/{requirementDiagram-UZGBJVZJ-9Wt82hOZ.js → requirementDiagram-UZGBJVZJ-D36MI1k0.js} +12 -12
- package/dist/rpm-_8LbzMVc.js +5 -0
- package/dist/ruby-Cr8IJ5VZ.js +4 -0
- package/dist/{sankeyDiagram-TZEHDZUN-x_aTXZeN.js → sankeyDiagram-TZEHDZUN-D1mygNPC.js} +4 -4
- package/dist/sas-CFcSfo2_.js +4 -0
- package/dist/scheme-N4XRoKgc.js +4 -0
- package/dist/{sequenceDiagram-WL72ISMW-CXXmJqiQ.js → sequenceDiagram-WL72ISMW-CWdn91Rf.js} +6 -6
- package/dist/shell-B4L7f_ds.js +4 -0
- package/dist/sieve-UI6J3Gm0.js +4 -0
- package/dist/smalltalk-BuaPZAZU.js +4 -0
- package/dist/sparql-1rKrq463.js +4 -0
- package/dist/{src-szye8OCw.js → src-jICM_d2B.js} +1 -1
- package/dist/{stateDiagram-FKZM4ZOC-CiSKS_Mx.js → stateDiagram-FKZM4ZOC-CPxroWXd.js} +15 -15
- package/dist/{stateDiagram-v2-4FDKWEC3-A43Itnjp.js → stateDiagram-v2-4FDKWEC3-BpM9Q54b.js} +13 -13
- package/dist/{step-1PmBKr2y.js → step-BqVgkWtk.js} +1 -1
- package/dist/stylus-DvSovJEP.js +4 -0
- package/dist/swift-D-_E7Yyb.js +4 -0
- package/dist/tcl-Di5sAVHN.js +4 -0
- package/dist/textile-Benwt66z.js +4 -0
- package/dist/{time-DC4qQGmA.js → time-CrYsYnQU.js} +4 -4
- package/dist/{timeline-definition-IT6M3QCI-DR26eWb4.js → timeline-definition-IT6M3QCI-CVnRHx_t.js} +3 -3
- package/dist/toml-CeOvPOkY.js +4 -0
- package/dist/troff-DJN9hfgu.js +4 -0
- package/dist/ttcn-DQW2Psjf.js +4 -0
- package/dist/ttcn-cfg-zFG_MNpg.js +4 -0
- package/dist/turtle-DHRyNlSc.js +4 -0
- package/dist/{types-Bb-6p8hv.js → types-Ckva8JJq.js} +203 -156
- package/dist/{useDeepCompareMemoize-BhZZsis0.js → useDeepCompareMemoize-ChviuF5n.js} +1 -1
- package/dist/vb-CXWH9DD-.js +4 -0
- package/dist/vbscript-qr8qVck5.js +4 -0
- package/dist/{vega-component-DCxUyPnb.js → vega-component-CnG0vAjf.js} +7 -7
- package/dist/{vega-loader.browser-BJ1uJidF.js → vega-loader.browser-DqHiiBeQ.js} +3 -3
- package/dist/velocity-C_9pUJRx.js +4 -0
- package/dist/verilog-DxBstgBa.js +4 -0
- package/dist/vhdl-odUxAbE6.js +4 -0
- package/dist/webidl-Dfn5Rku4.js +4 -0
- package/dist/xquery-CrJs6SXr.js +4 -0
- package/dist/{xychartDiagram-PRI3JC2R-BcVxCRox.js → xychartDiagram-PRI3JC2R-BltwMWKC.js} +11 -11
- package/dist/yacas-B-uDDLZe.js +4 -0
- package/dist/z80-51gxgAXE.js +4 -0
- package/package.json +10 -11
- package/src/components/data-table/__tests__/columns.test.tsx +47 -0
- package/src/components/data-table/column-header.tsx +3 -0
- package/src/components/data-table/columns.tsx +17 -2
- package/src/components/editor/chrome/wrapper/app-chrome.tsx +2 -0
- package/src/core/codemirror/misc/__tests__/paste.test.ts +18 -0
- package/src/core/codemirror/misc/paste.ts +14 -10
- package/src/plugins/impl/chat/ChatPlugin.tsx +2 -0
- package/src/plugins/impl/chat/chat-ui.tsx +10 -1
- package/src/plugins/impl/plotly/Plot.tsx +171 -0
- package/src/plugins/impl/plotly/PlotlyPlugin.tsx +5 -10
- package/src/plugins/impl/plotly/__tests__/parse-from-template.test.ts +1 -0
- package/src/plugins/impl/plotly/__tests__/usePlotlyLayout.test.ts +2 -1
- package/src/plugins/impl/plotly/parse-from-template.ts +1 -0
- package/src/plugins/impl/plotly/usePlotlyLayout.ts +2 -1
- package/src/theme/ThemeProvider.tsx +2 -0
- package/dist/apl-BuwKwesW.js +0 -4
- package/dist/asciiarmor-zAEd_wtn.js +0 -4
- package/dist/asn1-DWEA66J4.js +0 -4
- package/dist/brainfuck-mIPR6Ong.js +0 -4
- package/dist/classDiagram-2ON5EDUG-B9pkKjjc.js +0 -30
- package/dist/classDiagram-v2-WZHVMYZB-CRhhA0tV.js +0 -30
- package/dist/clojure-DkhhNHNQ.js +0 -4
- package/dist/cmake-1obPvqtc.js +0 -4
- package/dist/cobol-oWNTiXPE.js +0 -4
- package/dist/coffeescript-LtYUvf6r.js +0 -4
- package/dist/commonlisp-C_06qBYF.js +0 -4
- package/dist/crystal-CDJkbx14.js +0 -4
- package/dist/css-Bi_Nk0uN.js +0 -4
- package/dist/cypher-TrG0NvZ0.js +0 -4
- package/dist/d-CFKOrZsi.js +0 -4
- package/dist/diff-CfnSF48q.js +0 -4
- package/dist/dist-2OSzSqy2.js +0 -5
- package/dist/dist-B1H2TQGB.js +0 -8
- package/dist/dist-BNvasp6N.js +0 -5
- package/dist/dist-CFi_P6cs.js +0 -5
- package/dist/dist-CG4LWTPv.js +0 -8
- package/dist/dist-CHWVQZ6Z.js +0 -6
- package/dist/dist-C_8-swED.js +0 -5
- package/dist/dist-DIhtur5b.js +0 -5
- package/dist/dist-DoQ7RS4e.js +0 -5
- package/dist/dist-DsMd-F9h.js +0 -5
- package/dist/dist-DurmUshd.js +0 -8
- package/dist/dist-PZgrh2z6.js +0 -6
- package/dist/dist-g1p2PEVs.js +0 -1242
- package/dist/dist-wudNDAiO.js +0 -5
- package/dist/dist-zVskjQcA.js +0 -8
- package/dist/dtd-Ctw8_JkU.js +0 -4
- package/dist/dylan-f7rMBKDP.js +0 -4
- package/dist/ecl-C2h3oBMY.js +0 -4
- package/dist/eiffel-Ce81wv20.js +0 -4
- package/dist/elm-BVV8QQcc.js +0 -4
- package/dist/erlang-DjB35ZUh.js +0 -4
- package/dist/factor-CIcp3U2B.js +0 -4
- package/dist/forth-CVgjsHhD.js +0 -4
- package/dist/fortran-CcTXj0d_.js +0 -4
- package/dist/gas-JWpamkLf.js +0 -4
- package/dist/gherkin-BveSCSJV.js +0 -4
- package/dist/groovy-Np3AZt00.js +0 -4
- package/dist/haskell-CVfmFALm.js +0 -4
- package/dist/haxe-C10xkMLg.js +0 -5
- package/dist/idl-CKBSGnKC.js +0 -4
- package/dist/javascript-Cur-15Bn.js +0 -4
- package/dist/julia-BZZH2Gnx.js +0 -4
- package/dist/livescript-D_rTTm_U.js +0 -4
- package/dist/lua-Mf_Of7eV.js +0 -4
- package/dist/mathematica-DCYjugDb.js +0 -4
- package/dist/mbox-KBWrT8JD.js +0 -4
- package/dist/mirc-JwEQJ8Fb.js +0 -4
- package/dist/mllike-C7TxLvh6.js +0 -6
- package/dist/modelica-uvNgvUyw.js +0 -4
- package/dist/mscgen-CGnokp5x.js +0 -6
- package/dist/mumps-Dl9QdOZz.js +0 -4
- package/dist/nsis-BbDhbgPN.js +0 -4
- package/dist/ntriples-ChL1mlp7.js +0 -4
- package/dist/octave-B9ZGG6zv.js +0 -4
- package/dist/oz-XHEu31wr.js +0 -4
- package/dist/pascal-BxtYw-iH.js +0 -4
- package/dist/perl-Br5BgHPb.js +0 -4
- package/dist/pig-BByO2hBz.js +0 -4
- package/dist/powershell-Cd4Zaef3.js +0 -4
- package/dist/prop-types-C9QZf2SY.js +0 -51
- package/dist/properties-B-BOCIOl.js +0 -4
- package/dist/protobuf-CaLimlho.js +0 -4
- package/dist/pug-bonARSG6.js +0 -4
- package/dist/puppet-BSlT-3sc.js +0 -4
- package/dist/python-BIJhGYYP.js +0 -4
- package/dist/q-D9TX8A0B.js +0 -4
- package/dist/r-BXelX7Rl.js +0 -4
- package/dist/react-vega-3WcLHYC7.js +0 -9
- package/dist/rpm-BxAh9B1A.js +0 -5
- package/dist/ruby-BCZLQyhc.js +0 -4
- package/dist/sas-Bo7lsyNX.js +0 -4
- package/dist/scheme-Brhptkt-.js +0 -4
- package/dist/shell-fWWb8_qx.js +0 -4
- package/dist/sieve-Ba8_hMLn.js +0 -4
- package/dist/smalltalk-7sHxwMDT.js +0 -4
- package/dist/sparql-BBFrPJ7z.js +0 -4
- package/dist/stylus-CIB0KT46.js +0 -4
- package/dist/swift-CZinekXz.js +0 -4
- package/dist/tcl-DCHZJVq_.js +0 -4
- package/dist/textile-ThTMxgkN.js +0 -4
- package/dist/toml-DK17wlJ7.js +0 -4
- package/dist/troff-CuUAOgMy.js +0 -4
- package/dist/ttcn-DS2tj6rW.js +0 -4
- package/dist/ttcn-cfg-CdZGarnc.js +0 -4
- package/dist/turtle-Bkz-FLZ7.js +0 -4
- package/dist/vb-ITdOmxvR.js +0 -4
- package/dist/vbscript-B7oeGyfL.js +0 -4
- package/dist/velocity-D__EkuSd.js +0 -4
- package/dist/verilog-CPH50gr9.js +0 -4
- package/dist/vhdl-CQAwKCk_.js +0 -4
- package/dist/webidl-BnEptfVX.js +0 -4
- package/dist/xquery-D7eTv-CR.js +0 -4
- package/dist/yacas-0x1rX89s.js +0 -4
- package/dist/z80-B25SJVDf.js +0 -4
- /package/dist/{ImageComparisonComponent-DkEXPki_.js → ImageComparisonComponent-CRbA-1eg.js} +0 -0
- /package/dist/{apl-D9gTcP3Q.js → apl-Oc3bL26_.js} +0 -0
- /package/dist/{array-D7wW5QoO.js → array-CEIRxyh3.js} +0 -0
- /package/dist/{asciiarmor-mLyg-Z5h.js → asciiarmor-DTbPh2VI.js} +0 -0
- /package/dist/{asn1-AE7eHomk.js → asn1-CGhwu1Ri.js} +0 -0
- /package/dist/{brainfuck-Bdd6NcL6.js → brainfuck-CA0L8lRq.js} +0 -0
- /package/dist/{click-outside-container-DNfggvIW.js → click-outside-container-C_k38vlR.js} +0 -0
- /package/dist/{clike-D_s3fKg5.js → clike-CEtUBPHD.js} +0 -0
- /package/dist/{clojure-zTYBCd80.js → clojure-BszjvdGo.js} +0 -0
- /package/dist/{cmake-BnJV90fC.js → cmake-B2Gvps8b.js} +0 -0
- /package/dist/{cobol-CH0OZO8A.js → cobol-DuMch8nn.js} +0 -0
- /package/dist/{coffeescript-CLhc1U6Q.js → coffeescript-L9aKXVsJ.js} +0 -0
- /package/dist/{colors-6DRQ0kEF.js → colors-DR_aHfmQ.js} +0 -0
- /package/dist/{commonlisp-8K2-IkUD.js → commonlisp-CrtdssxB.js} +0 -0
- /package/dist/{crystal-8to4H-ep.js → crystal-vvNY0LpY.js} +0 -0
- /package/dist/{css-BVo-JOy5.js → css-B1GdzqT1.js} +0 -0
- /package/dist/{cypher-BTFaDDd_.js → cypher-BtZvV7bW.js} +0 -0
- /package/dist/{d-c9bddW2W.js → d-B0UN3V-Z.js} +0 -0
- /package/dist/{defaultLocale-Bxoo2-30.js → defaultLocale-B_A76Zpk.js} +0 -0
- /package/dist/{defaultLocale-qS7DaAmi.js → defaultLocale-DjFHq3Xk.js} +0 -0
- /package/dist/{diff-PA28xMKg.js → diff-DOpgjj1W.js} +0 -0
- /package/dist/{dist-BBYTEAvO.js → dist-DF_77D2B.js} +0 -0
- /package/dist/{dtd-DRlC7Bx8.js → dtd-Ctnjxrle.js} +0 -0
- /package/dist/{dylan-d5ufc25E.js → dylan-DFXkoaZy.js} +0 -0
- /package/dist/{ecl-Ci3afVKc.js → ecl-C1NExZip.js} +0 -0
- /package/dist/{eiffel-G6DmeEi3.js → eiffel-uXVGgleg.js} +0 -0
- /package/dist/{elm-ByYWHu8b.js → elm-CBOFnnib.js} +0 -0
- /package/dist/{erlang-C7_LcVDw.js → erlang-DMnrT8XK.js} +0 -0
- /package/dist/{esm-CAd2HmbR.js → esm-0_ieXYNc.js} +0 -0
- /package/dist/{forth-BgUerAyz.js → forth-DDpxS4nw.js} +0 -0
- /package/dist/{fortran-BCXxm4xF.js → fortran-B6uYqQMz.js} +0 -0
- /package/dist/{gas-CKTQRKLl.js → gas-BKnWzuFz.js} +0 -0
- /package/dist/{gherkin-ByVP9cY_.js → gherkin-pBt0wT4X.js} +0 -0
- /package/dist/{groovy-BPbrw0GZ.js → groovy-DKsn4ppB.js} +0 -0
- /package/dist/{haskell-B8fq1DW4.js → haskell-BJVBJQcy.js} +0 -0
- /package/dist/{haxe-B7SHQmJo.js → haxe-rLN5UZU5.js} +0 -0
- /package/dist/{idl-CeJBDjsl.js → idl-B4mwMAo-.js} +0 -0
- /package/dist/{init-BfRhston.js → init-TaqZJsBY.js} +0 -0
- /package/dist/{javascript-dCv9_Kn8.js → javascript-Hf2NLNC0.js} +0 -0
- /package/dist/{julia-CD5lO88_.js → julia-GGpx21YN.js} +0 -0
- /package/dist/{katex-Db0k5oV_.js → katex-Ba7xZPrx.js} +0 -0
- /package/dist/{livescript-Cc8RvFBv.js → livescript-CSvXMspZ.js} +0 -0
- /package/dist/{lua-4nedfnvd.js → lua-CVMR5LMW.js} +0 -0
- /package/dist/{math-BbMyrONz.js → math-CTnb-N1W.js} +0 -0
- /package/dist/{mathematica-BIufdZr2.js → mathematica-JENNt-p4.js} +0 -0
- /package/dist/{mbox-DQkYSHKe.js → mbox-mzifoc8E.js} +0 -0
- /package/dist/{mirc-CI-RWqUR.js → mirc-BXoiItvN.js} +0 -0
- /package/dist/{mllike-DQzbf1xo.js → mllike-H-KR9OuH.js} +0 -0
- /package/dist/{modelica-BnF_cDWj.js → modelica-B6Hm3mMl.js} +0 -0
- /package/dist/{mscgen-MirFrDhW.js → mscgen-D8TF_Hei.js} +0 -0
- /package/dist/{mumps-eNRTuWOD.js → mumps-CD-kNPt4.js} +0 -0
- /package/dist/{ntriples-BLneip4i.js → ntriples-DgnpxU40.js} +0 -0
- /package/dist/{octave-C0eG-pKq.js → octave-CkobqyVm.js} +0 -0
- /package/dist/{oz-BPMLow2T.js → oz-ChDLd9tS.js} +0 -0
- /package/dist/{pascal-5eb9v5Dl.js → pascal-CvlkwK7E.js} +0 -0
- /package/dist/{path-C_x2ySFi.js → path-7gr7eZmp.js} +0 -0
- /package/dist/{perl-DOu6rCkF.js → perl-BNEFTNbM.js} +0 -0
- /package/dist/{pig-CRW0kne3.js → pig-Cd1DMS7P.js} +0 -0
- /package/dist/{powershell-CWgJhiiJ.js → powershell-CPxA0zpc.js} +0 -0
- /package/dist/{properties-CHxpmfXW.js → properties-BaFBm-Xa.js} +0 -0
- /package/dist/{protobuf-DGUXb_-T.js → protobuf-BQV_-X0H.js} +0 -0
- /package/dist/{puppet-C7uSiW6_.js → puppet-LXLST0mx.js} +0 -0
- /package/dist/{python-DAbhVcUr.js → python-DLjLzX4k.js} +0 -0
- /package/dist/{q-DKjWHias.js → q-DswTX1Y9.js} +0 -0
- /package/dist/{r-KD2KhyeL.js → r-CO7NpMwE.js} +0 -0
- /package/dist/{range-BYuZFTbA.js → range-DwpxnYuB.js} +0 -0
- /package/dist/{rpm-GFtnpQ6M.js → rpm-BlmEDT6r.js} +0 -0
- /package/dist/{ruby-CBAewzLY.js → ruby-BTPKgeZZ.js} +0 -0
- /package/dist/{sas-CCi_AaZi.js → sas-DTDTiNO8.js} +0 -0
- /package/dist/{scheme-CGGGD6kR.js → scheme-UzAAg4GJ.js} +0 -0
- /package/dist/{shell-b7vZ8ucI.js → shell-DQ0hQCsB.js} +0 -0
- /package/dist/{sieve-ClXOUV85.js → sieve-BVyYIx9u.js} +0 -0
- /package/dist/{simple-mode-Uad4lEG7.js → simple-mode-Dryu-fC9.js} +0 -0
- /package/dist/{slides-component-Dp-y50K9.js → slides-component-DfwLApNr.js} +0 -0
- /package/dist/{smalltalk-_PFt9_gp.js → smalltalk-DAdMAHTu.js} +0 -0
- /package/dist/{sparql-BCF6qcHt.js → sparql-Bi7quYgw.js} +0 -0
- /package/dist/{stylus-DMFZWz-G.js → stylus-jhpzcQ6Y.js} +0 -0
- /package/dist/{swift-De2YpSxT.js → swift-BrO8qThZ.js} +0 -0
- /package/dist/{tcl-jV8Xs_1k.js → tcl-s5QI5gv3.js} +0 -0
- /package/dist/{textile-D_zo778l.js → textile-ClhvJrxM.js} +0 -0
- /package/dist/{timer-pEiW44EO.js → timer-DV8t68ti.js} +0 -0
- /package/dist/{toml-_M0gsKn5.js → toml-TFa3EJQE.js} +0 -0
- /package/dist/{treemap-BzS5cW_6.js → treemap-CQJ0bIDy.js} +0 -0
- /package/dist/{troff-B06gyD33.js → troff-SqLg0heF.js} +0 -0
- /package/dist/{ttcn-DoQoQNUM.js → ttcn-Cfrap7HJ.js} +0 -0
- /package/dist/{ttcn-cfg-l_6PksD2.js → ttcn-cfg-Dopc-iwE.js} +0 -0
- /package/dist/{turtle-zEnD4bpn.js → turtle-Dt52DvVH.js} +0 -0
- /package/dist/{useAsyncData-Dyq3DyOF.js → useAsyncData-dr8GazGv.js} +0 -0
- /package/dist/{vb-fUsnAuzb.js → vb-D1pAvfDe.js} +0 -0
- /package/dist/{vbscript-CVlD7uZQ.js → vbscript-DZ7RBxn5.js} +0 -0
- /package/dist/{velocity-CHkEIdMC.js → velocity-Csau7eZy.js} +0 -0
- /package/dist/{verilog-B3ctZTB4.js → verilog-gXlZACs5.js} +0 -0
- /package/dist/{vhdl-rXdBgR5O.js → vhdl-NaUWbI1B.js} +0 -0
- /package/dist/{webidl-Cv9aQfcc.js → webidl-BJmPjW01.js} +0 -0
- /package/dist/{xquery-Du0w47aa.js → xquery-CJIPsC0g.js} +0 -0
- /package/dist/{yacas-Eq4p_g3L.js → yacas-8f2Vjiiz.js} +0 -0
- /package/dist/{z80-Dz4HTTRf.js → z80-s5Xk2hCP.js} +0 -0
package/dist/dist-g1p2PEVs.js
DELETED
|
@@ -1,1242 +0,0 @@
|
|
|
1
|
-
import { $ as ViewPlugin, At as RangeSet, Ct as CharCategory, Dt as Facet, Ft as Text, Ht as fromCodePoint, I as syntaxTree, It as Transaction, Lt as codePointAt, Mt as RangeValue, Nt as StateEffect, Ot as MapMode, Pt as StateField, Rt as codePointSize, Tt as EditorSelection, X as Direction, Y as Decoration, Z as EditorView, at as getTooltip, bt as Annotation, dt as keymap, et as WidgetType, j as indentUnit, kt as Prec, pt as logException, vt as showTooltip, zt as combineConfig } from "./dist-D7jHtwN8.js";
|
|
2
|
-
var CompletionContext = class {
|
|
3
|
-
constructor(r8, M, N, P) {
|
|
4
|
-
this.state = r8, this.pos = M, this.explicit = N, this.view = P, this.abortListeners = [], this.abortOnDocChange = false;
|
|
5
|
-
}
|
|
6
|
-
tokenBefore(r8) {
|
|
7
|
-
let M = syntaxTree(this.state).resolveInner(this.pos, -1);
|
|
8
|
-
for (; M && r8.indexOf(M.name) < 0; ) M = M.parent;
|
|
9
|
-
return M ? {
|
|
10
|
-
from: M.from,
|
|
11
|
-
to: this.pos,
|
|
12
|
-
text: this.state.sliceDoc(M.from, this.pos),
|
|
13
|
-
type: M.type
|
|
14
|
-
} : null;
|
|
15
|
-
}
|
|
16
|
-
matchBefore(r8) {
|
|
17
|
-
let M = this.state.doc.lineAt(this.pos), N = Math.max(M.from, this.pos - 250), P = M.text.slice(N - M.from, this.pos - M.from), F = P.search(ensureAnchor(r8, false));
|
|
18
|
-
return F < 0 ? null : {
|
|
19
|
-
from: N + F,
|
|
20
|
-
to: this.pos,
|
|
21
|
-
text: P.slice(F)
|
|
22
|
-
};
|
|
23
|
-
}
|
|
24
|
-
get aborted() {
|
|
25
|
-
return this.abortListeners == null;
|
|
26
|
-
}
|
|
27
|
-
addEventListener(r8, M, N) {
|
|
28
|
-
r8 == "abort" && this.abortListeners && (this.abortListeners.push(M), N && N.onDocChange && (this.abortOnDocChange = true));
|
|
29
|
-
}
|
|
30
|
-
};
|
|
31
|
-
function toSet(r8) {
|
|
32
|
-
let M = Object.keys(r8).join(""), N = /\w/.test(M);
|
|
33
|
-
return N && (M = M.replace(/\w/g, "")), `[${N ? "\\w" : ""}${M.replace(/[^\w\s]/g, "\\$&")}]`;
|
|
34
|
-
}
|
|
35
|
-
function prefixMatch(r8) {
|
|
36
|
-
let M = /* @__PURE__ */ Object.create(null), N = /* @__PURE__ */ Object.create(null);
|
|
37
|
-
for (let { label: P2 } of r8) {
|
|
38
|
-
M[P2[0]] = true;
|
|
39
|
-
for (let r9 = 1; r9 < P2.length; r9++) N[P2[r9]] = true;
|
|
40
|
-
}
|
|
41
|
-
let P = toSet(M) + toSet(N) + "*$";
|
|
42
|
-
return [/* @__PURE__ */ RegExp("^" + P), new RegExp(P)];
|
|
43
|
-
}
|
|
44
|
-
function completeFromList(r8) {
|
|
45
|
-
let M = r8.map((r9) => typeof r9 == "string" ? { label: r9 } : r9), [N, P] = M.every((r9) => /^\w+$/.test(r9.label)) ? [/\w*$/, /\w+$/] : prefixMatch(M);
|
|
46
|
-
return (r9) => {
|
|
47
|
-
let F = r9.matchBefore(P);
|
|
48
|
-
return F || r9.explicit ? {
|
|
49
|
-
from: F ? F.from : r9.pos,
|
|
50
|
-
options: M,
|
|
51
|
-
validFor: N
|
|
52
|
-
} : null;
|
|
53
|
-
};
|
|
54
|
-
}
|
|
55
|
-
function ifNotIn(r8, M) {
|
|
56
|
-
return (N) => {
|
|
57
|
-
for (let M2 = syntaxTree(N.state).resolveInner(N.pos, -1); M2; M2 = M2.parent) {
|
|
58
|
-
if (r8.indexOf(M2.name) > -1) return null;
|
|
59
|
-
if (M2.type.isTop) break;
|
|
60
|
-
}
|
|
61
|
-
return M(N);
|
|
62
|
-
};
|
|
63
|
-
}
|
|
64
|
-
var Option = class {
|
|
65
|
-
constructor(r8, M, N, P) {
|
|
66
|
-
this.completion = r8, this.source = M, this.match = N, this.score = P;
|
|
67
|
-
}
|
|
68
|
-
};
|
|
69
|
-
function cur(r8) {
|
|
70
|
-
return r8.selection.main.from;
|
|
71
|
-
}
|
|
72
|
-
function ensureAnchor(r8, M) {
|
|
73
|
-
let { source: N } = r8, P = M && N[0] != "^", F = N[N.length - 1] != "$";
|
|
74
|
-
return !P && !F ? r8 : RegExp(`${P ? "^" : ""}(?:${N})${F ? "$" : ""}`, r8.flags ?? (r8.ignoreCase ? "i" : ""));
|
|
75
|
-
}
|
|
76
|
-
var pickedCompletion = /* @__PURE__ */ Annotation.define();
|
|
77
|
-
function insertCompletionText(r8, M, N, P) {
|
|
78
|
-
let { main: F } = r8.selection, I = N - F.from, L = P - F.from;
|
|
79
|
-
return {
|
|
80
|
-
...r8.changeByRange((R) => {
|
|
81
|
-
if (R != F && N != P && r8.sliceDoc(R.from + I, R.from + L) != r8.sliceDoc(N, P)) return { range: R };
|
|
82
|
-
let z = r8.toText(M);
|
|
83
|
-
return {
|
|
84
|
-
changes: {
|
|
85
|
-
from: R.from + I,
|
|
86
|
-
to: P == F.from ? R.to : R.from + L,
|
|
87
|
-
insert: z
|
|
88
|
-
},
|
|
89
|
-
range: EditorSelection.cursor(R.from + I + z.length)
|
|
90
|
-
};
|
|
91
|
-
}),
|
|
92
|
-
scrollIntoView: true,
|
|
93
|
-
userEvent: "input.complete"
|
|
94
|
-
};
|
|
95
|
-
}
|
|
96
|
-
var SourceCache = /* @__PURE__ */ new WeakMap();
|
|
97
|
-
function asSource(r8) {
|
|
98
|
-
if (!Array.isArray(r8)) return r8;
|
|
99
|
-
let M = SourceCache.get(r8);
|
|
100
|
-
return M || SourceCache.set(r8, M = completeFromList(r8)), M;
|
|
101
|
-
}
|
|
102
|
-
var startCompletionEffect = /* @__PURE__ */ StateEffect.define(), closeCompletionEffect = /* @__PURE__ */ StateEffect.define(), FuzzyMatcher = class {
|
|
103
|
-
constructor(r8) {
|
|
104
|
-
this.pattern = r8, this.chars = [], this.folded = [], this.any = [], this.precise = [], this.byWord = [], this.score = 0, this.matched = [];
|
|
105
|
-
for (let M = 0; M < r8.length; ) {
|
|
106
|
-
let N = codePointAt(r8, M), P = codePointSize(N);
|
|
107
|
-
this.chars.push(N);
|
|
108
|
-
let F = r8.slice(M, M + P), I = F.toUpperCase();
|
|
109
|
-
this.folded.push(codePointAt(I == F ? F.toLowerCase() : I, 0)), M += P;
|
|
110
|
-
}
|
|
111
|
-
this.astral = r8.length != this.chars.length;
|
|
112
|
-
}
|
|
113
|
-
ret(r8, M) {
|
|
114
|
-
return this.score = r8, this.matched = M, this;
|
|
115
|
-
}
|
|
116
|
-
match(r8) {
|
|
117
|
-
if (this.pattern.length == 0) return this.ret(-100, []);
|
|
118
|
-
if (r8.length < this.pattern.length) return null;
|
|
119
|
-
let { chars: M, folded: N, any: P, precise: F, byWord: L } = this;
|
|
120
|
-
if (M.length == 1) {
|
|
121
|
-
let P2 = codePointAt(r8, 0), F2 = codePointSize(P2), I = F2 == r8.length ? 0 : -100;
|
|
122
|
-
if (P2 != M[0]) if (P2 == N[0]) I += -200;
|
|
123
|
-
else return null;
|
|
124
|
-
return this.ret(I, [0, F2]);
|
|
125
|
-
}
|
|
126
|
-
let R = r8.indexOf(this.pattern);
|
|
127
|
-
if (R == 0) return this.ret(r8.length == this.pattern.length ? 0 : -100, [0, this.pattern.length]);
|
|
128
|
-
let B = M.length, V = 0;
|
|
129
|
-
if (R < 0) {
|
|
130
|
-
for (let F2 = 0, I = Math.min(r8.length, 200); F2 < I && V < B; ) {
|
|
131
|
-
let I2 = codePointAt(r8, F2);
|
|
132
|
-
(I2 == M[V] || I2 == N[V]) && (P[V++] = F2), F2 += codePointSize(I2);
|
|
133
|
-
}
|
|
134
|
-
if (V < B) return null;
|
|
135
|
-
}
|
|
136
|
-
let H = 0, U = 0, G = false, K = 0, q = -1, J = -1, Y = /[a-z]/.test(r8), X = true;
|
|
137
|
-
for (let P2 = 0, V2 = Math.min(r8.length, 200), Z = 0; P2 < V2 && U < B; ) {
|
|
138
|
-
let V3 = codePointAt(r8, P2);
|
|
139
|
-
R < 0 && (H < B && V3 == M[H] && (F[H++] = P2), K < B && (V3 == M[K] || V3 == N[K] ? (K == 0 && (q = P2), J = P2 + 1, K++) : K = 0));
|
|
140
|
-
let Q, $ = V3 < 255 ? V3 >= 48 && V3 <= 57 || V3 >= 97 && V3 <= 122 ? 2 : V3 >= 65 && V3 <= 90 ? 1 : 0 : (Q = fromCodePoint(V3)) == Q.toLowerCase() ? Q == Q.toUpperCase() ? 0 : 2 : 1;
|
|
141
|
-
(!P2 || $ == 1 && Y || Z == 0 && $ != 0) && (M[U] == V3 || N[U] == V3 && (G = true) ? L[U++] = P2 : L.length && (X = false)), Z = $, P2 += codePointSize(V3);
|
|
142
|
-
}
|
|
143
|
-
return U == B && L[0] == 0 && X ? this.result(-100 + (G ? -200 : 0), L, r8) : K == B && q == 0 ? this.ret(-200 - r8.length + (J == r8.length ? 0 : -100), [0, J]) : R > -1 ? this.ret(-700 - r8.length, [R, R + this.pattern.length]) : K == B ? this.ret(-900 - r8.length, [q, J]) : U == B ? this.result(-100 + (G ? -200 : 0) + -700 + (X ? 0 : -1100), L, r8) : M.length == 2 ? null : this.result((P[0] ? -700 : 0) + -200 + -1100, P, r8);
|
|
144
|
-
}
|
|
145
|
-
result(r8, M, N) {
|
|
146
|
-
let P = [], F = 0;
|
|
147
|
-
for (let r9 of M) {
|
|
148
|
-
let M2 = r9 + (this.astral ? codePointSize(codePointAt(N, r9)) : 1);
|
|
149
|
-
F && P[F - 1] == r9 ? P[F - 1] = M2 : (P[F++] = r9, P[F++] = M2);
|
|
150
|
-
}
|
|
151
|
-
return this.ret(r8 - N.length, P);
|
|
152
|
-
}
|
|
153
|
-
}, StrictMatcher = class {
|
|
154
|
-
constructor(r8) {
|
|
155
|
-
this.pattern = r8, this.matched = [], this.score = 0, this.folded = r8.toLowerCase();
|
|
156
|
-
}
|
|
157
|
-
match(r8) {
|
|
158
|
-
if (r8.length < this.pattern.length) return null;
|
|
159
|
-
let M = r8.slice(0, this.pattern.length), N = M == this.pattern ? 0 : M.toLowerCase() == this.folded ? -200 : null;
|
|
160
|
-
return N == null ? null : (this.matched = [0, M.length], this.score = N + (r8.length == this.pattern.length ? 0 : -100), this);
|
|
161
|
-
}
|
|
162
|
-
}, completionConfig = /* @__PURE__ */ Facet.define({ combine(r8) {
|
|
163
|
-
return combineConfig(r8, {
|
|
164
|
-
activateOnTyping: true,
|
|
165
|
-
activateOnCompletion: () => false,
|
|
166
|
-
activateOnTypingDelay: 100,
|
|
167
|
-
selectOnOpen: true,
|
|
168
|
-
override: null,
|
|
169
|
-
closeOnBlur: true,
|
|
170
|
-
maxRenderedOptions: 100,
|
|
171
|
-
defaultKeymap: true,
|
|
172
|
-
tooltipClass: () => "",
|
|
173
|
-
optionClass: () => "",
|
|
174
|
-
aboveCursor: false,
|
|
175
|
-
icons: true,
|
|
176
|
-
addToOptions: [],
|
|
177
|
-
positionInfo: defaultPositionInfo,
|
|
178
|
-
filterStrict: false,
|
|
179
|
-
compareCompletions: (r9, M) => (r9.sortText || r9.label).localeCompare(M.sortText || M.label),
|
|
180
|
-
interactionDelay: 75,
|
|
181
|
-
updateSyncTime: 100
|
|
182
|
-
}, {
|
|
183
|
-
defaultKeymap: (r9, M) => r9 && M,
|
|
184
|
-
closeOnBlur: (r9, M) => r9 && M,
|
|
185
|
-
icons: (r9, M) => r9 && M,
|
|
186
|
-
tooltipClass: (r9, M) => (N) => joinClass(r9(N), M(N)),
|
|
187
|
-
optionClass: (r9, M) => (N) => joinClass(r9(N), M(N)),
|
|
188
|
-
addToOptions: (r9, M) => r9.concat(M),
|
|
189
|
-
filterStrict: (r9, M) => r9 || M
|
|
190
|
-
});
|
|
191
|
-
} });
|
|
192
|
-
function joinClass(r8, M) {
|
|
193
|
-
return r8 ? M ? r8 + " " + M : r8 : M;
|
|
194
|
-
}
|
|
195
|
-
function defaultPositionInfo(r8, M, N, P, F, I) {
|
|
196
|
-
let L = r8.textDirection == Direction.RTL, R = L, z = false, B = "top", V, H, U = M.left - F.left, W = F.right - M.right, G = P.right - P.left, q = P.bottom - P.top;
|
|
197
|
-
if (R && U < Math.min(G, W) ? R = false : !R && W < Math.min(G, U) && (R = true), G <= (R ? U : W)) V = Math.max(F.top, Math.min(N.top, F.bottom - q)) - M.top, H = Math.min(400, R ? U : W);
|
|
198
|
-
else {
|
|
199
|
-
z = true, H = Math.min(400, (L ? M.right : F.right - M.left) - 30);
|
|
200
|
-
let r9 = F.bottom - M.bottom;
|
|
201
|
-
r9 >= q || r9 > M.top ? V = N.bottom - M.top : (B = "bottom", V = M.bottom - N.top);
|
|
202
|
-
}
|
|
203
|
-
let J = (M.bottom - M.top) / I.offsetHeight, Y = (M.right - M.left) / I.offsetWidth;
|
|
204
|
-
return {
|
|
205
|
-
style: `${B}: ${V / J}px; max-width: ${H / Y}px`,
|
|
206
|
-
class: "cm-completionInfo-" + (z ? L ? "left-narrow" : "right-narrow" : R ? "left" : "right")
|
|
207
|
-
};
|
|
208
|
-
}
|
|
209
|
-
function optionContent(r8) {
|
|
210
|
-
let M = r8.addToOptions.slice();
|
|
211
|
-
return r8.icons && M.push({
|
|
212
|
-
render(r9) {
|
|
213
|
-
let M2 = document.createElement("div");
|
|
214
|
-
return M2.classList.add("cm-completionIcon"), r9.type && M2.classList.add(...r9.type.split(/\s+/g).map((r10) => "cm-completionIcon-" + r10)), M2.setAttribute("aria-hidden", "true"), M2;
|
|
215
|
-
},
|
|
216
|
-
position: 20
|
|
217
|
-
}), M.push({
|
|
218
|
-
render(r9, M2, N, P) {
|
|
219
|
-
let F = document.createElement("span");
|
|
220
|
-
F.className = "cm-completionLabel";
|
|
221
|
-
let I = r9.displayLabel || r9.label, L = 0;
|
|
222
|
-
for (let r10 = 0; r10 < P.length; ) {
|
|
223
|
-
let M3 = P[r10++], N2 = P[r10++];
|
|
224
|
-
M3 > L && F.appendChild(document.createTextNode(I.slice(L, M3)));
|
|
225
|
-
let R = F.appendChild(document.createElement("span"));
|
|
226
|
-
R.appendChild(document.createTextNode(I.slice(M3, N2))), R.className = "cm-completionMatchedText", L = N2;
|
|
227
|
-
}
|
|
228
|
-
return L < I.length && F.appendChild(document.createTextNode(I.slice(L))), F;
|
|
229
|
-
},
|
|
230
|
-
position: 50
|
|
231
|
-
}, {
|
|
232
|
-
render(r9) {
|
|
233
|
-
if (!r9.detail) return null;
|
|
234
|
-
let M2 = document.createElement("span");
|
|
235
|
-
return M2.className = "cm-completionDetail", M2.textContent = r9.detail, M2;
|
|
236
|
-
},
|
|
237
|
-
position: 80
|
|
238
|
-
}), M.sort((r9, M2) => r9.position - M2.position).map((r9) => r9.render);
|
|
239
|
-
}
|
|
240
|
-
function rangeAroundSelected(r8, M, N) {
|
|
241
|
-
if (r8 <= N) return {
|
|
242
|
-
from: 0,
|
|
243
|
-
to: r8
|
|
244
|
-
};
|
|
245
|
-
if (M < 0 && (M = 0), M <= r8 >> 1) {
|
|
246
|
-
let r9 = Math.floor(M / N);
|
|
247
|
-
return {
|
|
248
|
-
from: r9 * N,
|
|
249
|
-
to: (r9 + 1) * N
|
|
250
|
-
};
|
|
251
|
-
}
|
|
252
|
-
let P = Math.floor((r8 - M) / N);
|
|
253
|
-
return {
|
|
254
|
-
from: r8 - (P + 1) * N,
|
|
255
|
-
to: r8 - P * N
|
|
256
|
-
};
|
|
257
|
-
}
|
|
258
|
-
var CompletionTooltip = class {
|
|
259
|
-
constructor(r8, M, N) {
|
|
260
|
-
this.view = r8, this.stateField = M, this.applyCompletion = N, this.info = null, this.infoDestroy = null, this.placeInfoReq = {
|
|
261
|
-
read: () => this.measureInfo(),
|
|
262
|
-
write: (r9) => this.placeInfo(r9),
|
|
263
|
-
key: this
|
|
264
|
-
}, this.space = null, this.currentClass = "";
|
|
265
|
-
let P = r8.state.field(M), { options: F, selected: I } = P.open, L = r8.state.facet(completionConfig);
|
|
266
|
-
this.optionContent = optionContent(L), this.optionClass = L.optionClass, this.tooltipClass = L.tooltipClass, this.range = rangeAroundSelected(F.length, I, L.maxRenderedOptions), this.dom = document.createElement("div"), this.dom.className = "cm-tooltip-autocomplete", this.updateTooltipClass(r8.state), this.dom.addEventListener("mousedown", (N2) => {
|
|
267
|
-
let { options: P2 } = r8.state.field(M).open;
|
|
268
|
-
for (let M2 = N2.target, F2; M2 && M2 != this.dom; M2 = M2.parentNode) if (M2.nodeName == "LI" && (F2 = /-(\d+)$/.exec(M2.id)) && +F2[1] < P2.length) {
|
|
269
|
-
this.applyCompletion(r8, P2[+F2[1]]), N2.preventDefault();
|
|
270
|
-
return;
|
|
271
|
-
}
|
|
272
|
-
}), this.dom.addEventListener("focusout", (M2) => {
|
|
273
|
-
let N2 = r8.state.field(this.stateField, false);
|
|
274
|
-
N2 && N2.tooltip && r8.state.facet(completionConfig).closeOnBlur && M2.relatedTarget != r8.contentDOM && r8.dispatch({ effects: closeCompletionEffect.of(null) });
|
|
275
|
-
}), this.showOptions(F, P.id);
|
|
276
|
-
}
|
|
277
|
-
mount() {
|
|
278
|
-
this.updateSel();
|
|
279
|
-
}
|
|
280
|
-
showOptions(r8, M) {
|
|
281
|
-
this.list && this.list.remove(), this.list = this.dom.appendChild(this.createListBox(r8, M, this.range)), this.list.addEventListener("scroll", () => {
|
|
282
|
-
this.info && this.view.requestMeasure(this.placeInfoReq);
|
|
283
|
-
});
|
|
284
|
-
}
|
|
285
|
-
update(r8) {
|
|
286
|
-
var _a;
|
|
287
|
-
let M = r8.state.field(this.stateField), N = r8.startState.field(this.stateField);
|
|
288
|
-
if (this.updateTooltipClass(r8.state), M != N) {
|
|
289
|
-
let { options: P, selected: F, disabled: I } = M.open;
|
|
290
|
-
(!N.open || N.open.options != P) && (this.range = rangeAroundSelected(P.length, F, r8.state.facet(completionConfig).maxRenderedOptions), this.showOptions(P, M.id)), this.updateSel(), I != ((_a = N.open) == null ? void 0 : _a.disabled) && this.dom.classList.toggle("cm-tooltip-autocomplete-disabled", !!I);
|
|
291
|
-
}
|
|
292
|
-
}
|
|
293
|
-
updateTooltipClass(r8) {
|
|
294
|
-
let M = this.tooltipClass(r8);
|
|
295
|
-
if (M != this.currentClass) {
|
|
296
|
-
for (let r9 of this.currentClass.split(" ")) r9 && this.dom.classList.remove(r9);
|
|
297
|
-
for (let r9 of M.split(" ")) r9 && this.dom.classList.add(r9);
|
|
298
|
-
this.currentClass = M;
|
|
299
|
-
}
|
|
300
|
-
}
|
|
301
|
-
positioned(r8) {
|
|
302
|
-
this.space = r8, this.info && this.view.requestMeasure(this.placeInfoReq);
|
|
303
|
-
}
|
|
304
|
-
updateSel() {
|
|
305
|
-
let r8 = this.view.state.field(this.stateField), M = r8.open;
|
|
306
|
-
(M.selected > -1 && M.selected < this.range.from || M.selected >= this.range.to) && (this.range = rangeAroundSelected(M.options.length, M.selected, this.view.state.facet(completionConfig).maxRenderedOptions), this.showOptions(M.options, r8.id));
|
|
307
|
-
let N = this.updateSelectedOption(M.selected);
|
|
308
|
-
if (N) {
|
|
309
|
-
this.destroyInfo();
|
|
310
|
-
let { completion: P } = M.options[M.selected], { info: F } = P;
|
|
311
|
-
if (!F) return;
|
|
312
|
-
let I = typeof F == "string" ? document.createTextNode(F) : F(P);
|
|
313
|
-
if (!I) return;
|
|
314
|
-
"then" in I ? I.then((M2) => {
|
|
315
|
-
M2 && this.view.state.field(this.stateField, false) == r8 && this.addInfoPane(M2, P);
|
|
316
|
-
}).catch((r9) => logException(this.view.state, r9, "completion info")) : (this.addInfoPane(I, P), N.setAttribute("aria-describedby", this.info.id));
|
|
317
|
-
}
|
|
318
|
-
}
|
|
319
|
-
addInfoPane(r8, M) {
|
|
320
|
-
this.destroyInfo();
|
|
321
|
-
let N = this.info = document.createElement("div");
|
|
322
|
-
if (N.className = "cm-tooltip cm-completionInfo", N.id = "cm-completionInfo-" + Math.floor(Math.random() * 65535).toString(16), r8.nodeType != null) N.appendChild(r8), this.infoDestroy = null;
|
|
323
|
-
else {
|
|
324
|
-
let { dom: M2, destroy: P } = r8;
|
|
325
|
-
N.appendChild(M2), this.infoDestroy = P || null;
|
|
326
|
-
}
|
|
327
|
-
this.dom.appendChild(N), this.view.requestMeasure(this.placeInfoReq);
|
|
328
|
-
}
|
|
329
|
-
updateSelectedOption(r8) {
|
|
330
|
-
let M = null;
|
|
331
|
-
for (let N = this.list.firstChild, P = this.range.from; N; N = N.nextSibling, P++) N.nodeName != "LI" || !N.id ? P-- : P == r8 ? N.hasAttribute("aria-selected") || (N.setAttribute("aria-selected", "true"), M = N) : N.hasAttribute("aria-selected") && (N.removeAttribute("aria-selected"), N.removeAttribute("aria-describedby"));
|
|
332
|
-
return M && scrollIntoView(this.list, M), M;
|
|
333
|
-
}
|
|
334
|
-
measureInfo() {
|
|
335
|
-
let r8 = this.dom.querySelector("[aria-selected]");
|
|
336
|
-
if (!r8 || !this.info) return null;
|
|
337
|
-
let M = this.dom.getBoundingClientRect(), N = this.info.getBoundingClientRect(), P = r8.getBoundingClientRect(), F = this.space;
|
|
338
|
-
if (!F) {
|
|
339
|
-
let r9 = this.dom.ownerDocument.documentElement;
|
|
340
|
-
F = {
|
|
341
|
-
left: 0,
|
|
342
|
-
top: 0,
|
|
343
|
-
right: r9.clientWidth,
|
|
344
|
-
bottom: r9.clientHeight
|
|
345
|
-
};
|
|
346
|
-
}
|
|
347
|
-
return P.top > Math.min(F.bottom, M.bottom) - 10 || P.bottom < Math.max(F.top, M.top) + 10 ? null : this.view.state.facet(completionConfig).positionInfo(this.view, M, P, N, F, this.dom);
|
|
348
|
-
}
|
|
349
|
-
placeInfo(r8) {
|
|
350
|
-
this.info && (r8 ? (r8.style && (this.info.style.cssText = r8.style), this.info.className = "cm-tooltip cm-completionInfo " + (r8.class || "")) : this.info.style.cssText = "top: -1e6px");
|
|
351
|
-
}
|
|
352
|
-
createListBox(r8, M, N) {
|
|
353
|
-
let P = document.createElement("ul");
|
|
354
|
-
P.id = M, P.setAttribute("role", "listbox"), P.setAttribute("aria-expanded", "true"), P.setAttribute("aria-label", this.view.state.phrase("Completions")), P.addEventListener("mousedown", (r9) => {
|
|
355
|
-
r9.target == P && r9.preventDefault();
|
|
356
|
-
});
|
|
357
|
-
let F = null;
|
|
358
|
-
for (let I = N.from; I < N.to; I++) {
|
|
359
|
-
let { completion: L, match: R } = r8[I], { section: z } = L;
|
|
360
|
-
if (z) {
|
|
361
|
-
let r9 = typeof z == "string" ? z : z.name;
|
|
362
|
-
if (r9 != F && (I > N.from || N.from == 0)) if (F = r9, typeof z != "string" && z.header) P.appendChild(z.header(z));
|
|
363
|
-
else {
|
|
364
|
-
let M2 = P.appendChild(document.createElement("completion-section"));
|
|
365
|
-
M2.textContent = r9;
|
|
366
|
-
}
|
|
367
|
-
}
|
|
368
|
-
let B = P.appendChild(document.createElement("li"));
|
|
369
|
-
B.id = M + "-" + I, B.setAttribute("role", "option");
|
|
370
|
-
let V = this.optionClass(L);
|
|
371
|
-
V && (B.className = V);
|
|
372
|
-
for (let r9 of this.optionContent) {
|
|
373
|
-
let M2 = r9(L, this.view.state, this.view, R);
|
|
374
|
-
M2 && B.appendChild(M2);
|
|
375
|
-
}
|
|
376
|
-
}
|
|
377
|
-
return N.from && P.classList.add("cm-completionListIncompleteTop"), N.to < r8.length && P.classList.add("cm-completionListIncompleteBottom"), P;
|
|
378
|
-
}
|
|
379
|
-
destroyInfo() {
|
|
380
|
-
this.info && (this.info = (this.infoDestroy && this.infoDestroy(), this.info.remove(), null));
|
|
381
|
-
}
|
|
382
|
-
destroy() {
|
|
383
|
-
this.destroyInfo();
|
|
384
|
-
}
|
|
385
|
-
};
|
|
386
|
-
function completionTooltip(r8, M) {
|
|
387
|
-
return (N) => new CompletionTooltip(N, r8, M);
|
|
388
|
-
}
|
|
389
|
-
function scrollIntoView(r8, M) {
|
|
390
|
-
let N = r8.getBoundingClientRect(), P = M.getBoundingClientRect(), F = N.height / r8.offsetHeight;
|
|
391
|
-
P.top < N.top ? r8.scrollTop -= (N.top - P.top) / F : P.bottom > N.bottom && (r8.scrollTop += (P.bottom - N.bottom) / F);
|
|
392
|
-
}
|
|
393
|
-
function score(r8) {
|
|
394
|
-
return (r8.boost || 0) * 100 + (r8.apply ? 10 : 0) + (r8.info ? 5 : 0) + (r8.type ? 1 : 0);
|
|
395
|
-
}
|
|
396
|
-
function sortOptions(r8, M) {
|
|
397
|
-
let N = [], P = null, F = null, I = (r9) => {
|
|
398
|
-
N.push(r9);
|
|
399
|
-
let { section: M2 } = r9.completion;
|
|
400
|
-
if (M2) {
|
|
401
|
-
P || (P = []);
|
|
402
|
-
let r10 = typeof M2 == "string" ? M2 : M2.name;
|
|
403
|
-
P.some((M3) => M3.name == r10) || P.push(typeof M2 == "string" ? { name: r10 } : M2);
|
|
404
|
-
}
|
|
405
|
-
}, L = M.facet(completionConfig);
|
|
406
|
-
for (let P2 of r8) if (P2.hasResult()) {
|
|
407
|
-
let r9 = P2.result.getMatch;
|
|
408
|
-
if (P2.result.filter === false) for (let M2 of P2.result.options) I(new Option(M2, P2.source, r9 ? r9(M2) : [], 1e9 - N.length));
|
|
409
|
-
else {
|
|
410
|
-
let N2 = M.sliceDoc(P2.from, P2.to), R2, z2 = L.filterStrict ? new StrictMatcher(N2) : new FuzzyMatcher(N2);
|
|
411
|
-
for (let M2 of P2.result.options) if (R2 = z2.match(M2.label)) {
|
|
412
|
-
let N3 = M2.displayLabel ? r9 ? r9(M2, R2.matched) : [] : R2.matched, L2 = R2.score + (M2.boost || 0);
|
|
413
|
-
if (I(new Option(M2, P2.source, N3, L2)), typeof M2.section == "object" && M2.section.rank === "dynamic") {
|
|
414
|
-
let { name: r10 } = M2.section;
|
|
415
|
-
F || (F = /* @__PURE__ */ Object.create(null)), F[r10] = Math.max(L2, F[r10] || -1e9);
|
|
416
|
-
}
|
|
417
|
-
}
|
|
418
|
-
}
|
|
419
|
-
}
|
|
420
|
-
if (P) {
|
|
421
|
-
let r9 = /* @__PURE__ */ Object.create(null), M2 = 0, I2 = (r10, M3) => (r10.rank === "dynamic" && M3.rank === "dynamic" ? F[M3.name] - F[r10.name] : 0) || (typeof r10.rank == "number" ? r10.rank : 1e9) - (typeof M3.rank == "number" ? M3.rank : 1e9) || (r10.name < M3.name ? -1 : 1);
|
|
422
|
-
for (let N2 of P.sort(I2)) M2 -= 1e5, r9[N2.name] = M2;
|
|
423
|
-
for (let M3 of N) {
|
|
424
|
-
let { section: N2 } = M3.completion;
|
|
425
|
-
N2 && (M3.score += r9[typeof N2 == "string" ? N2 : N2.name]);
|
|
426
|
-
}
|
|
427
|
-
}
|
|
428
|
-
let R = [], z = null, B = L.compareCompletions;
|
|
429
|
-
for (let r9 of N.sort((r10, M2) => M2.score - r10.score || B(r10.completion, M2.completion))) {
|
|
430
|
-
let M2 = r9.completion;
|
|
431
|
-
!z || z.label != M2.label || z.detail != M2.detail || z.type != null && M2.type != null && z.type != M2.type || z.apply != M2.apply || z.boost != M2.boost ? R.push(r9) : score(r9.completion) > score(z) && (R[R.length - 1] = r9), z = r9.completion;
|
|
432
|
-
}
|
|
433
|
-
return R;
|
|
434
|
-
}
|
|
435
|
-
var CompletionDialog = class r {
|
|
436
|
-
constructor(r8, M, N, P, F, I) {
|
|
437
|
-
this.options = r8, this.attrs = M, this.tooltip = N, this.timestamp = P, this.selected = F, this.disabled = I;
|
|
438
|
-
}
|
|
439
|
-
setSelected(M, N) {
|
|
440
|
-
return M == this.selected || M >= this.options.length ? this : new r(this.options, makeAttrs(N, M), this.tooltip, this.timestamp, M, this.disabled);
|
|
441
|
-
}
|
|
442
|
-
static build(M, N, P, F, I, L) {
|
|
443
|
-
if (F && !L && M.some((r8) => r8.isPending)) return F.setDisabled();
|
|
444
|
-
let R = sortOptions(M, N);
|
|
445
|
-
if (!R.length) return F && M.some((r8) => r8.isPending) ? F.setDisabled() : null;
|
|
446
|
-
let z = N.facet(completionConfig).selectOnOpen ? 0 : -1;
|
|
447
|
-
if (F && F.selected != z && F.selected != -1) {
|
|
448
|
-
let r8 = F.options[F.selected].completion;
|
|
449
|
-
for (let M2 = 0; M2 < R.length; M2++) if (R[M2].completion == r8) {
|
|
450
|
-
z = M2;
|
|
451
|
-
break;
|
|
452
|
-
}
|
|
453
|
-
}
|
|
454
|
-
return new r(R, makeAttrs(P, z), {
|
|
455
|
-
pos: M.reduce((r8, M2) => M2.hasResult() ? Math.min(r8, M2.from) : r8, 1e8),
|
|
456
|
-
create: createTooltip,
|
|
457
|
-
above: I.aboveCursor
|
|
458
|
-
}, F ? F.timestamp : Date.now(), z, false);
|
|
459
|
-
}
|
|
460
|
-
map(M) {
|
|
461
|
-
return new r(this.options, this.attrs, {
|
|
462
|
-
...this.tooltip,
|
|
463
|
-
pos: M.mapPos(this.tooltip.pos)
|
|
464
|
-
}, this.timestamp, this.selected, this.disabled);
|
|
465
|
-
}
|
|
466
|
-
setDisabled() {
|
|
467
|
-
return new r(this.options, this.attrs, this.tooltip, this.timestamp, this.selected, true);
|
|
468
|
-
}
|
|
469
|
-
}, CompletionState = class r2 {
|
|
470
|
-
constructor(r8, M, N) {
|
|
471
|
-
this.active = r8, this.id = M, this.open = N;
|
|
472
|
-
}
|
|
473
|
-
static start() {
|
|
474
|
-
return new r2(none, "cm-ac-" + Math.floor(Math.random() * 2e6).toString(36), null);
|
|
475
|
-
}
|
|
476
|
-
update(M) {
|
|
477
|
-
let { state: N } = M, P = N.facet(completionConfig), F = (P.override || N.languageDataAt("autocomplete", cur(N)).map(asSource)).map((r8) => (this.active.find((M2) => M2.source == r8) || new ActiveSource(r8, this.active.some((r9) => r9.state != 0) ? 1 : 0)).update(M, P));
|
|
478
|
-
F.length == this.active.length && F.every((r8, M2) => r8 == this.active[M2]) && (F = this.active);
|
|
479
|
-
let I = this.open, L = M.effects.some((r8) => r8.is(setActiveEffect));
|
|
480
|
-
I && M.docChanged && (I = I.map(M.changes)), M.selection || F.some((r8) => r8.hasResult() && M.changes.touchesRange(r8.from, r8.to)) || !sameResults(F, this.active) || L ? I = CompletionDialog.build(F, N, this.id, I, P, L) : I && I.disabled && !F.some((r8) => r8.isPending) && (I = null), !I && F.every((r8) => !r8.isPending) && F.some((r8) => r8.hasResult()) && (F = F.map((r8) => r8.hasResult() ? new ActiveSource(r8.source, 0) : r8));
|
|
481
|
-
for (let r8 of M.effects) r8.is(setSelectedEffect) && (I && (I = I.setSelected(r8.value, this.id)));
|
|
482
|
-
return F == this.active && I == this.open ? this : new r2(F, this.id, I);
|
|
483
|
-
}
|
|
484
|
-
get tooltip() {
|
|
485
|
-
return this.open ? this.open.tooltip : null;
|
|
486
|
-
}
|
|
487
|
-
get attrs() {
|
|
488
|
-
return this.open ? this.open.attrs : this.active.length ? baseAttrs : noAttrs;
|
|
489
|
-
}
|
|
490
|
-
};
|
|
491
|
-
function sameResults(r8, M) {
|
|
492
|
-
if (r8 == M) return true;
|
|
493
|
-
for (let N = 0, P = 0; ; ) {
|
|
494
|
-
for (; N < r8.length && !r8[N].hasResult(); ) N++;
|
|
495
|
-
for (; P < M.length && !M[P].hasResult(); ) P++;
|
|
496
|
-
let F = N == r8.length, I = P == M.length;
|
|
497
|
-
if (F || I) return F == I;
|
|
498
|
-
if (r8[N++].result != M[P++].result) return false;
|
|
499
|
-
}
|
|
500
|
-
}
|
|
501
|
-
var baseAttrs = { "aria-autocomplete": "list" }, noAttrs = {};
|
|
502
|
-
function makeAttrs(r8, M) {
|
|
503
|
-
let N = {
|
|
504
|
-
"aria-autocomplete": "list",
|
|
505
|
-
"aria-haspopup": "listbox",
|
|
506
|
-
"aria-controls": r8
|
|
507
|
-
};
|
|
508
|
-
return M > -1 && (N["aria-activedescendant"] = r8 + "-" + M), N;
|
|
509
|
-
}
|
|
510
|
-
var none = [];
|
|
511
|
-
function getUpdateType(r8, M) {
|
|
512
|
-
if (r8.isUserEvent("input.complete")) {
|
|
513
|
-
let N2 = r8.annotation(pickedCompletion);
|
|
514
|
-
if (N2 && M.activateOnCompletion(N2)) return 12;
|
|
515
|
-
}
|
|
516
|
-
let N = r8.isUserEvent("input.type");
|
|
517
|
-
return N && M.activateOnTyping ? 5 : N ? 1 : r8.isUserEvent("delete.backward") ? 2 : r8.selection ? 8 : r8.docChanged ? 16 : 0;
|
|
518
|
-
}
|
|
519
|
-
var ActiveSource = class r3 {
|
|
520
|
-
constructor(r8, M, N = false) {
|
|
521
|
-
this.source = r8, this.state = M, this.explicit = N;
|
|
522
|
-
}
|
|
523
|
-
hasResult() {
|
|
524
|
-
return false;
|
|
525
|
-
}
|
|
526
|
-
get isPending() {
|
|
527
|
-
return this.state == 1;
|
|
528
|
-
}
|
|
529
|
-
update(M, N) {
|
|
530
|
-
let P = getUpdateType(M, N), F = this;
|
|
531
|
-
(P & 8 || P & 16 && this.touches(M)) && (F = new r3(F.source, 0)), P & 4 && F.state == 0 && (F = new r3(this.source, 1)), F = F.updateFor(M, P);
|
|
532
|
-
for (let N2 of M.effects) if (N2.is(startCompletionEffect)) F = new r3(F.source, 1, N2.value);
|
|
533
|
-
else if (N2.is(closeCompletionEffect)) F = new r3(F.source, 0);
|
|
534
|
-
else if (N2.is(setActiveEffect)) for (let r8 of N2.value) r8.source == F.source && (F = r8);
|
|
535
|
-
return F;
|
|
536
|
-
}
|
|
537
|
-
updateFor(r8, M) {
|
|
538
|
-
return this.map(r8.changes);
|
|
539
|
-
}
|
|
540
|
-
map(r8) {
|
|
541
|
-
return this;
|
|
542
|
-
}
|
|
543
|
-
touches(r8) {
|
|
544
|
-
return r8.changes.touchesRange(cur(r8.state));
|
|
545
|
-
}
|
|
546
|
-
}, ActiveResult = class r4 extends ActiveSource {
|
|
547
|
-
constructor(r8, M, N, P, F, I) {
|
|
548
|
-
super(r8, 3, M), this.limit = N, this.result = P, this.from = F, this.to = I;
|
|
549
|
-
}
|
|
550
|
-
hasResult() {
|
|
551
|
-
return true;
|
|
552
|
-
}
|
|
553
|
-
updateFor(M, N) {
|
|
554
|
-
if (!(N & 3)) return this.map(M.changes);
|
|
555
|
-
let P = this.result;
|
|
556
|
-
P.map && !M.changes.empty && (P = P.map(P, M.changes));
|
|
557
|
-
let F = M.changes.mapPos(this.from), I = M.changes.mapPos(this.to, 1), L = cur(M.state);
|
|
558
|
-
if (L > I || !P || N & 2 && (cur(M.startState) == this.from || L < this.limit)) return new ActiveSource(this.source, N & 4 ? 1 : 0);
|
|
559
|
-
let R = M.changes.mapPos(this.limit);
|
|
560
|
-
return checkValid(P.validFor, M.state, F, I) ? new r4(this.source, this.explicit, R, P, F, I) : P.update && (P = P.update(P, F, I, new CompletionContext(M.state, L, false))) ? new r4(this.source, this.explicit, R, P, P.from, P.to ?? cur(M.state)) : new ActiveSource(this.source, 1, this.explicit);
|
|
561
|
-
}
|
|
562
|
-
map(M) {
|
|
563
|
-
return M.empty ? this : (this.result.map ? this.result.map(this.result, M) : this.result) ? new r4(this.source, this.explicit, M.mapPos(this.limit), this.result, M.mapPos(this.from), M.mapPos(this.to, 1)) : new ActiveSource(this.source, 0);
|
|
564
|
-
}
|
|
565
|
-
touches(r8) {
|
|
566
|
-
return r8.changes.touchesRange(this.from, this.to);
|
|
567
|
-
}
|
|
568
|
-
};
|
|
569
|
-
function checkValid(r8, M, N, P) {
|
|
570
|
-
if (!r8) return false;
|
|
571
|
-
let F = M.sliceDoc(N, P);
|
|
572
|
-
return typeof r8 == "function" ? r8(F, N, P, M) : ensureAnchor(r8, true).test(F);
|
|
573
|
-
}
|
|
574
|
-
var setActiveEffect = /* @__PURE__ */ StateEffect.define({ map(r8, M) {
|
|
575
|
-
return r8.map((r9) => r9.map(M));
|
|
576
|
-
} }), setSelectedEffect = /* @__PURE__ */ StateEffect.define(), completionState = /* @__PURE__ */ StateField.define({
|
|
577
|
-
create() {
|
|
578
|
-
return CompletionState.start();
|
|
579
|
-
},
|
|
580
|
-
update(r8, M) {
|
|
581
|
-
return r8.update(M);
|
|
582
|
-
},
|
|
583
|
-
provide: (r8) => [showTooltip.from(r8, (r9) => r9.tooltip), EditorView.contentAttributes.from(r8, (r9) => r9.attrs)]
|
|
584
|
-
});
|
|
585
|
-
function applyCompletion(r8, M) {
|
|
586
|
-
let N = M.completion.apply || M.completion.label, P = r8.state.field(completionState).active.find((r9) => r9.source == M.source);
|
|
587
|
-
return P instanceof ActiveResult ? (typeof N == "string" ? r8.dispatch({
|
|
588
|
-
...insertCompletionText(r8.state, N, P.from, P.to),
|
|
589
|
-
annotations: pickedCompletion.of(M.completion)
|
|
590
|
-
}) : N(r8, M.completion, P.from, P.to), true) : false;
|
|
591
|
-
}
|
|
592
|
-
var createTooltip = /* @__PURE__ */ completionTooltip(completionState, applyCompletion);
|
|
593
|
-
function moveCompletionSelection(r8, M = "option") {
|
|
594
|
-
return (N) => {
|
|
595
|
-
let P = N.state.field(completionState, false);
|
|
596
|
-
if (!P || !P.open || P.open.disabled || Date.now() - P.open.timestamp < N.state.facet(completionConfig).interactionDelay) return false;
|
|
597
|
-
let F = 1, I;
|
|
598
|
-
M == "page" && (I = getTooltip(N, P.open.tooltip)) && (F = Math.max(2, Math.floor(I.dom.offsetHeight / I.dom.querySelector("li").offsetHeight) - 1));
|
|
599
|
-
let { length: L } = P.open.options, R = P.open.selected > -1 ? P.open.selected + F * (r8 ? 1 : -1) : r8 ? 0 : L - 1;
|
|
600
|
-
return R < 0 ? R = M == "page" ? 0 : L - 1 : R >= L && (R = M == "page" ? L - 1 : 0), N.dispatch({ effects: setSelectedEffect.of(R) }), true;
|
|
601
|
-
};
|
|
602
|
-
}
|
|
603
|
-
var acceptCompletion = (r8) => {
|
|
604
|
-
let M = r8.state.field(completionState, false);
|
|
605
|
-
return r8.state.readOnly || !M || !M.open || M.open.selected < 0 || M.open.disabled || Date.now() - M.open.timestamp < r8.state.facet(completionConfig).interactionDelay ? false : applyCompletion(r8, M.open.options[M.open.selected]);
|
|
606
|
-
}, startCompletion = (r8) => r8.state.field(completionState, false) ? (r8.dispatch({ effects: startCompletionEffect.of(true) }), true) : false, closeCompletion = (r8) => {
|
|
607
|
-
let M = r8.state.field(completionState, false);
|
|
608
|
-
return !M || !M.active.some((r9) => r9.state != 0) ? false : (r8.dispatch({ effects: closeCompletionEffect.of(null) }), true);
|
|
609
|
-
}, RunningQuery = class {
|
|
610
|
-
constructor(r8, M) {
|
|
611
|
-
this.active = r8, this.context = M, this.time = Date.now(), this.updates = [], this.done = void 0;
|
|
612
|
-
}
|
|
613
|
-
}, MaxUpdateCount = 50, MinAbortTime = 1e3, completionPlugin = /* @__PURE__ */ ViewPlugin.fromClass(class {
|
|
614
|
-
constructor(r8) {
|
|
615
|
-
this.view = r8, this.debounceUpdate = -1, this.running = [], this.debounceAccept = -1, this.pendingStart = false, this.composing = 0;
|
|
616
|
-
for (let M of r8.state.field(completionState).active) M.isPending && this.startQuery(M);
|
|
617
|
-
}
|
|
618
|
-
update(r8) {
|
|
619
|
-
let M = r8.state.field(completionState), N = r8.state.facet(completionConfig);
|
|
620
|
-
if (!r8.selectionSet && !r8.docChanged && r8.startState.field(completionState) == M) return;
|
|
621
|
-
let P = r8.transactions.some((r9) => {
|
|
622
|
-
let M2 = getUpdateType(r9, N);
|
|
623
|
-
return M2 & 8 || (r9.selection || r9.docChanged) && !(M2 & 3);
|
|
624
|
-
});
|
|
625
|
-
for (let M2 = 0; M2 < this.running.length; M2++) {
|
|
626
|
-
let N2 = this.running[M2];
|
|
627
|
-
if (P || N2.context.abortOnDocChange && r8.docChanged || N2.updates.length + r8.transactions.length > MaxUpdateCount && Date.now() - N2.time > MinAbortTime) {
|
|
628
|
-
for (let r9 of N2.context.abortListeners) try {
|
|
629
|
-
r9();
|
|
630
|
-
} catch (r10) {
|
|
631
|
-
logException(this.view.state, r10);
|
|
632
|
-
}
|
|
633
|
-
N2.context.abortListeners = null, this.running.splice(M2--, 1);
|
|
634
|
-
} else N2.updates.push(...r8.transactions);
|
|
635
|
-
}
|
|
636
|
-
this.debounceUpdate > -1 && clearTimeout(this.debounceUpdate), r8.transactions.some((r9) => r9.effects.some((r10) => r10.is(startCompletionEffect))) && (this.pendingStart = true);
|
|
637
|
-
let F = this.pendingStart ? 50 : N.activateOnTypingDelay;
|
|
638
|
-
if (this.debounceUpdate = M.active.some((r9) => r9.isPending && !this.running.some((M2) => M2.active.source == r9.source)) ? setTimeout(() => this.startUpdate(), F) : -1, this.composing != 0) for (let M2 of r8.transactions) M2.isUserEvent("input.type") ? this.composing = 2 : this.composing == 2 && M2.selection && (this.composing = 3);
|
|
639
|
-
}
|
|
640
|
-
startUpdate() {
|
|
641
|
-
this.debounceUpdate = -1, this.pendingStart = false;
|
|
642
|
-
let { state: r8 } = this.view, M = r8.field(completionState);
|
|
643
|
-
for (let r9 of M.active) r9.isPending && !this.running.some((M2) => M2.active.source == r9.source) && this.startQuery(r9);
|
|
644
|
-
this.running.length && M.open && M.open.disabled && (this.debounceAccept = setTimeout(() => this.accept(), this.view.state.facet(completionConfig).updateSyncTime));
|
|
645
|
-
}
|
|
646
|
-
startQuery(r8) {
|
|
647
|
-
let { state: M } = this.view, N = new CompletionContext(M, cur(M), r8.explicit, this.view), P = new RunningQuery(r8, N);
|
|
648
|
-
this.running.push(P), Promise.resolve(r8.source(N)).then((r9) => {
|
|
649
|
-
P.context.aborted || (P.done = r9 || null, this.scheduleAccept());
|
|
650
|
-
}, (r9) => {
|
|
651
|
-
this.view.dispatch({ effects: closeCompletionEffect.of(null) }), logException(this.view.state, r9);
|
|
652
|
-
});
|
|
653
|
-
}
|
|
654
|
-
scheduleAccept() {
|
|
655
|
-
this.running.every((r8) => r8.done !== void 0) ? this.accept() : this.debounceAccept < 0 && (this.debounceAccept = setTimeout(() => this.accept(), this.view.state.facet(completionConfig).updateSyncTime));
|
|
656
|
-
}
|
|
657
|
-
accept() {
|
|
658
|
-
this.debounceAccept > -1 && clearTimeout(this.debounceAccept), this.debounceAccept = -1;
|
|
659
|
-
let r8 = [], M = this.view.state.facet(completionConfig), N = this.view.state.field(completionState);
|
|
660
|
-
for (let P = 0; P < this.running.length; P++) {
|
|
661
|
-
let F = this.running[P];
|
|
662
|
-
if (F.done === void 0) continue;
|
|
663
|
-
if (this.running.splice(P--, 1), F.done) {
|
|
664
|
-
let N2 = cur(F.updates.length ? F.updates[0].startState : this.view.state), P2 = Math.min(N2, F.done.from + (F.active.explicit ? 0 : 1)), I2 = new ActiveResult(F.active.source, F.active.explicit, P2, F.done, F.done.from, F.done.to ?? N2);
|
|
665
|
-
for (let r9 of F.updates) I2 = I2.update(r9, M);
|
|
666
|
-
if (I2.hasResult()) {
|
|
667
|
-
r8.push(I2);
|
|
668
|
-
continue;
|
|
669
|
-
}
|
|
670
|
-
}
|
|
671
|
-
let I = N.active.find((r9) => r9.source == F.active.source);
|
|
672
|
-
if (I && I.isPending) if (F.done == null) {
|
|
673
|
-
let N2 = new ActiveSource(F.active.source, 0);
|
|
674
|
-
for (let r9 of F.updates) N2 = N2.update(r9, M);
|
|
675
|
-
N2.isPending || r8.push(N2);
|
|
676
|
-
} else this.startQuery(I);
|
|
677
|
-
}
|
|
678
|
-
(r8.length || N.open && N.open.disabled) && this.view.dispatch({ effects: setActiveEffect.of(r8) });
|
|
679
|
-
}
|
|
680
|
-
}, { eventHandlers: {
|
|
681
|
-
blur(r8) {
|
|
682
|
-
let M = this.view.state.field(completionState, false);
|
|
683
|
-
if (M && M.tooltip && this.view.state.facet(completionConfig).closeOnBlur) {
|
|
684
|
-
let N = M.open && getTooltip(this.view, M.open.tooltip);
|
|
685
|
-
(!N || !N.dom.contains(r8.relatedTarget)) && setTimeout(() => this.view.dispatch({ effects: closeCompletionEffect.of(null) }), 10);
|
|
686
|
-
}
|
|
687
|
-
},
|
|
688
|
-
compositionstart() {
|
|
689
|
-
this.composing = 1;
|
|
690
|
-
},
|
|
691
|
-
compositionend() {
|
|
692
|
-
this.composing == 3 && setTimeout(() => this.view.dispatch({ effects: startCompletionEffect.of(false) }), 20), this.composing = 0;
|
|
693
|
-
}
|
|
694
|
-
} }), windows = typeof navigator == "object" && /* @__PURE__ */ /Win/.test(navigator.platform), commitCharacters = /* @__PURE__ */ Prec.highest(/* @__PURE__ */ EditorView.domEventHandlers({ keydown(r8, M) {
|
|
695
|
-
let N = M.state.field(completionState, false);
|
|
696
|
-
if (!N || !N.open || N.open.disabled || N.open.selected < 0 || r8.key.length > 1 || r8.ctrlKey && !(windows && r8.altKey) || r8.metaKey) return false;
|
|
697
|
-
let P = N.open.options[N.open.selected], F = N.active.find((r9) => r9.source == P.source), I = P.completion.commitCharacters || F.result.commitCharacters;
|
|
698
|
-
return I && I.indexOf(r8.key) > -1 && applyCompletion(M, P), false;
|
|
699
|
-
} })), baseTheme = /* @__PURE__ */ EditorView.baseTheme({
|
|
700
|
-
".cm-tooltip.cm-tooltip-autocomplete": { "& > ul": {
|
|
701
|
-
fontFamily: "monospace",
|
|
702
|
-
whiteSpace: "nowrap",
|
|
703
|
-
overflow: "hidden auto",
|
|
704
|
-
maxWidth_fallback: "700px",
|
|
705
|
-
maxWidth: "min(700px, 95vw)",
|
|
706
|
-
minWidth: "250px",
|
|
707
|
-
maxHeight: "10em",
|
|
708
|
-
height: "100%",
|
|
709
|
-
listStyle: "none",
|
|
710
|
-
margin: 0,
|
|
711
|
-
padding: 0,
|
|
712
|
-
"& > li, & > completion-section": {
|
|
713
|
-
padding: "1px 3px",
|
|
714
|
-
lineHeight: 1.2
|
|
715
|
-
},
|
|
716
|
-
"& > li": {
|
|
717
|
-
overflowX: "hidden",
|
|
718
|
-
textOverflow: "ellipsis",
|
|
719
|
-
cursor: "pointer"
|
|
720
|
-
},
|
|
721
|
-
"& > completion-section": {
|
|
722
|
-
display: "list-item",
|
|
723
|
-
borderBottom: "1px solid silver",
|
|
724
|
-
paddingLeft: "0.5em",
|
|
725
|
-
opacity: 0.7
|
|
726
|
-
}
|
|
727
|
-
} },
|
|
728
|
-
"&light .cm-tooltip-autocomplete ul li[aria-selected]": {
|
|
729
|
-
background: "#17c",
|
|
730
|
-
color: "white"
|
|
731
|
-
},
|
|
732
|
-
"&light .cm-tooltip-autocomplete-disabled ul li[aria-selected]": { background: "#777" },
|
|
733
|
-
"&dark .cm-tooltip-autocomplete ul li[aria-selected]": {
|
|
734
|
-
background: "#347",
|
|
735
|
-
color: "white"
|
|
736
|
-
},
|
|
737
|
-
"&dark .cm-tooltip-autocomplete-disabled ul li[aria-selected]": { background: "#444" },
|
|
738
|
-
".cm-completionListIncompleteTop:before, .cm-completionListIncompleteBottom:after": {
|
|
739
|
-
content: '"\xB7\xB7\xB7"',
|
|
740
|
-
opacity: 0.5,
|
|
741
|
-
display: "block",
|
|
742
|
-
textAlign: "center"
|
|
743
|
-
},
|
|
744
|
-
".cm-tooltip.cm-completionInfo": {
|
|
745
|
-
position: "absolute",
|
|
746
|
-
padding: "3px 9px",
|
|
747
|
-
width: "max-content",
|
|
748
|
-
maxWidth: "400px",
|
|
749
|
-
boxSizing: "border-box",
|
|
750
|
-
whiteSpace: "pre-line"
|
|
751
|
-
},
|
|
752
|
-
".cm-completionInfo.cm-completionInfo-left": { right: "100%" },
|
|
753
|
-
".cm-completionInfo.cm-completionInfo-right": { left: "100%" },
|
|
754
|
-
".cm-completionInfo.cm-completionInfo-left-narrow": { right: "30px" },
|
|
755
|
-
".cm-completionInfo.cm-completionInfo-right-narrow": { left: "30px" },
|
|
756
|
-
"&light .cm-snippetField": { backgroundColor: "#00000022" },
|
|
757
|
-
"&dark .cm-snippetField": { backgroundColor: "#ffffff22" },
|
|
758
|
-
".cm-snippetFieldPosition": {
|
|
759
|
-
verticalAlign: "text-top",
|
|
760
|
-
width: 0,
|
|
761
|
-
height: "1.15em",
|
|
762
|
-
display: "inline-block",
|
|
763
|
-
margin: "0 -0.7px -.7em",
|
|
764
|
-
borderLeft: "1.4px dotted #888"
|
|
765
|
-
},
|
|
766
|
-
".cm-completionMatchedText": { textDecoration: "underline" },
|
|
767
|
-
".cm-completionDetail": {
|
|
768
|
-
marginLeft: "0.5em",
|
|
769
|
-
fontStyle: "italic"
|
|
770
|
-
},
|
|
771
|
-
".cm-completionIcon": {
|
|
772
|
-
fontSize: "90%",
|
|
773
|
-
width: ".8em",
|
|
774
|
-
display: "inline-block",
|
|
775
|
-
textAlign: "center",
|
|
776
|
-
paddingRight: ".6em",
|
|
777
|
-
opacity: "0.6",
|
|
778
|
-
boxSizing: "content-box"
|
|
779
|
-
},
|
|
780
|
-
".cm-completionIcon-function, .cm-completionIcon-method": { "&:after": { content: "'\u0192'" } },
|
|
781
|
-
".cm-completionIcon-class": { "&:after": { content: "'\u25CB'" } },
|
|
782
|
-
".cm-completionIcon-interface": { "&:after": { content: "'\u25CC'" } },
|
|
783
|
-
".cm-completionIcon-variable": { "&:after": { content: "'\u{1D465}'" } },
|
|
784
|
-
".cm-completionIcon-constant": { "&:after": { content: "'\u{1D436}'" } },
|
|
785
|
-
".cm-completionIcon-type": { "&:after": { content: "'\u{1D461}'" } },
|
|
786
|
-
".cm-completionIcon-enum": { "&:after": { content: "'\u222A'" } },
|
|
787
|
-
".cm-completionIcon-property": { "&:after": { content: "'\u25A1'" } },
|
|
788
|
-
".cm-completionIcon-keyword": { "&:after": { content: "'\u{1F511}\uFE0E'" } },
|
|
789
|
-
".cm-completionIcon-namespace": { "&:after": { content: "'\u25A2'" } },
|
|
790
|
-
".cm-completionIcon-text": { "&:after": {
|
|
791
|
-
content: "'abc'",
|
|
792
|
-
fontSize: "50%",
|
|
793
|
-
verticalAlign: "middle"
|
|
794
|
-
} }
|
|
795
|
-
}), FieldPos = class {
|
|
796
|
-
constructor(r8, M, N, P) {
|
|
797
|
-
this.field = r8, this.line = M, this.from = N, this.to = P;
|
|
798
|
-
}
|
|
799
|
-
}, FieldRange = class r5 {
|
|
800
|
-
constructor(r8, M, N) {
|
|
801
|
-
this.field = r8, this.from = M, this.to = N;
|
|
802
|
-
}
|
|
803
|
-
map(M) {
|
|
804
|
-
let N = M.mapPos(this.from, -1, MapMode.TrackDel), P = M.mapPos(this.to, 1, MapMode.TrackDel);
|
|
805
|
-
return N == null || P == null ? null : new r5(this.field, N, P);
|
|
806
|
-
}
|
|
807
|
-
}, Snippet = class r6 {
|
|
808
|
-
constructor(r8, M) {
|
|
809
|
-
this.lines = r8, this.fieldPositions = M;
|
|
810
|
-
}
|
|
811
|
-
instantiate(r8, M) {
|
|
812
|
-
let N = [], P = [M], F = r8.doc.lineAt(M), I = /^\s*/.exec(F.text)[0];
|
|
813
|
-
for (let F2 of this.lines) {
|
|
814
|
-
if (N.length) {
|
|
815
|
-
let N2 = I, L = /^\t*/.exec(F2)[0].length;
|
|
816
|
-
for (let M2 = 0; M2 < L; M2++) N2 += r8.facet(indentUnit);
|
|
817
|
-
P.push(M + N2.length - L), F2 = N2 + F2.slice(L);
|
|
818
|
-
}
|
|
819
|
-
N.push(F2), M += F2.length + 1;
|
|
820
|
-
}
|
|
821
|
-
return {
|
|
822
|
-
text: N,
|
|
823
|
-
ranges: this.fieldPositions.map((r9) => new FieldRange(r9.field, P[r9.line] + r9.from, P[r9.line] + r9.to))
|
|
824
|
-
};
|
|
825
|
-
}
|
|
826
|
-
static parse(M) {
|
|
827
|
-
let N = [], P = [], F = [], I;
|
|
828
|
-
for (let r8 of M.split(/\r\n?|\n/)) {
|
|
829
|
-
for (; I = /[#$]\{(?:(\d+)(?::([^{}]*))?|((?:\\[{}]|[^{}])*))\}/.exec(r8); ) {
|
|
830
|
-
let M2 = I[1] ? +I[1] : null, L = I[2] || I[3] || "", R = -1, z = L.replace(/\\[{}]/g, (r9) => r9[1]);
|
|
831
|
-
for (let r9 = 0; r9 < N.length; r9++) (M2 == null ? z && N[r9].name == z : N[r9].seq == M2) && (R = r9);
|
|
832
|
-
if (R < 0) {
|
|
833
|
-
let r9 = 0;
|
|
834
|
-
for (; r9 < N.length && (M2 == null || N[r9].seq != null && N[r9].seq < M2); ) r9++;
|
|
835
|
-
N.splice(r9, 0, {
|
|
836
|
-
seq: M2,
|
|
837
|
-
name: z
|
|
838
|
-
}), R = r9;
|
|
839
|
-
for (let r10 of F) r10.field >= R && r10.field++;
|
|
840
|
-
}
|
|
841
|
-
for (let r9 of F) if (r9.line == P.length && r9.from > I.index) {
|
|
842
|
-
let M3 = I[2] ? 3 + (I[1] || "").length : 2;
|
|
843
|
-
r9.from -= M3, r9.to -= M3;
|
|
844
|
-
}
|
|
845
|
-
F.push(new FieldPos(R, P.length, I.index, I.index + z.length)), r8 = r8.slice(0, I.index) + L + r8.slice(I.index + I[0].length);
|
|
846
|
-
}
|
|
847
|
-
r8 = r8.replace(/\\([{}])/g, (r9, M2, N2) => {
|
|
848
|
-
for (let r10 of F) r10.line == P.length && r10.from > N2 && (r10.from--, r10.to--);
|
|
849
|
-
return M2;
|
|
850
|
-
}), P.push(r8);
|
|
851
|
-
}
|
|
852
|
-
return new r6(P, F);
|
|
853
|
-
}
|
|
854
|
-
}, fieldMarker = /* @__PURE__ */ Decoration.widget({ widget: /* @__PURE__ */ new class extends WidgetType {
|
|
855
|
-
toDOM() {
|
|
856
|
-
let r8 = document.createElement("span");
|
|
857
|
-
return r8.className = "cm-snippetFieldPosition", r8;
|
|
858
|
-
}
|
|
859
|
-
ignoreEvent() {
|
|
860
|
-
return false;
|
|
861
|
-
}
|
|
862
|
-
}() }), fieldRange = /* @__PURE__ */ Decoration.mark({ class: "cm-snippetField" }), ActiveSnippet = class r7 {
|
|
863
|
-
constructor(r8, M) {
|
|
864
|
-
this.ranges = r8, this.active = M, this.deco = Decoration.set(r8.map((r9) => (r9.from == r9.to ? fieldMarker : fieldRange).range(r9.from, r9.to)), true);
|
|
865
|
-
}
|
|
866
|
-
map(M) {
|
|
867
|
-
let N = [];
|
|
868
|
-
for (let r8 of this.ranges) {
|
|
869
|
-
let P = r8.map(M);
|
|
870
|
-
if (!P) return null;
|
|
871
|
-
N.push(P);
|
|
872
|
-
}
|
|
873
|
-
return new r7(N, this.active);
|
|
874
|
-
}
|
|
875
|
-
selectionInsideField(r8) {
|
|
876
|
-
return r8.ranges.every((r9) => this.ranges.some((M) => M.field == this.active && M.from <= r9.from && M.to >= r9.to));
|
|
877
|
-
}
|
|
878
|
-
}, setActive = /* @__PURE__ */ StateEffect.define({ map(r8, M) {
|
|
879
|
-
return r8 && r8.map(M);
|
|
880
|
-
} }), moveToField = /* @__PURE__ */ StateEffect.define(), snippetState = /* @__PURE__ */ StateField.define({
|
|
881
|
-
create() {
|
|
882
|
-
return null;
|
|
883
|
-
},
|
|
884
|
-
update(r8, M) {
|
|
885
|
-
for (let N of M.effects) {
|
|
886
|
-
if (N.is(setActive)) return N.value;
|
|
887
|
-
if (N.is(moveToField) && r8) return new ActiveSnippet(r8.ranges, N.value);
|
|
888
|
-
}
|
|
889
|
-
return r8 && M.docChanged && (r8 = r8.map(M.changes)), r8 && M.selection && !r8.selectionInsideField(M.selection) && (r8 = null), r8;
|
|
890
|
-
},
|
|
891
|
-
provide: (r8) => EditorView.decorations.from(r8, (r9) => r9 ? r9.deco : Decoration.none)
|
|
892
|
-
});
|
|
893
|
-
function fieldSelection(r8, M) {
|
|
894
|
-
return EditorSelection.create(r8.filter((r9) => r9.field == M).map((r9) => EditorSelection.range(r9.from, r9.to)));
|
|
895
|
-
}
|
|
896
|
-
function snippet(r8) {
|
|
897
|
-
let M = Snippet.parse(r8);
|
|
898
|
-
return (r9, N, P, I) => {
|
|
899
|
-
let { text: L, ranges: z } = M.instantiate(r9.state, P), { main: B } = r9.state.selection, H = {
|
|
900
|
-
changes: {
|
|
901
|
-
from: P,
|
|
902
|
-
to: I == B.from ? B.to : I,
|
|
903
|
-
insert: Text.of(L)
|
|
904
|
-
},
|
|
905
|
-
scrollIntoView: true,
|
|
906
|
-
annotations: N ? [pickedCompletion.of(N), Transaction.userEvent.of("input.complete")] : void 0
|
|
907
|
-
};
|
|
908
|
-
if (z.length && (H.selection = fieldSelection(z, 0)), z.some((r10) => r10.field > 0)) {
|
|
909
|
-
let M2 = new ActiveSnippet(z, 0), N2 = H.effects = [setActive.of(M2)];
|
|
910
|
-
r9.state.field(snippetState, false) === void 0 && N2.push(StateEffect.appendConfig.of([
|
|
911
|
-
snippetState,
|
|
912
|
-
addSnippetKeymap,
|
|
913
|
-
snippetPointerHandler,
|
|
914
|
-
baseTheme
|
|
915
|
-
]));
|
|
916
|
-
}
|
|
917
|
-
r9.dispatch(r9.state.update(H));
|
|
918
|
-
};
|
|
919
|
-
}
|
|
920
|
-
function moveField(r8) {
|
|
921
|
-
return ({ state: M, dispatch: N }) => {
|
|
922
|
-
let P = M.field(snippetState, false);
|
|
923
|
-
if (!P || r8 < 0 && P.active == 0) return false;
|
|
924
|
-
let F = P.active + r8, I = r8 > 0 && !P.ranges.some((M2) => M2.field == F + r8);
|
|
925
|
-
return N(M.update({
|
|
926
|
-
selection: fieldSelection(P.ranges, F),
|
|
927
|
-
effects: setActive.of(I ? null : new ActiveSnippet(P.ranges, F)),
|
|
928
|
-
scrollIntoView: true
|
|
929
|
-
})), true;
|
|
930
|
-
};
|
|
931
|
-
}
|
|
932
|
-
var defaultSnippetKeymap = [{
|
|
933
|
-
key: "Tab",
|
|
934
|
-
run: /* @__PURE__ */ moveField(1),
|
|
935
|
-
shift: /* @__PURE__ */ moveField(-1)
|
|
936
|
-
}, {
|
|
937
|
-
key: "Escape",
|
|
938
|
-
run: ({ state: r8, dispatch: M }) => r8.field(snippetState, false) ? (M(r8.update({ effects: setActive.of(null) })), true) : false
|
|
939
|
-
}], snippetKeymap = /* @__PURE__ */ Facet.define({ combine(r8) {
|
|
940
|
-
return r8.length ? r8[0] : defaultSnippetKeymap;
|
|
941
|
-
} }), addSnippetKeymap = /* @__PURE__ */ Prec.highest(/* @__PURE__ */ keymap.compute([snippetKeymap], (r8) => r8.facet(snippetKeymap)));
|
|
942
|
-
function snippetCompletion(r8, M) {
|
|
943
|
-
return {
|
|
944
|
-
...M,
|
|
945
|
-
apply: snippet(r8)
|
|
946
|
-
};
|
|
947
|
-
}
|
|
948
|
-
var snippetPointerHandler = /* @__PURE__ */ EditorView.domEventHandlers({ mousedown(r8, M) {
|
|
949
|
-
let N = M.state.field(snippetState, false), P;
|
|
950
|
-
if (!N || (P = M.posAtCoords({
|
|
951
|
-
x: r8.clientX,
|
|
952
|
-
y: r8.clientY
|
|
953
|
-
})) == null) return false;
|
|
954
|
-
let F = N.ranges.find((r9) => r9.from <= P && r9.to >= P);
|
|
955
|
-
return !F || F.field == N.active ? false : (M.dispatch({
|
|
956
|
-
selection: fieldSelection(N.ranges, F.field),
|
|
957
|
-
effects: setActive.of(N.ranges.some((r9) => r9.field > F.field) ? new ActiveSnippet(N.ranges, F.field) : null),
|
|
958
|
-
scrollIntoView: true
|
|
959
|
-
}), true);
|
|
960
|
-
} }), defaults = {
|
|
961
|
-
brackets: [
|
|
962
|
-
"(",
|
|
963
|
-
"[",
|
|
964
|
-
"{",
|
|
965
|
-
"'",
|
|
966
|
-
'"'
|
|
967
|
-
],
|
|
968
|
-
before: ")]}:;>",
|
|
969
|
-
stringPrefixes: []
|
|
970
|
-
}, closeBracketEffect = /* @__PURE__ */ StateEffect.define({ map(r8, M) {
|
|
971
|
-
return M.mapPos(r8, -1, MapMode.TrackAfter) ?? void 0;
|
|
972
|
-
} }), closedBracket = /* @__PURE__ */ new class extends RangeValue {
|
|
973
|
-
}();
|
|
974
|
-
closedBracket.startSide = 1, closedBracket.endSide = -1;
|
|
975
|
-
var bracketState = /* @__PURE__ */ StateField.define({
|
|
976
|
-
create() {
|
|
977
|
-
return RangeSet.empty;
|
|
978
|
-
},
|
|
979
|
-
update(r8, M) {
|
|
980
|
-
if (r8 = r8.map(M.changes), M.selection) {
|
|
981
|
-
let N = M.state.doc.lineAt(M.selection.main.head);
|
|
982
|
-
r8 = r8.update({ filter: (r9) => r9 >= N.from && r9 <= N.to });
|
|
983
|
-
}
|
|
984
|
-
for (let N of M.effects) N.is(closeBracketEffect) && (r8 = r8.update({ add: [closedBracket.range(N.value, N.value + 1)] }));
|
|
985
|
-
return r8;
|
|
986
|
-
}
|
|
987
|
-
});
|
|
988
|
-
function closeBrackets() {
|
|
989
|
-
return [inputHandler, bracketState];
|
|
990
|
-
}
|
|
991
|
-
var definedClosing = "()[]{}<>\xAB\xBB\xBB\xAB\uFF3B\uFF3D\uFF5B\uFF5D";
|
|
992
|
-
function closing(r8) {
|
|
993
|
-
for (let M = 0; M < 16; M += 2) if (definedClosing.charCodeAt(M) == r8) return definedClosing.charAt(M + 1);
|
|
994
|
-
return fromCodePoint(r8 < 128 ? r8 : r8 + 1);
|
|
995
|
-
}
|
|
996
|
-
function config(r8, M) {
|
|
997
|
-
return r8.languageDataAt("closeBrackets", M)[0] || defaults;
|
|
998
|
-
}
|
|
999
|
-
var android = typeof navigator == "object" && /* @__PURE__ */ /Android\b/.test(navigator.userAgent), inputHandler = /* @__PURE__ */ EditorView.inputHandler.of((r8, M, N, P) => {
|
|
1000
|
-
if ((android ? r8.composing : r8.compositionStarted) || r8.state.readOnly) return false;
|
|
1001
|
-
let F = r8.state.selection.main;
|
|
1002
|
-
if (P.length > 2 || P.length == 2 && codePointSize(codePointAt(P, 0)) == 1 || M != F.from || N != F.to) return false;
|
|
1003
|
-
let I = insertBracket(r8.state, P);
|
|
1004
|
-
return I ? (r8.dispatch(I), true) : false;
|
|
1005
|
-
}), closeBracketsKeymap = [{
|
|
1006
|
-
key: "Backspace",
|
|
1007
|
-
run: ({ state: r8, dispatch: M }) => {
|
|
1008
|
-
if (r8.readOnly) return false;
|
|
1009
|
-
let N = config(r8, r8.selection.main.head).brackets || defaults.brackets, P = null, F = r8.changeByRange((M2) => {
|
|
1010
|
-
if (M2.empty) {
|
|
1011
|
-
let P2 = prevChar(r8.doc, M2.head);
|
|
1012
|
-
for (let F2 of N) if (F2 == P2 && nextChar(r8.doc, M2.head) == closing(codePointAt(F2, 0))) return {
|
|
1013
|
-
changes: {
|
|
1014
|
-
from: M2.head - F2.length,
|
|
1015
|
-
to: M2.head + F2.length
|
|
1016
|
-
},
|
|
1017
|
-
range: EditorSelection.cursor(M2.head - F2.length)
|
|
1018
|
-
};
|
|
1019
|
-
}
|
|
1020
|
-
return { range: P = M2 };
|
|
1021
|
-
});
|
|
1022
|
-
return P || M(r8.update(F, {
|
|
1023
|
-
scrollIntoView: true,
|
|
1024
|
-
userEvent: "delete.backward"
|
|
1025
|
-
})), !P;
|
|
1026
|
-
}
|
|
1027
|
-
}];
|
|
1028
|
-
function insertBracket(r8, M) {
|
|
1029
|
-
let N = config(r8, r8.selection.main.head), P = N.brackets || defaults.brackets;
|
|
1030
|
-
for (let F of P) {
|
|
1031
|
-
let I = closing(codePointAt(F, 0));
|
|
1032
|
-
if (M == F) return I == F ? handleSame(r8, F, P.indexOf(F + F + F) > -1, N) : handleOpen(r8, F, I, N.before || defaults.before);
|
|
1033
|
-
if (M == I && closedBracketAt(r8, r8.selection.main.from)) return handleClose(r8, F, I);
|
|
1034
|
-
}
|
|
1035
|
-
return null;
|
|
1036
|
-
}
|
|
1037
|
-
function closedBracketAt(r8, M) {
|
|
1038
|
-
let N = false;
|
|
1039
|
-
return r8.field(bracketState).between(0, r8.doc.length, (r9) => {
|
|
1040
|
-
r9 == M && (N = true);
|
|
1041
|
-
}), N;
|
|
1042
|
-
}
|
|
1043
|
-
function nextChar(r8, M) {
|
|
1044
|
-
let N = r8.sliceString(M, M + 2);
|
|
1045
|
-
return N.slice(0, codePointSize(codePointAt(N, 0)));
|
|
1046
|
-
}
|
|
1047
|
-
function prevChar(r8, M) {
|
|
1048
|
-
let N = r8.sliceString(M - 2, M);
|
|
1049
|
-
return codePointSize(codePointAt(N, 0)) == N.length ? N : N.slice(1);
|
|
1050
|
-
}
|
|
1051
|
-
function handleOpen(r8, M, N, P) {
|
|
1052
|
-
let F = null, I = r8.changeByRange((I2) => {
|
|
1053
|
-
if (!I2.empty) return {
|
|
1054
|
-
changes: [{
|
|
1055
|
-
insert: M,
|
|
1056
|
-
from: I2.from
|
|
1057
|
-
}, {
|
|
1058
|
-
insert: N,
|
|
1059
|
-
from: I2.to
|
|
1060
|
-
}],
|
|
1061
|
-
effects: closeBracketEffect.of(I2.to + M.length),
|
|
1062
|
-
range: EditorSelection.range(I2.anchor + M.length, I2.head + M.length)
|
|
1063
|
-
};
|
|
1064
|
-
let L = nextChar(r8.doc, I2.head);
|
|
1065
|
-
return !L || /\s/.test(L) || P.indexOf(L) > -1 ? {
|
|
1066
|
-
changes: {
|
|
1067
|
-
insert: M + N,
|
|
1068
|
-
from: I2.head
|
|
1069
|
-
},
|
|
1070
|
-
effects: closeBracketEffect.of(I2.head + M.length),
|
|
1071
|
-
range: EditorSelection.cursor(I2.head + M.length)
|
|
1072
|
-
} : { range: F = I2 };
|
|
1073
|
-
});
|
|
1074
|
-
return F ? null : r8.update(I, {
|
|
1075
|
-
scrollIntoView: true,
|
|
1076
|
-
userEvent: "input.type"
|
|
1077
|
-
});
|
|
1078
|
-
}
|
|
1079
|
-
function handleClose(r8, M, N) {
|
|
1080
|
-
let P = null, F = r8.changeByRange((M2) => M2.empty && nextChar(r8.doc, M2.head) == N ? {
|
|
1081
|
-
changes: {
|
|
1082
|
-
from: M2.head,
|
|
1083
|
-
to: M2.head + N.length,
|
|
1084
|
-
insert: N
|
|
1085
|
-
},
|
|
1086
|
-
range: EditorSelection.cursor(M2.head + N.length)
|
|
1087
|
-
} : P = { range: M2 });
|
|
1088
|
-
return P ? null : r8.update(F, {
|
|
1089
|
-
scrollIntoView: true,
|
|
1090
|
-
userEvent: "input.type"
|
|
1091
|
-
});
|
|
1092
|
-
}
|
|
1093
|
-
function handleSame(r8, M, P, F) {
|
|
1094
|
-
let I = F.stringPrefixes || defaults.stringPrefixes, L = null, R = r8.changeByRange((F2) => {
|
|
1095
|
-
if (!F2.empty) return {
|
|
1096
|
-
changes: [{
|
|
1097
|
-
insert: M,
|
|
1098
|
-
from: F2.from
|
|
1099
|
-
}, {
|
|
1100
|
-
insert: M,
|
|
1101
|
-
from: F2.to
|
|
1102
|
-
}],
|
|
1103
|
-
effects: closeBracketEffect.of(F2.to + M.length),
|
|
1104
|
-
range: EditorSelection.range(F2.anchor + M.length, F2.head + M.length)
|
|
1105
|
-
};
|
|
1106
|
-
let R2 = F2.head, z = nextChar(r8.doc, R2), B;
|
|
1107
|
-
if (z == M) {
|
|
1108
|
-
if (nodeStart(r8, R2)) return {
|
|
1109
|
-
changes: {
|
|
1110
|
-
insert: M + M,
|
|
1111
|
-
from: R2
|
|
1112
|
-
},
|
|
1113
|
-
effects: closeBracketEffect.of(R2 + M.length),
|
|
1114
|
-
range: EditorSelection.cursor(R2 + M.length)
|
|
1115
|
-
};
|
|
1116
|
-
if (closedBracketAt(r8, R2)) {
|
|
1117
|
-
let N = P && r8.sliceDoc(R2, R2 + M.length * 3) == M + M + M ? M + M + M : M;
|
|
1118
|
-
return {
|
|
1119
|
-
changes: {
|
|
1120
|
-
from: R2,
|
|
1121
|
-
to: R2 + N.length,
|
|
1122
|
-
insert: N
|
|
1123
|
-
},
|
|
1124
|
-
range: EditorSelection.cursor(R2 + N.length)
|
|
1125
|
-
};
|
|
1126
|
-
}
|
|
1127
|
-
} else if (P && r8.sliceDoc(R2 - 2 * M.length, R2) == M + M && (B = canStartStringAt(r8, R2 - 2 * M.length, I)) > -1 && nodeStart(r8, B)) return {
|
|
1128
|
-
changes: {
|
|
1129
|
-
insert: M + M + M + M,
|
|
1130
|
-
from: R2
|
|
1131
|
-
},
|
|
1132
|
-
effects: closeBracketEffect.of(R2 + M.length),
|
|
1133
|
-
range: EditorSelection.cursor(R2 + M.length)
|
|
1134
|
-
};
|
|
1135
|
-
else if (r8.charCategorizer(R2)(z) != CharCategory.Word && canStartStringAt(r8, R2, I) > -1 && !probablyInString(r8, R2, M, I)) return {
|
|
1136
|
-
changes: {
|
|
1137
|
-
insert: M + M,
|
|
1138
|
-
from: R2
|
|
1139
|
-
},
|
|
1140
|
-
effects: closeBracketEffect.of(R2 + M.length),
|
|
1141
|
-
range: EditorSelection.cursor(R2 + M.length)
|
|
1142
|
-
};
|
|
1143
|
-
return { range: L = F2 };
|
|
1144
|
-
});
|
|
1145
|
-
return L ? null : r8.update(R, {
|
|
1146
|
-
scrollIntoView: true,
|
|
1147
|
-
userEvent: "input.type"
|
|
1148
|
-
});
|
|
1149
|
-
}
|
|
1150
|
-
function nodeStart(r8, M) {
|
|
1151
|
-
let N = syntaxTree(r8).resolveInner(M + 1);
|
|
1152
|
-
return N.parent && N.from == M;
|
|
1153
|
-
}
|
|
1154
|
-
function probablyInString(r8, M, N, P) {
|
|
1155
|
-
let F = syntaxTree(r8).resolveInner(M, -1), I = P.reduce((r9, M2) => Math.max(r9, M2.length), 0);
|
|
1156
|
-
for (let L = 0; L < 5; L++) {
|
|
1157
|
-
let L2 = r8.sliceDoc(F.from, Math.min(F.to, F.from + N.length + I)), R = L2.indexOf(N);
|
|
1158
|
-
if (!R || R > -1 && P.indexOf(L2.slice(0, R)) > -1) {
|
|
1159
|
-
let M2 = F.firstChild;
|
|
1160
|
-
for (; M2 && M2.from == F.from && M2.to - M2.from > N.length + R; ) {
|
|
1161
|
-
if (r8.sliceDoc(M2.to - N.length, M2.to) == N) return false;
|
|
1162
|
-
M2 = M2.firstChild;
|
|
1163
|
-
}
|
|
1164
|
-
return true;
|
|
1165
|
-
}
|
|
1166
|
-
let z = F.to == M && F.parent;
|
|
1167
|
-
if (!z) break;
|
|
1168
|
-
F = z;
|
|
1169
|
-
}
|
|
1170
|
-
return false;
|
|
1171
|
-
}
|
|
1172
|
-
function canStartStringAt(r8, M, P) {
|
|
1173
|
-
let F = r8.charCategorizer(M);
|
|
1174
|
-
if (F(r8.sliceDoc(M - 1, M)) != CharCategory.Word) return M;
|
|
1175
|
-
for (let I of P) {
|
|
1176
|
-
let P2 = M - I.length;
|
|
1177
|
-
if (r8.sliceDoc(P2, M) == I && F(r8.sliceDoc(P2 - 1, P2)) != CharCategory.Word) return P2;
|
|
1178
|
-
}
|
|
1179
|
-
return -1;
|
|
1180
|
-
}
|
|
1181
|
-
function autocompletion(r8 = {}) {
|
|
1182
|
-
return [
|
|
1183
|
-
commitCharacters,
|
|
1184
|
-
completionState,
|
|
1185
|
-
completionConfig.of(r8),
|
|
1186
|
-
completionPlugin,
|
|
1187
|
-
completionKeymapExt,
|
|
1188
|
-
baseTheme
|
|
1189
|
-
];
|
|
1190
|
-
}
|
|
1191
|
-
var completionKeymap = [
|
|
1192
|
-
{
|
|
1193
|
-
key: "Ctrl-Space",
|
|
1194
|
-
run: startCompletion
|
|
1195
|
-
},
|
|
1196
|
-
{
|
|
1197
|
-
mac: "Alt-`",
|
|
1198
|
-
run: startCompletion
|
|
1199
|
-
},
|
|
1200
|
-
{
|
|
1201
|
-
mac: "Alt-i",
|
|
1202
|
-
run: startCompletion
|
|
1203
|
-
},
|
|
1204
|
-
{
|
|
1205
|
-
key: "Escape",
|
|
1206
|
-
run: closeCompletion
|
|
1207
|
-
},
|
|
1208
|
-
{
|
|
1209
|
-
key: "ArrowDown",
|
|
1210
|
-
run: /* @__PURE__ */ moveCompletionSelection(true)
|
|
1211
|
-
},
|
|
1212
|
-
{
|
|
1213
|
-
key: "ArrowUp",
|
|
1214
|
-
run: /* @__PURE__ */ moveCompletionSelection(false)
|
|
1215
|
-
},
|
|
1216
|
-
{
|
|
1217
|
-
key: "PageDown",
|
|
1218
|
-
run: /* @__PURE__ */ moveCompletionSelection(true, "page")
|
|
1219
|
-
},
|
|
1220
|
-
{
|
|
1221
|
-
key: "PageUp",
|
|
1222
|
-
run: /* @__PURE__ */ moveCompletionSelection(false, "page")
|
|
1223
|
-
},
|
|
1224
|
-
{
|
|
1225
|
-
key: "Enter",
|
|
1226
|
-
run: acceptCompletion
|
|
1227
|
-
}
|
|
1228
|
-
], completionKeymapExt = /* @__PURE__ */ Prec.highest(/* @__PURE__ */ keymap.computeN([completionConfig], (r8) => r8.facet(completionConfig).defaultKeymap ? [completionKeymap] : []));
|
|
1229
|
-
export {
|
|
1230
|
-
closeBracketsKeymap as a,
|
|
1231
|
-
completionKeymap as c,
|
|
1232
|
-
snippet as d,
|
|
1233
|
-
snippetCompletion as f,
|
|
1234
|
-
closeBrackets as i,
|
|
1235
|
-
ifNotIn as l,
|
|
1236
|
-
acceptCompletion as n,
|
|
1237
|
-
closeCompletion as o,
|
|
1238
|
-
autocompletion as r,
|
|
1239
|
-
completeFromList as s,
|
|
1240
|
-
CompletionContext as t,
|
|
1241
|
-
insertCompletionText as u
|
|
1242
|
-
};
|