@marimo-team/frontend 0.19.8-dev5 → 0.19.8-dev50
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-CZlcjSUO.js +1 -0
- package/dist/assets/Combination-BAEdC-rz.js +41 -0
- package/dist/assets/ConnectedDataExplorerComponent-HbY4uSsv.js +1 -0
- package/dist/assets/Deferred-DxQeE5uh.js +1 -0
- package/dist/assets/DeferredRequestRegistry-CMf25YiV.js +1 -0
- package/dist/assets/ErrorBoundary-B9Ifj8Jf.js +1 -0
- package/dist/assets/ImageComparisonComponent-BmIQwrIS.js +1 -0
- package/dist/assets/ImperativeModal-BNN1HA7x.js +1 -0
- package/dist/assets/Inputs-GV-aQbOR.js +1 -0
- package/dist/assets/JsonOutput-PE5ko4gi.js +46 -0
- package/dist/assets/LazyAnyLanguageCodeMirror-DgZ8iknE.js +2 -0
- package/dist/assets/MarimoErrorOutput-Lf9P8Fhl.js +7 -0
- package/dist/assets/RenderHTML-D-of_-s7.js +1 -0
- package/dist/assets/SSRProvider-BIDQNg9Q.js +1 -0
- package/dist/assets/__vite-browser-external-D-ioOGDE.js +1 -0
- package/dist/assets/__vite-browser-external-DT1nudb6.js +1 -0
- package/dist/assets/add-cell-with-ai-e_HMl7UU.js +90 -0
- package/dist/assets/add-database-form-DvnhmpaG.js +111 -0
- package/dist/assets/agent-panel-bOQya9ER.js +287 -0
- package/dist/assets/ai-model-dropdown-Dk2SdB3C.js +5 -0
- package/dist/assets/alert-BOoN6gJ1.js +1 -0
- package/dist/assets/alert-dialog-BW4srmS0.js +11 -0
- package/dist/assets/any-language-editor-BODEG_5g.js +3 -0
- package/dist/assets/apl-CaYjM5u2.js +1 -0
- package/dist/assets/app-config-button-DMsJtN9b.js +1 -0
- package/dist/assets/arc-D1owqr0z.js +1 -0
- package/dist/assets/architecture-U656AL7Q-DENTsr7c.js +1 -0
- package/dist/assets/architectureDiagram-VXUJARFQ-CDeVogFv.js +36 -0
- package/dist/assets/arrow-left-VDC1u5rq.js +1 -0
- package/dist/assets/asciiarmor-D2cJUKTq.js +1 -0
- package/dist/assets/asn1-CZDBKivQ.js +1 -0
- package/dist/assets/badge-DX6CQ6PA.js +1 -0
- package/dist/assets/blob-D-eV0cU3.js +1 -0
- package/dist/assets/blockDiagram-VD42YOAC-Bol-uwBO.js +122 -0
- package/dist/assets/bot-message-square-B2ThzDUZ.js +1 -0
- package/dist/assets/brainfuck-D5O26WTe.js +1 -0
- package/dist/assets/bundle.esm-i_UbZC0w.js +1 -0
- package/dist/assets/button-CZ3Cs4qb.js +1 -0
- package/dist/assets/c4Diagram-YG6GDRKO-C-eNQ40H.js +10 -0
- package/dist/assets/cache-panel-D07YsKqa.js +1 -0
- package/dist/assets/card-OlSjYhmd.js +1 -0
- package/dist/assets/cell-editor-BW4w46wt.js +23 -0
- package/dist/assets/cell-link-B9b7J8QK.js +1 -0
- package/dist/assets/cells-DPp5cDaO.js +254 -0
- package/dist/assets/channel-CdzZX-OR.js +1 -0
- package/dist/assets/chart-no-axes-column-qvVRjhv1.js +1 -0
- package/dist/assets/chat-display--jAB7huF.js +1 -0
- package/dist/assets/chat-panel-DzMwk8Wu.js +3 -0
- package/dist/assets/check-Dr3SxUsb.js +1 -0
- package/dist/assets/chevron-right--18M_6o9.js +1 -0
- package/dist/assets/chunk-4BX2VUAB-KawmK-5L.js +1 -0
- package/dist/assets/chunk-55IACEB6-njZIr50E.js +1 -0
- package/dist/assets/chunk-5FQGJX7Z-DPlx2kjA.js +113 -0
- package/dist/assets/chunk-ABZYJK2D-0jga8uiE.js +80 -0
- package/dist/assets/chunk-ATLVNIR6-B17dg7Ry.js +1 -0
- package/dist/assets/chunk-B4BG7PRW-DoVbcCDm.js +165 -0
- package/dist/assets/chunk-CVBHYZKI-DU48rJVu.js +1 -0
- package/dist/assets/chunk-DI55MBZ5-rLpl7joX.js +220 -0
- package/dist/assets/chunk-EXTU4WIE-Dmu97ZvI.js +1 -0
- package/dist/assets/chunk-FMBD7UC4-CHJv683r.js +15 -0
- package/dist/assets/chunk-HN2XXSSU-Bdbi3Mns.js +1 -0
- package/dist/assets/chunk-JA3XYJ7Z-DOm8KfKa.js +70 -0
- package/dist/assets/chunk-JZLCHNYA-48QVgmR4.js +54 -0
- package/dist/assets/chunk-MI3HLSF2-n3vxgSbN.js +32 -0
- package/dist/assets/chunk-N4CR4FBY-BNoQB557.js +2 -0
- package/dist/assets/chunk-QN33PNHL-BOQncxfy.js +1 -0
- package/dist/assets/chunk-QXUST7PY-DkCIa8tJ.js +7 -0
- package/dist/assets/chunk-QZHKN3VN-Cp_TxrNJ.js +1 -0
- package/dist/assets/chunk-S3R3BYOJ-8loRaCFh.js +2 -0
- package/dist/assets/chunk-TZMSLE5B-CPHBPwrM.js +1 -0
- package/dist/assets/circle-check-DquVD4wZ.js +1 -0
- package/dist/assets/circle-play-EowqxNIC.js +1 -0
- package/dist/assets/circle-plus-haI9GLDP.js +1 -0
- package/dist/assets/classDiagram-2ON5EDUG-CUlU7OLD.js +1 -0
- package/dist/assets/classDiagram-v2-WZHVMYZB-DAwrDtTO.js +1 -0
- package/dist/assets/clear-button-DMZhBF9S.js +1 -0
- package/dist/assets/click-outside-container-BXzp0MYr.js +1 -0
- package/dist/assets/clike-TwxwxEw_.js +1 -0
- package/dist/assets/clipboard-paste-CpyPR-HZ.js +1 -0
- 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-DnnrjIZy.js +2 -0
- package/dist/assets/code-xml-CgN_Yig7.js +1 -0
- package/dist/assets/coffeescript-DG-Oj54u.js +1 -0
- package/dist/assets/column-preview-CXjSXUhP.js +1 -0
- package/dist/assets/command-2ElA5IkO.js +1 -0
- package/dist/assets/command-palette-DrD2qhGV.js +1 -0
- package/dist/assets/common-DSlhalAu.js +1 -0
- package/dist/assets/commonlisp-CWlOS49U.js +1 -0
- package/dist/assets/compiler-runtime-B3qBwwSJ.js +1 -0
- package/dist/assets/config-Q0O7_stz.js +1 -0
- package/dist/assets/context-BfYAMNLF.js +1 -0
- package/dist/assets/copy-D-8y6iMN.js +1 -0
- package/dist/assets/copy-icon-v8ME_JKB.js +1 -0
- package/dist/assets/cose-bilkent-S5V4N54A-tFAvjCRW.js +1 -0
- package/dist/assets/createLucideIcon-BCdY6lG5.js +1 -0
- package/dist/assets/createReducer-B3rBsy4P.js +1 -0
- package/dist/assets/crystal-CD-LQ3E-.js +1 -0
- package/dist/assets/css-sdrF9ahV.js +1 -0
- package/dist/assets/cypher-oiVTIRlU.js +1 -0
- package/dist/assets/d-KaoGirPa.js +1 -0
- package/dist/assets/dagre-6UL2VRFP-DOB6anec.js +4 -0
- package/dist/assets/data-grid-overlay-editor-D8lE4fym.js +1 -0
- package/dist/assets/database-zap-k4ePIFAU.js +1 -0
- package/dist/assets/datasource-CtyqtITR.js +3 -0
- package/dist/assets/dates-CrvjILe3.js +1 -0
- package/dist/assets/dependency-graph-panel-Cbke_QgZ.js +4 -0
- package/dist/assets/diagram-PSM6KHXK-DpuCiAS7.js +24 -0
- package/dist/assets/diagram-QEK2KX5R-IlkvvuKX.js +43 -0
- package/dist/assets/diagram-S2PKOQOG-DJt_T1Gq.js +24 -0
- package/dist/assets/dialog-eb-NieZw.js +1 -0
- package/dist/assets/diff-Df1QxxZl.js +1 -0
- package/dist/assets/dist-4mAhUzty.js +1 -0
- package/dist/assets/dist-5CXgzdUa.js +1 -0
- package/dist/assets/dist-8kKeYgOg.js +1 -0
- package/dist/assets/dist-B27MCO52.js +1 -0
- package/dist/assets/dist-BXnpRw3d.js +1 -0
- package/dist/assets/dist-BZP3Xxma.js +1 -0
- package/dist/assets/dist-Bc7uxGRW.js +1 -0
- package/dist/assets/dist-BtJZmWkg.js +1 -0
- package/dist/assets/dist-Btv5Rh1v.js +1 -0
- package/dist/assets/dist-ByjGU_ag.js +1 -0
- package/dist/assets/dist-C-V6lvxH.js +1 -0
- package/dist/assets/dist-C6SivM7z.js +1 -0
- package/dist/assets/dist-C9k2RMmO.js +1 -0
- package/dist/assets/dist-CDXJRSCj.js +1 -0
- package/dist/assets/dist-CEEqzIVj.js +1 -0
- package/dist/assets/dist-CEaOyZOW.js +1 -0
- package/dist/assets/dist-CLc5WXWw.js +1 -0
- package/dist/assets/dist-CRjEDsfC.js +1 -0
- package/dist/assets/dist-CsRJPnA9.js +1 -0
- package/dist/assets/dist-Cx8mOJOB.js +1 -0
- package/dist/assets/dist-DLgWirXg.js +1 -0
- package/dist/assets/dist-DOZ8nmkC.js +1 -0
- package/dist/assets/dist-DUlOLsKi.js +1 -0
- package/dist/assets/dist-Dv0MupEh.js +1 -0
- package/dist/assets/dist-DwV58Fb1.js +1 -0
- package/dist/assets/dist-OlCHPNfN.js +1 -0
- package/dist/assets/dist-bBwmhqty.js +6 -0
- package/dist/assets/dist-fO1a06Tp.js +1 -0
- package/dist/assets/dist-iXB2pOUD.js +1 -0
- package/dist/assets/dist-lTwzYaMX.js +1 -0
- package/dist/assets/dist-wS1s8MYb.js +1 -0
- package/dist/assets/dockerfile-BmwSYxi2.js +1 -0
- package/dist/assets/documentation-panel-BDQNa1xE.js +1 -0
- package/dist/assets/download-Dg7clfkc.js +1 -0
- package/dist/assets/download-os8QlW6l.js +9 -0
- package/dist/assets/dropdown-menu-ldcmQvIV.js +1 -0
- 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-BpIuEeU6.js +13 -0
- package/dist/assets/eiffel-Bws25dAs.js +1 -0
- package/dist/assets/ellipsis-DfDsMPvA.js +1 -0
- package/dist/assets/ellipsis-vertical-J1F7_WS9.js +1 -0
- package/dist/assets/elm--WkcLZ1a.js +1 -0
- package/dist/assets/empty-state-B8Cxr9nj.js +1 -0
- package/dist/assets/en-US-CCVfmA-q.js +1 -0
- package/dist/assets/erDiagram-Q2GNP2WA-CekwCx1v.js +60 -0
- package/dist/assets/erlang-Ct30wW1o.js +1 -0
- package/dist/assets/error-banner-B9ts0mNl.js +1 -0
- package/dist/assets/error-panel-B_234Lt3.js +1 -0
- package/dist/assets/errors-TZBmrJmc.js +1 -0
- package/dist/assets/es-BYgU_srD.js +5 -0
- package/dist/assets/esm-Bmu2DhPy.js +1 -0
- package/dist/assets/esm-D82gQH1f.js +1 -0
- package/dist/assets/eye-off-AK_9uodG.js +1 -0
- package/dist/assets/factor-B3fhZG6W.js +1 -0
- package/dist/assets/factor-DbSpQa-0.js +1 -0
- package/dist/assets/field-CySaBlkz.js +1 -0
- package/dist/assets/file-Ch78NKWp.js +1 -0
- package/dist/assets/file-explorer-panel-T3oL7Bzx.js +1 -0
- package/dist/assets/file-plus-corner-CvAy4H5W.js +1 -0
- package/dist/assets/file-video-camera-C3wGzBnE.js +1 -0
- package/dist/assets/floating-outline-BtdqbkUq.js +1 -0
- package/dist/assets/flowDiagram-NV44I4VS-BhCyaqwV.js +162 -0
- package/dist/assets/focus-C1YokgL7.js +1 -0
- package/dist/assets/form-BidPUZUn.js +2 -0
- package/dist/assets/forth-BP0pXyoR.js +1 -0
- package/dist/assets/fortran-DpX_2iww.js +1 -0
- package/dist/assets/gallery-page-D5ulMArd.js +1 -0
- package/dist/assets/ganttDiagram-JELNMOA3-Ct2B_ci4.js +267 -0
- package/dist/assets/gas-CiUR6fHB.js +1 -0
- package/dist/assets/gherkin-C9v48C48.js +1 -0
- package/dist/assets/gitGraph-F6HP7TQM-BwJPuiCH.js +1 -0
- package/dist/assets/gitGraphDiagram-NY62KEGX-DOBPUqeq.js +65 -0
- package/dist/assets/glide-data-editor-D1ZoJKPr.js +132 -0
- package/dist/assets/globals-BgACvYmr.js +1 -0
- 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-DUMF8ZY4.js +4 -0
- package/dist/assets/hooks-BGeojgid.js +1 -0
- package/dist/assets/html-to-image-CIQqSu-S.js +2 -0
- package/dist/assets/icons-CCHmxi8d.js +1 -0
- package/dist/assets/idl-CSA8C1ck.js +1 -0
- package/dist/assets/index-CeUwN_0i.css +2 -0
- package/dist/assets/index-DFrkvKWf.js +38 -0
- package/dist/assets/info-NVLQJR56-Ccg18Lpe.js +1 -0
- package/dist/assets/infoDiagram-WHAUD3N6-Cytag0-K.js +2 -0
- package/dist/assets/input-DUrq2DiR.js +1 -0
- package/dist/assets/isValid-DDt9wNjK.js +1 -0
- package/dist/assets/javascript-XMYUq5-t.js +1 -0
- package/dist/assets/journeyDiagram-XKPGCS4Q-CPDnALH5.js +139 -0
- package/dist/assets/julia-oON8zLDW.js +1 -0
- package/dist/assets/kanban-definition-3W4ZIXB7-D0-Tthpw.js +89 -0
- package/dist/assets/katex-CDLTCvjQ.js +261 -0
- package/dist/assets/katex-DF982Ty5.js +1 -0
- package/dist/assets/kbd-Cm6Ba9qg.js +1 -0
- package/dist/assets/kiosk-mode-WmM7aFkh.js +1 -0
- package/dist/assets/label-E64zk6_7.js +1 -0
- package/dist/assets/layout-_O8thjaV.js +5 -0
- package/dist/assets/line-BA7eTS55.js +1 -0
- package/dist/assets/linear-BWciPXnd.js +1 -0
- package/dist/assets/link-DxicfMbs.js +1 -0
- package/dist/assets/links-7AQBmdyV.js +1 -0
- package/dist/assets/links-DWIqY1l5.js +1 -0
- package/dist/assets/livescript--BxQO5G_.js +1 -0
- package/dist/assets/logs-panel-C3cavnFO.js +1 -0
- package/dist/assets/loro_wasm_bg-C3Vl7VMX.js +1 -0
- package/dist/assets/loro_wasm_bg-DzFUi5p_.js +2 -0
- package/dist/assets/loro_wasm_bg-WKwciKJa.wasm +0 -0
- package/dist/assets/lua-CUyaVUOv.js +1 -0
- package/dist/assets/maps-D2_Mq1pZ.js +1 -0
- package/dist/assets/markdown-renderer-DJy8ww5d.js +10 -0
- package/dist/assets/mathematica-ONd8izyd.js +1 -0
- package/dist/assets/mbox-kjl3g9N-.js +1 -0
- package/dist/assets/menu-items-BMjcEb2j.js +1 -0
- package/dist/assets/mermaid-4DMBBIKO-DyygmIT8.js +1 -0
- package/dist/assets/mermaid-parser.core-BLHYb13y.js +4 -0
- package/dist/assets/mermaid-y-IBDpJK.js +11 -0
- package/dist/assets/mhchem-ICopO0mb.js +1 -0
- package/dist/assets/mindmap-definition-VGOIOE7T-BflEJS3A.js +68 -0
- package/dist/assets/mirc-BZ6TyuOO.js +1 -0
- package/dist/assets/mllike-Dxt2U6MQ.js +1 -0
- package/dist/assets/mode-Bn7pdJvO.js +1 -0
- package/dist/assets/modelica-B9sdhdtj.js +1 -0
- package/dist/assets/mscgen-5e5Z5trn.js +1 -0
- package/dist/assets/multi-icon-jM74Rbvg.js +1 -0
- package/dist/assets/multi-map-DxdLNTBd.js +1 -0
- package/dist/assets/mumps-BUfWDrRe.js +1 -0
- package/dist/assets/name-cell-input-Bc7geMVf.js +1 -0
- package/dist/assets/nsis-Dq7T79DJ.js +1 -0
- package/dist/assets/nsis-QuE155sg.js +1 -0
- package/dist/assets/ntriples-Dqzi7kwu.js +1 -0
- package/dist/assets/number-overlay-editor-Dylprn80.js +9 -0
- package/dist/assets/octave-v4IgjFm5.js +1 -0
- package/dist/assets/ordinal-DG_POl79.js +1 -0
- package/dist/assets/outline-panel-Bxt_JABC.js +1 -0
- package/dist/assets/oz-BtUsXhbc.js +1 -0
- package/dist/assets/packages-panel-yEp7rAYf.js +1 -0
- package/dist/assets/packet-BFZMPI3H-C_EwQwCX.js +1 -0
- package/dist/assets/panel-context-HhzMRtZm.js +1 -0
- package/dist/assets/panels-IsIZwIow.js +1 -0
- package/dist/assets/pascal-DV7k6vJ0.js +1 -0
- package/dist/assets/perl-Bz7YaP_R.js +1 -0
- package/dist/assets/pie-7BOR55EZ-B2NFlNeo.js +1 -0
- package/dist/assets/pieDiagram-ADFJNKIX-DXRnX2TS.js +30 -0
- package/dist/assets/pig-BQWmcOEQ.js +1 -0
- package/dist/assets/play-GLWQQs7F.js +1 -0
- package/dist/assets/plus-B7DF33lD.js +1 -0
- package/dist/assets/popover-CH1FzjxU.js +1 -0
- package/dist/assets/powershell-CmIFs71i.js +1 -0
- package/dist/assets/process-output-ByfLnk6j.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-NA-6TsNe.js +1 -0
- 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-e3OVACTV.js +7 -0
- package/dist/assets/r-B0lU_x8o.js +1 -0
- package/dist/assets/radar-NHE76QYJ-C3XGuwbG.js +1 -0
- package/dist/assets/react-Bj1aDYRI.js +1 -0
- package/dist/assets/react-dom-CSu739Rf.js +1 -0
- package/dist/assets/react-plotly-kw5W3sN8.js +4030 -0
- package/dist/assets/react-resizable-panels.browser.esm-Da3ksQXL.js +1 -0
- package/dist/assets/react-vega-BL1HBBjq.js +190 -0
- package/dist/assets/react-vega-gERE3HQc.js +1 -0
- package/dist/assets/readonly-python-code-WjTf6Pdd.js +1 -0
- package/dist/assets/refresh-ccw-DN_xCV6A.js +1 -0
- package/dist/assets/refresh-cw-Dx8TEWFP.js +1 -0
- package/dist/assets/renderShortcut-BckyRbYt.js +1 -0
- package/dist/assets/request-registry-C5_pVc8Y.js +1 -0
- package/dist/assets/requests-B4FYHTZl.js +1 -0
- package/dist/assets/requests-De5yEBc8.js +1 -0
- package/dist/assets/requirementDiagram-UZGBJVZJ-DMbzgjKI.js +64 -0
- package/dist/assets/rotate-ccw-DPbJxVVN.js +1 -0
- package/dist/assets/rpm-BqQ3VFpY.js +1 -0
- package/dist/assets/ruby-AFh8QoqR.js +1 -0
- package/dist/assets/run-page-_7E2SCeQ.js +1 -0
- package/dist/assets/runs-YUGrkyfE.js +1 -0
- package/dist/assets/sankeyDiagram-TZEHDZUN-B90PTMUW.js +10 -0
- package/dist/assets/sas-CeRTI9sn.js +1 -0
- package/dist/assets/save-DZodxFnE.js +1 -0
- package/dist/assets/save-worker-CtJsIYIM.js +77 -0
- package/dist/assets/scheme-D0VcE_o1.js +1 -0
- package/dist/assets/scratchpad-panel-C6thsU6k.js +1 -0
- package/dist/assets/secrets-panel-Db_JucCn.js +1 -0
- package/dist/assets/select-BVdzZKAh.js +1 -0
- package/dist/assets/sequenceDiagram-WL72ISMW-DKFGl_80.js +145 -0
- package/dist/assets/session-panel-3zs_-lnF.js +1 -0
- package/dist/assets/settings-OBbrbhij.js +1 -0
- package/dist/assets/share-ipf2hrOh.js +1 -0
- package/dist/assets/shell-BBh9RTgS.js +1 -0
- package/dist/assets/sieve-BSX0MHaT.js +1 -0
- package/dist/assets/slides-component-JYH8kck6.js +1 -0
- package/dist/assets/smalltalk-PvrpLgKW.js +1 -0
- package/dist/assets/snippets-panel-Bbk7MFBI.js +1 -0
- package/dist/assets/sparql-CXsmb8zq.js +1 -0
- package/dist/assets/spec-Ch0xnJY4.js +1 -0
- package/dist/assets/spinner-DA8-7wQv.js +1 -0
- package/dist/assets/square-CuJ72M8f.js +1 -0
- package/dist/assets/square-function-B6mgCeFJ.js +1 -0
- package/dist/assets/src-CvyFXpBy.js +1 -0
- package/dist/assets/state-BrMfOLl1.js +1 -0
- package/dist/assets/state-D4T75eZb.js +1 -0
- package/dist/assets/stateDiagram-FKZM4ZOC-Czf6mxbq.js +1 -0
- package/dist/assets/stateDiagram-v2-4FDKWEC3-DT577w6p.js +1 -0
- package/dist/assets/step-CVy5FnKg.js +1 -0
- package/dist/assets/stex-Dn4qnyVB.js +1 -0
- package/dist/assets/stylus-B60bUBy2.js +1 -0
- package/dist/assets/swift-BwnHGvoR.js +1 -0
- package/dist/assets/switch-dWLWbbtg.js +1 -0
- package/dist/assets/table-CfDbAm78.js +1 -0
- package/dist/assets/table-DScsXgJW.js +1 -0
- package/dist/assets/tcl-Bj8phnhq.js +1 -0
- package/dist/assets/terminal-CjhjkmtR.js +62 -0
- package/dist/assets/textarea-CRI7xDBj.js +1 -0
- package/dist/assets/textile-WPCmEeGb.js +1 -0
- package/dist/assets/time-DkuObi5n.js +1 -0
- package/dist/assets/timeline-definition-IT6M3QCI-Cr57imdX.js +61 -0
- package/dist/assets/toDate-DETS9bBd.js +1 -0
- package/dist/assets/toggle-zVW4FXNz.js +1 -0
- package/dist/assets/toml-Cdfp0vaG.js +1 -0
- package/dist/assets/tooltip-CMQz28hC.js +1 -0
- package/dist/assets/tracing-U3RlLbPJ.js +1 -0
- package/dist/assets/tracing-panel-D6GhZuLA.js +2 -0
- package/dist/assets/trash-2-DDsWrxuJ.js +1 -0
- package/dist/assets/trash-DCF6Krvi.js +1 -0
- package/dist/assets/tree-B--q0-tu.js +3 -0
- package/dist/assets/treemap-KMMF4GRG-CQXdJ2ER.js +1 -0
- package/dist/assets/triangle-alert-CebQ7XwA.js +1 -0
- 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/types-BRfQN3HL.js +17 -0
- package/dist/assets/types-C1UhS3qM.js +1 -0
- package/dist/assets/use-toast-BDYuj3zG.js +1 -0
- package/dist/assets/useAddCell-CmuX2hOk.js +1 -0
- package/dist/assets/useAsyncData-BMGLSTg8.js +1 -0
- package/dist/assets/useBoolean-Ck_unDZw.js +1 -0
- package/dist/assets/useCellActionButton-DUDHPTmq.js +1 -0
- package/dist/assets/useDateFormatter-CqhdUl2n.js +1 -0
- package/dist/assets/useDebounce-7iEVSqwM.js +1 -0
- package/dist/assets/useDeepCompareMemoize-5OUgerQ3.js +1 -0
- package/dist/assets/useDeleteCell-DdRX94yC.js +1 -0
- package/dist/assets/useDependencyPanelTab-CeDmKn0Z.js +1 -0
- package/dist/assets/useEvent-BhXAndur.js +1 -0
- package/dist/assets/useEventListener-Cb-RVVEn.js +1 -0
- package/dist/assets/useIframeCapabilities-B_pQb20b.js +1 -0
- package/dist/assets/useInstallPackage-D4fX0Ee_.js +1 -0
- package/dist/assets/useInterval-B-PjgTm9.js +1 -0
- package/dist/assets/useLifecycle-ClI_npeg.js +1 -0
- package/dist/assets/useNonce-CS26E0hA.js +56 -0
- package/dist/assets/useNotebookActions-BFGSBiOA.js +1 -0
- package/dist/assets/useNumberFormatter-Db6Vjve5.js +1 -0
- package/dist/assets/usePress-C__vuri5.js +7 -0
- package/dist/assets/useRunCells-D2HBb4DB.js +1 -0
- package/dist/assets/useSplitCell-C4khe6eU.js +1 -0
- package/dist/assets/useTheme-DQozhcp1.js +1 -0
- package/dist/assets/utilities.esm-MA1QpjVT.js +3 -0
- package/dist/assets/utils-YqBXNpsM.js +1 -0
- package/dist/assets/vb-CSNH0UHQ.js +1 -0
- package/dist/assets/vbscript-DTgXfl5y.js +1 -0
- package/dist/assets/vega-component-D4L27L4Y.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-BPV9SmHz.js +120 -0
- package/dist/assets/workflow-BphwJiK3.js +1 -0
- package/dist/assets/write-secret-modal-1fGKmd5H.js +1 -0
- package/dist/assets/x-ZP5cObgf.js +1 -0
- package/dist/assets/xquery-DQLXMdMd.js +1 -0
- package/dist/assets/xychartDiagram-PRI3JC2R-DtYN6-1-.js +7 -0
- package/dist/assets/yacas-DlkZlCdY.js +1 -0
- package/dist/assets/youtube--tNPNRy6.js +1 -0
- package/dist/assets/z80-YKwwCjvZ.js +1 -0
- package/dist/assets/zod-H_cgTO0M.js +40 -0
- package/dist/index.html +139 -140
- package/package.json +18 -18
- package/src/components/app-config/ai-config.tsx +11 -2
- package/src/components/app-config/optional-features.tsx +1 -1
- package/src/components/app-config/user-config-form.tsx +0 -54
- package/src/components/chat/__tests__/useFileState.test.tsx +93 -0
- package/src/components/chat/acp/__tests__/state.test.ts +69 -0
- package/src/components/chat/acp/agent-panel.tsx +26 -77
- package/src/components/chat/acp/state.ts +6 -6
- package/src/components/chat/chat-components.tsx +114 -1
- package/src/components/chat/chat-panel.tsx +79 -134
- package/src/components/chat/chat-utils.ts +42 -0
- package/src/components/data-table/__tests__/data-table.test.tsx +94 -2
- package/src/components/editor/actions/useCellActionButton.tsx +14 -1
- package/src/components/editor/ai/add-cell-with-ai.tsx +85 -53
- package/src/components/editor/ai/ai-completion-editor.tsx +15 -38
- package/src/components/editor/cell/CreateCellButton.tsx +2 -1
- package/src/components/editor/cell/code/cell-editor.tsx +12 -0
- package/src/components/editor/chrome/panels/packages-panel.tsx +12 -9
- package/src/components/editor/database/__tests__/__snapshots__/as-code.test.ts.snap +15 -0
- package/src/components/editor/database/__tests__/as-code.test.ts +8 -0
- package/src/components/editor/database/as-code.ts +3 -0
- package/src/components/editor/database/schemas.ts +9 -0
- package/src/components/editor/renderers/cell-array.tsx +2 -1
- package/src/components/editor/renderers/vertical-layout/vertical-layout.tsx +12 -0
- package/src/components/pages/gallery-page.tsx +37 -6
- package/src/core/MarimoApp.tsx +12 -8
- package/src/core/ai/context/providers/file.ts +1 -1
- package/src/core/cells/__tests__/cells.test.ts +120 -0
- package/src/core/cells/__tests__/session.test.ts +37 -1
- package/src/core/cells/cells.ts +14 -0
- package/src/core/cells/session.ts +20 -8
- package/src/core/codemirror/language/languages/markdown.ts +7 -0
- package/src/core/config/feature-flag.tsx +0 -4
- package/src/core/dom/uiregistry.ts +4 -1
- package/src/core/islands/__tests__/bridge.test.ts +7 -2
- package/src/core/islands/bridge.ts +1 -1
- package/src/core/islands/main.ts +7 -0
- package/src/core/network/types.ts +2 -2
- package/src/core/run-app.tsx +11 -4
- package/src/core/static/__tests__/files.test.ts +195 -1
- package/src/core/static/files.ts +39 -9
- package/src/core/wasm/bridge.ts +1 -1
- package/src/core/websocket/useMarimoKernelConnection.tsx +5 -15
- package/src/plugins/core/registerReactComponent.tsx +9 -1
- package/src/plugins/impl/__tests__/DataTablePlugin.test.tsx +164 -0
- package/src/plugins/impl/anywidget/AnyWidgetPlugin.tsx +93 -168
- package/src/plugins/impl/anywidget/__tests__/AnyWidgetPlugin.test.tsx +37 -123
- package/src/plugins/impl/anywidget/__tests__/model.test.ts +128 -122
- package/src/plugins/impl/anywidget/__tests__/serialization.test.ts +457 -0
- package/src/plugins/impl/anywidget/model.ts +348 -223
- package/src/plugins/impl/anywidget/schemas.ts +32 -0
- package/src/plugins/impl/anywidget/serialization.ts +120 -0
- package/src/plugins/impl/anywidget/types.ts +27 -0
- package/src/plugins/impl/chat/chat-ui.tsx +22 -20
- package/src/utils/Deferred.ts +21 -0
- package/src/utils/__tests__/blob.test.ts +3 -3
- package/src/utils/__tests__/id-tree.test.ts +22 -7
- package/src/utils/__tests__/mime-types.test.ts +8 -10
- package/src/utils/__tests__/url-parser.test.ts +22 -0
- package/src/utils/blob.ts +14 -27
- package/src/utils/id-tree.tsx +11 -19
- package/src/utils/json/base64.ts +38 -8
- package/src/utils/mime-types.ts +5 -5
- package/src/utils/url-parser.ts +1 -1
- package/dist/assets/CellStatus-CTtb89yx.js +0 -1
- package/dist/assets/Combination-C_mRvd_Z.js +0 -41
- package/dist/assets/ConnectedDataExplorerComponent-CX7YQX42.js +0 -1
- package/dist/assets/Deferred-CrO5-0RA.js +0 -1
- package/dist/assets/DeferredRequestRegistry-CO2AyNfd.js +0 -1
- package/dist/assets/ErrorBoundary-ChCiwl15.js +0 -1
- package/dist/assets/ImageComparisonComponent-BVBGmVcA.js +0 -1
- package/dist/assets/ImperativeModal-CKeCkc1k.js +0 -1
- package/dist/assets/Inputs-CBxLLWdV.js +0 -1
- package/dist/assets/JsonOutput-BTBD86gT.js +0 -46
- package/dist/assets/LazyAnyLanguageCodeMirror-Be7SB10I.js +0 -2
- package/dist/assets/MarimoErrorOutput-DuaUr0W-.js +0 -7
- package/dist/assets/RenderHTML-IBhB_MjX.js +0 -1
- package/dist/assets/SSRProvider-DBS9qs3r.js +0 -1
- package/dist/assets/__vite-browser-external-BkzFKOxE.js +0 -1
- package/dist/assets/__vite-browser-external-CPyDqUtZ.js +0 -1
- package/dist/assets/add-cell-with-ai-DsiiVErB.js +0 -90
- package/dist/assets/add-database-form-B1frIn24.js +0 -111
- package/dist/assets/agent-panel-B_Ur2utx.js +0 -287
- package/dist/assets/ai-model-dropdown-Dix8JIRc.js +0 -5
- package/dist/assets/alert-adkp2Qj8.js +0 -1
- package/dist/assets/alert-dialog-CordKci7.js +0 -11
- package/dist/assets/any-language-editor-Z9d2XKUM.js +0 -3
- package/dist/assets/apl-DpOiWl6J.js +0 -1
- package/dist/assets/app-config-button-CYFJH9oz.js +0 -1
- package/dist/assets/arc-xh3ZebK_.js +0 -1
- package/dist/assets/architecture-U656AL7Q-DQB1ihe9.js +0 -1
- package/dist/assets/architectureDiagram-VXUJARFQ-B-zQV2Ro.js +0 -36
- package/dist/assets/arrow-left-Cb_73j1f.js +0 -1
- package/dist/assets/asciiarmor-DVIuYySe.js +0 -1
- package/dist/assets/asn1-CWHjZJq6.js +0 -1
- package/dist/assets/badge-Ce8wRjuQ.js +0 -1
- package/dist/assets/blob-t6qcPM7K.js +0 -1
- package/dist/assets/blockDiagram-VD42YOAC-B7BRAty8.js +0 -122
- package/dist/assets/brainfuck-CIKJewgG.js +0 -1
- package/dist/assets/bundle.esm-B-jCcPJK.js +0 -1
- package/dist/assets/button-YC1gW_kJ.js +0 -1
- package/dist/assets/c4Diagram-YG6GDRKO-C5JyC9v_.js +0 -10
- package/dist/assets/cache-panel-BfCxvTOh.js +0 -1
- package/dist/assets/card-BAxUmnnT.js +0 -1
- package/dist/assets/cell-editor-BQ5bBOiS.js +0 -23
- package/dist/assets/cell-link-DW0zobk9.js +0 -1
- package/dist/assets/cells-BcMpgRWV.js +0 -254
- package/dist/assets/channel-ownMsSXG.js +0 -1
- package/dist/assets/chart-no-axes-column-W42b2ZIs.js +0 -1
- package/dist/assets/chat-components-BpIX7pUp.js +0 -1
- package/dist/assets/chat-display-CVXM0cmr.js +0 -1
- package/dist/assets/chat-panel-FiDMP_Qr.js +0 -3
- package/dist/assets/check-DdfN0k2d.js +0 -1
- package/dist/assets/chevron-right-DwagBitu.js +0 -1
- package/dist/assets/chunk-4BX2VUAB-BP-RGZn9.js +0 -1
- package/dist/assets/chunk-55IACEB6-NZRDKuqH.js +0 -1
- package/dist/assets/chunk-5FQGJX7Z-Bmb7yu_c.js +0 -113
- package/dist/assets/chunk-ABZYJK2D-Coo5qi7b.js +0 -80
- package/dist/assets/chunk-ATLVNIR6-C0ULYreM.js +0 -1
- package/dist/assets/chunk-B4BG7PRW-D6Q5lT5Z.js +0 -165
- package/dist/assets/chunk-CVBHYZKI-Brsoob-W.js +0 -1
- package/dist/assets/chunk-DI55MBZ5-BUUtkB-8.js +0 -220
- package/dist/assets/chunk-EXTU4WIE-DQy5cN5X.js +0 -1
- package/dist/assets/chunk-FMBD7UC4-kejklSRQ.js +0 -15
- package/dist/assets/chunk-HN2XXSSU-BBxJMYrA.js +0 -1
- package/dist/assets/chunk-JA3XYJ7Z-99Y1UR46.js +0 -70
- package/dist/assets/chunk-JZLCHNYA-DRGkEV50.js +0 -54
- package/dist/assets/chunk-MI3HLSF2-D6we5Ftb.js +0 -32
- package/dist/assets/chunk-N4CR4FBY-DHFG9ldR.js +0 -2
- package/dist/assets/chunk-QN33PNHL-DB8FgLRd.js +0 -1
- package/dist/assets/chunk-QXUST7PY-_zxuSm7L.js +0 -7
- package/dist/assets/chunk-QZHKN3VN-DCq7JxLD.js +0 -1
- package/dist/assets/chunk-S3R3BYOJ-PVCoxQeQ.js +0 -2
- package/dist/assets/chunk-TZMSLE5B-KYGSDxPK.js +0 -1
- package/dist/assets/circle-check-C57eOpl0.js +0 -1
- package/dist/assets/circle-play-BuOtSgid.js +0 -1
- package/dist/assets/circle-plus-CnWl9uZo.js +0 -1
- package/dist/assets/classDiagram-2ON5EDUG-CSgD2v8F.js +0 -1
- package/dist/assets/classDiagram-v2-WZHVMYZB-YTETTIT0.js +0 -1
- package/dist/assets/clear-button-CF0iBcV9.js +0 -1
- package/dist/assets/click-outside-container-B12FHFHm.js +0 -1
- package/dist/assets/clike-wo4CVrJj.js +0 -1
- package/dist/assets/clipboard-paste-BiDF-cqm.js +0 -1
- package/dist/assets/clojure-CTxjMkBI.js +0 -1
- package/dist/assets/cmake-aJ0aGjat.js +0 -1
- package/dist/assets/cobol-Dw9T4cw-.js +0 -1
- package/dist/assets/code-block-37QAKDTI-D5PRUB7R.js +0 -2
- package/dist/assets/code-xml-XLwHyDBr.js +0 -1
- package/dist/assets/coffeescript-B5HCKl_0.js +0 -1
- package/dist/assets/column-preview-v3J210SK.js +0 -1
- package/dist/assets/command-DOzj5zu3.js +0 -1
- package/dist/assets/command-palette-B94wuFEk.js +0 -1
- package/dist/assets/common-DHF6uQdA.js +0 -1
- package/dist/assets/commonlisp-C578hhl1.js +0 -1
- package/dist/assets/compiler-runtime-DeeZ7FnK.js +0 -1
- package/dist/assets/config-C3-Nti03.js +0 -1
- package/dist/assets/context-CJp-B2dx.js +0 -1
- package/dist/assets/copy-CQ15EONK.js +0 -1
- package/dist/assets/copy-icon-C1fNHY3M.js +0 -1
- package/dist/assets/cose-bilkent-S5V4N54A-vYRNxW8r.js +0 -1
- package/dist/assets/createLucideIcon-CnW3RofX.js +0 -1
- package/dist/assets/createReducer-Dnna-AUO.js +0 -1
- package/dist/assets/crystal-D84c1nzD.js +0 -1
- package/dist/assets/css-BJsW3aHa.js +0 -1
- package/dist/assets/cypher-DBO3MHmN.js +0 -1
- package/dist/assets/d-KvHiAR3H.js +0 -1
- package/dist/assets/dagre-6UL2VRFP-khPiqbzB.js +0 -4
- package/dist/assets/data-grid-overlay-editor-Ca1ELXWD.js +0 -1
- package/dist/assets/database-zap-B9y7063w.js +0 -1
- package/dist/assets/datasource-BZ3O2HG1.js +0 -3
- package/dist/assets/dates-Cx863TsG.js +0 -1
- package/dist/assets/dependency-graph-panel-s45LIDec.js +0 -4
- package/dist/assets/diagram-PSM6KHXK-C7-DZLOE.js +0 -24
- package/dist/assets/diagram-QEK2KX5R-Ct2_XsRV.js +0 -43
- package/dist/assets/diagram-S2PKOQOG-C82IZoPA.js +0 -24
- package/dist/assets/dialog-Dstm3Ubn.js +0 -1
- package/dist/assets/diff-BmUpKGx-.js +0 -1
- package/dist/assets/dist-1nstYXhq.js +0 -1
- package/dist/assets/dist-2qScxWoK.js +0 -1
- package/dist/assets/dist-8LCoAaYJ.js +0 -1
- package/dist/assets/dist-B1CD4nG7.js +0 -1
- package/dist/assets/dist-B407S7D_.js +0 -1
- package/dist/assets/dist-B6bNYRJb.js +0 -1
- package/dist/assets/dist-BKMynip3.js +0 -1
- package/dist/assets/dist-BP1tfplb.js +0 -1
- package/dist/assets/dist-BSxIk2Vq.js +0 -1
- package/dist/assets/dist-BcotcL0h.js +0 -1
- package/dist/assets/dist-BhLw_JdQ.js +0 -1
- package/dist/assets/dist-BtUqLXS9.js +0 -1
- package/dist/assets/dist-BuwU3nUf.js +0 -1
- package/dist/assets/dist-BwcKpTZt.js +0 -1
- package/dist/assets/dist-C0QU3Oay.js +0 -1
- package/dist/assets/dist-CNknMFYG.js +0 -1
- package/dist/assets/dist-Cayq-K1c.js +0 -6
- package/dist/assets/dist-Cip4Ndtd.js +0 -1
- package/dist/assets/dist-DGPkGdD2.js +0 -1
- package/dist/assets/dist-DXT0W0hS.js +0 -1
- package/dist/assets/dist-DrFRlZJz.js +0 -1
- package/dist/assets/dist-DstaRs6N.js +0 -1
- package/dist/assets/dist-DzjeKTWA.js +0 -1
- package/dist/assets/dist-GCDTTvNx.js +0 -1
- package/dist/assets/dist-PT7WsOdN.js +0 -1
- package/dist/assets/dist-QPLTo43F.js +0 -1
- package/dist/assets/dist-SpkGM8op.js +0 -1
- package/dist/assets/dist-TiFCI16_.js +0 -1
- package/dist/assets/dist-YQMqR1ri.js +0 -1
- package/dist/assets/dist-h7FGpi6W.js +0 -1
- package/dist/assets/dist-oarhZoo6.js +0 -1
- package/dist/assets/dockerfile-BPCA7-hu.js +0 -1
- package/dist/assets/documentation-panel-DRqbOPwM.js +0 -1
- package/dist/assets/download-B9SUL40m.js +0 -1
- package/dist/assets/download-zuPzhwvm.js +0 -9
- package/dist/assets/dropdown-menu-D8v7RjW8.js +0 -1
- package/dist/assets/dtd-Dwf-AbUl.js +0 -1
- package/dist/assets/dylan-VHUB-7ez.js +0 -1
- package/dist/assets/ecl-DvGrObaA.js +0 -1
- package/dist/assets/edit-page-Dlr4v1eI.js +0 -13
- package/dist/assets/eiffel-CUYga93e.js +0 -1
- package/dist/assets/ellipsis-5ip-qDfN.js +0 -1
- package/dist/assets/ellipsis-vertical-C7jYiLCo.js +0 -1
- package/dist/assets/elm-BhMhmEP6.js +0 -1
- package/dist/assets/empty-state-BAGXXrn8.js +0 -1
- package/dist/assets/en-US-XLBup7bs.js +0 -1
- package/dist/assets/erDiagram-Q2GNP2WA-Ftt2qDiM.js +0 -60
- package/dist/assets/erlang-D4xbdJFD.js +0 -1
- package/dist/assets/error-banner-JIexM8h5.js +0 -1
- package/dist/assets/error-panel-TqjIx6nC.js +0 -1
- package/dist/assets/errors-B5AI4nf5.js +0 -1
- package/dist/assets/es-CPSXxuS6.js +0 -5
- package/dist/assets/esm-BbNm2fB0.js +0 -1
- package/dist/assets/esm-BmQh-C2G.js +0 -1
- package/dist/assets/eye-off-BhExYOph.js +0 -1
- package/dist/assets/factor-C0grrWrC.js +0 -1
- package/dist/assets/factor-Ccw_GUUV.js +0 -1
- package/dist/assets/field-1uCBX4j4.js +0 -1
- package/dist/assets/file-Cs1JbsV6.js +0 -1
- package/dist/assets/file-explorer-panel-jku_uMQn.js +0 -1
- package/dist/assets/file-plus-corner-Da9I6dgU.js +0 -1
- package/dist/assets/file-video-camera-DW3v07j2.js +0 -1
- package/dist/assets/floating-outline-CZbF47gm.js +0 -1
- package/dist/assets/flowDiagram-NV44I4VS-Ca9aZp-3.js +0 -162
- package/dist/assets/focus-BxGelf2n.js +0 -1
- package/dist/assets/form-DQt-Ldr4.js +0 -2
- package/dist/assets/forth-CSTdXn4A.js +0 -1
- package/dist/assets/fortran-fENQO2l9.js +0 -1
- package/dist/assets/gallery-page-D_5X4kKx.js +0 -1
- package/dist/assets/ganttDiagram-JELNMOA3-PYFPdyuJ.js +0 -267
- package/dist/assets/gas-CPJMP4zj.js +0 -1
- package/dist/assets/gherkin-CiUmN4EE.js +0 -1
- package/dist/assets/gitGraph-F6HP7TQM-ULnyMCh9.js +0 -1
- package/dist/assets/gitGraphDiagram-NY62KEGX-CfGWoYOo.js +0 -65
- package/dist/assets/glide-data-editor-8ek3zzAO.js +0 -132
- package/dist/assets/globals-D4t_HyAp.js +0 -1
- package/dist/assets/groovy-DMooZA1X.js +0 -1
- package/dist/assets/haskell-sDlThg6u.js +0 -1
- package/dist/assets/haxe-Do80ITri.js +0 -1
- package/dist/assets/home-page-xDhfcHL1.js +0 -4
- package/dist/assets/hooks-MQa8CSUr.js +0 -1
- package/dist/assets/house-DhFkiXz7.js +0 -1
- package/dist/assets/html-to-image-DKqpcM7V.js +0 -2
- package/dist/assets/icons-Dw4USSvE.js +0 -1
- package/dist/assets/idl-DFPg6k4F.js +0 -1
- package/dist/assets/index-CikhHYAB.css +0 -2
- package/dist/assets/index-DuqUGjtK.js +0 -38
- package/dist/assets/info-NVLQJR56-gsco60Pt.js +0 -1
- package/dist/assets/infoDiagram-WHAUD3N6-Csbwq6Ks.js +0 -2
- package/dist/assets/input-DcAGg_4_.js +0 -1
- package/dist/assets/isValid-BLB2jskA.js +0 -1
- package/dist/assets/javascript-BGc4iHiT.js +0 -1
- package/dist/assets/journeyDiagram-XKPGCS4Q-DArwMxlY.js +0 -139
- package/dist/assets/julia-BHNHVraD.js +0 -1
- package/dist/assets/kanban-definition-3W4ZIXB7-CPjBJiO_.js +0 -89
- package/dist/assets/katex-BZrXWsTs.js +0 -1
- package/dist/assets/katex-DYp6oq7P.js +0 -261
- package/dist/assets/kbd-uRyPZ9w_.js +0 -1
- package/dist/assets/kiosk-mode-C9XznhoS.js +0 -1
- package/dist/assets/label-CL9Xfexh.js +0 -1
- package/dist/assets/layout-D-YPCWvX.js +0 -5
- package/dist/assets/line-VKarCWVL.js +0 -1
- package/dist/assets/linear-BxhToEEF.js +0 -1
- package/dist/assets/link-BsTPF7B0.js +0 -1
- package/dist/assets/links-BhgWpHdU.js +0 -1
- package/dist/assets/links-DgZx-VxW.js +0 -1
- package/dist/assets/livescript-Bv2FpOTI.js +0 -1
- package/dist/assets/logs-panel-DKSJRyF4.js +0 -1
- package/dist/assets/loro_wasm_bg-BnAHSQ7o.js +0 -2
- package/dist/assets/loro_wasm_bg-CKQGJrH5.js +0 -1
- package/dist/assets/loro_wasm_bg-DV7Kb4_M.wasm +0 -0
- package/dist/assets/lua-BysKHKPZ.js +0 -1
- package/dist/assets/maps-t9yNKYA8.js +0 -1
- package/dist/assets/markdown-renderer-Bu12gPyJ.js +0 -10
- package/dist/assets/mathematica-BBTHoTvM.js +0 -1
- package/dist/assets/mbox-DeT9_lvk.js +0 -1
- package/dist/assets/menu-items-NblnuU_B.js +0 -1
- package/dist/assets/mermaid-4DMBBIKO-RE7Z6-fl.js +0 -1
- package/dist/assets/mermaid-Bzaf_nA9.js +0 -11
- package/dist/assets/mermaid-parser.core-D237JwYN.js +0 -4
- package/dist/assets/mhchem-DLDYYsJK.js +0 -1
- package/dist/assets/mindmap-definition-VGOIOE7T-DVB4z5Yy.js +0 -68
- package/dist/assets/mirc-D5fMSrXQ.js +0 -1
- package/dist/assets/mllike-BtxCpmpf.js +0 -1
- package/dist/assets/mode-CevBiFCd.js +0 -1
- package/dist/assets/modelica-CRQcZpK6.js +0 -1
- package/dist/assets/mscgen-BfscU11q.js +0 -1
- package/dist/assets/multi-icon-CLzAg610.js +0 -1
- package/dist/assets/multi-map-W4zci54U.js +0 -1
- package/dist/assets/mumps-g7ooySbl.js +0 -1
- package/dist/assets/name-cell-input-DwvdP1Ck.js +0 -1
- package/dist/assets/nsis-BtyCmCHZ.js +0 -1
- package/dist/assets/nsis-CzZqoCdu.js +0 -1
- package/dist/assets/ntriples-DLyxF-NO.js +0 -1
- package/dist/assets/number-overlay-editor-CvIcqV0W.js +0 -9
- package/dist/assets/octave-CFXP_zzr.js +0 -1
- package/dist/assets/ordinal-C93T4L8H.js +0 -1
- package/dist/assets/outline-panel-Bg_CP1WV.js +0 -1
- package/dist/assets/oz-CrQbC0N_.js +0 -1
- package/dist/assets/packages-panel-DBgrbk-q.js +0 -1
- package/dist/assets/packet-BFZMPI3H-CnHEXEVi.js +0 -1
- package/dist/assets/panel-context-C-UJlFyL.js +0 -1
- package/dist/assets/panels-CaoDGKmF.js +0 -1
- package/dist/assets/pascal-CCSZgYZH.js +0 -1
- package/dist/assets/perl-Bc1MycMl.js +0 -1
- package/dist/assets/pie-7BOR55EZ-C5Sp4r8f.js +0 -1
- package/dist/assets/pieDiagram-ADFJNKIX-vwwb5uL8.js +0 -30
- package/dist/assets/pig-CDr04RdE.js +0 -1
- package/dist/assets/play-BPIh-ZEU.js +0 -1
- package/dist/assets/plus-BD5o34_i.js +0 -1
- package/dist/assets/popover-BZZFx3Q8.js +0 -1
- package/dist/assets/powershell-DcvrUwmh.js +0 -1
- package/dist/assets/process-output-Cl2N-HlT.js +0 -1
- package/dist/assets/properties-Y8OgFJMt.js +0 -1
- package/dist/assets/protobuf-Dyx-ENis.js +0 -1
- package/dist/assets/pug-BqLMXh-D.js +0 -1
- package/dist/assets/pug-T7qjkmFh.js +0 -1
- package/dist/assets/puppet-BzYSg90u.js +0 -1
- package/dist/assets/python-D4S7tVrv.js +0 -1
- package/dist/assets/q-YpqabiSl.js +0 -1
- package/dist/assets/quadrantDiagram-AYHSOK5B-Y8bEZ32G.js +0 -7
- package/dist/assets/r-DzpuVbmQ.js +0 -1
- package/dist/assets/radar-NHE76QYJ-DAElyE_r.js +0 -1
- package/dist/assets/react-BGmjiNul.js +0 -1
- package/dist/assets/react-dom-C9fstfnp.js +0 -1
- package/dist/assets/react-plotly-CZMBCa5P.js +0 -4030
- package/dist/assets/react-resizable-panels.browser.esm-BFvP7Upm.js +0 -1
- package/dist/assets/react-vega-BCDifxTe.js +0 -190
- package/dist/assets/react-vega-DkHO4e2L.js +0 -1
- package/dist/assets/readonly-python-code-H1kzT-lB.js +0 -1
- package/dist/assets/refresh-ccw-DLEiQDS3.js +0 -1
- package/dist/assets/refresh-cw-CQd-1kjx.js +0 -1
- package/dist/assets/renderShortcut-zxgoVTeP.js +0 -1
- package/dist/assets/request-registry-CjZcQuTP.js +0 -1
- package/dist/assets/requests-BSPGoGJL.js +0 -1
- package/dist/assets/requests-BsVD4CdD.js +0 -1
- package/dist/assets/requirementDiagram-UZGBJVZJ-ChckaTrX.js +0 -64
- package/dist/assets/rotate-ccw-B_yU4f05.js +0 -1
- package/dist/assets/rpm-DlmAEsH3.js +0 -1
- package/dist/assets/ruby-BHSBK3B4.js +0 -1
- package/dist/assets/run-page-BmTC7uxn.js +0 -1
- package/dist/assets/runs-X54OGDTq.js +0 -1
- package/dist/assets/sankeyDiagram-TZEHDZUN-DtU4O0-i.js +0 -10
- package/dist/assets/sas-DmQmrPAn.js +0 -1
- package/dist/assets/save-PMHbdtqc.js +0 -1
- package/dist/assets/save-worker-DtF6B3PS.js +0 -77
- package/dist/assets/scheme-CZHvt0eC.js +0 -1
- package/dist/assets/scratchpad-panel-CIxZIJ-1.js +0 -1
- package/dist/assets/secrets-panel-TwfjwIVv.js +0 -1
- package/dist/assets/select-CX1Yi8J8.js +0 -1
- package/dist/assets/sequenceDiagram-WL72ISMW-BGXrTemh.js +0 -145
- package/dist/assets/session-panel-CNeWVmTR.js +0 -1
- package/dist/assets/settings-DOXWMfVd.js +0 -1
- package/dist/assets/share-Ba-pHZtq.js +0 -1
- package/dist/assets/shell-BJzvpTMz.js +0 -1
- package/dist/assets/sieve-DGjPhm-6.js +0 -1
- package/dist/assets/slides-component-CGMJm_kL.js +0 -1
- package/dist/assets/smalltalk-DaG60CSr.js +0 -1
- package/dist/assets/snippets-panel-DMN_ZSXA.js +0 -1
- package/dist/assets/sparql-CN49rXKB.js +0 -1
- package/dist/assets/spec-D1kBp3jX.js +0 -1
- package/dist/assets/spinner-DaIKav-i.js +0 -1
- package/dist/assets/square-C8Tw_XXG.js +0 -1
- package/dist/assets/square-function-CqXXKtIq.js +0 -1
- package/dist/assets/src-DJ8ZKoFs.js +0 -1
- package/dist/assets/state-BLsnFVwy.js +0 -1
- package/dist/assets/state-n1Xz9vt7.js +0 -1
- package/dist/assets/stateDiagram-FKZM4ZOC-BwSf7RIr.js +0 -1
- package/dist/assets/stateDiagram-v2-4FDKWEC3-SWMI9LKY.js +0 -1
- package/dist/assets/step-DGkZosD0.js +0 -1
- package/dist/assets/stex-D6sqtveI.js +0 -1
- package/dist/assets/stylus-CzHZ_0CL.js +0 -1
- package/dist/assets/swift-5fr5bTbW.js +0 -1
- package/dist/assets/switch-CfRu5JBF.js +0 -1
- package/dist/assets/table-DZR6ewbN.js +0 -1
- package/dist/assets/table-qbh6Daed.js +0 -1
- package/dist/assets/tcl-D5oaR_GS.js +0 -1
- package/dist/assets/terminal-C0fH4d_0.js +0 -62
- package/dist/assets/textarea-3ZXdUni1.js +0 -1
- package/dist/assets/textile-CJ5e8-7o.js +0 -1
- package/dist/assets/time-EL4bnqqQ.js +0 -1
- package/dist/assets/timeline-definition-IT6M3QCI-BZakpQwy.js +0 -61
- package/dist/assets/toDate-CgbKQM5E.js +0 -1
- package/dist/assets/toggle-CWS-iCmF.js +0 -1
- package/dist/assets/toml-D9QwsDZO.js +0 -1
- package/dist/assets/tooltip-DH6k_bBY.js +0 -1
- package/dist/assets/tracing-panel-DogOVTzf.js +0 -2
- package/dist/assets/tracing-zzjDz6Hy.js +0 -1
- package/dist/assets/trash-2-CyqGun26.js +0 -1
- package/dist/assets/trash-DMqDgJ5r.js +0 -1
- package/dist/assets/tree-DHpFOpHo.js +0 -3
- package/dist/assets/treemap-KMMF4GRG-Bf9yeA5X.js +0 -1
- package/dist/assets/triangle-alert-B65rDESJ.js +0 -1
- package/dist/assets/troff-DlwQJbfr.js +0 -1
- package/dist/assets/ttcn-DUvoO9Vo.js +0 -1
- package/dist/assets/ttcn-cfg-Cj-t-B3M.js +0 -1
- package/dist/assets/turtle-DzvxCIjc.js +0 -1
- package/dist/assets/types-CS34eOZi.js +0 -1
- package/dist/assets/types-CW-zyy80.js +0 -17
- package/dist/assets/use-toast-rmUWldD_.js +0 -1
- package/dist/assets/useAddCell-mkD8zurm.js +0 -1
- package/dist/assets/useAsyncData-BAVCkkQP.js +0 -1
- package/dist/assets/useBoolean-BjVFTMam.js +0 -1
- package/dist/assets/useCellActionButton-BZ46_Pdt.js +0 -1
- package/dist/assets/useDateFormatter-D89e9xZY.js +0 -1
- package/dist/assets/useDebounce-CU_caGaU.js +0 -1
- package/dist/assets/useDeepCompareMemoize-DiyglPgJ.js +0 -1
- package/dist/assets/useDeleteCell-B8CxYiji.js +0 -1
- package/dist/assets/useDependencyPanelTab-YtWR0xDK.js +0 -1
- package/dist/assets/useEvent-DO6uJBas.js +0 -1
- package/dist/assets/useEventListener-DIUKKfEy.js +0 -1
- package/dist/assets/useIframeCapabilities-DzIlROXe.js +0 -1
- package/dist/assets/useInstallPackage-C-gjrVjb.js +0 -1
- package/dist/assets/useInterval-y9MtYlSD.js +0 -1
- package/dist/assets/useLifecycle-D35CBukS.js +0 -1
- package/dist/assets/useNonce-_Aax6sXd.js +0 -56
- package/dist/assets/useNotebookActions-Dfh_7NPm.js +0 -1
- package/dist/assets/useNumberFormatter-CTkflual.js +0 -1
- package/dist/assets/usePress-CoEeT5jq.js +0 -7
- package/dist/assets/useRunCells-rjrIgU8v.js +0 -1
- package/dist/assets/useSplitCell-fcjSuBNO.js +0 -1
- package/dist/assets/useTheme-EGf2UOFo.js +0 -1
- package/dist/assets/utilities.esm-CkqwfzLw.js +0 -3
- package/dist/assets/utils-DXvhzCGS.js +0 -1
- package/dist/assets/vb-Caf126uo.js +0 -1
- package/dist/assets/vbscript-BgRl-LR8.js +0 -1
- package/dist/assets/vega-component-DAJbxD47.js +0 -1
- package/dist/assets/velocity-CpvfwasF.js +0 -1
- package/dist/assets/verilog-hsHogyKv.js +0 -1
- package/dist/assets/vhdl-FciHazR1.js +0 -1
- package/dist/assets/webidl-CqjZNx5V.js +0 -1
- package/dist/assets/worker-CUL1lW-N.js +0 -120
- package/dist/assets/workflow-CMjI9cxl.js +0 -1
- package/dist/assets/write-secret-modal-CgAvgY9w.js +0 -1
- package/dist/assets/x-CoXDX2vQ.js +0 -1
- package/dist/assets/xquery-DpTaL2IT.js +0 -1
- package/dist/assets/xychartDiagram-PRI3JC2R-CAHFvN1H.js +0 -7
- package/dist/assets/yacas-D6bbkHsk.js +0 -1
- package/dist/assets/youtube-8p26v8EM.js +0 -1
- package/dist/assets/z80-MlujNizn.js +0 -1
- package/dist/assets/zod-Cg4WLWh2.js +0 -40
- package/src/utils/__tests__/data-views.test.ts +0 -511
- package/src/utils/data-views.ts +0 -143
- /package/dist/assets/{apl-CpVTW0fY.js → apl-DHQPYmx2.js} +0 -0
- /package/dist/assets/{array-BKCdRGCR.js → array-Cf4PUXPA.js} +0 -0
- /package/dist/assets/{asciiarmor-qDK46YPd.js → asciiarmor-fnQAw8T8.js} +0 -0
- /package/dist/assets/{asn1-s2ZJql-T.js → asn1-5lb7I37s.js} +0 -0
- /package/dist/assets/{asterisk-Cy-53Fu-.js → asterisk-B04IJwAt.js} +0 -0
- /package/dist/assets/{brainfuck-5fD7ZBSv.js → brainfuck-D30bRgvC.js} +0 -0
- /package/dist/assets/{chunk-76Q3JFCE-B261Xkae.js → chunk-76Q3JFCE-BAZ3z-Fu.js} +0 -0
- /package/dist/assets/{chunk-FWNWRKHM-C0b0DIG0.js → chunk-FWNWRKHM-DzIkWreD.js} +0 -0
- /package/dist/assets/{chunk-LBM3YZW2-D3uTpSOd.js → chunk-LBM3YZW2-BRBe7ZaP.js} +0 -0
- /package/dist/assets/{chunk-LHMN2FUI-2FK1AIwU.js → chunk-LHMN2FUI-C4onQD9F.js} +0 -0
- /package/dist/assets/{chunk-O7ZBX7Z2-DoE29Zoe.js → chunk-O7ZBX7Z2-CFqB9i7k.js} +0 -0
- /package/dist/assets/{chunk-S6J4BHB3-Cvr0itXK.js → chunk-S6J4BHB3-C4KwSfr_.js} +0 -0
- /package/dist/assets/{chunk-T53DSG4Q-C7bPrBIt.js → chunk-T53DSG4Q-Bhd043Cg.js} +0 -0
- /package/dist/assets/{chunk-XAJISQIX-TwS9jXHm.js → chunk-XAJISQIX-0gvwv13B.js} +0 -0
- /package/dist/assets/{clike-D58k-9vu.js → clike-jZeb2kFn.js} +0 -0
- /package/dist/assets/{clojure-Dkfjc-Fr.js → clojure-C0pkR8m2.js} +0 -0
- /package/dist/assets/{cmake-ffkxaUPf.js → cmake-DlvFtk_M.js} +0 -0
- /package/dist/assets/{cobol-CKARYRbQ.js → cobol-C_yb45mr.js} +0 -0
- /package/dist/assets/{coffeescript-Dz_r13Pd.js → coffeescript-DBK0AeMT.js} +0 -0
- /package/dist/assets/{colors-CUF0x3zZ.js → colors-DUsH-HF1.js} +0 -0
- /package/dist/assets/{common-keywords-CU-S2Vqm.js → common-keywords-D6ImdZX8.js} +0 -0
- /package/dist/assets/{commonlisp-EavL1_-N.js → commonlisp-Bo8hOdn-.js} +0 -0
- /package/dist/assets/{crystal-BQ8grXRY.js → crystal-DYrQEMVi.js} +0 -0
- /package/dist/assets/{css-Bmqfl4iE.js → css-zh47N2UC.js} +0 -0
- /package/dist/assets/{cypher-BKXIqXpT.js → cypher-BWPAHm69.js} +0 -0
- /package/dist/assets/{cytoscape.esm-BihqZ2_-.js → cytoscape.esm-BauVghWH.js} +0 -0
- /package/dist/assets/{d-DRfFJaS4.js → d-CMuL95tt.js} +0 -0
- /package/dist/assets/{diff-BWk1g4qN.js → diff-oor_HZ51.js} +0 -0
- /package/dist/assets/{dist-qIIHXwC_.js → dist-B62Xo7-b.js} +0 -0
- /package/dist/assets/{dist-Bx6F_B1m.js → dist-B83wRp_v.js} +0 -0
- /package/dist/assets/{dist-DLCy1STk.js → dist-BZWmfQbq.js} +0 -0
- /package/dist/assets/{dist-OZngTf6n.js → dist-BpuNldXk.js} +0 -0
- /package/dist/assets/{dist-DxxvVPQH.js → dist-C1VXabOr.js} +0 -0
- /package/dist/assets/{dist-Bpsss9Eu.js → dist-C5H5qIvq.js} +0 -0
- /package/dist/assets/{dist-DsxhNXOv.js → dist-CF4gkF4y.js} +0 -0
- /package/dist/assets/{dist-rT8uZk_k.js → dist-CNW1zLeq.js} +0 -0
- /package/dist/assets/{dist-BYyu59D8.js → dist-CoCQUAeM.js} +0 -0
- /package/dist/assets/{dist-Dj9zNHXU.js → dist-CtrmRz20.js} +0 -0
- /package/dist/assets/{dist-BIKFl48f.js → dist-Dcqqg9UU.js} +0 -0
- /package/dist/assets/{dist-B0VqT_4z.js → dist-sMh6mJ2d.js} +0 -0
- /package/dist/assets/{dist-BZe-2kC9.js → dist-tLOz534J.js} +0 -0
- /package/dist/assets/{dtd-C1gvGnbI.js → dtd-Fe_Eikw6.js} +0 -0
- /package/dist/assets/{duckdb-keywords-CR9f4wu5.js → duckdb-keywords-5i8us9ML.js} +0 -0
- /package/dist/assets/{dylan-D26gjyBo.js → dylan-DjUZAjRK.js} +0 -0
- /package/dist/assets/{ebnf-BdwTqLUx.js → ebnf--2SLsnbd.js} +0 -0
- /package/dist/assets/{ecl-D_pghsRW.js → ecl-qgyT1LqI.js} +0 -0
- /package/dist/assets/{eiffel-CQeRT5l7.js → eiffel-Dgulx8rf.js} +0 -0
- /package/dist/assets/{elm-BMJejWwJ.js → elm-BvFY4GJb.js} +0 -0
- /package/dist/assets/{erlang-DTDt7sE1.js → erlang-Ba0XOLlj.js} +0 -0
- /package/dist/assets/{esm-DvGqZhsW.js → esm-vpVfqVb3.js} +0 -0
- /package/dist/assets/{fcl-BFWIADMy.js → fcl-CcJxrJDr.js} +0 -0
- /package/dist/assets/{forth-DLug1Uos.js → forth-gbBFxz8f.js} +0 -0
- /package/dist/assets/{fortran-CfPd9x83.js → fortran-CXijpPbh.js} +0 -0
- /package/dist/assets/{gas-C1vwqe1-.js → gas-CnHGSLCd.js} +0 -0
- /package/dist/assets/{gherkin-DxFhlJYL.js → gherkin-DfEZpSxY.js} +0 -0
- /package/dist/assets/{groovy-AqjvKzmp.js → groovy-9JiNA9gq.js} +0 -0
- /package/dist/assets/{haskell-B9BMJXS_.js → haskell-CKr_RZFK.js} +0 -0
- /package/dist/assets/{haxe-CFd4aFZH.js → haxe-DsAAHfaR.js} +0 -0
- /package/dist/assets/{http-CgzOAOXj.js → http-BBXW5Cu0.js} +0 -0
- /package/dist/assets/{icon-32x32-XIbzzdoo.js → icon-32x32-DH9kM4Sh.js} +0 -0
- /package/dist/assets/{idl-DKlFwAHI.js → idl-Djz72z1a.js} +0 -0
- /package/dist/assets/{init-DZpk0tdu.js → init-DRQmrFIb.js} +0 -0
- /package/dist/assets/{javascript-BMuus-3E.js → javascript-CsBr0q2-.js} +0 -0
- /package/dist/assets/{julia-DGv2rboF.js → julia-BCYfl68O.js} +0 -0
- /package/dist/assets/{livescript-51GCvdcX.js → livescript-BEw7FNJP.js} +0 -0
- /package/dist/assets/{lua-BwsAaftY.js → lua-DqxHXOsz.js} +0 -0
- /package/dist/assets/{math-PgJy15ir.js → math-BJjKGmt3.js} +0 -0
- /package/dist/assets/{mathematica-Du4amQ2X.js → mathematica-Do-octY0.js} +0 -0
- /package/dist/assets/{mbox-DKL-l6mb.js → mbox-VgrgGytk.js} +0 -0
- /package/dist/assets/{mirc-CvS1f8zr.js → mirc-DkD5mNIp.js} +0 -0
- /package/dist/assets/{mllike-VhUq11ot.js → mllike-C8Ah4kKN.js} +0 -0
- /package/dist/assets/{modelica-CjlHUZat.js → modelica-2q7w6nLE.js} +0 -0
- /package/dist/assets/{mscgen-26STiUsc.js → mscgen-BRqvO7u4.js} +0 -0
- /package/dist/assets/{mumps-4o8IRFVU.js → mumps-CjtiTT1a.js} +0 -0
- /package/dist/assets/{nginx-CFpObAqg.js → nginx-CiiHaY6Q.js} +0 -0
- /package/dist/assets/{node-sql-parser-UQ9Ur_LP.js → node-sql-parser-Bzh-sm1v.js} +0 -0
- /package/dist/assets/{ntriples-D0zMsGJ-.js → ntriples-4lauqsM6.js} +0 -0
- /package/dist/assets/{numbers-UHLm3mA-.js → numbers-D7O23mOZ.js} +0 -0
- /package/dist/assets/{octave-CpJ40RVG.js → octave-A2kFK0nR.js} +0 -0
- /package/dist/assets/{oz-W9l5CbXg.js → oz-CvXDMSbl.js} +0 -0
- /package/dist/assets/{pascal-BZtdYBm4.js → pascal-6Jinj26u.js} +0 -0
- /package/dist/assets/{path-dqkZlAhR.js → path-D7fidI_g.js} +0 -0
- /package/dist/assets/{paths-Dfii2bN8.js → paths-BzSgteR-.js} +0 -0
- /package/dist/assets/{perl-Q79ziUtd.js → perl-CXauYQdN.js} +0 -0
- /package/dist/assets/{pig-Dn9ueYxG.js → pig-Dl0QLQI6.js} +0 -0
- /package/dist/assets/{powershell-DfXPJ56g.js → powershell-6bdy_rHW.js} +0 -0
- /package/dist/assets/{preload-helper-DItdS47A.js → preload-helper-D2MJg03u.js} +0 -0
- /package/dist/assets/{properties-DRrw--9g.js → properties-p1rx3aF7.js} +0 -0
- /package/dist/assets/{protobuf-5jBh6Y7Q.js → protobuf-BZ6p9Xh_.js} +0 -0
- /package/dist/assets/{puppet-Bql5dDjm.js → puppet-CjdIRV7D.js} +0 -0
- /package/dist/assets/{python-C7HNB5A8.js → python-uzyJYIWU.js} +0 -0
- /package/dist/assets/{q-CW9lnZXb.js → q-CfD3i9uI.js} +0 -0
- /package/dist/assets/{r-DmuxMz9j.js → r-JyJdYHQB.js} +0 -0
- /package/dist/assets/{rpm-2BQZRXYJ.js → rpm-DuGPfDyX.js} +0 -0
- /package/dist/assets/{ruby-B-FyRKB2.js → ruby-CA1TzLxZ.js} +0 -0
- /package/dist/assets/{sas-Q-94el51.js → sas-BJPWZC7M.js} +0 -0
- /package/dist/assets/{scheme-By445Ne_.js → scheme-IRagAY3r.js} +0 -0
- /package/dist/assets/{session-fBtIbMpB.js → session-BOFn9QrD.js} +0 -0
- /package/dist/assets/{shell-CezKrT5T.js → shell-BVpF3W_J.js} +0 -0
- /package/dist/assets/{sieve-MRWdUbX3.js → sieve-BSfPMeZl.js} +0 -0
- /package/dist/assets/{simple-mode-BtxX-F6Z.js → simple-mode-BmS_AmGQ.js} +0 -0
- /package/dist/assets/{smalltalk-C0KZrhPl.js → smalltalk-CkHVehky.js} +0 -0
- /package/dist/assets/{solr-BkyoAXqg.js → solr-DYYuHZ7Q.js} +0 -0
- /package/dist/assets/{sparql-CIMoBhOL.js → sparql-CmKKjr-f.js} +0 -0
- /package/dist/assets/{spreadsheet-7FZkhkVo.js → spreadsheet-hVThRh5Z.js} +0 -0
- /package/dist/assets/{sql-BNnXxKXA.js → sql-DG1AJQLP.js} +0 -0
- /package/dist/assets/{src-CmKhyEBC.js → src-CsZby044.js} +0 -0
- /package/dist/assets/{stex-CtmkcLz7.js → stex-jWatZkll.js} +0 -0
- /package/dist/assets/{stylus-BxV1gbJN.js → stylus-D28PuRsm.js} +0 -0
- /package/dist/assets/{swift-C7ozIpB2.js → swift-D-jfpPuv.js} +0 -0
- /package/dist/assets/{tcl-D9BrnXdg.js → tcl-BrQdCDVA.js} +0 -0
- /package/dist/assets/{textile-8cDJUs1C.js → textile-DXBc8HMq.js} +0 -0
- /package/dist/assets/{tiddlywiki-DE5lnTl3.js → tiddlywiki-Dc8c_QaF.js} +0 -0
- /package/dist/assets/{tiki-Dt9oCY2i.js → tiki-CwGnGueS.js} +0 -0
- /package/dist/assets/{timer-DXL2Iyk5.js → timer-B6DpdVnC.js} +0 -0
- /package/dist/assets/{toml-Dtc3-sql.js → toml-ClSouHPE.js} +0 -0
- /package/dist/assets/{treemap-8bMgVaTX.js → treemap-CZF0Enj1.js} +0 -0
- /package/dist/assets/{troff-CxUT34rC.js → troff-BGDyQn9x.js} +0 -0
- /package/dist/assets/{ttcn-BiVwbsr5.js → ttcn-De1OdISX.js} +0 -0
- /package/dist/assets/{ttcn-cfg-BLBfLtVM.js → ttcn-cfg-CQMSrhCz.js} +0 -0
- /package/dist/assets/{turtle-DqTQI7WU.js → turtle-DNhfxysg.js} +0 -0
- /package/dist/assets/{types-DZmRsGZN.js → types-iYXk7c05.js} +0 -0
- /package/dist/assets/{uuid-DercMavo.js → uuid-DXdzqzcr.js} +0 -0
- /package/dist/assets/{vb-D-mN5USJ.js → vb-BX7-Md9G.js} +0 -0
- /package/dist/assets/{vbscript-BHlqX42l.js → vbscript-DNMzJOTU.js} +0 -0
- /package/dist/assets/{velocity-BX6395is.js → velocity-viirwPm7.js} +0 -0
- /package/dist/assets/{verilog-CixbCKyb.js → verilog-CZguTLBV.js} +0 -0
- /package/dist/assets/{vhdl-CofOR-02.js → vhdl-CAEhCBOl.js} +0 -0
- /package/dist/assets/{web-vitals-Br9feh_D.js → web-vitals-CUbDLLN1.js} +0 -0
- /package/dist/assets/{webidl-DAqkXtNt.js → webidl-BNJg_7gX.js} +0 -0
- /package/dist/assets/{ws-DQY2KwIl.js → ws-DcVtI9Wj.js} +0 -0
- /package/dist/assets/{xquery-wPbfv0-o.js → xquery-CGV_r322.js} +0 -0
- /package/dist/assets/{yacas-B5Zk1avC.js → yacas-uRzw7z7m.js} +0 -0
- /package/dist/assets/{z80-C0HuDTqd.js → z80-CBK8t-9T.js} +0 -0
|
@@ -1,511 +0,0 @@
|
|
|
1
|
-
/* Copyright 2026 Marimo. All rights reserved. */
|
|
2
|
-
import { describe, expect, it } from "vitest";
|
|
3
|
-
import {
|
|
4
|
-
decodeFromWire,
|
|
5
|
-
isWireFormat,
|
|
6
|
-
serializeBuffersToBase64,
|
|
7
|
-
type WireFormat,
|
|
8
|
-
} from "../data-views";
|
|
9
|
-
import type { Base64String } from "../json/base64";
|
|
10
|
-
|
|
11
|
-
describe("decodeFromWire with DataViews", () => {
|
|
12
|
-
it("should return the original state if bufferPaths.length === 0", () => {
|
|
13
|
-
const state = { a: 1, b: 2 };
|
|
14
|
-
const result = decodeFromWire({ state, bufferPaths: [] });
|
|
15
|
-
expect(result).toEqual(state);
|
|
16
|
-
});
|
|
17
|
-
|
|
18
|
-
it("should insert DataViews at specified buffer paths", () => {
|
|
19
|
-
const state = {
|
|
20
|
-
a: 1,
|
|
21
|
-
b: {
|
|
22
|
-
c: "Hello",
|
|
23
|
-
d: "World",
|
|
24
|
-
},
|
|
25
|
-
};
|
|
26
|
-
const bufferPaths = [
|
|
27
|
-
["b", "c"],
|
|
28
|
-
["b", "d"],
|
|
29
|
-
];
|
|
30
|
-
const buffers = [
|
|
31
|
-
new TextEncoder().encode("Hello"),
|
|
32
|
-
new TextEncoder().encode("World"),
|
|
33
|
-
].map((b) => new DataView(b.buffer));
|
|
34
|
-
const result = decodeFromWire({ state, bufferPaths, buffers });
|
|
35
|
-
expect(result).toMatchInlineSnapshot(`
|
|
36
|
-
{
|
|
37
|
-
"a": 1,
|
|
38
|
-
"b": {
|
|
39
|
-
"c": DataView [
|
|
40
|
-
72,
|
|
41
|
-
101,
|
|
42
|
-
108,
|
|
43
|
-
108,
|
|
44
|
-
111,
|
|
45
|
-
],
|
|
46
|
-
"d": DataView [
|
|
47
|
-
87,
|
|
48
|
-
111,
|
|
49
|
-
114,
|
|
50
|
-
108,
|
|
51
|
-
100,
|
|
52
|
-
],
|
|
53
|
-
},
|
|
54
|
-
}
|
|
55
|
-
`);
|
|
56
|
-
});
|
|
57
|
-
|
|
58
|
-
it("should throw error when buffers and paths length mismatch", () => {
|
|
59
|
-
const state = { a: 1 };
|
|
60
|
-
const bufferPaths = [
|
|
61
|
-
["b", "c"],
|
|
62
|
-
["b", "d"],
|
|
63
|
-
];
|
|
64
|
-
const buffers = [new DataView(new ArrayBuffer())]; // Only one buffer for two paths
|
|
65
|
-
|
|
66
|
-
expect(() => decodeFromWire({ state, bufferPaths, buffers })).toThrow(
|
|
67
|
-
"Buffers and buffer paths not the same length",
|
|
68
|
-
);
|
|
69
|
-
});
|
|
70
|
-
|
|
71
|
-
it("should handle empty buffers array", () => {
|
|
72
|
-
const state = { a: 1 };
|
|
73
|
-
const bufferPaths = [["b", "c"]];
|
|
74
|
-
const buffers: DataView[] = [];
|
|
75
|
-
|
|
76
|
-
expect(() => decodeFromWire({ state, bufferPaths, buffers })).toThrow(
|
|
77
|
-
"Buffers and buffer paths not the same length",
|
|
78
|
-
);
|
|
79
|
-
});
|
|
80
|
-
});
|
|
81
|
-
|
|
82
|
-
describe("Immutability Tests", () => {
|
|
83
|
-
it("serializeBuffersToBase64 should not mutate input", () => {
|
|
84
|
-
const encoder = new TextEncoder();
|
|
85
|
-
const dataView1 = new DataView(encoder.encode("data1").buffer);
|
|
86
|
-
const dataView2 = new DataView(encoder.encode("data2").buffer);
|
|
87
|
-
|
|
88
|
-
const input = {
|
|
89
|
-
buffer1: dataView1,
|
|
90
|
-
nested: {
|
|
91
|
-
buffer2: dataView2,
|
|
92
|
-
value: "test",
|
|
93
|
-
},
|
|
94
|
-
array: [1, 2, 3],
|
|
95
|
-
};
|
|
96
|
-
|
|
97
|
-
const clone = structuredClone(input);
|
|
98
|
-
|
|
99
|
-
serializeBuffersToBase64(input);
|
|
100
|
-
|
|
101
|
-
// Check deep equality
|
|
102
|
-
expect(input).toEqual(clone);
|
|
103
|
-
|
|
104
|
-
// Check references are unchanged
|
|
105
|
-
expect(input.buffer1).toBe(dataView1);
|
|
106
|
-
expect(input.nested.buffer2).toBe(dataView2);
|
|
107
|
-
expect(input.nested).toBe(input.nested); // Nested object reference unchanged
|
|
108
|
-
expect(input.array).toBe(input.array); // Array reference unchanged
|
|
109
|
-
});
|
|
110
|
-
|
|
111
|
-
it("decodeFromWire (wire format) should not mutate input", () => {
|
|
112
|
-
const encoder = new TextEncoder();
|
|
113
|
-
const data = encoder.encode("Hello");
|
|
114
|
-
const base64 = btoa(String.fromCharCode(...data)) as Base64String;
|
|
115
|
-
|
|
116
|
-
const input = {
|
|
117
|
-
state: { text: base64, number: 42, nested: { value: "test" } },
|
|
118
|
-
bufferPaths: [["text"]],
|
|
119
|
-
buffers: [base64],
|
|
120
|
-
};
|
|
121
|
-
|
|
122
|
-
const clone = structuredClone(input);
|
|
123
|
-
|
|
124
|
-
decodeFromWire(input);
|
|
125
|
-
|
|
126
|
-
// Check deep equality
|
|
127
|
-
expect(input).toEqual(clone);
|
|
128
|
-
|
|
129
|
-
// Check references are unchanged
|
|
130
|
-
expect(input.state).toBe(input.state);
|
|
131
|
-
expect(input.state.nested).toBe(input.state.nested);
|
|
132
|
-
});
|
|
133
|
-
|
|
134
|
-
it("decodeFromWire (with DataViews) should not mutate input", () => {
|
|
135
|
-
const encoder = new TextEncoder();
|
|
136
|
-
const dataView = new DataView(encoder.encode("data").buffer);
|
|
137
|
-
|
|
138
|
-
const state = {
|
|
139
|
-
placeholder: "value",
|
|
140
|
-
nested: { key: "test" },
|
|
141
|
-
array: [1, 2, 3],
|
|
142
|
-
};
|
|
143
|
-
const bufferPaths = [["data"]];
|
|
144
|
-
const buffers = [dataView];
|
|
145
|
-
|
|
146
|
-
const input = { state, bufferPaths, buffers };
|
|
147
|
-
const clone = structuredClone(input);
|
|
148
|
-
|
|
149
|
-
decodeFromWire(input);
|
|
150
|
-
|
|
151
|
-
// Check deep equality
|
|
152
|
-
expect(input).toEqual(clone);
|
|
153
|
-
|
|
154
|
-
// Check references are unchanged
|
|
155
|
-
expect(input.state.nested).toBe(state.nested);
|
|
156
|
-
expect(input.state.array).toBe(state.array);
|
|
157
|
-
expect(input.buffers?.[0]).toBe(dataView); // Buffer reference unchanged
|
|
158
|
-
});
|
|
159
|
-
|
|
160
|
-
it("decodeFromWire should return new object, not mutate", () => {
|
|
161
|
-
const encoder = new TextEncoder();
|
|
162
|
-
const dataView = new DataView(encoder.encode("data").buffer);
|
|
163
|
-
|
|
164
|
-
const state = { a: 1, b: 2 };
|
|
165
|
-
const bufferPaths = [["c"]];
|
|
166
|
-
const buffers = [dataView];
|
|
167
|
-
|
|
168
|
-
const result = decodeFromWire({ state, bufferPaths, buffers });
|
|
169
|
-
|
|
170
|
-
// Result should be different reference
|
|
171
|
-
expect(result).not.toBe(state);
|
|
172
|
-
|
|
173
|
-
// Input should not have new property
|
|
174
|
-
expect("c" in state).toBe(false);
|
|
175
|
-
|
|
176
|
-
// Result should have new property
|
|
177
|
-
expect("c" in result).toBe(true);
|
|
178
|
-
});
|
|
179
|
-
|
|
180
|
-
it("serializeBuffersToBase64 should return new state object", () => {
|
|
181
|
-
const encoder = new TextEncoder();
|
|
182
|
-
const dataView = new DataView(encoder.encode("data").buffer);
|
|
183
|
-
|
|
184
|
-
const input = {
|
|
185
|
-
buffer: dataView,
|
|
186
|
-
value: "test",
|
|
187
|
-
};
|
|
188
|
-
|
|
189
|
-
const result = serializeBuffersToBase64(input);
|
|
190
|
-
|
|
191
|
-
// State should be different reference
|
|
192
|
-
expect(result.state).not.toBe(input);
|
|
193
|
-
|
|
194
|
-
// Input should still have DataView
|
|
195
|
-
expect(input.buffer).toBeInstanceOf(DataView);
|
|
196
|
-
|
|
197
|
-
// Result state should have base64 string
|
|
198
|
-
expect(typeof result.state.buffer).toBe("string");
|
|
199
|
-
});
|
|
200
|
-
|
|
201
|
-
it("decodeFromWire with object input should not mutate state", () => {
|
|
202
|
-
const encoder = new TextEncoder();
|
|
203
|
-
const dataView = new DataView(encoder.encode("data").buffer);
|
|
204
|
-
|
|
205
|
-
const state = { a: 1, b: { c: 2 } };
|
|
206
|
-
const bufferPaths = [["d"]];
|
|
207
|
-
const buffers = [dataView];
|
|
208
|
-
|
|
209
|
-
const input = { state, bufferPaths, buffers };
|
|
210
|
-
const clone = structuredClone(input);
|
|
211
|
-
|
|
212
|
-
decodeFromWire(input);
|
|
213
|
-
|
|
214
|
-
// Check deep equality
|
|
215
|
-
expect(input).toEqual(clone);
|
|
216
|
-
|
|
217
|
-
// Check references are unchanged
|
|
218
|
-
expect(input.state.b).toBe(state.b);
|
|
219
|
-
});
|
|
220
|
-
|
|
221
|
-
it("nested objects should maintain independence after serialization", () => {
|
|
222
|
-
const encoder = new TextEncoder();
|
|
223
|
-
const dataView = new DataView(encoder.encode("data").buffer);
|
|
224
|
-
|
|
225
|
-
const nested = { buffer: dataView, value: "nested" };
|
|
226
|
-
const input = {
|
|
227
|
-
nested,
|
|
228
|
-
other: "value",
|
|
229
|
-
};
|
|
230
|
-
|
|
231
|
-
const result = serializeBuffersToBase64(input);
|
|
232
|
-
|
|
233
|
-
// Mutate result state
|
|
234
|
-
(result.state.nested as Record<string, unknown>).value = "changed";
|
|
235
|
-
|
|
236
|
-
// Original nested object should be unchanged
|
|
237
|
-
expect(nested.value).toBe("nested");
|
|
238
|
-
expect(input.nested.value).toBe("nested");
|
|
239
|
-
});
|
|
240
|
-
|
|
241
|
-
it("arrays should not be mutated during operations", () => {
|
|
242
|
-
const encoder = new TextEncoder();
|
|
243
|
-
const dataView = new DataView(encoder.encode("data").buffer);
|
|
244
|
-
|
|
245
|
-
const input = {
|
|
246
|
-
items: [dataView, "middle", { value: 1 }],
|
|
247
|
-
};
|
|
248
|
-
|
|
249
|
-
const originalItems = input.items;
|
|
250
|
-
const originalMiddle = input.items[1];
|
|
251
|
-
const originalObject = input.items[2];
|
|
252
|
-
|
|
253
|
-
serializeBuffersToBase64(input);
|
|
254
|
-
|
|
255
|
-
// Array reference should be unchanged
|
|
256
|
-
expect(input.items).toBe(originalItems);
|
|
257
|
-
expect(input.items[1]).toBe(originalMiddle);
|
|
258
|
-
expect(input.items[2]).toBe(originalObject);
|
|
259
|
-
});
|
|
260
|
-
});
|
|
261
|
-
|
|
262
|
-
describe("serializeBuffersToBase64", () => {
|
|
263
|
-
it("should return empty arrays when no DataViews present", () => {
|
|
264
|
-
const input = { a: 1, b: "text", c: { d: true } };
|
|
265
|
-
const result = serializeBuffersToBase64(input);
|
|
266
|
-
|
|
267
|
-
expect(result).toEqual({
|
|
268
|
-
state: input,
|
|
269
|
-
buffers: [],
|
|
270
|
-
bufferPaths: [],
|
|
271
|
-
});
|
|
272
|
-
});
|
|
273
|
-
|
|
274
|
-
it("should serialize DataViews at top level", () => {
|
|
275
|
-
const encoder = new TextEncoder();
|
|
276
|
-
const dataView = new DataView(encoder.encode("test").buffer);
|
|
277
|
-
const input = { data: dataView, other: 123 };
|
|
278
|
-
|
|
279
|
-
const result = serializeBuffersToBase64(input);
|
|
280
|
-
|
|
281
|
-
expect(result.buffers).toHaveLength(1);
|
|
282
|
-
expect(result.bufferPaths).toEqual([["data"]]);
|
|
283
|
-
expect(typeof result.state.data).toBe("string");
|
|
284
|
-
expect(result.state.other).toBe(123);
|
|
285
|
-
});
|
|
286
|
-
|
|
287
|
-
it("should serialize nested DataViews", () => {
|
|
288
|
-
const encoder = new TextEncoder();
|
|
289
|
-
const dataView1 = new DataView(encoder.encode("first").buffer);
|
|
290
|
-
const dataView2 = new DataView(encoder.encode("second").buffer);
|
|
291
|
-
const input = {
|
|
292
|
-
nested: {
|
|
293
|
-
buffer1: dataView1,
|
|
294
|
-
deeper: {
|
|
295
|
-
buffer2: dataView2,
|
|
296
|
-
},
|
|
297
|
-
},
|
|
298
|
-
regular: "value",
|
|
299
|
-
};
|
|
300
|
-
|
|
301
|
-
const result = serializeBuffersToBase64(input);
|
|
302
|
-
|
|
303
|
-
expect(result.buffers).toHaveLength(2);
|
|
304
|
-
expect(result.bufferPaths).toEqual([
|
|
305
|
-
["nested", "buffer1"],
|
|
306
|
-
["nested", "deeper", "buffer2"],
|
|
307
|
-
]);
|
|
308
|
-
expect(typeof result.state.nested.buffer1).toBe("string");
|
|
309
|
-
expect(typeof result.state.nested.deeper.buffer2).toBe("string");
|
|
310
|
-
});
|
|
311
|
-
|
|
312
|
-
it("should serialize DataViews in arrays", () => {
|
|
313
|
-
const encoder = new TextEncoder();
|
|
314
|
-
const dataView1 = new DataView(encoder.encode("one").buffer);
|
|
315
|
-
const dataView2 = new DataView(encoder.encode("two").buffer);
|
|
316
|
-
const input = {
|
|
317
|
-
items: [dataView1, "middle", dataView2],
|
|
318
|
-
};
|
|
319
|
-
|
|
320
|
-
const result = serializeBuffersToBase64(input);
|
|
321
|
-
|
|
322
|
-
expect(result.buffers).toHaveLength(2);
|
|
323
|
-
expect(result.bufferPaths).toEqual([
|
|
324
|
-
["items", 0],
|
|
325
|
-
["items", 2],
|
|
326
|
-
]);
|
|
327
|
-
expect(result.state.items[1]).toBe("middle");
|
|
328
|
-
});
|
|
329
|
-
|
|
330
|
-
it("should handle mixed nested structures", () => {
|
|
331
|
-
const encoder = new TextEncoder();
|
|
332
|
-
const dataView = new DataView(encoder.encode("data").buffer);
|
|
333
|
-
const input = {
|
|
334
|
-
array: [{ nested: dataView }, [dataView]],
|
|
335
|
-
};
|
|
336
|
-
|
|
337
|
-
const result = serializeBuffersToBase64(input);
|
|
338
|
-
|
|
339
|
-
expect(result.buffers).toHaveLength(2);
|
|
340
|
-
expect(result.bufferPaths).toContainEqual(["array", 0, "nested"]);
|
|
341
|
-
expect(result.bufferPaths).toContainEqual(["array", 1, 0]);
|
|
342
|
-
});
|
|
343
|
-
});
|
|
344
|
-
|
|
345
|
-
describe("isWireFormat", () => {
|
|
346
|
-
it("should return true for valid wire format", () => {
|
|
347
|
-
const wireFormat: WireFormat = {
|
|
348
|
-
state: { a: 1 },
|
|
349
|
-
bufferPaths: [],
|
|
350
|
-
buffers: [],
|
|
351
|
-
};
|
|
352
|
-
expect(isWireFormat(wireFormat)).toBe(true);
|
|
353
|
-
});
|
|
354
|
-
|
|
355
|
-
it("should return true for wire format with data", () => {
|
|
356
|
-
const wireFormat: WireFormat = {
|
|
357
|
-
state: { value: "SGVsbG8=" },
|
|
358
|
-
bufferPaths: [["value"]],
|
|
359
|
-
buffers: ["SGVsbG8=" as Base64String],
|
|
360
|
-
};
|
|
361
|
-
expect(isWireFormat(wireFormat)).toBe(true);
|
|
362
|
-
});
|
|
363
|
-
|
|
364
|
-
it("should return false for null", () => {
|
|
365
|
-
expect(isWireFormat(null)).toBe(false);
|
|
366
|
-
});
|
|
367
|
-
|
|
368
|
-
it("should return false for non-objects", () => {
|
|
369
|
-
expect(isWireFormat("string")).toBe(false);
|
|
370
|
-
expect(isWireFormat(123)).toBe(false);
|
|
371
|
-
expect(isWireFormat(true)).toBe(false);
|
|
372
|
-
expect(isWireFormat(undefined)).toBe(false);
|
|
373
|
-
});
|
|
374
|
-
|
|
375
|
-
it("should return false when missing state", () => {
|
|
376
|
-
expect(isWireFormat({ bufferPaths: [], buffers: [] })).toBe(false);
|
|
377
|
-
});
|
|
378
|
-
|
|
379
|
-
it("should return false when missing bufferPaths", () => {
|
|
380
|
-
expect(isWireFormat({ state: {}, buffers: [] })).toBe(false);
|
|
381
|
-
});
|
|
382
|
-
|
|
383
|
-
it("should return false when missing buffers", () => {
|
|
384
|
-
expect(isWireFormat({ state: {}, bufferPaths: [] })).toBe(false);
|
|
385
|
-
});
|
|
386
|
-
|
|
387
|
-
it("should return false for plain objects", () => {
|
|
388
|
-
expect(isWireFormat({ a: 1, b: 2 })).toBe(false);
|
|
389
|
-
});
|
|
390
|
-
});
|
|
391
|
-
|
|
392
|
-
describe("decodeFromWire from WireFormat", () => {
|
|
393
|
-
it("should return state unchanged when no buffer paths", () => {
|
|
394
|
-
const wire: WireFormat = {
|
|
395
|
-
state: { a: 1, b: "text" },
|
|
396
|
-
bufferPaths: [],
|
|
397
|
-
buffers: [],
|
|
398
|
-
};
|
|
399
|
-
const result = decodeFromWire(wire);
|
|
400
|
-
expect(result).toEqual({ a: 1, b: "text" });
|
|
401
|
-
});
|
|
402
|
-
|
|
403
|
-
it("should decode single buffer at top level", () => {
|
|
404
|
-
const encoder = new TextEncoder();
|
|
405
|
-
const originalData = encoder.encode("Hello");
|
|
406
|
-
const base64 = btoa(String.fromCharCode(...originalData)) as Base64String;
|
|
407
|
-
|
|
408
|
-
const wire: WireFormat = {
|
|
409
|
-
state: { data: base64, other: 123 },
|
|
410
|
-
bufferPaths: [["data"]],
|
|
411
|
-
buffers: [base64],
|
|
412
|
-
};
|
|
413
|
-
|
|
414
|
-
const result = decodeFromWire(wire);
|
|
415
|
-
|
|
416
|
-
expect(result.data).toBeInstanceOf(DataView);
|
|
417
|
-
expect(result.other).toBe(123);
|
|
418
|
-
|
|
419
|
-
// Verify the DataView contains correct data
|
|
420
|
-
const bytes = new Uint8Array((result.data as DataView).buffer);
|
|
421
|
-
const decoded = new TextDecoder().decode(bytes);
|
|
422
|
-
expect(decoded).toBe("Hello");
|
|
423
|
-
});
|
|
424
|
-
|
|
425
|
-
it("should decode nested buffers", () => {
|
|
426
|
-
const encoder = new TextEncoder();
|
|
427
|
-
const data1 = encoder.encode("first");
|
|
428
|
-
const data2 = encoder.encode("second");
|
|
429
|
-
const base641 = btoa(String.fromCharCode(...data1)) as Base64String;
|
|
430
|
-
const base642 = btoa(String.fromCharCode(...data2)) as Base64String;
|
|
431
|
-
|
|
432
|
-
const wire: WireFormat = {
|
|
433
|
-
state: {
|
|
434
|
-
nested: {
|
|
435
|
-
buf1: base641,
|
|
436
|
-
deeper: {
|
|
437
|
-
buf2: base642,
|
|
438
|
-
},
|
|
439
|
-
},
|
|
440
|
-
},
|
|
441
|
-
bufferPaths: [
|
|
442
|
-
["nested", "buf1"],
|
|
443
|
-
["nested", "deeper", "buf2"],
|
|
444
|
-
],
|
|
445
|
-
buffers: [base641, base642],
|
|
446
|
-
};
|
|
447
|
-
|
|
448
|
-
const result = decodeFromWire(wire) as {
|
|
449
|
-
nested: { buf1: unknown; deeper: { buf2: unknown } };
|
|
450
|
-
};
|
|
451
|
-
|
|
452
|
-
expect(result.nested.buf1).toBeInstanceOf(DataView);
|
|
453
|
-
expect(result.nested.deeper.buf2).toBeInstanceOf(DataView);
|
|
454
|
-
});
|
|
455
|
-
|
|
456
|
-
it("should decode buffers in arrays", () => {
|
|
457
|
-
const encoder = new TextEncoder();
|
|
458
|
-
const data = encoder.encode("test");
|
|
459
|
-
const base64 = btoa(String.fromCharCode(...data)) as Base64String;
|
|
460
|
-
|
|
461
|
-
const wire: WireFormat = {
|
|
462
|
-
state: {
|
|
463
|
-
items: [base64, "middle", base64],
|
|
464
|
-
},
|
|
465
|
-
bufferPaths: [
|
|
466
|
-
["items", 0],
|
|
467
|
-
["items", 2],
|
|
468
|
-
],
|
|
469
|
-
buffers: [base64, base64],
|
|
470
|
-
};
|
|
471
|
-
|
|
472
|
-
const result = decodeFromWire(wire) as { items: unknown[] };
|
|
473
|
-
|
|
474
|
-
expect(result.items[0]).toBeInstanceOf(DataView);
|
|
475
|
-
expect(result.items[1]).toBe("middle");
|
|
476
|
-
expect(result.items[2]).toBeInstanceOf(DataView);
|
|
477
|
-
});
|
|
478
|
-
|
|
479
|
-
it("should handle round-trip serialization", () => {
|
|
480
|
-
const encoder = new TextEncoder();
|
|
481
|
-
const dataView1 = new DataView(encoder.encode("data1").buffer);
|
|
482
|
-
const dataView2 = new DataView(encoder.encode("data2").buffer);
|
|
483
|
-
|
|
484
|
-
const original = {
|
|
485
|
-
buffer1: dataView1,
|
|
486
|
-
nested: {
|
|
487
|
-
buffer2: dataView2,
|
|
488
|
-
},
|
|
489
|
-
regular: "value",
|
|
490
|
-
};
|
|
491
|
-
|
|
492
|
-
// Serialize
|
|
493
|
-
const serialized = serializeBuffersToBase64(original);
|
|
494
|
-
|
|
495
|
-
// Deserialize
|
|
496
|
-
const deserialized = decodeFromWire(serialized);
|
|
497
|
-
|
|
498
|
-
// Verify structure is preserved
|
|
499
|
-
expect(deserialized.buffer1).toBeInstanceOf(DataView);
|
|
500
|
-
expect(deserialized.nested.buffer2).toBeInstanceOf(DataView);
|
|
501
|
-
expect(deserialized.regular).toBe("value");
|
|
502
|
-
|
|
503
|
-
// Verify data integrity
|
|
504
|
-
const bytes1 = new Uint8Array((deserialized.buffer1 as DataView).buffer);
|
|
505
|
-
const bytes2 = new Uint8Array(
|
|
506
|
-
(deserialized.nested.buffer2 as DataView).buffer,
|
|
507
|
-
);
|
|
508
|
-
expect(new TextDecoder().decode(bytes1)).toBe("data1");
|
|
509
|
-
expect(new TextDecoder().decode(bytes2)).toBe("data2");
|
|
510
|
-
});
|
|
511
|
-
});
|
package/src/utils/data-views.ts
DELETED
|
@@ -1,143 +0,0 @@
|
|
|
1
|
-
/* Copyright 2026 Marimo. All rights reserved. */
|
|
2
|
-
import { get, set } from "lodash-es";
|
|
3
|
-
import { invariant } from "./invariant";
|
|
4
|
-
import {
|
|
5
|
-
type Base64String,
|
|
6
|
-
base64ToDataView,
|
|
7
|
-
dataViewToBase64,
|
|
8
|
-
} from "./json/base64";
|
|
9
|
-
import { Logger } from "./Logger";
|
|
10
|
-
|
|
11
|
-
/**
|
|
12
|
-
* Recursively find all DataViews in an object and return their paths.
|
|
13
|
-
*
|
|
14
|
-
* This mirrors ipywidgets' _separate_buffers logic.
|
|
15
|
-
*/
|
|
16
|
-
function findDataViewPaths(
|
|
17
|
-
obj: unknown,
|
|
18
|
-
currentPath: (string | number)[] = [],
|
|
19
|
-
): (string | number)[][] {
|
|
20
|
-
const paths: (string | number)[][] = [];
|
|
21
|
-
|
|
22
|
-
if (obj instanceof DataView) {
|
|
23
|
-
paths.push(currentPath);
|
|
24
|
-
} else if (Array.isArray(obj)) {
|
|
25
|
-
for (const [i, element] of obj.entries()) {
|
|
26
|
-
paths.push(...findDataViewPaths(element, [...currentPath, i]));
|
|
27
|
-
}
|
|
28
|
-
} else if (obj !== null && typeof obj === "object") {
|
|
29
|
-
for (const [key, value] of Object.entries(obj)) {
|
|
30
|
-
paths.push(...findDataViewPaths(value, [...currentPath, key]));
|
|
31
|
-
}
|
|
32
|
-
}
|
|
33
|
-
|
|
34
|
-
return paths;
|
|
35
|
-
}
|
|
36
|
-
|
|
37
|
-
/**
|
|
38
|
-
* Serialize DataView buffers to base64 strings.
|
|
39
|
-
*
|
|
40
|
-
* Finds all DataViews in the object.
|
|
41
|
-
*/
|
|
42
|
-
export function serializeBuffersToBase64<T extends Record<string, unknown>>(
|
|
43
|
-
inputObject: T,
|
|
44
|
-
): WireFormat<T> {
|
|
45
|
-
// Dynamically find all DataView paths instead of using fixed bufferPaths
|
|
46
|
-
const dataViewPaths = findDataViewPaths(inputObject);
|
|
47
|
-
|
|
48
|
-
if (dataViewPaths.length === 0) {
|
|
49
|
-
return { state: inputObject, buffers: [], bufferPaths: [] };
|
|
50
|
-
}
|
|
51
|
-
|
|
52
|
-
const state = structuredClone(inputObject);
|
|
53
|
-
const buffers: Base64String[] = [];
|
|
54
|
-
const bufferPaths: (string | number)[][] = [];
|
|
55
|
-
|
|
56
|
-
for (const bufferPath of dataViewPaths) {
|
|
57
|
-
const dataView = get(inputObject, bufferPath);
|
|
58
|
-
if (dataView instanceof DataView) {
|
|
59
|
-
const base64 = dataViewToBase64(dataView);
|
|
60
|
-
buffers.push(base64);
|
|
61
|
-
bufferPaths.push(bufferPath);
|
|
62
|
-
set(state, bufferPath, base64);
|
|
63
|
-
}
|
|
64
|
-
}
|
|
65
|
-
|
|
66
|
-
return { state, buffers, bufferPaths };
|
|
67
|
-
}
|
|
68
|
-
|
|
69
|
-
/**
|
|
70
|
-
* Wire format for anywidget state with binary data.
|
|
71
|
-
* Buffers can be either base64 strings (from network) or DataViews (in-memory).
|
|
72
|
-
*/
|
|
73
|
-
export interface WireFormat<T = Record<string, unknown>> {
|
|
74
|
-
state: T;
|
|
75
|
-
bufferPaths: (string | number)[][];
|
|
76
|
-
buffers: Base64String[];
|
|
77
|
-
}
|
|
78
|
-
|
|
79
|
-
/**
|
|
80
|
-
* Check if an object is in wire format.
|
|
81
|
-
*/
|
|
82
|
-
export function isWireFormat<T = Record<string, unknown>>(
|
|
83
|
-
obj: unknown,
|
|
84
|
-
): obj is WireFormat<T> {
|
|
85
|
-
return (
|
|
86
|
-
obj !== null &&
|
|
87
|
-
typeof obj === "object" &&
|
|
88
|
-
"state" in obj &&
|
|
89
|
-
"bufferPaths" in obj &&
|
|
90
|
-
"buffers" in obj
|
|
91
|
-
);
|
|
92
|
-
}
|
|
93
|
-
|
|
94
|
-
/**
|
|
95
|
-
* Decode wire format or insert DataViews at specified paths.
|
|
96
|
-
*
|
|
97
|
-
* Accepts either:
|
|
98
|
-
* 1. Wire format: { state, bufferPaths, buffers } where buffers are base64 strings
|
|
99
|
-
* 2. Direct format: { state, bufferPaths, buffers } where buffers are DataViews
|
|
100
|
-
*
|
|
101
|
-
* For ndarray-like structures {view: null, dtype, shape}, we insert the DataView
|
|
102
|
-
* at the 'view' key, preserving the structure for round-tripping.
|
|
103
|
-
*/
|
|
104
|
-
export function decodeFromWire<T extends Record<string, unknown>>(input: {
|
|
105
|
-
state: T;
|
|
106
|
-
bufferPaths?: (string | number)[][];
|
|
107
|
-
buffers?: readonly (DataView | Base64String)[];
|
|
108
|
-
}): T {
|
|
109
|
-
const { state, bufferPaths, buffers } = input;
|
|
110
|
-
|
|
111
|
-
// If no buffer paths, return the original state
|
|
112
|
-
if (!bufferPaths || bufferPaths.length === 0) {
|
|
113
|
-
return state;
|
|
114
|
-
}
|
|
115
|
-
|
|
116
|
-
// If has buffers, assert they are the same size
|
|
117
|
-
if (buffers) {
|
|
118
|
-
invariant(
|
|
119
|
-
buffers.length === bufferPaths.length,
|
|
120
|
-
"Buffers and buffer paths not the same length",
|
|
121
|
-
);
|
|
122
|
-
}
|
|
123
|
-
|
|
124
|
-
const out = structuredClone(state);
|
|
125
|
-
|
|
126
|
-
for (const [i, bufferPath] of bufferPaths.entries()) {
|
|
127
|
-
const buffer = buffers?.[i];
|
|
128
|
-
|
|
129
|
-
if (buffer == null) {
|
|
130
|
-
Logger.warn("[anywidget] Could not find buffer at path", bufferPath);
|
|
131
|
-
continue;
|
|
132
|
-
}
|
|
133
|
-
|
|
134
|
-
// Handle both base64 strings (from wire format) and DataViews (direct usage)
|
|
135
|
-
if (typeof buffer === "string") {
|
|
136
|
-
set(out, bufferPath, base64ToDataView(buffer));
|
|
137
|
-
} else {
|
|
138
|
-
set(out, bufferPath, buffer);
|
|
139
|
-
}
|
|
140
|
-
}
|
|
141
|
-
|
|
142
|
-
return out;
|
|
143
|
-
}
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|