@marimo-team/frontend 0.23.10-dev3 → 0.23.10-dev31
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-D_RReCKN.js → CellStatus-BKK6G_iZ.js} +1 -1
- package/dist/assets/{ConnectedDataExplorerComponent-W0UfNkj7.js → ConnectedDataExplorerComponent-Vdy8K3hf.js} +1 -1
- package/dist/assets/{ImperativeModal-B3Th7k4R.js → ImperativeModal-CDPfRIx5.js} +1 -1
- package/dist/assets/JsonOutput-Bg1SpAZP.js +53 -0
- package/dist/assets/LazyAnyLanguageCodeMirror-DClDnO_2.js +2 -0
- package/dist/assets/{MarimoErrorOutput-HYZo17DD.js → MarimoErrorOutput-BQyzDTet.js} +1 -1
- package/dist/assets/{RSPContexts-CdN1NyAt.js → RSPContexts-QoVyPvhN.js} +1 -1
- package/dist/assets/{RenderHTML-B_YU1hMw.js → RenderHTML-B5i6Qdbh.js} +1 -1
- package/dist/assets/RunButton-ACHY83op.js +1 -0
- package/dist/assets/__vite-browser-external-CeH7R2Sf.js +1 -0
- package/dist/assets/__vite-browser-external-DTK_qJHK.js +1 -0
- package/dist/assets/{add-cell-with-ai-QmkSVxE_.js → add-cell-with-ai-Bt1jO2nX.js} +12 -12
- package/dist/assets/{add-connection-dialog-C_d6NoB6.js → add-connection-dialog-D0x71Nfb.js} +1 -1
- package/dist/assets/{agent-panel-Dq-14MP2.js → agent-panel-hQYUxnQ5.js} +1 -1
- package/dist/assets/{ai-model-dropdown-BZsz2gBj.js → ai-model-dropdown-BEPeAxTW.js} +1 -1
- package/dist/assets/{alert-dialog-BqFLkbUc.js → alert-dialog-5BGIfskO.js} +2 -2
- package/dist/assets/{any-language-editor-CXeLf_N8.js → any-language-editor-4KTAtjWB.js} +1 -1
- package/dist/assets/apl-DpOiWl6J.js +1 -0
- package/dist/assets/{app-config-button-DrjQAYDI.js → app-config-button-BeBbgBbf.js} +1 -1
- package/dist/assets/{arc-CWuN1tfc.js → arc-xh3ZebK_.js} +1 -1
- package/dist/assets/{architecture-7HQA4BMR-DJtUfdk-.js → architecture-7HQA4BMR-CtZSskKa.js} +1 -1
- package/dist/assets/{architectureDiagram-VXUJARFQ-Cgi4wo9P.js → architectureDiagram-VXUJARFQ-BOj65Cij.js} +1 -1
- package/dist/assets/asciiarmor-DVIuYySe.js +1 -0
- package/dist/assets/asn1-CWHjZJq6.js +1 -0
- package/dist/assets/{blockDiagram-VD42YOAC-CsHap8-F.js → blockDiagram-VD42YOAC-C1dCrclf.js} +1 -1
- package/dist/assets/brainfuck-CIKJewgG.js +1 -0
- package/dist/assets/{c4Diagram-YG6GDRKO-CZuArudM.js → c4Diagram-YG6GDRKO-i2yUrWYM.js} +1 -1
- package/dist/assets/{cache-panel-DYiVMv5x.js → cache-panel-Cs308ish.js} +1 -1
- package/dist/assets/{cell-editor-BnxVODbx.js → cell-editor-Brq_fn75.js} +12 -12
- package/dist/assets/{cell-link-Gwsf-bMV.js → cell-link-BFEa98Sc.js} +1 -1
- package/dist/assets/{cells-BRMYB7Wo.js → cells-k7Js5h2t.js} +68 -66
- package/dist/assets/cells-pu5xzE_v.css +2 -0
- package/dist/assets/channel-C8k5aAg8.js +1 -0
- package/dist/assets/{chat-display-DG6DhHcQ.js → chat-display-Umskg52b.js} +1 -1
- package/dist/assets/{chat-panel-BvrrOl8J.js → chat-panel-BEpdLxDR.js} +1 -1
- package/dist/assets/{chat-ui-g5FqhPv-.js → chat-ui-qtgqHWnk.js} +1 -1
- package/dist/assets/{chunk-4BX2VUAB-Ca6WzYTr.js → chunk-4BX2VUAB-CHtIUBVX.js} +1 -1
- package/dist/assets/chunk-55IACEB6-DJtiFmZI.js +1 -0
- package/dist/assets/{chunk-5FQGJX7Z-D9iBG0F7.js → chunk-5FQGJX7Z-Bp9g5nD2.js} +2 -2
- package/dist/assets/{chunk-ABZYJK2D-BG7Eb4WW.js → chunk-ABZYJK2D-CW6LcQEi.js} +3 -3
- package/dist/assets/{chunk-ATLVNIR6-CqLn9HI1.js → chunk-ATLVNIR6-CaXl_ZVt.js} +1 -1
- package/dist/assets/{chunk-B4BG7PRW-D4SyZNjn.js → chunk-B4BG7PRW-Dkcioyxv.js} +1 -1
- package/dist/assets/{chunk-CVBHYZKI-C-NWvPQL.js → chunk-CVBHYZKI-Cx6_q0Bq.js} +1 -1
- package/dist/assets/{chunk-DI55MBZ5-t9uiMPiN.js → chunk-DI55MBZ5-CpmNjAbj.js} +1 -1
- package/dist/assets/{chunk-EXTU4WIE-BmVk7Fyq.js → chunk-EXTU4WIE-BfQ60QJd.js} +1 -1
- package/dist/assets/{chunk-FMBD7UC4-DlnzxSkO.js → chunk-FMBD7UC4-Dzk6L3_z.js} +1 -1
- package/dist/assets/{chunk-HN2XXSSU-Bcaj5fRB.js → chunk-HN2XXSSU-DKAgaU5O.js} +1 -1
- package/dist/assets/{chunk-JA3XYJ7Z-B5b2QHOb.js → chunk-JA3XYJ7Z-Cx9lJRz-.js} +1 -1
- package/dist/assets/{chunk-JZLCHNYA-1_sVfAnw.js → chunk-JZLCHNYA-LdSYK6Ej.js} +1 -1
- package/dist/assets/{chunk-MI3HLSF2-DqzZqBCh.js → chunk-MI3HLSF2-AJRVV4NE.js} +1 -1
- package/dist/assets/{chunk-N4CR4FBY-CFJoD-EQ.js → chunk-N4CR4FBY-DM96YL3R.js} +2 -2
- package/dist/assets/{chunk-QN33PNHL-BBE_bx9E.js → chunk-QN33PNHL-4cZDuwgu.js} +1 -1
- package/dist/assets/{chunk-QXUST7PY-Cu1nR-L2.js → chunk-QXUST7PY-Di5YbBao.js} +1 -1
- package/dist/assets/{chunk-QZHKN3VN-BAnb9AKF.js → chunk-QZHKN3VN-B2hZ4g68.js} +1 -1
- package/dist/assets/{chunk-S3R3BYOJ-Cl0iW04v.js → chunk-S3R3BYOJ-BAKX3hoQ.js} +1 -1
- package/dist/assets/{chunk-TZMSLE5B-f5ix6iSd.js → chunk-TZMSLE5B-BFdV9a1D.js} +1 -1
- package/dist/assets/classDiagram-2ON5EDUG-CFISa78E.js +1 -0
- package/dist/assets/classDiagram-v2-WZHVMYZB-BzMNKvre.js +1 -0
- package/dist/assets/{clike-bdcjLdZ4.js → clike-wo4CVrJj.js} +1 -1
- package/dist/assets/clojure-CTxjMkBI.js +1 -0
- package/dist/assets/cmake-aJ0aGjat.js +1 -0
- package/dist/assets/cobol-Dw9T4cw-.js +1 -0
- package/dist/assets/{code-block-37QAKDTI-B19XL3UR.js → code-block-37QAKDTI-Cj7FoIhl.js} +1 -1
- package/dist/assets/coffeescript-B5HCKl_0.js +1 -0
- package/dist/assets/column-preview-CibBmCB_.js +1 -0
- package/dist/assets/{command-KARR7KMq.js → command-BkXWJLBP.js} +1 -1
- package/dist/assets/{command-palette-NK5d8oXe.js → command-palette-DLeYFxOX.js} +1 -1
- package/dist/assets/{common-uMN7vCPi.js → common-C9lH0PD9.js} +1 -1
- package/dist/assets/commonlisp-C578hhl1.js +1 -0
- package/dist/assets/{components-C6xgQdpy.js → components-CXG-2UWv.js} +1 -1
- package/dist/assets/{copy-icon-OjtDb4gO.js → copy-icon-BuRdHNPA.js} +1 -1
- package/dist/assets/{cose-bilkent-S5V4N54A-CQqSLzd1.js → cose-bilkent-S5V4N54A-DsnN-_2o.js} +1 -1
- package/dist/assets/crystal-D84c1nzD.js +1 -0
- package/dist/assets/{css-ACAb8MRM.js → css-BJsW3aHa.js} +1 -1
- package/dist/assets/cypher-DBO3MHmN.js +1 -0
- package/dist/assets/d-KvHiAR3H.js +1 -0
- package/dist/assets/{dagre-6UL2VRFP-CVKXpDlr.js → dagre-6UL2VRFP-CHMBr-on.js} +1 -1
- package/dist/assets/{data-grid-overlay-editor-BdDYn72O.js → data-grid-overlay-editor-orng_e3E.js} +1 -1
- package/dist/assets/{datasource-CHSjxFZg.js → datasource-mov7mYsn.js} +1 -1
- package/dist/assets/dependency-graph-panel-DCUqRSKS.js +5 -0
- package/dist/assets/{diagram-PSM6KHXK-BfzLNKp-.js → diagram-PSM6KHXK-BAkhyJz0.js} +1 -1
- package/dist/assets/{diagram-QEK2KX5R-D_H77Ni5.js → diagram-QEK2KX5R-OUubZf2n.js} +1 -1
- package/dist/assets/{diagram-S2PKOQOG-DJmVBeMk.js → diagram-S2PKOQOG-CGIZL2qm.js} +1 -1
- package/dist/assets/{dialog-DzC_QCtT.js → dialog-DRnNAWYl.js} +1 -1
- package/dist/assets/diff-BmUpKGx-.js +1 -0
- package/dist/assets/dist-0sLFAEuj.js +1 -0
- package/dist/assets/dist-2FedModH.js +7 -0
- package/dist/assets/{dist-CNyMUs19.js → dist-2TkSwR77.js} +1 -1
- package/dist/assets/dist-AQEMgdxp.js +1 -0
- package/dist/assets/dist-B65RnwM5.js +1 -0
- package/dist/assets/dist-BURue7-e.js +3 -0
- package/dist/assets/{dist-A7swzSTR.js → dist-BXcZeTeA.js} +1 -1
- package/dist/assets/dist-BXeHg5NQ.js +1 -0
- package/dist/assets/{dist-DqVEVg0c.js → dist-BcvGVYKl.js} +1 -1
- package/dist/assets/dist-BdKlcwR7.js +1 -0
- package/dist/assets/{dist-CsvFAFh9.js → dist-BieDRQs9.js} +1 -1
- package/dist/assets/{dist-HlsDto3K.js → dist-Bo13cFwO.js} +1 -1
- package/dist/assets/dist-Bqr3AzD8.js +1 -0
- package/dist/assets/{dist-C78V1LRz.js → dist-BscEQwf7.js} +1 -1
- package/dist/assets/{dist-CpTFpfm_.js → dist-BwnT-_gD.js} +1 -1
- package/dist/assets/dist-BznMRbTz.js +1 -0
- package/dist/assets/dist-C5PcfT25.js +1 -0
- package/dist/assets/{dist-BdyjRhEt.js → dist-CWMKC7yO.js} +1 -1
- package/dist/assets/dist-CZ5EKIth.js +1 -0
- package/dist/assets/{dist-CJIOLS6O.js → dist-CbwsxTDg.js} +1 -1
- package/dist/assets/dist-CdtVwSQt.js +1 -0
- package/dist/assets/{dist-Dr8mWwQ_.js → dist-ChrXdgjb.js} +1 -1
- package/dist/assets/{dist-CqEym3Sr.js → dist-CvuhNTbr.js} +1 -1
- package/dist/assets/{dist-CKT_lJKW.js → dist-CycP1Cdf.js} +1 -1
- package/dist/assets/{dist-BrR4M-k3.js → dist-D0HyMpgV.js} +12 -11
- package/dist/assets/{dist-CciFN1z_.js → dist-D2g-G0wk.js} +1 -1
- package/dist/assets/dist-D3lJti6y.js +1 -0
- package/dist/assets/dist-DBklo-uX.js +1 -0
- package/dist/assets/{dist-DUHHizRG.js → dist-DCzr8T5W.js} +1 -1
- package/dist/assets/{dist-BlOtCkpT.js → dist-DU8NrdIh.js} +1 -1
- package/dist/assets/dist-DUDjfnME.js +1 -0
- package/dist/assets/dist-DVkC-Qmw.js +2 -0
- package/dist/assets/{dist-CocyeH0q.js → dist-DgGMawx8.js} +1 -1
- package/dist/assets/dist-Dq1Qheae.js +1 -0
- package/dist/assets/{dist-D70Tz1Kr.js → dist-DxlQcmyw.js} +1 -1
- package/dist/assets/dist-GiCZ_RyY.js +1 -0
- package/dist/assets/{dist-CBSMxaO_.js → dist-HyCgERnW.js} +4 -4
- package/dist/assets/{dist-CpcTHxTt.js → dist-Otadb4Hb.js} +1 -1
- package/dist/assets/dist-PCikvPoP.js +1 -0
- package/dist/assets/{dist-4ni0fia5.js → dist-PHrL7abE.js} +3 -3
- package/dist/assets/{dist-BQeNY9Zl.js → dist-QqcJxlfK.js} +1 -1
- package/dist/assets/dist-RMRSa-Mj.js +13 -0
- package/dist/assets/dist-RnuaWZoB.js +1 -0
- package/dist/assets/{dist-C9ZB41s2.js → dist-YEXtMjTi.js} +2 -2
- package/dist/assets/dist-deBZx53p.js +1 -0
- package/dist/assets/{dist-BF6UNR6V.js → dist-flL-WW8v.js} +1 -1
- package/dist/assets/dist-rBRbke5D.js +1 -0
- package/dist/assets/{dockerfile-BSMbgQQl.js → dockerfile-DQFWVVcg.js} +1 -1
- package/dist/assets/{documentation-panel-6ZJIjjrY.js → documentation-panel-CQ8pDf0n.js} +1 -1
- package/dist/assets/download-GddKDXL8.js +9 -0
- package/dist/assets/{dropdown-menu-CR7cnzLX.js → dropdown-menu-CZ4XbE-c.js} +1 -1
- package/dist/assets/dtd-Dwf-AbUl.js +1 -0
- package/dist/assets/dylan-VHUB-7ez.js +1 -0
- package/dist/assets/ecl-DvGrObaA.js +1 -0
- package/dist/assets/edit-page-BgX4RqUv.js +9 -0
- package/dist/assets/eiffel-CUYga93e.js +1 -0
- package/dist/assets/elm-BhMhmEP6.js +1 -0
- package/dist/assets/{erDiagram-Q2GNP2WA-ROTNwSJz.js → erDiagram-Q2GNP2WA-Da5CNIuT.js} +1 -1
- package/dist/assets/erlang-D4xbdJFD.js +1 -0
- package/dist/assets/{error-banner-LdWZDbqd.js → error-banner-DWuez3Jq.js} +1 -1
- package/dist/assets/{error-panel-BAL4mIVv.js → error-panel-lbt2yT6e.js} +1 -1
- package/dist/assets/{es-DGgq-Wes.js → es-By9LYOsD.js} +1 -1
- package/dist/assets/{esm-DeiyaVAJ.js → esm-DgI-7XOj.js} +1 -1
- package/dist/assets/esm-xaw4Vy8N.js +1 -0
- package/dist/assets/eye-off-Cm6DdkeR.js +1 -0
- package/dist/assets/factor-C0grrWrC.js +1 -0
- package/dist/assets/{factor-C-_cRSDM.js → factor-Ccw_GUUV.js} +1 -1
- package/dist/assets/{field-zLmMOSA4.js → field-BWxnw0_c.js} +1 -1
- package/dist/assets/file-explorer-panel-B80nuHmZ.js +26 -0
- package/dist/assets/{file-icons-CNegz5Wt.js → file-icons-on-PIYta.js} +1 -1
- package/dist/assets/{file-name-input-BNHbCr1E.js → file-name-input-5TJN9FVv.js} +3 -3
- package/dist/assets/{fileToBase64-DZfwJMrG.js → fileToBase64-D15LPv1Y.js} +1 -1
- package/dist/assets/{floating-outline-C_E8vH7G.js → floating-outline-CCH9y0X9.js} +1 -1
- package/dist/assets/{flowDiagram-NV44I4VS--ee3IIVF.js → flowDiagram-NV44I4VS-BxZczAJ3.js} +1 -1
- package/dist/assets/{focus-B2t0WTxH.js → focus-CRI5ilWC.js} +1 -1
- package/dist/assets/{form-BnFjtYoC.js → form-BUnTfUo-.js} +2 -2
- package/dist/assets/forth-CSTdXn4A.js +1 -0
- package/dist/assets/fortran-fENQO2l9.js +1 -0
- package/dist/assets/{fullscreen-eipL3i3Y.js → fullscreen-DFky0PAA.js} +3 -3
- package/dist/assets/{gallery-page-Bcf7fYLy.js → gallery-page-ClMvrHMz.js} +1 -1
- package/dist/assets/{ganttDiagram-JELNMOA3-BGhmW2aP.js → ganttDiagram-JELNMOA3-D6lhmAdR.js} +1 -1
- package/dist/assets/gas-CPJMP4zj.js +1 -0
- package/dist/assets/gherkin-CiUmN4EE.js +1 -0
- package/dist/assets/{gitGraph-G5XIXVHT-DuJ_0c_E.js → gitGraph-G5XIXVHT-Du3ykVxi.js} +1 -1
- package/dist/assets/{gitGraphDiagram-V2S2FVAM-DXFCZcxr.js → gitGraphDiagram-V2S2FVAM-Cn2X9uyf.js} +1 -1
- package/dist/assets/{glide-data-editor-DqKNgyfg.js → glide-data-editor-C_ammsJR.js} +4 -4
- package/dist/assets/{globals-7JnRMGd4.js → globals-BivClSmn.js} +1 -1
- package/dist/assets/groovy-DMooZA1X.js +1 -0
- package/dist/assets/haskell-sDlThg6u.js +1 -0
- package/dist/assets/haxe-Do80ITri.js +1 -0
- package/dist/assets/home-page-a0C5a4iJ.js +4 -0
- package/dist/assets/{hooks-DTSuaBec.js → hooks-C153jvoU.js} +1 -1
- package/dist/assets/{html-to-image-GGmvROsd.js → html-to-image-rLeQGF-G.js} +1 -1
- package/dist/assets/idl-DFPg6k4F.js +1 -0
- package/dist/assets/index-Ct3LgsQ8.css +2 -0
- package/dist/assets/index-CyOq1SNo.js +38 -0
- package/dist/assets/{info-VBDWY6EO-DPQEAe2T.js → info-VBDWY6EO-DfrFT_jr.js} +1 -1
- package/dist/assets/infoDiagram-HS3SLOUP-DkUueEWV.js +2 -0
- package/dist/assets/{input-C3Hrdlqq.js → input-DckzEovC.js} +1 -1
- package/dist/assets/javascript-BGc4iHiT.js +1 -0
- package/dist/assets/{journeyDiagram-XKPGCS4Q-9D2JCyrN.js → journeyDiagram-XKPGCS4Q-D_8hf_60.js} +1 -1
- package/dist/assets/julia-BHNHVraD.js +1 -0
- package/dist/assets/{kanban-definition-3W4ZIXB7-DxV26rf-.js → kanban-definition-3W4ZIXB7-DLnwfoGw.js} +1 -1
- package/dist/assets/katex-Bty7Bcil.js +1 -0
- package/dist/assets/{kiosk-mode-Di1lkQq9.js → kiosk-mode-DhNcHA04.js} +1 -1
- package/dist/assets/{label-xHqFtfdz.js → label-C2_YQRio.js} +1 -1
- package/dist/assets/layout-C_EG2AcB.js +9 -0
- package/dist/assets/{line-x4bpd_8D.js → line-VKarCWVL.js} +1 -1
- package/dist/assets/{linear-CW_ww8od.js → linear-BrLBJGJq.js} +1 -1
- package/dist/assets/livescript-Bv2FpOTI.js +1 -0
- package/dist/assets/{logs-panel-CaW-dsNY.js → logs-panel-c4pWZhi-.js} +1 -1
- package/dist/assets/{loro_wasm_bg-CtNTubKN.js → loro_wasm_bg-Drxc4adW.js} +1 -1
- package/dist/assets/lua-BysKHKPZ.js +1 -0
- package/dist/assets/{markdown-renderer-CHlWY8PG.js → markdown-renderer-BFAnsPek.js} +3 -3
- package/dist/assets/mathematica-BBTHoTvM.js +1 -0
- package/dist/assets/mbox-DeT9_lvk.js +1 -0
- package/dist/assets/{menu-items-DcP01QzW.js → menu-items-BP7Ju9ww.js} +1 -1
- package/dist/assets/mermaid-4DMBBIKO-Otg-raA6.js +1 -0
- package/dist/assets/{mermaid-Bes0ynI8.js → mermaid-a0JtkT4R.js} +3 -3
- package/dist/assets/{mermaid-parser.core-aYU6qXxk.js → mermaid-parser.core-B73Gp-Wo.js} +2 -2
- package/dist/assets/{mhchem-8N2oE3tb.js → mhchem-LBCEVJFr.js} +1 -1
- package/dist/assets/{mindmap-definition-VGOIOE7T-DTJAbAQ8.js → mindmap-definition-VGOIOE7T-DO_Zb7LC.js} +1 -1
- package/dist/assets/mirc-D5fMSrXQ.js +1 -0
- package/dist/assets/mllike-BtxCpmpf.js +1 -0
- package/dist/assets/modelica-CRQcZpK6.js +1 -0
- package/dist/assets/mscgen-BfscU11q.js +1 -0
- package/dist/assets/multi-map-C4OANz8X.js +1 -0
- package/dist/assets/mumps-g7ooySbl.js +1 -0
- package/dist/assets/{name-cell-input-DUOo0eNf.js → name-cell-input-mVvyyh5P.js} +1 -1
- package/dist/assets/nsis-BtyCmCHZ.js +1 -0
- package/dist/assets/{nsis-BGZ5EB-j.js → nsis-CzZqoCdu.js} +1 -1
- package/dist/assets/ntriples-DLyxF-NO.js +1 -0
- package/dist/assets/{number-overlay-editor-DL4IwqDH.js → number-overlay-editor-DyhbXrfU.js} +1 -1
- package/dist/assets/octave-CFXP_zzr.js +1 -0
- package/dist/assets/{ordinal-_nQ2r1qQ.js → ordinal-DgI3JO68.js} +1 -1
- package/dist/assets/{outline-panel-BOHhothv.js → outline-panel-DdPSzT5z.js} +1 -1
- package/dist/assets/oz-CrQbC0N_.js +1 -0
- package/dist/assets/{packages-panel-4nEohRPp.js → packages-panel-C4tFa1Sc.js} +1 -1
- package/dist/assets/{packet-DYOGHKS2-CxgeJpvT.js → packet-DYOGHKS2-DoIJcGk-.js} +1 -1
- package/dist/assets/{pair-with-agent-modal-1tufe5MP.js → pair-with-agent-modal-_SlYEcmZ.js} +1 -1
- package/dist/assets/{panels-BAdoiY2Y.js → panels-CAd4fjM2.js} +1 -1
- package/dist/assets/pascal-CCSZgYZH.js +1 -0
- package/dist/assets/perl-Bc1MycMl.js +1 -0
- package/dist/assets/{pie-VRWISCQL-GZ13ReaG.js → pie-VRWISCQL-DYulZZ0A.js} +1 -1
- package/dist/assets/{pieDiagram-ADFJNKIX-_3l2XiEo.js → pieDiagram-ADFJNKIX-Dxph8su5.js} +1 -1
- package/dist/assets/pig-CDr04RdE.js +1 -0
- package/dist/assets/{popover-Bz_0Vkyf.js → popover-CNCYAwbC.js} +1 -1
- package/dist/assets/powershell-DcvrUwmh.js +1 -0
- package/dist/assets/{process-output-ClRYUndH.js → process-output-CRgRzt0h.js} +1 -1
- package/dist/assets/properties-Y8OgFJMt.js +1 -0
- package/dist/assets/protobuf-Dyx-ENis.js +1 -0
- package/dist/assets/{pug-CYW0agOo.js → pug-BqLMXh-D.js} +1 -1
- package/dist/assets/pug-T7qjkmFh.js +1 -0
- package/dist/assets/puppet-BzYSg90u.js +1 -0
- package/dist/assets/python-D4S7tVrv.js +1 -0
- package/dist/assets/q-YpqabiSl.js +1 -0
- package/dist/assets/{quadrantDiagram-AYHSOK5B-CX3AMAvR.js → quadrantDiagram-AYHSOK5B-OK6c_k6c.js} +1 -1
- package/dist/assets/r-DzpuVbmQ.js +1 -0
- package/dist/assets/{radar-ZZBFDIW7-CbAjwmA0.js → radar-ZZBFDIW7-DsPiq6Fm.js} +1 -1
- package/dist/assets/radio-group-DS_mmqHJ.js +1 -0
- package/dist/assets/{react-vega-COx3Ibyn.js → react-vega-CF0xMHAj.js} +1 -1
- package/dist/assets/{react-vega-CXIQBUis.js → react-vega-DiXzyRNd.js} +1 -1
- package/dist/assets/readonly-python-code-3HZIBvHp.js +1 -0
- package/dist/assets/{renderShortcut-CcFk3m01.js → renderShortcut--ku7VECI.js} +1 -1
- package/dist/assets/{requirementDiagram-UZGBJVZJ-ORHKBnkg.js → requirementDiagram-UZGBJVZJ-CHfh_UWf.js} +1 -1
- package/dist/assets/reveal-component-D2A1xGKf.js +1069 -0
- package/dist/assets/rpm-DlmAEsH3.js +1 -0
- package/dist/assets/ruby-BHSBK3B4.js +1 -0
- package/dist/assets/{run-page-iIqjPtCe.js → run-page-BhDNPbBY.js} +1 -1
- package/dist/assets/{sankeyDiagram-TZEHDZUN-Dvb8kmWa.js → sankeyDiagram-TZEHDZUN-DJTjdP71.js} +1 -1
- package/dist/assets/sas-DmQmrPAn.js +1 -0
- package/dist/assets/save-worker-Bcr7rl0C.js +77 -0
- package/dist/assets/scheme-CZHvt0eC.js +1 -0
- package/dist/assets/scratchpad-panel-BNnBStKO.js +1 -0
- package/dist/assets/{secrets-panel-BBvdIhtU.js → secrets-panel-NK379MhX.js} +1 -1
- package/dist/assets/{select-DZcFyKFQ.js → select-6suE6YM2.js} +1 -1
- package/dist/assets/{sequenceDiagram-WL72ISMW-DQycpQtE.js → sequenceDiagram-WL72ISMW-BbqjAz3N.js} +1 -1
- package/dist/assets/session-panel-rrXDbccI.js +1 -0
- package/dist/assets/{share-DMwTZOTH.js → share-mSf5FZIP.js} +1 -1
- package/dist/assets/shell-BJzvpTMz.js +1 -0
- package/dist/assets/sieve-DGjPhm-6.js +1 -0
- package/dist/assets/smalltalk-DaG60CSr.js +1 -0
- package/dist/assets/{snippets-panel-CUFYazvB.js → snippets-panel-BqUEqlG4.js} +1 -1
- package/dist/assets/sparql-CN49rXKB.js +1 -0
- package/dist/assets/{src-CvyFXpBy.js → src-Cf4NnJCp.js} +1 -1
- package/dist/assets/{state-BZoBW9cM.js → state-C9ggN1rs.js} +1 -1
- package/dist/assets/{state-CRuZ8deV.js → state-DvSTWgUA.js} +3 -3
- package/dist/assets/{stateDiagram-FKZM4ZOC-D78DIR_F.js → stateDiagram-FKZM4ZOC-DF2xwZZf.js} +1 -1
- package/dist/assets/stateDiagram-v2-4FDKWEC3-6MssSC6h.js +1 -0
- package/dist/assets/{step-D7xg1Moj.js → step-DGkZosD0.js} +1 -1
- package/dist/assets/stylus-CzHZ_0CL.js +1 -0
- package/dist/assets/swift-5fr5bTbW.js +1 -0
- package/dist/assets/{switch-BiU_sAcn.js → switch-Ac7CgLgh.js} +1 -1
- package/dist/assets/tcl-D5oaR_GS.js +1 -0
- package/dist/assets/{terminal-BYGihNNp.js → terminal-BJktwlxI.js} +1 -1
- package/dist/assets/{textarea-0Z0sU8Go.js → textarea-BfDUjd9c.js} +1 -1
- package/dist/assets/textile-CJ5e8-7o.js +1 -0
- package/dist/assets/{time-DLdI7jB3.js → time-BCqVDrZA.js} +1 -1
- package/dist/assets/{timeline-definition-IT6M3QCI-DIywx3xf.js → timeline-definition-IT6M3QCI-5BUJBQNX.js} +1 -1
- package/dist/assets/toml-D9QwsDZO.js +1 -0
- package/dist/assets/{tooltip-DTV9tlSr.js → tooltip-B_PkSKN3.js} +1 -1
- package/dist/assets/{tracing-Drwmt2bI.js → tracing-DhjGEWqy.js} +1 -1
- package/dist/assets/{tracing-panel-Bk-q3YTu.js → tracing-panel-Dyt4cvQF.js} +2 -2
- package/dist/assets/tree-actions-XvgFV23w.js +1 -0
- package/dist/assets/{treemap-GDKQZRPO-Dz_qZhuG.js → treemap-GDKQZRPO-4ltp47XX.js} +1 -1
- package/dist/assets/troff-DlwQJbfr.js +1 -0
- package/dist/assets/ttcn-DUvoO9Vo.js +1 -0
- package/dist/assets/ttcn-cfg-Cj-t-B3M.js +1 -0
- package/dist/assets/turtle-DzvxCIjc.js +1 -0
- package/dist/assets/use-toast-CJ1Tj2eC.js +1 -0
- package/dist/assets/useBoolean-CE6PfxGj.js +1 -0
- package/dist/assets/useCellActionButton-BHCh6qfk.js +1 -0
- package/dist/assets/useDeleteCell-cucOoAuB.js +1 -0
- package/dist/assets/{useDependencyPanelTab-CP0s5K4d.js → useDependencyPanelTab-BYu7OQY_.js} +1 -1
- package/dist/assets/{useInstallPackage-DUF4IRRI.js → useInstallPackage-GI6gu7_S.js} +1 -1
- package/dist/assets/useNotebookActions-D5xq_tdd.js +1 -0
- package/dist/assets/{useRunCells-2n74L4TT.js → useRunCells-CVd2QKS9.js} +1 -1
- package/dist/assets/{useSplitCell-CLVd_9hM.js → useSplitCell-D1KubWSa.js} +1 -1
- package/dist/assets/vb-Caf126uo.js +1 -0
- package/dist/assets/vbscript-BgRl-LR8.js +1 -0
- package/dist/assets/{vega-component-COOhhZ3h.js → vega-component-C-fGN8Hr.js} +1 -1
- package/dist/assets/velocity-CpvfwasF.js +1 -0
- package/dist/assets/verilog-hsHogyKv.js +1 -0
- package/dist/assets/vhdl-FciHazR1.js +1 -0
- package/dist/assets/webidl-CqjZNx5V.js +1 -0
- package/dist/assets/{worker-B38WhSlZ.js → worker-Bp53hInb.js} +6 -6
- package/dist/assets/{write-secret-modal-BFLlHwgU.js → write-secret-modal-CwsDn7jz.js} +1 -1
- package/dist/assets/xquery-DpTaL2IT.js +1 -0
- package/dist/assets/{xychartDiagram-PRI3JC2R-CjS1dL8k.js → xychartDiagram-PRI3JC2R-Cqm5NYAj.js} +1 -1
- package/dist/assets/yacas-D6bbkHsk.js +1 -0
- package/dist/assets/z80-MlujNizn.js +1 -0
- package/dist/index.html +68 -70
- package/package.json +3 -3
- package/src/components/data-table/TableBottomBar.tsx +1 -15
- package/src/components/data-table/TableTopBar.tsx +8 -13
- package/src/components/data-table/__tests__/TableBottomBar.test.tsx +6 -12
- package/src/components/data-table/__tests__/column-visibility-dropdown.test.tsx +227 -0
- package/src/components/data-table/__tests__/data-table.test.tsx +154 -12
- package/src/components/data-table/column-visibility-dropdown.tsx +204 -0
- package/src/components/data-table/data-table.tsx +1 -1
- package/src/components/data-table/filter-by-values-picker.tsx +39 -17
- package/src/components/data-table/filter-pills.tsx +1 -1
- package/src/components/data-table/hover-tooltip/__tests__/content.test.ts +60 -0
- package/src/components/data-table/hover-tooltip/content.ts +44 -0
- package/src/components/data-table/hover-tooltip/hover-tooltip.tsx +55 -0
- package/src/components/data-table/hover-tooltip/use-table-hover-tooltip.ts +159 -0
- package/src/components/data-table/renderers.tsx +27 -43
- package/src/components/datasources/__tests__/filter-empty.test.ts +183 -0
- package/src/components/datasources/datasources.tsx +92 -3
- package/src/components/editor/cell/cell-context-menu.tsx +15 -2
- package/src/components/editor/cell/code/language-toggle.tsx +7 -1
- package/src/components/editor/chrome/wrapper/app-chrome.tsx +97 -52
- package/src/components/editor/chrome/wrapper/lazy-panels.ts +91 -0
- package/src/components/editor/chrome/wrapper/sidebar.tsx +2 -0
- package/src/components/editor/documentation.css +35 -0
- package/src/components/editor/file-tree/file-explorer.tsx +8 -18
- package/src/components/editor/file-tree/tree-actions.tsx +46 -1
- package/src/components/editor/renderers/slides-layout/__tests__/plugin.test.ts +20 -0
- package/src/components/editor/renderers/slides-layout/types.ts +1 -0
- package/src/components/slides/__tests__/minimap-actions.test.tsx +166 -0
- package/src/components/slides/__tests__/reveal-component.test.ts +425 -0
- package/src/components/slides/minimap.tsx +127 -10
- package/src/components/slides/reveal-component.tsx +287 -61
- package/src/components/slides/slide-cell-view.tsx +26 -2
- package/src/components/slides/slide-form.tsx +26 -4
- package/src/components/storage/__tests__/storage-inspector.test.ts +53 -0
- package/src/components/storage/storage-inspector.tsx +68 -48
- package/src/components/ui/__tests__/use-toast.test.ts +75 -0
- package/src/components/ui/combobox.tsx +51 -32
- package/src/components/ui/reorderable-list.tsx +13 -0
- package/src/components/ui/select-core/__tests__/use-select-list.test.ts +294 -0
- package/src/components/ui/select-core/__tests__/utils.test.ts +222 -0
- package/src/components/ui/select-core/index.ts +16 -0
- package/src/components/ui/select-core/option-row.tsx +33 -0
- package/src/components/ui/select-core/render-slot.ts +20 -0
- package/src/components/ui/select-core/select-list.tsx +248 -0
- package/src/components/ui/select-core/types.ts +44 -0
- package/src/components/ui/select-core/use-select-list.ts +347 -0
- package/src/components/ui/select-core/utils.ts +121 -0
- package/src/components/ui/use-toast.ts +33 -13
- package/src/core/cells/__tests__/__snapshots__/cells.test.ts.snap +0 -28
- package/src/core/cells/__tests__/cell.test.ts +29 -2
- package/src/core/cells/cell.ts +5 -1
- package/src/core/codemirror/go-to-definition/commands.ts +4 -3
- package/src/core/codemirror/language/languages/python.ts +2 -0
- package/src/core/codemirror/language/languages/sql/utils.ts +3 -1
- package/src/core/codemirror/lsp/__tests__/markdown-renderer.test.ts +41 -0
- package/src/core/codemirror/lsp/markdown-renderer.ts +59 -0
- package/src/core/datasets/data-source-connections.ts +2 -0
- package/src/core/network/__tests__/requests-static.test.ts +30 -0
- package/src/core/network/requests-static.ts +14 -10
- package/src/core/wasm/worker/bootstrap.ts +12 -4
- package/src/plugins/impl/MultiselectPlugin.tsx +19 -142
- package/src/plugins/impl/SearchableSelect.tsx +16 -97
- package/src/plugins/impl/__tests__/DropdownPlugin.test.tsx +5 -2
- package/src/plugins/impl/__tests__/MultiSelectPlugin.test.ts +1 -1
- package/src/plugins/layout/DownloadPlugin.tsx +1 -1
- package/src/utils/lazy.ts +6 -1
- package/dist/assets/JsonOutput-40Fp2jEG.js +0 -53
- package/dist/assets/LazyAnyLanguageCodeMirror-BEvXb3VX.js +0 -2
- package/dist/assets/RunButton-NDsrcmxR.js +0 -1
- package/dist/assets/__vite-browser-external-DuZehUbK.js +0 -1
- package/dist/assets/__vite-browser-external-Jpm67kL1.js +0 -1
- package/dist/assets/apl-EAxnZS_5.js +0 -1
- package/dist/assets/asciiarmor-zxnaShQE.js +0 -1
- package/dist/assets/asn1-7i28Os5R.js +0 -1
- package/dist/assets/brainfuck-BZegPsXK.js +0 -1
- package/dist/assets/cells-jmgGt1lS.css +0 -2
- package/dist/assets/channel-6XBTrC3Q.js +0 -1
- package/dist/assets/chunk-55IACEB6-Cr4aqhf3.js +0 -1
- package/dist/assets/classDiagram-2ON5EDUG-DlIMDu6i.js +0 -1
- package/dist/assets/classDiagram-v2-WZHVMYZB-CcIhhkQu.js +0 -1
- package/dist/assets/clojure-VUVi7fTV.js +0 -1
- package/dist/assets/cmake-DZJIDbjY.js +0 -1
- package/dist/assets/cobol-klCRwlLm.js +0 -1
- package/dist/assets/coffeescript-C9foD9ub.js +0 -1
- package/dist/assets/column-preview-Bd7jDAiw.js +0 -1
- package/dist/assets/commonlisp-tHxoA35J.js +0 -1
- package/dist/assets/components-C_z0Dsug.js +0 -1
- package/dist/assets/crystal-CQ11GdrX.js +0 -1
- package/dist/assets/cypher-CJ0Uzw29.js +0 -1
- package/dist/assets/d-DP0SUIt1.js +0 -1
- package/dist/assets/dependency-graph-panel-BmJ-hPrs.js +0 -5
- package/dist/assets/diff-CNs8MB38.js +0 -1
- package/dist/assets/dist-B1U1kGCR.js +0 -1
- package/dist/assets/dist-B7U5jPfs.js +0 -1
- package/dist/assets/dist-BZX17NA8.js +0 -1
- package/dist/assets/dist-BtL81uwZ.js +0 -1
- package/dist/assets/dist-Bww7hlVc.js +0 -1
- package/dist/assets/dist-CAIBlJtJ.js +0 -1
- package/dist/assets/dist-CHcznzB-.js +0 -2
- package/dist/assets/dist-CPF3W2Y-.js +0 -1
- package/dist/assets/dist-CPczQFlJ.js +0 -3
- package/dist/assets/dist-CUapWJe4.js +0 -1
- package/dist/assets/dist-CWeWT34c.js +0 -1
- package/dist/assets/dist-CXBpwk_w.js +0 -7
- package/dist/assets/dist-ChF5Ln9c.js +0 -13
- package/dist/assets/dist-CuCuJBdf.js +0 -1
- package/dist/assets/dist-DH60fwgs.js +0 -1
- package/dist/assets/dist-DZPpMvcR.js +0 -1
- package/dist/assets/dist-DkcQg5xD.js +0 -1
- package/dist/assets/dist-DkzFxGAX.js +0 -1
- package/dist/assets/dist-DmBXXm0k.js +0 -1
- package/dist/assets/dist-W1iHBJeE.js +0 -1
- package/dist/assets/dist-_fyDen1v.js +0 -1
- package/dist/assets/dist-cgiAP5sW.js +0 -1
- package/dist/assets/dist-vkd1160q.js +0 -1
- package/dist/assets/download-cs3tezQD.js +0 -9
- package/dist/assets/dtd-BsD0uJw0.js +0 -1
- package/dist/assets/dylan-DbrGP1IP.js +0 -1
- package/dist/assets/ecl-C0rZlhHw.js +0 -1
- package/dist/assets/edit-page-DBwRiakc.js +0 -9
- package/dist/assets/eiffel-2ZX-OpSJ.js +0 -1
- package/dist/assets/ellipsis-vertical-CkwWkOQL.js +0 -1
- package/dist/assets/elm-CbOSKldD.js +0 -1
- package/dist/assets/erlang-BWiOgHIX.js +0 -1
- package/dist/assets/esm-CqWdmSnV.js +0 -1
- package/dist/assets/factor-CUwFIMOP.js +0 -1
- package/dist/assets/file-explorer-panel-B6UWw04X.js +0 -26
- package/dist/assets/forth-BEQA4QQL.js +0 -1
- package/dist/assets/fortran-DoPpOZgG.js +0 -1
- package/dist/assets/gas-BYovsvOE.js +0 -1
- package/dist/assets/gherkin-CFiRc1Pf.js +0 -1
- package/dist/assets/groovy-DJNH7evt.js +0 -1
- package/dist/assets/haskell-duZvcePm.js +0 -1
- package/dist/assets/haxe-B2l95qvB.js +0 -1
- package/dist/assets/home-page-5euYDrSb.js +0 -4
- package/dist/assets/idl-CZ_xwU8I.js +0 -1
- package/dist/assets/index-BIw7BKLH.css +0 -2
- package/dist/assets/index-DIc0rD1S.js +0 -38
- package/dist/assets/infoDiagram-HS3SLOUP-CaaUieFa.js +0 -2
- package/dist/assets/javascript-CF5KGSAj.js +0 -1
- package/dist/assets/julia-BQlq5iZn.js +0 -1
- package/dist/assets/katex-CzQ1KdW3.js +0 -1
- package/dist/assets/layout-Bco8l-YP.js +0 -9
- package/dist/assets/livescript-sRMenfqS.js +0 -1
- package/dist/assets/lua-a56ITumN.js +0 -1
- package/dist/assets/maps-n3GaPJwv.js +0 -1
- package/dist/assets/mathematica-B3m4jXeH.js +0 -1
- package/dist/assets/mbox-BtL7aO2I.js +0 -1
- package/dist/assets/mermaid-4DMBBIKO-CekzuCTz.js +0 -1
- package/dist/assets/mirc-S27kuZ31.js +0 -1
- package/dist/assets/mllike-B3kx3KeF.js +0 -1
- package/dist/assets/modelica-DgbW4dSi.js +0 -1
- package/dist/assets/mscgen-BIa_4d-0.js +0 -1
- package/dist/assets/multi-map-CUuNtzHt.js +0 -1
- package/dist/assets/mumps-4fnELyHs.js +0 -1
- package/dist/assets/nsis-BfGyMssE.js +0 -1
- package/dist/assets/ntriples-DeY1n_tC.js +0 -1
- package/dist/assets/octave-7Qn21jzx.js +0 -1
- package/dist/assets/oz-CiPFl3Ni.js +0 -1
- package/dist/assets/pascal-BH9yQLzw.js +0 -1
- package/dist/assets/perl-DfMCx2i2.js +0 -1
- package/dist/assets/pig-D9CNebQN.js +0 -1
- package/dist/assets/play-C7DcCsoO.js +0 -1
- package/dist/assets/powershell-Dss0bU9F.js +0 -1
- package/dist/assets/properties-CHADYQUL.js +0 -1
- package/dist/assets/protobuf-DFN-V4SD.js +0 -1
- package/dist/assets/pug-DOI9FnEk.js +0 -1
- package/dist/assets/puppet-BV0HAkDS.js +0 -1
- package/dist/assets/python-C83Db0-4.js +0 -1
- package/dist/assets/q-D84S4YaJ.js +0 -1
- package/dist/assets/r-jmqrRzXv.js +0 -1
- package/dist/assets/radio-group-DcUXH-59.js +0 -1
- package/dist/assets/readonly-python-code-D6Ca_8n6.js +0 -1
- package/dist/assets/reveal-component-ComuCTva.js +0 -1069
- package/dist/assets/rpm-DUjG0xRk.js +0 -1
- package/dist/assets/ruby-SP4FIzir.js +0 -1
- package/dist/assets/sas-BxaPz2EX.js +0 -1
- package/dist/assets/save-worker-D2iQi-UK.js +0 -77
- package/dist/assets/scheme-HBseLApj.js +0 -1
- package/dist/assets/scratchpad-panel-rClgbzFO.js +0 -1
- package/dist/assets/session-panel-DSNfdRG3.js +0 -1
- package/dist/assets/shell-w8ATY_lQ.js +0 -1
- package/dist/assets/sieve-Dyq0LGDO.js +0 -1
- package/dist/assets/smalltalk-D7mAtumc.js +0 -1
- package/dist/assets/sparql-DAeEYE_u.js +0 -1
- package/dist/assets/stateDiagram-v2-4FDKWEC3-DX9rpmwh.js +0 -1
- package/dist/assets/stylus-Cw3Ugan7.js +0 -1
- package/dist/assets/swift-CPsNOBsX.js +0 -1
- package/dist/assets/tcl-BfWyQdZa.js +0 -1
- package/dist/assets/textile-BKgaSzSN.js +0 -1
- package/dist/assets/toml-BSOdv04W.js +0 -1
- package/dist/assets/tree-actions-BM_EJr3E.js +0 -1
- package/dist/assets/troff-C0hD9kig.js +0 -1
- package/dist/assets/ttcn-DEqPxhoh.js +0 -1
- package/dist/assets/ttcn-cfg-B-7jSlUe.js +0 -1
- package/dist/assets/turtle-BTtgFsu8.js +0 -1
- package/dist/assets/use-toast-IPAtJGea.js +0 -1
- package/dist/assets/useBoolean-Bp18o6XG.js +0 -1
- package/dist/assets/useCellActionButton-DARfBbL-.js +0 -1
- package/dist/assets/useDeleteCell-l5BAp1WU.js +0 -1
- package/dist/assets/useNotebookActions-DFkPMDea.js +0 -1
- package/dist/assets/vb-DfRPk_ji.js +0 -1
- package/dist/assets/vbscript-C8D4uv5N.js +0 -1
- package/dist/assets/velocity-DxKr2FFC.js +0 -1
- package/dist/assets/verilog-CxVhamiH.js +0 -1
- package/dist/assets/vhdl-B-IpBNOA.js +0 -1
- package/dist/assets/webidl-CBjKmBwO.js +0 -1
- package/dist/assets/xquery-ABGCbLv0.js +0 -1
- package/dist/assets/yacas-Ckyxh7oh.js +0 -1
- package/dist/assets/z80-Dr5sQweg.js +0 -1
- package/src/plugins/impl/multiselectFilterFn.tsx +0 -22
- /package/dist/assets/{ImageComparisonComponent-BIetTBDq.js → ImageComparisonComponent-_eB8PDFu.js} +0 -0
- /package/dist/assets/{Inputs-C6ftxLAJ.js → Inputs-CdyQ7nLC.js} +0 -0
- /package/dist/assets/{Plot-Ba3WGWNu.js → Plot-BEhgxy0k.js} +0 -0
- /package/dist/assets/{apl-Byte72fT.js → apl-CpVTW0fY.js} +0 -0
- /package/dist/assets/{array-CC7vZNGO.js → array-BKCdRGCR.js} +0 -0
- /package/dist/assets/{asciiarmor-BU-VnG1Y.js → asciiarmor-qDK46YPd.js} +0 -0
- /package/dist/assets/{asn1-hTvH3S4T.js → asn1-s2ZJql-T.js} +0 -0
- /package/dist/assets/{asterisk-DIMri3P4.js → asterisk-BCtKIQ_I.js} +0 -0
- /package/dist/assets/{azure-B42ls0Ui.js → azure-DHLkI9dd.js} +0 -0
- /package/dist/assets/{brainfuck-C-q1Rv8J.js → brainfuck-5fD7ZBSv.js} +0 -0
- /package/dist/assets/{card--6HRj4T9.js → card-C9wGDUuq.js} +0 -0
- /package/dist/assets/{chunk-4F5CHEZ2-eEwFz7fp.js → chunk-4F5CHEZ2-DyHrF3GO.js} +0 -0
- /package/dist/assets/{chunk-B2363JML-COExSe0d.js → chunk-B2363JML-DutzPsZq.js} +0 -0
- /package/dist/assets/{chunk-DR5Q36YT-OB6tC_dd.js → chunk-DR5Q36YT-CbaaAWZ2.js} +0 -0
- /package/dist/assets/{chunk-FRFDVMJY-CO3-6rb4.js → chunk-FRFDVMJY-2_jGMKZ2.js} +0 -0
- /package/dist/assets/{chunk-PL6DKKU2-B9mDp5iV.js → chunk-PL6DKKU2-Ce2JFCUf.js} +0 -0
- /package/dist/assets/{chunk-SJTYNZTY-Dh_h90Yu.js → chunk-SJTYNZTY-PWGFKpLd.js} +0 -0
- /package/dist/assets/{chunk-TQ3KTPDO-CFybjK0M.js → chunk-TQ3KTPDO-CNkbM7LT.js} +0 -0
- /package/dist/assets/{chunk-UMXZTB3W-C3w83KpJ.js → chunk-UMXZTB3W-emEajCOH.js} +0 -0
- /package/dist/assets/{clear-button-Cfe8K4j_.js → clear-button-UYLFbizO.js} +0 -0
- /package/dist/assets/{click-outside-container-BNVqwewc.js → click-outside-container-B4pJ8dzi.js} +0 -0
- /package/dist/assets/{clike-BE-9Ct_H.js → clike-D58k-9vu.js} +0 -0
- /package/dist/assets/{clojure-Co-TLeNo.js → clojure-Dkfjc-Fr.js} +0 -0
- /package/dist/assets/{cmake-B-Nm_Opd.js → cmake-ffkxaUPf.js} +0 -0
- /package/dist/assets/{cobol-BGdihAZT.js → cobol-CKARYRbQ.js} +0 -0
- /package/dist/assets/{coffeescript-BUZXkMUO.js → coffeescript-Dz_r13Pd.js} +0 -0
- /package/dist/assets/{colors-BG8Z91CW.js → colors-CUF0x3zZ.js} +0 -0
- /package/dist/assets/{common-keywords-15xBKau4.js → common-keywords-Dl8aWedN.js} +0 -0
- /package/dist/assets/{commonlisp-CFkPbxvX.js → commonlisp-EavL1_-N.js} +0 -0
- /package/dist/assets/{crystal-CqfqDl34.js → crystal-BQ8grXRY.js} +0 -0
- /package/dist/assets/{css-DPEtZWJi.js → css-Bmqfl4iE.js} +0 -0
- /package/dist/assets/{cypher-B0t8FJvU.js → cypher-BKXIqXpT.js} +0 -0
- /package/dist/assets/{cytoscape.esm-DT8iy6p1.js → cytoscape.esm-Dr1GhgW1.js} +0 -0
- /package/dist/assets/{d-DRa_XRSB.js → d-DRfFJaS4.js} +0 -0
- /package/dist/assets/{diff-GLneonpD.js → diff-BWk1g4qN.js} +0 -0
- /package/dist/assets/{dist-BQWswd1A.js → dist-3Zzc89mE.js} +0 -0
- /package/dist/assets/{dist-BXRWfNwi.js → dist-D_deoNzY.js} +0 -0
- /package/dist/assets/{dtd-uVrZNVF0.js → dtd-C1gvGnbI.js} +0 -0
- /package/dist/assets/{duckdb-keywords-CYQ5DEZJ.js → duckdb-keywords-C_J2q1mp.js} +0 -0
- /package/dist/assets/{dylan-DkNeA4FZ.js → dylan-D26gjyBo.js} +0 -0
- /package/dist/assets/{ebnf-XMH6KY7E.js → ebnf-VrI3aTER.js} +0 -0
- /package/dist/assets/{ecl-CldUgvc9.js → ecl-D_pghsRW.js} +0 -0
- /package/dist/assets/{eiffel-CoMDRbRL.js → eiffel-CQeRT5l7.js} +0 -0
- /package/dist/assets/{elm-Cb5XC6ev.js → elm-BMJejWwJ.js} +0 -0
- /package/dist/assets/{empty-state-Cjt8SfMh.js → empty-state-vCWg-_A9.js} +0 -0
- /package/dist/assets/{erlang-8H3fTZ3L.js → erlang-DTDt7sE1.js} +0 -0
- /package/dist/assets/{esm-1wf4HygE.js → esm-DAVeZ8YU.js} +0 -0
- /package/dist/assets/{fcl-DyFJAgkq.js → fcl-B9roOCQ-.js} +0 -0
- /package/dist/assets/{formatting-CSG9kqNb.js → formatting-30FX-rC-.js} +0 -0
- /package/dist/assets/{forth-B8kC4npz.js → forth-DLug1Uos.js} +0 -0
- /package/dist/assets/{fortran-CNWGEL3c.js → fortran-CfPd9x83.js} +0 -0
- /package/dist/assets/{gas-DnZQNTHK.js → gas-C1vwqe1-.js} +0 -0
- /package/dist/assets/{gherkin-JfGcGvci.js → gherkin-DxFhlJYL.js} +0 -0
- /package/dist/assets/{groovy-D0FWiAVm.js → groovy-AqjvKzmp.js} +0 -0
- /package/dist/assets/{haskell-wUB3uX-G.js → haskell-B9BMJXS_.js} +0 -0
- /package/dist/assets/{haxe-g0JY6eL-.js → haxe-CFd4aFZH.js} +0 -0
- /package/dist/assets/{http-ySzAzH5W.js → http-BM6n_euc.js} +0 -0
- /package/dist/assets/{idl-CV2cLkPc.js → idl-DKlFwAHI.js} +0 -0
- /package/dist/assets/{init-DsZRk2YA.js → init-DZpk0tdu.js} +0 -0
- /package/dist/assets/{javascript-CT6okXEZ.js → javascript-BMuus-3E.js} +0 -0
- /package/dist/assets/{julia-CKC48ufo.js → julia-DGv2rboF.js} +0 -0
- /package/dist/assets/{katex-BE4UDS50.js → katex-DL3QMY8n.js} +0 -0
- /package/dist/assets/{links-1rtF1-eC.js → links-DoPgJNku.js} +0 -0
- /package/dist/assets/{livescript-C43pZ6Ue.js → livescript-51GCvdcX.js} +0 -0
- /package/dist/assets/{loro_wasm_bg-CXnd80ne.js → loro_wasm_bg-DYsTic7p.js} +0 -0
- /package/dist/assets/{lua-Cs2mb10K.js → lua-BwsAaftY.js} +0 -0
- /package/dist/assets/{marimo-icons-CiwvnnsT.js → marimo-icons-CLbC-oB3.js} +0 -0
- /package/dist/assets/{math-B-ZqhQTL.js → math-PgJy15ir.js} +0 -0
- /package/dist/assets/{mathematica-B5FMK3ma.js → mathematica-Du4amQ2X.js} +0 -0
- /package/dist/assets/{mbox-36Zrn5Bd.js → mbox-DKL-l6mb.js} +0 -0
- /package/dist/assets/{mirc-BKTAABSX.js → mirc-CvS1f8zr.js} +0 -0
- /package/dist/assets/{mllike-DbuClUqc.js → mllike-VhUq11ot.js} +0 -0
- /package/dist/assets/{modelica-CKRvBm7N.js → modelica-CjlHUZat.js} +0 -0
- /package/dist/assets/{mscgen-B4BRgnCi.js → mscgen-26STiUsc.js} +0 -0
- /package/dist/assets/{multi-icon-NVkxesVZ.js → multi-icon-BvuxcR2m.js} +0 -0
- /package/dist/assets/{mumps-BFiMcyFV.js → mumps-4o8IRFVU.js} +0 -0
- /package/dist/assets/{nginx-Cz_XvoTm.js → nginx-Tk1rzBXg.js} +0 -0
- /package/dist/assets/{node-sql-parser-BtkrI4pN.js → node-sql-parser-BRpb-iwO.js} +0 -0
- /package/dist/assets/{ntriples-QQAkJYAR.js → ntriples-D0zMsGJ-.js} +0 -0
- /package/dist/assets/{octave-DsTphmGZ.js → octave-CpJ40RVG.js} +0 -0
- /package/dist/assets/{oz-CD9rr5Iz.js → oz-W9l5CbXg.js} +0 -0
- /package/dist/assets/{panel-context-BJbBGfoL.js → panel-context-D7Ggu8Nw.js} +0 -0
- /package/dist/assets/{pascal-DdHEIlJE.js → pascal-BZtdYBm4.js} +0 -0
- /package/dist/assets/{path-DvTahePH.js → path-dqkZlAhR.js} +0 -0
- /package/dist/assets/{pathUtils-CJjndqMI.js → pathUtils-DPJ-EgtH.js} +0 -0
- /package/dist/assets/{perl-DHPJBQ1u.js → perl-Q79ziUtd.js} +0 -0
- /package/dist/assets/{pig-Yz7ERgca.js → pig-Dn9ueYxG.js} +0 -0
- /package/dist/assets/{powershell-CHPZ_bsU.js → powershell-DfXPJ56g.js} +0 -0
- /package/dist/assets/{properties-CI9nc7K4.js → properties-DRrw--9g.js} +0 -0
- /package/dist/assets/{protobuf-BYSIv2pY.js → protobuf-5jBh6Y7Q.js} +0 -0
- /package/dist/assets/{puppet-CEpLafZX.js → puppet-Bql5dDjm.js} +0 -0
- /package/dist/assets/{python-BndVuwG1.js → python-C7HNB5A8.js} +0 -0
- /package/dist/assets/{q-L_cetpiW.js → q-CW9lnZXb.js} +0 -0
- /package/dist/assets/{r-Dd37AKWk.js → r-DmuxMz9j.js} +0 -0
- /package/dist/assets/{request-registry--h6PWG50.js → request-registry-BmtPM40k.js} +0 -0
- /package/dist/assets/{requests-DqJEWJ-Q.js → requests-QKoDeQkn.js} +0 -0
- /package/dist/assets/{rpm-CHrvhtlN.js → rpm-2BQZRXYJ.js} +0 -0
- /package/dist/assets/{ruby-BPOowfX6.js → ruby-B-FyRKB2.js} +0 -0
- /package/dist/assets/{runs-BD0G-C2A.js → runs-DSnhrBgK.js} +0 -0
- /package/dist/assets/{sas-BsEFSvEP.js → sas-Q-94el51.js} +0 -0
- /package/dist/assets/{scheme-B42INBu7.js → scheme-By445Ne_.js} +0 -0
- /package/dist/assets/{semaphore-FlZezxaf.js → semaphore-qUGKVeAE.js} +0 -0
- /package/dist/assets/{shell-BPea12OI.js → shell-CezKrT5T.js} +0 -0
- /package/dist/assets/{sieve-C-yPcLw5.js → sieve-MRWdUbX3.js} +0 -0
- /package/dist/assets/{simple-mode-CFlvn0Mm.js → simple-mode-BtxX-F6Z.js} +0 -0
- /package/dist/assets/{smalltalk-e7OO1ATb.js → smalltalk-C0KZrhPl.js} +0 -0
- /package/dist/assets/{solr-BAO4N63o.js → solr-DaMZCY5b.js} +0 -0
- /package/dist/assets/{sparql-B4I2Ledx.js → sparql-CIMoBhOL.js} +0 -0
- /package/dist/assets/{spreadsheet-DWqd5foV.js → spreadsheet-CAZFfDgv.js} +0 -0
- /package/dist/assets/{sql-RBdzBYsM.js → sql-bIHkMPYp.js} +0 -0
- /package/dist/assets/{src-BnrQkOKh.js → src-DvosOx8X.js} +0 -0
- /package/dist/assets/{state-BGDrw26V.js → state-B2X5_9Jc.js} +0 -0
- /package/dist/assets/{stylus-CBRbZwhN.js → stylus-BxV1gbJN.js} +0 -0
- /package/dist/assets/{swift-B2hnU7ha.js → swift-C7ozIpB2.js} +0 -0
- /package/dist/assets/{swiper-component-YGJlBaCp.js → swiper-component-BA40Nidc.js} +0 -0
- /package/dist/assets/{tcl-BtyamtaZ.js → tcl-D9BrnXdg.js} +0 -0
- /package/dist/assets/{textile-M9mhyNE9.js → textile-8cDJUs1C.js} +0 -0
- /package/dist/assets/{tiddlywiki-BsHUDwie.js → tiddlywiki-C-jC8X9Z.js} +0 -0
- /package/dist/assets/{tiki-ZqBe4Kjv.js → tiki-CJPdyY5i.js} +0 -0
- /package/dist/assets/{timer-B6DpdVnC.js → timer-ffBO1paY.js} +0 -0
- /package/dist/assets/{toml-YxyxhyRy.js → toml-Dtc3-sql.js} +0 -0
- /package/dist/assets/{treemap-DeGcO9km.js → treemap-8bMgVaTX.js} +0 -0
- /package/dist/assets/{troff-C7xpi05X.js → troff-CxUT34rC.js} +0 -0
- /package/dist/assets/{ttcn-D3YytrJU.js → ttcn-BiVwbsr5.js} +0 -0
- /package/dist/assets/{ttcn-cfg-DlZ5vA9E.js → ttcn-cfg-BLBfLtVM.js} +0 -0
- /package/dist/assets/{turtle-BSHvAsUe.js → turtle-DqTQI7WU.js} +0 -0
- /package/dist/assets/{types-a-yURniQ.js → types-Cpe-qFT-.js} +0 -0
- /package/dist/assets/{useDeepCompareMemoize-zUHU--0D.js → useDeepCompareMemoize-CVmg-GkP.js} +0 -0
- /package/dist/assets/{useInterval-2YvvhIZI.js → useInterval-COQ3SSh0.js} +0 -0
- /package/dist/assets/{vb-DdkIDLlO.js → vb-D-mN5USJ.js} +0 -0
- /package/dist/assets/{vbscript-DhYGmk_p.js → vbscript-BHlqX42l.js} +0 -0
- /package/dist/assets/{velocity-DAXJNEw4.js → velocity-BX6395is.js} +0 -0
- /package/dist/assets/{verilog-jmuT_L3b.js → verilog-CixbCKyb.js} +0 -0
- /package/dist/assets/{vhdl-DcVQ97RU.js → vhdl-CofOR-02.js} +0 -0
- /package/dist/assets/{web-vitals-xkV-JBVF.js → web-vitals-CpL_P378.js} +0 -0
- /package/dist/assets/{webidl-B-YB_4OQ.js → webidl-DAqkXtNt.js} +0 -0
- /package/dist/assets/{ws-BnE9sl8z.js → ws-K6nioC-Z.js} +0 -0
- /package/dist/assets/{xquery-DOmY3Oe8.js → xquery-wPbfv0-o.js} +0 -0
- /package/dist/assets/{yacas-pL3kJRXV.js → yacas-B5Zk1avC.js} +0 -0
- /package/dist/assets/{z80-VwVuI_MT.js → z80-C0HuDTqd.js} +0 -0
- /package/src/components/{data-table → ui}/value-chips.tsx +0 -0
|
@@ -5,8 +5,8 @@ import type {
|
|
|
5
5
|
RowSelectionState,
|
|
6
6
|
SortingState,
|
|
7
7
|
} from "@tanstack/react-table";
|
|
8
|
-
import { fireEvent, render, screen, within } from "@testing-library/react";
|
|
9
|
-
import { describe, expect, it, vi } from "vitest";
|
|
8
|
+
import { act, fireEvent, render, screen, within } from "@testing-library/react";
|
|
9
|
+
import { afterEach, describe, expect, it, vi } from "vitest";
|
|
10
10
|
import { TooltipProvider } from "@/components/ui/tooltip";
|
|
11
11
|
import { DataTable } from "../data-table";
|
|
12
12
|
|
|
@@ -16,6 +16,12 @@ interface TestData {
|
|
|
16
16
|
}
|
|
17
17
|
|
|
18
18
|
describe("DataTable", () => {
|
|
19
|
+
// Restore real timers unconditionally so a failed assertion in a
|
|
20
|
+
// fake-timer test can't leak fake timers into later tests.
|
|
21
|
+
afterEach(() => {
|
|
22
|
+
vi.useRealTimers();
|
|
23
|
+
});
|
|
24
|
+
|
|
19
25
|
it("should maintain selection state when remounted", () => {
|
|
20
26
|
const mockOnRowSelectionChange = vi.fn();
|
|
21
27
|
const testData: TestData[] = [
|
|
@@ -63,17 +69,15 @@ describe("DataTable", () => {
|
|
|
63
69
|
expect(commonProps.rowSelection).toEqual(initialRowSelection);
|
|
64
70
|
});
|
|
65
71
|
|
|
66
|
-
it("
|
|
72
|
+
it("shows the hoverTemplate text as a styled tooltip on hover", async () => {
|
|
73
|
+
vi.useFakeTimers();
|
|
67
74
|
interface RowData {
|
|
68
75
|
id: number;
|
|
69
76
|
first: string;
|
|
70
77
|
last: string;
|
|
71
78
|
}
|
|
72
79
|
|
|
73
|
-
const testData: RowData[] = [
|
|
74
|
-
{ id: 1, first: "Michael", last: "Scott" },
|
|
75
|
-
{ id: 2, first: "Jim", last: "Halpert" },
|
|
76
|
-
];
|
|
80
|
+
const testData: RowData[] = [{ id: 1, first: "Michael", last: "Scott" }];
|
|
77
81
|
|
|
78
82
|
const columns: ColumnDef<RowData>[] = [
|
|
79
83
|
{ accessorKey: "first", header: "First" },
|
|
@@ -86,7 +90,7 @@ describe("DataTable", () => {
|
|
|
86
90
|
data={testData}
|
|
87
91
|
columns={columns}
|
|
88
92
|
selection={null}
|
|
89
|
-
totalRows={
|
|
93
|
+
totalRows={1}
|
|
90
94
|
totalColumns={2}
|
|
91
95
|
pagination={false}
|
|
92
96
|
hoverTemplate={"{{first}} {{last}}"}
|
|
@@ -94,11 +98,149 @@ describe("DataTable", () => {
|
|
|
94
98
|
</TooltipProvider>,
|
|
95
99
|
);
|
|
96
100
|
|
|
97
|
-
// Grab all rows and assert title attribute computed from template
|
|
98
101
|
const rows = screen.getAllByRole("row");
|
|
99
|
-
//
|
|
100
|
-
expect(rows[1]).toHaveAttribute("title"
|
|
101
|
-
|
|
102
|
+
// Native title is gone; hover text now comes from the styled tooltip.
|
|
103
|
+
expect(rows[1]).not.toHaveAttribute("title");
|
|
104
|
+
|
|
105
|
+
const cell = within(rows[1]).getAllByRole("cell")[0];
|
|
106
|
+
fireEvent.mouseOver(cell, { buttons: 0 });
|
|
107
|
+
act(() => {
|
|
108
|
+
vi.advanceTimersByTime(400);
|
|
109
|
+
});
|
|
110
|
+
|
|
111
|
+
// Radix renders the content twice (visible + a11y-hidden), so match all.
|
|
112
|
+
expect(screen.getAllByText("Michael Scott").length).toBeGreaterThan(0);
|
|
113
|
+
});
|
|
114
|
+
|
|
115
|
+
it("shows per-cell hover text from cellHoverTexts on hover", () => {
|
|
116
|
+
vi.useFakeTimers();
|
|
117
|
+
const testData: TestData[] = [{ id: 1, name: "Test 1" }];
|
|
118
|
+
const columns: ColumnDef<TestData>[] = [
|
|
119
|
+
{ id: "name", accessorKey: "name", header: "Name" },
|
|
120
|
+
];
|
|
121
|
+
|
|
122
|
+
render(
|
|
123
|
+
<TooltipProvider>
|
|
124
|
+
<DataTable
|
|
125
|
+
data={testData}
|
|
126
|
+
columns={columns}
|
|
127
|
+
selection={null}
|
|
128
|
+
totalRows={1}
|
|
129
|
+
totalColumns={1}
|
|
130
|
+
pagination={false}
|
|
131
|
+
cellHoverTexts={{ "0": { name: "per-cell tip" } }}
|
|
132
|
+
/>
|
|
133
|
+
</TooltipProvider>,
|
|
134
|
+
);
|
|
135
|
+
|
|
136
|
+
const cell = within(screen.getAllByRole("row")[1]).getByRole("cell");
|
|
137
|
+
fireEvent.mouseOver(cell, { buttons: 0 });
|
|
138
|
+
act(() => {
|
|
139
|
+
vi.advanceTimersByTime(400);
|
|
140
|
+
});
|
|
141
|
+
|
|
142
|
+
expect(screen.getAllByText("per-cell tip").length).toBeGreaterThan(0);
|
|
143
|
+
});
|
|
144
|
+
|
|
145
|
+
it("links the focused cell to the tooltip content for assistive tech", () => {
|
|
146
|
+
const testData: TestData[] = [{ id: 1, name: "Test 1" }];
|
|
147
|
+
const columns: ColumnDef<TestData>[] = [
|
|
148
|
+
{ id: "name", accessorKey: "name", header: "Name" },
|
|
149
|
+
];
|
|
150
|
+
|
|
151
|
+
render(
|
|
152
|
+
<TooltipProvider>
|
|
153
|
+
<DataTable
|
|
154
|
+
data={testData}
|
|
155
|
+
columns={columns}
|
|
156
|
+
selection={null}
|
|
157
|
+
totalRows={1}
|
|
158
|
+
totalColumns={1}
|
|
159
|
+
pagination={false}
|
|
160
|
+
cellHoverTexts={{ "0": { name: "focus tip" } }}
|
|
161
|
+
/>
|
|
162
|
+
</TooltipProvider>,
|
|
163
|
+
);
|
|
164
|
+
|
|
165
|
+
const cell = within(screen.getAllByRole("row")[1]).getByRole("cell");
|
|
166
|
+
fireEvent.focus(cell);
|
|
167
|
+
|
|
168
|
+
const describedBy = cell.getAttribute("aria-describedby");
|
|
169
|
+
expect(describedBy).toBeTruthy();
|
|
170
|
+
expect(document.getElementById(describedBy as string)).toHaveTextContent(
|
|
171
|
+
"focus tip",
|
|
172
|
+
);
|
|
173
|
+
|
|
174
|
+
fireEvent.blur(cell);
|
|
175
|
+
expect(cell).not.toHaveAttribute("aria-describedby");
|
|
176
|
+
});
|
|
177
|
+
|
|
178
|
+
it("does not show a tooltip on pointer-induced focus", () => {
|
|
179
|
+
const testData: TestData[] = [{ id: 1, name: "Test 1" }];
|
|
180
|
+
const columns: ColumnDef<TestData>[] = [
|
|
181
|
+
{ id: "name", accessorKey: "name", header: "Name" },
|
|
182
|
+
];
|
|
183
|
+
|
|
184
|
+
render(
|
|
185
|
+
<TooltipProvider>
|
|
186
|
+
<DataTable
|
|
187
|
+
data={testData}
|
|
188
|
+
columns={columns}
|
|
189
|
+
selection={null}
|
|
190
|
+
totalRows={1}
|
|
191
|
+
totalColumns={1}
|
|
192
|
+
pagination={false}
|
|
193
|
+
cellHoverTexts={{ "0": { name: "click tip" } }}
|
|
194
|
+
/>
|
|
195
|
+
</TooltipProvider>,
|
|
196
|
+
);
|
|
197
|
+
|
|
198
|
+
const cell = within(screen.getAllByRole("row")[1]).getByRole("cell");
|
|
199
|
+
// A click focuses the cell; the resulting focus must not show a tooltip.
|
|
200
|
+
fireEvent.mouseDown(cell);
|
|
201
|
+
fireEvent.focus(cell);
|
|
202
|
+
|
|
203
|
+
expect(cell).not.toHaveAttribute("aria-describedby");
|
|
204
|
+
expect(screen.queryByText("click tip")).toBeNull();
|
|
205
|
+
});
|
|
206
|
+
|
|
207
|
+
it("does not let a pending hover timer overwrite a focus tooltip", () => {
|
|
208
|
+
vi.useFakeTimers();
|
|
209
|
+
interface RowData {
|
|
210
|
+
id: number;
|
|
211
|
+
a: string;
|
|
212
|
+
b: string;
|
|
213
|
+
}
|
|
214
|
+
const testData: RowData[] = [{ id: 1, a: "a", b: "b" }];
|
|
215
|
+
const columns: ColumnDef<RowData>[] = [
|
|
216
|
+
{ id: "a", accessorKey: "a", header: "A" },
|
|
217
|
+
{ id: "b", accessorKey: "b", header: "B" },
|
|
218
|
+
];
|
|
219
|
+
|
|
220
|
+
render(
|
|
221
|
+
<TooltipProvider>
|
|
222
|
+
<DataTable
|
|
223
|
+
data={testData}
|
|
224
|
+
columns={columns}
|
|
225
|
+
selection={null}
|
|
226
|
+
totalRows={1}
|
|
227
|
+
totalColumns={2}
|
|
228
|
+
pagination={false}
|
|
229
|
+
cellHoverTexts={{ "0": { a: "hover A", b: "focus B" } }}
|
|
230
|
+
/>
|
|
231
|
+
</TooltipProvider>,
|
|
232
|
+
);
|
|
233
|
+
|
|
234
|
+
const cells = within(screen.getAllByRole("row")[1]).getAllByRole("cell");
|
|
235
|
+
// Start a pending hover-show on cell A, then focus cell B before it fires.
|
|
236
|
+
fireEvent.mouseOver(cells[0], { buttons: 0 });
|
|
237
|
+
fireEvent.focus(cells[1]);
|
|
238
|
+
act(() => {
|
|
239
|
+
vi.advanceTimersByTime(400);
|
|
240
|
+
});
|
|
241
|
+
|
|
242
|
+
expect(screen.getAllByText("focus B").length).toBeGreaterThan(0);
|
|
243
|
+
expect(screen.queryByText("hover A")).toBeNull();
|
|
102
244
|
});
|
|
103
245
|
|
|
104
246
|
it("does not virtualize small datasets without pagination", () => {
|
|
@@ -0,0 +1,204 @@
|
|
|
1
|
+
/* Copyright 2026 Marimo. All rights reserved. */
|
|
2
|
+
"use no memo";
|
|
3
|
+
|
|
4
|
+
// tanstack/table is not compatible with React compiler
|
|
5
|
+
// https://github.com/TanStack/table/issues/5567
|
|
6
|
+
|
|
7
|
+
import type { Table } from "@tanstack/react-table";
|
|
8
|
+
import { Columns3Icon, EyeIcon, EyeOffIcon } from "lucide-react";
|
|
9
|
+
import React from "react";
|
|
10
|
+
import { ColumnName } from "@/components/datasources/components";
|
|
11
|
+
import { Button } from "@/components/ui/button";
|
|
12
|
+
import {
|
|
13
|
+
Command,
|
|
14
|
+
CommandEmpty,
|
|
15
|
+
CommandInput,
|
|
16
|
+
CommandItem,
|
|
17
|
+
CommandList,
|
|
18
|
+
CommandSeparator,
|
|
19
|
+
} from "@/components/ui/command";
|
|
20
|
+
import {
|
|
21
|
+
Popover,
|
|
22
|
+
PopoverContent,
|
|
23
|
+
PopoverTrigger,
|
|
24
|
+
} from "@/components/ui/popover";
|
|
25
|
+
import { type BulkAction, useSelectList } from "@/components/ui/select-core";
|
|
26
|
+
import type { DataType } from "@/core/kernel/messages";
|
|
27
|
+
import { cn } from "@/utils/cn";
|
|
28
|
+
import { Events } from "@/utils/events";
|
|
29
|
+
import { smartMatchFilter } from "@/utils/smartMatch";
|
|
30
|
+
import { NAMELESS_COLUMN_PREFIX } from "./columns";
|
|
31
|
+
import { INDEX_COLUMN_NAME, SELECT_COLUMN_ID } from "./types";
|
|
32
|
+
|
|
33
|
+
function getUserColumns<TData>(table: Table<TData>) {
|
|
34
|
+
return table
|
|
35
|
+
.getAllLeafColumns()
|
|
36
|
+
.filter(
|
|
37
|
+
(column) =>
|
|
38
|
+
column.id !== SELECT_COLUMN_ID &&
|
|
39
|
+
column.id !== INDEX_COLUMN_NAME &&
|
|
40
|
+
!column.id.startsWith(NAMELESS_COLUMN_PREFIX),
|
|
41
|
+
);
|
|
42
|
+
}
|
|
43
|
+
|
|
44
|
+
export const ColumnVisibilityDropdown = <TData,>({
|
|
45
|
+
table,
|
|
46
|
+
}: {
|
|
47
|
+
table: Table<TData>;
|
|
48
|
+
}) => {
|
|
49
|
+
const userColumns = getUserColumns(table);
|
|
50
|
+
const options = userColumns.map((column) => ({
|
|
51
|
+
value: column.id,
|
|
52
|
+
label: column.id,
|
|
53
|
+
disabled: !column.getCanHide(),
|
|
54
|
+
data: { dataType: column.columnDef.meta?.dataType },
|
|
55
|
+
}));
|
|
56
|
+
// Modeled as a select list over hidden columns: "selected" means hidden, so
|
|
57
|
+
// the hook's pinning floats hidden columns to the top and freezes that order
|
|
58
|
+
// while the menu is open.
|
|
59
|
+
const hiddenIds = userColumns
|
|
60
|
+
.filter((column) => !column.getIsVisible())
|
|
61
|
+
.map((column) => column.id);
|
|
62
|
+
|
|
63
|
+
const applyHidden = (next: string[] | string | null) => {
|
|
64
|
+
const hidden = new Set(Array.isArray(next) ? next : []);
|
|
65
|
+
table.setColumnVisibility((previous) => ({
|
|
66
|
+
...previous,
|
|
67
|
+
...Object.fromEntries(
|
|
68
|
+
userColumns.map((column) => [column.id, !hidden.has(column.id)]),
|
|
69
|
+
),
|
|
70
|
+
}));
|
|
71
|
+
};
|
|
72
|
+
|
|
73
|
+
const list = useSelectList<string>({
|
|
74
|
+
options,
|
|
75
|
+
value: hiddenIds,
|
|
76
|
+
onChange: applyHidden,
|
|
77
|
+
multiple: true,
|
|
78
|
+
filterFn: smartMatchFilter,
|
|
79
|
+
pinSelected: true,
|
|
80
|
+
});
|
|
81
|
+
// With selection modeling hidden columns, select-matching hides the visible
|
|
82
|
+
// matches and deselect-matching shows the hidden ones.
|
|
83
|
+
const matchingActions = list.bulkActions.filter(
|
|
84
|
+
(
|
|
85
|
+
action,
|
|
86
|
+
): action is Extract<
|
|
87
|
+
BulkAction<string>,
|
|
88
|
+
{ kind: "select-matching" | "deselect-matching" }
|
|
89
|
+
> =>
|
|
90
|
+
action.kind === "select-matching" || action.kind === "deselect-matching",
|
|
91
|
+
);
|
|
92
|
+
|
|
93
|
+
return (
|
|
94
|
+
<Popover open={list.open} onOpenChange={list.setOpen}>
|
|
95
|
+
<PopoverTrigger asChild={true}>
|
|
96
|
+
<Button
|
|
97
|
+
variant="text"
|
|
98
|
+
size="xs"
|
|
99
|
+
data-testid="column-visibility-trigger"
|
|
100
|
+
onMouseDown={Events.preventFocus}
|
|
101
|
+
className={cn(
|
|
102
|
+
"print:hidden text-xs gap-1",
|
|
103
|
+
list.open ? "text-primary" : "text-muted-foreground",
|
|
104
|
+
)}
|
|
105
|
+
>
|
|
106
|
+
<Columns3Icon className="w-3.5 h-3.5" />
|
|
107
|
+
Columns
|
|
108
|
+
</Button>
|
|
109
|
+
</PopoverTrigger>
|
|
110
|
+
<PopoverContent className="w-64 p-0" align="end">
|
|
111
|
+
<Command shouldFilter={false}>
|
|
112
|
+
<CommandInput
|
|
113
|
+
placeholder="Search columns..."
|
|
114
|
+
value={list.searchQuery}
|
|
115
|
+
onValueChange={list.setSearchQuery}
|
|
116
|
+
/>
|
|
117
|
+
<CommandList>
|
|
118
|
+
<CommandEmpty>No results.</CommandEmpty>
|
|
119
|
+
{list.searchQuery === "" ? (
|
|
120
|
+
<>
|
|
121
|
+
<CommandItem
|
|
122
|
+
value="__show_all__"
|
|
123
|
+
disabled={hiddenIds.length === 0}
|
|
124
|
+
onSelect={() => applyHidden([])}
|
|
125
|
+
className="cursor-pointer"
|
|
126
|
+
>
|
|
127
|
+
<EyeIcon className="w-3 h-3 mr-1.5" />
|
|
128
|
+
Show all
|
|
129
|
+
</CommandItem>
|
|
130
|
+
<CommandSeparator />
|
|
131
|
+
</>
|
|
132
|
+
) : (
|
|
133
|
+
matchingActions.length > 0 && (
|
|
134
|
+
<>
|
|
135
|
+
{matchingActions.map((action) => (
|
|
136
|
+
<CommandItem
|
|
137
|
+
key={action.kind}
|
|
138
|
+
value={`__bulk_${action.kind}`}
|
|
139
|
+
onSelect={action.run}
|
|
140
|
+
className="cursor-pointer"
|
|
141
|
+
>
|
|
142
|
+
{action.kind === "select-matching" ? (
|
|
143
|
+
<EyeOffIcon className="w-3 h-3 mr-1.5" />
|
|
144
|
+
) : (
|
|
145
|
+
<EyeIcon className="w-3 h-3 mr-1.5" />
|
|
146
|
+
)}
|
|
147
|
+
{action.kind === "select-matching" ? "Hide" : "Show"}{" "}
|
|
148
|
+
{action.items.length} matching
|
|
149
|
+
</CommandItem>
|
|
150
|
+
))}
|
|
151
|
+
<CommandSeparator />
|
|
152
|
+
</>
|
|
153
|
+
)
|
|
154
|
+
)}
|
|
155
|
+
{list.visibleOptions.map((option, index) => {
|
|
156
|
+
const hidden = list.isChecked(option.value);
|
|
157
|
+
const { dataType } = option.data as {
|
|
158
|
+
dataType: DataType | undefined;
|
|
159
|
+
};
|
|
160
|
+
const isSectionBoundary =
|
|
161
|
+
index === list.pinnedCount &&
|
|
162
|
+
list.pinnedCount > 0 &&
|
|
163
|
+
list.pinnedCount < list.visibleOptions.length;
|
|
164
|
+
return (
|
|
165
|
+
<React.Fragment key={option.value}>
|
|
166
|
+
{isSectionBoundary && <CommandSeparator />}
|
|
167
|
+
<CommandItem
|
|
168
|
+
value={option.value}
|
|
169
|
+
disabled={option.disabled}
|
|
170
|
+
onSelect={() => list.toggle(option.value)}
|
|
171
|
+
className="flex items-center gap-1.5 cursor-pointer"
|
|
172
|
+
>
|
|
173
|
+
{dataType === undefined ? (
|
|
174
|
+
<span>{option.label}</span>
|
|
175
|
+
) : (
|
|
176
|
+
<ColumnName
|
|
177
|
+
columnName={option.label}
|
|
178
|
+
dataType={dataType}
|
|
179
|
+
/>
|
|
180
|
+
)}
|
|
181
|
+
{!option.disabled && (
|
|
182
|
+
<span
|
|
183
|
+
className={cn(
|
|
184
|
+
"ml-auto",
|
|
185
|
+
hidden ? "text-primary" : "text-muted-foreground",
|
|
186
|
+
)}
|
|
187
|
+
>
|
|
188
|
+
{hidden ? (
|
|
189
|
+
<EyeOffIcon className="w-3 h-3" />
|
|
190
|
+
) : (
|
|
191
|
+
<EyeIcon className="w-3 h-3" />
|
|
192
|
+
)}
|
|
193
|
+
</span>
|
|
194
|
+
)}
|
|
195
|
+
</CommandItem>
|
|
196
|
+
</React.Fragment>
|
|
197
|
+
);
|
|
198
|
+
})}
|
|
199
|
+
</CommandList>
|
|
200
|
+
</Command>
|
|
201
|
+
</PopoverContent>
|
|
202
|
+
</Popover>
|
|
203
|
+
);
|
|
204
|
+
};
|
|
@@ -356,6 +356,7 @@ const DataTableInternal = <TData,>({
|
|
|
356
356
|
className={cn(className || "rounded-md border overflow-hidden")}
|
|
357
357
|
>
|
|
358
358
|
<TableTopBar
|
|
359
|
+
table={table}
|
|
359
360
|
enableSearch={enableSearch}
|
|
360
361
|
searchQuery={searchQuery}
|
|
361
362
|
onSearchQueryChange={onSearchQueryChange}
|
|
@@ -413,7 +414,6 @@ const DataTableInternal = <TData,>({
|
|
|
413
414
|
getRowIds={getRowIds}
|
|
414
415
|
showPageSizeSelector={showPageSizeSelector}
|
|
415
416
|
tableLoading={reloading}
|
|
416
|
-
togglePanel={togglePanel}
|
|
417
417
|
/>
|
|
418
418
|
</div>
|
|
419
419
|
</CellSelectionProvider>
|
|
@@ -7,6 +7,8 @@ import { useMemo, useState } from "react";
|
|
|
7
7
|
import { useAsyncData } from "@/hooks/useAsyncData";
|
|
8
8
|
import { ErrorBanner } from "@/plugins/impl/common/error-banner";
|
|
9
9
|
import type { CalculateTopKRows } from "@/plugins/impl/DataTablePlugin";
|
|
10
|
+
import type { Option } from "@/components/ui/select-core";
|
|
11
|
+
import { useSelectList } from "@/components/ui/select-core";
|
|
10
12
|
import { Logger } from "@/utils/Logger";
|
|
11
13
|
import { Sets } from "@/utils/sets";
|
|
12
14
|
import { smartMatch } from "@/utils/smartMatch";
|
|
@@ -23,7 +25,7 @@ import {
|
|
|
23
25
|
import { Popover, PopoverContent, PopoverTrigger } from "../ui/popover";
|
|
24
26
|
import { SentinelCell } from "./sentinel-cell";
|
|
25
27
|
import { detectSentinel, stringifyUnknownValue } from "./utils";
|
|
26
|
-
import { CompactChipRow } from "
|
|
28
|
+
import { CompactChipRow } from "@/components/ui/value-chips";
|
|
27
29
|
|
|
28
30
|
const TOP_K_ROWS = 30;
|
|
29
31
|
|
|
@@ -101,8 +103,6 @@ export const FilterByValuesList = <TData, TValue>({
|
|
|
101
103
|
onChange,
|
|
102
104
|
creatable = false,
|
|
103
105
|
}: FilterByValuesListProps<TData, TValue>) => {
|
|
104
|
-
const [query, setQuery] = useState<string>("");
|
|
105
|
-
|
|
106
106
|
const { data, isPending, error } = useAsyncData(async () => {
|
|
107
107
|
if (!calculateTopKRows) {
|
|
108
108
|
return null;
|
|
@@ -111,27 +111,49 @@ export const FilterByValuesList = <TData, TValue>({
|
|
|
111
111
|
return res.data;
|
|
112
112
|
}, [calculateTopKRows, column.id]);
|
|
113
113
|
|
|
114
|
-
const
|
|
114
|
+
const options = useMemo<Array<Option<unknown>>>(() => {
|
|
115
115
|
if (!data) {
|
|
116
116
|
return [];
|
|
117
117
|
}
|
|
118
118
|
try {
|
|
119
|
-
|
|
120
|
-
|
|
121
|
-
|
|
122
|
-
|
|
123
|
-
|
|
124
|
-
|
|
125
|
-
|
|
126
|
-
smartMatch(query, str) ||
|
|
127
|
-
str.toLowerCase().includes(query.toLowerCase())
|
|
128
|
-
);
|
|
129
|
-
});
|
|
119
|
+
return data
|
|
120
|
+
.filter(([value]) => value !== undefined)
|
|
121
|
+
.map(([value, count]) => ({
|
|
122
|
+
value,
|
|
123
|
+
label: String(value),
|
|
124
|
+
data: { count },
|
|
125
|
+
}));
|
|
130
126
|
} catch (error_) {
|
|
131
|
-
Logger.error("Error
|
|
127
|
+
Logger.error("Error building filter options", error_);
|
|
132
128
|
return [];
|
|
133
129
|
}
|
|
134
|
-
}, [data
|
|
130
|
+
}, [data]);
|
|
131
|
+
|
|
132
|
+
const list = useSelectList<unknown>({
|
|
133
|
+
options,
|
|
134
|
+
value: [...chosenValues],
|
|
135
|
+
onChange: (next) => onChange(next as unknown[]),
|
|
136
|
+
multiple: true,
|
|
137
|
+
filterFn: (label, q) =>
|
|
138
|
+
smartMatch(q, label) || label.toLowerCase().includes(q.toLowerCase())
|
|
139
|
+
? 1
|
|
140
|
+
: 0,
|
|
141
|
+
});
|
|
142
|
+
|
|
143
|
+
const query = list.searchQuery;
|
|
144
|
+
const setQuery = list.setSearchQuery;
|
|
145
|
+
|
|
146
|
+
const filteredData = useMemo<Array<[unknown, number | undefined]>>(
|
|
147
|
+
() =>
|
|
148
|
+
list.visibleOptions.map(
|
|
149
|
+
(o) =>
|
|
150
|
+
[o.value, (o.data as { count: number }).count] as [
|
|
151
|
+
unknown,
|
|
152
|
+
number | undefined,
|
|
153
|
+
],
|
|
154
|
+
),
|
|
155
|
+
[list.visibleOptions],
|
|
156
|
+
);
|
|
135
157
|
|
|
136
158
|
// Surface chosen values that aren't in the top-K so they stay visible/uncheckable.
|
|
137
159
|
// Count is undefined for these rows; the cell renders an em-dash.
|
|
@@ -21,7 +21,7 @@ import { AddFilterButton } from "./add-filter-button";
|
|
|
21
21
|
import { FilterPillEditor } from "./filter-pill-editor";
|
|
22
22
|
import { type ColumnFilterValue, formatValue, type Snapshot } from "./filters";
|
|
23
23
|
import { extractTimezone } from "./types";
|
|
24
|
-
import { ChipWithComma, CompactChipRow } from "
|
|
24
|
+
import { ChipWithComma, CompactChipRow } from "@/components/ui/value-chips";
|
|
25
25
|
|
|
26
26
|
interface Props<TData> {
|
|
27
27
|
filters: ColumnFiltersState | undefined;
|
|
@@ -0,0 +1,60 @@
|
|
|
1
|
+
/* Copyright 2026 Marimo. All rights reserved. */
|
|
2
|
+
import type { Cell } from "@tanstack/react-table";
|
|
3
|
+
import { describe, expect, it } from "vitest";
|
|
4
|
+
import { applyHoverTemplate, computeCellTooltipContent } from "../content";
|
|
5
|
+
|
|
6
|
+
function fakeCell(columnId: string, value: unknown, hoverTitle?: string) {
|
|
7
|
+
return {
|
|
8
|
+
column: { id: columnId },
|
|
9
|
+
getValue: () => value,
|
|
10
|
+
getHoverTitle: () => hoverTitle,
|
|
11
|
+
} as unknown as Cell<unknown, unknown>;
|
|
12
|
+
}
|
|
13
|
+
|
|
14
|
+
describe("applyHoverTemplate", () => {
|
|
15
|
+
it("substitutes column placeholders", () => {
|
|
16
|
+
const cells = [fakeCell("first", "Michael"), fakeCell("last", "Scott")];
|
|
17
|
+
expect(applyHoverTemplate("{{first}} {{last}}", cells)).toBe(
|
|
18
|
+
"Michael Scott",
|
|
19
|
+
);
|
|
20
|
+
});
|
|
21
|
+
|
|
22
|
+
it("renders nulls as empty strings", () => {
|
|
23
|
+
const cells = [fakeCell("a", null)];
|
|
24
|
+
expect(applyHoverTemplate("[{{a}}]", cells)).toBe("[]");
|
|
25
|
+
});
|
|
26
|
+
|
|
27
|
+
it("leaves unknown placeholders intact", () => {
|
|
28
|
+
expect(applyHoverTemplate("{{missing}}", [fakeCell("a", 1)])).toBe(
|
|
29
|
+
"{{missing}}",
|
|
30
|
+
);
|
|
31
|
+
});
|
|
32
|
+
});
|
|
33
|
+
|
|
34
|
+
describe("computeCellTooltipContent", () => {
|
|
35
|
+
it("prefers cell-level hover title", () => {
|
|
36
|
+
const cell = fakeCell("a", 1, "cell text");
|
|
37
|
+
expect(computeCellTooltipContent(cell, "{{a}}")).toBe("cell text");
|
|
38
|
+
});
|
|
39
|
+
|
|
40
|
+
it("falls back to row template when no cell title", () => {
|
|
41
|
+
const cell = {
|
|
42
|
+
column: { id: "first" },
|
|
43
|
+
getValue: () => "X",
|
|
44
|
+
getHoverTitle: () => undefined,
|
|
45
|
+
row: {
|
|
46
|
+
getVisibleCells: () => [
|
|
47
|
+
fakeCell("first", "Jim"),
|
|
48
|
+
fakeCell("last", "Halpert"),
|
|
49
|
+
],
|
|
50
|
+
},
|
|
51
|
+
} as unknown as Cell<unknown, unknown>;
|
|
52
|
+
expect(computeCellTooltipContent(cell, "{{first}} {{last}}")).toBe(
|
|
53
|
+
"Jim Halpert",
|
|
54
|
+
);
|
|
55
|
+
});
|
|
56
|
+
|
|
57
|
+
it("returns undefined with no title and no template", () => {
|
|
58
|
+
expect(computeCellTooltipContent(fakeCell("a", 1), null)).toBeUndefined();
|
|
59
|
+
});
|
|
60
|
+
});
|
|
@@ -0,0 +1,44 @@
|
|
|
1
|
+
/* Copyright 2026 Marimo. All rights reserved. */
|
|
2
|
+
import type { Cell, RowData } from "@tanstack/react-table";
|
|
3
|
+
import type { ReactNode } from "react";
|
|
4
|
+
import { stringifyUnknownValue } from "../utils";
|
|
5
|
+
|
|
6
|
+
export function applyHoverTemplate<TData extends RowData>(
|
|
7
|
+
template: string,
|
|
8
|
+
cells: Cell<TData, unknown>[],
|
|
9
|
+
): string {
|
|
10
|
+
const variableRegex = /{{(\w+)}}/g;
|
|
11
|
+
const idToValue = new Map<string, string>();
|
|
12
|
+
for (const c of cells) {
|
|
13
|
+
const s = stringifyUnknownValue({
|
|
14
|
+
value: c.getValue(),
|
|
15
|
+
nullAsEmptyString: true,
|
|
16
|
+
});
|
|
17
|
+
idToValue.set(c.column.id, s);
|
|
18
|
+
}
|
|
19
|
+
return template.replaceAll(variableRegex, (_substr, varName: string) => {
|
|
20
|
+
const val = idToValue.get(varName);
|
|
21
|
+
return val === undefined ? `{{${varName}}}` : val;
|
|
22
|
+
});
|
|
23
|
+
}
|
|
24
|
+
|
|
25
|
+
/**
|
|
26
|
+
* Resolve the tooltip content for a hovered cell.
|
|
27
|
+
*
|
|
28
|
+
* Cell-level (callable `hover_template`) takes precedence; otherwise the
|
|
29
|
+
* row-level string template is rendered against the row's visible cells.
|
|
30
|
+
* Returns `undefined` when there is nothing to show.
|
|
31
|
+
*/
|
|
32
|
+
export function computeCellTooltipContent<TData extends RowData>(
|
|
33
|
+
cell: Cell<TData, unknown>,
|
|
34
|
+
hoverTemplate: string | null,
|
|
35
|
+
): ReactNode {
|
|
36
|
+
const cellTitle = cell.getHoverTitle?.();
|
|
37
|
+
if (cellTitle != null && cellTitle !== "") {
|
|
38
|
+
return cellTitle;
|
|
39
|
+
}
|
|
40
|
+
if (hoverTemplate) {
|
|
41
|
+
return applyHoverTemplate(hoverTemplate, cell.row.getVisibleCells());
|
|
42
|
+
}
|
|
43
|
+
return undefined;
|
|
44
|
+
}
|
|
@@ -0,0 +1,55 @@
|
|
|
1
|
+
/* Copyright 2026 Marimo. All rights reserved. */
|
|
2
|
+
import {
|
|
3
|
+
TooltipContent,
|
|
4
|
+
TooltipPortal,
|
|
5
|
+
TooltipRoot,
|
|
6
|
+
TooltipTrigger,
|
|
7
|
+
} from "@/components/ui/tooltip";
|
|
8
|
+
import type { HoverTooltipState } from "./use-table-hover-tooltip";
|
|
9
|
+
|
|
10
|
+
interface HoverTooltipProps {
|
|
11
|
+
state: HoverTooltipState | null;
|
|
12
|
+
contentId: string;
|
|
13
|
+
onClose: () => void;
|
|
14
|
+
}
|
|
15
|
+
|
|
16
|
+
/**
|
|
17
|
+
* A single radix tooltip whose anchor is repositioned to the hovered cell.
|
|
18
|
+
* Rendering one instance per table (instead of one per cell) keeps the cost
|
|
19
|
+
* constant regardless of how many cells are on screen.
|
|
20
|
+
*/
|
|
21
|
+
export const HoverTooltip = ({
|
|
22
|
+
state,
|
|
23
|
+
contentId,
|
|
24
|
+
onClose,
|
|
25
|
+
}: HoverTooltipProps) => {
|
|
26
|
+
return (
|
|
27
|
+
<TooltipRoot
|
|
28
|
+
open={state != null}
|
|
29
|
+
onOpenChange={(open) => {
|
|
30
|
+
if (!open) {
|
|
31
|
+
onClose();
|
|
32
|
+
}
|
|
33
|
+
}}
|
|
34
|
+
delayDuration={0}
|
|
35
|
+
disableHoverableContent={true}
|
|
36
|
+
>
|
|
37
|
+
<TooltipTrigger asChild={true}>
|
|
38
|
+
<div
|
|
39
|
+
aria-hidden={true}
|
|
40
|
+
style={{
|
|
41
|
+
position: "fixed",
|
|
42
|
+
top: state?.rect.top ?? 0,
|
|
43
|
+
left: state?.rect.left ?? 0,
|
|
44
|
+
width: state?.rect.width ?? 0,
|
|
45
|
+
height: state?.rect.height ?? 0,
|
|
46
|
+
pointerEvents: "none",
|
|
47
|
+
}}
|
|
48
|
+
/>
|
|
49
|
+
</TooltipTrigger>
|
|
50
|
+
<TooltipPortal>
|
|
51
|
+
<TooltipContent id={contentId}>{state?.content}</TooltipContent>
|
|
52
|
+
</TooltipPortal>
|
|
53
|
+
</TooltipRoot>
|
|
54
|
+
);
|
|
55
|
+
};
|