@marimo-team/frontend 0.15.3 → 0.15.5

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 (474) hide show
  1. package/dist/assets/{ConnectedDataExplorerComponent-D-5E8ink.js → ConnectedDataExplorerComponent-Cn5-l2X1.js} +2 -2
  2. package/dist/assets/{ImageComparisonComponent-lZA6EaZ7.js → ImageComparisonComponent-CEXMKKA4.js} +1 -1
  3. package/dist/assets/{VegaLite-C80SZuda.js → VegaLite-Bt14Ds9k.js} +6 -6
  4. package/dist/assets/_baseEach-C1FLm7WW.js +1 -0
  5. package/dist/assets/_baseMap-DBVArUYD.js +1 -0
  6. package/dist/assets/_baseUniq-Dk7ZPJ3N.js +1 -0
  7. package/dist/assets/_createAggregator-Bn38fDd3.js +1 -0
  8. package/dist/assets/abap-DnJxzdy9.js +1 -0
  9. package/dist/assets/actionscript-3-CKUqbIUM.js +1 -0
  10. package/dist/assets/ada-iG1FnIvR.js +1 -0
  11. package/dist/assets/agent-panel-COUYnuIK.js +475 -0
  12. package/dist/assets/agent-panel-DpQ6muj-.css +1 -0
  13. package/dist/assets/andromeeda-C-Jbm3Hp.js +1 -0
  14. package/dist/assets/angular-html-BZhSV2-l.js +1 -0
  15. package/dist/assets/angular-ts-DRQ-j7PL.js +1 -0
  16. package/dist/assets/{any-language-editor-Cn0Ju0SA.js → any-language-editor-DiwNT6zp.js} +1 -1
  17. package/dist/assets/apache-CdTKWnKT.js +1 -0
  18. package/dist/assets/apex-3xxtq2mv.js +1 -0
  19. package/dist/assets/apl-BnBkWLuz.js +1 -0
  20. package/dist/assets/applescript-BlLNmGTp.js +1 -0
  21. package/dist/assets/ara-Ba3fhlsS.js +1 -0
  22. package/dist/assets/arc-Cuwikxov.js +1 -0
  23. package/dist/assets/architectureDiagram-W76B3OCA-DBzWQKKu.js +36 -0
  24. package/dist/assets/asciidoc-XTVL4-GN.js +1 -0
  25. package/dist/assets/asm-CHX6lpGW.js +1 -0
  26. package/dist/assets/astro-CXYfh229.js +1 -0
  27. package/dist/assets/aurora-x-D-2ljcwZ.js +1 -0
  28. package/dist/assets/awk-XRrwoikR.js +1 -0
  29. package/dist/assets/ayu-dark-Cv9koXgw.js +1 -0
  30. package/dist/assets/ballerina-Dh0JsEtz.js +1 -0
  31. package/dist/assets/bat-BVu0TwaT.js +1 -0
  32. package/dist/assets/beancount-BuQJKJpV.js +1 -0
  33. package/dist/assets/berry-D4qT7XM1.js +1 -0
  34. package/dist/assets/{between-horizontal-start-BrmUizGs.js → between-horizontal-start-FyewyCGn.js} +1 -1
  35. package/dist/assets/bibtex-CGjxJ4Zd.js +1 -0
  36. package/dist/assets/bicep-DysT5qaJ.js +1 -0
  37. package/dist/assets/blade-CkGRa-l8.js +1 -0
  38. package/dist/assets/{blockDiagram-QIGZ2CNN-D08JxTYL.js → blockDiagram-QIGZ2CNN-BrOkAf_c.js} +4 -4
  39. package/dist/assets/bsl-DGicdwC0.js +1 -0
  40. package/dist/assets/c-BmJt9k-y.js +1 -0
  41. package/dist/assets/{c4Diagram-FPNF74CW-B5Ki5s6c.js → c4Diagram-FPNF74CW-BHPzDxE2.js} +1 -1
  42. package/dist/assets/cadence-CWn_mfEc.js +1 -0
  43. package/dist/assets/cairo-Dz8fl918.js +1 -0
  44. package/dist/assets/catppuccin-frappe-BBxmzUt6.js +1 -0
  45. package/dist/assets/catppuccin-latte-Jep7L2Wt.js +1 -0
  46. package/dist/assets/catppuccin-macchiato-CIUZ1G5V.js +1 -0
  47. package/dist/assets/catppuccin-mocha-NBseiqgx.js +1 -0
  48. package/dist/assets/channel-CjhbjOv4.js +1 -0
  49. package/dist/assets/chat-panel-BPXKoTnZ.js +7 -0
  50. package/dist/assets/chunk-4BX2VUAB-DLxaCNYh.js +1 -0
  51. package/dist/assets/chunk-55IACEB6-DdzvO3HR.js +1 -0
  52. package/dist/assets/{chunk-FMBD7UC4-CPtXh_Tc.js → chunk-FMBD7UC4-R5o-nSiG.js} +1 -1
  53. package/dist/assets/{chunk-K7UQS3LO-H1GayBnp.js → chunk-K7UQS3LO-DxaMrGgG.js} +1 -1
  54. package/dist/assets/chunk-QN33PNHL-DqS9-FYm.js +1 -0
  55. package/dist/assets/chunk-QZHKN3VN-BZ-TzajS.js +1 -0
  56. package/dist/assets/{chunk-TVAH2DTR-CKpRI29L.js → chunk-TVAH2DTR-BsgP2dyv.js} +5 -5
  57. package/dist/assets/{chunk-TZMSLE5B-CnU05RC1.js → chunk-TZMSLE5B-D-h3ahXI.js} +1 -1
  58. package/dist/assets/{circle-play-Dizu3hR4.js → circle-play-CQtRZ-rT.js} +1 -1
  59. package/dist/assets/clarity-DF5_RAtY.js +1 -0
  60. package/dist/assets/classDiagram-KNZD7YFC-DHs5cFzy.js +1 -0
  61. package/dist/assets/classDiagram-v2-RKCZMP56-DHs5cFzy.js +1 -0
  62. package/dist/assets/{clear-button-BASAgaZM.js → clear-button-BY6Z_ViL.js} +1 -1
  63. package/dist/assets/clojure-BjI0Knrv.js +1 -0
  64. package/dist/assets/clone-DM1YNjEn.js +1 -0
  65. package/dist/assets/cmake-BYiqpiH1.js +1 -0
  66. package/dist/assets/cobol-Dt3m7Jkx.js +1 -0
  67. package/dist/assets/codeowners-L91meNbn.js +1 -0
  68. package/dist/assets/codeql-Cd-JFsJB.js +1 -0
  69. package/dist/assets/coffee-DgxxYT5L.js +1 -0
  70. package/dist/assets/{command-palette-6abbxoUb.js → command-palette-S0bzQp7v.js} +1 -1
  71. package/dist/assets/{common-BxprsFNA.js → common-B8U9k2Ly.js} +1 -1
  72. package/dist/assets/common-lisp-DOi1njVG.js +1 -0
  73. package/dist/assets/{compile-BGXIlCMz.js → compile-Ct_jzdKr.js} +1 -1
  74. package/dist/assets/coq-BfbrVLCY.js +1 -0
  75. package/dist/assets/cose-bilkent-S5V4N54A-wz1Sfx7j.js +1 -0
  76. package/dist/assets/cpp-BmKY377x.js +1 -0
  77. package/dist/assets/crystal-DB6V90z1.js +1 -0
  78. package/dist/assets/csharp-yFVQ185C.js +1 -0
  79. package/dist/assets/css-l46fsARh.js +1 -0
  80. package/dist/assets/csv-DXKU4rRd.js +1 -0
  81. package/dist/assets/cue-zmT78Agv.js +1 -0
  82. package/dist/assets/cypher-bkHSskm3.js +1 -0
  83. package/dist/assets/d-vs9xsbRV.js +1 -0
  84. package/dist/assets/dagre-5GWH7T2D-BfpcVBgq.js +4 -0
  85. package/dist/assets/dark-plus-C3mMm8J8.js +1 -0
  86. package/dist/assets/dart-BMkYYGiN.js +1 -0
  87. package/dist/assets/{data-grid-overlay-editor-CJkpT222.js → data-grid-overlay-editor-BN_wulc3.js} +1 -1
  88. package/dist/assets/{datasources-panel-HITG8eye.js → datasources-panel-DfuURLJw.js} +1 -1
  89. package/dist/assets/dax-D135z3aS.js +1 -0
  90. package/dist/assets/{dependency-graph-panel-D9np9LSb.js → dependency-graph-panel-BOmSCZf7.js} +4 -4
  91. package/dist/assets/desktop-CigPEpQ5.js +1 -0
  92. package/dist/assets/diagram-N5W7TBWH-Bf0oqqQh.js +24 -0
  93. package/dist/assets/diagram-QEK2KX5R-ZTc3qikh.js +43 -0
  94. package/dist/assets/diagram-S2PKOQOG-tLScBy7Z.js +24 -0
  95. package/dist/assets/diff-Beq1YlA8.js +1 -0
  96. package/dist/assets/docker-V5Al5bpF.js +1 -0
  97. package/dist/assets/{documentation-panel-bTy-gCid.js → documentation-panel-BxjJO_Gw.js} +1 -1
  98. package/dist/assets/dotenv-D9G8sA2m.js +1 -0
  99. package/dist/assets/dracula-BzJJZx-M.js +1 -0
  100. package/dist/assets/dracula-soft-BXkSAIEj.js +1 -0
  101. package/dist/assets/dream-maker-BsoKROiO.js +1 -0
  102. package/dist/assets/edge-Brl-y200.js +1 -0
  103. package/dist/assets/{edit-page-DVsJ5OUI.js → edit-page-DJ8kJZ9w.js} +35 -35
  104. package/dist/assets/elixir-CGzfkNtR.js +1 -0
  105. package/dist/assets/{ellipsis-vertical-GW_YrU8C.js → ellipsis-vertical-UHbmjI2n.js} +1 -1
  106. package/dist/assets/elm-DmpuOW2E.js +1 -0
  107. package/dist/assets/emacs-lisp-BcpYGiHp.js +1 -0
  108. package/dist/assets/empty-state-BIBXzY_0.js +1 -0
  109. package/dist/assets/{erDiagram-AWTI2OKA-lCwUhmIf.js → erDiagram-AWTI2OKA-E84mAle_.js} +1 -1
  110. package/dist/assets/erb-BNAqOH5i.js +1 -0
  111. package/dist/assets/erlang-DAw79KxH.js +1 -0
  112. package/dist/assets/{error-panel-Cnlgqo61.js → error-panel-MEvQ6K7h.js} +2 -2
  113. package/dist/assets/everforest-dark-BgDCqdQA.js +1 -0
  114. package/dist/assets/everforest-light-C8M2exoo.js +1 -0
  115. package/dist/assets/fennel-qzPJJAAI.js +1 -0
  116. package/dist/assets/file-explorer-panel-CzNUJ63G.js +1 -0
  117. package/dist/assets/fish-BTv9qkVe.js +1 -0
  118. package/dist/assets/{flowDiagram-PVAE7QVJ-DnG1jaGB.js → flowDiagram-PVAE7QVJ-DfbIRSAW.js} +1 -1
  119. package/dist/assets/fluent-BsukS3Co.js +1 -0
  120. package/dist/assets/fortran-fixed-form-D_2otJTs.js +1 -0
  121. package/dist/assets/fortran-free-form-Ix_0F1Zz.js +1 -0
  122. package/dist/assets/fsharp-DmSnwM-W.js +1 -0
  123. package/dist/assets/{ganttDiagram-OWAHRB6G-CX39q7PN.js → ganttDiagram-OWAHRB6G-DR4HZ1z_.js} +3 -3
  124. package/dist/assets/gdresource-BLuZCTp3.js +1 -0
  125. package/dist/assets/gdscript-fffAh1pn.js +1 -0
  126. package/dist/assets/gdshader-BC7WJXp9.js +1 -0
  127. package/dist/assets/genie-IZOju1hG.js +1 -0
  128. package/dist/assets/gherkin-DUpgZfGr.js +1 -0
  129. package/dist/assets/git-commit-Bptnmh-c.js +1 -0
  130. package/dist/assets/git-rebase-CqNhyBhE.js +1 -0
  131. package/dist/assets/gitGraphDiagram-NY62KEGX-C1t6QtVa.js +65 -0
  132. package/dist/assets/github-dark-DHJKELXO.js +1 -0
  133. package/dist/assets/github-dark-default-Cuk6v7N8.js +1 -0
  134. package/dist/assets/github-dark-dimmed-DH5Ifo-i.js +1 -0
  135. package/dist/assets/github-dark-high-contrast-E3gJ1_iC.js +1 -0
  136. package/dist/assets/github-light-DAi9KRSo.js +1 -0
  137. package/dist/assets/github-light-default-D7oLnXFd.js +1 -0
  138. package/dist/assets/github-light-high-contrast-BfjtVDDH.js +1 -0
  139. package/dist/assets/gleam-CCCEh_av.js +1 -0
  140. package/dist/assets/{glide-data-editor-l-bMUJyX.js → glide-data-editor-nNmo1lPq.js} +11 -11
  141. package/dist/assets/glimmer-js-CamsSOgS.js +1 -0
  142. package/dist/assets/glimmer-ts-DpQMos9P.js +1 -0
  143. package/dist/assets/glsl-BDbjGBhJ.js +1 -0
  144. package/dist/assets/gnuplot-D0FoiB-W.js +1 -0
  145. package/dist/assets/go-BR7YH85S.js +1 -0
  146. package/dist/assets/graph-CssCVWIq.js +1 -0
  147. package/dist/assets/graphql-DMns_A3G.js +1 -0
  148. package/dist/assets/groovy-D9sPn4Z-.js +1 -0
  149. package/dist/assets/gruvbox-dark-hard-D1uDOp7C.js +1 -0
  150. package/dist/assets/gruvbox-dark-medium-DkhsQLT2.js +1 -0
  151. package/dist/assets/gruvbox-dark-soft-CcyOm34o.js +1 -0
  152. package/dist/assets/gruvbox-light-hard-DKzvysjW.js +1 -0
  153. package/dist/assets/gruvbox-light-medium-DPcUKYIF.js +1 -0
  154. package/dist/assets/gruvbox-light-soft-CGqH5EJj.js +1 -0
  155. package/dist/assets/hack-CXH7pT2m.js +1 -0
  156. package/dist/assets/haml-DiuhmbKg.js +1 -0
  157. package/dist/assets/handlebars-PuluTGUb.js +1 -0
  158. package/dist/assets/haskell-Cp0NQEkn.js +1 -0
  159. package/dist/assets/haxe-D-PmAGDa.js +1 -0
  160. package/dist/assets/hcl-DRMo6eis.js +1 -0
  161. package/dist/assets/hjson-BPEpXUFQ.js +1 -0
  162. package/dist/assets/hlsl-B-PjNM4a.js +1 -0
  163. package/dist/assets/{home-page-B1kjvR5n.js → home-page-9eW6qida.js} +3 -3
  164. package/dist/assets/houston-DnULxvSX.js +1 -0
  165. package/dist/assets/html-ReiWYoHo.js +1 -0
  166. package/dist/assets/html-derivative-BEFkAAPd.js +1 -0
  167. package/dist/assets/http-BPFbEDC3.js +1 -0
  168. package/dist/assets/hxml-DB3_nACV.js +1 -0
  169. package/dist/assets/hy-CLIvbAhW.js +1 -0
  170. package/dist/assets/imba-B-tO30Ge.js +1 -0
  171. package/dist/assets/{index-DXC6BC43.js → index-B1_GXGaP.js} +1 -1
  172. package/dist/assets/index-B7yXbrLa.js +1 -0
  173. package/dist/assets/{index-CuFO3AB8.js → index-B8llrTSo.js} +1 -1
  174. package/dist/assets/{index-Co5sPjJc.js → index-BAH034Ue.js} +1 -1
  175. package/dist/assets/{index-Dut0n0LK.js → index-BFSnz7iM.js} +1 -1
  176. package/dist/assets/{index-ByYzywJk.js → index-BLu5CX6z.js} +1 -1
  177. package/dist/assets/index-Bq516OmX.js +1 -0
  178. package/dist/assets/index-CB2pnVQG.js +1 -0
  179. package/dist/assets/{index-QpAlOfLT.js → index-CPN7TRA1.js} +1 -1
  180. package/dist/assets/{index-C5GV-DhP.js → index-CSgxTUzD.js} +1 -1
  181. package/dist/assets/index-CknhX2Vy.css +1 -0
  182. package/dist/assets/index-DMomwMcN.js +1 -0
  183. package/dist/assets/{index-OdZ649Ww.js → index-DSU75csX.js} +1 -1
  184. package/dist/assets/{index-DXqCSfYv.js → index-DWOaniGT.js} +1 -1
  185. package/dist/assets/index-DcCIe7np.js +28 -0
  186. package/dist/assets/index-DqzMPAC8.js +7 -0
  187. package/dist/assets/{index-BTeNT_Tt.js → index-Dt9UWeWn.js} +1 -1
  188. package/dist/assets/{index-CuVt_RTJ.js → index-DyLSuOH1.js} +1 -1
  189. package/dist/assets/{index-StZz2sD-.js → index-OC46250R.js} +175 -175
  190. package/dist/assets/{index-DAhZ64xY.js → index-VPWqq2Pg.js} +1 -1
  191. package/dist/assets/index-c6If577Q.js +1 -0
  192. package/dist/assets/{index-CiKUoc5G.js → index-uacyUula.js} +1 -1
  193. package/dist/assets/infoDiagram-STP46IZ2-CwiAoz9f.js +2 -0
  194. package/dist/assets/ini-Bpxu4Zsc.js +1 -0
  195. package/dist/assets/java-DtRXFtDl.js +1 -0
  196. package/dist/assets/javascript-CY0YvwoL.js +1 -0
  197. package/dist/assets/jinja-CXJbPSuL.js +1 -0
  198. package/dist/assets/jison-iRP-Iv-P.js +1 -0
  199. package/dist/assets/{journeyDiagram-BIP6EPQ6-Ducmkxc0.js → journeyDiagram-BIP6EPQ6-BBiFyygf.js} +1 -1
  200. package/dist/assets/json-LWN7Ml79.js +1 -0
  201. package/dist/assets/json5-CgCB487x.js +1 -0
  202. package/dist/assets/jsonc-BXrjvC_e.js +1 -0
  203. package/dist/assets/jsonl-D5dm1SHP.js +1 -0
  204. package/dist/assets/jsonnet-B60UklUs.js +1 -0
  205. package/dist/assets/jssm-CsqlGknB.js +1 -0
  206. package/dist/assets/jsx-g2NrEQII.js +1 -0
  207. package/dist/assets/julia-BabrhEml.js +1 -0
  208. package/dist/assets/kanagawa-dragon-CkXjmgJE.js +1 -0
  209. package/dist/assets/kanagawa-lotus-CfQXZHmo.js +1 -0
  210. package/dist/assets/kanagawa-wave-DWedfzmr.js +1 -0
  211. package/dist/assets/{kanban-definition-6OIFK2YF-Drd9VUQq.js → kanban-definition-6OIFK2YF-DhgA6Nt6.js} +5 -5
  212. package/dist/assets/kotlin-DiV2Dt9D.js +1 -0
  213. package/dist/assets/kusto-KSLuQd98.js +1 -0
  214. package/dist/assets/laserwave-DUszq2jm.js +1 -0
  215. package/dist/assets/latex-CCwiU5tQ.js +1 -0
  216. package/dist/assets/{layout-DYVxODOR.js → layout-DpQrxGW-.js} +1 -1
  217. package/dist/assets/lean-C20waPKk.js +1 -0
  218. package/dist/assets/less-DKKxO4Pm.js +1 -0
  219. package/dist/assets/light-plus-B7mTdjB0.js +1 -0
  220. package/dist/assets/linear-NsreOeBF.js +1 -0
  221. package/dist/assets/links-CbvGxbsJ.js +7 -0
  222. package/dist/assets/liquid-QTP3a8yd.js +1 -0
  223. package/dist/assets/llvm-CfjccL00.js +1 -0
  224. package/dist/assets/log-CnKjEmrw.js +1 -0
  225. package/dist/assets/logo-BmG1tMr6.js +1 -0
  226. package/dist/assets/{logs-panel-BdZwSU1-.js → logs-panel-B9SmTZAW.js} +1 -1
  227. package/dist/assets/lua-B09NiSMa.js +1 -0
  228. package/dist/assets/luau-C2pF66fA.js +1 -0
  229. package/dist/assets/make-Ccm3NI5i.js +1 -0
  230. package/dist/assets/markdown-DY93LJPj.js +1 -0
  231. package/dist/assets/marko-CgCapwG0.js +1 -0
  232. package/dist/assets/material-theme-D5KoaKCx.js +1 -0
  233. package/dist/assets/material-theme-darker-BfHTSMKl.js +1 -0
  234. package/dist/assets/material-theme-lighter-B0m2ddpp.js +1 -0
  235. package/dist/assets/material-theme-ocean-CyktbL80.js +1 -0
  236. package/dist/assets/material-theme-palenight-Csfq5Kiy.js +1 -0
  237. package/dist/assets/matlab-nYX3zffi.js +1 -0
  238. package/dist/assets/mdc-CVidKc4b.js +1 -0
  239. package/dist/assets/mdx-C8C9IGe9.js +1 -0
  240. package/dist/assets/mermaid-DSt0r6IQ.js +1 -0
  241. package/dist/assets/mermaid-ZuTRVWig.js +1 -0
  242. package/dist/assets/{mermaid-JltzhJwZ.js → mermaid.core-4nVOEVX3.js} +44 -44
  243. package/dist/assets/min-D259kI3t.js +1 -0
  244. package/dist/assets/min-dark-CafNBF8u.js +1 -0
  245. package/dist/assets/min-light-CTRr51gU.js +1 -0
  246. package/dist/assets/{mindmap-definition-Q6HEUPPD-DVMI0DKx.js → mindmap-definition-Q6HEUPPD-CVLQNn1q.js} +1 -1
  247. package/dist/assets/mipsasm-BjAqecqh.js +1 -0
  248. package/dist/assets/mojo-gr1MWCNv.js +1 -0
  249. package/dist/assets/monokai-D4h5O-jR.js +1 -0
  250. package/dist/assets/move-BJN6DhLB.js +1 -0
  251. package/dist/assets/narrat-BTSicUR-.js +1 -0
  252. package/dist/assets/nextflow-CvZ2-N7x.js +1 -0
  253. package/dist/assets/nginx-CtwUG8yW.js +1 -0
  254. package/dist/assets/night-owl-C39BiMTA.js +1 -0
  255. package/dist/assets/nim-BCqJOqd2.js +1 -0
  256. package/dist/assets/nix-DiXPdoNa.js +1 -0
  257. package/dist/assets/nord-Ddv68eIx.js +1 -0
  258. package/dist/assets/{number-overlay-editor-BolEVFqu.js → number-overlay-editor-CzRzXLcd.js} +1 -1
  259. package/dist/assets/nushell-a9nsepcr.js +1 -0
  260. package/dist/assets/objective-c-DLT9zZoE.js +1 -0
  261. package/dist/assets/objective-cpp-DKXr-AK_.js +1 -0
  262. package/dist/assets/ocaml-DP9q6K5L.js +1 -0
  263. package/dist/assets/one-dark-pro-DVMEJ2y_.js +1 -0
  264. package/dist/assets/one-light-PoHY5YXO.js +1 -0
  265. package/dist/assets/{outline-panel-CmQbujCA.js → outline-panel-uvsS-YEQ.js} +1 -1
  266. package/dist/assets/packages-panel-xMz9W2hW.js +1 -0
  267. package/dist/assets/pascal-DjTTLVNS.js +1 -0
  268. package/dist/assets/perl-Da10OPbb.js +1 -0
  269. package/dist/assets/php-hSYFjEJr.js +1 -0
  270. package/dist/assets/pieDiagram-ADFJNKIX-C5IQ5DBZ.js +30 -0
  271. package/dist/assets/plastic-3e1v2bzS.js +1 -0
  272. package/dist/assets/plsql-CJrHCTnj.js +1 -0
  273. package/dist/assets/po-y5MdiEbo.js +1 -0
  274. package/dist/assets/poimandres-CS3Unz2-.js +1 -0
  275. package/dist/assets/polar-Bsx6RkUC.js +1 -0
  276. package/dist/assets/postcss-CeUBPB2S.js +1 -0
  277. package/dist/assets/powerquery-CW27I574.js +1 -0
  278. package/dist/assets/powershell-DSYJ6xcj.js +1 -0
  279. package/dist/assets/prisma-CLoN-gBj.js +1 -0
  280. package/dist/assets/prolog-Bgt5DHUA.js +1 -0
  281. package/dist/assets/proto-BVbLr_ub.js +1 -0
  282. package/dist/assets/pug-DYUvS0f2.js +1 -0
  283. package/dist/assets/puppet-TSkl_nn0.js +1 -0
  284. package/dist/assets/purescript-BrDje9qL.js +1 -0
  285. package/dist/assets/python-DlV7vnVD.js +1 -0
  286. package/dist/assets/qml-DiX3J200.js +1 -0
  287. package/dist/assets/qmldir-CSZk7E48.js +1 -0
  288. package/dist/assets/qss-DACx-k9g.js +1 -0
  289. package/dist/assets/{quadrantDiagram-LMRXKWRM-C3KUHV9E.js → quadrantDiagram-LMRXKWRM-CFXFnQxx.js} +2 -2
  290. package/dist/assets/r-C1kzXVmM.js +1 -0
  291. package/dist/assets/racket-D1nq-KeH.js +1 -0
  292. package/dist/assets/raku-DocPDKZq.js +1 -0
  293. package/dist/assets/razor-7Qmv-3mF.js +1 -0
  294. package/dist/assets/{react-plotly-D8t1Fm8s.js → react-plotly-mzdv02_Y.js} +1 -1
  295. package/dist/assets/red-bN70gL4F.js +1 -0
  296. package/dist/assets/reg-5ydmJHEw.js +1 -0
  297. package/dist/assets/regexp-CpyjTnFF.js +1 -0
  298. package/dist/assets/rel-D68lwU-3.js +1 -0
  299. package/dist/assets/{requirementDiagram-4UW4RH46-COaNtrVe.js → requirementDiagram-4UW4RH46-D9bPC89T.js} +3 -3
  300. package/dist/assets/riscv-Cl4WfXj6.js +1 -0
  301. package/dist/assets/rose-pine-BHrmToEH.js +1 -0
  302. package/dist/assets/rose-pine-dawn-CnK8MTSM.js +1 -0
  303. package/dist/assets/rose-pine-moon-NleAzG8P.js +1 -0
  304. package/dist/assets/rst-DU5WA_Li.js +1 -0
  305. package/dist/assets/ruby-DJftxM78.js +1 -0
  306. package/dist/assets/{run-page-k_GylS9j.js → run-page-Bb68qdhQ.js} +1 -1
  307. package/dist/assets/rust-DpWcZSqc.js +1 -0
  308. package/dist/assets/sankeyDiagram-GR3RE2ED-BSJOau8E.js +10 -0
  309. package/dist/assets/sas-BBCK0tAG.js +1 -0
  310. package/dist/assets/sass-DY_rGA2-.js +1 -0
  311. package/dist/assets/save-worker-B386kalt.js +1 -0
  312. package/dist/assets/scala-CYRsmRER.js +1 -0
  313. package/dist/assets/scheme-C45fPb3F.js +1 -0
  314. package/dist/assets/scratchpad-panel-BF4BO-U4.js +1 -0
  315. package/dist/assets/scss-CHxzYwli.js +1 -0
  316. package/dist/assets/sdbl-BpucmfEo.js +1 -0
  317. package/dist/assets/secrets-panel-CdIX44dQ.js +1 -0
  318. package/dist/assets/{sequenceDiagram-C3RYC4MD-BEe1Fsqh.js → sequenceDiagram-C3RYC4MD-6N7_hY4k.js} +1 -1
  319. package/dist/assets/shaderlab-DNyPh2Q6.js +1 -0
  320. package/dist/assets/shellscript-B8OHlvmy.js +1 -0
  321. package/dist/assets/shellsession-OATBsyRD.js +1 -0
  322. package/dist/assets/slack-dark-BthQWCQV.js +1 -0
  323. package/dist/assets/slack-ochin-DqwNpetd.js +1 -0
  324. package/dist/assets/{slides-component-CMKWJLfP.js → slides-component-EcjC8sDK.js} +1 -1
  325. package/dist/assets/smalltalk-CKvddXL8.js +1 -0
  326. package/dist/assets/snazzy-light-Bw305WKR.js +1 -0
  327. package/dist/assets/snippets-panel-Dco9h0rb.js +1 -0
  328. package/dist/assets/solarized-dark-DXbdFlpD.js +1 -0
  329. package/dist/assets/solarized-light-L9t79GZl.js +1 -0
  330. package/dist/assets/solidity-NK5CeKHG.js +1 -0
  331. package/dist/assets/{sortBy-4KXyROF_.js → sortBy-aLGA-PGK.js} +1 -1
  332. package/dist/assets/soy-BjzVbqVk.js +1 -0
  333. package/dist/assets/sparql-CLNNOQQI.js +1 -0
  334. package/dist/assets/splunk-CFtInczE.js +1 -0
  335. package/dist/assets/sql-BhJCBb_s.js +1 -0
  336. package/dist/assets/ssh-config-Dqsr-I88.js +1 -0
  337. package/dist/assets/stata-G4GYNNPE.js +1 -0
  338. package/dist/assets/stateDiagram-KXAO66HF-Bd68WT3b.js +1 -0
  339. package/dist/assets/stateDiagram-v2-UMBNRL4Z-BXz_GSwb.js +1 -0
  340. package/dist/assets/{storage-VLG_EHzh.js → storage-CGlP4lCF.js} +3 -3
  341. package/dist/assets/stylus-BeJftkpb.js +1 -0
  342. package/dist/assets/svelte-Dg-n8Id4.js +1 -0
  343. package/dist/assets/swift-CvVgI3Em.js +1 -0
  344. package/dist/assets/synthwave-84-ChtBzv_y.js +1 -0
  345. package/dist/assets/system-verilog-B3nElewZ.js +1 -0
  346. package/dist/assets/systemd-B7SlkmfE.js +1 -0
  347. package/dist/assets/talonscript-BrsbXmRy.js +1 -0
  348. package/dist/assets/tasl-CMkPZNj1.js +1 -0
  349. package/dist/assets/tcl-CiyEbZSK.js +1 -0
  350. package/dist/assets/templ-C0tOEwaA.js +1 -0
  351. package/dist/assets/{terminal-Wdc0-Jlz.js → terminal-CxkHubcu.js} +1 -1
  352. package/dist/assets/terraform-BUB-_BlF.js +1 -0
  353. package/dist/assets/tex-BGsfIjRo.js +1 -0
  354. package/dist/assets/{time-C5Wary3f.js → time-D2nr1UgQ.js} +1 -1
  355. package/dist/assets/{timeline-definition-XQNQX7LJ-D0VlQxOo.js → timeline-definition-XQNQX7LJ-BEaynAiY.js} +6 -6
  356. package/dist/assets/tokyo-night-hegEt444.js +1 -0
  357. package/dist/assets/toml-VldhK7iW.js +1 -0
  358. package/dist/assets/{tracing-DBzGH-b_.js → tracing-kTqHxa7q.js} +2 -2
  359. package/dist/assets/tracing-panel-BmuHLPrY.js +2 -0
  360. package/dist/assets/{trash-UWzp31DZ.js → trash-UBqfK4mR.js} +1 -1
  361. package/dist/assets/{tree-DPr9DmVF.js → tree-XiEycetl.js} +1 -1
  362. package/dist/assets/{treemap-75Q7IDZK-BpyhzZ5o.js → treemap-75Q7IDZK-CnuVFbBG.js} +1 -1
  363. package/dist/assets/ts-tags-CloPe9IY.js +1 -0
  364. package/dist/assets/tsv-BQ9ptESM.js +1 -0
  365. package/dist/assets/tsx-DYwE5ssU.js +1 -0
  366. package/dist/assets/turtle-BVy4HXn4.js +1 -0
  367. package/dist/assets/twig-D8xgA4Ji.js +1 -0
  368. package/dist/assets/typescript-C6YI4KwS.js +1 -0
  369. package/dist/assets/typespec-DDqafzeT.js +1 -0
  370. package/dist/assets/typst-JIZTSUoJ.js +1 -0
  371. package/dist/assets/v-CfE8ItaL.js +1 -0
  372. package/dist/assets/vala-p2PL1w-1.js +1 -0
  373. package/dist/assets/{variable-panel-DjFf6P8t.js → variable-panel-noTnH-AQ.js} +1 -1
  374. package/dist/assets/vb-Dv-GCw1m.js +1 -0
  375. package/dist/assets/vega-component-DsTH4tuX.js +1 -0
  376. package/dist/assets/verilog-DKP7kpC6.js +1 -0
  377. package/dist/assets/vesper-DU1UobuO.js +1 -0
  378. package/dist/assets/vhdl-Cog-DhcW.js +1 -0
  379. package/dist/assets/viml-0AN1aqkP.js +1 -0
  380. package/dist/assets/vitesse-black-Bkuqu6BP.js +1 -0
  381. package/dist/assets/vitesse-dark-D0r3Knsf.js +1 -0
  382. package/dist/assets/vitesse-light-CVO1_9PV.js +1 -0
  383. package/dist/assets/vue-ChwqA4lT.js +1 -0
  384. package/dist/assets/vue-html-DP_EF96N.js +1 -0
  385. package/dist/assets/vue-vine-K4R7Z1Ei.js +1 -0
  386. package/dist/assets/vyper-sB2l1MOO.js +1 -0
  387. package/dist/assets/wasm--yL7jHw-.js +1 -0
  388. package/dist/assets/wasm-CSAWeJiV.js +1 -0
  389. package/dist/assets/wenyan-CLHHXU5e.js +1 -0
  390. package/dist/assets/wgsl-DiTcYanS.js +1 -0
  391. package/dist/assets/wikitext-DT8E9qe0.js +1 -0
  392. package/dist/assets/wit-CtjT-RdY.js +1 -0
  393. package/dist/assets/wolfram-1xJNnwe2.js +1 -0
  394. package/dist/assets/worker-X5rxzQGQ.js +1 -0
  395. package/dist/assets/xml-BsgRw6d1.js +1 -0
  396. package/dist/assets/xsl-DCNnPbrB.js +1 -0
  397. package/dist/assets/{xychartDiagram-6GGTOJPD-E4W1u4ej.js → xychartDiagram-6GGTOJPD-Dcz3O-A3.js} +1 -1
  398. package/dist/assets/yaml-c2-Vhxho.js +1 -0
  399. package/dist/assets/zenscript-ChP1MlQf.js +1 -0
  400. package/dist/assets/zig-rivS3YQG.js +1 -0
  401. package/dist/index.html +2 -2
  402. package/package.json +6 -3
  403. package/src/components/ai/ai-provider-icon.tsx +5 -1
  404. package/src/components/chat/acp/__tests__/__snapshots__/prompt.test.ts.snap +304 -0
  405. package/src/components/chat/acp/__tests__/atoms.test.ts +56 -0
  406. package/src/components/chat/acp/__tests__/prompt.test.ts +12 -0
  407. package/src/components/chat/acp/__tests__/state.test.ts +621 -0
  408. package/src/components/chat/acp/agent-docs.tsx +78 -0
  409. package/src/components/chat/acp/agent-panel.css +23 -0
  410. package/src/components/chat/acp/agent-panel.tsx +715 -0
  411. package/src/components/chat/acp/agent-selector.tsx +138 -0
  412. package/src/components/chat/acp/blocks.tsx +664 -0
  413. package/src/components/chat/acp/common.tsx +198 -0
  414. package/src/components/chat/acp/prompt.ts +284 -0
  415. package/src/components/chat/acp/scroll-to-bottom-button.tsx +50 -0
  416. package/src/components/chat/acp/session-tabs.tsx +138 -0
  417. package/src/components/chat/acp/state.ts +263 -0
  418. package/src/components/chat/acp/thread.tsx +121 -0
  419. package/src/components/chat/acp/types.ts +63 -0
  420. package/src/components/chat/acp/utils.ts +45 -0
  421. package/src/components/chat/tool-call-accordion.tsx +1 -1
  422. package/src/components/editor/chrome/types.ts +10 -0
  423. package/src/components/editor/chrome/wrapper/app-chrome.tsx +17 -3
  424. package/src/core/config/feature-flag.tsx +2 -0
  425. package/src/plugins/impl/vega/vega.css +121 -0
  426. package/src/utils/Logger.ts +5 -6
  427. package/dist/assets/_baseEach-b7jKF32j.js +0 -1
  428. package/dist/assets/_baseMap-DACTv_oG.js +0 -1
  429. package/dist/assets/_baseUniq-DARYnBeS.js +0 -1
  430. package/dist/assets/_createAggregator-D2w-TTce.js +0 -1
  431. package/dist/assets/arc-ZB5pDULS.js +0 -1
  432. package/dist/assets/architectureDiagram-W76B3OCA-C3JRQ7yL.js +0 -36
  433. package/dist/assets/channel-BX-eVUbR.js +0 -1
  434. package/dist/assets/chat-panel-CFCVImGh.js +0 -34
  435. package/dist/assets/chunk-4BX2VUAB-BSBD21Hr.js +0 -1
  436. package/dist/assets/chunk-55IACEB6-C-pI4fDn.js +0 -1
  437. package/dist/assets/chunk-QN33PNHL-BaU4TJ76.js +0 -1
  438. package/dist/assets/chunk-QZHKN3VN-ChHKlyCz.js +0 -1
  439. package/dist/assets/classDiagram-KNZD7YFC-CXSeERCZ.js +0 -1
  440. package/dist/assets/classDiagram-v2-RKCZMP56-CXSeERCZ.js +0 -1
  441. package/dist/assets/clone-B0GDon06.js +0 -1
  442. package/dist/assets/cose-bilkent-S5V4N54A-BhnFxMKY.js +0 -1
  443. package/dist/assets/dagre-5GWH7T2D-BcbHFxhs.js +0 -4
  444. package/dist/assets/diagram-N5W7TBWH-CXogdFBb.js +0 -24
  445. package/dist/assets/diagram-QEK2KX5R-BpNMo7fW.js +0 -43
  446. package/dist/assets/diagram-S2PKOQOG-CWI07XEW.js +0 -24
  447. package/dist/assets/empty-state-BihAqBDu.js +0 -1
  448. package/dist/assets/file-explorer-panel-42yshMSG.js +0 -1
  449. package/dist/assets/gitGraphDiagram-NY62KEGX-Ce1EEDpB.js +0 -65
  450. package/dist/assets/graph-n-eoL6DT.js +0 -1
  451. package/dist/assets/index-0ZBpRFZW.js +0 -1
  452. package/dist/assets/index-Bm5j99kK.js +0 -7
  453. package/dist/assets/index-CMLEU4vI.js +0 -1
  454. package/dist/assets/index-CgtzsYeY.js +0 -1
  455. package/dist/assets/index-PsA_OWtk.js +0 -1
  456. package/dist/assets/index-a0QzZKmG.css +0 -1
  457. package/dist/assets/index-zdTab9tW.js +0 -1
  458. package/dist/assets/infoDiagram-STP46IZ2-BErnpd6u.js +0 -2
  459. package/dist/assets/linear-fPFwSU0H.js +0 -1
  460. package/dist/assets/links-xiQ_O8X2.js +0 -7
  461. package/dist/assets/min-ClQWkzzs.js +0 -1
  462. package/dist/assets/packages-panel-BeNG3M96.js +0 -1
  463. package/dist/assets/pieDiagram-ADFJNKIX-DbNp00N2.js +0 -30
  464. package/dist/assets/sankeyDiagram-GR3RE2ED-D7rChvzY.js +0 -10
  465. package/dist/assets/save-worker-IRA-wdDF.js +0 -1
  466. package/dist/assets/scratchpad-panel-qj2Bbf2w.js +0 -1
  467. package/dist/assets/secrets-panel-DxB6ux_Z.js +0 -1
  468. package/dist/assets/snippets-panel-CaclRXMo.js +0 -1
  469. package/dist/assets/stateDiagram-KXAO66HF-WnDNanSf.js +0 -1
  470. package/dist/assets/stateDiagram-v2-UMBNRL4Z-B2b4NZKb.js +0 -1
  471. package/dist/assets/tracing-panel-D839Di_w.js +0 -2
  472. package/dist/assets/vega-component-xHtaYq3O.js +0 -1
  473. package/dist/assets/worker-PaVjsxkz.js +0 -1
  474. /package/dist/assets/{transform-CDNfLgV5.js → transform-D9VCJYws.js} +0 -0
@@ -0,0 +1,198 @@
1
+ /* Copyright 2024 Marimo. All rights reserved. */
2
+
3
+ import {
4
+ CheckCircleIcon,
5
+ Loader2,
6
+ PlugIcon,
7
+ ShieldCheckIcon,
8
+ WifiIcon,
9
+ WifiOffIcon,
10
+ XCircleIcon,
11
+ } from "lucide-react";
12
+ import React, { memo } from "react";
13
+ import {
14
+ Accordion,
15
+ AccordionContent,
16
+ AccordionItem,
17
+ AccordionTrigger,
18
+ } from "@/components/ui/accordion";
19
+ import { Badge } from "@/components/ui/badge";
20
+ import { Button } from "@/components/ui/button";
21
+ import { cn } from "@/utils/cn";
22
+ import { ToolBodyBlock } from "./blocks";
23
+ import type { AgentPendingPermission } from "./types";
24
+
25
+ interface SimpleAccordionProps {
26
+ title: string | React.ReactNode;
27
+ children: React.ReactNode | string;
28
+ status?: "loading" | "error" | "success";
29
+ index?: number;
30
+ defaultIcon?: React.ReactNode;
31
+ }
32
+
33
+ export const SimpleAccordion: React.FC<SimpleAccordionProps> = ({
34
+ title,
35
+ children,
36
+ status,
37
+ index = 0,
38
+ defaultIcon,
39
+ }) => {
40
+ const getStatusIcon = () => {
41
+ switch (status) {
42
+ case "loading":
43
+ return <Loader2 className="h-3 w-3 animate-spin" />;
44
+ case "error":
45
+ return <XCircleIcon className="h-3 w-3 text-destructive" />;
46
+ case "success":
47
+ return <CheckCircleIcon className="h-3 w-3 text-[var(--blue-9)]" />;
48
+ default:
49
+ return defaultIcon;
50
+ }
51
+ };
52
+
53
+ return (
54
+ <Accordion
55
+ key={`tool-${index}`}
56
+ type="single"
57
+ collapsible={true}
58
+ className="w-full"
59
+ >
60
+ <AccordionItem value="tool-call" className="border-0">
61
+ <AccordionTrigger
62
+ className={cn(
63
+ "py-1 text-xs border-border shadow-none! ring-0! bg-muted hover:bg-muted/30 px-2 gap-1 rounded-sm [&[data-state=open]>svg]:rotate-180",
64
+ status === "error" && "text-destructive/80",
65
+ status === "success" && "text-[var(--blue-8)]",
66
+ )}
67
+ >
68
+ <span className="flex items-center gap-1">
69
+ {getStatusIcon()}
70
+ <code className="font-mono text-xs">{title}</code>
71
+ </span>
72
+ </AccordionTrigger>
73
+ <AccordionContent className="p-2">
74
+ <div className="space-y-3 max-h-64 overflow-y-auto scrollbar-thin">
75
+ {status !== "error" && (
76
+ <div className="text-xs font-medium text-muted-foreground mb-1">
77
+ {children}
78
+ </div>
79
+ )}
80
+
81
+ {status === "error" && (
82
+ <div className="bg-destructive/10 border border-destructive/20 rounded-md p-3 text-xs text-destructive">
83
+ {children}
84
+ </div>
85
+ )}
86
+ </div>
87
+ </AccordionContent>
88
+ </AccordionItem>
89
+ </Accordion>
90
+ );
91
+ };
92
+
93
+ interface ConnectionStatusProps {
94
+ status: string;
95
+ className?: string;
96
+ }
97
+
98
+ export const ConnectionStatus: React.FC<ConnectionStatusProps> = memo(
99
+ ({ status, className }) => {
100
+ const getStatusConfig = () => {
101
+ switch (status) {
102
+ case "connected":
103
+ return {
104
+ icon: <WifiIcon className="h-3 w-3" />,
105
+ label: "Connected",
106
+ variant: "default" as const,
107
+ className:
108
+ "bg-[var(--blue-3)] text-[var(--blue-11)] border-[var(--blue-5)]",
109
+ };
110
+ case "connecting":
111
+ return {
112
+ icon: <PlugIcon className="h-3 w-3 animate-pulse" />,
113
+ label: "Connecting",
114
+ variant: "secondary" as const,
115
+ className:
116
+ "bg-[var(--yellow-3)] text-[var(--yellow-11)] border-[var(--yellow-5)]",
117
+ };
118
+ case "disconnected":
119
+ return {
120
+ icon: <WifiOffIcon className="h-3 w-3" />,
121
+ label: "Disconnected",
122
+ variant: "outline" as const,
123
+ className:
124
+ "bg-[var(--red-3)] text-[var(--red-11)] border-[var(--red-5)]",
125
+ };
126
+ default:
127
+ return {
128
+ icon: <WifiOffIcon className="h-3 w-3" />,
129
+ label: status || "Unknown",
130
+ variant: "outline" as const,
131
+ className:
132
+ "bg-[var(--gray-3)] text-[var(--gray-11)] border-[var(--gray-5)]",
133
+ };
134
+ }
135
+ };
136
+
137
+ const config = getStatusConfig();
138
+
139
+ return (
140
+ <Badge
141
+ variant={config.variant}
142
+ className={cn(config.className, className)}
143
+ >
144
+ {config.icon}
145
+ <span className="ml-1 text-xs font-medium">{config.label}</span>
146
+ </Badge>
147
+ );
148
+ },
149
+ );
150
+ ConnectionStatus.displayName = "ConnectionStatus";
151
+
152
+ interface PermissionRequestProps {
153
+ permission: NonNullable<AgentPendingPermission>;
154
+ onResolve: (option: unknown) => void;
155
+ }
156
+
157
+ export const PermissionRequest: React.FC<PermissionRequestProps> = memo(
158
+ ({ permission, onResolve }) => {
159
+ return (
160
+ <div className="border border-[var(--amber-8)] bg-[var(--amber-2)] rounded-lg p-2">
161
+ <div className="flex items-center gap-2 mb-3">
162
+ <ShieldCheckIcon className="h-4 w-4 text-[var(--amber-11)]" />
163
+ <h3 className="text-sm font-medium text-[var(--amber-11)]">
164
+ Permission Request
165
+ </h3>
166
+ </div>
167
+ <p className="text-sm text-[var(--amber-11)] mb-3">
168
+ The AI agent is requesting permission to proceed:
169
+ </p>
170
+ <ToolBodyBlock data={permission.toolCall} />
171
+ <div className="flex gap-2">
172
+ {permission.options.map((option) => (
173
+ <Button
174
+ key={option.optionId}
175
+ size="xs"
176
+ variant="text"
177
+ className={
178
+ option.kind.startsWith("allow")
179
+ ? "text-[var(--blue-10)]"
180
+ : "text-[var(--red-10)]"
181
+ }
182
+ onClick={() => onResolve(option)}
183
+ >
184
+ {option.kind.startsWith("allow") && (
185
+ <CheckCircleIcon className="h-3 w-3 mr-1" />
186
+ )}
187
+ {option.kind.startsWith("reject") && (
188
+ <XCircleIcon className="h-3 w-3 mr-1" />
189
+ )}
190
+ {option.name}
191
+ </Button>
192
+ ))}
193
+ </div>
194
+ </div>
195
+ );
196
+ },
197
+ );
198
+ PermissionRequest.displayName = "PermissionRequest";
@@ -0,0 +1,284 @@
1
+ /* Copyright 2024 Marimo. All rights reserved. */
2
+
3
+ export function getAgentPrompt(filename: string) {
4
+ return `
5
+ I am currently editing a marimo notebook.
6
+ You can read or write to the notebook at @${filename}
7
+
8
+ If you make edits to the notebook, only edit the contents inside the function decorator with @app.cell.
9
+ marimo will automatically handle adding the parameters and return statement of the function. For example,
10
+ for each edit, just return:
11
+
12
+ \`\`\`
13
+ @app.cell
14
+ def __():
15
+ <your code here>
16
+ return
17
+ \`\`\`
18
+
19
+ ## Marimo fundamentals
20
+
21
+ Marimo is a reactive notebook that differs from traditional notebooks in key ways:
22
+
23
+ - Cells execute automatically when their dependencies change
24
+ - Variables cannot be redeclared across cells
25
+ - The notebook forms a directed acyclic graph (DAG)
26
+ - The last expression in a cell is automatically displayed
27
+ - UI elements are reactive and update the notebook automatically
28
+
29
+ ## Code Requirements
30
+
31
+ 1. All code must be complete and runnable
32
+ 2. Follow consistent coding style throughout
33
+ 3. Include descriptive variable names and helpful comments
34
+ 4. Import all modules in the first cell, always including \`import marimo as mo\`
35
+ 5. Never redeclare variables across cells
36
+ 6. Ensure no cycles in notebook dependency graph
37
+ 7. The last expression in a cell is automatically displayed, just like in Jupyter notebooks.
38
+ 8. Don't include comments in markdown cells
39
+ 9. Don't include comments in SQL cells
40
+
41
+ ## Reactivity
42
+
43
+ Marimo's reactivity means:
44
+
45
+ - When a variable changes, all cells that use that variable automatically re-execute
46
+ - UI elements trigger updates when their values change without explicit callbacks
47
+ - UI element values are accessed through \`.value\` attribute
48
+ - You cannot access a UI element's value in the same cell where it's defined
49
+
50
+ ## Best Practices
51
+
52
+ <data_handling>
53
+ - Use pandas for data manipulation
54
+ - Implement proper data validation
55
+ - Handle missing values appropriately
56
+ - Use efficient data structures
57
+ - A variable in the last expression of a cell is automatically displayed as a table
58
+ </data_handling>
59
+
60
+ <visualization>
61
+ - For matplotlib: use plt.gca() as the last expression instead of plt.show()
62
+ - For plotly: return the figure object directly
63
+ - For altair: return the chart object directly
64
+ - Include proper labels, titles, and color schemes
65
+ - Make visualizations interactive where appropriate
66
+ </visualization>
67
+
68
+ <ui_elements>
69
+ - Access UI element values with .value attribute (e.g., slider.value)
70
+ - Create UI elements in one cell and reference them in later cells
71
+ - Create intuitive layouts with mo.hstack(), mo.vstack(), and mo.tabs()
72
+ - Prefer reactive updates over callbacks (marimo handles reactivity automatically)
73
+ - Group related UI elements for better organization
74
+ </ui_elements>
75
+
76
+ <sql>
77
+ - When writing duckdb, prefer using marimo's SQL cells, which start with _df = mo.sql(query)
78
+ - See the SQL with duckdb example for an example on how to do this
79
+ - Don't add comments in cells that use mo.sql()
80
+ - Consider using \`vega_datasets\` for common example datasets
81
+ </sql>
82
+
83
+ ## Troubleshooting
84
+
85
+ Common issues and solutions:
86
+ - Circular dependencies: Reorganize code to remove cycles in the dependency graph
87
+ - UI element value access: Move access to a separate cell from definition
88
+ - Visualization not showing: Ensure the visualization object is the last expression
89
+
90
+ ## Available UI elements
91
+
92
+ - \`mo.ui.altair_chart(altair_chart)\`
93
+ - \`mo.ui.button(value=None, kind='primary')\`
94
+ - \`mo.ui.run_button(label=None, tooltip=None, kind='primary')\`
95
+ - \`mo.ui.checkbox(label='', value=False)\`
96
+ - \`mo.ui.date(value=None, label=None, full_width=False)\`
97
+ - \`mo.ui.dropdown(options, value=None, label=None, full_width=False)\`
98
+ - \`mo.ui.file(label='', multiple=False, full_width=False)\`
99
+ - \`mo.ui.number(value=None, label=None, full_width=False)\`
100
+ - \`mo.ui.radio(options, value=None, label=None, full_width=False)\`
101
+ - \`mo.ui.refresh(options: List[str], default_interval: str)\`
102
+ - \`mo.ui.slider(start, stop, value=None, label=None, full_width=False, step=None)\`
103
+ - \`mo.ui.range_slider(start, stop, value=None, label=None, full_width=False, step=None)\`
104
+ - \`mo.ui.table(data, columns=None, on_select=None, sortable=True, filterable=True)\`
105
+ - \`mo.ui.text(value='', label=None, full_width=False)\`
106
+ - \`mo.ui.text_area(value='', label=None, full_width=False)\`
107
+ - \`mo.ui.data_explorer(df)\`
108
+ - \`mo.ui.dataframe(df)\`
109
+ - \`mo.ui.plotly(plotly_figure)\`
110
+ - \`mo.ui.tabs(elements: dict[str, mo.ui.Element])\`
111
+ - \`mo.ui.array(elements: list[mo.ui.Element])\`
112
+ - \`mo.ui.form(element: mo.ui.Element, label='', bordered=True)\`
113
+
114
+ ## Layout and utility functions
115
+
116
+ - \`mo.md(text)\` - display markdown
117
+ - \`mo.stop(predicate, output=None)\` - stop execution conditionally
118
+ - \`mo.Html(html)\` - display HTML
119
+ - \`mo.image(image)\` - display an image
120
+ - \`mo.hstack(elements)\` - stack elements horizontally
121
+ - \`mo.vstack(elements)\` - stack elements vertically
122
+ - \`mo.tabs(elements)\` - create a tabbed interface
123
+
124
+ ## Examples
125
+
126
+ <example title="Basic UI with reactivity">
127
+ ${formatCells([
128
+ `
129
+ import marimo as mo
130
+ import matplotlib.pyplot as plt
131
+ import numpy as np
132
+ `,
133
+ `
134
+ n_points = mo.ui.slider(10, 100, value=50, label="Number of points")
135
+ n_points
136
+ `,
137
+ `
138
+ x = np.random.rand(n_points.value)
139
+ y = np.random.rand(n_points.value)
140
+
141
+ plt.figure(figsize=(8, 6))
142
+ plt.scatter(x, y, alpha=0.7)
143
+ plt.title(f"Scatter plot with {n_points.value} points")
144
+ plt.xlabel("X axis")
145
+ plt.ylabel("Y axis")
146
+ plt.gca()
147
+ `,
148
+ ])}
149
+ </example>
150
+
151
+ <example title="Data explorer">
152
+ ${formatCells([
153
+ `
154
+ import marimo as mo
155
+ import pandas as pd
156
+ from vega_datasets import data
157
+ `,
158
+ `
159
+ cars_df = data.cars()
160
+ mo.ui.data_explorer(cars_df)
161
+ `,
162
+ ])}
163
+ </example>
164
+
165
+ <example title="Multiple UI elements">
166
+ ${formatCells([
167
+ `
168
+ import marimo as mo
169
+ import pandas as pd
170
+ import matplotlib.pyplot as plt
171
+ import seaborn as sns
172
+ `,
173
+ `
174
+ iris = sns.load_dataset('iris')
175
+ `,
176
+ `
177
+ species_selector = mo.ui.dropdown(
178
+ options=["All"] + iris["species"].unique().tolist(),
179
+ value="All",
180
+ label="Species"
181
+ )
182
+ x_feature = mo.ui.dropdown(
183
+ options=iris.select_dtypes('number').columns.tolist(),
184
+ value="sepal_length",
185
+ label="X Feature"
186
+ )
187
+ y_feature = mo.ui.dropdown(
188
+ options=iris.select_dtypes('number').columns.tolist(),
189
+ value="sepal_width",
190
+ label="Y Feature"
191
+ )
192
+ mo.hstack([species_selector, x_feature, y_feature])
193
+ `,
194
+ `
195
+ filtered_data = iris if species_selector.value == "All" else iris[iris["species"] == species_selector.value]
196
+
197
+ plt.figure(figsize=(10, 6))
198
+ sns.scatterplot(
199
+ data=filtered_data,
200
+ x=x_feature.value,
201
+ y=y_feature.value,
202
+ hue="species"
203
+ )
204
+ plt.title(f"{y_feature.value} vs {x_feature.value}")
205
+ plt.gca()
206
+ `,
207
+ ])}
208
+ </example>
209
+
210
+ <example title="Interactive chart with Altair">
211
+ ${formatCells([
212
+ `
213
+ import marimo as mo
214
+ import altair as alt
215
+ import pandas as pd
216
+ `,
217
+ `# Load dataset
218
+ cars_df = pd.read_csv('<https://raw.githubusercontent.com/vega/vega-datasets/master/data/cars.json>')
219
+ _chart = alt.Chart(cars_df).mark_point().encode(
220
+ x='Horsepower',
221
+ y='Miles_per_Gallon',
222
+ color='Origin',
223
+ )
224
+ `,
225
+ "chart = mo.ui.altair_chart(_chart)\nchart",
226
+ `
227
+ # Display the selection
228
+ chart.value`,
229
+ ])}
230
+ </example>
231
+
232
+ <example title="Run Button Example">
233
+ ${formatCells([
234
+ "import marimo as mo",
235
+ `
236
+ first_button = mo.ui.run_button(label="Option 1")
237
+ second_button = mo.ui.run_button(label="Option 2")
238
+ [first_button, second_button]`,
239
+ `
240
+ if first_button.value:
241
+ print("You chose option 1!")
242
+ elif second_button.value:
243
+ print("You chose option 2!")
244
+ else:
245
+ print("Click a button!")`,
246
+ ])}
247
+ </example>
248
+
249
+ <example title="SQL with duckdb">
250
+ ${formatCells([
251
+ "import marimo as mo\nimport pandas as pd",
252
+ `cars_df = pd.read_csv('<https://raw.githubusercontent.com/vega/vega-datasets/master/data/cars.json>')`,
253
+ `_df = mo.sql("SELECT * from cars_df WHERE Miles_per_Gallon > 20")`,
254
+ ])}
255
+ </example>`;
256
+ }
257
+
258
+ function formatCells(cells: string[]) {
259
+ // Option 1:
260
+ // return cells.map((cell) => {
261
+ // return `# Cell ${cell}`;
262
+ // });
263
+
264
+ const indent = " ";
265
+ const indentCode = (code: string) => {
266
+ return code
267
+ .trim()
268
+ .split("\n")
269
+ .map((line) => indent + line)
270
+ .join("\n");
271
+ };
272
+
273
+ // Option 2:
274
+ const formatCell = (cell: string) => {
275
+ return `
276
+ @app.cell
277
+ def __():
278
+ ${indentCode(cell)}
279
+ return
280
+ `;
281
+ };
282
+
283
+ return cells.map(formatCell).join("");
284
+ }
@@ -0,0 +1,50 @@
1
+ /* Copyright 2024 Marimo. All rights reserved. */
2
+
3
+ import { ArrowDownIcon } from "lucide-react";
4
+ import { memo } from "react";
5
+ import { Button } from "@/components/ui/button";
6
+ import { cn } from "@/utils/cn";
7
+
8
+ interface ScrollToBottomButtonProps {
9
+ isVisible: boolean;
10
+ onScrollToBottom: () => void;
11
+ className?: string;
12
+ }
13
+
14
+ const ScrollToBottomButton = memo<ScrollToBottomButtonProps>(
15
+ ({ isVisible, onScrollToBottom, className }) => {
16
+ if (!isVisible) {
17
+ return null;
18
+ }
19
+
20
+ return (
21
+ <div
22
+ className={cn(
23
+ "absolute bottom-2 right-6 z-10 animate-in fade-in-0 zoom-in-95 duration-200",
24
+ className,
25
+ )}
26
+ >
27
+ <Button
28
+ variant="secondary"
29
+ size="sm"
30
+ onClick={onScrollToBottom}
31
+ className={cn(
32
+ "h-8 w-8 p-0 rounded-full",
33
+ "bg-background/90 backdrop-blur-sm",
34
+ "border border-border/50",
35
+ "shadow-md shadow-black/10",
36
+ "hover:bg-background hover:shadow-black/15",
37
+ "transition-all duration-200",
38
+ "focus:outline-none focus:ring-2 focus:ring-primary/50",
39
+ )}
40
+ >
41
+ <ArrowDownIcon className="h-4 w-4" />
42
+ <span className="sr-only">Scroll to bottom</span>
43
+ </Button>
44
+ </div>
45
+ );
46
+ },
47
+ );
48
+ ScrollToBottomButton.displayName = "ScrollToBottomButton";
49
+
50
+ export default ScrollToBottomButton;
@@ -0,0 +1,138 @@
1
+ /* Copyright 2024 Marimo. All rights reserved. */
2
+
3
+ import { useAtom, useSetAtom } from "jotai";
4
+ import { XIcon } from "lucide-react";
5
+ import React, { memo } from "react";
6
+ import useEvent from "react-use-event-hook";
7
+ import { AiProviderIcon } from "@/components/ai/ai-provider-icon";
8
+ import { Button } from "@/components/ui/button";
9
+ import { cn } from "@/utils/cn";
10
+ import { AgentSelector } from "./agent-selector";
11
+ import {
12
+ type AgentSession,
13
+ agentSessionStateAtom,
14
+ removeSession,
15
+ selectedTabAtom,
16
+ type TabId,
17
+ updateSessionLastUsed,
18
+ } from "./state";
19
+
20
+ interface SessionTabProps {
21
+ session: AgentSession;
22
+ isActive: boolean;
23
+ onSelect: (sessionId: TabId) => void;
24
+ onClose: (sessionId: TabId) => void;
25
+ }
26
+
27
+ const SessionTab: React.FC<SessionTabProps> = memo(
28
+ ({ session, isActive, onSelect, onClose }) => {
29
+ return (
30
+ <div
31
+ className={cn(
32
+ "flex items-center gap-1 px-2 py-1 text-xs border-r border-border bg-muted/30 hover:bg-muted/50 cursor-pointer min-w-0",
33
+ isActive && "bg-background border-b-0 relative z-10",
34
+ )}
35
+ onClick={() => onSelect(session.tabId)}
36
+ >
37
+ <div className="flex items-center gap-1 min-w-0 flex-1">
38
+ <span className="text-muted-foreground text-[10px] font-medium">
39
+ <AiProviderIcon provider={session.agentId} className="h-3 w-3" />
40
+ </span>
41
+ <span className="truncate" title={session.title}>
42
+ {session.title}
43
+ </span>
44
+ </div>
45
+ <Button
46
+ variant="ghost"
47
+ size="sm"
48
+ className="h-4 w-4 p-0 hover:bg-destructive/20 hover:text-destructive flex-shrink-0"
49
+ onClick={(e) => {
50
+ e.stopPropagation();
51
+ onClose(session.tabId);
52
+ }}
53
+ >
54
+ <XIcon className="h-3 w-3" />
55
+ </Button>
56
+ </div>
57
+ );
58
+ },
59
+ );
60
+ SessionTab.displayName = "SessionTab";
61
+
62
+ interface SessionTabsProps {
63
+ onAddSession?: () => void;
64
+ className?: string;
65
+ }
66
+
67
+ interface SessionListProps {
68
+ sessions: AgentSession[];
69
+ activeTabId: TabId | null;
70
+ onSelectSession: (sessionId: TabId) => void;
71
+ onCloseSession: (sessionId: TabId) => void;
72
+ }
73
+
74
+ const SessionList = memo<SessionListProps>(
75
+ ({ sessions, activeTabId, onSelectSession, onCloseSession }) => (
76
+ <div className="flex min-w-0 flex-1 overflow-x-auto">
77
+ {sessions.map((session) => (
78
+ <SessionTab
79
+ key={session.tabId}
80
+ session={session}
81
+ isActive={session.tabId === activeTabId}
82
+ onSelect={onSelectSession}
83
+ onClose={onCloseSession}
84
+ />
85
+ ))}
86
+ </div>
87
+ ),
88
+ );
89
+ SessionList.displayName = "SessionList";
90
+
91
+ interface EmptySessionTabsProps {
92
+ className?: string;
93
+ }
94
+
95
+ const EmptySessionTabs = memo<EmptySessionTabsProps>(({ className }) => (
96
+ <div className={cn("flex items-center border-b bg-muted/20", className)}>
97
+ <AgentSelector className="h-6" />
98
+ </div>
99
+ ));
100
+ EmptySessionTabs.displayName = "EmptySessionTabs";
101
+
102
+ export const SessionTabs: React.FC<SessionTabsProps> = memo(({ className }) => {
103
+ const [sessionState, setSessionState] = useAtom(agentSessionStateAtom);
104
+ const setActiveSession = useSetAtom(selectedTabAtom);
105
+
106
+ const handleSelectSession = useEvent((sessionId: TabId) => {
107
+ setActiveSession(sessionId);
108
+ setSessionState((prev) => updateSessionLastUsed(prev, sessionId));
109
+ });
110
+
111
+ const handleCloseSession = useEvent((sessionId: TabId) => {
112
+ setSessionState((prev) => removeSession(prev, sessionId));
113
+ });
114
+
115
+ const { sessions, activeTabId } = sessionState;
116
+
117
+ if (sessions.length === 0) {
118
+ return <EmptySessionTabs className={className} />;
119
+ }
120
+
121
+ return (
122
+ <div
123
+ className={cn(
124
+ "flex items-center border-b bg-muted/20 overflow-hidden",
125
+ className,
126
+ )}
127
+ >
128
+ <SessionList
129
+ sessions={sessions}
130
+ activeTabId={activeTabId}
131
+ onSelectSession={handleSelectSession}
132
+ onCloseSession={handleCloseSession}
133
+ />
134
+ <AgentSelector className="h-6 flex-shrink-0" />
135
+ </div>
136
+ );
137
+ });
138
+ SessionTabs.displayName = "SessionTabs";