@marimo-team/islands 0.23.7-dev8 → 0.23.7-dev80

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 (554) hide show
  1. package/dist/{ConnectedDataExplorerComponent-PmilQqXR.js → ConnectedDataExplorerComponent-2lBNiUv6.js} +14 -14
  2. package/dist/{ErrorBoundary-Da4UeYxT.js → ErrorBoundary-D3wrPNma.js} +1 -1
  3. package/dist/{any-language-editor-BVR0l12r.js → any-language-editor-VWs_7v27.js} +15 -15
  4. package/dist/apl-Bdc61P1y.js +4 -0
  5. package/dist/{arc-CHF8PiiF.js → arc-DfkSnvZm.js} +2 -2
  6. package/dist/{architecture-7HQA4BMR-D0JB_3hE.js → architecture-7HQA4BMR-CS9jOrqM.js} +1 -1
  7. package/dist/{architectureDiagram-VXUJARFQ-BXQEUDtK.js → architectureDiagram-VXUJARFQ-CXVJxFhH.js} +16 -16
  8. package/dist/asciiarmor-DVRHDGzT.js +4 -0
  9. package/dist/asn1-BmuKfkfu.js +4 -0
  10. package/dist/assets/__vite-browser-external-CAdMKBac.js +1 -0
  11. package/dist/assets/worker-CpBbwbQo.js +73 -0
  12. package/dist/{blockDiagram-VD42YOAC-DhJe-Y9i.js → blockDiagram-VD42YOAC-DGDaxR8I.js} +11 -11
  13. package/dist/brainfuck-DPrRpyTV.js +4 -0
  14. package/dist/{button-CA5pI2YF.js → button-Dj4BTre0.js} +5 -0
  15. package/dist/{c4Diagram-YG6GDRKO-9dSfzOFR.js → c4Diagram-YG6GDRKO-C2hc6ne8.js} +5 -5
  16. package/dist/{capabilities-6laDasij.js → capabilities-C9rrYCzf.js} +1 -1
  17. package/dist/{channel-MqYIiKgS.js → channel-BBoIVUrJ.js} +1 -1
  18. package/dist/{chat-ui-D8SqlFay.js → chat-ui-D3XBept8.js} +626 -234
  19. package/dist/{check-CFM2mVDr.js → check-BcUIXnUT.js} +1 -1
  20. package/dist/{chunk-4BX2VUAB-BwfrWBqN.js → chunk-4BX2VUAB-CzXltWHN.js} +1 -1
  21. package/dist/{chunk-55IACEB6-D8THf2mi.js → chunk-55IACEB6-B-1mjMMC.js} +1 -1
  22. package/dist/{chunk-5FQGJX7Z-CO1e63h_.js → chunk-5FQGJX7Z-BOg95xG5.js} +2 -2
  23. package/dist/{chunk-ABZYJK2D-BrBb_0yY.js → chunk-ABZYJK2D-D0cLy8Bb.js} +2 -2
  24. package/dist/{chunk-ATLVNIR6-D-0XqNah.js → chunk-ATLVNIR6-BXsEjlHF.js} +2 -2
  25. package/dist/{chunk-B4BG7PRW-8iRKvugR.js → chunk-B4BG7PRW-Q1usn6T3.js} +7 -7
  26. package/dist/{chunk-CVBHYZKI-B6xhgaBd.js → chunk-CVBHYZKI-B_c5YBcW.js} +1 -1
  27. package/dist/{chunk-DI55MBZ5-C0_2D4m4.js → chunk-DI55MBZ5-D1qLYNrb.js} +6 -6
  28. package/dist/{chunk-EXTU4WIE-Jiw9ca1u.js → chunk-EXTU4WIE-BKNXdLmD.js} +2 -2
  29. package/dist/{chunk-FMBD7UC4-CHdus51S.js → chunk-FMBD7UC4-Ie8M9q0W.js} +1 -1
  30. package/dist/{chunk-HN2XXSSU-2Vfbq-kU.js → chunk-HN2XXSSU-E3n-Ys7Z.js} +1 -1
  31. package/dist/{chunk-JA3XYJ7Z-6wbaigKe.js → chunk-JA3XYJ7Z-D6c6cOBG.js} +3 -3
  32. package/dist/{chunk-JZLCHNYA-_rfptlUP.js → chunk-JZLCHNYA-BvsPHJmL.js} +6 -6
  33. package/dist/{chunk-MI3HLSF2-Do0-KRc0.js → chunk-MI3HLSF2-CUYEasXO.js} +1 -1
  34. package/dist/{chunk-N4CR4FBY-DIZG9dVD.js → chunk-N4CR4FBY-8ycT-O9a.js} +7 -7
  35. package/dist/{chunk-QN33PNHL-Cc64y40m.js → chunk-QN33PNHL-Bb-eUBW3.js} +2 -2
  36. package/dist/{chunk-QXUST7PY-BDG0-0Or.js → chunk-QXUST7PY-DV8yRwBd.js} +10 -10
  37. package/dist/{chunk-QZHKN3VN-B_Mdb8GC.js → chunk-QZHKN3VN-DRjXVwuJ.js} +1 -1
  38. package/dist/{chunk-S3R3BYOJ-DphMP0FA.js → chunk-S3R3BYOJ-mQeCz5CE.js} +4 -4
  39. package/dist/{chunk-TZMSLE5B-C9LUoYkc.js → chunk-TZMSLE5B-BqW10dHe.js} +3 -3
  40. package/dist/classDiagram-2ON5EDUG--Yh__LHb.js +30 -0
  41. package/dist/classDiagram-v2-WZHVMYZB-BC7X7Xtc.js +30 -0
  42. package/dist/{clike-sBZrGeF8.js → clike-DTxNUn7l.js} +1 -1
  43. package/dist/clojure-DEttQW5T.js +4 -0
  44. package/dist/cmake-jNlx_DaM.js +4 -0
  45. package/dist/cobol-BvvIm5MJ.js +4 -0
  46. package/dist/{code-block-37QAKDTI-0JNwiPGv.js → code-block-37QAKDTI-BsGy1AOJ.js} +1 -1
  47. package/dist/{code-visibility-i-wZHH96.js → code-visibility-BTN1sEU2.js} +11481 -1993
  48. package/dist/coffeescript-DTpBMyFU.js +4 -0
  49. package/dist/commonlisp-BmmUG8jb.js +4 -0
  50. package/dist/{copy-TGGAUEWp.js → copy-DLf4aN7I.js} +2 -2
  51. package/dist/{cose-bilkent-S5V4N54A-DXHZkJKX.js → cose-bilkent-S5V4N54A-kjoZoid4.js} +2 -2
  52. package/dist/crystal-BxyqmEWC.js +4 -0
  53. package/dist/css-BGoCtuG3.js +4 -0
  54. package/dist/cypher-BmCbdl3u.js +4 -0
  55. package/dist/d-CFrlbjZt.js +4 -0
  56. package/dist/{dagre-6UL2VRFP-tH87fkPA.js → dagre-6UL2VRFP-DRBWoQUw.js} +10 -10
  57. package/dist/{data-grid-overlay-editor-CWUN78-s.js → data-grid-overlay-editor-efe5ZagF.js} +2 -2
  58. package/dist/{diagram-PSM6KHXK-2VjPSCDn.js → diagram-PSM6KHXK-H66ATWP2.js} +18 -18
  59. package/dist/{diagram-QEK2KX5R-CiLmNyta.js → diagram-QEK2KX5R-DItl5Wns.js} +14 -14
  60. package/dist/{diagram-S2PKOQOG-Zha_1CLx.js → diagram-S2PKOQOG-CtuW_ZuL.js} +14 -14
  61. package/dist/diff-D6XwL6P8.js +4 -0
  62. package/dist/{dist-Brkazupz.js → dist--sWVZwjW.js} +1 -1
  63. package/dist/{dist-FN0ZA_8F.js → dist-21ButRCu.js} +1 -1
  64. package/dist/{dist-BetEKbPG.js → dist-B8RaFTRF.js} +1 -1
  65. package/dist/dist-BoHGySTM.js +5 -0
  66. package/dist/dist-ByAz19Qc.js +5 -0
  67. package/dist/dist-C93EysN4.js +5 -0
  68. package/dist/{dist-BHnX0ia_.js → dist-CY-lVor6.js} +1 -1
  69. package/dist/{dist-YP-G7W0f.js → dist-CYDuv4bR.js} +1 -1
  70. package/dist/{dist-CMjD5MQb.js → dist-Cfo5EE2t.js} +1 -1
  71. package/dist/dist-CjivSDvN.js +5 -0
  72. package/dist/dist-Cqwx-MH7.js +5 -0
  73. package/dist/{dist-ESg7xyoD.js → dist-D3ZI9nhS.js} +2 -2
  74. package/dist/{dist-DkC6YEo0.js → dist-DMZNjfX4.js} +1 -1
  75. package/dist/{dist-ChC1BhqM.js → dist-DbpcoFAV.js} +1 -1
  76. package/dist/dist-FUNenbiQ.js +5 -0
  77. package/dist/{dist-BEOU2g1b.js → dist-zhSud5X3.js} +1 -1
  78. package/dist/{dockerfile-COvlVLcE.js → dockerfile-twL37N91.js} +1 -1
  79. package/dist/dtd-Bw0lRN0-.js +4 -0
  80. package/dist/dylan-B55eBHTt.js +4 -0
  81. package/dist/ecl-C8G4p0wn.js +4 -0
  82. package/dist/eiffel-BmH46VJl.js +4 -0
  83. package/dist/elm-DhzeFqkl.js +4 -0
  84. package/dist/{erDiagram-Q2GNP2WA-biHZS05w.js → erDiagram-Q2GNP2WA--19X2kU5.js} +14 -14
  85. package/dist/erlang-CY-wdlsU.js +4 -0
  86. package/dist/{error-banner-DnBPzEWg.js → error-banner-CVkfBUT3.js} +2 -2
  87. package/dist/{esm-Dd1z1auZ.js → esm-CWp0KQeK.js} +1 -1
  88. package/dist/{esm-CYEyrE3Y.js → esm-DjNnlmpf.js} +96 -96
  89. package/dist/{extends-CzJgxo2J.js → extends-vAi97cpa.js} +4 -4
  90. package/dist/{factor-C2GT7jfQ.js → factor-CajWS6mS.js} +1 -1
  91. package/dist/factor-DWkgl0xw.js +4 -0
  92. package/dist/{flowDiagram-NV44I4VS-CWWlUpBR.js → flowDiagram-NV44I4VS-DQmWlo7f.js} +16 -16
  93. package/dist/{formats-CgaK7Gmx.js → formats-Dsy9kkZu.js} +3 -3
  94. package/dist/forth-Cij_ie2t.js +4 -0
  95. package/dist/fortran-Br3X9cfm.js +4 -0
  96. package/dist/{ganttDiagram-JELNMOA3-D7B2c4Z9.js → ganttDiagram-JELNMOA3-BOGXJ8Lk.js} +7 -7
  97. package/dist/gas-DYsGcMN2.js +4 -0
  98. package/dist/gherkin-eVgXQ0fQ.js +4 -0
  99. package/dist/{gitGraph-G5XIXVHT-BdepdFa_.js → gitGraph-G5XIXVHT-DGlbae5m.js} +1 -1
  100. package/dist/{gitGraphDiagram-V2S2FVAM-CtLvNR1S.js → gitGraphDiagram-V2S2FVAM-DjzxfF0P.js} +14 -14
  101. package/dist/{glide-data-editor-CvlvtPWJ.js → glide-data-editor-DucgdjRo.js} +13 -13
  102. package/dist/groovy-_NFHIXG7.js +4 -0
  103. package/dist/haskell-D6xNG_bH.js +4 -0
  104. package/dist/haxe-sU_rzAwn.js +5 -0
  105. package/dist/{html-to-image-_jxGvsrc.js → html-to-image-CpggM7u1.js} +2798 -2539
  106. package/dist/idl-Ds_VbrUx.js +4 -0
  107. package/dist/{info-VBDWY6EO--JNA2rNu.js → info-VBDWY6EO-D2lvLLw5.js} +1 -1
  108. package/dist/{infoDiagram-HS3SLOUP-BbZyOxsP.js → infoDiagram-HS3SLOUP-ChNufFsP.js} +12 -12
  109. package/dist/{input-BAOe64zx.js → input-D4kjoQUB.js} +8 -6
  110. package/dist/javascript-CztfIl0i.js +4 -0
  111. package/dist/{journeyDiagram-XKPGCS4Q-BU2mjjzl.js → journeyDiagram-XKPGCS4Q-BO_O4Ij1.js} +6 -6
  112. package/dist/julia-DDv40QMV.js +4 -0
  113. package/dist/{kanban-definition-3W4ZIXB7-BlmczUuw.js → kanban-definition-3W4ZIXB7-CPpiiiWk.js} +11 -11
  114. package/dist/{katex-qPqrBHZ8.js → katex-9-9QRhxz.js} +1 -1
  115. package/dist/{label-BCWi-Oqu.js → label-BLqV33b1.js} +2 -2
  116. package/dist/{line-BWRi3U3S.js → line-C5s_12ee.js} +3 -3
  117. package/dist/{linear-DnHwODZa.js → linear-2NnK4cxi.js} +2 -2
  118. package/dist/livescript-BEOngLLc.js +4 -0
  119. package/dist/{loader-BvW0-YWZ.js → loader-Dr8Qem8p.js} +1 -1
  120. package/dist/lua-9-7BhQ4Y.js +4 -0
  121. package/dist/main.js +1712 -10297
  122. package/dist/mathematica-DDa0Pfxm.js +4 -0
  123. package/dist/mbox-iO03mmoE.js +4 -0
  124. package/dist/{mermaid-4DMBBIKO-CG1ECj5W.js → mermaid-4DMBBIKO-B7VQMwJx.js} +1 -1
  125. package/dist/{mermaid-CEbzCxCc.js → mermaid-DO-Daq7u.js} +46 -46
  126. package/dist/{mermaid-parser.core-CleJseNW.js → mermaid-parser.core-DreccfmS.js} +7 -7
  127. package/dist/{mhchem-BwoRNwg_.js → mhchem-yiCCuiEF.js} +1 -1
  128. package/dist/{mindmap-definition-VGOIOE7T-CcSYqYP9.js → mindmap-definition-VGOIOE7T-CC1_Vl0f.js} +13 -13
  129. package/dist/mirc-C9z5LT4X.js +4 -0
  130. package/dist/mllike-jGJbdm_C.js +6 -0
  131. package/dist/modelica-DzF7oIEL.js +4 -0
  132. package/dist/mscgen-DB-u125o.js +6 -0
  133. package/dist/mumps-CRTFHhzh.js +4 -0
  134. package/dist/nsis-C4NPTuox.js +4 -0
  135. package/dist/{nsis-B5K1qoyo.js → nsis-ClF3r5Tr.js} +1 -1
  136. package/dist/ntriples-BCOoGph1.js +4 -0
  137. package/dist/{number-overlay-editor-_GnlYFHC.js → number-overlay-editor-CpKi64Fy.js} +1 -1
  138. package/dist/octave-DTwNlazz.js +4 -0
  139. package/dist/{ordinal-2jIulmcR.js → ordinal-B43ZeR68.js} +1 -1
  140. package/dist/oz-DD38AzSz.js +4 -0
  141. package/dist/{packet-DYOGHKS2-CBxXGWNr.js → packet-DYOGHKS2-CmWtF3uO.js} +1 -1
  142. package/dist/pascal-BohSp9jV.js +4 -0
  143. package/dist/perl-f5OutoPM.js +4 -0
  144. package/dist/{pie-VRWISCQL-Bmdnqjip.js → pie-VRWISCQL-B6u8vus8.js} +1 -1
  145. package/dist/{pieDiagram-ADFJNKIX-DNyLF5H2.js → pieDiagram-ADFJNKIX-Di34MOFQ.js} +19 -19
  146. package/dist/pig-Dv7wSmHb.js +4 -0
  147. package/dist/powershell-rYgjKB39.js +4 -0
  148. package/dist/{process-output-ClDgSR3m.js → process-output-X8TR20AK.js} +30 -25
  149. package/dist/properties-BFUNLRDN.js +4 -0
  150. package/dist/protobuf-B9QJQPPv.js +4 -0
  151. package/dist/{pug-tjbzJCFk.js → pug-B_rby2yb.js} +1 -1
  152. package/dist/pug-DzvWpaMC.js +4 -0
  153. package/dist/puppet-B_K-n_xK.js +4 -0
  154. package/dist/python-CAiFcaA2.js +4 -0
  155. package/dist/q-cLeFIBLK.js +4 -0
  156. package/dist/{quadrantDiagram-AYHSOK5B-rXwjifrj.js → quadrantDiagram-AYHSOK5B-B9kVk1ny.js} +3 -3
  157. package/dist/r-04Y-Wco3.js +4 -0
  158. package/dist/{radar-ZZBFDIW7-BmCWDffL.js → radar-ZZBFDIW7-XAmXSa8s.js} +1 -1
  159. package/dist/{react-vega-B-rkEqtS.js → react-vega-Cavbrg4l.js} +1 -1
  160. package/dist/{react-vega-k9ODWPlI.js → react-vega-Dh6-UKKe.js} +13 -13
  161. package/dist/{requirementDiagram-UZGBJVZJ-DBdrMVbs.js → requirementDiagram-UZGBJVZJ-BxGfGYEx.js} +13 -13
  162. package/dist/reveal-component-CsfEpSwA.js +7447 -0
  163. package/dist/rpm-FUdrIia9.js +5 -0
  164. package/dist/ruby-DMjFXuEW.js +4 -0
  165. package/dist/{sankeyDiagram-TZEHDZUN-CxmzalGv.js → sankeyDiagram-TZEHDZUN-D09PBJ-n.js} +4 -4
  166. package/dist/sas-DzHZxjXK.js +4 -0
  167. package/dist/scheme-DxHd_Rb9.js +4 -0
  168. package/dist/semaphore-CNDGTzkX.js +46 -0
  169. package/dist/{sequenceDiagram-WL72ISMW-CVCDsJ9h.js → sequenceDiagram-WL72ISMW-t_Dpemj0.js} +7 -7
  170. package/dist/shell-C8Kwypgf.js +4 -0
  171. package/dist/sieve-DdyqOKXZ.js +4 -0
  172. package/dist/smalltalk-pB7X1D9y.js +4 -0
  173. package/dist/sparql-NhBO6oOa.js +4 -0
  174. package/dist/{spec-DSIuqd3f.js → spec-hVaaZsY5.js} +4 -4
  175. package/dist/{src-BY0BGg6V.js → src-Bf2iLOlr.js} +1 -1
  176. package/dist/{stateDiagram-FKZM4ZOC-D_2djEhW.js → stateDiagram-FKZM4ZOC-B18gTP_j.js} +16 -16
  177. package/dist/stateDiagram-v2-4FDKWEC3-B6e_t14A.js +29 -0
  178. package/dist/{step-DGAGWg3y.js → step-CWipAYTY.js} +1 -1
  179. package/dist/{strings-B_FOH6eV.js → strings-BiIhGaI8.js} +4 -4
  180. package/dist/style.css +1 -1
  181. package/dist/stylus-SfWSnzPv.js +4 -0
  182. package/dist/swift-jRPdq2zR.js +4 -0
  183. package/dist/{swiper-component-KkEVUDd3.js → swiper-component-DlD2GU2g.js} +2 -2
  184. package/dist/tcl-_hpTHGX3.js +4 -0
  185. package/dist/textile-C9h8slqH.js +4 -0
  186. package/dist/{time-CMdrp3hw.js → time-C1SGcFMH.js} +2 -2
  187. package/dist/{timeline-definition-IT6M3QCI-E4NzxCs3.js → timeline-definition-IT6M3QCI-DJnh1ks5.js} +3 -3
  188. package/dist/{toDate-CHtl9vts.js → toDate-CIpC_34u.js} +33 -20
  189. package/dist/toml-DWvtinD4.js +4 -0
  190. package/dist/{tooltip-B0mtKTXm.js → tooltip-DRaMBu06.js} +3 -3
  191. package/dist/{treemap-GDKQZRPO-CoKHPxa7.js → treemap-GDKQZRPO-Du95DV6u.js} +1 -1
  192. package/dist/troff-Dwo_A0y7.js +4 -0
  193. package/dist/ttcn-V--CPFKq.js +4 -0
  194. package/dist/ttcn-cfg-CPSMchTG.js +4 -0
  195. package/dist/turtle-B4rPGBWu.js +4 -0
  196. package/dist/{types-DBtDeUKD.js → types-Dzuoc3LN.js} +1 -1
  197. package/dist/{useAsyncData-B6hCGywC.js → useAsyncData-C56Khv_R.js} +1 -1
  198. package/dist/{useDateFormatter-B3mCQMP3.js → useDateFormatter-B_9k85Ex.js} +2 -2
  199. package/dist/{useDeepCompareMemoize-CmwDuYUH.js → useDeepCompareMemoize-Dt98v2ua.js} +1 -1
  200. package/dist/{useIframeCapabilities-DbdLoEDm.js → useIframeCapabilities-BkYHTrss.js} +1 -1
  201. package/dist/{useLifecycle-CjMjllqy.js → useLifecycle-BF6-z62y.js} +3 -3
  202. package/dist/{useTheme-CByZUW0p.js → useTheme-DykuNHR2.js} +2 -2
  203. package/dist/vb-DaMBBd4j.js +4 -0
  204. package/dist/vbscript-BMJQqcE2.js +4 -0
  205. package/dist/{vega-component-CC8TqWWV.js → vega-component-cSdqoAxe.js} +26 -24
  206. package/dist/velocity-CGq2QRq2.js +4 -0
  207. package/dist/verilog-CUNo8F5u.js +4 -0
  208. package/dist/vhdl-CCzA0msW.js +4 -0
  209. package/dist/webidl-CqIMDIBL.js +4 -0
  210. package/dist/xquery-XC5Kbr-1.js +4 -0
  211. package/dist/{xychartDiagram-PRI3JC2R-CuxTvjw5.js → xychartDiagram-PRI3JC2R-Dk2d_bX0.js} +10 -10
  212. package/dist/yacas-CGOv7Dzy.js +4 -0
  213. package/dist/z80-CXhVmi-f.js +4 -0
  214. package/dist/{zod-BxdsqRPd.js → zod-BWkcDORu.js} +1 -1
  215. package/package.json +3 -3
  216. package/src/components/chat/chat-components.tsx +47 -0
  217. package/src/components/chat/chat-display.tsx +41 -7
  218. package/src/components/chat/chat-panel.tsx +37 -10
  219. package/src/components/chat/chat-utils.ts +42 -20
  220. package/src/components/chat/reasoning-accordion.tsx +14 -3
  221. package/src/components/chat/tool-call/shared.ts +13 -0
  222. package/src/components/chat/tool-call/tool-approval-card.tsx +62 -0
  223. package/src/components/chat/tool-call/tool-args.tsx +26 -0
  224. package/src/components/chat/tool-call/tool-call-view.tsx +99 -0
  225. package/src/components/chat/tool-call/tool-error-card.tsx +81 -0
  226. package/src/components/chat/tool-call/tool-history-row.tsx +153 -0
  227. package/src/components/chat/tool-call/tool-result.tsx +101 -0
  228. package/src/components/data-table/__tests__/column-header.test.ts +3 -1
  229. package/src/components/data-table/__tests__/column-header.test.tsx +308 -0
  230. package/src/components/data-table/__tests__/filter-by-values-picker.test.tsx +112 -0
  231. package/src/components/data-table/__tests__/filter-pill-editor.test.tsx +261 -0
  232. package/src/components/data-table/__tests__/filters.test.ts +196 -49
  233. package/src/components/data-table/charts/components/form-fields.tsx +1 -0
  234. package/src/components/data-table/column-header.tsx +349 -170
  235. package/src/components/data-table/date-filter-inputs.tsx +325 -0
  236. package/src/components/data-table/filter-by-values-picker.tsx +70 -9
  237. package/src/components/data-table/filter-pill-editor.tsx +410 -156
  238. package/src/components/data-table/filter-pills.tsx +69 -54
  239. package/src/components/data-table/filters.ts +218 -101
  240. package/src/components/data-table/header-items.tsx +8 -1
  241. package/src/components/data-table/operator-labels.ts +25 -0
  242. package/src/components/data-table/regex-input.tsx +61 -0
  243. package/src/components/dependency-graph/minimap-content.tsx +14 -3
  244. package/src/components/editor/actions/pair-with-agent-modal.tsx +140 -49
  245. package/src/components/editor/actions/useNotebookActions.tsx +3 -1
  246. package/src/components/editor/app-container.tsx +7 -1
  247. package/src/components/editor/chrome/panels/context-aware-panel/context-aware-panel.tsx +10 -2
  248. package/src/components/editor/chrome/wrapper/app-chrome.tsx +1 -0
  249. package/src/components/editor/chrome/wrapper/footer-items/backend-status.tsx +1 -1
  250. package/src/components/editor/chrome/wrapper/footer.tsx +4 -1
  251. package/src/components/editor/chrome/wrapper/panels.tsx +4 -1
  252. package/src/components/editor/chrome/wrapper/sidebar.tsx +4 -1
  253. package/src/components/editor/controls/Controls.tsx +11 -3
  254. package/src/components/editor/file-tree/file-explorer.tsx +12 -2
  255. package/src/components/editor/file-tree/requesting-tree.tsx +27 -25
  256. package/src/components/editor/file-tree/upload.tsx +23 -17
  257. package/src/components/editor/header/__tests__/status.test.tsx +108 -0
  258. package/src/components/editor/header/status.tsx +44 -10
  259. package/src/components/editor/navigation/__tests__/clipboard.test.ts +106 -0
  260. package/src/components/editor/navigation/__tests__/navigation.test.ts +70 -0
  261. package/src/components/editor/navigation/clipboard.ts +99 -25
  262. package/src/components/editor/navigation/navigation.ts +15 -1
  263. package/src/components/editor/notebook-cell.tsx +5 -0
  264. package/src/components/editor/output/console/ConsoleOutput.tsx +23 -5
  265. package/src/components/editor/output/console/__tests__/ConsoleOutput.test.tsx +114 -0
  266. package/src/components/editor/renderers/slides-layout/__tests__/compute-slide-cells.test.ts +5 -4
  267. package/src/components/editor/renderers/slides-layout/__tests__/plugin.test.ts +55 -15
  268. package/src/components/editor/renderers/slides-layout/plugin.tsx +8 -25
  269. package/src/components/editor/renderers/slides-layout/slides-layout.tsx +19 -6
  270. package/src/components/editor/renderers/slides-layout/types.ts +40 -31
  271. package/src/components/editor/renderers/vertical-layout/vertical-layout.tsx +1 -0
  272. package/src/components/home/components.tsx +6 -0
  273. package/src/components/pages/run-page.tsx +4 -1
  274. package/src/components/scratchpad/scratchpad.tsx +1 -0
  275. package/src/components/slides/__tests__/slide-notes.test.ts +131 -0
  276. package/src/components/slides/reveal-component.tsx +252 -147
  277. package/src/components/slides/slide-notes-editor.tsx +127 -0
  278. package/src/components/slides/slide-notes.ts +64 -0
  279. package/src/components/slides/slides.css +14 -0
  280. package/src/components/ui/combobox.tsx +24 -5
  281. package/src/components/ui/number-field.tsx +2 -0
  282. package/src/core/ai/tools/__tests__/registry.test.ts +10 -12
  283. package/src/core/ai/tools/registry.ts +9 -5
  284. package/src/core/cells/__tests__/cells.test.ts +187 -0
  285. package/src/core/cells/__tests__/pending-cut-service.test.tsx +123 -0
  286. package/src/core/cells/cells.ts +102 -17
  287. package/src/core/cells/document-changes.ts +6 -1
  288. package/src/core/cells/pending-cut-service.ts +55 -0
  289. package/src/core/cells/utils.ts +11 -0
  290. package/src/core/codemirror/cells/extensions.ts +10 -0
  291. package/src/core/codemirror/go-to-definition/__tests__/commands.test.ts +152 -0
  292. package/src/core/codemirror/go-to-definition/__tests__/utils.test.ts +99 -0
  293. package/src/core/codemirror/go-to-definition/commands.ts +382 -22
  294. package/src/core/codemirror/go-to-definition/utils.ts +23 -5
  295. package/src/core/edit-app.tsx +3 -2
  296. package/src/core/hotkeys/hotkeys.ts +5 -0
  297. package/src/core/islands/worker/worker.tsx +3 -2
  298. package/src/core/run-app.tsx +2 -1
  299. package/src/core/runtime/__tests__/runtime.test.ts +38 -17
  300. package/src/core/runtime/runtime.ts +57 -34
  301. package/src/core/wasm/__tests__/utils.test.ts +34 -0
  302. package/src/core/wasm/utils.ts +14 -0
  303. package/src/core/wasm/worker/bootstrap.ts +3 -2
  304. package/src/core/wasm/worker/worker.ts +3 -2
  305. package/src/core/websocket/__tests__/useMarimoKernelConnection.hook.test.tsx +156 -0
  306. package/src/core/websocket/__tests__/useMarimoKernelConnection.test.ts +101 -0
  307. package/src/core/websocket/transports/__tests__/ws.test.ts +125 -0
  308. package/src/core/websocket/transports/basic.ts +1 -1
  309. package/src/core/websocket/transports/ws.ts +96 -0
  310. package/src/core/websocket/useMarimoKernelConnection.tsx +133 -54
  311. package/src/core/websocket/useWebSocket.tsx +3 -15
  312. package/src/css/app/Cell.css +10 -0
  313. package/src/plugins/core/__test__/sanitize.test.ts +30 -0
  314. package/src/plugins/impl/DropdownPlugin.tsx +12 -1
  315. package/src/plugins/impl/MultiselectPlugin.tsx +4 -0
  316. package/src/plugins/impl/SearchableSelect.tsx +11 -1
  317. package/src/plugins/impl/TabsPlugin.tsx +35 -7
  318. package/src/plugins/impl/__tests__/DropdownPlugin.test.tsx +56 -0
  319. package/src/plugins/impl/__tests__/TabsPlugin.test.tsx +154 -0
  320. package/src/plugins/impl/data-frames/forms/__tests__/__snapshots__/form.test.tsx.snap +48 -36
  321. package/src/plugins/impl/data-frames/schema.ts +4 -1
  322. package/src/plugins/impl/vega/resolve-data.ts +8 -1
  323. package/src/plugins/layout/DownloadPlugin.tsx +9 -7
  324. package/src/utils/__tests__/id-tree.test.ts +71 -0
  325. package/src/utils/__tests__/semaphore.test.ts +218 -0
  326. package/src/utils/download.ts +4 -2
  327. package/src/utils/fileToBase64.ts +8 -7
  328. package/src/utils/id-tree.tsx +89 -0
  329. package/src/utils/semaphore.ts +88 -0
  330. package/dist/apl-BKoVld9y.js +0 -4
  331. package/dist/asciiarmor-DQrKIjoo.js +0 -4
  332. package/dist/asn1-BZvnj0dq.js +0 -4
  333. package/dist/assets/__vite-browser-external-rrUYDKRl.js +0 -1
  334. package/dist/assets/worker-Bfy15ViQ.js +0 -73
  335. package/dist/brainfuck-D558nlUv.js +0 -4
  336. package/dist/classDiagram-2ON5EDUG-CBHMR6ZU.js +0 -30
  337. package/dist/classDiagram-v2-WZHVMYZB-BsUtUGM_.js +0 -30
  338. package/dist/clojure-Cq8mTSrE.js +0 -4
  339. package/dist/cmake-D8HCovWK.js +0 -4
  340. package/dist/cobol-UolN-9iU.js +0 -4
  341. package/dist/coffeescript-VdNuWrt5.js +0 -4
  342. package/dist/commonlisp-ALX7fpDc.js +0 -4
  343. package/dist/crystal-PbyO9Q_s.js +0 -4
  344. package/dist/css-DFklJkr_.js +0 -4
  345. package/dist/cypher-BifNeYlv.js +0 -4
  346. package/dist/d-BA-JP4PJ.js +0 -4
  347. package/dist/diff-CtkDpav4.js +0 -4
  348. package/dist/dist-BuBwsFva.js +0 -5
  349. package/dist/dist-BzmEQ9u7.js +0 -5
  350. package/dist/dist-Cih01ssx.js +0 -5
  351. package/dist/dist-CqfONiY9.js +0 -5
  352. package/dist/dist-D0iD0Fi9.js +0 -5
  353. package/dist/dist-DtNLXm8d.js +0 -5
  354. package/dist/dtd-DW3_UFEG.js +0 -4
  355. package/dist/dylan-pDhodO2N.js +0 -4
  356. package/dist/ecl-BJT8-YD7.js +0 -4
  357. package/dist/eiffel-Dmns-9vS.js +0 -4
  358. package/dist/elm-Da4sO4Bz.js +0 -4
  359. package/dist/erlang-C-zBsDi7.js +0 -4
  360. package/dist/factor-4xPWlWB5.js +0 -4
  361. package/dist/forth-l-c75zSd.js +0 -4
  362. package/dist/fortran-DIujSODW.js +0 -4
  363. package/dist/gas-CXnG5g_b.js +0 -4
  364. package/dist/gherkin-VPeqd4-X.js +0 -4
  365. package/dist/groovy-CphhZQgg.js +0 -4
  366. package/dist/haskell-CCvlS5Iq.js +0 -4
  367. package/dist/haxe-C_bi66fP.js +0 -5
  368. package/dist/idl-1DcP4Dm8.js +0 -4
  369. package/dist/javascript-DUIGhBvO.js +0 -4
  370. package/dist/julia-Cs2G4PQi.js +0 -4
  371. package/dist/livescript-DMtVFaAN.js +0 -4
  372. package/dist/lua-BAoLtdJg.js +0 -4
  373. package/dist/mathematica-C_NoFtbo.js +0 -4
  374. package/dist/mbox-DcFJFYrH.js +0 -4
  375. package/dist/mirc-71dccf_u.js +0 -4
  376. package/dist/mllike-CWcOFVDq.js +0 -6
  377. package/dist/modelica-Ape2VXxx.js +0 -4
  378. package/dist/mscgen-Cc6TwbSN.js +0 -6
  379. package/dist/mumps-h-ZbdkJ9.js +0 -4
  380. package/dist/nsis-C0p3m7JW.js +0 -4
  381. package/dist/ntriples-c9lEeT5w.js +0 -4
  382. package/dist/octave-DzEgB_74.js +0 -4
  383. package/dist/oz-CAxvHkyQ.js +0 -4
  384. package/dist/pascal-BJzu1sgP.js +0 -4
  385. package/dist/perl--IrOzZ2Z.js +0 -4
  386. package/dist/pig-CiBKKNhC.js +0 -4
  387. package/dist/powershell-KY0j6Qop.js +0 -4
  388. package/dist/properties-BW8q3ziV.js +0 -4
  389. package/dist/protobuf-BGaeuTGV.js +0 -4
  390. package/dist/pug-DjOKK-4J.js +0 -4
  391. package/dist/puppet-DWm2o6zX.js +0 -4
  392. package/dist/python-Bp2gezZy.js +0 -4
  393. package/dist/q-DljPshos.js +0 -4
  394. package/dist/r-BajPMnEu.js +0 -4
  395. package/dist/reveal-component-DisX89FD.js +0 -4863
  396. package/dist/rpm-BKx-ZZ62.js +0 -5
  397. package/dist/ruby-DJq_HNKc.js +0 -4
  398. package/dist/sas-WANvpcOU.js +0 -4
  399. package/dist/scheme-CliBbhGF.js +0 -4
  400. package/dist/shell-BwhrNUvM.js +0 -4
  401. package/dist/sieve-BIVePvMp.js +0 -4
  402. package/dist/smalltalk-D6G48JmY.js +0 -4
  403. package/dist/sparql-jjc3BmEP.js +0 -4
  404. package/dist/stateDiagram-v2-4FDKWEC3-Cv9Av10H.js +0 -29
  405. package/dist/stylus-WPBPQ4PE.js +0 -4
  406. package/dist/swift-O1Qy6iCm.js +0 -4
  407. package/dist/tcl-BAFdhvsi.js +0 -4
  408. package/dist/textile-DFuzhNLG.js +0 -4
  409. package/dist/toml-DRSTeely.js +0 -4
  410. package/dist/troff-B_ZjwBW0.js +0 -4
  411. package/dist/ttcn-CAyiB3ic.js +0 -4
  412. package/dist/ttcn-cfg-BS5_BGBJ.js +0 -4
  413. package/dist/turtle-CUBEDy3E.js +0 -4
  414. package/dist/vb-DY9S6-U2.js +0 -4
  415. package/dist/vbscript-gaHC39Jq.js +0 -4
  416. package/dist/velocity-TfCOtJZ_.js +0 -4
  417. package/dist/verilog-c2JOX8mv.js +0 -4
  418. package/dist/vhdl-dHBirRiO.js +0 -4
  419. package/dist/webidl-Bauj-i07.js +0 -4
  420. package/dist/xquery-CtaEAOt8.js +0 -4
  421. package/dist/yacas-BZ85agQP.js +0 -4
  422. package/dist/z80-hCgR-L4U.js +0 -4
  423. package/src/components/chat/tool-call-accordion.tsx +0 -247
  424. /package/dist/{ImageComparisonComponent-DaocPIse.js → ImageComparisonComponent-CNHIsPDj.js} +0 -0
  425. /package/dist/{Plot-PIeIvFnD.js → Plot-4wn-lMVn.js} +0 -0
  426. /package/dist/{apl-Dt8GMXYg.js → apl-BCgCq9iM.js} +0 -0
  427. /package/dist/{array-B-MVxRIF.js → array-tvvEqPy7.js} +0 -0
  428. /package/dist/{asciiarmor-CitDQ85h.js → asciiarmor-BtqU-KJQ.js} +0 -0
  429. /package/dist/{asn1-abrf9SMK.js → asn1-Dmb-dTMx.js} +0 -0
  430. /package/dist/{asterisk-BUZwqih-.js → asterisk-DaVJJDnV.js} +0 -0
  431. /package/dist/{brainfuck-BL-Boof0.js → brainfuck-C1HoZKlE.js} +0 -0
  432. /package/dist/{chunk-4F5CHEZ2-C6tO9vjs.js → chunk-4F5CHEZ2-BZq7Kom7.js} +0 -0
  433. /package/dist/{chunk-B2363JML-Ds8wZXyP.js → chunk-B2363JML-D9-XOau1.js} +0 -0
  434. /package/dist/{chunk-DR5Q36YT-CP69aZS_.js → chunk-DR5Q36YT-BflwErH1.js} +0 -0
  435. /package/dist/{chunk-FRFDVMJY-BgQv1HBE.js → chunk-FRFDVMJY-BSBUAX7r.js} +0 -0
  436. /package/dist/{chunk-PL6DKKU2-DHfTUHy8.js → chunk-PL6DKKU2-B0MTXvyc.js} +0 -0
  437. /package/dist/{chunk-SJTYNZTY-Diciw4sx.js → chunk-SJTYNZTY-CEG4F0pB.js} +0 -0
  438. /package/dist/{chunk-TQ3KTPDO-CQfP9npd.js → chunk-TQ3KTPDO-DiCtqVSi.js} +0 -0
  439. /package/dist/{chunk-UMXZTB3W-MSKeGL7W.js → chunk-UMXZTB3W-97iS1iEl.js} +0 -0
  440. /package/dist/{click-outside-container-BZgN7xS_.js → click-outside-container-BDd67_1U.js} +0 -0
  441. /package/dist/{clike-RWg7anhx.js → clike-CdT0yHjt.js} +0 -0
  442. /package/dist/{clojure-DaojKHow.js → clojure-CdyrCpUv.js} +0 -0
  443. /package/dist/{cmake-DN-_v0XE.js → cmake-BFlPxym7.js} +0 -0
  444. /package/dist/{cobol-C3VpMyux.js → cobol-CcJXewp8.js} +0 -0
  445. /package/dist/{coffeescript-DIkz3Tbt.js → coffeescript-DnKuIKRo.js} +0 -0
  446. /package/dist/{colors-Cn2p_FA3.js → colors-CQAOa8cK.js} +0 -0
  447. /package/dist/{common-keywords-hbLeU7VU.js → common-keywords-FBrXPTcz.js} +0 -0
  448. /package/dist/{commonlisp-CB1boOiP.js → commonlisp-B-kok83Z.js} +0 -0
  449. /package/dist/{crystal-DI2oCml6.js → crystal-FYRYjI1I.js} +0 -0
  450. /package/dist/{css-BdEVwQDV.js → css-B45lc2V3.js} +0 -0
  451. /package/dist/{cypher-BNHToqxU.js → cypher-DZMLyVY_.js} +0 -0
  452. /package/dist/{cytoscape.esm-WbbDoCfu.js → cytoscape.esm-ayF70frT.js} +0 -0
  453. /package/dist/{d-D7we7I1b.js → d-x-VVT4o9.js} +0 -0
  454. /package/dist/{diff-Cia6fzjN.js → diff-Dxe2mpXk.js} +0 -0
  455. /package/dist/{dist-BK-3fF4P.js → dist-B4LJpMEg.js} +0 -0
  456. /package/dist/{dist-CxdUraQr.js → dist-B507mf_I.js} +0 -0
  457. /package/dist/{dist-C89sHDXk.js → dist-BGdYVvOu.js} +0 -0
  458. /package/dist/{dist-DquyVv5H.js → dist-BNyrZfqT.js} +0 -0
  459. /package/dist/{dist-Zn0KNbo9.js → dist-Bc5pmZIw.js} +0 -0
  460. /package/dist/{dist-C-J0pt5p.js → dist-BvCfQQQE.js} +0 -0
  461. /package/dist/{dist-D9r7Cmw7.js → dist-C2ej4eOH.js} +0 -0
  462. /package/dist/{dist-HVuryI1a.js → dist-C34oIrQ9.js} +0 -0
  463. /package/dist/{dist-CGLzXdrt.js → dist-CDFZi-QD.js} +0 -0
  464. /package/dist/{dist-C9fmTOin.js → dist-CYEylvZA.js} +0 -0
  465. /package/dist/{dist-DadjmS-4.js → dist-DJ6zJQZ4.js} +0 -0
  466. /package/dist/{dist-CtCY55Jf.js → dist-Dh3wkoyH.js} +0 -0
  467. /package/dist/{dist-C474qFoq.js → dist-Dhk6FMb0.js} +0 -0
  468. /package/dist/{dist-DZjQ_MBo.js → dist-KnujRhFL.js} +0 -0
  469. /package/dist/{dist-CinA9Enb.js → dist-WdPUFc56.js} +0 -0
  470. /package/dist/{dist-DBLeRrPp.js → dist-t_qL7eB8.js} +0 -0
  471. /package/dist/{dist-CyFFzJTb.js → dist-usPCDYx8.js} +0 -0
  472. /package/dist/{dtd-H4Hubdwp.js → dtd-C9VM_Wfu.js} +0 -0
  473. /package/dist/{duckdb-keywords-CZ_ZTscu.js → duckdb-keywords-CvJhR_Yd.js} +0 -0
  474. /package/dist/{dylan-fVO6rnq3.js → dylan-DTSnEIFO.js} +0 -0
  475. /package/dist/{ebnf-WEXPLEWb.js → ebnf-2D4Ctp3y.js} +0 -0
  476. /package/dist/{ecl-B94VPjNR.js → ecl-N04ptnRK.js} +0 -0
  477. /package/dist/{eiffel-C_R6TusS.js → eiffel-Dd8rpqr_.js} +0 -0
  478. /package/dist/{elm-DzCHbO2g.js → elm-GT2E866W.js} +0 -0
  479. /package/dist/{erlang-BGNkx6JU.js → erlang-Cf0Bp5pY.js} +0 -0
  480. /package/dist/{esm-Bb_hbWan.js → esm-BaaaPNGl.js} +0 -0
  481. /package/dist/{fcl-B_Gv5Jfx.js → fcl-Ccj8Z5Xd.js} +0 -0
  482. /package/dist/{forth-Bybw0cJ7.js → forth-wd_XzGTg.js} +0 -0
  483. /package/dist/{fortran-C6PoCLkI.js → fortran-DcwUTZFe.js} +0 -0
  484. /package/dist/{gas-BBlhenj4.js → gas-DeALIER3.js} +0 -0
  485. /package/dist/{gherkin-NXtNG85X.js → gherkin-CKTqaJNX.js} +0 -0
  486. /package/dist/{groovy-BoFYK9xM.js → groovy-Bwdp_d8D.js} +0 -0
  487. /package/dist/{haskell-BtBdvQ1n.js → haskell-DCdCcPLK.js} +0 -0
  488. /package/dist/{haxe-D--o6dr0.js → haxe-DAyktQWJ.js} +0 -0
  489. /package/dist/{http-Dc2fv19V.js → http-_DVAYWoR.js} +0 -0
  490. /package/dist/{idl-AqTq5l7e.js → idl-CBuZiRYu.js} +0 -0
  491. /package/dist/{init-D-g0ONX1.js → init-uv0kkh4g.js} +0 -0
  492. /package/dist/{javascript-DvwNVye9.js → javascript-DzigE11c.js} +0 -0
  493. /package/dist/{julia-DoKiagZC.js → julia-PwfB-0Cm.js} +0 -0
  494. /package/dist/{katex-B7pMJpE0.js → katex-C_XRmjAP.js} +0 -0
  495. /package/dist/{livescript-DxBZMiWB.js → livescript-BJLz1EbT.js} +0 -0
  496. /package/dist/{lua-DmS_0NTu.js → lua-ZC-XC2jf.js} +0 -0
  497. /package/dist/{math-BYK36kWZ.js → math-DFcdCCU8.js} +0 -0
  498. /package/dist/{mathematica-ChlDFeIC.js → mathematica-DCYMx6qB.js} +0 -0
  499. /package/dist/{mbox-CguZuODr.js → mbox-OxMK_9XI.js} +0 -0
  500. /package/dist/{mirc-CFtY8dqz.js → mirc-nJVyhA0H.js} +0 -0
  501. /package/dist/{mllike-C0EJrEOk.js → mllike-DRO89bsU.js} +0 -0
  502. /package/dist/{modelica-C1kO1nfS.js → modelica-Don3E6ZD.js} +0 -0
  503. /package/dist/{mscgen-DEYdr7AY.js → mscgen-DJfqD3bN.js} +0 -0
  504. /package/dist/{mumps-B3NVJs2V.js → mumps-SjGTvDYL.js} +0 -0
  505. /package/dist/{nginx-ComVAAGN.js → nginx-DasThI7R.js} +0 -0
  506. /package/dist/{node-sql-parser-DNGGJ-Rw.js → node-sql-parser-B8nBD36q.js} +0 -0
  507. /package/dist/{ntriples-DHol9X9H.js → ntriples-CNBKRl3I.js} +0 -0
  508. /package/dist/{octave-CYGz0bfo.js → octave-DdeVHNlx.js} +0 -0
  509. /package/dist/{oz-kPxb2ni5.js → oz-CcKSoNvN.js} +0 -0
  510. /package/dist/{pascal-bZ0yrJKy.js → pascal-6leftwNj.js} +0 -0
  511. /package/dist/{path-Du6n3sOU.js → path-BGaWgPKg.js} +0 -0
  512. /package/dist/{perl-z4hvqyqz.js → perl-BhJIwWzN.js} +0 -0
  513. /package/dist/{pig-DZO8QDF9.js → pig-r-xDHqRf.js} +0 -0
  514. /package/dist/{powershell-BSuaDQEC.js → powershell-D-BELeNi.js} +0 -0
  515. /package/dist/{properties-BXhGLlIx.js → properties-CnuDhbll.js} +0 -0
  516. /package/dist/{protobuf-DM6iybWV.js → protobuf-CO8RBhvX.js} +0 -0
  517. /package/dist/{puppet-Bn05sQT8.js → puppet-NmXHjLy8.js} +0 -0
  518. /package/dist/{python-Cvnhm0g7.js → python-DAQXi720.js} +0 -0
  519. /package/dist/{q-B9V8hzex.js → q-DlikXfV0.js} +0 -0
  520. /package/dist/{r-Cf0gFqmq.js → r-CuohilwT.js} +0 -0
  521. /package/dist/{rpm-D-LMkTV1.js → rpm-0Pjwp0Pb.js} +0 -0
  522. /package/dist/{ruby-DeuPikpK.js → ruby-Dq8NJTDG.js} +0 -0
  523. /package/dist/{sas-C9tjgAo9.js → sas-CuwonyVP.js} +0 -0
  524. /package/dist/{scheme-D1_bUF0G.js → scheme-CYU-RRIf.js} +0 -0
  525. /package/dist/{shell-CJBmnks3.js → shell-COPmX2qE.js} +0 -0
  526. /package/dist/{sieve-1fSV75CF.js → sieve-B_3zyLne.js} +0 -0
  527. /package/dist/{simple-mode-B90Wdavj.js → simple-mode-DSBniks8.js} +0 -0
  528. /package/dist/{smalltalk-sZNPD0HO.js → smalltalk-DRft7iPv.js} +0 -0
  529. /package/dist/{solr-DTkyqJ-Z.js → solr-RZ9uTl59.js} +0 -0
  530. /package/dist/{sparql-oHc1nm77.js → sparql-CN6qj55H.js} +0 -0
  531. /package/dist/{spreadsheet-CER0raqY.js → spreadsheet-BNNUNXA2.js} +0 -0
  532. /package/dist/{sql-ByOoEONQ.js → sql-B4x8IkwU.js} +0 -0
  533. /package/dist/{stylus-KzkX6zRB.js → stylus-Bn_ZjOQ3.js} +0 -0
  534. /package/dist/{swift-DqVxZvKo.js → swift-BLUJhMbz.js} +0 -0
  535. /package/dist/{tcl-BtWSwXfA.js → tcl-C86fxecl.js} +0 -0
  536. /package/dist/{textile-CWDbn9Ql.js → textile-DmHh2rsK.js} +0 -0
  537. /package/dist/{tiddlywiki-Cr9xyOY1.js → tiddlywiki-DI0mF2WJ.js} +0 -0
  538. /package/dist/{tiki-D5JONyfZ.js → tiki-2HU6XLLn.js} +0 -0
  539. /package/dist/{timer-D7JVdX9U.js → timer-YZl28NYN.js} +0 -0
  540. /package/dist/{toml-BfehlgmL.js → toml-GWANRNAD.js} +0 -0
  541. /package/dist/{treemap-qFGzn7xk.js → treemap-D-ka1hvx.js} +0 -0
  542. /package/dist/{troff-BZBk6AAu.js → troff-BHTsomIy.js} +0 -0
  543. /package/dist/{ttcn-DVwvXg0_.js → ttcn-DQuhn5Mn.js} +0 -0
  544. /package/dist/{ttcn-cfg-gjbVLf1L.js → ttcn-cfg-HjFYtdB-.js} +0 -0
  545. /package/dist/{turtle-CgxKXorV.js → turtle-nCay33Nv.js} +0 -0
  546. /package/dist/{vb-B9kSwTdM.js → vb-BG-XlqqJ.js} +0 -0
  547. /package/dist/{vbscript-DrUKSCdb.js → vbscript-B6vyW0-D.js} +0 -0
  548. /package/dist/{velocity-AlMYTnMy.js → velocity-CWegueqO.js} +0 -0
  549. /package/dist/{verilog-DLUaM05j.js → verilog-CzSQm4cG.js} +0 -0
  550. /package/dist/{vhdl-DUJOtSmO.js → vhdl-DqnNVL7r.js} +0 -0
  551. /package/dist/{webidl-CQp4aHk_.js → webidl-DXEUpDWH.js} +0 -0
  552. /package/dist/{xquery-IxkjlwOD.js → xquery-Ba_NB5bD.js} +0 -0
  553. /package/dist/{yacas-Bnctn5w8.js → yacas-HKQU6hyk.js} +0 -0
  554. /package/dist/{z80-DrFwhx53.js → z80-CXkHXLdj.js} +0 -0
@@ -23,6 +23,7 @@ import {
23
23
  splitEditor,
24
24
  updateEditorCodeFromPython,
25
25
  } from "../codemirror/language/utils";
26
+ import type { SerializedEditorState } from "../codemirror/types";
26
27
  import { findCollapseRange, mergeOutlines } from "../dom/outline";
27
28
  import type { CellMessage } from "../kernel/messages";
28
29
  import { isErrorMime } from "../mime";
@@ -50,11 +51,36 @@ import {
50
51
  canUndoDeletes,
51
52
  disabledCellIds,
52
53
  enabledCellIds,
54
+ getUndoLabel,
53
55
  notebookIsRunning,
54
56
  notebookNeedsRun,
55
57
  notebookQueueOrRunningCount,
56
58
  } from "./utils";
57
59
 
60
+ /**
61
+ * History entry for undoing a cell deletion.
62
+ */
63
+ export interface UndoDeleteEntry {
64
+ type: "delete";
65
+ name: string;
66
+ serializedEditorState: SerializedEditorState;
67
+ column: CellColumnId;
68
+ index: CellIndex;
69
+ isSetupCell: boolean;
70
+ config: CellConfig;
71
+ }
72
+
73
+ /**
74
+ * History entry for undoing a cut-paste (move).
75
+ */
76
+ export interface UndoMoveEntry {
77
+ type: "move";
78
+ cellIds: CellId[];
79
+ placements: Array<{ columnId: CellColumnId; index: CellIndex }>;
80
+ }
81
+
82
+ export type HistoryEntry = UndoDeleteEntry | UndoMoveEntry;
83
+
58
84
  /**
59
85
  * The state of the notebook.
60
86
  */
@@ -76,19 +102,9 @@ export interface NotebookState {
76
102
  */
77
103
  cellHandles: Record<CellId, React.RefObject<CellHandle | null>>;
78
104
  /**
79
- * Array of deleted cells (with their data and index) so that cell deletion can be undone
80
- *
81
- * (CodeMirror types the serialized config as any.)
105
+ * Undo stack: deleted cells and cut-paste moves, in chronological order.
82
106
  */
83
- history: {
84
- name: string;
85
- // oxlint-disable-next-line typescript/no-explicit-any
86
- serializedEditorState: any;
87
- column: CellColumnId;
88
- index: CellIndex;
89
- isSetupCell: boolean;
90
- config: CellConfig;
91
- }[];
107
+ history: HistoryEntry[];
92
108
  /**
93
109
  * Key of cell to scroll to; typically set by actions that re-order the cell
94
110
  * array. Call the SCROLL_TO_TARGET action to scroll to the specified cell
@@ -158,6 +174,10 @@ export interface CreateNewCellAction {
158
174
  before: boolean;
159
175
  /** Initial code content for the new cell */
160
176
  code?: string;
177
+ /** Optional name for the new cell */
178
+ name?: string;
179
+ /** Optional cell configuration */
180
+ config?: CellConfig;
161
181
  /** The last executed code for the new cell */
162
182
  lastCodeRun?: string;
163
183
  /** Timestamp of the last execution */
@@ -187,11 +207,13 @@ const {
187
207
  cellId,
188
208
  before,
189
209
  code,
210
+ name,
211
+ config,
190
212
  lastCodeRun = null,
191
213
  lastExecutionTime = null,
192
214
  autoFocus = true,
193
215
  skipIfCodeExists = false,
194
- hideCode = false,
216
+ hideCode = undefined,
195
217
  } = action;
196
218
 
197
219
  let columnId: CellColumnId;
@@ -234,8 +256,12 @@ const {
234
256
  [newCellId]: createCell({
235
257
  id: newCellId,
236
258
  code,
259
+ name,
237
260
  lastCodeRun,
238
- config: createCellConfig({ hide_code: hideCode }),
261
+ config: createCellConfig({
262
+ ...config,
263
+ ...(hideCode != null && { hide_code: hideCode }),
264
+ }),
239
265
  lastExecutionTime,
240
266
  edited: Boolean(code) && code !== lastCodeRun,
241
267
  }),
@@ -417,6 +443,40 @@ const {
417
443
  scrollKey: null,
418
444
  };
419
445
  },
446
+ moveCellsRelativeTo: (
447
+ state,
448
+ action: {
449
+ cellIds: CellId[];
450
+ targetCellId: CellId;
451
+ position: "before" | "after";
452
+ previousPlacements?: Array<{ columnId: CellColumnId; index: CellIndex }>;
453
+ },
454
+ ) => {
455
+ const { cellIds, targetCellId, position, previousPlacements } = action;
456
+ if (cellIds.length === 0) {
457
+ return state;
458
+ }
459
+ const newCellIds = state.cellIds.moveCellsRelativeTo(
460
+ cellIds,
461
+ targetCellId,
462
+ position,
463
+ );
464
+ // Only record undo when caller provided full before-state
465
+ const canUndoMove =
466
+ previousPlacements && previousPlacements.length === cellIds.length;
467
+ const history = canUndoMove
468
+ ? [
469
+ ...state.history,
470
+ { type: "move" as const, cellIds, placements: previousPlacements },
471
+ ]
472
+ : state.history;
473
+ return {
474
+ ...state,
475
+ cellIds: newCellIds,
476
+ history,
477
+ scrollKey: null,
478
+ };
479
+ },
420
480
  dropCellOverColumn: (
421
481
  state,
422
482
  action: { cellId: CellId; columnId: CellColumnId },
@@ -659,6 +719,7 @@ const {
659
719
  history: [
660
720
  ...state.history,
661
721
  {
722
+ type: "delete",
662
723
  name: prevData.name,
663
724
  serializedEditorState: serializedEditorState,
664
725
  column: column.id,
@@ -675,7 +736,29 @@ const {
675
736
  return state;
676
737
  }
677
738
 
678
- const mostRecentlyDeleted = state.history[state.history.length - 1];
739
+ const last = state.history[state.history.length - 1];
740
+
741
+ if (last.type === "move") {
742
+ const { cellIds, placements } = last;
743
+ if (
744
+ cellIds.length === 0 ||
745
+ placements.length !== cellIds.length ||
746
+ cellIds.some((id) => !state.cellData[id])
747
+ ) {
748
+ return { ...state, history: state.history.slice(0, -1) };
749
+ }
750
+ const toRestore = cellIds.map((id, i) => ({
751
+ id,
752
+ columnId: placements[i].columnId,
753
+ index: placements[i].index,
754
+ }));
755
+ return {
756
+ ...state,
757
+ cellIds: state.cellIds.placeCells(toRestore),
758
+ history: state.history.slice(0, -1),
759
+ scrollKey: cellIds[0] ?? null,
760
+ };
761
+ }
679
762
 
680
763
  const {
681
764
  name,
@@ -684,7 +767,7 @@ const {
684
767
  index,
685
768
  isSetupCell,
686
769
  config,
687
- } = mostRecentlyDeleted;
770
+ } = last;
688
771
 
689
772
  const cellId = isSetupCell ? SETUP_CELL_ID : CellId.create();
690
773
  const undoCell = createCell({
@@ -790,7 +873,7 @@ const {
790
873
  cellReducer: (cell) => {
791
874
  return {
792
875
  ...cell,
793
- config: { ...cell.config, ...config },
876
+ config: createCellConfig({ ...cell.config, ...config }),
794
877
  };
795
878
  },
796
879
  });
@@ -1633,6 +1716,8 @@ export const canUndoDeletesAtom = atom((get) =>
1633
1716
  canUndoDeletes(get(notebookAtom)),
1634
1717
  );
1635
1718
 
1719
+ export const undoLabelAtom = atom((get) => getUndoLabel(get(notebookAtom)));
1720
+
1636
1721
  export const needsRunAtom = atom((get) => notebookNeedsRun(get(notebookAtom)));
1637
1722
 
1638
1723
  export const cellErrorsAtom = atom((get) => {
@@ -218,13 +218,14 @@ export function toDocumentChanges(
218
218
  ];
219
219
  }
220
220
 
221
- // dropCellOverCell/dropCellOverColumn/moveCellToIndex → set-config + reorder-cells
221
+ // dropCellOverCell/dropCellOverColumn/moveCellToIndex/moveCellsRelativeTo → set-config + reorder-cells
222
222
  // Drag-and-drop reorders can move cells within or across columns.
223
223
  // We emit config changes for cells whose column changed, then
224
224
  // the full ordering.
225
225
  case "dropCellOverCell":
226
226
  case "dropCellOverColumn":
227
227
  case "moveCellToIndex":
228
+ case "moveCellsRelativeTo":
228
229
  return columnChanges(prevState, newState);
229
230
 
230
231
  // updateCellCode → set-code
@@ -302,6 +303,10 @@ export function toDocumentChanges(
302
303
  case "undoDeleteCell": {
303
304
  const changes = newCellChanges(prevState, newState);
304
305
  const colChanges = columnChanges(prevState, newState);
306
+ // Undo-cut has no new cells — always emit reorder to sync the move.
307
+ if (changes.length === 0) {
308
+ return colChanges;
309
+ }
305
310
  // Only include column changes if layout actually changed
306
311
  // (colChanges always has at least a reorder-cells change)
307
312
  return colChanges.length > 1 ? [...changes, ...colChanges] : changes;
@@ -0,0 +1,55 @@
1
+ /* Copyright 2026 Marimo. All rights reserved. */
2
+
3
+ import { atom, useAtomValue } from "jotai";
4
+ import type { CellId } from "@/core/cells/ids";
5
+ import { createReducerAndAtoms } from "@/utils/createReducer";
6
+
7
+ interface PendingCutState {
8
+ cellIds: Set<CellId>;
9
+ }
10
+
11
+ const initialState = (): PendingCutState => ({
12
+ cellIds: new Set(),
13
+ });
14
+
15
+ const {
16
+ valueAtom: pendingCutStateAtom,
17
+ useActions: usePendingCutActionsInternal,
18
+ } = createReducerAndAtoms(initialState, {
19
+ markForCut: (_state, action: { cellIds: CellId[] }) => {
20
+ return {
21
+ cellIds: new Set(action.cellIds),
22
+ };
23
+ },
24
+ clear: () => {
25
+ return initialState();
26
+ },
27
+ });
28
+
29
+ export { pendingCutStateAtom };
30
+
31
+ export const pendingCutCellIdsAtom = atom(
32
+ (get) => get(pendingCutStateAtom).cellIds,
33
+ );
34
+
35
+ export const clearPendingCutAtom = atom(null, (_get, set) => {
36
+ set(pendingCutStateAtom, initialState());
37
+ });
38
+
39
+ export function usePendingCutActions() {
40
+ return usePendingCutActionsInternal();
41
+ }
42
+
43
+ export function useIsPendingCut(cellId: CellId): boolean {
44
+ const cellIds = useAtomValue(pendingCutCellIdsAtom);
45
+ return cellIds.has(cellId);
46
+ }
47
+
48
+ export function usePendingCutState() {
49
+ return useAtomValue(pendingCutStateAtom);
50
+ }
51
+
52
+ export function useHasPendingCut(): boolean {
53
+ const state = useAtomValue(pendingCutStateAtom);
54
+ return state.cellIds.size > 0;
55
+ }
@@ -65,6 +65,17 @@ export function canUndoDeletes(state: NotebookState) {
65
65
  return state.history.length > 0;
66
66
  }
67
67
 
68
+ /**
69
+ * Label for the undo action based on the last history entry type.
70
+ */
71
+ export function getUndoLabel(state: NotebookState): string {
72
+ const last = state.history[state.history.length - 1];
73
+ if (!last) {
74
+ return "Undo cell deletion";
75
+ }
76
+ return last.type === "move" ? "Undo move" : "Undo cell deletion";
77
+ }
78
+
68
79
  /**
69
80
  * Get the status of the descendants of the given cell.
70
81
  */
@@ -10,6 +10,10 @@ import {
10
10
  } from "@codemirror/view";
11
11
  import { createTracebackInfoAtom } from "@/core/cells/cells";
12
12
  import { type CellId, HTMLCellId, SCRATCH_CELL_ID } from "@/core/cells/ids";
13
+ import {
14
+ clearPendingCutAtom,
15
+ pendingCutCellIdsAtom,
16
+ } from "@/core/cells/pending-cut-service";
13
17
  import { loroSyncAnnotation } from "@/core/codemirror/rtc/loro/sync";
14
18
  import type { KeymapConfig } from "@/core/config/config-schema";
15
19
  import type { HotkeyProvider } from "@/core/hotkeys/hotkeys";
@@ -326,6 +330,12 @@ function cellCodeEditing(hotkeys: HotkeyProvider): Extension[] {
326
330
  code: nextCode,
327
331
  formattingChange: isFormattingChange,
328
332
  });
333
+
334
+ // Clear pending cut state if this cell was marked for cut
335
+ const pendingCutCellIds = store.get(pendingCutCellIdsAtom);
336
+ if (pendingCutCellIds.has(cellId)) {
337
+ store.set(clearPendingCutAtom);
338
+ }
329
339
  }
330
340
  });
331
341
 
@@ -101,6 +101,158 @@ print(x)`);
101
101
  `);
102
102
  });
103
103
 
104
+ test("selects the nearest in-scope local definition", async () => {
105
+ const code = `\
106
+ a = 10
107
+
108
+ def my_func():
109
+ a = 20
110
+ print(a)`;
111
+ view = createEditor(code);
112
+ const result = goToVariableDefinition(view, "a", code.lastIndexOf("a"));
113
+
114
+ expect(result).toBe(true);
115
+ await tick();
116
+ expect(renderEditorView(view)).toMatchInlineSnapshot(`
117
+ "
118
+ a = 10
119
+
120
+ def my_func():
121
+ a = 20
122
+ ^
123
+ print(a)
124
+ "
125
+ `);
126
+ });
127
+
128
+ test("selects the nearest in-scope parameter definition", async () => {
129
+ const code = `\
130
+ a = 10
131
+
132
+ def my_func(a):
133
+ print(a)`;
134
+ view = createEditor(code);
135
+ const result = goToVariableDefinition(view, "a", code.lastIndexOf("a"));
136
+
137
+ expect(result).toBe(true);
138
+ await tick();
139
+ expect(renderEditorView(view)).toMatchInlineSnapshot(`
140
+ "
141
+ a = 10
142
+
143
+ def my_func(a):
144
+ ^
145
+ print(a)
146
+ "
147
+ `);
148
+ });
149
+
150
+ test("selects the comprehension target inside a set comprehension", async () => {
151
+ const code = `\
152
+ x = 100
153
+ s = {x for x in range(10)}`;
154
+ view = createEditor(code);
155
+ // Go-to-definition on the `x` before `for` (the expression part of the
156
+ // comprehension).
157
+ const usagePosition = code.indexOf("{x") + 1;
158
+ const result = goToVariableDefinition(view, "x", usagePosition);
159
+
160
+ expect(result).toBe(true);
161
+ await tick();
162
+ // Should jump to the comprehension target `x` (after `for`), not the
163
+ // outer `x = 100`. The Lezer Python grammar emits
164
+ // `SetComprehensionExpression`, and we now correctly match it in
165
+ // SCOPE_CREATING_NODES, so the comprehension creates a scope and the
166
+ // for-target is collected correctly.
167
+ expect(renderEditorView(view)).toMatchInlineSnapshot(`
168
+ "
169
+ x = 100
170
+ s = {x for x in range(10)}
171
+ ^
172
+ "
173
+ `);
174
+ });
175
+
176
+ test("selects the comprehension target inside a dict comprehension", async () => {
177
+ const code = `\
178
+ x = 100
179
+ d = {x: x for x in range(10)}`;
180
+ view = createEditor(code);
181
+ const usagePosition = code.indexOf("{x") + 1;
182
+ const result = goToVariableDefinition(view, "x", usagePosition);
183
+
184
+ expect(result).toBe(true);
185
+ await tick();
186
+ // Positive control: `DictionaryComprehensionExpression` matches the grammar
187
+ // and is in SCOPE_CREATING_NODES, so this should jump to the comprehension
188
+ // target `x` (after `for`).
189
+ expect(renderEditorView(view)).toMatchInlineSnapshot(`
190
+ "
191
+ x = 100
192
+ d = {x: x for x in range(10)}
193
+ ^
194
+ "
195
+ `);
196
+ });
197
+
198
+ test("skips enclosing class scope when resolving from inside a method", async () => {
199
+ const code = `\
200
+ x = 100
201
+ class Foo:
202
+ x = 10
203
+ def method(self):
204
+ return x`;
205
+ view = createEditor(code);
206
+ // Go-to-definition on the `x` inside `return x`.
207
+ const usagePosition = code.lastIndexOf("x");
208
+ const result = goToVariableDefinition(view, "x", usagePosition);
209
+
210
+ expect(result).toBe(true);
211
+ await tick();
212
+ // Should jump to `x = 100` at module scope. In Python, methods do NOT see
213
+ // their enclosing class body's names — class scopes are skipped in LEGB
214
+ // lookup once a function boundary has been crossed. We now correctly skip
215
+ // ClassDefinition in getScopeChain once a function boundary is crossed.
216
+ expect(renderEditorView(view)).toMatchInlineSnapshot(`
217
+ "
218
+ x = 100
219
+ ^
220
+ class Foo:
221
+ x = 10
222
+ def method(self):
223
+ return x
224
+ "
225
+ `);
226
+ });
227
+
228
+ test("resolves a global forward-reference from inside a function", async () => {
229
+ const code = `\
230
+ def foo():
231
+ return a
232
+
233
+ a = 10`;
234
+ view = createEditor(code);
235
+ // Go-to-definition on the `a` inside `return a`.
236
+ const usagePosition = code.indexOf("return a") + "return ".length;
237
+ const result = goToVariableDefinition(view, "a", usagePosition);
238
+
239
+ expect(result).toBe(true);
240
+ await tick();
241
+ // Should jump to `a = 10` at the bottom. Python allows forward references
242
+ // from within nested functions to module-level names. We now correctly omit
243
+ // "global" from POSITION_SENSITIVE_SCOPES, allowing forward references to
244
+ // global-level definitions declared after the usage position.
245
+ expect(renderEditorView(view)).toMatchInlineSnapshot(`
246
+ "
247
+ def foo():
248
+ return a
249
+
250
+ a = 10
251
+ ^
252
+ "
253
+ `);
254
+ });
255
+
104
256
  test("selects outer-scope function declaration", async () => {
105
257
  view = createEditor(`\
106
258
  def x():
@@ -0,0 +1,99 @@
1
+ /* Copyright 2026 Marimo. All rights reserved. */
2
+
3
+ import { python } from "@codemirror/lang-python";
4
+ import { EditorState } from "@codemirror/state";
5
+ import { EditorView } from "@codemirror/view";
6
+ import { afterEach, describe, expect, test } from "vitest";
7
+ import { cellId, variableName } from "@/__tests__/branded";
8
+ import { initialNotebookState, notebookAtom } from "@/core/cells/cells";
9
+ import { store } from "@/core/state/jotai";
10
+ import { variablesAtom } from "@/core/variables/state";
11
+ import { goToDefinitionAtCursorPosition } from "../utils";
12
+
13
+ async function tick(): Promise<void> {
14
+ await new Promise((resolve) => requestAnimationFrame(resolve));
15
+ }
16
+
17
+ function createEditor(content: string, selection: number) {
18
+ const state = EditorState.create({
19
+ doc: content,
20
+ selection: { anchor: selection },
21
+ extensions: [python()],
22
+ });
23
+
24
+ return new EditorView({
25
+ state,
26
+ parent: document.body,
27
+ });
28
+ }
29
+
30
+ const views: EditorView[] = [];
31
+
32
+ afterEach(() => {
33
+ for (const view of views.splice(0)) {
34
+ view.destroy();
35
+ }
36
+
37
+ store.set(notebookAtom, initialNotebookState());
38
+ store.set(variablesAtom, {});
39
+ });
40
+
41
+ describe("goToDefinitionAtCursorPosition", () => {
42
+ test("prefers the current-cell local definition over a reactive global", async () => {
43
+ const globalCell = cellId("global-cell");
44
+ const localCell = cellId("local-cell");
45
+ const globalCode = `\
46
+ a = 10
47
+ print(a)`;
48
+ const localCode = `\
49
+ def test():
50
+ a = 20
51
+ print(a)`;
52
+
53
+ const globalView = createEditor(globalCode, globalCode.length);
54
+ const localView = createEditor(localCode, localCode.lastIndexOf("a"));
55
+ views.push(globalView, localView);
56
+
57
+ const notebook = initialNotebookState();
58
+ notebook.cellHandles[globalCell] = {
59
+ current: { editorView: globalView, editorViewOrNull: globalView },
60
+ };
61
+ notebook.cellHandles[localCell] = {
62
+ current: { editorView: localView, editorViewOrNull: localView },
63
+ };
64
+
65
+ store.set(notebookAtom, notebook);
66
+ store.set(variablesAtom, {
67
+ [variableName("a")]: {
68
+ dataType: "int",
69
+ declaredBy: [globalCell],
70
+ name: variableName("a"),
71
+ usedBy: [localCell],
72
+ value: "10",
73
+ },
74
+ });
75
+
76
+ const result = goToDefinitionAtCursorPosition(localView);
77
+
78
+ expect(result).toBe(true);
79
+ await tick();
80
+ expect(localView.state.selection.main.head).toBe(
81
+ localCode.indexOf("a = 20"),
82
+ );
83
+ expect(globalView.state.selection.main.head).toBe(globalCode.length);
84
+ });
85
+
86
+ test("keeps private variables within the current cell", async () => {
87
+ const code = `\
88
+ _x = 10
89
+ output = _x + 10`;
90
+ const view = createEditor(code, code.lastIndexOf("_x"));
91
+ views.push(view);
92
+
93
+ const result = goToDefinitionAtCursorPosition(view);
94
+
95
+ expect(result).toBe(true);
96
+ await tick();
97
+ expect(view.state.selection.main.head).toBe(code.indexOf("_x = 10"));
98
+ });
99
+ });