@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.
Files changed (418) hide show
  1. package/dist/{ConnectedDataExplorerComponent-BAeQ8DWw.js → ConnectedDataExplorerComponent-CkXO-pKy.js} +6 -6
  2. package/dist/{react-plotly-BuRa9xtI.js → Plot-CmsrWWji.js} +72 -286
  3. package/dist/{any-language-editor-D0UQItkS.js → any-language-editor-t_VsTNa-.js} +16 -16
  4. package/dist/apl-C1bki_dE.js +4 -0
  5. package/dist/{arc-CEWBr4jc.js → arc-9nABupDE.js} +2 -2
  6. package/dist/{architectureDiagram-VXUJARFQ-DPPYVq8H.js → architectureDiagram-VXUJARFQ-DmJQhcJb.js} +6 -6
  7. package/dist/asciiarmor-BdlkCCRr.js +4 -0
  8. package/dist/asn1-CvE30hox.js +4 -0
  9. package/dist/{blockDiagram-VD42YOAC-BA5N05Y9.js → blockDiagram-VD42YOAC-CRofISJs.js} +10 -10
  10. package/dist/brainfuck-BalwWy1a.js +4 -0
  11. package/dist/{c4Diagram-YG6GDRKO-DJLzuGJJ.js → c4Diagram-YG6GDRKO-Deqoag4I.js} +4 -4
  12. package/dist/{channel-Dob5kWXR.js → channel-CMsnebrL.js} +1 -1
  13. package/dist/{chunk-4BX2VUAB-DZQibjKA.js → chunk-4BX2VUAB-WmXmzRBr.js} +1 -1
  14. package/dist/{chunk-55IACEB6-C3BASkh4.js → chunk-55IACEB6-irYMvHJu.js} +1 -1
  15. package/dist/{chunk-5FQGJX7Z-BEb20Lzt.js → chunk-5FQGJX7Z-pOElJy8t.js} +2 -2
  16. package/dist/{chunk-ABZYJK2D-BXTC53mt.js → chunk-ABZYJK2D-BGWvKte3.js} +2 -2
  17. package/dist/{chunk-ATLVNIR6-BJDjUR_c.js → chunk-ATLVNIR6-BYZB6C5T.js} +2 -2
  18. package/dist/{chunk-B4BG7PRW-DzmUUpfH.js → chunk-B4BG7PRW-CwYUp6Uj.js} +7 -7
  19. package/dist/{chunk-CVBHYZKI-Dhc_e3rA.js → chunk-CVBHYZKI-Bb2XMuXJ.js} +1 -1
  20. package/dist/{chunk-DI55MBZ5-gTd3J8Tu.js → chunk-DI55MBZ5-Gyro6dvN.js} +6 -6
  21. package/dist/{chunk-EXTU4WIE-DyoOs5QX.js → chunk-EXTU4WIE-BlA7aWEw.js} +2 -2
  22. package/dist/{chunk-FMBD7UC4-geNUIndh.js → chunk-FMBD7UC4-C0DZU_4q.js} +1 -1
  23. package/dist/{chunk-HN2XXSSU-CqPwpolw.js → chunk-HN2XXSSU-BsB4dtgF.js} +1 -1
  24. package/dist/{chunk-JA3XYJ7Z-BGnAIbOP.js → chunk-JA3XYJ7Z-Cm-pccR-.js} +3 -3
  25. package/dist/{chunk-JZLCHNYA-CIRgweVQ.js → chunk-JZLCHNYA-CoLqqXMe.js} +6 -6
  26. package/dist/{chunk-MI3HLSF2-DOJkNER1.js → chunk-MI3HLSF2-DeDZS-tQ.js} +1 -1
  27. package/dist/{chunk-N4CR4FBY-DKSvXAIS.js → chunk-N4CR4FBY-ByLbY9L-.js} +7 -7
  28. package/dist/{chunk-QN33PNHL-B6zC8BTi.js → chunk-QN33PNHL-eodIiY9F.js} +2 -2
  29. package/dist/{chunk-QXUST7PY-C7750n_u.js → chunk-QXUST7PY-CuJlDW6A.js} +10 -10
  30. package/dist/{chunk-QZHKN3VN-BF_oGUlG.js → chunk-QZHKN3VN-Diy_Cdek.js} +1 -1
  31. package/dist/{chunk-S3R3BYOJ-CBkH6JZZ.js → chunk-S3R3BYOJ-CwDGYMVf.js} +3 -3
  32. package/dist/{chunk-TZMSLE5B-DObGL7xi.js → chunk-TZMSLE5B-DFDr5FCr.js} +2 -2
  33. package/dist/classDiagram-2ON5EDUG-BDBX9etk.js +30 -0
  34. package/dist/classDiagram-v2-WZHVMYZB-Bzj_L_BF.js +30 -0
  35. package/dist/{clike-B1zispTy.js → clike-B90WKs4D.js} +1 -1
  36. package/dist/clojure-CUC2I1hM.js +4 -0
  37. package/dist/cmake-8PcMxXnB.js +4 -0
  38. package/dist/cobol-DkkkDz5v.js +4 -0
  39. package/dist/{code-block-37QAKDTI-u5kgjqmr.js → code-block-37QAKDTI-zh5AeoJo.js} +1 -1
  40. package/dist/coffeescript-CCupxOZf.js +4 -0
  41. package/dist/commonlisp-DhUfGX6b.js +4 -0
  42. package/dist/{cose-bilkent-S5V4N54A-CO4ORQHF.js → cose-bilkent-S5V4N54A-BK1nIR2J.js} +1 -1
  43. package/dist/crystal-DSaw6rFQ.js +4 -0
  44. package/dist/css-D4QDewkG.js +4 -0
  45. package/dist/cypher-CrYVqw_F.js +4 -0
  46. package/dist/d-Cr3H3pPx.js +4 -0
  47. package/dist/{dagre-6UL2VRFP-C2C2XxsB.js → dagre-6UL2VRFP-r2rSdJYL.js} +9 -9
  48. package/dist/{data-grid-overlay-editor-BXqtz1ia.js → data-grid-overlay-editor-BVFT970w.js} +2 -2
  49. package/dist/{diagram-PSM6KHXK-DHBY-94p.js → diagram-PSM6KHXK-BpxVUe9U.js} +10 -10
  50. package/dist/{diagram-QEK2KX5R-CgMshOwn.js → diagram-QEK2KX5R-q3dHUcp6.js} +5 -5
  51. package/dist/{diagram-S2PKOQOG-F1KPva3Y.js → diagram-S2PKOQOG-MDBKrxSC.js} +5 -5
  52. package/dist/diff-ODiZJGls.js +4 -0
  53. package/dist/dist-4YNZxwMI.js +8 -0
  54. package/dist/dist-7nR3r2kG.js +5 -0
  55. package/dist/{dist-CBA36Nuy.js → dist-B2-r9y-0.js} +109 -109
  56. package/dist/dist-B2gkyT3r.js +5 -0
  57. package/dist/{dist--JwRU9u5.js → dist-B4tYJP_i.js} +2 -2
  58. package/dist/{dist-DA1J6LvO.js → dist-B5ATpkxy.js} +2 -2
  59. package/dist/dist-B8G3I6vJ.js +8 -0
  60. package/dist/{dist-DKnxaCRl.js → dist-B94MxrQS.js} +2 -2
  61. package/dist/dist-BJ96Ykfp.js +8 -0
  62. package/dist/dist-BKLIWGw4.js +5 -0
  63. package/dist/{dist-l0KayR2-.js → dist-BLwfpZD-.js} +2 -2
  64. package/dist/{dist-C_Kw_Kc0.js → dist-BYmtF1W6.js} +2 -2
  65. package/dist/{dist-Cpj5BHNP.js → dist-BbBnU4tG.js} +1 -1
  66. package/dist/dist-Bf3ou00A.js +6 -0
  67. package/dist/{dist-CITQGRtG.js → dist-BfactX3G.js} +4 -4
  68. package/dist/{dist-CsN7lsea.js → dist-BoAHOW2l.js} +2 -2
  69. package/dist/{dist-BcXuIt-h.js → dist-Bsv_ARko.js} +4 -4
  70. package/dist/dist-BvkKXuPm.js +5 -0
  71. package/dist/{dist-DsqQCNKw.js → dist-C2-m5aEk.js} +119 -119
  72. package/dist/dist-C6NJ3n6r.js +5 -0
  73. package/dist/{dist-DIVeCGlI.js → dist-CC9VUnXd.js} +1 -1
  74. package/dist/{dist-BKGWAN8J.js → dist-CE43BRmt.js} +1 -1
  75. package/dist/{dist-COp5dkis.js → dist-CJrHMxlI.js} +31 -31
  76. package/dist/{dist-BbQ-5HAA.js → dist-CPTE45iS.js} +1 -1
  77. package/dist/{dist-9trj4p6n.js → dist-CcOGT46m.js} +27 -27
  78. package/dist/dist-CecLPYY5.js +5 -0
  79. package/dist/{dist-BSMZYwqW.js → dist-Cgf353Ki.js} +1 -1
  80. package/dist/dist-Ch0SwRzK.js +5 -0
  81. package/dist/{dist-C6p7UKkB.js → dist-CkEUrAus.js} +2 -2
  82. package/dist/{dist-MFzhAmKV.js → dist-CmZYrgd_.js} +1 -1
  83. package/dist/{dist-b7Sc3Tj8.js → dist-Crk9ejOy.js} +4 -4
  84. package/dist/dist-D6eWHiFh.js +6 -0
  85. package/dist/dist-DCQ710Bv.js +5 -0
  86. package/dist/{dist-r6N_0WG-.js → dist-DOil6y-3.js} +4 -4
  87. package/dist/{dist-CPd_adhw.js → dist-Dc1SFk5I.js} +2 -2
  88. package/dist/dist-Dit9tk8a.js +1242 -0
  89. package/dist/{dist-B7NoEgR4.js → dist-DqJdzAYM.js} +2 -2
  90. package/dist/dist-P_pkS5f-.js +8 -0
  91. package/dist/{dist--Em7gfgX.js → dist-T4g7Sr6e.js} +3 -3
  92. package/dist/{dist-BhBtK2sL.js → dist-glA_fIK_.js} +2 -2
  93. package/dist/{dist-9J8_3DZN.js → dist-iiugPhCC.js} +1 -1
  94. package/dist/{dist-D7jHtwN8.js → dist-r8ecBV-v.js} +135 -65
  95. package/dist/{dist-BlRm4v0e.js → dist-yVJ4xE5n.js} +5 -5
  96. package/dist/{dockerfile-BBT_Ira6.js → dockerfile-D1Q_4uCN.js} +1 -1
  97. package/dist/dtd-C-t2Rk7F.js +4 -0
  98. package/dist/dylan-B4ctBLGp.js +4 -0
  99. package/dist/ecl-DqWfymni.js +4 -0
  100. package/dist/eiffel-DjBKKAr7.js +4 -0
  101. package/dist/elm--fxeC0FV.js +4 -0
  102. package/dist/{erDiagram-Q2GNP2WA-18gGng8V.js → erDiagram-Q2GNP2WA-CX1XdqVD.js} +13 -13
  103. package/dist/erlang-CaKXCX6H.js +4 -0
  104. package/dist/{esm-CgRNPmz8.js → esm-BAS2d2Ad.js} +1503 -1536
  105. package/dist/{factor-DdqWbSyy.js → factor--4HHM8Rw.js} +1 -1
  106. package/dist/factor-DlLO5EFS.js +4 -0
  107. package/dist/{flowDiagram-NV44I4VS-iHFiHYe0.js → flowDiagram-NV44I4VS-BCj-ONTw.js} +15 -15
  108. package/dist/forth-rOO6LVj_.js +4 -0
  109. package/dist/fortran-CUg15VGR.js +4 -0
  110. package/dist/{ganttDiagram-JELNMOA3-D7GixxiF.js → ganttDiagram-JELNMOA3-D1l5ewiQ.js} +8 -8
  111. package/dist/gas-BMRJspiW.js +4 -0
  112. package/dist/gherkin-DRxzijZU.js +4 -0
  113. package/dist/{gitGraphDiagram-NY62KEGX-CJFHytRK.js → gitGraphDiagram-NY62KEGX-KdZh0iiW.js} +5 -5
  114. package/dist/{glide-data-editor-BYwb17Bf.js → glide-data-editor-2RvcPqmc.js} +75 -76
  115. package/dist/groovy-BmrQ8pUP.js +4 -0
  116. package/dist/haskell-BuaYfKOz.js +4 -0
  117. package/dist/haxe-DcH9eA0a.js +5 -0
  118. package/dist/idl-DGlcm4Ls.js +4 -0
  119. package/dist/{infoDiagram-WHAUD3N6-B5Lkh3A9.js → infoDiagram-WHAUD3N6-PSH7lQ0D.js} +3 -3
  120. package/dist/javascript-CeTk7rzr.js +4 -0
  121. package/dist/{journeyDiagram-XKPGCS4Q-CV_9R9iP.js → journeyDiagram-XKPGCS4Q-BrTAxQ1J.js} +5 -5
  122. package/dist/julia-BoP_q1gm.js +4 -0
  123. package/dist/{kanban-definition-3W4ZIXB7-Dp21D5Ym.js → kanban-definition-3W4ZIXB7-BoYCDp_9.js} +10 -10
  124. package/dist/{katex-CX2BKujk.js → katex-DaGuLbVh.js} +1 -1
  125. package/dist/{line-LK_5q2B9.js → line-Bc27KE1D.js} +3 -3
  126. package/dist/{linear-vWf1Qj0e.js → linear-Bnc6E9kA.js} +4 -4
  127. package/dist/livescript-B7IMN-ba.js +4 -0
  128. package/dist/{loader-B0KEFFi-.js → loader-C0-eIoas.js} +1 -1
  129. package/dist/lua-q1InavKb.js +4 -0
  130. package/dist/main.js +207 -204
  131. package/dist/mathematica-DvR8-_EI.js +4 -0
  132. package/dist/mbox-7h5MNBS_.js +4 -0
  133. package/dist/{mermaid-4DMBBIKO-BhDCqnO1.js → mermaid-4DMBBIKO-BmJdHPwx.js} +1 -1
  134. package/dist/{mermaid-B__BZSXU.js → mermaid-C2cSe5YL.js} +40 -40
  135. package/dist/{mhchem-w1tkUnWr.js → mhchem-B_tiMbKF.js} +1 -1
  136. package/dist/{mindmap-definition-VGOIOE7T-B_5mfdYp.js → mindmap-definition-VGOIOE7T-CmRjsKEt.js} +12 -12
  137. package/dist/mirc-D-XM8A5c.js +4 -0
  138. package/dist/mllike-BQGkkbmf.js +6 -0
  139. package/dist/modelica-D_yRj_WU.js +4 -0
  140. package/dist/mscgen-B-rltAjp.js +6 -0
  141. package/dist/mumps-2kh8TU2b.js +4 -0
  142. package/dist/{nsis-CunMjZ_n.js → nsis-B6EN9LWI.js} +1 -1
  143. package/dist/nsis-CtusEqwb.js +4 -0
  144. package/dist/ntriples-BdAXw6zV.js +4 -0
  145. package/dist/{number-overlay-editor-D-4WQAGX.js → number-overlay-editor-DKVJgXpp.js} +1 -1
  146. package/dist/octave-CsNFmVp5.js +4 -0
  147. package/dist/{ordinal-IlASfRja.js → ordinal-DLLbwLkP.js} +1 -1
  148. package/dist/oz-odIXCrKd.js +4 -0
  149. package/dist/pascal-B9Mfk3Fo.js +4 -0
  150. package/dist/perl-C48inLcz.js +4 -0
  151. package/dist/{pieDiagram-ADFJNKIX-B-DGEopK.js → pieDiagram-ADFJNKIX-CtxQlnsU.js} +10 -10
  152. package/dist/pig-uwRtAssU.js +4 -0
  153. package/dist/powershell-CXqlca-i.js +4 -0
  154. package/dist/{precisionRound-CGLoV26P.js → precisionRound-Duzbr5ur.js} +1 -1
  155. package/dist/properties-D6Zu1rpK.js +4 -0
  156. package/dist/protobuf-BlNNWZaR.js +4 -0
  157. package/dist/pug-DytcK7bv.js +4 -0
  158. package/dist/{pug-Dr-sA_9V.js → pug-xrm7jQ2R.js} +1 -1
  159. package/dist/puppet-lJ8Ok3iY.js +4 -0
  160. package/dist/python-cMaF7kUp.js +4 -0
  161. package/dist/q-Dgt2HYQh.js +4 -0
  162. package/dist/{quadrantDiagram-AYHSOK5B-M_yRSIZn.js → quadrantDiagram-AYHSOK5B-DllnB2Hl.js} +4 -4
  163. package/dist/r-Bm4S4awf.js +4 -0
  164. package/dist/react-vega-1ub36dPZ.js +9 -0
  165. package/dist/{react-vega-DLFvGrpJ.js → react-vega-CCNu2JE0.js} +18 -18
  166. package/dist/{requirementDiagram-UZGBJVZJ-9Wt82hOZ.js → requirementDiagram-UZGBJVZJ-D36MI1k0.js} +12 -12
  167. package/dist/rpm-_8LbzMVc.js +5 -0
  168. package/dist/ruby-Cr8IJ5VZ.js +4 -0
  169. package/dist/{sankeyDiagram-TZEHDZUN-x_aTXZeN.js → sankeyDiagram-TZEHDZUN-D1mygNPC.js} +4 -4
  170. package/dist/sas-CFcSfo2_.js +4 -0
  171. package/dist/scheme-N4XRoKgc.js +4 -0
  172. package/dist/{sequenceDiagram-WL72ISMW-CXXmJqiQ.js → sequenceDiagram-WL72ISMW-CWdn91Rf.js} +6 -6
  173. package/dist/shell-B4L7f_ds.js +4 -0
  174. package/dist/sieve-UI6J3Gm0.js +4 -0
  175. package/dist/smalltalk-BuaPZAZU.js +4 -0
  176. package/dist/sparql-1rKrq463.js +4 -0
  177. package/dist/{src-szye8OCw.js → src-jICM_d2B.js} +1 -1
  178. package/dist/{stateDiagram-FKZM4ZOC-CiSKS_Mx.js → stateDiagram-FKZM4ZOC-CPxroWXd.js} +15 -15
  179. package/dist/{stateDiagram-v2-4FDKWEC3-A43Itnjp.js → stateDiagram-v2-4FDKWEC3-BpM9Q54b.js} +13 -13
  180. package/dist/{step-1PmBKr2y.js → step-BqVgkWtk.js} +1 -1
  181. package/dist/stylus-DvSovJEP.js +4 -0
  182. package/dist/swift-D-_E7Yyb.js +4 -0
  183. package/dist/tcl-Di5sAVHN.js +4 -0
  184. package/dist/textile-Benwt66z.js +4 -0
  185. package/dist/{time-DC4qQGmA.js → time-CrYsYnQU.js} +4 -4
  186. package/dist/{timeline-definition-IT6M3QCI-DR26eWb4.js → timeline-definition-IT6M3QCI-CVnRHx_t.js} +3 -3
  187. package/dist/toml-CeOvPOkY.js +4 -0
  188. package/dist/troff-DJN9hfgu.js +4 -0
  189. package/dist/ttcn-DQW2Psjf.js +4 -0
  190. package/dist/ttcn-cfg-zFG_MNpg.js +4 -0
  191. package/dist/turtle-DHRyNlSc.js +4 -0
  192. package/dist/{types-Bb-6p8hv.js → types-Ckva8JJq.js} +203 -156
  193. package/dist/{useDeepCompareMemoize-BhZZsis0.js → useDeepCompareMemoize-ChviuF5n.js} +1 -1
  194. package/dist/vb-CXWH9DD-.js +4 -0
  195. package/dist/vbscript-qr8qVck5.js +4 -0
  196. package/dist/{vega-component-DCxUyPnb.js → vega-component-CnG0vAjf.js} +7 -7
  197. package/dist/{vega-loader.browser-BJ1uJidF.js → vega-loader.browser-DqHiiBeQ.js} +3 -3
  198. package/dist/velocity-C_9pUJRx.js +4 -0
  199. package/dist/verilog-DxBstgBa.js +4 -0
  200. package/dist/vhdl-odUxAbE6.js +4 -0
  201. package/dist/webidl-Dfn5Rku4.js +4 -0
  202. package/dist/xquery-CrJs6SXr.js +4 -0
  203. package/dist/{xychartDiagram-PRI3JC2R-BcVxCRox.js → xychartDiagram-PRI3JC2R-BltwMWKC.js} +11 -11
  204. package/dist/yacas-B-uDDLZe.js +4 -0
  205. package/dist/z80-51gxgAXE.js +4 -0
  206. package/package.json +10 -11
  207. package/src/components/data-table/__tests__/columns.test.tsx +47 -0
  208. package/src/components/data-table/column-header.tsx +3 -0
  209. package/src/components/data-table/columns.tsx +17 -2
  210. package/src/components/editor/chrome/wrapper/app-chrome.tsx +2 -0
  211. package/src/core/codemirror/misc/__tests__/paste.test.ts +18 -0
  212. package/src/core/codemirror/misc/paste.ts +14 -10
  213. package/src/plugins/impl/chat/ChatPlugin.tsx +2 -0
  214. package/src/plugins/impl/chat/chat-ui.tsx +10 -1
  215. package/src/plugins/impl/plotly/Plot.tsx +171 -0
  216. package/src/plugins/impl/plotly/PlotlyPlugin.tsx +5 -10
  217. package/src/plugins/impl/plotly/__tests__/parse-from-template.test.ts +1 -0
  218. package/src/plugins/impl/plotly/__tests__/usePlotlyLayout.test.ts +2 -1
  219. package/src/plugins/impl/plotly/parse-from-template.ts +1 -0
  220. package/src/plugins/impl/plotly/usePlotlyLayout.ts +2 -1
  221. package/src/theme/ThemeProvider.tsx +2 -0
  222. package/dist/apl-BuwKwesW.js +0 -4
  223. package/dist/asciiarmor-zAEd_wtn.js +0 -4
  224. package/dist/asn1-DWEA66J4.js +0 -4
  225. package/dist/brainfuck-mIPR6Ong.js +0 -4
  226. package/dist/classDiagram-2ON5EDUG-B9pkKjjc.js +0 -30
  227. package/dist/classDiagram-v2-WZHVMYZB-CRhhA0tV.js +0 -30
  228. package/dist/clojure-DkhhNHNQ.js +0 -4
  229. package/dist/cmake-1obPvqtc.js +0 -4
  230. package/dist/cobol-oWNTiXPE.js +0 -4
  231. package/dist/coffeescript-LtYUvf6r.js +0 -4
  232. package/dist/commonlisp-C_06qBYF.js +0 -4
  233. package/dist/crystal-CDJkbx14.js +0 -4
  234. package/dist/css-Bi_Nk0uN.js +0 -4
  235. package/dist/cypher-TrG0NvZ0.js +0 -4
  236. package/dist/d-CFKOrZsi.js +0 -4
  237. package/dist/diff-CfnSF48q.js +0 -4
  238. package/dist/dist-2OSzSqy2.js +0 -5
  239. package/dist/dist-B1H2TQGB.js +0 -8
  240. package/dist/dist-BNvasp6N.js +0 -5
  241. package/dist/dist-CFi_P6cs.js +0 -5
  242. package/dist/dist-CG4LWTPv.js +0 -8
  243. package/dist/dist-CHWVQZ6Z.js +0 -6
  244. package/dist/dist-C_8-swED.js +0 -5
  245. package/dist/dist-DIhtur5b.js +0 -5
  246. package/dist/dist-DoQ7RS4e.js +0 -5
  247. package/dist/dist-DsMd-F9h.js +0 -5
  248. package/dist/dist-DurmUshd.js +0 -8
  249. package/dist/dist-PZgrh2z6.js +0 -6
  250. package/dist/dist-g1p2PEVs.js +0 -1242
  251. package/dist/dist-wudNDAiO.js +0 -5
  252. package/dist/dist-zVskjQcA.js +0 -8
  253. package/dist/dtd-Ctw8_JkU.js +0 -4
  254. package/dist/dylan-f7rMBKDP.js +0 -4
  255. package/dist/ecl-C2h3oBMY.js +0 -4
  256. package/dist/eiffel-Ce81wv20.js +0 -4
  257. package/dist/elm-BVV8QQcc.js +0 -4
  258. package/dist/erlang-DjB35ZUh.js +0 -4
  259. package/dist/factor-CIcp3U2B.js +0 -4
  260. package/dist/forth-CVgjsHhD.js +0 -4
  261. package/dist/fortran-CcTXj0d_.js +0 -4
  262. package/dist/gas-JWpamkLf.js +0 -4
  263. package/dist/gherkin-BveSCSJV.js +0 -4
  264. package/dist/groovy-Np3AZt00.js +0 -4
  265. package/dist/haskell-CVfmFALm.js +0 -4
  266. package/dist/haxe-C10xkMLg.js +0 -5
  267. package/dist/idl-CKBSGnKC.js +0 -4
  268. package/dist/javascript-Cur-15Bn.js +0 -4
  269. package/dist/julia-BZZH2Gnx.js +0 -4
  270. package/dist/livescript-D_rTTm_U.js +0 -4
  271. package/dist/lua-Mf_Of7eV.js +0 -4
  272. package/dist/mathematica-DCYjugDb.js +0 -4
  273. package/dist/mbox-KBWrT8JD.js +0 -4
  274. package/dist/mirc-JwEQJ8Fb.js +0 -4
  275. package/dist/mllike-C7TxLvh6.js +0 -6
  276. package/dist/modelica-uvNgvUyw.js +0 -4
  277. package/dist/mscgen-CGnokp5x.js +0 -6
  278. package/dist/mumps-Dl9QdOZz.js +0 -4
  279. package/dist/nsis-BbDhbgPN.js +0 -4
  280. package/dist/ntriples-ChL1mlp7.js +0 -4
  281. package/dist/octave-B9ZGG6zv.js +0 -4
  282. package/dist/oz-XHEu31wr.js +0 -4
  283. package/dist/pascal-BxtYw-iH.js +0 -4
  284. package/dist/perl-Br5BgHPb.js +0 -4
  285. package/dist/pig-BByO2hBz.js +0 -4
  286. package/dist/powershell-Cd4Zaef3.js +0 -4
  287. package/dist/prop-types-C9QZf2SY.js +0 -51
  288. package/dist/properties-B-BOCIOl.js +0 -4
  289. package/dist/protobuf-CaLimlho.js +0 -4
  290. package/dist/pug-bonARSG6.js +0 -4
  291. package/dist/puppet-BSlT-3sc.js +0 -4
  292. package/dist/python-BIJhGYYP.js +0 -4
  293. package/dist/q-D9TX8A0B.js +0 -4
  294. package/dist/r-BXelX7Rl.js +0 -4
  295. package/dist/react-vega-3WcLHYC7.js +0 -9
  296. package/dist/rpm-BxAh9B1A.js +0 -5
  297. package/dist/ruby-BCZLQyhc.js +0 -4
  298. package/dist/sas-Bo7lsyNX.js +0 -4
  299. package/dist/scheme-Brhptkt-.js +0 -4
  300. package/dist/shell-fWWb8_qx.js +0 -4
  301. package/dist/sieve-Ba8_hMLn.js +0 -4
  302. package/dist/smalltalk-7sHxwMDT.js +0 -4
  303. package/dist/sparql-BBFrPJ7z.js +0 -4
  304. package/dist/stylus-CIB0KT46.js +0 -4
  305. package/dist/swift-CZinekXz.js +0 -4
  306. package/dist/tcl-DCHZJVq_.js +0 -4
  307. package/dist/textile-ThTMxgkN.js +0 -4
  308. package/dist/toml-DK17wlJ7.js +0 -4
  309. package/dist/troff-CuUAOgMy.js +0 -4
  310. package/dist/ttcn-DS2tj6rW.js +0 -4
  311. package/dist/ttcn-cfg-CdZGarnc.js +0 -4
  312. package/dist/turtle-Bkz-FLZ7.js +0 -4
  313. package/dist/vb-ITdOmxvR.js +0 -4
  314. package/dist/vbscript-B7oeGyfL.js +0 -4
  315. package/dist/velocity-D__EkuSd.js +0 -4
  316. package/dist/verilog-CPH50gr9.js +0 -4
  317. package/dist/vhdl-CQAwKCk_.js +0 -4
  318. package/dist/webidl-BnEptfVX.js +0 -4
  319. package/dist/xquery-D7eTv-CR.js +0 -4
  320. package/dist/yacas-0x1rX89s.js +0 -4
  321. package/dist/z80-B25SJVDf.js +0 -4
  322. /package/dist/{ImageComparisonComponent-DkEXPki_.js → ImageComparisonComponent-CRbA-1eg.js} +0 -0
  323. /package/dist/{apl-D9gTcP3Q.js → apl-Oc3bL26_.js} +0 -0
  324. /package/dist/{array-D7wW5QoO.js → array-CEIRxyh3.js} +0 -0
  325. /package/dist/{asciiarmor-mLyg-Z5h.js → asciiarmor-DTbPh2VI.js} +0 -0
  326. /package/dist/{asn1-AE7eHomk.js → asn1-CGhwu1Ri.js} +0 -0
  327. /package/dist/{brainfuck-Bdd6NcL6.js → brainfuck-CA0L8lRq.js} +0 -0
  328. /package/dist/{click-outside-container-DNfggvIW.js → click-outside-container-C_k38vlR.js} +0 -0
  329. /package/dist/{clike-D_s3fKg5.js → clike-CEtUBPHD.js} +0 -0
  330. /package/dist/{clojure-zTYBCd80.js → clojure-BszjvdGo.js} +0 -0
  331. /package/dist/{cmake-BnJV90fC.js → cmake-B2Gvps8b.js} +0 -0
  332. /package/dist/{cobol-CH0OZO8A.js → cobol-DuMch8nn.js} +0 -0
  333. /package/dist/{coffeescript-CLhc1U6Q.js → coffeescript-L9aKXVsJ.js} +0 -0
  334. /package/dist/{colors-6DRQ0kEF.js → colors-DR_aHfmQ.js} +0 -0
  335. /package/dist/{commonlisp-8K2-IkUD.js → commonlisp-CrtdssxB.js} +0 -0
  336. /package/dist/{crystal-8to4H-ep.js → crystal-vvNY0LpY.js} +0 -0
  337. /package/dist/{css-BVo-JOy5.js → css-B1GdzqT1.js} +0 -0
  338. /package/dist/{cypher-BTFaDDd_.js → cypher-BtZvV7bW.js} +0 -0
  339. /package/dist/{d-c9bddW2W.js → d-B0UN3V-Z.js} +0 -0
  340. /package/dist/{defaultLocale-Bxoo2-30.js → defaultLocale-B_A76Zpk.js} +0 -0
  341. /package/dist/{defaultLocale-qS7DaAmi.js → defaultLocale-DjFHq3Xk.js} +0 -0
  342. /package/dist/{diff-PA28xMKg.js → diff-DOpgjj1W.js} +0 -0
  343. /package/dist/{dist-BBYTEAvO.js → dist-DF_77D2B.js} +0 -0
  344. /package/dist/{dtd-DRlC7Bx8.js → dtd-Ctnjxrle.js} +0 -0
  345. /package/dist/{dylan-d5ufc25E.js → dylan-DFXkoaZy.js} +0 -0
  346. /package/dist/{ecl-Ci3afVKc.js → ecl-C1NExZip.js} +0 -0
  347. /package/dist/{eiffel-G6DmeEi3.js → eiffel-uXVGgleg.js} +0 -0
  348. /package/dist/{elm-ByYWHu8b.js → elm-CBOFnnib.js} +0 -0
  349. /package/dist/{erlang-C7_LcVDw.js → erlang-DMnrT8XK.js} +0 -0
  350. /package/dist/{esm-CAd2HmbR.js → esm-0_ieXYNc.js} +0 -0
  351. /package/dist/{forth-BgUerAyz.js → forth-DDpxS4nw.js} +0 -0
  352. /package/dist/{fortran-BCXxm4xF.js → fortran-B6uYqQMz.js} +0 -0
  353. /package/dist/{gas-CKTQRKLl.js → gas-BKnWzuFz.js} +0 -0
  354. /package/dist/{gherkin-ByVP9cY_.js → gherkin-pBt0wT4X.js} +0 -0
  355. /package/dist/{groovy-BPbrw0GZ.js → groovy-DKsn4ppB.js} +0 -0
  356. /package/dist/{haskell-B8fq1DW4.js → haskell-BJVBJQcy.js} +0 -0
  357. /package/dist/{haxe-B7SHQmJo.js → haxe-rLN5UZU5.js} +0 -0
  358. /package/dist/{idl-CeJBDjsl.js → idl-B4mwMAo-.js} +0 -0
  359. /package/dist/{init-BfRhston.js → init-TaqZJsBY.js} +0 -0
  360. /package/dist/{javascript-dCv9_Kn8.js → javascript-Hf2NLNC0.js} +0 -0
  361. /package/dist/{julia-CD5lO88_.js → julia-GGpx21YN.js} +0 -0
  362. /package/dist/{katex-Db0k5oV_.js → katex-Ba7xZPrx.js} +0 -0
  363. /package/dist/{livescript-Cc8RvFBv.js → livescript-CSvXMspZ.js} +0 -0
  364. /package/dist/{lua-4nedfnvd.js → lua-CVMR5LMW.js} +0 -0
  365. /package/dist/{math-BbMyrONz.js → math-CTnb-N1W.js} +0 -0
  366. /package/dist/{mathematica-BIufdZr2.js → mathematica-JENNt-p4.js} +0 -0
  367. /package/dist/{mbox-DQkYSHKe.js → mbox-mzifoc8E.js} +0 -0
  368. /package/dist/{mirc-CI-RWqUR.js → mirc-BXoiItvN.js} +0 -0
  369. /package/dist/{mllike-DQzbf1xo.js → mllike-H-KR9OuH.js} +0 -0
  370. /package/dist/{modelica-BnF_cDWj.js → modelica-B6Hm3mMl.js} +0 -0
  371. /package/dist/{mscgen-MirFrDhW.js → mscgen-D8TF_Hei.js} +0 -0
  372. /package/dist/{mumps-eNRTuWOD.js → mumps-CD-kNPt4.js} +0 -0
  373. /package/dist/{ntriples-BLneip4i.js → ntriples-DgnpxU40.js} +0 -0
  374. /package/dist/{octave-C0eG-pKq.js → octave-CkobqyVm.js} +0 -0
  375. /package/dist/{oz-BPMLow2T.js → oz-ChDLd9tS.js} +0 -0
  376. /package/dist/{pascal-5eb9v5Dl.js → pascal-CvlkwK7E.js} +0 -0
  377. /package/dist/{path-C_x2ySFi.js → path-7gr7eZmp.js} +0 -0
  378. /package/dist/{perl-DOu6rCkF.js → perl-BNEFTNbM.js} +0 -0
  379. /package/dist/{pig-CRW0kne3.js → pig-Cd1DMS7P.js} +0 -0
  380. /package/dist/{powershell-CWgJhiiJ.js → powershell-CPxA0zpc.js} +0 -0
  381. /package/dist/{properties-CHxpmfXW.js → properties-BaFBm-Xa.js} +0 -0
  382. /package/dist/{protobuf-DGUXb_-T.js → protobuf-BQV_-X0H.js} +0 -0
  383. /package/dist/{puppet-C7uSiW6_.js → puppet-LXLST0mx.js} +0 -0
  384. /package/dist/{python-DAbhVcUr.js → python-DLjLzX4k.js} +0 -0
  385. /package/dist/{q-DKjWHias.js → q-DswTX1Y9.js} +0 -0
  386. /package/dist/{r-KD2KhyeL.js → r-CO7NpMwE.js} +0 -0
  387. /package/dist/{range-BYuZFTbA.js → range-DwpxnYuB.js} +0 -0
  388. /package/dist/{rpm-GFtnpQ6M.js → rpm-BlmEDT6r.js} +0 -0
  389. /package/dist/{ruby-CBAewzLY.js → ruby-BTPKgeZZ.js} +0 -0
  390. /package/dist/{sas-CCi_AaZi.js → sas-DTDTiNO8.js} +0 -0
  391. /package/dist/{scheme-CGGGD6kR.js → scheme-UzAAg4GJ.js} +0 -0
  392. /package/dist/{shell-b7vZ8ucI.js → shell-DQ0hQCsB.js} +0 -0
  393. /package/dist/{sieve-ClXOUV85.js → sieve-BVyYIx9u.js} +0 -0
  394. /package/dist/{simple-mode-Uad4lEG7.js → simple-mode-Dryu-fC9.js} +0 -0
  395. /package/dist/{slides-component-Dp-y50K9.js → slides-component-DfwLApNr.js} +0 -0
  396. /package/dist/{smalltalk-_PFt9_gp.js → smalltalk-DAdMAHTu.js} +0 -0
  397. /package/dist/{sparql-BCF6qcHt.js → sparql-Bi7quYgw.js} +0 -0
  398. /package/dist/{stylus-DMFZWz-G.js → stylus-jhpzcQ6Y.js} +0 -0
  399. /package/dist/{swift-De2YpSxT.js → swift-BrO8qThZ.js} +0 -0
  400. /package/dist/{tcl-jV8Xs_1k.js → tcl-s5QI5gv3.js} +0 -0
  401. /package/dist/{textile-D_zo778l.js → textile-ClhvJrxM.js} +0 -0
  402. /package/dist/{timer-pEiW44EO.js → timer-DV8t68ti.js} +0 -0
  403. /package/dist/{toml-_M0gsKn5.js → toml-TFa3EJQE.js} +0 -0
  404. /package/dist/{treemap-BzS5cW_6.js → treemap-CQJ0bIDy.js} +0 -0
  405. /package/dist/{troff-B06gyD33.js → troff-SqLg0heF.js} +0 -0
  406. /package/dist/{ttcn-DoQoQNUM.js → ttcn-Cfrap7HJ.js} +0 -0
  407. /package/dist/{ttcn-cfg-l_6PksD2.js → ttcn-cfg-Dopc-iwE.js} +0 -0
  408. /package/dist/{turtle-zEnD4bpn.js → turtle-Dt52DvVH.js} +0 -0
  409. /package/dist/{useAsyncData-Dyq3DyOF.js → useAsyncData-dr8GazGv.js} +0 -0
  410. /package/dist/{vb-fUsnAuzb.js → vb-D1pAvfDe.js} +0 -0
  411. /package/dist/{vbscript-CVlD7uZQ.js → vbscript-DZ7RBxn5.js} +0 -0
  412. /package/dist/{velocity-CHkEIdMC.js → velocity-Csau7eZy.js} +0 -0
  413. /package/dist/{verilog-B3ctZTB4.js → verilog-gXlZACs5.js} +0 -0
  414. /package/dist/{vhdl-rXdBgR5O.js → vhdl-NaUWbI1B.js} +0 -0
  415. /package/dist/{webidl-Cv9aQfcc.js → webidl-BJmPjW01.js} +0 -0
  416. /package/dist/{xquery-Du0w47aa.js → xquery-CJIPsC0g.js} +0 -0
  417. /package/dist/{yacas-Eq4p_g3L.js → yacas-8f2Vjiiz.js} +0 -0
  418. /package/dist/{z80-Dz4HTTRf.js → z80-s5Xk2hCP.js} +0 -0
@@ -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
- };