@marimo-team/frontend 0.20.5-dev1 → 0.20.5-dev3
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/assets/{JsonOutput-BSyDxU0G.js → JsonOutput-GlMQ3aLA.js} +10 -10
- package/dist/assets/{add-connection-dialog-D4U9I7ze.js → add-connection-dialog-9CzjZlY9.js} +43 -38
- package/dist/assets/{agent-panel-ZBBeZzCj.js → agent-panel-BX_iKZeN.js} +1 -1
- package/dist/assets/{cell-editor-E00pyx5t.js → cell-editor-B1x4zkBp.js} +1 -1
- package/dist/assets/{column-preview-BQP0K_pZ.js → column-preview-BhU5Ow0e.js} +1 -1
- package/dist/assets/{command-palette-CqTN1VKY.js → command-palette-BSS73m03.js} +1 -1
- package/dist/assets/{context-aware-panel-D7ygyp92.js → context-aware-panel-HnyO4-L2.js} +1 -1
- package/dist/assets/{edit-page-lJN42JGx.js → edit-page-26-lDVMB.js} +3 -3
- package/dist/assets/{file-explorer-panel-BU69ZByp.js → file-explorer-panel-Bv8lRdKl.js} +1 -1
- package/dist/assets/{hooks-FnmFpagQ.js → hooks-BY6oGAlX.js} +1 -1
- package/dist/assets/{index-DyRdaW9o.js → index-B8ImLAg8.js} +3 -3
- package/dist/assets/index-Dzwe9vKA.css +2 -0
- package/dist/assets/{layout-DnAy5Tn0.js → layout-DVAA7kHH.js} +1 -1
- package/dist/assets/{panels-h8gAGYxu.js → panels-Do1_ry1k.js} +1 -1
- package/dist/assets/{run-page-hoKz5ZHk.js → run-page-BGijCqbR.js} +1 -1
- package/dist/assets/{scratchpad-panel-BJOVrgA9.js → scratchpad-panel-ByOWj9u_.js} +1 -1
- package/dist/assets/{session-panel-Bpv4DUGh.js → session-panel-B_8ny7jh.js} +1 -1
- package/dist/assets/{useNotebookActions-B17g4RO8.js → useNotebookActions-XGX8NzaB.js} +1 -1
- package/dist/index.html +5 -5
- package/package.json +1 -1
- package/src/components/data-table/range-focus/__tests__/cell-selection-stats.test.tsx +14 -9
- package/src/components/data-table/range-focus/cell-selection-stats.tsx +44 -13
- package/src/components/editor/connections/storage/__tests__/__snapshots__/as-code.test.ts.snap +37 -0
- package/src/components/editor/connections/storage/__tests__/as-code.test.ts +60 -0
- package/src/components/editor/connections/storage/add-storage-form.tsx +20 -13
- package/src/components/editor/connections/storage/as-code.ts +37 -0
- package/src/components/editor/connections/storage/schemas.ts +45 -1
- package/src/components/storage/components.tsx +6 -2
- package/dist/assets/index-DrPzoH7F.css +0 -2
|
@@ -1 +1 @@
|
|
|
1
|
-
import{s as fe}from"./chunk-LvLJmgfZ.js";import{d as E,l as Ge,p as Ye,u as ie}from"./useEvent-WUlsM6MC.js";import{t as $e}from"./react-Bj1aDYRI.js";import{Cn as Ke,En as Je,Gt as Xe,Nr as Ze,Sn as Qe,T as ye,_ as et,ar as tt,cr as at,dt as ke,h as be,lt as ot,pr as nt,pt as it,rr as st,t as lt,ut as rt,vi as se,xn as dt}from"./cells-CCtxWKxf.js";import{t as S}from"./compiler-runtime-B3qBwwSJ.js";import{n as ct}from"./assertNever-Dw9aFN4h.js";import{s as xe}from"./useLifecycle-BDXC6oVR.js";import{a as ht,n as we}from"./add-connection-dialog-D4U9I7ze.js";import{n as pt,x as mt}from"./ai-model-dropdown-C3Y44M85.js";import{c as ge,m as I}from"./useEventListener-CjXriKgk.js";import{y as ut}from"./utils-CORJ8yYa.js";import{n as _,t as je}from"./constants-CdR60lKM.js";import{S as le,h as ft,x as yt}from"./config-D9X9QKiL.js";import{t as kt}from"./jsx-runtime-CP2fAiZX.js";import{r as bt,t as re}from"./button-BmOH9agK.js";import{r as L}from"./requests-DZy_SQ_v.js";import{t as h}from"./createLucideIcon-BvP5LBIs.js";import{a as ve,f as xt,i as Ce,m as wt,p as ze,u as We}from"./layout-DnAy5Tn0.js";import{t as Me}from"./check-BnZGcuDh.js";import{c as gt,d as Se,n as jt,o as vt,r as _e,t as Ct}from"./download-BTm4CTKr.js";import{f as zt}from"./maps-8VTEe-0T.js";import{r as Wt}from"./useCellActionButton-DFgACqVf.js";import{t as Mt}from"./copy-CAR4dOiD.js";import{t as St}from"./download-BG-iMGgV.js";import{t as _t}from"./eye-off-DgTL09j7.js";import{t as Dt}from"./file-plus-corner-BRwJx0yp.js";import{t as Y}from"./file-DVwc11C3.js";import{t as At}from"./github-BrsjF9dp.js";import{m as Nt}from"./form-B7_NRa34.js";import{n as Pt,r as Et,t as It}from"./youtube-fKFch587.js";import{n as Lt,t as Tt}from"./square-oV8Csj8Y.js";import{i as Ht}from"./html-to-image-b9BimK8l.js";import{t as qt}from"./link-Cpo6yhBB.js";import{r as Rt}from"./input-BPldEXfy.js";import{t as Vt}from"./settings-DD8FJvQ_.js";import{x as Ft}from"./azure-Ddr1pZpW.js";import{t as C}from"./use-toast-BhMe50aT.js";import{n as De,t as Ot}from"./paths-bMgYkaP2.js";import{o as Ut}from"./session-DnMOyddG.js";import{a as Bt,c as Gt,i as Yt,n as $t,r as Kt,s as Jt,t as Xt}from"./select-DygbgNTD.js";import{t as Zt}from"./tooltip-DOQlecCr.js";import{o as Qt}from"./alert-dialog-DsNfSYaw.js";import{a as ea,c as ta,i as aa,n as oa,r as na}from"./dialog-BXzvlof-.js";import{n as de}from"./ImperativeModal-CRNJOvqT.js";import{r as ia,t as sa}from"./share-sD4fbzpH.js";import{t as $}from"./copy-DMCkK2TI.js";import{a as la}from"./cell-link-B59Kn5nL.js";import{a as ra}from"./renderShortcut-BJEd-iA7.js";import{t as da}from"./icons-B9sHgc9n.js";import{t as ca}from"./links-syPBpTLO.js";import{r as ha,t as pa}from"./hooks-FnmFpagQ.js";import{t as Ae}from"./types-Myu7G9iV.js";var ma=h("circle-chevron-down",[["circle",{cx:"12",cy:"12",r:"10",key:"1mglay"}],["path",{d:"m16 10-4 4-4-4",key:"894hmk"}]]),ua=h("circle-chevron-right",[["circle",{cx:"12",cy:"12",r:"10",key:"1mglay"}],["path",{d:"m10 8 4 4-4 4",key:"1wy4r4"}]]),Ne=h("clipboard-copy",[["rect",{width:"8",height:"4",x:"8",y:"2",rx:"1",ry:"1",key:"tgr4d6"}],["path",{d:"M8 4H6a2 2 0 0 0-2 2v14a2 2 0 0 0 2 2h12a2 2 0 0 0 2-2v-2",key:"4jdomd"}],["path",{d:"M16 4h2a2 2 0 0 1 2 2v4",key:"3hqy98"}],["path",{d:"M21 14H11",key:"1bme5i"}],["path",{d:"m15 10-4 4 4 4",key:"5dvupr"}]]),Pe=h("command",[["path",{d:"M15 6v12a3 3 0 1 0 3-3H6a3 3 0 1 0 3 3V6a3 3 0 1 0-3 3h12a3 3 0 1 0-3-3",key:"11bfej"}]]),Ee=h("diamond-plus",[["path",{d:"M12 8v8",key:"napkw2"}],["path",{d:"M2.7 10.3a2.41 2.41 0 0 0 0 3.41l7.59 7.59a2.41 2.41 0 0 0 3.41 0l7.59-7.59a2.41 2.41 0 0 0 0-3.41L13.7 2.71a2.41 2.41 0 0 0-3.41 0z",key:"1ey20j"}],["path",{d:"M8 12h8",key:"1wcyev"}]]),fa=h("fast-forward",[["path",{d:"M12 6a2 2 0 0 1 3.414-1.414l6 6a2 2 0 0 1 0 2.828l-6 6A2 2 0 0 1 12 18z",key:"b19h5q"}],["path",{d:"M2 6a2 2 0 0 1 3.414-1.414l6 6a2 2 0 0 1 0 2.828l-6 6A2 2 0 0 1 2 18z",key:"h7h5ge"}]]),ya=h("files",[["path",{d:"M15 2h-4a2 2 0 0 0-2 2v11a2 2 0 0 0 2 2h8a2 2 0 0 0 2-2V8",key:"14sh0y"}],["path",{d:"M16.706 2.706A2.4 2.4 0 0 0 15 2v5a1 1 0 0 0 1 1h5a2.4 2.4 0 0 0-.706-1.706z",key:"1970lx"}],["path",{d:"M5 7a2 2 0 0 0-2 2v11a2 2 0 0 0 2 2h8a2 2 0 0 0 1.732-1",key:"l4dndm"}]]),ka=h("keyboard",[["path",{d:"M10 8h.01",key:"1r9ogq"}],["path",{d:"M12 12h.01",key:"1mp3jc"}],["path",{d:"M14 8h.01",key:"1primd"}],["path",{d:"M16 12h.01",key:"1l6xoz"}],["path",{d:"M18 8h.01",key:"emo2bl"}],["path",{d:"M6 8h.01",key:"x9i8wu"}],["path",{d:"M7 16h10",key:"wp8him"}],["path",{d:"M8 12h.01",key:"czm47f"}],["rect",{width:"20",height:"16",x:"2",y:"4",rx:"2",key:"18n3k1"}]]),Ie=h("layout-template",[["rect",{width:"18",height:"7",x:"3",y:"3",rx:"1",key:"f1a2em"}],["rect",{width:"9",height:"7",x:"3",y:"14",rx:"1",key:"jqznyg"}],["rect",{width:"5",height:"7",x:"16",y:"14",rx:"1",key:"q5h2i8"}]]),ba=h("list",[["path",{d:"M3 5h.01",key:"18ugdj"}],["path",{d:"M3 12h.01",key:"nlz23k"}],["path",{d:"M3 19h.01",key:"noohij"}],["path",{d:"M8 5h13",key:"1pao27"}],["path",{d:"M8 12h13",key:"1za7za"}],["path",{d:"M8 19h13",key:"m83p4d"}]]),xa=h("panel-left",[["rect",{width:"18",height:"18",x:"3",y:"3",rx:"2",key:"afitv7"}],["path",{d:"M9 3v18",key:"fh3hqa"}]]),Le=h("presentation",[["path",{d:"M2 3h20",key:"91anmk"}],["path",{d:"M21 3v11a2 2 0 0 1-2 2H5a2 2 0 0 1-2-2V3",key:"2k9sn8"}],["path",{d:"m7 21 5-5 5 5",key:"bip4we"}]]),wa=h("share-2",[["circle",{cx:"18",cy:"5",r:"3",key:"gq8acd"}],["circle",{cx:"6",cy:"12",r:"3",key:"w7nqdw"}],["circle",{cx:"18",cy:"19",r:"3",key:"1xt0gg"}],["line",{x1:"8.59",x2:"15.42",y1:"13.51",y2:"17.49",key:"47mynk"}],["line",{x1:"15.41",x2:"8.59",y1:"6.51",y2:"10.49",key:"1n3mei"}]]),ga=h("square-power",[["path",{d:"M12 7v4",key:"xawao1"}],["path",{d:"M7.998 9.003a5 5 0 1 0 8-.005",key:"1pek45"}],["rect",{x:"3",y:"3",width:"18",height:"18",rx:"2",key:"h1oib"}]]),Te=h("undo-2",[["path",{d:"M9 14 4 9l5-5",key:"102s5s"}],["path",{d:"M4 9h10.5a5.5 5.5 0 0 1 5.5 5.5a5.5 5.5 0 0 1-5.5 5.5H11",key:"f3b9sd"}]]),He=S(),ce=fe($e(),1),a=fe(kt(),1),K="https://static.marimo.app";const ja=e=>{let t=(0,He.c)(25),{onClose:n}=e,[o,s]=(0,ce.useState)(""),{exportAsHTML:r}=L(),l=`${o}-${Math.random().toString(36).slice(2,6)}`,i=`${K}/static/${l}`,d;t[0]!==r||t[1]!==n||t[2]!==l?(d=async v=>{v.preventDefault(),n();let A=await r({download:!1,includeCode:!0,files:xt.INSTANCE.filenames()}),z=C({title:"Uploading static notebook...",description:"Please wait."});await fetch(`${K}/api/static`,{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({html:A,path:l})}).catch(()=>{z.dismiss(),C({title:"Error uploading static page",description:(0,a.jsxs)("div",{children:["Please try again later. If the problem persists, please file a bug report on"," ",(0,a.jsx)("a",{href:_.issuesPage,target:"_blank",className:"underline",children:"GitHub"}),"."]})})}),z.dismiss(),C({title:"Static page uploaded!",description:(0,a.jsxs)("div",{children:["The URL has been copied to your clipboard.",(0,a.jsx)("br",{}),"You can share it with anyone."]})})},t[0]=r,t[1]=n,t[2]=l,t[3]=d):d=t[3];let p;t[4]===Symbol.for("react.memo_cache_sentinel")?(p=(0,a.jsx)(ta,{children:"Share static notebook"}),t[4]=p):p=t[4];let w;t[5]===Symbol.for("react.memo_cache_sentinel")?(w=(0,a.jsxs)(ea,{children:[p,(0,a.jsxs)(na,{children:["You can publish a static, non-interactive version of this notebook to the public web. We will create a link for you that lives on"," ",(0,a.jsx)("a",{href:K,target:"_blank",children:K}),"."]})]}),t[5]=w):w=t[5];let g;t[6]===Symbol.for("react.memo_cache_sentinel")?(g=v=>{s(v.target.value.toLowerCase().replaceAll(/\s/g,"-").replaceAll(/[^\da-z-]/g,""))},t[6]=g):g=t[6];let u;t[7]===o?u=t[8]:(u=(0,a.jsx)(Rt,{"data-testid":"slug-input",id:"slug",autoFocus:!0,value:o,placeholder:"Notebook slug",onChange:g,required:!0,autoComplete:"off"}),t[7]=o,t[8]=u);let f;t[9]===i?f=t[10]:(f=(0,a.jsxs)("div",{className:"font-semibold text-sm text-muted-foreground gap-2 flex flex-col",children:["Anyone will be able to access your notebook at this URL:",(0,a.jsxs)("div",{className:"flex items-center gap-2",children:[(0,a.jsx)(va,{text:i}),(0,a.jsx)("span",{className:"text-primary",children:i})]})]}),t[9]=i,t[10]=f);let y;t[11]!==u||t[12]!==f?(y=(0,a.jsxs)("div",{className:"flex flex-col gap-6 py-4",children:[u,f]}),t[11]=u,t[12]=f,t[13]=y):y=t[13];let k;t[14]===n?k=t[15]:(k=(0,a.jsx)(re,{"data-testid":"cancel-share-static-notebook-button",variant:"secondary",onClick:n,children:"Cancel"}),t[14]=n,t[15]=k);let b;t[16]===i?b=t[17]:(b=(0,a.jsx)(re,{"data-testid":"share-static-notebook-button","aria-label":"Save",variant:"default",type:"submit",onClick:async()=>{await $(i)},children:"Create"}),t[16]=i,t[17]=b);let x;t[18]!==k||t[19]!==b?(x=(0,a.jsxs)(aa,{children:[k,b]}),t[18]=k,t[19]=b,t[20]=x):x=t[20];let j;return t[21]!==d||t[22]!==x||t[23]!==y?(j=(0,a.jsx)(oa,{className:"w-fit",children:(0,a.jsxs)("form",{onSubmit:d,children:[w,y,x]})}),t[21]=d,t[22]=x,t[23]=y,t[24]=j):j=t[24],j};var va=e=>{let t=(0,He.c)(8),[n,o]=ce.useState(!1),s;t[0]===e.text?s=t[1]:(s=bt.stopPropagation(async p=>{p.preventDefault(),await $(e.text),o(!0),setTimeout(()=>o(!1),2e3)}),t[0]=e.text,t[1]=s);let r=s,l;t[2]===Symbol.for("react.memo_cache_sentinel")?(l=(0,a.jsx)(Mt,{size:14,strokeWidth:1.5}),t[2]=l):l=t[2];let i;t[3]===r?i=t[4]:(i=(0,a.jsx)(re,{"data-testid":"copy-static-notebook-url-button",onClick:r,size:"xs",variant:"secondary",children:l}),t[3]=r,t[4]=i);let d;return t[5]!==n||t[6]!==i?(d=(0,a.jsx)(Zt,{content:"Copied!",open:n,children:i}),t[5]=n,t[6]=i,t[7]=d):d=t[7],d},Ca=S();function za(){let e=document.getElementsByClassName(je.outputArea);for(let t of e){let n=t.getBoundingClientRect();if(n.bottom>0&&n.top<window.innerHeight){let o=se.findElement(t);if(!o){I.warn("Could not find HTMLCellId for visible output area",t);continue}return{cellId:se.parse(o.id)}}}return I.warn("No visible output area found for scroll anchor"),null}function Wa(e){if(!e){I.warn("No scroll anchor provided to restore scroll position");return}let t=document.getElementById(se.create(e.cellId));if(!t){I.warn("Could not find cell element to restore scroll position",e.cellId);return}if(!t.querySelector(`.${je.outputArea}`)){I.warn("Could not find output area to restore scroll position",e.cellId);return}t.scrollIntoView({block:"start",behavior:"auto"})}function qe(){let e=(0,Ca.c)(2),t=E(ke),n;return e[0]===t?n=e[1]:(n=()=>{let o=za();t(s=>({mode:rt(s.mode),cellAnchor:(o==null?void 0:o.cellId)??null})),requestAnimationFrame(()=>{requestAnimationFrame(()=>{Wa(o)})})},e[0]=t,e[1]=n),n}const Re=Ye(!1);var Ma=S();const Sa=()=>{let e=(0,Ma.c)(7),{selectedLayout:t}=ve(),{setLayoutView:n}=Ce();if(le()&&!Je("wasm_layouts"))return null;let o;e[0]===n?o=e[1]:(o=i=>n(i),e[0]=n,e[1]=o);let s;e[2]===Symbol.for("react.memo_cache_sentinel")?(s=(0,a.jsx)(Jt,{className:"min-w-[110px] border-border bg-background","data-testid":"layout-select",children:(0,a.jsx)(Gt,{placeholder:"Select a view"})}),e[2]=s):s=e[2];let r;e[3]===Symbol.for("react.memo_cache_sentinel")?(r=(0,a.jsx)($t,{children:(0,a.jsxs)(Kt,{children:[(0,a.jsx)(Bt,{children:"View as"}),Ae.map(Da)]})}),e[3]=r):r=e[3];let l;return e[4]!==t||e[5]!==o?(l=(0,a.jsxs)(Xt,{"data-testid":"layout-select",value:t,onValueChange:o,children:[s,r]}),e[4]=t,e[5]=o,e[6]=l):l=e[6],l};function _a(e){return(0,a.jsx)(Ve(e),{className:"h-4 w-4"})}function Ve(e){switch(e){case"vertical":return ba;case"grid":return Et;case"slides":return Le;default:return ct(e),Tt}}function Fe(e){return xe(e)}function Da(e){return(0,a.jsx)(Yt,{value:e,children:(0,a.jsxs)("div",{className:"flex items-center gap-1.5 leading-5",children:[_a(e),(0,a.jsx)("span",{children:Fe(e)})]})},e)}async function Aa(e){let{filename:t,preset:n,downloadPDF:o}=e;await o({filename:t,webpdf:!1,preset:n,includeInputs:!0,rasterServer:"static"})}var Na=S();function Pa(e){let t=(0,Na.c)(5),{openPrompt:n,closeModal:o}=de(),{sendCopy:s}=L(),r;return t[0]!==o||t[1]!==n||t[2]!==s||t[3]!==e?(r=()=>{if(!e)return null;let l=Ot.guessDeliminator(e);n({title:"Copy notebook",description:"Enter a new filename for the notebook copy.",defaultValue:`_${De.basename(e)}`,confirmText:"Copy notebook",spellCheck:!1,onConfirm:i=>{let d=l.join(De.dirname(e),i);s({source:e,destination:d}).then(()=>{o(),C({title:"Notebook copied",description:"A copy of the notebook has been created."}),ca(d)})}})},t[0]=o,t[1]=n,t[2]=s,t[3]=e,t[4]=r):r=t[4],r}const Ea=()=>{let{updateCellConfig:e}=ye(),{saveCellConfig:t}=L();return(0,ce.useCallback)(async()=>{let n=new Xe,o=be(),s=o.cellIds.inOrderIds,r={};for(let i of s){if(o.cellData[i]===void 0)continue;let{code:d,config:p}=o.cellData[i];p.hide_code||n.isSupported(d)&&(r[i]={hide_code:!0})}let l=ge.entries(r);if(l.length!==0){await t({configs:r});for(let[i,d]of l)e({cellId:i,config:d})}},[e])};var Ia=S();function Oe(){let e=(0,Ia.c)(4),{openConfirm:t}=de(),n=E(ft),{sendRestart:o}=L(),s;return e[0]!==t||e[1]!==o||e[2]!==n?(s=()=>{t({title:"Restart Kernel",description:"This will restart the Python kernel. You'll lose all data that's in memory. You will also lose any unsaved changes, so make sure to save your work before restarting.",variant:"destructive",confirmAction:(0,a.jsx)(Qt,{onClick:async()=>{n({state:yt.CLOSING}),await o(),ia()},"aria-label":"Confirm Restart",children:"Restart"})})},e[0]=t,e[1]=o,e[2]=n,e[3]=s):s=e[3],s}var La=S(),D=e=>{e==null||e.preventDefault(),e==null||e.stopPropagation()};function Ta(){var me,ue;let e=(0,La.c)(45),t=la(),{openModal:n,closeModal:o}=de(),{toggleApplication:s}=dt(),{selectedPanel:r}=Qe(),[l]=Ge(ke),i=ie(ot),d=Ea(),[p]=ut(),{updateCellConfig:w,undoDeleteCell:g,clearAllCellOutputs:u,addSetupCellIfDoesntExist:f,collapseAllCells:y,expandAllCells:k}=ye(),b=Oe(),x=it(),j=Pa(t),v=E(Re),A=E(pt),z=E(mt),{exportAsMarkdown:J,readCode:N,saveCellConfig:X,updateCellOutputs:Z}=L(),Q=ha(),ee=ie(et),te=ie(lt),{selectedLayout:T}=ve(),{setLayoutView:ae}=Ce(),H=qe(),q=((me=p.sharing)==null?void 0:me.html)??!0,R=((ue=p.sharing)==null?void 0:ue.wasm)??!0,pe=!le(),oe=T==="slides",Ue=to,Be=eo,V;e[0]!==t||e[1]!==Q||e[2]!==Z?(V=async c=>{let{preset:m,title:P}=c;if(!t){he();return}await gt(P,async ne=>{await pa({takeScreenshots:()=>Q({progress:ne}),updateCellOutputs:Z}),await Aa({filename:t,preset:m,downloadPDF:jt})})},e[0]=t,e[1]=Q,e[2]=Z,e[3]=V):V=e[3];let W=V,F;e[4]===W?F=e[5]:(F=async()=>{if(pe){await W({preset:"document",title:"Downloading Document PDF..."});return}let c=new Event("export-beforeprint"),m=new Event("export-afterprint");window.dispatchEvent(c),setTimeout(Qa,0),setTimeout(()=>window.dispatchEvent(m),0)},e[4]=W,e[5]=F);let O=F,U;e[6]===Symbol.for("react.memo_cache_sentinel")?(U=(0,a.jsx)(St,{size:14,strokeWidth:1.5}),e[6]=U):U=e[6];let B;e[7]===Symbol.for("react.memo_cache_sentinel")?(B=(0,a.jsx)(ze,{size:14,strokeWidth:1.5}),e[7]=B):B=e[7];let M;e[8]===t?M=e[9]:(M=async()=>{if(!t){he();return}await We({filename:t,includeCode:!0})},e[8]=t,e[9]=M);let G;return e[10]!==f||e[11]!==te||e[12]!==u||e[13]!==o||e[14]!==y||e[15]!==j||e[16]!==W||e[17]!==k||e[18]!==J||e[19]!==t||e[20]!==O||e[21]!==ee||e[22]!==d||e[23]!==oe||e[24]!==i||e[25]!==n||e[26]!==N||e[27]!==b||e[28]!==x||e[29]!==X||e[30]!==T||e[31]!==r||e[32]!==v||e[33]!==z||e[34]!==ae||e[35]!==A||e[36]!==q||e[37]!==R||e[38]!==M||e[39]!==s||e[40]!==H||e[41]!==g||e[42]!==w||e[43]!==l.mode?(G=[{icon:U,label:"Download",handle:D,dropdown:[{icon:B,label:"Download as HTML",handle:M},{icon:(0,a.jsx)(ze,{size:14,strokeWidth:1.5}),label:"Download as HTML (exclude code)",handle:async()=>{if(!t){he();return}await We({filename:t,includeCode:!1})}},{icon:(0,a.jsx)(da,{strokeWidth:1.5,style:{width:14,height:14}}),label:"Download as Markdown",handle:async()=>{let c=await J({download:!1});_e(new Blob([c],{type:"text/plain"}),Se.toMarkdown(document.title))}},{icon:(0,a.jsx)(wt,{size:14,strokeWidth:1.5}),label:"Download Python code",handle:async()=>{let c=await N();_e(new Blob([c.contents],{type:"text/plain"}),Se.toPY(document.title))}},{divider:!0,icon:(0,a.jsx)(Ht,{size:14,strokeWidth:1.5}),label:"Download as PNG",disabled:l.mode!=="present",tooltip:l.mode==="present"?void 0:(0,a.jsxs)("span",{children:["Only available in app view. ",(0,a.jsx)("br",{}),"Toggle with: ",ra("global.hideCode",!1)]}),handle:Za},oe?{divider:!0,icon:(0,a.jsx)(Y,{size:14,strokeWidth:1.5}),label:"Download as PDF",handle:D,dropdown:[{icon:(0,a.jsx)(Y,{size:14,strokeWidth:1.5}),label:"Document Layout",handle:O},{icon:(0,a.jsx)(Y,{size:14,strokeWidth:1.5}),label:"Slides Layout",rightElement:Be(!0),hidden:!pe,handle:async()=>{await W({preset:"slides",title:"Downloading Slides PDF..."})}}]}:{divider:!0,icon:(0,a.jsx)(Y,{size:14,strokeWidth:1.5}),label:"Download as PDF",handle:O}]},{icon:(0,a.jsx)(wa,{size:14,strokeWidth:1.5}),label:"Share",handle:D,hidden:!q&&!R,dropdown:[{icon:(0,a.jsx)(Nt,{size:14,strokeWidth:1.5}),label:"Publish HTML to web",hidden:!q,handle:async()=>{n((0,a.jsx)(ja,{onClose:o}))}},{icon:(0,a.jsx)(qt,{size:14,strokeWidth:1.5}),label:"Create WebAssembly link",hidden:!R,handle:async()=>{await $(sa({code:(await N()).contents})),C({title:"Copied",description:"Link copied to clipboard."})}}]},{icon:(0,a.jsx)(xa,{size:14,strokeWidth:1.5}),label:"Helper panel",redundant:!0,handle:D,dropdown:Ke.flatMap(c=>{let{type:m,Icon:P,hidden:ne}=c;return ne?[]:{label:xe(m),rightElement:Ue(r===m),icon:(0,a.jsx)(P,{size:14,strokeWidth:1.5}),handle:()=>s(m)}})},{icon:(0,a.jsx)(Le,{size:14,strokeWidth:1.5}),label:"Present as",handle:D,dropdown:[{icon:l.mode==="present"?(0,a.jsx)(Ft,{size:14,strokeWidth:1.5}):(0,a.jsx)(Ie,{size:14,strokeWidth:1.5}),label:"Toggle app view",hotkey:"global.hideCode",handle:()=>{H()}},...Ae.map((c,m)=>{let P=Ve(c);return{divider:m===0,label:Fe(c),icon:(0,a.jsx)(P,{size:14,strokeWidth:1.5}),rightElement:(0,a.jsx)("div",{className:"w-8 flex justify-end",children:T===c&&(0,a.jsx)(Me,{size:14})}),handle:()=>{ae(c),l.mode==="edit"&&H()}}})]},{icon:(0,a.jsx)(ya,{size:14,strokeWidth:1.5}),label:"Duplicate notebook",hidden:!t||le(),handle:j},{icon:(0,a.jsx)(Ne,{size:14,strokeWidth:1.5}),label:"Copy code to clipboard",hidden:!t,handle:async()=>{await $((await N()).contents),C({title:"Copied",description:"Code copied to clipboard."})}},{icon:(0,a.jsx)(Wt,{size:14,strokeWidth:1.5}),label:"Enable all cells",hidden:!ee||i,handle:async()=>{let c=Ze(be());await X({configs:ge.fromEntries(c.map(Xa))});for(let m of c)w({cellId:m,config:{disabled:!1}})}},{divider:!0,icon:(0,a.jsx)(Ee,{size:14,strokeWidth:1.5}),label:"Add setup cell",handle:()=>{f({})}},{icon:(0,a.jsx)(tt,{size:14,strokeWidth:1.5}),label:"Add database connection",handle:()=>{n((0,a.jsx)(we,{onClose:o}))}},{icon:(0,a.jsx)(ht,{size:14,strokeWidth:1.5}),label:"Add remote storage",handle:()=>{n((0,a.jsx)(we,{defaultTab:"storage",onClose:o}))}},{icon:(0,a.jsx)(Te,{size:14,strokeWidth:1.5}),label:"Undo cell deletion",hidden:!te||i,handle:()=>{g()}},{icon:(0,a.jsx)(ga,{size:14,strokeWidth:1.5}),label:"Restart kernel",variant:"danger",handle:b},{icon:(0,a.jsx)(fa,{size:14,strokeWidth:1.5}),label:"Re-run all cells",redundant:!0,hotkey:"global.runAll",handle:async()=>{x()}},{icon:(0,a.jsx)(at,{size:14,strokeWidth:1.5}),label:"Clear all outputs",redundant:!0,handle:()=>{u()}},{icon:(0,a.jsx)(_t,{size:14,strokeWidth:1.5}),label:"Hide all markdown code",handle:d,redundant:!0},{icon:(0,a.jsx)(ua,{size:14,strokeWidth:1.5}),label:"Collapse all sections",hotkey:"global.collapseAllSections",handle:y,redundant:!0},{icon:(0,a.jsx)(ma,{size:14,strokeWidth:1.5}),label:"Expand all sections",hotkey:"global.expandAllSections",handle:k,redundant:!0},{divider:!0,icon:(0,a.jsx)(Pe,{size:14,strokeWidth:1.5}),label:"Command palette",hotkey:"global.commandPalette",handle:()=>v(Ja)},{icon:(0,a.jsx)(ka,{size:14,strokeWidth:1.5}),label:"Keyboard shortcuts",hotkey:"global.showHelp",handle:()=>z(Ka)},{icon:(0,a.jsx)(Vt,{size:14,strokeWidth:1.5}),label:"User settings",handle:()=>A($a),redundant:!0},{icon:(0,a.jsx)(zt,{size:14,strokeWidth:1.5}),label:"Resources",handle:D,dropdown:[{icon:(0,a.jsx)(nt,{size:14,strokeWidth:1.5}),label:"Documentation",handle:Ya},{icon:(0,a.jsx)(At,{size:14,strokeWidth:1.5}),label:"GitHub",handle:Ga},{icon:(0,a.jsx)(Pt,{size:14,strokeWidth:1.5}),label:"Discord Community",handle:Ba},{icon:(0,a.jsx)(It,{size:14,strokeWidth:1.5}),label:"YouTube",handle:Ua},{icon:(0,a.jsx)(st,{size:14,strokeWidth:1.5}),label:"Changelog",handle:Oa}]},{divider:!0,icon:(0,a.jsx)(Lt,{size:14,strokeWidth:1.5}),label:"Return home",hidden:!location.search.includes("file"),handle:Fa},{icon:(0,a.jsx)(Dt,{size:14,strokeWidth:1.5}),label:"New notebook",hidden:!location.search.includes("file"),handle:Va}].filter(Ra).map(Ha),e[10]=f,e[11]=te,e[12]=u,e[13]=o,e[14]=y,e[15]=j,e[16]=W,e[17]=k,e[18]=J,e[19]=t,e[20]=O,e[21]=ee,e[22]=d,e[23]=oe,e[24]=i,e[25]=n,e[26]=N,e[27]=b,e[28]=x,e[29]=X,e[30]=T,e[31]=r,e[32]=v,e[33]=z,e[34]=ae,e[35]=A,e[36]=q,e[37]=R,e[38]=M,e[39]=s,e[40]=H,e[41]=g,e[42]=w,e[43]=l.mode,e[44]=G):G=e[44],G}function Ha(e){return e.dropdown?{...e,dropdown:e.dropdown.filter(qa)}:e}function qa(e){return!e.hidden}function Ra(e){return!e.hidden}function Va(){let e=Ut();window.open(e,"_blank")}function Fa(){let e=document.baseURI.split("?")[0];window.open(e,"_self")}function Oa(){window.open(_.releasesPage,"_blank")}function Ua(){window.open(_.youtube,"_blank")}function Ba(){window.open(_.discordLink,"_blank")}function Ga(){window.open(_.githubPage,"_blank")}function Ya(){window.open(_.docsPage,"_blank")}function $a(e){return!e}function Ka(e){return!e}function Ja(e){return!e}function Xa(e){return[e,{disabled:!1}]}async function Za(){let e=document.getElementById("App");e&&await vt({element:e,filename:document.title,prepare:Ct})}function Qa(){return window.print()}function eo(e){return e?(0,a.jsx)("span",{className:"ml-3 shrink-0 rounded-full border border-emerald-200 bg-emerald-50 px-2 py-0.5 text-[10px] font-semibold uppercase tracking-wide text-emerald-700",children:"Recommended"}):null}function to(e){return(0,a.jsx)("div",{className:"w-8 flex justify-end",children:e&&(0,a.jsx)(Me,{size:14})})}function he(){C({title:"Error",description:"Notebooks must be named to be exported.",variant:"danger"})}export{qe as a,Ee as c,Re as i,Pe as l,Oe as n,Te as o,Sa as r,Ie as s,Ta as t,Ne as u};
|
|
1
|
+
import{s as fe}from"./chunk-LvLJmgfZ.js";import{d as E,l as Ge,p as Ye,u as ie}from"./useEvent-WUlsM6MC.js";import{t as $e}from"./react-Bj1aDYRI.js";import{Cn as Ke,En as Je,Gt as Xe,Nr as Ze,Sn as Qe,T as ye,_ as et,ar as tt,cr as at,dt as ke,h as be,lt as ot,pr as nt,pt as it,rr as st,t as lt,ut as rt,vi as se,xn as dt}from"./cells-CCtxWKxf.js";import{t as S}from"./compiler-runtime-B3qBwwSJ.js";import{n as ct}from"./assertNever-Dw9aFN4h.js";import{s as xe}from"./useLifecycle-BDXC6oVR.js";import{a as ht,n as we}from"./add-connection-dialog-9CzjZlY9.js";import{n as pt,x as mt}from"./ai-model-dropdown-C3Y44M85.js";import{c as ge,m as I}from"./useEventListener-CjXriKgk.js";import{y as ut}from"./utils-CORJ8yYa.js";import{n as _,t as je}from"./constants-CdR60lKM.js";import{S as le,h as ft,x as yt}from"./config-D9X9QKiL.js";import{t as kt}from"./jsx-runtime-CP2fAiZX.js";import{r as bt,t as re}from"./button-BmOH9agK.js";import{r as L}from"./requests-DZy_SQ_v.js";import{t as h}from"./createLucideIcon-BvP5LBIs.js";import{a as ve,f as xt,i as Ce,m as wt,p as ze,u as We}from"./layout-DVAA7kHH.js";import{t as Me}from"./check-BnZGcuDh.js";import{c as gt,d as Se,n as jt,o as vt,r as _e,t as Ct}from"./download-BTm4CTKr.js";import{f as zt}from"./maps-8VTEe-0T.js";import{r as Wt}from"./useCellActionButton-DFgACqVf.js";import{t as Mt}from"./copy-CAR4dOiD.js";import{t as St}from"./download-BG-iMGgV.js";import{t as _t}from"./eye-off-DgTL09j7.js";import{t as Dt}from"./file-plus-corner-BRwJx0yp.js";import{t as Y}from"./file-DVwc11C3.js";import{t as At}from"./github-BrsjF9dp.js";import{m as Nt}from"./form-B7_NRa34.js";import{n as Pt,r as Et,t as It}from"./youtube-fKFch587.js";import{n as Lt,t as Tt}from"./square-oV8Csj8Y.js";import{i as Ht}from"./html-to-image-b9BimK8l.js";import{t as qt}from"./link-Cpo6yhBB.js";import{r as Rt}from"./input-BPldEXfy.js";import{t as Vt}from"./settings-DD8FJvQ_.js";import{x as Ft}from"./azure-Ddr1pZpW.js";import{t as C}from"./use-toast-BhMe50aT.js";import{n as De,t as Ot}from"./paths-bMgYkaP2.js";import{o as Ut}from"./session-DnMOyddG.js";import{a as Bt,c as Gt,i as Yt,n as $t,r as Kt,s as Jt,t as Xt}from"./select-DygbgNTD.js";import{t as Zt}from"./tooltip-DOQlecCr.js";import{o as Qt}from"./alert-dialog-DsNfSYaw.js";import{a as ea,c as ta,i as aa,n as oa,r as na}from"./dialog-BXzvlof-.js";import{n as de}from"./ImperativeModal-CRNJOvqT.js";import{r as ia,t as sa}from"./share-sD4fbzpH.js";import{t as $}from"./copy-DMCkK2TI.js";import{a as la}from"./cell-link-B59Kn5nL.js";import{a as ra}from"./renderShortcut-BJEd-iA7.js";import{t as da}from"./icons-B9sHgc9n.js";import{t as ca}from"./links-syPBpTLO.js";import{r as ha,t as pa}from"./hooks-BY6oGAlX.js";import{t as Ae}from"./types-Myu7G9iV.js";var ma=h("circle-chevron-down",[["circle",{cx:"12",cy:"12",r:"10",key:"1mglay"}],["path",{d:"m16 10-4 4-4-4",key:"894hmk"}]]),ua=h("circle-chevron-right",[["circle",{cx:"12",cy:"12",r:"10",key:"1mglay"}],["path",{d:"m10 8 4 4-4 4",key:"1wy4r4"}]]),Ne=h("clipboard-copy",[["rect",{width:"8",height:"4",x:"8",y:"2",rx:"1",ry:"1",key:"tgr4d6"}],["path",{d:"M8 4H6a2 2 0 0 0-2 2v14a2 2 0 0 0 2 2h12a2 2 0 0 0 2-2v-2",key:"4jdomd"}],["path",{d:"M16 4h2a2 2 0 0 1 2 2v4",key:"3hqy98"}],["path",{d:"M21 14H11",key:"1bme5i"}],["path",{d:"m15 10-4 4 4 4",key:"5dvupr"}]]),Pe=h("command",[["path",{d:"M15 6v12a3 3 0 1 0 3-3H6a3 3 0 1 0 3 3V6a3 3 0 1 0-3 3h12a3 3 0 1 0-3-3",key:"11bfej"}]]),Ee=h("diamond-plus",[["path",{d:"M12 8v8",key:"napkw2"}],["path",{d:"M2.7 10.3a2.41 2.41 0 0 0 0 3.41l7.59 7.59a2.41 2.41 0 0 0 3.41 0l7.59-7.59a2.41 2.41 0 0 0 0-3.41L13.7 2.71a2.41 2.41 0 0 0-3.41 0z",key:"1ey20j"}],["path",{d:"M8 12h8",key:"1wcyev"}]]),fa=h("fast-forward",[["path",{d:"M12 6a2 2 0 0 1 3.414-1.414l6 6a2 2 0 0 1 0 2.828l-6 6A2 2 0 0 1 12 18z",key:"b19h5q"}],["path",{d:"M2 6a2 2 0 0 1 3.414-1.414l6 6a2 2 0 0 1 0 2.828l-6 6A2 2 0 0 1 2 18z",key:"h7h5ge"}]]),ya=h("files",[["path",{d:"M15 2h-4a2 2 0 0 0-2 2v11a2 2 0 0 0 2 2h8a2 2 0 0 0 2-2V8",key:"14sh0y"}],["path",{d:"M16.706 2.706A2.4 2.4 0 0 0 15 2v5a1 1 0 0 0 1 1h5a2.4 2.4 0 0 0-.706-1.706z",key:"1970lx"}],["path",{d:"M5 7a2 2 0 0 0-2 2v11a2 2 0 0 0 2 2h8a2 2 0 0 0 1.732-1",key:"l4dndm"}]]),ka=h("keyboard",[["path",{d:"M10 8h.01",key:"1r9ogq"}],["path",{d:"M12 12h.01",key:"1mp3jc"}],["path",{d:"M14 8h.01",key:"1primd"}],["path",{d:"M16 12h.01",key:"1l6xoz"}],["path",{d:"M18 8h.01",key:"emo2bl"}],["path",{d:"M6 8h.01",key:"x9i8wu"}],["path",{d:"M7 16h10",key:"wp8him"}],["path",{d:"M8 12h.01",key:"czm47f"}],["rect",{width:"20",height:"16",x:"2",y:"4",rx:"2",key:"18n3k1"}]]),Ie=h("layout-template",[["rect",{width:"18",height:"7",x:"3",y:"3",rx:"1",key:"f1a2em"}],["rect",{width:"9",height:"7",x:"3",y:"14",rx:"1",key:"jqznyg"}],["rect",{width:"5",height:"7",x:"16",y:"14",rx:"1",key:"q5h2i8"}]]),ba=h("list",[["path",{d:"M3 5h.01",key:"18ugdj"}],["path",{d:"M3 12h.01",key:"nlz23k"}],["path",{d:"M3 19h.01",key:"noohij"}],["path",{d:"M8 5h13",key:"1pao27"}],["path",{d:"M8 12h13",key:"1za7za"}],["path",{d:"M8 19h13",key:"m83p4d"}]]),xa=h("panel-left",[["rect",{width:"18",height:"18",x:"3",y:"3",rx:"2",key:"afitv7"}],["path",{d:"M9 3v18",key:"fh3hqa"}]]),Le=h("presentation",[["path",{d:"M2 3h20",key:"91anmk"}],["path",{d:"M21 3v11a2 2 0 0 1-2 2H5a2 2 0 0 1-2-2V3",key:"2k9sn8"}],["path",{d:"m7 21 5-5 5 5",key:"bip4we"}]]),wa=h("share-2",[["circle",{cx:"18",cy:"5",r:"3",key:"gq8acd"}],["circle",{cx:"6",cy:"12",r:"3",key:"w7nqdw"}],["circle",{cx:"18",cy:"19",r:"3",key:"1xt0gg"}],["line",{x1:"8.59",x2:"15.42",y1:"13.51",y2:"17.49",key:"47mynk"}],["line",{x1:"15.41",x2:"8.59",y1:"6.51",y2:"10.49",key:"1n3mei"}]]),ga=h("square-power",[["path",{d:"M12 7v4",key:"xawao1"}],["path",{d:"M7.998 9.003a5 5 0 1 0 8-.005",key:"1pek45"}],["rect",{x:"3",y:"3",width:"18",height:"18",rx:"2",key:"h1oib"}]]),Te=h("undo-2",[["path",{d:"M9 14 4 9l5-5",key:"102s5s"}],["path",{d:"M4 9h10.5a5.5 5.5 0 0 1 5.5 5.5a5.5 5.5 0 0 1-5.5 5.5H11",key:"f3b9sd"}]]),He=S(),ce=fe($e(),1),a=fe(kt(),1),K="https://static.marimo.app";const ja=e=>{let t=(0,He.c)(25),{onClose:n}=e,[o,s]=(0,ce.useState)(""),{exportAsHTML:r}=L(),l=`${o}-${Math.random().toString(36).slice(2,6)}`,i=`${K}/static/${l}`,d;t[0]!==r||t[1]!==n||t[2]!==l?(d=async v=>{v.preventDefault(),n();let A=await r({download:!1,includeCode:!0,files:xt.INSTANCE.filenames()}),z=C({title:"Uploading static notebook...",description:"Please wait."});await fetch(`${K}/api/static`,{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({html:A,path:l})}).catch(()=>{z.dismiss(),C({title:"Error uploading static page",description:(0,a.jsxs)("div",{children:["Please try again later. If the problem persists, please file a bug report on"," ",(0,a.jsx)("a",{href:_.issuesPage,target:"_blank",className:"underline",children:"GitHub"}),"."]})})}),z.dismiss(),C({title:"Static page uploaded!",description:(0,a.jsxs)("div",{children:["The URL has been copied to your clipboard.",(0,a.jsx)("br",{}),"You can share it with anyone."]})})},t[0]=r,t[1]=n,t[2]=l,t[3]=d):d=t[3];let p;t[4]===Symbol.for("react.memo_cache_sentinel")?(p=(0,a.jsx)(ta,{children:"Share static notebook"}),t[4]=p):p=t[4];let w;t[5]===Symbol.for("react.memo_cache_sentinel")?(w=(0,a.jsxs)(ea,{children:[p,(0,a.jsxs)(na,{children:["You can publish a static, non-interactive version of this notebook to the public web. We will create a link for you that lives on"," ",(0,a.jsx)("a",{href:K,target:"_blank",children:K}),"."]})]}),t[5]=w):w=t[5];let g;t[6]===Symbol.for("react.memo_cache_sentinel")?(g=v=>{s(v.target.value.toLowerCase().replaceAll(/\s/g,"-").replaceAll(/[^\da-z-]/g,""))},t[6]=g):g=t[6];let u;t[7]===o?u=t[8]:(u=(0,a.jsx)(Rt,{"data-testid":"slug-input",id:"slug",autoFocus:!0,value:o,placeholder:"Notebook slug",onChange:g,required:!0,autoComplete:"off"}),t[7]=o,t[8]=u);let f;t[9]===i?f=t[10]:(f=(0,a.jsxs)("div",{className:"font-semibold text-sm text-muted-foreground gap-2 flex flex-col",children:["Anyone will be able to access your notebook at this URL:",(0,a.jsxs)("div",{className:"flex items-center gap-2",children:[(0,a.jsx)(va,{text:i}),(0,a.jsx)("span",{className:"text-primary",children:i})]})]}),t[9]=i,t[10]=f);let y;t[11]!==u||t[12]!==f?(y=(0,a.jsxs)("div",{className:"flex flex-col gap-6 py-4",children:[u,f]}),t[11]=u,t[12]=f,t[13]=y):y=t[13];let k;t[14]===n?k=t[15]:(k=(0,a.jsx)(re,{"data-testid":"cancel-share-static-notebook-button",variant:"secondary",onClick:n,children:"Cancel"}),t[14]=n,t[15]=k);let b;t[16]===i?b=t[17]:(b=(0,a.jsx)(re,{"data-testid":"share-static-notebook-button","aria-label":"Save",variant:"default",type:"submit",onClick:async()=>{await $(i)},children:"Create"}),t[16]=i,t[17]=b);let x;t[18]!==k||t[19]!==b?(x=(0,a.jsxs)(aa,{children:[k,b]}),t[18]=k,t[19]=b,t[20]=x):x=t[20];let j;return t[21]!==d||t[22]!==x||t[23]!==y?(j=(0,a.jsx)(oa,{className:"w-fit",children:(0,a.jsxs)("form",{onSubmit:d,children:[w,y,x]})}),t[21]=d,t[22]=x,t[23]=y,t[24]=j):j=t[24],j};var va=e=>{let t=(0,He.c)(8),[n,o]=ce.useState(!1),s;t[0]===e.text?s=t[1]:(s=bt.stopPropagation(async p=>{p.preventDefault(),await $(e.text),o(!0),setTimeout(()=>o(!1),2e3)}),t[0]=e.text,t[1]=s);let r=s,l;t[2]===Symbol.for("react.memo_cache_sentinel")?(l=(0,a.jsx)(Mt,{size:14,strokeWidth:1.5}),t[2]=l):l=t[2];let i;t[3]===r?i=t[4]:(i=(0,a.jsx)(re,{"data-testid":"copy-static-notebook-url-button",onClick:r,size:"xs",variant:"secondary",children:l}),t[3]=r,t[4]=i);let d;return t[5]!==n||t[6]!==i?(d=(0,a.jsx)(Zt,{content:"Copied!",open:n,children:i}),t[5]=n,t[6]=i,t[7]=d):d=t[7],d},Ca=S();function za(){let e=document.getElementsByClassName(je.outputArea);for(let t of e){let n=t.getBoundingClientRect();if(n.bottom>0&&n.top<window.innerHeight){let o=se.findElement(t);if(!o){I.warn("Could not find HTMLCellId for visible output area",t);continue}return{cellId:se.parse(o.id)}}}return I.warn("No visible output area found for scroll anchor"),null}function Wa(e){if(!e){I.warn("No scroll anchor provided to restore scroll position");return}let t=document.getElementById(se.create(e.cellId));if(!t){I.warn("Could not find cell element to restore scroll position",e.cellId);return}if(!t.querySelector(`.${je.outputArea}`)){I.warn("Could not find output area to restore scroll position",e.cellId);return}t.scrollIntoView({block:"start",behavior:"auto"})}function qe(){let e=(0,Ca.c)(2),t=E(ke),n;return e[0]===t?n=e[1]:(n=()=>{let o=za();t(s=>({mode:rt(s.mode),cellAnchor:(o==null?void 0:o.cellId)??null})),requestAnimationFrame(()=>{requestAnimationFrame(()=>{Wa(o)})})},e[0]=t,e[1]=n),n}const Re=Ye(!1);var Ma=S();const Sa=()=>{let e=(0,Ma.c)(7),{selectedLayout:t}=ve(),{setLayoutView:n}=Ce();if(le()&&!Je("wasm_layouts"))return null;let o;e[0]===n?o=e[1]:(o=i=>n(i),e[0]=n,e[1]=o);let s;e[2]===Symbol.for("react.memo_cache_sentinel")?(s=(0,a.jsx)(Jt,{className:"min-w-[110px] border-border bg-background","data-testid":"layout-select",children:(0,a.jsx)(Gt,{placeholder:"Select a view"})}),e[2]=s):s=e[2];let r;e[3]===Symbol.for("react.memo_cache_sentinel")?(r=(0,a.jsx)($t,{children:(0,a.jsxs)(Kt,{children:[(0,a.jsx)(Bt,{children:"View as"}),Ae.map(Da)]})}),e[3]=r):r=e[3];let l;return e[4]!==t||e[5]!==o?(l=(0,a.jsxs)(Xt,{"data-testid":"layout-select",value:t,onValueChange:o,children:[s,r]}),e[4]=t,e[5]=o,e[6]=l):l=e[6],l};function _a(e){return(0,a.jsx)(Ve(e),{className:"h-4 w-4"})}function Ve(e){switch(e){case"vertical":return ba;case"grid":return Et;case"slides":return Le;default:return ct(e),Tt}}function Fe(e){return xe(e)}function Da(e){return(0,a.jsx)(Yt,{value:e,children:(0,a.jsxs)("div",{className:"flex items-center gap-1.5 leading-5",children:[_a(e),(0,a.jsx)("span",{children:Fe(e)})]})},e)}async function Aa(e){let{filename:t,preset:n,downloadPDF:o}=e;await o({filename:t,webpdf:!1,preset:n,includeInputs:!0,rasterServer:"static"})}var Na=S();function Pa(e){let t=(0,Na.c)(5),{openPrompt:n,closeModal:o}=de(),{sendCopy:s}=L(),r;return t[0]!==o||t[1]!==n||t[2]!==s||t[3]!==e?(r=()=>{if(!e)return null;let l=Ot.guessDeliminator(e);n({title:"Copy notebook",description:"Enter a new filename for the notebook copy.",defaultValue:`_${De.basename(e)}`,confirmText:"Copy notebook",spellCheck:!1,onConfirm:i=>{let d=l.join(De.dirname(e),i);s({source:e,destination:d}).then(()=>{o(),C({title:"Notebook copied",description:"A copy of the notebook has been created."}),ca(d)})}})},t[0]=o,t[1]=n,t[2]=s,t[3]=e,t[4]=r):r=t[4],r}const Ea=()=>{let{updateCellConfig:e}=ye(),{saveCellConfig:t}=L();return(0,ce.useCallback)(async()=>{let n=new Xe,o=be(),s=o.cellIds.inOrderIds,r={};for(let i of s){if(o.cellData[i]===void 0)continue;let{code:d,config:p}=o.cellData[i];p.hide_code||n.isSupported(d)&&(r[i]={hide_code:!0})}let l=ge.entries(r);if(l.length!==0){await t({configs:r});for(let[i,d]of l)e({cellId:i,config:d})}},[e])};var Ia=S();function Oe(){let e=(0,Ia.c)(4),{openConfirm:t}=de(),n=E(ft),{sendRestart:o}=L(),s;return e[0]!==t||e[1]!==o||e[2]!==n?(s=()=>{t({title:"Restart Kernel",description:"This will restart the Python kernel. You'll lose all data that's in memory. You will also lose any unsaved changes, so make sure to save your work before restarting.",variant:"destructive",confirmAction:(0,a.jsx)(Qt,{onClick:async()=>{n({state:yt.CLOSING}),await o(),ia()},"aria-label":"Confirm Restart",children:"Restart"})})},e[0]=t,e[1]=o,e[2]=n,e[3]=s):s=e[3],s}var La=S(),D=e=>{e==null||e.preventDefault(),e==null||e.stopPropagation()};function Ta(){var me,ue;let e=(0,La.c)(45),t=la(),{openModal:n,closeModal:o}=de(),{toggleApplication:s}=dt(),{selectedPanel:r}=Qe(),[l]=Ge(ke),i=ie(ot),d=Ea(),[p]=ut(),{updateCellConfig:w,undoDeleteCell:g,clearAllCellOutputs:u,addSetupCellIfDoesntExist:f,collapseAllCells:y,expandAllCells:k}=ye(),b=Oe(),x=it(),j=Pa(t),v=E(Re),A=E(pt),z=E(mt),{exportAsMarkdown:J,readCode:N,saveCellConfig:X,updateCellOutputs:Z}=L(),Q=ha(),ee=ie(et),te=ie(lt),{selectedLayout:T}=ve(),{setLayoutView:ae}=Ce(),H=qe(),q=((me=p.sharing)==null?void 0:me.html)??!0,R=((ue=p.sharing)==null?void 0:ue.wasm)??!0,pe=!le(),oe=T==="slides",Ue=to,Be=eo,V;e[0]!==t||e[1]!==Q||e[2]!==Z?(V=async c=>{let{preset:m,title:P}=c;if(!t){he();return}await gt(P,async ne=>{await pa({takeScreenshots:()=>Q({progress:ne}),updateCellOutputs:Z}),await Aa({filename:t,preset:m,downloadPDF:jt})})},e[0]=t,e[1]=Q,e[2]=Z,e[3]=V):V=e[3];let W=V,F;e[4]===W?F=e[5]:(F=async()=>{if(pe){await W({preset:"document",title:"Downloading Document PDF..."});return}let c=new Event("export-beforeprint"),m=new Event("export-afterprint");window.dispatchEvent(c),setTimeout(Qa,0),setTimeout(()=>window.dispatchEvent(m),0)},e[4]=W,e[5]=F);let O=F,U;e[6]===Symbol.for("react.memo_cache_sentinel")?(U=(0,a.jsx)(St,{size:14,strokeWidth:1.5}),e[6]=U):U=e[6];let B;e[7]===Symbol.for("react.memo_cache_sentinel")?(B=(0,a.jsx)(ze,{size:14,strokeWidth:1.5}),e[7]=B):B=e[7];let M;e[8]===t?M=e[9]:(M=async()=>{if(!t){he();return}await We({filename:t,includeCode:!0})},e[8]=t,e[9]=M);let G;return e[10]!==f||e[11]!==te||e[12]!==u||e[13]!==o||e[14]!==y||e[15]!==j||e[16]!==W||e[17]!==k||e[18]!==J||e[19]!==t||e[20]!==O||e[21]!==ee||e[22]!==d||e[23]!==oe||e[24]!==i||e[25]!==n||e[26]!==N||e[27]!==b||e[28]!==x||e[29]!==X||e[30]!==T||e[31]!==r||e[32]!==v||e[33]!==z||e[34]!==ae||e[35]!==A||e[36]!==q||e[37]!==R||e[38]!==M||e[39]!==s||e[40]!==H||e[41]!==g||e[42]!==w||e[43]!==l.mode?(G=[{icon:U,label:"Download",handle:D,dropdown:[{icon:B,label:"Download as HTML",handle:M},{icon:(0,a.jsx)(ze,{size:14,strokeWidth:1.5}),label:"Download as HTML (exclude code)",handle:async()=>{if(!t){he();return}await We({filename:t,includeCode:!1})}},{icon:(0,a.jsx)(da,{strokeWidth:1.5,style:{width:14,height:14}}),label:"Download as Markdown",handle:async()=>{let c=await J({download:!1});_e(new Blob([c],{type:"text/plain"}),Se.toMarkdown(document.title))}},{icon:(0,a.jsx)(wt,{size:14,strokeWidth:1.5}),label:"Download Python code",handle:async()=>{let c=await N();_e(new Blob([c.contents],{type:"text/plain"}),Se.toPY(document.title))}},{divider:!0,icon:(0,a.jsx)(Ht,{size:14,strokeWidth:1.5}),label:"Download as PNG",disabled:l.mode!=="present",tooltip:l.mode==="present"?void 0:(0,a.jsxs)("span",{children:["Only available in app view. ",(0,a.jsx)("br",{}),"Toggle with: ",ra("global.hideCode",!1)]}),handle:Za},oe?{divider:!0,icon:(0,a.jsx)(Y,{size:14,strokeWidth:1.5}),label:"Download as PDF",handle:D,dropdown:[{icon:(0,a.jsx)(Y,{size:14,strokeWidth:1.5}),label:"Document Layout",handle:O},{icon:(0,a.jsx)(Y,{size:14,strokeWidth:1.5}),label:"Slides Layout",rightElement:Be(!0),hidden:!pe,handle:async()=>{await W({preset:"slides",title:"Downloading Slides PDF..."})}}]}:{divider:!0,icon:(0,a.jsx)(Y,{size:14,strokeWidth:1.5}),label:"Download as PDF",handle:O}]},{icon:(0,a.jsx)(wa,{size:14,strokeWidth:1.5}),label:"Share",handle:D,hidden:!q&&!R,dropdown:[{icon:(0,a.jsx)(Nt,{size:14,strokeWidth:1.5}),label:"Publish HTML to web",hidden:!q,handle:async()=>{n((0,a.jsx)(ja,{onClose:o}))}},{icon:(0,a.jsx)(qt,{size:14,strokeWidth:1.5}),label:"Create WebAssembly link",hidden:!R,handle:async()=>{await $(sa({code:(await N()).contents})),C({title:"Copied",description:"Link copied to clipboard."})}}]},{icon:(0,a.jsx)(xa,{size:14,strokeWidth:1.5}),label:"Helper panel",redundant:!0,handle:D,dropdown:Ke.flatMap(c=>{let{type:m,Icon:P,hidden:ne}=c;return ne?[]:{label:xe(m),rightElement:Ue(r===m),icon:(0,a.jsx)(P,{size:14,strokeWidth:1.5}),handle:()=>s(m)}})},{icon:(0,a.jsx)(Le,{size:14,strokeWidth:1.5}),label:"Present as",handle:D,dropdown:[{icon:l.mode==="present"?(0,a.jsx)(Ft,{size:14,strokeWidth:1.5}):(0,a.jsx)(Ie,{size:14,strokeWidth:1.5}),label:"Toggle app view",hotkey:"global.hideCode",handle:()=>{H()}},...Ae.map((c,m)=>{let P=Ve(c);return{divider:m===0,label:Fe(c),icon:(0,a.jsx)(P,{size:14,strokeWidth:1.5}),rightElement:(0,a.jsx)("div",{className:"w-8 flex justify-end",children:T===c&&(0,a.jsx)(Me,{size:14})}),handle:()=>{ae(c),l.mode==="edit"&&H()}}})]},{icon:(0,a.jsx)(ya,{size:14,strokeWidth:1.5}),label:"Duplicate notebook",hidden:!t||le(),handle:j},{icon:(0,a.jsx)(Ne,{size:14,strokeWidth:1.5}),label:"Copy code to clipboard",hidden:!t,handle:async()=>{await $((await N()).contents),C({title:"Copied",description:"Code copied to clipboard."})}},{icon:(0,a.jsx)(Wt,{size:14,strokeWidth:1.5}),label:"Enable all cells",hidden:!ee||i,handle:async()=>{let c=Ze(be());await X({configs:ge.fromEntries(c.map(Xa))});for(let m of c)w({cellId:m,config:{disabled:!1}})}},{divider:!0,icon:(0,a.jsx)(Ee,{size:14,strokeWidth:1.5}),label:"Add setup cell",handle:()=>{f({})}},{icon:(0,a.jsx)(tt,{size:14,strokeWidth:1.5}),label:"Add database connection",handle:()=>{n((0,a.jsx)(we,{onClose:o}))}},{icon:(0,a.jsx)(ht,{size:14,strokeWidth:1.5}),label:"Add remote storage",handle:()=>{n((0,a.jsx)(we,{defaultTab:"storage",onClose:o}))}},{icon:(0,a.jsx)(Te,{size:14,strokeWidth:1.5}),label:"Undo cell deletion",hidden:!te||i,handle:()=>{g()}},{icon:(0,a.jsx)(ga,{size:14,strokeWidth:1.5}),label:"Restart kernel",variant:"danger",handle:b},{icon:(0,a.jsx)(fa,{size:14,strokeWidth:1.5}),label:"Re-run all cells",redundant:!0,hotkey:"global.runAll",handle:async()=>{x()}},{icon:(0,a.jsx)(at,{size:14,strokeWidth:1.5}),label:"Clear all outputs",redundant:!0,handle:()=>{u()}},{icon:(0,a.jsx)(_t,{size:14,strokeWidth:1.5}),label:"Hide all markdown code",handle:d,redundant:!0},{icon:(0,a.jsx)(ua,{size:14,strokeWidth:1.5}),label:"Collapse all sections",hotkey:"global.collapseAllSections",handle:y,redundant:!0},{icon:(0,a.jsx)(ma,{size:14,strokeWidth:1.5}),label:"Expand all sections",hotkey:"global.expandAllSections",handle:k,redundant:!0},{divider:!0,icon:(0,a.jsx)(Pe,{size:14,strokeWidth:1.5}),label:"Command palette",hotkey:"global.commandPalette",handle:()=>v(Ja)},{icon:(0,a.jsx)(ka,{size:14,strokeWidth:1.5}),label:"Keyboard shortcuts",hotkey:"global.showHelp",handle:()=>z(Ka)},{icon:(0,a.jsx)(Vt,{size:14,strokeWidth:1.5}),label:"User settings",handle:()=>A($a),redundant:!0},{icon:(0,a.jsx)(zt,{size:14,strokeWidth:1.5}),label:"Resources",handle:D,dropdown:[{icon:(0,a.jsx)(nt,{size:14,strokeWidth:1.5}),label:"Documentation",handle:Ya},{icon:(0,a.jsx)(At,{size:14,strokeWidth:1.5}),label:"GitHub",handle:Ga},{icon:(0,a.jsx)(Pt,{size:14,strokeWidth:1.5}),label:"Discord Community",handle:Ba},{icon:(0,a.jsx)(It,{size:14,strokeWidth:1.5}),label:"YouTube",handle:Ua},{icon:(0,a.jsx)(st,{size:14,strokeWidth:1.5}),label:"Changelog",handle:Oa}]},{divider:!0,icon:(0,a.jsx)(Lt,{size:14,strokeWidth:1.5}),label:"Return home",hidden:!location.search.includes("file"),handle:Fa},{icon:(0,a.jsx)(Dt,{size:14,strokeWidth:1.5}),label:"New notebook",hidden:!location.search.includes("file"),handle:Va}].filter(Ra).map(Ha),e[10]=f,e[11]=te,e[12]=u,e[13]=o,e[14]=y,e[15]=j,e[16]=W,e[17]=k,e[18]=J,e[19]=t,e[20]=O,e[21]=ee,e[22]=d,e[23]=oe,e[24]=i,e[25]=n,e[26]=N,e[27]=b,e[28]=x,e[29]=X,e[30]=T,e[31]=r,e[32]=v,e[33]=z,e[34]=ae,e[35]=A,e[36]=q,e[37]=R,e[38]=M,e[39]=s,e[40]=H,e[41]=g,e[42]=w,e[43]=l.mode,e[44]=G):G=e[44],G}function Ha(e){return e.dropdown?{...e,dropdown:e.dropdown.filter(qa)}:e}function qa(e){return!e.hidden}function Ra(e){return!e.hidden}function Va(){let e=Ut();window.open(e,"_blank")}function Fa(){let e=document.baseURI.split("?")[0];window.open(e,"_self")}function Oa(){window.open(_.releasesPage,"_blank")}function Ua(){window.open(_.youtube,"_blank")}function Ba(){window.open(_.discordLink,"_blank")}function Ga(){window.open(_.githubPage,"_blank")}function Ya(){window.open(_.docsPage,"_blank")}function $a(e){return!e}function Ka(e){return!e}function Ja(e){return!e}function Xa(e){return[e,{disabled:!1}]}async function Za(){let e=document.getElementById("App");e&&await vt({element:e,filename:document.title,prepare:Ct})}function Qa(){return window.print()}function eo(e){return e?(0,a.jsx)("span",{className:"ml-3 shrink-0 rounded-full border border-emerald-200 bg-emerald-50 px-2 py-0.5 text-[10px] font-semibold uppercase tracking-wide text-emerald-700",children:"Recommended"}):null}function to(e){return(0,a.jsx)("div",{className:"w-8 flex justify-end",children:e&&(0,a.jsx)(Me,{size:14})})}function he(){C({title:"Error",description:"Notebooks must be named to be exported.",variant:"danger"})}export{qe as a,Ee as c,Re as i,Pe as l,Oe as n,Te as o,Sa as r,Ie as s,Ta as t,Ne as u};
|
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-
|
|
69
|
+
<script type="module" crossorigin src="./assets/index-B8ImLAg8.js"></script>
|
|
70
70
|
<link rel="modulepreload" crossorigin href="./assets/preload-helper-TXkS1QI3.js">
|
|
71
71
|
<link rel="modulepreload" crossorigin href="./assets/clsx-A78R3nYl.js">
|
|
72
72
|
<link rel="modulepreload" crossorigin href="./assets/cn-d_A4rA-x.js">
|
|
@@ -206,7 +206,7 @@
|
|
|
206
206
|
<link rel="modulepreload" crossorigin href="./assets/useDateFormatter-CmtFqjqu.js">
|
|
207
207
|
<link rel="modulepreload" crossorigin href="./assets/range-BGa3qZre.js">
|
|
208
208
|
<link rel="modulepreload" crossorigin href="./assets/table-CeILsq6V.js">
|
|
209
|
-
<link rel="modulepreload" crossorigin href="./assets/JsonOutput-
|
|
209
|
+
<link rel="modulepreload" crossorigin href="./assets/JsonOutput-GlMQ3aLA.js">
|
|
210
210
|
<link rel="modulepreload" crossorigin href="./assets/useDeleteCell-BAfiIxKf.js">
|
|
211
211
|
<link rel="modulepreload" crossorigin href="./assets/icons-B9sHgc9n.js">
|
|
212
212
|
<link rel="modulepreload" crossorigin href="./assets/process-output-4yip1nZE.js">
|
|
@@ -223,13 +223,13 @@
|
|
|
223
223
|
<link rel="modulepreload" crossorigin href="./assets/square-function-4zY5Dv0P.js">
|
|
224
224
|
<link rel="modulepreload" crossorigin href="./assets/spec-Be-iRLAY.js">
|
|
225
225
|
<link rel="modulepreload" crossorigin href="./assets/components-CF9x5raB.js">
|
|
226
|
-
<link rel="modulepreload" crossorigin href="./assets/column-preview-
|
|
226
|
+
<link rel="modulepreload" crossorigin href="./assets/column-preview-BhU5Ow0e.js">
|
|
227
227
|
<link rel="modulepreload" crossorigin href="./assets/toggle-BhEcsHTu.js">
|
|
228
228
|
<link rel="modulepreload" crossorigin href="./assets/globals-BlB0Ba6E.js">
|
|
229
229
|
<link rel="modulepreload" crossorigin href="./assets/share-sD4fbzpH.js">
|
|
230
230
|
<link rel="modulepreload" crossorigin href="./assets/_baseSet-BEHvSeoM.js">
|
|
231
231
|
<link rel="modulepreload" crossorigin href="./assets/react-resizable-panels.browser.esm-RgA6v8U3.js">
|
|
232
|
-
<link rel="modulepreload" crossorigin href="./assets/context-aware-panel-
|
|
232
|
+
<link rel="modulepreload" crossorigin href="./assets/context-aware-panel-HnyO4-L2.js">
|
|
233
233
|
<link rel="modulepreload" crossorigin href="./assets/floating-outline-BWK_nLJy.js">
|
|
234
234
|
<link rel="modulepreload" crossorigin href="./assets/useAddCell-BRlAqdmq.js">
|
|
235
235
|
<link rel="modulepreload" crossorigin href="./assets/eye-off-DgTL09j7.js">
|
|
@@ -257,7 +257,7 @@
|
|
|
257
257
|
<link rel="stylesheet" crossorigin href="./assets/cells-jmgGt1lS.css">
|
|
258
258
|
<link rel="stylesheet" crossorigin href="./assets/markdown-renderer-DdDKmWlR.css">
|
|
259
259
|
<link rel="stylesheet" crossorigin href="./assets/JsonOutput-B7vuddcd.css">
|
|
260
|
-
<link rel="stylesheet" crossorigin href="./assets/index-
|
|
260
|
+
<link rel="stylesheet" crossorigin href="./assets/index-Dzwe9vKA.css">
|
|
261
261
|
</head>
|
|
262
262
|
<body>
|
|
263
263
|
<div id="root"></div>
|
package/package.json
CHANGED
|
@@ -3,6 +3,7 @@
|
|
|
3
3
|
import type { Table } from "@tanstack/react-table";
|
|
4
4
|
import { render, screen } from "@testing-library/react";
|
|
5
5
|
import { useEffect } from "react";
|
|
6
|
+
import { I18nProvider } from "react-aria";
|
|
6
7
|
import { describe, expect, it } from "vitest";
|
|
7
8
|
import { SELECT_COLUMN_ID } from "../../types";
|
|
8
9
|
import { useCellSelectionReducerActions } from "../atoms";
|
|
@@ -21,7 +22,11 @@ const TestHarness = ({
|
|
|
21
22
|
useEffect(() => {
|
|
22
23
|
actions.setSelectedCells(selectedCellIds);
|
|
23
24
|
}, [actions, selectedCellIds]);
|
|
24
|
-
return
|
|
25
|
+
return (
|
|
26
|
+
<I18nProvider locale="en-US">
|
|
27
|
+
<CellSelectionStats table={table} />
|
|
28
|
+
</I18nProvider>
|
|
29
|
+
);
|
|
25
30
|
};
|
|
26
31
|
|
|
27
32
|
describe("CellSelectionStats", () => {
|
|
@@ -107,7 +112,7 @@ describe("CellSelectionStats", () => {
|
|
|
107
112
|
expect(screen.queryByText(/Average:/)).not.toBeInTheDocument();
|
|
108
113
|
});
|
|
109
114
|
|
|
110
|
-
it("should round sum and average to
|
|
115
|
+
it("should round sum and average to 3 decimal places", () => {
|
|
111
116
|
const row = createMockRow("0", [
|
|
112
117
|
createMockCell("0_0", 0.112_233_441_1),
|
|
113
118
|
createMockCell("0_1", 0.112_233_441_1),
|
|
@@ -120,14 +125,14 @@ describe("CellSelectionStats", () => {
|
|
|
120
125
|
</CellSelectionProvider>,
|
|
121
126
|
);
|
|
122
127
|
|
|
123
|
-
expect(screen.getByText("Sum: 0.
|
|
124
|
-
expect(screen.getByText("Average: 0.
|
|
128
|
+
expect(screen.getByText("Sum: 0.224")).toBeInTheDocument();
|
|
129
|
+
expect(screen.getByText("Average: 0.112")).toBeInTheDocument();
|
|
125
130
|
});
|
|
126
131
|
|
|
127
|
-
it("should correctly round sum and average to
|
|
132
|
+
it("should correctly round sum and average to 3 decimal places", () => {
|
|
128
133
|
const row = createMockRow("0", [
|
|
129
|
-
createMockCell("0_0", 0.
|
|
130
|
-
createMockCell("0_1", 0.
|
|
134
|
+
createMockCell("0_0", 0.112_833_443_3),
|
|
135
|
+
createMockCell("0_1", 0.112_833_443_3),
|
|
131
136
|
]);
|
|
132
137
|
const table = createMockTable([row], []);
|
|
133
138
|
|
|
@@ -137,8 +142,8 @@ describe("CellSelectionStats", () => {
|
|
|
137
142
|
</CellSelectionProvider>,
|
|
138
143
|
);
|
|
139
144
|
|
|
140
|
-
expect(screen.getByText("Sum: 0.
|
|
141
|
-
expect(screen.getByText("Average: 0.
|
|
145
|
+
expect(screen.getByText("Sum: 0.226")).toBeInTheDocument();
|
|
146
|
+
expect(screen.getByText("Average: 0.113")).toBeInTheDocument();
|
|
142
147
|
});
|
|
143
148
|
|
|
144
149
|
it("should not add extra decimal places to sum and average", () => {
|
|
@@ -2,6 +2,7 @@
|
|
|
2
2
|
|
|
3
3
|
import type { Table } from "@tanstack/react-table";
|
|
4
4
|
import { useAtomValue } from "jotai";
|
|
5
|
+
import { useLocale } from "react-aria";
|
|
5
6
|
import { cn } from "@/utils/cn";
|
|
6
7
|
import { selectedCellsAtom } from "./atoms";
|
|
7
8
|
import {
|
|
@@ -9,6 +10,9 @@ import {
|
|
|
9
10
|
getNumericValuesFromSelectedCells,
|
|
10
11
|
} from "./utils";
|
|
11
12
|
|
|
13
|
+
// Offers a good default for most use cases.
|
|
14
|
+
const MAX_FRACTION_DIGITS = 3;
|
|
15
|
+
|
|
12
16
|
/**
|
|
13
17
|
* Displays summary stats (Count, Sum, Average) for the current cell selection.
|
|
14
18
|
* Renders only when 2+ data cells are selected (checkbox column excluded).
|
|
@@ -22,6 +26,7 @@ export const CellSelectionStats = <TData,>({
|
|
|
22
26
|
table: Table<TData>;
|
|
23
27
|
className?: string;
|
|
24
28
|
}) => {
|
|
29
|
+
const { locale } = useLocale();
|
|
25
30
|
const selectedCells = useAtomValue(selectedCellsAtom);
|
|
26
31
|
const dataCellCount = countDataCellsInSelection(selectedCells);
|
|
27
32
|
|
|
@@ -38,42 +43,68 @@ export const CellSelectionStats = <TData,>({
|
|
|
38
43
|
className,
|
|
39
44
|
)}
|
|
40
45
|
>
|
|
41
|
-
<CountStat count={dataCellCount} />
|
|
42
|
-
<SumStat numericValues={numericValues} />
|
|
43
|
-
<AverageStat numericValues={numericValues} />
|
|
46
|
+
<CountStat count={dataCellCount} locale={locale} />
|
|
47
|
+
<SumStat numericValues={numericValues} locale={locale} />
|
|
48
|
+
<AverageStat numericValues={numericValues} locale={locale} />
|
|
44
49
|
</div>
|
|
45
50
|
);
|
|
46
51
|
};
|
|
47
52
|
|
|
48
|
-
const
|
|
53
|
+
const formatNumber = (value: number, locale: string): string => {
|
|
54
|
+
return value.toLocaleString(locale, {
|
|
55
|
+
maximumFractionDigits: MAX_FRACTION_DIGITS,
|
|
56
|
+
});
|
|
57
|
+
};
|
|
58
|
+
|
|
59
|
+
const StatSpan = ({
|
|
60
|
+
name,
|
|
61
|
+
value,
|
|
62
|
+
locale,
|
|
63
|
+
}: {
|
|
64
|
+
name: string;
|
|
65
|
+
value: number;
|
|
66
|
+
locale: string;
|
|
67
|
+
}) => {
|
|
49
68
|
return (
|
|
50
69
|
<span>
|
|
51
|
-
{
|
|
70
|
+
{name}: {formatNumber(value, locale)}
|
|
52
71
|
</span>
|
|
53
72
|
);
|
|
54
73
|
};
|
|
55
74
|
|
|
56
|
-
const CountStat = ({ count }: { count: number }) => {
|
|
57
|
-
return StatSpan
|
|
75
|
+
const CountStat = ({ count, locale }: { count: number; locale: string }) => {
|
|
76
|
+
return <StatSpan name="Count" value={count} locale={locale} />;
|
|
58
77
|
};
|
|
59
78
|
|
|
60
|
-
const SumStat = ({
|
|
79
|
+
const SumStat = ({
|
|
80
|
+
numericValues,
|
|
81
|
+
locale,
|
|
82
|
+
}: {
|
|
83
|
+
numericValues: number[];
|
|
84
|
+
locale: string;
|
|
85
|
+
}) => {
|
|
61
86
|
if (numericValues.length === 0) {
|
|
62
87
|
return null;
|
|
63
88
|
}
|
|
64
89
|
|
|
65
90
|
const sum = numericValues.reduce((acc, n) => acc + n, 0);
|
|
66
|
-
const sumRounded = Number(sum.toFixed(
|
|
67
|
-
return StatSpan
|
|
91
|
+
const sumRounded = Number(sum.toFixed(MAX_FRACTION_DIGITS));
|
|
92
|
+
return <StatSpan name="Sum" value={sumRounded} locale={locale} />;
|
|
68
93
|
};
|
|
69
94
|
|
|
70
|
-
const AverageStat = ({
|
|
95
|
+
const AverageStat = ({
|
|
96
|
+
numericValues,
|
|
97
|
+
locale,
|
|
98
|
+
}: {
|
|
99
|
+
numericValues: number[];
|
|
100
|
+
locale: string;
|
|
101
|
+
}) => {
|
|
71
102
|
if (numericValues.length === 0) {
|
|
72
103
|
return null;
|
|
73
104
|
}
|
|
74
105
|
|
|
75
106
|
const average =
|
|
76
107
|
numericValues.reduce((acc, n) => acc + n, 0) / numericValues.length;
|
|
77
|
-
const averageRounded = Number(average.toFixed(
|
|
78
|
-
return StatSpan
|
|
108
|
+
const averageRounded = Number(average.toFixed(MAX_FRACTION_DIGITS));
|
|
109
|
+
return <StatSpan name="Average" value={averageRounded} locale={locale} />;
|
|
79
110
|
};
|
package/src/components/editor/connections/storage/__tests__/__snapshots__/as-code.test.ts.snap
CHANGED
|
@@ -29,6 +29,43 @@ store = AzureStore("my-container",
|
|
|
29
29
|
)"
|
|
30
30
|
`;
|
|
31
31
|
|
|
32
|
+
exports[`generateStorageCode > CoreWeave > basic connection with all fields 1`] = `
|
|
33
|
+
"from obstore.store import S3Store
|
|
34
|
+
|
|
35
|
+
store = S3Store("operator-bucket",
|
|
36
|
+
region="US-EAST-04A",
|
|
37
|
+
access_key_id="AKIAIOSFODNN7EXAMPLE",
|
|
38
|
+
secret_access_key="wJalrXUtnFEMI/K7MDENG/bPxRfiCYEXAMPLEKEY",
|
|
39
|
+
endpoint="https://operator-bucket.cwobject.com",
|
|
40
|
+
virtual_hosted_style_request=True,
|
|
41
|
+
)"
|
|
42
|
+
`;
|
|
43
|
+
|
|
44
|
+
exports[`generateStorageCode > CoreWeave > minimal connection (bucket and region only) 1`] = `
|
|
45
|
+
"from obstore.store import S3Store
|
|
46
|
+
|
|
47
|
+
store = S3Store("operator-bucket",
|
|
48
|
+
region="US-EAST-04A",
|
|
49
|
+
endpoint="https://operator-bucket.cwobject.com",
|
|
50
|
+
virtual_hosted_style_request=True,
|
|
51
|
+
)"
|
|
52
|
+
`;
|
|
53
|
+
|
|
54
|
+
exports[`generateStorageCode > CoreWeave > with secrets 1`] = `
|
|
55
|
+
"from obstore.store import S3Store
|
|
56
|
+
import os
|
|
57
|
+
|
|
58
|
+
_access_key_id = os.environ.get("COREWEAVE_OBJECT_STORAGE_KEY")
|
|
59
|
+
_secret_access_key = os.environ.get("COREWEAVE_OBJECT_STORAGE_SECRET")
|
|
60
|
+
store = S3Store("operator-bucket",
|
|
61
|
+
region="US-EAST-04A",
|
|
62
|
+
access_key_id=_access_key_id,
|
|
63
|
+
secret_access_key=_secret_access_key,
|
|
64
|
+
endpoint="https://operator-bucket.cwobject.com",
|
|
65
|
+
virtual_hosted_style_request=True,
|
|
66
|
+
)"
|
|
67
|
+
`;
|
|
68
|
+
|
|
32
69
|
exports[`generateStorageCode > GCS > with service account key 1`] = `
|
|
33
70
|
"from obstore.store import GCSStore
|
|
34
71
|
import json
|
|
@@ -27,6 +27,14 @@ describe("generateStorageCode", () => {
|
|
|
27
27
|
account_key: "base64accountkey==",
|
|
28
28
|
};
|
|
29
29
|
|
|
30
|
+
const baseCoreWeave: StorageConnection = {
|
|
31
|
+
type: "coreweave",
|
|
32
|
+
bucket: "operator-bucket",
|
|
33
|
+
region: "US-EAST-04A",
|
|
34
|
+
access_key_id: "AKIAIOSFODNN7EXAMPLE",
|
|
35
|
+
secret_access_key: "wJalrXUtnFEMI/K7MDENG/bPxRfiCYEXAMPLEKEY",
|
|
36
|
+
};
|
|
37
|
+
|
|
30
38
|
const baseGDrive: StorageConnection = {
|
|
31
39
|
type: "gdrive",
|
|
32
40
|
credentials_json:
|
|
@@ -105,6 +113,32 @@ describe("generateStorageCode", () => {
|
|
|
105
113
|
});
|
|
106
114
|
});
|
|
107
115
|
|
|
116
|
+
describe("CoreWeave", () => {
|
|
117
|
+
it("basic connection with all fields", () => {
|
|
118
|
+
expect(generateStorageCode(baseCoreWeave, "obstore")).toMatchSnapshot();
|
|
119
|
+
});
|
|
120
|
+
|
|
121
|
+
it("minimal connection (bucket and region only)", () => {
|
|
122
|
+
const conn: StorageConnection = {
|
|
123
|
+
type: "coreweave",
|
|
124
|
+
bucket: "operator-bucket",
|
|
125
|
+
region: "US-EAST-04A",
|
|
126
|
+
};
|
|
127
|
+
expect(generateStorageCode(conn, "obstore")).toMatchSnapshot();
|
|
128
|
+
});
|
|
129
|
+
|
|
130
|
+
it("with secrets", () => {
|
|
131
|
+
const conn: StorageConnection = {
|
|
132
|
+
type: "coreweave",
|
|
133
|
+
bucket: "operator-bucket",
|
|
134
|
+
region: "US-EAST-04A",
|
|
135
|
+
access_key_id: prefixSecret("COREWEAVE_OBJECT_STORAGE_KEY"),
|
|
136
|
+
secret_access_key: prefixSecret("COREWEAVE_OBJECT_STORAGE_SECRET"),
|
|
137
|
+
};
|
|
138
|
+
expect(generateStorageCode(conn, "obstore")).toMatchSnapshot();
|
|
139
|
+
});
|
|
140
|
+
});
|
|
141
|
+
|
|
108
142
|
describe("Google Drive", () => {
|
|
109
143
|
it("with service account credentials", () => {
|
|
110
144
|
expect(generateStorageCode(baseGDrive, "fsspec")).toMatchSnapshot();
|
|
@@ -162,5 +196,31 @@ describe("generateStorageCode", () => {
|
|
|
162
196
|
),
|
|
163
197
|
).toThrow();
|
|
164
198
|
});
|
|
199
|
+
|
|
200
|
+
it("throws for empty CoreWeave bucket", () => {
|
|
201
|
+
expect(() =>
|
|
202
|
+
generateStorageCode(
|
|
203
|
+
{
|
|
204
|
+
type: "coreweave",
|
|
205
|
+
bucket: "",
|
|
206
|
+
region: "US-EAST-04A",
|
|
207
|
+
} as StorageConnection,
|
|
208
|
+
"obstore",
|
|
209
|
+
),
|
|
210
|
+
).toThrow();
|
|
211
|
+
});
|
|
212
|
+
|
|
213
|
+
it("throws for empty CoreWeave region", () => {
|
|
214
|
+
expect(() =>
|
|
215
|
+
generateStorageCode(
|
|
216
|
+
{
|
|
217
|
+
type: "coreweave",
|
|
218
|
+
bucket: "operator-bucket",
|
|
219
|
+
region: "",
|
|
220
|
+
} as StorageConnection,
|
|
221
|
+
"obstore",
|
|
222
|
+
),
|
|
223
|
+
).toThrow();
|
|
224
|
+
});
|
|
165
225
|
});
|
|
166
226
|
});
|
|
@@ -4,6 +4,7 @@ import { useState } from "react";
|
|
|
4
4
|
import type { FieldValues } from "react-hook-form";
|
|
5
5
|
import type { z } from "zod";
|
|
6
6
|
import { ProtocolIcon } from "@/components/storage/components";
|
|
7
|
+
import type { KnownStorageProtocol } from "@/core/storage/types";
|
|
7
8
|
import { ConnectionForm, SelectorButton, SelectorGrid } from "../components";
|
|
8
9
|
import {
|
|
9
10
|
generateStorageCode,
|
|
@@ -12,6 +13,7 @@ import {
|
|
|
12
13
|
} from "./as-code";
|
|
13
14
|
import {
|
|
14
15
|
AzureStorageSchema,
|
|
16
|
+
CoreWeaveStorageSchema,
|
|
15
17
|
GCSStorageSchema,
|
|
16
18
|
GoogleDriveStorageSchema,
|
|
17
19
|
S3StorageSchema,
|
|
@@ -21,7 +23,6 @@ import {
|
|
|
21
23
|
interface StorageProviderSchema {
|
|
22
24
|
name: string;
|
|
23
25
|
schema: z.ZodType<StorageConnection, FieldValues>;
|
|
24
|
-
color: string;
|
|
25
26
|
protocol: string;
|
|
26
27
|
storageLibraries: {
|
|
27
28
|
libraries: StorageLibrary[];
|
|
@@ -29,11 +30,12 @@ interface StorageProviderSchema {
|
|
|
29
30
|
};
|
|
30
31
|
}
|
|
31
32
|
|
|
33
|
+
const BACKGROUND_COLOR = "#232F3E";
|
|
34
|
+
|
|
32
35
|
const STORAGE_PROVIDERS = [
|
|
33
36
|
{
|
|
34
37
|
name: "Amazon S3",
|
|
35
38
|
schema: S3StorageSchema,
|
|
36
|
-
color: "#232F3E",
|
|
37
39
|
protocol: "s3",
|
|
38
40
|
storageLibraries: {
|
|
39
41
|
libraries: ["obstore"],
|
|
@@ -43,7 +45,6 @@ const STORAGE_PROVIDERS = [
|
|
|
43
45
|
{
|
|
44
46
|
name: "Google Cloud Storage",
|
|
45
47
|
schema: GCSStorageSchema,
|
|
46
|
-
color: "#4285F4",
|
|
47
48
|
protocol: "gcs",
|
|
48
49
|
storageLibraries: {
|
|
49
50
|
libraries: ["obstore"],
|
|
@@ -53,17 +54,24 @@ const STORAGE_PROVIDERS = [
|
|
|
53
54
|
{
|
|
54
55
|
name: "Azure Blob Storage",
|
|
55
56
|
schema: AzureStorageSchema,
|
|
56
|
-
color: "#0062AD",
|
|
57
57
|
protocol: "azure",
|
|
58
58
|
storageLibraries: {
|
|
59
59
|
libraries: ["obstore"],
|
|
60
60
|
preferred: "obstore",
|
|
61
61
|
},
|
|
62
62
|
},
|
|
63
|
+
{
|
|
64
|
+
name: "CoreWeave",
|
|
65
|
+
schema: CoreWeaveStorageSchema,
|
|
66
|
+
protocol: "coreweave",
|
|
67
|
+
storageLibraries: {
|
|
68
|
+
libraries: ["obstore"],
|
|
69
|
+
preferred: "obstore",
|
|
70
|
+
},
|
|
71
|
+
},
|
|
63
72
|
{
|
|
64
73
|
name: "Google Drive",
|
|
65
74
|
schema: GoogleDriveStorageSchema,
|
|
66
|
-
color: "#177834",
|
|
67
75
|
protocol: "gdrive",
|
|
68
76
|
storageLibraries: {
|
|
69
77
|
libraries: ["fsspec"],
|
|
@@ -77,18 +85,17 @@ const StorageProviderSelector: React.FC<{
|
|
|
77
85
|
}> = ({ onSelect }) => {
|
|
78
86
|
return (
|
|
79
87
|
<SelectorGrid>
|
|
80
|
-
{STORAGE_PROVIDERS.map(({ name, schema,
|
|
88
|
+
{STORAGE_PROVIDERS.map(({ name, schema, protocol }) => (
|
|
81
89
|
<SelectorButton
|
|
82
90
|
key={name}
|
|
83
91
|
name={name}
|
|
84
|
-
color={
|
|
92
|
+
color={BACKGROUND_COLOR}
|
|
85
93
|
icon={
|
|
86
|
-
<
|
|
87
|
-
|
|
88
|
-
|
|
89
|
-
|
|
90
|
-
|
|
91
|
-
</span>
|
|
94
|
+
<ProtocolIcon
|
|
95
|
+
protocol={protocol as KnownStorageProtocol}
|
|
96
|
+
forceDark={true}
|
|
97
|
+
className="w-7.5 h-7.5"
|
|
98
|
+
/>
|
|
92
99
|
}
|
|
93
100
|
onSelect={() => onSelect(schema)}
|
|
94
101
|
/>
|
|
@@ -125,6 +125,40 @@ function generateAzureCode(
|
|
|
125
125
|
return { imports, code };
|
|
126
126
|
}
|
|
127
127
|
|
|
128
|
+
function generateCoreWeaveCode(
|
|
129
|
+
connection: Extract<StorageConnection, { type: "coreweave" }>,
|
|
130
|
+
secrets: SecretContainer,
|
|
131
|
+
): { imports: Set<string>; code: string } {
|
|
132
|
+
const bucket = secrets.print("bucket", connection.bucket);
|
|
133
|
+
const imports = new Set(["from obstore.store import S3Store"]);
|
|
134
|
+
const params: string[] = [
|
|
135
|
+
` region=${secrets.print("region", connection.region)},`,
|
|
136
|
+
];
|
|
137
|
+
|
|
138
|
+
if (connection.access_key_id) {
|
|
139
|
+
params.push(
|
|
140
|
+
` access_key_id=${secrets.print("access_key_id", connection.access_key_id)},`,
|
|
141
|
+
);
|
|
142
|
+
}
|
|
143
|
+
if (connection.secret_access_key) {
|
|
144
|
+
params.push(
|
|
145
|
+
` secret_access_key=${secrets.print("secret_access_key", connection.secret_access_key)},`,
|
|
146
|
+
);
|
|
147
|
+
}
|
|
148
|
+
|
|
149
|
+
params.push(
|
|
150
|
+
` endpoint="https://${connection.bucket}.cwobject.com",`,
|
|
151
|
+
" virtual_hosted_style_request=True,",
|
|
152
|
+
);
|
|
153
|
+
|
|
154
|
+
const paramsStr = `\n${params.join("\n")}\n`;
|
|
155
|
+
|
|
156
|
+
const code = dedent(`
|
|
157
|
+
store = S3Store(${bucket},${paramsStr})
|
|
158
|
+
`);
|
|
159
|
+
return { imports, code };
|
|
160
|
+
}
|
|
161
|
+
|
|
128
162
|
function generateGDriveCode(
|
|
129
163
|
connection: Extract<StorageConnection, { type: "gdrive" }>,
|
|
130
164
|
secrets: SecretContainer,
|
|
@@ -169,6 +203,9 @@ export function generateStorageCode(
|
|
|
169
203
|
case "azure":
|
|
170
204
|
result = generateAzureCode(connection, secrets);
|
|
171
205
|
break;
|
|
206
|
+
case "coreweave":
|
|
207
|
+
result = generateCoreWeaveCode(connection, secrets);
|
|
208
|
+
break;
|
|
172
209
|
case "gdrive":
|
|
173
210
|
result = generateGDriveCode(connection, secrets);
|
|
174
211
|
break;
|