@marimo-team/frontend 0.23.7-dev2 → 0.23.7-dev20
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-CO_unhk0.js → CellStatus-CSvTla4f.js} +1 -1
- package/dist/assets/{ConnectedDataExplorerComponent-k8s9vETJ.js → ConnectedDataExplorerComponent-BEDxXsa0.js} +1 -1
- package/dist/assets/{ErrorBoundary-DzYV_VeY.js → ErrorBoundary-DyYDV0HI.js} +1 -1
- package/dist/assets/{ImperativeModal-D7lQ0Q7_.js → ImperativeModal-CvOOClOZ.js} +1 -1
- package/dist/assets/{JsonOutput-BalWi8Qq.js → JsonOutput-JTrlf9N4.js} +12 -12
- package/dist/assets/LazyAnyLanguageCodeMirror-CXbgDeVw.js +2 -0
- package/dist/assets/{MarimoErrorOutput-1q6qtvxi.js → MarimoErrorOutput-hJIljqUO.js} +2 -2
- package/dist/assets/{RSPContexts-CINae4Gg.js → RSPContexts-eRifaAal.js} +1 -1
- package/dist/assets/{RenderHTML-DkEHxB1r.js → RenderHTML-a81krr2r.js} +1 -1
- package/dist/assets/{RunButton-CJsJsGj-.js → RunButton-Cw4OpYze.js} +1 -1
- package/dist/assets/__vite-browser-external-DuZehUbK.js +1 -0
- package/dist/assets/__vite-browser-external-Jpm67kL1.js +1 -0
- package/dist/assets/{add-cell-with-ai-D5JeNTNV.js → add-cell-with-ai-DfJY2bip.js} +16 -16
- package/dist/assets/{add-connection-dialog-Dh2rjP3o.js → add-connection-dialog-Dr86oIaM.js} +1 -1
- package/dist/assets/{agent-panel-CiOQnIC9.js → agent-panel-BqqMglHo.js} +3 -3
- package/dist/assets/{ai-model-dropdown-B-9yxYM4.js → ai-model-dropdown-BtI9PY1X.js} +4 -4
- package/dist/assets/{alert-dialog-BGBdrcqJ.js → alert-dialog-BqFLkbUc.js} +1 -1
- package/dist/assets/{any-language-editor-C9DM60EN.js → any-language-editor-Bu4hSl-d.js} +1 -1
- package/dist/assets/apl-CaYjM5u2.js +1 -0
- package/dist/assets/{app-config-button-BOc_z0uX.js → app-config-button-BE6k0AGO.js} +1 -1
- package/dist/assets/{arc-ONRhTAm2.js → arc-D1owqr0z.js} +1 -1
- package/dist/assets/{architecture-7HQA4BMR-B8Ryu75w.js → architecture-7HQA4BMR-BzXB-NJy.js} +1 -1
- package/dist/assets/{architectureDiagram-VXUJARFQ-JNogHSZh.js → architectureDiagram-VXUJARFQ-D6wy26r_.js} +1 -1
- package/dist/assets/asciiarmor-D2cJUKTq.js +1 -0
- package/dist/assets/asn1-CZDBKivQ.js +1 -0
- package/dist/assets/{blockDiagram-VD42YOAC-Dy-_c6-H.js → blockDiagram-VD42YOAC-CGtjuPGT.js} +1 -1
- package/dist/assets/brainfuck-D5O26WTe.js +1 -0
- package/dist/assets/{button-D9nb17Rw.js → button-BbCh-29a.js} +1 -1
- package/dist/assets/{c4Diagram-YG6GDRKO-DHRUX7S-.js → c4Diagram-YG6GDRKO-BSjPyzdq.js} +1 -1
- package/dist/assets/{cache-panel-B_zs00Q_.js → cache-panel-VFeeaT52.js} +1 -1
- package/dist/assets/{capabilities-C_FLIcjP.js → capabilities-A_KhFcGV.js} +1 -1
- package/dist/assets/cell-editor-BnpmZwdT.js +20 -0
- package/dist/assets/cell-link-DieESi6t.js +1 -0
- package/dist/assets/{cells-DAxz8J5R.js → cells-CQvqgbJL.js} +72 -72
- package/dist/assets/channel-D2-MhlpJ.js +1 -0
- package/dist/assets/{chat-display-BiUNr6dU.js → chat-display-DXa2yk_L.js} +1 -1
- package/dist/assets/{chat-panel-BHsaaTzR.js → chat-panel-B_FKBw0c.js} +1 -1
- package/dist/assets/{chat-ui-CTYG4pnL.js → chat-ui-DRuFbdVZ.js} +1 -1
- package/dist/assets/{chunk-4BX2VUAB-mPGRpph5.js → chunk-4BX2VUAB-Co_nHYv2.js} +1 -1
- package/dist/assets/chunk-55IACEB6-CSG9iNvo.js +1 -0
- package/dist/assets/{chunk-5FQGJX7Z-e_arGD4o.js → chunk-5FQGJX7Z-BReOK4Lg.js} +2 -2
- package/dist/assets/{chunk-ABZYJK2D-BInZW7OW.js → chunk-ABZYJK2D-CvNlx3OC.js} +3 -3
- package/dist/assets/{chunk-ATLVNIR6-_9Zaw7IP.js → chunk-ATLVNIR6-EZIDpjkm.js} +1 -1
- package/dist/assets/{chunk-B4BG7PRW-Bg43tpY1.js → chunk-B4BG7PRW-B3yrge9N.js} +1 -1
- package/dist/assets/{chunk-CVBHYZKI-Brsoob-W.js → chunk-CVBHYZKI-lxEaq00s.js} +1 -1
- package/dist/assets/{chunk-DI55MBZ5-DX01Gov5.js → chunk-DI55MBZ5-NrI5veM7.js} +1 -1
- package/dist/assets/{chunk-EXTU4WIE-Cwo9-IiR.js → chunk-EXTU4WIE-DcGAJuBg.js} +1 -1
- package/dist/assets/{chunk-FMBD7UC4-Bt9icXTy.js → chunk-FMBD7UC4-CD1D2uhs.js} +1 -1
- package/dist/assets/{chunk-HN2XXSSU-BBxJMYrA.js → chunk-HN2XXSSU-DNIvfs-V.js} +1 -1
- package/dist/assets/{chunk-JA3XYJ7Z-C6cvGHie.js → chunk-JA3XYJ7Z-B-G51Lop.js} +1 -1
- package/dist/assets/{chunk-JZLCHNYA-BM-e2D_8.js → chunk-JZLCHNYA-B1QJXpkc.js} +1 -1
- package/dist/assets/{chunk-MI3HLSF2-D6we5Ftb.js → chunk-MI3HLSF2-SpVCtnNg.js} +1 -1
- package/dist/assets/{chunk-N4CR4FBY-BREYOeLP.js → chunk-N4CR4FBY-DaT7rK9q.js} +2 -2
- package/dist/assets/{chunk-QN33PNHL-DwGffwWu.js → chunk-QN33PNHL-eWaiYkN_.js} +1 -1
- package/dist/assets/{chunk-QXUST7PY-Q2jlSUop.js → chunk-QXUST7PY-yCShGuH_.js} +1 -1
- package/dist/assets/{chunk-QZHKN3VN-CeNfSWg4.js → chunk-QZHKN3VN-Bf2ysi2t.js} +1 -1
- package/dist/assets/{chunk-S3R3BYOJ-DGKPoF4U.js → chunk-S3R3BYOJ-BuT2smkb.js} +1 -1
- package/dist/assets/{chunk-TZMSLE5B-Bfbjtd_W.js → chunk-TZMSLE5B-tzDl0-3S.js} +1 -1
- package/dist/assets/classDiagram-2ON5EDUG-CSdm65qE.js +1 -0
- package/dist/assets/classDiagram-v2-WZHVMYZB-B2-GAMOQ.js +1 -0
- package/dist/assets/{clike-O99jWPIc.js → clike-TwxwxEw_.js} +1 -1
- package/dist/assets/clojure-B8dfjAV6.js +1 -0
- package/dist/assets/cmake-D3vlGJdL.js +1 -0
- package/dist/assets/cobol-S-4I_F1W.js +1 -0
- package/dist/assets/{code-block-37QAKDTI-CtU_48GW.js → code-block-37QAKDTI-BZ77cXM8.js} +1 -1
- package/dist/assets/coffeescript-DG-Oj54u.js +1 -0
- package/dist/assets/{column-preview-C1-l9fq3.js → column-preview-B59x-AoX.js} +1 -1
- package/dist/assets/{command-CBCkexpx.js → command-OHlV5HHD.js} +1 -1
- package/dist/assets/{command-palette-0Bx056Jf.js → command-palette-BM-axWW4.js} +1 -1
- package/dist/assets/{common-Qy2P7rii.js → common-DstWRPls.js} +1 -1
- package/dist/assets/commonlisp-CWlOS49U.js +1 -0
- package/dist/assets/{components-D9aJNSr-.js → components-BKjSTOL0.js} +1 -1
- package/dist/assets/{components-CZy03693.js → components-BLTMoYca.js} +1 -1
- package/dist/assets/{config-CPqw1wUv.js → config-CeTe6Mau.js} +1 -1
- package/dist/assets/{copy-BCF-tANo.js → copy-DqHGjTAN.js} +1 -1
- package/dist/assets/{copy-icon-BYNydU7b.js → copy-icon-8abB4Lgh.js} +1 -1
- package/dist/assets/{cose-bilkent-S5V4N54A-DWjOkKYE.js → cose-bilkent-S5V4N54A-CEx_UMjg.js} +1 -1
- package/dist/assets/{createReducer-1ePoj7v6.js → createReducer-CI9qeK_X.js} +1 -1
- package/dist/assets/crystal-CD-LQ3E-.js +1 -0
- package/dist/assets/{css-Ctj1grpW.js → css-sdrF9ahV.js} +1 -1
- package/dist/assets/cypher-oiVTIRlU.js +1 -0
- package/dist/assets/d-KaoGirPa.js +1 -0
- package/dist/assets/{dagre-6UL2VRFP-DWD6iJku.js → dagre-6UL2VRFP-Ca6G800E.js} +1 -1
- package/dist/assets/{data-grid-overlay-editor-DvZ8PZ2g.js → data-grid-overlay-editor-D-UNM6-P.js} +1 -1
- package/dist/assets/{datasource-C1JWjcmE.js → datasource-BpHWX4lD.js} +2 -2
- package/dist/assets/{dates-CAlnO9QB.js → dates-orWokFRU.js} +1 -1
- package/dist/assets/{dependency-graph-panel-DOHj-hNc.js → dependency-graph-panel-DVAWOnhj.js} +4 -4
- package/dist/assets/{diagram-PSM6KHXK-B_Cc0ttH.js → diagram-PSM6KHXK-B6oP3YWR.js} +1 -1
- package/dist/assets/{diagram-QEK2KX5R-DhI0d2dH.js → diagram-QEK2KX5R-BjsoVcta.js} +1 -1
- package/dist/assets/{diagram-S2PKOQOG-cc2LNQee.js → diagram-S2PKOQOG-CmzTe5KJ.js} +1 -1
- package/dist/assets/{dialog-Dj0qTFnG.js → dialog-DBzaWZPw.js} +1 -1
- package/dist/assets/diff-Df1QxxZl.js +1 -0
- package/dist/assets/dist-2Z1sSg1x.js +1 -0
- package/dist/assets/{dist-CbOE2rpr.js → dist-7iwSqhl8.js} +1 -1
- package/dist/assets/dist-B6zNcPeA.js +1 -0
- package/dist/assets/{dist-BoOh2kN5.js → dist-BdyjRhEt.js} +1 -1
- package/dist/assets/{dist-Dq4wQg6C.js → dist-BiTPETny.js} +1 -1
- package/dist/assets/{dist-e6kaTCKJ.js → dist-BojrNCCU.js} +1 -1
- package/dist/assets/{dist-BvZKHNvJ.js → dist-CHMkheIP.js} +1 -1
- package/dist/assets/{dist-DMSWEOfO.js → dist-D1lU2Qzi.js} +1 -1
- package/dist/assets/{dist-Cn0rcGlX.js → dist-D8QLIJ8u.js} +1 -1
- package/dist/assets/dist-DOBJtV_h.js +1 -0
- package/dist/assets/dist-DUpLnFKL.js +1 -0
- package/dist/assets/{dist-R7_s36kw.js → dist-DZaaRVnC.js} +1 -1
- package/dist/assets/{dist-C204e66A.js → dist-DZq-MBWk.js} +1 -1
- package/dist/assets/{dist-Dn_fCOGr.js → dist-Iv0YPPAU.js} +1 -1
- package/dist/assets/{dist-D4HwuQrf.js → dist-YUbAFc_i.js} +1 -1
- package/dist/assets/{dist-BVBYIAbx.js → dist-bOUvGRGG.js} +1 -1
- package/dist/assets/{dockerfile-DERk1oNL.js → dockerfile-CImncS5w.js} +1 -1
- package/dist/assets/documentation-panel-DOwrxSmS.js +1 -0
- package/dist/assets/{download-CXTuIv7r.js → download-D37eAThw.js} +4 -4
- package/dist/assets/{dropdown-menu-D1A3cFC8.js → dropdown-menu-CR7cnzLX.js} +1 -1
- package/dist/assets/dtd-Aj5m459l.js +1 -0
- package/dist/assets/dylan-CdSB1nh8.js +1 -0
- package/dist/assets/ecl-CvwsCfi6.js +1 -0
- package/dist/assets/{edit-page-Q7KKSAbL.js → edit-page-DZuEJBmv.js} +6 -6
- package/dist/assets/eiffel-Bws25dAs.js +1 -0
- package/dist/assets/elm--WkcLZ1a.js +1 -0
- package/dist/assets/{erDiagram-Q2GNP2WA-CPtVWZYn.js → erDiagram-Q2GNP2WA-CK4Kc1gP.js} +1 -1
- package/dist/assets/erlang-Ct30wW1o.js +1 -0
- package/dist/assets/{error-banner-C6aBa98y.js → error-banner-JKAA0BVv.js} +1 -1
- package/dist/assets/{error-panel-BN-anQD3.js → error-panel-iXq4blF1.js} +1 -1
- package/dist/assets/{es-DaYh1PsD.js → es-CaLpD1T5.js} +1 -1
- package/dist/assets/{esm-BRNC35J6.js → esm-DN_A77ya.js} +1 -1
- package/dist/assets/{factor-BbYo7zsD.js → factor-B3fhZG6W.js} +1 -1
- package/dist/assets/factor-DbSpQa-0.js +1 -0
- package/dist/assets/{field-BrLPDxsA.js → field-CD7Io4xo.js} +1 -1
- package/dist/assets/file-explorer-panel-YmaDORzk.js +26 -0
- package/dist/assets/{file-icons-5G4ZC70N.js → file-icons-CJjHFZoa.js} +1 -1
- package/dist/assets/file-name-input-Dti85i-l.js +3 -0
- package/dist/assets/fileToBase64-Dpv4aII5.js +1 -0
- package/dist/assets/{floating-outline-DHE0ukvC.js → floating-outline-CRNblX2_.js} +1 -1
- package/dist/assets/{flowDiagram-NV44I4VS-LeaIbfPS.js → flowDiagram-NV44I4VS-hhUTWDGs.js} +1 -1
- package/dist/assets/{focus-Crs_4nnQ.js → focus-BOQLCb0u.js} +1 -1
- package/dist/assets/{form-FbNsGFA8.js → form-Zq0BEAeQ.js} +2 -2
- package/dist/assets/{formats-Dsc8AdCp.js → formats-D4Sso5bX.js} +1 -1
- package/dist/assets/{formatting-TmuwpwTs.js → formatting-BDxRugYY.js} +1 -1
- package/dist/assets/forth-BP0pXyoR.js +1 -0
- package/dist/assets/fortran-DpX_2iww.js +1 -0
- package/dist/assets/{fullscreen-BDxedMYP.js → fullscreen-eipL3i3Y.js} +1 -1
- package/dist/assets/{gallery-page-C4kMatxN.js → gallery-page-DDCU0YEU.js} +1 -1
- package/dist/assets/{ganttDiagram-JELNMOA3-Bj-STLOZ.js → ganttDiagram-JELNMOA3-Dpb7hBaR.js} +1 -1
- package/dist/assets/gas-CiUR6fHB.js +1 -0
- package/dist/assets/gherkin-C9v48C48.js +1 -0
- package/dist/assets/{gitGraph-G5XIXVHT-CiMGDHpk.js → gitGraph-G5XIXVHT-Xz2NQxVt.js} +1 -1
- package/dist/assets/{gitGraphDiagram-V2S2FVAM-B9HDL4DZ.js → gitGraphDiagram-V2S2FVAM-DHCl4EFT.js} +1 -1
- package/dist/assets/{glide-data-editor-DqqLCmqF.js → glide-data-editor-BELaKoS9.js} +4 -4
- package/dist/assets/{globals-DUw71mRV.js → globals-B64vMQ0L.js} +1 -1
- package/dist/assets/groovy-psUnKwK-.js +1 -0
- package/dist/assets/haskell-DZHQAKUV.js +1 -0
- package/dist/assets/haxe-AOvPCF-w.js +1 -0
- package/dist/assets/{home-page-BM_BZnw7.js → home-page-CFZknmVJ.js} +1 -1
- package/dist/assets/{hooks-BgTKQ8y5.js → hooks-BhxMMR6X.js} +1 -1
- package/dist/assets/{html-to-image-v-_444d3.js → html-to-image-D1De-o9R.js} +2 -2
- package/dist/assets/idl-CSA8C1ck.js +1 -0
- package/dist/assets/index-BTq_h4uZ.js +42 -0
- package/dist/assets/index-DisN5cp_.css +2 -0
- package/dist/assets/{info-VBDWY6EO-yA01qfll.js → info-VBDWY6EO-BpskktdI.js} +1 -1
- package/dist/assets/infoDiagram-HS3SLOUP-C51uJjUn.js +2 -0
- package/dist/assets/{input-BX98vgAu.js → input-DW6LU13i.js} +1 -1
- package/dist/assets/javascript-XMYUq5-t.js +1 -0
- package/dist/assets/{journeyDiagram-XKPGCS4Q-D29tj64e.js → journeyDiagram-XKPGCS4Q-CD6bTQpr.js} +1 -1
- package/dist/assets/julia-oON8zLDW.js +1 -0
- package/dist/assets/{kanban-definition-3W4ZIXB7-DStZ4tGj.js → kanban-definition-3W4ZIXB7-D3rGxlSj.js} +1 -1
- package/dist/assets/katex-DPCeZ37j.js +1 -0
- package/dist/assets/kiosk-mode-DGC0xDP_.js +1 -0
- package/dist/assets/{label-DTR8T0AE.js → label-xHqFtfdz.js} +1 -1
- package/dist/assets/{layout-x1k2voam.js → layout-C74kqxlS.js} +5 -5
- package/dist/assets/{line-j0cbFv7-.js → line-BA7eTS55.js} +1 -1
- package/dist/assets/{linear-Cof2JLCQ.js → linear-Dmb_KwjK.js} +1 -1
- package/dist/assets/{links-iy4RlM-h.js → links-Bi_gi3iZ.js} +1 -1
- package/dist/assets/livescript--BxQO5G_.js +1 -0
- package/dist/assets/{logs-panel-BWCDk8Zy.js → logs-panel-B8xVxjgp.js} +1 -1
- package/dist/assets/{loro_wasm_bg-DWJCS9pK.js → loro_wasm_bg-CklgjGbG.js} +1 -1
- package/dist/assets/lua-CUyaVUOv.js +1 -0
- package/dist/assets/{maps-C48Oksn0.js → maps-BS8Ra-JU.js} +1 -1
- package/dist/assets/{markdown-renderer-CbuqHMPu.js → markdown-renderer-DDfK2Hm1.js} +3 -3
- package/dist/assets/mathematica-ONd8izyd.js +1 -0
- package/dist/assets/mbox-kjl3g9N-.js +1 -0
- package/dist/assets/{menu-items-CwUpDHG7.js → menu-items-DcP01QzW.js} +1 -1
- package/dist/assets/mermaid-4DMBBIKO-BeB_2G2B.js +1 -0
- package/dist/assets/{mermaid-BfdNvRSd.js → mermaid-B6II7_1_.js} +7 -7
- package/dist/assets/{mermaid-parser.core-BQULBKwL.js → mermaid-parser.core-CzmbMcI0.js} +2 -2
- package/dist/assets/{mhchem-BNLsaqjJ.js → mhchem-B4Y0i8Fp.js} +1 -1
- package/dist/assets/{mindmap-definition-VGOIOE7T-Cy9nt356.js → mindmap-definition-VGOIOE7T-CmLdKdIH.js} +1 -1
- package/dist/assets/mirc-BZ6TyuOO.js +1 -0
- package/dist/assets/mllike-Dxt2U6MQ.js +1 -0
- package/dist/assets/modelica-B9sdhdtj.js +1 -0
- package/dist/assets/mscgen-5e5Z5trn.js +1 -0
- package/dist/assets/{multi-map-rafH3cg3.js → multi-map-CUuNtzHt.js} +1 -1
- package/dist/assets/mumps-BUfWDrRe.js +1 -0
- package/dist/assets/{name-cell-input-DoYtA-nF.js → name-cell-input-BOJED96M.js} +1 -1
- package/dist/assets/nsis-Dq7T79DJ.js +1 -0
- package/dist/assets/{nsis-Cr8jf68z.js → nsis-QuE155sg.js} +1 -1
- package/dist/assets/ntriples-Dqzi7kwu.js +1 -0
- package/dist/assets/{number-overlay-editor-8-GuvfJX.js → number-overlay-editor-C8YnP6Ac.js} +1 -1
- package/dist/assets/{numbers-CAW8yjzj.js → numbers-etj36G80.js} +1 -1
- package/dist/assets/octave-v4IgjFm5.js +1 -0
- package/dist/assets/{ordinal-K0JYqmCT.js → ordinal-C9PZ4yw5.js} +1 -1
- package/dist/assets/outline-panel-b7DUTxCg.js +1 -0
- package/dist/assets/oz-BtUsXhbc.js +1 -0
- package/dist/assets/{packages-panel-CHVjLKJK.js → packages-panel-CsjVrbrw.js} +1 -1
- package/dist/assets/{packet-DYOGHKS2-D9yUvksZ.js → packet-DYOGHKS2-BqwwD9JS.js} +1 -1
- package/dist/assets/panels-rOdN-lhQ.js +1 -0
- package/dist/assets/pascal-DV7k6vJ0.js +1 -0
- package/dist/assets/perl-Bz7YaP_R.js +1 -0
- package/dist/assets/{pie-VRWISCQL-Cz1iTD2y.js → pie-VRWISCQL-BqNfdcWg.js} +1 -1
- package/dist/assets/{pieDiagram-ADFJNKIX-CqhovvcK.js → pieDiagram-ADFJNKIX-MH-0tvkn.js} +1 -1
- package/dist/assets/pig-BQWmcOEQ.js +1 -0
- package/dist/assets/{popover-UExmgBsf.js → popover-Bz_0Vkyf.js} +1 -1
- package/dist/assets/powershell-CmIFs71i.js +1 -0
- package/dist/assets/process-output-lWggtdHR.js +1 -0
- package/dist/assets/properties-D7F2Eomu.js +1 -0
- package/dist/assets/protobuf-BMELuvny.js +1 -0
- package/dist/assets/pug-C2KbP_v3.js +1 -0
- package/dist/assets/{pug-CKg66ZCy.js → pug-NA-6TsNe.js} +1 -1
- package/dist/assets/puppet-C7MviiPj.js +1 -0
- package/dist/assets/python-BUl8uFIl.js +1 -0
- package/dist/assets/q-B5bIbNKB.js +1 -0
- package/dist/assets/{quadrantDiagram-AYHSOK5B-BNyiC3hL.js → quadrantDiagram-AYHSOK5B-BSw-Ouba.js} +1 -1
- package/dist/assets/r-B0lU_x8o.js +1 -0
- package/dist/assets/{radar-ZZBFDIW7-y2-V58qq.js → radar-ZZBFDIW7-CYyEWqrT.js} +1 -1
- package/dist/assets/{radio-group-BI3wOhfc.js → radio-group-dnHLEMQN.js} +1 -1
- package/dist/assets/{react-vega-SibldZnp.js → react-vega-B30MPQ4_.js} +1 -1
- package/dist/assets/{react-vega-C1LnPwEN.js → react-vega-CXAF6OHL.js} +1 -1
- package/dist/assets/{readonly-python-code-CaKJ84fy.js → readonly-python-code-B2nKkRm8.js} +1 -1
- package/dist/assets/{renderShortcut-Bfk4NjRL.js → renderShortcut-D_8sQXCD.js} +1 -1
- package/dist/assets/{requirementDiagram-UZGBJVZJ-U4CoEx7e.js → requirementDiagram-UZGBJVZJ-BtGFP-o9.js} +1 -1
- package/dist/assets/{reveal-component-CZjszfUY.js → reveal-component-CRXRtrKQ.js} +2 -2
- package/dist/assets/rpm-BqQ3VFpY.js +1 -0
- package/dist/assets/ruby-AFh8QoqR.js +1 -0
- package/dist/assets/run-page-HwiYpW0n.js +1 -0
- package/dist/assets/{runs-5odJFrfi.js → runs-D87fZMlB.js} +1 -1
- package/dist/assets/{sankeyDiagram-TZEHDZUN-BXgCc5j4.js → sankeyDiagram-TZEHDZUN-yIdYlc6x.js} +1 -1
- package/dist/assets/sas-CeRTI9sn.js +1 -0
- package/dist/assets/{save-worker-CvbUHJh7.js → save-worker-D2iQi-UK.js} +4 -4
- package/dist/assets/scheme-D0VcE_o1.js +1 -0
- package/dist/assets/scratchpad-panel-CQPeL9uQ.js +1 -0
- package/dist/assets/{secrets-panel-DaR50P_m.js → secrets-panel-DgXG36fa.js} +1 -1
- package/dist/assets/{select-5i7URBEn.js → select-DZcFyKFQ.js} +1 -1
- package/dist/assets/semaphore-QJCD9q3h.js +1 -0
- package/dist/assets/{sequenceDiagram-WL72ISMW-CB8apKmu.js → sequenceDiagram-WL72ISMW-DQwYuLw4.js} +1 -1
- package/dist/assets/{session-VtovaFBS.js → session-gB-8RZAq.js} +1 -1
- package/dist/assets/{session-panel-DBKRhLd_.js → session-panel-DDsg3OVJ.js} +1 -1
- package/dist/assets/{share-DIVpiHPe.js → share-DdpVbvDN.js} +1 -1
- package/dist/assets/shell-BBh9RTgS.js +1 -0
- package/dist/assets/sieve-BSX0MHaT.js +1 -0
- package/dist/assets/smalltalk-PvrpLgKW.js +1 -0
- package/dist/assets/{snippets-panel-BvuRa1mc.js → snippets-panel-CL4Fe7G1.js} +1 -1
- package/dist/assets/sparql-CXsmb8zq.js +1 -0
- package/dist/assets/{spec-Cq8FVoTf.js → spec-ByOlaO3e.js} +1 -1
- package/dist/assets/{src-nKy6a3tt.js → src-Cf4NnJCp.js} +1 -1
- package/dist/assets/{state-B34hXjp9.js → state-BNbY1nER.js} +1 -1
- package/dist/assets/{state-Z-H4o98V.js → state-BmNumiqM.js} +1 -1
- package/dist/assets/{state-DgRSUIT8.js → state-Cy8CWhme.js} +1 -1
- package/dist/assets/state-Qlb7fpYs.js +3 -0
- package/dist/assets/{stateDiagram-FKZM4ZOC-3YqeHe0_.js → stateDiagram-FKZM4ZOC-CseMlyhB.js} +1 -1
- package/dist/assets/stateDiagram-v2-4FDKWEC3-Bpp9WfFj.js +1 -0
- package/dist/assets/{step-BE8c2ivx.js → step-CVy5FnKg.js} +1 -1
- package/dist/assets/{strings-md4mFbOQ.js → strings-wdPMRf6Z.js} +1 -1
- package/dist/assets/stylus-B60bUBy2.js +1 -0
- package/dist/assets/swift-BwnHGvoR.js +1 -0
- package/dist/assets/{swiper-component-B-P7FNP9.js → swiper-component-B1e0X8Wt.js} +1 -1
- package/dist/assets/{switch-BvybnC9P.js → switch-BT9Ki10B.js} +1 -1
- package/dist/assets/tcl-Bj8phnhq.js +1 -0
- package/dist/assets/{terminal-zehb39z5.js → terminal-G4Y2HQik.js} +1 -1
- package/dist/assets/{textarea-GPxmW3rS.js → textarea-BIlunvBI.js} +1 -1
- package/dist/assets/textile-WPCmEeGb.js +1 -0
- package/dist/assets/{time-C12vLLcl.js → time-RwUekUwP.js} +1 -1
- package/dist/assets/{timeline-definition-IT6M3QCI-DZQqxPSn.js → timeline-definition-IT6M3QCI-Cac1cr1H.js} +1 -1
- package/dist/assets/toml-Cdfp0vaG.js +1 -0
- package/dist/assets/{tooltip-Gcwqb_SK.js → tooltip-DTV9tlSr.js} +1 -1
- package/dist/assets/{tracing-CVQn241p.js → tracing-DxGrQWpp.js} +1 -1
- package/dist/assets/{tracing-panel-TnogJs00.js → tracing-panel-CkSlaa2T.js} +2 -2
- package/dist/assets/{tree-actions-Ci3CV3hN.js → tree-actions-Bzr5XDGx.js} +1 -1
- package/dist/assets/{treemap-GDKQZRPO-C139r55s.js → treemap-GDKQZRPO-Bimjb3pR.js} +1 -1
- package/dist/assets/troff-D4suUzlg.js +1 -0
- package/dist/assets/ttcn-CvD_6RGm.js +1 -0
- package/dist/assets/ttcn-cfg-BX59kgnW.js +1 -0
- package/dist/assets/turtle-midFOTTV.js +1 -0
- package/dist/assets/{useBoolean-xXcxYCaI.js → useBoolean-BYUGB06y.js} +1 -1
- package/dist/assets/useCellActionButton-BUDcn6TS.js +1 -0
- package/dist/assets/{useDeleteCell-DMZGFMOB.js → useDeleteCell-BImYFHqx.js} +1 -1
- package/dist/assets/{useDependencyPanelTab-Jnl7B-vS.js → useDependencyPanelTab-DjkP1aZy.js} +1 -1
- package/dist/assets/{useEventListener-BR0C1MaI.js → useEventListener-DvoEXWke.js} +1 -1
- package/dist/assets/{useHotkey-DccKPSPx.js → useHotkey-3DXVR1KZ.js} +1 -1
- package/dist/assets/{useIframeCapabilities-BvE4n6hj.js → useIframeCapabilities-BfimgBBe.js} +1 -1
- package/dist/assets/{useInstallPackage-D0NLybAx.js → useInstallPackage-CScpUItd.js} +1 -1
- package/dist/assets/{useInterval-CG264TRB.js → useInterval-CAy_JAzY.js} +1 -1
- package/dist/assets/useNotebookActions-CcSrDfx2.js +1 -0
- package/dist/assets/useRunCells-CHuy8C5z.js +1 -0
- package/dist/assets/useSplitCell-BxJOt_Lh.js +1 -0
- package/dist/assets/{useTheme-DFXuDFj9.js → useTheme-DyLIIrGi.js} +1 -1
- package/dist/assets/{utils-CGtUbqcR.js → utils-441jgnV8.js} +1 -1
- package/dist/assets/{utils-BrXijSdZ.js → utils-Wvjk_Y4h.js} +1 -1
- package/dist/assets/vb-CSNH0UHQ.js +1 -0
- package/dist/assets/vbscript-DTgXfl5y.js +1 -0
- package/dist/assets/vega-component-2S2ePGs4.js +1 -0
- package/dist/assets/velocity-CKgzALh9.js +1 -0
- package/dist/assets/verilog-NDqaS3bW.js +1 -0
- package/dist/assets/vhdl-BibQgFNM.js +1 -0
- package/dist/assets/webidl-BjqVurO-.js +1 -0
- package/dist/assets/{worker-CF8V9c2V.js → worker-B38WhSlZ.js} +4 -4
- package/dist/assets/{write-secret-modal-BFLUPDlo.js → write-secret-modal-BcEaI0rD.js} +1 -1
- package/dist/assets/ws-BV7dcs53.js +22 -0
- package/dist/assets/xquery-DQLXMdMd.js +1 -0
- package/dist/assets/{xychartDiagram-PRI3JC2R-CmNNcgCM.js → xychartDiagram-PRI3JC2R-DwmHTbm4.js} +1 -1
- package/dist/assets/yacas-DlkZlCdY.js +1 -0
- package/dist/assets/z80-YKwwCjvZ.js +1 -0
- package/dist/index.html +73 -72
- package/package.json +2 -2
- package/src/components/data-table/TableTopBar.tsx +5 -1
- package/src/components/data-table/data-table.tsx +5 -0
- package/src/components/data-table/download-policy/atoms.ts +10 -0
- package/src/components/data-table/export-actions.tsx +31 -4
- package/src/components/editor/actions/useNotebookActions.tsx +3 -1
- package/src/components/editor/app-container.tsx +7 -1
- package/src/components/editor/controls/Controls.tsx +3 -1
- package/src/components/editor/file-tree/requesting-tree.tsx +27 -25
- package/src/components/editor/file-tree/upload.tsx +23 -24
- package/src/components/editor/header/__tests__/status.test.tsx +108 -0
- package/src/components/editor/header/status.tsx +44 -10
- package/src/components/editor/navigation/__tests__/clipboard.test.ts +106 -0
- package/src/components/editor/navigation/__tests__/navigation.test.ts +70 -0
- package/src/components/editor/navigation/clipboard.ts +99 -25
- package/src/components/editor/navigation/navigation.ts +15 -1
- package/src/components/editor/notebook-cell.tsx +3 -0
- package/src/components/pages/run-page.tsx +4 -1
- package/src/core/cells/__tests__/cells.test.ts +187 -0
- package/src/core/cells/__tests__/pending-cut-service.test.tsx +123 -0
- package/src/core/cells/cells.ts +102 -17
- package/src/core/cells/document-changes.ts +6 -1
- package/src/core/cells/pending-cut-service.ts +55 -0
- package/src/core/cells/utils.ts +11 -0
- package/src/core/codemirror/cells/extensions.ts +10 -0
- package/src/core/codemirror/markdown/__tests__/commands.test.ts +3 -3
- package/src/core/codemirror/markdown/commands.ts +1 -2
- package/src/core/edit-app.tsx +2 -1
- package/src/core/hotkeys/hotkeys.ts +5 -0
- package/src/core/islands/worker/worker.tsx +3 -2
- package/src/core/network/requests-network.ts +21 -3
- package/src/core/network/types.ts +12 -1
- package/src/core/run-app.tsx +2 -1
- package/src/core/wasm/__tests__/utils.test.ts +34 -0
- package/src/core/wasm/bridge.ts +14 -1
- package/src/core/wasm/utils.ts +14 -0
- package/src/core/wasm/worker/bootstrap.ts +3 -2
- package/src/core/wasm/worker/worker.ts +3 -2
- package/src/core/websocket/__tests__/useMarimoKernelConnection.hook.test.tsx +155 -0
- package/src/core/websocket/__tests__/useMarimoKernelConnection.test.ts +137 -0
- package/src/core/websocket/transports/basic.ts +2 -0
- package/src/core/websocket/transports/transport.ts +1 -0
- package/src/core/websocket/useMarimoKernelConnection.tsx +130 -55
- package/src/core/websocket/useWebSocket.tsx +5 -2
- package/src/css/app/Cell.css +10 -0
- package/src/plugins/core/__test__/sanitize.test.ts +8 -0
- package/src/plugins/impl/DataTablePlugin.tsx +12 -0
- package/src/plugins/impl/TabsPlugin.tsx +35 -7
- package/src/plugins/impl/__tests__/TabsPlugin.test.tsx +154 -0
- package/src/plugins/impl/data-frames/DataFramePlugin.tsx +6 -0
- package/src/plugins/impl/vega/resolve-data.ts +8 -1
- package/src/plugins/layout/__test__/MermaidPlugin.test.ts +50 -0
- package/src/plugins/layout/mermaid/MermaidPlugin.tsx +11 -1
- package/src/plugins/layout/mermaid/mermaid.tsx +7 -3
- package/src/utils/__tests__/id-tree.test.ts +71 -0
- package/src/utils/__tests__/semaphore.test.ts +218 -0
- package/src/utils/fileToBase64.ts +8 -7
- package/src/utils/id-tree.tsx +89 -0
- package/src/utils/semaphore.ts +88 -0
- package/dist/assets/LazyAnyLanguageCodeMirror-BF3xpDgO.js +0 -2
- package/dist/assets/__vite-browser-external-D0cSGXjR.js +0 -1
- package/dist/assets/__vite-browser-external-DQc2JVNq.js +0 -1
- package/dist/assets/apl-m-AMVo9Q.js +0 -1
- package/dist/assets/asciiarmor-BCgPMx-s.js +0 -1
- package/dist/assets/asn1-f2_lxsgc.js +0 -1
- package/dist/assets/brainfuck-ZYebo2B9.js +0 -1
- package/dist/assets/cell-editor-CtnFLzYa.js +0 -22
- package/dist/assets/cell-link-CC2MiW7a.js +0 -1
- package/dist/assets/channel-CWEEnT6g.js +0 -1
- package/dist/assets/chunk-55IACEB6-DD051KDZ.js +0 -1
- package/dist/assets/classDiagram-2ON5EDUG-CBbpzZPu.js +0 -1
- package/dist/assets/classDiagram-v2-WZHVMYZB-B0cWCuuo.js +0 -1
- package/dist/assets/clojure-NE6UT6b9.js +0 -1
- package/dist/assets/cmake-7TIUAxVu.js +0 -1
- package/dist/assets/cobol-BdI6-uBH.js +0 -1
- package/dist/assets/coffeescript-CLx5m4GS.js +0 -1
- package/dist/assets/commonlisp-8d9AwdCm.js +0 -1
- package/dist/assets/crystal-Bn-cOTHZ.js +0 -1
- package/dist/assets/cypher-DnT9gfY3.js +0 -1
- package/dist/assets/d-DCjbmG72.js +0 -1
- package/dist/assets/diff-DtVdhdPz.js +0 -1
- package/dist/assets/dist-BkhaSQrg.js +0 -1
- package/dist/assets/dist-_KQbcsP1.js +0 -1
- package/dist/assets/dist-bvHsEZ9m.js +0 -1
- package/dist/assets/dist-jLyLmWUE.js +0 -1
- package/dist/assets/documentation-panel-BM7hNnyp.js +0 -1
- package/dist/assets/dtd-CHKGQo-k.js +0 -1
- package/dist/assets/dylan-DKXsKw9e.js +0 -1
- package/dist/assets/ecl-BJuToLkm.js +0 -1
- package/dist/assets/eiffel-Bs0gRCeB.js +0 -1
- package/dist/assets/elm-BXUbhN4m.js +0 -1
- package/dist/assets/erlang-B9b7RAaI.js +0 -1
- package/dist/assets/factor-C2NWkG3V.js +0 -1
- package/dist/assets/file-explorer-panel-Y0zOwZxs.js +0 -26
- package/dist/assets/file-name-input-C70pv8AE.js +0 -3
- package/dist/assets/fileToBase64-Bzn96tYq.js +0 -1
- package/dist/assets/forth-DAh7UX6C.js +0 -1
- package/dist/assets/fortran-Dy64-0b5.js +0 -1
- package/dist/assets/gas-DC-7PUFB.js +0 -1
- package/dist/assets/gherkin-ByiMyVl5.js +0 -1
- package/dist/assets/groovy-DaM0RAwa.js +0 -1
- package/dist/assets/haskell-BwRtIbXW.js +0 -1
- package/dist/assets/haxe-DFGSCjmC.js +0 -1
- package/dist/assets/idl-Ip8qszMi.js +0 -1
- package/dist/assets/index-DH5UUBE4.css +0 -2
- package/dist/assets/index-g2qQV71h.js +0 -42
- package/dist/assets/infoDiagram-HS3SLOUP-BDcw9LMK.js +0 -2
- package/dist/assets/javascript-DmUu6wxV.js +0 -1
- package/dist/assets/julia-C8K-9kxt.js +0 -1
- package/dist/assets/katex-S9z-JFdU.js +0 -1
- package/dist/assets/kiosk-mode-DKb6W1WN.js +0 -1
- package/dist/assets/livescript-B3MfBDE2.js +0 -1
- package/dist/assets/lua-B2YpVx0h.js +0 -1
- package/dist/assets/mathematica-D9tSC-hw.js +0 -1
- package/dist/assets/mbox-CjoMCyMH.js +0 -1
- package/dist/assets/mermaid-4DMBBIKO-gHC2PS1m.js +0 -1
- package/dist/assets/mirc-DvJdMBLZ.js +0 -1
- package/dist/assets/mllike-5ykSeapn.js +0 -1
- package/dist/assets/modelica-laYOX8Zo.js +0 -1
- package/dist/assets/mscgen-z_sYErek.js +0 -1
- package/dist/assets/mumps-BwcCoPkA.js +0 -1
- package/dist/assets/nsis-CpSPdWjV.js +0 -1
- package/dist/assets/ntriples-D2ki9JZ6.js +0 -1
- package/dist/assets/octave-D817mWs9.js +0 -1
- package/dist/assets/outline-panel-C5bTOsj4.js +0 -1
- package/dist/assets/oz-3GS03IG4.js +0 -1
- package/dist/assets/panels-D0bfHEhi.js +0 -1
- package/dist/assets/pascal-C08wXab2.js +0 -1
- package/dist/assets/perl-Ija-iETI.js +0 -1
- package/dist/assets/pig-BlBD3yVJ.js +0 -1
- package/dist/assets/powershell-CjOQ_PjD.js +0 -1
- package/dist/assets/process-output-CKd9tbdL.js +0 -1
- package/dist/assets/properties-5yVGVBrw.js +0 -1
- package/dist/assets/protobuf-hlm5v2rk.js +0 -1
- package/dist/assets/pug-DifRb20b.js +0 -1
- package/dist/assets/puppet-BpFPuj45.js +0 -1
- package/dist/assets/python-B_AEFhuO.js +0 -1
- package/dist/assets/q-BzDxfEQq.js +0 -1
- package/dist/assets/r-BJ9VYyYa.js +0 -1
- package/dist/assets/rpm-Ez4HwV9T.js +0 -1
- package/dist/assets/ruby-BcHOM0EI.js +0 -1
- package/dist/assets/run-page-tVelC3Sm.js +0 -1
- package/dist/assets/sas-Qmf5gHIU.js +0 -1
- package/dist/assets/scheme-Ctib9V77.js +0 -1
- package/dist/assets/scratchpad-panel-DB8GmXPG.js +0 -1
- package/dist/assets/shell-BtgVCAhn.js +0 -1
- package/dist/assets/sieve-CMsTkuH0.js +0 -1
- package/dist/assets/smalltalk-BKSCdMTS.js +0 -1
- package/dist/assets/sparql-TK6HapG4.js +0 -1
- package/dist/assets/state-CjlRDG08.js +0 -3
- package/dist/assets/stateDiagram-v2-4FDKWEC3-Dfvjjqh4.js +0 -1
- package/dist/assets/stylus-C8FKVvgQ.js +0 -1
- package/dist/assets/swift-D7BZKS_y.js +0 -1
- package/dist/assets/tcl-DFrjfFmM.js +0 -1
- package/dist/assets/textile-Bj913nF7.js +0 -1
- package/dist/assets/toml-B6qgmS36.js +0 -1
- package/dist/assets/troff-CysSpyUG.js +0 -1
- package/dist/assets/ttcn-DG1k5i1B.js +0 -1
- package/dist/assets/ttcn-cfg-p1jV7x_I.js +0 -1
- package/dist/assets/turtle-DSkxUncB.js +0 -1
- package/dist/assets/useCellActionButton-C8PCItmw.js +0 -1
- package/dist/assets/useNotebookActions-Bfp8EPmq.js +0 -1
- package/dist/assets/useRunCells-BMgfN_OV.js +0 -1
- package/dist/assets/useSplitCell-B5YK7yVe.js +0 -1
- package/dist/assets/vb-BIvYC4My.js +0 -1
- package/dist/assets/vbscript-Coxg2EVQ.js +0 -1
- package/dist/assets/vega-component-DOyQwlmD.js +0 -1
- package/dist/assets/velocity-Cy90c7hC.js +0 -1
- package/dist/assets/verilog-CTtn3HA0.js +0 -1
- package/dist/assets/vhdl-D3r3mwOF.js +0 -1
- package/dist/assets/webidl-CHPMhkWI.js +0 -1
- package/dist/assets/ws-CtTwmdal.js +0 -22
- package/dist/assets/xquery-d-YlNlXH.js +0 -1
- package/dist/assets/yacas-BfZ0gs5_.js +0 -1
- package/dist/assets/z80-cYJ4lyZA.js +0 -1
- /package/dist/assets/{ImageComparisonComponent-2VO41-VE.js → ImageComparisonComponent-MKB-qBjQ.js} +0 -0
- /package/dist/assets/{Inputs-BdyX096j.js → Inputs-NeZ9OMUu.js} +0 -0
- /package/dist/assets/{Plot-IawheWsD.js → Plot-KSPp-GdN.js} +0 -0
- /package/dist/assets/{apl-T0uH_RjM.js → apl-DHQPYmx2.js} +0 -0
- /package/dist/assets/{array-BCwZq3ts.js → array-Cf4PUXPA.js} +0 -0
- /package/dist/assets/{asciiarmor-D3ol7c2G.js → asciiarmor-fnQAw8T8.js} +0 -0
- /package/dist/assets/{asn1-DA-fXXsk.js → asn1-5lb7I37s.js} +0 -0
- /package/dist/assets/{asterisk-Cy-53Fu-.js → asterisk-XerxOHb_.js} +0 -0
- /package/dist/assets/{azure-ZuB1zQ8Q.js → azure-C2Di2emT.js} +0 -0
- /package/dist/assets/{blob-D-eV0cU3.js → blob-Daju1h1M.js} +0 -0
- /package/dist/assets/{brainfuck-exn1QR7H.js → brainfuck-D30bRgvC.js} +0 -0
- /package/dist/assets/{card-BsOjr9wU.js → card-ICvk7-qa.js} +0 -0
- /package/dist/assets/{chunk-4F5CHEZ2-BBsStyPF.js → chunk-4F5CHEZ2-CRKjiogH.js} +0 -0
- /package/dist/assets/{chunk-B2363JML-CPCjJ6tH.js → chunk-B2363JML-DvPUNzRx.js} +0 -0
- /package/dist/assets/{chunk-DR5Q36YT-DpSMafKt.js → chunk-DR5Q36YT-DrxpR6Mz.js} +0 -0
- /package/dist/assets/{chunk-FRFDVMJY-D6StbPqE.js → chunk-FRFDVMJY-DpWfc7R9.js} +0 -0
- /package/dist/assets/{chunk-PL6DKKU2-x3Qoia3Y.js → chunk-PL6DKKU2-D7_8iK_E.js} +0 -0
- /package/dist/assets/{chunk-SJTYNZTY-BNaCydHS.js → chunk-SJTYNZTY-DwmVeUIB.js} +0 -0
- /package/dist/assets/{chunk-TQ3KTPDO-DfYTN8Ct.js → chunk-TQ3KTPDO-BdfwTgi0.js} +0 -0
- /package/dist/assets/{chunk-UMXZTB3W-DsE6dCbX.js → chunk-UMXZTB3W-BZR4zVXt.js} +0 -0
- /package/dist/assets/{clear-button-DBrTU3uL.js → clear-button-DJUQ_tmP.js} +0 -0
- /package/dist/assets/{click-outside-container-BXzp0MYr.js → click-outside-container-Npdlddni.js} +0 -0
- /package/dist/assets/{clike-BK27e5qn.js → clike-jZeb2kFn.js} +0 -0
- /package/dist/assets/{clojure-Df1U5nhC.js → clojure-C0pkR8m2.js} +0 -0
- /package/dist/assets/{cmake-DrCf0yvp.js → cmake-DlvFtk_M.js} +0 -0
- /package/dist/assets/{cobol-BWxHqof4.js → cobol-C_yb45mr.js} +0 -0
- /package/dist/assets/{coffeescript-nKvg8y_U.js → coffeescript-DBK0AeMT.js} +0 -0
- /package/dist/assets/{colors-CI3VyX7X.js → colors-DUsH-HF1.js} +0 -0
- /package/dist/assets/{common-keywords-CU-S2Vqm.js → common-keywords-D2VmoaPb.js} +0 -0
- /package/dist/assets/{commonlisp-Dm562cBV.js → commonlisp-Bo8hOdn-.js} +0 -0
- /package/dist/assets/{crystal-CrCmK2Cb.js → crystal-DYrQEMVi.js} +0 -0
- /package/dist/assets/{css-jpfGFPDE.js → css-zh47N2UC.js} +0 -0
- /package/dist/assets/{cypher-RQ5M28al.js → cypher-BWPAHm69.js} +0 -0
- /package/dist/assets/{cytoscape.esm-BbAjzIsa.js → cytoscape.esm-B7Zr-PlQ.js} +0 -0
- /package/dist/assets/{d-CNQ_nPqU.js → d-CMuL95tt.js} +0 -0
- /package/dist/assets/{diff-DOODcY7A.js → diff-oor_HZ51.js} +0 -0
- /package/dist/assets/{dist-CsEqrZxx.js → dist-1sgFrolC.js} +0 -0
- /package/dist/assets/{dist-DBBYmRY4.js → dist-B847wb8t.js} +0 -0
- /package/dist/assets/{dist-_qPWf6sD.js → dist-BDZFwK9_.js} +0 -0
- /package/dist/assets/{dist-ooLAQ9IK.js → dist-BjkXqMhR.js} +0 -0
- /package/dist/assets/{dist-DggusHaA.js → dist-Bu99ARwH.js} +0 -0
- /package/dist/assets/{dist-HW7R98td.js → dist-Bxj5sO2I.js} +0 -0
- /package/dist/assets/{dist-D6wwIjcW.js → dist-CBX4gLSR.js} +0 -0
- /package/dist/assets/{dist-CEUFTp7U.js → dist-CPepgudT.js} +0 -0
- /package/dist/assets/{dist-CGDn0y-i.js → dist-CQG39nVX.js} +0 -0
- /package/dist/assets/{dist-Cmcbyg5X.js → dist-CSOCJn9h.js} +0 -0
- /package/dist/assets/{dist-DxxvVPQH.js → dist-CpSELpRR.js} +0 -0
- /package/dist/assets/{dist-B96NwXcp.js → dist-DLY3MFt_.js} +0 -0
- /package/dist/assets/{dist-DS5RCKZO.js → dist-D_yqofzt.js} +0 -0
- /package/dist/assets/{dist-rzeRelEY.js → dist-DaXyrkOa.js} +0 -0
- /package/dist/assets/{dist-9g-_Ln9y.js → dist-DdITFgCr.js} +0 -0
- /package/dist/assets/{dist-DCqWIRLq.js → dist-DsbE_iBm.js} +0 -0
- /package/dist/assets/{dist-_XomGjg6.js → dist-GYoBJCzF.js} +0 -0
- /package/dist/assets/{dist-Dw9UX7x1.js → dist-q4pwbvzW.js} +0 -0
- /package/dist/assets/{dtd-CRYKjxdR.js → dtd-Fe_Eikw6.js} +0 -0
- /package/dist/assets/{duckdb-keywords-CR9f4wu5.js → duckdb-keywords-qEANwaB-.js} +0 -0
- /package/dist/assets/{dylan-Bg0sO2y3.js → dylan-DjUZAjRK.js} +0 -0
- /package/dist/assets/{ebnf-BdwTqLUx.js → ebnf-BbpZiR1i.js} +0 -0
- /package/dist/assets/{ecl-DaBeV7OZ.js → ecl-qgyT1LqI.js} +0 -0
- /package/dist/assets/{eiffel-BtJc6fqQ.js → eiffel-Dgulx8rf.js} +0 -0
- /package/dist/assets/{elm-D9Rly7Qq.js → elm-BvFY4GJb.js} +0 -0
- /package/dist/assets/{empty-state-CsVQSqKA.js → empty-state-vCWg-_A9.js} +0 -0
- /package/dist/assets/{erlang-FZMRuv-7.js → erlang-Ba0XOLlj.js} +0 -0
- /package/dist/assets/{errors-TZBmrJmc.js → errors-CPlNr33a.js} +0 -0
- /package/dist/assets/{esm-D_nSG7uo.js → esm-C9WujutX.js} +0 -0
- /package/dist/assets/{fcl-BFWIADMy.js → fcl-CvYyfPhf.js} +0 -0
- /package/dist/assets/{forth-C6jh4lHA.js → forth-gbBFxz8f.js} +0 -0
- /package/dist/assets/{fortran-DuxTe5qi.js → fortran-CXijpPbh.js} +0 -0
- /package/dist/assets/{gas-D7RWbiQ0.js → gas-CnHGSLCd.js} +0 -0
- /package/dist/assets/{gherkin-DV4l4nlf.js → gherkin-DfEZpSxY.js} +0 -0
- /package/dist/assets/{groovy-Ij7mXzwd.js → groovy-9JiNA9gq.js} +0 -0
- /package/dist/assets/{haskell-BT_ZNgUJ.js → haskell-CKr_RZFK.js} +0 -0
- /package/dist/assets/{haxe-DYYwGmM8.js → haxe-DsAAHfaR.js} +0 -0
- /package/dist/assets/{http-CgzOAOXj.js → http-BJwmEMko.js} +0 -0
- /package/dist/assets/{idl-CjBvIccU.js → idl-Djz72z1a.js} +0 -0
- /package/dist/assets/{init-DE_uL9Ns.js → init-DRQmrFIb.js} +0 -0
- /package/dist/assets/{javascript-DQz7szA1.js → javascript-CsBr0q2-.js} +0 -0
- /package/dist/assets/{julia-U0NSUEwm.js → julia-BCYfl68O.js} +0 -0
- /package/dist/assets/{katex-M9SX-Gs-.js → katex-BywUFgaS.js} +0 -0
- /package/dist/assets/{livescript-D7jeebX7.js → livescript-BEw7FNJP.js} +0 -0
- /package/dist/assets/{loro_wasm_bg-Bu4Ofw1K.js → loro_wasm_bg-BArxhAm3.js} +0 -0
- /package/dist/assets/{lua-CT4vrRvN.js → lua-DqxHXOsz.js} +0 -0
- /package/dist/assets/{marimo-icons-BSB-Z_W3.js → marimo-icons-Dk6YhPWV.js} +0 -0
- /package/dist/assets/{math-Bf0RgaKx.js → math-BJjKGmt3.js} +0 -0
- /package/dist/assets/{mathematica-DmzlinOc.js → mathematica-Do-octY0.js} +0 -0
- /package/dist/assets/{mbox-DYDL20A1.js → mbox-VgrgGytk.js} +0 -0
- /package/dist/assets/{mirc-6LiBC6Dw.js → mirc-DkD5mNIp.js} +0 -0
- /package/dist/assets/{mllike-orSu1SHG.js → mllike-C8Ah4kKN.js} +0 -0
- /package/dist/assets/{modelica-BsibU-7c.js → modelica-2q7w6nLE.js} +0 -0
- /package/dist/assets/{mscgen-vX4NsSXf.js → mscgen-BRqvO7u4.js} +0 -0
- /package/dist/assets/{multi-icon-DQxqgfM2.js → multi-icon-BvuxcR2m.js} +0 -0
- /package/dist/assets/{mumps-DIZYQE11.js → mumps-CjtiTT1a.js} +0 -0
- /package/dist/assets/{nginx-CFpObAqg.js → nginx-JMUOT8EG.js} +0 -0
- /package/dist/assets/{node-sql-parser-B8vXamqL.js → node-sql-parser-TdBo37ty.js} +0 -0
- /package/dist/assets/{ntriples-CwlUIE0o.js → ntriples-4lauqsM6.js} +0 -0
- /package/dist/assets/{octave-BWtN_wao.js → octave-A2kFK0nR.js} +0 -0
- /package/dist/assets/{oz-CJMVKlqL.js → oz-CvXDMSbl.js} +0 -0
- /package/dist/assets/{panel-context-B3J07LRC.js → panel-context-D-qi_oxP.js} +0 -0
- /package/dist/assets/{pascal-C9rPtth-.js → pascal-6Jinj26u.js} +0 -0
- /package/dist/assets/{path-LDcaQ64B.js → path-D7fidI_g.js} +0 -0
- /package/dist/assets/{perl-CF7pKLbl.js → perl-CXauYQdN.js} +0 -0
- /package/dist/assets/{pig-Bu0nn8JT.js → pig-Dl0QLQI6.js} +0 -0
- /package/dist/assets/{powershell-Bzwpi8yQ.js → powershell-6bdy_rHW.js} +0 -0
- /package/dist/assets/{properties-Cfh_Lj0j.js → properties-p1rx3aF7.js} +0 -0
- /package/dist/assets/{protobuf-Vz3fs9Hb.js → protobuf-BZ6p9Xh_.js} +0 -0
- /package/dist/assets/{puppet-JwSHf4DX.js → puppet-CjdIRV7D.js} +0 -0
- /package/dist/assets/{python-BRHQZrcc.js → python-uzyJYIWU.js} +0 -0
- /package/dist/assets/{q-DWFQ7YI_.js → q-CfD3i9uI.js} +0 -0
- /package/dist/assets/{r-DHkTNFL2.js → r-JyJdYHQB.js} +0 -0
- /package/dist/assets/{request-registry-BwzANGxx.js → request-registry-5ELz5pd2.js} +0 -0
- /package/dist/assets/{requests-BqcqF00P.js → requests-QKoDeQkn.js} +0 -0
- /package/dist/assets/{rpm-zbaZz_dk.js → rpm-DuGPfDyX.js} +0 -0
- /package/dist/assets/{ruby-COvM5Bj_.js → ruby-CA1TzLxZ.js} +0 -0
- /package/dist/assets/{sas-Be8P6y_s.js → sas-BJPWZC7M.js} +0 -0
- /package/dist/assets/{scheme-B9Zors0b.js → scheme-IRagAY3r.js} +0 -0
- /package/dist/assets/{shell-CaaQwZ-W.js → shell-BVpF3W_J.js} +0 -0
- /package/dist/assets/{sieve-CdflT_3W.js → sieve-BSfPMeZl.js} +0 -0
- /package/dist/assets/{simple-mode-BJAT_N3M.js → simple-mode-BmS_AmGQ.js} +0 -0
- /package/dist/assets/{smalltalk-CRO88y3z.js → smalltalk-CkHVehky.js} +0 -0
- /package/dist/assets/{solr-BkyoAXqg.js → solr-BHjX6hxO.js} +0 -0
- /package/dist/assets/{sparql-DEker8ZS.js → sparql-CmKKjr-f.js} +0 -0
- /package/dist/assets/{spreadsheet-7FZkhkVo.js → spreadsheet-ColK3G9J.js} +0 -0
- /package/dist/assets/{sql-BNnXxKXA.js → sql-BfkgiLSh.js} +0 -0
- /package/dist/assets/{src-CmKhyEBC.js → src-HwYBNPfa.js} +0 -0
- /package/dist/assets/{stylus-DAJwnVOa.js → stylus-D28PuRsm.js} +0 -0
- /package/dist/assets/{swift-D5F-FU3-.js → swift-D-jfpPuv.js} +0 -0
- /package/dist/assets/{tcl-DirNbhYm.js → tcl-BrQdCDVA.js} +0 -0
- /package/dist/assets/{textile-DhHo4rKl.js → textile-DXBc8HMq.js} +0 -0
- /package/dist/assets/{tiddlywiki-DE5lnTl3.js → tiddlywiki-DzM1IR9M.js} +0 -0
- /package/dist/assets/{tiki-Dt9oCY2i.js → tiki-DI4TiGi6.js} +0 -0
- /package/dist/assets/{timer-CIInKAPS.js → timer-ffBO1paY.js} +0 -0
- /package/dist/assets/{toml-CrP9HWVu.js → toml-ClSouHPE.js} +0 -0
- /package/dist/assets/{treemap-BKxvGXqJ.js → treemap-CZF0Enj1.js} +0 -0
- /package/dist/assets/{troff-BWD1WiE0.js → troff-BGDyQn9x.js} +0 -0
- /package/dist/assets/{ttcn-CQzcRj0D.js → ttcn-De1OdISX.js} +0 -0
- /package/dist/assets/{ttcn-cfg-jzTcqwRW.js → ttcn-cfg-CQMSrhCz.js} +0 -0
- /package/dist/assets/{turtle-BAqH2D2z.js → turtle-DNhfxysg.js} +0 -0
- /package/dist/assets/{types-z6Sk3JCV.js → types-Bhw3Hco_.js} +0 -0
- /package/dist/assets/{vb-CrUpzy4g.js → vb-BX7-Md9G.js} +0 -0
- /package/dist/assets/{vbscript-DEuHZ0Y0.js → vbscript-DNMzJOTU.js} +0 -0
- /package/dist/assets/{velocity-D99sTvXl.js → velocity-viirwPm7.js} +0 -0
- /package/dist/assets/{verilog-XWBMMjwd.js → verilog-CZguTLBV.js} +0 -0
- /package/dist/assets/{vhdl-BAGmVXDV.js → vhdl-CAEhCBOl.js} +0 -0
- /package/dist/assets/{web-vitals-BaJPM15X.js → web-vitals-CBsQ2DM_.js} +0 -0
- /package/dist/assets/{webidl-xagG_7hd.js → webidl-BNJg_7gX.js} +0 -0
- /package/dist/assets/{xquery-B8Mguhly.js → xquery-CGV_r322.js} +0 -0
- /package/dist/assets/{yacas-XW2NxGKw.js → yacas-uRzw7z7m.js} +0 -0
- /package/dist/assets/{z80-DhICfTcL.js → z80-CBK8t-9T.js} +0 -0
|
@@ -0,0 +1,155 @@
|
|
|
1
|
+
/* Copyright 2026 Marimo. All rights reserved. */
|
|
2
|
+
// @vitest-environment jsdom
|
|
3
|
+
|
|
4
|
+
import { act, renderHook } from "@testing-library/react";
|
|
5
|
+
import { createStore, Provider as JotaiProvider } from "jotai";
|
|
6
|
+
import type React from "react";
|
|
7
|
+
import { ErrorBoundary } from "react-error-boundary";
|
|
8
|
+
import { beforeEach, describe, expect, it, vi } from "vitest";
|
|
9
|
+
|
|
10
|
+
vi.mock("@/core/websocket/useWebSocket", async () => {
|
|
11
|
+
const actual =
|
|
12
|
+
await vi.importActual<typeof import("../useWebSocket")>("../useWebSocket");
|
|
13
|
+
return {
|
|
14
|
+
...actual,
|
|
15
|
+
useConnectionTransport: vi.fn(),
|
|
16
|
+
};
|
|
17
|
+
});
|
|
18
|
+
|
|
19
|
+
vi.mock("@/core/runtime/config", async () => {
|
|
20
|
+
const actual = await vi.importActual<typeof import("@/core/runtime/config")>(
|
|
21
|
+
"@/core/runtime/config",
|
|
22
|
+
);
|
|
23
|
+
return {
|
|
24
|
+
...actual,
|
|
25
|
+
useRuntimeManager: vi.fn(),
|
|
26
|
+
};
|
|
27
|
+
});
|
|
28
|
+
|
|
29
|
+
import { useRuntimeManager } from "@/core/runtime/config";
|
|
30
|
+
import { connectionAtom } from "../../network/connection";
|
|
31
|
+
import type { SessionId } from "../../kernel/session";
|
|
32
|
+
import { WebSocketClosedReason, WebSocketState } from "../types";
|
|
33
|
+
import { useMarimoKernelConnection } from "../useMarimoKernelConnection";
|
|
34
|
+
import { useConnectionTransport } from "../useWebSocket";
|
|
35
|
+
|
|
36
|
+
interface MockTransport {
|
|
37
|
+
readyState: 0 | 1 | 2 | 3;
|
|
38
|
+
retryCount: number;
|
|
39
|
+
reconnect: ReturnType<typeof vi.fn>;
|
|
40
|
+
close: ReturnType<typeof vi.fn>;
|
|
41
|
+
send: ReturnType<typeof vi.fn>;
|
|
42
|
+
addEventListener: ReturnType<typeof vi.fn>;
|
|
43
|
+
removeEventListener: ReturnType<typeof vi.fn>;
|
|
44
|
+
}
|
|
45
|
+
|
|
46
|
+
function makeTransport(
|
|
47
|
+
readyState: 0 | 1 | 2 | 3 = WebSocket.CLOSED,
|
|
48
|
+
): MockTransport {
|
|
49
|
+
return {
|
|
50
|
+
readyState,
|
|
51
|
+
retryCount: 0,
|
|
52
|
+
reconnect: vi.fn(),
|
|
53
|
+
close: vi.fn(),
|
|
54
|
+
send: vi.fn(),
|
|
55
|
+
addEventListener: vi.fn(),
|
|
56
|
+
removeEventListener: vi.fn(),
|
|
57
|
+
};
|
|
58
|
+
}
|
|
59
|
+
|
|
60
|
+
function makeRuntimeManager(isHealthy = vi.fn().mockResolvedValue(true)) {
|
|
61
|
+
return {
|
|
62
|
+
isHealthy,
|
|
63
|
+
getWsURL: () => new URL("ws://localhost/ws"),
|
|
64
|
+
waitForHealthy: vi.fn().mockResolvedValue(undefined),
|
|
65
|
+
isSameOrigin: true,
|
|
66
|
+
};
|
|
67
|
+
}
|
|
68
|
+
|
|
69
|
+
describe("useMarimoKernelConnection.reconnect()", () => {
|
|
70
|
+
let transport: MockTransport;
|
|
71
|
+
let isHealthy: ReturnType<typeof vi.fn>;
|
|
72
|
+
let store: ReturnType<typeof createStore>;
|
|
73
|
+
|
|
74
|
+
beforeEach(() => {
|
|
75
|
+
transport = makeTransport(WebSocket.CLOSED);
|
|
76
|
+
isHealthy = vi.fn().mockResolvedValue(true);
|
|
77
|
+
store = createStore();
|
|
78
|
+
store.set(connectionAtom, {
|
|
79
|
+
state: WebSocketState.CLOSED,
|
|
80
|
+
code: WebSocketClosedReason.KERNEL_DISCONNECTED,
|
|
81
|
+
reason: "kernel not found",
|
|
82
|
+
});
|
|
83
|
+
vi.mocked(useConnectionTransport).mockReturnValue(transport);
|
|
84
|
+
vi.mocked(useRuntimeManager).mockReturnValue(
|
|
85
|
+
makeRuntimeManager(isHealthy) as unknown as ReturnType<
|
|
86
|
+
typeof useRuntimeManager
|
|
87
|
+
>,
|
|
88
|
+
);
|
|
89
|
+
});
|
|
90
|
+
|
|
91
|
+
function renderUseHook() {
|
|
92
|
+
const wrapper: React.FC<React.PropsWithChildren> = ({ children }) => (
|
|
93
|
+
<JotaiProvider store={store}>
|
|
94
|
+
<ErrorBoundary fallback={null}>{children}</ErrorBoundary>
|
|
95
|
+
</JotaiProvider>
|
|
96
|
+
);
|
|
97
|
+
return renderHook(
|
|
98
|
+
() =>
|
|
99
|
+
useMarimoKernelConnection({
|
|
100
|
+
sessionId: "test-session" as SessionId,
|
|
101
|
+
autoInstantiate: false,
|
|
102
|
+
setCells: () => {},
|
|
103
|
+
}),
|
|
104
|
+
{ wrapper },
|
|
105
|
+
);
|
|
106
|
+
}
|
|
107
|
+
|
|
108
|
+
it("is a no-op when the transport is already OPEN", async () => {
|
|
109
|
+
transport.readyState = WebSocket.OPEN;
|
|
110
|
+
const { result } = renderUseHook();
|
|
111
|
+
await act(async () => {
|
|
112
|
+
await result.current.reconnect();
|
|
113
|
+
});
|
|
114
|
+
expect(isHealthy).not.toHaveBeenCalled();
|
|
115
|
+
expect(transport.reconnect).not.toHaveBeenCalled();
|
|
116
|
+
});
|
|
117
|
+
|
|
118
|
+
it("is a no-op when the transport is already CONNECTING", async () => {
|
|
119
|
+
transport.readyState = WebSocket.CONNECTING;
|
|
120
|
+
const { result } = renderUseHook();
|
|
121
|
+
await act(async () => {
|
|
122
|
+
await result.current.reconnect();
|
|
123
|
+
});
|
|
124
|
+
expect(isHealthy).not.toHaveBeenCalled();
|
|
125
|
+
expect(transport.reconnect).not.toHaveBeenCalled();
|
|
126
|
+
});
|
|
127
|
+
|
|
128
|
+
it("probes /health and reconnects when the runtime is healthy", async () => {
|
|
129
|
+
isHealthy.mockResolvedValue(true);
|
|
130
|
+
const { result } = renderUseHook();
|
|
131
|
+
await act(async () => {
|
|
132
|
+
await result.current.reconnect();
|
|
133
|
+
});
|
|
134
|
+
expect(isHealthy).toHaveBeenCalledOnce();
|
|
135
|
+
expect(transport.reconnect).toHaveBeenCalledOnce();
|
|
136
|
+
expect(store.get(connectionAtom)).toEqual({
|
|
137
|
+
state: WebSocketState.CONNECTING,
|
|
138
|
+
});
|
|
139
|
+
});
|
|
140
|
+
|
|
141
|
+
it("transitions to CLOSED and does not call ws.reconnect when the probe fails", async () => {
|
|
142
|
+
isHealthy.mockResolvedValue(false);
|
|
143
|
+
const { result } = renderUseHook();
|
|
144
|
+
await act(async () => {
|
|
145
|
+
await result.current.reconnect();
|
|
146
|
+
});
|
|
147
|
+
expect(isHealthy).toHaveBeenCalledOnce();
|
|
148
|
+
expect(transport.reconnect).not.toHaveBeenCalled();
|
|
149
|
+
expect(store.get(connectionAtom)).toEqual({
|
|
150
|
+
state: WebSocketState.CLOSED,
|
|
151
|
+
code: WebSocketClosedReason.KERNEL_DISCONNECTED,
|
|
152
|
+
reason: "kernel not found",
|
|
153
|
+
});
|
|
154
|
+
});
|
|
155
|
+
});
|
|
@@ -0,0 +1,137 @@
|
|
|
1
|
+
/* Copyright 2026 Marimo. All rights reserved. */
|
|
2
|
+
|
|
3
|
+
import { afterEach, describe, expect, it, vi } from "vitest";
|
|
4
|
+
import { Logger } from "@/utils/Logger";
|
|
5
|
+
import { WebSocketClosedReason, WebSocketState } from "../types";
|
|
6
|
+
import { classifyCloseEvent } from "../useMarimoKernelConnection";
|
|
7
|
+
import { MAX_RETRIES } from "../useWebSocket";
|
|
8
|
+
|
|
9
|
+
function classify(
|
|
10
|
+
reason: string | undefined,
|
|
11
|
+
retryCount = 0,
|
|
12
|
+
maxRetries = MAX_RETRIES,
|
|
13
|
+
) {
|
|
14
|
+
return classifyCloseEvent({ reason }, { retryCount, maxRetries });
|
|
15
|
+
}
|
|
16
|
+
|
|
17
|
+
describe("classifyCloseEvent", () => {
|
|
18
|
+
describe("transient closes (default branch)", () => {
|
|
19
|
+
it("retries when retryCount < maxRetries", () => {
|
|
20
|
+
const decision = classify(undefined, 0);
|
|
21
|
+
expect(decision.kind).toBe("retry");
|
|
22
|
+
expect(decision.status).toEqual({ state: WebSocketState.CONNECTING });
|
|
23
|
+
});
|
|
24
|
+
|
|
25
|
+
it("retries on each intermediate close event during a retry storm", () => {
|
|
26
|
+
for (let n = 0; n < MAX_RETRIES; n++) {
|
|
27
|
+
const decision = classify(undefined, n);
|
|
28
|
+
expect(decision.kind).toBe("retry");
|
|
29
|
+
expect(decision.status).toEqual({ state: WebSocketState.CONNECTING });
|
|
30
|
+
}
|
|
31
|
+
});
|
|
32
|
+
|
|
33
|
+
it("transitions to CLOSED when retryCount reaches maxRetries", () => {
|
|
34
|
+
const decision = classify(undefined, MAX_RETRIES);
|
|
35
|
+
expect(decision.kind).toBe("gave-up");
|
|
36
|
+
expect(decision.status).toEqual({
|
|
37
|
+
state: WebSocketState.CLOSED,
|
|
38
|
+
code: WebSocketClosedReason.KERNEL_DISCONNECTED,
|
|
39
|
+
reason: "kernel not found",
|
|
40
|
+
});
|
|
41
|
+
});
|
|
42
|
+
|
|
43
|
+
it("transitions to CLOSED when retryCount exceeds maxRetries", () => {
|
|
44
|
+
const decision = classify(undefined, MAX_RETRIES + 5);
|
|
45
|
+
expect(decision.kind).toBe("gave-up");
|
|
46
|
+
});
|
|
47
|
+
|
|
48
|
+
it("treats unknown reason strings as transient and logs a warning", () => {
|
|
49
|
+
const logger = vi.spyOn(Logger, "warn").mockImplementation(() => {});
|
|
50
|
+
const decision = classify("something-else", 3);
|
|
51
|
+
expect(decision.kind).toBe("retry");
|
|
52
|
+
expect(logger).toHaveBeenCalled();
|
|
53
|
+
logger.mockRestore();
|
|
54
|
+
});
|
|
55
|
+
});
|
|
56
|
+
|
|
57
|
+
afterEach(() => {
|
|
58
|
+
vi.restoreAllMocks();
|
|
59
|
+
});
|
|
60
|
+
|
|
61
|
+
describe("terminal closes (server-initiated)", () => {
|
|
62
|
+
it("MARIMO_ALREADY_CONNECTED → terminal + closeTransport, with takeover", () => {
|
|
63
|
+
const decision = classify("MARIMO_ALREADY_CONNECTED", 0);
|
|
64
|
+
expect(decision.kind).toBe("terminal");
|
|
65
|
+
expect(decision.status).toMatchObject({
|
|
66
|
+
state: WebSocketState.CLOSED,
|
|
67
|
+
code: WebSocketClosedReason.ALREADY_RUNNING,
|
|
68
|
+
canTakeover: true,
|
|
69
|
+
});
|
|
70
|
+
if (decision.kind === "terminal") {
|
|
71
|
+
expect(decision.closeTransport).toBe(true);
|
|
72
|
+
}
|
|
73
|
+
});
|
|
74
|
+
|
|
75
|
+
it.each([
|
|
76
|
+
"MARIMO_WRONG_KERNEL_ID",
|
|
77
|
+
"MARIMO_NO_FILE_KEY",
|
|
78
|
+
"MARIMO_NO_SESSION_ID",
|
|
79
|
+
"MARIMO_NO_SESSION",
|
|
80
|
+
"MARIMO_SHUTDOWN",
|
|
81
|
+
])("%s → terminal with KERNEL_DISCONNECTED, closes transport", (reason) => {
|
|
82
|
+
const decision = classify(reason, 0);
|
|
83
|
+
expect(decision.kind).toBe("terminal");
|
|
84
|
+
expect(decision.status).toMatchObject({
|
|
85
|
+
state: WebSocketState.CLOSED,
|
|
86
|
+
code: WebSocketClosedReason.KERNEL_DISCONNECTED,
|
|
87
|
+
});
|
|
88
|
+
if (decision.kind === "terminal") {
|
|
89
|
+
expect(decision.closeTransport).toBe(true);
|
|
90
|
+
}
|
|
91
|
+
});
|
|
92
|
+
|
|
93
|
+
it("MARIMO_MALFORMED_QUERY → terminal but does NOT close transport", () => {
|
|
94
|
+
const decision = classify("MARIMO_MALFORMED_QUERY", 0);
|
|
95
|
+
expect(decision.kind).toBe("terminal");
|
|
96
|
+
expect(decision.status).toMatchObject({
|
|
97
|
+
state: WebSocketState.CLOSED,
|
|
98
|
+
code: WebSocketClosedReason.MALFORMED_QUERY,
|
|
99
|
+
});
|
|
100
|
+
if (decision.kind === "terminal") {
|
|
101
|
+
expect(decision.closeTransport).toBe(false);
|
|
102
|
+
}
|
|
103
|
+
});
|
|
104
|
+
|
|
105
|
+
it("MARIMO_KERNEL_STARTUP_ERROR → terminal + closeTransport", () => {
|
|
106
|
+
const decision = classify("MARIMO_KERNEL_STARTUP_ERROR", 0);
|
|
107
|
+
expect(decision.kind).toBe("terminal");
|
|
108
|
+
expect(decision.status).toMatchObject({
|
|
109
|
+
state: WebSocketState.CLOSED,
|
|
110
|
+
code: WebSocketClosedReason.KERNEL_STARTUP_ERROR,
|
|
111
|
+
});
|
|
112
|
+
if (decision.kind === "terminal") {
|
|
113
|
+
expect(decision.closeTransport).toBe(true);
|
|
114
|
+
}
|
|
115
|
+
});
|
|
116
|
+
|
|
117
|
+
it("terminal closes ignore retryCount entirely", () => {
|
|
118
|
+
const decision = classify("MARIMO_SHUTDOWN", 99);
|
|
119
|
+
expect(decision.kind).toBe("terminal");
|
|
120
|
+
});
|
|
121
|
+
});
|
|
122
|
+
|
|
123
|
+
describe("retry budget exhaustion", () => {
|
|
124
|
+
it("yields retry on attempts 1..maxRetries-1 and gave-up on the final close", () => {
|
|
125
|
+
const states: string[] = [];
|
|
126
|
+
for (let attempt = 1; attempt <= MAX_RETRIES; attempt++) {
|
|
127
|
+
states.push(classify(undefined, attempt - 1).kind);
|
|
128
|
+
}
|
|
129
|
+
states.push(classify(undefined, MAX_RETRIES).kind);
|
|
130
|
+
|
|
131
|
+
expect(states).toEqual([
|
|
132
|
+
...Array.from({ length: MAX_RETRIES }, () => "retry"),
|
|
133
|
+
"gave-up",
|
|
134
|
+
]);
|
|
135
|
+
});
|
|
136
|
+
});
|
|
137
|
+
});
|
|
@@ -11,7 +11,10 @@ import type {
|
|
|
11
11
|
NotificationMessageData,
|
|
12
12
|
NotificationPayload,
|
|
13
13
|
} from "@/core/kernel/messages";
|
|
14
|
-
import {
|
|
14
|
+
import {
|
|
15
|
+
MAX_RETRIES,
|
|
16
|
+
useConnectionTransport,
|
|
17
|
+
} from "@/core/websocket/useWebSocket";
|
|
15
18
|
import { renderHTML } from "@/plugins/core/RenderHTML";
|
|
16
19
|
import {
|
|
17
20
|
handleWidgetMessage,
|
|
@@ -69,10 +72,96 @@ import { useStorageActions } from "../storage/state";
|
|
|
69
72
|
import { useVariablesActions } from "../variables/state";
|
|
70
73
|
import type { VariableName } from "../variables/types";
|
|
71
74
|
import { isWasm } from "../wasm/utils";
|
|
72
|
-
import {
|
|
75
|
+
import {
|
|
76
|
+
type ConnectionStatus,
|
|
77
|
+
WebSocketClosedReason,
|
|
78
|
+
WebSocketState,
|
|
79
|
+
} from "./types";
|
|
73
80
|
|
|
74
81
|
const SUPPORTS_LAZY_KERNELS = true;
|
|
75
82
|
|
|
83
|
+
export type CloseDecision =
|
|
84
|
+
| { kind: "terminal"; status: ConnectionStatus; closeTransport: boolean }
|
|
85
|
+
| { kind: "gave-up"; status: ConnectionStatus }
|
|
86
|
+
| { kind: "retry"; status: ConnectionStatus };
|
|
87
|
+
|
|
88
|
+
export function classifyCloseEvent(
|
|
89
|
+
event: { reason?: string },
|
|
90
|
+
context: { retryCount: number; maxRetries: number },
|
|
91
|
+
): CloseDecision {
|
|
92
|
+
switch (event.reason) {
|
|
93
|
+
case "MARIMO_ALREADY_CONNECTED":
|
|
94
|
+
return {
|
|
95
|
+
kind: "terminal",
|
|
96
|
+
status: {
|
|
97
|
+
state: WebSocketState.CLOSED,
|
|
98
|
+
code: WebSocketClosedReason.ALREADY_RUNNING,
|
|
99
|
+
reason: "another browser tab is already connected to the kernel",
|
|
100
|
+
canTakeover: true,
|
|
101
|
+
},
|
|
102
|
+
closeTransport: true,
|
|
103
|
+
};
|
|
104
|
+
case "MARIMO_WRONG_KERNEL_ID":
|
|
105
|
+
case "MARIMO_NO_FILE_KEY":
|
|
106
|
+
case "MARIMO_NO_SESSION_ID":
|
|
107
|
+
case "MARIMO_NO_SESSION":
|
|
108
|
+
case "MARIMO_SHUTDOWN":
|
|
109
|
+
return {
|
|
110
|
+
kind: "terminal",
|
|
111
|
+
status: {
|
|
112
|
+
state: WebSocketState.CLOSED,
|
|
113
|
+
code: WebSocketClosedReason.KERNEL_DISCONNECTED,
|
|
114
|
+
reason: "kernel not found",
|
|
115
|
+
},
|
|
116
|
+
closeTransport: true,
|
|
117
|
+
};
|
|
118
|
+
case "MARIMO_MALFORMED_QUERY":
|
|
119
|
+
return {
|
|
120
|
+
kind: "terminal",
|
|
121
|
+
status: {
|
|
122
|
+
state: WebSocketState.CLOSED,
|
|
123
|
+
code: WebSocketClosedReason.MALFORMED_QUERY,
|
|
124
|
+
reason:
|
|
125
|
+
"the kernel did not recognize a request; please file a bug with marimo",
|
|
126
|
+
},
|
|
127
|
+
closeTransport: false,
|
|
128
|
+
};
|
|
129
|
+
case "MARIMO_KERNEL_STARTUP_ERROR":
|
|
130
|
+
return {
|
|
131
|
+
kind: "terminal",
|
|
132
|
+
status: {
|
|
133
|
+
state: WebSocketState.CLOSED,
|
|
134
|
+
code: WebSocketClosedReason.KERNEL_STARTUP_ERROR,
|
|
135
|
+
reason: "Failed to start kernel sandbox",
|
|
136
|
+
},
|
|
137
|
+
closeTransport: true,
|
|
138
|
+
};
|
|
139
|
+
default:
|
|
140
|
+
// Empty/undefined reasons are normal transient closes. Anything else is
|
|
141
|
+
// an unknown server reason; warn so a new MARIMO_* reason doesn't fall
|
|
142
|
+
// silently into the retry path.
|
|
143
|
+
if (event.reason) {
|
|
144
|
+
logNever(event.reason as never);
|
|
145
|
+
}
|
|
146
|
+
}
|
|
147
|
+
// partysocket stops retrying silently once `maxRetries` is hit; surface
|
|
148
|
+
// CLOSED so callers can detect the give-up.
|
|
149
|
+
if (context.retryCount >= context.maxRetries) {
|
|
150
|
+
return {
|
|
151
|
+
kind: "gave-up",
|
|
152
|
+
status: {
|
|
153
|
+
state: WebSocketState.CLOSED,
|
|
154
|
+
code: WebSocketClosedReason.KERNEL_DISCONNECTED,
|
|
155
|
+
reason: "kernel not found",
|
|
156
|
+
},
|
|
157
|
+
};
|
|
158
|
+
}
|
|
159
|
+
return {
|
|
160
|
+
kind: "retry",
|
|
161
|
+
status: { state: WebSocketState.CONNECTING },
|
|
162
|
+
};
|
|
163
|
+
}
|
|
164
|
+
|
|
76
165
|
function getExistingCells(): CellData[] | undefined {
|
|
77
166
|
if (!SUPPORTS_LAZY_KERNELS) {
|
|
78
167
|
return undefined;
|
|
@@ -340,6 +429,30 @@ export function useMarimoKernelConnection(opts: {
|
|
|
340
429
|
}
|
|
341
430
|
};
|
|
342
431
|
|
|
432
|
+
// Manual reconnect. Probes /health first to fail fast when the runtime
|
|
433
|
+
// is unreachable, instead of waiting on partysocket's retry budget.
|
|
434
|
+
const reconnect = async () => {
|
|
435
|
+
if (
|
|
436
|
+
ws.readyState === WebSocket.OPEN ||
|
|
437
|
+
ws.readyState === WebSocket.CONNECTING
|
|
438
|
+
) {
|
|
439
|
+
return;
|
|
440
|
+
}
|
|
441
|
+
shouldTryReconnecting.current = true;
|
|
442
|
+
setConnection({ state: WebSocketState.CONNECTING });
|
|
443
|
+
const healthy = await runtimeManager.isHealthy();
|
|
444
|
+
if (!healthy) {
|
|
445
|
+
shouldTryReconnecting.current = false;
|
|
446
|
+
setConnection({
|
|
447
|
+
state: WebSocketState.CLOSED,
|
|
448
|
+
code: WebSocketClosedReason.KERNEL_DISCONNECTED,
|
|
449
|
+
reason: "kernel not found",
|
|
450
|
+
});
|
|
451
|
+
return;
|
|
452
|
+
}
|
|
453
|
+
ws.reconnect();
|
|
454
|
+
};
|
|
455
|
+
|
|
343
456
|
const ws = useConnectionTransport({
|
|
344
457
|
static: isStaticNotebook(),
|
|
345
458
|
/**
|
|
@@ -399,58 +512,20 @@ export function useMarimoKernelConnection(opts: {
|
|
|
399
512
|
*/
|
|
400
513
|
onClose: (e) => {
|
|
401
514
|
Logger.warn("WebSocket closed", e.code, e.reason);
|
|
402
|
-
|
|
403
|
-
|
|
404
|
-
|
|
405
|
-
|
|
406
|
-
|
|
407
|
-
|
|
408
|
-
|
|
409
|
-
|
|
410
|
-
|
|
411
|
-
|
|
412
|
-
|
|
413
|
-
|
|
414
|
-
|
|
415
|
-
|
|
416
|
-
case "MARIMO_NO_SESSION":
|
|
417
|
-
case "MARIMO_SHUTDOWN":
|
|
418
|
-
setConnection({
|
|
419
|
-
state: WebSocketState.CLOSED,
|
|
420
|
-
code: WebSocketClosedReason.KERNEL_DISCONNECTED,
|
|
421
|
-
reason: "kernel not found",
|
|
422
|
-
});
|
|
423
|
-
ws.close(); // close to prevent reconnecting
|
|
424
|
-
return;
|
|
425
|
-
|
|
426
|
-
case "MARIMO_MALFORMED_QUERY":
|
|
427
|
-
setConnection({
|
|
428
|
-
state: WebSocketState.CLOSED,
|
|
429
|
-
code: WebSocketClosedReason.MALFORMED_QUERY,
|
|
430
|
-
reason:
|
|
431
|
-
"the kernel did not recognize a request; please file a bug with marimo",
|
|
432
|
-
});
|
|
433
|
-
return;
|
|
434
|
-
|
|
435
|
-
default:
|
|
436
|
-
// Check for kernel startup error (full error already received via message)
|
|
437
|
-
if (e.reason === "MARIMO_KERNEL_STARTUP_ERROR") {
|
|
438
|
-
setConnection({
|
|
439
|
-
state: WebSocketState.CLOSED,
|
|
440
|
-
code: WebSocketClosedReason.KERNEL_STARTUP_ERROR,
|
|
441
|
-
reason: "Failed to start kernel sandbox",
|
|
442
|
-
});
|
|
443
|
-
ws.close(); // prevent reconnecting
|
|
444
|
-
return;
|
|
445
|
-
}
|
|
446
|
-
|
|
447
|
-
// Session should be valid
|
|
448
|
-
// - browser tab might have been closed or re-opened
|
|
449
|
-
// - computer might have just woken from sleep
|
|
450
|
-
//
|
|
451
|
-
// so try reconnecting.
|
|
452
|
-
setConnection({ state: WebSocketState.CONNECTING });
|
|
453
|
-
tryReconnecting(e.code, e.reason);
|
|
515
|
+
const decision = classifyCloseEvent(e, {
|
|
516
|
+
retryCount: ws.retryCount,
|
|
517
|
+
maxRetries: MAX_RETRIES,
|
|
518
|
+
});
|
|
519
|
+
setConnection(decision.status);
|
|
520
|
+
if (decision.kind === "terminal" && decision.closeTransport) {
|
|
521
|
+
ws.close(); // close to prevent reconnecting
|
|
522
|
+
return;
|
|
523
|
+
}
|
|
524
|
+
if (decision.kind === "retry") {
|
|
525
|
+
// Session should be valid
|
|
526
|
+
// - browser tab might have been closed or re-opened
|
|
527
|
+
// - computer might have just woken from sleep
|
|
528
|
+
tryReconnecting(e.code, e.reason);
|
|
454
529
|
}
|
|
455
530
|
},
|
|
456
531
|
|
|
@@ -468,5 +543,5 @@ export function useMarimoKernelConnection(opts: {
|
|
|
468
543
|
},
|
|
469
544
|
});
|
|
470
545
|
|
|
471
|
-
return { connection };
|
|
546
|
+
return { connection, reconnect };
|
|
472
547
|
}
|
|
@@ -18,6 +18,10 @@ interface UseConnectionTransportOptions {
|
|
|
18
18
|
onError: (event: WebSocketEventMap["error"]) => void;
|
|
19
19
|
}
|
|
20
20
|
|
|
21
|
+
// Per-`reconnect()` retry budget for partysocket. After exhaustion, partysocket
|
|
22
|
+
// stops silently; treat `retryCount >= MAX_RETRIES` as the give-up signal.
|
|
23
|
+
export const MAX_RETRIES = 10;
|
|
24
|
+
|
|
21
25
|
function createConnectionTransport(
|
|
22
26
|
options: Pick<UseConnectionTransportOptions, "url" | "static">,
|
|
23
27
|
): IConnectionTransport {
|
|
@@ -33,8 +37,7 @@ function createConnectionTransport(
|
|
|
33
37
|
// Cast needed: ReconnectingWebSocket types readyState as `number`
|
|
34
38
|
// but IConnectionTransport expects `0 | 1 | 2 | 3`
|
|
35
39
|
return new ReconnectingWebSocket(urlProvider, undefined, {
|
|
36
|
-
|
|
37
|
-
maxRetries: 10,
|
|
40
|
+
maxRetries: MAX_RETRIES,
|
|
38
41
|
debug: false,
|
|
39
42
|
startClosed: true,
|
|
40
43
|
// long timeout -- the server can become slow when many notebooks
|
package/src/css/app/Cell.css
CHANGED
|
@@ -145,6 +145,14 @@ describe("sanitizeHtml", () => {
|
|
|
145
145
|
);
|
|
146
146
|
});
|
|
147
147
|
|
|
148
|
+
test("preserves marimo-mermaid with theme attributes", () => {
|
|
149
|
+
const html =
|
|
150
|
+
"<marimo-mermaid data-diagram='"graph TD\\nA --> B"' data-theme='"base"' data-theme_variables='{"primaryColor": "#E8EEF5", "lineColor": "#475569"}'></marimo-mermaid>";
|
|
151
|
+
expect(sanitizeHtml(html)).toMatchInlineSnapshot(
|
|
152
|
+
`"<marimo-mermaid data-diagram=""graph TD\\nA --> B"" data-theme=""base"" data-theme_variables="{"primaryColor": "#E8EEF5", "lineColor": "#475569"}"></marimo-mermaid>"`,
|
|
153
|
+
);
|
|
154
|
+
});
|
|
155
|
+
|
|
148
156
|
test("keeps style tags with FORCE_BODY", () => {
|
|
149
157
|
const html = "<style>body { color: red; }</style><p>Text</p>";
|
|
150
158
|
expect(sanitizeHtml(html)).toMatchInlineSnapshot(
|
|
@@ -194,6 +194,7 @@ interface Data<T> {
|
|
|
194
194
|
wrappedColumns?: string[];
|
|
195
195
|
headerTooltip?: Record<string, string>;
|
|
196
196
|
totalColumns: number;
|
|
197
|
+
sizeBytes?: number | null;
|
|
197
198
|
maxColumns: number | "all";
|
|
198
199
|
hasStableRowId: boolean;
|
|
199
200
|
lazy: boolean;
|
|
@@ -220,6 +221,7 @@ type DataTableFunctions = {
|
|
|
220
221
|
cell_styles?: CellStyleState | null;
|
|
221
222
|
cell_hover_texts?: Record<string, Record<string, string | null>> | null;
|
|
222
223
|
raw_data?: TableData<T> | null;
|
|
224
|
+
size_bytes?: number | null;
|
|
223
225
|
}>;
|
|
224
226
|
get_data_url?: GetDataUrl;
|
|
225
227
|
get_row_ids?: GetRowIds;
|
|
@@ -270,6 +272,7 @@ export const DataTablePlugin = createPlugin<S>("marimo-table")
|
|
|
270
272
|
headerTooltip: z.record(z.string(), z.string()).optional(),
|
|
271
273
|
fieldTypes: columnToFieldTypesSchema.nullish(),
|
|
272
274
|
totalColumns: z.number(),
|
|
275
|
+
sizeBytes: z.number().nullish(),
|
|
273
276
|
maxColumns: z.union([z.number(), z.literal("all")]).default("all"),
|
|
274
277
|
hasStableRowId: z.boolean().default(false),
|
|
275
278
|
maxHeight: z.number().optional(),
|
|
@@ -327,6 +330,7 @@ export const DataTablePlugin = createPlugin<S>("marimo-table")
|
|
|
327
330
|
.nullable(),
|
|
328
331
|
cell_hover_texts: cellHoverTextSchema.nullable(),
|
|
329
332
|
raw_data: z.union([z.string(), z.array(z.looseObject({}))]).nullish(),
|
|
333
|
+
size_bytes: z.number().nullish(),
|
|
330
334
|
}),
|
|
331
335
|
),
|
|
332
336
|
get_row_ids: rpc.input(z.object({}).passthrough()).output(
|
|
@@ -532,6 +536,7 @@ export const LoadingDataTableComponent = memo(
|
|
|
532
536
|
rows: T[];
|
|
533
537
|
rawRows?: T[];
|
|
534
538
|
totalRows: number | TooManyRows;
|
|
539
|
+
sizeBytes?: number | null;
|
|
535
540
|
cellStyles: CellStyleState | undefined | null;
|
|
536
541
|
cellHoverTexts?: Record<string, Record<string, string | null>> | null;
|
|
537
542
|
}>(async () => {
|
|
@@ -548,6 +553,7 @@ export const LoadingDataTableComponent = memo(
|
|
|
548
553
|
let tableData = props.data;
|
|
549
554
|
let rawTableData: TableData<T> | undefined | null = props.rawData;
|
|
550
555
|
let totalRows = props.totalRows;
|
|
556
|
+
let sizeBytes = props.sizeBytes ?? null;
|
|
551
557
|
let cellStyles = props.cellStyles;
|
|
552
558
|
let cellHoverTexts = props.cellHoverTexts;
|
|
553
559
|
|
|
@@ -591,6 +597,7 @@ export const LoadingDataTableComponent = memo(
|
|
|
591
597
|
tableData = searchResults.data;
|
|
592
598
|
rawTableData = searchResults.raw_data;
|
|
593
599
|
totalRows = searchResults.total_rows;
|
|
600
|
+
sizeBytes = searchResults.size_bytes ?? null;
|
|
594
601
|
cellStyles = searchResults.cell_styles || {};
|
|
595
602
|
cellHoverTexts = searchResults.cell_hover_texts || {};
|
|
596
603
|
}
|
|
@@ -603,6 +610,7 @@ export const LoadingDataTableComponent = memo(
|
|
|
603
610
|
rows: tableData,
|
|
604
611
|
rawRows: rawData,
|
|
605
612
|
totalRows: totalRows,
|
|
613
|
+
sizeBytes,
|
|
606
614
|
cellStyles,
|
|
607
615
|
cellHoverTexts,
|
|
608
616
|
};
|
|
@@ -614,6 +622,7 @@ export const LoadingDataTableComponent = memo(
|
|
|
614
622
|
useDeepCompareMemoize(props.fieldTypes),
|
|
615
623
|
props.data,
|
|
616
624
|
props.totalRows,
|
|
625
|
+
props.sizeBytes,
|
|
617
626
|
props.lazy,
|
|
618
627
|
props.cellHoverTexts,
|
|
619
628
|
props.cellStyles,
|
|
@@ -728,6 +737,7 @@ export const LoadingDataTableComponent = memo(
|
|
|
728
737
|
setFilters={setFilters}
|
|
729
738
|
reloading={isFetching && !isPending}
|
|
730
739
|
totalRows={data?.totalRows ?? props.totalRows}
|
|
740
|
+
sizeBytes={data?.sizeBytes ?? props.sizeBytes ?? null}
|
|
731
741
|
paginationState={paginationState}
|
|
732
742
|
setPaginationState={setPaginationState}
|
|
733
743
|
cellStyles={data?.cellStyles ?? props.cellStyles}
|
|
@@ -774,6 +784,7 @@ const DataTableComponent = ({
|
|
|
774
784
|
data,
|
|
775
785
|
rawData,
|
|
776
786
|
totalRows,
|
|
787
|
+
sizeBytes,
|
|
777
788
|
maxColumns,
|
|
778
789
|
pagination,
|
|
779
790
|
selection,
|
|
@@ -1053,6 +1064,7 @@ const DataTableComponent = ({
|
|
|
1053
1064
|
maxHeight={maxHeight}
|
|
1054
1065
|
sorting={sorting}
|
|
1055
1066
|
totalRows={totalRows}
|
|
1067
|
+
sizeBytes={sizeBytes}
|
|
1056
1068
|
totalColumns={totalColumns}
|
|
1057
1069
|
manualSorting={true}
|
|
1058
1070
|
setSorting={setSorting}
|