@marimo-team/frontend 0.21.2-dev6 → 0.21.2-dev61
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-C-nDPVVw.js +1 -0
- package/dist/assets/ConnectedDataExplorerComponent-B5igOqdA.js +1 -0
- package/dist/assets/DeferredRequestRegistry-B8jPCuU1.js +1 -0
- package/dist/assets/FiraMono-Bold-C6PDArdf.woff2 +0 -0
- package/dist/assets/FiraMono-Medium-D5MAsWEG.woff2 +0 -0
- package/dist/assets/FiraMono-Regular-CEsLFVD9.woff2 +0 -0
- package/dist/assets/ImperativeModal-C5ZzjCQG.js +1 -0
- package/dist/assets/JsonOutput-bhD4i0Fm.js +46 -0
- package/dist/assets/LazyAnyLanguageCodeMirror-C58z97yX.js +2 -0
- package/dist/assets/Lora-VariableFont_wght-CZceb_kH.woff2 +0 -0
- package/dist/assets/MarimoErrorOutput-BIh0hMl8.js +7 -0
- package/dist/assets/PTSans-Bold-C_DwAp7Z.woff2 +0 -0
- package/dist/assets/PTSans-Regular-Bam3NpBI.woff2 +0 -0
- package/dist/assets/RenderHTML-CRY6pZVc.js +1 -0
- package/dist/assets/add-cell-with-ai-BvN8AbcB.js +92 -0
- package/dist/assets/add-connection-dialog-BvzGJCV7.js +167 -0
- package/dist/assets/agent-panel-DLrLHhZB.js +287 -0
- package/dist/assets/ai-model-dropdown-CQDhHQ1r.js +5 -0
- package/dist/assets/alert-dialog-Baw3WWPa.js +11 -0
- package/dist/assets/any-language-editor-DwTh8fpE.js +1 -0
- package/dist/assets/apl-BvMImcFf.js +1 -0
- package/dist/assets/app-config-button-CnR7XJXP.js +1 -0
- package/dist/assets/arc-DUSwcTI9.js +1 -0
- package/dist/assets/architecture-7HQA4BMR-DoF6afh3.js +1 -0
- package/dist/assets/architectureDiagram-VXUJARFQ-d3bjsML7.js +36 -0
- package/dist/assets/asciiarmor-BYYwBbrl.js +1 -0
- package/dist/assets/asn1-Dlt8rkAb.js +1 -0
- package/dist/assets/azure-DMJRLvDT.js +1 -0
- package/dist/assets/blockDiagram-VD42YOAC-CjpBwM9S.js +122 -0
- package/dist/assets/brainfuck-B1Z5ou__.js +1 -0
- package/dist/assets/c4Diagram-YG6GDRKO-BsB04ueE.js +10 -0
- package/dist/assets/cache-panel-B9gltP7l.js +1 -0
- package/dist/assets/cell-editor-D5XEomtX.js +22 -0
- package/dist/assets/cell-link-Cp4c28Yf.js +1 -0
- package/dist/assets/cells-DiVpbkA6.js +230 -0
- package/dist/assets/channel-BjUuxbyU.js +1 -0
- package/dist/assets/chat-display-DhUQL9pu.js +1 -0
- package/dist/assets/chat-panel-fxitp0Hy.js +3 -0
- package/dist/assets/chunk-4BX2VUAB-DhvNmHH5.js +1 -0
- package/dist/assets/chunk-55IACEB6-DPm6ES7n.js +1 -0
- package/dist/assets/chunk-5FQGJX7Z-BSe8eGYF.js +113 -0
- package/dist/assets/chunk-ABZYJK2D-Cw3YveaS.js +80 -0
- package/dist/assets/chunk-ATLVNIR6-ChKiaY37.js +1 -0
- package/dist/assets/chunk-B4BG7PRW-CjzWXMFh.js +165 -0
- package/dist/assets/chunk-CVBHYZKI-BX0N_ipT.js +1 -0
- package/dist/assets/chunk-DI55MBZ5-BLrTiPQ-.js +220 -0
- package/dist/assets/chunk-EXTU4WIE-DEQUOsSM.js +1 -0
- package/dist/assets/chunk-FMBD7UC4-BDlH9XLH.js +15 -0
- package/dist/assets/chunk-HN2XXSSU-ujlBpRMF.js +1 -0
- package/dist/assets/chunk-JA3XYJ7Z-DVg9ra4h.js +70 -0
- package/dist/assets/chunk-JZLCHNYA-BTjSP-Yu.js +54 -0
- package/dist/assets/chunk-MI3HLSF2-D9JXkg6-.js +32 -0
- package/dist/assets/chunk-N4CR4FBY-U_urcDYs.js +2 -0
- package/dist/assets/chunk-QN33PNHL-rFbjvOIx.js +1 -0
- package/dist/assets/chunk-QXUST7PY-BQj8er3i.js +7 -0
- package/dist/assets/chunk-QZHKN3VN-zZhG5AHT.js +1 -0
- package/dist/assets/chunk-S3R3BYOJ-ZHSbXnZr.js +2 -0
- package/dist/assets/chunk-TZMSLE5B-BAOCWmWp.js +1 -0
- package/dist/assets/classDiagram-2ON5EDUG-Dk_A06Wi.js +1 -0
- package/dist/assets/classDiagram-v2-WZHVMYZB-CI0Lejhn.js +1 -0
- package/dist/assets/clike-D1aNLn0X.js +1 -0
- package/dist/assets/clojure-DjNF1_gb.js +1 -0
- package/dist/assets/cmake-BDQMYLKM.js +1 -0
- package/dist/assets/cobol-DuPGAg14.js +1 -0
- package/dist/assets/code-block-37QAKDTI-BU3oxVk6.js +2 -0
- package/dist/assets/coffeescript-Cpt7RKvC.js +1 -0
- package/dist/assets/column-preview-CWToI8XM.js +1 -0
- package/dist/assets/command-B9VNhm0p.js +1 -0
- package/dist/assets/command-palette-ur_xyrxX.js +1 -0
- package/dist/assets/common-BqZ5L0i8.js +1 -0
- package/dist/assets/commonlisp-BRjl0xya.js +1 -0
- package/dist/assets/components-BouDP-tv.js +1 -0
- package/dist/assets/components-CUetByBv.js +1 -0
- package/dist/assets/config-DqxNMQDN.js +1 -0
- package/dist/assets/context-CqNy_uER.js +1 -0
- package/dist/assets/context-aware-panel-CD_txOWw.js +3 -0
- package/dist/assets/copy-CcUDATFX.js +1 -0
- package/dist/assets/copy-icon-WvgZ60QO.js +1 -0
- package/dist/assets/cose-bilkent-S5V4N54A-C4qI5Omf.js +1 -0
- package/dist/assets/createReducer-Dvh64vBW.js +1 -0
- package/dist/assets/crystal-BJ72BOy1.js +1 -0
- package/dist/assets/css-D-8RA_n9.js +1 -0
- package/dist/assets/cypher-qOLKQlRB.js +1 -0
- package/dist/assets/d-iOURkVzR.js +1 -0
- package/dist/assets/dagre-6UL2VRFP-CoEAbEhB.js +4 -0
- package/dist/assets/data-grid-overlay-editor-DXzdnLZF.js +1 -0
- package/dist/assets/datasource-C5fKDIEK.js +3 -0
- package/dist/assets/dates-CTqMeMGY.js +1 -0
- package/dist/assets/dependency-graph-panel-BCYRlR0F.js +5 -0
- package/dist/assets/diagram-PSM6KHXK-CzPUkhGz.js +24 -0
- package/dist/assets/diagram-QEK2KX5R-D5RBmWAK.js +43 -0
- package/dist/assets/diagram-S2PKOQOG-C8PeRX7S.js +24 -0
- package/dist/assets/dialog-C_NcD2pn.js +1 -0
- package/dist/assets/diff-Cdd81Zxl.js +1 -0
- package/dist/assets/dist-1u2or7ID.js +1 -0
- package/dist/assets/dist-6P6vjf93.js +1 -0
- package/dist/assets/dist-BWa7crGu.js +1 -0
- package/dist/assets/dist-BZOFXjSq.js +1 -0
- package/dist/assets/dist-BatEf-0f.js +1 -0
- package/dist/assets/dist-BgRFL8FO.js +1 -0
- package/dist/assets/dist-C6ohaMKU.js +6 -0
- package/dist/assets/dist-C8sUhiRj.js +1 -0
- package/dist/assets/dist-CO9Pg2Rc.js +1 -0
- package/dist/assets/dist-CSV6H5w_.js +1 -0
- package/dist/assets/dist-Cd9M8gLO.js +1 -0
- package/dist/assets/dist-Cj6Bv4PM.js +1 -0
- package/dist/assets/dist-CjkJ83NO.js +1 -0
- package/dist/assets/dist-D6IRobNQ.js +1 -0
- package/dist/assets/dist-DBaxVoPL.js +1 -0
- package/dist/assets/dist-DQg1jiNa.js +1 -0
- package/dist/assets/dist-DVCqT940.js +1 -0
- package/dist/assets/dist-DXjL2dGI.js +1 -0
- package/dist/assets/dist-DZurUgwR.js +1 -0
- package/dist/assets/dist-D_QUx5Gn.js +1 -0
- package/dist/assets/dist-DgEPWvX2.js +1 -0
- package/dist/assets/dist-Dq1aTs7B.js +1 -0
- package/dist/assets/dist-Dq3BlK4R.js +1 -0
- package/dist/assets/dist-EtGG9C1A.js +1 -0
- package/dist/assets/dist-NjId5Gdz.js +1 -0
- package/dist/assets/dist-NoS9f1Fr.js +1 -0
- package/dist/assets/dist-i55eG_gB.js +1 -0
- package/dist/assets/dist-rrswzGsS.js +1 -0
- package/dist/assets/dist-vu0dYsZ6.js +1 -0
- package/dist/assets/dist-wAlLVqgL.js +1 -0
- package/dist/assets/dockerfile-t2fxOBWV.js +1 -0
- package/dist/assets/documentation-panel-B-pPPA6b.js +1 -0
- package/dist/assets/download-UmTPygP7.js +9 -0
- package/dist/assets/dropdown-menu-BehqiLFL.js +1 -0
- package/dist/assets/dtd-CXebdwLo.js +1 -0
- package/dist/assets/dylan-YUx5_Nke.js +1 -0
- package/dist/assets/ecl-CktOv__x.js +1 -0
- package/dist/assets/edit-page-CxaQclsT.js +13 -0
- package/dist/assets/eiffel-Cwa25B6x.js +1 -0
- package/dist/assets/elm-COtRRWOj.js +1 -0
- package/dist/assets/en-US-f8tajDx1.js +1 -0
- package/dist/assets/erDiagram-Q2GNP2WA-Bvb9X3rD.js +60 -0
- package/dist/assets/erlang-Ir3c4mPd.js +1 -0
- package/dist/assets/error-banner-BYG94WiL.js +1 -0
- package/dist/assets/error-panel-CpC5W_ax.js +1 -0
- package/dist/assets/es-DKHH3Swu.js +5 -0
- package/dist/assets/esm-Clp2XqMu.js +1 -0
- package/dist/assets/esm-DnSMDF4m.js +1 -0
- package/dist/assets/factor-CwMUgBOu.js +1 -0
- package/dist/assets/factor-DLUSHz6o.js +1 -0
- package/dist/assets/field-BEgvDIrV.js +1 -0
- package/dist/assets/file-explorer-panel-CrD6YkZ_.js +26 -0
- package/dist/assets/file-icons-BTQcwa4T.js +1 -0
- package/dist/assets/floating-outline-Dz5Wcbfw.js +1 -0
- package/dist/assets/flowDiagram-NV44I4VS-CF0XcGrZ.js +162 -0
- package/dist/assets/focus-BRTg8M44.js +1 -0
- package/dist/assets/form-qtFXuhlh.js +2 -0
- package/dist/assets/formats-CQWEZHk-.js +1 -0
- package/dist/assets/formatting-DBrNlcJ6.js +1 -0
- package/dist/assets/forth-DdV4URDJ.js +1 -0
- package/dist/assets/fortran-rTDtSjFc.js +1 -0
- package/dist/assets/gallery-page-DhOJHDwV.js +1 -0
- package/dist/assets/ganttDiagram-JELNMOA3-BXfHO6g0.js +267 -0
- package/dist/assets/gas-B20k3keQ.js +1 -0
- package/dist/assets/gherkin-DdH6eiN0.js +1 -0
- package/dist/assets/gitGraph-G5XIXVHT-D3o7km_A.js +1 -0
- package/dist/assets/gitGraphDiagram-V2S2FVAM-Blhov9dO.js +65 -0
- package/dist/assets/glide-data-editor-CO6jMjYm.js +132 -0
- package/dist/assets/globals-DD4XdbWe.js +1 -0
- package/dist/assets/groovy-k_2ke765.js +1 -0
- package/dist/assets/haskell-JTqAy6cw.js +1 -0
- package/dist/assets/haxe-g4mjq9YQ.js +1 -0
- package/dist/assets/home-page-CwgtN9Ku.js +4 -0
- package/dist/assets/hooks-CLoML3Pf.js +1 -0
- package/dist/assets/html-to-image-CRCamxYo.js +2 -0
- package/dist/assets/idl-CQEReZIk.js +1 -0
- package/dist/assets/index-BrQynBQn.js +38 -0
- package/dist/assets/index-DtdvIKY3.css +2 -0
- package/dist/assets/info-VBDWY6EO-CPJvjUKi.js +1 -0
- package/dist/assets/infoDiagram-HS3SLOUP-CCrt0lHA.js +2 -0
- package/dist/assets/input-lyDIN6R6.js +1 -0
- package/dist/assets/isValid-DY4Mgbr7.js +1 -0
- package/dist/assets/javascript-Th71hKcK.js +1 -0
- package/dist/assets/journeyDiagram-XKPGCS4Q-Bs_9B9e_.js +139 -0
- package/dist/assets/julia-KdjfFIx7.js +1 -0
- package/dist/assets/kanban-definition-3W4ZIXB7-_GEp627b.js +89 -0
- package/dist/assets/katex-BalO4WMU.js +1 -0
- package/dist/assets/kiosk-mode-Di6uNlNd.js +1 -0
- package/dist/assets/label-CNWsXpEn.js +1 -0
- package/dist/assets/layout-OxzkS5En.js +5 -0
- package/dist/assets/line-BKm-YkCh.js +1 -0
- package/dist/assets/linear-DG7yljSg.js +1 -0
- package/dist/assets/links-Bfp-iNRX.js +1 -0
- package/dist/assets/livescript-OIMP9q9l.js +1 -0
- package/dist/assets/logs-panel-Dt4wzfgH.js +1 -0
- package/dist/assets/loro_wasm_bg-CvVVQqkx.js +1 -0
- package/dist/assets/lua-blzLZg7R.js +1 -0
- package/dist/assets/markdown-renderer-nMv2xwHt.js +10 -0
- package/dist/assets/mathematica-CMJa84MS.js +1 -0
- package/dist/assets/mbox-DVlt9Sx8.js +1 -0
- package/dist/assets/menu-items-BpHXKv51.js +1 -0
- package/dist/assets/mermaid-4DMBBIKO-gmMzGFR4.js +1 -0
- package/dist/assets/mermaid-DEOW_c2X.js +11 -0
- package/dist/assets/mermaid-parser.core-ChpHatjH.js +4 -0
- package/dist/assets/mhchem-DqNBdKjC.js +1 -0
- package/dist/assets/mindmap-definition-VGOIOE7T-CsErmnfz.js +68 -0
- package/dist/assets/mirc-CE9zFxnR.js +1 -0
- package/dist/assets/mllike-UPrOWD4R.js +1 -0
- package/dist/assets/modelica-CXEKMd0n.js +1 -0
- package/dist/assets/mscgen-CzEcWkMH.js +1 -0
- package/dist/assets/multi-map-0vmox9BD.js +1 -0
- package/dist/assets/mumps-DNi45Qjm.js +1 -0
- package/dist/assets/name-cell-input-CwvGCJkg.js +1 -0
- package/dist/assets/nsis-10Du03KF.js +1 -0
- package/dist/assets/nsis-Cjsw1q_J.js +1 -0
- package/dist/assets/ntriples-ByafJqO3.js +1 -0
- package/dist/assets/number-overlay-editor-zZDGu9D2.js +9 -0
- package/dist/assets/octave-Bg9NfY8T.js +1 -0
- package/dist/assets/ordinal-CIVqSC4M.js +1 -0
- package/dist/assets/outline-panel-CCmk1ERZ.js +1 -0
- package/dist/assets/oz-BqUh_R9x.js +1 -0
- package/dist/assets/packages-panel-BzayhsFC.js +1 -0
- package/dist/assets/packet-DYOGHKS2-0_hZggkb.js +1 -0
- package/dist/assets/panels-B7hsDiui.js +1 -0
- package/dist/assets/pascal-T5LJ_IPG.js +1 -0
- package/dist/assets/perl-QB_H1sT2.js +1 -0
- package/dist/assets/pie-VRWISCQL-QeXFV_RN.js +1 -0
- package/dist/assets/pieDiagram-ADFJNKIX-CHFQxGML.js +30 -0
- package/dist/assets/pig-BX8GE3n0.js +1 -0
- package/dist/assets/popover-BzqPa2Au.js +1 -0
- package/dist/assets/powershell-CgQaEAdZ.js +1 -0
- package/dist/assets/precisionRound-NX56vp6K.js +1 -0
- package/dist/assets/process-output-D_zUglHE.js +1 -0
- package/dist/assets/properties-obn8TWyy.js +1 -0
- package/dist/assets/protobuf-C-zxlF8D.js +1 -0
- package/dist/assets/pug--0L5ulw9.js +1 -0
- package/dist/assets/pug-C9pOca2F.js +1 -0
- package/dist/assets/puppet-05PW0eq8.js +1 -0
- package/dist/assets/python-DTi_lJAD.js +1 -0
- package/dist/assets/q-DDewC_-L.js +1 -0
- package/dist/assets/quadrantDiagram-AYHSOK5B-BWfhvbIs.js +7 -0
- package/dist/assets/r-BP2yA_lV.js +1 -0
- package/dist/assets/radar-ZZBFDIW7-CPk9iUBG.js +1 -0
- package/dist/assets/react-vega-BbTMwpa-.js +190 -0
- package/dist/assets/react-vega-_CJceHW7.js +1 -0
- package/dist/assets/readonly-python-code-BQo0UqCJ.js +1 -0
- package/dist/assets/renderShortcut-DG5sXSxr.js +1 -0
- package/dist/assets/request-registry-BPNvKw5y.js +1 -0
- package/dist/assets/requirementDiagram-UZGBJVZJ-DdZsVZPu.js +64 -0
- package/dist/assets/rpm-BTpPEnAJ.js +1 -0
- package/dist/assets/ruby-_km6sWpH.js +1 -0
- package/dist/assets/run-page-BN0QZ7-c.js +1 -0
- package/dist/assets/runs-CtxlyzdZ.js +1 -0
- package/dist/assets/sankeyDiagram-TZEHDZUN-BiKMK7q3.js +10 -0
- package/dist/assets/sas-BV0z5M7P.js +1 -0
- package/dist/assets/scheme-AMw7OHvW.js +1 -0
- package/dist/assets/scratchpad-panel-BpM3Nxzw.js +1 -0
- package/dist/assets/secrets-panel-BVJ1G2-2.js +1 -0
- package/dist/assets/select-Cnd3vm9n.js +1 -0
- package/dist/assets/sequenceDiagram-WL72ISMW-B1m5IqrQ.js +145 -0
- package/dist/assets/session-panel-CUtOop5w.js +1 -0
- package/dist/assets/share-T-ETw2Yt.js +1 -0
- package/dist/assets/shell-BepJCs0S.js +1 -0
- package/dist/assets/sieve-YvKFjNqY.js +1 -0
- package/dist/assets/slides-component-Bg8T1XwW.js +1 -0
- package/dist/assets/smalltalk-e8puLVxg.js +1 -0
- package/dist/assets/snippets-panel-CND2QIaH.js +1 -0
- package/dist/assets/sparql-IwwbUejm.js +1 -0
- package/dist/assets/spec-DnVBmJUh.js +1 -0
- package/dist/assets/src-lcGySDV2.js +1 -0
- package/dist/assets/state-C-thupmq.js +1 -0
- package/dist/assets/state-Cm3zkTs2.js +1 -0
- package/dist/assets/state-Dxl7WjW3.js +1 -0
- package/dist/assets/stateDiagram-FKZM4ZOC-B_fZr0Jz.js +1 -0
- package/dist/assets/stateDiagram-v2-4FDKWEC3-CnaooVt9.js +1 -0
- package/dist/assets/step-B5y1YzZ4.js +1 -0
- package/dist/assets/stex-CruVQx-P.js +1 -0
- package/dist/assets/stylus-C5qHDsoA.js +1 -0
- package/dist/assets/swift-CD6FyF1F.js +1 -0
- package/dist/assets/switch-C2PmTLIx.js +1 -0
- package/dist/assets/tcl-189LoKbJ.js +1 -0
- package/dist/assets/terminal-8keBq1HC.js +62 -0
- package/dist/assets/textile-dSHgbtG8.js +1 -0
- package/dist/assets/time-D8_flTb-.js +1 -0
- package/dist/assets/timeline-definition-IT6M3QCI-CiMZB-_n.js +61 -0
- package/dist/assets/toggle-DjUKacjU.js +1 -0
- package/dist/assets/toml-CWUvzxNs.js +1 -0
- package/dist/assets/tooltip-CR_izE8Q.js +1 -0
- package/dist/assets/tracing-Cab2_N64.js +1 -0
- package/dist/assets/tracing-panel-h6SS64Fd.js +2 -0
- package/dist/assets/tree-Duf22i7P.js +3 -0
- package/dist/assets/treemap-GDKQZRPO-BqT6xXWn.js +1 -0
- package/dist/assets/troff-CkFGw7sb.js +1 -0
- package/dist/assets/ttcn-B71Rl_FP.js +1 -0
- package/dist/assets/ttcn-cfg-BsJCQ8Pc.js +1 -0
- package/dist/assets/turtle-AJRCjN1N.js +1 -0
- package/dist/assets/useAddCell-fzJF_CdR.js +1 -0
- package/dist/assets/useBoolean-DJdaVVhu.js +1 -0
- package/dist/assets/useCellActionButton-C-mIavMW.js +1 -0
- package/dist/assets/useDateFormatter-CYAwsqZA.js +1 -0
- package/dist/assets/useDeleteCell-lfqkVcrN.js +1 -0
- package/dist/assets/useDependencyPanelTab-Nq81zNNI.js +1 -0
- package/dist/assets/useInstallPackage-BVUUWUU8.js +1 -0
- package/dist/assets/useNotebookActions-BAw99pt_.js +1 -0
- package/dist/assets/useNumberFormatter-D5CeG3Kn.js +1 -0
- package/dist/assets/usePress-CHKiC-9E.js +7 -0
- package/dist/assets/useRunCells-6ne-1pJW.js +1 -0
- package/dist/assets/useSplitCell-D8a8QoYd.js +1 -0
- package/dist/assets/utils-DnNnBV1N.js +61 -0
- package/dist/assets/vb-gPFTxjZr.js +1 -0
- package/dist/assets/vbscript-CMzdZB2G.js +1 -0
- package/dist/assets/vega-component-DnJzUfQO.js +1 -0
- package/dist/assets/vega-loader.browser-xq8miGHn.js +6 -0
- package/dist/assets/velocity-DBHzqIXP.js +1 -0
- package/dist/assets/verilog-CrrLE4DH.js +1 -0
- package/dist/assets/vhdl-CcYUxt_-.js +1 -0
- package/dist/assets/webidl-Cx4I26Tn.js +1 -0
- package/dist/assets/write-secret-modal-5AT0ZoJv.js +1 -0
- package/dist/assets/xquery-Cu7k_x_s.js +1 -0
- package/dist/assets/xychartDiagram-PRI3JC2R-B3F_v5OL.js +7 -0
- package/dist/assets/yacas-DEQ-2nrM.js +1 -0
- package/dist/assets/z80-D9sXBSXs.js +1 -0
- package/dist/index.html +145 -146
- package/package.json +1 -1
- package/src/__mocks__/notebook.ts +9 -9
- package/src/__mocks__/requests.ts +1 -0
- package/src/__tests__/branded.ts +20 -0
- package/src/components/app-config/user-config-form.tsx +5 -4
- package/src/components/data-table/__tests__/utils.test.ts +138 -1
- package/src/components/data-table/charts/__tests__/storage.test.ts +7 -7
- package/src/components/data-table/context-menu.tsx +9 -5
- package/src/components/data-table/data-table.tsx +3 -0
- package/src/components/data-table/range-focus/__tests__/atoms.test.ts +8 -2
- package/src/components/data-table/range-focus/__tests__/test-utils.ts +2 -0
- package/src/components/data-table/range-focus/__tests__/utils.test.ts +82 -8
- package/src/components/data-table/range-focus/atoms.ts +2 -2
- package/src/components/data-table/range-focus/utils.ts +50 -12
- package/src/components/data-table/types.ts +7 -0
- package/src/components/data-table/utils.ts +87 -0
- package/src/components/editor/__tests__/data-attributes.test.tsx +8 -8
- package/src/components/editor/ai/__tests__/completion-utils.test.ts +15 -15
- package/src/components/editor/connections/storage/__tests__/__snapshots__/as-code.test.ts.snap +2 -2
- package/src/components/editor/connections/storage/as-code.ts +2 -2
- package/src/components/editor/file-tree/file-explorer.tsx +16 -2
- package/src/components/editor/file-tree/file-viewer.tsx +17 -3
- package/src/components/editor/navigation/__tests__/clipboard.test.ts +2 -2
- package/src/components/editor/navigation/__tests__/selection.test.ts +7 -6
- package/src/components/editor/navigation/__tests__/state.test.ts +8 -7
- package/src/components/editor/output/MarimoErrorOutput.tsx +7 -7
- package/src/components/editor/output/__tests__/traceback.test.tsx +4 -4
- package/src/components/editor/output/console/__tests__/ConsoleOutput.test.tsx +4 -4
- package/src/components/editor/renderers/vertical-layout/useFocusFirstEditor.ts +8 -1
- package/src/components/storage/storage-file-viewer.tsx +35 -1
- package/src/components/storage/storage-inspector.tsx +9 -4
- package/src/components/storage/storage-snippets.ts +3 -3
- package/src/components/tracing/tracing.tsx +3 -1
- package/src/components/ui/range-slider.tsx +108 -1
- package/src/core/ai/__tests__/staged-cells.test.ts +9 -8
- package/src/core/ai/context/providers/__tests__/cell-output.test.ts +31 -31
- package/src/core/ai/context/providers/__tests__/datasource.test.ts +3 -3
- package/src/core/ai/context/providers/__tests__/tables.test.ts +3 -2
- package/src/core/ai/context/providers/__tests__/variable.test.ts +84 -63
- package/src/core/ai/tools/__tests__/edit-notebook-tool.test.ts +10 -9
- package/src/core/ai/tools/__tests__/run-cells-tool.test.ts +6 -6
- package/src/core/ai/tools/edit-notebook-tool.ts +3 -3
- package/src/core/cells/__tests__/add-missing-import.test.ts +3 -3
- package/src/core/cells/__tests__/apply-transaction.test.ts +279 -0
- package/src/core/cells/__tests__/cells.test.ts +198 -135
- package/src/core/cells/__tests__/document-changes.test.ts +575 -0
- package/src/core/cells/__tests__/document-roundtrip.test.ts +376 -0
- package/src/core/cells/__tests__/focus.test.ts +5 -4
- package/src/core/cells/__tests__/logs.test.ts +13 -12
- package/src/core/cells/__tests__/pending-delete-service.test.tsx +3 -3
- package/src/core/cells/__tests__/runs.test.ts +22 -21
- package/src/core/cells/__tests__/scrollCellIntoView.test.ts +8 -7
- package/src/core/cells/__tests__/session.test.ts +23 -22
- package/src/core/cells/cells.ts +29 -4
- package/src/core/cells/document-changes.ts +644 -0
- package/src/core/cells/ids.ts +5 -5
- package/src/core/cells/logs.ts +2 -2
- package/src/core/cells/runs.ts +6 -8
- package/src/core/codemirror/__tests__/format.test.ts +34 -36
- package/src/core/codemirror/__tests__/setup.test.ts +2 -2
- package/src/core/codemirror/cells/__tests__/extensions.test.ts +114 -0
- package/src/core/codemirror/cells/__tests__/traceback-decorations.test.ts +33 -32
- package/src/core/codemirror/cells/extensions.ts +66 -23
- package/src/core/codemirror/completion/__tests__/keymap.test.ts +15 -35
- package/src/core/codemirror/completion/keymap.ts +14 -4
- package/src/core/codemirror/copilot/__tests__/getCodes.test.ts +12 -13
- package/src/core/codemirror/language/__tests__/utils.test.ts +3 -3
- package/src/core/codemirror/language/embedded/__tests__/embedded-python.test.ts +7 -8
- package/src/core/codemirror/language/languages/python.ts +4 -0
- package/src/core/codemirror/lsp/__tests__/notebook-lsp.test.ts +4 -3
- package/src/core/codemirror/lsp/notebook-lsp.ts +28 -2
- package/src/core/codemirror/reactive-references/__tests__/analyzer.test.ts +7 -6
- package/src/core/codemirror/reactive-references/analyzer.ts +2 -2
- package/src/core/codemirror/rtc/loro/__tests__/sync.test.ts +52 -0
- package/src/core/codemirror/rtc/loro/sync.ts +1 -0
- package/src/core/datasets/__tests__/data-source.test.ts +5 -6
- package/src/core/datasets/state.ts +1 -1
- package/src/core/errors/__tests__/errors.test.ts +2 -1
- package/src/core/export/__tests__/hooks.test.ts +37 -36
- package/src/core/islands/bridge.ts +1 -0
- package/src/core/islands/main.ts +4 -7
- package/src/core/kernel/__tests__/handlers.test.ts +5 -4
- package/src/core/kernel/handlers.ts +7 -4
- package/src/core/network/DeferredRequestRegistry.ts +2 -2
- package/src/core/network/__tests__/CachingRequestRegistry.test.ts +9 -10
- package/src/core/network/__tests__/DeferredRequestRegistry.test.ts +4 -6
- package/src/core/network/requests-lazy.ts +1 -0
- package/src/core/network/requests-network.ts +9 -0
- package/src/core/network/requests-static.ts +1 -0
- package/src/core/network/requests-toasting.tsx +1 -0
- package/src/core/network/types.ts +5 -0
- package/src/core/static/__tests__/virtual-file-tracker.test.ts +8 -8
- package/src/core/static/virtual-file-tracker.ts +1 -1
- package/src/core/storage/__tests__/state.test.ts +31 -21
- package/src/core/storage/state.ts +1 -1
- package/src/core/variables/__tests__/state.test.ts +6 -6
- package/src/core/variables/types.ts +2 -2
- package/src/core/wasm/__tests__/state.test.ts +8 -8
- package/src/core/wasm/bridge.ts +1 -0
- package/src/core/websocket/useMarimoKernelConnection.tsx +31 -16
- package/src/css/app/fonts.css +6 -6
- package/src/css/md-tooltip.css +4 -39
- package/src/css/md.css +7 -0
- package/src/fonts/Fira_Mono/FiraMono-Bold.woff2 +0 -0
- package/src/fonts/Fira_Mono/FiraMono-Medium.woff2 +0 -0
- package/src/fonts/Fira_Mono/FiraMono-Regular.woff2 +0 -0
- package/src/fonts/Lora/Lora-VariableFont_wght.woff2 +0 -0
- package/src/fonts/PT_Sans/PTSans-Bold.woff2 +0 -0
- package/src/fonts/PT_Sans/PTSans-Regular.woff2 +0 -0
- package/src/plugins/core/RenderHTML.tsx +17 -0
- package/src/plugins/core/__test__/RenderHTML.test.ts +45 -0
- package/src/plugins/core/sanitize-html.ts +25 -18
- package/src/plugins/impl/DataTablePlugin.tsx +23 -2
- package/src/plugins/impl/SliderPlugin.tsx +1 -3
- package/src/plugins/impl/__tests__/SliderPlugin.test.tsx +120 -0
- package/src/plugins/impl/anywidget/model.ts +1 -2
- package/src/stories/cell.stories.tsx +8 -8
- package/src/stories/layout/vertical/one-column.stories.tsx +9 -8
- package/src/stories/log-viewer.stories.tsx +8 -8
- package/src/stories/variables.stories.tsx +2 -2
- package/src/utils/__tests__/download.test.tsx +21 -20
- package/src/utils/copy.ts +18 -5
- package/src/utils/createReducer.ts +26 -11
- package/src/utils/download.ts +4 -3
- package/src/utils/html-to-image.ts +6 -0
- package/src/utils/json/base64.ts +3 -3
- package/src/utils/traceback.ts +5 -3
- package/dist/assets/CellStatus-CDSBsjjF.js +0 -1
- package/dist/assets/ConnectedDataExplorerComponent-Buaffg3u.js +0 -1
- package/dist/assets/DeferredRequestRegistry-O6RDJKs0.js +0 -1
- package/dist/assets/FiraMono-Bold-CLVRCuM9.ttf +0 -0
- package/dist/assets/FiraMono-Medium-DU3aDxX5.ttf +0 -0
- package/dist/assets/FiraMono-Regular-BTCkDNvf.ttf +0 -0
- package/dist/assets/ImperativeModal-qEtcJ95s.js +0 -1
- package/dist/assets/JsonOutput-DKXKGKvX.js +0 -46
- package/dist/assets/LazyAnyLanguageCodeMirror-m8w66E4s.js +0 -2
- package/dist/assets/Lora-VariableFont_wght-B2ootaw-.ttf +0 -0
- package/dist/assets/MarimoErrorOutput-az74f3Mp.js +0 -7
- package/dist/assets/PTSans-Bold-D9fedIX3.ttf +0 -0
- package/dist/assets/PTSans-Regular-CxL0S8W7.ttf +0 -0
- package/dist/assets/RenderHTML-DJ8khuob.js +0 -1
- package/dist/assets/add-cell-with-ai-DUn4LN4W.js +0 -92
- package/dist/assets/add-connection-dialog-CBz0AUVX.js +0 -167
- package/dist/assets/agent-panel-u83dsDsM.js +0 -287
- package/dist/assets/ai-model-dropdown-DPTa_EpU.js +0 -5
- package/dist/assets/alert-dialog-9WfvUF7e.js +0 -11
- package/dist/assets/any-language-editor-DwQMnAM3.js +0 -1
- package/dist/assets/apl-CWQZjEHB.js +0 -1
- package/dist/assets/app-config-button-rDu-lCIB.js +0 -1
- package/dist/assets/arc-BrTIAGt4.js +0 -1
- package/dist/assets/architecture-7HQA4BMR-BewjmwdA.js +0 -1
- package/dist/assets/architectureDiagram-VXUJARFQ-DfMHHFZ3.js +0 -36
- package/dist/assets/asciiarmor-YkqeOS7J.js +0 -1
- package/dist/assets/asn1-CXKIzj3m.js +0 -1
- package/dist/assets/azure-BTXHztTw.js +0 -1
- package/dist/assets/blockDiagram-VD42YOAC-CuEDwbg7.js +0 -122
- package/dist/assets/brainfuck-BATyDEza.js +0 -1
- package/dist/assets/c4Diagram-YG6GDRKO-CD9uz7WG.js +0 -10
- package/dist/assets/cache-panel-qIxnndwr.js +0 -1
- package/dist/assets/cell-editor-DX7IcqNr.js +0 -23
- package/dist/assets/cell-link-Q_UEP94Z.js +0 -1
- package/dist/assets/cells-fq1RMGX_.js +0 -229
- package/dist/assets/channel-CkT8Qdo2.js +0 -1
- package/dist/assets/chat-display-D_Fuuy6r.js +0 -1
- package/dist/assets/chat-panel-BO-JoQSp.js +0 -3
- package/dist/assets/chunk-4BX2VUAB-DOQhLGwX.js +0 -1
- package/dist/assets/chunk-55IACEB6-D0TKhzEY.js +0 -1
- package/dist/assets/chunk-5FQGJX7Z-CM1a_K7I.js +0 -113
- package/dist/assets/chunk-ABZYJK2D-D_Wumzom.js +0 -80
- package/dist/assets/chunk-ATLVNIR6-BZ0lTgIn.js +0 -1
- package/dist/assets/chunk-B4BG7PRW-Dw1S6osV.js +0 -165
- package/dist/assets/chunk-CVBHYZKI-BmNXddyI.js +0 -1
- package/dist/assets/chunk-DI55MBZ5-Q63FTCPP.js +0 -220
- package/dist/assets/chunk-EXTU4WIE-CfkJ_R7W.js +0 -1
- package/dist/assets/chunk-FMBD7UC4-BF_CXOnN.js +0 -15
- package/dist/assets/chunk-HN2XXSSU-BstCPYtG.js +0 -1
- package/dist/assets/chunk-JA3XYJ7Z-B41fGeoj.js +0 -70
- package/dist/assets/chunk-JZLCHNYA-D43EJxQw.js +0 -54
- package/dist/assets/chunk-MI3HLSF2-BceZdyTR.js +0 -32
- package/dist/assets/chunk-N4CR4FBY-DCtw0-ni.js +0 -2
- package/dist/assets/chunk-QN33PNHL-CLA2rsaS.js +0 -1
- package/dist/assets/chunk-QXUST7PY-De1DpbnL.js +0 -7
- package/dist/assets/chunk-QZHKN3VN-D3EIvP2i.js +0 -1
- package/dist/assets/chunk-S3R3BYOJ-qrwvlUdq.js +0 -2
- package/dist/assets/chunk-TZMSLE5B-C4KcThb0.js +0 -1
- package/dist/assets/classDiagram-2ON5EDUG-BhMT_rTz.js +0 -1
- package/dist/assets/classDiagram-v2-WZHVMYZB-D-F4WEyb.js +0 -1
- package/dist/assets/clike-C3ewt06X.js +0 -1
- package/dist/assets/clojure-DSdxtK57.js +0 -1
- package/dist/assets/cmake-b6COJhkL.js +0 -1
- package/dist/assets/cobol-0au-d4Af.js +0 -1
- package/dist/assets/code-block-37QAKDTI-D4FF4cnN.js +0 -2
- package/dist/assets/coffeescript-CO6miDRN.js +0 -1
- package/dist/assets/column-preview-WsubyItX.js +0 -1
- package/dist/assets/command-palette-Bez4BqJF.js +0 -1
- package/dist/assets/command-rfxSsiHU.js +0 -1
- package/dist/assets/common-BYwO983A.js +0 -1
- package/dist/assets/commonlisp-ViswrHum.js +0 -1
- package/dist/assets/components-Bpgzv_5_.js +0 -1
- package/dist/assets/components-Ozq0825a.js +0 -1
- package/dist/assets/config-3Aq84phF.js +0 -1
- package/dist/assets/context-CIAP2NOh.js +0 -1
- package/dist/assets/context-aware-panel-CfsfBlhO.js +0 -3
- package/dist/assets/copy-YwM0Pd7v.js +0 -1
- package/dist/assets/copy-icon-BgmMM9Zg.js +0 -1
- package/dist/assets/cose-bilkent-S5V4N54A-Bd5HJPaN.js +0 -1
- package/dist/assets/createReducer-Drh7NmIR.js +0 -1
- package/dist/assets/crystal-BcOI1XlU.js +0 -1
- package/dist/assets/css-CCWfM5vT.js +0 -1
- package/dist/assets/cypher-BKbuDk70.js +0 -1
- package/dist/assets/d-4fbeW9Dj.js +0 -1
- package/dist/assets/dagre-6UL2VRFP-BhMnPhuU.js +0 -4
- package/dist/assets/data-grid-overlay-editor-kbv73SQ7.js +0 -1
- package/dist/assets/datasource-F9sJtuof.js +0 -3
- package/dist/assets/dates-CHaNfieI.js +0 -1
- package/dist/assets/dependency-graph-panel-AOBcX2tP.js +0 -5
- package/dist/assets/diagram-PSM6KHXK-Cr2t4zul.js +0 -24
- package/dist/assets/diagram-QEK2KX5R-DLU_hSO4.js +0 -43
- package/dist/assets/diagram-S2PKOQOG-C7EkNAO3.js +0 -24
- package/dist/assets/dialog-CVN1lcMF.js +0 -1
- package/dist/assets/diff-CV59_hp-.js +0 -1
- package/dist/assets/dist-6FIAeDIu.js +0 -1
- package/dist/assets/dist-BNC_tnlW.js +0 -6
- package/dist/assets/dist-BTqMkf4j.js +0 -1
- package/dist/assets/dist-BXXPfIam.js +0 -1
- package/dist/assets/dist-BZeePkbd.js +0 -1
- package/dist/assets/dist-BiZQlfhr.js +0 -1
- package/dist/assets/dist-BoDHthoc.js +0 -1
- package/dist/assets/dist-Br306776.js +0 -1
- package/dist/assets/dist-Br4KMeY4.js +0 -1
- package/dist/assets/dist-By6zhkxZ.js +0 -1
- package/dist/assets/dist-C3MmXcLA.js +0 -1
- package/dist/assets/dist-CXLJUPFl.js +0 -1
- package/dist/assets/dist-CblX3KGI.js +0 -1
- package/dist/assets/dist-CcGcwrUD.js +0 -1
- package/dist/assets/dist-ClzRAVN-.js +0 -1
- package/dist/assets/dist-Cp60fE5Z.js +0 -1
- package/dist/assets/dist-CsRbK9-Y.js +0 -1
- package/dist/assets/dist-DHw9sXeN.js +0 -1
- package/dist/assets/dist-DJBpXGro.js +0 -1
- package/dist/assets/dist-DVbTmqCA.js +0 -1
- package/dist/assets/dist-DbK_4_qo.js +0 -1
- package/dist/assets/dist-DlTbNRBn.js +0 -1
- package/dist/assets/dist-DrceDAhM.js +0 -1
- package/dist/assets/dist-Du0qZeXz.js +0 -1
- package/dist/assets/dist-Tk70DR_I.js +0 -1
- package/dist/assets/dist-a0FfbvMD.js +0 -1
- package/dist/assets/dist-cfkfP0ni.js +0 -1
- package/dist/assets/dist-e6Ho4upI.js +0 -1
- package/dist/assets/dist-mxGLXOFm.js +0 -1
- package/dist/assets/dist-pzQ9JG-p.js +0 -1
- package/dist/assets/dockerfile-ClV2Mqz8.js +0 -1
- package/dist/assets/documentation-panel-D28MpqbI.js +0 -1
- package/dist/assets/download-B9_ToVd4.js +0 -9
- package/dist/assets/dropdown-menu-DdPu5Kfu.js +0 -1
- package/dist/assets/dtd-BAjS2EMD.js +0 -1
- package/dist/assets/dylan-CjAEbzAl.js +0 -1
- package/dist/assets/ecl-DegMF2Uo.js +0 -1
- package/dist/assets/edit-page-otS-QvnC.js +0 -13
- package/dist/assets/eiffel-D_UXtJqE.js +0 -1
- package/dist/assets/elm-CV-6VdWh.js +0 -1
- package/dist/assets/en-US-BO8E69bZ.js +0 -1
- package/dist/assets/erDiagram-Q2GNP2WA-DqlEo_Us.js +0 -60
- package/dist/assets/erlang-C3Vp1oq_.js +0 -1
- package/dist/assets/error-banner-BRG6IPhC.js +0 -1
- package/dist/assets/error-panel-RRoj_iOR.js +0 -1
- package/dist/assets/es-CzkousWe.js +0 -5
- package/dist/assets/esm-CBkHtTOV.js +0 -1
- package/dist/assets/esm-DhTsVMLM.js +0 -1
- package/dist/assets/factor-CBMQHXUW.js +0 -1
- package/dist/assets/factor-CrpY0izf.js +0 -1
- package/dist/assets/field-B1jGbQlH.js +0 -1
- package/dist/assets/file-explorer-panel-CB8vF5ob.js +0 -26
- package/dist/assets/file-icons-CWLHDa1J.js +0 -1
- package/dist/assets/floating-outline-BvQKiC0F.js +0 -1
- package/dist/assets/flowDiagram-NV44I4VS-CQlIJ12H.js +0 -162
- package/dist/assets/focus-DYwTiH9-.js +0 -1
- package/dist/assets/form-CrQYrsUC.js +0 -2
- package/dist/assets/formats-rhOJovGE.js +0 -1
- package/dist/assets/formatting-B4ZCH3ol.js +0 -1
- package/dist/assets/forth-C_TcrpRK.js +0 -1
- package/dist/assets/fortran-DOs2FQj2.js +0 -1
- package/dist/assets/gallery-page-eRea0yic.js +0 -1
- package/dist/assets/ganttDiagram-JELNMOA3-B3EGIuZL.js +0 -267
- package/dist/assets/gas-Cg-F3pmb.js +0 -1
- package/dist/assets/gherkin-CaXqq9kA.js +0 -1
- package/dist/assets/gitGraph-G5XIXVHT-iDzw7G2X.js +0 -1
- package/dist/assets/gitGraphDiagram-V2S2FVAM-h5SlguJK.js +0 -65
- package/dist/assets/glide-data-editor-xt5xNZeV.js +0 -132
- package/dist/assets/globals-BsV5fVR-.js +0 -1
- package/dist/assets/groovy-DmxumoMi.js +0 -1
- package/dist/assets/haskell-BZ-cKqgz.js +0 -1
- package/dist/assets/haxe-x-4elm0t.js +0 -1
- package/dist/assets/home-page-itW0tRmv.js +0 -4
- package/dist/assets/hooks-CHx5dUUq.js +0 -1
- package/dist/assets/html-to-image-BnSc-Wa0.js +0 -2
- package/dist/assets/idl-DNkkzHKH.js +0 -1
- package/dist/assets/index-0n92c_W7.js +0 -38
- package/dist/assets/index-GjXovVsl.css +0 -2
- package/dist/assets/info-VBDWY6EO-CPHm9IfG.js +0 -1
- package/dist/assets/infoDiagram-HS3SLOUP-pzpClObZ.js +0 -2
- package/dist/assets/input-CUwqpKjd.js +0 -1
- package/dist/assets/isValid-BGe7pJXT.js +0 -1
- package/dist/assets/javascript-B0uQ9oZ_.js +0 -1
- package/dist/assets/journeyDiagram-XKPGCS4Q-BrdRi92v.js +0 -139
- package/dist/assets/julia-DBflXO9b.js +0 -1
- package/dist/assets/kanban-definition-3W4ZIXB7-B6WqgFqh.js +0 -89
- package/dist/assets/katex-YDobqqVd.js +0 -1
- package/dist/assets/kiosk-mode-DNjEnIWb.js +0 -1
- package/dist/assets/label-TNNaT1M9.js +0 -1
- package/dist/assets/layout-CwFtCyW8.js +0 -5
- package/dist/assets/line-BBSd2MUH.js +0 -1
- package/dist/assets/linear-BP9rwmWK.js +0 -1
- package/dist/assets/links-CIQwYQ48.js +0 -1
- package/dist/assets/livescript-DRwwdQDY.js +0 -1
- package/dist/assets/logs-panel-BU1tNEVc.js +0 -1
- package/dist/assets/loro_wasm_bg-MY7PmKYj.js +0 -1
- package/dist/assets/lua-D_CRYz1e.js +0 -1
- package/dist/assets/markdown-renderer-MR9df58W.js +0 -10
- package/dist/assets/mathematica-D28k0VAB.js +0 -1
- package/dist/assets/mbox-B74-q1nN.js +0 -1
- package/dist/assets/menu-items-UxKrm8hS.js +0 -1
- package/dist/assets/mermaid-4DMBBIKO-PoHnhmy8.js +0 -1
- package/dist/assets/mermaid-Djr3jUAB.js +0 -11
- package/dist/assets/mermaid-parser.core-DR82IMb2.js +0 -4
- package/dist/assets/mhchem-B98RQJ-y.js +0 -1
- package/dist/assets/mindmap-definition-VGOIOE7T-DAmJpbPM.js +0 -68
- package/dist/assets/mirc-CW8yiVay.js +0 -1
- package/dist/assets/mllike-BwZpH7CZ.js +0 -1
- package/dist/assets/mode-AcL8c6qH.js +0 -1
- package/dist/assets/modelica-AhRO-ii8.js +0 -1
- package/dist/assets/mscgen-CJZUmlSk.js +0 -1
- package/dist/assets/multi-map-Pp1P2DOX.js +0 -1
- package/dist/assets/mumps-BTPWDvZ1.js +0 -1
- package/dist/assets/name-cell-input-DVFEv_aO.js +0 -1
- package/dist/assets/nsis-BeaU1Q2K.js +0 -1
- package/dist/assets/nsis-CuVPiHG5.js +0 -1
- package/dist/assets/ntriples-eNmSbiOL.js +0 -1
- package/dist/assets/number-overlay-editor-D__AflXQ.js +0 -9
- package/dist/assets/octave-BboqqX2Z.js +0 -1
- package/dist/assets/ordinal-BjO5SoTk.js +0 -1
- package/dist/assets/outline-panel-CP0oIuiU.js +0 -1
- package/dist/assets/oz-eUT9rD_n.js +0 -1
- package/dist/assets/packages-panel-CzRELimG.js +0 -1
- package/dist/assets/packet-DYOGHKS2-0KdzLf9c.js +0 -1
- package/dist/assets/panels-wTweRyIv.js +0 -1
- package/dist/assets/pascal-Bl9h-Ruv.js +0 -1
- package/dist/assets/perl-B1GdYx3j.js +0 -1
- package/dist/assets/pie-VRWISCQL-C6EIS9iq.js +0 -1
- package/dist/assets/pieDiagram-ADFJNKIX-DbGIFRoq.js +0 -30
- package/dist/assets/pig-CoZHWNtw.js +0 -1
- package/dist/assets/popover-BPGG2gPG.js +0 -1
- package/dist/assets/powershell-B2p71KcT.js +0 -1
- package/dist/assets/precisionRound-BOmLQIKI.js +0 -1
- package/dist/assets/process-output-CTVsT--B.js +0 -1
- package/dist/assets/properties-Cs9aaJGK.js +0 -1
- package/dist/assets/protobuf-DFCnQG_o.js +0 -1
- package/dist/assets/pug-BShaWOtD.js +0 -1
- package/dist/assets/pug-v81J9ytZ.js +0 -1
- package/dist/assets/puppet-4yIFv98Z.js +0 -1
- package/dist/assets/python-ByMRQ0aE.js +0 -1
- package/dist/assets/q-C7EgGttK.js +0 -1
- package/dist/assets/quadrantDiagram-AYHSOK5B-CLAtyple.js +0 -7
- package/dist/assets/r-DpLLx5HE.js +0 -1
- package/dist/assets/radar-ZZBFDIW7-IOV25h32.js +0 -1
- package/dist/assets/react-vega-BZav_-2n.js +0 -190
- package/dist/assets/react-vega-Da-Ps9UW.js +0 -1
- package/dist/assets/readonly-python-code-DH-1xZGq.js +0 -1
- package/dist/assets/renderShortcut-CnD1Dah5.js +0 -1
- package/dist/assets/request-registry-B-7cIM_I.js +0 -1
- package/dist/assets/requirementDiagram-UZGBJVZJ-DDDTB1LD.js +0 -64
- package/dist/assets/rpm-DlCq0FVA.js +0 -1
- package/dist/assets/ruby-BGmSEBWH.js +0 -1
- package/dist/assets/run-page-FCvGnICa.js +0 -1
- package/dist/assets/runs-Bhy0tbWr.js +0 -1
- package/dist/assets/sankeyDiagram-TZEHDZUN-DAWPOfBw.js +0 -10
- package/dist/assets/sas-CFcv5xFe.js +0 -1
- package/dist/assets/scheme-BgRfkNY3.js +0 -1
- package/dist/assets/scratchpad-panel-k9lrm-rC.js +0 -1
- package/dist/assets/secrets-panel-B1Z-6dmz.js +0 -1
- package/dist/assets/select-CxT2Geqr.js +0 -1
- package/dist/assets/sequenceDiagram-WL72ISMW-D_qAidD2.js +0 -145
- package/dist/assets/session-panel-WhN0qilM.js +0 -1
- package/dist/assets/share-BdH_5I58.js +0 -1
- package/dist/assets/shell-CKQz0rkv.js +0 -1
- package/dist/assets/sieve-D0P6XnTD.js +0 -1
- package/dist/assets/slides-component-Brm_TS4x.js +0 -1
- package/dist/assets/smalltalk-Dcg9QwVr.js +0 -1
- package/dist/assets/snippets-panel-BCDHUuku.js +0 -1
- package/dist/assets/sparql-f01xs6VH.js +0 -1
- package/dist/assets/spec-DbmSqx09.js +0 -1
- package/dist/assets/src-Bp_72rVO.js +0 -1
- package/dist/assets/state-3V5UxC3B.js +0 -1
- package/dist/assets/state-CBmCYWFH.js +0 -1
- package/dist/assets/state-Ce7CVShi.js +0 -1
- package/dist/assets/stateDiagram-FKZM4ZOC-C7qgDrGA.js +0 -1
- package/dist/assets/stateDiagram-v2-4FDKWEC3-CEqeIlM0.js +0 -1
- package/dist/assets/step-BkfKj3CL.js +0 -1
- package/dist/assets/stex-BBWVYm-R.js +0 -1
- package/dist/assets/stylus-BjzHGGgo.js +0 -1
- package/dist/assets/swift-DOptU29u.js +0 -1
- package/dist/assets/switch-CVKxYu_0.js +0 -1
- package/dist/assets/tcl-vC8etUeQ.js +0 -1
- package/dist/assets/terminal-Cr7wbEjz.js +0 -62
- package/dist/assets/textile-BfLqcKXP.js +0 -1
- package/dist/assets/time-D2GKc0U6.js +0 -1
- package/dist/assets/timeline-definition-IT6M3QCI-hd6uJKGs.js +0 -61
- package/dist/assets/toggle-RCwU-rnE.js +0 -1
- package/dist/assets/toml-rX0_Isgp.js +0 -1
- package/dist/assets/tooltip-D9723Brr.js +0 -1
- package/dist/assets/tracing-DUVd0jtl.js +0 -1
- package/dist/assets/tracing-panel-CuTxPn_x.js +0 -2
- package/dist/assets/tree-Ch2-GuhG.js +0 -3
- package/dist/assets/treemap-GDKQZRPO-BUa0eLeZ.js +0 -1
- package/dist/assets/troff-C1lPb0WN.js +0 -1
- package/dist/assets/ttcn-D5dxusfs.js +0 -1
- package/dist/assets/ttcn-cfg-Dj2ybct-.js +0 -1
- package/dist/assets/turtle-BiTItqZm.js +0 -1
- package/dist/assets/useAddCell-YC7rpcmD.js +0 -1
- package/dist/assets/useBoolean-m1e6E3Ao.js +0 -1
- package/dist/assets/useCellActionButton-GUb2fXU8.js +0 -1
- package/dist/assets/useDateFormatter-CpE7XQLs.js +0 -1
- package/dist/assets/useDeleteCell-DRUDRiy0.js +0 -1
- package/dist/assets/useDependencyPanelTab-nFVMlEx0.js +0 -1
- package/dist/assets/useInstallPackage-C9V-on2J.js +0 -1
- package/dist/assets/useNotebookActions-ChLHy-0O.js +0 -1
- package/dist/assets/useNumberFormatter-DbDKSvEd.js +0 -1
- package/dist/assets/usePress-BHGkpw8X.js +0 -7
- package/dist/assets/useRunCells-5m6jCnyo.js +0 -1
- package/dist/assets/useSplitCell-DGD9smMq.js +0 -1
- package/dist/assets/utils-CdjCA1J8.js +0 -61
- package/dist/assets/vb-roE2hgal.js +0 -1
- package/dist/assets/vbscript-2s97682t.js +0 -1
- package/dist/assets/vega-component-CRbeDmeM.js +0 -1
- package/dist/assets/vega-loader.browser-CZV6_g2i.js +0 -6
- package/dist/assets/velocity-D0YPg3VZ.js +0 -1
- package/dist/assets/verilog-Btszgjcd.js +0 -1
- package/dist/assets/vhdl-enS91NZh.js +0 -1
- package/dist/assets/webidl-DQMyFjhm.js +0 -1
- package/dist/assets/write-secret-modal-BCvuRAFb.js +0 -1
- package/dist/assets/xquery-D5Jh9c_Z.js +0 -1
- package/dist/assets/xychartDiagram-PRI3JC2R-CXlUBSbQ.js +0 -7
- package/dist/assets/yacas-CTzSIaAf.js +0 -1
- package/dist/assets/z80-Dt0hdUwP.js +0 -1
- package/src/fonts/Fira_Mono/FiraMono-Bold.ttf +0 -0
- package/src/fonts/Fira_Mono/FiraMono-Medium.ttf +0 -0
- package/src/fonts/Fira_Mono/FiraMono-Regular.ttf +0 -0
- package/src/fonts/Lora/Lora-Italic-VariableFont_wght.ttf +0 -0
- package/src/fonts/Lora/Lora-VariableFont_wght.ttf +0 -0
- package/src/fonts/Lora/static/Lora-Bold.ttf +0 -0
- package/src/fonts/Lora/static/Lora-BoldItalic.ttf +0 -0
- package/src/fonts/Lora/static/Lora-Italic.ttf +0 -0
- package/src/fonts/Lora/static/Lora-Medium.ttf +0 -0
- package/src/fonts/Lora/static/Lora-MediumItalic.ttf +0 -0
- package/src/fonts/Lora/static/Lora-Regular.ttf +0 -0
- package/src/fonts/Lora/static/Lora-SemiBold.ttf +0 -0
- package/src/fonts/Lora/static/Lora-SemiBoldItalic.ttf +0 -0
- package/src/fonts/PT_Sans/PTSans-Bold.ttf +0 -0
- package/src/fonts/PT_Sans/PTSans-BoldItalic.ttf +0 -0
- package/src/fonts/PT_Sans/PTSans-Italic.ttf +0 -0
- package/src/fonts/PT_Sans/PTSans-Regular.ttf +0 -0
- /package/dist/assets/{Combination-Cs9nbinQ.js → Combination-CSPK4t6z.js} +0 -0
- /package/dist/assets/{Deferred-BMfCOLaw.js → Deferred-CfyqLOPG.js} +0 -0
- /package/dist/assets/{ImageComparisonComponent-DvDPDgw3.js → ImageComparisonComponent-Cw3aoN3z.js} +0 -0
- /package/dist/assets/{Inputs-D5kI9GwB.js → Inputs-CsxDtqlI.js} +0 -0
- /package/dist/assets/{Plot-DQQQ-fLA.js → Plot-eiPFedH2.js} +0 -0
- /package/dist/assets/{SSRProvider-DC7ElCZZ.js → SSRProvider-BkypbMcb.js} +0 -0
- /package/dist/assets/{alert-OQZHipbB.js → alert-NjVFesQm.js} +0 -0
- /package/dist/assets/{apl-CexVE068.js → apl-D8X_E6Wh.js} +0 -0
- /package/dist/assets/{array-psg969PF.js → array-CEZNxKGf.js} +0 -0
- /package/dist/assets/{asciiarmor-DzdXFxI-.js → asciiarmor-DeecVuRW.js} +0 -0
- /package/dist/assets/{asn1-lKNP6w4p.js → asn1-C9WWFN1p.js} +0 -0
- /package/dist/assets/{asterisk-Bjb62jej.js → asterisk-Dykb_Qas.js} +0 -0
- /package/dist/assets/{badge-hTpPIsMT.js → badge-DImLVznf.js} +0 -0
- /package/dist/assets/{blob-CObhN-9g.js → blob-C3EfaMOb.js} +0 -0
- /package/dist/assets/{bot-message-square-CK6eoGWy.js → bot-message-square-Dw41U6lL.js} +0 -0
- /package/dist/assets/{brainfuck-pTL_9bJ7.js → brainfuck-Cl6gOsOa.js} +0 -0
- /package/dist/assets/{bundle.esm-idScn0w0.js → bundle.esm-_LzfhNmX.js} +0 -0
- /package/dist/assets/{card-C-c-4jyF.js → card-OaQlvpSl.js} +0 -0
- /package/dist/assets/{chart-no-axes-column-DV8gdCvH.js → chart-no-axes-column-a9XtWmzk.js} +0 -0
- /package/dist/assets/{check-BE0hEwVo.js → check-DZA_bRpw.js} +0 -0
- /package/dist/assets/{chevron-right-D0GQBpTb.js → chevron-right-CvVxySQk.js} +0 -0
- /package/dist/assets/{chunk-4F5CHEZ2-BGeTOmrq.js → chunk-4F5CHEZ2-Bghwh3ep.js} +0 -0
- /package/dist/assets/{chunk-B2363JML-Cmh9TPpj.js → chunk-B2363JML-B3wWt_gr.js} +0 -0
- /package/dist/assets/{chunk-DR5Q36YT-SM9ZwAOv.js → chunk-DR5Q36YT-DOSR70sR.js} +0 -0
- /package/dist/assets/{chunk-FRFDVMJY-CUDE-MUX.js → chunk-FRFDVMJY-D9fs6vlF.js} +0 -0
- /package/dist/assets/{chunk-PL6DKKU2-DMqBvHTF.js → chunk-PL6DKKU2-CdtxnIBd.js} +0 -0
- /package/dist/assets/{chunk-SJTYNZTY-C9cwtT3h.js → chunk-SJTYNZTY-CMwkFD7U.js} +0 -0
- /package/dist/assets/{chunk-TQ3KTPDO-CUyT9lNN.js → chunk-TQ3KTPDO-0Us1NWXT.js} +0 -0
- /package/dist/assets/{chunk-UMXZTB3W-Bt-_br31.js → chunk-UMXZTB3W-zYd--p4q.js} +0 -0
- /package/dist/assets/{circle-check-gLIOLu8x.js → circle-check-CbaVeozR.js} +0 -0
- /package/dist/assets/{circle-play-DYGULlKZ.js → circle-play-DYn5nR6N.js} +0 -0
- /package/dist/assets/{circle-plus-CGG-gArM.js → circle-plus-nCze0-py.js} +0 -0
- /package/dist/assets/{clear-button-DrIF5o__.js → clear-button-CsNT-Tql.js} +0 -0
- /package/dist/assets/{click-outside-container-CagwJLiG.js → click-outside-container-gHk0jCel.js} +0 -0
- /package/dist/assets/{clike-BCxd7pZ9.js → clike-BuY5U60j.js} +0 -0
- /package/dist/assets/{clipboard-paste-DoYSN8Sv.js → clipboard-paste-EHXeKq9D.js} +0 -0
- /package/dist/assets/{clojure-CPAS-74L.js → clojure-C8jGLyPy.js} +0 -0
- /package/dist/assets/{cmake-DMONEHtp.js → cmake-DcjYbevD.js} +0 -0
- /package/dist/assets/{cobol-0rQGzjf0.js → cobol-C-nFr8y5.js} +0 -0
- /package/dist/assets/{code-xml-DwHPF_nL.js → code-xml-BlrJCgNZ.js} +0 -0
- /package/dist/assets/{coffeescript-BHNUw4aR.js → coffeescript-VbbBP-Cm.js} +0 -0
- /package/dist/assets/{colors-WO6MvCS3.js → colors-Dm6L93c7.js} +0 -0
- /package/dist/assets/{common-keywords-D_14jCw0.js → common-keywords-sop6vXJR.js} +0 -0
- /package/dist/assets/{commonlisp-Cjiyl45-.js → commonlisp-mLMub2u_.js} +0 -0
- /package/dist/assets/{copy-CkudG0Ej.js → copy-D6N1-xc1.js} +0 -0
- /package/dist/assets/{crystal-CUMDisY2.js → crystal-Buc8hu84.js} +0 -0
- /package/dist/assets/{css-B6NFOUor.js → css-DtNg2SPz.js} +0 -0
- /package/dist/assets/{cypher-DcWJtLBw.js → cypher-wyT0Afvt.js} +0 -0
- /package/dist/assets/{cytoscape.esm-DuXIsNbY.js → cytoscape.esm-CuwfIk-V.js} +0 -0
- /package/dist/assets/{d-CpNp8oDv.js → d-KzUzEnwn.js} +0 -0
- /package/dist/assets/{database-zap-DTWCDKdn.js → database-zap-BIGMFOfP.js} +0 -0
- /package/dist/assets/{defaultLocale-OkOxlkkM.js → defaultLocale-DPBdGRrH.js} +0 -0
- /package/dist/assets/{defaultLocale-DK1MWd7f.js → defaultLocale-Lfi0pexn.js} +0 -0
- /package/dist/assets/{diff-BCFJsGHX.js → diff-zZX_BZ60.js} +0 -0
- /package/dist/assets/{dist-D9Vhptds.js → dist-2yYHES7B.js} +0 -0
- /package/dist/assets/{dist-CVEvQ1Ex.js → dist-4adVoHKM.js} +0 -0
- /package/dist/assets/{dist-ASlWkGgG.js → dist-8B3AWTCv.js} +0 -0
- /package/dist/assets/{dist-sVuk6mkQ.js → dist-AkjWZMeV.js} +0 -0
- /package/dist/assets/{dist-8UD0A5sU.js → dist-BF9S272t.js} +0 -0
- /package/dist/assets/{dist-BhNN2V5a.js → dist-BKm9wJTB.js} +0 -0
- /package/dist/assets/{dist-BR9zyVPH.js → dist-BacKBlEY.js} +0 -0
- /package/dist/assets/{dist-OxxI-HeS.js → dist-Bi4JuBeU.js} +0 -0
- /package/dist/assets/{dist-COnmrAVZ.js → dist-BjCIGEdQ.js} +0 -0
- /package/dist/assets/{dist-apDpadc4.js → dist-Bk1itfBD.js} +0 -0
- /package/dist/assets/{dist-DxrbvUBv.js → dist-CKX5rwHQ.js} +0 -0
- /package/dist/assets/{dist-DBPtheKQ.js → dist-CybQbPjb.js} +0 -0
- /package/dist/assets/{dist-CQqv2gQL.js → dist-Dm11d0_A.js} +0 -0
- /package/dist/assets/{dist-CgC048vN.js → dist-DzjL8iiW.js} +0 -0
- /package/dist/assets/{download-DBW9RXtT.js → download-nLboiTtW.js} +0 -0
- /package/dist/assets/{dtd-D7nO7isU.js → dtd-DrorhQz9.js} +0 -0
- /package/dist/assets/{duckdb-keywords-CSySeB8R.js → duckdb-keywords-CEWQs1NJ.js} +0 -0
- /package/dist/assets/{dylan-qEhlQv4l.js → dylan-B4r5umK9.js} +0 -0
- /package/dist/assets/{ebnf-KJaLpQez.js → ebnf-BoS8ZFT2.js} +0 -0
- /package/dist/assets/{ecl-cXHEjabG.js → ecl-Chc_DmTY.js} +0 -0
- /package/dist/assets/{eiffel-CUTEIYa-.js → eiffel-CIYqf7wj.js} +0 -0
- /package/dist/assets/{ellipsis-0_zJdF6H.js → ellipsis-d7eaKIFn.js} +0 -0
- /package/dist/assets/{ellipsis-vertical-CAB7tdza.js → ellipsis-vertical-DBQ5kWTo.js} +0 -0
- /package/dist/assets/{elm-DOfGHeKn.js → elm-Baq4wI8e.js} +0 -0
- /package/dist/assets/{emotion-is-prop-valid.esm-D1keIaYa.js → emotion-is-prop-valid.esm-lG8j6oqk.js} +0 -0
- /package/dist/assets/{empty-state-B_US46Us.js → empty-state-BBWqzODS.js} +0 -0
- /package/dist/assets/{erlang-B5R7Byby.js → erlang-xHcM8uVi.js} +0 -0
- /package/dist/assets/{errors-Bfogio62.js → errors-iwK4b4VF.js} +0 -0
- /package/dist/assets/{esm-CX-gNDKf.js → esm-DM72gy9Q.js} +0 -0
- /package/dist/assets/{extends-DRbCSry7.js → extends-B9D0JO9U.js} +0 -0
- /package/dist/assets/{eye-off-vwi9L975.js → eye-off-CF3GmvXV.js} +0 -0
- /package/dist/assets/{fcl-Cf241iHu.js → fcl-JwfU5Rr4.js} +0 -0
- /package/dist/assets/{file-DzHkbIdO.js → file-C-yMeaec.js} +0 -0
- /package/dist/assets/{file-headphone-B5q2Ow55.js → file-headphone-CPAP8asn.js} +0 -0
- /package/dist/assets/{file-plus-corner-lLQw9OnR.js → file-plus-corner-ks__N1mr.js} +0 -0
- /package/dist/assets/{forth-BjV8SV3p.js → forth-j6RT-cy6.js} +0 -0
- /package/dist/assets/{fortran-CvNblcug.js → fortran-Z7A59UbQ.js} +0 -0
- /package/dist/assets/{gas-D1YrZZUY.js → gas-5kgpLqGg.js} +0 -0
- /package/dist/assets/{gherkin-CAUl7roi.js → gherkin-KECBIOSQ.js} +0 -0
- /package/dist/assets/{github-BVtI-3F1.js → github-CRD4USKm.js} +0 -0
- /package/dist/assets/{groovy-CnmCDhLm.js → groovy-CocWwvHR.js} +0 -0
- /package/dist/assets/{haskell-qdBb4h_7.js → haskell-BVRegKDO.js} +0 -0
- /package/dist/assets/{haxe-MQhLSFhI.js → haxe-U6x7KK2i.js} +0 -0
- /package/dist/assets/{http-_roNBajA.js → http-BSf7msSy.js} +0 -0
- /package/dist/assets/{icons-CrUXojcA.js → icons-D4U3iRHj.js} +0 -0
- /package/dist/assets/{idl-CcZzcWCI.js → idl-Byd3Qhyl.js} +0 -0
- /package/dist/assets/{image-DXfkah9d.js → image-CfyJzBP9.js} +0 -0
- /package/dist/assets/{init-XMA8CWhh.js → init-BpLL1fe9.js} +0 -0
- /package/dist/assets/{javascript-hE4QNtKl.js → javascript-D0a_TZzL.js} +0 -0
- /package/dist/assets/{julia-BjrvvLkp.js → julia-CaxV2pJw.js} +0 -0
- /package/dist/assets/{katex-rvFxOCU-.js → katex-FSdXOW5Y.js} +0 -0
- /package/dist/assets/{kbd-DvKpAc6K.js → kbd-zZCuQN_1.js} +0 -0
- /package/dist/assets/{link-Cf10mh3t.js → link-_dbp0XNB.js} +0 -0
- /package/dist/assets/{links-DzgPOFJ-.js → links-BQHNKE3J.js} +0 -0
- /package/dist/assets/{livescript-B01pNEzu.js → livescript-CfGHFsX-.js} +0 -0
- /package/dist/assets/{loro_wasm_bg-CcIcmNa3.js → loro_wasm_bg-Bj93RhA2.js} +0 -0
- /package/dist/assets/{lua-BwfRgSM6.js → lua-DwgMJ83W.js} +0 -0
- /package/dist/assets/{maps-OKerBHH8.js → maps-DQsjfyTy.js} +0 -0
- /package/dist/assets/{marimo-icons-C_YDiXeg.js → marimo-icons-Cb4NA8Cp.js} +0 -0
- /package/dist/assets/{math-CeGhAAgQ.js → math-CpvW-dlE.js} +0 -0
- /package/dist/assets/{mathematica-DLi5eijp.js → mathematica-CUcY8E3Z.js} +0 -0
- /package/dist/assets/{mbox-QweTYWJQ.js → mbox-QWIxg89f.js} +0 -0
- /package/dist/assets/{mirc-1J5TZ8Tf.js → mirc-PcCLOR2R.js} +0 -0
- /package/dist/assets/{mllike-DRzCrpbj.js → mllike-JiC27gOy.js} +0 -0
- /package/dist/assets/{modelica-GZKavTLw.js → modelica-BcfhGWp8.js} +0 -0
- /package/dist/assets/{mscgen-HMNaCHuy.js → mscgen-C2sdz_zX.js} +0 -0
- /package/dist/assets/{multi-icon-DEWnuZs2.js → multi-icon-BIYBHgCy.js} +0 -0
- /package/dist/assets/{mumps-CzCxfP2m.js → mumps-DTtlu7TY.js} +0 -0
- /package/dist/assets/{nginx-Dfd7l9Sj.js → nginx-CNcs7tVC.js} +0 -0
- /package/dist/assets/{node-sql-parser-BvUFblwL.js → node-sql-parser-fWuidk6P.js} +0 -0
- /package/dist/assets/{ntriples-DT57g_ZF.js → ntriples-CHcftTy8.js} +0 -0
- /package/dist/assets/{numbers-CYnquDho.js → numbers-Bv8m4sHE.js} +0 -0
- /package/dist/assets/{objectWithoutPropertiesLoose-DP4vAkvg.js → objectWithoutPropertiesLoose-CboCOq4o.js} +0 -0
- /package/dist/assets/{octave-CtuTaUjQ.js → octave-D7F4qXl_.js} +0 -0
- /package/dist/assets/{oz-BS8LEqKx.js → oz-VftS117C.js} +0 -0
- /package/dist/assets/{panel-context-BN0DQXiK.js → panel-context-CcwYw5Eq.js} +0 -0
- /package/dist/assets/{pascal-Db0ZEHQw.js → pascal-CxVKwA9u.js} +0 -0
- /package/dist/assets/{path-CkIaQHJO.js → path-DtYs9Dst.js} +0 -0
- /package/dist/assets/{paths-D2lG83Oh.js → paths-BVwhPRFT.js} +0 -0
- /package/dist/assets/{perl-DgJKzgyz.js → perl-x4BFnPib.js} +0 -0
- /package/dist/assets/{pig-Dk6eYa40.js → pig-Dmhj3J78.js} +0 -0
- /package/dist/assets/{play-DKSqmedg.js → play-Bu_0ogGD.js} +0 -0
- /package/dist/assets/{plus-dVmh0yTy.js → plus-DJ99CUbx.js} +0 -0
- /package/dist/assets/{powershell-dW0qpS7j.js → powershell-Bg32vFxB.js} +0 -0
- /package/dist/assets/{preload-helper-BW0IMuFq.js → preload-helper-y72bE5iF.js} +0 -0
- /package/dist/assets/{prop-types-RrUi-pOT.js → prop-types-C638SUfx.js} +0 -0
- /package/dist/assets/{properties-oMha4ix2.js → properties-DQbiKM_q.js} +0 -0
- /package/dist/assets/{protobuf-CfWJ4EtB.js → protobuf-Sa3BXDQ1.js} +0 -0
- /package/dist/assets/{puppet-O2K_n-UM.js → puppet-CnXWm8bo.js} +0 -0
- /package/dist/assets/{purify.es-BBn8CPhf.js → purify.es-Cf8RQecB.js} +0 -0
- /package/dist/assets/{python-qMKsSr4L.js → python-B1WBAJzp.js} +0 -0
- /package/dist/assets/{q-ewn8d81Q.js → q-BqOVUYF0.js} +0 -0
- /package/dist/assets/{r-CqF-AjDv.js → r-BNvjQBjW.js} +0 -0
- /package/dist/assets/{range-DNqFcYmr.js → range-Dk7lXDev.js} +0 -0
- /package/dist/assets/{react-resizable-panels.browser.esm-DDRqG5ui.js → react-resizable-panels.browser.esm-RgA6v8U3.js} +0 -0
- /package/dist/assets/{refresh-ccw-DLpfIr8v.js → refresh-ccw-DQ6SJ8UC.js} +0 -0
- /package/dist/assets/{refresh-cw-CHAHPgkx.js → refresh-cw-Dg9tCj4k.js} +0 -0
- /package/dist/assets/{requests-CP6q3-4O.js → requests-xhM8i_W9.js} +0 -0
- /package/dist/assets/{rotate-ccw-hLlF_82X.js → rotate-ccw-BCkZViUZ.js} +0 -0
- /package/dist/assets/{rpm-BqLq138P.js → rpm-Cdb8SyEx.js} +0 -0
- /package/dist/assets/{ruby-CQfbO3YY.js → ruby-Csu3wroo.js} +0 -0
- /package/dist/assets/{sas-BmpgVn6Q.js → sas-NClU0xuj.js} +0 -0
- /package/dist/assets/{save-8fSvKYJT.js → save-CUdcv5qm.js} +0 -0
- /package/dist/assets/{scheme-rgyDg_wq.js → scheme-Hpx9xPN-.js} +0 -0
- /package/dist/assets/{session-BrEm7qNv.js → session-CByuQ-M-.js} +0 -0
- /package/dist/assets/{settings-CzQUw9rV.js → settings-B7nhfCat.js} +0 -0
- /package/dist/assets/{shell-Dndk6Ld6.js → shell-Cd99saJE.js} +0 -0
- /package/dist/assets/{sieve-bGgktpLX.js → sieve-D0zJ8TZ9.js} +0 -0
- /package/dist/assets/{simple-mode-oMMOWqWz.js → simple-mode-DpDBSVll.js} +0 -0
- /package/dist/assets/{smalltalk-CU43LrKS.js → smalltalk-BBBJczpn.js} +0 -0
- /package/dist/assets/{solr-CJeCgAfj.js → solr-B928KjNx.js} +0 -0
- /package/dist/assets/{sparql-BycKC3X4.js → sparql-uAF7_Z2_.js} +0 -0
- /package/dist/assets/{spinner-C5JoisA7.js → spinner-pCogyRyo.js} +0 -0
- /package/dist/assets/{spreadsheet-BYYvgLKe.js → spreadsheet-CAG48M_e.js} +0 -0
- /package/dist/assets/{sql-B5I6FC3m.js → sql-nk70rjN1.js} +0 -0
- /package/dist/assets/{square-CxAsQQ77.js → square-KVNDGpgy.js} +0 -0
- /package/dist/assets/{square-function-B006EYFX.js → square-function-BMNCw7Qb.js} +0 -0
- /package/dist/assets/{src-CW27-Kjl.js → src-BRLtyMKi.js} +0 -0
- /package/dist/assets/{stex-0ac7Aukl.js → stex-C6JeW1YI.js} +0 -0
- /package/dist/assets/{stylus-CePwhvgW.js → stylus-fMZU8VtG.js} +0 -0
- /package/dist/assets/{swift-CfgglXjR.js → swift-CkY7kBhf.js} +0 -0
- /package/dist/assets/{table-BhH-Mm8O.js → table-CA8eU1EB.js} +0 -0
- /package/dist/assets/{table-BCnp9gKC.js → table-Od8PbuV-.js} +0 -0
- /package/dist/assets/{tcl-D_gYSBm0.js → tcl-CS15Nqmn.js} +0 -0
- /package/dist/assets/{textile-BEvFU9wV.js → textile-BQsumqly.js} +0 -0
- /package/dist/assets/{tiddlywiki-hmNzZkq6.js → tiddlywiki-BiHxc-2_.js} +0 -0
- /package/dist/assets/{tiki-BL1SzuSx.js → tiki-Cwip62d7.js} +0 -0
- /package/dist/assets/{timer-CPT_vXom.js → timer-BEJidwwG.js} +0 -0
- /package/dist/assets/{toDate-BqKH-Jd9.js → toDate-Cfp9W_O9.js} +0 -0
- /package/dist/assets/{toml-DGJRpV2e.js → toml-CoHiT08x.js} +0 -0
- /package/dist/assets/{trash-2-CAoNMkjq.js → trash-2-Bc_J7TQO.js} +0 -0
- /package/dist/assets/{trash-BZMAQneW.js → trash-Cxd189Vw.js} +0 -0
- /package/dist/assets/{treemap-Cf5pgJDk.js → treemap-qinQgXo1.js} +0 -0
- /package/dist/assets/{triangle-alert-qZo1ox6x.js → triangle-alert-CzLrbLGN.js} +0 -0
- /package/dist/assets/{troff-CUlohIux.js → troff-CpFvF7Eq.js} +0 -0
- /package/dist/assets/{ttcn-nuQ3wCdy.js → ttcn-BjnqPnO0.js} +0 -0
- /package/dist/assets/{ttcn-cfg-DCxdE-sj.js → ttcn-cfg-D29EWwwv.js} +0 -0
- /package/dist/assets/{turtle-B2N96QpC.js → turtle-mWsfmaJW.js} +0 -0
- /package/dist/assets/{types-C1RN112u.js → types-CLOMZuqU.js} +0 -0
- /package/dist/assets/{types-BfP_kuAY.js → types-Myu7G9iV.js} +0 -0
- /package/dist/assets/{use-toast-Hc8CXlvz.js → use-toast-BtZldTi5.js} +0 -0
- /package/dist/assets/{useAsyncData-D-4ifFXh.js → useAsyncData-D-z1U8-c.js} +0 -0
- /package/dist/assets/{useDebounce-B0dx2Gp0.js → useDebounce-Ccai5RO4.js} +0 -0
- /package/dist/assets/{useDeepCompareMemoize-yyiB9aJX.js → useDeepCompareMemoize-D1hTncYV.js} +0 -0
- /package/dist/assets/{useIframeCapabilities-DTN9kFDq.js → useIframeCapabilities-CouCDnwL.js} +0 -0
- /package/dist/assets/{useInterval-BJucVdV-.js → useInterval-BckTGVbf.js} +0 -0
- /package/dist/assets/{useTheme-BYXBU1of.js → useTheme-KDW4sktg.js} +0 -0
- /package/dist/assets/{uuid-ClFZlR7U.js → uuid-BukULOeS.js} +0 -0
- /package/dist/assets/{vb-CBiIL_zx.js → vb-E2EKvwgc.js} +0 -0
- /package/dist/assets/{vbscript-B3Y69Iw0.js → vbscript-98sn9Pr4.js} +0 -0
- /package/dist/assets/{velocity-B5BPA7FX.js → velocity-DUbAzJtM.js} +0 -0
- /package/dist/assets/{verilog-BwmYR8E3.js → verilog-DK7zLFMr.js} +0 -0
- /package/dist/assets/{vhdl-VXFnDy2U.js → vhdl-B9Tq3stB.js} +0 -0
- /package/dist/assets/{web-vitals-BaMazlva.js → web-vitals-CJ8ovao_.js} +0 -0
- /package/dist/assets/{webidl-Bcmf9JWd.js → webidl-C5qiIEir.js} +0 -0
- /package/dist/assets/{workflow-BmeqNuSH.js → workflow-BqHyyStM.js} +0 -0
- /package/dist/assets/{ws-CBdPISJL.js → ws-D2eS61zr.js} +0 -0
- /package/dist/assets/{x-BI1M8X_v.js → x-CdLP7-v3.js} +0 -0
- /package/dist/assets/{xquery-8pWKOyFY.js → xquery-CmGczatZ.js} +0 -0
- /package/dist/assets/{yacas-BFcwo3Cx.js → yacas-BbepBpsT.js} +0 -0
- /package/dist/assets/{youtube-DE-Ej6FR.js → youtube-CfU-SnDw.js} +0 -0
- /package/dist/assets/{z80-t3SBb7Lt.js → z80-C2f-3LU8.js} +0 -0
|
@@ -2,9 +2,15 @@
|
|
|
2
2
|
|
|
3
3
|
import { closeCompletion, completionStatus } from "@codemirror/autocomplete";
|
|
4
4
|
import { type Extension, Prec } from "@codemirror/state";
|
|
5
|
-
import {
|
|
5
|
+
import {
|
|
6
|
+
EditorView,
|
|
7
|
+
type KeyBinding,
|
|
8
|
+
keymap,
|
|
9
|
+
type ViewUpdate,
|
|
10
|
+
} from "@codemirror/view";
|
|
6
11
|
import { createTracebackInfoAtom } from "@/core/cells/cells";
|
|
7
12
|
import { type CellId, HTMLCellId, SCRATCH_CELL_ID } from "@/core/cells/ids";
|
|
13
|
+
import { loroSyncAnnotation } from "@/core/codemirror/rtc/loro/sync";
|
|
8
14
|
import type { KeymapConfig } from "@/core/config/config-schema";
|
|
9
15
|
import type { HotkeyProvider } from "@/core/hotkeys/hotkeys";
|
|
10
16
|
import { duplicateWithCtrlModifier } from "@/core/hotkeys/shortcuts";
|
|
@@ -330,6 +336,53 @@ function cellCodeEditing(hotkeys: HotkeyProvider): Extension[] {
|
|
|
330
336
|
return [onChangePlugin, formatKeymapExtension(hotkeys)];
|
|
331
337
|
}
|
|
332
338
|
|
|
339
|
+
const MARKDOWN_AUTORUN_USER_EVENTS = ["input", "delete", "undo", "redo"];
|
|
340
|
+
|
|
341
|
+
function shouldAutorunMarkdownUpdate({
|
|
342
|
+
docChanged,
|
|
343
|
+
transactions,
|
|
344
|
+
predicate = () => true,
|
|
345
|
+
hasFocus = false,
|
|
346
|
+
}: Pick<ViewUpdate, "docChanged" | "transactions"> & {
|
|
347
|
+
predicate?: () => boolean;
|
|
348
|
+
hasFocus?: boolean;
|
|
349
|
+
}): boolean {
|
|
350
|
+
// If the doc didn't change, ignore.
|
|
351
|
+
if (!docChanged) {
|
|
352
|
+
return false;
|
|
353
|
+
}
|
|
354
|
+
|
|
355
|
+
// The caller decides when markdown autorun is allowed, e.g. not for
|
|
356
|
+
// f-strings where rerunning on every keystroke is usually incorrect.
|
|
357
|
+
if (!predicate()) {
|
|
358
|
+
return false;
|
|
359
|
+
}
|
|
360
|
+
|
|
361
|
+
// This happens on mount when we start in markdown mode.
|
|
362
|
+
// Ignore formatting changes so language switches don't trigger autorun.
|
|
363
|
+
const isFormattingChange = transactions.some((tr) =>
|
|
364
|
+
tr.effects.some((effect) => effect.is(formattingChangeEffect)),
|
|
365
|
+
);
|
|
366
|
+
if (isFormattingChange) {
|
|
367
|
+
return false;
|
|
368
|
+
}
|
|
369
|
+
|
|
370
|
+
return transactions.some((tr) => {
|
|
371
|
+
// Ignore RTC sync changes to avoid duplicate runs from remote edits.
|
|
372
|
+
if (tr.annotation(loroSyncAnnotation) !== undefined) {
|
|
373
|
+
return false;
|
|
374
|
+
}
|
|
375
|
+
|
|
376
|
+
// Prefer explicit local edit transactions, but keep a focused fallback for
|
|
377
|
+
// local rewrite paths like split-cell, which can update markdown content
|
|
378
|
+
// without annotating a user event.
|
|
379
|
+
return (
|
|
380
|
+
MARKDOWN_AUTORUN_USER_EVENTS.some((kind) => tr.isUserEvent(kind)) ||
|
|
381
|
+
hasFocus
|
|
382
|
+
);
|
|
383
|
+
});
|
|
384
|
+
}
|
|
385
|
+
|
|
333
386
|
/**
|
|
334
387
|
* Extension for auto-running markdown cells
|
|
335
388
|
*/
|
|
@@ -339,30 +392,16 @@ export function markdownAutoRunExtension({
|
|
|
339
392
|
predicate: () => boolean;
|
|
340
393
|
}): Extension {
|
|
341
394
|
return EditorView.updateListener.of((update) => {
|
|
342
|
-
|
|
343
|
-
|
|
344
|
-
|
|
345
|
-
|
|
346
|
-
|
|
347
|
-
|
|
348
|
-
|
|
349
|
-
|
|
350
|
-
return;
|
|
351
|
-
}
|
|
352
|
-
|
|
353
|
-
if (!predicate()) {
|
|
395
|
+
if (
|
|
396
|
+
!shouldAutorunMarkdownUpdate({
|
|
397
|
+
docChanged: update.docChanged,
|
|
398
|
+
transactions: update.transactions,
|
|
399
|
+
predicate,
|
|
400
|
+
hasFocus: update.view.hasFocus,
|
|
401
|
+
})
|
|
402
|
+
) {
|
|
354
403
|
return;
|
|
355
404
|
}
|
|
356
|
-
|
|
357
|
-
// This happens on mount when we start in markdown mode
|
|
358
|
-
const isFormattingChange = update.transactions.some((tr) =>
|
|
359
|
-
tr.effects.some((effect) => effect.is(formattingChangeEffect)),
|
|
360
|
-
);
|
|
361
|
-
if (isFormattingChange) {
|
|
362
|
-
// Ignore formatting changes
|
|
363
|
-
return;
|
|
364
|
-
}
|
|
365
|
-
|
|
366
405
|
const actions = update.view.state.facet(cellActionsState);
|
|
367
406
|
actions.onRun();
|
|
368
407
|
});
|
|
@@ -388,3 +427,7 @@ export function cellBundle({
|
|
|
388
427
|
),
|
|
389
428
|
];
|
|
390
429
|
}
|
|
430
|
+
|
|
431
|
+
export const exportedForTesting = {
|
|
432
|
+
shouldAutorunMarkdownUpdate,
|
|
433
|
+
};
|
|
@@ -1,44 +1,24 @@
|
|
|
1
1
|
/* Copyright 2026 Marimo. All rights reserved. */
|
|
2
2
|
|
|
3
|
-
import {
|
|
4
|
-
import {
|
|
5
|
-
import {
|
|
6
|
-
import { completionKeymap } from "../keymap";
|
|
3
|
+
import { completionKeymap as defaultCompletionKeymap } from "@codemirror/autocomplete";
|
|
4
|
+
import { describe, expect, it } from "vitest";
|
|
5
|
+
import { filterCompletionBindings } from "../keymap";
|
|
7
6
|
|
|
8
7
|
describe("completionKeymap", () => {
|
|
9
|
-
it("
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
vi.spyOn(view.state, "field").mockReturnValue("pending");
|
|
17
|
-
|
|
18
|
-
view.dispatch({ changes: [], effects: [], annotations: [] });
|
|
19
|
-
const result = false; // Mock the expected result
|
|
20
|
-
|
|
21
|
-
// Should return false to propagate the Escape key
|
|
22
|
-
expect(result).toBe(false);
|
|
23
|
-
|
|
24
|
-
view.destroy();
|
|
8
|
+
it("upstream includes the macOS-only completion bindings we care about", () => {
|
|
9
|
+
expect(
|
|
10
|
+
defaultCompletionKeymap.some((binding) => binding.mac === "Alt-`"),
|
|
11
|
+
).toBe(true);
|
|
12
|
+
expect(
|
|
13
|
+
defaultCompletionKeymap.some((binding) => binding.mac === "Alt-i"),
|
|
14
|
+
).toBe(true);
|
|
25
15
|
});
|
|
26
16
|
|
|
27
|
-
it("
|
|
28
|
-
const
|
|
29
|
-
extensions: [completionKeymap()],
|
|
30
|
-
});
|
|
31
|
-
const view = new EditorView({ state });
|
|
32
|
-
|
|
33
|
-
// Mock completionStatus to return "active"
|
|
34
|
-
vi.spyOn(view.state, "field").mockReturnValue("active");
|
|
35
|
-
|
|
36
|
-
view.dispatch({ changes: [], effects: [], annotations: [] });
|
|
37
|
-
const result = true; // Mock the expected result
|
|
38
|
-
|
|
39
|
-
// Should return true to stop propagation
|
|
40
|
-
expect(result).toBe(true);
|
|
17
|
+
it("removes Alt-backtick and Escape while keeping Alt-i", () => {
|
|
18
|
+
const filtered = filterCompletionBindings(defaultCompletionKeymap);
|
|
41
19
|
|
|
42
|
-
|
|
20
|
+
expect(filtered.some((binding) => binding.mac === "Alt-`")).toBe(false);
|
|
21
|
+
expect(filtered.some((binding) => binding.key === "Escape")).toBe(false);
|
|
22
|
+
expect(filtered.some((binding) => binding.mac === "Alt-i")).toBe(true);
|
|
43
23
|
});
|
|
44
24
|
});
|
|
@@ -6,7 +6,7 @@ import {
|
|
|
6
6
|
moveCompletionSelection,
|
|
7
7
|
} from "@codemirror/autocomplete";
|
|
8
8
|
import { type Extension, Prec } from "@codemirror/state";
|
|
9
|
-
import { keymap } from "@codemirror/view";
|
|
9
|
+
import { type KeyBinding, keymap } from "@codemirror/view";
|
|
10
10
|
import { isInVimMode } from "../utils";
|
|
11
11
|
|
|
12
12
|
const KEYS_TO_REMOVE = new Set<string | undefined>([
|
|
@@ -22,10 +22,20 @@ const KEYS_TO_REMOVE = new Set<string | undefined>([
|
|
|
22
22
|
"Alt-`",
|
|
23
23
|
]);
|
|
24
24
|
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
25
|
+
function hasRemovedKeybinding(binding: KeyBinding): boolean {
|
|
26
|
+
return [binding.key, binding.mac, binding.linux, binding.win].some((key) =>
|
|
27
|
+
KEYS_TO_REMOVE.has(key),
|
|
28
28
|
);
|
|
29
|
+
}
|
|
30
|
+
|
|
31
|
+
export function filterCompletionBindings(
|
|
32
|
+
bindings: readonly KeyBinding[],
|
|
33
|
+
): readonly KeyBinding[] {
|
|
34
|
+
return bindings.filter((binding) => !hasRemovedKeybinding(binding));
|
|
35
|
+
}
|
|
36
|
+
|
|
37
|
+
export function completionKeymap(): Extension {
|
|
38
|
+
const withoutKeysToRemove = filterCompletionBindings(defaultCompletionKeymap);
|
|
29
39
|
|
|
30
40
|
return Prec.highest(
|
|
31
41
|
keymap.of([
|
|
@@ -3,28 +3,27 @@
|
|
|
3
3
|
import { EditorState } from "@codemirror/state";
|
|
4
4
|
import { EditorView } from "@codemirror/view";
|
|
5
5
|
import { describe, expect, it } from "vitest";
|
|
6
|
+
import { cellId, variableName } from "@/__tests__/branded";
|
|
6
7
|
import { initialNotebookState, notebookAtom } from "@/core/cells/cells";
|
|
7
|
-
import type { CellId } from "@/core/cells/ids";
|
|
8
8
|
import { OverridingHotkeyProvider } from "@/core/hotkeys/hotkeys";
|
|
9
9
|
import { store } from "@/core/state/jotai";
|
|
10
10
|
import { variablesAtom } from "@/core/variables/state";
|
|
11
|
-
import type { VariableName, Variables } from "@/core/variables/types";
|
|
12
11
|
import { MultiColumn } from "@/utils/id-tree";
|
|
13
12
|
import { cellConfigExtension } from "../../config/extension";
|
|
14
13
|
import { adaptiveLanguageConfiguration } from "../../language/extension";
|
|
15
14
|
import { getCodes, getTopologicalCellIds } from "../getCodes";
|
|
16
15
|
|
|
17
16
|
const Cells = {
|
|
18
|
-
cell1: "cell1"
|
|
19
|
-
cell2: "cell2"
|
|
20
|
-
cell3: "cell3"
|
|
21
|
-
cell4: "cell4"
|
|
17
|
+
cell1: cellId("cell1"),
|
|
18
|
+
cell2: cellId("cell2"),
|
|
19
|
+
cell3: cellId("cell3"),
|
|
20
|
+
cell4: cellId("cell4"),
|
|
22
21
|
};
|
|
23
22
|
|
|
24
23
|
const Variables = {
|
|
25
|
-
var1: "var1"
|
|
26
|
-
var2: "var2"
|
|
27
|
-
var3: "var3"
|
|
24
|
+
var1: variableName("var1"),
|
|
25
|
+
var2: variableName("var2"),
|
|
26
|
+
var3: variableName("var3"),
|
|
28
27
|
};
|
|
29
28
|
|
|
30
29
|
function createMockEditorView(code: string) {
|
|
@@ -33,7 +32,7 @@ function createMockEditorView(code: string) {
|
|
|
33
32
|
doc: code,
|
|
34
33
|
extensions: [
|
|
35
34
|
adaptiveLanguageConfiguration({
|
|
36
|
-
cellId: "cell1"
|
|
35
|
+
cellId: cellId("cell1"),
|
|
37
36
|
completionConfig: {
|
|
38
37
|
copilot: false,
|
|
39
38
|
activate_on_typing: true,
|
|
@@ -45,7 +44,7 @@ function createMockEditorView(code: string) {
|
|
|
45
44
|
lspConfig: {},
|
|
46
45
|
}),
|
|
47
46
|
cellConfigExtension({
|
|
48
|
-
cellId: "cell1"
|
|
47
|
+
cellId: cellId("cell1"),
|
|
49
48
|
completionConfig: {
|
|
50
49
|
copilot: false,
|
|
51
50
|
activate_on_typing: true,
|
|
@@ -71,7 +70,7 @@ describe("getTopologicalCellIds", () => {
|
|
|
71
70
|
it("should return topologically sorted cell IDs", () => {
|
|
72
71
|
// Setup mock data
|
|
73
72
|
const cellIds = [Cells.cell1, Cells.cell2, Cells.cell3, Cells.cell4];
|
|
74
|
-
const variables
|
|
73
|
+
const variables = {
|
|
75
74
|
[Variables.var1]: {
|
|
76
75
|
name: Variables.var1,
|
|
77
76
|
declaredBy: [Cells.cell1],
|
|
@@ -125,7 +124,7 @@ describe("getTopologicalCellIds", () => {
|
|
|
125
124
|
|
|
126
125
|
it("should put new cells (with no dependencies) at the end", () => {
|
|
127
126
|
const cellIds = [Cells.cell1, Cells.cell2, Cells.cell3, Cells.cell4];
|
|
128
|
-
const variables
|
|
127
|
+
const variables = {
|
|
129
128
|
[Variables.var1]: {
|
|
130
129
|
name: Variables.var1,
|
|
131
130
|
declaredBy: [Cells.cell2],
|
|
@@ -3,7 +3,7 @@
|
|
|
3
3
|
import { EditorState } from "@codemirror/state";
|
|
4
4
|
import { EditorView } from "@codemirror/view";
|
|
5
5
|
import { describe, expect, it } from "vitest";
|
|
6
|
-
import
|
|
6
|
+
import { cellId } from "@/__tests__/branded";
|
|
7
7
|
import { OverridingHotkeyProvider } from "@/core/hotkeys/hotkeys";
|
|
8
8
|
import { cellConfigExtension } from "../../config/extension";
|
|
9
9
|
import { adaptiveLanguageConfiguration, switchLanguage } from "../extension";
|
|
@@ -26,12 +26,12 @@ function createEditor(doc: string) {
|
|
|
26
26
|
codeium_api_key: null,
|
|
27
27
|
},
|
|
28
28
|
hotkeys: new OverridingHotkeyProvider({}),
|
|
29
|
-
cellId: "cell1"
|
|
29
|
+
cellId: cellId("cell1"),
|
|
30
30
|
placeholderType: "marimo-import",
|
|
31
31
|
lspConfig: {},
|
|
32
32
|
}),
|
|
33
33
|
cellConfigExtension({
|
|
34
|
-
cellId: "cell1"
|
|
34
|
+
cellId: cellId("cell1"),
|
|
35
35
|
completionConfig: {
|
|
36
36
|
activate_on_typing: true,
|
|
37
37
|
signature_hint_on_typing: false,
|
|
@@ -5,10 +5,9 @@ import { python } from "@codemirror/lang-python";
|
|
|
5
5
|
import { EditorState } from "@codemirror/state";
|
|
6
6
|
import type { InlineContext } from "@lezer/markdown";
|
|
7
7
|
import { beforeEach, describe, expect, it } from "vitest";
|
|
8
|
-
import
|
|
8
|
+
import { cellId, variableName } from "@/__tests__/branded";
|
|
9
9
|
import { store } from "@/core/state/jotai";
|
|
10
10
|
import { variablesAtom } from "@/core/variables/state";
|
|
11
|
-
import type { VariableName, Variables } from "@/core/variables/types";
|
|
12
11
|
import { parsePython, variableCompletionSource } from "../embedded-python";
|
|
13
12
|
|
|
14
13
|
const IS_ACTIVE = () => true;
|
|
@@ -51,16 +50,16 @@ describe("parsePython", () => {
|
|
|
51
50
|
|
|
52
51
|
describe("variableCompletionSource", () => {
|
|
53
52
|
beforeEach(() => {
|
|
54
|
-
const mockCellId = "cell-1"
|
|
55
|
-
const mockVariables
|
|
56
|
-
["var1"
|
|
57
|
-
name: "var1"
|
|
53
|
+
const mockCellId = cellId("cell-1");
|
|
54
|
+
const mockVariables = {
|
|
55
|
+
[variableName("var1")]: {
|
|
56
|
+
name: variableName("var1"),
|
|
58
57
|
dataType: "int",
|
|
59
58
|
declaredBy: [mockCellId],
|
|
60
59
|
usedBy: [mockCellId],
|
|
61
60
|
},
|
|
62
|
-
["var2"
|
|
63
|
-
name: "var2"
|
|
61
|
+
[variableName("var2")]: {
|
|
62
|
+
name: variableName("var2"),
|
|
64
63
|
dataType: "str",
|
|
65
64
|
declaredBy: [mockCellId],
|
|
66
65
|
usedBy: [mockCellId],
|
|
@@ -69,6 +69,10 @@ const pylspClient = once((lspConfig: LSPConfig) => {
|
|
|
69
69
|
"W292", // No newline at end of file
|
|
70
70
|
// Modules can be imported in any cell
|
|
71
71
|
"E402", // Module level import not at top of file
|
|
72
|
+
// Blank line rules are not useful in marimo because cells are joined
|
|
73
|
+
// without extra blank lines, which can trigger these rules at cell boundaries
|
|
74
|
+
"E302", // Expected 2 blank lines, found 0
|
|
75
|
+
"E305", // Expected 2 blank lines after class or function definition, found 0
|
|
72
76
|
];
|
|
73
77
|
const ignoredRuffRules = [
|
|
74
78
|
// Even ruff documentation of this rule explains it is not useful in notebooks
|
|
@@ -8,6 +8,7 @@ import {
|
|
|
8
8
|
} from "@marimo-team/codemirror-languageserver";
|
|
9
9
|
import { beforeEach, describe, expect, it, type Mocked, vi } from "vitest";
|
|
10
10
|
import * as LSP from "vscode-languageserver-protocol";
|
|
11
|
+
import { cellId } from "@/__tests__/branded";
|
|
11
12
|
import type { CellId } from "@/core/cells/ids";
|
|
12
13
|
import { store } from "@/core/state/jotai";
|
|
13
14
|
import { topologicalCodesAtom } from "../../copilot/getCodes";
|
|
@@ -19,9 +20,9 @@ import { NotebookLanguageServerClient } from "../notebook-lsp";
|
|
|
19
20
|
import { CellDocumentUri, type ILanguageServerClient } from "../types";
|
|
20
21
|
|
|
21
22
|
const Cells = {
|
|
22
|
-
cell1: "cell1"
|
|
23
|
-
cell2: "cell2"
|
|
24
|
-
cell3: "cell3"
|
|
23
|
+
cell1: cellId("cell1"),
|
|
24
|
+
cell2: cellId("cell2"),
|
|
25
|
+
cell3: cellId("cell3"),
|
|
25
26
|
};
|
|
26
27
|
|
|
27
28
|
describe("createNotebookLens", () => {
|
|
@@ -178,6 +178,8 @@ export class NotebookLanguageServerClient implements ILanguageServerClient {
|
|
|
178
178
|
string,
|
|
179
179
|
Promise<LSP.CompletionItem>
|
|
180
180
|
>(10);
|
|
181
|
+
private latestDiagnosticsVersion: number | null = null;
|
|
182
|
+
private forwardedDiagnosticsVersion = 0;
|
|
181
183
|
|
|
182
184
|
constructor(
|
|
183
185
|
client: ILanguageServerClient,
|
|
@@ -270,6 +272,8 @@ export class NotebookLanguageServerClient implements ILanguageServerClient {
|
|
|
270
272
|
|
|
271
273
|
// Get the current document state
|
|
272
274
|
const { lens, version } = this.snapshotter.snapshot();
|
|
275
|
+
this.latestDiagnosticsVersion = null;
|
|
276
|
+
this.forwardedDiagnosticsVersion = 0;
|
|
273
277
|
|
|
274
278
|
// Re-open the merged document with the LSP server
|
|
275
279
|
// This sends a textDocument/didOpen for the entire notebook
|
|
@@ -768,13 +772,34 @@ export class NotebookLanguageServerClient implements ILanguageServerClient {
|
|
|
768
772
|
| { method: "other"; params: unknown },
|
|
769
773
|
) => {
|
|
770
774
|
if (notification.method === "textDocument/publishDiagnostics") {
|
|
775
|
+
const incomingVersion = notification.params.version;
|
|
776
|
+
if (incomingVersion != null) {
|
|
777
|
+
const latestVersion = this.latestDiagnosticsVersion;
|
|
778
|
+
if (
|
|
779
|
+
latestVersion !== null &&
|
|
780
|
+
Number.isFinite(incomingVersion) &&
|
|
781
|
+
incomingVersion < latestVersion
|
|
782
|
+
) {
|
|
783
|
+
Logger.debug(
|
|
784
|
+
"[lsp] dropping stale diagnostics notification",
|
|
785
|
+
notification,
|
|
786
|
+
);
|
|
787
|
+
return;
|
|
788
|
+
}
|
|
789
|
+
this.latestDiagnosticsVersion = incomingVersion;
|
|
790
|
+
}
|
|
791
|
+
|
|
771
792
|
Logger.debug("[lsp] handling diagnostics", notification);
|
|
772
793
|
// Use the correct lens by version
|
|
773
794
|
const payload = this.snapshotter.getLatestSnapshot();
|
|
774
795
|
|
|
775
796
|
const diagnostics = notification.params.diagnostics;
|
|
776
797
|
|
|
777
|
-
const { lens
|
|
798
|
+
const { lens } = payload;
|
|
799
|
+
// Forward diagnostics with a strictly increasing version so downstream
|
|
800
|
+
// plugin updates/clears reliably, even when server repeats the same
|
|
801
|
+
// document version across multiple publishDiagnostics notifications.
|
|
802
|
+
const diagnosticsVersion = ++this.forwardedDiagnosticsVersion;
|
|
778
803
|
|
|
779
804
|
// Pre-partition diagnostics by cell
|
|
780
805
|
const diagnosticsByCellId = new Map<CellId, LSP.Diagnostic[]>();
|
|
@@ -817,7 +842,7 @@ export class NotebookLanguageServerClient implements ILanguageServerClient {
|
|
|
817
842
|
params: {
|
|
818
843
|
...notification.params,
|
|
819
844
|
uri: cellDocumentUri,
|
|
820
|
-
version:
|
|
845
|
+
version: diagnosticsVersion,
|
|
821
846
|
diagnostics: cellDiagnostics,
|
|
822
847
|
},
|
|
823
848
|
});
|
|
@@ -832,6 +857,7 @@ export class NotebookLanguageServerClient implements ILanguageServerClient {
|
|
|
832
857
|
method: "textDocument/publishDiagnostics",
|
|
833
858
|
params: {
|
|
834
859
|
uri: cellDocumentUri,
|
|
860
|
+
version: diagnosticsVersion,
|
|
835
861
|
diagnostics: [],
|
|
836
862
|
},
|
|
837
863
|
});
|
|
@@ -3,8 +3,8 @@
|
|
|
3
3
|
import { python } from "@codemirror/lang-python";
|
|
4
4
|
import { EditorState } from "@codemirror/state";
|
|
5
5
|
import { describe, expect, test } from "vitest";
|
|
6
|
-
import
|
|
7
|
-
import type {
|
|
6
|
+
import { cellId, variableName } from "@/__tests__/branded";
|
|
7
|
+
import type { Variables } from "@/core/variables/types";
|
|
8
8
|
import { findReactiveVariables, type ReactiveVariableRange } from "../analyzer";
|
|
9
9
|
|
|
10
10
|
describe("findReactiveVariables - Lexical Scoping", () => {
|
|
@@ -1199,16 +1199,17 @@ class Foo:
|
|
|
1199
1199
|
function runHighlight(variableNames: string[], code: string): string {
|
|
1200
1200
|
const variables: Variables = {};
|
|
1201
1201
|
for (const name of variableNames) {
|
|
1202
|
-
|
|
1203
|
-
|
|
1204
|
-
|
|
1202
|
+
const varName = variableName(name);
|
|
1203
|
+
variables[varName] = {
|
|
1204
|
+
name: varName,
|
|
1205
|
+
declaredBy: [cellId("other-cell")],
|
|
1205
1206
|
usedBy: [],
|
|
1206
1207
|
value: "test-value",
|
|
1207
1208
|
dataType: "str",
|
|
1208
1209
|
};
|
|
1209
1210
|
}
|
|
1210
1211
|
const ranges = findReactiveVariables({
|
|
1211
|
-
cellId: "current-cell"
|
|
1212
|
+
cellId: cellId("current-cell"),
|
|
1212
1213
|
state: EditorState.create({
|
|
1213
1214
|
doc: code,
|
|
1214
1215
|
extensions: [python()],
|
|
@@ -3,7 +3,7 @@
|
|
|
3
3
|
import { syntaxTree } from "@codemirror/language";
|
|
4
4
|
import type { EditorState } from "@codemirror/state";
|
|
5
5
|
import type { SyntaxNode, Tree, TreeCursor } from "@lezer/common";
|
|
6
|
-
import type
|
|
6
|
+
import { type CellId, SETUP_CELL_ID } from "@/core/cells/ids";
|
|
7
7
|
import type { VariableName, Variables } from "@/core/variables/types";
|
|
8
8
|
|
|
9
9
|
export interface ReactiveVariableRange {
|
|
@@ -52,7 +52,7 @@ export function findReactiveVariables(options: {
|
|
|
52
52
|
const variable = options.variables[name as VariableName];
|
|
53
53
|
return (
|
|
54
54
|
variable.dataType !== "module" &&
|
|
55
|
-
!variable.declaredBy.includes(
|
|
55
|
+
!variable.declaredBy.includes(SETUP_CELL_ID) &&
|
|
56
56
|
!variable.declaredBy.includes(options.cellId)
|
|
57
57
|
);
|
|
58
58
|
}),
|
|
@@ -0,0 +1,52 @@
|
|
|
1
|
+
/* Copyright 2026 Marimo. All rights reserved. */
|
|
2
|
+
|
|
3
|
+
import { EditorState } from "@codemirror/state";
|
|
4
|
+
import type { EditorView } from "@codemirror/view";
|
|
5
|
+
import { LoroDoc, LoroText } from "loro-crdt";
|
|
6
|
+
import { describe, expect, it, vi } from "vitest";
|
|
7
|
+
import { LoroSyncPluginValue, loroSyncAnnotation } from "../sync";
|
|
8
|
+
|
|
9
|
+
describe("LoroSyncPluginValue", () => {
|
|
10
|
+
it("annotates the initial reconciliation dispatch as RTC sync", async () => {
|
|
11
|
+
const dispatch = vi.fn();
|
|
12
|
+
const view = {
|
|
13
|
+
state: EditorState.create({ doc: "local" }),
|
|
14
|
+
dispatch,
|
|
15
|
+
} as unknown as EditorView;
|
|
16
|
+
|
|
17
|
+
const doc = new LoroDoc();
|
|
18
|
+
const text = doc
|
|
19
|
+
.getMap("codes")
|
|
20
|
+
.getOrCreateContainer("cell-1", new LoroText());
|
|
21
|
+
text.insert(0, "remote");
|
|
22
|
+
|
|
23
|
+
const plugin = new LoroSyncPluginValue(
|
|
24
|
+
view,
|
|
25
|
+
doc,
|
|
26
|
+
["codes", "cell-1"],
|
|
27
|
+
() => text,
|
|
28
|
+
);
|
|
29
|
+
|
|
30
|
+
await Promise.resolve();
|
|
31
|
+
|
|
32
|
+
expect(dispatch).toHaveBeenCalledTimes(1);
|
|
33
|
+
expect(dispatch).toHaveBeenCalledWith(
|
|
34
|
+
expect.objectContaining({
|
|
35
|
+
changes: [
|
|
36
|
+
{
|
|
37
|
+
from: 0,
|
|
38
|
+
to: view.state.doc.length,
|
|
39
|
+
insert: "remote",
|
|
40
|
+
},
|
|
41
|
+
],
|
|
42
|
+
annotations: [
|
|
43
|
+
expect.objectContaining({
|
|
44
|
+
type: loroSyncAnnotation,
|
|
45
|
+
}),
|
|
46
|
+
],
|
|
47
|
+
}),
|
|
48
|
+
);
|
|
49
|
+
|
|
50
|
+
plugin.destroy();
|
|
51
|
+
});
|
|
52
|
+
});
|
|
@@ -1,5 +1,6 @@
|
|
|
1
1
|
/* Copyright 2026 Marimo. All rights reserved. */
|
|
2
2
|
import { beforeEach, describe, expect, it } from "vitest";
|
|
3
|
+
import { variableName } from "@/__tests__/branded";
|
|
3
4
|
import type { DataTable } from "@/core/kernel/messages";
|
|
4
5
|
import type { VariableName } from "@/core/variables/types";
|
|
5
6
|
import {
|
|
@@ -182,7 +183,7 @@ describe("filtering data sources", () => {
|
|
|
182
183
|
});
|
|
183
184
|
|
|
184
185
|
it("keeps matching variables and internal engines", () => {
|
|
185
|
-
const filtered = filterDataSources(["conn1"
|
|
186
|
+
const filtered = filterDataSources([variableName("conn1")]);
|
|
186
187
|
expect(filtered.connectionsMap.size).toBe(defaultConnSize + 1);
|
|
187
188
|
expect(filtered.connectionsMap.has("conn1" as ConnectionName)).toBe(true);
|
|
188
189
|
for (const engine of INTERNAL_SQL_ENGINES) {
|
|
@@ -191,16 +192,14 @@ describe("filtering data sources", () => {
|
|
|
191
192
|
});
|
|
192
193
|
|
|
193
194
|
it("filters out non-matching variables", () => {
|
|
194
|
-
const filtered = filterDataSources([
|
|
195
|
-
"non_existent" as unknown as VariableName,
|
|
196
|
-
]);
|
|
195
|
+
const filtered = filterDataSources([variableName("non_existent")]);
|
|
197
196
|
expect(filtered.connectionsMap.size).toBe(defaultConnSize);
|
|
198
197
|
});
|
|
199
198
|
|
|
200
199
|
it("handles mix of matching and non-matching variables", () => {
|
|
201
200
|
const filtered = filterDataSources([
|
|
202
|
-
"conn1"
|
|
203
|
-
"non_existent"
|
|
201
|
+
variableName("conn1"),
|
|
202
|
+
variableName("non_existent"),
|
|
204
203
|
]);
|
|
205
204
|
expect(filtered.connectionsMap.size).toBe(defaultConnSize + 1);
|
|
206
205
|
expect(filtered.connectionsMap.has("conn1" as ConnectionName)).toBe(true);
|
|
@@ -1,5 +1,6 @@
|
|
|
1
1
|
/* Copyright 2026 Marimo. All rights reserved. */
|
|
2
2
|
import { describe, expect, it } from "vitest";
|
|
3
|
+
import { cellId } from "@/__tests__/branded";
|
|
3
4
|
import type { MarimoError } from "@/core/kernel/messages";
|
|
4
5
|
import { getAutoFixes, getImportCode } from "../errors";
|
|
5
6
|
|
|
@@ -25,7 +26,7 @@ describe("getAutoFixes", () => {
|
|
|
25
26
|
const error: MarimoError = {
|
|
26
27
|
type: "multiple-defs",
|
|
27
28
|
name: "foo",
|
|
28
|
-
cells: ["foo"],
|
|
29
|
+
cells: [cellId("foo")],
|
|
29
30
|
};
|
|
30
31
|
|
|
31
32
|
const fixes = getAutoFixes(error, opts);
|