@marimo-team/frontend 0.23.9-dev3 → 0.23.9-dev32
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-Dm3YCiM6.js +1 -0
- package/dist/assets/ConnectedDataExplorerComponent-CduY7ZLg.js +1 -0
- package/dist/assets/DeferredRequestRegistry-CNldVcrP.js +1 -0
- package/dist/assets/ImperativeModal-B3Th7k4R.js +1 -0
- package/dist/assets/JsonOutput-DzATTBoP.js +53 -0
- package/dist/assets/LazyAnyLanguageCodeMirror-BEvXb3VX.js +2 -0
- package/dist/assets/MarimoErrorOutput-XPsNfvEO.js +7 -0
- package/dist/assets/RSPContexts-CdN1NyAt.js +1 -0
- package/dist/assets/RenderHTML-BvW-obUg.js +1 -0
- package/dist/assets/RunButton-BUq1ZIzv.js +1 -0
- package/dist/assets/add-cell-with-ai-C4H664zc.js +97 -0
- package/dist/assets/add-connection-dialog-DdJBM1-Q.js +167 -0
- package/dist/assets/agent-panel-BB1ZRQse.js +287 -0
- package/dist/assets/ai-model-dropdown-9UrkfG-1.js +5 -0
- package/dist/assets/any-language-editor-CXeLf_N8.js +1 -0
- package/dist/assets/apl-EAxnZS_5.js +1 -0
- package/dist/assets/app-config-button-N_G5k5XW.js +1 -0
- package/dist/assets/arc-CWuN1tfc.js +1 -0
- package/dist/assets/architecture-7HQA4BMR-DJtUfdk-.js +1 -0
- package/dist/assets/architectureDiagram-VXUJARFQ-Cgi4wo9P.js +36 -0
- 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-CsHap8-F.js +122 -0
- package/dist/assets/brainfuck-BZegPsXK.js +1 -0
- package/dist/assets/c4Diagram-YG6GDRKO-CZuArudM.js +10 -0
- package/dist/assets/cache-panel-DYiVMv5x.js +1 -0
- package/dist/assets/cell-editor-B-9MV21_.js +20 -0
- package/dist/assets/cell-link-Bkd6QnOS.js +1 -0
- package/dist/assets/cells-BP6kg4iF.js +229 -0
- package/dist/assets/channel-6XBTrC3Q.js +1 -0
- package/dist/assets/chat-display-76m4LMD2.js +1 -0
- package/dist/assets/chat-panel-BAIgHYyO.js +3 -0
- package/dist/assets/chat-ui-BggP20am.js +4 -0
- package/dist/assets/chunk-4BX2VUAB-Ca6WzYTr.js +1 -0
- package/dist/assets/chunk-55IACEB6-Cr4aqhf3.js +1 -0
- package/dist/assets/chunk-5FQGJX7Z-D9iBG0F7.js +113 -0
- package/dist/assets/chunk-ABZYJK2D-BG7Eb4WW.js +80 -0
- package/dist/assets/chunk-ATLVNIR6-CqLn9HI1.js +1 -0
- package/dist/assets/chunk-B4BG7PRW-D4SyZNjn.js +165 -0
- package/dist/assets/chunk-CVBHYZKI-C-NWvPQL.js +1 -0
- package/dist/assets/chunk-DI55MBZ5-t9uiMPiN.js +220 -0
- package/dist/assets/chunk-EXTU4WIE-BmVk7Fyq.js +1 -0
- package/dist/assets/chunk-FMBD7UC4-DlnzxSkO.js +15 -0
- package/dist/assets/chunk-HN2XXSSU-Bcaj5fRB.js +1 -0
- package/dist/assets/chunk-JA3XYJ7Z-B5b2QHOb.js +70 -0
- package/dist/assets/chunk-JZLCHNYA-1_sVfAnw.js +54 -0
- package/dist/assets/chunk-MI3HLSF2-DqzZqBCh.js +32 -0
- package/dist/assets/chunk-N4CR4FBY-CFJoD-EQ.js +2 -0
- package/dist/assets/chunk-QN33PNHL-BBE_bx9E.js +1 -0
- package/dist/assets/chunk-QXUST7PY-Cu1nR-L2.js +7 -0
- package/dist/assets/chunk-QZHKN3VN-BAnb9AKF.js +1 -0
- package/dist/assets/chunk-S3R3BYOJ-Cl0iW04v.js +2 -0
- package/dist/assets/chunk-TZMSLE5B-f5ix6iSd.js +1 -0
- package/dist/assets/classDiagram-2ON5EDUG-DlIMDu6i.js +1 -0
- package/dist/assets/classDiagram-v2-WZHVMYZB-CcIhhkQu.js +1 -0
- package/dist/assets/clike-bdcjLdZ4.js +1 -0
- 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-B19XL3UR.js +2 -0
- package/dist/assets/coffeescript-C9foD9ub.js +1 -0
- package/dist/assets/column-preview-9_vf_vQt.js +1 -0
- package/dist/assets/command-KARR7KMq.js +1 -0
- package/dist/assets/command-palette-drFTNlvg.js +1 -0
- package/dist/assets/common-G2mwxgr_.js +1 -0
- package/dist/assets/commonlisp-tHxoA35J.js +1 -0
- package/dist/assets/components-D2tmc0KN.js +1 -0
- package/dist/assets/components-DvggA56E.js +1 -0
- package/dist/assets/config-hed0CaQL.js +1 -0
- package/dist/assets/context-QkTujrKn.js +1 -0
- package/dist/assets/copy-icon-OjtDb4gO.js +1 -0
- package/dist/assets/cose-bilkent-S5V4N54A-CQqSLzd1.js +1 -0
- package/dist/assets/crystal-CQ11GdrX.js +1 -0
- package/dist/assets/css-ACAb8MRM.js +1 -0
- package/dist/assets/cypher-CJ0Uzw29.js +1 -0
- package/dist/assets/d-DP0SUIt1.js +1 -0
- package/dist/assets/dagre-6UL2VRFP-CVKXpDlr.js +4 -0
- package/dist/assets/data-grid-overlay-editor-BdDYn72O.js +1 -0
- package/dist/assets/datasource-BjfZ5rCV.js +3 -0
- package/dist/assets/dates-CTxr0EqQ.js +1 -0
- package/dist/assets/dependency-graph-panel-BQlFSqu5.js +5 -0
- package/dist/assets/diagram-PSM6KHXK-BfzLNKp-.js +24 -0
- package/dist/assets/diagram-QEK2KX5R-D_H77Ni5.js +43 -0
- package/dist/assets/diagram-S2PKOQOG-DJmVBeMk.js +24 -0
- package/dist/assets/diff-CNs8MB38.js +1 -0
- package/dist/assets/dist-B7U5jPfs.js +1 -0
- package/dist/assets/dist-BF6UNR6V.js +1 -0
- package/dist/assets/dist-BQWswd1A.js +1 -0
- package/dist/assets/dist-BtL81uwZ.js +1 -0
- package/dist/assets/dist-Bww7hlVc.js +1 -0
- package/dist/assets/dist-CAIBlJtJ.js +1 -0
- package/dist/assets/dist-CBSMxaO_.js +6 -0
- package/dist/assets/dist-CJIOLS6O.js +7 -0
- package/dist/assets/dist-CKT_lJKW.js +1 -0
- package/dist/assets/dist-CNyMUs19.js +1 -0
- package/dist/assets/dist-CPF3W2Y-.js +1 -0
- package/dist/assets/dist-CUapWJe4.js +1 -0
- package/dist/assets/dist-CWeWT34c.js +1 -0
- package/dist/assets/dist-CciFN1z_.js +1 -0
- package/dist/assets/dist-CocyeH0q.js +1 -0
- package/dist/assets/dist-CpTFpfm_.js +1 -0
- package/dist/assets/dist-CpcTHxTt.js +1 -0
- package/dist/assets/dist-CqEym3Sr.js +1 -0
- package/dist/assets/dist-CuCuJBdf.js +1 -0
- package/dist/assets/dist-DH60fwgs.js +1 -0
- 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-DmBXXm0k.js +1 -0
- package/dist/assets/dist-DqVEVg0c.js +1 -0
- package/dist/assets/dist-Dr8mWwQ_.js +1 -0
- package/dist/assets/dist-W1iHBJeE.js +1 -0
- package/dist/assets/dist-_fyDen1v.js +1 -0
- package/dist/assets/dist-cgiAP5sW.js +1 -0
- package/dist/assets/dist-vkd1160q.js +1 -0
- package/dist/assets/dockerfile-BSMbgQQl.js +1 -0
- package/dist/assets/documentation-panel-BbVMQHz5.js +1 -0
- package/dist/assets/download-DrC3sFE3.js +9 -0
- 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-ClIQhScA.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-ROTNwSJz.js +60 -0
- package/dist/assets/erlang-BWiOgHIX.js +1 -0
- package/dist/assets/error-banner-LdWZDbqd.js +1 -0
- package/dist/assets/error-panel-aaHrLkBh.js +1 -0
- package/dist/assets/es-DGgq-Wes.js +5 -0
- package/dist/assets/esm-CqWdmSnV.js +1 -0
- package/dist/assets/esm-DeiyaVAJ.js +1 -0
- package/dist/assets/factor-C-_cRSDM.js +1 -0
- package/dist/assets/factor-CUwFIMOP.js +1 -0
- package/dist/assets/field-zLmMOSA4.js +1 -0
- package/dist/assets/file-explorer-panel-BQ9nMxks.js +26 -0
- package/dist/assets/file-icons-pUZ3DUy5.js +1 -0
- package/dist/assets/file-name-input-BNHbCr1E.js +3 -0
- package/dist/assets/fileToBase64-DZfwJMrG.js +1 -0
- package/dist/assets/floating-outline-CDjyi71K.js +1 -0
- package/dist/assets/flowDiagram-NV44I4VS--ee3IIVF.js +162 -0
- package/dist/assets/focus-D2kXD_rc.js +1 -0
- package/dist/assets/form-COQrUWdR.js +2 -0
- package/dist/assets/formats-b7Sf6DAK.js +1 -0
- package/dist/assets/formatting-CSG9kqNb.js +1 -0
- package/dist/assets/forth-BEQA4QQL.js +1 -0
- package/dist/assets/fortran-DoPpOZgG.js +1 -0
- package/dist/assets/gallery-page-Bcf7fYLy.js +1 -0
- package/dist/assets/ganttDiagram-JELNMOA3-BGhmW2aP.js +267 -0
- package/dist/assets/gas-BYovsvOE.js +1 -0
- package/dist/assets/gherkin-CFiRc1Pf.js +1 -0
- package/dist/assets/gitGraph-G5XIXVHT-DuJ_0c_E.js +1 -0
- package/dist/assets/gitGraphDiagram-V2S2FVAM-DXFCZcxr.js +65 -0
- package/dist/assets/glide-data-editor-7_pHQtPX.js +132 -0
- package/dist/assets/globals-Dd7eo1nD.js +1 -0
- 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-DNFOElFw.js +4 -0
- package/dist/assets/hooks-DjKf5pQ9.js +1 -0
- package/dist/assets/html-to-image-EYrNFuGt.js +2 -0
- package/dist/assets/idl-CZ_xwU8I.js +1 -0
- package/dist/assets/index-DAfPvCnw.css +2 -0
- package/dist/assets/index-DsF3qFAR.js +38 -0
- package/dist/assets/info-VBDWY6EO-DPQEAe2T.js +1 -0
- package/dist/assets/infoDiagram-HS3SLOUP-CaaUieFa.js +2 -0
- package/dist/assets/input-C3Hrdlqq.js +1 -0
- package/dist/assets/javascript-CF5KGSAj.js +1 -0
- package/dist/assets/journeyDiagram-XKPGCS4Q-9D2JCyrN.js +139 -0
- package/dist/assets/julia-BQlq5iZn.js +1 -0
- package/dist/assets/kanban-definition-3W4ZIXB7-DxV26rf-.js +89 -0
- package/dist/assets/katex-CzQ1KdW3.js +1 -0
- package/dist/assets/kiosk-mode-Ht1DwVD4.js +1 -0
- package/dist/assets/layout-CwCyg6Oq.js +9 -0
- package/dist/assets/line-x4bpd_8D.js +1 -0
- package/dist/assets/linear-CW_ww8od.js +1 -0
- package/dist/assets/links-1rtF1-eC.js +1 -0
- package/dist/assets/livescript-sRMenfqS.js +1 -0
- package/dist/assets/logs-panel-8V1eZbE7.js +1 -0
- package/dist/assets/loro_wasm_bg-CtNTubKN.js +1 -0
- package/dist/assets/lua-a56ITumN.js +1 -0
- package/dist/assets/markdown-renderer-d9Lol4Mr.js +5 -0
- 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-DAflnvW9.js +11 -0
- package/dist/assets/mermaid-parser.core-aYU6qXxk.js +4 -0
- package/dist/assets/mhchem-8N2oE3tb.js +1 -0
- package/dist/assets/mindmap-definition-VGOIOE7T-DTJAbAQ8.js +68 -0
- 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-DDR4EexG.js +1 -0
- package/dist/assets/nsis-BGZ5EB-j.js +1 -0
- package/dist/assets/nsis-BfGyMssE.js +1 -0
- package/dist/assets/ntriples-DeY1n_tC.js +1 -0
- package/dist/assets/number-overlay-editor-DL4IwqDH.js +9 -0
- package/dist/assets/octave-7Qn21jzx.js +1 -0
- package/dist/assets/ordinal-_nQ2r1qQ.js +1 -0
- package/dist/assets/outline-panel-B-fr1jRf.js +1 -0
- package/dist/assets/oz-CiPFl3Ni.js +1 -0
- package/dist/assets/packages-panel-B4MR9Vnv.js +1 -0
- package/dist/assets/packet-DYOGHKS2-CxgeJpvT.js +1 -0
- package/dist/assets/pair-with-agent-modal-Derso4uY.js +4 -0
- package/dist/assets/panels-DsbaLR3B.js +1 -0
- package/dist/assets/pascal-BH9yQLzw.js +1 -0
- package/dist/assets/pathUtils-CJjndqMI.js +1 -0
- package/dist/assets/perl-DfMCx2i2.js +1 -0
- package/dist/assets/pie-VRWISCQL-GZ13ReaG.js +1 -0
- package/dist/assets/pieDiagram-ADFJNKIX-_3l2XiEo.js +30 -0
- package/dist/assets/pig-D9CNebQN.js +1 -0
- package/dist/assets/powershell-Dss0bU9F.js +1 -0
- package/dist/assets/precisionRound-Cl9k9ZmS.js +1 -0
- package/dist/assets/process-output-CJeKhzqO.js +1 -0
- package/dist/assets/properties-CHADYQUL.js +1 -0
- package/dist/assets/protobuf-DFN-V4SD.js +1 -0
- package/dist/assets/pug-CYW0agOo.js +1 -0
- 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-CX3AMAvR.js +7 -0
- package/dist/assets/r-jmqrRzXv.js +1 -0
- package/dist/assets/radar-ZZBFDIW7-CbAjwmA0.js +1 -0
- package/dist/assets/radio-group-cvI-M2aa.js +1 -0
- package/dist/assets/react-vega-COx3Ibyn.js +1 -0
- package/dist/assets/react-vega-CXIQBUis.js +188 -0
- package/dist/assets/readonly-python-code-BmZ0KZKm.js +1 -0
- package/dist/assets/renderShortcut-CzUfgpdJ.js +1 -0
- package/dist/assets/request-registry--h6PWG50.js +1 -0
- package/dist/assets/requirementDiagram-UZGBJVZJ-ORHKBnkg.js +64 -0
- package/dist/assets/reveal-component-Bff44fKv.js +1069 -0
- package/dist/assets/rpm-DUjG0xRk.js +1 -0
- package/dist/assets/ruby-SP4FIzir.js +1 -0
- package/dist/assets/run-page-4im7P8v3.js +1 -0
- package/dist/assets/sankeyDiagram-TZEHDZUN-Dvb8kmWa.js +10 -0
- package/dist/assets/sas-BxaPz2EX.js +1 -0
- package/dist/assets/scheme-HBseLApj.js +1 -0
- package/dist/assets/scratchpad-panel-BFvydb89.js +1 -0
- package/dist/assets/secrets-panel-BBvdIhtU.js +1 -0
- package/dist/assets/sequenceDiagram-WL72ISMW-DQycpQtE.js +145 -0
- package/dist/assets/session-panel-CwggjKWr.js +1 -0
- package/dist/assets/share-DMwTZOTH.js +1 -0
- 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-BmWXl5GE.js +1 -0
- package/dist/assets/sparql-DAeEYE_u.js +1 -0
- package/dist/assets/spec-CPQR_o92.js +1 -0
- package/dist/assets/state-BGDrw26V.js +1 -0
- package/dist/assets/state-DTislnZA.js +1 -0
- package/dist/assets/state-G8Xj60GT.js +3 -0
- package/dist/assets/state-d_LoPKHg.js +1 -0
- package/dist/assets/stateDiagram-FKZM4ZOC-D78DIR_F.js +1 -0
- package/dist/assets/stateDiagram-v2-4FDKWEC3-DX9rpmwh.js +1 -0
- package/dist/assets/step-D7xg1Moj.js +1 -0
- package/dist/assets/stex-Ccczot4V.js +1 -0
- package/dist/assets/stylus-Cw3Ugan7.js +1 -0
- package/dist/assets/swift-CPsNOBsX.js +1 -0
- package/dist/assets/swiper-component-YGJlBaCp.js +1 -0
- package/dist/assets/switch-YcZLs0mS.js +1 -0
- package/dist/assets/tcl-BfWyQdZa.js +1 -0
- package/dist/assets/terminal-BydBi1dE.js +62 -0
- package/dist/assets/textarea-DV6LIVoz.js +1 -0
- package/dist/assets/textile-BKgaSzSN.js +1 -0
- package/dist/assets/time-DLdI7jB3.js +1 -0
- package/dist/assets/timeline-definition-IT6M3QCI-DIywx3xf.js +61 -0
- package/dist/assets/toml-BSOdv04W.js +1 -0
- package/dist/assets/tracing-CvLPM0Wh.js +1 -0
- package/dist/assets/tracing-panel-iTdY5N_y.js +2 -0
- package/dist/assets/tree-actions-BM_EJr3E.js +1 -0
- package/dist/assets/treemap-GDKQZRPO-Dz_qZhuG.js +1 -0
- 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-oqDq5zze.js +1 -0
- package/dist/assets/useCellActionButton-CsyGJEYN.js +1 -0
- package/dist/assets/useDateFormatter-ICIDGgHf.js +1 -0
- package/dist/assets/useDeleteCell-BQA5MqKt.js +1 -0
- package/dist/assets/useDependencyPanelTab-CIH_2h1J.js +1 -0
- package/dist/assets/useHotkey-BtqYcnxQ.js +1 -0
- package/dist/assets/useInstallPackage-DUF4IRRI.js +1 -0
- package/dist/assets/useNotebookActions-jRhy52S-.js +1 -0
- package/dist/assets/useNumberFormatter-ByUv-u9o.js +1 -0
- package/dist/assets/usePress-DQ_tAz5W.js +7 -0
- package/dist/assets/useRunCells-rD6HJnx6.js +1 -0
- package/dist/assets/useSplitCell-CqznVs7m.js +1 -0
- package/dist/assets/useTheme-KJ1rGmnj.js +1 -0
- package/dist/assets/utils-Bok_hGT2.js +1 -0
- package/dist/assets/utils-DCL4n9wx.js +61 -0
- package/dist/assets/vb-DfRPk_ji.js +1 -0
- package/dist/assets/vbscript-C8D4uv5N.js +1 -0
- package/dist/assets/vega-component-DOlcjhuV.js +1 -0
- package/dist/assets/vega-loader.browser-C8wT63Va.js +6 -0
- 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/write-secret-modal-BFLlHwgU.js +1 -0
- package/dist/assets/xquery-ABGCbLv0.js +1 -0
- package/dist/assets/xychartDiagram-PRI3JC2R-CjS1dL8k.js +7 -0
- package/dist/assets/yacas-Ckyxh7oh.js +1 -0
- package/dist/assets/z80-Dr5sQweg.js +1 -0
- package/dist/index.html +116 -117
- 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 +73 -1
- 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 +36 -3
- package/src/components/chat/chat-utils.ts +14 -58
- package/src/components/data-table/TableBottomBar.tsx +27 -6
- package/src/components/data-table/TableTopBar.tsx +7 -1
- package/src/components/data-table/__tests__/TableBottomBar.test.tsx +73 -0
- package/src/components/data-table/__tests__/column-explorer.test.tsx +128 -0
- package/src/components/data-table/__tests__/column-header.test.tsx +110 -277
- package/src/components/data-table/__tests__/data-table.test.tsx +52 -1
- package/src/components/data-table/__tests__/date-filter-inputs.test.tsx +33 -0
- package/src/components/data-table/__tests__/filter-pill-editor.test.tsx +75 -38
- package/src/components/data-table/__tests__/filter-pills.test.tsx +287 -0
- package/src/components/data-table/__tests__/filter-test-utils.ts +47 -0
- package/src/components/data-table/__tests__/filters.test.ts +5 -5
- package/src/components/data-table/__tests__/header-items.test.tsx +47 -1
- package/src/components/data-table/__tests__/useColumnVisibility.test.ts +42 -0
- package/src/components/data-table/add-filter-button.tsx +85 -0
- package/src/components/data-table/column-explorer-panel/column-explorer.tsx +98 -26
- package/src/components/data-table/column-header.tsx +94 -691
- package/src/components/data-table/columns.tsx +3 -4
- package/src/components/data-table/context-menu.tsx +26 -12
- package/src/components/data-table/data-table.tsx +125 -56
- package/src/components/data-table/date-filter-inputs.tsx +13 -10
- package/src/components/data-table/export-actions.tsx +17 -6
- package/src/components/data-table/filter-by-values-picker.tsx +13 -19
- package/src/components/data-table/filter-editor-context.tsx +34 -0
- package/src/components/data-table/filter-pill-editor.tsx +152 -175
- package/src/components/data-table/filter-pills.tsx +190 -153
- package/src/components/data-table/filters/builders.ts +102 -0
- package/src/components/data-table/filters/defaults.ts +31 -0
- package/src/components/data-table/filters/format.ts +131 -0
- package/src/components/data-table/filters/guards.ts +51 -0
- package/src/components/data-table/filters/index.ts +7 -0
- package/src/components/data-table/filters/operators.ts +76 -0
- package/src/components/data-table/filters/serialize.ts +186 -0
- package/src/components/data-table/filters/types.ts +33 -0
- package/src/components/data-table/header-items.tsx +25 -85
- package/src/components/data-table/hooks/use-column-visibility.ts +56 -0
- package/src/components/data-table/pagination.tsx +16 -3
- package/src/components/data-table/table-explorer-panel/table-explorer-panel.tsx +16 -6
- package/src/components/data-table/value-chips.tsx +52 -0
- 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/actions/pair-with-agent-modal.tsx +1 -0
- package/src/components/editor/errors/mangled-local-chip.tsx +50 -0
- package/src/components/editor/output/MarimoErrorOutput.tsx +110 -27
- package/src/components/editor/output/MarimoTracebackOutput.tsx +51 -34
- package/src/components/editor/renderers/slides-layout/slides-layout.tsx +1 -1
- package/src/components/slides/reveal-component.tsx +3 -3
- package/src/components/slides/slide-form.tsx +11 -3
- package/src/components/ui/number-field.tsx +13 -1
- 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 +3 -2
- 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 +2 -0
- package/src/core/config/config-schema.ts +2 -0
- package/src/css/app/Cell.css +0 -1
- package/src/plugins/impl/DataTablePlugin.tsx +94 -33
- package/src/plugins/impl/__tests__/DataTablePlugin.test.tsx +1 -0
- 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/plugins/impl/data-frames/DataFramePlugin.tsx +8 -6
- package/src/stories/dataframe.stories.tsx +1 -0
- package/src/utils/__tests__/local-variables.test.ts +132 -0
- package/src/utils/dates.ts +39 -0
- package/src/utils/local-variables.ts +67 -0
- package/dist/assets/CellStatus-DGBvmSvq.js +0 -1
- package/dist/assets/ConnectedDataExplorerComponent-D-boDGAP.js +0 -1
- package/dist/assets/DeferredRequestRegistry-CzVJLtsG.js +0 -1
- package/dist/assets/ImperativeModal-DEC1mXgV.js +0 -1
- package/dist/assets/JsonOutput-05-R3eil.js +0 -53
- package/dist/assets/LazyAnyLanguageCodeMirror-GdhQ07zA.js +0 -2
- package/dist/assets/MarimoErrorOutput-XWqnhvJ6.js +0 -7
- package/dist/assets/RSPContexts-Bk1r00gJ.js +0 -1
- package/dist/assets/RenderHTML-B5r25cP5.js +0 -1
- package/dist/assets/RunButton-Dbak5hfa.js +0 -1
- package/dist/assets/add-cell-with-ai-BbZkMqv2.js +0 -97
- package/dist/assets/add-connection-dialog-CzxRpS5F.js +0 -167
- package/dist/assets/agent-panel-zPhlhkYL.js +0 -287
- package/dist/assets/ai-model-dropdown-CjhUqXgj.js +0 -5
- package/dist/assets/any-language-editor-Bdhmwznp.js +0 -1
- package/dist/assets/apl-Bl4yyYus.js +0 -1
- package/dist/assets/app-config-button-CCs8Jepz.js +0 -1
- package/dist/assets/arc-npelKso9.js +0 -1
- package/dist/assets/architecture-7HQA4BMR-CaNOiKrI.js +0 -1
- package/dist/assets/architectureDiagram-VXUJARFQ-BsWISGgz.js +0 -36
- package/dist/assets/asciiarmor-BlzLkEza.js +0 -1
- package/dist/assets/asn1-Khb778U5.js +0 -1
- package/dist/assets/blockDiagram-VD42YOAC-CzfQ0Exj.js +0 -122
- package/dist/assets/brainfuck-BzHxpB_u.js +0 -1
- package/dist/assets/c4Diagram-YG6GDRKO-D0FgqleO.js +0 -10
- package/dist/assets/cache-panel-VL13fWgF.js +0 -1
- package/dist/assets/cell-editor-ODyJXDT8.js +0 -20
- package/dist/assets/cell-link-PQYiMZw1.js +0 -1
- package/dist/assets/cells-Dnu4nDoy.js +0 -229
- package/dist/assets/channel-DjPEzqq3.js +0 -1
- package/dist/assets/chat-display-DetTBnqK.js +0 -1
- package/dist/assets/chat-panel-CEgw_vg0.js +0 -3
- package/dist/assets/chat-ui-D-Y7p_cT.js +0 -4
- package/dist/assets/chunk-4BX2VUAB-Br07KPs3.js +0 -1
- package/dist/assets/chunk-55IACEB6-BHM3yXYz.js +0 -1
- package/dist/assets/chunk-5FQGJX7Z-BSzccEgu.js +0 -113
- package/dist/assets/chunk-ABZYJK2D-pjI0V9vG.js +0 -80
- package/dist/assets/chunk-ATLVNIR6-DMcOYQJi.js +0 -1
- package/dist/assets/chunk-B4BG7PRW-jxe9_Hde.js +0 -165
- package/dist/assets/chunk-CVBHYZKI-DwNHftX6.js +0 -1
- package/dist/assets/chunk-DI55MBZ5-CNxnbO1g.js +0 -220
- package/dist/assets/chunk-EXTU4WIE-C7TYTuus.js +0 -1
- package/dist/assets/chunk-FMBD7UC4-jBIrJcS0.js +0 -15
- package/dist/assets/chunk-HN2XXSSU-COpG_X4X.js +0 -1
- package/dist/assets/chunk-JA3XYJ7Z-2W_JmZ4z.js +0 -70
- package/dist/assets/chunk-JZLCHNYA-DdjotIam.js +0 -54
- package/dist/assets/chunk-MI3HLSF2-D_z13ybc.js +0 -32
- package/dist/assets/chunk-N4CR4FBY-Y37VEUfx.js +0 -2
- package/dist/assets/chunk-QN33PNHL-BcKQMXSf.js +0 -1
- package/dist/assets/chunk-QXUST7PY-CU78e3vp.js +0 -7
- package/dist/assets/chunk-QZHKN3VN-g-7LWEK-.js +0 -1
- package/dist/assets/chunk-S3R3BYOJ-EEhIeeuI.js +0 -2
- package/dist/assets/chunk-TZMSLE5B-D1A_Dyzt.js +0 -1
- package/dist/assets/classDiagram-2ON5EDUG-CDgVuBLy.js +0 -1
- package/dist/assets/classDiagram-v2-WZHVMYZB-B2UHhBVi.js +0 -1
- package/dist/assets/clike-TW9KXOmZ.js +0 -1
- package/dist/assets/clojure-C_sT-_CQ.js +0 -1
- package/dist/assets/cmake-BjrhHx8m.js +0 -1
- package/dist/assets/cobol-Cs8YSzaw.js +0 -1
- package/dist/assets/code-block-37QAKDTI-U2R1jyOo.js +0 -2
- package/dist/assets/coffeescript-juXyFkA0.js +0 -1
- package/dist/assets/column-preview-BLIWbdOX.js +0 -1
- package/dist/assets/command-2NPJCYDa.js +0 -1
- package/dist/assets/command-palette-CeDe63_W.js +0 -1
- package/dist/assets/common-BaBE_ygg.js +0 -1
- package/dist/assets/commonlisp-Cmn_5nuv.js +0 -1
- package/dist/assets/components-CvGaLA5d.js +0 -1
- package/dist/assets/components-zB5yT_R8.js +0 -1
- package/dist/assets/config-C2lTvbuU.js +0 -1
- package/dist/assets/context-C1Tm_47t.js +0 -1
- package/dist/assets/copy-icon-BdZPgXgo.js +0 -1
- package/dist/assets/cose-bilkent-S5V4N54A-B7DsItpC.js +0 -1
- package/dist/assets/crystal-DJrWmXfk.js +0 -1
- package/dist/assets/css-BJpII9DZ.js +0 -1
- package/dist/assets/cypher-D549BT6Q.js +0 -1
- package/dist/assets/d-CQplIm4C.js +0 -1
- package/dist/assets/dagre-6UL2VRFP-F7ectrvx.js +0 -4
- package/dist/assets/data-grid-overlay-editor-Cvj8Susd.js +0 -1
- package/dist/assets/datasource-I-LOgxeP.js +0 -3
- package/dist/assets/dates-DI1TvEEK.js +0 -1
- package/dist/assets/dependency-graph-panel-ClI5byUa.js +0 -5
- package/dist/assets/diagram-PSM6KHXK-DLOGvjhP.js +0 -24
- package/dist/assets/diagram-QEK2KX5R-BEJdNpvg.js +0 -43
- package/dist/assets/diagram-S2PKOQOG-CqMnWWB8.js +0 -24
- package/dist/assets/diff-Dz2enOOE.js +0 -1
- package/dist/assets/dist-7TsTgeOV.js +0 -1
- package/dist/assets/dist-B0N0-Vx5.js +0 -1
- package/dist/assets/dist-BE3jO1WU.js +0 -1
- package/dist/assets/dist-BNfAUjeR.js +0 -1
- package/dist/assets/dist-BQxSimS-.js +0 -1
- package/dist/assets/dist-BSp3naSP.js +0 -1
- package/dist/assets/dist-BYShiqDa.js +0 -1
- package/dist/assets/dist-BZe5KYlj.js +0 -1
- package/dist/assets/dist-BZr6MMV-.js +0 -1
- package/dist/assets/dist-BbkYHvT2.js +0 -1
- package/dist/assets/dist-CAWvCIk5.js +0 -1
- package/dist/assets/dist-CK56b5MF.js +0 -1
- package/dist/assets/dist-COz0Y8UW.js +0 -1
- package/dist/assets/dist-CW3rweKM.js +0 -7
- package/dist/assets/dist-CodYQwM5.js +0 -1
- package/dist/assets/dist-D4Od5Ds4.js +0 -1
- package/dist/assets/dist-DCqxOggh.js +0 -6
- package/dist/assets/dist-DLjDyeX7.js +0 -1
- package/dist/assets/dist-DOY95WD5.js +0 -1
- package/dist/assets/dist-Da-HT0I8.js +0 -1
- package/dist/assets/dist-Dc1gTRL9.js +0 -1
- package/dist/assets/dist-Dn1-guC7.js +0 -1
- package/dist/assets/dist-Dwy8b-Zd.js +0 -1
- package/dist/assets/dist-DxEuZTVa.js +0 -1
- package/dist/assets/dist-LFeDu06u.js +0 -1
- package/dist/assets/dist-ThkhuYAm.js +0 -1
- package/dist/assets/dist-jwcsaiRe.js +0 -1
- package/dist/assets/dist-oedZSmHi.js +0 -1
- package/dist/assets/dist-r-YlHvr1.js +0 -1
- package/dist/assets/dist-v1cdVFWt.js +0 -1
- package/dist/assets/dockerfile-AiWrCVkd.js +0 -1
- package/dist/assets/documentation-panel-DMdFXuBf.js +0 -1
- package/dist/assets/download-B1QFVDP-.js +0 -9
- package/dist/assets/dtd-DxzWHAng.js +0 -1
- package/dist/assets/dylan-Bj1NVjKa.js +0 -1
- package/dist/assets/ecl-Ch-B_r8E.js +0 -1
- package/dist/assets/edit-page-ZFpn8-WM.js +0 -9
- package/dist/assets/eiffel-CICk6vIb.js +0 -1
- package/dist/assets/elm-C1O6zP9K.js +0 -1
- package/dist/assets/erDiagram-Q2GNP2WA-DlCxoG4y.js +0 -60
- package/dist/assets/erlang-BwL41NIP.js +0 -1
- package/dist/assets/error-banner-CLO6LFll.js +0 -1
- package/dist/assets/error-panel-iXznkJZ1.js +0 -1
- package/dist/assets/es-au8YY-8E.js +0 -5
- package/dist/assets/esm-BGRsx_Fp.js +0 -1
- package/dist/assets/esm-Cb2bnV6o.js +0 -1
- package/dist/assets/eye-off-BT-KOYV5.js +0 -1
- package/dist/assets/factor-DgyyQiBQ.js +0 -1
- package/dist/assets/factor-DjzhghfA.js +0 -1
- package/dist/assets/field-DNlzfMKW.js +0 -1
- package/dist/assets/file-explorer-panel-BVBKF1SH.js +0 -26
- package/dist/assets/file-icons-B6DaZdP0.js +0 -1
- package/dist/assets/file-name-input-g2H2sY2h.js +0 -3
- package/dist/assets/fileToBase64-BeYUTUzO.js +0 -1
- package/dist/assets/floating-outline-DbOtUfo-.js +0 -1
- package/dist/assets/flowDiagram-NV44I4VS-CXUevMnh.js +0 -162
- package/dist/assets/focus-BaOnnMs-.js +0 -1
- package/dist/assets/form-BjUJP6PJ.js +0 -2
- package/dist/assets/formats-BRq458WH.js +0 -1
- package/dist/assets/formatting-XTtGIhGk.js +0 -1
- package/dist/assets/forth-D9Pm6H-4.js +0 -1
- package/dist/assets/fortran-Bkmw-ITl.js +0 -1
- package/dist/assets/gallery-page-MrZHjySE.js +0 -1
- package/dist/assets/ganttDiagram-JELNMOA3-D8_HISpS.js +0 -267
- package/dist/assets/gas-hS11Npqh.js +0 -1
- package/dist/assets/gherkin-HvvvGZ2_.js +0 -1
- package/dist/assets/gitGraph-G5XIXVHT-DiktmQLx.js +0 -1
- package/dist/assets/gitGraphDiagram-V2S2FVAM-CN_m3FDa.js +0 -65
- package/dist/assets/glide-data-editor-4Wql6uq7.js +0 -132
- package/dist/assets/globals-CpVAcN9Z.js +0 -1
- package/dist/assets/groovy-BymCZpo_.js +0 -1
- package/dist/assets/haskell-D1PB_nO2.js +0 -1
- package/dist/assets/haxe-BbvC3Y-d.js +0 -1
- package/dist/assets/home-page-De1W6q6f.js +0 -4
- package/dist/assets/hooks-jWLD3t7P.js +0 -1
- package/dist/assets/html-to-image-D6SgvARi.js +0 -2
- package/dist/assets/idl-Do8pA7p2.js +0 -1
- package/dist/assets/index-B30qjBZM.css +0 -2
- package/dist/assets/index-ZA7t2ThT.js +0 -38
- package/dist/assets/info-VBDWY6EO-BH3NOLYF.js +0 -1
- package/dist/assets/infoDiagram-HS3SLOUP-C20LNJkf.js +0 -2
- package/dist/assets/input-CVE-gIjt.js +0 -1
- package/dist/assets/javascript-C0HGxgJT.js +0 -1
- package/dist/assets/journeyDiagram-XKPGCS4Q-CQWCJPyH.js +0 -139
- package/dist/assets/julia-B-Inh9cI.js +0 -1
- package/dist/assets/kanban-definition-3W4ZIXB7-CeH-UkBO.js +0 -89
- package/dist/assets/katex-Bci6q_jh.js +0 -1
- package/dist/assets/kiosk-mode-Czvj3vmL.js +0 -1
- package/dist/assets/layout-DEU6lX-9.js +0 -9
- package/dist/assets/line-BkpbatV-.js +0 -1
- package/dist/assets/linear-BHpZPQfO.js +0 -1
- package/dist/assets/links-Av1BIe0O.js +0 -1
- package/dist/assets/livescript-C6P4ddCY.js +0 -1
- package/dist/assets/logs-panel-BMAfoMJg.js +0 -1
- package/dist/assets/loro_wasm_bg-Bg3nlaci.js +0 -1
- package/dist/assets/lua-DTvhQBWH.js +0 -1
- package/dist/assets/markdown-renderer-BQ-BQLiJ.js +0 -5
- package/dist/assets/mathematica-wRwDN36m.js +0 -1
- package/dist/assets/mbox-BeQS3Xo8.js +0 -1
- package/dist/assets/mermaid-4DMBBIKO-C0OyyVdo.js +0 -1
- package/dist/assets/mermaid-CZhfODkT.js +0 -11
- package/dist/assets/mermaid-parser.core-867JpRcd.js +0 -4
- package/dist/assets/mhchem-BKhnkPip.js +0 -1
- package/dist/assets/mindmap-definition-VGOIOE7T-BNg30ltj.js +0 -68
- package/dist/assets/mirc-D0yC5rBL.js +0 -1
- package/dist/assets/mllike-sRDGjaMs.js +0 -1
- package/dist/assets/modelica-CTTCwBwt.js +0 -1
- package/dist/assets/mscgen-D9NVglDL.js +0 -1
- package/dist/assets/mumps-eJkJqAKw.js +0 -1
- package/dist/assets/name-cell-input-bwfAyC0i.js +0 -1
- package/dist/assets/nsis-B3ap5r7i.js +0 -1
- package/dist/assets/nsis-bDE8IZXy.js +0 -1
- package/dist/assets/ntriples-B2LCbtl9.js +0 -1
- package/dist/assets/number-overlay-editor-BOtWFe1E.js +0 -9
- package/dist/assets/octave-DhLlnMzQ.js +0 -1
- package/dist/assets/ordinal-BKex0QZH.js +0 -1
- package/dist/assets/outline-panel-CkZUQcZ1.js +0 -1
- package/dist/assets/oz-CLovtD0B.js +0 -1
- package/dist/assets/packages-panel-B3dRYuRM.js +0 -1
- package/dist/assets/packet-DYOGHKS2-BZAo-1WV.js +0 -1
- package/dist/assets/panels-DWhhEgv4.js +0 -1
- package/dist/assets/pascal-BJwozZXL.js +0 -1
- package/dist/assets/pathUtils-vgBYIo5B.js +0 -1
- package/dist/assets/perl-B3rIP59U.js +0 -1
- package/dist/assets/pie-VRWISCQL-DSqXSW1A.js +0 -1
- package/dist/assets/pieDiagram-ADFJNKIX-CkDeU73E.js +0 -30
- package/dist/assets/pig-BQrpamWX.js +0 -1
- package/dist/assets/powershell-Crqgmja1.js +0 -1
- package/dist/assets/precisionRound-NX56vp6K.js +0 -1
- package/dist/assets/process-output-9W-JyYdE.js +0 -1
- package/dist/assets/properties-BMPI0iSd.js +0 -1
- package/dist/assets/protobuf-BMPWl2Em.js +0 -1
- package/dist/assets/pug-BvTKD58f.js +0 -1
- package/dist/assets/pug-CcL3ml0F.js +0 -1
- package/dist/assets/puppet-B1rTmaHH.js +0 -1
- package/dist/assets/python-DGMqnM8m.js +0 -1
- package/dist/assets/q-BNL1PH4D.js +0 -1
- package/dist/assets/quadrantDiagram-AYHSOK5B-DAx3aobn.js +0 -7
- package/dist/assets/r-DOvfvYEk.js +0 -1
- package/dist/assets/radar-ZZBFDIW7-BPcQHRAq.js +0 -1
- package/dist/assets/radio-group-rsi1ibXY.js +0 -1
- package/dist/assets/react-vega-4VQqM03t.js +0 -188
- package/dist/assets/react-vega-5tTMnjwa.js +0 -1
- package/dist/assets/readonly-python-code-BKYj8PNf.js +0 -1
- package/dist/assets/renderShortcut-DK-VjfaX.js +0 -1
- package/dist/assets/request-registry-DKAymYdP.js +0 -1
- package/dist/assets/requirementDiagram-UZGBJVZJ-u-qLWr1t.js +0 -64
- package/dist/assets/reveal-component-DNpBzX6F.js +0 -1069
- package/dist/assets/rpm-B7R9RTHE.js +0 -1
- package/dist/assets/ruby-BGJp-XLA.js +0 -1
- package/dist/assets/run-page-CO2X6wso.js +0 -1
- package/dist/assets/sankeyDiagram-TZEHDZUN-VL3oPzoy.js +0 -10
- package/dist/assets/sas-CZmYq1Si.js +0 -1
- package/dist/assets/scheme-CdW_eMia.js +0 -1
- package/dist/assets/scratchpad-panel-CWfddArs.js +0 -1
- package/dist/assets/secrets-panel-DqHGq3V8.js +0 -1
- package/dist/assets/sequenceDiagram-WL72ISMW-CyhmzEul.js +0 -145
- package/dist/assets/session-panel-BP0QxaoM.js +0 -1
- package/dist/assets/share-oorMPghT.js +0 -1
- package/dist/assets/shell-oPdLMo8m.js +0 -1
- package/dist/assets/sieve-DEd8Bmn8.js +0 -1
- package/dist/assets/smalltalk-CnqQIV2W.js +0 -1
- package/dist/assets/snippets-panel-DFJd1ui5.js +0 -1
- package/dist/assets/sparql-DKyVXlni.js +0 -1
- package/dist/assets/spec-D1ptWKg6.js +0 -1
- package/dist/assets/state-BXNNuw9g.js +0 -3
- package/dist/assets/state-D-vYm99C.js +0 -1
- package/dist/assets/state-D9EoHCkz.js +0 -1
- package/dist/assets/state-dx303w7J.js +0 -1
- package/dist/assets/stateDiagram-FKZM4ZOC-eVhhAfzW.js +0 -1
- package/dist/assets/stateDiagram-v2-4FDKWEC3-cGl1lSTF.js +0 -1
- package/dist/assets/step-vqKxn7TP.js +0 -1
- package/dist/assets/stex-C8c2RsN8.js +0 -1
- package/dist/assets/stylus-Dk_-yu_w.js +0 -1
- package/dist/assets/swift-CjrgUbUd.js +0 -1
- package/dist/assets/swiper-component-Da-gZjtJ.js +0 -1
- package/dist/assets/switch-BtkQp293.js +0 -1
- package/dist/assets/tcl-DCmY87p6.js +0 -1
- package/dist/assets/terminal-BSE1Vg5d.js +0 -62
- package/dist/assets/textarea-BBTcSr-i.js +0 -1
- package/dist/assets/textile-C_0nHQXl.js +0 -1
- package/dist/assets/time-Di7MbY-a.js +0 -1
- package/dist/assets/timeline-definition-IT6M3QCI-C01GhhW1.js +0 -61
- package/dist/assets/toml-DRTXXEvh.js +0 -1
- package/dist/assets/tracing-BQU8fBDM.js +0 -1
- package/dist/assets/tracing-panel-DEVpyGX3.js +0 -2
- package/dist/assets/tree-actions-DY8FUp3V.js +0 -1
- package/dist/assets/treemap-GDKQZRPO-Bqwz-MRa.js +0 -1
- package/dist/assets/troff-Cc6RCKwc.js +0 -1
- package/dist/assets/ttcn-B_hjyyZd.js +0 -1
- package/dist/assets/ttcn-cfg-C9kHEAnH.js +0 -1
- package/dist/assets/turtle-BpKw2L0C.js +0 -1
- package/dist/assets/useBoolean-B8LMGUHl.js +0 -1
- package/dist/assets/useCellActionButton-QaDO24oW.js +0 -1
- package/dist/assets/useDateFormatter-d3yglQmW.js +0 -1
- package/dist/assets/useDeleteCell-DFahVcdW.js +0 -1
- package/dist/assets/useDependencyPanelTab-BB_XeSAg.js +0 -1
- package/dist/assets/useHotkey-C04CW11R.js +0 -1
- package/dist/assets/useInstallPackage-hKfTes-m.js +0 -1
- package/dist/assets/useNotebookActions-CJEicFed.js +0 -4
- package/dist/assets/useNumberFormatter-CW4V-fpE.js +0 -1
- package/dist/assets/usePress-jH2RfcUG.js +0 -7
- package/dist/assets/useRunCells-C0BPo9m1.js +0 -1
- package/dist/assets/useSplitCell-BN53wD86.js +0 -1
- package/dist/assets/useTheme-Kwyx4PvL.js +0 -1
- package/dist/assets/utils-DQRuLEof.js +0 -61
- package/dist/assets/utils-Wvjk_Y4h.js +0 -1
- package/dist/assets/vb-DrexAmUA.js +0 -1
- package/dist/assets/vbscript-BxgSn4mU.js +0 -1
- package/dist/assets/vega-component-C9fDGx86.js +0 -1
- package/dist/assets/vega-loader.browser-xq8miGHn.js +0 -6
- package/dist/assets/velocity-FfkCaLcE.js +0 -1
- package/dist/assets/verilog-CqmLdpPq.js +0 -1
- package/dist/assets/vhdl-Brd1jg5j.js +0 -1
- package/dist/assets/webidl-I7JvNTQ0.js +0 -1
- package/dist/assets/write-secret-modal-Liv_9MXS.js +0 -1
- package/dist/assets/xquery-DryU6qzU.js +0 -1
- package/dist/assets/xychartDiagram-PRI3JC2R-CohoDL7X.js +0 -7
- package/dist/assets/yacas-CxNmk6Uw.js +0 -1
- package/dist/assets/z80-CIIYHJij.js +0 -1
- package/src/components/data-table/__tests__/column-header.test.ts +0 -65
- package/src/components/data-table/filters.ts +0 -386
- /package/dist/assets/{Deferred-DWBqOhWa.js → Deferred-CP7vq682.js} +0 -0
- /package/dist/assets/{ImageComparisonComponent-nhywlX8O.js → ImageComparisonComponent-BIetTBDq.js} +0 -0
- /package/dist/assets/{Inputs-COvM_tLq.js → Inputs-C6ftxLAJ.js} +0 -0
- /package/dist/assets/{Plot-BDBiXfv_.js → Plot-Ba3WGWNu.js} +0 -0
- /package/dist/assets/{SSRProvider-BIDQNg9Q.js → SSRProvider-CkFAAHXw.js} +0 -0
- /package/dist/assets/{alert-DrHguQlr.js → alert-yTS3WpF4.js} +0 -0
- /package/dist/assets/{apl-iXnrDoYq.js → apl-Byte72fT.js} +0 -0
- /package/dist/assets/{array-DdrmtJsl.js → array-CC7vZNGO.js} +0 -0
- /package/dist/assets/{asciiarmor-CK-aFa78.js → asciiarmor-BU-VnG1Y.js} +0 -0
- /package/dist/assets/{asn1-DWJdxrMP.js → asn1-hTvH3S4T.js} +0 -0
- /package/dist/assets/{asterisk-DmqsRS7E.js → asterisk-DIMri3P4.js} +0 -0
- /package/dist/assets/{azure-DBVzcmvx.js → azure-B42ls0Ui.js} +0 -0
- /package/dist/assets/{badge-DOX1Xxa9.js → badge-j3NGjqhR.js} +0 -0
- /package/dist/assets/{blob-3_FN0u9S.js → blob-Bgnx1kuY.js} +0 -0
- /package/dist/assets/{brainfuck-0bMZHpH_.js → brainfuck-C-q1Rv8J.js} +0 -0
- /package/dist/assets/{bundle.esm-BXIlAZ6T.js → bundle.esm-DjhGJy4I.js} +0 -0
- /package/dist/assets/{card-BFWJLptH.js → card--6HRj4T9.js} +0 -0
- /package/dist/assets/{chunk-4F5CHEZ2-BqEXxh1Z.js → chunk-4F5CHEZ2-eEwFz7fp.js} +0 -0
- /package/dist/assets/{chunk-B2363JML-BMBEdPpn.js → chunk-B2363JML-COExSe0d.js} +0 -0
- /package/dist/assets/{chunk-DR5Q36YT-DKTVLAfY.js → chunk-DR5Q36YT-OB6tC_dd.js} +0 -0
- /package/dist/assets/{chunk-FRFDVMJY-CfFB3K1V.js → chunk-FRFDVMJY-CO3-6rb4.js} +0 -0
- /package/dist/assets/{chunk-PL6DKKU2-B33xUOa0.js → chunk-PL6DKKU2-B9mDp5iV.js} +0 -0
- /package/dist/assets/{chunk-SJTYNZTY-8WPtvsjT.js → chunk-SJTYNZTY-Dh_h90Yu.js} +0 -0
- /package/dist/assets/{chunk-TQ3KTPDO-D2AjvUV_.js → chunk-TQ3KTPDO-CFybjK0M.js} +0 -0
- /package/dist/assets/{chunk-UMXZTB3W-BCNtLoey.js → chunk-UMXZTB3W-C3w83KpJ.js} +0 -0
- /package/dist/assets/{clear-button-pxtY_gQU.js → clear-button-Cfe8K4j_.js} +0 -0
- /package/dist/assets/{click-outside-container-C9uindjY.js → click-outside-container-BNVqwewc.js} +0 -0
- /package/dist/assets/{clike-5SQqmvx2.js → clike-BE-9Ct_H.js} +0 -0
- /package/dist/assets/{clojure-B0kIwyv8.js → clojure-Co-TLeNo.js} +0 -0
- /package/dist/assets/{cmake-CLXeINvH.js → cmake-B-Nm_Opd.js} +0 -0
- /package/dist/assets/{cobol-C9SsG--s.js → cobol-BGdihAZT.js} +0 -0
- /package/dist/assets/{coffeescript-UIQG6RnU.js → coffeescript-BUZXkMUO.js} +0 -0
- /package/dist/assets/{colors-CDxbWdyG.js → colors-BG8Z91CW.js} +0 -0
- /package/dist/assets/{common-keywords-Bf68gXm2.js → common-keywords-15xBKau4.js} +0 -0
- /package/dist/assets/{commonlisp-BBPumpJY.js → commonlisp-CFkPbxvX.js} +0 -0
- /package/dist/assets/{copy-Ch48HVPK.js → copy-LK56fFow.js} +0 -0
- /package/dist/assets/{crystal-CGN1wsuY.js → crystal-CqfqDl34.js} +0 -0
- /package/dist/assets/{css-aQ-Krb7T.js → css-DPEtZWJi.js} +0 -0
- /package/dist/assets/{cypher-DEE4_Yec.js → cypher-B0t8FJvU.js} +0 -0
- /package/dist/assets/{cytoscape.esm-DuXIsNbY.js → cytoscape.esm-DT8iy6p1.js} +0 -0
- /package/dist/assets/{d-CgJ8N-gL.js → d-DRa_XRSB.js} +0 -0
- /package/dist/assets/{defaultLocale-DPBdGRrH.js → defaultLocale-BLUna9fQ.js} +0 -0
- /package/dist/assets/{defaultLocale-Lfi0pexn.js → defaultLocale-DzliDDTm.js} +0 -0
- /package/dist/assets/{dialog-DqOQT_n4.js → dialog-DzC_QCtT.js} +0 -0
- /package/dist/assets/{diff-B8e18dKs.js → diff-GLneonpD.js} +0 -0
- /package/dist/assets/{dist-DP9Si-4r.js → dist-4ni0fia5.js} +0 -0
- /package/dist/assets/{dist-DjGavUj4.js → dist-A7swzSTR.js} +0 -0
- /package/dist/assets/{dist-BU26XwgJ.js → dist-B1U1kGCR.js} +0 -0
- /package/dist/assets/{dist-DGhKKgfN.js → dist-BQeNY9Zl.js} +0 -0
- /package/dist/assets/{dist-DQ3_8QJg.js → dist-BXRWfNwi.js} +0 -0
- /package/dist/assets/{dist-Scx61XLd.js → dist-BlOtCkpT.js} +0 -0
- /package/dist/assets/{dist-FS1xQUNb.js → dist-C78V1LRz.js} +0 -0
- /package/dist/assets/{dist-DkA__6UI.js → dist-CPczQFlJ.js} +0 -0
- /package/dist/assets/{dist-Bm0v4xuz.js → dist-CXBpwk_w.js} +0 -0
- /package/dist/assets/{dist-COs9gIu5.js → dist-ChF5Ln9c.js} +0 -0
- /package/dist/assets/{dist-EbJ2Bafg.js → dist-CsvFAFh9.js} +0 -0
- /package/dist/assets/{dist-CyKkoCYJ.js → dist-D70Tz1Kr.js} +0 -0
- /package/dist/assets/{dist-CTvZbFwy.js → dist-DUHHizRG.js} +0 -0
- /package/dist/assets/{dtd-DtwMcoo9.js → dtd-uVrZNVF0.js} +0 -0
- /package/dist/assets/{duckdb-keywords-BWKLsQSd.js → duckdb-keywords-CYQ5DEZJ.js} +0 -0
- /package/dist/assets/{dylan-Be6i1K-V.js → dylan-DkNeA4FZ.js} +0 -0
- /package/dist/assets/{ebnf-dezZofVm.js → ebnf-XMH6KY7E.js} +0 -0
- /package/dist/assets/{ecl-D5tlhe8s.js → ecl-CldUgvc9.js} +0 -0
- /package/dist/assets/{eiffel-8SQWO4xP.js → eiffel-CoMDRbRL.js} +0 -0
- /package/dist/assets/{elm-CtGe_7Jw.js → elm-Cb5XC6ev.js} +0 -0
- /package/dist/assets/{emotion-is-prop-valid.esm-Dangy3Bv.js → emotion-is-prop-valid.esm-C59xfSYt.js} +0 -0
- /package/dist/assets/{empty-state-CcobJSnG.js → empty-state-Cjt8SfMh.js} +0 -0
- /package/dist/assets/{en-US-C7vnqfgk.js → en-US-Cb8rIK52.js} +0 -0
- /package/dist/assets/{erlang-CNwX3Z_M.js → erlang-8H3fTZ3L.js} +0 -0
- /package/dist/assets/{errors-iwK4b4VF.js → errors-vr57w7Ul.js} +0 -0
- /package/dist/assets/{esm-CX-gNDKf.js → esm-1wf4HygE.js} +0 -0
- /package/dist/assets/{events-CBm-hwqS.js → events-CPoJAfgx.js} +0 -0
- /package/dist/assets/{extends-Dqvpuc10.js → extends-BiFDv3jB.js} +0 -0
- /package/dist/assets/{fcl-D566gDVV.js → fcl-DyFJAgkq.js} +0 -0
- /package/dist/assets/{file-HTLbeC2b.js → file-BrdxGLRX.js} +0 -0
- /package/dist/assets/{file-headphone-B3fuktN0.js → file-headphone-BrQspHac.js} +0 -0
- /package/dist/assets/{forth-CaVwPSxM.js → forth-B8kC4npz.js} +0 -0
- /package/dist/assets/{fortran-B28t9xoj.js → fortran-CNWGEL3c.js} +0 -0
- /package/dist/assets/{gas-BSiJHAcz.js → gas-DnZQNTHK.js} +0 -0
- /package/dist/assets/{gherkin-1QurHPOF.js → gherkin-JfGcGvci.js} +0 -0
- /package/dist/assets/{github-raQvpeuZ.js → github-BKS_2Qwn.js} +0 -0
- /package/dist/assets/{groovy-DFOLwJLv.js → groovy-D0FWiAVm.js} +0 -0
- /package/dist/assets/{haskell-CUN2jxPH.js → haskell-wUB3uX-G.js} +0 -0
- /package/dist/assets/{haxe-BYzKptPQ.js → haxe-g0JY6eL-.js} +0 -0
- /package/dist/assets/{house-D2ldnAB9.js → house-mGK3v0Mm.js} +0 -0
- /package/dist/assets/{http-Ms617AZI.js → http-ySzAzH5W.js} +0 -0
- /package/dist/assets/{icons-8tfAri2V.js → icons-Ol38nIbL.js} +0 -0
- /package/dist/assets/{idl-cdmrQY5J.js → idl-CV2cLkPc.js} +0 -0
- /package/dist/assets/{image-BIibSXT6.js → image-DQHXdEQn.js} +0 -0
- /package/dist/assets/{init-DiAYA_Co.js → init-DsZRk2YA.js} +0 -0
- /package/dist/assets/{isValid-DdlR4-BY.js → isValid-CklTTytn.js} +0 -0
- /package/dist/assets/{javascript-l5LYdpfx.js → javascript-CT6okXEZ.js} +0 -0
- /package/dist/assets/{julia-DxiTohY8.js → julia-CKC48ufo.js} +0 -0
- /package/dist/assets/{katex-CgXtp7UB.js → katex-BE4UDS50.js} +0 -0
- /package/dist/assets/{kbd-BJB2rf7K.js → kbd-CTUAEnEx.js} +0 -0
- /package/dist/assets/{link-CoJxTwWE.js → link-CfEtM3Rl.js} +0 -0
- /package/dist/assets/{links-B8WzCnbo.js → links-D1JoyKTt.js} +0 -0
- /package/dist/assets/{livescript-BZkzGFkJ.js → livescript-C43pZ6Ue.js} +0 -0
- /package/dist/assets/{loro_wasm_bg-C5TJxMR5.js → loro_wasm_bg-CXnd80ne.js} +0 -0
- /package/dist/assets/{lua-rVV1vLen.js → lua-Cs2mb10K.js} +0 -0
- /package/dist/assets/{marimo-icons-CUuBQ0ae.js → marimo-icons-CiwvnnsT.js} +0 -0
- /package/dist/assets/{math-CS811RUM.js → math-B-ZqhQTL.js} +0 -0
- /package/dist/assets/{mathematica-DktJ0aJB.js → mathematica-B5FMK3ma.js} +0 -0
- /package/dist/assets/{mbox-Ch6IVA7h.js → mbox-36Zrn5Bd.js} +0 -0
- /package/dist/assets/{message-circle-1YLdnr8A.js → message-circle-CWm2KnSx.js} +0 -0
- /package/dist/assets/{micromark-factory-space-BUQpMdx2.js → micromark-factory-space-BygYYKhs.js} +0 -0
- /package/dist/assets/{mirc-CdWws4At.js → mirc-BKTAABSX.js} +0 -0
- /package/dist/assets/{mllike-CB0tp4Bz.js → mllike-DbuClUqc.js} +0 -0
- /package/dist/assets/{modelica-DQGg_xsi.js → modelica-CKRvBm7N.js} +0 -0
- /package/dist/assets/{mscgen-vDSxnAXy.js → mscgen-B4BRgnCi.js} +0 -0
- /package/dist/assets/{mumps-BzlVzIzl.js → mumps-BFiMcyFV.js} +0 -0
- /package/dist/assets/{nginx-CNtYBWy9.js → nginx-Cz_XvoTm.js} +0 -0
- /package/dist/assets/{node-sql-parser-BvUFblwL.js → node-sql-parser-BtkrI4pN.js} +0 -0
- /package/dist/assets/{ntriples-BndMB6TK.js → ntriples-QQAkJYAR.js} +0 -0
- /package/dist/assets/{numbers-mY4EY0yG.js → numbers-C3BAdHZE.js} +0 -0
- /package/dist/assets/{objectWithoutPropertiesLoose-DoKw85w0.js → objectWithoutPropertiesLoose-DfWeGRFv.js} +0 -0
- /package/dist/assets/{octave-DhnkL0CH.js → octave-DsTphmGZ.js} +0 -0
- /package/dist/assets/{oz-DbZmNL9y.js → oz-CD9rr5Iz.js} +0 -0
- /package/dist/assets/{package-B8oXOUM-.js → package-Tv6ztuzw.js} +0 -0
- /package/dist/assets/{panel-context-DQWeG2KK.js → panel-context-BJbBGfoL.js} +0 -0
- /package/dist/assets/{pascal-DhE1sEjD.js → pascal-DdHEIlJE.js} +0 -0
- /package/dist/assets/{path-D1tAOolS.js → path-DvTahePH.js} +0 -0
- /package/dist/assets/{paths-SFhaqGlE.js → paths-D5zczhUD.js} +0 -0
- /package/dist/assets/{perl-BOZHK4Y3.js → perl-DHPJBQ1u.js} +0 -0
- /package/dist/assets/{pig-eswHTOE9.js → pig-Yz7ERgca.js} +0 -0
- /package/dist/assets/{play-5vQl-hy9.js → play-C7DcCsoO.js} +0 -0
- /package/dist/assets/{plus-CxkHs8QM.js → plus-BgB18UzY.js} +0 -0
- /package/dist/assets/{powershell-pm9G_Qg5.js → powershell-CHPZ_bsU.js} +0 -0
- /package/dist/assets/{preload-helper-DdZsAcJe.js → preload-helper-BPPi7vOr.js} +0 -0
- /package/dist/assets/{prop-types-DVDiRdwc.js → prop-types-DaaA-ptl.js} +0 -0
- /package/dist/assets/{properties-7VoeFdHR.js → properties-CI9nc7K4.js} +0 -0
- /package/dist/assets/{protobuf-BAsuCsmK.js → protobuf-BYSIv2pY.js} +0 -0
- /package/dist/assets/{puppet-DUYPK8CV.js → puppet-CEpLafZX.js} +0 -0
- /package/dist/assets/{purify.es-DvRMX74T.js → purify.es-B9KxLTTS.js} +0 -0
- /package/dist/assets/{python-UQl3_T6H.js → python-BndVuwG1.js} +0 -0
- /package/dist/assets/{q-CnvA_jxT.js → q-L_cetpiW.js} +0 -0
- /package/dist/assets/{r-fM1OLzJB.js → r-Dd37AKWk.js} +0 -0
- /package/dist/assets/{range-Dk7lXDev.js → range-gMGfxVwZ.js} +0 -0
- /package/dist/assets/{react-icons.esm--O4lBTlZ.js → react-icons.esm-BNzu6e7h.js} +0 -0
- /package/dist/assets/{react-resizable-panels.browser.esm-Ce2ksurd.js → react-resizable-panels.browser.esm-CV8-hvjx.js} +0 -0
- /package/dist/assets/{refresh-ccw-DLc784Sj.js → refresh-ccw-C-n2VFP5.js} +0 -0
- /package/dist/assets/{refresh-cw-a_9k9BK7.js → refresh-cw-DHwG4Mac.js} +0 -0
- /package/dist/assets/{rotate-ccw-DoQtGgvU.js → rotate-ccw-CNsAb2VZ.js} +0 -0
- /package/dist/assets/{rpm-D62D_dq6.js → rpm-CHrvhtlN.js} +0 -0
- /package/dist/assets/{ruby-DemvBD0m.js → ruby-BPOowfX6.js} +0 -0
- /package/dist/assets/{runs-Cn-NiTzH.js → runs-BD0G-C2A.js} +0 -0
- /package/dist/assets/{sas-CZjYQi4h.js → sas-BsEFSvEP.js} +0 -0
- /package/dist/assets/{save-DZ5aail6.js → save-Clg5dMoP.js} +0 -0
- /package/dist/assets/{scheme-nPNaP0Qp.js → scheme-B42INBu7.js} +0 -0
- /package/dist/assets/{semaphore-X3ApuO41.js → semaphore-FlZezxaf.js} +0 -0
- /package/dist/assets/{session-DGdfs0bJ.js → session-0B5NBztP.js} +0 -0
- /package/dist/assets/{settings-SnYErNWQ.js → settings-DfFe0dWD.js} +0 -0
- /package/dist/assets/{shell-BE2ANxN1.js → shell-BPea12OI.js} +0 -0
- /package/dist/assets/{sieve-DXFUN4C7.js → sieve-C-yPcLw5.js} +0 -0
- /package/dist/assets/{simple-mode-CZ1ts7NY.js → simple-mode-CFlvn0Mm.js} +0 -0
- /package/dist/assets/{smalltalk-DwXXlSAY.js → smalltalk-e7OO1ATb.js} +0 -0
- /package/dist/assets/{solr-DndbfGC6.js → solr-BAO4N63o.js} +0 -0
- /package/dist/assets/{sparkles-CC9Bko6a.js → sparkles-lWUAsPhp.js} +0 -0
- /package/dist/assets/{sparql-CgejAdiJ.js → sparql-B4I2Ledx.js} +0 -0
- /package/dist/assets/{spinner-UuZAUjoP.js → spinner-Bhir8k53.js} +0 -0
- /package/dist/assets/{spreadsheet-DHoeoJHd.js → spreadsheet-DWqd5foV.js} +0 -0
- /package/dist/assets/{sql-DzyjqiRG.js → sql-RBdzBYsM.js} +0 -0
- /package/dist/assets/{square-rACnnz-q.js → square-B5xWCt0a.js} +0 -0
- /package/dist/assets/{square-function-blYaQso8.js → square-function-uY_yJr5g.js} +0 -0
- /package/dist/assets/{src-D57-7XBB.js → src-BnrQkOKh.js} +0 -0
- /package/dist/assets/{stex-lcoTi-7o.js → stex-BGrE-q7N.js} +0 -0
- /package/dist/assets/{stylus-CslB9TS3.js → stylus-CBRbZwhN.js} +0 -0
- /package/dist/assets/{swift-5t7SQPo8.js → swift-B2hnU7ha.js} +0 -0
- /package/dist/assets/{table-DQE9hQzM.js → table-BGPSHfig.js} +0 -0
- /package/dist/assets/{tcl-Ddpe8YBc.js → tcl-BtyamtaZ.js} +0 -0
- /package/dist/assets/{textile-D_Db33mq.js → textile-M9mhyNE9.js} +0 -0
- /package/dist/assets/{tiddlywiki-Laz7iVQn.js → tiddlywiki-BsHUDwie.js} +0 -0
- /package/dist/assets/{tiki-Dd2_LAYu.js → tiki-ZqBe4Kjv.js} +0 -0
- /package/dist/assets/{toml-CgkLq_pv.js → toml-YxyxhyRy.js} +0 -0
- /package/dist/assets/{trash-2-BJLYnZpG.js → trash-2-rVklqqFF.js} +0 -0
- /package/dist/assets/{trash-wVOgGgQw.js → trash-DqeDe-Ua.js} +0 -0
- /package/dist/assets/{treemap-Cli48Hv9.js → treemap-DeGcO9km.js} +0 -0
- /package/dist/assets/{triangle-alert-CJ0ZIqcz.js → triangle-alert-D2p96PEF.js} +0 -0
- /package/dist/assets/{troff-6nX9d05T.js → troff-C7xpi05X.js} +0 -0
- /package/dist/assets/{ttcn-Dd4SMoHT.js → ttcn-D3YytrJU.js} +0 -0
- /package/dist/assets/{ttcn-cfg-ByNDYolW.js → ttcn-cfg-DlZ5vA9E.js} +0 -0
- /package/dist/assets/{turtle-LDF8uFGv.js → turtle-BSHvAsUe.js} +0 -0
- /package/dist/assets/{types-BYwxXaSY.js → types-W8WWuumF.js} +0 -0
- /package/dist/assets/{types-DZmRsGZN.js → types-a-yURniQ.js} +0 -0
- /package/dist/assets/{use-toast-ERM44-k9.js → use-toast-IPAtJGea.js} +0 -0
- /package/dist/assets/{useAsyncData-C5i0IRVM.js → useAsyncData-bgszE9F0.js} +0 -0
- /package/dist/assets/{useDebounce-_BZcy6gx.js → useDebounce-7xZwVnnu.js} +0 -0
- /package/dist/assets/{useDeepCompareMemoize-CWcgQCbT.js → useDeepCompareMemoize-zUHU--0D.js} +0 -0
- /package/dist/assets/{useIframeCapabilities-DPVTppnD.js → useIframeCapabilities-CcI1zSdn.js} +0 -0
- /package/dist/assets/{useInterval-CSOniNAx.js → useInterval-2YvvhIZI.js} +0 -0
- /package/dist/assets/{uuid-D_zLHhNi.js → uuid-e9lSomwA.js} +0 -0
- /package/dist/assets/{vb-DaLxM60T.js → vb-DdkIDLlO.js} +0 -0
- /package/dist/assets/{vbscript-CwitZ57u.js → vbscript-DhYGmk_p.js} +0 -0
- /package/dist/assets/{velocity-D6bc4mrP.js → velocity-DAXJNEw4.js} +0 -0
- /package/dist/assets/{verilog-CIyPdzYJ.js → verilog-jmuT_L3b.js} +0 -0
- /package/dist/assets/{vhdl-DfyhlM4K.js → vhdl-DcVQ97RU.js} +0 -0
- /package/dist/assets/{web-vitals-BaMazlva.js → web-vitals-xkV-JBVF.js} +0 -0
- /package/dist/assets/{webidl-C23hA3Le.js → webidl-B-YB_4OQ.js} +0 -0
- /package/dist/assets/{workflow-CgnDnnoN.js → workflow-Bm8qF7yj.js} +0 -0
- /package/dist/assets/{ws-Cb8IUKlU.js → ws-BnE9sl8z.js} +0 -0
- /package/dist/assets/{xquery-BAVQXrAf.js → xquery-DOmY3Oe8.js} +0 -0
- /package/dist/assets/{yacas-DrybVty2.js → yacas-pL3kJRXV.js} +0 -0
- /package/dist/assets/{youtube-3lRHw8NU.js → youtube-CbdpN8oL.js} +0 -0
- /package/dist/assets/{z80-8KI6AMtY.js → z80-VwVuI_MT.js} +0 -0
|
@@ -0,0 +1,278 @@
|
|
|
1
|
+
/* Copyright 2026 Marimo. All rights reserved. */
|
|
2
|
+
|
|
3
|
+
import type { UIMessageChunk } from "ai";
|
|
4
|
+
import { describe, expect, it, vi } from "vitest";
|
|
5
|
+
import { routeIncomingChatChunk } from "../chat-ui";
|
|
6
|
+
|
|
7
|
+
/**
|
|
8
|
+
* The stale-chunk filter prevents chunks from an aborted run from being enqueued into a new run's stream.
|
|
9
|
+
*
|
|
10
|
+
* It triggers when:
|
|
11
|
+
* 1. User sends a prompt (request_id = OLD), kernel starts emitting chunks
|
|
12
|
+
* 2. User clicks Stop — frontend tears down its controller, fires cancel_prompt
|
|
13
|
+
* 3. Kernel hasn't received the cancel yet and is still emitting chunks
|
|
14
|
+
* 4. User sends a new prompt (request_id = NEW), new controller opens
|
|
15
|
+
* 5. Late chunks tagged OLD arrive after NEW's controller is in place
|
|
16
|
+
*/
|
|
17
|
+
|
|
18
|
+
const makeChunk = (opts: {
|
|
19
|
+
messageId: string;
|
|
20
|
+
content: unknown;
|
|
21
|
+
isFinal?: boolean;
|
|
22
|
+
}): Parameters<typeof routeIncomingChatChunk>[0] => ({
|
|
23
|
+
type: "stream_chunk",
|
|
24
|
+
message_id: opts.messageId,
|
|
25
|
+
content: opts.content as UIMessageChunk | null,
|
|
26
|
+
is_final: opts.isFinal ?? false,
|
|
27
|
+
});
|
|
28
|
+
|
|
29
|
+
const makeRefs = () => ({
|
|
30
|
+
controllerRef: {
|
|
31
|
+
current: null as ReadableStreamDefaultController<UIMessageChunk> | null,
|
|
32
|
+
},
|
|
33
|
+
activeRequestIdRef: { current: null as string | null },
|
|
34
|
+
});
|
|
35
|
+
|
|
36
|
+
const makeMockController = () => {
|
|
37
|
+
return {
|
|
38
|
+
enqueue: vi.fn(),
|
|
39
|
+
close: vi.fn(),
|
|
40
|
+
error: vi.fn(),
|
|
41
|
+
desiredSize: 0,
|
|
42
|
+
} as unknown as ReadableStreamDefaultController<UIMessageChunk> & {
|
|
43
|
+
enqueue: ReturnType<typeof vi.fn>;
|
|
44
|
+
close: ReturnType<typeof vi.fn>;
|
|
45
|
+
};
|
|
46
|
+
};
|
|
47
|
+
|
|
48
|
+
describe("routeIncomingChatChunk", () => {
|
|
49
|
+
it("drops chunks when there is no active controller", () => {
|
|
50
|
+
const refs = makeRefs();
|
|
51
|
+
|
|
52
|
+
const result = routeIncomingChatChunk(
|
|
53
|
+
makeChunk({
|
|
54
|
+
messageId: "req-A",
|
|
55
|
+
content: { type: "text-delta", id: "t1", delta: "hi" },
|
|
56
|
+
}),
|
|
57
|
+
refs,
|
|
58
|
+
);
|
|
59
|
+
|
|
60
|
+
expect(result).toBe("dropped-no-controller");
|
|
61
|
+
});
|
|
62
|
+
|
|
63
|
+
it("enqueues chunks that match the active request_id", () => {
|
|
64
|
+
const refs = makeRefs();
|
|
65
|
+
const controller = makeMockController();
|
|
66
|
+
refs.controllerRef.current = controller;
|
|
67
|
+
refs.activeRequestIdRef.current = "req-A";
|
|
68
|
+
|
|
69
|
+
const chunk = { type: "text-delta", id: "t1", delta: "hi" } as const;
|
|
70
|
+
const result = routeIncomingChatChunk(
|
|
71
|
+
makeChunk({ messageId: "req-A", content: chunk }),
|
|
72
|
+
refs,
|
|
73
|
+
);
|
|
74
|
+
|
|
75
|
+
expect(result).toBe("enqueued");
|
|
76
|
+
expect(controller.enqueue).toHaveBeenCalledWith(chunk);
|
|
77
|
+
expect(controller.close).not.toHaveBeenCalled();
|
|
78
|
+
});
|
|
79
|
+
|
|
80
|
+
it("closes the controller and clears refs on is_final", () => {
|
|
81
|
+
const refs = makeRefs();
|
|
82
|
+
const controller = makeMockController();
|
|
83
|
+
refs.controllerRef.current = controller;
|
|
84
|
+
refs.activeRequestIdRef.current = "req-A";
|
|
85
|
+
|
|
86
|
+
const result = routeIncomingChatChunk(
|
|
87
|
+
makeChunk({ messageId: "req-A", content: null, isFinal: true }),
|
|
88
|
+
refs,
|
|
89
|
+
);
|
|
90
|
+
|
|
91
|
+
expect(result).toBe("closed");
|
|
92
|
+
expect(controller.close).toHaveBeenCalledTimes(1);
|
|
93
|
+
expect(refs.controllerRef.current).toBeNull();
|
|
94
|
+
expect(refs.activeRequestIdRef.current).toBeNull();
|
|
95
|
+
});
|
|
96
|
+
|
|
97
|
+
it("drops chunks whose message_id does not match the active run", () => {
|
|
98
|
+
// Simulates the bug: kernel hasn't received cancel for OLD yet but the
|
|
99
|
+
// user has already started a NEW run. A reasoning-delta for OLD arrives
|
|
100
|
+
// here; it must not be enqueued into NEW's stream.
|
|
101
|
+
const refs = makeRefs();
|
|
102
|
+
const controller = makeMockController();
|
|
103
|
+
refs.controllerRef.current = controller;
|
|
104
|
+
refs.activeRequestIdRef.current = "req-NEW";
|
|
105
|
+
|
|
106
|
+
const staleChunk = {
|
|
107
|
+
type: "reasoning-delta",
|
|
108
|
+
id: "r-old",
|
|
109
|
+
delta: "...",
|
|
110
|
+
} as const;
|
|
111
|
+
const result = routeIncomingChatChunk(
|
|
112
|
+
makeChunk({ messageId: "req-OLD", content: staleChunk }),
|
|
113
|
+
refs,
|
|
114
|
+
);
|
|
115
|
+
|
|
116
|
+
expect(result).toBe("dropped-stale");
|
|
117
|
+
expect(controller.enqueue).not.toHaveBeenCalled();
|
|
118
|
+
expect(controller.close).not.toHaveBeenCalled();
|
|
119
|
+
expect(refs.activeRequestIdRef.current).toBe("req-NEW");
|
|
120
|
+
});
|
|
121
|
+
|
|
122
|
+
it("drops is_final from a stale run without closing the active stream", () => {
|
|
123
|
+
// Belt-and-suspenders: an `is_final` for OLD that races in after NEW
|
|
124
|
+
// started must not tear down NEW's controller.
|
|
125
|
+
const refs = makeRefs();
|
|
126
|
+
const controller = makeMockController();
|
|
127
|
+
refs.controllerRef.current = controller;
|
|
128
|
+
refs.activeRequestIdRef.current = "req-NEW";
|
|
129
|
+
|
|
130
|
+
const result = routeIncomingChatChunk(
|
|
131
|
+
makeChunk({ messageId: "req-OLD", content: null, isFinal: true }),
|
|
132
|
+
refs,
|
|
133
|
+
);
|
|
134
|
+
|
|
135
|
+
expect(result).toBe("dropped-stale");
|
|
136
|
+
expect(controller.close).not.toHaveBeenCalled();
|
|
137
|
+
expect(refs.controllerRef.current).toBe(controller);
|
|
138
|
+
expect(refs.activeRequestIdRef.current).toBe("req-NEW");
|
|
139
|
+
});
|
|
140
|
+
|
|
141
|
+
it("forwards reasoning-start/delta/end sequences when ids match", () => {
|
|
142
|
+
// Walks the canonical happy path for a reasoning stream end-to-end.
|
|
143
|
+
const refs = makeRefs();
|
|
144
|
+
const controller = makeMockController();
|
|
145
|
+
refs.controllerRef.current = controller;
|
|
146
|
+
refs.activeRequestIdRef.current = "req-A";
|
|
147
|
+
|
|
148
|
+
const sequence = [
|
|
149
|
+
{ type: "reasoning-start", id: "r1" },
|
|
150
|
+
{ type: "reasoning-delta", id: "r1", delta: "thinking" },
|
|
151
|
+
{ type: "reasoning-end", id: "r1" },
|
|
152
|
+
] as const;
|
|
153
|
+
for (const chunk of sequence) {
|
|
154
|
+
const result = routeIncomingChatChunk(
|
|
155
|
+
makeChunk({ messageId: "req-A", content: chunk }),
|
|
156
|
+
refs,
|
|
157
|
+
);
|
|
158
|
+
expect(result).toBe("enqueued");
|
|
159
|
+
}
|
|
160
|
+
|
|
161
|
+
expect(controller.enqueue).toHaveBeenCalledTimes(3);
|
|
162
|
+
expect(controller.enqueue).toHaveBeenNthCalledWith(1, sequence[0]);
|
|
163
|
+
expect(controller.enqueue).toHaveBeenNthCalledWith(2, sequence[1]);
|
|
164
|
+
expect(controller.enqueue).toHaveBeenNthCalledWith(3, sequence[2]);
|
|
165
|
+
});
|
|
166
|
+
|
|
167
|
+
it(
|
|
168
|
+
"drops stale reasoning-delta after Stop → new run sequence " +
|
|
169
|
+
"(regression for missing reasoning part error)",
|
|
170
|
+
() => {
|
|
171
|
+
// Full scenario: A runs, A is stopped, B starts, A's late chunk arrives.
|
|
172
|
+
const refs = makeRefs();
|
|
173
|
+
|
|
174
|
+
// 1. Run A starts: controller A active.
|
|
175
|
+
const controllerA = makeMockController();
|
|
176
|
+
refs.controllerRef.current = controllerA;
|
|
177
|
+
refs.activeRequestIdRef.current = "req-A";
|
|
178
|
+
|
|
179
|
+
// First reasoning chunks for A flow through.
|
|
180
|
+
routeIncomingChatChunk(
|
|
181
|
+
makeChunk({
|
|
182
|
+
messageId: "req-A",
|
|
183
|
+
content: { type: "reasoning-start", id: "rA" },
|
|
184
|
+
}),
|
|
185
|
+
refs,
|
|
186
|
+
);
|
|
187
|
+
routeIncomingChatChunk(
|
|
188
|
+
makeChunk({
|
|
189
|
+
messageId: "req-A",
|
|
190
|
+
content: {
|
|
191
|
+
type: "reasoning-delta",
|
|
192
|
+
id: "rA",
|
|
193
|
+
delta: "thinking",
|
|
194
|
+
},
|
|
195
|
+
}),
|
|
196
|
+
refs,
|
|
197
|
+
);
|
|
198
|
+
expect(controllerA.enqueue).toHaveBeenCalledTimes(2);
|
|
199
|
+
|
|
200
|
+
// 2. User clicks Stop: abort handler clears refs (simulated).
|
|
201
|
+
refs.controllerRef.current = null;
|
|
202
|
+
refs.activeRequestIdRef.current = null;
|
|
203
|
+
|
|
204
|
+
// A late chunk for A arrives in this window — must be a no-op.
|
|
205
|
+
const between = routeIncomingChatChunk(
|
|
206
|
+
makeChunk({
|
|
207
|
+
messageId: "req-A",
|
|
208
|
+
content: {
|
|
209
|
+
type: "reasoning-delta",
|
|
210
|
+
id: "rA",
|
|
211
|
+
delta: "leftover",
|
|
212
|
+
},
|
|
213
|
+
}),
|
|
214
|
+
refs,
|
|
215
|
+
);
|
|
216
|
+
expect(between).toBe("dropped-no-controller");
|
|
217
|
+
|
|
218
|
+
// 3. User sends Run B: new controller, new active id.
|
|
219
|
+
const controllerB = makeMockController();
|
|
220
|
+
refs.controllerRef.current = controllerB;
|
|
221
|
+
refs.activeRequestIdRef.current = "req-B";
|
|
222
|
+
|
|
223
|
+
// 4. Another late chunk for A arrives AFTER B opened. This is the
|
|
224
|
+
// case that previously threw `Received reasoning-delta for missing
|
|
225
|
+
// reasoning part with ID "rA"` in the SDK parser.
|
|
226
|
+
const stale = routeIncomingChatChunk(
|
|
227
|
+
makeChunk({
|
|
228
|
+
messageId: "req-A",
|
|
229
|
+
content: {
|
|
230
|
+
type: "reasoning-delta",
|
|
231
|
+
id: "rA",
|
|
232
|
+
delta: "still leaking",
|
|
233
|
+
},
|
|
234
|
+
}),
|
|
235
|
+
refs,
|
|
236
|
+
);
|
|
237
|
+
expect(stale).toBe("dropped-stale");
|
|
238
|
+
expect(controllerB.enqueue).not.toHaveBeenCalled();
|
|
239
|
+
|
|
240
|
+
// 5. B's own chunks flow normally.
|
|
241
|
+
routeIncomingChatChunk(
|
|
242
|
+
makeChunk({
|
|
243
|
+
messageId: "req-B",
|
|
244
|
+
content: { type: "reasoning-start", id: "rB" },
|
|
245
|
+
}),
|
|
246
|
+
refs,
|
|
247
|
+
);
|
|
248
|
+
routeIncomingChatChunk(
|
|
249
|
+
makeChunk({
|
|
250
|
+
messageId: "req-B",
|
|
251
|
+
content: { type: "reasoning-delta", id: "rB", delta: "fresh" },
|
|
252
|
+
}),
|
|
253
|
+
refs,
|
|
254
|
+
);
|
|
255
|
+
expect(controllerB.enqueue).toHaveBeenCalledTimes(2);
|
|
256
|
+
},
|
|
257
|
+
);
|
|
258
|
+
|
|
259
|
+
it("enqueues content alongside is_final and then closes", () => {
|
|
260
|
+
// Sanity: a single chunk that carries both `content` and `is_final` (rare
|
|
261
|
+
// but legal — backend may bundle final content with the terminator)
|
|
262
|
+
// should enqueue then close.
|
|
263
|
+
const refs = makeRefs();
|
|
264
|
+
const controller = makeMockController();
|
|
265
|
+
refs.controllerRef.current = controller;
|
|
266
|
+
refs.activeRequestIdRef.current = "req-A";
|
|
267
|
+
|
|
268
|
+
const chunk = { type: "text-delta", id: "t1", delta: "bye" } as const;
|
|
269
|
+
const result = routeIncomingChatChunk(
|
|
270
|
+
makeChunk({ messageId: "req-A", content: chunk, isFinal: true }),
|
|
271
|
+
refs,
|
|
272
|
+
);
|
|
273
|
+
|
|
274
|
+
expect(result).toBe("closed");
|
|
275
|
+
expect(controller.enqueue).toHaveBeenCalledWith(chunk);
|
|
276
|
+
expect(controller.close).toHaveBeenCalledTimes(1);
|
|
277
|
+
});
|
|
278
|
+
});
|
|
@@ -20,13 +20,17 @@ import {
|
|
|
20
20
|
RotateCwIcon,
|
|
21
21
|
SendHorizontalIcon,
|
|
22
22
|
SettingsIcon,
|
|
23
|
+
SquareIcon,
|
|
23
24
|
Trash2Icon,
|
|
24
25
|
X,
|
|
25
26
|
} from "lucide-react";
|
|
26
27
|
import React, { useEffect, useRef, useState } from "react";
|
|
27
28
|
import { z } from "zod";
|
|
28
29
|
import { renderUIMessage } from "@/components/chat/chat-display";
|
|
29
|
-
import {
|
|
30
|
+
import {
|
|
31
|
+
convertToFileUIPart,
|
|
32
|
+
hasPendingToolCalls,
|
|
33
|
+
} from "@/components/chat/chat-utils";
|
|
30
34
|
import {
|
|
31
35
|
type AdditionalCompletions,
|
|
32
36
|
PromptInput,
|
|
@@ -60,6 +64,7 @@ import { cn } from "@/utils/cn";
|
|
|
60
64
|
import { Logger } from "@/utils/Logger";
|
|
61
65
|
import { Objects } from "@/utils/objects";
|
|
62
66
|
import { Strings } from "@/utils/strings";
|
|
67
|
+
import { generateUUID } from "@/utils/uuid";
|
|
63
68
|
import { ErrorBanner } from "../common/error-banner";
|
|
64
69
|
import type { PluginFunctions } from "./ChatPlugin";
|
|
65
70
|
import type { ChatConfig } from "./types";
|
|
@@ -86,6 +91,48 @@ const ChatMessageIncomingSchema = z.object({
|
|
|
86
91
|
is_final: z.boolean().optional(),
|
|
87
92
|
});
|
|
88
93
|
|
|
94
|
+
type ChatMessageIncoming = z.infer<typeof ChatMessageIncomingSchema>;
|
|
95
|
+
|
|
96
|
+
export interface IncomingChatChunkRefs {
|
|
97
|
+
controllerRef: {
|
|
98
|
+
current: ReadableStreamDefaultController<UIMessageChunk> | null;
|
|
99
|
+
};
|
|
100
|
+
activeRequestIdRef: { current: string | null };
|
|
101
|
+
}
|
|
102
|
+
|
|
103
|
+
/**
|
|
104
|
+
* Route a single incoming chunk to the active stream controller, dropping it
|
|
105
|
+
* if it belongs to a stale (aborted-but-not-yet-cancelled) backend run.
|
|
106
|
+
*/
|
|
107
|
+
export function routeIncomingChatChunk(
|
|
108
|
+
message: ChatMessageIncoming,
|
|
109
|
+
refs: IncomingChatChunkRefs,
|
|
110
|
+
): "enqueued" | "closed" | "dropped-no-controller" | "dropped-stale" {
|
|
111
|
+
const { controllerRef, activeRequestIdRef } = refs;
|
|
112
|
+
const controller = controllerRef.current;
|
|
113
|
+
if (controller === null) {
|
|
114
|
+
return "dropped-no-controller";
|
|
115
|
+
}
|
|
116
|
+
const activeRequestId = activeRequestIdRef.current;
|
|
117
|
+
if (activeRequestId !== null && message.message_id !== activeRequestId) {
|
|
118
|
+
Logger.debug("Dropping stale chat chunk", {
|
|
119
|
+
chunkRequestId: message.message_id,
|
|
120
|
+
activeRequestId,
|
|
121
|
+
});
|
|
122
|
+
return "dropped-stale";
|
|
123
|
+
}
|
|
124
|
+
if (message.content) {
|
|
125
|
+
controller.enqueue(message.content);
|
|
126
|
+
}
|
|
127
|
+
if (message.is_final) {
|
|
128
|
+
controller.close();
|
|
129
|
+
controllerRef.current = null;
|
|
130
|
+
activeRequestIdRef.current = null;
|
|
131
|
+
return "closed";
|
|
132
|
+
}
|
|
133
|
+
return "enqueued";
|
|
134
|
+
}
|
|
135
|
+
|
|
89
136
|
export const Chatbot: React.FC<Props> = (props) => {
|
|
90
137
|
const [input, setInput] = useState("");
|
|
91
138
|
const [config, setConfig] = useState<ChatConfig>(props.config);
|
|
@@ -113,16 +160,15 @@ export const Chatbot: React.FC<Props> = (props) => {
|
|
|
113
160
|
const configRef = useRef<ChatConfig>(config);
|
|
114
161
|
configRef.current = config;
|
|
115
162
|
|
|
116
|
-
// Track streaming state - maps backend message_id to frontend message index
|
|
117
|
-
const streamingStateRef = useRef<{
|
|
118
|
-
backendMessageId: string | null;
|
|
119
|
-
frontendMessageIndex: number | null;
|
|
120
|
-
}>({ backendMessageId: null, frontendMessageIndex: null });
|
|
121
|
-
|
|
122
163
|
// For frontend-managed streaming, create a controller to enqueue chunks to.
|
|
123
164
|
const frontendStreamControllerRef =
|
|
124
165
|
useRef<ReadableStreamDefaultController<UIMessageChunk> | null>(null);
|
|
125
166
|
|
|
167
|
+
// The request_id of the currently-active prompt run. Chunks arriving with a
|
|
168
|
+
// different message_id are stale (from an aborted-but-not-yet-cancelled run
|
|
169
|
+
// on the kernel) and must be dropped
|
|
170
|
+
const activeRequestIdRef = useRef<string | null>(null);
|
|
171
|
+
|
|
126
172
|
const { data: backendMessages } = useAsyncData(async () => {
|
|
127
173
|
const response = await props.get_chat_history({});
|
|
128
174
|
return response.messages;
|
|
@@ -143,7 +189,9 @@ export const Chatbot: React.FC<Props> = (props) => {
|
|
|
143
189
|
error,
|
|
144
190
|
regenerate,
|
|
145
191
|
clearError,
|
|
192
|
+
addToolApprovalResponse,
|
|
146
193
|
} = useChat({
|
|
194
|
+
sendAutomaticallyWhen: ({ messages }) => hasPendingToolCalls(messages),
|
|
147
195
|
transport: new DefaultChatTransport({
|
|
148
196
|
fetch: async (
|
|
149
197
|
request: RequestInfo | URL,
|
|
@@ -180,17 +228,33 @@ export const Chatbot: React.FC<Props> = (props) => {
|
|
|
180
228
|
};
|
|
181
229
|
});
|
|
182
230
|
|
|
231
|
+
// Client-generated id used to (a) route chunks back to this stream
|
|
232
|
+
// and (b) ask the kernel to cancel just this run on Stop.
|
|
233
|
+
const requestId = generateUUID();
|
|
234
|
+
|
|
183
235
|
const stream = new ReadableStream<UIMessageChunk>({
|
|
184
236
|
start(controller) {
|
|
185
237
|
frontendStreamControllerRef.current = controller;
|
|
238
|
+
activeRequestIdRef.current = requestId;
|
|
186
239
|
|
|
187
240
|
const abortHandler = () => {
|
|
241
|
+
// Close the local controller first so the chat status flips to
|
|
242
|
+
// "ready" immediately and any racing chunks are dropped; then
|
|
243
|
+
// fire-and-forget the backend cancel so the kernel stops the
|
|
244
|
+
// model and we don't waste tokens / leak chunks to the next
|
|
245
|
+
// run.
|
|
188
246
|
try {
|
|
189
247
|
controller.close();
|
|
190
248
|
} catch (error) {
|
|
191
249
|
Logger.debug("Controller may already be closed", { error });
|
|
192
250
|
}
|
|
193
251
|
frontendStreamControllerRef.current = null;
|
|
252
|
+
activeRequestIdRef.current = null;
|
|
253
|
+
void props
|
|
254
|
+
.cancel_prompt({ request_id: requestId })
|
|
255
|
+
.catch((error: Error) => {
|
|
256
|
+
Logger.debug("cancel_prompt failed", { error });
|
|
257
|
+
});
|
|
194
258
|
};
|
|
195
259
|
signal?.addEventListener("abort", abortHandler);
|
|
196
260
|
|
|
@@ -200,28 +264,25 @@ export const Chatbot: React.FC<Props> = (props) => {
|
|
|
200
264
|
},
|
|
201
265
|
cancel() {
|
|
202
266
|
frontendStreamControllerRef.current = null;
|
|
267
|
+
activeRequestIdRef.current = null;
|
|
203
268
|
},
|
|
204
269
|
});
|
|
205
270
|
|
|
206
271
|
// Start the prompt, chunks will be sent via events
|
|
207
272
|
void props
|
|
208
273
|
.send_prompt({
|
|
274
|
+
request_id: requestId,
|
|
209
275
|
messages: messages,
|
|
210
276
|
config: chatConfig,
|
|
211
277
|
})
|
|
212
278
|
.catch((error: Error) => {
|
|
213
279
|
frontendStreamControllerRef.current?.error(error);
|
|
214
280
|
frontendStreamControllerRef.current = null;
|
|
281
|
+
activeRequestIdRef.current = null;
|
|
215
282
|
});
|
|
216
283
|
|
|
217
284
|
return createUIMessageStreamResponse({ stream });
|
|
218
285
|
} catch (error: unknown) {
|
|
219
|
-
// Clear streaming state on error
|
|
220
|
-
streamingStateRef.current = {
|
|
221
|
-
backendMessageId: null,
|
|
222
|
-
frontendMessageIndex: null,
|
|
223
|
-
};
|
|
224
|
-
|
|
225
286
|
// Handle abort gracefully without showing an error
|
|
226
287
|
if (error instanceof Error && error.name === "AbortError") {
|
|
227
288
|
return new Response("Aborted", { status: 499 });
|
|
@@ -244,21 +305,10 @@ export const Chatbot: React.FC<Props> = (props) => {
|
|
|
244
305
|
}
|
|
245
306
|
Logger.debug("Finished streaming message:", message);
|
|
246
307
|
|
|
247
|
-
// Clear streaming state
|
|
248
|
-
streamingStateRef.current = {
|
|
249
|
-
backendMessageId: null,
|
|
250
|
-
frontendMessageIndex: null,
|
|
251
|
-
};
|
|
252
|
-
|
|
253
308
|
props.setValue(message.messages);
|
|
254
309
|
},
|
|
255
310
|
onError: (error) => {
|
|
256
311
|
Logger.error("An error occurred:", error);
|
|
257
|
-
// Clear streaming state on error
|
|
258
|
-
streamingStateRef.current = {
|
|
259
|
-
backendMessageId: null,
|
|
260
|
-
frontendMessageIndex: null,
|
|
261
|
-
};
|
|
262
312
|
},
|
|
263
313
|
});
|
|
264
314
|
|
|
@@ -273,23 +323,10 @@ export const Chatbot: React.FC<Props> = (props) => {
|
|
|
273
323
|
if (!parsedMessage.success) {
|
|
274
324
|
return;
|
|
275
325
|
}
|
|
276
|
-
|
|
277
|
-
|
|
278
|
-
|
|
279
|
-
|
|
280
|
-
if (!controller) {
|
|
281
|
-
return;
|
|
282
|
-
}
|
|
283
|
-
|
|
284
|
-
if (message.content) {
|
|
285
|
-
controller.enqueue(message.content);
|
|
286
|
-
}
|
|
287
|
-
if (message.is_final) {
|
|
288
|
-
controller.close();
|
|
289
|
-
frontendStreamControllerRef.current = null;
|
|
290
|
-
}
|
|
291
|
-
|
|
292
|
-
return;
|
|
326
|
+
routeIncomingChatChunk(parsedMessage.data, {
|
|
327
|
+
controllerRef: frontendStreamControllerRef,
|
|
328
|
+
activeRequestIdRef,
|
|
329
|
+
});
|
|
293
330
|
},
|
|
294
331
|
);
|
|
295
332
|
|
|
@@ -408,6 +445,9 @@ export const Chatbot: React.FC<Props> = (props) => {
|
|
|
408
445
|
message,
|
|
409
446
|
isStreamingReasoning: status === "streaming",
|
|
410
447
|
isLast,
|
|
448
|
+
addToolApprovalResponse: isLast
|
|
449
|
+
? addToolApprovalResponse
|
|
450
|
+
: undefined,
|
|
411
451
|
})}
|
|
412
452
|
</div>
|
|
413
453
|
<div className="flex justify-end text-xs gap-2 invisible group-hover:visible">
|
|
@@ -429,16 +469,8 @@ export const Chatbot: React.FC<Props> = (props) => {
|
|
|
429
469
|
})}
|
|
430
470
|
|
|
431
471
|
{isLoading && (
|
|
432
|
-
<div className="flex items-center justify-center
|
|
472
|
+
<div className="flex items-center justify-center mb-4">
|
|
433
473
|
<Spinner size="small" />
|
|
434
|
-
<Button
|
|
435
|
-
variant="link"
|
|
436
|
-
size="sm"
|
|
437
|
-
onClick={() => stop()}
|
|
438
|
-
className="text-(--red-9) hover:text-(--red-11)"
|
|
439
|
-
>
|
|
440
|
-
Stop
|
|
441
|
-
</Button>
|
|
442
474
|
</div>
|
|
443
475
|
)}
|
|
444
476
|
|
|
@@ -569,15 +601,30 @@ export const Chatbot: React.FC<Props> = (props) => {
|
|
|
569
601
|
/>
|
|
570
602
|
</>
|
|
571
603
|
)}
|
|
572
|
-
|
|
573
|
-
|
|
574
|
-
|
|
575
|
-
|
|
576
|
-
|
|
577
|
-
|
|
578
|
-
|
|
579
|
-
|
|
580
|
-
|
|
604
|
+
{isLoading ? (
|
|
605
|
+
<Tooltip content="Stop generating">
|
|
606
|
+
<Button
|
|
607
|
+
type="button"
|
|
608
|
+
variant="link"
|
|
609
|
+
size="xs"
|
|
610
|
+
onClick={() => stop()}
|
|
611
|
+
className="text-(--red-9) hover:text-(--red-11)"
|
|
612
|
+
>
|
|
613
|
+
<SquareIcon className="h-4 w-4 fill-current" />
|
|
614
|
+
</Button>
|
|
615
|
+
</Tooltip>
|
|
616
|
+
) : (
|
|
617
|
+
<Button
|
|
618
|
+
type="submit"
|
|
619
|
+
disabled={!input}
|
|
620
|
+
variant="outline"
|
|
621
|
+
size="xs"
|
|
622
|
+
className="text-(--slate-11)"
|
|
623
|
+
aria-label="Send message"
|
|
624
|
+
>
|
|
625
|
+
<SendHorizontalIcon className="h-4 w-4" />
|
|
626
|
+
</Button>
|
|
627
|
+
)}
|
|
581
628
|
</form>
|
|
582
629
|
</div>
|
|
583
630
|
);
|
|
@@ -64,7 +64,6 @@ type PluginFunctions = {
|
|
|
64
64
|
column_types_per_step: FieldTypesWithExternalType[];
|
|
65
65
|
python_code?: string | null;
|
|
66
66
|
sql_code?: string | null;
|
|
67
|
-
size_bytes?: number | null;
|
|
68
67
|
}>;
|
|
69
68
|
get_column_values: (req: { column: string }) => Promise<{
|
|
70
69
|
values: unknown[];
|
|
@@ -82,9 +81,11 @@ type PluginFunctions = {
|
|
|
82
81
|
}) => Promise<{
|
|
83
82
|
data: TableData<T>;
|
|
84
83
|
total_rows: number;
|
|
85
|
-
size_bytes?: number | null;
|
|
86
84
|
}>;
|
|
87
85
|
download_as: DownloadAsArgs;
|
|
86
|
+
get_size_bytes: (opts: Record<string, never>) => Promise<{
|
|
87
|
+
size_bytes?: number | null;
|
|
88
|
+
}>;
|
|
88
89
|
};
|
|
89
90
|
|
|
90
91
|
// Value is selection, but it is not currently exposed to the user
|
|
@@ -120,7 +121,6 @@ export const DataFramePlugin = createPlugin<S>("marimo-dataframe")
|
|
|
120
121
|
column_types_per_step: z.array(columnToFieldTypesSchema),
|
|
121
122
|
python_code: z.string().nullish(),
|
|
122
123
|
sql_code: z.string().nullish(),
|
|
123
|
-
size_bytes: z.number().nullish(),
|
|
124
124
|
}),
|
|
125
125
|
),
|
|
126
126
|
get_column_values: rpc.input(z.object({ column: z.string() })).output(
|
|
@@ -150,10 +150,12 @@ export const DataFramePlugin = createPlugin<S>("marimo-dataframe")
|
|
|
150
150
|
z.object({
|
|
151
151
|
data: z.union([z.string(), z.array(z.object({}).passthrough())]),
|
|
152
152
|
total_rows: z.number(),
|
|
153
|
-
size_bytes: z.number().nullish(),
|
|
154
153
|
}),
|
|
155
154
|
),
|
|
156
155
|
download_as: DownloadAsSchema,
|
|
156
|
+
get_size_bytes: rpc
|
|
157
|
+
.input(z.object({}))
|
|
158
|
+
.output(z.object({ size_bytes: z.number().nullish() })),
|
|
157
159
|
})
|
|
158
160
|
.renderer((props) => (
|
|
159
161
|
<TableProviders>
|
|
@@ -192,6 +194,7 @@ export const DataFrameComponent = memo(
|
|
|
192
194
|
get_column_values,
|
|
193
195
|
search,
|
|
194
196
|
download_as,
|
|
197
|
+
get_size_bytes,
|
|
195
198
|
host,
|
|
196
199
|
}: DataTableProps): JSX.Element => {
|
|
197
200
|
const { data, error, isPending } = useAsyncData(
|
|
@@ -207,7 +210,6 @@ export const DataFrameComponent = memo(
|
|
|
207
210
|
column_types_per_step,
|
|
208
211
|
python_code,
|
|
209
212
|
sql_code,
|
|
210
|
-
size_bytes,
|
|
211
213
|
} = data || {};
|
|
212
214
|
|
|
213
215
|
const totalColumns = field_types?.length;
|
|
@@ -327,7 +329,6 @@ export const DataFrameComponent = memo(
|
|
|
327
329
|
data={url || ""}
|
|
328
330
|
hasStableRowId={false}
|
|
329
331
|
totalRows={total_rows ?? 0}
|
|
330
|
-
sizeBytes={size_bytes ?? null}
|
|
331
332
|
totalColumns={totalColumns ?? 0}
|
|
332
333
|
maxColumns="all"
|
|
333
334
|
pageSize={pageSize}
|
|
@@ -336,6 +337,7 @@ export const DataFrameComponent = memo(
|
|
|
336
337
|
rowHeaders={row_headers || Arrays.EMPTY}
|
|
337
338
|
showDownload={showDownload}
|
|
338
339
|
download_as={download_as}
|
|
340
|
+
get_size_bytes={get_size_bytes}
|
|
339
341
|
enableSearch={false}
|
|
340
342
|
showFilters={false}
|
|
341
343
|
search={search}
|