@marimo-team/frontend 0.23.6-dev2 → 0.23.6-dev21

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 (97) hide show
  1. package/dist/assets/{CellStatus-DKMrz26-.js → CellStatus-eBz5dnxe.js} +1 -1
  2. package/dist/assets/{ConnectedDataExplorerComponent-DNoHDaQW.js → ConnectedDataExplorerComponent-k8s9vETJ.js} +1 -1
  3. package/dist/assets/{JsonOutput-02ehjjSC.js → JsonOutput-DCI5rUbO.js} +1 -1
  4. package/dist/assets/{MarimoErrorOutput-Dbk0HqOA.js → MarimoErrorOutput-BBRTedcZ.js} +1 -1
  5. package/dist/assets/RenderHTML-CL9ay8Ii.js +1 -0
  6. package/dist/assets/{RunButton-DHxYW_jZ.js → RunButton-BH6H93bY.js} +1 -1
  7. package/dist/assets/{add-cell-with-ai-DfniMbLM.js → add-cell-with-ai-BHu0yrkE.js} +1 -1
  8. package/dist/assets/{add-connection-dialog-8ChtH4mo.js → add-connection-dialog-BW9DyfLG.js} +1 -1
  9. package/dist/assets/{agent-panel-jsnbrvBR.js → agent-panel-08nZa_6H.js} +1 -1
  10. package/dist/assets/ai-model-dropdown-2xg-utp6.js +5 -0
  11. package/dist/assets/{app-config-button-c_2rVezv.js → app-config-button-CLx-Gg0p.js} +1 -1
  12. package/dist/assets/{cell-editor-WSoKgacR.js → cell-editor-yeOwpn5w.js} +1 -1
  13. package/dist/assets/{cell-link-BRdZl0OJ.js → cell-link-BMyYJsGH.js} +1 -1
  14. package/dist/assets/{cells-CcBfzJ1Z.js → cells-BPSZbR83.js} +47 -47
  15. package/dist/assets/{chat-display-NiFkPnNN.js → chat-display-BVtlWWyB.js} +1 -1
  16. package/dist/assets/{chat-panel-C6V6gxrr.js → chat-panel-CrPpgbFk.js} +1 -1
  17. package/dist/assets/{chat-ui-BLiRBYhk.js → chat-ui-BdBE-cwt.js} +1 -1
  18. package/dist/assets/{column-preview-rDM8Q-wn.js → column-preview-BOUfJkSp.js} +1 -1
  19. package/dist/assets/{command-palette-CUYBVGPU.js → command-palette-Bol4aUlE.js} +1 -1
  20. package/dist/assets/{common-CHmdPmWi.js → common-CUslB949.js} +1 -1
  21. package/dist/assets/{components-HCInimq-.js → components-CVmnuvKA.js} +1 -1
  22. package/dist/assets/{components-DVKf_7RU.js → components-DPRoMb_X.js} +1 -1
  23. package/dist/assets/{config-DczIUz0b.js → config-NNGlrvbj.js} +1 -1
  24. package/dist/assets/{datasource-Czm_KBfK.js → datasource-DDj2B7Ss.js} +1 -1
  25. package/dist/assets/{dependency-graph-panel-DPKylrlr.js → dependency-graph-panel-sz_gQlcU.js} +1 -1
  26. package/dist/assets/{documentation-panel-DZkIKuPv.js → documentation-panel-B3FIOHGO.js} +1 -1
  27. package/dist/assets/{download-YUQiaxS9.js → download-B97Ad3KO.js} +1 -1
  28. package/dist/assets/{edit-page-BiwFohnL.js → edit-page-DP83zVb6.js} +3 -3
  29. package/dist/assets/{error-panel-C4UQHEjp.js → error-panel-DVmhotHi.js} +1 -1
  30. package/dist/assets/{file-explorer-panel-DEJtGGUp.js → file-explorer-panel-Dk5m8SbX.js} +1 -1
  31. package/dist/assets/{file-icons-CMxkj_kV.js → file-icons-B3v9xKEQ.js} +1 -1
  32. package/dist/assets/{floating-outline-BtNnv2IX.js → floating-outline-CEDD_IFg.js} +1 -1
  33. package/dist/assets/{focus-CXQpR65O.js → focus-BYFe-tpE.js} +1 -1
  34. package/dist/assets/{form-EgPmt17c.js → form-CrtrbmNl.js} +1 -1
  35. package/dist/assets/{glide-data-editor-CxV4Ph39.js → glide-data-editor-DqqLCmqF.js} +1 -1
  36. package/dist/assets/{globals-B-ZMi0ZU.js → globals-CZHmfW40.js} +1 -1
  37. package/dist/assets/{home-page-CaIONOO0.js → home-page-DFAczvKN.js} +1 -1
  38. package/dist/assets/{hooks-CZcajTLZ.js → hooks-BBmZdZs3.js} +1 -1
  39. package/dist/assets/{html-to-image-BHdf1t5J.js → html-to-image-BFtSv8Pw.js} +1 -1
  40. package/dist/assets/{index-CL4WR8q8.js → index-DuVXA-sG.js} +6 -6
  41. package/dist/assets/{kiosk-mode-vHMq9vr1.js → kiosk-mode-GZCnZFaF.js} +1 -1
  42. package/dist/assets/layout-Csy8Kty8.js +9 -0
  43. package/dist/assets/{logs-panel-DL9WeQsv.js → logs-panel-vIAw1PAv.js} +1 -1
  44. package/dist/assets/{markdown-renderer-DmnGXdCp.js → markdown-renderer-BySoarzx.js} +1 -1
  45. package/dist/assets/{mermaid-CXmjgj4p.js → mermaid-BfdNvRSd.js} +1 -1
  46. package/dist/assets/{name-cell-input-CHuLB3H7.js → name-cell-input-CWgwtXI1.js} +1 -1
  47. package/dist/assets/{outline-panel-JaSUHnmD.js → outline-panel-B5uTq6I8.js} +1 -1
  48. package/dist/assets/{packages-panel-BB5_Iu2c.js → packages-panel-DtGLvb39.js} +1 -1
  49. package/dist/assets/{panels-D4g3bUpO.js → panels-B9MdojaM.js} +1 -1
  50. package/dist/assets/{process-output-hJso9ugZ.js → process-output-C9OGP4VN.js} +1 -1
  51. package/dist/assets/{radio-group-6t7ozlnG.js → radio-group-C-al8pQI.js} +1 -1
  52. package/dist/assets/{readonly-python-code-JBCsN3-9.js → readonly-python-code-Dq6zyequ.js} +1 -1
  53. package/dist/assets/{renderShortcut-DZpkrZaP.js → renderShortcut-Bfk4NjRL.js} +1 -1
  54. package/dist/assets/{reveal-component-BKMB17JT.js → reveal-component-BqTsSmz7.js} +1 -1
  55. package/dist/assets/{run-page-BPM6GfJo.js → run-page-B3OKplhl.js} +1 -1
  56. package/dist/assets/{scratchpad-panel-Cabu2odx.js → scratchpad-panel-BFzS53bO.js} +1 -1
  57. package/dist/assets/{session-panel-BAiIHm0d.js → session-panel-BJN9rWqs.js} +1 -1
  58. package/dist/assets/{snippets-panel-CQKr-OMs.js → snippets-panel-Byv2itpa.js} +1 -1
  59. package/dist/assets/{state-DCT6JLba.js → state-31owe31-.js} +1 -1
  60. package/dist/assets/{state-DGoUR-mM.js → state-Bb2WcLMF.js} +1 -1
  61. package/dist/assets/{switch-ecwOrzz3.js → switch-BRZnhEsx.js} +1 -1
  62. package/dist/assets/{terminal-CQZ69wrS.js → terminal-CTa0CRvJ.js} +1 -1
  63. package/dist/assets/{textarea-BI_mXP9w.js → textarea-DvLP5rPe.js} +1 -1
  64. package/dist/assets/{tracing-BF-ca60a.js → tracing-JGGF8495.js} +1 -1
  65. package/dist/assets/{tracing-panel-D1j7Fbvr.js → tracing-panel-DgYxM6Ao.js} +2 -2
  66. package/dist/assets/{useBoolean-B_vDzBHf.js → useBoolean-XOrergn4.js} +1 -1
  67. package/dist/assets/{useCellActionButton-CcXV09GQ.js → useCellActionButton-DfeGNY_S.js} +1 -1
  68. package/dist/assets/{useDeleteCell-BVX9aH-t.js → useDeleteCell-BId7kUpZ.js} +1 -1
  69. package/dist/assets/{useDependencyPanelTab-CewdyAAy.js → useDependencyPanelTab-DDU-NsHT.js} +1 -1
  70. package/dist/assets/{useHotkey-Cm0DaHEJ.js → useHotkey-DccKPSPx.js} +1 -1
  71. package/dist/assets/useNotebookActions-Dhy6t0gn.js +1 -0
  72. package/dist/assets/{useRunCells-CgXnbA14.js → useRunCells-B9oL9NIs.js} +1 -1
  73. package/dist/assets/{useSplitCell-_Q2wQXsQ.js → useSplitCell-Cc8EEdIY.js} +1 -1
  74. package/dist/assets/{useTheme-Cb4Wekek.js → useTheme-DFXuDFj9.js} +1 -1
  75. package/dist/assets/utils-BrXijSdZ.js +1 -0
  76. package/dist/assets/{vega-component-BDK4MwYT.js → vega-component-CGpxsBwV.js} +1 -1
  77. package/dist/index.html +29 -29
  78. package/package.json +5 -5
  79. package/src/components/ai/ai-provider-icon.tsx +1 -0
  80. package/src/components/ai/ai-utils.ts +1 -0
  81. package/src/components/app-config/ai-config.tsx +30 -0
  82. package/src/components/slides/slide-form.tsx +43 -0
  83. package/src/components/ui/links.tsx +2 -1
  84. package/src/core/ai/ids/ids.ts +1 -0
  85. package/src/core/cells/__tests__/apply-transaction.test.ts +193 -27
  86. package/src/core/cells/__tests__/cells.test.ts +99 -0
  87. package/src/core/cells/__tests__/document-changes.test.ts +14 -0
  88. package/src/core/cells/cells.ts +14 -1
  89. package/src/core/cells/document-changes.ts +17 -14
  90. package/src/core/config/config-schema.ts +1 -0
  91. package/src/plugins/core/RenderHTML.tsx +49 -3
  92. package/src/plugins/core/__test__/RenderHTML.test.ts +54 -0
  93. package/dist/assets/RenderHTML-8cI8zL5y.js +0 -1
  94. package/dist/assets/ai-model-dropdown-BFTnsrTP.js +0 -5
  95. package/dist/assets/layout-DNOqvNbP.js +0 -9
  96. package/dist/assets/useNotebookActions-CWpi-dx_.js +0 -1
  97. package/dist/assets/utils-DIGrmLDO.js +0 -1
@@ -1 +1 @@
1
- import{s as z}from"./chunk-LvLJmgfZ.js";import{n as C}from"./useEvent-D91BmmQi.js";import{t as Y}from"./react-Bj1aDYRI.js";import"./react-dom-CSu739Rf.js";import{t as tt}from"./compiler-runtime-B3qBwwSJ.js";import{t as et}from"./debounce-DhnxH9Rh.js";import{_,d as T}from"./useEventListener-BR0C1MaI.js";import{n as V}from"./config-DczIUz0b.js";import{t as nt}from"./cn-DCUzRj2J.js";import{t as rt}from"./jsx-runtime-BqBOg78p.js";import"./fullscreen-BDxedMYP.js";import{t as at}from"./tooltip-Gcwqb_SK.js";import{r as it}from"./button-D9nb17Rw.js";import{d as N}from"./arrays-DYDL-3-i.js";import{u as ot}from"./toDate-B5A0DFEz.js";import"./session-VtovaFBS.js";import{r as lt}from"./useTheme-Cb4Wekek.js";import{t as ct}from"./isValid-C8T5uJYI.js";import{a as st,r as mt,t as pt}from"./utils-CGtUbqcR.js";import{n as ut}from"./vega-loader.browser-BegSZk0G.js";import{t as ft}from"./react-vega-SibldZnp.js";import"./defaultLocale-YteS-k_t.js";import"./defaultLocale-B6z1Qyqt.js";import{r as dt,t as ht}from"./alert-DvqcBMUv.js";import{n as gt}from"./error-banner-C6aBa98y.js";import{n as yt}from"./useAsyncData-BFC6lWG9.js";import{t as vt}from"./formats-Dsc8AdCp.js";import{t as H}from"./useDeepCompareMemoize-D0WTlCXt.js";var kt=tt(),S=z(Y(),1);function bt(t){return t.data&&"url"in t.data&&(t.data.url=V(t.data.url).href),t}const u={arc:"arc",area:"area",bar:"bar",image:"image",line:"line",point:"point",rect:"rect",rule:"rule",text:"text",tick:"tick",trail:"trail",circle:"circle",square:"square",geoshape:"geoshape"};var F=new Set(["boxplot","errorband","errorbar"]);const x={getMarkType(t){let e=typeof t=="string"?t:t.type;if(F.has(e))throw Error("Not supported");return e},isInteractive(t){let e=typeof t=="string"?t:t.type;return!F.has(e)},makeClickable(t){let e=typeof t=="string"?t:t.type;return e in u?typeof t=="string"?{type:t,cursor:"pointer",tooltip:!0}:{...t,type:e,cursor:"pointer",tooltip:!0}:t},getOpacity(t){return typeof t=="string"?null:"opacity"in t&&typeof t.opacity=="number"?t.opacity:null}},y={point(t){return t==null?"select_point":`select_point_${t}`},interval(t){return t==null?"select_interval":`select_interval_${t}`},legendSelection(t){return`legend_selection_${t}`},binColoring(t){return t==null?"bin_coloring":`bin_coloring_${t}`},HIGHLIGHT:"highlight",PAN_ZOOM:"pan_zoom",hasPoint(t){return t.some(e=>e.startsWith("select_point"))},hasInterval(t){return t.some(e=>e.startsWith("select_interval"))},hasLegend(t){return t.some(e=>e.startsWith("legend_selection"))},hasPanZoom(t){return t.some(e=>e.startsWith("pan_zoom"))},isBinColoring(t){return t.startsWith("bin_coloring")}},j={highlight(){return{name:y.HIGHLIGHT,select:{type:"point",on:"mouseover"}}},interval(t,e){return{name:y.interval(e),select:{type:"interval",encodings:W(t),mark:{fill:"#669EFF",fillOpacity:.07,stroke:"#669EFF",strokeOpacity:.4},on:"[mousedown[!event.metaKey], mouseup] > mousemove[!event.metaKey]",translate:"[mousedown[!event.metaKey], mouseup] > mousemove[!event.metaKey]"}}},point(t,e){return{name:y.point(e),select:{type:"point",encodings:W(t),on:"click[!event.metaKey]"}}},binColoring(t){return{name:y.binColoring(t),select:{type:"point",on:"click[!event.metaKey]"}}},legend(t){return{name:y.legendSelection(t),select:{type:"point",fields:[t]},bind:"legend"}},panZoom(){return{name:y.PAN_ZOOM,bind:"scales",select:{type:"interval",on:"[mousedown[event.metaKey], window:mouseup] > window:mousemove!",translate:"[mousedown[event.metaKey], window:mouseup] > window:mousemove!",zoom:"wheel![event.metaKey]"}}}};function W(t){switch(x.getMarkType(t.mark)){case u.image:case u.trail:return;case u.area:case u.arc:return["color"];case u.bar:{let e=wt(t);return e==="horizontal"?["y"]:e==="vertical"?["x"]:void 0}case u.circle:case u.geoshape:case u.line:case u.point:case u.rect:case u.rule:case u.square:case u.text:case u.tick:return["x","y"]}}function P(t){return"params"in t&&t.params&&t.params.length>0?N(t.params.filter(e=>e==null?!1:"select"in e&&e.select!==void 0).map(e=>e.name)):"layer"in t?N(t.layer.flatMap(P)):"vconcat"in t?N(t.vconcat.flatMap(P)):"hconcat"in t?N(t.hconcat.flatMap(P)):[]}function wt(t){var a,r;if(!t||!("mark"in t))return;let e=(a=t.encoding)==null?void 0:a.x,n=(r=t.encoding)==null?void 0:r.y;if(e&&"type"in e&&e.type==="nominal")return"vertical";if(n&&"type"in n&&n.type==="nominal"||e&&"aggregate"in e)return"horizontal";if(n&&"aggregate"in n)return"vertical"}function St(t){if(!t.encoding)return[];let e=[];for(let n of Object.values(t.encoding))n&&typeof n=="object"&&"bin"in n&&n.bin&&"field"in n&&typeof n.field=="string"&&e.push(n.field);return e}function D(t){if(!t||!("encoding"in t))return[];let{encoding:e}=t;return e?Object.entries(e).flatMap(n=>{let[a,r]=n;return!r||!xt.has(a)?[]:"field"in r&&typeof r.field=="string"?[r.field]:"condition"in r&&r.condition&&typeof r.condition=="object"&&"field"in r.condition&&r.condition.field&&typeof r.condition.field=="string"?[r.condition.field]:[]}):[]}var xt=new Set(["color","fill","fillOpacity","opacity","shape","size"]);function G(t,e,n,a){let r=n.filter(o=>y.isBinColoring(o)),i={and:(r.length>0?r:n).map(o=>({param:o}))};if(t==="opacity"){let o=x.getOpacity(a)||1;return{...e,opacity:{condition:{test:i,value:o},value:o/5}}}else return e}function At(t){if(!("select"in t)||!t.select)return JSON.stringify(t);let e=t.select;if(typeof e=="string")return JSON.stringify({type:e,bind:t.bind});let n={type:e.type,encodings:"encodings"in e&&e.encodings?[...e.encodings].toSorted():void 0,fields:"fields"in e&&e.fields?[...e.fields].toSorted():void 0,bind:t.bind};return JSON.stringify(n)}function $(t){let e=E(t);if(e.length===0)return t;let n=_t(e);return n.length===0?t:{...L(K(t,new Set(n.map(a=>a.name))),n.map(a=>a.name)),params:[...t.params||[],...n]}}function E(t){let e=[];if("vconcat"in t&&Array.isArray(t.vconcat))for(let n of t.vconcat)e.push(...E(n));else if("hconcat"in t&&Array.isArray(t.hconcat))for(let n of t.hconcat)e.push(...E(n));else{if("layer"in t)return[];"mark"in t&&"params"in t&&t.params&&t.params.length>0&&e.push({params:t.params})}return e}function _t(t){if(t.length===0)return[];let e=new Map,n=t.length;for(let{params:r}of t){let i=new Set;for(let o of r){let l=At(o);i.has(l)||(i.add(l),e.has(l)||e.set(l,{count:0,param:o}),e.get(l).count++)}}let a=[];for(let[,{count:r,param:i}]of e)r===n&&a.push(i);return a}function K(t,e){if("vconcat"in t&&Array.isArray(t.vconcat))return{...t,vconcat:t.vconcat.map(n=>K(n,e))};if("hconcat"in t&&Array.isArray(t.hconcat))return{...t,hconcat:t.hconcat.map(n=>K(n,e))};if("mark"in t&&"params"in t&&t.params){let n=t.params,a=[];for(let r of n){if(!r||typeof r!="object"||!("name"in r)){a.push(r);continue}e.has(r.name)||a.push(r)}if(a.length===0){let{params:r,...i}=t;return i}return{...t,params:a}}return t}function L(t,e){return"vconcat"in t&&Array.isArray(t.vconcat)?{...t,vconcat:t.vconcat.map(n=>L(n,e))}:"hconcat"in t&&Array.isArray(t.hconcat)?{...t,hconcat:t.hconcat.map(n=>L(n,e))}:"layer"in t?t:"mark"in t&&x.isInteractive(t.mark)?{...t,mark:x.makeClickable(t.mark),encoding:G("opacity",t.encoding||{},e,t.mark)}:t}function Z(t,e){var l,k;let{chartSelection:n=!0,fieldSelection:a=!0}=e;if(!n&&!a)return t;(l=t.params)!=null&&l.some(s=>s.bind==="legend")&&(a=!1);let r=(k=t.params)==null?void 0:k.some(s=>!s.bind);r&&(n=!1);let i="vconcat"in t||"hconcat"in t;if(r&&i)return t;if("vconcat"in t){let s=t.vconcat.map(m=>"mark"in m?Z(m,{chartSelection:n,fieldSelection:a}):m);return $({...t,vconcat:s})}if("hconcat"in t){let s=t.hconcat.map(m=>"mark"in m?Z(m,{chartSelection:n,fieldSelection:a}):m);return $({...t,hconcat:s})}if("layer"in t){let s=t.params&&t.params.length>0,m=a!==!1&&!s,v=[];if(m){let p=t.layer.flatMap(f=>"mark"in f?D(f):[]);v=[...new Set(p)],Array.isArray(a)&&(v=v.filter(f=>a.includes(f)))}let w=t.layer.map((p,f)=>{if(!("mark"in p))return p;let h=p;if(f===0&&v.length>0){let O=v.map(M=>j.legend(M));h={...h,params:[...h.params||[],...O]}}return h=q(h,n,f),h=R(h),f===0&&(h=J(h)),h});return{...t,layer:w}}if(!("mark"in t)||!x.isInteractive(t.mark))return t;let o=t;return o=jt(o,a),o=q(o,n,void 0),o=R(o),o=J(o),o}function jt(t,e){if(e===!1)return t;let n=D(t);Array.isArray(e)&&(n=n.filter(i=>e.includes(i)));let a=n.map(i=>j.legend(i)),r=[...t.params||[],...a];return{...t,params:r}}function q(t,e,n){if(e===!1)return t;let a;try{a=x.getMarkType(t.mark)}catch{return t}if(a==="geoshape")return t;let r=St(t),i=e===!0?r.length>0?["point"]:Ot(a):[e];if(!i||i.length===0)return t;let o=i.map(k=>k==="interval"?j.interval(t,n):j.point(t,n)),l=[...t.params||[],...o];return r.length>0&&i.includes("point")&&l.push(j.binColoring(n)),{...t,params:l}}function J(t){let e;try{e=x.getMarkType(t.mark)}catch{}if(e==="geoshape")return t;let n=t.params||[];return n.some(a=>a.bind==="scales")?t:{...t,params:[...n,j.panZoom()]}}function R(t){let e="encoding"in t?t.encoding:void 0,n=t.params||[],a=n.map(r=>r.name);return n.length===0||!x.isInteractive(t.mark)?t:{...t,mark:x.makeClickable(t.mark),encoding:G("opacity",e||{},a,t.mark)}}function Ot(t){switch(t){case"arc":case"area":return["point"];case"text":case"bar":return["point","interval"];case"line":return;default:return["point","interval"]}}async function Mt(t){if(!t)return t;let e="datasets"in t?{...t.datasets}:{},n=async r=>{if(!r)return r;if("layer"in r){let l=await Promise.all(r.layer.map(n));r={...r,layer:l}}if("hconcat"in r){let l=await Promise.all(r.hconcat.map(n));r={...r,hconcat:l}}if("vconcat"in r){let l=await Promise.all(r.vconcat.map(n));r={...r,vconcat:l}}if("spec"in r&&(r={...r,spec:await n(r.spec)}),!r.data||!("url"in r.data))return r;let i;try{i=V(r.data.url)}catch{return r}let o=await st(i.href,r.data.format);return e[i.pathname]=o,{...r,data:{name:i.pathname}}},a=await n(t);return Object.keys(e).length===0?a:{...a,datasets:e}}var d=z(rt(),1);ut("arrow",vt);var Nt=t=>{let e=(0,kt.c)(12),{value:n,setValue:a,chartSelection:r,fieldSelection:i,spec:o,embedOptions:l}=t,k,s;e[0]===o?(k=e[1],s=e[2]):(k=async()=>Mt(o),s=[o],e[0]=o,e[1]=k,e[2]=s);let{data:m,error:v}=yt(k,s);if(v){let p;return e[3]===v?p=e[4]:(p=(0,d.jsx)(gt,{error:v}),e[3]=v,e[4]=p),p}if(!m)return null;let w;return e[5]!==r||e[6]!==l||e[7]!==i||e[8]!==m||e[9]!==a||e[10]!==n?(w=(0,d.jsx)(Pt,{value:n,setValue:a,chartSelection:r,fieldSelection:i,spec:m,embedOptions:l}),e[5]=r,e[6]=l,e[7]=i,e[8]=m,e[9]=a,e[10]=n,e[11]=w):w=e[11],w},Pt=({value:t,setValue:e,chartSelection:n,fieldSelection:a,spec:r,embedOptions:i})=>{let{theme:o}=lt(),l=(0,S.useRef)(null),k=(0,S.useRef)(void 0),[s,m]=(0,S.useState)(),v=(0,S.useMemo)(()=>i&&"actions"in i?i.actions:{source:!1,compiled:!1},[i]),w=H(r),p=(0,S.useMemo)(()=>Z(bt(w),{chartSelection:n,fieldSelection:a}),[w,n,a]),f=(0,S.useMemo)(()=>P(p),[p]),h=C(c=>{e({...t,...c})}),O=(0,S.useMemo)(()=>et((c,g)=>{_.debug("[Vega signal]",c,g);let b=T.mapValues(g,Ct);b=T.mapValues(b,It),h({[c]:b})},100),[h]),M=H(f),I=(0,S.useMemo)(()=>M.reduce((c,g)=>(y.PAN_ZOOM===g||y.isBinColoring(g)||c.push({signalName:g,handler:(b,X)=>O(b,X)}),c),[]),[M,O]),B=C(c=>{_.error(c),_.debug(p),m(c)}),Q=C(c=>{_.debug("[Vega view] created",c),k.current=c,m(void 0)}),U=()=>{let c=[];return y.hasPoint(f)&&c.push(["Point selection","click to select a point; hold shift for multi-select"]),y.hasInterval(f)&&c.push(["Interval selection","click and drag to select an interval"]),y.hasLegend(f)&&c.push(["Legend selection","click to select a legend item; hold shift for multi-select"]),y.hasPanZoom(f)&&c.push(["Pan","hold the meta key and drag"],["Zoom","hold the meta key and scroll"]),c.length===0?null:(0,d.jsx)(at,{delayDuration:300,side:"left",content:(0,d.jsx)("div",{className:"text-xs flex flex-col",children:c.map((g,b)=>(0,d.jsxs)("div",{children:[(0,d.jsxs)("span",{className:"font-bold tracking-wide",children:[g[0],":"]})," ",g[1]]},b))}),children:(0,d.jsx)(ot,{className:"absolute bottom-1 right-0 m-2 h-4 w-4 cursor-help text-muted-foreground hover:text-foreground"})})},A=ft({ref:l,spec:p,options:{theme:o==="dark"?"dark":void 0,actions:v,mode:"vega-lite",tooltip:mt.call,renderer:"canvas"},onError:B,onEmbed:Q});return(0,S.useEffect)(()=>(I.forEach(({signalName:c,handler:g})=>{try{A==null||A.view.addSignalListener(c,g)}catch(b){_.error(b)}}),()=>{I.forEach(({signalName:c,handler:g})=>{try{A==null||A.view.removeSignalListener(c,g)}catch(b){_.error(b)}})}),[A,I]),(0,d.jsxs)(d.Fragment,{children:[s&&(0,d.jsxs)(ht,{variant:"destructive",children:[(0,d.jsx)(dt,{children:s.message}),(0,d.jsx)("div",{className:"text-md",children:s.stack})]}),(0,d.jsxs)("div",{className:nt("relative"),onPointerDown:it.stopPropagation(),children:[(0,d.jsx)("div",{ref:l,"data-container-width":pt(p)}),U()]})]})};function It(t){return t instanceof Set?[...t]:t}function Ct(t){return Array.isArray(t)?t.map(e=>e instanceof Date&&ct(e)?new Date(e).getTime():e):t}var Et=Nt;export{Et as default};
1
+ import{s as z}from"./chunk-LvLJmgfZ.js";import{n as C}from"./useEvent-D91BmmQi.js";import{t as Y}from"./react-Bj1aDYRI.js";import"./react-dom-CSu739Rf.js";import{t as tt}from"./compiler-runtime-B3qBwwSJ.js";import{t as et}from"./debounce-DhnxH9Rh.js";import{_,d as T}from"./useEventListener-BR0C1MaI.js";import{n as V}from"./config-NNGlrvbj.js";import{t as nt}from"./cn-DCUzRj2J.js";import{t as rt}from"./jsx-runtime-BqBOg78p.js";import"./fullscreen-BDxedMYP.js";import{t as at}from"./tooltip-Gcwqb_SK.js";import{r as it}from"./button-D9nb17Rw.js";import{d as N}from"./arrays-DYDL-3-i.js";import{u as ot}from"./toDate-B5A0DFEz.js";import"./session-VtovaFBS.js";import{r as lt}from"./useTheme-DFXuDFj9.js";import{t as ct}from"./isValid-C8T5uJYI.js";import{a as st,r as mt,t as pt}from"./utils-CGtUbqcR.js";import{n as ut}from"./vega-loader.browser-BegSZk0G.js";import{t as ft}from"./react-vega-SibldZnp.js";import"./defaultLocale-YteS-k_t.js";import"./defaultLocale-B6z1Qyqt.js";import{r as dt,t as ht}from"./alert-DvqcBMUv.js";import{n as gt}from"./error-banner-C6aBa98y.js";import{n as yt}from"./useAsyncData-BFC6lWG9.js";import{t as vt}from"./formats-Dsc8AdCp.js";import{t as H}from"./useDeepCompareMemoize-D0WTlCXt.js";var kt=tt(),S=z(Y(),1);function bt(t){return t.data&&"url"in t.data&&(t.data.url=V(t.data.url).href),t}const u={arc:"arc",area:"area",bar:"bar",image:"image",line:"line",point:"point",rect:"rect",rule:"rule",text:"text",tick:"tick",trail:"trail",circle:"circle",square:"square",geoshape:"geoshape"};var F=new Set(["boxplot","errorband","errorbar"]);const x={getMarkType(t){let e=typeof t=="string"?t:t.type;if(F.has(e))throw Error("Not supported");return e},isInteractive(t){let e=typeof t=="string"?t:t.type;return!F.has(e)},makeClickable(t){let e=typeof t=="string"?t:t.type;return e in u?typeof t=="string"?{type:t,cursor:"pointer",tooltip:!0}:{...t,type:e,cursor:"pointer",tooltip:!0}:t},getOpacity(t){return typeof t=="string"?null:"opacity"in t&&typeof t.opacity=="number"?t.opacity:null}},y={point(t){return t==null?"select_point":`select_point_${t}`},interval(t){return t==null?"select_interval":`select_interval_${t}`},legendSelection(t){return`legend_selection_${t}`},binColoring(t){return t==null?"bin_coloring":`bin_coloring_${t}`},HIGHLIGHT:"highlight",PAN_ZOOM:"pan_zoom",hasPoint(t){return t.some(e=>e.startsWith("select_point"))},hasInterval(t){return t.some(e=>e.startsWith("select_interval"))},hasLegend(t){return t.some(e=>e.startsWith("legend_selection"))},hasPanZoom(t){return t.some(e=>e.startsWith("pan_zoom"))},isBinColoring(t){return t.startsWith("bin_coloring")}},j={highlight(){return{name:y.HIGHLIGHT,select:{type:"point",on:"mouseover"}}},interval(t,e){return{name:y.interval(e),select:{type:"interval",encodings:W(t),mark:{fill:"#669EFF",fillOpacity:.07,stroke:"#669EFF",strokeOpacity:.4},on:"[mousedown[!event.metaKey], mouseup] > mousemove[!event.metaKey]",translate:"[mousedown[!event.metaKey], mouseup] > mousemove[!event.metaKey]"}}},point(t,e){return{name:y.point(e),select:{type:"point",encodings:W(t),on:"click[!event.metaKey]"}}},binColoring(t){return{name:y.binColoring(t),select:{type:"point",on:"click[!event.metaKey]"}}},legend(t){return{name:y.legendSelection(t),select:{type:"point",fields:[t]},bind:"legend"}},panZoom(){return{name:y.PAN_ZOOM,bind:"scales",select:{type:"interval",on:"[mousedown[event.metaKey], window:mouseup] > window:mousemove!",translate:"[mousedown[event.metaKey], window:mouseup] > window:mousemove!",zoom:"wheel![event.metaKey]"}}}};function W(t){switch(x.getMarkType(t.mark)){case u.image:case u.trail:return;case u.area:case u.arc:return["color"];case u.bar:{let e=wt(t);return e==="horizontal"?["y"]:e==="vertical"?["x"]:void 0}case u.circle:case u.geoshape:case u.line:case u.point:case u.rect:case u.rule:case u.square:case u.text:case u.tick:return["x","y"]}}function P(t){return"params"in t&&t.params&&t.params.length>0?N(t.params.filter(e=>e==null?!1:"select"in e&&e.select!==void 0).map(e=>e.name)):"layer"in t?N(t.layer.flatMap(P)):"vconcat"in t?N(t.vconcat.flatMap(P)):"hconcat"in t?N(t.hconcat.flatMap(P)):[]}function wt(t){var a,r;if(!t||!("mark"in t))return;let e=(a=t.encoding)==null?void 0:a.x,n=(r=t.encoding)==null?void 0:r.y;if(e&&"type"in e&&e.type==="nominal")return"vertical";if(n&&"type"in n&&n.type==="nominal"||e&&"aggregate"in e)return"horizontal";if(n&&"aggregate"in n)return"vertical"}function St(t){if(!t.encoding)return[];let e=[];for(let n of Object.values(t.encoding))n&&typeof n=="object"&&"bin"in n&&n.bin&&"field"in n&&typeof n.field=="string"&&e.push(n.field);return e}function D(t){if(!t||!("encoding"in t))return[];let{encoding:e}=t;return e?Object.entries(e).flatMap(n=>{let[a,r]=n;return!r||!xt.has(a)?[]:"field"in r&&typeof r.field=="string"?[r.field]:"condition"in r&&r.condition&&typeof r.condition=="object"&&"field"in r.condition&&r.condition.field&&typeof r.condition.field=="string"?[r.condition.field]:[]}):[]}var xt=new Set(["color","fill","fillOpacity","opacity","shape","size"]);function G(t,e,n,a){let r=n.filter(o=>y.isBinColoring(o)),i={and:(r.length>0?r:n).map(o=>({param:o}))};if(t==="opacity"){let o=x.getOpacity(a)||1;return{...e,opacity:{condition:{test:i,value:o},value:o/5}}}else return e}function At(t){if(!("select"in t)||!t.select)return JSON.stringify(t);let e=t.select;if(typeof e=="string")return JSON.stringify({type:e,bind:t.bind});let n={type:e.type,encodings:"encodings"in e&&e.encodings?[...e.encodings].toSorted():void 0,fields:"fields"in e&&e.fields?[...e.fields].toSorted():void 0,bind:t.bind};return JSON.stringify(n)}function $(t){let e=E(t);if(e.length===0)return t;let n=_t(e);return n.length===0?t:{...L(K(t,new Set(n.map(a=>a.name))),n.map(a=>a.name)),params:[...t.params||[],...n]}}function E(t){let e=[];if("vconcat"in t&&Array.isArray(t.vconcat))for(let n of t.vconcat)e.push(...E(n));else if("hconcat"in t&&Array.isArray(t.hconcat))for(let n of t.hconcat)e.push(...E(n));else{if("layer"in t)return[];"mark"in t&&"params"in t&&t.params&&t.params.length>0&&e.push({params:t.params})}return e}function _t(t){if(t.length===0)return[];let e=new Map,n=t.length;for(let{params:r}of t){let i=new Set;for(let o of r){let l=At(o);i.has(l)||(i.add(l),e.has(l)||e.set(l,{count:0,param:o}),e.get(l).count++)}}let a=[];for(let[,{count:r,param:i}]of e)r===n&&a.push(i);return a}function K(t,e){if("vconcat"in t&&Array.isArray(t.vconcat))return{...t,vconcat:t.vconcat.map(n=>K(n,e))};if("hconcat"in t&&Array.isArray(t.hconcat))return{...t,hconcat:t.hconcat.map(n=>K(n,e))};if("mark"in t&&"params"in t&&t.params){let n=t.params,a=[];for(let r of n){if(!r||typeof r!="object"||!("name"in r)){a.push(r);continue}e.has(r.name)||a.push(r)}if(a.length===0){let{params:r,...i}=t;return i}return{...t,params:a}}return t}function L(t,e){return"vconcat"in t&&Array.isArray(t.vconcat)?{...t,vconcat:t.vconcat.map(n=>L(n,e))}:"hconcat"in t&&Array.isArray(t.hconcat)?{...t,hconcat:t.hconcat.map(n=>L(n,e))}:"layer"in t?t:"mark"in t&&x.isInteractive(t.mark)?{...t,mark:x.makeClickable(t.mark),encoding:G("opacity",t.encoding||{},e,t.mark)}:t}function Z(t,e){var l,k;let{chartSelection:n=!0,fieldSelection:a=!0}=e;if(!n&&!a)return t;(l=t.params)!=null&&l.some(s=>s.bind==="legend")&&(a=!1);let r=(k=t.params)==null?void 0:k.some(s=>!s.bind);r&&(n=!1);let i="vconcat"in t||"hconcat"in t;if(r&&i)return t;if("vconcat"in t){let s=t.vconcat.map(m=>"mark"in m?Z(m,{chartSelection:n,fieldSelection:a}):m);return $({...t,vconcat:s})}if("hconcat"in t){let s=t.hconcat.map(m=>"mark"in m?Z(m,{chartSelection:n,fieldSelection:a}):m);return $({...t,hconcat:s})}if("layer"in t){let s=t.params&&t.params.length>0,m=a!==!1&&!s,v=[];if(m){let p=t.layer.flatMap(f=>"mark"in f?D(f):[]);v=[...new Set(p)],Array.isArray(a)&&(v=v.filter(f=>a.includes(f)))}let w=t.layer.map((p,f)=>{if(!("mark"in p))return p;let h=p;if(f===0&&v.length>0){let O=v.map(M=>j.legend(M));h={...h,params:[...h.params||[],...O]}}return h=q(h,n,f),h=R(h),f===0&&(h=J(h)),h});return{...t,layer:w}}if(!("mark"in t)||!x.isInteractive(t.mark))return t;let o=t;return o=jt(o,a),o=q(o,n,void 0),o=R(o),o=J(o),o}function jt(t,e){if(e===!1)return t;let n=D(t);Array.isArray(e)&&(n=n.filter(i=>e.includes(i)));let a=n.map(i=>j.legend(i)),r=[...t.params||[],...a];return{...t,params:r}}function q(t,e,n){if(e===!1)return t;let a;try{a=x.getMarkType(t.mark)}catch{return t}if(a==="geoshape")return t;let r=St(t),i=e===!0?r.length>0?["point"]:Ot(a):[e];if(!i||i.length===0)return t;let o=i.map(k=>k==="interval"?j.interval(t,n):j.point(t,n)),l=[...t.params||[],...o];return r.length>0&&i.includes("point")&&l.push(j.binColoring(n)),{...t,params:l}}function J(t){let e;try{e=x.getMarkType(t.mark)}catch{}if(e==="geoshape")return t;let n=t.params||[];return n.some(a=>a.bind==="scales")?t:{...t,params:[...n,j.panZoom()]}}function R(t){let e="encoding"in t?t.encoding:void 0,n=t.params||[],a=n.map(r=>r.name);return n.length===0||!x.isInteractive(t.mark)?t:{...t,mark:x.makeClickable(t.mark),encoding:G("opacity",e||{},a,t.mark)}}function Ot(t){switch(t){case"arc":case"area":return["point"];case"text":case"bar":return["point","interval"];case"line":return;default:return["point","interval"]}}async function Mt(t){if(!t)return t;let e="datasets"in t?{...t.datasets}:{},n=async r=>{if(!r)return r;if("layer"in r){let l=await Promise.all(r.layer.map(n));r={...r,layer:l}}if("hconcat"in r){let l=await Promise.all(r.hconcat.map(n));r={...r,hconcat:l}}if("vconcat"in r){let l=await Promise.all(r.vconcat.map(n));r={...r,vconcat:l}}if("spec"in r&&(r={...r,spec:await n(r.spec)}),!r.data||!("url"in r.data))return r;let i;try{i=V(r.data.url)}catch{return r}let o=await st(i.href,r.data.format);return e[i.pathname]=o,{...r,data:{name:i.pathname}}},a=await n(t);return Object.keys(e).length===0?a:{...a,datasets:e}}var d=z(rt(),1);ut("arrow",vt);var Nt=t=>{let e=(0,kt.c)(12),{value:n,setValue:a,chartSelection:r,fieldSelection:i,spec:o,embedOptions:l}=t,k,s;e[0]===o?(k=e[1],s=e[2]):(k=async()=>Mt(o),s=[o],e[0]=o,e[1]=k,e[2]=s);let{data:m,error:v}=yt(k,s);if(v){let p;return e[3]===v?p=e[4]:(p=(0,d.jsx)(gt,{error:v}),e[3]=v,e[4]=p),p}if(!m)return null;let w;return e[5]!==r||e[6]!==l||e[7]!==i||e[8]!==m||e[9]!==a||e[10]!==n?(w=(0,d.jsx)(Pt,{value:n,setValue:a,chartSelection:r,fieldSelection:i,spec:m,embedOptions:l}),e[5]=r,e[6]=l,e[7]=i,e[8]=m,e[9]=a,e[10]=n,e[11]=w):w=e[11],w},Pt=({value:t,setValue:e,chartSelection:n,fieldSelection:a,spec:r,embedOptions:i})=>{let{theme:o}=lt(),l=(0,S.useRef)(null),k=(0,S.useRef)(void 0),[s,m]=(0,S.useState)(),v=(0,S.useMemo)(()=>i&&"actions"in i?i.actions:{source:!1,compiled:!1},[i]),w=H(r),p=(0,S.useMemo)(()=>Z(bt(w),{chartSelection:n,fieldSelection:a}),[w,n,a]),f=(0,S.useMemo)(()=>P(p),[p]),h=C(c=>{e({...t,...c})}),O=(0,S.useMemo)(()=>et((c,g)=>{_.debug("[Vega signal]",c,g);let b=T.mapValues(g,Ct);b=T.mapValues(b,It),h({[c]:b})},100),[h]),M=H(f),I=(0,S.useMemo)(()=>M.reduce((c,g)=>(y.PAN_ZOOM===g||y.isBinColoring(g)||c.push({signalName:g,handler:(b,X)=>O(b,X)}),c),[]),[M,O]),B=C(c=>{_.error(c),_.debug(p),m(c)}),Q=C(c=>{_.debug("[Vega view] created",c),k.current=c,m(void 0)}),U=()=>{let c=[];return y.hasPoint(f)&&c.push(["Point selection","click to select a point; hold shift for multi-select"]),y.hasInterval(f)&&c.push(["Interval selection","click and drag to select an interval"]),y.hasLegend(f)&&c.push(["Legend selection","click to select a legend item; hold shift for multi-select"]),y.hasPanZoom(f)&&c.push(["Pan","hold the meta key and drag"],["Zoom","hold the meta key and scroll"]),c.length===0?null:(0,d.jsx)(at,{delayDuration:300,side:"left",content:(0,d.jsx)("div",{className:"text-xs flex flex-col",children:c.map((g,b)=>(0,d.jsxs)("div",{children:[(0,d.jsxs)("span",{className:"font-bold tracking-wide",children:[g[0],":"]})," ",g[1]]},b))}),children:(0,d.jsx)(ot,{className:"absolute bottom-1 right-0 m-2 h-4 w-4 cursor-help text-muted-foreground hover:text-foreground"})})},A=ft({ref:l,spec:p,options:{theme:o==="dark"?"dark":void 0,actions:v,mode:"vega-lite",tooltip:mt.call,renderer:"canvas"},onError:B,onEmbed:Q});return(0,S.useEffect)(()=>(I.forEach(({signalName:c,handler:g})=>{try{A==null||A.view.addSignalListener(c,g)}catch(b){_.error(b)}}),()=>{I.forEach(({signalName:c,handler:g})=>{try{A==null||A.view.removeSignalListener(c,g)}catch(b){_.error(b)}})}),[A,I]),(0,d.jsxs)(d.Fragment,{children:[s&&(0,d.jsxs)(ht,{variant:"destructive",children:[(0,d.jsx)(dt,{children:s.message}),(0,d.jsx)("div",{className:"text-md",children:s.stack})]}),(0,d.jsxs)("div",{className:nt("relative"),onPointerDown:it.stopPropagation(),children:[(0,d.jsx)("div",{ref:l,"data-container-width":pt(p)}),U()]})]})};function It(t){return t instanceof Set?[...t]:t}function Ct(t){return Array.isArray(t)?t.map(e=>e instanceof Date&&ct(e)?new Date(e).getTime():e):t}var Et=Nt;export{Et as default};
package/dist/index.html CHANGED
@@ -66,7 +66,7 @@
66
66
  <marimo-server-token data-token="{{ server_token }}" hidden></marimo-server-token>
67
67
  <!-- /TODO -->
68
68
  <title>{{ title }}</title>
69
- <script type="module" crossorigin src="./assets/index-CL4WR8q8.js"></script>
69
+ <script type="module" crossorigin src="./assets/index-DuVXA-sG.js"></script>
70
70
  <link rel="modulepreload" crossorigin href="./assets/preload-helper-DItdS47A.js">
71
71
  <link rel="modulepreload" crossorigin href="./assets/chunk-LvLJmgfZ.js">
72
72
  <link rel="modulepreload" crossorigin href="./assets/react-Bj1aDYRI.js">
@@ -98,17 +98,17 @@
98
98
  <link rel="modulepreload" crossorigin href="./assets/_baseFor-DKD1r8uL.js">
99
99
  <link rel="modulepreload" crossorigin href="./assets/merge-_9WLTEyt.js">
100
100
  <link rel="modulepreload" crossorigin href="./assets/zod-H_cgTO0M.js">
101
- <link rel="modulepreload" crossorigin href="./assets/utils-DIGrmLDO.js">
101
+ <link rel="modulepreload" crossorigin href="./assets/utils-BrXijSdZ.js">
102
102
  <link rel="modulepreload" crossorigin href="./assets/Deferred-DMWKlZOV.js">
103
103
  <link rel="modulepreload" crossorigin href="./assets/uuid-DercMavo.js">
104
104
  <link rel="modulepreload" crossorigin href="./assets/DeferredRequestRegistry-CUzZ0y7K.js">
105
105
  <link rel="modulepreload" crossorigin href="./assets/constants-DMpttj8Q.js">
106
106
  <link rel="modulepreload" crossorigin href="./assets/session-VtovaFBS.js">
107
- <link rel="modulepreload" crossorigin href="./assets/config-DczIUz0b.js">
107
+ <link rel="modulepreload" crossorigin href="./assets/config-NNGlrvbj.js">
108
108
  <link rel="modulepreload" crossorigin href="./assets/requests-DIwGYs0l.js">
109
109
  <link rel="modulepreload" crossorigin href="./assets/useLifecycle-DieWOfXE.js">
110
110
  <link rel="modulepreload" crossorigin href="./assets/useNonce-DfoVjkkH.js">
111
- <link rel="modulepreload" crossorigin href="./assets/useTheme-Cb4Wekek.js">
111
+ <link rel="modulepreload" crossorigin href="./assets/useTheme-DFXuDFj9.js">
112
112
  <link rel="modulepreload" crossorigin href="./assets/arrays-DYDL-3-i.js">
113
113
  <link rel="modulepreload" crossorigin href="./assets/strings-md4mFbOQ.js">
114
114
  <link rel="modulepreload" crossorigin href="./assets/once-DRroIaBz.js">
@@ -133,7 +133,7 @@
133
133
  <link rel="modulepreload" crossorigin href="./assets/debounce-DhnxH9Rh.js">
134
134
  <link rel="modulepreload" crossorigin href="./assets/database-zap-kIkTfzTX.js">
135
135
  <link rel="modulepreload" crossorigin href="./assets/main-B0OX4z33.js">
136
- <link rel="modulepreload" crossorigin href="./assets/cells-CcBfzJ1Z.js">
136
+ <link rel="modulepreload" crossorigin href="./assets/cells-BPSZbR83.js">
137
137
  <link rel="modulepreload" crossorigin href="./assets/ErrorBoundary-DzYV_VeY.js">
138
138
  <link rel="modulepreload" crossorigin href="./assets/kbd-B3Breaz2.js">
139
139
  <link rel="modulepreload" crossorigin href="./assets/useInstallPackage-D0NLybAx.js">
@@ -147,33 +147,33 @@
147
147
  <link rel="modulepreload" crossorigin href="./assets/usePress-CfcdTqJM.js">
148
148
  <link rel="modulepreload" crossorigin href="./assets/input-BX98vgAu.js">
149
149
  <link rel="modulepreload" crossorigin href="./assets/ImperativeModal-D7lQ0Q7_.js">
150
- <link rel="modulepreload" crossorigin href="./assets/cell-link-BRdZl0OJ.js">
150
+ <link rel="modulepreload" crossorigin href="./assets/cell-link-BMyYJsGH.js">
151
151
  <link rel="modulepreload" crossorigin href="./assets/multi-map-rafH3cg3.js">
152
152
  <link rel="modulepreload" crossorigin href="./assets/alert-DvqcBMUv.js">
153
153
  <link rel="modulepreload" crossorigin href="./assets/chevron-right-CG5QYXYk.js">
154
154
  <link rel="modulepreload" crossorigin href="./assets/dropdown-menu-D1A3cFC8.js">
155
155
  <link rel="modulepreload" crossorigin href="./assets/links-Dpap8NI2.js">
156
- <link rel="modulepreload" crossorigin href="./assets/useRunCells-CgXnbA14.js">
156
+ <link rel="modulepreload" crossorigin href="./assets/useRunCells-B9oL9NIs.js">
157
157
  <link rel="modulepreload" crossorigin href="./assets/copy-BCF-tANo.js">
158
158
  <link rel="modulepreload" crossorigin href="./assets/copy-BwrPA9zQ.js">
159
159
  <link rel="modulepreload" crossorigin href="./assets/copy-icon-BYNydU7b.js">
160
- <link rel="modulepreload" crossorigin href="./assets/RenderHTML-8cI8zL5y.js">
161
- <link rel="modulepreload" crossorigin href="./assets/datasource-Czm_KBfK.js">
162
- <link rel="modulepreload" crossorigin href="./assets/state-DCT6JLba.js">
160
+ <link rel="modulepreload" crossorigin href="./assets/RenderHTML-CL9ay8Ii.js">
161
+ <link rel="modulepreload" crossorigin href="./assets/datasource-DDj2B7Ss.js">
162
+ <link rel="modulepreload" crossorigin href="./assets/state-31owe31-.js">
163
163
  <link rel="modulepreload" crossorigin href="./assets/sparkles-CZ5WmLPA.js">
164
- <link rel="modulepreload" crossorigin href="./assets/MarimoErrorOutput-Dbk0HqOA.js">
164
+ <link rel="modulepreload" crossorigin href="./assets/MarimoErrorOutput-BBRTedcZ.js">
165
165
  <link rel="modulepreload" crossorigin href="./assets/spinner-Bhir8k53.js">
166
- <link rel="modulepreload" crossorigin href="./assets/html-to-image-BHdf1t5J.js">
167
- <link rel="modulepreload" crossorigin href="./assets/focus-CXQpR65O.js">
166
+ <link rel="modulepreload" crossorigin href="./assets/html-to-image-BFtSv8Pw.js">
167
+ <link rel="modulepreload" crossorigin href="./assets/focus-BYFe-tpE.js">
168
168
  <link rel="modulepreload" crossorigin href="./assets/useAsyncData-BFC6lWG9.js">
169
169
  <link rel="modulepreload" crossorigin href="./assets/LazyAnyLanguageCodeMirror-BF3xpDgO.js">
170
170
  <link rel="modulepreload" crossorigin href="./assets/micromark-factory-space-DzSMahmM.js">
171
171
  <link rel="modulepreload" crossorigin href="./assets/chunk-5FQGJX7Z-e_arGD4o.js">
172
- <link rel="modulepreload" crossorigin href="./assets/markdown-renderer-DmnGXdCp.js">
172
+ <link rel="modulepreload" crossorigin href="./assets/markdown-renderer-BySoarzx.js">
173
173
  <link rel="modulepreload" crossorigin href="./assets/command-CBCkexpx.js">
174
174
  <link rel="modulepreload" crossorigin href="./assets/popover-UExmgBsf.js">
175
175
  <link rel="modulepreload" crossorigin href="./assets/errors-TZBmrJmc.js">
176
- <link rel="modulepreload" crossorigin href="./assets/download-YUQiaxS9.js">
176
+ <link rel="modulepreload" crossorigin href="./assets/download-B97Ad3KO.js">
177
177
  <link rel="modulepreload" crossorigin href="./assets/table-DPyRV1LT.js">
178
178
  <link rel="modulepreload" crossorigin href="./assets/useIframeCapabilities-BvE4n6hj.js">
179
179
  <link rel="modulepreload" crossorigin href="./assets/error-banner-C6aBa98y.js">
@@ -191,44 +191,44 @@
191
191
  <link rel="modulepreload" crossorigin href="./assets/message-circle-CWm2KnSx.js">
192
192
  <link rel="modulepreload" crossorigin href="./assets/trash-2-CKlZA04n.js">
193
193
  <link rel="modulepreload" crossorigin href="./assets/react-resizable-panels.browser.esm-BUNcfKXO.js">
194
- <link rel="modulepreload" crossorigin href="./assets/JsonOutput-02ehjjSC.js">
194
+ <link rel="modulepreload" crossorigin href="./assets/JsonOutput-DCI5rUbO.js">
195
195
  <link rel="modulepreload" crossorigin href="./assets/chart-no-axes-column-nqk474t8.js">
196
196
  <link rel="modulepreload" crossorigin href="./assets/square-function-D1dlJvD8.js">
197
197
  <link rel="modulepreload" crossorigin href="./assets/spec-Cq8FVoTf.js">
198
198
  <link rel="modulepreload" crossorigin href="./assets/ellipsis-vertical-CkwWkOQL.js">
199
199
  <link rel="modulepreload" crossorigin href="./assets/refresh-cw-DHwG4Mac.js">
200
200
  <link rel="modulepreload" crossorigin href="./assets/tree-actions-Ci3CV3hN.js">
201
- <link rel="modulepreload" crossorigin href="./assets/components-DVKf_7RU.js">
202
- <link rel="modulepreload" crossorigin href="./assets/column-preview-rDM8Q-wn.js">
201
+ <link rel="modulepreload" crossorigin href="./assets/components-DPRoMb_X.js">
202
+ <link rel="modulepreload" crossorigin href="./assets/column-preview-BOUfJkSp.js">
203
203
  <link rel="modulepreload" crossorigin href="./assets/icons-D9TuFTJG.js">
204
- <link rel="modulepreload" crossorigin href="./assets/radio-group-6t7ozlnG.js">
205
- <link rel="modulepreload" crossorigin href="./assets/floating-outline-BtNnv2IX.js">
204
+ <link rel="modulepreload" crossorigin href="./assets/radio-group-C-al8pQI.js">
205
+ <link rel="modulepreload" crossorigin href="./assets/floating-outline-CEDD_IFg.js">
206
206
  <link rel="modulepreload" crossorigin href="./assets/objectWithoutPropertiesLoose-DaPAPabU.js">
207
207
  <link rel="modulepreload" crossorigin href="./assets/esm-BmrwxxCo.js">
208
208
  <link rel="modulepreload" crossorigin href="./assets/eye-off-n1Li95bE.js">
209
209
  <link rel="modulepreload" crossorigin href="./assets/plus-BgB18UzY.js">
210
- <link rel="modulepreload" crossorigin href="./assets/readonly-python-code-JBCsN3-9.js">
210
+ <link rel="modulepreload" crossorigin href="./assets/readonly-python-code-Dq6zyequ.js">
211
211
  <link rel="modulepreload" crossorigin href="./assets/file-headphone-BrQspHac.js">
212
212
  <link rel="modulepreload" crossorigin href="./assets/file-BrdxGLRX.js">
213
213
  <link rel="modulepreload" crossorigin href="./assets/image-DQHXdEQn.js">
214
- <link rel="modulepreload" crossorigin href="./assets/file-icons-CMxkj_kV.js">
215
- <link rel="modulepreload" crossorigin href="./assets/switch-ecwOrzz3.js">
214
+ <link rel="modulepreload" crossorigin href="./assets/file-icons-B3v9xKEQ.js">
215
+ <link rel="modulepreload" crossorigin href="./assets/switch-BRZnhEsx.js">
216
216
  <link rel="modulepreload" crossorigin href="./assets/events-BRAWQiYK.js">
217
- <link rel="modulepreload" crossorigin href="./assets/globals-B-ZMi0ZU.js">
217
+ <link rel="modulepreload" crossorigin href="./assets/globals-CZHmfW40.js">
218
218
  <link rel="modulepreload" crossorigin href="./assets/share-DIVpiHPe.js">
219
219
  <link rel="modulepreload" crossorigin href="./assets/blob-D-eV0cU3.js">
220
220
  <link rel="modulepreload" crossorigin href="./assets/memoize-Tp7rARFe.js">
221
221
  <link rel="modulepreload" crossorigin href="./assets/get-C-qh_et5.js">
222
222
  <link rel="modulepreload" crossorigin href="./assets/_baseSet-CxV9N1bc.js">
223
- <link rel="modulepreload" crossorigin href="./assets/state-DGoUR-mM.js">
223
+ <link rel="modulepreload" crossorigin href="./assets/state-Bb2WcLMF.js">
224
224
  <link rel="modulepreload" crossorigin href="./assets/label-DTR8T0AE.js">
225
- <link rel="modulepreload" crossorigin href="./assets/textarea-BI_mXP9w.js">
225
+ <link rel="modulepreload" crossorigin href="./assets/textarea-DvLP5rPe.js">
226
226
  <link rel="modulepreload" crossorigin href="./assets/refresh-ccw-C-n2VFP5.js">
227
- <link rel="modulepreload" crossorigin href="./assets/form-EgPmt17c.js">
228
- <link rel="modulepreload" crossorigin href="./assets/renderShortcut-DZpkrZaP.js">
227
+ <link rel="modulepreload" crossorigin href="./assets/form-CrtrbmNl.js">
228
+ <link rel="modulepreload" crossorigin href="./assets/renderShortcut-Bfk4NjRL.js">
229
229
  <link rel="modulepreload" crossorigin href="./assets/field-BrLPDxsA.js">
230
230
  <link rel="modulepreload" crossorigin href="./assets/RSPContexts-CINae4Gg.js">
231
- <link rel="modulepreload" crossorigin href="./assets/useBoolean-B_vDzBHf.js">
231
+ <link rel="modulepreload" crossorigin href="./assets/useBoolean-XOrergn4.js">
232
232
  <link rel="modulepreload" crossorigin href="./assets/useDeepCompareMemoize-D0WTlCXt.js">
233
233
  <link rel="modulepreload" crossorigin href="./assets/types-W8WWuumF.js">
234
234
  <link rel="modulepreload" crossorigin href="./assets/fileToBase64-Bzn96tYq.js">
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@marimo-team/frontend",
3
- "version": "0.23.6-dev2",
3
+ "version": "0.23.6-dev21",
4
4
  "main": "dist/main.js",
5
5
  "types": "dist/index.d.ts",
6
6
  "type": "module",
@@ -195,9 +195,9 @@
195
195
  "@codecov/vite-plugin": "^1.9.1",
196
196
  "@csstools/postcss-light-dark-function": "^2.0.11",
197
197
  "@playwright/test": "^1.59.1",
198
- "@storybook/addon-docs": "^10.2.12",
199
- "@storybook/addon-links": "^10.2.12",
200
- "@storybook/react-vite": "^10.2.12",
198
+ "@storybook/addon-docs": "^10.3.5",
199
+ "@storybook/addon-links": "^10.3.5",
200
+ "@storybook/react-vite": "^10.3.5",
201
201
  "@swc-jotai/react-refresh": "^0.5.0",
202
202
  "@testing-library/jest-dom": "^6.9.1",
203
203
  "@testing-library/react": "^16.3.2",
@@ -223,7 +223,7 @@
223
223
  "react": "^19.2.4",
224
224
  "react-compiler-runtime": "19.1.0-rc.3",
225
225
  "react-dom": "^19.2.4",
226
- "storybook": "^10.2.12",
226
+ "storybook": "^10.3.5",
227
227
  "stylelint": "^16.26.1",
228
228
  "stylelint-config-standard": "^36.0.1",
229
229
  "tailwindcss": "^4.2.2",
@@ -33,6 +33,7 @@ const icons: Record<ProviderId | ExternalAgentId, string> = {
33
33
  github: GitHubIcon,
34
34
  openrouter: OpenRouterIcon,
35
35
  wandb: WandbIcon,
36
+ "opencode-go": OpencodeIcon,
36
37
  marimo: marimoIcon,
37
38
  opencode: OpencodeIcon,
38
39
  cursor: CursorIcon,
@@ -21,6 +21,7 @@ const CREDENTIAL_CHECKERS: Record<KnownProviderId, CredentialChecker> = {
21
21
  openrouter: (ai) => Boolean(ai?.openrouter?.api_key),
22
22
  azure: (ai) => Boolean(ai?.azure?.api_key && ai?.azure?.base_url),
23
23
  wandb: (ai) => Boolean(ai?.wandb?.api_key),
24
+ "opencode-go": (ai) => Boolean(ai?.opencode_go?.api_key),
24
25
  bedrock: (ai) => Boolean(ai?.bedrock?.region_name),
25
26
  ollama: (ai) => Boolean(ai?.ollama?.base_url),
26
27
  // These providers don't have user-configurable credentials in the UI
@@ -1058,6 +1058,36 @@ export const AiProvidersConfig: React.FC<AiConfigProps> = ({
1058
1058
  />
1059
1059
  </AccordionFormItem>
1060
1060
 
1061
+ <AccordionFormItem
1062
+ title="OpenCode Go"
1063
+ provider="opencode-go"
1064
+ isConfigured={hasValue("ai.opencode_go.api_key")}
1065
+ >
1066
+ <ApiKey
1067
+ form={form}
1068
+ config={config}
1069
+ name="ai.opencode_go.api_key"
1070
+ placeholder="your-opencode-api-key"
1071
+ testId="ai-opencode-go-api-key-input"
1072
+ description={
1073
+ <>
1074
+ Your OpenCode API key from{" "}
1075
+ <ExternalLink href="https://opencode.ai/auth">
1076
+ opencode.ai
1077
+ </ExternalLink>
1078
+ . OpenCode Go is a low-cost subscription for open coding models.
1079
+ </>
1080
+ }
1081
+ />
1082
+ <BaseUrl
1083
+ form={form}
1084
+ config={config}
1085
+ name="ai.opencode_go.base_url"
1086
+ placeholder="https://opencode.ai/zen/go/v1/"
1087
+ testId="ai-opencode-go-base-url-input"
1088
+ />
1089
+ </AccordionFormItem>
1090
+
1061
1091
  <AccordionFormItem
1062
1092
  title="Azure"
1063
1093
  provider="azure"
@@ -8,6 +8,7 @@ import {
8
8
  CookieIcon,
9
9
  PanelRightCloseIcon,
10
10
  PanelRightOpenIcon,
11
+ KeyboardIcon,
11
12
  } from "lucide-react";
12
13
  import { RadioGroup, RadioGroupItem } from "@/components/ui/radio-group";
13
14
  import {
@@ -28,6 +29,7 @@ import type {
28
29
  import { useState } from "react";
29
30
  import { Tooltip } from "../ui/tooltip";
30
31
  import { Button } from "../ui/button";
32
+ import { Kbd } from "../ui/kbd";
31
33
  import type { RuntimeCell } from "@/core/cells/types";
32
34
 
33
35
  export const DEFAULT_SLIDE_TYPE: SlideType = "slide";
@@ -132,10 +134,51 @@ const SlidesForm = ({
132
134
  <TabsContent value="deck" className="mt-0 flex-1">
133
135
  <DeckConfigForm layout={layout} setLayout={setLayout} />
134
136
  </TabsContent>
137
+ <hr />
138
+ <KeyboardTips />
135
139
  </Tabs>
136
140
  );
137
141
  };
138
142
 
143
+ const KEYBOARD_TIPS: { keys: string[]; description: string }[] = [
144
+ { keys: ["F"], description: "Enter fullscreen" },
145
+ { keys: ["C"], description: "Toggle code editor" },
146
+ ];
147
+
148
+ const KEYBOARD_SHORTCUTS_URL =
149
+ "https://vlaaad.github.io/reveal/keyboard-shortcuts";
150
+
151
+ const KeyboardTips = () => {
152
+ return (
153
+ <div className="flex flex-col gap-2 text-xs text-muted-foreground">
154
+ <div className="flex items-center gap-1.5 font-medium text-foreground/80">
155
+ <KeyboardIcon className="h-3.5 w-3.5" />
156
+ <span>Shortcuts</span>
157
+ </div>
158
+ <ul className="flex flex-col gap-1.5">
159
+ {KEYBOARD_TIPS.map(({ keys, description }) => (
160
+ <li key={description} className="flex items-center justify-between">
161
+ <span>{description}</span>
162
+ <span className="flex gap-1">
163
+ {keys.map((key) => (
164
+ <Kbd key={key}>{key}</Kbd>
165
+ ))}
166
+ </span>
167
+ </li>
168
+ ))}
169
+ </ul>
170
+ <a
171
+ href={KEYBOARD_SHORTCUTS_URL}
172
+ target="_blank"
173
+ rel="noopener noreferrer"
174
+ className="text-link hover:underline"
175
+ >
176
+ See all shortcuts
177
+ </a>
178
+ </div>
179
+ );
180
+ };
181
+
139
182
  const SlideConfigForm = ({
140
183
  layout,
141
184
  setLayout,
@@ -15,7 +15,8 @@ export const ExternalLink = ({
15
15
  | `https://marimo.io/${string}`
16
16
  | `https://links.marimo.app/${string}`
17
17
  | `https://wandb.ai/${string}`
18
- | `https://portal.azure.com/${string}`;
18
+ | `https://portal.azure.com/${string}`
19
+ | `https://opencode.ai/${string}`;
19
20
  children: React.ReactNode;
20
21
  }) => {
21
22
  return (
@@ -13,6 +13,7 @@ export const KNOWN_PROVIDERS = [
13
13
  "github",
14
14
  "openrouter",
15
15
  "wandb",
16
+ "opencode-go",
16
17
  "marimo",
17
18
  ] as const;
18
19
  export type KnownProviderId = (typeof KNOWN_PROVIDERS)[number];