@marimo-team/frontend 0.23.7-dev9 → 0.23.7-dev90
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-DGBvmSvq.js +1 -0
- package/dist/assets/ConnectedDataExplorerComponent-D-boDGAP.js +1 -0
- package/dist/assets/DeferredRequestRegistry-CzVJLtsG.js +1 -0
- package/dist/assets/ErrorBoundary-DyYDV0HI.js +1 -0
- package/dist/assets/ImperativeModal-DEC1mXgV.js +1 -0
- package/dist/assets/JsonOutput-05-R3eil.js +53 -0
- package/dist/assets/LazyAnyLanguageCodeMirror-GdhQ07zA.js +2 -0
- package/dist/assets/MarimoErrorOutput-XWqnhvJ6.js +7 -0
- package/dist/assets/RSPContexts-Bk1r00gJ.js +1 -0
- package/dist/assets/RenderHTML-B5r25cP5.js +1 -0
- package/dist/assets/RunButton-Dbak5hfa.js +1 -0
- 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-BbZkMqv2.js +97 -0
- package/dist/assets/add-connection-dialog-CzxRpS5F.js +167 -0
- package/dist/assets/agent-panel-zPhlhkYL.js +287 -0
- package/dist/assets/ai-model-dropdown-CjhUqXgj.js +5 -0
- package/dist/assets/alert-dialog-BqFLkbUc.js +11 -0
- package/dist/assets/any-language-editor-Bdhmwznp.js +1 -0
- package/dist/assets/apl-Bl4yyYus.js +1 -0
- package/dist/assets/app-config-button-CCs8Jepz.js +1 -0
- package/dist/assets/arc-npelKso9.js +1 -0
- package/dist/assets/architecture-7HQA4BMR-CaNOiKrI.js +1 -0
- package/dist/assets/architectureDiagram-VXUJARFQ-BsWISGgz.js +36 -0
- package/dist/assets/asciiarmor-BlzLkEza.js +1 -0
- package/dist/assets/asn1-Khb778U5.js +1 -0
- package/dist/assets/ban-0fKnt00i.js +1 -0
- package/dist/assets/blockDiagram-VD42YOAC-CzfQ0Exj.js +122 -0
- package/dist/assets/brainfuck-BzHxpB_u.js +1 -0
- package/dist/assets/button-BbCh-29a.js +1 -0
- package/dist/assets/c4Diagram-YG6GDRKO-D0FgqleO.js +10 -0
- package/dist/assets/cache-panel-VL13fWgF.js +1 -0
- package/dist/assets/capabilities-A_KhFcGV.js +1 -0
- package/dist/assets/cell-editor-ODyJXDT8.js +20 -0
- package/dist/assets/cell-link-PQYiMZw1.js +1 -0
- package/dist/assets/cells-Dnu4nDoy.js +229 -0
- package/dist/assets/channel-DjPEzqq3.js +1 -0
- package/dist/assets/chat-display-DetTBnqK.js +1 -0
- package/dist/assets/chat-panel-CEgw_vg0.js +3 -0
- package/dist/assets/chat-ui-D-Y7p_cT.js +4 -0
- package/dist/assets/chunk-4BX2VUAB-Br07KPs3.js +1 -0
- package/dist/assets/chunk-55IACEB6-BHM3yXYz.js +1 -0
- package/dist/assets/chunk-5FQGJX7Z-BSzccEgu.js +113 -0
- package/dist/assets/chunk-ABZYJK2D-pjI0V9vG.js +80 -0
- package/dist/assets/chunk-ATLVNIR6-DMcOYQJi.js +1 -0
- package/dist/assets/chunk-B4BG7PRW-jxe9_Hde.js +165 -0
- package/dist/assets/chunk-CVBHYZKI-DwNHftX6.js +1 -0
- package/dist/assets/chunk-DI55MBZ5-CNxnbO1g.js +220 -0
- package/dist/assets/chunk-EXTU4WIE-C7TYTuus.js +1 -0
- package/dist/assets/chunk-FMBD7UC4-jBIrJcS0.js +15 -0
- package/dist/assets/chunk-HN2XXSSU-COpG_X4X.js +1 -0
- package/dist/assets/chunk-JA3XYJ7Z-2W_JmZ4z.js +70 -0
- package/dist/assets/chunk-JZLCHNYA-DdjotIam.js +54 -0
- package/dist/assets/chunk-MI3HLSF2-D_z13ybc.js +32 -0
- package/dist/assets/chunk-N4CR4FBY-Y37VEUfx.js +2 -0
- package/dist/assets/chunk-QN33PNHL-BcKQMXSf.js +1 -0
- package/dist/assets/chunk-QXUST7PY-CU78e3vp.js +7 -0
- package/dist/assets/chunk-QZHKN3VN-g-7LWEK-.js +1 -0
- package/dist/assets/chunk-S3R3BYOJ-EEhIeeuI.js +2 -0
- package/dist/assets/chunk-TZMSLE5B-D1A_Dyzt.js +1 -0
- package/dist/assets/classDiagram-2ON5EDUG-CDgVuBLy.js +1 -0
- package/dist/assets/classDiagram-v2-WZHVMYZB-B2UHhBVi.js +1 -0
- package/dist/assets/clike-TW9KXOmZ.js +1 -0
- package/dist/assets/clojure-C_sT-_CQ.js +1 -0
- package/dist/assets/cmake-BjrhHx8m.js +1 -0
- package/dist/assets/cobol-Cs8YSzaw.js +1 -0
- package/dist/assets/code-block-37QAKDTI-U2R1jyOo.js +2 -0
- package/dist/assets/coffeescript-juXyFkA0.js +1 -0
- package/dist/assets/column-preview-BLIWbdOX.js +1 -0
- package/dist/assets/command-2NPJCYDa.js +1 -0
- package/dist/assets/command-palette-CeDe63_W.js +1 -0
- package/dist/assets/common-BaBE_ygg.js +1 -0
- package/dist/assets/commonlisp-Cmn_5nuv.js +1 -0
- package/dist/assets/components-CvGaLA5d.js +1 -0
- package/dist/assets/components-zB5yT_R8.js +1 -0
- package/dist/assets/config-C2lTvbuU.js +1 -0
- package/dist/assets/context-C1Tm_47t.js +1 -0
- package/dist/assets/copy-Ch48HVPK.js +1 -0
- package/dist/assets/copy-icon-BdZPgXgo.js +1 -0
- package/dist/assets/cose-bilkent-S5V4N54A-B7DsItpC.js +1 -0
- package/dist/assets/createReducer-CI9qeK_X.js +1 -0
- package/dist/assets/crystal-DJrWmXfk.js +1 -0
- package/dist/assets/css-BJpII9DZ.js +1 -0
- package/dist/assets/cypher-D549BT6Q.js +1 -0
- package/dist/assets/d-CQplIm4C.js +1 -0
- package/dist/assets/dagre-6UL2VRFP-F7ectrvx.js +4 -0
- package/dist/assets/data-grid-overlay-editor-Cvj8Susd.js +1 -0
- package/dist/assets/datasource-I-LOgxeP.js +3 -0
- package/dist/assets/dates-DI1TvEEK.js +1 -0
- package/dist/assets/dependency-graph-panel-D-QLNUZN.js +5 -0
- package/dist/assets/diagram-PSM6KHXK-DLOGvjhP.js +24 -0
- package/dist/assets/diagram-QEK2KX5R-BEJdNpvg.js +43 -0
- package/dist/assets/diagram-S2PKOQOG-CqMnWWB8.js +24 -0
- package/dist/assets/dialog-DqOQT_n4.js +1 -0
- package/dist/assets/diff-Dz2enOOE.js +1 -0
- package/dist/assets/dist-7TsTgeOV.js +1 -0
- package/dist/assets/dist-B0N0-Vx5.js +1 -0
- package/dist/assets/dist-BE3jO1WU.js +1 -0
- package/dist/assets/dist-BNfAUjeR.js +1 -0
- package/dist/assets/dist-BQxSimS-.js +1 -0
- package/dist/assets/dist-BSp3naSP.js +1 -0
- package/dist/assets/dist-BYShiqDa.js +1 -0
- package/dist/assets/dist-BZe5KYlj.js +1 -0
- package/dist/assets/dist-BZr6MMV-.js +1 -0
- package/dist/assets/dist-BbkYHvT2.js +1 -0
- package/dist/assets/dist-BdyjRhEt.js +1 -0
- package/dist/assets/dist-CAWvCIk5.js +1 -0
- package/dist/assets/dist-CK56b5MF.js +1 -0
- package/dist/assets/dist-COz0Y8UW.js +1 -0
- package/dist/assets/dist-CW3rweKM.js +7 -0
- package/dist/assets/dist-CodYQwM5.js +1 -0
- package/dist/assets/dist-D4Od5Ds4.js +1 -0
- package/dist/assets/dist-DCqxOggh.js +6 -0
- package/dist/assets/dist-DLjDyeX7.js +1 -0
- package/dist/assets/dist-DOY95WD5.js +1 -0
- package/dist/assets/dist-Da-HT0I8.js +1 -0
- package/dist/assets/dist-Dc1gTRL9.js +1 -0
- package/dist/assets/dist-Dn1-guC7.js +1 -0
- package/dist/assets/dist-Dwy8b-Zd.js +1 -0
- package/dist/assets/dist-DxEuZTVa.js +1 -0
- package/dist/assets/dist-LFeDu06u.js +1 -0
- package/dist/assets/dist-ThkhuYAm.js +1 -0
- package/dist/assets/dist-jwcsaiRe.js +1 -0
- package/dist/assets/dist-oedZSmHi.js +1 -0
- package/dist/assets/dist-r-YlHvr1.js +1 -0
- package/dist/assets/dist-v1cdVFWt.js +1 -0
- package/dist/assets/dockerfile-AiWrCVkd.js +1 -0
- package/dist/assets/documentation-panel-DMdFXuBf.js +1 -0
- package/dist/assets/download-B1QFVDP-.js +9 -0
- package/dist/assets/dropdown-menu-CR7cnzLX.js +1 -0
- package/dist/assets/dtd-DxzWHAng.js +1 -0
- package/dist/assets/dylan-Bj1NVjKa.js +1 -0
- package/dist/assets/ecl-Ch-B_r8E.js +1 -0
- package/dist/assets/edit-page-D_MrFGP2.js +9 -0
- package/dist/assets/eiffel-CICk6vIb.js +1 -0
- package/dist/assets/elm-C1O6zP9K.js +1 -0
- package/dist/assets/erDiagram-Q2GNP2WA-DlCxoG4y.js +60 -0
- package/dist/assets/erlang-BwL41NIP.js +1 -0
- package/dist/assets/error-banner-CLO6LFll.js +1 -0
- package/dist/assets/error-panel-iXznkJZ1.js +1 -0
- package/dist/assets/es-au8YY-8E.js +5 -0
- package/dist/assets/esm-BGRsx_Fp.js +1 -0
- package/dist/assets/esm-Cb2bnV6o.js +1 -0
- package/dist/assets/external-link-BTNxSavU.js +1 -0
- package/dist/assets/factor-DgyyQiBQ.js +1 -0
- package/dist/assets/factor-DjzhghfA.js +1 -0
- package/dist/assets/field-DNlzfMKW.js +1 -0
- package/dist/assets/file-explorer-panel-BVBKF1SH.js +26 -0
- package/dist/assets/file-icons-B6DaZdP0.js +1 -0
- package/dist/assets/file-name-input-g2H2sY2h.js +3 -0
- package/dist/assets/fileToBase64-BeYUTUzO.js +1 -0
- package/dist/assets/floating-outline-DbOtUfo-.js +1 -0
- package/dist/assets/flowDiagram-NV44I4VS-CXUevMnh.js +162 -0
- package/dist/assets/focus-BaOnnMs-.js +1 -0
- package/dist/assets/form-BjUJP6PJ.js +2 -0
- package/dist/assets/formats-BRq458WH.js +1 -0
- package/dist/assets/formatting-XTtGIhGk.js +1 -0
- package/dist/assets/forth-D9Pm6H-4.js +1 -0
- package/dist/assets/fortran-Bkmw-ITl.js +1 -0
- package/dist/assets/fullscreen-eipL3i3Y.js +41 -0
- package/dist/assets/gallery-page-MrZHjySE.js +1 -0
- package/dist/assets/ganttDiagram-JELNMOA3-D8_HISpS.js +267 -0
- package/dist/assets/gas-hS11Npqh.js +1 -0
- package/dist/assets/gherkin-HvvvGZ2_.js +1 -0
- package/dist/assets/gitGraph-G5XIXVHT-DiktmQLx.js +1 -0
- package/dist/assets/gitGraphDiagram-V2S2FVAM-CN_m3FDa.js +65 -0
- package/dist/assets/glide-data-editor-4Wql6uq7.js +132 -0
- package/dist/assets/globals-CpVAcN9Z.js +1 -0
- package/dist/assets/groovy-BymCZpo_.js +1 -0
- package/dist/assets/haskell-D1PB_nO2.js +1 -0
- package/dist/assets/haxe-BbvC3Y-d.js +1 -0
- package/dist/assets/home-page-De1W6q6f.js +4 -0
- package/dist/assets/hooks-jWLD3t7P.js +1 -0
- package/dist/assets/html-to-image-D6SgvARi.js +2 -0
- package/dist/assets/idl-Do8pA7p2.js +1 -0
- package/dist/assets/index-CA2sQKnW.js +38 -0
- package/dist/assets/index-DH00kbhV.css +2 -0
- package/dist/assets/info-VBDWY6EO-BH3NOLYF.js +1 -0
- package/dist/assets/infoDiagram-HS3SLOUP-C20LNJkf.js +2 -0
- package/dist/assets/input-CVE-gIjt.js +1 -0
- package/dist/assets/javascript-C0HGxgJT.js +1 -0
- package/dist/assets/journeyDiagram-XKPGCS4Q-CQWCJPyH.js +139 -0
- package/dist/assets/julia-B-Inh9cI.js +1 -0
- package/dist/assets/kanban-definition-3W4ZIXB7-CeH-UkBO.js +89 -0
- package/dist/assets/katex-Bci6q_jh.js +1 -0
- package/dist/assets/kiosk-mode-Czvj3vmL.js +1 -0
- package/dist/assets/label-xHqFtfdz.js +1 -0
- package/dist/assets/layout-DEU6lX-9.js +9 -0
- package/dist/assets/line-BkpbatV-.js +1 -0
- package/dist/assets/linear-BHpZPQfO.js +1 -0
- package/dist/assets/links-Av1BIe0O.js +1 -0
- package/dist/assets/livescript-C6P4ddCY.js +1 -0
- package/dist/assets/logs-panel-BMAfoMJg.js +1 -0
- package/dist/assets/loro_wasm_bg-Bg3nlaci.js +1 -0
- package/dist/assets/lua-DTvhQBWH.js +1 -0
- package/dist/assets/maps-n3GaPJwv.js +1 -0
- package/dist/assets/markdown-renderer-BQ-BQLiJ.js +5 -0
- package/dist/assets/mathematica-wRwDN36m.js +1 -0
- package/dist/assets/mbox-BeQS3Xo8.js +1 -0
- package/dist/assets/menu-items-DcP01QzW.js +1 -0
- package/dist/assets/mermaid-4DMBBIKO-C0OyyVdo.js +1 -0
- package/dist/assets/mermaid-CZhfODkT.js +11 -0
- package/dist/assets/mermaid-parser.core-867JpRcd.js +4 -0
- package/dist/assets/mhchem-BKhnkPip.js +1 -0
- package/dist/assets/mindmap-definition-VGOIOE7T-BNg30ltj.js +68 -0
- package/dist/assets/mirc-D0yC5rBL.js +1 -0
- package/dist/assets/mllike-sRDGjaMs.js +1 -0
- package/dist/assets/modelica-CTTCwBwt.js +1 -0
- package/dist/assets/mscgen-D9NVglDL.js +1 -0
- package/dist/assets/multi-map-CUuNtzHt.js +1 -0
- package/dist/assets/mumps-eJkJqAKw.js +1 -0
- package/dist/assets/name-cell-input-bwfAyC0i.js +1 -0
- package/dist/assets/nsis-B3ap5r7i.js +1 -0
- package/dist/assets/nsis-bDE8IZXy.js +1 -0
- package/dist/assets/ntriples-B2LCbtl9.js +1 -0
- package/dist/assets/number-overlay-editor-BOtWFe1E.js +9 -0
- package/dist/assets/numbers-mY4EY0yG.js +1 -0
- package/dist/assets/octave-DhLlnMzQ.js +1 -0
- package/dist/assets/ordinal-BKex0QZH.js +1 -0
- package/dist/assets/outline-panel-CkZUQcZ1.js +1 -0
- package/dist/assets/oz-CLovtD0B.js +1 -0
- package/dist/assets/package-B8oXOUM-.js +1 -0
- package/dist/assets/packages-panel-B3dRYuRM.js +1 -0
- package/dist/assets/packet-DYOGHKS2-BZAo-1WV.js +1 -0
- package/dist/assets/panels-DWhhEgv4.js +1 -0
- package/dist/assets/pascal-BJwozZXL.js +1 -0
- package/dist/assets/pathUtils-vgBYIo5B.js +1 -0
- package/dist/assets/perl-B3rIP59U.js +1 -0
- package/dist/assets/pie-VRWISCQL-DSqXSW1A.js +1 -0
- package/dist/assets/pieDiagram-ADFJNKIX-CkDeU73E.js +30 -0
- package/dist/assets/pig-BQrpamWX.js +1 -0
- package/dist/assets/popover-Bz_0Vkyf.js +1 -0
- package/dist/assets/powershell-Crqgmja1.js +1 -0
- package/dist/assets/precisionRound-NX56vp6K.js +1 -0
- package/dist/assets/process-output-9W-JyYdE.js +1 -0
- package/dist/assets/properties-BMPI0iSd.js +1 -0
- package/dist/assets/protobuf-BMPWl2Em.js +1 -0
- package/dist/assets/pug-BvTKD58f.js +1 -0
- package/dist/assets/pug-CcL3ml0F.js +1 -0
- package/dist/assets/puppet-B1rTmaHH.js +1 -0
- package/dist/assets/python-DGMqnM8m.js +1 -0
- package/dist/assets/q-BNL1PH4D.js +1 -0
- package/dist/assets/quadrantDiagram-AYHSOK5B-DAx3aobn.js +7 -0
- package/dist/assets/r-DOvfvYEk.js +1 -0
- package/dist/assets/radar-ZZBFDIW7-BPcQHRAq.js +1 -0
- package/dist/assets/radio-group-rsi1ibXY.js +1 -0
- package/dist/assets/react-vega-4VQqM03t.js +188 -0
- package/dist/assets/react-vega-5tTMnjwa.js +1 -0
- package/dist/assets/readonly-python-code-BKYj8PNf.js +1 -0
- package/dist/assets/renderShortcut-DK-VjfaX.js +1 -0
- package/dist/assets/request-registry-DKAymYdP.js +1 -0
- package/dist/assets/requirementDiagram-UZGBJVZJ-u-qLWr1t.js +64 -0
- package/dist/assets/reveal-component-DNpBzX6F.js +1069 -0
- package/dist/assets/rpm-B7R9RTHE.js +1 -0
- package/dist/assets/ruby-BGJp-XLA.js +1 -0
- package/dist/assets/run-page-CO2X6wso.js +1 -0
- package/dist/assets/runs-Cn-NiTzH.js +1 -0
- package/dist/assets/sankeyDiagram-TZEHDZUN-VL3oPzoy.js +10 -0
- package/dist/assets/sas-CZmYq1Si.js +1 -0
- package/dist/assets/save-worker-D2iQi-UK.js +77 -0
- package/dist/assets/scheme-CdW_eMia.js +1 -0
- package/dist/assets/scratchpad-panel-CWfddArs.js +1 -0
- package/dist/assets/secrets-panel-DqHGq3V8.js +1 -0
- package/dist/assets/select-DZcFyKFQ.js +1 -0
- package/dist/assets/sequenceDiagram-WL72ISMW-CyhmzEul.js +145 -0
- package/dist/assets/session-DGdfs0bJ.js +1 -0
- package/dist/assets/session-panel-BP0QxaoM.js +1 -0
- package/dist/assets/share-oorMPghT.js +1 -0
- package/dist/assets/shell-oPdLMo8m.js +1 -0
- package/dist/assets/sieve-DEd8Bmn8.js +1 -0
- package/dist/assets/slides-MCbMDtlY.css +1 -0
- package/dist/assets/smalltalk-CnqQIV2W.js +1 -0
- package/dist/assets/snippets-panel-DFJd1ui5.js +1 -0
- package/dist/assets/sparql-DKyVXlni.js +1 -0
- package/dist/assets/spec-D1ptWKg6.js +1 -0
- package/dist/assets/src-CvyFXpBy.js +1 -0
- package/dist/assets/state-BXNNuw9g.js +3 -0
- package/dist/assets/state-D-vYm99C.js +1 -0
- package/dist/assets/state-D9EoHCkz.js +1 -0
- package/dist/assets/state-dx303w7J.js +1 -0
- package/dist/assets/stateDiagram-FKZM4ZOC-eVhhAfzW.js +1 -0
- package/dist/assets/stateDiagram-v2-4FDKWEC3-cGl1lSTF.js +1 -0
- package/dist/assets/step-vqKxn7TP.js +1 -0
- package/dist/assets/stex-C8c2RsN8.js +1 -0
- package/dist/assets/strings-wdPMRf6Z.js +2 -0
- package/dist/assets/stylus-Dk_-yu_w.js +1 -0
- package/dist/assets/swift-CjrgUbUd.js +1 -0
- package/dist/assets/swiper-component-Da-gZjtJ.js +1 -0
- package/dist/assets/switch-BtkQp293.js +1 -0
- package/dist/assets/tcl-DCmY87p6.js +1 -0
- package/dist/assets/terminal-BSE1Vg5d.js +62 -0
- package/dist/assets/textarea-BBTcSr-i.js +1 -0
- package/dist/assets/textile-C_0nHQXl.js +1 -0
- package/dist/assets/time-Di7MbY-a.js +1 -0
- package/dist/assets/timeline-definition-IT6M3QCI-C01GhhW1.js +61 -0
- package/dist/assets/toml-DRTXXEvh.js +1 -0
- package/dist/assets/tooltip-DTV9tlSr.js +1 -0
- package/dist/assets/tracing-BQU8fBDM.js +1 -0
- package/dist/assets/tracing-panel-DEVpyGX3.js +2 -0
- package/dist/assets/tree-actions-DY8FUp3V.js +1 -0
- package/dist/assets/treemap-GDKQZRPO-Bqwz-MRa.js +1 -0
- package/dist/assets/troff-Cc6RCKwc.js +1 -0
- package/dist/assets/ttcn-B_hjyyZd.js +1 -0
- package/dist/assets/ttcn-cfg-C9kHEAnH.js +1 -0
- package/dist/assets/turtle-BpKw2L0C.js +1 -0
- package/dist/assets/useBoolean-B8LMGUHl.js +1 -0
- package/dist/assets/useCellActionButton-QaDO24oW.js +1 -0
- package/dist/assets/useDateFormatter-d3yglQmW.js +1 -0
- package/dist/assets/useDeleteCell-DFahVcdW.js +1 -0
- package/dist/assets/useDependencyPanelTab-BB_XeSAg.js +1 -0
- package/dist/assets/useEventListener-DvoEXWke.js +1 -0
- package/dist/assets/useHotkey-C04CW11R.js +1 -0
- package/dist/assets/useIframeCapabilities-DPVTppnD.js +1 -0
- package/dist/assets/useInstallPackage-hKfTes-m.js +1 -0
- package/dist/assets/useInterval-CSOniNAx.js +1 -0
- package/dist/assets/useNotebookActions-CJEicFed.js +4 -0
- package/dist/assets/useNumberFormatter-CW4V-fpE.js +1 -0
- package/dist/assets/usePress-jH2RfcUG.js +7 -0
- package/dist/assets/useRunCells-C0BPo9m1.js +1 -0
- package/dist/assets/useSplitCell-BN53wD86.js +1 -0
- package/dist/assets/useTheme-Kwyx4PvL.js +1 -0
- package/dist/assets/utils-DQRuLEof.js +61 -0
- package/dist/assets/utils-Wvjk_Y4h.js +1 -0
- package/dist/assets/vb-DrexAmUA.js +1 -0
- package/dist/assets/vbscript-BxgSn4mU.js +1 -0
- package/dist/assets/vega-component-C9fDGx86.js +1 -0
- package/dist/assets/vega-loader.browser-xq8miGHn.js +6 -0
- package/dist/assets/velocity-FfkCaLcE.js +1 -0
- package/dist/assets/verilog-CqmLdpPq.js +1 -0
- package/dist/assets/vhdl-Brd1jg5j.js +1 -0
- package/dist/assets/webidl-I7JvNTQ0.js +1 -0
- package/dist/assets/worker-B38WhSlZ.js +120 -0
- package/dist/assets/write-secret-modal-Liv_9MXS.js +1 -0
- package/dist/assets/ws-Cb8IUKlU.js +22 -0
- package/dist/assets/xquery-DryU6qzU.js +1 -0
- package/dist/assets/xychartDiagram-PRI3JC2R-CohoDL7X.js +7 -0
- package/dist/assets/yacas-CxNmk6Uw.js +1 -0
- package/dist/assets/z80-CIIYHJij.js +1 -0
- package/dist/index.html +135 -133
- package/package.json +3 -3
- package/src/components/chat/chat-components.tsx +47 -0
- package/src/components/chat/chat-display.tsx +41 -7
- package/src/components/chat/chat-panel.tsx +37 -10
- package/src/components/chat/chat-utils.ts +42 -20
- package/src/components/chat/reasoning-accordion.tsx +14 -3
- package/src/components/chat/tool-call/shared.ts +13 -0
- package/src/components/chat/tool-call/tool-approval-card.tsx +62 -0
- package/src/components/chat/tool-call/tool-args.tsx +26 -0
- package/src/components/chat/tool-call/tool-call-view.tsx +99 -0
- package/src/components/chat/tool-call/tool-error-card.tsx +81 -0
- package/src/components/chat/tool-call/tool-history-row.tsx +153 -0
- package/src/components/chat/tool-call/tool-result.tsx +101 -0
- package/src/components/data-table/__tests__/column-header.test.ts +3 -1
- package/src/components/data-table/__tests__/column-header.test.tsx +308 -0
- package/src/components/data-table/__tests__/filter-by-values-picker.test.tsx +112 -0
- package/src/components/data-table/__tests__/filter-pill-editor.test.tsx +261 -0
- package/src/components/data-table/__tests__/filters.test.ts +196 -49
- package/src/components/data-table/charts/components/form-fields.tsx +1 -0
- package/src/components/data-table/column-header.tsx +349 -170
- package/src/components/data-table/date-filter-inputs.tsx +325 -0
- package/src/components/data-table/filter-by-values-picker.tsx +70 -9
- package/src/components/data-table/filter-pill-editor.tsx +410 -156
- package/src/components/data-table/filter-pills.tsx +69 -54
- package/src/components/data-table/filters.ts +218 -101
- package/src/components/data-table/header-items.tsx +8 -1
- package/src/components/data-table/operator-labels.ts +25 -0
- package/src/components/data-table/regex-input.tsx +61 -0
- package/src/components/dependency-graph/minimap-content.tsx +14 -3
- package/src/components/editor/actions/pair-with-agent-modal.tsx +140 -49
- package/src/components/editor/actions/useNotebookActions.tsx +3 -1
- package/src/components/editor/app-container.tsx +7 -1
- package/src/components/editor/chrome/panels/context-aware-panel/context-aware-panel.tsx +10 -2
- package/src/components/editor/chrome/wrapper/app-chrome.tsx +1 -0
- package/src/components/editor/chrome/wrapper/footer-items/backend-status.tsx +1 -1
- package/src/components/editor/chrome/wrapper/footer.tsx +4 -1
- package/src/components/editor/chrome/wrapper/panels.tsx +4 -1
- package/src/components/editor/chrome/wrapper/sidebar.tsx +4 -1
- package/src/components/editor/controls/Controls.tsx +11 -3
- package/src/components/editor/file-tree/file-explorer.tsx +12 -2
- 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 +5 -0
- package/src/components/editor/output/console/ConsoleOutput.tsx +23 -5
- package/src/components/editor/output/console/__tests__/ConsoleOutput.test.tsx +114 -0
- package/src/components/editor/renderers/slides-layout/__tests__/compute-slide-cells.test.ts +5 -4
- package/src/components/editor/renderers/slides-layout/__tests__/plugin.test.ts +55 -15
- package/src/components/editor/renderers/slides-layout/plugin.tsx +8 -25
- package/src/components/editor/renderers/slides-layout/slides-layout.tsx +19 -6
- package/src/components/editor/renderers/slides-layout/types.ts +40 -31
- package/src/components/editor/renderers/vertical-layout/vertical-layout.tsx +1 -0
- package/src/components/home/components.tsx +6 -0
- package/src/components/pages/run-page.tsx +4 -1
- package/src/components/scratchpad/scratchpad.tsx +1 -0
- package/src/components/slides/__tests__/slide-notes.test.ts +131 -0
- package/src/components/slides/reveal-component.tsx +252 -147
- package/src/components/slides/slide-notes-editor.tsx +127 -0
- package/src/components/slides/slide-notes.ts +64 -0
- package/src/components/slides/slides.css +14 -0
- package/src/components/ui/combobox.tsx +24 -5
- package/src/components/ui/number-field.tsx +2 -0
- package/src/core/ai/tools/__tests__/registry.test.ts +10 -12
- package/src/core/ai/tools/registry.ts +9 -5
- 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/go-to-definition/__tests__/commands.test.ts +152 -0
- package/src/core/codemirror/go-to-definition/__tests__/utils.test.ts +99 -0
- package/src/core/codemirror/go-to-definition/commands.ts +382 -22
- package/src/core/codemirror/go-to-definition/utils.ts +23 -5
- package/src/core/edit-app.tsx +3 -2
- package/src/core/hotkeys/hotkeys.ts +5 -0
- package/src/core/islands/worker/worker.tsx +3 -2
- package/src/core/run-app.tsx +2 -1
- package/src/core/runtime/__tests__/runtime.test.ts +38 -17
- package/src/core/runtime/runtime.ts +57 -34
- package/src/core/wasm/__tests__/utils.test.ts +34 -0
- 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 +156 -0
- package/src/core/websocket/__tests__/useMarimoKernelConnection.test.ts +101 -0
- package/src/core/websocket/transports/__tests__/ws.test.ts +125 -0
- package/src/core/websocket/transports/basic.ts +1 -1
- package/src/core/websocket/transports/ws.ts +96 -0
- package/src/core/websocket/useMarimoKernelConnection.tsx +133 -54
- package/src/core/websocket/useWebSocket.tsx +3 -15
- package/src/css/app/Cell.css +10 -0
- package/src/plugins/core/__test__/sanitize.test.ts +30 -0
- package/src/plugins/impl/DropdownPlugin.tsx +12 -1
- package/src/plugins/impl/MultiselectPlugin.tsx +4 -0
- package/src/plugins/impl/SearchableSelect.tsx +11 -1
- package/src/plugins/impl/TabsPlugin.tsx +35 -7
- package/src/plugins/impl/__tests__/DropdownPlugin.test.tsx +56 -0
- package/src/plugins/impl/__tests__/TabsPlugin.test.tsx +154 -0
- package/src/plugins/impl/data-frames/forms/__tests__/__snapshots__/form.test.tsx.snap +48 -36
- package/src/plugins/impl/data-frames/schema.ts +4 -1
- package/src/plugins/layout/DownloadPlugin.tsx +9 -7
- package/src/utils/__tests__/id-tree.test.ts +71 -0
- package/src/utils/download.ts +4 -2
- package/src/utils/id-tree.tsx +89 -0
- package/dist/assets/CellStatus-CN4mKUXv.js +0 -1
- package/dist/assets/ConnectedDataExplorerComponent-DeBM0cl9.js +0 -1
- package/dist/assets/DeferredRequestRegistry-CUzZ0y7K.js +0 -1
- package/dist/assets/ErrorBoundary-DzYV_VeY.js +0 -1
- package/dist/assets/ImperativeModal-D7lQ0Q7_.js +0 -1
- package/dist/assets/JsonOutput-B0sjIMBK.js +0 -49
- package/dist/assets/LazyAnyLanguageCodeMirror-pAFdCqyC.js +0 -2
- package/dist/assets/MarimoErrorOutput-ClA7EZGX.js +0 -7
- package/dist/assets/RSPContexts-CINae4Gg.js +0 -1
- package/dist/assets/RenderHTML-CruxVneu.js +0 -1
- package/dist/assets/RunButton-CJsJsGj-.js +0 -1
- package/dist/assets/__vite-browser-external-D0cSGXjR.js +0 -1
- package/dist/assets/__vite-browser-external-DQc2JVNq.js +0 -1
- package/dist/assets/add-cell-with-ai-C7f_bUyB.js +0 -92
- package/dist/assets/add-connection-dialog-DSOgwTlO.js +0 -167
- package/dist/assets/agent-panel-CeDyKw1_.js +0 -287
- package/dist/assets/ai-model-dropdown-kQdQhWyz.js +0 -5
- package/dist/assets/alert-dialog-BGBdrcqJ.js +0 -11
- package/dist/assets/any-language-editor-CwwS-naY.js +0 -1
- package/dist/assets/apl-CaYjM5u2.js +0 -1
- package/dist/assets/app-config-button-dnmk7p6n.js +0 -1
- package/dist/assets/arc-D1owqr0z.js +0 -1
- package/dist/assets/architecture-7HQA4BMR-BzXB-NJy.js +0 -1
- package/dist/assets/architectureDiagram-VXUJARFQ-D6wy26r_.js +0 -36
- package/dist/assets/asciiarmor-D2cJUKTq.js +0 -1
- package/dist/assets/asn1-CZDBKivQ.js +0 -1
- package/dist/assets/blockDiagram-VD42YOAC-CGtjuPGT.js +0 -122
- package/dist/assets/brainfuck-D5O26WTe.js +0 -1
- package/dist/assets/button-D9nb17Rw.js +0 -1
- package/dist/assets/c4Diagram-YG6GDRKO-BSjPyzdq.js +0 -10
- package/dist/assets/cache-panel-DDJqyuAl.js +0 -1
- package/dist/assets/capabilities-C_FLIcjP.js +0 -1
- package/dist/assets/cell-editor-DOImf428.js +0 -22
- package/dist/assets/cell-link-DqiCeeeS.js +0 -1
- package/dist/assets/cells-BBDzmUIS.js +0 -229
- package/dist/assets/channel-D2-MhlpJ.js +0 -1
- package/dist/assets/chat-display-Ct3Me0kL.js +0 -1
- package/dist/assets/chat-panel-CXvtUFUU.js +0 -3
- package/dist/assets/chat-ui-UFERs8Gx.js +0 -4
- package/dist/assets/chunk-4BX2VUAB-Co_nHYv2.js +0 -1
- package/dist/assets/chunk-55IACEB6-CSG9iNvo.js +0 -1
- package/dist/assets/chunk-5FQGJX7Z-BReOK4Lg.js +0 -113
- package/dist/assets/chunk-ABZYJK2D-CvNlx3OC.js +0 -80
- package/dist/assets/chunk-ATLVNIR6-EZIDpjkm.js +0 -1
- package/dist/assets/chunk-B4BG7PRW-B3yrge9N.js +0 -165
- package/dist/assets/chunk-CVBHYZKI-lxEaq00s.js +0 -1
- package/dist/assets/chunk-DI55MBZ5-NrI5veM7.js +0 -220
- package/dist/assets/chunk-EXTU4WIE-DcGAJuBg.js +0 -1
- package/dist/assets/chunk-FMBD7UC4-CD1D2uhs.js +0 -15
- package/dist/assets/chunk-HN2XXSSU-DNIvfs-V.js +0 -1
- package/dist/assets/chunk-JA3XYJ7Z-B-G51Lop.js +0 -70
- package/dist/assets/chunk-JZLCHNYA-B1QJXpkc.js +0 -54
- package/dist/assets/chunk-MI3HLSF2-SpVCtnNg.js +0 -32
- package/dist/assets/chunk-N4CR4FBY-DaT7rK9q.js +0 -2
- package/dist/assets/chunk-QN33PNHL-eWaiYkN_.js +0 -1
- package/dist/assets/chunk-QXUST7PY-yCShGuH_.js +0 -7
- package/dist/assets/chunk-QZHKN3VN-Bf2ysi2t.js +0 -1
- package/dist/assets/chunk-S3R3BYOJ-BuT2smkb.js +0 -2
- package/dist/assets/chunk-TZMSLE5B-tzDl0-3S.js +0 -1
- package/dist/assets/classDiagram-2ON5EDUG-CSdm65qE.js +0 -1
- package/dist/assets/classDiagram-v2-WZHVMYZB-B2-GAMOQ.js +0 -1
- package/dist/assets/clike-TwxwxEw_.js +0 -1
- package/dist/assets/clojure-B8dfjAV6.js +0 -1
- package/dist/assets/cmake-D3vlGJdL.js +0 -1
- package/dist/assets/cobol-S-4I_F1W.js +0 -1
- package/dist/assets/code-block-37QAKDTI-BZ77cXM8.js +0 -2
- package/dist/assets/coffeescript-DG-Oj54u.js +0 -1
- package/dist/assets/column-preview-Xuel1zsI.js +0 -1
- package/dist/assets/command-CBCkexpx.js +0 -1
- package/dist/assets/command-palette-CSa-ZC8t.js +0 -1
- package/dist/assets/common-Dk5VdfJt.js +0 -1
- package/dist/assets/commonlisp-CWlOS49U.js +0 -1
- package/dist/assets/components-CTKNCmC_.js +0 -1
- package/dist/assets/components-DsoH1pO3.js +0 -1
- package/dist/assets/config-CPqw1wUv.js +0 -1
- package/dist/assets/context-B3MsQb-b.js +0 -1
- package/dist/assets/copy-BCF-tANo.js +0 -1
- package/dist/assets/copy-icon-BYNydU7b.js +0 -1
- package/dist/assets/cose-bilkent-S5V4N54A-CEx_UMjg.js +0 -1
- package/dist/assets/createReducer-1ePoj7v6.js +0 -1
- package/dist/assets/crystal-CD-LQ3E-.js +0 -1
- package/dist/assets/css-sdrF9ahV.js +0 -1
- package/dist/assets/cypher-oiVTIRlU.js +0 -1
- package/dist/assets/d-KaoGirPa.js +0 -1
- package/dist/assets/dagre-6UL2VRFP-Ca6G800E.js +0 -4
- package/dist/assets/data-grid-overlay-editor-D-UNM6-P.js +0 -1
- package/dist/assets/datasource-CmTCEk66.js +0 -3
- package/dist/assets/dates-CAlnO9QB.js +0 -1
- package/dist/assets/dependency-graph-panel-0u1-ZaOT.js +0 -5
- package/dist/assets/diagram-PSM6KHXK-B6oP3YWR.js +0 -24
- package/dist/assets/diagram-QEK2KX5R-BjsoVcta.js +0 -43
- package/dist/assets/diagram-S2PKOQOG-CmzTe5KJ.js +0 -24
- package/dist/assets/dialog-Dj0qTFnG.js +0 -1
- package/dist/assets/diff-Df1QxxZl.js +0 -1
- package/dist/assets/dist-2Z1sSg1x.js +0 -1
- package/dist/assets/dist-7iwSqhl8.js +0 -1
- package/dist/assets/dist-A6v5-U3i.js +0 -1
- package/dist/assets/dist-B6zNcPeA.js +0 -1
- package/dist/assets/dist-BDZFwK9_.js +0 -1
- package/dist/assets/dist-BiTPETny.js +0 -1
- package/dist/assets/dist-BoOh2kN5.js +0 -1
- package/dist/assets/dist-BojrNCCU.js +0 -1
- package/dist/assets/dist-CHMkheIP.js +0 -1
- package/dist/assets/dist-CPepgudT.js +0 -1
- package/dist/assets/dist-CQG39nVX.js +0 -1
- package/dist/assets/dist-CSOCJn9h.js +0 -1
- package/dist/assets/dist-CmTrDl8w.js +0 -1
- package/dist/assets/dist-CwZoXpmG.js +0 -1
- package/dist/assets/dist-Cwcldbhl.js +0 -1
- package/dist/assets/dist-D1lU2Qzi.js +0 -1
- package/dist/assets/dist-D8QLIJ8u.js +0 -1
- package/dist/assets/dist-DBiqbYe-.js +0 -1
- package/dist/assets/dist-DLY3MFt_.js +0 -1
- package/dist/assets/dist-DOBJtV_h.js +0 -1
- package/dist/assets/dist-DQOq2Tf-.js +0 -6
- package/dist/assets/dist-DUpLnFKL.js +0 -1
- package/dist/assets/dist-DZaaRVnC.js +0 -1
- package/dist/assets/dist-DZq-MBWk.js +0 -7
- package/dist/assets/dist-DaXyrkOa.js +0 -1
- package/dist/assets/dist-GYoBJCzF.js +0 -1
- package/dist/assets/dist-Iv0YPPAU.js +0 -1
- package/dist/assets/dist-RsQv8CvG.js +0 -1
- package/dist/assets/dist-YUbAFc_i.js +0 -1
- package/dist/assets/dist-bOUvGRGG.js +0 -1
- package/dist/assets/dist-q4pwbvzW.js +0 -1
- package/dist/assets/dockerfile-CImncS5w.js +0 -1
- package/dist/assets/documentation-panel-CcE7aGO9.js +0 -1
- package/dist/assets/download-QGh9oR1D.js +0 -9
- package/dist/assets/dropdown-menu-D1A3cFC8.js +0 -1
- package/dist/assets/dtd-Aj5m459l.js +0 -1
- package/dist/assets/dylan-CdSB1nh8.js +0 -1
- package/dist/assets/ecl-CvwsCfi6.js +0 -1
- package/dist/assets/edit-page-CMzqgK6j.js +0 -9
- package/dist/assets/eiffel-Bws25dAs.js +0 -1
- package/dist/assets/elm--WkcLZ1a.js +0 -1
- package/dist/assets/erDiagram-Q2GNP2WA-CK4Kc1gP.js +0 -60
- package/dist/assets/erlang-Ct30wW1o.js +0 -1
- package/dist/assets/error-banner-C10O4l3y.js +0 -1
- package/dist/assets/error-panel-ChlzbfWg.js +0 -1
- package/dist/assets/es-DaYh1PsD.js +0 -5
- package/dist/assets/esm-BmrwxxCo.js +0 -1
- package/dist/assets/esm-DN_A77ya.js +0 -1
- package/dist/assets/factor-B3fhZG6W.js +0 -1
- package/dist/assets/factor-DbSpQa-0.js +0 -1
- package/dist/assets/field-BrLPDxsA.js +0 -1
- package/dist/assets/file-explorer-panel-8dWLD2PY.js +0 -26
- package/dist/assets/file-icons-Cs4oXsAy.js +0 -1
- package/dist/assets/file-name-input-g7pBBCjk.js +0 -3
- package/dist/assets/fileToBase64-Dpv4aII5.js +0 -1
- package/dist/assets/floating-outline-CFUSr2du.js +0 -1
- package/dist/assets/flowDiagram-NV44I4VS-hhUTWDGs.js +0 -162
- package/dist/assets/focus-J47a1GCq.js +0 -1
- package/dist/assets/form-CdFqEqTA.js +0 -2
- package/dist/assets/formats-Dsc8AdCp.js +0 -1
- package/dist/assets/formatting-Chn6WhRe.js +0 -1
- package/dist/assets/forth-BP0pXyoR.js +0 -1
- package/dist/assets/fortran-DpX_2iww.js +0 -1
- package/dist/assets/fullscreen-BDxedMYP.js +0 -41
- package/dist/assets/gallery-page-TIWZFnOT.js +0 -1
- package/dist/assets/ganttDiagram-JELNMOA3-Dpb7hBaR.js +0 -267
- package/dist/assets/gas-CiUR6fHB.js +0 -1
- package/dist/assets/gherkin-C9v48C48.js +0 -1
- package/dist/assets/gitGraph-G5XIXVHT-Xz2NQxVt.js +0 -1
- package/dist/assets/gitGraphDiagram-V2S2FVAM-DHCl4EFT.js +0 -65
- package/dist/assets/glide-data-editor-ChlIFl33.js +0 -132
- package/dist/assets/globals-DUw71mRV.js +0 -1
- package/dist/assets/groovy-psUnKwK-.js +0 -1
- package/dist/assets/haskell-DZHQAKUV.js +0 -1
- package/dist/assets/haxe-AOvPCF-w.js +0 -1
- package/dist/assets/home-page-HhJfA35e.js +0 -4
- package/dist/assets/hooks-BpoZRNxw.js +0 -1
- package/dist/assets/html-to-image-CAiN3VHj.js +0 -2
- package/dist/assets/idl-CSA8C1ck.js +0 -1
- package/dist/assets/index-DH5UUBE4.css +0 -2
- package/dist/assets/index-x_VZzCd9.js +0 -42
- package/dist/assets/info-VBDWY6EO-BpskktdI.js +0 -1
- package/dist/assets/infoDiagram-HS3SLOUP-C51uJjUn.js +0 -2
- package/dist/assets/input-BX98vgAu.js +0 -1
- package/dist/assets/javascript-XMYUq5-t.js +0 -1
- package/dist/assets/journeyDiagram-XKPGCS4Q-CD6bTQpr.js +0 -139
- package/dist/assets/julia-oON8zLDW.js +0 -1
- package/dist/assets/kanban-definition-3W4ZIXB7-D3rGxlSj.js +0 -89
- package/dist/assets/katex-DPCeZ37j.js +0 -1
- package/dist/assets/kiosk-mode-Cr9yyT7A.js +0 -1
- package/dist/assets/label-DTR8T0AE.js +0 -1
- package/dist/assets/layout-D5myrs5s.js +0 -9
- package/dist/assets/line-BA7eTS55.js +0 -1
- package/dist/assets/linear-Dmb_KwjK.js +0 -1
- package/dist/assets/links-BhX7oUFH.js +0 -1
- package/dist/assets/livescript--BxQO5G_.js +0 -1
- package/dist/assets/logs-panel-B2tW94um.js +0 -1
- package/dist/assets/loro_wasm_bg-CklgjGbG.js +0 -1
- package/dist/assets/lua-CUyaVUOv.js +0 -1
- package/dist/assets/maps-C48Oksn0.js +0 -1
- package/dist/assets/markdown-renderer-CVd_mMPt.js +0 -5
- package/dist/assets/mathematica-ONd8izyd.js +0 -1
- package/dist/assets/mbox-kjl3g9N-.js +0 -1
- package/dist/assets/menu-items-CwUpDHG7.js +0 -1
- package/dist/assets/mermaid-4DMBBIKO-BeB_2G2B.js +0 -1
- package/dist/assets/mermaid-ByDNZESx.js +0 -11
- package/dist/assets/mermaid-parser.core-CzmbMcI0.js +0 -4
- package/dist/assets/mhchem-B4Y0i8Fp.js +0 -1
- package/dist/assets/mindmap-definition-VGOIOE7T-CmLdKdIH.js +0 -68
- package/dist/assets/mirc-BZ6TyuOO.js +0 -1
- package/dist/assets/mllike-Dxt2U6MQ.js +0 -1
- package/dist/assets/modelica-B9sdhdtj.js +0 -1
- package/dist/assets/mscgen-5e5Z5trn.js +0 -1
- package/dist/assets/multi-map-rafH3cg3.js +0 -1
- package/dist/assets/mumps-BUfWDrRe.js +0 -1
- package/dist/assets/name-cell-input-DDQOQSsh.js +0 -1
- package/dist/assets/nsis-Dq7T79DJ.js +0 -1
- package/dist/assets/nsis-QuE155sg.js +0 -1
- package/dist/assets/ntriples-Dqzi7kwu.js +0 -1
- package/dist/assets/number-overlay-editor-C8YnP6Ac.js +0 -9
- package/dist/assets/numbers-CAW8yjzj.js +0 -1
- package/dist/assets/octave-v4IgjFm5.js +0 -1
- package/dist/assets/ordinal-C9PZ4yw5.js +0 -1
- package/dist/assets/outline-panel-BuTQis3o.js +0 -1
- package/dist/assets/oz-BtUsXhbc.js +0 -1
- package/dist/assets/packages-panel-CVu8Cpkz.js +0 -1
- package/dist/assets/packet-DYOGHKS2-BqwwD9JS.js +0 -1
- package/dist/assets/panels-COAp5_gz.js +0 -1
- package/dist/assets/pascal-DV7k6vJ0.js +0 -1
- package/dist/assets/pathUtils-DOhgNpTR.js +0 -1
- package/dist/assets/perl-Bz7YaP_R.js +0 -1
- package/dist/assets/pie-VRWISCQL-BqNfdcWg.js +0 -1
- package/dist/assets/pieDiagram-ADFJNKIX-MH-0tvkn.js +0 -30
- package/dist/assets/pig-BQWmcOEQ.js +0 -1
- package/dist/assets/popover-UExmgBsf.js +0 -1
- package/dist/assets/powershell-CmIFs71i.js +0 -1
- package/dist/assets/precisionRound-C3fmBb6j.js +0 -1
- package/dist/assets/process-output-DSqjZYr-.js +0 -1
- package/dist/assets/properties-D7F2Eomu.js +0 -1
- package/dist/assets/protobuf-BMELuvny.js +0 -1
- package/dist/assets/pug-C2KbP_v3.js +0 -1
- package/dist/assets/pug-NA-6TsNe.js +0 -1
- package/dist/assets/puppet-C7MviiPj.js +0 -1
- package/dist/assets/python-BUl8uFIl.js +0 -1
- package/dist/assets/q-B5bIbNKB.js +0 -1
- package/dist/assets/quadrantDiagram-AYHSOK5B-BSw-Ouba.js +0 -7
- package/dist/assets/r-B0lU_x8o.js +0 -1
- package/dist/assets/radar-ZZBFDIW7-CYyEWqrT.js +0 -1
- package/dist/assets/radio-group-CpHTexlq.js +0 -1
- package/dist/assets/react-vega-B30MPQ4_.js +0 -188
- package/dist/assets/react-vega-CXAF6OHL.js +0 -1
- package/dist/assets/readonly-python-code-DOXF2p8K.js +0 -1
- package/dist/assets/renderShortcut-Bfk4NjRL.js +0 -1
- package/dist/assets/request-registry-5ELz5pd2.js +0 -1
- package/dist/assets/requirementDiagram-UZGBJVZJ-BtGFP-o9.js +0 -64
- package/dist/assets/reveal-component-CJYRD8Yf.js +0 -91
- package/dist/assets/rpm-BqQ3VFpY.js +0 -1
- package/dist/assets/ruby-AFh8QoqR.js +0 -1
- package/dist/assets/run-page-CTQJzZGR.js +0 -1
- package/dist/assets/runs-DRld30N_.js +0 -1
- package/dist/assets/sankeyDiagram-TZEHDZUN-yIdYlc6x.js +0 -10
- package/dist/assets/sas-CeRTI9sn.js +0 -1
- package/dist/assets/save-worker-CvbUHJh7.js +0 -77
- package/dist/assets/scheme-D0VcE_o1.js +0 -1
- package/dist/assets/scratchpad-panel-SgUSM06x.js +0 -1
- package/dist/assets/secrets-panel-B8CbRNMo.js +0 -1
- package/dist/assets/select-5i7URBEn.js +0 -1
- package/dist/assets/sequenceDiagram-WL72ISMW-DQwYuLw4.js +0 -145
- package/dist/assets/session-VtovaFBS.js +0 -1
- package/dist/assets/session-panel-DHfR6tDv.js +0 -1
- package/dist/assets/share-CqnSBwZy.js +0 -1
- package/dist/assets/shell-BBh9RTgS.js +0 -1
- package/dist/assets/sieve-BSX0MHaT.js +0 -1
- package/dist/assets/slides-BVvo79ll.css +0 -1
- package/dist/assets/smalltalk-PvrpLgKW.js +0 -1
- package/dist/assets/snippets-panel-CGs_ME5h.js +0 -1
- package/dist/assets/sparql-CXsmb8zq.js +0 -1
- package/dist/assets/spec-Cq8FVoTf.js +0 -1
- package/dist/assets/src-Cf4NnJCp.js +0 -1
- package/dist/assets/state-B34hXjp9.js +0 -1
- package/dist/assets/state-BV_qjCwT.js +0 -1
- package/dist/assets/state-B_kYpAQh.js +0 -3
- package/dist/assets/state-DzJiyfWW.js +0 -1
- package/dist/assets/stateDiagram-FKZM4ZOC-CseMlyhB.js +0 -1
- package/dist/assets/stateDiagram-v2-4FDKWEC3-Bpp9WfFj.js +0 -1
- package/dist/assets/step-CVy5FnKg.js +0 -1
- package/dist/assets/stex-D6sqtveI.js +0 -1
- package/dist/assets/strings-md4mFbOQ.js +0 -2
- package/dist/assets/stylus-B60bUBy2.js +0 -1
- package/dist/assets/swift-BwnHGvoR.js +0 -1
- package/dist/assets/swiper-component-CBSZ9l9W.js +0 -1
- package/dist/assets/switch-BvybnC9P.js +0 -1
- package/dist/assets/tcl-Bj8phnhq.js +0 -1
- package/dist/assets/terminal-bb566dQu.js +0 -62
- package/dist/assets/textarea-bAp21zYj.js +0 -1
- package/dist/assets/textile-WPCmEeGb.js +0 -1
- package/dist/assets/time-RwUekUwP.js +0 -1
- package/dist/assets/timeline-definition-IT6M3QCI-Cac1cr1H.js +0 -61
- package/dist/assets/toml-Cdfp0vaG.js +0 -1
- package/dist/assets/tooltip-Gcwqb_SK.js +0 -1
- package/dist/assets/tracing-HakOQiQR.js +0 -1
- package/dist/assets/tracing-panel-eas_Nc-b.js +0 -2
- package/dist/assets/tree-actions-Ci3CV3hN.js +0 -1
- package/dist/assets/treemap-GDKQZRPO-Bimjb3pR.js +0 -1
- package/dist/assets/troff-D4suUzlg.js +0 -1
- package/dist/assets/ttcn-CvD_6RGm.js +0 -1
- package/dist/assets/ttcn-cfg-BX59kgnW.js +0 -1
- package/dist/assets/turtle-midFOTTV.js +0 -1
- package/dist/assets/useBoolean-xXcxYCaI.js +0 -1
- package/dist/assets/useCellActionButton-CHLJURZ7.js +0 -1
- package/dist/assets/useDateFormatter-CgFoBhVq.js +0 -1
- package/dist/assets/useDeleteCell-GFhvGBJ7.js +0 -1
- package/dist/assets/useDependencyPanelTab-DHd7_0b9.js +0 -1
- package/dist/assets/useEventListener-BR0C1MaI.js +0 -1
- package/dist/assets/useHotkey-DccKPSPx.js +0 -1
- package/dist/assets/useIframeCapabilities-BvE4n6hj.js +0 -1
- package/dist/assets/useInstallPackage-D0NLybAx.js +0 -1
- package/dist/assets/useInterval-CvFz96h2.js +0 -1
- package/dist/assets/useNotebookActions-CrtC0jVZ.js +0 -1
- package/dist/assets/useNumberFormatter-DtiQW2H_.js +0 -1
- package/dist/assets/usePress-CfcdTqJM.js +0 -7
- package/dist/assets/useRunCells-RJeImyCn.js +0 -1
- package/dist/assets/useSplitCell-BRZ3fmLD.js +0 -1
- package/dist/assets/useTheme-DFXuDFj9.js +0 -1
- package/dist/assets/utils-BrXijSdZ.js +0 -1
- package/dist/assets/utils-CGtUbqcR.js +0 -61
- package/dist/assets/vb-CSNH0UHQ.js +0 -1
- package/dist/assets/vbscript-DTgXfl5y.js +0 -1
- package/dist/assets/vega-component-Bq0lrkG7.js +0 -1
- package/dist/assets/vega-loader.browser-BegSZk0G.js +0 -6
- package/dist/assets/velocity-CKgzALh9.js +0 -1
- package/dist/assets/verilog-NDqaS3bW.js +0 -1
- package/dist/assets/vhdl-BibQgFNM.js +0 -1
- package/dist/assets/webidl-BjqVurO-.js +0 -1
- package/dist/assets/worker-CF8V9c2V.js +0 -120
- package/dist/assets/write-secret-modal-D8Sww7eA.js +0 -1
- package/dist/assets/ws-BZQmQxZ7.js +0 -22
- package/dist/assets/xquery-DQLXMdMd.js +0 -1
- package/dist/assets/xychartDiagram-PRI3JC2R-DwmHTbm4.js +0 -7
- package/dist/assets/yacas-DlkZlCdY.js +0 -1
- package/dist/assets/z80-YKwwCjvZ.js +0 -1
- package/src/components/chat/tool-call-accordion.tsx +0 -247
- /package/dist/assets/{Deferred-DMWKlZOV.js → Deferred-DWBqOhWa.js} +0 -0
- /package/dist/assets/{ImageComparisonComponent-MKB-qBjQ.js → ImageComparisonComponent-nhywlX8O.js} +0 -0
- /package/dist/assets/{Inputs-NeZ9OMUu.js → Inputs-COvM_tLq.js} +0 -0
- /package/dist/assets/{Plot-KSPp-GdN.js → Plot-BDBiXfv_.js} +0 -0
- /package/dist/assets/{SSRProvider-kyGHZp36.js → SSRProvider-BIDQNg9Q.js} +0 -0
- /package/dist/assets/{alert-DvqcBMUv.js → alert-DrHguQlr.js} +0 -0
- /package/dist/assets/{apl-DHQPYmx2.js → apl-iXnrDoYq.js} +0 -0
- /package/dist/assets/{array-Cf4PUXPA.js → array-DdrmtJsl.js} +0 -0
- /package/dist/assets/{asciiarmor-fnQAw8T8.js → asciiarmor-CK-aFa78.js} +0 -0
- /package/dist/assets/{asn1-5lb7I37s.js → asn1-DWJdxrMP.js} +0 -0
- /package/dist/assets/{asterisk-XerxOHb_.js → asterisk-DmqsRS7E.js} +0 -0
- /package/dist/assets/{azure-C2Di2emT.js → azure-DBVzcmvx.js} +0 -0
- /package/dist/assets/{badge-C7-HR1IO.js → badge-DOX1Xxa9.js} +0 -0
- /package/dist/assets/{blob-Daju1h1M.js → blob-3_FN0u9S.js} +0 -0
- /package/dist/assets/{brainfuck-D30bRgvC.js → brainfuck-0bMZHpH_.js} +0 -0
- /package/dist/assets/{bundle.esm-BIoPrMH_.js → bundle.esm-BXIlAZ6T.js} +0 -0
- /package/dist/assets/{card-ICvk7-qa.js → card-BFWJLptH.js} +0 -0
- /package/dist/assets/{chunk-4F5CHEZ2-CRKjiogH.js → chunk-4F5CHEZ2-BqEXxh1Z.js} +0 -0
- /package/dist/assets/{chunk-B2363JML-DvPUNzRx.js → chunk-B2363JML-BMBEdPpn.js} +0 -0
- /package/dist/assets/{chunk-DR5Q36YT-DrxpR6Mz.js → chunk-DR5Q36YT-DKTVLAfY.js} +0 -0
- /package/dist/assets/{chunk-FRFDVMJY-DpWfc7R9.js → chunk-FRFDVMJY-CfFB3K1V.js} +0 -0
- /package/dist/assets/{chunk-PL6DKKU2-D7_8iK_E.js → chunk-PL6DKKU2-B33xUOa0.js} +0 -0
- /package/dist/assets/{chunk-SJTYNZTY-DwmVeUIB.js → chunk-SJTYNZTY-8WPtvsjT.js} +0 -0
- /package/dist/assets/{chunk-TQ3KTPDO-BdfwTgi0.js → chunk-TQ3KTPDO-D2AjvUV_.js} +0 -0
- /package/dist/assets/{chunk-UMXZTB3W-BZR4zVXt.js → chunk-UMXZTB3W-BCNtLoey.js} +0 -0
- /package/dist/assets/{clear-button-DJUQ_tmP.js → clear-button-pxtY_gQU.js} +0 -0
- /package/dist/assets/{click-outside-container-Npdlddni.js → click-outside-container-C9uindjY.js} +0 -0
- /package/dist/assets/{clike-jZeb2kFn.js → clike-5SQqmvx2.js} +0 -0
- /package/dist/assets/{clojure-C0pkR8m2.js → clojure-B0kIwyv8.js} +0 -0
- /package/dist/assets/{cmake-DlvFtk_M.js → cmake-CLXeINvH.js} +0 -0
- /package/dist/assets/{cobol-C_yb45mr.js → cobol-C9SsG--s.js} +0 -0
- /package/dist/assets/{coffeescript-DBK0AeMT.js → coffeescript-UIQG6RnU.js} +0 -0
- /package/dist/assets/{colors-DUsH-HF1.js → colors-CDxbWdyG.js} +0 -0
- /package/dist/assets/{common-keywords-D2VmoaPb.js → common-keywords-Bf68gXm2.js} +0 -0
- /package/dist/assets/{commonlisp-Bo8hOdn-.js → commonlisp-BBPumpJY.js} +0 -0
- /package/dist/assets/{crystal-DYrQEMVi.js → crystal-CGN1wsuY.js} +0 -0
- /package/dist/assets/{css-zh47N2UC.js → css-aQ-Krb7T.js} +0 -0
- /package/dist/assets/{cypher-BWPAHm69.js → cypher-DEE4_Yec.js} +0 -0
- /package/dist/assets/{cytoscape.esm-B7Zr-PlQ.js → cytoscape.esm-DuXIsNbY.js} +0 -0
- /package/dist/assets/{d-CMuL95tt.js → d-CgJ8N-gL.js} +0 -0
- /package/dist/assets/{defaultLocale-YteS-k_t.js → defaultLocale-DPBdGRrH.js} +0 -0
- /package/dist/assets/{defaultLocale-B6z1Qyqt.js → defaultLocale-Lfi0pexn.js} +0 -0
- /package/dist/assets/{diff-oor_HZ51.js → diff-B8e18dKs.js} +0 -0
- /package/dist/assets/{dist-VjDnmGCZ.js → dist-BU26XwgJ.js} +0 -0
- /package/dist/assets/{dist-DdITFgCr.js → dist-Bm0v4xuz.js} +0 -0
- /package/dist/assets/{dist-E6ttb8td.js → dist-COs9gIu5.js} +0 -0
- /package/dist/assets/{dist-B847wb8t.js → dist-CTvZbFwy.js} +0 -0
- /package/dist/assets/{dist-Bu99ARwH.js → dist-CyKkoCYJ.js} +0 -0
- /package/dist/assets/{dist-D_yqofzt.js → dist-DGhKKgfN.js} +0 -0
- /package/dist/assets/{dist-DsbE_iBm.js → dist-DP9Si-4r.js} +0 -0
- /package/dist/assets/{dist-CpSELpRR.js → dist-DQ3_8QJg.js} +0 -0
- /package/dist/assets/{dist-CBX4gLSR.js → dist-DjGavUj4.js} +0 -0
- /package/dist/assets/{dist-B324sPca.js → dist-DkA__6UI.js} +0 -0
- /package/dist/assets/{dist-1sgFrolC.js → dist-EbJ2Bafg.js} +0 -0
- /package/dist/assets/{dist-Bxj5sO2I.js → dist-FS1xQUNb.js} +0 -0
- /package/dist/assets/{dist-BjkXqMhR.js → dist-Scx61XLd.js} +0 -0
- /package/dist/assets/{dtd-Fe_Eikw6.js → dtd-DtwMcoo9.js} +0 -0
- /package/dist/assets/{duckdb-keywords-qEANwaB-.js → duckdb-keywords-BWKLsQSd.js} +0 -0
- /package/dist/assets/{dylan-DjUZAjRK.js → dylan-Be6i1K-V.js} +0 -0
- /package/dist/assets/{ebnf-BbpZiR1i.js → ebnf-dezZofVm.js} +0 -0
- /package/dist/assets/{ecl-qgyT1LqI.js → ecl-D5tlhe8s.js} +0 -0
- /package/dist/assets/{eiffel-Dgulx8rf.js → eiffel-8SQWO4xP.js} +0 -0
- /package/dist/assets/{elm-BvFY4GJb.js → elm-CtGe_7Jw.js} +0 -0
- /package/dist/assets/{emotion-is-prop-valid.esm-DD4AwVTU.js → emotion-is-prop-valid.esm-Dangy3Bv.js} +0 -0
- /package/dist/assets/{empty-state-vCWg-_A9.js → empty-state-CcobJSnG.js} +0 -0
- /package/dist/assets/{en-US-D_il4jD7.js → en-US-C7vnqfgk.js} +0 -0
- /package/dist/assets/{erlang-Ba0XOLlj.js → erlang-CNwX3Z_M.js} +0 -0
- /package/dist/assets/{errors-CPlNr33a.js → errors-iwK4b4VF.js} +0 -0
- /package/dist/assets/{esm-C9WujutX.js → esm-CX-gNDKf.js} +0 -0
- /package/dist/assets/{events-BRAWQiYK.js → events-CBm-hwqS.js} +0 -0
- /package/dist/assets/{extends-B2LJnKU3.js → extends-Dqvpuc10.js} +0 -0
- /package/dist/assets/{eye-off-n1Li95bE.js → eye-off-BT-KOYV5.js} +0 -0
- /package/dist/assets/{fcl-CvYyfPhf.js → fcl-D566gDVV.js} +0 -0
- /package/dist/assets/{file-BrdxGLRX.js → file-HTLbeC2b.js} +0 -0
- /package/dist/assets/{file-headphone-BrQspHac.js → file-headphone-B3fuktN0.js} +0 -0
- /package/dist/assets/{forth-gbBFxz8f.js → forth-CaVwPSxM.js} +0 -0
- /package/dist/assets/{fortran-CXijpPbh.js → fortran-B28t9xoj.js} +0 -0
- /package/dist/assets/{gas-CnHGSLCd.js → gas-BSiJHAcz.js} +0 -0
- /package/dist/assets/{gherkin-DfEZpSxY.js → gherkin-1QurHPOF.js} +0 -0
- /package/dist/assets/{github-BKS_2Qwn.js → github-raQvpeuZ.js} +0 -0
- /package/dist/assets/{groovy-9JiNA9gq.js → groovy-DFOLwJLv.js} +0 -0
- /package/dist/assets/{haskell-CKr_RZFK.js → haskell-CUN2jxPH.js} +0 -0
- /package/dist/assets/{haxe-DsAAHfaR.js → haxe-BYzKptPQ.js} +0 -0
- /package/dist/assets/{house-mGK3v0Mm.js → house-D2ldnAB9.js} +0 -0
- /package/dist/assets/{http-BJwmEMko.js → http-Ms617AZI.js} +0 -0
- /package/dist/assets/{icons-D9TuFTJG.js → icons-8tfAri2V.js} +0 -0
- /package/dist/assets/{idl-Djz72z1a.js → idl-cdmrQY5J.js} +0 -0
- /package/dist/assets/{image-DQHXdEQn.js → image-BIibSXT6.js} +0 -0
- /package/dist/assets/{init-DRQmrFIb.js → init-DiAYA_Co.js} +0 -0
- /package/dist/assets/{isValid-C8T5uJYI.js → isValid-DdlR4-BY.js} +0 -0
- /package/dist/assets/{javascript-CsBr0q2-.js → javascript-l5LYdpfx.js} +0 -0
- /package/dist/assets/{julia-BCYfl68O.js → julia-DxiTohY8.js} +0 -0
- /package/dist/assets/{katex-BywUFgaS.js → katex-CgXtp7UB.js} +0 -0
- /package/dist/assets/{kbd-B3Breaz2.js → kbd-BJB2rf7K.js} +0 -0
- /package/dist/assets/{link-CfEtM3Rl.js → link-CoJxTwWE.js} +0 -0
- /package/dist/assets/{links-Dpap8NI2.js → links-B8WzCnbo.js} +0 -0
- /package/dist/assets/{livescript-BEw7FNJP.js → livescript-BZkzGFkJ.js} +0 -0
- /package/dist/assets/{loro_wasm_bg-BArxhAm3.js → loro_wasm_bg-C5TJxMR5.js} +0 -0
- /package/dist/assets/{lua-DqxHXOsz.js → lua-rVV1vLen.js} +0 -0
- /package/dist/assets/{marimo-icons-Dk6YhPWV.js → marimo-icons-CUuBQ0ae.js} +0 -0
- /package/dist/assets/{math-BJjKGmt3.js → math-CS811RUM.js} +0 -0
- /package/dist/assets/{mathematica-Do-octY0.js → mathematica-DktJ0aJB.js} +0 -0
- /package/dist/assets/{mbox-VgrgGytk.js → mbox-Ch6IVA7h.js} +0 -0
- /package/dist/assets/{message-circle-CWm2KnSx.js → message-circle-1YLdnr8A.js} +0 -0
- /package/dist/assets/{micromark-factory-space-DzSMahmM.js → micromark-factory-space-BUQpMdx2.js} +0 -0
- /package/dist/assets/{mirc-DkD5mNIp.js → mirc-CdWws4At.js} +0 -0
- /package/dist/assets/{mllike-C8Ah4kKN.js → mllike-CB0tp4Bz.js} +0 -0
- /package/dist/assets/{modelica-2q7w6nLE.js → modelica-DQGg_xsi.js} +0 -0
- /package/dist/assets/{mscgen-BRqvO7u4.js → mscgen-vDSxnAXy.js} +0 -0
- /package/dist/assets/{multi-icon-BvuxcR2m.js → multi-icon-NVkxesVZ.js} +0 -0
- /package/dist/assets/{mumps-CjtiTT1a.js → mumps-BzlVzIzl.js} +0 -0
- /package/dist/assets/{nginx-JMUOT8EG.js → nginx-CNtYBWy9.js} +0 -0
- /package/dist/assets/{node-sql-parser-TdBo37ty.js → node-sql-parser-BvUFblwL.js} +0 -0
- /package/dist/assets/{ntriples-4lauqsM6.js → ntriples-BndMB6TK.js} +0 -0
- /package/dist/assets/{objectWithoutPropertiesLoose-DaPAPabU.js → objectWithoutPropertiesLoose-DoKw85w0.js} +0 -0
- /package/dist/assets/{octave-A2kFK0nR.js → octave-DhnkL0CH.js} +0 -0
- /package/dist/assets/{oz-CvXDMSbl.js → oz-DbZmNL9y.js} +0 -0
- /package/dist/assets/{panel-context-D-qi_oxP.js → panel-context-DQWeG2KK.js} +0 -0
- /package/dist/assets/{pascal-6Jinj26u.js → pascal-DhE1sEjD.js} +0 -0
- /package/dist/assets/{path-D7fidI_g.js → path-D1tAOolS.js} +0 -0
- /package/dist/assets/{paths-BXWH6vv4.js → paths-SFhaqGlE.js} +0 -0
- /package/dist/assets/{perl-CXauYQdN.js → perl-BOZHK4Y3.js} +0 -0
- /package/dist/assets/{pig-Dl0QLQI6.js → pig-eswHTOE9.js} +0 -0
- /package/dist/assets/{play-C7DcCsoO.js → play-5vQl-hy9.js} +0 -0
- /package/dist/assets/{plus-BgB18UzY.js → plus-CxkHs8QM.js} +0 -0
- /package/dist/assets/{powershell-6bdy_rHW.js → powershell-pm9G_Qg5.js} +0 -0
- /package/dist/assets/{preload-helper-DItdS47A.js → preload-helper-DdZsAcJe.js} +0 -0
- /package/dist/assets/{prop-types-BiQYf0aU.js → prop-types-DVDiRdwc.js} +0 -0
- /package/dist/assets/{properties-p1rx3aF7.js → properties-7VoeFdHR.js} +0 -0
- /package/dist/assets/{protobuf-BZ6p9Xh_.js → protobuf-BAsuCsmK.js} +0 -0
- /package/dist/assets/{puppet-CjdIRV7D.js → puppet-DUYPK8CV.js} +0 -0
- /package/dist/assets/{purify.es-DBmVz-Wl.js → purify.es-DvRMX74T.js} +0 -0
- /package/dist/assets/{python-uzyJYIWU.js → python-UQl3_T6H.js} +0 -0
- /package/dist/assets/{q-CfD3i9uI.js → q-CnvA_jxT.js} +0 -0
- /package/dist/assets/{r-JyJdYHQB.js → r-fM1OLzJB.js} +0 -0
- /package/dist/assets/{range-7fnH_zLA.js → range-Dk7lXDev.js} +0 -0
- /package/dist/assets/{react-icons.esm-D9xfKaPZ.js → react-icons.esm--O4lBTlZ.js} +0 -0
- /package/dist/assets/{react-resizable-panels.browser.esm-BUNcfKXO.js → react-resizable-panels.browser.esm-Ce2ksurd.js} +0 -0
- /package/dist/assets/{refresh-ccw-C-n2VFP5.js → refresh-ccw-DLc784Sj.js} +0 -0
- /package/dist/assets/{refresh-cw-DHwG4Mac.js → refresh-cw-a_9k9BK7.js} +0 -0
- /package/dist/assets/{requests-QKoDeQkn.js → requests-DqJEWJ-Q.js} +0 -0
- /package/dist/assets/{rotate-ccw-CNsAb2VZ.js → rotate-ccw-DoQtGgvU.js} +0 -0
- /package/dist/assets/{rpm-DuGPfDyX.js → rpm-D62D_dq6.js} +0 -0
- /package/dist/assets/{ruby-CA1TzLxZ.js → ruby-DemvBD0m.js} +0 -0
- /package/dist/assets/{sas-BJPWZC7M.js → sas-CZjYQi4h.js} +0 -0
- /package/dist/assets/{save-Clg5dMoP.js → save-DZ5aail6.js} +0 -0
- /package/dist/assets/{scheme-IRagAY3r.js → scheme-nPNaP0Qp.js} +0 -0
- /package/dist/assets/{semaphore-QJCD9q3h.js → semaphore-X3ApuO41.js} +0 -0
- /package/dist/assets/{settings-DfFe0dWD.js → settings-SnYErNWQ.js} +0 -0
- /package/dist/assets/{shell-BVpF3W_J.js → shell-BE2ANxN1.js} +0 -0
- /package/dist/assets/{sieve-BSfPMeZl.js → sieve-DXFUN4C7.js} +0 -0
- /package/dist/assets/{simple-mode-BmS_AmGQ.js → simple-mode-CZ1ts7NY.js} +0 -0
- /package/dist/assets/{smalltalk-CkHVehky.js → smalltalk-DwXXlSAY.js} +0 -0
- /package/dist/assets/{solr-BHjX6hxO.js → solr-DndbfGC6.js} +0 -0
- /package/dist/assets/{sparkles-CZ5WmLPA.js → sparkles-CC9Bko6a.js} +0 -0
- /package/dist/assets/{sparql-CmKKjr-f.js → sparql-CgejAdiJ.js} +0 -0
- /package/dist/assets/{spinner-Bhir8k53.js → spinner-UuZAUjoP.js} +0 -0
- /package/dist/assets/{spreadsheet-ColK3G9J.js → spreadsheet-DHoeoJHd.js} +0 -0
- /package/dist/assets/{sql-BfkgiLSh.js → sql-DzyjqiRG.js} +0 -0
- /package/dist/assets/{square-function-D1dlJvD8.js → square-function-blYaQso8.js} +0 -0
- /package/dist/assets/{square-DMaNzePN.js → square-rACnnz-q.js} +0 -0
- /package/dist/assets/{src-HwYBNPfa.js → src-D57-7XBB.js} +0 -0
- /package/dist/assets/{stex-CtmkcLz7.js → stex-lcoTi-7o.js} +0 -0
- /package/dist/assets/{stylus-D28PuRsm.js → stylus-CslB9TS3.js} +0 -0
- /package/dist/assets/{swift-D-jfpPuv.js → swift-5t7SQPo8.js} +0 -0
- /package/dist/assets/{table-DPyRV1LT.js → table-DQE9hQzM.js} +0 -0
- /package/dist/assets/{tcl-BrQdCDVA.js → tcl-Ddpe8YBc.js} +0 -0
- /package/dist/assets/{textile-DXBc8HMq.js → textile-D_Db33mq.js} +0 -0
- /package/dist/assets/{tiddlywiki-DzM1IR9M.js → tiddlywiki-Laz7iVQn.js} +0 -0
- /package/dist/assets/{tiki-DI4TiGi6.js → tiki-Dd2_LAYu.js} +0 -0
- /package/dist/assets/{timer-ffBO1paY.js → timer-B6DpdVnC.js} +0 -0
- /package/dist/assets/{toml-ClSouHPE.js → toml-CgkLq_pv.js} +0 -0
- /package/dist/assets/{trash-2-CKlZA04n.js → trash-2-BJLYnZpG.js} +0 -0
- /package/dist/assets/{trash-CdBDfa8x.js → trash-wVOgGgQw.js} +0 -0
- /package/dist/assets/{treemap-CZF0Enj1.js → treemap-Cli48Hv9.js} +0 -0
- /package/dist/assets/{triangle-alert-B8l157gP.js → triangle-alert-CJ0ZIqcz.js} +0 -0
- /package/dist/assets/{troff-BGDyQn9x.js → troff-6nX9d05T.js} +0 -0
- /package/dist/assets/{ttcn-De1OdISX.js → ttcn-Dd4SMoHT.js} +0 -0
- /package/dist/assets/{ttcn-cfg-CQMSrhCz.js → ttcn-cfg-ByNDYolW.js} +0 -0
- /package/dist/assets/{turtle-DNhfxysg.js → turtle-LDF8uFGv.js} +0 -0
- /package/dist/assets/{types-W8WWuumF.js → types-BYwxXaSY.js} +0 -0
- /package/dist/assets/{types-Bhw3Hco_.js → types-DZmRsGZN.js} +0 -0
- /package/dist/assets/{use-toast-T0_cQDma.js → use-toast-ERM44-k9.js} +0 -0
- /package/dist/assets/{useAsyncData-BFC6lWG9.js → useAsyncData-C5i0IRVM.js} +0 -0
- /package/dist/assets/{useDebounce-CLMpJfhX.js → useDebounce-_BZcy6gx.js} +0 -0
- /package/dist/assets/{useDeepCompareMemoize-D0WTlCXt.js → useDeepCompareMemoize-CWcgQCbT.js} +0 -0
- /package/dist/assets/{uuid-DercMavo.js → uuid-D_zLHhNi.js} +0 -0
- /package/dist/assets/{vb-BX7-Md9G.js → vb-DaLxM60T.js} +0 -0
- /package/dist/assets/{vbscript-DNMzJOTU.js → vbscript-CwitZ57u.js} +0 -0
- /package/dist/assets/{velocity-viirwPm7.js → velocity-D6bc4mrP.js} +0 -0
- /package/dist/assets/{verilog-CZguTLBV.js → verilog-CIyPdzYJ.js} +0 -0
- /package/dist/assets/{vhdl-CAEhCBOl.js → vhdl-DfyhlM4K.js} +0 -0
- /package/dist/assets/{web-vitals-CBsQ2DM_.js → web-vitals-BaMazlva.js} +0 -0
- /package/dist/assets/{webidl-BNJg_7gX.js → webidl-C23hA3Le.js} +0 -0
- /package/dist/assets/{workflow-ClChd5xI.js → workflow-CgnDnnoN.js} +0 -0
- /package/dist/assets/{xquery-CGV_r322.js → xquery-BAVQXrAf.js} +0 -0
- /package/dist/assets/{yacas-uRzw7z7m.js → yacas-DrybVty2.js} +0 -0
- /package/dist/assets/{youtube-CbdpN8oL.js → youtube-3lRHw8NU.js} +0 -0
- /package/dist/assets/{z80-CBK8t-9T.js → z80-8KI6AMtY.js} +0 -0
|
@@ -28,6 +28,7 @@ describe("ConsoleOutput integration", () => {
|
|
|
28
28
|
cellName: "test_cell",
|
|
29
29
|
consoleOutputs: [] as WithResponse<OutputMessage>[],
|
|
30
30
|
stale: false,
|
|
31
|
+
interrupted: false,
|
|
31
32
|
debuggerActive: false,
|
|
32
33
|
onSubmitDebugger: () => {
|
|
33
34
|
// noop
|
|
@@ -59,6 +60,7 @@ describe("ConsoleOutput pdb history", () => {
|
|
|
59
60
|
cellName: "test_cell",
|
|
60
61
|
consoleOutputs: [] as WithResponse<OutputMessage>[],
|
|
61
62
|
stale: false,
|
|
63
|
+
interrupted: false,
|
|
62
64
|
debuggerActive: false,
|
|
63
65
|
onSubmitDebugger: vi.fn(),
|
|
64
66
|
};
|
|
@@ -118,6 +120,82 @@ describe("ConsoleOutput pdb history", () => {
|
|
|
118
120
|
expect(newInput).toHaveValue("next");
|
|
119
121
|
});
|
|
120
122
|
|
|
123
|
+
it("should submit an empty string when Enter is pressed with no input", () => {
|
|
124
|
+
// Many CLIs prompt "Press Enter to continue" and expect "" back.
|
|
125
|
+
const onSubmitDebugger = vi.fn();
|
|
126
|
+
const outputs: WithResponse<OutputMessage>[] = [
|
|
127
|
+
stdinPrompt("Press Enter to continue: "),
|
|
128
|
+
];
|
|
129
|
+
|
|
130
|
+
renderWithProvider(
|
|
131
|
+
<ConsoleOutput
|
|
132
|
+
{...defaultProps}
|
|
133
|
+
consoleOutputs={outputs}
|
|
134
|
+
onSubmitDebugger={onSubmitDebugger}
|
|
135
|
+
/>,
|
|
136
|
+
);
|
|
137
|
+
|
|
138
|
+
const input = screen.getByTestId("console-input");
|
|
139
|
+
fireEvent.keyDown(input, { key: "Enter" });
|
|
140
|
+
|
|
141
|
+
expect(onSubmitDebugger).toHaveBeenCalledWith("", 0);
|
|
142
|
+
});
|
|
143
|
+
|
|
144
|
+
it("should not record empty submissions in input history", () => {
|
|
145
|
+
const onSubmitDebugger = vi.fn();
|
|
146
|
+
const outputs1: WithResponse<OutputMessage>[] = [stdinPrompt("(Pdb) ")];
|
|
147
|
+
|
|
148
|
+
const { rerender } = renderWithProvider(
|
|
149
|
+
<ConsoleOutput
|
|
150
|
+
{...defaultProps}
|
|
151
|
+
consoleOutputs={outputs1}
|
|
152
|
+
onSubmitDebugger={onSubmitDebugger}
|
|
153
|
+
/>,
|
|
154
|
+
);
|
|
155
|
+
|
|
156
|
+
let input = screen.getByTestId("console-input");
|
|
157
|
+
fireEvent.change(input, { target: { value: "step" } });
|
|
158
|
+
fireEvent.keyDown(input, { key: "Enter" });
|
|
159
|
+
|
|
160
|
+
const outputs2: WithResponse<OutputMessage>[] = [
|
|
161
|
+
stdinPrompt("(Pdb) ", "step"),
|
|
162
|
+
stdinPrompt("(Pdb) "),
|
|
163
|
+
];
|
|
164
|
+
rerender(
|
|
165
|
+
<TooltipProvider>
|
|
166
|
+
<ConsoleOutput
|
|
167
|
+
{...defaultProps}
|
|
168
|
+
consoleOutputs={outputs2}
|
|
169
|
+
onSubmitDebugger={onSubmitDebugger}
|
|
170
|
+
/>
|
|
171
|
+
</TooltipProvider>,
|
|
172
|
+
);
|
|
173
|
+
|
|
174
|
+
// Submit an empty value; this should NOT enter the history stack.
|
|
175
|
+
input = screen.getByTestId("console-input");
|
|
176
|
+
fireEvent.keyDown(input, { key: "Enter" });
|
|
177
|
+
|
|
178
|
+
const outputs3: WithResponse<OutputMessage>[] = [
|
|
179
|
+
stdinPrompt("(Pdb) ", "step"),
|
|
180
|
+
stdinPrompt("(Pdb) ", ""),
|
|
181
|
+
stdinPrompt("(Pdb) "),
|
|
182
|
+
];
|
|
183
|
+
rerender(
|
|
184
|
+
<TooltipProvider>
|
|
185
|
+
<ConsoleOutput
|
|
186
|
+
{...defaultProps}
|
|
187
|
+
consoleOutputs={outputs3}
|
|
188
|
+
onSubmitDebugger={onSubmitDebugger}
|
|
189
|
+
/>
|
|
190
|
+
</TooltipProvider>,
|
|
191
|
+
);
|
|
192
|
+
|
|
193
|
+
// ArrowUp should jump back to "step", skipping the empty submission.
|
|
194
|
+
input = screen.getByTestId("console-input");
|
|
195
|
+
fireEvent.keyDown(input, { key: "ArrowUp" });
|
|
196
|
+
expect(input).toHaveValue("step");
|
|
197
|
+
});
|
|
198
|
+
|
|
121
199
|
it("should navigate through multiple history entries across remounts", () => {
|
|
122
200
|
const onSubmitDebugger = vi.fn();
|
|
123
201
|
|
|
@@ -192,6 +270,41 @@ describe("ConsoleOutput pdb history", () => {
|
|
|
192
270
|
fireEvent.keyDown(input, { key: "ArrowDown" });
|
|
193
271
|
expect(input).toHaveValue("");
|
|
194
272
|
});
|
|
273
|
+
|
|
274
|
+
it("should distinguish an interrupted prompt from a bare-Enter submission", () => {
|
|
275
|
+
// After interrupt, cell.ts coerces pending stdin prompts to response: "".
|
|
276
|
+
// We must render that case differently from a real bare-Enter response,
|
|
277
|
+
// so the user isn't told they "submitted" a blank value.
|
|
278
|
+
const interruptedOutputs: WithResponse<OutputMessage>[] = [
|
|
279
|
+
stdinPrompt("Press Enter to continue: ", ""),
|
|
280
|
+
];
|
|
281
|
+
|
|
282
|
+
const { rerender } = renderWithProvider(
|
|
283
|
+
<ConsoleOutput
|
|
284
|
+
{...defaultProps}
|
|
285
|
+
consoleOutputs={interruptedOutputs}
|
|
286
|
+
interrupted={true}
|
|
287
|
+
/>,
|
|
288
|
+
);
|
|
289
|
+
|
|
290
|
+
// No response chunk should be rendered for an interrupted pending prompt.
|
|
291
|
+
expect(screen.queryByLabelText("stdin response")).not.toBeInTheDocument();
|
|
292
|
+
|
|
293
|
+
// Same outputs, but the cell isn't interrupted -- this is a real
|
|
294
|
+
// bare-Enter submission, so we should render the (empty) placeholder.
|
|
295
|
+
rerender(
|
|
296
|
+
<TooltipProvider>
|
|
297
|
+
<ConsoleOutput
|
|
298
|
+
{...defaultProps}
|
|
299
|
+
consoleOutputs={interruptedOutputs}
|
|
300
|
+
interrupted={false}
|
|
301
|
+
/>
|
|
302
|
+
</TooltipProvider>,
|
|
303
|
+
);
|
|
304
|
+
|
|
305
|
+
expect(screen.getByLabelText("stdin response")).toBeInTheDocument();
|
|
306
|
+
expect(screen.getByText("(empty)")).toBeInTheDocument();
|
|
307
|
+
});
|
|
195
308
|
});
|
|
196
309
|
|
|
197
310
|
describe("ConsoleOutput debounced clearing", () => {
|
|
@@ -219,6 +332,7 @@ describe("ConsoleOutput debounced clearing", () => {
|
|
|
219
332
|
cellName: "test_cell",
|
|
220
333
|
consoleOutputs: [] as WithResponse<OutputMessage>[],
|
|
221
334
|
stale: false,
|
|
335
|
+
interrupted: false,
|
|
222
336
|
debuggerActive: false,
|
|
223
337
|
onSubmitDebugger: vi.fn(),
|
|
224
338
|
};
|
|
@@ -4,6 +4,7 @@ import { describe, it, expect } from "vitest";
|
|
|
4
4
|
import { computeSlideCellsInfo } from "../compute-slide-cells";
|
|
5
5
|
import type { SlideConfig, SlidesLayout } from "../types";
|
|
6
6
|
import type { CellId } from "@/core/cells/ids";
|
|
7
|
+
import { cellId } from "@/__tests__/branded";
|
|
7
8
|
|
|
8
9
|
interface TestCell {
|
|
9
10
|
id: CellId;
|
|
@@ -15,10 +16,10 @@ const DEFAULT_OUTPUT: TestCell["output"] = { data: "ok" };
|
|
|
15
16
|
const cell = (
|
|
16
17
|
id: string,
|
|
17
18
|
output: TestCell["output"] = DEFAULT_OUTPUT,
|
|
18
|
-
): TestCell => ({ id: id
|
|
19
|
+
): TestCell => ({ id: cellId(id), output });
|
|
19
20
|
|
|
20
21
|
const layoutOf = (entries: Array<[string, SlideConfig]>): SlidesLayout => ({
|
|
21
|
-
cells: new Map(entries.map(([id, cfg]) => [id
|
|
22
|
+
cells: new Map(entries.map(([id, cfg]) => [cellId(id), cfg])),
|
|
22
23
|
deck: {},
|
|
23
24
|
});
|
|
24
25
|
|
|
@@ -121,7 +122,7 @@ describe("computeSlideCellsInfo", () => {
|
|
|
121
122
|
// Skipped cells are still "visible" deck cells — they just aren't rendered
|
|
122
123
|
// in reveal. The minimap relies on the full list plus skippedIds.
|
|
123
124
|
expect(result.cellsWithOutput.map((c) => c.id)).toEqual(["a", "b", "c"]);
|
|
124
|
-
expect(result.slideTypes.get("b"
|
|
125
|
+
expect(result.slideTypes.get(cellId("b"))).toBe("skip");
|
|
125
126
|
});
|
|
126
127
|
|
|
127
128
|
it("ignores layout entries for cells that have no output", () => {
|
|
@@ -137,7 +138,7 @@ describe("computeSlideCellsInfo", () => {
|
|
|
137
138
|
);
|
|
138
139
|
expect(result.cellsWithOutput.map((c) => c.id)).toEqual(["a"]);
|
|
139
140
|
expect(result.skippedIds.size).toBe(0);
|
|
140
|
-
expect(result.slideTypes.has("b"
|
|
141
|
+
expect(result.slideTypes.has(cellId("b"))).toBe(false);
|
|
141
142
|
});
|
|
142
143
|
|
|
143
144
|
it("preserves the input order of cells in cellsWithOutput", () => {
|
|
@@ -4,10 +4,11 @@ import { describe, it, expect } from "vitest";
|
|
|
4
4
|
import { SlidesLayoutPlugin } from "../plugin";
|
|
5
5
|
import type { CellData } from "@/core/cells/types";
|
|
6
6
|
import type { CellId } from "@/core/cells/ids";
|
|
7
|
+
import { cellId } from "@/__tests__/branded";
|
|
7
8
|
|
|
8
9
|
function makeCell(id: string, code = "print('hi')"): CellData {
|
|
9
10
|
return {
|
|
10
|
-
id: id
|
|
11
|
+
id: cellId(id),
|
|
11
12
|
name: id,
|
|
12
13
|
code,
|
|
13
14
|
edited: false,
|
|
@@ -198,7 +199,10 @@ const BACKWARDS_COMPAT_SNAPSHOTS: BackwardsCompatCase[] = [
|
|
|
198
199
|
},
|
|
199
200
|
{
|
|
200
201
|
// Defensive: if a future version adds a new SlideConfig field and a user
|
|
201
|
-
// downgrades, we must not crash on unknown keys
|
|
202
|
+
// downgrades, we must not crash on unknown keys — AND we must not silently
|
|
203
|
+
// drop them either. `notes` / `background` aren't in the current schema;
|
|
204
|
+
// they must still be present after validate + (de)serialize so a downgrade
|
|
205
|
+
// followed by a save doesn't erase the newer marimo's data.
|
|
202
206
|
label: "forward-compat: unknown SlideConfig fields present",
|
|
203
207
|
input: {
|
|
204
208
|
cells: [{ type: "slide", notes: "x", background: "#000" }],
|
|
@@ -206,7 +210,42 @@ const BACKWARDS_COMPAT_SNAPSHOTS: BackwardsCompatCase[] = [
|
|
|
206
210
|
expected: {
|
|
207
211
|
deck: {},
|
|
208
212
|
cellIds: ["a"],
|
|
209
|
-
cellEntries: [["a", { type: "slide" }]],
|
|
213
|
+
cellEntries: [["a", { type: "slide", notes: "x", background: "#000" }]],
|
|
214
|
+
},
|
|
215
|
+
},
|
|
216
|
+
{
|
|
217
|
+
// Same forward-compat guarantee for unknown deck-level fields (e.g. future
|
|
218
|
+
// Reveal options we haven't modeled yet).
|
|
219
|
+
label: "forward-compat: unknown deck fields present",
|
|
220
|
+
input: {
|
|
221
|
+
cells: [{}],
|
|
222
|
+
deck: { transition: "fade", controls: false, autoSlide: 5000 },
|
|
223
|
+
},
|
|
224
|
+
expected: {
|
|
225
|
+
deck: { transition: "fade", controls: false, autoSlide: 5000 },
|
|
226
|
+
cellIds: ["a"],
|
|
227
|
+
},
|
|
228
|
+
},
|
|
229
|
+
{
|
|
230
|
+
// `speakerNotes` was added to SlideConfig. The validator must
|
|
231
|
+
// know about it (so it isn't silently stripped), the deserializer must
|
|
232
|
+
// carry it through, and serialize → deserialize must round-trip it.
|
|
233
|
+
label: "speakerNotes round-trips through validate + (de)serialize",
|
|
234
|
+
input: {
|
|
235
|
+
cells: [
|
|
236
|
+
{ type: "slide", speakerNotes: "intro" },
|
|
237
|
+
{ type: "fragment", speakerNotes: "" },
|
|
238
|
+
{ type: "fragment", speakerNotes: "multi\n\nline\n\nnotes" },
|
|
239
|
+
],
|
|
240
|
+
},
|
|
241
|
+
expected: {
|
|
242
|
+
deck: {},
|
|
243
|
+
cellIds: ["a", "b", "c"],
|
|
244
|
+
cellEntries: [
|
|
245
|
+
["a", { type: "slide", speakerNotes: "intro" }],
|
|
246
|
+
["b", { type: "fragment", speakerNotes: "" }],
|
|
247
|
+
["c", { type: "fragment", speakerNotes: "multi\n\nline\n\nnotes" }],
|
|
248
|
+
],
|
|
210
249
|
},
|
|
211
250
|
},
|
|
212
251
|
];
|
|
@@ -223,20 +262,21 @@ describe("SlidesLayoutPlugin backwards compatibility", () => {
|
|
|
223
262
|
parsed.success,
|
|
224
263
|
`validator rejected: ${JSON.stringify(input)}`,
|
|
225
264
|
).toBe(true);
|
|
265
|
+
if (!parsed.success) {
|
|
266
|
+
return;
|
|
267
|
+
}
|
|
226
268
|
|
|
227
|
-
// 2.
|
|
228
|
-
|
|
229
|
-
|
|
230
|
-
|
|
231
|
-
|
|
232
|
-
|
|
233
|
-
cells,
|
|
234
|
-
);
|
|
269
|
+
// 2. Deserializing the *validator output* (not the raw input) must
|
|
270
|
+
// preserve every field listed in `expected.cellEntries`. This is what
|
|
271
|
+
// catches a schema regression: if the validator silently strips a
|
|
272
|
+
// known field, the deserialized config won't carry it and the
|
|
273
|
+
// assertion below fails.
|
|
274
|
+
const layout = SlidesLayoutPlugin.deserializeLayout(parsed.data, cells);
|
|
235
275
|
if (expected.deck !== undefined) {
|
|
236
276
|
expect(layout.deck).toEqual(expected.deck);
|
|
237
277
|
}
|
|
238
|
-
for (const [
|
|
239
|
-
expect(layout.cells.get(cellId
|
|
278
|
+
for (const [cellEntryId, expectedConfig] of expected.cellEntries ?? []) {
|
|
279
|
+
expect(layout.cells.get(cellId(cellEntryId))).toMatchObject(
|
|
240
280
|
expectedConfig as object,
|
|
241
281
|
);
|
|
242
282
|
}
|
|
@@ -251,8 +291,8 @@ describe("SlidesLayoutPlugin backwards compatibility", () => {
|
|
|
251
291
|
reserialized,
|
|
252
292
|
cells,
|
|
253
293
|
);
|
|
254
|
-
for (const [
|
|
255
|
-
expect(redeserialized.cells.get(cellId
|
|
294
|
+
for (const [cellEntryId, expectedConfig] of expected.cellEntries ?? []) {
|
|
295
|
+
expect(redeserialized.cells.get(cellId(cellEntryId))).toMatchObject(
|
|
256
296
|
expectedConfig as object,
|
|
257
297
|
);
|
|
258
298
|
}
|
|
@@ -1,15 +1,15 @@
|
|
|
1
1
|
/* Copyright 2026 Marimo. All rights reserved. */
|
|
2
2
|
|
|
3
|
-
import {
|
|
3
|
+
import type { CellId } from "@/core/cells/ids";
|
|
4
|
+
import { Logger } from "@/utils/Logger";
|
|
4
5
|
import type { ICellRendererPlugin } from "../types";
|
|
5
6
|
import { SlidesLayoutRenderer } from "./slides-layout";
|
|
6
|
-
import
|
|
7
|
-
SerializedSlidesLayout,
|
|
8
|
-
SlideConfig,
|
|
9
|
-
SlidesLayout,
|
|
7
|
+
import {
|
|
8
|
+
type SerializedSlidesLayout,
|
|
9
|
+
type SlideConfig,
|
|
10
|
+
type SlidesLayout,
|
|
11
|
+
SlidesLayoutSchema,
|
|
10
12
|
} from "./types";
|
|
11
|
-
import { Logger } from "@/utils/Logger";
|
|
12
|
-
import type { CellId } from "@/core/cells/ids";
|
|
13
13
|
|
|
14
14
|
/**
|
|
15
15
|
* Plugin definition for the slides layout.
|
|
@@ -20,24 +20,7 @@ export const SlidesLayoutPlugin: ICellRendererPlugin<
|
|
|
20
20
|
> = {
|
|
21
21
|
type: "slides",
|
|
22
22
|
name: "Slides",
|
|
23
|
-
|
|
24
|
-
// All fields are optional so layouts saved by older marimo versions will work
|
|
25
|
-
validator: z.object({
|
|
26
|
-
cells: z
|
|
27
|
-
.array(
|
|
28
|
-
z.object({
|
|
29
|
-
type: z.enum(["slide", "sub-slide", "fragment", "skip"]).optional(),
|
|
30
|
-
}),
|
|
31
|
-
)
|
|
32
|
-
.optional(),
|
|
33
|
-
deck: z
|
|
34
|
-
.object({
|
|
35
|
-
transition: z
|
|
36
|
-
.enum(["none", "fade", "slide", "convex", "concave", "zoom"])
|
|
37
|
-
.optional(),
|
|
38
|
-
})
|
|
39
|
-
.optional(),
|
|
40
|
-
}),
|
|
23
|
+
validator: SlidesLayoutSchema,
|
|
41
24
|
|
|
42
25
|
deserializeLayout: (serialized, cells): SlidesLayout => {
|
|
43
26
|
const serializedCells = serialized.cells ?? [];
|
|
@@ -3,6 +3,7 @@ import React, { useMemo, useState } from "react";
|
|
|
3
3
|
import { useAtomValue } from "jotai";
|
|
4
4
|
import { numColumnsAtom } from "@/core/cells/cells";
|
|
5
5
|
import type { CellId } from "@/core/cells/ids";
|
|
6
|
+
import { kioskModeAtom } from "@/core/mode";
|
|
6
7
|
import type { ICellRendererProps } from "../types";
|
|
7
8
|
import type { SlidesLayout } from "./types";
|
|
8
9
|
import { computeSlideCellsInfo } from "./compute-slide-cells";
|
|
@@ -21,7 +22,10 @@ export const SlidesLayoutRenderer: React.FC<Props> = ({
|
|
|
21
22
|
cells,
|
|
22
23
|
mode,
|
|
23
24
|
}) => {
|
|
24
|
-
|
|
25
|
+
// Kiosk clients (e.g. reveal.js's speaker-view iframes) are read-only and
|
|
26
|
+
// shouldn't show authoring chrome, so we collapse to the read-mode layout.
|
|
27
|
+
const kioskMode = useAtomValue(kioskModeAtom);
|
|
28
|
+
const isReading = mode === "read" || kioskMode;
|
|
25
29
|
const numColumns = useAtomValue(numColumnsAtom);
|
|
26
30
|
const isMultiColumn = numColumns > 1;
|
|
27
31
|
const [activeCellId, setActiveCellId] = useState<CellId | null>(null);
|
|
@@ -52,14 +56,23 @@ export const SlidesLayoutRenderer: React.FC<Props> = ({
|
|
|
52
56
|
activeIndex={resolvedIndex}
|
|
53
57
|
onSlideChange={handleSlideChange}
|
|
54
58
|
configWidth={300}
|
|
55
|
-
mode={mode}
|
|
56
|
-
isEditable={
|
|
59
|
+
mode={isReading ? "read" : mode}
|
|
60
|
+
isEditable={!isReading}
|
|
57
61
|
/>
|
|
58
62
|
);
|
|
59
63
|
|
|
60
64
|
if (isReading) {
|
|
61
|
-
//
|
|
62
|
-
//
|
|
65
|
+
// In kiosk mode (e.g. reveal.js's speaker-view iframes), anchor to the
|
|
66
|
+
// iframe viewport with `dvh`/`dvw` so the deck resizes with the popup
|
|
67
|
+
// window. The non-kiosk read mode keeps its 16:9 cap so the deck doesn't
|
|
68
|
+
// balloon to the full viewport on wide screens.
|
|
69
|
+
if (kioskMode) {
|
|
70
|
+
return (
|
|
71
|
+
<div className="flex h-dvh w-dvw overflow-hidden bg-background">
|
|
72
|
+
{slides}
|
|
73
|
+
</div>
|
|
74
|
+
);
|
|
75
|
+
}
|
|
63
76
|
return (
|
|
64
77
|
<div className="p-4 flex flex-1 items-center justify-center min-h-0">
|
|
65
78
|
<div className="h-full max-h-[95vh] aspect-video max-w-full flex">
|
|
@@ -70,7 +83,7 @@ export const SlidesLayoutRenderer: React.FC<Props> = ({
|
|
|
70
83
|
}
|
|
71
84
|
|
|
72
85
|
return (
|
|
73
|
-
<div className="pr-18 pb-2 flex flex-row gap-2 min-h-0">
|
|
86
|
+
<div className="flex-1 pr-18 pb-2 flex flex-row gap-2 min-h-0">
|
|
74
87
|
<SlidesMinimap
|
|
75
88
|
cells={cellsWithOutput}
|
|
76
89
|
thumbnailWidth={220}
|
|
@@ -1,41 +1,50 @@
|
|
|
1
1
|
/* Copyright 2026 Marimo. All rights reserved. */
|
|
2
|
-
/* oxlint-disable typescript/no-empty-object-type */
|
|
3
2
|
|
|
3
|
+
import { z } from "zod";
|
|
4
4
|
import type { CellId } from "@/core/cells/ids";
|
|
5
5
|
|
|
6
|
+
const SlideTypeSchema = z.enum(["slide", "sub-slide", "fragment", "skip"]);
|
|
7
|
+
export type SlideType = z.infer<typeof SlideTypeSchema>;
|
|
8
|
+
|
|
9
|
+
const SlideConfigSchema = z.looseObject({
|
|
10
|
+
type: SlideTypeSchema.optional(),
|
|
11
|
+
speakerNotes: z.string().optional(),
|
|
12
|
+
});
|
|
13
|
+
export type SlideConfig = z.infer<typeof SlideConfigSchema>;
|
|
14
|
+
|
|
15
|
+
const DeckTransitionSchema = z.enum([
|
|
16
|
+
"none",
|
|
17
|
+
"fade",
|
|
18
|
+
"slide",
|
|
19
|
+
"convex",
|
|
20
|
+
"concave",
|
|
21
|
+
"zoom",
|
|
22
|
+
]);
|
|
23
|
+
export type DeckTransition = z.infer<typeof DeckTransitionSchema>;
|
|
24
|
+
|
|
25
|
+
const DeckConfigSchema = z.looseObject({
|
|
26
|
+
transition: DeckTransitionSchema.optional(),
|
|
27
|
+
});
|
|
28
|
+
export type DeckConfig = z.infer<typeof DeckConfigSchema>;
|
|
29
|
+
|
|
6
30
|
/**
|
|
7
|
-
*
|
|
8
|
-
*
|
|
31
|
+
* Schema for the serialized form of a slides layout.
|
|
32
|
+
*
|
|
33
|
+
* This must be backwards-compatible as it is stored on the user's disk —
|
|
34
|
+
* fields are optional so files saved before they existed (e.g. the bare `{}`
|
|
35
|
+
* emitted by earlier marimo versions) still deserialize cleanly. Unknown
|
|
36
|
+
* keys are preserved (via `looseObject`) for the same reason.
|
|
9
37
|
*/
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
cells?: SlideConfig[];
|
|
16
|
-
};
|
|
38
|
+
export const SlidesLayoutSchema = z.looseObject({
|
|
39
|
+
cells: z.array(SlideConfigSchema).optional(),
|
|
40
|
+
deck: DeckConfigSchema.optional(),
|
|
41
|
+
});
|
|
42
|
+
export type SerializedSlidesLayout = z.infer<typeof SlidesLayoutSchema>;
|
|
17
43
|
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
// We map the cells to their IDs so that we can track them as they move around.
|
|
44
|
+
/**
|
|
45
|
+
* Runtime form of a slides layout.
|
|
46
|
+
*/
|
|
47
|
+
export interface SlidesLayout {
|
|
23
48
|
cells: Map<CellId, SlideConfig>;
|
|
24
49
|
deck: DeckConfig;
|
|
25
50
|
}
|
|
26
|
-
|
|
27
|
-
export type SlideType = "slide" | "sub-slide" | "fragment" | "skip";
|
|
28
|
-
export interface SlideConfig {
|
|
29
|
-
type?: SlideType;
|
|
30
|
-
}
|
|
31
|
-
|
|
32
|
-
export type DeckTransition =
|
|
33
|
-
| "none"
|
|
34
|
-
| "fade"
|
|
35
|
-
| "slide"
|
|
36
|
-
| "convex"
|
|
37
|
-
| "concave"
|
|
38
|
-
| "zoom";
|
|
39
|
-
export interface DeckConfig {
|
|
40
|
-
transition?: DeckTransition;
|
|
41
|
-
}
|
|
@@ -16,6 +16,7 @@ import {
|
|
|
16
16
|
LinkIcon,
|
|
17
17
|
MessagesSquareIcon,
|
|
18
18
|
OrbitIcon,
|
|
19
|
+
PackageIcon,
|
|
19
20
|
YoutubeIcon,
|
|
20
21
|
} from "lucide-react";
|
|
21
22
|
import type React from "react";
|
|
@@ -58,6 +59,11 @@ const TUTORIALS: Record<
|
|
|
58
59
|
FileIcon,
|
|
59
60
|
"Understand marimo's pure-Python file format",
|
|
60
61
|
],
|
|
62
|
+
"external-dependencies": [
|
|
63
|
+
"External dependencies",
|
|
64
|
+
PackageIcon,
|
|
65
|
+
"Declare dependencies with Python script metadata",
|
|
66
|
+
],
|
|
61
67
|
"for-jupyter-users": [
|
|
62
68
|
"For Jupyter users",
|
|
63
69
|
OrbitIcon,
|
|
@@ -34,7 +34,10 @@ const RunPage = (props: Props) => {
|
|
|
34
34
|
|
|
35
35
|
const Watermark = () => {
|
|
36
36
|
return (
|
|
37
|
-
<div
|
|
37
|
+
<div
|
|
38
|
+
className="fixed bottom-0 right-0 z-50 print:hidden"
|
|
39
|
+
data-testid="watermark"
|
|
40
|
+
>
|
|
38
41
|
<a
|
|
39
42
|
href={Constants.githubPage}
|
|
40
43
|
target="_blank"
|
|
@@ -0,0 +1,131 @@
|
|
|
1
|
+
/* Copyright 2026 Marimo. All rights reserved. */
|
|
2
|
+
|
|
3
|
+
import { describe, expect, it } from "vitest";
|
|
4
|
+
import type {
|
|
5
|
+
SlideConfig,
|
|
6
|
+
SlideType,
|
|
7
|
+
} from "@/components/editor/renderers/slides-layout/types";
|
|
8
|
+
import type { CellId } from "@/core/cells/ids";
|
|
9
|
+
import { cellId } from "@/__tests__/branded";
|
|
10
|
+
import { composeSlides } from "../compose-slides";
|
|
11
|
+
import { buildSubslideNotes, collectBlockNotes } from "../slide-notes";
|
|
12
|
+
|
|
13
|
+
interface Cell {
|
|
14
|
+
id: CellId;
|
|
15
|
+
type?: SlideType;
|
|
16
|
+
}
|
|
17
|
+
|
|
18
|
+
const cell = (id: string, type?: SlideType): Cell => ({
|
|
19
|
+
id: cellId(id),
|
|
20
|
+
type,
|
|
21
|
+
});
|
|
22
|
+
|
|
23
|
+
const configs = (
|
|
24
|
+
notes: Record<string, string>,
|
|
25
|
+
): ReadonlyMap<CellId, SlideConfig> =>
|
|
26
|
+
new Map(
|
|
27
|
+
Object.entries(notes).map(([id, speakerNotes]) => [
|
|
28
|
+
cellId(id),
|
|
29
|
+
{ speakerNotes } satisfies SlideConfig,
|
|
30
|
+
]),
|
|
31
|
+
);
|
|
32
|
+
|
|
33
|
+
const firstSubslide = (cells: Cell[]) =>
|
|
34
|
+
composeSlides({ cells, getType: (c) => c.type ?? "slide" }).stacks[0]
|
|
35
|
+
.subslides[0];
|
|
36
|
+
|
|
37
|
+
describe("collectBlockNotes", () => {
|
|
38
|
+
it("concatenates non-empty notes with paragraph spacing", () => {
|
|
39
|
+
const result = collectBlockNotes(
|
|
40
|
+
[cell("a"), cell("b"), cell("c")],
|
|
41
|
+
configs({ a: "first", b: "", c: "third" }),
|
|
42
|
+
);
|
|
43
|
+
expect(result).toBe("first\n\nthird");
|
|
44
|
+
});
|
|
45
|
+
|
|
46
|
+
it("returns an empty string when no cell has notes", () => {
|
|
47
|
+
expect(collectBlockNotes([cell("a")], configs({}))).toBe("");
|
|
48
|
+
});
|
|
49
|
+
|
|
50
|
+
it("ignores whitespace-only notes", () => {
|
|
51
|
+
expect(
|
|
52
|
+
collectBlockNotes([cell("a"), cell("b")], configs({ a: " ", b: "x" })),
|
|
53
|
+
).toBe("x");
|
|
54
|
+
});
|
|
55
|
+
});
|
|
56
|
+
|
|
57
|
+
describe("buildSubslideNotes", () => {
|
|
58
|
+
it("returns empty notes when no cell has any", () => {
|
|
59
|
+
const subslide = firstSubslide([cell("a"), cell("b", "fragment")]);
|
|
60
|
+
expect(buildSubslideNotes(subslide, configs({}))).toEqual({
|
|
61
|
+
slideLevel: "",
|
|
62
|
+
cumulativeByBlock: new Map(),
|
|
63
|
+
});
|
|
64
|
+
});
|
|
65
|
+
|
|
66
|
+
it("returns only slide-level notes when there are no fragments", () => {
|
|
67
|
+
const subslide = firstSubslide([cell("a")]);
|
|
68
|
+
expect(buildSubslideNotes(subslide, configs({ a: "intro" }))).toEqual({
|
|
69
|
+
slideLevel: "intro",
|
|
70
|
+
cumulativeByBlock: new Map(),
|
|
71
|
+
});
|
|
72
|
+
});
|
|
73
|
+
|
|
74
|
+
it("accumulates fragments below the slide-level notes with a divider", () => {
|
|
75
|
+
const subslide = firstSubslide([
|
|
76
|
+
cell("a"),
|
|
77
|
+
cell("b", "fragment"),
|
|
78
|
+
cell("c", "fragment"),
|
|
79
|
+
]);
|
|
80
|
+
const { slideLevel, cumulativeByBlock } = buildSubslideNotes(
|
|
81
|
+
subslide,
|
|
82
|
+
configs({ a: "intro", b: "step one", c: "step two" }),
|
|
83
|
+
);
|
|
84
|
+
expect(slideLevel).toBe("intro");
|
|
85
|
+
expect(cumulativeByBlock.get(1)).toBe("intro\n\n---\n\nstep one");
|
|
86
|
+
expect(cumulativeByBlock.get(2)).toBe(
|
|
87
|
+
"intro\n\n---\n\nstep one\n\n---\n\nstep two",
|
|
88
|
+
);
|
|
89
|
+
});
|
|
90
|
+
|
|
91
|
+
it("accumulates fragments with no slide-level notes", () => {
|
|
92
|
+
const subslide = firstSubslide([
|
|
93
|
+
cell("a"),
|
|
94
|
+
cell("b", "fragment"),
|
|
95
|
+
cell("c", "fragment"),
|
|
96
|
+
]);
|
|
97
|
+
const { slideLevel, cumulativeByBlock } = buildSubslideNotes(
|
|
98
|
+
subslide,
|
|
99
|
+
configs({ b: "first reveal", c: "second reveal" }),
|
|
100
|
+
);
|
|
101
|
+
expect(slideLevel).toBe("");
|
|
102
|
+
expect(cumulativeByBlock.get(1)).toBe("first reveal");
|
|
103
|
+
expect(cumulativeByBlock.get(2)).toBe(
|
|
104
|
+
"first reveal\n\n---\n\nsecond reveal",
|
|
105
|
+
);
|
|
106
|
+
});
|
|
107
|
+
|
|
108
|
+
it("skips empty fragments without leaving dangling dividers", () => {
|
|
109
|
+
const subslide = firstSubslide([
|
|
110
|
+
cell("a"),
|
|
111
|
+
cell("b", "fragment"),
|
|
112
|
+
cell("c", "fragment"),
|
|
113
|
+
]);
|
|
114
|
+
const { cumulativeByBlock } = buildSubslideNotes(
|
|
115
|
+
subslide,
|
|
116
|
+
configs({ a: "intro", c: "third" }),
|
|
117
|
+
);
|
|
118
|
+
expect(cumulativeByBlock.get(1)).toBe("intro");
|
|
119
|
+
expect(cumulativeByBlock.get(2)).toBe("intro\n\n---\n\nthird");
|
|
120
|
+
});
|
|
121
|
+
|
|
122
|
+
it("returns no cumulative entries when fragments and slide have no notes", () => {
|
|
123
|
+
const subslide = firstSubslide([
|
|
124
|
+
cell("a"),
|
|
125
|
+
cell("b", "fragment"),
|
|
126
|
+
cell("c", "fragment"),
|
|
127
|
+
]);
|
|
128
|
+
const { cumulativeByBlock } = buildSubslideNotes(subslide, configs({}));
|
|
129
|
+
expect(cumulativeByBlock.size).toBe(0);
|
|
130
|
+
});
|
|
131
|
+
});
|