@marimo-team/frontend 0.23.9-dev3 → 0.23.9-dev30
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-CLxcT_cM.js +1 -0
- package/dist/assets/ConnectedDataExplorerComponent-Dpgo8BF0.js +1 -0
- package/dist/assets/DeferredRequestRegistry-CNldVcrP.js +1 -0
- package/dist/assets/ImperativeModal-B3Th7k4R.js +1 -0
- package/dist/assets/JsonOutput-CusPgY2j.js +53 -0
- package/dist/assets/LazyAnyLanguageCodeMirror-DFv3yT20.js +2 -0
- package/dist/assets/MarimoErrorOutput-B_8Wgh_6.js +7 -0
- package/dist/assets/RSPContexts-CdN1NyAt.js +1 -0
- package/dist/assets/RenderHTML-Dm20tKw3.js +1 -0
- package/dist/assets/RunButton-BUq1ZIzv.js +1 -0
- package/dist/assets/add-cell-with-ai-DswIx72E.js +97 -0
- package/dist/assets/add-connection-dialog-BpPTpNHa.js +167 -0
- package/dist/assets/agent-panel-CsTSIg9p.js +287 -0
- package/dist/assets/ai-model-dropdown-BsQHdNap.js +5 -0
- package/dist/assets/any-language-editor-Cs-Qsdlp.js +1 -0
- package/dist/assets/apl-CZC-w0DM.js +1 -0
- package/dist/assets/app-config-button-I9nMXa1F.js +1 -0
- package/dist/assets/arc-D0XsJSsf.js +1 -0
- package/dist/assets/architecture-7HQA4BMR-CyeFAHwy.js +1 -0
- package/dist/assets/architectureDiagram-VXUJARFQ-1WJT-eC3.js +36 -0
- package/dist/assets/asciiarmor-Dxkbb4uS.js +1 -0
- package/dist/assets/asn1-CrA2MPaL.js +1 -0
- package/dist/assets/blockDiagram-VD42YOAC-JexHZqqE.js +122 -0
- package/dist/assets/brainfuck-B5oLVauS.js +1 -0
- package/dist/assets/c4Diagram-YG6GDRKO-Bq-DoY7t.js +10 -0
- package/dist/assets/cache-panel-CZqzacQu.js +1 -0
- package/dist/assets/cell-editor-CoGSiQv4.js +20 -0
- package/dist/assets/cell-link-DkEWt80K.js +1 -0
- package/dist/assets/cells-1XaQzJBc.js +229 -0
- package/dist/assets/channel-V1GV6hO1.js +1 -0
- package/dist/assets/chat-display-jeeyMZQK.js +1 -0
- package/dist/assets/chat-panel-B2a6auyE.js +3 -0
- package/dist/assets/chat-ui-DaAdi-2W.js +4 -0
- package/dist/assets/chunk-4BX2VUAB-Dhno12SW.js +1 -0
- package/dist/assets/chunk-55IACEB6-BRJvcREw.js +1 -0
- package/dist/assets/chunk-5FQGJX7Z-BzXnQz5s.js +113 -0
- package/dist/assets/chunk-ABZYJK2D-fbQovzbZ.js +80 -0
- package/dist/assets/chunk-ATLVNIR6-C71UReOL.js +1 -0
- package/dist/assets/chunk-B4BG7PRW-ChmO4xUA.js +165 -0
- package/dist/assets/chunk-CVBHYZKI-B6tT645I.js +1 -0
- package/dist/assets/chunk-DI55MBZ5-DaLBJUsc.js +220 -0
- package/dist/assets/chunk-EXTU4WIE-B3Lv3QWb.js +1 -0
- package/dist/assets/chunk-FMBD7UC4-CDFiCFLp.js +15 -0
- package/dist/assets/chunk-HN2XXSSU-xW6J7MXn.js +1 -0
- package/dist/assets/chunk-JA3XYJ7Z-jqUKn_dB.js +70 -0
- package/dist/assets/chunk-JZLCHNYA-xGZ72asD.js +54 -0
- package/dist/assets/chunk-MI3HLSF2-CXMqGP2w.js +32 -0
- package/dist/assets/chunk-N4CR4FBY-D8iMP1ch.js +2 -0
- package/dist/assets/chunk-QN33PNHL-Ddzf5Xc1.js +1 -0
- package/dist/assets/chunk-QXUST7PY-BUBd7EW9.js +7 -0
- package/dist/assets/chunk-QZHKN3VN-37WEuSLJ.js +1 -0
- package/dist/assets/chunk-S3R3BYOJ-7UJSqSFb.js +2 -0
- package/dist/assets/chunk-TZMSLE5B-B7Xjx897.js +1 -0
- package/dist/assets/classDiagram-2ON5EDUG-C8jlAFC-.js +1 -0
- package/dist/assets/classDiagram-v2-WZHVMYZB-DYST6eBL.js +1 -0
- package/dist/assets/clike-npv7NBwP.js +1 -0
- package/dist/assets/clojure-D60XavrX.js +1 -0
- package/dist/assets/cmake-CrWsGXcU.js +1 -0
- package/dist/assets/cobol-CZosvDFE.js +1 -0
- package/dist/assets/code-block-37QAKDTI-BZVOQdyl.js +2 -0
- package/dist/assets/coffeescript-DQGIz3iX.js +1 -0
- package/dist/assets/column-preview-DVkTxMGI.js +1 -0
- package/dist/assets/command-KARR7KMq.js +1 -0
- package/dist/assets/command-palette-BAlVQIwu.js +1 -0
- package/dist/assets/common-DPbBXxzB.js +1 -0
- package/dist/assets/commonlisp-DrWSVXOx.js +1 -0
- package/dist/assets/components-CJAJOpwt.js +1 -0
- package/dist/assets/components-vyxhSeYE.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-CgMkzBzk.js +1 -0
- package/dist/assets/crystal-CMu2RgP7.js +1 -0
- package/dist/assets/css-OVjTGRm9.js +1 -0
- package/dist/assets/cypher-C4I5nX3I.js +1 -0
- package/dist/assets/d-B_OAkSA3.js +1 -0
- package/dist/assets/dagre-6UL2VRFP-rclmYCNC.js +4 -0
- package/dist/assets/data-grid-overlay-editor-CO7vLLX5.js +1 -0
- package/dist/assets/datasource-CLXUP6g0.js +3 -0
- package/dist/assets/dates-CTxr0EqQ.js +1 -0
- package/dist/assets/dependency-graph-panel-B70NP6bp.js +5 -0
- package/dist/assets/diagram-PSM6KHXK-Dr5x-oaJ.js +24 -0
- package/dist/assets/diagram-QEK2KX5R-Cyino8Ci.js +43 -0
- package/dist/assets/diagram-S2PKOQOG-DYLuU52t.js +24 -0
- package/dist/assets/diff-f-qA4U7T.js +1 -0
- package/dist/assets/dist-B2-3vH3I.js +1 -0
- package/dist/assets/dist-B3r3gs4u.js +1 -0
- package/dist/assets/dist-B7U5jPfs.js +1 -0
- package/dist/assets/dist-BTDGJ6yw.js +7 -0
- package/dist/assets/dist-BYYXrYaA.js +1 -0
- package/dist/assets/dist-Bc225YxE.js +1 -0
- package/dist/assets/dist-CAIBlJtJ.js +1 -0
- package/dist/assets/dist-CBSMxaO_.js +6 -0
- package/dist/assets/dist-CGC-UAcL.js +1 -0
- package/dist/assets/dist-CNghxh0Q.js +1 -0
- package/dist/assets/dist-CO_N76Iz.js +1 -0
- package/dist/assets/dist-CSowihAs.js +1 -0
- package/dist/assets/dist-C_k5-SEy.js +1 -0
- package/dist/assets/dist-CcoNWYux.js +1 -0
- package/dist/assets/dist-CiOPfbN_.js +1 -0
- package/dist/assets/dist-Cofj3PRM.js +1 -0
- package/dist/assets/dist-CpTFpfm_.js +1 -0
- package/dist/assets/dist-CqEym3Sr.js +1 -0
- package/dist/assets/dist-CtCHoDJA.js +1 -0
- package/dist/assets/dist-D6HkmGB2.js +1 -0
- package/dist/assets/dist-D86l0QaP.js +1 -0
- package/dist/assets/dist-DB3ebLb3.js +1 -0
- package/dist/assets/dist-DYXeLJlk.js +1 -0
- package/dist/assets/dist-Dr8mWwQ_.js +1 -0
- package/dist/assets/dist-Dx65VI0Y.js +1 -0
- package/dist/assets/dist-FSgOAwAH.js +1 -0
- package/dist/assets/dist-K7UrYXpJ.js +1 -0
- package/dist/assets/dist-_fyDen1v.js +1 -0
- package/dist/assets/dist-cS6yvaqe.js +1 -0
- package/dist/assets/dist-fQYV9WTb.js +1 -0
- package/dist/assets/dockerfile-CrSl2ewL.js +1 -0
- package/dist/assets/documentation-panel-o-viwf0J.js +1 -0
- package/dist/assets/download-qESwLUZl.js +9 -0
- package/dist/assets/dtd-DWRTME-w.js +1 -0
- package/dist/assets/dylan-DnEm_ULG.js +1 -0
- package/dist/assets/ecl-Dbf1A5nG.js +1 -0
- package/dist/assets/edit-page-kaIkUPYh.js +9 -0
- package/dist/assets/eiffel-Xj76_r0X.js +1 -0
- package/dist/assets/elm-nUwO24NA.js +1 -0
- package/dist/assets/erDiagram-Q2GNP2WA-FdS4NKUh.js +60 -0
- package/dist/assets/erlang-CFVqMiR0.js +1 -0
- package/dist/assets/error-banner-LdWZDbqd.js +1 -0
- package/dist/assets/error-panel-69wfyEqu.js +1 -0
- package/dist/assets/es-DGgq-Wes.js +5 -0
- package/dist/assets/esm-CqWdmSnV.js +1 -0
- package/dist/assets/esm-CwPtnMeh.js +1 -0
- package/dist/assets/factor-MWFhpc0o.js +1 -0
- package/dist/assets/factor-mJPTAioV.js +1 -0
- package/dist/assets/field-zLmMOSA4.js +1 -0
- package/dist/assets/file-explorer-panel-DEiH3PAy.js +26 -0
- package/dist/assets/file-icons-nRpX80xD.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-BWfYKjEI.js +1 -0
- package/dist/assets/flowDiagram-NV44I4VS-DO4w8anv.js +162 -0
- package/dist/assets/focus-DCbL1KSz.js +1 -0
- package/dist/assets/form-DdWBrfFm.js +2 -0
- package/dist/assets/formats-b7Sf6DAK.js +1 -0
- package/dist/assets/formatting-3l1CoS7X.js +1 -0
- package/dist/assets/forth-DBQr6L61.js +1 -0
- package/dist/assets/fortran-BkjqlXUL.js +1 -0
- package/dist/assets/gallery-page-7ltBHWVR.js +1 -0
- package/dist/assets/ganttDiagram-JELNMOA3-Df-MBIrj.js +267 -0
- package/dist/assets/gas-BNFtcdO9.js +1 -0
- package/dist/assets/gherkin-BrOMWqkN.js +1 -0
- package/dist/assets/gitGraph-G5XIXVHT-BAQx1hNd.js +1 -0
- package/dist/assets/gitGraphDiagram-V2S2FVAM-fv2cmbLH.js +65 -0
- package/dist/assets/glide-data-editor-CjCd44bZ.js +132 -0
- package/dist/assets/globals-Dd7eo1nD.js +1 -0
- package/dist/assets/groovy-DuCnwFRS.js +1 -0
- package/dist/assets/haskell-BD39942g.js +1 -0
- package/dist/assets/haxe-CXsKoap0.js +1 -0
- package/dist/assets/home-page-B-GufMb4.js +4 -0
- package/dist/assets/hooks-DY7Iab_9.js +1 -0
- package/dist/assets/html-to-image-7hWS7hJz.js +2 -0
- package/dist/assets/idl-D7hb6rI1.js +1 -0
- package/dist/assets/index-BWVD6RQh.js +38 -0
- package/dist/assets/index-DAfPvCnw.css +2 -0
- package/dist/assets/info-VBDWY6EO-Cw9vVNQD.js +1 -0
- package/dist/assets/infoDiagram-HS3SLOUP-CpBkxLyN.js +2 -0
- package/dist/assets/input-C3Hrdlqq.js +1 -0
- package/dist/assets/javascript-1S1_-Xac.js +1 -0
- package/dist/assets/journeyDiagram-XKPGCS4Q-C_cdVaga.js +139 -0
- package/dist/assets/julia-CbOUdU45.js +1 -0
- package/dist/assets/kanban-definition-3W4ZIXB7-CLpEm5s3.js +89 -0
- package/dist/assets/katex-BuYoGw8D.js +1 -0
- package/dist/assets/kiosk-mode-JQPKtmIC.js +1 -0
- package/dist/assets/layout-c2Tt9BRr.js +9 -0
- package/dist/assets/line-ortW3H6T.js +1 -0
- package/dist/assets/linear-CIVE7jyt.js +1 -0
- package/dist/assets/links-DguLoFik.js +1 -0
- package/dist/assets/livescript-4YbxVKEy.js +1 -0
- package/dist/assets/logs-panel-BP3lKR0p.js +1 -0
- package/dist/assets/loro_wasm_bg-Ci19hd4D.js +1 -0
- package/dist/assets/lua-Dp2B-Joo.js +1 -0
- package/dist/assets/markdown-renderer-BzFpW89-.js +5 -0
- package/dist/assets/mathematica-BaSnKpgq.js +1 -0
- package/dist/assets/mbox-JZJfXD_G.js +1 -0
- package/dist/assets/mermaid-4DMBBIKO-BV51xhvi.js +1 -0
- package/dist/assets/mermaid-JS_fM0GY.js +11 -0
- package/dist/assets/mermaid-parser.core-CMygPhv_.js +4 -0
- package/dist/assets/mhchem-DSE1tfes.js +1 -0
- package/dist/assets/mindmap-definition-VGOIOE7T-mbWtJhR6.js +68 -0
- package/dist/assets/mirc-BZe50pjl.js +1 -0
- package/dist/assets/mllike-Bgkhf51-.js +1 -0
- package/dist/assets/modelica-BzrnHsaM.js +1 -0
- package/dist/assets/mscgen-C7fmiScS.js +1 -0
- package/dist/assets/mumps-DYao3Wbn.js +1 -0
- package/dist/assets/name-cell-input-BGUk0-hx.js +1 -0
- package/dist/assets/nsis-BV9URIq2.js +1 -0
- package/dist/assets/nsis-CDylpiaC.js +1 -0
- package/dist/assets/ntriples-CCTjcLNo.js +1 -0
- package/dist/assets/number-overlay-editor-CHaQ6o4_.js +9 -0
- package/dist/assets/octave-CalSSDIP.js +1 -0
- package/dist/assets/ordinal-RiUP-mHf.js +1 -0
- package/dist/assets/outline-panel-DF5K6QKx.js +1 -0
- package/dist/assets/oz-BwBvNNj4.js +1 -0
- package/dist/assets/packages-panel-DW3iGKmX.js +1 -0
- package/dist/assets/packet-DYOGHKS2-BXa5LrXK.js +1 -0
- package/dist/assets/panels-BBeYDaGT.js +1 -0
- package/dist/assets/pascal-VtYjd8tX.js +1 -0
- package/dist/assets/pathUtils-CJjndqMI.js +1 -0
- package/dist/assets/perl-CuiQHSod.js +1 -0
- package/dist/assets/pie-VRWISCQL-BpZiOBLl.js +1 -0
- package/dist/assets/pieDiagram-ADFJNKIX-ouQhtndl.js +30 -0
- package/dist/assets/pig-CIHZG4Z9.js +1 -0
- package/dist/assets/powershell-CI2Wos2z.js +1 -0
- package/dist/assets/precisionRound-Cl9k9ZmS.js +1 -0
- package/dist/assets/process-output-6n1ugWwo.js +1 -0
- package/dist/assets/properties-CBOFbPgT.js +1 -0
- package/dist/assets/protobuf-CdcXLd43.js +1 -0
- package/dist/assets/pug-BXVTM5jr.js +1 -0
- package/dist/assets/pug-DJHP9Svh.js +1 -0
- package/dist/assets/puppet-B2nxuZc5.js +1 -0
- package/dist/assets/python-VpIaVd-6.js +1 -0
- package/dist/assets/q-CamvlcK6.js +1 -0
- package/dist/assets/quadrantDiagram-AYHSOK5B-NRkmQ1sP.js +7 -0
- package/dist/assets/r-CgsrYWFj.js +1 -0
- package/dist/assets/radar-ZZBFDIW7-CB-lQl_C.js +1 -0
- package/dist/assets/radio-group-BarBLGia.js +1 -0
- package/dist/assets/react-vega-Bzl9LfSR.js +188 -0
- package/dist/assets/react-vega-CFabbyYN.js +1 -0
- package/dist/assets/readonly-python-code-D8e6pAzl.js +1 -0
- package/dist/assets/renderShortcut-CzUfgpdJ.js +1 -0
- package/dist/assets/request-registry-Gm-nOP6a.js +1 -0
- package/dist/assets/requirementDiagram-UZGBJVZJ-C0LTiV9S.js +64 -0
- package/dist/assets/reveal-component-xHcsF-r9.js +1069 -0
- package/dist/assets/rpm-DBux1aMG.js +1 -0
- package/dist/assets/ruby-BWHIAyVi.js +1 -0
- package/dist/assets/run-page-CzaWbsQO.js +1 -0
- package/dist/assets/sankeyDiagram-TZEHDZUN-CR2AycvD.js +10 -0
- package/dist/assets/sas-DJpj3tMb.js +1 -0
- package/dist/assets/scheme-DF-J69qP.js +1 -0
- package/dist/assets/scratchpad-panel-k5ZJMWG3.js +1 -0
- package/dist/assets/secrets-panel-B3E_Dkep.js +1 -0
- package/dist/assets/sequenceDiagram-WL72ISMW-CtF8-7iq.js +145 -0
- package/dist/assets/session-panel-DHZylfH3.js +1 -0
- package/dist/assets/share-DMwTZOTH.js +1 -0
- package/dist/assets/shell-m-RSMeeH.js +1 -0
- package/dist/assets/sieve-CtzQvaig.js +1 -0
- package/dist/assets/smalltalk-ClFvBgAI.js +1 -0
- package/dist/assets/snippets-panel-B33qfYgV.js +1 -0
- package/dist/assets/sparql-icVR0QFW.js +1 -0
- package/dist/assets/spec-CPQR_o92.js +1 -0
- package/dist/assets/src-CyeQdfB6.js +1 -0
- package/dist/assets/state-3SH6NVgL.js +1 -0
- package/dist/assets/state-BA_U3J4G.js +3 -0
- package/dist/assets/state-BGDrw26V.js +1 -0
- package/dist/assets/state-DTislnZA.js +1 -0
- package/dist/assets/stateDiagram-FKZM4ZOC-R47bQmIs.js +1 -0
- package/dist/assets/stateDiagram-v2-4FDKWEC3-sSKQU37N.js +1 -0
- package/dist/assets/step-Ca7ZnceH.js +1 -0
- package/dist/assets/stex-Ccczot4V.js +1 -0
- package/dist/assets/stylus-TkCXytG7.js +1 -0
- package/dist/assets/swift-CBYBwE0m.js +1 -0
- package/dist/assets/swiper-component-Dgt-sBCT.js +1 -0
- package/dist/assets/switch-YcZLs0mS.js +1 -0
- package/dist/assets/tcl-DvyBVTw2.js +1 -0
- package/dist/assets/terminal-S5iF6Td7.js +62 -0
- package/dist/assets/textarea-CTiWTiw-.js +1 -0
- package/dist/assets/textile-DA3WvzuI.js +1 -0
- package/dist/assets/time-Dfh8bLaf.js +1 -0
- package/dist/assets/timeline-definition-IT6M3QCI-qZnC-_po.js +61 -0
- package/dist/assets/toml-BJa3ckRR.js +1 -0
- package/dist/assets/tracing-CW1nKi50.js +1 -0
- package/dist/assets/tracing-panel-BY38SOBp.js +2 -0
- package/dist/assets/tree-actions-BM_EJr3E.js +1 -0
- package/dist/assets/treemap-GDKQZRPO-C2f4_yBW.js +1 -0
- package/dist/assets/troff-CqZSdBAp.js +1 -0
- package/dist/assets/ttcn-BouEBguh.js +1 -0
- package/dist/assets/ttcn-cfg-C1whpGsE.js +1 -0
- package/dist/assets/turtle-DQ8l-awL.js +1 -0
- package/dist/assets/useBoolean-oqDq5zze.js +1 -0
- package/dist/assets/useCellActionButton-BVzdWM6Q.js +1 -0
- package/dist/assets/useDateFormatter-ICIDGgHf.js +1 -0
- package/dist/assets/useDeleteCell-CnlX_9s7.js +1 -0
- package/dist/assets/useDependencyPanelTab-LJUqXtXa.js +1 -0
- package/dist/assets/useHotkey-BtqYcnxQ.js +1 -0
- package/dist/assets/useInstallPackage-DUF4IRRI.js +1 -0
- package/dist/assets/useNotebookActions-C3H0OkTO.js +4 -0
- package/dist/assets/useNumberFormatter-ByUv-u9o.js +1 -0
- package/dist/assets/usePress-DQ_tAz5W.js +7 -0
- package/dist/assets/useRunCells-BJP5VHUs.js +1 -0
- package/dist/assets/useSplitCell-DwfXLRQ8.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-B7wOdn6U.js +1 -0
- package/dist/assets/vbscript-DvH455rJ.js +1 -0
- package/dist/assets/vega-component-BsorOyX7.js +1 -0
- package/dist/assets/vega-loader.browser-C8wT63Va.js +6 -0
- package/dist/assets/velocity-B6C6O90i.js +1 -0
- package/dist/assets/verilog-JbcxpuFW.js +1 -0
- package/dist/assets/vhdl-SEFTp5Re.js +1 -0
- package/dist/assets/webidl-ChYZayPm.js +1 -0
- package/dist/assets/write-secret-modal-DEx_mRHR.js +1 -0
- package/dist/assets/xquery-DWwllqyg.js +1 -0
- package/dist/assets/xychartDiagram-PRI3JC2R-Ul_9KMcM.js +7 -0
- package/dist/assets/yacas-DQRdrpIp.js +1 -0
- package/dist/assets/z80-CGBxwDW7.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-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/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/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/src-CvyFXpBy.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-B5A-4CCj.js} +0 -0
- /package/dist/assets/{Inputs-COvM_tLq.js → Inputs-BG_nVZPt.js} +0 -0
- /package/dist/assets/{Plot-BDBiXfv_.js → Plot-CoEOwQq-.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-4hxG7HNk.js} +0 -0
- /package/dist/assets/{array-DdrmtJsl.js → array-D5VxClQs.js} +0 -0
- /package/dist/assets/{asciiarmor-CK-aFa78.js → asciiarmor-Dv_174xi.js} +0 -0
- /package/dist/assets/{asn1-DWJdxrMP.js → asn1-iiMvplI8.js} +0 -0
- /package/dist/assets/{asterisk-DmqsRS7E.js → asterisk-CC3QRUnf.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-C1zBqC_V.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-DUo5vZ2r.js} +0 -0
- /package/dist/assets/{chunk-B2363JML-BMBEdPpn.js → chunk-B2363JML-BBEseLU0.js} +0 -0
- /package/dist/assets/{chunk-DR5Q36YT-DKTVLAfY.js → chunk-DR5Q36YT-C0WIZcJM.js} +0 -0
- /package/dist/assets/{chunk-FRFDVMJY-CfFB3K1V.js → chunk-FRFDVMJY-CXpDqtzE.js} +0 -0
- /package/dist/assets/{chunk-PL6DKKU2-B33xUOa0.js → chunk-PL6DKKU2-CdWr1t_8.js} +0 -0
- /package/dist/assets/{chunk-SJTYNZTY-8WPtvsjT.js → chunk-SJTYNZTY-SWJVmNtW.js} +0 -0
- /package/dist/assets/{chunk-TQ3KTPDO-D2AjvUV_.js → chunk-TQ3KTPDO-NHSLONf7.js} +0 -0
- /package/dist/assets/{chunk-UMXZTB3W-BCNtLoey.js → chunk-UMXZTB3W-Ct179y25.js} +0 -0
- /package/dist/assets/{clear-button-pxtY_gQU.js → clear-button-CIwzVocs.js} +0 -0
- /package/dist/assets/{click-outside-container-C9uindjY.js → click-outside-container-Bx6OOW4y.js} +0 -0
- /package/dist/assets/{clike-5SQqmvx2.js → clike-DgscWMor.js} +0 -0
- /package/dist/assets/{clojure-B0kIwyv8.js → clojure-BHbbYwIQ.js} +0 -0
- /package/dist/assets/{cmake-CLXeINvH.js → cmake-DLR6lpqL.js} +0 -0
- /package/dist/assets/{cobol-C9SsG--s.js → cobol-BCxTxy3w.js} +0 -0
- /package/dist/assets/{coffeescript-UIQG6RnU.js → coffeescript-CpA2P5vm.js} +0 -0
- /package/dist/assets/{colors-CDxbWdyG.js → colors-CWfEs9Oi.js} +0 -0
- /package/dist/assets/{common-keywords-Bf68gXm2.js → common-keywords-0dB1lgek.js} +0 -0
- /package/dist/assets/{commonlisp-BBPumpJY.js → commonlisp-IOtLAQXJ.js} +0 -0
- /package/dist/assets/{copy-Ch48HVPK.js → copy-LK56fFow.js} +0 -0
- /package/dist/assets/{crystal-CGN1wsuY.js → crystal-D5D6_kGA.js} +0 -0
- /package/dist/assets/{css-aQ-Krb7T.js → css-DOb8-BDy.js} +0 -0
- /package/dist/assets/{cypher-DEE4_Yec.js → cypher-DLF7i4IG.js} +0 -0
- /package/dist/assets/{cytoscape.esm-DuXIsNbY.js → cytoscape.esm-CuwfIk-V.js} +0 -0
- /package/dist/assets/{d-CgJ8N-gL.js → d-ByNdxjrk.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-DgsriQcn.js} +0 -0
- /package/dist/assets/{dist-DP9Si-4r.js → dist-4ni0fia5.js} +0 -0
- /package/dist/assets/{dist-BU26XwgJ.js → dist-B1U1kGCR.js} +0 -0
- /package/dist/assets/{dist-DjGavUj4.js → dist-B6ehDvA-.js} +0 -0
- /package/dist/assets/{dist-DQ3_8QJg.js → dist-BA8xhrl2.js} +0 -0
- /package/dist/assets/{dist-DkA__6UI.js → dist-CPczQFlJ.js} +0 -0
- /package/dist/assets/{dist-COs9gIu5.js → dist-ChF5Ln9c.js} +0 -0
- /package/dist/assets/{dist-CTvZbFwy.js → dist-CjBmWBr2.js} +0 -0
- /package/dist/assets/{dist-FS1xQUNb.js → dist-D8MaDlGc.js} +0 -0
- /package/dist/assets/{dist-DGhKKgfN.js → dist-DviQ3W6h.js} +0 -0
- /package/dist/assets/{dist-EbJ2Bafg.js → dist-WcxjmQmQ.js} +0 -0
- /package/dist/assets/{dist-Scx61XLd.js → dist-fhXsH3fb.js} +0 -0
- /package/dist/assets/{dist-CyKkoCYJ.js → dist-oSdg9XA7.js} +0 -0
- /package/dist/assets/{dist-Bm0v4xuz.js → dist-qBfIhsAs.js} +0 -0
- /package/dist/assets/{dtd-DtwMcoo9.js → dtd-BY21shY3.js} +0 -0
- /package/dist/assets/{duckdb-keywords-BWKLsQSd.js → duckdb-keywords-DH8yhwVC.js} +0 -0
- /package/dist/assets/{dylan-Be6i1K-V.js → dylan-D_hF5J0y.js} +0 -0
- /package/dist/assets/{ebnf-dezZofVm.js → ebnf-D73UE5Hl.js} +0 -0
- /package/dist/assets/{ecl-D5tlhe8s.js → ecl-C1ORA0cg.js} +0 -0
- /package/dist/assets/{eiffel-8SQWO4xP.js → eiffel-1fe3g8c_.js} +0 -0
- /package/dist/assets/{elm-CtGe_7Jw.js → elm-hjWurFzL.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-Bp4wxA5O.js} +0 -0
- /package/dist/assets/{errors-iwK4b4VF.js → errors-vr57w7Ul.js} +0 -0
- /package/dist/assets/{esm-CX-gNDKf.js → esm-DM72gy9Q.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-1tMcz7c0.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-5O98d424.js} +0 -0
- /package/dist/assets/{fortran-B28t9xoj.js → fortran-BIuAFxQ8.js} +0 -0
- /package/dist/assets/{gas-BSiJHAcz.js → gas-CHHhShkY.js} +0 -0
- /package/dist/assets/{gherkin-1QurHPOF.js → gherkin-DIjcYYBT.js} +0 -0
- /package/dist/assets/{github-raQvpeuZ.js → github-BKS_2Qwn.js} +0 -0
- /package/dist/assets/{groovy-DFOLwJLv.js → groovy-BYU3Z-yz.js} +0 -0
- /package/dist/assets/{haskell-CUN2jxPH.js → haskell-CjOVOYhk.js} +0 -0
- /package/dist/assets/{haxe-BYzKptPQ.js → haxe-Cb_U41Kf.js} +0 -0
- /package/dist/assets/{house-D2ldnAB9.js → house-mGK3v0Mm.js} +0 -0
- /package/dist/assets/{http-Ms617AZI.js → http-DTsrgwMt.js} +0 -0
- /package/dist/assets/{icons-8tfAri2V.js → icons-Ol38nIbL.js} +0 -0
- /package/dist/assets/{idl-cdmrQY5J.js → idl-XfUB5VqU.js} +0 -0
- /package/dist/assets/{image-BIibSXT6.js → image-DQHXdEQn.js} +0 -0
- /package/dist/assets/{init-DiAYA_Co.js → init-BYCsRZEq.js} +0 -0
- /package/dist/assets/{isValid-DdlR4-BY.js → isValid-CklTTytn.js} +0 -0
- /package/dist/assets/{javascript-l5LYdpfx.js → javascript-BZ9iuJe9.js} +0 -0
- /package/dist/assets/{julia-DxiTohY8.js → julia-ZgWUbR6s.js} +0 -0
- /package/dist/assets/{katex-CgXtp7UB.js → katex-BNYG1in3.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-PvHqMAnA.js} +0 -0
- /package/dist/assets/{loro_wasm_bg-C5TJxMR5.js → loro_wasm_bg-Z5Iceaci.js} +0 -0
- /package/dist/assets/{lua-rVV1vLen.js → lua-BAkgehCh.js} +0 -0
- /package/dist/assets/{marimo-icons-CUuBQ0ae.js → marimo-icons-CcDNGIRM.js} +0 -0
- /package/dist/assets/{math-CS811RUM.js → math-D-qpUWKO.js} +0 -0
- /package/dist/assets/{mathematica-DktJ0aJB.js → mathematica-sYPoESCW.js} +0 -0
- /package/dist/assets/{mbox-Ch6IVA7h.js → mbox-BFVpgB4i.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-DAwdMlc7.js} +0 -0
- /package/dist/assets/{mllike-CB0tp4Bz.js → mllike-CNENYbun.js} +0 -0
- /package/dist/assets/{modelica-DQGg_xsi.js → modelica-FtpuFG3d.js} +0 -0
- /package/dist/assets/{mscgen-vDSxnAXy.js → mscgen-BZpZ1eAc.js} +0 -0
- /package/dist/assets/{multi-icon-NVkxesVZ.js → multi-icon-aZG-rdCp.js} +0 -0
- /package/dist/assets/{mumps-BzlVzIzl.js → mumps-BM8g2rR9.js} +0 -0
- /package/dist/assets/{nginx-CNtYBWy9.js → nginx-CREUN6EW.js} +0 -0
- /package/dist/assets/{node-sql-parser-BvUFblwL.js → node-sql-parser-fWuidk6P.js} +0 -0
- /package/dist/assets/{ntriples-BndMB6TK.js → ntriples-Dpum4Lhl.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-C-8skAyy.js} +0 -0
- /package/dist/assets/{oz-DbZmNL9y.js → oz-C9dNiWs3.js} +0 -0
- /package/dist/assets/{package-B8oXOUM-.js → package-Tv6ztuzw.js} +0 -0
- /package/dist/assets/{panel-context-DQWeG2KK.js → panel-context-C3ham7ZV.js} +0 -0
- /package/dist/assets/{pascal-DhE1sEjD.js → pascal-OtDoyUlT.js} +0 -0
- /package/dist/assets/{path-D1tAOolS.js → path-_EHCEa2c.js} +0 -0
- /package/dist/assets/{paths-SFhaqGlE.js → paths-D5zczhUD.js} +0 -0
- /package/dist/assets/{perl-BOZHK4Y3.js → perl-Bq6zPLry.js} +0 -0
- /package/dist/assets/{pig-eswHTOE9.js → pig-CzHJ3vXa.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-CPgLwhmC.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-Kfp4iofx.js} +0 -0
- /package/dist/assets/{protobuf-BAsuCsmK.js → protobuf-BtodseUb.js} +0 -0
- /package/dist/assets/{puppet-DUYPK8CV.js → puppet-DqMZ-3jb.js} +0 -0
- /package/dist/assets/{purify.es-DvRMX74T.js → purify.es-B9KxLTTS.js} +0 -0
- /package/dist/assets/{python-UQl3_T6H.js → python-Du1sm3Dz.js} +0 -0
- /package/dist/assets/{q-CnvA_jxT.js → q-mTJjDbkl.js} +0 -0
- /package/dist/assets/{r-fM1OLzJB.js → r-CiWGt8bY.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/{requests-DqJEWJ-Q.js → requests-Bm3bohzL.js} +0 -0
- /package/dist/assets/{rotate-ccw-DoQtGgvU.js → rotate-ccw-CNsAb2VZ.js} +0 -0
- /package/dist/assets/{rpm-D62D_dq6.js → rpm-DoWl8uQ-.js} +0 -0
- /package/dist/assets/{ruby-DemvBD0m.js → ruby-EPWn7HjP.js} +0 -0
- /package/dist/assets/{runs-Cn-NiTzH.js → runs-_nm7RTvJ.js} +0 -0
- /package/dist/assets/{sas-CZjYQi4h.js → sas-C49N66K9.js} +0 -0
- /package/dist/assets/{save-DZ5aail6.js → save-Clg5dMoP.js} +0 -0
- /package/dist/assets/{scheme-nPNaP0Qp.js → scheme-BKBMeaMf.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-B3Qif7WE.js} +0 -0
- /package/dist/assets/{sieve-DXFUN4C7.js → sieve-D2oOzUQe.js} +0 -0
- /package/dist/assets/{simple-mode-CZ1ts7NY.js → simple-mode-awvuWmjh.js} +0 -0
- /package/dist/assets/{smalltalk-DwXXlSAY.js → smalltalk-D2JNyQE_.js} +0 -0
- /package/dist/assets/{solr-DndbfGC6.js → solr-DD6Hdy4w.js} +0 -0
- /package/dist/assets/{sparkles-CC9Bko6a.js → sparkles-lWUAsPhp.js} +0 -0
- /package/dist/assets/{sparql-CgejAdiJ.js → sparql-B_E2GW41.js} +0 -0
- /package/dist/assets/{spinner-UuZAUjoP.js → spinner-Bhir8k53.js} +0 -0
- /package/dist/assets/{spreadsheet-DHoeoJHd.js → spreadsheet-DQc2JQ5m.js} +0 -0
- /package/dist/assets/{sql-DzyjqiRG.js → sql-Cj5Wcvsd.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-faGJHwXX.js} +0 -0
- /package/dist/assets/{stex-lcoTi-7o.js → stex-BGrE-q7N.js} +0 -0
- /package/dist/assets/{stylus-CslB9TS3.js → stylus-R6o8NrsG.js} +0 -0
- /package/dist/assets/{swift-5t7SQPo8.js → swift-Dbh-hbmH.js} +0 -0
- /package/dist/assets/{table-DQE9hQzM.js → table-BGPSHfig.js} +0 -0
- /package/dist/assets/{tcl-Ddpe8YBc.js → tcl-B7hCCUdg.js} +0 -0
- /package/dist/assets/{textile-D_Db33mq.js → textile-3T2abjma.js} +0 -0
- /package/dist/assets/{tiddlywiki-Laz7iVQn.js → tiddlywiki-Co__osNU.js} +0 -0
- /package/dist/assets/{tiki-Dd2_LAYu.js → tiki-CfCZczlo.js} +0 -0
- /package/dist/assets/{timer-B6DpdVnC.js → timer-BgiWPhV9.js} +0 -0
- /package/dist/assets/{toml-CgkLq_pv.js → toml-BfSTXCbK.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-F5PoC_M0.js} +0 -0
- /package/dist/assets/{triangle-alert-CJ0ZIqcz.js → triangle-alert-D2p96PEF.js} +0 -0
- /package/dist/assets/{troff-6nX9d05T.js → troff-TmwTwfFH.js} +0 -0
- /package/dist/assets/{ttcn-Dd4SMoHT.js → ttcn-BptQ-efU.js} +0 -0
- /package/dist/assets/{ttcn-cfg-ByNDYolW.js → ttcn-cfg-BJSeQh2j.js} +0 -0
- /package/dist/assets/{turtle-LDF8uFGv.js → turtle-NWQZPdQh.js} +0 -0
- /package/dist/assets/{types-BYwxXaSY.js → types-W8WWuumF.js} +0 -0
- /package/dist/assets/{types-DZmRsGZN.js → types-iYXk7c05.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-Bc-mr0KL.js} +0 -0
- /package/dist/assets/{uuid-D_zLHhNi.js → uuid-e9lSomwA.js} +0 -0
- /package/dist/assets/{vb-DaLxM60T.js → vb-5MAVubtN.js} +0 -0
- /package/dist/assets/{vbscript-CwitZ57u.js → vbscript-C3wI-prb.js} +0 -0
- /package/dist/assets/{velocity-D6bc4mrP.js → velocity-BZ0SsVqc.js} +0 -0
- /package/dist/assets/{verilog-CIyPdzYJ.js → verilog-sCLfsuOk.js} +0 -0
- /package/dist/assets/{vhdl-DfyhlM4K.js → vhdl-D8-XDERr.js} +0 -0
- /package/dist/assets/{web-vitals-BaMazlva.js → web-vitals-CJ8ovao_.js} +0 -0
- /package/dist/assets/{webidl-C23hA3Le.js → webidl-C2DK9LNJ.js} +0 -0
- /package/dist/assets/{workflow-CgnDnnoN.js → workflow-Bm8qF7yj.js} +0 -0
- /package/dist/assets/{ws-Cb8IUKlU.js → ws-YSapF1PN.js} +0 -0
- /package/dist/assets/{xquery-BAVQXrAf.js → xquery-Db3HYO3C.js} +0 -0
- /package/dist/assets/{yacas-DrybVty2.js → yacas-DhfMSinV.js} +0 -0
- /package/dist/assets/{youtube-3lRHw8NU.js → youtube-CbdpN8oL.js} +0 -0
- /package/dist/assets/{z80-8KI6AMtY.js → z80-CH-vqbta.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}
|