@marimo-team/frontend 0.23.7-dev2 → 0.23.7-dev20

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (633) hide show
  1. package/dist/assets/{CellStatus-CO_unhk0.js → CellStatus-CSvTla4f.js} +1 -1
  2. package/dist/assets/{ConnectedDataExplorerComponent-k8s9vETJ.js → ConnectedDataExplorerComponent-BEDxXsa0.js} +1 -1
  3. package/dist/assets/{ErrorBoundary-DzYV_VeY.js → ErrorBoundary-DyYDV0HI.js} +1 -1
  4. package/dist/assets/{ImperativeModal-D7lQ0Q7_.js → ImperativeModal-CvOOClOZ.js} +1 -1
  5. package/dist/assets/{JsonOutput-BalWi8Qq.js → JsonOutput-JTrlf9N4.js} +12 -12
  6. package/dist/assets/LazyAnyLanguageCodeMirror-CXbgDeVw.js +2 -0
  7. package/dist/assets/{MarimoErrorOutput-1q6qtvxi.js → MarimoErrorOutput-hJIljqUO.js} +2 -2
  8. package/dist/assets/{RSPContexts-CINae4Gg.js → RSPContexts-eRifaAal.js} +1 -1
  9. package/dist/assets/{RenderHTML-DkEHxB1r.js → RenderHTML-a81krr2r.js} +1 -1
  10. package/dist/assets/{RunButton-CJsJsGj-.js → RunButton-Cw4OpYze.js} +1 -1
  11. package/dist/assets/__vite-browser-external-DuZehUbK.js +1 -0
  12. package/dist/assets/__vite-browser-external-Jpm67kL1.js +1 -0
  13. package/dist/assets/{add-cell-with-ai-D5JeNTNV.js → add-cell-with-ai-DfJY2bip.js} +16 -16
  14. package/dist/assets/{add-connection-dialog-Dh2rjP3o.js → add-connection-dialog-Dr86oIaM.js} +1 -1
  15. package/dist/assets/{agent-panel-CiOQnIC9.js → agent-panel-BqqMglHo.js} +3 -3
  16. package/dist/assets/{ai-model-dropdown-B-9yxYM4.js → ai-model-dropdown-BtI9PY1X.js} +4 -4
  17. package/dist/assets/{alert-dialog-BGBdrcqJ.js → alert-dialog-BqFLkbUc.js} +1 -1
  18. package/dist/assets/{any-language-editor-C9DM60EN.js → any-language-editor-Bu4hSl-d.js} +1 -1
  19. package/dist/assets/apl-CaYjM5u2.js +1 -0
  20. package/dist/assets/{app-config-button-BOc_z0uX.js → app-config-button-BE6k0AGO.js} +1 -1
  21. package/dist/assets/{arc-ONRhTAm2.js → arc-D1owqr0z.js} +1 -1
  22. package/dist/assets/{architecture-7HQA4BMR-B8Ryu75w.js → architecture-7HQA4BMR-BzXB-NJy.js} +1 -1
  23. package/dist/assets/{architectureDiagram-VXUJARFQ-JNogHSZh.js → architectureDiagram-VXUJARFQ-D6wy26r_.js} +1 -1
  24. package/dist/assets/asciiarmor-D2cJUKTq.js +1 -0
  25. package/dist/assets/asn1-CZDBKivQ.js +1 -0
  26. package/dist/assets/{blockDiagram-VD42YOAC-Dy-_c6-H.js → blockDiagram-VD42YOAC-CGtjuPGT.js} +1 -1
  27. package/dist/assets/brainfuck-D5O26WTe.js +1 -0
  28. package/dist/assets/{button-D9nb17Rw.js → button-BbCh-29a.js} +1 -1
  29. package/dist/assets/{c4Diagram-YG6GDRKO-DHRUX7S-.js → c4Diagram-YG6GDRKO-BSjPyzdq.js} +1 -1
  30. package/dist/assets/{cache-panel-B_zs00Q_.js → cache-panel-VFeeaT52.js} +1 -1
  31. package/dist/assets/{capabilities-C_FLIcjP.js → capabilities-A_KhFcGV.js} +1 -1
  32. package/dist/assets/cell-editor-BnpmZwdT.js +20 -0
  33. package/dist/assets/cell-link-DieESi6t.js +1 -0
  34. package/dist/assets/{cells-DAxz8J5R.js → cells-CQvqgbJL.js} +72 -72
  35. package/dist/assets/channel-D2-MhlpJ.js +1 -0
  36. package/dist/assets/{chat-display-BiUNr6dU.js → chat-display-DXa2yk_L.js} +1 -1
  37. package/dist/assets/{chat-panel-BHsaaTzR.js → chat-panel-B_FKBw0c.js} +1 -1
  38. package/dist/assets/{chat-ui-CTYG4pnL.js → chat-ui-DRuFbdVZ.js} +1 -1
  39. package/dist/assets/{chunk-4BX2VUAB-mPGRpph5.js → chunk-4BX2VUAB-Co_nHYv2.js} +1 -1
  40. package/dist/assets/chunk-55IACEB6-CSG9iNvo.js +1 -0
  41. package/dist/assets/{chunk-5FQGJX7Z-e_arGD4o.js → chunk-5FQGJX7Z-BReOK4Lg.js} +2 -2
  42. package/dist/assets/{chunk-ABZYJK2D-BInZW7OW.js → chunk-ABZYJK2D-CvNlx3OC.js} +3 -3
  43. package/dist/assets/{chunk-ATLVNIR6-_9Zaw7IP.js → chunk-ATLVNIR6-EZIDpjkm.js} +1 -1
  44. package/dist/assets/{chunk-B4BG7PRW-Bg43tpY1.js → chunk-B4BG7PRW-B3yrge9N.js} +1 -1
  45. package/dist/assets/{chunk-CVBHYZKI-Brsoob-W.js → chunk-CVBHYZKI-lxEaq00s.js} +1 -1
  46. package/dist/assets/{chunk-DI55MBZ5-DX01Gov5.js → chunk-DI55MBZ5-NrI5veM7.js} +1 -1
  47. package/dist/assets/{chunk-EXTU4WIE-Cwo9-IiR.js → chunk-EXTU4WIE-DcGAJuBg.js} +1 -1
  48. package/dist/assets/{chunk-FMBD7UC4-Bt9icXTy.js → chunk-FMBD7UC4-CD1D2uhs.js} +1 -1
  49. package/dist/assets/{chunk-HN2XXSSU-BBxJMYrA.js → chunk-HN2XXSSU-DNIvfs-V.js} +1 -1
  50. package/dist/assets/{chunk-JA3XYJ7Z-C6cvGHie.js → chunk-JA3XYJ7Z-B-G51Lop.js} +1 -1
  51. package/dist/assets/{chunk-JZLCHNYA-BM-e2D_8.js → chunk-JZLCHNYA-B1QJXpkc.js} +1 -1
  52. package/dist/assets/{chunk-MI3HLSF2-D6we5Ftb.js → chunk-MI3HLSF2-SpVCtnNg.js} +1 -1
  53. package/dist/assets/{chunk-N4CR4FBY-BREYOeLP.js → chunk-N4CR4FBY-DaT7rK9q.js} +2 -2
  54. package/dist/assets/{chunk-QN33PNHL-DwGffwWu.js → chunk-QN33PNHL-eWaiYkN_.js} +1 -1
  55. package/dist/assets/{chunk-QXUST7PY-Q2jlSUop.js → chunk-QXUST7PY-yCShGuH_.js} +1 -1
  56. package/dist/assets/{chunk-QZHKN3VN-CeNfSWg4.js → chunk-QZHKN3VN-Bf2ysi2t.js} +1 -1
  57. package/dist/assets/{chunk-S3R3BYOJ-DGKPoF4U.js → chunk-S3R3BYOJ-BuT2smkb.js} +1 -1
  58. package/dist/assets/{chunk-TZMSLE5B-Bfbjtd_W.js → chunk-TZMSLE5B-tzDl0-3S.js} +1 -1
  59. package/dist/assets/classDiagram-2ON5EDUG-CSdm65qE.js +1 -0
  60. package/dist/assets/classDiagram-v2-WZHVMYZB-B2-GAMOQ.js +1 -0
  61. package/dist/assets/{clike-O99jWPIc.js → clike-TwxwxEw_.js} +1 -1
  62. package/dist/assets/clojure-B8dfjAV6.js +1 -0
  63. package/dist/assets/cmake-D3vlGJdL.js +1 -0
  64. package/dist/assets/cobol-S-4I_F1W.js +1 -0
  65. package/dist/assets/{code-block-37QAKDTI-CtU_48GW.js → code-block-37QAKDTI-BZ77cXM8.js} +1 -1
  66. package/dist/assets/coffeescript-DG-Oj54u.js +1 -0
  67. package/dist/assets/{column-preview-C1-l9fq3.js → column-preview-B59x-AoX.js} +1 -1
  68. package/dist/assets/{command-CBCkexpx.js → command-OHlV5HHD.js} +1 -1
  69. package/dist/assets/{command-palette-0Bx056Jf.js → command-palette-BM-axWW4.js} +1 -1
  70. package/dist/assets/{common-Qy2P7rii.js → common-DstWRPls.js} +1 -1
  71. package/dist/assets/commonlisp-CWlOS49U.js +1 -0
  72. package/dist/assets/{components-D9aJNSr-.js → components-BKjSTOL0.js} +1 -1
  73. package/dist/assets/{components-CZy03693.js → components-BLTMoYca.js} +1 -1
  74. package/dist/assets/{config-CPqw1wUv.js → config-CeTe6Mau.js} +1 -1
  75. package/dist/assets/{copy-BCF-tANo.js → copy-DqHGjTAN.js} +1 -1
  76. package/dist/assets/{copy-icon-BYNydU7b.js → copy-icon-8abB4Lgh.js} +1 -1
  77. package/dist/assets/{cose-bilkent-S5V4N54A-DWjOkKYE.js → cose-bilkent-S5V4N54A-CEx_UMjg.js} +1 -1
  78. package/dist/assets/{createReducer-1ePoj7v6.js → createReducer-CI9qeK_X.js} +1 -1
  79. package/dist/assets/crystal-CD-LQ3E-.js +1 -0
  80. package/dist/assets/{css-Ctj1grpW.js → css-sdrF9ahV.js} +1 -1
  81. package/dist/assets/cypher-oiVTIRlU.js +1 -0
  82. package/dist/assets/d-KaoGirPa.js +1 -0
  83. package/dist/assets/{dagre-6UL2VRFP-DWD6iJku.js → dagre-6UL2VRFP-Ca6G800E.js} +1 -1
  84. package/dist/assets/{data-grid-overlay-editor-DvZ8PZ2g.js → data-grid-overlay-editor-D-UNM6-P.js} +1 -1
  85. package/dist/assets/{datasource-C1JWjcmE.js → datasource-BpHWX4lD.js} +2 -2
  86. package/dist/assets/{dates-CAlnO9QB.js → dates-orWokFRU.js} +1 -1
  87. package/dist/assets/{dependency-graph-panel-DOHj-hNc.js → dependency-graph-panel-DVAWOnhj.js} +4 -4
  88. package/dist/assets/{diagram-PSM6KHXK-B_Cc0ttH.js → diagram-PSM6KHXK-B6oP3YWR.js} +1 -1
  89. package/dist/assets/{diagram-QEK2KX5R-DhI0d2dH.js → diagram-QEK2KX5R-BjsoVcta.js} +1 -1
  90. package/dist/assets/{diagram-S2PKOQOG-cc2LNQee.js → diagram-S2PKOQOG-CmzTe5KJ.js} +1 -1
  91. package/dist/assets/{dialog-Dj0qTFnG.js → dialog-DBzaWZPw.js} +1 -1
  92. package/dist/assets/diff-Df1QxxZl.js +1 -0
  93. package/dist/assets/dist-2Z1sSg1x.js +1 -0
  94. package/dist/assets/{dist-CbOE2rpr.js → dist-7iwSqhl8.js} +1 -1
  95. package/dist/assets/dist-B6zNcPeA.js +1 -0
  96. package/dist/assets/{dist-BoOh2kN5.js → dist-BdyjRhEt.js} +1 -1
  97. package/dist/assets/{dist-Dq4wQg6C.js → dist-BiTPETny.js} +1 -1
  98. package/dist/assets/{dist-e6kaTCKJ.js → dist-BojrNCCU.js} +1 -1
  99. package/dist/assets/{dist-BvZKHNvJ.js → dist-CHMkheIP.js} +1 -1
  100. package/dist/assets/{dist-DMSWEOfO.js → dist-D1lU2Qzi.js} +1 -1
  101. package/dist/assets/{dist-Cn0rcGlX.js → dist-D8QLIJ8u.js} +1 -1
  102. package/dist/assets/dist-DOBJtV_h.js +1 -0
  103. package/dist/assets/dist-DUpLnFKL.js +1 -0
  104. package/dist/assets/{dist-R7_s36kw.js → dist-DZaaRVnC.js} +1 -1
  105. package/dist/assets/{dist-C204e66A.js → dist-DZq-MBWk.js} +1 -1
  106. package/dist/assets/{dist-Dn_fCOGr.js → dist-Iv0YPPAU.js} +1 -1
  107. package/dist/assets/{dist-D4HwuQrf.js → dist-YUbAFc_i.js} +1 -1
  108. package/dist/assets/{dist-BVBYIAbx.js → dist-bOUvGRGG.js} +1 -1
  109. package/dist/assets/{dockerfile-DERk1oNL.js → dockerfile-CImncS5w.js} +1 -1
  110. package/dist/assets/documentation-panel-DOwrxSmS.js +1 -0
  111. package/dist/assets/{download-CXTuIv7r.js → download-D37eAThw.js} +4 -4
  112. package/dist/assets/{dropdown-menu-D1A3cFC8.js → dropdown-menu-CR7cnzLX.js} +1 -1
  113. package/dist/assets/dtd-Aj5m459l.js +1 -0
  114. package/dist/assets/dylan-CdSB1nh8.js +1 -0
  115. package/dist/assets/ecl-CvwsCfi6.js +1 -0
  116. package/dist/assets/{edit-page-Q7KKSAbL.js → edit-page-DZuEJBmv.js} +6 -6
  117. package/dist/assets/eiffel-Bws25dAs.js +1 -0
  118. package/dist/assets/elm--WkcLZ1a.js +1 -0
  119. package/dist/assets/{erDiagram-Q2GNP2WA-CPtVWZYn.js → erDiagram-Q2GNP2WA-CK4Kc1gP.js} +1 -1
  120. package/dist/assets/erlang-Ct30wW1o.js +1 -0
  121. package/dist/assets/{error-banner-C6aBa98y.js → error-banner-JKAA0BVv.js} +1 -1
  122. package/dist/assets/{error-panel-BN-anQD3.js → error-panel-iXq4blF1.js} +1 -1
  123. package/dist/assets/{es-DaYh1PsD.js → es-CaLpD1T5.js} +1 -1
  124. package/dist/assets/{esm-BRNC35J6.js → esm-DN_A77ya.js} +1 -1
  125. package/dist/assets/{factor-BbYo7zsD.js → factor-B3fhZG6W.js} +1 -1
  126. package/dist/assets/factor-DbSpQa-0.js +1 -0
  127. package/dist/assets/{field-BrLPDxsA.js → field-CD7Io4xo.js} +1 -1
  128. package/dist/assets/file-explorer-panel-YmaDORzk.js +26 -0
  129. package/dist/assets/{file-icons-5G4ZC70N.js → file-icons-CJjHFZoa.js} +1 -1
  130. package/dist/assets/file-name-input-Dti85i-l.js +3 -0
  131. package/dist/assets/fileToBase64-Dpv4aII5.js +1 -0
  132. package/dist/assets/{floating-outline-DHE0ukvC.js → floating-outline-CRNblX2_.js} +1 -1
  133. package/dist/assets/{flowDiagram-NV44I4VS-LeaIbfPS.js → flowDiagram-NV44I4VS-hhUTWDGs.js} +1 -1
  134. package/dist/assets/{focus-Crs_4nnQ.js → focus-BOQLCb0u.js} +1 -1
  135. package/dist/assets/{form-FbNsGFA8.js → form-Zq0BEAeQ.js} +2 -2
  136. package/dist/assets/{formats-Dsc8AdCp.js → formats-D4Sso5bX.js} +1 -1
  137. package/dist/assets/{formatting-TmuwpwTs.js → formatting-BDxRugYY.js} +1 -1
  138. package/dist/assets/forth-BP0pXyoR.js +1 -0
  139. package/dist/assets/fortran-DpX_2iww.js +1 -0
  140. package/dist/assets/{fullscreen-BDxedMYP.js → fullscreen-eipL3i3Y.js} +1 -1
  141. package/dist/assets/{gallery-page-C4kMatxN.js → gallery-page-DDCU0YEU.js} +1 -1
  142. package/dist/assets/{ganttDiagram-JELNMOA3-Bj-STLOZ.js → ganttDiagram-JELNMOA3-Dpb7hBaR.js} +1 -1
  143. package/dist/assets/gas-CiUR6fHB.js +1 -0
  144. package/dist/assets/gherkin-C9v48C48.js +1 -0
  145. package/dist/assets/{gitGraph-G5XIXVHT-CiMGDHpk.js → gitGraph-G5XIXVHT-Xz2NQxVt.js} +1 -1
  146. package/dist/assets/{gitGraphDiagram-V2S2FVAM-B9HDL4DZ.js → gitGraphDiagram-V2S2FVAM-DHCl4EFT.js} +1 -1
  147. package/dist/assets/{glide-data-editor-DqqLCmqF.js → glide-data-editor-BELaKoS9.js} +4 -4
  148. package/dist/assets/{globals-DUw71mRV.js → globals-B64vMQ0L.js} +1 -1
  149. package/dist/assets/groovy-psUnKwK-.js +1 -0
  150. package/dist/assets/haskell-DZHQAKUV.js +1 -0
  151. package/dist/assets/haxe-AOvPCF-w.js +1 -0
  152. package/dist/assets/{home-page-BM_BZnw7.js → home-page-CFZknmVJ.js} +1 -1
  153. package/dist/assets/{hooks-BgTKQ8y5.js → hooks-BhxMMR6X.js} +1 -1
  154. package/dist/assets/{html-to-image-v-_444d3.js → html-to-image-D1De-o9R.js} +2 -2
  155. package/dist/assets/idl-CSA8C1ck.js +1 -0
  156. package/dist/assets/index-BTq_h4uZ.js +42 -0
  157. package/dist/assets/index-DisN5cp_.css +2 -0
  158. package/dist/assets/{info-VBDWY6EO-yA01qfll.js → info-VBDWY6EO-BpskktdI.js} +1 -1
  159. package/dist/assets/infoDiagram-HS3SLOUP-C51uJjUn.js +2 -0
  160. package/dist/assets/{input-BX98vgAu.js → input-DW6LU13i.js} +1 -1
  161. package/dist/assets/javascript-XMYUq5-t.js +1 -0
  162. package/dist/assets/{journeyDiagram-XKPGCS4Q-D29tj64e.js → journeyDiagram-XKPGCS4Q-CD6bTQpr.js} +1 -1
  163. package/dist/assets/julia-oON8zLDW.js +1 -0
  164. package/dist/assets/{kanban-definition-3W4ZIXB7-DStZ4tGj.js → kanban-definition-3W4ZIXB7-D3rGxlSj.js} +1 -1
  165. package/dist/assets/katex-DPCeZ37j.js +1 -0
  166. package/dist/assets/kiosk-mode-DGC0xDP_.js +1 -0
  167. package/dist/assets/{label-DTR8T0AE.js → label-xHqFtfdz.js} +1 -1
  168. package/dist/assets/{layout-x1k2voam.js → layout-C74kqxlS.js} +5 -5
  169. package/dist/assets/{line-j0cbFv7-.js → line-BA7eTS55.js} +1 -1
  170. package/dist/assets/{linear-Cof2JLCQ.js → linear-Dmb_KwjK.js} +1 -1
  171. package/dist/assets/{links-iy4RlM-h.js → links-Bi_gi3iZ.js} +1 -1
  172. package/dist/assets/livescript--BxQO5G_.js +1 -0
  173. package/dist/assets/{logs-panel-BWCDk8Zy.js → logs-panel-B8xVxjgp.js} +1 -1
  174. package/dist/assets/{loro_wasm_bg-DWJCS9pK.js → loro_wasm_bg-CklgjGbG.js} +1 -1
  175. package/dist/assets/lua-CUyaVUOv.js +1 -0
  176. package/dist/assets/{maps-C48Oksn0.js → maps-BS8Ra-JU.js} +1 -1
  177. package/dist/assets/{markdown-renderer-CbuqHMPu.js → markdown-renderer-DDfK2Hm1.js} +3 -3
  178. package/dist/assets/mathematica-ONd8izyd.js +1 -0
  179. package/dist/assets/mbox-kjl3g9N-.js +1 -0
  180. package/dist/assets/{menu-items-CwUpDHG7.js → menu-items-DcP01QzW.js} +1 -1
  181. package/dist/assets/mermaid-4DMBBIKO-BeB_2G2B.js +1 -0
  182. package/dist/assets/{mermaid-BfdNvRSd.js → mermaid-B6II7_1_.js} +7 -7
  183. package/dist/assets/{mermaid-parser.core-BQULBKwL.js → mermaid-parser.core-CzmbMcI0.js} +2 -2
  184. package/dist/assets/{mhchem-BNLsaqjJ.js → mhchem-B4Y0i8Fp.js} +1 -1
  185. package/dist/assets/{mindmap-definition-VGOIOE7T-Cy9nt356.js → mindmap-definition-VGOIOE7T-CmLdKdIH.js} +1 -1
  186. package/dist/assets/mirc-BZ6TyuOO.js +1 -0
  187. package/dist/assets/mllike-Dxt2U6MQ.js +1 -0
  188. package/dist/assets/modelica-B9sdhdtj.js +1 -0
  189. package/dist/assets/mscgen-5e5Z5trn.js +1 -0
  190. package/dist/assets/{multi-map-rafH3cg3.js → multi-map-CUuNtzHt.js} +1 -1
  191. package/dist/assets/mumps-BUfWDrRe.js +1 -0
  192. package/dist/assets/{name-cell-input-DoYtA-nF.js → name-cell-input-BOJED96M.js} +1 -1
  193. package/dist/assets/nsis-Dq7T79DJ.js +1 -0
  194. package/dist/assets/{nsis-Cr8jf68z.js → nsis-QuE155sg.js} +1 -1
  195. package/dist/assets/ntriples-Dqzi7kwu.js +1 -0
  196. package/dist/assets/{number-overlay-editor-8-GuvfJX.js → number-overlay-editor-C8YnP6Ac.js} +1 -1
  197. package/dist/assets/{numbers-CAW8yjzj.js → numbers-etj36G80.js} +1 -1
  198. package/dist/assets/octave-v4IgjFm5.js +1 -0
  199. package/dist/assets/{ordinal-K0JYqmCT.js → ordinal-C9PZ4yw5.js} +1 -1
  200. package/dist/assets/outline-panel-b7DUTxCg.js +1 -0
  201. package/dist/assets/oz-BtUsXhbc.js +1 -0
  202. package/dist/assets/{packages-panel-CHVjLKJK.js → packages-panel-CsjVrbrw.js} +1 -1
  203. package/dist/assets/{packet-DYOGHKS2-D9yUvksZ.js → packet-DYOGHKS2-BqwwD9JS.js} +1 -1
  204. package/dist/assets/panels-rOdN-lhQ.js +1 -0
  205. package/dist/assets/pascal-DV7k6vJ0.js +1 -0
  206. package/dist/assets/perl-Bz7YaP_R.js +1 -0
  207. package/dist/assets/{pie-VRWISCQL-Cz1iTD2y.js → pie-VRWISCQL-BqNfdcWg.js} +1 -1
  208. package/dist/assets/{pieDiagram-ADFJNKIX-CqhovvcK.js → pieDiagram-ADFJNKIX-MH-0tvkn.js} +1 -1
  209. package/dist/assets/pig-BQWmcOEQ.js +1 -0
  210. package/dist/assets/{popover-UExmgBsf.js → popover-Bz_0Vkyf.js} +1 -1
  211. package/dist/assets/powershell-CmIFs71i.js +1 -0
  212. package/dist/assets/process-output-lWggtdHR.js +1 -0
  213. package/dist/assets/properties-D7F2Eomu.js +1 -0
  214. package/dist/assets/protobuf-BMELuvny.js +1 -0
  215. package/dist/assets/pug-C2KbP_v3.js +1 -0
  216. package/dist/assets/{pug-CKg66ZCy.js → pug-NA-6TsNe.js} +1 -1
  217. package/dist/assets/puppet-C7MviiPj.js +1 -0
  218. package/dist/assets/python-BUl8uFIl.js +1 -0
  219. package/dist/assets/q-B5bIbNKB.js +1 -0
  220. package/dist/assets/{quadrantDiagram-AYHSOK5B-BNyiC3hL.js → quadrantDiagram-AYHSOK5B-BSw-Ouba.js} +1 -1
  221. package/dist/assets/r-B0lU_x8o.js +1 -0
  222. package/dist/assets/{radar-ZZBFDIW7-y2-V58qq.js → radar-ZZBFDIW7-CYyEWqrT.js} +1 -1
  223. package/dist/assets/{radio-group-BI3wOhfc.js → radio-group-dnHLEMQN.js} +1 -1
  224. package/dist/assets/{react-vega-SibldZnp.js → react-vega-B30MPQ4_.js} +1 -1
  225. package/dist/assets/{react-vega-C1LnPwEN.js → react-vega-CXAF6OHL.js} +1 -1
  226. package/dist/assets/{readonly-python-code-CaKJ84fy.js → readonly-python-code-B2nKkRm8.js} +1 -1
  227. package/dist/assets/{renderShortcut-Bfk4NjRL.js → renderShortcut-D_8sQXCD.js} +1 -1
  228. package/dist/assets/{requirementDiagram-UZGBJVZJ-U4CoEx7e.js → requirementDiagram-UZGBJVZJ-BtGFP-o9.js} +1 -1
  229. package/dist/assets/{reveal-component-CZjszfUY.js → reveal-component-CRXRtrKQ.js} +2 -2
  230. package/dist/assets/rpm-BqQ3VFpY.js +1 -0
  231. package/dist/assets/ruby-AFh8QoqR.js +1 -0
  232. package/dist/assets/run-page-HwiYpW0n.js +1 -0
  233. package/dist/assets/{runs-5odJFrfi.js → runs-D87fZMlB.js} +1 -1
  234. package/dist/assets/{sankeyDiagram-TZEHDZUN-BXgCc5j4.js → sankeyDiagram-TZEHDZUN-yIdYlc6x.js} +1 -1
  235. package/dist/assets/sas-CeRTI9sn.js +1 -0
  236. package/dist/assets/{save-worker-CvbUHJh7.js → save-worker-D2iQi-UK.js} +4 -4
  237. package/dist/assets/scheme-D0VcE_o1.js +1 -0
  238. package/dist/assets/scratchpad-panel-CQPeL9uQ.js +1 -0
  239. package/dist/assets/{secrets-panel-DaR50P_m.js → secrets-panel-DgXG36fa.js} +1 -1
  240. package/dist/assets/{select-5i7URBEn.js → select-DZcFyKFQ.js} +1 -1
  241. package/dist/assets/semaphore-QJCD9q3h.js +1 -0
  242. package/dist/assets/{sequenceDiagram-WL72ISMW-CB8apKmu.js → sequenceDiagram-WL72ISMW-DQwYuLw4.js} +1 -1
  243. package/dist/assets/{session-VtovaFBS.js → session-gB-8RZAq.js} +1 -1
  244. package/dist/assets/{session-panel-DBKRhLd_.js → session-panel-DDsg3OVJ.js} +1 -1
  245. package/dist/assets/{share-DIVpiHPe.js → share-DdpVbvDN.js} +1 -1
  246. package/dist/assets/shell-BBh9RTgS.js +1 -0
  247. package/dist/assets/sieve-BSX0MHaT.js +1 -0
  248. package/dist/assets/smalltalk-PvrpLgKW.js +1 -0
  249. package/dist/assets/{snippets-panel-BvuRa1mc.js → snippets-panel-CL4Fe7G1.js} +1 -1
  250. package/dist/assets/sparql-CXsmb8zq.js +1 -0
  251. package/dist/assets/{spec-Cq8FVoTf.js → spec-ByOlaO3e.js} +1 -1
  252. package/dist/assets/{src-nKy6a3tt.js → src-Cf4NnJCp.js} +1 -1
  253. package/dist/assets/{state-B34hXjp9.js → state-BNbY1nER.js} +1 -1
  254. package/dist/assets/{state-Z-H4o98V.js → state-BmNumiqM.js} +1 -1
  255. package/dist/assets/{state-DgRSUIT8.js → state-Cy8CWhme.js} +1 -1
  256. package/dist/assets/state-Qlb7fpYs.js +3 -0
  257. package/dist/assets/{stateDiagram-FKZM4ZOC-3YqeHe0_.js → stateDiagram-FKZM4ZOC-CseMlyhB.js} +1 -1
  258. package/dist/assets/stateDiagram-v2-4FDKWEC3-Bpp9WfFj.js +1 -0
  259. package/dist/assets/{step-BE8c2ivx.js → step-CVy5FnKg.js} +1 -1
  260. package/dist/assets/{strings-md4mFbOQ.js → strings-wdPMRf6Z.js} +1 -1
  261. package/dist/assets/stylus-B60bUBy2.js +1 -0
  262. package/dist/assets/swift-BwnHGvoR.js +1 -0
  263. package/dist/assets/{swiper-component-B-P7FNP9.js → swiper-component-B1e0X8Wt.js} +1 -1
  264. package/dist/assets/{switch-BvybnC9P.js → switch-BT9Ki10B.js} +1 -1
  265. package/dist/assets/tcl-Bj8phnhq.js +1 -0
  266. package/dist/assets/{terminal-zehb39z5.js → terminal-G4Y2HQik.js} +1 -1
  267. package/dist/assets/{textarea-GPxmW3rS.js → textarea-BIlunvBI.js} +1 -1
  268. package/dist/assets/textile-WPCmEeGb.js +1 -0
  269. package/dist/assets/{time-C12vLLcl.js → time-RwUekUwP.js} +1 -1
  270. package/dist/assets/{timeline-definition-IT6M3QCI-DZQqxPSn.js → timeline-definition-IT6M3QCI-Cac1cr1H.js} +1 -1
  271. package/dist/assets/toml-Cdfp0vaG.js +1 -0
  272. package/dist/assets/{tooltip-Gcwqb_SK.js → tooltip-DTV9tlSr.js} +1 -1
  273. package/dist/assets/{tracing-CVQn241p.js → tracing-DxGrQWpp.js} +1 -1
  274. package/dist/assets/{tracing-panel-TnogJs00.js → tracing-panel-CkSlaa2T.js} +2 -2
  275. package/dist/assets/{tree-actions-Ci3CV3hN.js → tree-actions-Bzr5XDGx.js} +1 -1
  276. package/dist/assets/{treemap-GDKQZRPO-C139r55s.js → treemap-GDKQZRPO-Bimjb3pR.js} +1 -1
  277. package/dist/assets/troff-D4suUzlg.js +1 -0
  278. package/dist/assets/ttcn-CvD_6RGm.js +1 -0
  279. package/dist/assets/ttcn-cfg-BX59kgnW.js +1 -0
  280. package/dist/assets/turtle-midFOTTV.js +1 -0
  281. package/dist/assets/{useBoolean-xXcxYCaI.js → useBoolean-BYUGB06y.js} +1 -1
  282. package/dist/assets/useCellActionButton-BUDcn6TS.js +1 -0
  283. package/dist/assets/{useDeleteCell-DMZGFMOB.js → useDeleteCell-BImYFHqx.js} +1 -1
  284. package/dist/assets/{useDependencyPanelTab-Jnl7B-vS.js → useDependencyPanelTab-DjkP1aZy.js} +1 -1
  285. package/dist/assets/{useEventListener-BR0C1MaI.js → useEventListener-DvoEXWke.js} +1 -1
  286. package/dist/assets/{useHotkey-DccKPSPx.js → useHotkey-3DXVR1KZ.js} +1 -1
  287. package/dist/assets/{useIframeCapabilities-BvE4n6hj.js → useIframeCapabilities-BfimgBBe.js} +1 -1
  288. package/dist/assets/{useInstallPackage-D0NLybAx.js → useInstallPackage-CScpUItd.js} +1 -1
  289. package/dist/assets/{useInterval-CG264TRB.js → useInterval-CAy_JAzY.js} +1 -1
  290. package/dist/assets/useNotebookActions-CcSrDfx2.js +1 -0
  291. package/dist/assets/useRunCells-CHuy8C5z.js +1 -0
  292. package/dist/assets/useSplitCell-BxJOt_Lh.js +1 -0
  293. package/dist/assets/{useTheme-DFXuDFj9.js → useTheme-DyLIIrGi.js} +1 -1
  294. package/dist/assets/{utils-CGtUbqcR.js → utils-441jgnV8.js} +1 -1
  295. package/dist/assets/{utils-BrXijSdZ.js → utils-Wvjk_Y4h.js} +1 -1
  296. package/dist/assets/vb-CSNH0UHQ.js +1 -0
  297. package/dist/assets/vbscript-DTgXfl5y.js +1 -0
  298. package/dist/assets/vega-component-2S2ePGs4.js +1 -0
  299. package/dist/assets/velocity-CKgzALh9.js +1 -0
  300. package/dist/assets/verilog-NDqaS3bW.js +1 -0
  301. package/dist/assets/vhdl-BibQgFNM.js +1 -0
  302. package/dist/assets/webidl-BjqVurO-.js +1 -0
  303. package/dist/assets/{worker-CF8V9c2V.js → worker-B38WhSlZ.js} +4 -4
  304. package/dist/assets/{write-secret-modal-BFLUPDlo.js → write-secret-modal-BcEaI0rD.js} +1 -1
  305. package/dist/assets/ws-BV7dcs53.js +22 -0
  306. package/dist/assets/xquery-DQLXMdMd.js +1 -0
  307. package/dist/assets/{xychartDiagram-PRI3JC2R-CmNNcgCM.js → xychartDiagram-PRI3JC2R-DwmHTbm4.js} +1 -1
  308. package/dist/assets/yacas-DlkZlCdY.js +1 -0
  309. package/dist/assets/z80-YKwwCjvZ.js +1 -0
  310. package/dist/index.html +73 -72
  311. package/package.json +2 -2
  312. package/src/components/data-table/TableTopBar.tsx +5 -1
  313. package/src/components/data-table/data-table.tsx +5 -0
  314. package/src/components/data-table/download-policy/atoms.ts +10 -0
  315. package/src/components/data-table/export-actions.tsx +31 -4
  316. package/src/components/editor/actions/useNotebookActions.tsx +3 -1
  317. package/src/components/editor/app-container.tsx +7 -1
  318. package/src/components/editor/controls/Controls.tsx +3 -1
  319. package/src/components/editor/file-tree/requesting-tree.tsx +27 -25
  320. package/src/components/editor/file-tree/upload.tsx +23 -24
  321. package/src/components/editor/header/__tests__/status.test.tsx +108 -0
  322. package/src/components/editor/header/status.tsx +44 -10
  323. package/src/components/editor/navigation/__tests__/clipboard.test.ts +106 -0
  324. package/src/components/editor/navigation/__tests__/navigation.test.ts +70 -0
  325. package/src/components/editor/navigation/clipboard.ts +99 -25
  326. package/src/components/editor/navigation/navigation.ts +15 -1
  327. package/src/components/editor/notebook-cell.tsx +3 -0
  328. package/src/components/pages/run-page.tsx +4 -1
  329. package/src/core/cells/__tests__/cells.test.ts +187 -0
  330. package/src/core/cells/__tests__/pending-cut-service.test.tsx +123 -0
  331. package/src/core/cells/cells.ts +102 -17
  332. package/src/core/cells/document-changes.ts +6 -1
  333. package/src/core/cells/pending-cut-service.ts +55 -0
  334. package/src/core/cells/utils.ts +11 -0
  335. package/src/core/codemirror/cells/extensions.ts +10 -0
  336. package/src/core/codemirror/markdown/__tests__/commands.test.ts +3 -3
  337. package/src/core/codemirror/markdown/commands.ts +1 -2
  338. package/src/core/edit-app.tsx +2 -1
  339. package/src/core/hotkeys/hotkeys.ts +5 -0
  340. package/src/core/islands/worker/worker.tsx +3 -2
  341. package/src/core/network/requests-network.ts +21 -3
  342. package/src/core/network/types.ts +12 -1
  343. package/src/core/run-app.tsx +2 -1
  344. package/src/core/wasm/__tests__/utils.test.ts +34 -0
  345. package/src/core/wasm/bridge.ts +14 -1
  346. package/src/core/wasm/utils.ts +14 -0
  347. package/src/core/wasm/worker/bootstrap.ts +3 -2
  348. package/src/core/wasm/worker/worker.ts +3 -2
  349. package/src/core/websocket/__tests__/useMarimoKernelConnection.hook.test.tsx +155 -0
  350. package/src/core/websocket/__tests__/useMarimoKernelConnection.test.ts +137 -0
  351. package/src/core/websocket/transports/basic.ts +2 -0
  352. package/src/core/websocket/transports/transport.ts +1 -0
  353. package/src/core/websocket/useMarimoKernelConnection.tsx +130 -55
  354. package/src/core/websocket/useWebSocket.tsx +5 -2
  355. package/src/css/app/Cell.css +10 -0
  356. package/src/plugins/core/__test__/sanitize.test.ts +8 -0
  357. package/src/plugins/impl/DataTablePlugin.tsx +12 -0
  358. package/src/plugins/impl/TabsPlugin.tsx +35 -7
  359. package/src/plugins/impl/__tests__/TabsPlugin.test.tsx +154 -0
  360. package/src/plugins/impl/data-frames/DataFramePlugin.tsx +6 -0
  361. package/src/plugins/impl/vega/resolve-data.ts +8 -1
  362. package/src/plugins/layout/__test__/MermaidPlugin.test.ts +50 -0
  363. package/src/plugins/layout/mermaid/MermaidPlugin.tsx +11 -1
  364. package/src/plugins/layout/mermaid/mermaid.tsx +7 -3
  365. package/src/utils/__tests__/id-tree.test.ts +71 -0
  366. package/src/utils/__tests__/semaphore.test.ts +218 -0
  367. package/src/utils/fileToBase64.ts +8 -7
  368. package/src/utils/id-tree.tsx +89 -0
  369. package/src/utils/semaphore.ts +88 -0
  370. package/dist/assets/LazyAnyLanguageCodeMirror-BF3xpDgO.js +0 -2
  371. package/dist/assets/__vite-browser-external-D0cSGXjR.js +0 -1
  372. package/dist/assets/__vite-browser-external-DQc2JVNq.js +0 -1
  373. package/dist/assets/apl-m-AMVo9Q.js +0 -1
  374. package/dist/assets/asciiarmor-BCgPMx-s.js +0 -1
  375. package/dist/assets/asn1-f2_lxsgc.js +0 -1
  376. package/dist/assets/brainfuck-ZYebo2B9.js +0 -1
  377. package/dist/assets/cell-editor-CtnFLzYa.js +0 -22
  378. package/dist/assets/cell-link-CC2MiW7a.js +0 -1
  379. package/dist/assets/channel-CWEEnT6g.js +0 -1
  380. package/dist/assets/chunk-55IACEB6-DD051KDZ.js +0 -1
  381. package/dist/assets/classDiagram-2ON5EDUG-CBbpzZPu.js +0 -1
  382. package/dist/assets/classDiagram-v2-WZHVMYZB-B0cWCuuo.js +0 -1
  383. package/dist/assets/clojure-NE6UT6b9.js +0 -1
  384. package/dist/assets/cmake-7TIUAxVu.js +0 -1
  385. package/dist/assets/cobol-BdI6-uBH.js +0 -1
  386. package/dist/assets/coffeescript-CLx5m4GS.js +0 -1
  387. package/dist/assets/commonlisp-8d9AwdCm.js +0 -1
  388. package/dist/assets/crystal-Bn-cOTHZ.js +0 -1
  389. package/dist/assets/cypher-DnT9gfY3.js +0 -1
  390. package/dist/assets/d-DCjbmG72.js +0 -1
  391. package/dist/assets/diff-DtVdhdPz.js +0 -1
  392. package/dist/assets/dist-BkhaSQrg.js +0 -1
  393. package/dist/assets/dist-_KQbcsP1.js +0 -1
  394. package/dist/assets/dist-bvHsEZ9m.js +0 -1
  395. package/dist/assets/dist-jLyLmWUE.js +0 -1
  396. package/dist/assets/documentation-panel-BM7hNnyp.js +0 -1
  397. package/dist/assets/dtd-CHKGQo-k.js +0 -1
  398. package/dist/assets/dylan-DKXsKw9e.js +0 -1
  399. package/dist/assets/ecl-BJuToLkm.js +0 -1
  400. package/dist/assets/eiffel-Bs0gRCeB.js +0 -1
  401. package/dist/assets/elm-BXUbhN4m.js +0 -1
  402. package/dist/assets/erlang-B9b7RAaI.js +0 -1
  403. package/dist/assets/factor-C2NWkG3V.js +0 -1
  404. package/dist/assets/file-explorer-panel-Y0zOwZxs.js +0 -26
  405. package/dist/assets/file-name-input-C70pv8AE.js +0 -3
  406. package/dist/assets/fileToBase64-Bzn96tYq.js +0 -1
  407. package/dist/assets/forth-DAh7UX6C.js +0 -1
  408. package/dist/assets/fortran-Dy64-0b5.js +0 -1
  409. package/dist/assets/gas-DC-7PUFB.js +0 -1
  410. package/dist/assets/gherkin-ByiMyVl5.js +0 -1
  411. package/dist/assets/groovy-DaM0RAwa.js +0 -1
  412. package/dist/assets/haskell-BwRtIbXW.js +0 -1
  413. package/dist/assets/haxe-DFGSCjmC.js +0 -1
  414. package/dist/assets/idl-Ip8qszMi.js +0 -1
  415. package/dist/assets/index-DH5UUBE4.css +0 -2
  416. package/dist/assets/index-g2qQV71h.js +0 -42
  417. package/dist/assets/infoDiagram-HS3SLOUP-BDcw9LMK.js +0 -2
  418. package/dist/assets/javascript-DmUu6wxV.js +0 -1
  419. package/dist/assets/julia-C8K-9kxt.js +0 -1
  420. package/dist/assets/katex-S9z-JFdU.js +0 -1
  421. package/dist/assets/kiosk-mode-DKb6W1WN.js +0 -1
  422. package/dist/assets/livescript-B3MfBDE2.js +0 -1
  423. package/dist/assets/lua-B2YpVx0h.js +0 -1
  424. package/dist/assets/mathematica-D9tSC-hw.js +0 -1
  425. package/dist/assets/mbox-CjoMCyMH.js +0 -1
  426. package/dist/assets/mermaid-4DMBBIKO-gHC2PS1m.js +0 -1
  427. package/dist/assets/mirc-DvJdMBLZ.js +0 -1
  428. package/dist/assets/mllike-5ykSeapn.js +0 -1
  429. package/dist/assets/modelica-laYOX8Zo.js +0 -1
  430. package/dist/assets/mscgen-z_sYErek.js +0 -1
  431. package/dist/assets/mumps-BwcCoPkA.js +0 -1
  432. package/dist/assets/nsis-CpSPdWjV.js +0 -1
  433. package/dist/assets/ntriples-D2ki9JZ6.js +0 -1
  434. package/dist/assets/octave-D817mWs9.js +0 -1
  435. package/dist/assets/outline-panel-C5bTOsj4.js +0 -1
  436. package/dist/assets/oz-3GS03IG4.js +0 -1
  437. package/dist/assets/panels-D0bfHEhi.js +0 -1
  438. package/dist/assets/pascal-C08wXab2.js +0 -1
  439. package/dist/assets/perl-Ija-iETI.js +0 -1
  440. package/dist/assets/pig-BlBD3yVJ.js +0 -1
  441. package/dist/assets/powershell-CjOQ_PjD.js +0 -1
  442. package/dist/assets/process-output-CKd9tbdL.js +0 -1
  443. package/dist/assets/properties-5yVGVBrw.js +0 -1
  444. package/dist/assets/protobuf-hlm5v2rk.js +0 -1
  445. package/dist/assets/pug-DifRb20b.js +0 -1
  446. package/dist/assets/puppet-BpFPuj45.js +0 -1
  447. package/dist/assets/python-B_AEFhuO.js +0 -1
  448. package/dist/assets/q-BzDxfEQq.js +0 -1
  449. package/dist/assets/r-BJ9VYyYa.js +0 -1
  450. package/dist/assets/rpm-Ez4HwV9T.js +0 -1
  451. package/dist/assets/ruby-BcHOM0EI.js +0 -1
  452. package/dist/assets/run-page-tVelC3Sm.js +0 -1
  453. package/dist/assets/sas-Qmf5gHIU.js +0 -1
  454. package/dist/assets/scheme-Ctib9V77.js +0 -1
  455. package/dist/assets/scratchpad-panel-DB8GmXPG.js +0 -1
  456. package/dist/assets/shell-BtgVCAhn.js +0 -1
  457. package/dist/assets/sieve-CMsTkuH0.js +0 -1
  458. package/dist/assets/smalltalk-BKSCdMTS.js +0 -1
  459. package/dist/assets/sparql-TK6HapG4.js +0 -1
  460. package/dist/assets/state-CjlRDG08.js +0 -3
  461. package/dist/assets/stateDiagram-v2-4FDKWEC3-Dfvjjqh4.js +0 -1
  462. package/dist/assets/stylus-C8FKVvgQ.js +0 -1
  463. package/dist/assets/swift-D7BZKS_y.js +0 -1
  464. package/dist/assets/tcl-DFrjfFmM.js +0 -1
  465. package/dist/assets/textile-Bj913nF7.js +0 -1
  466. package/dist/assets/toml-B6qgmS36.js +0 -1
  467. package/dist/assets/troff-CysSpyUG.js +0 -1
  468. package/dist/assets/ttcn-DG1k5i1B.js +0 -1
  469. package/dist/assets/ttcn-cfg-p1jV7x_I.js +0 -1
  470. package/dist/assets/turtle-DSkxUncB.js +0 -1
  471. package/dist/assets/useCellActionButton-C8PCItmw.js +0 -1
  472. package/dist/assets/useNotebookActions-Bfp8EPmq.js +0 -1
  473. package/dist/assets/useRunCells-BMgfN_OV.js +0 -1
  474. package/dist/assets/useSplitCell-B5YK7yVe.js +0 -1
  475. package/dist/assets/vb-BIvYC4My.js +0 -1
  476. package/dist/assets/vbscript-Coxg2EVQ.js +0 -1
  477. package/dist/assets/vega-component-DOyQwlmD.js +0 -1
  478. package/dist/assets/velocity-Cy90c7hC.js +0 -1
  479. package/dist/assets/verilog-CTtn3HA0.js +0 -1
  480. package/dist/assets/vhdl-D3r3mwOF.js +0 -1
  481. package/dist/assets/webidl-CHPMhkWI.js +0 -1
  482. package/dist/assets/ws-CtTwmdal.js +0 -22
  483. package/dist/assets/xquery-d-YlNlXH.js +0 -1
  484. package/dist/assets/yacas-BfZ0gs5_.js +0 -1
  485. package/dist/assets/z80-cYJ4lyZA.js +0 -1
  486. /package/dist/assets/{ImageComparisonComponent-2VO41-VE.js → ImageComparisonComponent-MKB-qBjQ.js} +0 -0
  487. /package/dist/assets/{Inputs-BdyX096j.js → Inputs-NeZ9OMUu.js} +0 -0
  488. /package/dist/assets/{Plot-IawheWsD.js → Plot-KSPp-GdN.js} +0 -0
  489. /package/dist/assets/{apl-T0uH_RjM.js → apl-DHQPYmx2.js} +0 -0
  490. /package/dist/assets/{array-BCwZq3ts.js → array-Cf4PUXPA.js} +0 -0
  491. /package/dist/assets/{asciiarmor-D3ol7c2G.js → asciiarmor-fnQAw8T8.js} +0 -0
  492. /package/dist/assets/{asn1-DA-fXXsk.js → asn1-5lb7I37s.js} +0 -0
  493. /package/dist/assets/{asterisk-Cy-53Fu-.js → asterisk-XerxOHb_.js} +0 -0
  494. /package/dist/assets/{azure-ZuB1zQ8Q.js → azure-C2Di2emT.js} +0 -0
  495. /package/dist/assets/{blob-D-eV0cU3.js → blob-Daju1h1M.js} +0 -0
  496. /package/dist/assets/{brainfuck-exn1QR7H.js → brainfuck-D30bRgvC.js} +0 -0
  497. /package/dist/assets/{card-BsOjr9wU.js → card-ICvk7-qa.js} +0 -0
  498. /package/dist/assets/{chunk-4F5CHEZ2-BBsStyPF.js → chunk-4F5CHEZ2-CRKjiogH.js} +0 -0
  499. /package/dist/assets/{chunk-B2363JML-CPCjJ6tH.js → chunk-B2363JML-DvPUNzRx.js} +0 -0
  500. /package/dist/assets/{chunk-DR5Q36YT-DpSMafKt.js → chunk-DR5Q36YT-DrxpR6Mz.js} +0 -0
  501. /package/dist/assets/{chunk-FRFDVMJY-D6StbPqE.js → chunk-FRFDVMJY-DpWfc7R9.js} +0 -0
  502. /package/dist/assets/{chunk-PL6DKKU2-x3Qoia3Y.js → chunk-PL6DKKU2-D7_8iK_E.js} +0 -0
  503. /package/dist/assets/{chunk-SJTYNZTY-BNaCydHS.js → chunk-SJTYNZTY-DwmVeUIB.js} +0 -0
  504. /package/dist/assets/{chunk-TQ3KTPDO-DfYTN8Ct.js → chunk-TQ3KTPDO-BdfwTgi0.js} +0 -0
  505. /package/dist/assets/{chunk-UMXZTB3W-DsE6dCbX.js → chunk-UMXZTB3W-BZR4zVXt.js} +0 -0
  506. /package/dist/assets/{clear-button-DBrTU3uL.js → clear-button-DJUQ_tmP.js} +0 -0
  507. /package/dist/assets/{click-outside-container-BXzp0MYr.js → click-outside-container-Npdlddni.js} +0 -0
  508. /package/dist/assets/{clike-BK27e5qn.js → clike-jZeb2kFn.js} +0 -0
  509. /package/dist/assets/{clojure-Df1U5nhC.js → clojure-C0pkR8m2.js} +0 -0
  510. /package/dist/assets/{cmake-DrCf0yvp.js → cmake-DlvFtk_M.js} +0 -0
  511. /package/dist/assets/{cobol-BWxHqof4.js → cobol-C_yb45mr.js} +0 -0
  512. /package/dist/assets/{coffeescript-nKvg8y_U.js → coffeescript-DBK0AeMT.js} +0 -0
  513. /package/dist/assets/{colors-CI3VyX7X.js → colors-DUsH-HF1.js} +0 -0
  514. /package/dist/assets/{common-keywords-CU-S2Vqm.js → common-keywords-D2VmoaPb.js} +0 -0
  515. /package/dist/assets/{commonlisp-Dm562cBV.js → commonlisp-Bo8hOdn-.js} +0 -0
  516. /package/dist/assets/{crystal-CrCmK2Cb.js → crystal-DYrQEMVi.js} +0 -0
  517. /package/dist/assets/{css-jpfGFPDE.js → css-zh47N2UC.js} +0 -0
  518. /package/dist/assets/{cypher-RQ5M28al.js → cypher-BWPAHm69.js} +0 -0
  519. /package/dist/assets/{cytoscape.esm-BbAjzIsa.js → cytoscape.esm-B7Zr-PlQ.js} +0 -0
  520. /package/dist/assets/{d-CNQ_nPqU.js → d-CMuL95tt.js} +0 -0
  521. /package/dist/assets/{diff-DOODcY7A.js → diff-oor_HZ51.js} +0 -0
  522. /package/dist/assets/{dist-CsEqrZxx.js → dist-1sgFrolC.js} +0 -0
  523. /package/dist/assets/{dist-DBBYmRY4.js → dist-B847wb8t.js} +0 -0
  524. /package/dist/assets/{dist-_qPWf6sD.js → dist-BDZFwK9_.js} +0 -0
  525. /package/dist/assets/{dist-ooLAQ9IK.js → dist-BjkXqMhR.js} +0 -0
  526. /package/dist/assets/{dist-DggusHaA.js → dist-Bu99ARwH.js} +0 -0
  527. /package/dist/assets/{dist-HW7R98td.js → dist-Bxj5sO2I.js} +0 -0
  528. /package/dist/assets/{dist-D6wwIjcW.js → dist-CBX4gLSR.js} +0 -0
  529. /package/dist/assets/{dist-CEUFTp7U.js → dist-CPepgudT.js} +0 -0
  530. /package/dist/assets/{dist-CGDn0y-i.js → dist-CQG39nVX.js} +0 -0
  531. /package/dist/assets/{dist-Cmcbyg5X.js → dist-CSOCJn9h.js} +0 -0
  532. /package/dist/assets/{dist-DxxvVPQH.js → dist-CpSELpRR.js} +0 -0
  533. /package/dist/assets/{dist-B96NwXcp.js → dist-DLY3MFt_.js} +0 -0
  534. /package/dist/assets/{dist-DS5RCKZO.js → dist-D_yqofzt.js} +0 -0
  535. /package/dist/assets/{dist-rzeRelEY.js → dist-DaXyrkOa.js} +0 -0
  536. /package/dist/assets/{dist-9g-_Ln9y.js → dist-DdITFgCr.js} +0 -0
  537. /package/dist/assets/{dist-DCqWIRLq.js → dist-DsbE_iBm.js} +0 -0
  538. /package/dist/assets/{dist-_XomGjg6.js → dist-GYoBJCzF.js} +0 -0
  539. /package/dist/assets/{dist-Dw9UX7x1.js → dist-q4pwbvzW.js} +0 -0
  540. /package/dist/assets/{dtd-CRYKjxdR.js → dtd-Fe_Eikw6.js} +0 -0
  541. /package/dist/assets/{duckdb-keywords-CR9f4wu5.js → duckdb-keywords-qEANwaB-.js} +0 -0
  542. /package/dist/assets/{dylan-Bg0sO2y3.js → dylan-DjUZAjRK.js} +0 -0
  543. /package/dist/assets/{ebnf-BdwTqLUx.js → ebnf-BbpZiR1i.js} +0 -0
  544. /package/dist/assets/{ecl-DaBeV7OZ.js → ecl-qgyT1LqI.js} +0 -0
  545. /package/dist/assets/{eiffel-BtJc6fqQ.js → eiffel-Dgulx8rf.js} +0 -0
  546. /package/dist/assets/{elm-D9Rly7Qq.js → elm-BvFY4GJb.js} +0 -0
  547. /package/dist/assets/{empty-state-CsVQSqKA.js → empty-state-vCWg-_A9.js} +0 -0
  548. /package/dist/assets/{erlang-FZMRuv-7.js → erlang-Ba0XOLlj.js} +0 -0
  549. /package/dist/assets/{errors-TZBmrJmc.js → errors-CPlNr33a.js} +0 -0
  550. /package/dist/assets/{esm-D_nSG7uo.js → esm-C9WujutX.js} +0 -0
  551. /package/dist/assets/{fcl-BFWIADMy.js → fcl-CvYyfPhf.js} +0 -0
  552. /package/dist/assets/{forth-C6jh4lHA.js → forth-gbBFxz8f.js} +0 -0
  553. /package/dist/assets/{fortran-DuxTe5qi.js → fortran-CXijpPbh.js} +0 -0
  554. /package/dist/assets/{gas-D7RWbiQ0.js → gas-CnHGSLCd.js} +0 -0
  555. /package/dist/assets/{gherkin-DV4l4nlf.js → gherkin-DfEZpSxY.js} +0 -0
  556. /package/dist/assets/{groovy-Ij7mXzwd.js → groovy-9JiNA9gq.js} +0 -0
  557. /package/dist/assets/{haskell-BT_ZNgUJ.js → haskell-CKr_RZFK.js} +0 -0
  558. /package/dist/assets/{haxe-DYYwGmM8.js → haxe-DsAAHfaR.js} +0 -0
  559. /package/dist/assets/{http-CgzOAOXj.js → http-BJwmEMko.js} +0 -0
  560. /package/dist/assets/{idl-CjBvIccU.js → idl-Djz72z1a.js} +0 -0
  561. /package/dist/assets/{init-DE_uL9Ns.js → init-DRQmrFIb.js} +0 -0
  562. /package/dist/assets/{javascript-DQz7szA1.js → javascript-CsBr0q2-.js} +0 -0
  563. /package/dist/assets/{julia-U0NSUEwm.js → julia-BCYfl68O.js} +0 -0
  564. /package/dist/assets/{katex-M9SX-Gs-.js → katex-BywUFgaS.js} +0 -0
  565. /package/dist/assets/{livescript-D7jeebX7.js → livescript-BEw7FNJP.js} +0 -0
  566. /package/dist/assets/{loro_wasm_bg-Bu4Ofw1K.js → loro_wasm_bg-BArxhAm3.js} +0 -0
  567. /package/dist/assets/{lua-CT4vrRvN.js → lua-DqxHXOsz.js} +0 -0
  568. /package/dist/assets/{marimo-icons-BSB-Z_W3.js → marimo-icons-Dk6YhPWV.js} +0 -0
  569. /package/dist/assets/{math-Bf0RgaKx.js → math-BJjKGmt3.js} +0 -0
  570. /package/dist/assets/{mathematica-DmzlinOc.js → mathematica-Do-octY0.js} +0 -0
  571. /package/dist/assets/{mbox-DYDL20A1.js → mbox-VgrgGytk.js} +0 -0
  572. /package/dist/assets/{mirc-6LiBC6Dw.js → mirc-DkD5mNIp.js} +0 -0
  573. /package/dist/assets/{mllike-orSu1SHG.js → mllike-C8Ah4kKN.js} +0 -0
  574. /package/dist/assets/{modelica-BsibU-7c.js → modelica-2q7w6nLE.js} +0 -0
  575. /package/dist/assets/{mscgen-vX4NsSXf.js → mscgen-BRqvO7u4.js} +0 -0
  576. /package/dist/assets/{multi-icon-DQxqgfM2.js → multi-icon-BvuxcR2m.js} +0 -0
  577. /package/dist/assets/{mumps-DIZYQE11.js → mumps-CjtiTT1a.js} +0 -0
  578. /package/dist/assets/{nginx-CFpObAqg.js → nginx-JMUOT8EG.js} +0 -0
  579. /package/dist/assets/{node-sql-parser-B8vXamqL.js → node-sql-parser-TdBo37ty.js} +0 -0
  580. /package/dist/assets/{ntriples-CwlUIE0o.js → ntriples-4lauqsM6.js} +0 -0
  581. /package/dist/assets/{octave-BWtN_wao.js → octave-A2kFK0nR.js} +0 -0
  582. /package/dist/assets/{oz-CJMVKlqL.js → oz-CvXDMSbl.js} +0 -0
  583. /package/dist/assets/{panel-context-B3J07LRC.js → panel-context-D-qi_oxP.js} +0 -0
  584. /package/dist/assets/{pascal-C9rPtth-.js → pascal-6Jinj26u.js} +0 -0
  585. /package/dist/assets/{path-LDcaQ64B.js → path-D7fidI_g.js} +0 -0
  586. /package/dist/assets/{perl-CF7pKLbl.js → perl-CXauYQdN.js} +0 -0
  587. /package/dist/assets/{pig-Bu0nn8JT.js → pig-Dl0QLQI6.js} +0 -0
  588. /package/dist/assets/{powershell-Bzwpi8yQ.js → powershell-6bdy_rHW.js} +0 -0
  589. /package/dist/assets/{properties-Cfh_Lj0j.js → properties-p1rx3aF7.js} +0 -0
  590. /package/dist/assets/{protobuf-Vz3fs9Hb.js → protobuf-BZ6p9Xh_.js} +0 -0
  591. /package/dist/assets/{puppet-JwSHf4DX.js → puppet-CjdIRV7D.js} +0 -0
  592. /package/dist/assets/{python-BRHQZrcc.js → python-uzyJYIWU.js} +0 -0
  593. /package/dist/assets/{q-DWFQ7YI_.js → q-CfD3i9uI.js} +0 -0
  594. /package/dist/assets/{r-DHkTNFL2.js → r-JyJdYHQB.js} +0 -0
  595. /package/dist/assets/{request-registry-BwzANGxx.js → request-registry-5ELz5pd2.js} +0 -0
  596. /package/dist/assets/{requests-BqcqF00P.js → requests-QKoDeQkn.js} +0 -0
  597. /package/dist/assets/{rpm-zbaZz_dk.js → rpm-DuGPfDyX.js} +0 -0
  598. /package/dist/assets/{ruby-COvM5Bj_.js → ruby-CA1TzLxZ.js} +0 -0
  599. /package/dist/assets/{sas-Be8P6y_s.js → sas-BJPWZC7M.js} +0 -0
  600. /package/dist/assets/{scheme-B9Zors0b.js → scheme-IRagAY3r.js} +0 -0
  601. /package/dist/assets/{shell-CaaQwZ-W.js → shell-BVpF3W_J.js} +0 -0
  602. /package/dist/assets/{sieve-CdflT_3W.js → sieve-BSfPMeZl.js} +0 -0
  603. /package/dist/assets/{simple-mode-BJAT_N3M.js → simple-mode-BmS_AmGQ.js} +0 -0
  604. /package/dist/assets/{smalltalk-CRO88y3z.js → smalltalk-CkHVehky.js} +0 -0
  605. /package/dist/assets/{solr-BkyoAXqg.js → solr-BHjX6hxO.js} +0 -0
  606. /package/dist/assets/{sparql-DEker8ZS.js → sparql-CmKKjr-f.js} +0 -0
  607. /package/dist/assets/{spreadsheet-7FZkhkVo.js → spreadsheet-ColK3G9J.js} +0 -0
  608. /package/dist/assets/{sql-BNnXxKXA.js → sql-BfkgiLSh.js} +0 -0
  609. /package/dist/assets/{src-CmKhyEBC.js → src-HwYBNPfa.js} +0 -0
  610. /package/dist/assets/{stylus-DAJwnVOa.js → stylus-D28PuRsm.js} +0 -0
  611. /package/dist/assets/{swift-D5F-FU3-.js → swift-D-jfpPuv.js} +0 -0
  612. /package/dist/assets/{tcl-DirNbhYm.js → tcl-BrQdCDVA.js} +0 -0
  613. /package/dist/assets/{textile-DhHo4rKl.js → textile-DXBc8HMq.js} +0 -0
  614. /package/dist/assets/{tiddlywiki-DE5lnTl3.js → tiddlywiki-DzM1IR9M.js} +0 -0
  615. /package/dist/assets/{tiki-Dt9oCY2i.js → tiki-DI4TiGi6.js} +0 -0
  616. /package/dist/assets/{timer-CIInKAPS.js → timer-ffBO1paY.js} +0 -0
  617. /package/dist/assets/{toml-CrP9HWVu.js → toml-ClSouHPE.js} +0 -0
  618. /package/dist/assets/{treemap-BKxvGXqJ.js → treemap-CZF0Enj1.js} +0 -0
  619. /package/dist/assets/{troff-BWD1WiE0.js → troff-BGDyQn9x.js} +0 -0
  620. /package/dist/assets/{ttcn-CQzcRj0D.js → ttcn-De1OdISX.js} +0 -0
  621. /package/dist/assets/{ttcn-cfg-jzTcqwRW.js → ttcn-cfg-CQMSrhCz.js} +0 -0
  622. /package/dist/assets/{turtle-BAqH2D2z.js → turtle-DNhfxysg.js} +0 -0
  623. /package/dist/assets/{types-z6Sk3JCV.js → types-Bhw3Hco_.js} +0 -0
  624. /package/dist/assets/{vb-CrUpzy4g.js → vb-BX7-Md9G.js} +0 -0
  625. /package/dist/assets/{vbscript-DEuHZ0Y0.js → vbscript-DNMzJOTU.js} +0 -0
  626. /package/dist/assets/{velocity-D99sTvXl.js → velocity-viirwPm7.js} +0 -0
  627. /package/dist/assets/{verilog-XWBMMjwd.js → verilog-CZguTLBV.js} +0 -0
  628. /package/dist/assets/{vhdl-BAGmVXDV.js → vhdl-CAEhCBOl.js} +0 -0
  629. /package/dist/assets/{web-vitals-BaJPM15X.js → web-vitals-CBsQ2DM_.js} +0 -0
  630. /package/dist/assets/{webidl-xagG_7hd.js → webidl-BNJg_7gX.js} +0 -0
  631. /package/dist/assets/{xquery-B8Mguhly.js → xquery-CGV_r322.js} +0 -0
  632. /package/dist/assets/{yacas-XW2NxGKw.js → yacas-uRzw7z7m.js} +0 -0
  633. /package/dist/assets/{z80-DhICfTcL.js → z80-CBK8t-9T.js} +0 -0
@@ -44,6 +44,11 @@ vi.mock("../../cell/useRunCells", () => ({
44
44
  useRunCells: vi.fn(),
45
45
  }));
46
46
 
47
+ vi.mock("../../cell/useDeleteCell", () => ({
48
+ useDeleteCellCallback: vi.fn(),
49
+ useDeleteManyCellsCallback: vi.fn(),
50
+ }));
51
+
47
52
  vi.mock("../clipboard", () => ({
48
53
  useCellClipboard: vi.fn(),
49
54
  }));
@@ -112,6 +117,7 @@ const mockSaveIfNotebookIsPersistent = vi.fn();
112
117
  const mockSaveNotebook = vi.fn();
113
118
  const mockRunCell = vi.fn();
114
119
  const mockCopyCell = vi.fn();
120
+ const mockCutCell = vi.fn().mockResolvedValue(undefined);
115
121
  const mockPasteCell = vi.fn();
116
122
 
117
123
  const mockCellActions = MockNotebook.cellActions({
@@ -165,7 +171,9 @@ describe("useCellNavigationProps", () => {
165
171
  mockUseRunCells.mockReturnValue(mockRunCell);
166
172
  mockUseCellClipboard.mockReturnValue({
167
173
  copyCells: mockCopyCell,
174
+ cutCells: mockCutCell,
168
175
  pasteAtCell: mockPasteCell,
176
+ clearPendingCut: vi.fn(),
169
177
  });
170
178
 
171
179
  // Setup default config in store
@@ -237,6 +245,45 @@ describe("useCellNavigationProps", () => {
237
245
  expect(mockEvent.preventDefault).toHaveBeenCalled();
238
246
  });
239
247
 
248
+ it("should cut cell when 'x' key is pressed", async () => {
249
+ const { result } = renderWithProvider(() =>
250
+ useCellNavigationProps(mockCellId, options),
251
+ );
252
+
253
+ const mockEvent = Mocks.keyboardEvent({ key: "x" });
254
+
255
+ await act(async () => {
256
+ result.current.onKeyDown?.(mockEvent);
257
+ await Promise.resolve();
258
+ });
259
+
260
+ expect(mockCutCell).toHaveBeenCalledWith([mockCellId]);
261
+ expect(mockEvent.preventDefault).toHaveBeenCalled();
262
+ });
263
+
264
+ it("should cut multiple selected cells when 'x' key is pressed", async () => {
265
+ const selectionActions = setupSelection();
266
+ selectionActions.select({ cellId: cellId1 });
267
+ selectionActions.extend({
268
+ cellId: cellId2,
269
+ allCellIds: store.get(notebookAtom).cellIds,
270
+ });
271
+
272
+ const { result } = renderWithProvider(() =>
273
+ useCellNavigationProps(cellId1, options),
274
+ );
275
+
276
+ const mockEvent = Mocks.keyboardEvent({ key: "x" });
277
+
278
+ await act(async () => {
279
+ result.current.onKeyDown?.(mockEvent);
280
+ await Promise.resolve();
281
+ });
282
+
283
+ expect(mockCutCell).toHaveBeenCalledWith([cellId1, cellId2]);
284
+ expect(mockEvent.preventDefault).toHaveBeenCalled();
285
+ });
286
+
240
287
  it("should paste cell when 'v' key is pressed", () => {
241
288
  const { result } = renderWithProvider(() =>
242
289
  useCellNavigationProps(mockCellId, options),
@@ -775,6 +822,29 @@ describe("useCellNavigationProps", () => {
775
822
  expect(mockEvent.preventDefault).toHaveBeenCalled();
776
823
  });
777
824
 
825
+ it("should cut multiple cells when multiple cells selected", () => {
826
+ // Set up selection of multiple cells
827
+ const selectionActions = setupSelection();
828
+ selectionActions.select({ cellId: cellId1 });
829
+ selectionActions.extend({
830
+ cellId: cellId3,
831
+ allCellIds: store.get(notebookAtom).cellIds,
832
+ });
833
+
834
+ const { result } = renderWithProvider(() =>
835
+ useCellNavigationProps(cellId2, options),
836
+ );
837
+
838
+ const mockEvent = Mocks.keyboardEvent({ key: "x" });
839
+
840
+ act(() => {
841
+ result.current.onKeyDown?.(mockEvent);
842
+ });
843
+
844
+ expect(mockCutCell).toHaveBeenCalledWith([cellId1, cellId2, cellId3]);
845
+ expect(mockEvent.preventDefault).toHaveBeenCalled();
846
+ });
847
+
778
848
  it("should move multiple cells up when multiple cells selected", () => {
779
849
  // Set up selection of multiple cells
780
850
  const selectionActions = setupSelection();
@@ -5,15 +5,22 @@ import { z } from "zod";
5
5
  import { toast } from "@/components/ui/use-toast";
6
6
  import { getNotebook, useCellActions } from "@/core/cells/cells";
7
7
  import type { CellId } from "@/core/cells/ids";
8
+ import {
9
+ usePendingCutActions,
10
+ usePendingCutState,
11
+ } from "@/core/cells/pending-cut-service";
12
+ import type { CellConfig } from "@/core/network/types";
8
13
  import { copyToClipboard } from "@/utils/copy";
9
14
  import { Logger } from "@/utils/Logger";
10
15
 
11
16
  // According to MDN, custom mimetypes should start with "web "
12
17
  const MARIMO_CELL_MIMETYPE = "web application/x-marimo-cell";
13
18
 
14
- interface ClipboardCellData {
19
+ export interface ClipboardCellData {
15
20
  cells: {
16
21
  code: string;
22
+ name?: string;
23
+ config?: CellConfig;
17
24
  }[];
18
25
  version: "1.0";
19
26
  }
@@ -22,19 +29,51 @@ const ClipboardCellDataSchema = z.object({
22
29
  cells: z.array(
23
30
  z.object({
24
31
  code: z.string(),
32
+ name: z.string().optional(),
33
+ config: z
34
+ .object({
35
+ column: z.union([z.number(), z.null()]).optional(),
36
+ disabled: z.boolean().optional(),
37
+ hide_code: z.boolean().optional(),
38
+ })
39
+ .optional(),
25
40
  }),
26
41
  ),
27
42
  version: z.literal("1.0"),
28
43
  });
29
44
 
30
- // NOTE: We don't support Cut yet. We can wait for feedback before implementing.
31
- // It is a bit more complex as will need to:
32
- // - include id, outputs, and name
33
- // - delete the existing cell, but don't place on the undo stack
34
- // - don't want to invalidate downstream cells
45
+ interface ClipboardCellInput {
46
+ code: string;
47
+ name?: string;
48
+ config?: CellConfig;
49
+ }
50
+
51
+ function toPlainText(cells: ClipboardCellInput[]): string {
52
+ return cells.map((cell) => cell.code).join("\n\n");
53
+ }
54
+
55
+ async function writeCellsToClipboard(
56
+ cells: ClipboardCellInput[],
57
+ ): Promise<void> {
58
+ const clipboardData: ClipboardCellData = {
59
+ cells: cells.map((cell) => ({
60
+ code: cell.code,
61
+ name: cell.name,
62
+ config: cell.config,
63
+ })),
64
+ version: "1.0",
65
+ };
66
+ const clipboardItem = new ClipboardItemBuilder()
67
+ .add(MARIMO_CELL_MIMETYPE, clipboardData)
68
+ .add("text/plain", toPlainText(cells))
69
+ .build();
70
+ await navigator.clipboard.write([clipboardItem]);
71
+ }
35
72
 
36
73
  export function useCellClipboard() {
37
74
  const actions = useCellActions();
75
+ const pendingCutActions = usePendingCutActions();
76
+ const pendingCutState = usePendingCutState();
38
77
 
39
78
  const copyCells = useEvent(async (cellIds: CellId[]) => {
40
79
  const notebook = getNotebook();
@@ -43,35 +82,20 @@ export function useCellClipboard() {
43
82
  .filter(Boolean);
44
83
 
45
84
  if (cells.length === 0) {
46
- // No cells to copy
47
85
  return;
48
86
  }
49
87
 
50
88
  try {
51
- const clipboardData: ClipboardCellData = {
52
- cells: cells.map((cell) => ({ code: cell.code })),
53
- version: "1.0",
54
- };
55
-
56
- // Create plain text representation (joined by newlines)
57
- const plainText = cells.map((cell) => cell.code).join("\n\n");
58
-
59
- // Create clipboard item with both custom mimetype and plain text
60
- const clipboardItem = new ClipboardItemBuilder()
61
- .add(MARIMO_CELL_MIMETYPE, clipboardData)
62
- .add("text/plain", plainText)
63
- .build();
64
-
65
- await navigator.clipboard.write([clipboardItem]);
66
-
89
+ await writeCellsToClipboard(cells);
90
+ pendingCutActions.clear();
67
91
  toastSuccess(cells.length);
68
92
  } catch (error) {
69
93
  Logger.error("Failed to copy cells to clipboard", error);
70
94
 
71
95
  // Fallback to simple text copy
72
96
  try {
73
- const plainText = cells.map((cell) => cell.code).join("\n\n");
74
- await copyToClipboard(plainText);
97
+ await copyToClipboard(toPlainText(cells));
98
+ pendingCutActions.clear();
75
99
  toastSuccess(cells.length);
76
100
  } catch {
77
101
  toastError();
@@ -79,12 +103,57 @@ export function useCellClipboard() {
79
103
  }
80
104
  });
81
105
 
106
+ const cutCells = useEvent(async (cellIds: CellId[]) => {
107
+ const notebook = getNotebook();
108
+ const validCellIds = cellIds.filter((cellId) => notebook.cellData[cellId]);
109
+ const cells = validCellIds.map((cellId) => notebook.cellData[cellId]);
110
+
111
+ if (cells.length === 0) {
112
+ return;
113
+ }
114
+
115
+ try {
116
+ await writeCellsToClipboard(cells);
117
+ pendingCutActions.markForCut({ cellIds: validCellIds });
118
+ } catch (error) {
119
+ Logger.error("Failed to cut cells to clipboard", error);
120
+ try {
121
+ await copyToClipboard(toPlainText(cells));
122
+ // Mark cells as pending cut instead of deleting immediately
123
+ pendingCutActions.markForCut({ cellIds: validCellIds });
124
+ } catch {
125
+ toastError();
126
+ }
127
+ }
128
+ });
129
+
82
130
  interface PasteOptions {
83
131
  before?: boolean;
84
132
  }
85
133
 
86
134
  const pasteAtCell = useEvent(async (cellId: CellId, opts?: PasteOptions) => {
87
135
  const { before = false } = opts ?? {};
136
+
137
+ // Check if we have pending cut cells (internal move)
138
+ if (pendingCutState.cellIds.size > 0) {
139
+ const pendingCellIds = [...pendingCutState.cellIds];
140
+ const notebook = getNotebook();
141
+ const previousPlacements = pendingCellIds.map((id) => {
142
+ const column = notebook.cellIds.findWithId(id);
143
+ return { columnId: column.id, index: column.indexOfOrThrow(id) };
144
+ });
145
+
146
+ actions.moveCellsRelativeTo({
147
+ cellIds: pendingCellIds,
148
+ targetCellId: cellId,
149
+ position: before ? "before" : "after",
150
+ previousPlacements,
151
+ });
152
+
153
+ pendingCutActions.clear();
154
+ return;
155
+ }
156
+
88
157
  try {
89
158
  const clipboardItems = await navigator.clipboard.read();
90
159
 
@@ -112,6 +181,9 @@ export function useCellClipboard() {
112
181
  cellId: currentCellId,
113
182
  before,
114
183
  code: cell.code,
184
+ name: cell.name,
185
+ config: cell.config,
186
+ hideCode: cell.config?.hide_code,
115
187
  autoFocus: true,
116
188
  });
117
189
  }
@@ -143,7 +215,9 @@ export function useCellClipboard() {
143
215
 
144
216
  return {
145
217
  copyCells,
218
+ cutCells,
146
219
  pasteAtCell,
220
+ clearPendingCut: pendingCutActions.clear,
147
221
  };
148
222
  }
149
223
 
@@ -16,6 +16,10 @@ import { cellIdsAtom, notebookAtom, useCellActions } from "@/core/cells/cells";
16
16
  import { useCellFocusActions } from "@/core/cells/focus";
17
17
  import type { CellId } from "@/core/cells/ids";
18
18
  import { HTMLCellId } from "@/core/cells/ids";
19
+ import {
20
+ clearPendingCutAtom,
21
+ pendingCutCellIdsAtom,
22
+ } from "@/core/cells/pending-cut-service";
19
23
  import { usePendingDeleteService } from "@/core/cells/pending-delete-service";
20
24
  import { scrollCellIntoView } from "@/core/cells/scrollCellIntoView";
21
25
  import {
@@ -185,7 +189,7 @@ export function useCellNavigationProps(
185
189
  const temporarilyShownCodeActions = useTemporarilyShownCodeActions();
186
190
  const runCells = useRunCells();
187
191
  const keymapPreset = useAtomValue(keymapPresetAtom);
188
- const { copyCells, pasteAtCell } = useCellClipboard();
192
+ const { copyCells, pasteAtCell, cutCells } = useCellClipboard();
189
193
  const rawSelectionActions = useCellSelectionActions();
190
194
  const isSelected = useIsCellSelected(cellId);
191
195
  const pendingDeleteService = usePendingDeleteService();
@@ -317,6 +321,12 @@ export function useCellNavigationProps(
317
321
  },
318
322
  // Clear selection
319
323
  Escape: () => {
324
+ // Clear pending cut state if any
325
+ const pendingCutCellIds = store.get(pendingCutCellIdsAtom);
326
+ if (pendingCutCellIds.size > 0) {
327
+ store.set(clearPendingCutAtom);
328
+ return true;
329
+ }
320
330
  if (isSelected) {
321
331
  selectionActions.clear();
322
332
  return true;
@@ -510,6 +520,10 @@ export function useCellNavigationProps(
510
520
  copyCells(cellIds);
511
521
  return true;
512
522
  }),
523
+ "command.cutCell": addSingleHandler((cellIds) => {
524
+ cutCells(cellIds);
525
+ return true;
526
+ }),
513
527
  "command.pasteCell": (cellIds) => {
514
528
  pasteAtCell(cellIds);
515
529
  return true;
@@ -27,6 +27,7 @@ import { Tooltip, TooltipProvider } from "@/components/ui/tooltip";
27
27
  import { aiCompletionCellAtom } from "@/core/ai/state";
28
28
  import { outputIsLoading, outputIsStale } from "@/core/cells/cell";
29
29
  import { isOutputEmpty } from "@/core/cells/outputs";
30
+ import { useIsPendingCut } from "@/core/cells/pending-cut-service";
30
31
  import { autocompletionKeymap } from "@/core/codemirror/cm";
31
32
  import type { LanguageAdapterType } from "@/core/codemirror/language/types";
32
33
  import { CSSClasses } from "@/core/constants";
@@ -391,6 +392,7 @@ const EditableCellComponent = ({
391
392
  const deleteCell = useDeleteCellCallback();
392
393
  const runCell = useRunCell(cellId);
393
394
  const { sendStdin } = useRequestClient();
395
+ const isPendingCut = useIsPendingCut(cellId);
394
396
 
395
397
  const [languageAdapter, setLanguageAdapter] = useState<LanguageAdapterType>();
396
398
 
@@ -545,6 +547,7 @@ const EditableCellComponent = ({
545
547
  }),
546
548
  borderless:
547
549
  isMarkdownCodeHidden && hasOutput && !navigationProps["data-selected"],
550
+ "pending-cut": isPendingCut,
548
551
  });
549
552
 
550
553
  const handleRefactorWithAI: OnRefactorWithAI = useEvent(
@@ -34,7 +34,10 @@ const RunPage = (props: Props) => {
34
34
 
35
35
  const Watermark = () => {
36
36
  return (
37
- <div className="fixed bottom-0 right-0 z-50" data-testid="watermark">
37
+ <div
38
+ className="fixed bottom-0 right-0 z-50 print:hidden"
39
+ data-testid="watermark"
40
+ >
38
41
  <a
39
42
  href={Constants.githubPage}
40
43
  target="_blank"
@@ -212,6 +212,20 @@ describe("cell reducer", () => {
212
212
  `);
213
213
  });
214
214
 
215
+ it("can add a cell with name and config", () => {
216
+ actions.createNewCell({
217
+ cellId: firstCellId,
218
+ before: false,
219
+ code: "x = 1",
220
+ name: "My Cell",
221
+ config: { hide_code: true, disabled: false },
222
+ });
223
+ const newCellId = state.cellIds.inOrderIds[1];
224
+ expect(state.cellData[newCellId].name).toBe("My Cell");
225
+ expect(state.cellData[newCellId].config.hide_code).toBe(true);
226
+ expect(state.cellData[newCellId].config.disabled).toBe(false);
227
+ });
228
+
215
229
  it("can delete a Python cell and undo delete", () => {
216
230
  actions.createNewCell({
217
231
  cellId: firstCellId,
@@ -602,6 +616,179 @@ describe("cell reducer", () => {
602
616
  expect(formatCells(state)).toBe(before);
603
617
  });
604
618
 
619
+ it("can move multiple cells relative to target", () => {
620
+ actions.createNewCell({
621
+ cellId: firstCellId,
622
+ before: false,
623
+ });
624
+ actions.createNewCell({
625
+ cellId: cellId("1"),
626
+ before: false,
627
+ });
628
+ expect(formatCells(state)).toMatchInlineSnapshot(`
629
+ "
630
+ [0] ''
631
+
632
+ [1] ''
633
+
634
+ [2] ''
635
+ "
636
+ `);
637
+
638
+ // Move first two cells after the third
639
+ actions.moveCellsRelativeTo({
640
+ cellIds: [firstCellId, cellId("1")],
641
+ targetCellId: cellId("2"),
642
+ position: "after",
643
+ });
644
+ expect(formatCells(state)).toMatchInlineSnapshot(`
645
+ "
646
+ [2] ''
647
+
648
+ [0] ''
649
+
650
+ [1] ''
651
+ "
652
+ `);
653
+ });
654
+
655
+ it("can undo cut-paste (move with previousPlacements)", () => {
656
+ actions.createNewCell({
657
+ cellId: firstCellId,
658
+ before: false,
659
+ });
660
+ actions.createNewCell({
661
+ cellId: cellId("1"),
662
+ before: false,
663
+ });
664
+ expect(formatCells(state)).toMatchInlineSnapshot(`
665
+ "
666
+ [0] ''
667
+
668
+ [1] ''
669
+
670
+ [2] ''
671
+ "
672
+ `);
673
+
674
+ const col = state.cellIds.findWithId(firstCellId);
675
+ const previousPlacements = [
676
+ {
677
+ columnId: col.id,
678
+ index: col.indexOfOrThrow(
679
+ firstCellId,
680
+ ) as import("@/utils/id-tree").CellIndex,
681
+ },
682
+ {
683
+ columnId: col.id,
684
+ index: col.indexOfOrThrow(
685
+ cellId("1"),
686
+ ) as import("@/utils/id-tree").CellIndex,
687
+ },
688
+ ];
689
+
690
+ actions.moveCellsRelativeTo({
691
+ cellIds: [firstCellId, cellId("1")],
692
+ targetCellId: cellId("2"),
693
+ position: "after",
694
+ previousPlacements,
695
+ });
696
+ expect(formatCells(state)).toMatchInlineSnapshot(`
697
+ "
698
+ [2] ''
699
+
700
+ [0] ''
701
+
702
+ [1] ''
703
+ "
704
+ `);
705
+
706
+ actions.undoDeleteCell();
707
+ expect(formatCells(state)).toMatchInlineSnapshot(`
708
+ "
709
+ [0] ''
710
+
711
+ [1] ''
712
+
713
+ [2] ''
714
+ "
715
+ `);
716
+ });
717
+
718
+ it("undo order: cut-paste then delete — first undo restores delete, second undo undoes move", () => {
719
+ actions.createNewCell({
720
+ cellId: firstCellId,
721
+ before: false,
722
+ });
723
+ actions.createNewCell({
724
+ cellId: cellId("1"),
725
+ before: false,
726
+ });
727
+
728
+ const col = state.cellIds.findWithId(firstCellId);
729
+ const previousPlacements = [
730
+ {
731
+ columnId: col.id,
732
+ index: col.indexOfOrThrow(
733
+ firstCellId,
734
+ ) as import("@/utils/id-tree").CellIndex,
735
+ },
736
+ {
737
+ columnId: col.id,
738
+ index: col.indexOfOrThrow(
739
+ cellId("1"),
740
+ ) as import("@/utils/id-tree").CellIndex,
741
+ },
742
+ ];
743
+
744
+ actions.moveCellsRelativeTo({
745
+ cellIds: [firstCellId, cellId("1")],
746
+ targetCellId: cellId("2"),
747
+ position: "after",
748
+ previousPlacements,
749
+ });
750
+ expect(formatCells(state)).toMatchInlineSnapshot(`
751
+ "
752
+ [2] ''
753
+
754
+ [0] ''
755
+
756
+ [1] ''
757
+ "
758
+ `);
759
+
760
+ actions.deleteCell({ cellId: cellId("2") });
761
+ expect(formatCells(state)).toMatchInlineSnapshot(`
762
+ "
763
+ [0] ''
764
+
765
+ [1] ''
766
+ "
767
+ `);
768
+
769
+ actions.undoDeleteCell();
770
+ expect(formatCells(state)).toMatchInlineSnapshot(`
771
+ "
772
+ [3] ''
773
+
774
+ [0] ''
775
+
776
+ [1] ''
777
+ "
778
+ `);
779
+
780
+ actions.undoDeleteCell();
781
+ expect(formatCells(state)).toMatchInlineSnapshot(`
782
+ "
783
+ [0] ''
784
+
785
+ [1] ''
786
+
787
+ [3] ''
788
+ "
789
+ `);
790
+ });
791
+
605
792
  it("can run cell and receive cell messages", () => {
606
793
  // HAPPY PATH
607
794
  /////////////////
@@ -0,0 +1,123 @@
1
+ /* Copyright 2026 Marimo. All rights reserved. */
2
+
3
+ import { act, renderHook } from "@testing-library/react";
4
+ import { createStore, Provider } from "jotai";
5
+ import { describe, expect, it } from "vitest";
6
+ import { cellId } from "@/__tests__/branded";
7
+ import type { CellId } from "@/core/cells/ids";
8
+ import {
9
+ pendingCutStateAtom,
10
+ useHasPendingCut,
11
+ useIsPendingCut,
12
+ usePendingCutActions,
13
+ usePendingCutState,
14
+ } from "../pending-cut-service";
15
+
16
+ function createTestWrapper() {
17
+ const store = createStore();
18
+ const wrapper = ({ children }: { children: React.ReactNode }) => (
19
+ <Provider store={store}>{children}</Provider>
20
+ );
21
+ return { wrapper, store };
22
+ }
23
+
24
+ describe("pending-cut-service", () => {
25
+ it("markForCut sets cellIds", () => {
26
+ const { wrapper, store } = createTestWrapper();
27
+ const cellIds: CellId[] = [cellId("cell-1"), cellId("cell-2")];
28
+
29
+ const { result } = renderHook(
30
+ () => ({
31
+ actions: usePendingCutActions(),
32
+ state: usePendingCutState(),
33
+ }),
34
+ { wrapper },
35
+ );
36
+
37
+ act(() => {
38
+ result.current.actions.markForCut({ cellIds });
39
+ });
40
+
41
+ const state = store.get(pendingCutStateAtom);
42
+ expect(state.cellIds).toEqual(new Set(cellIds));
43
+ });
44
+
45
+ it("clear resets to initial state", () => {
46
+ const { wrapper, store } = createTestWrapper();
47
+ const cellIds: CellId[] = [cellId("cell-1")];
48
+
49
+ const { result } = renderHook(
50
+ () => ({
51
+ actions: usePendingCutActions(),
52
+ state: usePendingCutState(),
53
+ }),
54
+ { wrapper },
55
+ );
56
+
57
+ act(() => {
58
+ result.current.actions.markForCut({ cellIds });
59
+ });
60
+ expect(store.get(pendingCutStateAtom).cellIds.size).toBe(1);
61
+
62
+ act(() => {
63
+ result.current.actions.clear();
64
+ });
65
+ const state = store.get(pendingCutStateAtom);
66
+ expect(state.cellIds.size).toBe(0);
67
+ });
68
+
69
+ it("useIsPendingCut returns true when cellId is marked for cut", () => {
70
+ const { wrapper } = createTestWrapper();
71
+ const targetCellId = cellId("cell-1");
72
+
73
+ const { result: actionsResult } = renderHook(() => usePendingCutActions(), {
74
+ wrapper,
75
+ });
76
+ const { result: isPendingResult } = renderHook(
77
+ () => useIsPendingCut(targetCellId),
78
+ { wrapper },
79
+ );
80
+
81
+ expect(isPendingResult.current).toBe(false);
82
+
83
+ act(() => {
84
+ actionsResult.current.markForCut({ cellIds: [targetCellId] });
85
+ });
86
+
87
+ expect(isPendingResult.current).toBe(true);
88
+ });
89
+
90
+ it("useIsPendingCut returns false when cellId is not marked for cut", () => {
91
+ const { wrapper } = createTestWrapper();
92
+ const { result } = renderHook(() => useIsPendingCut(cellId("other-cell")), {
93
+ wrapper,
94
+ });
95
+
96
+ const { result: actionsResult } = renderHook(() => usePendingCutActions(), {
97
+ wrapper,
98
+ });
99
+ act(() => {
100
+ actionsResult.current.markForCut({ cellIds: [cellId("cell-1")] });
101
+ });
102
+
103
+ expect(result.current).toBe(false);
104
+ });
105
+
106
+ it("useHasPendingCut returns true when any cells are marked for cut", () => {
107
+ const { wrapper } = createTestWrapper();
108
+ const { result: hasPendingResult } = renderHook(() => useHasPendingCut(), {
109
+ wrapper,
110
+ });
111
+ const { result: actionsResult } = renderHook(() => usePendingCutActions(), {
112
+ wrapper,
113
+ });
114
+
115
+ expect(hasPendingResult.current).toBe(false);
116
+
117
+ act(() => {
118
+ actionsResult.current.markForCut({ cellIds: [cellId("cell-1")] });
119
+ });
120
+
121
+ expect(hasPendingResult.current).toBe(true);
122
+ });
123
+ });