@marimo-team/frontend 0.23.9-dev8 → 0.23.9
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/assets/{CellStatus-D_-Xs2i2.js → CellStatus-BLWR83i_.js} +1 -1
- package/dist/assets/{ConnectedDataExplorerComponent-CKOLvj_e.js → ConnectedDataExplorerComponent-W0UfNkj7.js} +1 -1
- package/dist/assets/JsonOutput-BJaeXQim.js +53 -0
- package/dist/assets/LazyAnyLanguageCodeMirror-BEvXb3VX.js +2 -0
- package/dist/assets/MarimoErrorOutput-B0h5OVW9.js +7 -0
- package/dist/assets/{RenderHTML-IGRZU9wj.js → RenderHTML-ChwPJgPd.js} +1 -1
- package/dist/assets/{RunButton-Cf9ByHXe.js → RunButton-NDsrcmxR.js} +1 -1
- package/dist/assets/{add-cell-with-ai-9EyttqGQ.js → add-cell-with-ai-FxJitVGs.js} +21 -21
- package/dist/assets/{add-connection-dialog-Bqsr9NiO.js → add-connection-dialog-EgkKupsZ.js} +1 -1
- package/dist/assets/{agent-panel-CSzzOKD1.js → agent-panel-BSt1fSQZ.js} +6 -6
- package/dist/assets/ai-model-dropdown-DxAk02Lc.js +5 -0
- package/dist/assets/{any-language-editor-Cs-Qsdlp.js → any-language-editor-CXeLf_N8.js} +1 -1
- package/dist/assets/apl-EAxnZS_5.js +1 -0
- package/dist/assets/{app-config-button-Cooknt8P.js → app-config-button-BcOcIm9W.js} +1 -1
- package/dist/assets/{arc-D0XsJSsf.js → arc-CWuN1tfc.js} +1 -1
- package/dist/assets/{architecture-7HQA4BMR-CyeFAHwy.js → architecture-7HQA4BMR-DJtUfdk-.js} +1 -1
- package/dist/assets/{architectureDiagram-VXUJARFQ-1WJT-eC3.js → architectureDiagram-VXUJARFQ-Cgi4wo9P.js} +1 -1
- package/dist/assets/arrow-right-pRnMoIOW.js +1 -0
- package/dist/assets/asciiarmor-zxnaShQE.js +1 -0
- package/dist/assets/asn1-7i28Os5R.js +1 -0
- package/dist/assets/{blockDiagram-VD42YOAC-JexHZqqE.js → blockDiagram-VD42YOAC-CsHap8-F.js} +1 -1
- package/dist/assets/brainfuck-BZegPsXK.js +1 -0
- package/dist/assets/{c4Diagram-YG6GDRKO-Bq-DoY7t.js → c4Diagram-YG6GDRKO-CZuArudM.js} +1 -1
- package/dist/assets/{cache-panel-CZqzacQu.js → cache-panel-DYiVMv5x.js} +1 -1
- package/dist/assets/cell-editor-C5CDtKML.js +20 -0
- package/dist/assets/{cell-link-VlbhstGP.js → cell-link-B1pHtGWp.js} +1 -1
- package/dist/assets/{cells-WW455pbI.js → cells-BsaJrRWi.js} +60 -62
- package/dist/assets/channel-6XBTrC3Q.js +1 -0
- package/dist/assets/{chat-display-0SSKyMkt.js → chat-display-ccjE30z9.js} +1 -1
- package/dist/assets/chat-panel-CtvtP3kb.js +3 -0
- package/dist/assets/chat-ui-DV8CD_s1.js +4 -0
- package/dist/assets/{chunk-4BX2VUAB-Dhno12SW.js → chunk-4BX2VUAB-Ca6WzYTr.js} +1 -1
- package/dist/assets/chunk-55IACEB6-Cr4aqhf3.js +1 -0
- package/dist/assets/{chunk-5FQGJX7Z-BzXnQz5s.js → chunk-5FQGJX7Z-D9iBG0F7.js} +2 -2
- package/dist/assets/{chunk-ABZYJK2D-fbQovzbZ.js → chunk-ABZYJK2D-BG7Eb4WW.js} +3 -3
- package/dist/assets/{chunk-ATLVNIR6-C71UReOL.js → chunk-ATLVNIR6-CqLn9HI1.js} +1 -1
- package/dist/assets/{chunk-B4BG7PRW-ChmO4xUA.js → chunk-B4BG7PRW-D4SyZNjn.js} +1 -1
- package/dist/assets/{chunk-CVBHYZKI-B6tT645I.js → chunk-CVBHYZKI-C-NWvPQL.js} +1 -1
- package/dist/assets/{chunk-DI55MBZ5-DaLBJUsc.js → chunk-DI55MBZ5-t9uiMPiN.js} +1 -1
- package/dist/assets/{chunk-EXTU4WIE-B3Lv3QWb.js → chunk-EXTU4WIE-BmVk7Fyq.js} +1 -1
- package/dist/assets/{chunk-FMBD7UC4-CDFiCFLp.js → chunk-FMBD7UC4-DlnzxSkO.js} +1 -1
- package/dist/assets/{chunk-HN2XXSSU-xW6J7MXn.js → chunk-HN2XXSSU-Bcaj5fRB.js} +1 -1
- package/dist/assets/{chunk-JA3XYJ7Z-jqUKn_dB.js → chunk-JA3XYJ7Z-B5b2QHOb.js} +1 -1
- package/dist/assets/{chunk-JZLCHNYA-xGZ72asD.js → chunk-JZLCHNYA-1_sVfAnw.js} +1 -1
- package/dist/assets/{chunk-MI3HLSF2-CXMqGP2w.js → chunk-MI3HLSF2-DqzZqBCh.js} +1 -1
- package/dist/assets/{chunk-N4CR4FBY-D8iMP1ch.js → chunk-N4CR4FBY-CFJoD-EQ.js} +2 -2
- package/dist/assets/{chunk-QN33PNHL-Ddzf5Xc1.js → chunk-QN33PNHL-BBE_bx9E.js} +1 -1
- package/dist/assets/{chunk-QXUST7PY-BUBd7EW9.js → chunk-QXUST7PY-Cu1nR-L2.js} +1 -1
- package/dist/assets/{chunk-QZHKN3VN-37WEuSLJ.js → chunk-QZHKN3VN-BAnb9AKF.js} +1 -1
- package/dist/assets/{chunk-S3R3BYOJ-7UJSqSFb.js → chunk-S3R3BYOJ-Cl0iW04v.js} +1 -1
- package/dist/assets/{chunk-TZMSLE5B-B7Xjx897.js → chunk-TZMSLE5B-f5ix6iSd.js} +1 -1
- package/dist/assets/classDiagram-2ON5EDUG-DlIMDu6i.js +1 -0
- package/dist/assets/classDiagram-v2-WZHVMYZB-CcIhhkQu.js +1 -0
- package/dist/assets/{clike-npv7NBwP.js → clike-bdcjLdZ4.js} +1 -1
- package/dist/assets/clojure-VUVi7fTV.js +1 -0
- package/dist/assets/cmake-DZJIDbjY.js +1 -0
- package/dist/assets/cobol-klCRwlLm.js +1 -0
- package/dist/assets/{code-block-37QAKDTI-BZVOQdyl.js → code-block-37QAKDTI-B19XL3UR.js} +1 -1
- package/dist/assets/coffeescript-C9foD9ub.js +1 -0
- package/dist/assets/{column-preview-CyyMserX.js → column-preview-BPismotx.js} +1 -1
- package/dist/assets/{command-palette-C0SuD26e.js → command-palette-Cdy8eCpi.js} +1 -1
- package/dist/assets/{common-Bei_EA1L.js → common-6n8M1qiK.js} +1 -1
- package/dist/assets/commonlisp-tHxoA35J.js +1 -0
- package/dist/assets/{components-B-vsJpY6.js → components-BzBUxUz0.js} +1 -1
- package/dist/assets/{components-cjKlTr3f.js → components-CK-WtvAJ.js} +1 -1
- package/dist/assets/config-ClMcu_sV.js +1 -0
- package/dist/assets/{cose-bilkent-S5V4N54A-CgMkzBzk.js → cose-bilkent-S5V4N54A-CQqSLzd1.js} +1 -1
- package/dist/assets/crystal-CQ11GdrX.js +1 -0
- package/dist/assets/{css-OVjTGRm9.js → css-ACAb8MRM.js} +1 -1
- package/dist/assets/cypher-CJ0Uzw29.js +1 -0
- package/dist/assets/d-DP0SUIt1.js +1 -0
- package/dist/assets/{dagre-6UL2VRFP-rclmYCNC.js → dagre-6UL2VRFP-CVKXpDlr.js} +1 -1
- package/dist/assets/{data-grid-overlay-editor-CO7vLLX5.js → data-grid-overlay-editor-BdDYn72O.js} +1 -1
- package/dist/assets/{datasource-CrDfHWto.js → datasource-DjDpJnbt.js} +2 -2
- package/dist/assets/dependency-graph-panel-BNaXAcZr.js +5 -0
- package/dist/assets/{diagram-PSM6KHXK-Dr5x-oaJ.js → diagram-PSM6KHXK-BfzLNKp-.js} +1 -1
- package/dist/assets/{diagram-QEK2KX5R-Cyino8Ci.js → diagram-QEK2KX5R-D_H77Ni5.js} +1 -1
- package/dist/assets/{diagram-S2PKOQOG-DYLuU52t.js → diagram-S2PKOQOG-DJmVBeMk.js} +1 -1
- package/dist/assets/diff-CNs8MB38.js +1 -0
- package/dist/assets/{dist-K7UrYXpJ.js → dist-BtL81uwZ.js} +1 -1
- package/dist/assets/{dist-BYYXrYaA.js → dist-Bww7hlVc.js} +1 -1
- package/dist/assets/{dist-BTDGJ6yw.js → dist-CJIOLS6O.js} +1 -1
- package/dist/assets/dist-CPF3W2Y-.js +1 -0
- package/dist/assets/{dist-D6HkmGB2.js → dist-CUapWJe4.js} +1 -1
- package/dist/assets/{dist-DYXeLJlk.js → dist-CWeWT34c.js} +1 -1
- package/dist/assets/{dist-CSowihAs.js → dist-CuCuJBdf.js} +1 -1
- package/dist/assets/{dist-fQYV9WTb.js → dist-DH60fwgs.js} +1 -1
- package/dist/assets/dist-DZPpMvcR.js +1 -0
- package/dist/assets/dist-DkcQg5xD.js +1 -0
- package/dist/assets/dist-DkzFxGAX.js +1 -0
- package/dist/assets/{dist-CtCHoDJA.js → dist-DmBXXm0k.js} +1 -1
- package/dist/assets/{dist-DB3ebLb3.js → dist-W1iHBJeE.js} +1 -1
- package/dist/assets/{dist-CO_N76Iz.js → dist-cgiAP5sW.js} +1 -1
- package/dist/assets/{dist-CGC-UAcL.js → dist-vkd1160q.js} +1 -1
- package/dist/assets/{dockerfile-CrSl2ewL.js → dockerfile-BSMbgQQl.js} +1 -1
- package/dist/assets/{documentation-panel-BWa3CXAu.js → documentation-panel-5jUKZR-l.js} +1 -1
- package/dist/assets/{download-CKGdZtPf.js → download-DT8gf0PL.js} +1 -1
- package/dist/assets/dtd-BsD0uJw0.js +1 -0
- package/dist/assets/dylan-DbrGP1IP.js +1 -0
- package/dist/assets/ecl-C0rZlhHw.js +1 -0
- package/dist/assets/edit-page-B7KTvcRN.js +9 -0
- package/dist/assets/eiffel-2ZX-OpSJ.js +1 -0
- package/dist/assets/elm-CbOSKldD.js +1 -0
- package/dist/assets/{erDiagram-Q2GNP2WA-FdS4NKUh.js → erDiagram-Q2GNP2WA-ROTNwSJz.js} +1 -1
- package/dist/assets/erlang-BWiOgHIX.js +1 -0
- package/dist/assets/{error-panel-BW7R1Ohr.js → error-panel-DHcg_ER5.js} +1 -1
- package/dist/assets/{esm-CwPtnMeh.js → esm-DeiyaVAJ.js} +1 -1
- package/dist/assets/{factor-MWFhpc0o.js → factor-C-_cRSDM.js} +1 -1
- package/dist/assets/factor-CUwFIMOP.js +1 -0
- package/dist/assets/{file-explorer-panel-C5v0FnJv.js → file-explorer-panel-CbOdvGyZ.js} +3 -3
- package/dist/assets/{file-icons-B1JtCN2e.js → file-icons-BiMOJy0r.js} +1 -1
- package/dist/assets/{floating-outline-wGcVRNZu.js → floating-outline-BN9sAcQ0.js} +1 -1
- package/dist/assets/{flowDiagram-NV44I4VS-DO4w8anv.js → flowDiagram-NV44I4VS--ee3IIVF.js} +1 -1
- package/dist/assets/{focus-COroLbWe.js → focus-q38vUCl-.js} +1 -1
- package/dist/assets/{form-Bstooyv1.js → form-BtBTvVVd.js} +2 -2
- package/dist/assets/forth-BEQA4QQL.js +1 -0
- package/dist/assets/fortran-DoPpOZgG.js +1 -0
- package/dist/assets/{ganttDiagram-JELNMOA3-Df-MBIrj.js → ganttDiagram-JELNMOA3-BGhmW2aP.js} +1 -1
- package/dist/assets/gas-BYovsvOE.js +1 -0
- package/dist/assets/gherkin-CFiRc1Pf.js +1 -0
- package/dist/assets/{gitGraph-G5XIXVHT-BAQx1hNd.js → gitGraph-G5XIXVHT-DuJ_0c_E.js} +1 -1
- package/dist/assets/{gitGraphDiagram-V2S2FVAM-fv2cmbLH.js → gitGraphDiagram-V2S2FVAM-DXFCZcxr.js} +1 -1
- package/dist/assets/{glide-data-editor-BAApVyo5.js → glide-data-editor-DqKNgyfg.js} +4 -4
- package/dist/assets/{globals-DggqXXLE.js → globals-7JnRMGd4.js} +1 -1
- package/dist/assets/groovy-DJNH7evt.js +1 -0
- package/dist/assets/haskell-duZvcePm.js +1 -0
- package/dist/assets/haxe-B2l95qvB.js +1 -0
- package/dist/assets/{home-page-B8SPyTFn.js → home-page-lXjPDNM0.js} +2 -2
- package/dist/assets/{hooks-CktFWxvJ.js → hooks-DP41kAWj.js} +1 -1
- package/dist/assets/{html-to-image-DB5sfuws.js → html-to-image-BWL3Ct4n.js} +1 -1
- package/dist/assets/idl-CZ_xwU8I.js +1 -0
- package/dist/assets/index-BIw7BKLH.css +2 -0
- package/dist/assets/index-awsLWRjZ.js +38 -0
- package/dist/assets/{info-VBDWY6EO-Cw9vVNQD.js → info-VBDWY6EO-DPQEAe2T.js} +1 -1
- package/dist/assets/infoDiagram-HS3SLOUP-CaaUieFa.js +2 -0
- package/dist/assets/javascript-CF5KGSAj.js +1 -0
- package/dist/assets/{journeyDiagram-XKPGCS4Q-C_cdVaga.js → journeyDiagram-XKPGCS4Q-9D2JCyrN.js} +1 -1
- package/dist/assets/julia-BQlq5iZn.js +1 -0
- package/dist/assets/{kanban-definition-3W4ZIXB7-CLpEm5s3.js → kanban-definition-3W4ZIXB7-DxV26rf-.js} +1 -1
- package/dist/assets/katex-CzQ1KdW3.js +1 -0
- package/dist/assets/{kiosk-mode-tHwBN3rS.js → kiosk-mode-BqvqWsFx.js} +1 -1
- package/dist/assets/layout-DXDnDtNw.js +9 -0
- package/dist/assets/{line-ortW3H6T.js → line-x4bpd_8D.js} +1 -1
- package/dist/assets/{linear-CIVE7jyt.js → linear-CW_ww8od.js} +1 -1
- package/dist/assets/livescript-sRMenfqS.js +1 -0
- package/dist/assets/{logs-panel-DZSPhsIs.js → logs-panel-BNoBKY1q.js} +1 -1
- package/dist/assets/{loro_wasm_bg-Ci19hd4D.js → loro_wasm_bg-CtNTubKN.js} +1 -1
- package/dist/assets/lua-a56ITumN.js +1 -0
- package/dist/assets/{markdown-renderer-BnUV17Tg.js → markdown-renderer-CU5Lbyax.js} +3 -3
- package/dist/assets/mathematica-B3m4jXeH.js +1 -0
- package/dist/assets/mbox-BtL7aO2I.js +1 -0
- package/dist/assets/mermaid-4DMBBIKO-CekzuCTz.js +1 -0
- package/dist/assets/{mermaid-D619LWHW.js → mermaid-Bes0ynI8.js} +3 -3
- package/dist/assets/{mermaid-parser.core-CMygPhv_.js → mermaid-parser.core-aYU6qXxk.js} +2 -2
- package/dist/assets/{mhchem-DSE1tfes.js → mhchem-8N2oE3tb.js} +1 -1
- package/dist/assets/{mindmap-definition-VGOIOE7T-mbWtJhR6.js → mindmap-definition-VGOIOE7T-DTJAbAQ8.js} +1 -1
- package/dist/assets/mirc-S27kuZ31.js +1 -0
- package/dist/assets/mllike-B3kx3KeF.js +1 -0
- package/dist/assets/modelica-DgbW4dSi.js +1 -0
- package/dist/assets/mscgen-BIa_4d-0.js +1 -0
- package/dist/assets/mumps-4fnELyHs.js +1 -0
- package/dist/assets/{name-cell-input-BZQLfDw0.js → name-cell-input-BNc3X9qF.js} +1 -1
- package/dist/assets/{nsis-CDylpiaC.js → nsis-BGZ5EB-j.js} +1 -1
- package/dist/assets/nsis-BfGyMssE.js +1 -0
- package/dist/assets/ntriples-DeY1n_tC.js +1 -0
- package/dist/assets/{number-overlay-editor-CHaQ6o4_.js → number-overlay-editor-DL4IwqDH.js} +1 -1
- package/dist/assets/octave-7Qn21jzx.js +1 -0
- package/dist/assets/{ordinal-RiUP-mHf.js → ordinal-_nQ2r1qQ.js} +1 -1
- package/dist/assets/{outline-panel-C4q1Ql1i.js → outline-panel-De2gw3Ro.js} +1 -1
- package/dist/assets/oz-CiPFl3Ni.js +1 -0
- package/dist/assets/{packages-panel-D9p8Tiee.js → packages-panel-C8maQt0Q.js} +1 -1
- package/dist/assets/{packet-DYOGHKS2-BXa5LrXK.js → packet-DYOGHKS2-CxgeJpvT.js} +1 -1
- package/dist/assets/pair-with-agent-modal-1tufe5MP.js +4 -0
- package/dist/assets/panels-BKv_j2lC.js +1 -0
- package/dist/assets/pascal-BH9yQLzw.js +1 -0
- package/dist/assets/perl-DfMCx2i2.js +1 -0
- package/dist/assets/{pie-VRWISCQL-BpZiOBLl.js → pie-VRWISCQL-GZ13ReaG.js} +1 -1
- package/dist/assets/{pieDiagram-ADFJNKIX-ouQhtndl.js → pieDiagram-ADFJNKIX-_3l2XiEo.js} +1 -1
- package/dist/assets/pig-D9CNebQN.js +1 -0
- package/dist/assets/powershell-Dss0bU9F.js +1 -0
- package/dist/assets/{process-output-czqgvDia.js → process-output-B2oklQi4.js} +1 -1
- package/dist/assets/properties-CHADYQUL.js +1 -0
- package/dist/assets/protobuf-DFN-V4SD.js +1 -0
- package/dist/assets/{pug-BXVTM5jr.js → pug-CYW0agOo.js} +1 -1
- package/dist/assets/pug-DOI9FnEk.js +1 -0
- package/dist/assets/puppet-BV0HAkDS.js +1 -0
- package/dist/assets/python-C83Db0-4.js +1 -0
- package/dist/assets/q-D84S4YaJ.js +1 -0
- package/dist/assets/{quadrantDiagram-AYHSOK5B-NRkmQ1sP.js → quadrantDiagram-AYHSOK5B-CX3AMAvR.js} +1 -1
- package/dist/assets/r-jmqrRzXv.js +1 -0
- package/dist/assets/{radar-ZZBFDIW7-CB-lQl_C.js → radar-ZZBFDIW7-CbAjwmA0.js} +1 -1
- package/dist/assets/{radio-group-BHzskOrm.js → radio-group-DlVSuZ_1.js} +1 -1
- package/dist/assets/{react-vega-CFabbyYN.js → react-vega-COx3Ibyn.js} +1 -1
- package/dist/assets/{react-vega-Bzl9LfSR.js → react-vega-CXIQBUis.js} +1 -1
- package/dist/assets/{readonly-python-code-u31O1EoO.js → readonly-python-code-D3_kHsDx.js} +1 -1
- package/dist/assets/renderShortcut-CcFk3m01.js +1 -0
- package/dist/assets/{requirementDiagram-UZGBJVZJ-C0LTiV9S.js → requirementDiagram-UZGBJVZJ-ORHKBnkg.js} +1 -1
- package/dist/assets/reveal-component-C50CTy8h.js +1069 -0
- package/dist/assets/rpm-DUjG0xRk.js +1 -0
- package/dist/assets/ruby-SP4FIzir.js +1 -0
- package/dist/assets/run-page-DeOIw0On.js +1 -0
- package/dist/assets/{sankeyDiagram-TZEHDZUN-CR2AycvD.js → sankeyDiagram-TZEHDZUN-Dvb8kmWa.js} +1 -1
- package/dist/assets/sas-BxaPz2EX.js +1 -0
- package/dist/assets/scheme-HBseLApj.js +1 -0
- package/dist/assets/{scratchpad-panel-B8GVlZFc.js → scratchpad-panel-DWbD_QB3.js} +1 -1
- package/dist/assets/{secrets-panel-B3E_Dkep.js → secrets-panel-BBvdIhtU.js} +1 -1
- package/dist/assets/{sequenceDiagram-WL72ISMW-CtF8-7iq.js → sequenceDiagram-WL72ISMW-DQycpQtE.js} +1 -1
- package/dist/assets/{session-panel-CeJHBx2m.js → session-panel-BHgL-7KC.js} +1 -1
- package/dist/assets/shell-w8ATY_lQ.js +1 -0
- package/dist/assets/sieve-Dyq0LGDO.js +1 -0
- package/dist/assets/smalltalk-D7mAtumc.js +1 -0
- package/dist/assets/{snippets-panel-BxEqEAeR.js → snippets-panel-FY_Ezibl.js} +1 -1
- package/dist/assets/sparql-DAeEYE_u.js +1 -0
- package/dist/assets/{src-CyeQdfB6.js → src-CvyFXpBy.js} +1 -1
- package/dist/assets/{state-D9_BpRuU.js → state-BTTshiKq.js} +3 -3
- package/dist/assets/{state-NqzCpbZn.js → state-D-2KaAHK.js} +1 -1
- package/dist/assets/{stateDiagram-FKZM4ZOC-R47bQmIs.js → stateDiagram-FKZM4ZOC-D78DIR_F.js} +1 -1
- package/dist/assets/stateDiagram-v2-4FDKWEC3-DX9rpmwh.js +1 -0
- package/dist/assets/{step-Ca7ZnceH.js → step-D7xg1Moj.js} +1 -1
- package/dist/assets/stylus-Cw3Ugan7.js +1 -0
- package/dist/assets/swift-CPsNOBsX.js +1 -0
- package/dist/assets/{switch-C8Pev-_F.js → switch-BiU_sAcn.js} +1 -1
- package/dist/assets/tcl-BfWyQdZa.js +1 -0
- package/dist/assets/{terminal-HJ3qH9Tb.js → terminal-BYGihNNp.js} +1 -1
- package/dist/assets/{textarea-By_oENlk.js → textarea-DwltG8V6.js} +1 -1
- package/dist/assets/textile-BKgaSzSN.js +1 -0
- package/dist/assets/{time-Dfh8bLaf.js → time-DLdI7jB3.js} +1 -1
- package/dist/assets/{timeline-definition-IT6M3QCI-qZnC-_po.js → timeline-definition-IT6M3QCI-DIywx3xf.js} +1 -1
- package/dist/assets/toml-BSOdv04W.js +1 -0
- package/dist/assets/{tracing-panel-DHbxfRgn.js → tracing-panel-bN0O3PuU.js} +2 -2
- package/dist/assets/{tracing-D3RHMNJS.js → tracing-zLH-qWb2.js} +1 -1
- package/dist/assets/{treemap-GDKQZRPO-C2f4_yBW.js → treemap-GDKQZRPO-Dz_qZhuG.js} +1 -1
- package/dist/assets/troff-C0hD9kig.js +1 -0
- package/dist/assets/ttcn-DEqPxhoh.js +1 -0
- package/dist/assets/ttcn-cfg-B-7jSlUe.js +1 -0
- package/dist/assets/turtle-BTtgFsu8.js +1 -0
- package/dist/assets/{useBoolean-DRITaoFR.js → useBoolean-Bp18o6XG.js} +1 -1
- package/dist/assets/{useCellActionButton-JqNWxCAc.js → useCellActionButton-h5LjhtEx.js} +1 -1
- package/dist/assets/{useDeleteCell-DhTEQpE6.js → useDeleteCell-BBPIhnQj.js} +1 -1
- package/dist/assets/useDependencyPanelTab-BSkmlMqr.js +1 -0
- package/dist/assets/{useHotkey-CKk0vHze.js → useHotkey-TKvjHf1m.js} +1 -1
- package/dist/assets/useNotebookActions-B32eCmtG.js +1 -0
- package/dist/assets/{useRunCells-DeA7yeHJ.js → useRunCells-BiCBGyeW.js} +1 -1
- package/dist/assets/{useSplitCell-DWx-q9BJ.js → useSplitCell-uogO-7ac.js} +1 -1
- package/dist/assets/useTheme-CI2eq4XN.js +1 -0
- package/dist/assets/utils-CvI-39U6.js +1 -0
- package/dist/assets/vb-DfRPk_ji.js +1 -0
- package/dist/assets/vbscript-C8D4uv5N.js +1 -0
- package/dist/assets/{vega-component-CBW7fUCI.js → vega-component-COOhhZ3h.js} +1 -1
- package/dist/assets/velocity-DxKr2FFC.js +1 -0
- package/dist/assets/verilog-CxVhamiH.js +1 -0
- package/dist/assets/vhdl-B-IpBNOA.js +1 -0
- package/dist/assets/webidl-CBjKmBwO.js +1 -0
- package/dist/assets/xquery-ABGCbLv0.js +1 -0
- package/dist/assets/{xychartDiagram-PRI3JC2R-Ul_9KMcM.js → xychartDiagram-PRI3JC2R-CjS1dL8k.js} +1 -1
- package/dist/assets/yacas-Ckyxh7oh.js +1 -0
- package/dist/assets/z80-Dr5sQweg.js +1 -0
- package/dist/index.html +32 -32
- package/package.json +1 -1
- package/src/components/ai/__tests__/ai-utils.test.ts +43 -38
- package/src/components/ai/ai-model-dropdown.tsx +2 -2
- package/src/components/app-config/ai-config.tsx +147 -16
- package/src/components/app-config/user-config-form.tsx +37 -1
- package/src/components/chat/__tests__/chat-utils.test.ts +269 -0
- package/src/components/chat/chat-panel.tsx +38 -5
- package/src/components/chat/chat-utils.ts +14 -58
- package/src/components/data-table/TableBottomBar.tsx +5 -8
- package/src/components/data-table/__tests__/column-explorer.test.tsx +128 -0
- package/src/components/data-table/__tests__/header-items.test.tsx +220 -10
- package/src/components/data-table/column-explorer-panel/column-explorer.tsx +95 -29
- package/src/components/data-table/column-header.tsx +17 -12
- package/src/components/data-table/data-table.tsx +4 -0
- package/src/components/data-table/export-actions.tsx +19 -12
- package/src/components/data-table/header-items.tsx +40 -16
- package/src/components/data-table/hooks/use-column-visibility.ts +14 -0
- package/src/components/data-table/schemas.ts +2 -2
- package/src/components/data-table/table-explorer-panel/table-explorer-panel.tsx +16 -6
- package/src/components/databases/display.tsx +2 -0
- package/src/components/datasources/__tests__/utils.test.ts +82 -0
- package/src/components/datasources/utils.ts +16 -15
- package/src/components/editor/Disconnected.tsx +1 -60
- package/src/components/editor/__tests__/viewer-banner.test.tsx +89 -0
- package/src/components/editor/actions/pair-with-agent-modal.tsx +1 -0
- package/src/components/editor/actions/useCellActionButton.tsx +3 -3
- package/src/components/editor/actions/useNotebookActions.tsx +5 -2
- package/src/components/editor/cell/code/cell-editor.tsx +25 -5
- package/src/components/editor/chrome/types.ts +13 -6
- package/src/components/editor/chrome/wrapper/app-chrome.tsx +6 -4
- package/src/components/editor/chrome/wrapper/footer-items/ai-status.tsx +10 -1
- package/src/components/editor/chrome/wrapper/sidebar.tsx +7 -5
- package/src/components/editor/errors/auto-fix.tsx +3 -3
- package/src/components/editor/header/__tests__/status.test.tsx +0 -15
- package/src/components/editor/header/app-header.tsx +1 -4
- package/src/components/editor/header/status.tsx +4 -13
- package/src/components/editor/navigation/__tests__/navigation.test.ts +15 -0
- package/src/components/editor/navigation/navigation.ts +5 -0
- package/src/components/editor/output/MarimoErrorOutput.tsx +103 -25
- package/src/components/editor/output/MarimoTracebackOutput.tsx +28 -39
- package/src/components/editor/renderers/cell-array.tsx +27 -24
- package/src/components/editor/renderers/slides-layout/__tests__/compute-slide-cells.test.ts +30 -17
- package/src/components/editor/renderers/slides-layout/compute-slide-cells.ts +17 -8
- package/src/components/editor/renderers/slides-layout/slides-layout.tsx +10 -12
- package/src/components/editor/viewer-banner.tsx +82 -0
- package/src/components/slides/minimap.tsx +45 -9
- package/src/components/slides/reveal-component.tsx +82 -37
- package/src/components/slides/slide-cell-view.tsx +12 -1
- package/src/components/slides/slide-form.tsx +11 -3
- package/src/components/static-html/static-banner.tsx +28 -22
- package/src/core/ai/__tests__/model-registry.test.ts +72 -60
- package/src/core/ai/model-registry.ts +33 -28
- package/src/core/cells/__tests__/actions.test.ts +48 -0
- package/src/core/cells/actions.ts +5 -6
- package/src/core/codemirror/__tests__/setup.test.ts +29 -0
- package/src/core/codemirror/cells/traceback-decorations.ts +1 -1
- package/src/core/codemirror/cm.ts +50 -3
- package/src/core/codemirror/completion/hints.ts +4 -1
- package/src/core/codemirror/format.ts +1 -0
- package/src/core/codemirror/keymaps/vim.ts +63 -0
- package/src/core/codemirror/language/languages/sql/sql.ts +1 -0
- package/src/core/codemirror/language/languages/sql/utils.ts +2 -0
- package/src/core/config/__tests__/config-schema.test.ts +4 -0
- package/src/core/config/config-schema.ts +4 -0
- package/src/core/config/config.ts +16 -0
- package/src/core/edit-app.tsx +3 -0
- package/src/core/islands/bootstrap.ts +2 -0
- package/src/core/kernel/__tests__/handlers.test.ts +5 -0
- package/src/core/websocket/__tests__/useMarimoKernelConnection.test.ts +0 -13
- package/src/core/websocket/types.ts +0 -6
- package/src/core/websocket/useMarimoKernelConnection.tsx +3 -12
- package/src/css/app/Cell.css +0 -1
- package/src/plugins/impl/DataTablePlugin.tsx +48 -22
- package/src/plugins/impl/chat/ChatPlugin.tsx +7 -1
- package/src/plugins/impl/chat/__tests__/chat-ui.test.ts +278 -0
- package/src/plugins/impl/chat/chat-ui.tsx +106 -59
- package/src/plugins/impl/chat/types.ts +5 -0
- package/src/utils/__tests__/json-parser.test.ts +1 -69
- package/src/utils/json/json-parser.ts +0 -30
- package/dist/assets/JsonOutput-DfDkDg0V.js +0 -53
- package/dist/assets/LazyAnyLanguageCodeMirror-DFv3yT20.js +0 -2
- package/dist/assets/MarimoErrorOutput-BXSRPZqF.js +0 -7
- package/dist/assets/ai-model-dropdown-D0tfwqft.js +0 -5
- package/dist/assets/apl-CZC-w0DM.js +0 -1
- package/dist/assets/asciiarmor-Dxkbb4uS.js +0 -1
- package/dist/assets/asn1-CrA2MPaL.js +0 -1
- package/dist/assets/brainfuck-B5oLVauS.js +0 -1
- package/dist/assets/cell-editor-hBNMClE6.js +0 -20
- package/dist/assets/channel-V1GV6hO1.js +0 -1
- package/dist/assets/chat-panel-BC-bG7Ms.js +0 -3
- package/dist/assets/chat-ui-B0pCMupQ.js +0 -4
- package/dist/assets/chunk-55IACEB6-BRJvcREw.js +0 -1
- package/dist/assets/classDiagram-2ON5EDUG-C8jlAFC-.js +0 -1
- package/dist/assets/classDiagram-v2-WZHVMYZB-DYST6eBL.js +0 -1
- package/dist/assets/clojure-D60XavrX.js +0 -1
- package/dist/assets/cmake-CrWsGXcU.js +0 -1
- package/dist/assets/cobol-CZosvDFE.js +0 -1
- package/dist/assets/coffeescript-DQGIz3iX.js +0 -1
- package/dist/assets/commonlisp-DrWSVXOx.js +0 -1
- package/dist/assets/config-C1gn3-tv.js +0 -1
- package/dist/assets/crystal-CMu2RgP7.js +0 -1
- package/dist/assets/cypher-C4I5nX3I.js +0 -1
- package/dist/assets/d-B_OAkSA3.js +0 -1
- package/dist/assets/dependency-graph-panel-skSyvOmU.js +0 -5
- package/dist/assets/diff-f-qA4U7T.js +0 -1
- package/dist/assets/dist-B2-3vH3I.js +0 -1
- package/dist/assets/dist-B3r3gs4u.js +0 -1
- package/dist/assets/dist-Dx65VI0Y.js +0 -1
- package/dist/assets/dist-FSgOAwAH.js +0 -1
- package/dist/assets/dtd-DWRTME-w.js +0 -1
- package/dist/assets/dylan-DnEm_ULG.js +0 -1
- package/dist/assets/ecl-Dbf1A5nG.js +0 -1
- package/dist/assets/edit-page-cW6c6KHJ.js +0 -9
- package/dist/assets/eiffel-Xj76_r0X.js +0 -1
- package/dist/assets/elm-nUwO24NA.js +0 -1
- package/dist/assets/erlang-CFVqMiR0.js +0 -1
- package/dist/assets/factor-mJPTAioV.js +0 -1
- package/dist/assets/forth-DBQr6L61.js +0 -1
- package/dist/assets/fortran-BkjqlXUL.js +0 -1
- package/dist/assets/gas-BNFtcdO9.js +0 -1
- package/dist/assets/gherkin-BrOMWqkN.js +0 -1
- package/dist/assets/groovy-DuCnwFRS.js +0 -1
- package/dist/assets/haskell-BD39942g.js +0 -1
- package/dist/assets/haxe-CXsKoap0.js +0 -1
- package/dist/assets/idl-D7hb6rI1.js +0 -1
- package/dist/assets/index-Cn0RBoFD.css +0 -2
- package/dist/assets/index-Df-5tfH1.js +0 -38
- package/dist/assets/infoDiagram-HS3SLOUP-CpBkxLyN.js +0 -2
- package/dist/assets/javascript-1S1_-Xac.js +0 -1
- package/dist/assets/julia-CbOUdU45.js +0 -1
- package/dist/assets/katex-BuYoGw8D.js +0 -1
- package/dist/assets/layout-CCKaB1K9.js +0 -9
- package/dist/assets/livescript-4YbxVKEy.js +0 -1
- package/dist/assets/lua-Dp2B-Joo.js +0 -1
- package/dist/assets/mathematica-BaSnKpgq.js +0 -1
- package/dist/assets/mbox-JZJfXD_G.js +0 -1
- package/dist/assets/mermaid-4DMBBIKO-BV51xhvi.js +0 -1
- package/dist/assets/mirc-BZe50pjl.js +0 -1
- package/dist/assets/mllike-Bgkhf51-.js +0 -1
- package/dist/assets/modelica-BzrnHsaM.js +0 -1
- package/dist/assets/mscgen-C7fmiScS.js +0 -1
- package/dist/assets/mumps-DYao3Wbn.js +0 -1
- package/dist/assets/nsis-BV9URIq2.js +0 -1
- package/dist/assets/ntriples-CCTjcLNo.js +0 -1
- package/dist/assets/octave-CalSSDIP.js +0 -1
- package/dist/assets/oz-BwBvNNj4.js +0 -1
- package/dist/assets/panels-CFhryJbE.js +0 -1
- package/dist/assets/pascal-VtYjd8tX.js +0 -1
- package/dist/assets/perl-CuiQHSod.js +0 -1
- package/dist/assets/pig-CIHZG4Z9.js +0 -1
- package/dist/assets/powershell-CI2Wos2z.js +0 -1
- package/dist/assets/properties-CBOFbPgT.js +0 -1
- package/dist/assets/protobuf-CdcXLd43.js +0 -1
- package/dist/assets/pug-DJHP9Svh.js +0 -1
- package/dist/assets/puppet-B2nxuZc5.js +0 -1
- package/dist/assets/python-VpIaVd-6.js +0 -1
- package/dist/assets/q-CamvlcK6.js +0 -1
- package/dist/assets/r-CgsrYWFj.js +0 -1
- package/dist/assets/renderShortcut-U2SzoZCS.js +0 -1
- package/dist/assets/reveal-component-Ds9C9Z1D.js +0 -1069
- package/dist/assets/rpm-DBux1aMG.js +0 -1
- package/dist/assets/ruby-BWHIAyVi.js +0 -1
- package/dist/assets/run-page-BC3D2rvr.js +0 -1
- package/dist/assets/sas-DJpj3tMb.js +0 -1
- package/dist/assets/scheme-DF-J69qP.js +0 -1
- package/dist/assets/shell-m-RSMeeH.js +0 -1
- package/dist/assets/sieve-CtzQvaig.js +0 -1
- package/dist/assets/smalltalk-ClFvBgAI.js +0 -1
- package/dist/assets/sparql-icVR0QFW.js +0 -1
- package/dist/assets/stateDiagram-v2-4FDKWEC3-sSKQU37N.js +0 -1
- package/dist/assets/stylus-TkCXytG7.js +0 -1
- package/dist/assets/swift-CBYBwE0m.js +0 -1
- package/dist/assets/tcl-DvyBVTw2.js +0 -1
- package/dist/assets/textile-DA3WvzuI.js +0 -1
- package/dist/assets/toml-BJa3ckRR.js +0 -1
- package/dist/assets/troff-CqZSdBAp.js +0 -1
- package/dist/assets/ttcn-BouEBguh.js +0 -1
- package/dist/assets/ttcn-cfg-C1whpGsE.js +0 -1
- package/dist/assets/turtle-DQ8l-awL.js +0 -1
- package/dist/assets/useDependencyPanelTab-BeLaV_28.js +0 -1
- package/dist/assets/useNotebookActions-C6L8GqPD.js +0 -4
- package/dist/assets/useTheme-TeWD29Uz.js +0 -1
- package/dist/assets/utils-Wvjk_Y4h.js +0 -1
- package/dist/assets/vb-B7wOdn6U.js +0 -1
- package/dist/assets/vbscript-DvH455rJ.js +0 -1
- package/dist/assets/velocity-B6C6O90i.js +0 -1
- package/dist/assets/verilog-JbcxpuFW.js +0 -1
- package/dist/assets/vhdl-SEFTp5Re.js +0 -1
- package/dist/assets/webidl-ChYZayPm.js +0 -1
- package/dist/assets/xquery-DWwllqyg.js +0 -1
- package/dist/assets/yacas-DQRdrpIp.js +0 -1
- package/dist/assets/z80-CGBxwDW7.js +0 -1
- /package/dist/assets/{ImageComparisonComponent-B5A-4CCj.js → ImageComparisonComponent-BIetTBDq.js} +0 -0
- /package/dist/assets/{Inputs-BG_nVZPt.js → Inputs-C6ftxLAJ.js} +0 -0
- /package/dist/assets/{Plot-CoEOwQq-.js → Plot-Ba3WGWNu.js} +0 -0
- /package/dist/assets/{apl-4hxG7HNk.js → apl-Byte72fT.js} +0 -0
- /package/dist/assets/{array-D5VxClQs.js → array-CC7vZNGO.js} +0 -0
- /package/dist/assets/{asciiarmor-Dv_174xi.js → asciiarmor-BU-VnG1Y.js} +0 -0
- /package/dist/assets/{asn1-iiMvplI8.js → asn1-hTvH3S4T.js} +0 -0
- /package/dist/assets/{asterisk-CC3QRUnf.js → asterisk-DIMri3P4.js} +0 -0
- /package/dist/assets/{brainfuck-C1zBqC_V.js → brainfuck-C-q1Rv8J.js} +0 -0
- /package/dist/assets/{chunk-4F5CHEZ2-DUo5vZ2r.js → chunk-4F5CHEZ2-eEwFz7fp.js} +0 -0
- /package/dist/assets/{chunk-B2363JML-BBEseLU0.js → chunk-B2363JML-COExSe0d.js} +0 -0
- /package/dist/assets/{chunk-DR5Q36YT-C0WIZcJM.js → chunk-DR5Q36YT-OB6tC_dd.js} +0 -0
- /package/dist/assets/{chunk-FRFDVMJY-CXpDqtzE.js → chunk-FRFDVMJY-CO3-6rb4.js} +0 -0
- /package/dist/assets/{chunk-PL6DKKU2-CdWr1t_8.js → chunk-PL6DKKU2-B9mDp5iV.js} +0 -0
- /package/dist/assets/{chunk-SJTYNZTY-SWJVmNtW.js → chunk-SJTYNZTY-Dh_h90Yu.js} +0 -0
- /package/dist/assets/{chunk-TQ3KTPDO-NHSLONf7.js → chunk-TQ3KTPDO-CFybjK0M.js} +0 -0
- /package/dist/assets/{chunk-UMXZTB3W-Ct179y25.js → chunk-UMXZTB3W-C3w83KpJ.js} +0 -0
- /package/dist/assets/{clear-button-CIwzVocs.js → clear-button-Cfe8K4j_.js} +0 -0
- /package/dist/assets/{click-outside-container-Bx6OOW4y.js → click-outside-container-BNVqwewc.js} +0 -0
- /package/dist/assets/{clike-DgscWMor.js → clike-BE-9Ct_H.js} +0 -0
- /package/dist/assets/{clojure-BHbbYwIQ.js → clojure-Co-TLeNo.js} +0 -0
- /package/dist/assets/{cmake-DLR6lpqL.js → cmake-B-Nm_Opd.js} +0 -0
- /package/dist/assets/{cobol-BCxTxy3w.js → cobol-BGdihAZT.js} +0 -0
- /package/dist/assets/{coffeescript-CpA2P5vm.js → coffeescript-BUZXkMUO.js} +0 -0
- /package/dist/assets/{colors-CWfEs9Oi.js → colors-BG8Z91CW.js} +0 -0
- /package/dist/assets/{common-keywords-0dB1lgek.js → common-keywords-15xBKau4.js} +0 -0
- /package/dist/assets/{commonlisp-IOtLAQXJ.js → commonlisp-CFkPbxvX.js} +0 -0
- /package/dist/assets/{crystal-D5D6_kGA.js → crystal-CqfqDl34.js} +0 -0
- /package/dist/assets/{css-DOb8-BDy.js → css-DPEtZWJi.js} +0 -0
- /package/dist/assets/{cypher-DLF7i4IG.js → cypher-B0t8FJvU.js} +0 -0
- /package/dist/assets/{cytoscape.esm-CuwfIk-V.js → cytoscape.esm-DT8iy6p1.js} +0 -0
- /package/dist/assets/{d-ByNdxjrk.js → d-DRa_XRSB.js} +0 -0
- /package/dist/assets/{diff-DgsriQcn.js → diff-GLneonpD.js} +0 -0
- /package/dist/assets/{dist-B6ehDvA-.js → dist-A7swzSTR.js} +0 -0
- /package/dist/assets/{dist-Cofj3PRM.js → dist-BF6UNR6V.js} +0 -0
- /package/dist/assets/{dist-Bc225YxE.js → dist-BQWswd1A.js} +0 -0
- /package/dist/assets/{dist-DviQ3W6h.js → dist-BQeNY9Zl.js} +0 -0
- /package/dist/assets/{dist-BA8xhrl2.js → dist-BXRWfNwi.js} +0 -0
- /package/dist/assets/{dist-fhXsH3fb.js → dist-BlOtCkpT.js} +0 -0
- /package/dist/assets/{dist-D8MaDlGc.js → dist-C78V1LRz.js} +0 -0
- /package/dist/assets/{dist-CcoNWYux.js → dist-CKT_lJKW.js} +0 -0
- /package/dist/assets/{dist-CNghxh0Q.js → dist-CNyMUs19.js} +0 -0
- /package/dist/assets/{dist-qBfIhsAs.js → dist-CXBpwk_w.js} +0 -0
- /package/dist/assets/{dist-D86l0QaP.js → dist-CciFN1z_.js} +0 -0
- /package/dist/assets/{dist-cS6yvaqe.js → dist-CocyeH0q.js} +0 -0
- /package/dist/assets/{dist-C_k5-SEy.js → dist-CpcTHxTt.js} +0 -0
- /package/dist/assets/{dist-WcxjmQmQ.js → dist-CsvFAFh9.js} +0 -0
- /package/dist/assets/{dist-oSdg9XA7.js → dist-D70Tz1Kr.js} +0 -0
- /package/dist/assets/{dist-CjBmWBr2.js → dist-DUHHizRG.js} +0 -0
- /package/dist/assets/{dist-CiOPfbN_.js → dist-DqVEVg0c.js} +0 -0
- /package/dist/assets/{dtd-BY21shY3.js → dtd-uVrZNVF0.js} +0 -0
- /package/dist/assets/{duckdb-keywords-DH8yhwVC.js → duckdb-keywords-CYQ5DEZJ.js} +0 -0
- /package/dist/assets/{dylan-D_hF5J0y.js → dylan-DkNeA4FZ.js} +0 -0
- /package/dist/assets/{ebnf-D73UE5Hl.js → ebnf-XMH6KY7E.js} +0 -0
- /package/dist/assets/{ecl-C1ORA0cg.js → ecl-CldUgvc9.js} +0 -0
- /package/dist/assets/{eiffel-1fe3g8c_.js → eiffel-CoMDRbRL.js} +0 -0
- /package/dist/assets/{elm-hjWurFzL.js → elm-Cb5XC6ev.js} +0 -0
- /package/dist/assets/{erlang-Bp4wxA5O.js → erlang-8H3fTZ3L.js} +0 -0
- /package/dist/assets/{esm-DM72gy9Q.js → esm-1wf4HygE.js} +0 -0
- /package/dist/assets/{fcl-1tMcz7c0.js → fcl-DyFJAgkq.js} +0 -0
- /package/dist/assets/{formatting-3l1CoS7X.js → formatting-CSG9kqNb.js} +0 -0
- /package/dist/assets/{forth-5O98d424.js → forth-B8kC4npz.js} +0 -0
- /package/dist/assets/{fortran-BIuAFxQ8.js → fortran-CNWGEL3c.js} +0 -0
- /package/dist/assets/{gallery-page-7ltBHWVR.js → gallery-page-Bcf7fYLy.js} +0 -0
- /package/dist/assets/{gas-CHHhShkY.js → gas-DnZQNTHK.js} +0 -0
- /package/dist/assets/{gherkin-DIjcYYBT.js → gherkin-JfGcGvci.js} +0 -0
- /package/dist/assets/{groovy-BYU3Z-yz.js → groovy-D0FWiAVm.js} +0 -0
- /package/dist/assets/{haskell-CjOVOYhk.js → haskell-wUB3uX-G.js} +0 -0
- /package/dist/assets/{haxe-Cb_U41Kf.js → haxe-g0JY6eL-.js} +0 -0
- /package/dist/assets/{http-DTsrgwMt.js → http-ySzAzH5W.js} +0 -0
- /package/dist/assets/{idl-XfUB5VqU.js → idl-CV2cLkPc.js} +0 -0
- /package/dist/assets/{init-BYCsRZEq.js → init-DsZRk2YA.js} +0 -0
- /package/dist/assets/{javascript-BZ9iuJe9.js → javascript-CT6okXEZ.js} +0 -0
- /package/dist/assets/{julia-ZgWUbR6s.js → julia-CKC48ufo.js} +0 -0
- /package/dist/assets/{katex-BNYG1in3.js → katex-BE4UDS50.js} +0 -0
- /package/dist/assets/{links-DguLoFik.js → links-1rtF1-eC.js} +0 -0
- /package/dist/assets/{livescript-PvHqMAnA.js → livescript-C43pZ6Ue.js} +0 -0
- /package/dist/assets/{loro_wasm_bg-Z5Iceaci.js → loro_wasm_bg-CXnd80ne.js} +0 -0
- /package/dist/assets/{lua-BAkgehCh.js → lua-Cs2mb10K.js} +0 -0
- /package/dist/assets/{marimo-icons-CcDNGIRM.js → marimo-icons-CiwvnnsT.js} +0 -0
- /package/dist/assets/{math-D-qpUWKO.js → math-B-ZqhQTL.js} +0 -0
- /package/dist/assets/{mathematica-sYPoESCW.js → mathematica-B5FMK3ma.js} +0 -0
- /package/dist/assets/{mbox-BFVpgB4i.js → mbox-36Zrn5Bd.js} +0 -0
- /package/dist/assets/{mirc-DAwdMlc7.js → mirc-BKTAABSX.js} +0 -0
- /package/dist/assets/{mllike-CNENYbun.js → mllike-DbuClUqc.js} +0 -0
- /package/dist/assets/{modelica-FtpuFG3d.js → modelica-CKRvBm7N.js} +0 -0
- /package/dist/assets/{mscgen-BZpZ1eAc.js → mscgen-B4BRgnCi.js} +0 -0
- /package/dist/assets/{multi-icon-aZG-rdCp.js → multi-icon-NVkxesVZ.js} +0 -0
- /package/dist/assets/{mumps-BM8g2rR9.js → mumps-BFiMcyFV.js} +0 -0
- /package/dist/assets/{nginx-CREUN6EW.js → nginx-Cz_XvoTm.js} +0 -0
- /package/dist/assets/{node-sql-parser-fWuidk6P.js → node-sql-parser-BtkrI4pN.js} +0 -0
- /package/dist/assets/{ntriples-Dpum4Lhl.js → ntriples-QQAkJYAR.js} +0 -0
- /package/dist/assets/{octave-C-8skAyy.js → octave-DsTphmGZ.js} +0 -0
- /package/dist/assets/{oz-C9dNiWs3.js → oz-CD9rr5Iz.js} +0 -0
- /package/dist/assets/{panel-context-C3ham7ZV.js → panel-context-BJbBGfoL.js} +0 -0
- /package/dist/assets/{pascal-OtDoyUlT.js → pascal-DdHEIlJE.js} +0 -0
- /package/dist/assets/{path-_EHCEa2c.js → path-DvTahePH.js} +0 -0
- /package/dist/assets/{perl-Bq6zPLry.js → perl-DHPJBQ1u.js} +0 -0
- /package/dist/assets/{pig-CzHJ3vXa.js → pig-Yz7ERgca.js} +0 -0
- /package/dist/assets/{powershell-CPgLwhmC.js → powershell-CHPZ_bsU.js} +0 -0
- /package/dist/assets/{properties-Kfp4iofx.js → properties-CI9nc7K4.js} +0 -0
- /package/dist/assets/{protobuf-BtodseUb.js → protobuf-BYSIv2pY.js} +0 -0
- /package/dist/assets/{puppet-DqMZ-3jb.js → puppet-CEpLafZX.js} +0 -0
- /package/dist/assets/{python-Du1sm3Dz.js → python-BndVuwG1.js} +0 -0
- /package/dist/assets/{q-mTJjDbkl.js → q-L_cetpiW.js} +0 -0
- /package/dist/assets/{r-CiWGt8bY.js → r-Dd37AKWk.js} +0 -0
- /package/dist/assets/{request-registry-Gm-nOP6a.js → request-registry--h6PWG50.js} +0 -0
- /package/dist/assets/{requests-Bm3bohzL.js → requests-DqJEWJ-Q.js} +0 -0
- /package/dist/assets/{rpm-DoWl8uQ-.js → rpm-CHrvhtlN.js} +0 -0
- /package/dist/assets/{ruby-EPWn7HjP.js → ruby-BPOowfX6.js} +0 -0
- /package/dist/assets/{runs-_nm7RTvJ.js → runs-BD0G-C2A.js} +0 -0
- /package/dist/assets/{sas-C49N66K9.js → sas-BsEFSvEP.js} +0 -0
- /package/dist/assets/{scheme-BKBMeaMf.js → scheme-B42INBu7.js} +0 -0
- /package/dist/assets/{shell-B3Qif7WE.js → shell-BPea12OI.js} +0 -0
- /package/dist/assets/{sieve-D2oOzUQe.js → sieve-C-yPcLw5.js} +0 -0
- /package/dist/assets/{simple-mode-awvuWmjh.js → simple-mode-CFlvn0Mm.js} +0 -0
- /package/dist/assets/{smalltalk-D2JNyQE_.js → smalltalk-e7OO1ATb.js} +0 -0
- /package/dist/assets/{solr-DD6Hdy4w.js → solr-BAO4N63o.js} +0 -0
- /package/dist/assets/{sparql-B_E2GW41.js → sparql-B4I2Ledx.js} +0 -0
- /package/dist/assets/{spreadsheet-DQc2JQ5m.js → spreadsheet-DWqd5foV.js} +0 -0
- /package/dist/assets/{sql-Cj5Wcvsd.js → sql-RBdzBYsM.js} +0 -0
- /package/dist/assets/{src-faGJHwXX.js → src-BnrQkOKh.js} +0 -0
- /package/dist/assets/{stylus-R6o8NrsG.js → stylus-CBRbZwhN.js} +0 -0
- /package/dist/assets/{swift-Dbh-hbmH.js → swift-B2hnU7ha.js} +0 -0
- /package/dist/assets/{swiper-component-Dgt-sBCT.js → swiper-component-YGJlBaCp.js} +0 -0
- /package/dist/assets/{tcl-B7hCCUdg.js → tcl-BtyamtaZ.js} +0 -0
- /package/dist/assets/{textile-3T2abjma.js → textile-M9mhyNE9.js} +0 -0
- /package/dist/assets/{tiddlywiki-Co__osNU.js → tiddlywiki-BsHUDwie.js} +0 -0
- /package/dist/assets/{tiki-CfCZczlo.js → tiki-ZqBe4Kjv.js} +0 -0
- /package/dist/assets/{timer-BgiWPhV9.js → timer-B6DpdVnC.js} +0 -0
- /package/dist/assets/{toml-BfSTXCbK.js → toml-YxyxhyRy.js} +0 -0
- /package/dist/assets/{treemap-F5PoC_M0.js → treemap-DeGcO9km.js} +0 -0
- /package/dist/assets/{troff-TmwTwfFH.js → troff-C7xpi05X.js} +0 -0
- /package/dist/assets/{ttcn-BptQ-efU.js → ttcn-D3YytrJU.js} +0 -0
- /package/dist/assets/{ttcn-cfg-BJSeQh2j.js → ttcn-cfg-DlZ5vA9E.js} +0 -0
- /package/dist/assets/{turtle-NWQZPdQh.js → turtle-BSHvAsUe.js} +0 -0
- /package/dist/assets/{types-iYXk7c05.js → types-a-yURniQ.js} +0 -0
- /package/dist/assets/{useInterval-Bc-mr0KL.js → useInterval-2YvvhIZI.js} +0 -0
- /package/dist/assets/{vb-5MAVubtN.js → vb-DdkIDLlO.js} +0 -0
- /package/dist/assets/{vbscript-C3wI-prb.js → vbscript-DhYGmk_p.js} +0 -0
- /package/dist/assets/{velocity-BZ0SsVqc.js → velocity-DAXJNEw4.js} +0 -0
- /package/dist/assets/{verilog-sCLfsuOk.js → verilog-jmuT_L3b.js} +0 -0
- /package/dist/assets/{vhdl-D8-XDERr.js → vhdl-DcVQ97RU.js} +0 -0
- /package/dist/assets/{web-vitals-CJ8ovao_.js → web-vitals-xkV-JBVF.js} +0 -0
- /package/dist/assets/{webidl-C2DK9LNJ.js → webidl-B-YB_4OQ.js} +0 -0
- /package/dist/assets/{write-secret-modal-DEx_mRHR.js → write-secret-modal-BFLlHwgU.js} +0 -0
- /package/dist/assets/{ws-YSapF1PN.js → ws-BnE9sl8z.js} +0 -0
- /package/dist/assets/{xquery-Db3HYO3C.js → xquery-DOmY3Oe8.js} +0 -0
- /package/dist/assets/{yacas-DhfMSinV.js → yacas-pL3kJRXV.js} +0 -0
- /package/dist/assets/{z80-CH-vqbta.js → z80-VwVuI_MT.js} +0 -0
|
@@ -509,7 +509,7 @@ const ModelInfoCard = ({ model }: { model: AiModel }) => {
|
|
|
509
509
|
<Tooltip content="Custom model">
|
|
510
510
|
{model.custom && <BotIcon className="h-4 w-4" />}
|
|
511
511
|
</Tooltip>
|
|
512
|
-
{model.thinking && (
|
|
512
|
+
{model.capabilities.includes("thinking") && (
|
|
513
513
|
<div
|
|
514
514
|
className={cn(
|
|
515
515
|
"flex items-center gap-1 rounded px-1 py-0.5 w-fit",
|
|
@@ -1253,6 +1253,13 @@ export const AiAssistConfig: React.FC<AiConfigProps> = ({
|
|
|
1253
1253
|
config,
|
|
1254
1254
|
onSubmit,
|
|
1255
1255
|
}) => {
|
|
1256
|
+
// Tracked locally rather than derived from the field value so that clearing
|
|
1257
|
+
// the input (a transient empty value, which commits `null`) does not disable
|
|
1258
|
+
// the input mid-edit and force the user to re-tick the Override checkbox.
|
|
1259
|
+
const [maxTokensEnabled, setMaxTokensEnabled] = useState(
|
|
1260
|
+
config.ai?.max_tokens != null,
|
|
1261
|
+
);
|
|
1262
|
+
|
|
1256
1263
|
return (
|
|
1257
1264
|
<SettingGroup>
|
|
1258
1265
|
<SettingSubtitle>AI Assistant</SettingSubtitle>
|
|
@@ -1279,6 +1286,71 @@ export const AiAssistConfig: React.FC<AiConfigProps> = ({
|
|
|
1279
1286
|
)}
|
|
1280
1287
|
/>
|
|
1281
1288
|
|
|
1289
|
+
<FormField
|
|
1290
|
+
control={form.control}
|
|
1291
|
+
name="ai.max_tokens"
|
|
1292
|
+
render={({ field }) => {
|
|
1293
|
+
return (
|
|
1294
|
+
<div className="flex flex-col gap-y-1">
|
|
1295
|
+
<div className="flex items-center gap-x-2">
|
|
1296
|
+
<FormItem className={formItemClasses}>
|
|
1297
|
+
<FormLabel className="font-normal">
|
|
1298
|
+
Max output tokens
|
|
1299
|
+
</FormLabel>
|
|
1300
|
+
<FormControl>
|
|
1301
|
+
<Input
|
|
1302
|
+
data-testid="ai-max-tokens-input"
|
|
1303
|
+
type="number"
|
|
1304
|
+
min={1}
|
|
1305
|
+
disabled={!maxTokensEnabled}
|
|
1306
|
+
className="w-28 h-6"
|
|
1307
|
+
value={field.value ?? (maxTokensEnabled ? "" : 32768)}
|
|
1308
|
+
onChange={(e) => {
|
|
1309
|
+
const n = Number.parseInt(e.target.value, 10);
|
|
1310
|
+
field.onChange(Number.isFinite(n) && n > 0 ? n : null);
|
|
1311
|
+
}}
|
|
1312
|
+
/>
|
|
1313
|
+
</FormControl>
|
|
1314
|
+
</FormItem>
|
|
1315
|
+
<FormItem className={formItemClasses}>
|
|
1316
|
+
<Checkbox
|
|
1317
|
+
data-testid="ai-max-tokens-checkbox"
|
|
1318
|
+
checked={maxTokensEnabled}
|
|
1319
|
+
onCheckedChange={(checked) => {
|
|
1320
|
+
const isChecked = checked === true;
|
|
1321
|
+
setMaxTokensEnabled(isChecked);
|
|
1322
|
+
// null signals delete to the server; cast because
|
|
1323
|
+
// UserConfig (OpenAPI-derived) types max_tokens as
|
|
1324
|
+
// `number | undefined`, but zod accepts `null`.
|
|
1325
|
+
const next = (
|
|
1326
|
+
isChecked ? (field.value ?? 32768) : null
|
|
1327
|
+
) as number | undefined;
|
|
1328
|
+
// shouldDirty: true forces RHF to keep this in
|
|
1329
|
+
// dirtyFields even when `next` happens to equal the
|
|
1330
|
+
// form's defaultValue (e.g. untick → tick when disk
|
|
1331
|
+
// started with 32768). Otherwise getDirtyValues
|
|
1332
|
+
// would skip it and the save body would be empty.
|
|
1333
|
+
form.setValue("ai.max_tokens", next, {
|
|
1334
|
+
shouldDirty: true,
|
|
1335
|
+
shouldTouch: true,
|
|
1336
|
+
});
|
|
1337
|
+
onSubmit(form.getValues());
|
|
1338
|
+
}}
|
|
1339
|
+
/>
|
|
1340
|
+
<FormLabel className="font-normal">Override</FormLabel>
|
|
1341
|
+
</FormItem>
|
|
1342
|
+
</div>
|
|
1343
|
+
|
|
1344
|
+
<FormDescription>
|
|
1345
|
+
Each provider sets its own max output tokens (Anthropic uses a
|
|
1346
|
+
recommended default). Adjust to control costs or enable more
|
|
1347
|
+
output.
|
|
1348
|
+
</FormDescription>
|
|
1349
|
+
</div>
|
|
1350
|
+
);
|
|
1351
|
+
}}
|
|
1352
|
+
/>
|
|
1353
|
+
|
|
1282
1354
|
<FormErrorsBanner />
|
|
1283
1355
|
<ModelSelector
|
|
1284
1356
|
label="Chat Model"
|
|
@@ -1777,6 +1849,38 @@ export type AiSettingsSubTab =
|
|
|
1777
1849
|
| "ai-models"
|
|
1778
1850
|
| "mcp";
|
|
1779
1851
|
|
|
1852
|
+
const AiEnabledConfig: React.FC<AiConfigProps> = ({ form, config }) => {
|
|
1853
|
+
return (
|
|
1854
|
+
<SettingGroup>
|
|
1855
|
+
<FormField
|
|
1856
|
+
control={form.control}
|
|
1857
|
+
name="ai.enabled"
|
|
1858
|
+
render={({ field }) => (
|
|
1859
|
+
<div className="flex flex-col gap-y-1">
|
|
1860
|
+
<FormItem className={formItemClasses}>
|
|
1861
|
+
<FormLabel className="font-normal">Enable AI features</FormLabel>
|
|
1862
|
+
<FormControl>
|
|
1863
|
+
<Checkbox
|
|
1864
|
+
data-testid="ai-enabled-checkbox"
|
|
1865
|
+
checked={field.value !== false}
|
|
1866
|
+
onCheckedChange={(checked) =>
|
|
1867
|
+
field.onChange(checked === true)
|
|
1868
|
+
}
|
|
1869
|
+
/>
|
|
1870
|
+
</FormControl>
|
|
1871
|
+
<IsOverridden userConfig={config} name="ai.enabled" />
|
|
1872
|
+
</FormItem>
|
|
1873
|
+
<FormDescription>
|
|
1874
|
+
When disabled, AI actions and panels are hidden from the marimo
|
|
1875
|
+
UI.
|
|
1876
|
+
</FormDescription>
|
|
1877
|
+
</div>
|
|
1878
|
+
)}
|
|
1879
|
+
/>
|
|
1880
|
+
</SettingGroup>
|
|
1881
|
+
);
|
|
1882
|
+
};
|
|
1883
|
+
|
|
1780
1884
|
export const AiConfig: React.FC<AiConfigProps> = ({
|
|
1781
1885
|
form,
|
|
1782
1886
|
config,
|
|
@@ -1785,18 +1889,30 @@ export const AiConfig: React.FC<AiConfigProps> = ({
|
|
|
1785
1889
|
// MCP is not supported in WASM
|
|
1786
1890
|
const wasm = isWasm();
|
|
1787
1891
|
const [activeTab, setActiveTab] = useAtom(aiSettingsSubTabAtom);
|
|
1892
|
+
const aiEnabled = useWatch({
|
|
1893
|
+
control: form.control,
|
|
1894
|
+
name: "ai.enabled",
|
|
1895
|
+
});
|
|
1896
|
+
const activeVisibleTab =
|
|
1897
|
+
aiEnabled === false && activeTab !== "ai-features"
|
|
1898
|
+
? "ai-features"
|
|
1899
|
+
: activeTab;
|
|
1788
1900
|
|
|
1789
1901
|
return (
|
|
1790
1902
|
<Tabs
|
|
1791
|
-
value={
|
|
1903
|
+
value={activeVisibleTab}
|
|
1792
1904
|
onValueChange={(value) => setActiveTab(value as AiSettingsSubTab)}
|
|
1793
1905
|
className="flex-1"
|
|
1794
1906
|
>
|
|
1795
1907
|
<TabsList className="mb-2">
|
|
1796
1908
|
<TabsTrigger value="ai-features">AI Features</TabsTrigger>
|
|
1797
|
-
|
|
1798
|
-
|
|
1799
|
-
|
|
1909
|
+
{aiEnabled !== false && (
|
|
1910
|
+
<>
|
|
1911
|
+
<TabsTrigger value="ai-providers">AI Providers</TabsTrigger>
|
|
1912
|
+
<TabsTrigger value="ai-models">AI Models</TabsTrigger>
|
|
1913
|
+
{!wasm && <TabsTrigger value="mcp">MCP</TabsTrigger>}
|
|
1914
|
+
</>
|
|
1915
|
+
)}
|
|
1800
1916
|
</TabsList>
|
|
1801
1917
|
|
|
1802
1918
|
<TabsContent value="ai-features">
|
|
@@ -1805,18 +1921,33 @@ export const AiConfig: React.FC<AiConfigProps> = ({
|
|
|
1805
1921
|
config={config}
|
|
1806
1922
|
onSubmit={onSubmit}
|
|
1807
1923
|
/>
|
|
1808
|
-
<
|
|
1809
|
-
|
|
1810
|
-
|
|
1811
|
-
|
|
1812
|
-
</TabsContent>
|
|
1813
|
-
<TabsContent value="ai-models">
|
|
1814
|
-
<AiModelDisplayConfig form={form} config={config} onSubmit={onSubmit} />
|
|
1924
|
+
<AiEnabledConfig form={form} config={config} onSubmit={onSubmit} />
|
|
1925
|
+
{aiEnabled !== false && (
|
|
1926
|
+
<AiAssistConfig form={form} config={config} onSubmit={onSubmit} />
|
|
1927
|
+
)}
|
|
1815
1928
|
</TabsContent>
|
|
1816
|
-
{
|
|
1817
|
-
|
|
1818
|
-
<
|
|
1819
|
-
|
|
1929
|
+
{aiEnabled !== false && (
|
|
1930
|
+
<>
|
|
1931
|
+
<TabsContent value="ai-providers">
|
|
1932
|
+
<AiProvidersConfig
|
|
1933
|
+
form={form}
|
|
1934
|
+
config={config}
|
|
1935
|
+
onSubmit={onSubmit}
|
|
1936
|
+
/>
|
|
1937
|
+
</TabsContent>
|
|
1938
|
+
<TabsContent value="ai-models">
|
|
1939
|
+
<AiModelDisplayConfig
|
|
1940
|
+
form={form}
|
|
1941
|
+
config={config}
|
|
1942
|
+
onSubmit={onSubmit}
|
|
1943
|
+
/>
|
|
1944
|
+
</TabsContent>
|
|
1945
|
+
{!wasm && (
|
|
1946
|
+
<TabsContent value="mcp">
|
|
1947
|
+
<MCPConfig form={form} onSubmit={onSubmit} />
|
|
1948
|
+
</TabsContent>
|
|
1949
|
+
)}
|
|
1950
|
+
</>
|
|
1820
1951
|
)}
|
|
1821
1952
|
</Tabs>
|
|
1822
1953
|
);
|
|
@@ -503,6 +503,42 @@ export const UserConfigForm: React.FC = () => {
|
|
|
503
503
|
</div>
|
|
504
504
|
)}
|
|
505
505
|
/>
|
|
506
|
+
<FormField
|
|
507
|
+
control={form.control}
|
|
508
|
+
name="completion.auto_close_pairs"
|
|
509
|
+
render={({ field }) => (
|
|
510
|
+
<div className="flex flex-col space-y-1">
|
|
511
|
+
<FormItem className={formItemClasses}>
|
|
512
|
+
<FormLabel className="font-normal">
|
|
513
|
+
Auto-close pairs
|
|
514
|
+
</FormLabel>
|
|
515
|
+
<FormControl>
|
|
516
|
+
<Checkbox
|
|
517
|
+
data-testid="auto-close-pairs-checkbox"
|
|
518
|
+
checked={field.value ?? true}
|
|
519
|
+
disabled={field.disabled}
|
|
520
|
+
onCheckedChange={(checked) => {
|
|
521
|
+
field.onChange(Boolean(checked));
|
|
522
|
+
}}
|
|
523
|
+
/>
|
|
524
|
+
</FormControl>
|
|
525
|
+
<FormMessage />
|
|
526
|
+
<IsOverridden
|
|
527
|
+
userConfig={config}
|
|
528
|
+
name="completion.auto_close_pairs"
|
|
529
|
+
/>
|
|
530
|
+
</FormItem>
|
|
531
|
+
<FormDescription>
|
|
532
|
+
Automatically insert closing brackets{" "}
|
|
533
|
+
<code className="text-xs">{"()"}</code>,{" "}
|
|
534
|
+
<code className="text-xs">{"[]"}</code>,{" "}
|
|
535
|
+
<code className="text-xs">{"{}"}</code>, and quotes{" "}
|
|
536
|
+
<code className="text-xs">{`""`}</code>,{" "}
|
|
537
|
+
<code className="text-xs">{`''`}</code> when opening one.
|
|
538
|
+
</FormDescription>
|
|
539
|
+
</div>
|
|
540
|
+
)}
|
|
541
|
+
/>
|
|
506
542
|
</SettingGroup>
|
|
507
543
|
<SettingGroup title="Language Servers">
|
|
508
544
|
<FormDescription>
|
|
@@ -1319,7 +1355,7 @@ export const UserConfigForm: React.FC = () => {
|
|
|
1319
1355
|
<Form {...form}>
|
|
1320
1356
|
<form
|
|
1321
1357
|
ref={formElement}
|
|
1322
|
-
onChange={form.handleSubmit(onSubmit)}
|
|
1358
|
+
onChange={form.handleSubmit((values) => onSubmit(values))}
|
|
1323
1359
|
className="flex text-pretty overflow-hidden"
|
|
1324
1360
|
>
|
|
1325
1361
|
<Tabs
|
|
@@ -0,0 +1,269 @@
|
|
|
1
|
+
/* Copyright 2026 Marimo. All rights reserved. */
|
|
2
|
+
|
|
3
|
+
import type { UIMessage } from "ai";
|
|
4
|
+
import { describe, expect, it } from "vitest";
|
|
5
|
+
import { hasPendingToolCalls } from "../chat-utils";
|
|
6
|
+
|
|
7
|
+
/**
|
|
8
|
+
* `hasPendingToolCalls` powers `sendAutomaticallyWhen` in `mo.ui.chat`:
|
|
9
|
+
* returns true only when the last assistant message *ends* with a tool
|
|
10
|
+
* call in a ready-to-round-trip state. Any trailing non-tool part (text,
|
|
11
|
+
* file, source-*, reasoning, data-*, new step-start) means the assistant
|
|
12
|
+
* has already answered and we leave the next turn to the user. The
|
|
13
|
+
* approval flow relies on this firing for `approval-responded`.
|
|
14
|
+
*/
|
|
15
|
+
|
|
16
|
+
const userMessage = (text: string): UIMessage => ({
|
|
17
|
+
id: `user-${text}`,
|
|
18
|
+
role: "user",
|
|
19
|
+
parts: [{ type: "text", text }],
|
|
20
|
+
});
|
|
21
|
+
|
|
22
|
+
const assistantToolMessage = (
|
|
23
|
+
parts: UIMessage["parts"],
|
|
24
|
+
id = "assistant-1",
|
|
25
|
+
): UIMessage => ({
|
|
26
|
+
id,
|
|
27
|
+
role: "assistant",
|
|
28
|
+
parts,
|
|
29
|
+
});
|
|
30
|
+
|
|
31
|
+
describe("hasPendingToolCalls", () => {
|
|
32
|
+
it("returns false when there are no messages", () => {
|
|
33
|
+
expect(hasPendingToolCalls([])).toBe(false);
|
|
34
|
+
});
|
|
35
|
+
|
|
36
|
+
it("returns false when the last message is a user message", () => {
|
|
37
|
+
expect(hasPendingToolCalls([userMessage("hi")])).toBe(false);
|
|
38
|
+
});
|
|
39
|
+
|
|
40
|
+
it("returns false when the last assistant message has no tool parts", () => {
|
|
41
|
+
expect(
|
|
42
|
+
hasPendingToolCalls([
|
|
43
|
+
userMessage("hi"),
|
|
44
|
+
assistantToolMessage([{ type: "text", text: "hello!" }]),
|
|
45
|
+
]),
|
|
46
|
+
).toBe(false);
|
|
47
|
+
});
|
|
48
|
+
|
|
49
|
+
it("returns false while a tool is still streaming or awaiting approval", () => {
|
|
50
|
+
expect(
|
|
51
|
+
hasPendingToolCalls([
|
|
52
|
+
userMessage("delete it"),
|
|
53
|
+
assistantToolMessage([
|
|
54
|
+
{
|
|
55
|
+
type: "tool-delete_file",
|
|
56
|
+
toolCallId: "call-1",
|
|
57
|
+
state: "approval-requested",
|
|
58
|
+
input: { path: "secrets.env" },
|
|
59
|
+
approval: { id: "approval-1" },
|
|
60
|
+
} as unknown as UIMessage["parts"][number],
|
|
61
|
+
]),
|
|
62
|
+
]),
|
|
63
|
+
).toBe(false);
|
|
64
|
+
});
|
|
65
|
+
|
|
66
|
+
it("returns true when the user has responded to an approval request", () => {
|
|
67
|
+
// The chat must auto-resume as soon as Approve/Deny is clicked.
|
|
68
|
+
expect(
|
|
69
|
+
hasPendingToolCalls([
|
|
70
|
+
userMessage("delete it"),
|
|
71
|
+
assistantToolMessage([
|
|
72
|
+
{
|
|
73
|
+
type: "tool-delete_file",
|
|
74
|
+
toolCallId: "call-1",
|
|
75
|
+
state: "approval-responded",
|
|
76
|
+
input: { path: "secrets.env" },
|
|
77
|
+
approval: { id: "approval-1", approved: true },
|
|
78
|
+
} as unknown as UIMessage["parts"][number],
|
|
79
|
+
]),
|
|
80
|
+
]),
|
|
81
|
+
).toBe(true);
|
|
82
|
+
});
|
|
83
|
+
|
|
84
|
+
it("returns true when a tool reached a terminal output state", () => {
|
|
85
|
+
expect(
|
|
86
|
+
hasPendingToolCalls([
|
|
87
|
+
userMessage("run it"),
|
|
88
|
+
assistantToolMessage([
|
|
89
|
+
{
|
|
90
|
+
type: "tool-run_query",
|
|
91
|
+
toolCallId: "call-1",
|
|
92
|
+
state: "output-available",
|
|
93
|
+
input: { sql: "select 1" },
|
|
94
|
+
output: 1,
|
|
95
|
+
} as unknown as UIMessage["parts"][number],
|
|
96
|
+
]),
|
|
97
|
+
]),
|
|
98
|
+
).toBe(true);
|
|
99
|
+
});
|
|
100
|
+
|
|
101
|
+
it("returns false when only some tool calls are ready", () => {
|
|
102
|
+
expect(
|
|
103
|
+
hasPendingToolCalls([
|
|
104
|
+
userMessage("two things"),
|
|
105
|
+
assistantToolMessage([
|
|
106
|
+
{
|
|
107
|
+
type: "tool-first",
|
|
108
|
+
toolCallId: "call-1",
|
|
109
|
+
state: "output-available",
|
|
110
|
+
input: {},
|
|
111
|
+
output: 1,
|
|
112
|
+
} as unknown as UIMessage["parts"][number],
|
|
113
|
+
{
|
|
114
|
+
type: "tool-second",
|
|
115
|
+
toolCallId: "call-2",
|
|
116
|
+
state: "input-available",
|
|
117
|
+
input: {},
|
|
118
|
+
} as unknown as UIMessage["parts"][number],
|
|
119
|
+
]),
|
|
120
|
+
]),
|
|
121
|
+
).toBe(false);
|
|
122
|
+
});
|
|
123
|
+
|
|
124
|
+
it("returns false once the assistant has appended text after the tool result", () => {
|
|
125
|
+
expect(
|
|
126
|
+
hasPendingToolCalls([
|
|
127
|
+
userMessage("run it"),
|
|
128
|
+
assistantToolMessage([
|
|
129
|
+
{
|
|
130
|
+
type: "tool-run_query",
|
|
131
|
+
toolCallId: "call-1",
|
|
132
|
+
state: "output-available",
|
|
133
|
+
input: {},
|
|
134
|
+
output: 1,
|
|
135
|
+
} as unknown as UIMessage["parts"][number],
|
|
136
|
+
{ type: "text", text: "The query returned 1." },
|
|
137
|
+
]),
|
|
138
|
+
]),
|
|
139
|
+
).toBe(false);
|
|
140
|
+
});
|
|
141
|
+
|
|
142
|
+
it("returns false when a file part trails the completed tool call", () => {
|
|
143
|
+
// Regression: tool → text → file used to loop because only trailing
|
|
144
|
+
// text counted as "the assistant has answered".
|
|
145
|
+
expect(
|
|
146
|
+
hasPendingToolCalls([
|
|
147
|
+
userMessage("show me Starry Night"),
|
|
148
|
+
assistantToolMessage([
|
|
149
|
+
{ type: "step-start" },
|
|
150
|
+
{
|
|
151
|
+
type: "tool-search_artwork",
|
|
152
|
+
toolCallId: "call-1",
|
|
153
|
+
state: "output-available",
|
|
154
|
+
input: { artist: "Van Gogh" },
|
|
155
|
+
output: { title: "The Starry Night" },
|
|
156
|
+
} as unknown as UIMessage["parts"][number],
|
|
157
|
+
{ type: "text", text: "Here is the painting:" },
|
|
158
|
+
{
|
|
159
|
+
type: "file",
|
|
160
|
+
mediaType: "image/jpeg",
|
|
161
|
+
url: "https://example.com/starry-night.jpg",
|
|
162
|
+
} as unknown as UIMessage["parts"][number],
|
|
163
|
+
]),
|
|
164
|
+
]),
|
|
165
|
+
).toBe(false);
|
|
166
|
+
});
|
|
167
|
+
|
|
168
|
+
it("returns false when a source-url part trails the completed tool call", () => {
|
|
169
|
+
expect(
|
|
170
|
+
hasPendingToolCalls([
|
|
171
|
+
userMessage("cite your sources"),
|
|
172
|
+
assistantToolMessage([
|
|
173
|
+
{
|
|
174
|
+
type: "tool-web_search",
|
|
175
|
+
toolCallId: "call-1",
|
|
176
|
+
state: "output-available",
|
|
177
|
+
input: { q: "marimo notebook" },
|
|
178
|
+
output: "found",
|
|
179
|
+
} as unknown as UIMessage["parts"][number],
|
|
180
|
+
{ type: "text", text: "marimo is a reactive notebook." },
|
|
181
|
+
{
|
|
182
|
+
type: "source-url",
|
|
183
|
+
sourceId: "src-1",
|
|
184
|
+
url: "https://marimo.io",
|
|
185
|
+
} as unknown as UIMessage["parts"][number],
|
|
186
|
+
]),
|
|
187
|
+
]),
|
|
188
|
+
).toBe(false);
|
|
189
|
+
});
|
|
190
|
+
|
|
191
|
+
it("returns false when a reasoning part trails the completed tool call", () => {
|
|
192
|
+
expect(
|
|
193
|
+
hasPendingToolCalls([
|
|
194
|
+
userMessage("explain"),
|
|
195
|
+
assistantToolMessage([
|
|
196
|
+
{
|
|
197
|
+
type: "tool-lookup",
|
|
198
|
+
toolCallId: "call-1",
|
|
199
|
+
state: "output-available",
|
|
200
|
+
input: {},
|
|
201
|
+
output: 1,
|
|
202
|
+
} as unknown as UIMessage["parts"][number],
|
|
203
|
+
{
|
|
204
|
+
type: "reasoning",
|
|
205
|
+
text: "Now I'll summarize.",
|
|
206
|
+
} as unknown as UIMessage["parts"][number],
|
|
207
|
+
]),
|
|
208
|
+
]),
|
|
209
|
+
).toBe(false);
|
|
210
|
+
});
|
|
211
|
+
|
|
212
|
+
it("returns false when a new step-start follows the completed tool call", () => {
|
|
213
|
+
expect(
|
|
214
|
+
hasPendingToolCalls([
|
|
215
|
+
userMessage("multi-step"),
|
|
216
|
+
assistantToolMessage([
|
|
217
|
+
{ type: "step-start" },
|
|
218
|
+
{
|
|
219
|
+
type: "tool-run_query",
|
|
220
|
+
toolCallId: "call-1",
|
|
221
|
+
state: "output-available",
|
|
222
|
+
input: {},
|
|
223
|
+
output: 1,
|
|
224
|
+
} as unknown as UIMessage["parts"][number],
|
|
225
|
+
{ type: "step-start" },
|
|
226
|
+
]),
|
|
227
|
+
]),
|
|
228
|
+
).toBe(false);
|
|
229
|
+
});
|
|
230
|
+
|
|
231
|
+
it("ignores providerExecuted tools", () => {
|
|
232
|
+
// Provider-side tools are resolved by the model, not the runtime, so
|
|
233
|
+
// they must not drive an auto-resume.
|
|
234
|
+
expect(
|
|
235
|
+
hasPendingToolCalls([
|
|
236
|
+
userMessage("hi"),
|
|
237
|
+
assistantToolMessage([
|
|
238
|
+
{
|
|
239
|
+
type: "tool-web_search",
|
|
240
|
+
toolCallId: "call-1",
|
|
241
|
+
state: "output-available",
|
|
242
|
+
input: {},
|
|
243
|
+
output: 1,
|
|
244
|
+
providerExecuted: true,
|
|
245
|
+
} as unknown as UIMessage["parts"][number],
|
|
246
|
+
]),
|
|
247
|
+
]),
|
|
248
|
+
).toBe(false);
|
|
249
|
+
});
|
|
250
|
+
|
|
251
|
+
it("returns true for dynamic-tool parts in a terminal state", () => {
|
|
252
|
+
// `dynamic-tool` parts must drive auto-resume alongside `tool-*`.
|
|
253
|
+
expect(
|
|
254
|
+
hasPendingToolCalls([
|
|
255
|
+
userMessage("run it"),
|
|
256
|
+
assistantToolMessage([
|
|
257
|
+
{
|
|
258
|
+
type: "dynamic-tool",
|
|
259
|
+
toolName: "run_query",
|
|
260
|
+
toolCallId: "call-1",
|
|
261
|
+
state: "output-available",
|
|
262
|
+
input: {},
|
|
263
|
+
output: 1,
|
|
264
|
+
} as unknown as UIMessage["parts"][number],
|
|
265
|
+
]),
|
|
266
|
+
]),
|
|
267
|
+
).toBe(true);
|
|
268
|
+
});
|
|
269
|
+
});
|
|
@@ -15,11 +15,13 @@ import { useAtom, useAtomValue, useSetAtom, useStore } from "jotai";
|
|
|
15
15
|
import {
|
|
16
16
|
BotMessageSquareIcon,
|
|
17
17
|
HatGlasses,
|
|
18
|
+
ArrowRightIcon,
|
|
18
19
|
Loader2,
|
|
19
20
|
type LucideIcon,
|
|
20
21
|
MessageCircleIcon,
|
|
21
22
|
NotebookText,
|
|
22
23
|
PlusIcon,
|
|
24
|
+
SparklesIcon,
|
|
23
25
|
SettingsIcon,
|
|
24
26
|
} from "lucide-react";
|
|
25
27
|
import { memo, useEffect, useRef, useState } from "react";
|
|
@@ -49,15 +51,17 @@ import {
|
|
|
49
51
|
FRONTEND_TOOL_REGISTRY,
|
|
50
52
|
} from "@/core/ai/tools/registry";
|
|
51
53
|
import { useCellActions } from "@/core/cells/cells";
|
|
52
|
-
import { aiAtom,
|
|
54
|
+
import { aiAtom, aiModelConfiguredAtom } from "@/core/config/config";
|
|
53
55
|
import { DEFAULT_AI_MODEL } from "@/core/config/config-schema";
|
|
54
56
|
import { useRequestClient } from "@/core/network/requests";
|
|
55
57
|
import { useRuntimeManager } from "@/core/runtime/config";
|
|
58
|
+
import { isWasm } from "@/core/wasm/utils";
|
|
56
59
|
import { ErrorBanner } from "@/plugins/impl/common/error-banner";
|
|
57
60
|
import { cn } from "@/utils/cn";
|
|
58
61
|
import { Logger } from "@/utils/Logger";
|
|
59
62
|
import { AIModelDropdown } from "../ai/ai-model-dropdown";
|
|
60
63
|
import { useOpenSettingsToTab } from "../app-config/state";
|
|
64
|
+
import { PairWithAgentModal } from "../editor/actions/pair-with-agent-modal";
|
|
61
65
|
import { PromptInput } from "../editor/ai/add-cell-with-ai";
|
|
62
66
|
import {
|
|
63
67
|
addContextCompletion,
|
|
@@ -65,6 +69,7 @@ import {
|
|
|
65
69
|
} from "../editor/ai/completion-utils";
|
|
66
70
|
import { PanelEmptyState } from "../editor/chrome/panels/empty-state";
|
|
67
71
|
import { CopyClipboardIcon } from "../icons/copy-icon";
|
|
72
|
+
import { useImperativeModal } from "../modal/ImperativeModal";
|
|
68
73
|
import { MCPStatusIndicator } from "../mcp/mcp-status-indicator";
|
|
69
74
|
import { Tooltip, TooltipProvider } from "../ui/tooltip";
|
|
70
75
|
import {
|
|
@@ -416,8 +421,28 @@ const ChatInput: React.FC<ChatInputProps> = memo(
|
|
|
416
421
|
|
|
417
422
|
ChatInput.displayName = "ChatInput";
|
|
418
423
|
|
|
424
|
+
const PairWithAgentCallout: React.FC<{
|
|
425
|
+
onPairWithAgent: () => void;
|
|
426
|
+
}> = ({ onPairWithAgent }) => {
|
|
427
|
+
if (isWasm()) {
|
|
428
|
+
return null;
|
|
429
|
+
}
|
|
430
|
+
|
|
431
|
+
return (
|
|
432
|
+
<Button
|
|
433
|
+
variant="text"
|
|
434
|
+
className="gap-1.5 text-sm text-link hover:underline"
|
|
435
|
+
onClick={onPairWithAgent}
|
|
436
|
+
>
|
|
437
|
+
<SparklesIcon className="h-3.5 w-3.5 shrink-0" />
|
|
438
|
+
<span>Work on this notebook with your own agent</span>
|
|
439
|
+
<ArrowRightIcon className="h-3 w-3 shrink-0" />
|
|
440
|
+
</Button>
|
|
441
|
+
);
|
|
442
|
+
};
|
|
443
|
+
|
|
419
444
|
const ChatPanel = () => {
|
|
420
|
-
const aiConfigured = useAtomValue(
|
|
445
|
+
const aiConfigured = useAtomValue(aiModelConfiguredAtom);
|
|
421
446
|
const { handleClick } = useOpenSettingsToTab();
|
|
422
447
|
|
|
423
448
|
if (!aiConfigured) {
|
|
@@ -455,6 +480,7 @@ const ChatPanelBody = () => {
|
|
|
455
480
|
const messagesEndRef = useRef<HTMLDivElement>(null);
|
|
456
481
|
const runtimeManager = useRuntimeManager();
|
|
457
482
|
const { invokeAiTool, sendRun } = useRequestClient();
|
|
483
|
+
const { openModal, closeModal } = useImperativeModal();
|
|
458
484
|
|
|
459
485
|
const activeChatId = activeChat?.id;
|
|
460
486
|
const store = useStore();
|
|
@@ -614,6 +640,10 @@ const ChatPanelBody = () => {
|
|
|
614
640
|
clearFiles();
|
|
615
641
|
});
|
|
616
642
|
|
|
643
|
+
const handlePairWithAgent = useEvent(() => {
|
|
644
|
+
openModal(<PairWithAgentModal onClose={closeModal} />);
|
|
645
|
+
});
|
|
646
|
+
|
|
617
647
|
const handleMessageEdit = useEvent((index: number, newValue: string) => {
|
|
618
648
|
const editedMessage = messages[index];
|
|
619
649
|
const fileParts = editedMessage.parts?.filter((p) => p.type === "file");
|
|
@@ -724,9 +754,12 @@ const ChatPanelBody = () => {
|
|
|
724
754
|
ref={scrollContainerRef}
|
|
725
755
|
>
|
|
726
756
|
{isNewThread && (
|
|
727
|
-
<div className="
|
|
728
|
-
|
|
729
|
-
|
|
757
|
+
<div className="flex flex-col gap-2">
|
|
758
|
+
<div className="rounded-md border bg-background">
|
|
759
|
+
{filesPills}
|
|
760
|
+
{chatInput}
|
|
761
|
+
</div>
|
|
762
|
+
<PairWithAgentCallout onPairWithAgent={handlePairWithAgent} />
|
|
730
763
|
</div>
|
|
731
764
|
)}
|
|
732
765
|
|