react-semaphor 0.0.524 → 0.0.525

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.
@@ -366,7 +366,7 @@
366
366
  ${l?`Python:
367
367
  ${l}`:""}
368
368
  `;g(z)}function F(){return e.jsxs(e.Fragment,{children:[r&&e.jsx("div",{className:"relative flex w-1/3 min-w-0 grow overflow-hidden text-xs",role:"editor-filter-container",children:e.jsx("div",{className:"mt-2 w-[99%]",children:e.jsx(Gn,{jsonString:JSON.stringify(x,null,2)})})}),x&&x.length>0&&e.jsx(t.Button,{variant:"ghost",onClick:()=>o(!r),className:"absolute bottom-0 right-6 size-7 p-1",children:r?e.jsx(t.X,{className:"size-3.5 text-muted-foreground"}):e.jsx(t.Filter,{className:"size-3.5 text-muted-foreground"})})]})}function P(){return e.jsxs(t.ResizablePanelGroup,{className:"flex grow pb-1",direction:"vertical",role:"editor-resizable-group",children:[e.jsxs(t.ResizablePanel,{id:"1",order:1,defaultSize:a?20:100,className:"relative flex grow",children:[e.jsx("div",{id:"sql-container",className:"relative flex w-[99%]",children:e.jsx(qn,{})}),a&&e.jsx("code",{className:"absolute right-6 top-3 text-xs text-muted-foreground/70",children:"sql"})]}),a&&e.jsxs(e.Fragment,{children:[e.jsx(t.ResizableHandle,{withHandle:!0,className:"border"}),e.jsxs(t.ResizablePanel,{id:"2",order:2,defaultSize:80,className:"relative flex grow",children:[e.jsx("div",{id:"python-container",className:"relative flex w-[99%] pt-0",children:e.jsx(_n,{})}),e.jsx("code",{className:"absolute right-6 top-3 text-xs text-muted-foreground/70",children:"python"})]})]})]})}function R(){return e.jsxs("div",{role:"editor-controls",className:"item-center flex flex-wrap justify-between gap-2 px-6 py-4",children:[e.jsxs("div",{className:"flex grow items-center gap-2",children:[e.jsxs(t.Button,{title:"Shift + Enter",disabled:S||D,onClick:()=>{T()},className:"h-8 shrink-0",size:"sm",children:[S||D?e.jsx(t.LoaderCircle,{className:"mr-2 h-4 w-4 animate-spin"}):e.jsx(t.Play,{className:"mr-2 h-4 w-4"}),"Run"]}),e.jsx(Kt,{sql:C==null?void 0:C.sql,error:b,onDebugWithAssistant:A}),e.jsx(t.EditorClearButton,{}),e.jsx(t.Toggle,{pressed:a,onPressedChange:z=>n(z),className:"",size:"sm",children:e.jsx(Rn,{className:"size-4 text-foreground/70"})}),e.jsx("button",{disabled:c,onClick:()=>{O(!0)},className:"h-9 w-full cursor-text px-3 text-left text-sm text-muted-foreground",children:c?"":"Type your question..."})]}),e.jsxs("div",{className:"flex items-center gap-2",children:[e.jsx(t.EditorCancelButton,{}),e.jsx(t.EditorAcceptButton,{})]})]})}return e.jsxs("section",{role:"editor-section",className:"flex grow flex-col justify-end",children:[e.jsxs("div",{className:"relative flex grow justify-between overflow-y-scroll",children:[P(),F()]}),R()]})}function Jn({data:s}){var c;const[a,n]=L.useState([]),o=Object.keys(s[0]).map(d=>({accessorKey:d,header:({column:l})=>{const x=l.getIsSorted();return e.jsx("div",{className:"flex gap-2",children:e.jsxs("div",{className:"flex cursor-pointer items-center",onClick:()=>l.toggleSorting(l.getIsSorted()==="asc"),children:[d,x==="asc"?e.jsx(t.TriangleUpIcon,{className:"ml-2 h-5 w-5"}):x==="desc"?e.jsx(t.TriangleDownIcon,{className:"ml-2 h-5 w-5"}):null]})})}})),i=t.useReactTable({data:s,columns:o,getCoreRowModel:t.getCoreRowModel(),getPaginationRowModel:t.getPaginationRowModel(),onSortingChange:n,getSortedRowModel:t.getSortedRowModel(),manualPagination:!0,state:{sorting:a}});return e.jsxs(t.CustomScrollArea,{className:"grow overflow-auto font-mono text-xs text-foreground/95",children:[e.jsxs("table",{className:"w-full",children:[e.jsx(t.TableHeader,{className:"sticky top-0 z-50 h-0 bg-muted",children:i.getHeaderGroups().map(d=>e.jsx(t.TableRow,{className:"",children:d.headers.map(l=>e.jsx(t.TableHead,{className:"h-11 font-semibold text-foreground",children:l.isPlaceholder?null:t.flexRender(l.column.columnDef.header,l.getContext())},l.id))},d.id))}),e.jsx(t.TableBody,{children:(c=i.getRowModel().rows)!=null&&c.length?i.getRowModel().rows.map(d=>e.jsx(t.TableRow,{className:"h-11 whitespace-nowrap py-2","data-state":d.getIsSelected()&&"selected",children:d.getVisibleCells().map(l=>e.jsx(t.TableCell,{className:"py-2",children:t.flexRender(l.column.columnDef.cell,l.getContext())},l.id))},d.id)):e.jsx(t.TableRow,{children:e.jsx(t.TableCell,{colSpan:o.length,className:"h-24 text-center",children:"No results."})})})]}),e.jsx(t.ScrollBar,{orientation:"horizontal"})]})}function Hn({card:s}){var g,O,I,k,v,C,S,D,w,m,B;const[a,n]=L.useState(!1),[r,o]=L.useState([]),{authToken:i}=t.useSemaphorContext(),c=t.getTokenParams(i==null?void 0:i.accessToken),d=t.useDashboardStore(M=>M.themeStyle),l={colors:((O=(g=d==null?void 0:d.chart)==null?void 0:g.dataset)==null?void 0:O.backgroundColor)||[]};(I=s.customCardPreferences)!=null&&I.inputData;const{getCard:x}=t.useCustomVisual(((k=s.customCardPreferences)==null?void 0:k.url)||""),h=((v=s.customCardPreferences)==null?void 0:v.visualType)||"single",u=t.useEditorStore(M=>M.frame),{setCustomCardPreferences:j}=t.useEditorActions(),{data:y}=t.useDashboardCardQuery(s),N=L.useCallback((M,T)=>{o(b=>({...b,[M]:T}))},[]);if(!((C=s.customCardPreferences)!=null&&C.componentName))return null;const f=x((S=s.customCardPreferences)==null?void 0:S.componentName);function E(M){n(M)}const p=Object.keys(((D=s.customCardPreferences)==null?void 0:D.dataInputCardIds)||{}).map(M=>{var A,F,P;const T=(F=(A=s.customCardPreferences)==null?void 0:A.dataInputCardIds)==null?void 0:F[M].cardId,b=(P=u==null?void 0:u.cards)==null?void 0:P.find(R=>R.id===T);return b||null});return e.jsx("div",{className:"semaphor-custom mb-3 flex grow basis-0 flex-col space-y-2 overflow-y-auto",children:e.jsxs(L.Suspense,{fallback:e.jsx(e.Fragment,{}),children:[f&&h==="single"&&e.jsx(f,{params:c,theme:l,settings:(w=s.customCardPreferences)==null?void 0:w.settings,onDataChange:N,data:(y==null?void 0:y.records)||[]}),f&&h==="multiple"&&e.jsxs(e.Fragment,{children:[Object.keys(((m=s.customCardPreferences)==null?void 0:m.dataInputCardIds)||{}).map(M=>{var A,F,P;const T=(F=(A=s.customCardPreferences)==null?void 0:A.dataInputCardIds)==null?void 0:F[M].cardId,b=(P=u==null?void 0:u.cards)==null?void 0:P.find(R=>R.id===T);if(b)return e.jsx(t.MultiInputEmptyRenderer,{onLoadingStatus:E,onDataChange:N,dataInputIndex:M,card:b},b.id+M)}),e.jsx("div",{className:"flex flex-col gap-2",children:e.jsx(f,{theme:l,onDataChange:N,settings:p.map(M=>{var T;return(T=M==null?void 0:M.customCardPreferences)==null?void 0:T.settings}),data:p.map(M=>M!=null&&M.id?r==null?void 0:r[M.id]:[])})})]})]},(B=s.customCardPreferences)==null?void 0:B.componentName)})}function Zt({className:s,...a}){var p;const n=t.useEditorStore(g=>g.card),r=((p=n.customCardPreferences)==null?void 0:p.showCardHeader)??!0,o=t.useEditorStore(g=>g.frame),i=t.useDashboardStore(g=>g.dashboard.filters);t.useEditorStore(g=>g.actions.setRunSql);const{updateFilter:c}=t.useDashboardActions(),d=i==null?void 0:i.find(g=>g.id===o.filterId),{data:l,isLoading:x,isFetching:h,errorMessage:u}=t.useDashboardCardQuery(n),{setCard:j}=t.useEditorActions(),{data:y}=t.useTopoJson(n),N=L.useMemo(()=>!n.id||!(l!=null&&l.records)?null:t.createChartConfig({card:n,data:l==null?void 0:l.records,cardType:n.type,queryConfig:n.queryConfig,customCfg:n.customCfg,preferences:n.preferences,topoJson:y}),[n.id,l==null?void 0:l.records,n.type,n.queryConfig,n.customCfg,n.preferences,y]);function f(g){return e.jsx(Hn,{card:g})}function E(){if(l!=null&&l.records&&(l==null?void 0:l.records.length)===0&&!x&&!h)return u?e.jsxs("div",{className:"flex h-full flex-col items-center justify-center gap-2",children:[e.jsx(t.SearchX,{className:"size-8 text-destructive"}),e.jsx("p",{className:"text-sm text-muted-foreground",children:n.mode!=="explorer"?"Error fetching data. Please check your SQL or Python code.":"Error fetching data. Please check your chart configuration"})]}):e.jsxs("div",{className:"flex h-full flex-col items-center justify-center gap-2",children:[e.jsx(t.TreePalm,{className:"size-8 text-muted-foreground"}),e.jsx("p",{className:"text-sm text-muted-foreground",children:"No results to display"})]});if(!n.id)return null;if(n.type==="custom")return f(n);if(!["table","custom"].includes(n.type)&&N)return e.jsx(e.Fragment,{children:x||h?e.jsx(e.Fragment,{}):e.jsx(t.ChartJsVisual,{cfg:N})});if(n.type==="table"&&(l!=null&&l.records)&&(l==null?void 0:l.records.length)>0)return e.jsx("div",{className:"relative mb-2 flex h-full min-h-0 w-full flex-1 grow basis-0",children:e.jsx(t.TableVisual,{card:n,data:l==null?void 0:l.records})})}return e.jsxs(t.Card,{role:"editor-visual-card",className:t.cn("relative flex h-full flex-col rounded-none",s),...a,children:[r&&e.jsxs(t.CardHeader,{className:"flex flex-row items-start justify-between py-4",children:[e.jsxs("div",{children:[e.jsx(t.Editable,{enabled:!0,text:n.title,onSave:g=>j({...n,title:g}),children:e.jsx("div",{className:"flex items-center gap-5",children:e.jsx(t.CardTitle,{className:"text-base",children:n.title||"Add title"})})},n.title),e.jsx(t.Editable,{enabled:!0,text:n.description||"",onSave:g=>j({...n,description:g}),children:e.jsx(t.CardDescription,{children:n.description||"Add description"})},n.description)]}),d&&e.jsxs("div",{className:"flex items-center gap-3",children:[e.jsx(t.Editable,{enabled:!0,className:"my-1",text:d.title||d.column,onSave:g=>c({...d,title:g}),children:e.jsx(t.Label,{children:d.title})}),e.jsx(t.FilterComponent,{filter:d})]})]}),e.jsx(t.CardContent,{className:"flex grow flex-col",children:E()})]})}const Je=({language:s,value:a,onChange:n,readonly:r})=>e.jsx(t.Ft,{className:"h-full w-full overflow-hidden text-xs",theme:"default",options:{minimap:{enabled:!1},wordWrap:"on",scrollbar:{verticalScrollbarSize:0,horizontalScrollbarSize:0},fontSize:12,lineHeight:16,renderLineHighlight:"none",readOnly:r},defaultLanguage:s,value:a,onChange:n}),Un=()=>e.jsxs(t.DialogHeader,{children:[e.jsx("div",{className:"flex items-center gap-2",children:e.jsx(t.DialogTitle,{children:"Customize Card"})}),e.jsxs(t.DialogDescription,{children:["See the configuration options and documentation",e.jsx("a",{target:"_blank",className:"ml-1 text-blue-500 underline",href:"https://www.chartjs.org/docs/latest/samples/bar/vertical.html",children:"here."})]})]}),Yn=({customCode:s,cardCustomCfgString:a,mergedConfig:n,onConfigChange:r,onCodeChange:o})=>e.jsxs(t.Tabs,{defaultValue:"final-config",className:"flex w-1/2 flex-col",children:[e.jsxs(t.TabsList,{className:"justify-start rounded-sm rounded-b-none border border-b-0",children:[e.jsx(t.TabsTrigger,{value:"final-config",children:"Config"}),e.jsx(t.TabsTrigger,{value:"custom-config",children:"Changes"}),e.jsx(t.TabsTrigger,{value:"custom-code",children:"Custom Code"})]}),e.jsx(t.TabsContent,{value:"final-config",className:"mt-0 grow rounded-b border border-t-0",children:e.jsx(Je,{language:"json",value:n,onChange:r})}),e.jsx(t.TabsContent,{value:"custom-config",className:"mt-0 grow rounded-b border border-t-0",children:e.jsx(Je,{readonly:!0,language:"json",value:a,onChange:()=>{}})}),e.jsx(t.TabsContent,{value:"custom-code",className:"mt-0 grow rounded-b border border-t-0",children:e.jsx(Je,{language:"javascript",value:s,onChange:o})})]}),Kn=({error:s,hasCardCustomConfig:a,onReset:n,onApply:r,onClose:o})=>e.jsxs(t.DialogFooter,{className:"flex items-center",children:[e.jsx(t.Label,{className:"mr-2 text-red-500",children:s}),e.jsx(t.Button,{disabled:!a,onClick:n,variant:"outline",children:"Reset"}),e.jsx(t.Button,{onClick:r,variant:"outline",children:"Apply"}),e.jsx(t.Button,{onClick:o,variant:"outline",children:"Close"})]});function Qn(){const[s,a]=L.useState(!1),[n,r]=L.useState(""),[o,i]=L.useState(""),[c,d]=L.useState(""),[l,x]=L.useState(""),h=t.useEditorStore(k=>k.card),u=t.useEditorStore(k=>k.card.customCfg),j=u?JSON.stringify(u,null,2):"",{data:y}=t.useDashboardCardQuery(h),{data:N}=t.useTopoJson(h),{setCardCustomCfg:f,setCustomVisualCode:E}=t.useEditorActions(),p=k=>{var v,C;return JSON.stringify({...k,data:{...k.data,datasets:(C=(v=k.data)==null?void 0:v.datasets)==null?void 0:C.map(S=>({...S,data:[]}))}},null,2)},g=()=>{var v,C;if(!((v=y==null?void 0:y.records)!=null&&v.length))return;const k=t.createChartConfig({card:h,data:y.records,cardType:h.type,queryConfig:h.queryConfig,preferences:h.preferences,topoJson:N});if(k){r(p(k)),d(((C=h.preferences)==null?void 0:C.customVisualCode)||"");const S=t.merge(k,u);i(p(S))}},O=()=>{try{if(c&&E(c),o){const k=JSON.parse(o),v=t.getObjectDiff(JSON.parse(n),k);f(v),x("")}}catch{x("Invalid JSON configuration")}},I=Object.keys(u||{}).length===0;return e.jsxs(t.Dialog,{open:s,onOpenChange:a,children:[e.jsx(t.DialogTrigger,{asChild:!0,children:e.jsx(t.IconButton,{tooltip:"Customize Visual",onClick:g,className:I?"":"text-green-600 hover:text-green-700",children:e.jsx(t.Settings,{className:"h-4 w-4"})})}),e.jsxs(t.DialogContent,{className:"flex h-[600px] grow flex-col overflow-auto sm:min-w-[900px] lg:min-w-[1200px]",children:[e.jsx(Un,{}),e.jsxs("div",{className:"flex grow gap-2",children:[e.jsx(t.ErrorBoundary,{FallbackComponent:t.FallbackEditorCard,children:e.jsx(Zt,{className:"w-1/2 rounded shadow-none"})}),e.jsx(Yn,{customCode:c,cardCustomCfgString:j,mergedConfig:o,onConfigChange:k=>i(k??""),onCodeChange:k=>d(k??"")})]}),e.jsx(Kn,{error:l,hasCardCustomConfig:!!u,onReset:()=>{i(n),f(null)},onApply:O,onClose:()=>a(!1)})]})]})}function Pe(s){const[a,n]=L.useState(null);return a}function dt(){const{authToken:s}=t.useSemaphorContext(),{data:a,isLoading:n,isFetching:r,isError:o}=t.useQuery({queryKey:["plugins",s==null?void 0:s.accessToken],queryFn:()=>t.getPlugins(s==null?void 0:s.accessToken)});return{data:a,isLoading:n,isFetching:r,isError:o}}function Wn({onChartTypeChange:s}){const[a,n]=L.useState([]),{setCardCustomCfg:r,setCardPreferences:o,setCardType:i,setCustomCardPreferences:c}=t.useEditorActions(),{data:d}=dt();function l(x,h){r(null),o({}),i(x),h&&c({type:"component",visualType:"single",url:h.url,componentName:h.name,icon:h.icon}),s==null||s()}return L.useEffect(()=>{(async()=>{var h;if(d){const j=(await Promise.all((h=d==null?void 0:d.plugins)==null?void 0:h.map(async y=>(await t.loadManifest(y.value)).visuals.map(E=>({name:E.name,icon:E.icon,url:y.value}))))).flat();n(j)}})()},[d]),a.length===0?null:e.jsxs(e.Fragment,{children:[e.jsx(t.Separator,{className:"my-2"}),e.jsx("div",{className:"grid grid-cols-4 place-items-center",children:a.map((x,h)=>e.jsx(Xn,{text:x.name,onClick:()=>l("custom",x),icon:x.icon},x.url+x.name+h))})]})}const Xn=({text:s,icon:a,onClick:n})=>{const r=Pe(),o=s.charAt(0).toUpperCase();return e.jsx(t.IconButton,{onClick:n,tooltip:s,children:r?e.jsx(r,{className:"h-4 w-4"}):o})};function ut(s){return ge({attr:{viewBox:"0 0 256 256",fill:"currentColor"},child:[{tag:"path",attr:{d:"M128,24A104,104,0,1,0,232,128,104.11,104.11,0,0,0,128,24Zm87.63,96H191.48A64.1,64.1,0,0,0,136,64.52V40.37A88.13,88.13,0,0,1,215.63,120ZM120,120H80.68A48.09,48.09,0,0,1,120,80.68Zm0,16v39.32A48.09,48.09,0,0,1,80.68,136Zm16,0h39.32A48.09,48.09,0,0,1,136,175.32Zm0-16V80.68A48.09,48.09,0,0,1,175.32,120ZM120,40.37V64.52A64.1,64.1,0,0,0,64.52,120H40.37A88.13,88.13,0,0,1,120,40.37ZM40.37,136H64.52A64.1,64.1,0,0,0,120,191.48v24.15A88.13,88.13,0,0,1,40.37,136ZM136,215.63V191.48A64.1,64.1,0,0,0,191.48,136h24.15A88.13,88.13,0,0,1,136,215.63Z"},child:[]}]})(s)}function Zn(s){return ge({attr:{viewBox:"0 0 256 256",fill:"currentColor"},child:[{tag:"path",attr:{d:"M48,180c0,11,7.18,20,16,20a14.24,14.24,0,0,0,10.22-4.66A8,8,0,0,1,85.78,206.4,30.06,30.06,0,0,1,64,216c-17.65,0-32-16.15-32-36s14.35-36,32-36a30.06,30.06,0,0,1,21.78,9.6,8,8,0,0,1-11.56,11.06A14.24,14.24,0,0,0,64,160C55.18,160,48,169,48,180Zm79.6-8.69c-4-1.16-8.14-2.35-10.45-3.84-1.25-.81-1.23-1-1.12-1.9a4.57,4.57,0,0,1,2-3.67c4.6-3.12,15.34-1.73,19.82-.56A8,8,0,0,0,142,145.86c-2.12-.55-21-5.22-32.84,2.76a20.58,20.58,0,0,0-9,14.95c-2,15.88,13.65,20.41,23,23.11,12.06,3.49,13.12,4.92,12.78,7.59-.31,2.41-1.26,3.34-2.14,3.93-4.6,3.06-15.17,1.56-19.55.36A8,8,0,0,0,109.94,214a61.34,61.34,0,0,0,15.19,2c5.82,0,12.3-1,17.49-4.46a20.82,20.82,0,0,0,9.19-15.23C154,179,137.49,174.17,127.6,171.31Zm83.09-26.84a8,8,0,0,0-10.23,4.84L188,184.21l-12.47-34.9a8,8,0,0,0-15.07,5.38l20,56a8,8,0,0,0,15.07,0l20-56A8,8,0,0,0,210.69,144.47ZM216,88v24a8,8,0,0,1-16,0V96H152a8,8,0,0,1-8-8V40H56v72a8,8,0,0,1-16,0V40A16,16,0,0,1,56,24h96a8,8,0,0,1,5.66,2.34l56,56A8,8,0,0,1,216,88Zm-27.31-8L160,51.31V80Z"},child:[]}]})(s)}function mt(s){return ge({attr:{viewBox:"0 0 24 24",fill:"none",stroke:"currentColor",strokeWidth:"2",strokeLinecap:"round",strokeLinejoin:"round"},child:[{tag:"path",attr:{d:"M6 16m-3 0a3 3 0 1 0 6 0a3 3 0 1 0 -6 0"},child:[]},{tag:"path",attr:{d:"M16 19m-2 0a2 2 0 1 0 4 0a2 2 0 1 0 -4 0"},child:[]},{tag:"path",attr:{d:"M14.5 7.5m-4.5 0a4.5 4.5 0 1 0 9 0a4.5 4.5 0 1 0 -9 0"},child:[]}]})(s)}function ht(s){return ge({attr:{viewBox:"0 0 24 24",fill:"none",stroke:"currentColor",strokeWidth:"2",strokeLinecap:"round",strokeLinejoin:"round"},child:[{tag:"path",attr:{d:"M4.387 3h15.226a1 1 0 0 1 .948 1.316l-5.105 15.316a2 2 0 0 1 -1.898 1.368h-3.116a2 2 0 0 1 -1.898 -1.368l-5.104 -15.316a1 1 0 0 1 .947 -1.316"},child:[]},{tag:"path",attr:{d:"M5 9h14"},child:[]},{tag:"path",attr:{d:"M7 15h10"},child:[]}]})(s)}function xt(s){return ge({attr:{viewBox:"0 0 24 24"},child:[{tag:"path",attr:{fill:"none",d:"M0 0h24v24H0z"},child:[]},{tag:"path",attr:{d:"m2 19.99 7.5-7.51 4 4 7.09-7.97L22 9.92l-8.5 9.56-4-4-6 6.01-1.5-1.5zm1.5-4.5 6-6.01 4 4L22 3.92l-1.41-1.41-7.09 7.97-4-4L2 13.99l1.5 1.5z"},child:[]}]})(s)}function pt(s){return ge({attr:{version:"1.2",baseProfile:"tiny",viewBox:"0 0 24 24"},child:[{tag:"path",attr:{d:"M4 18c-.552 0-1-.448-1-1v-6.382l-.553.276c-.495.248-1.095.046-1.342-.447-.247-.494-.046-1.094.448-1.342l2-1c.31-.155.678-.139.973.044.294.183.474.504.474.851v8c0 .552-.448 1-1 1zM13 18h-5c-.404 0-.769-.244-.924-.617-.155-.374-.069-.804.217-1.09l4-4c.254-.254.394-.591.394-.95 0-.358-.14-.695-.394-.949-.508-.508-1.39-.508-1.9.001-.253.252-.393.589-.393.948 0 .552-.448 1-1 1s-1-.448-1-1c0-.894.348-1.733.98-2.364 1.265-1.263 3.464-1.263 4.727.001.632.631.979 1.471.979 2.363 0 .893-.348 1.733-.979 2.364l-2.293 2.293h2.586c.552 0 1 .448 1 1s-.448 1-1 1zM20.955 12.377c.338-.457.545-1.016.545-1.627 0-1.517-1.234-2.75-2.75-2.75-1.031 0-1.966.569-2.44 1.484-.254.49-.063 1.094.428 1.348.49.254 1.094.062 1.348-.428.128-.249.383-.404.664-.404.414 0 .75.336.75.75s-.336.75-.75.75c-.552 0-1 .448-1 1s.448 1 1 1c.689 0 1.25.561 1.25 1.25s-.561 1.25-1.25 1.25-1.25-.561-1.25-1.25c0-.552-.448-1-1-1s-1 .448-1 1c0 1.792 1.458 3.25 3.25 3.25s3.25-1.458 3.25-3.25c0-.939-.406-1.779-1.045-2.373z"},child:[]}]})(s)}function es({onChartTypeChange:s,iconClassName:a}){const{setCardType:n,setCardPreferences:r,setIsDevMode:o}=t.useEditorStore(h=>h.actions),{setCardCustomCfg:i,setCustomCardPreferences:c,setQueryConfig:d}=t.useEditorActions();function l(h,u){i(null),r({}),n(h),["custom","text","map"].includes(h)&&(o(!0),d(void 0)),s==null||s()}const x=1e3;return e.jsxs("div",{className:"grid grid-cols-5 place-items-center",children:[e.jsx(t.IconButton,{openDelay:x,tooltip:"Table",onClick:()=>l("table"),className:"h-10 p-4",children:e.jsx(ze,{className:t.cn("size-5",a)})}),e.jsx(t.IconButton,{openDelay:x,tooltip:"Bar Chart",onClick:()=>l("bar"),className:"h-10 p-4",children:e.jsx(Be,{className:t.cn("size-5",a)})}),e.jsx(t.IconButton,{openDelay:x,tooltip:"Line Chart",onClick:()=>l("line"),className:"h-10 p-4",children:e.jsx(Fe,{className:t.cn("size-5",a)})}),e.jsx(t.IconButton,{openDelay:x,tooltip:"Stacked Bar Chart",onClick:()=>l("stackedBar"),className:"h-10 p-4",children:e.jsx(Xe,{className:t.cn("size-5",a)})}),e.jsx(t.IconButton,{openDelay:x,tooltip:"Stacked Line Chart",onClick:()=>l("stackedLine"),className:"h-10 p-4",children:e.jsx(xt,{className:t.cn("size-5",a),strokeWidth:0})}),e.jsx(t.IconButton,{openDelay:x,tooltip:"Scatter Chart",onClick:()=>l("scatter"),className:"h-10 p-4",children:e.jsx(tt,{className:t.cn("size-5",a)})}),e.jsx(t.IconButton,{openDelay:x,tooltip:"Bubble Chart",onClick:()=>l("bubble"),className:"h-10 p-4",children:e.jsx(mt,{className:t.cn("size-5",a)})}),e.jsx(t.IconButton,{openDelay:x,tooltip:"Pie Chart",onClick:()=>l("pie"),className:"h-10 p-4",children:e.jsx(et,{className:t.cn("size-5",a)})}),e.jsx(t.IconButton,{openDelay:x,tooltip:"Doughnut Chart",onClick:()=>l("doughnut"),className:"h-10 p-4",children:e.jsx(st,{className:t.cn("size-5",a)})}),e.jsx(t.IconButton,{openDelay:x,tooltip:"Funnel Chart",onClick:()=>l("funnel"),className:"h-10 p-4",children:e.jsx(ht,{className:t.cn("size-5",a)})}),e.jsx(t.IconButton,{openDelay:x,tooltip:"Radar Chart",onClick:()=>l("radar"),className:"h-10 p-4",children:e.jsx(rt,{className:t.cn("size-5",a)})}),e.jsx(t.IconButton,{openDelay:x,tooltip:"Polar Area Chart",onClick:()=>l("polarArea"),className:"h-10 p-4",children:e.jsx(ut,{className:t.cn("size-5",a)})}),e.jsx(t.IconButton,{openDelay:x,tooltip:"Tornado Chart",onClick:()=>l("tornado"),className:"h-10 p-4",children:e.jsx(ot,{className:t.cn("size-5",a)})}),e.jsx(t.IconButton,{tooltip:"Range Chart",onClick:()=>l("range"),className:"h-10 p-4",children:e.jsx(Ze,{className:t.cn("size-5",a)})}),e.jsx(t.IconButton,{openDelay:x,tooltip:"KPI",onClick:()=>l("kpi"),className:"h-10 p-4",children:e.jsx(pt,{className:t.cn("size-5",a)})}),e.jsx(t.IconButton,{openDelay:x,tooltip:"Text",onClick:()=>l("text"),className:"h-10 p-4",children:e.jsx(Lt,{className:t.cn("size-5",a)})}),e.jsx(t.IconButton,{tooltip:"Map",onClick:()=>l("map"),className:"h-10 p-4",children:e.jsx(at,{className:t.cn("size-5",a)})}),e.jsx(t.IconButton,{openDelay:x,tooltip:"Custom",onClick:()=>l("custom"),className:"h-10 p-4",children:e.jsx(we,{className:t.cn("size-5",a)})})]})}function ea({chartType:s,className:a,customIcon:n,componentName:r}){const o=Pe();switch(s){case"bar":return e.jsx(Be,{className:a});case"line":return e.jsx(Fe,{className:a});case"pie":return e.jsx(et,{className:a});case"radar":return e.jsx(rt,{className:a});case"scatter":return e.jsx(tt,{className:a});case"bubble":return e.jsx(mt,{className:a});case"doughnut":return e.jsx(st,{className:a});case"stackedBar":return e.jsx(Xe,{className:a});case"stackedLine":return e.jsx(xt,{className:a});case"polarArea":return e.jsx(ut,{className:a});case"funnel":return e.jsx(ht,{className:a});case"tornado":case"pyramid":return e.jsx(ot,{className:a});case"range":return e.jsx(Ze,{className:a});case"kpi":return e.jsx(pt,{className:a});case"text":return e.jsx(Rt,{className:a});case"map":return e.jsx(at,{className:a});case"custom":return n&&o?e.jsx(o,{className:a}):r?r==null?void 0:r.charAt(0).toUpperCase():e.jsx(we,{className:a});default:return e.jsx(ze,{className:a})}}function ts({variant:s="ghost"}){var i,c;const[a,n]=L.useState(!1),r=t.useEditorStore(d=>d.card),o=r.type;return t.useDashboardStore(d=>d.isVisualEditing),e.jsxs(t.Popover,{open:a,onOpenChange:n,children:[e.jsx(t.PopoverTrigger,{asChild:!0,children:e.jsx(t.Button,{size:"sm",variant:s||"ghost",children:e.jsx(ea,{className:"size-4",chartType:o,customIcon:(i=r.customCardPreferences)==null?void 0:i.icon,componentName:(c=r.customCardPreferences)==null?void 0:c.componentName})})}),e.jsxs(t.PopoverContentCustom,{onOpenAutoFocus:d=>d.preventDefault(),className:"w-72 p-1",children:[e.jsx(es,{onChartTypeChange:()=>n(!1)}),e.jsx(Wn,{onChartTypeChange:()=>n(!1)})]})]})}const Ee="focus-visible:ring-0 focus-visible:ring-ring focus-visible:ring-offset-0";function It(s,a){var r,o,i;const n=t.getNumberAxis(s,{});return["pie","doughnut","polarArea","funnel"].includes(a)?"category":((i=(o=(r=s==null?void 0:s.chartOptions)==null?void 0:r.scales)==null?void 0:o[n])==null?void 0:i.type)||"linear"}function ta(){var A,F,P,R,z,Y;const[s,a]=L.useState(!1),n=t.useEditorStore(V=>{var q;return(q=V.card)==null?void 0:q.preferences}),r=t.useEditorStore(V=>{var q;return(q=V.card)==null?void 0:q.type}),o=t.getNumberAxis(n,{}),[i,c]=L.useState(It(n,r)),[d,l]=L.useState(((P=(F=(A=n==null?void 0:n.chartOptions)==null?void 0:A.scales)==null?void 0:F[o])==null?void 0:P.min)||""),[x,h]=L.useState(((Y=(z=(R=n==null?void 0:n.chartOptions)==null?void 0:R.scales)==null?void 0:z[o])==null?void 0:Y.max)||""),[u,j]=L.useState(d||x?"custom":"auto"),[y,N]=L.useState(""),[f,E]=L.useState(0),[p,g]=L.useState(""),[O,I]=L.useState(""),[k,v]=L.useState(""),C=t.useEditorStore(V=>V.actions.setCardPreferences),{updateCardInFrame:S}=t.useEditorActions(),D=t.useEditorStore(V=>V.card),w=["pie","doughnut","polarArea","funnel"].includes(r);L.useEffect(()=>{var V,q,H,K,G,$,J,X,se,re,le,ne,te,ce;c(It(n,r)),l(((H=(q=(V=n==null?void 0:n.chartOptions)==null?void 0:V.scales)==null?void 0:q[o])==null?void 0:H.min)===0?0:""),h((($=(G=(K=n==null?void 0:n.chartOptions)==null?void 0:K.scales)==null?void 0:G[o])==null?void 0:$.max)||""),N(((re=(se=(X=(J=n==null?void 0:n.chartOptions)==null?void 0:J.scales)==null?void 0:X[o])==null?void 0:se.ticks)==null?void 0:re.stepSize)||""),E(((le=n==null?void 0:n.numberAxisFormat)==null?void 0:le.decimalPlaces)||0),g(((ne=n==null?void 0:n.numberAxisFormat)==null?void 0:ne.suffix)||""),I(((te=n==null?void 0:n.numberAxisFormat)==null?void 0:te.currency)||""),v(((ce=n==null?void 0:n.numberAxisFormat)==null?void 0:ce.locale)||"")},[s,n,o,r]);function m(V,q){return q===""||/^[0-9\b]+$/.test(q)?Number(q):Number(V)}function B(){const V=[...new Set(t.LOCALE_CURRENCY_PAIRS.map(q=>q.currency))];return e.jsxs(e.Fragment,{children:[e.jsxs("div",{className:"grid grid-cols-6 items-center gap-2",children:[e.jsx(t.Label,{className:"col-span-2 hover:cursor-pointer hover:underline",htmlFor:"currency",children:e.jsx("a",{target:"_blank",href:"https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Intl/NumberFormat",children:"Currency"})}),e.jsxs(t.Select,{value:O||"none",onValueChange:q=>I(q==="none"?"":q),children:[e.jsx(t.SelectTrigger,{className:"col-span-2 h-8 w-full focus:ring-1 focus:ring-offset-0",children:e.jsx(t.SelectValue,{})}),e.jsx(t.SelectContent,{children:e.jsxs(t.SelectGroup,{children:[e.jsx(t.SelectLabel,{children:"Currency"}),e.jsx(t.SelectItem,{value:"none",children:"None"}),V.map(q=>e.jsx(t.SelectItem,{value:q,children:q},q))]})})]}),e.jsxs(t.Select,{value:k,onValueChange:q=>v(q),children:[e.jsx(t.SelectTrigger,{className:"col-span-2 h-8 w-full focus:ring-1 focus:ring-offset-0",children:e.jsx(t.SelectValue,{})}),e.jsx(t.SelectContent,{children:e.jsxs(t.SelectGroup,{children:[e.jsx(t.SelectLabel,{children:"Locale"}),t.LOCALE_CURRENCY_PAIRS.map(q=>e.jsx(t.SelectItem,{value:q.locale,children:q.locale},q.locale))]})})]})]}),e.jsxs("div",{className:"grid grid-cols-9 items-center gap-2",children:[e.jsx(t.Label,{className:"col-span-3",htmlFor:"format",children:"Decimals"}),e.jsx(t.Input,{value:f,onChange:q=>E(Number(q.target.value)),id:"format",className:`col-span-6 h-8 w-full tracking-wide ${Ee}`})]})]})}function M(){return e.jsxs(e.Fragment,{children:[e.jsx("div",{className:"mt-4 space-y-2",children:e.jsx("p",{className:"text-sm text-muted-foreground",children:"Set the scale for number axis"})}),e.jsxs("div",{className:"mt-2 grid grid-cols-3 items-center gap-2",children:[e.jsx(t.Label,{htmlFor:"scale",children:"Type"}),e.jsxs(t.Select,{disabled:w,value:i,onValueChange:V=>c(V),children:[e.jsx(t.SelectTrigger,{className:"col-span-2 h-8 w-full focus:ring-1 focus:ring-offset-0",children:e.jsx(t.SelectValue,{})}),e.jsx(t.SelectContent,{id:"type",children:e.jsxs(t.SelectGroup,{children:[e.jsx(t.SelectLabel,{children:"Option"}),e.jsx(t.SelectItem,{value:"linear",children:"Linear"}),e.jsx(t.SelectItem,{value:"logarithmic",children:"Logarithmic"}),e.jsx(t.SelectItem,{value:"category",children:"Category"})]})})]})]}),i=="linear"&&e.jsxs("div",{className:"grid grid-cols-3 items-center gap-2 py-1",children:[e.jsx(t.Label,{htmlFor:"scale-option",children:"Setup"}),e.jsxs(t.RadioGroup,{disabled:w,id:"scale-option",value:u,onValueChange:V=>j(V),className:"col-span-2 flex gap-3",defaultValue:"x",children:[e.jsxs("div",{className:"flex items-center space-x-2",children:[e.jsx(t.RadioGroupItem,{value:"auto",id:"r1"}),e.jsx("label",{className:"text-sm",htmlFor:"r1",children:"Auto"})]}),e.jsxs("div",{className:"flex items-center space-x-2",children:[e.jsx(t.RadioGroupItem,{value:"custom",id:"r2"}),e.jsx("label",{className:"text-sm",htmlFor:"r2",children:"Custom"})]})]})]}),u==="custom"&&i=="linear"&&T()]})}function T(){return e.jsxs(e.Fragment,{children:[e.jsxs("div",{className:"grid grid-cols-3 items-center gap-2",children:[e.jsx(t.Label,{htmlFor:"range",children:"Range"}),e.jsx(t.Input,{id:"min",value:d,onChange:V=>l(q=>m(q,V.target.value)),className:`col-span-1 h-8 w-full ${Ee}`}),e.jsx(t.Input,{value:x,onChange:V=>h(q=>m(q,V.target.value)),id:"max",className:`col-span-1 h-8 w-full ${Ee}`})]}),e.jsxs("div",{className:"grid grid-cols-3 items-center gap-2",children:[e.jsx(t.Label,{htmlFor:"step-size",children:"Step Size"}),e.jsx(t.Input,{value:y,onChange:V=>N(q=>m(q,V.target.value)),id:"step-size",className:`col-span-1 h-8 w-full ${Ee}`})]})]})}function b(){var K;let V={};u==="custom"&&(V={min:d,max:x,ticks:{stepSize:y}});const q={...n||{},chartOptions:{...n==null?void 0:n.chartOptions,scales:{...(K=n==null?void 0:n.chartOptions)==null?void 0:K.scales,[o]:{type:i,...i==="linear"?V:{}}}},numberAxisFormat:{decimalPlaces:f,suffix:p,currency:O,locale:k}};console.log(q),C(q);const H={...D,preferences:q};S(H)}return e.jsxs(t.Popover,{onOpenChange:V=>a(V),children:[e.jsx(t.PopoverTrigger,{asChild:!0,children:e.jsx(t.IconButton,{tooltip:"Format Number",children:e.jsx(Js,{className:"size-4"})})}),e.jsx(t.PopoverContentCustom,{align:"end",className:"max-w-65",children:e.jsxs("div",{className:"grid gap-4",children:[e.jsxs("div",{className:"space-y-2",children:[e.jsx("h4",{className:"font-medium leading-none",children:"Format Options"}),e.jsx("p",{className:"text-sm text-muted-foreground",children:"Set the format for number axis"})]}),e.jsxs("div",{className:"grid gap-2",children:[B(),M(),e.jsx(t.SelectSeparator,{}),e.jsx("div",{className:"grid grid-cols-3",children:e.jsx(t.Button,{onClick:b,variant:"secondary",className:"col-span-1 col-start-3 h-8 w-full",children:"Apply"})})]})]})})]})}function sa(){const s=t.useEditorStore(d=>{var l,x,h,u;return(u=(h=(x=(l=d.card.preferences)==null?void 0:l.chartOptions)==null?void 0:x.plugins)==null?void 0:h.legend)==null?void 0:u.position}),a=t.useEditorStore(d=>{var l,x,h,u;return(u=(h=(x=(l=d.card.preferences)==null?void 0:l.chartOptions)==null?void 0:x.plugins)==null?void 0:h.legend)==null?void 0:u.align}),n=t.useEditorStore(d=>{var l,x,h,u;return(u=(h=(x=(l=d.card.preferences)==null?void 0:l.chartOptions)==null?void 0:x.plugins)==null?void 0:h.legend)==null?void 0:u.display}),{setLegendOptions:r}=t.useEditorActions(),o=d=>{r({display:d,position:s,align:a})},i=d=>{r({display:n,position:d,align:a})},c=d=>{r({display:n,position:s,align:d})};return e.jsxs(t.Popover,{children:[e.jsx(t.PopoverTrigger,{asChild:!0,children:e.jsx(t.IconButton,{tooltip:"Legend Settings",children:e.jsx(en,{className:"size-4"})})}),e.jsx(t.PopoverContentCustom,{align:"end",className:"w-72",children:e.jsxs("div",{className:"grid gap-4",children:[e.jsxs("div",{className:"space-y-2",children:[e.jsx("h4",{className:"font-medium leading-none",children:"Legend Options"}),e.jsx("p",{className:"text-sm text-muted-foreground",children:"Set the legend options for the chart."})]}),e.jsxs("div",{className:"grid gap-2",children:[e.jsxs("div",{className:"grid grid-cols-3 items-center gap-4",children:[e.jsx(t.Label,{htmlFor:"displayLegend",children:"Display"}),e.jsx("div",{className:"col-span-2 flex h-8 items-center",children:e.jsx(t.SmallSwitch,{checked:n,onCheckedChange:o,id:"displayLegend"})})]}),n&&e.jsxs(e.Fragment,{children:[e.jsxs("div",{className:"grid grid-cols-3 items-center gap-4",children:[e.jsx(t.Label,{htmlFor:"position",children:"Position"}),e.jsxs("div",{className:"col-span-2 flex h-8 items-center",children:[e.jsx(t.IconButton,{tooltip:"Top",onClick:()=>i("top"),children:e.jsx(t.ArrowUp,{className:"size-4"})}),e.jsx(t.IconButton,{tooltip:"Left",onClick:()=>i("left"),children:e.jsx(Ts,{className:"size-4"})}),e.jsx(t.IconButton,{tooltip:"Bottom",onClick:()=>i("bottom"),children:e.jsx(t.ArrowDown,{className:"size-4"})}),e.jsx(t.IconButton,{tooltip:"Right",onClick:()=>i("right"),children:e.jsx(Ms,{className:"size-4"})})]})]}),e.jsxs("div",{className:"grid grid-cols-3 items-center gap-4",children:[e.jsx(t.Label,{htmlFor:"align",children:"Align"}),e.jsxs("div",{className:"col-span-2 flex h-8 items-center",children:[e.jsx(t.IconButton,{tooltip:"Start",onClick:()=>c("start"),children:e.jsx(ws,{className:"size-4"})}),e.jsx(t.IconButton,{tooltip:"Center",onClick:()=>c("center"),children:e.jsx(Ss,{className:"size-4"})}),e.jsx(t.IconButton,{tooltip:"End",onClick:()=>c("end"),children:e.jsx(ks,{className:"size-4"})})]})]})]})]})]})})]})}function na(){const s=t.useEditorStore(i=>{var c,d;return(d=(c=i.card.preferences)==null?void 0:c.chartOptions)==null?void 0:d.indexAxis}),a=t.useEditorStore(i=>i.card.type),{setChartOrientation:n}=t.useEditorStore(i=>i.actions);function r(){return e.jsx(t.IconButton,{onClick:()=>{n(s==="x"||s===void 0?"y":"x")},tooltip:"Chart Orientation",children:s==="x"||s===void 0?e.jsx(St,{className:"size-4"}):e.jsx(Ct,{className:"size-4"})})}function o(){return e.jsx(t.IconButton,{onClick:()=>{n(s==="y"||s===void 0?"x":"y")},tooltip:"Chart Orientation",children:s==="y"||s===void 0?e.jsx(St,{className:"size-4"}):e.jsx(Ct,{className:"size-4"})})}return e.jsx(e.Fragment,{children:a==="funnel"?o():r()})}function ss(){const s=t.useEditorStore(c=>c.card),a=t.useEditorStore(c=>c.isShowingVisual),n=t.useEditorStore(c=>{var d,l;return(l=(d=c.card)==null?void 0:d.preferences)==null?void 0:l.chartOptions}),r=t.getChartGridStyle(n),{setChartGrid:o}=t.useEditorActions();function i(){const c=["xy","none","x","y"],l=(c.indexOf(r)+1)%c.length;o(c[l])}return a?e.jsxs("div",{"data-info":"visual-settings",className:"flex items-center",children:[["line","bar","range","stackedBar","stackedLine","horizontalBar","funnel"].includes(s.type)&&e.jsx(e.Fragment,{children:e.jsx(na,{})}),!["kpi","text","custom","table"].includes(s.type)&&e.jsxs(e.Fragment,{children:[e.jsx(ta,{}),e.jsx(sa,{})]}),!["pie","doughnut","funnel","radar","polarArea","table","custom","kpi","text","map"].includes(s.type)&&e.jsxs(t.IconButton,{tooltip:"Grid Style",onClick:i,children:[(r==="xy"||!r)&&e.jsx(Xs,{className:"size-4"}),r==="x"&&e.jsx(_s,{className:"size-4"}),r==="y"&&e.jsx(hn,{className:"size-4"}),r==="none"&&e.jsx(gn,{className:"size-4"})]})]}):null}function aa(){const s=t.useEditorStore(N=>N.frame),a=t.useEditorStore(N=>N.card),{setFrame:n,setActiveTabCardId:r,setCard:o,updateCardInFrame:i}=t.useEditorActions(),c=(N,f)=>{N.dataTransfer.setData("tabIndex",f.toString())},d=N=>{N.preventDefault()},l=(N,f)=>{const E=N.dataTransfer.getData("tabIndex");if(E===f.toString())return;const p=Array.from(s.cards),[g]=p.splice(parseInt(E),1);p.splice(f,0,g),n({...s,cards:p})};function x(N){const f=s.cards.filter(g=>g.id!==N),E=f[0],p={...s,cards:f,activeCardId:E.id};n(p),r(E.id),o(E)}function h(N,f){const E={...s,cards:[...s.cards,f],activeCardId:N.id};n(E),r(f.id)}function u(){const N={...a,id:t.v4(),title:`${a.title} Copy`,tabTitle:`${a.tabTitle||a.title} Copy`,mode:a.mode||"explorer"};h(a,N)}function j(N){const f={dataSource:N.dataSource,connectionId:N.connectionId,lastSelectedDatabase:N.lastSelectedDatabase,lastSelectedSchema:N.lastSelectedSchema,lastSelectedTable:N.lastSelectedTable,lastSelectedDatamodelId:N.lastSelectedDatamodelId,id:t.v4(),title:"Title",description:"",preferences:{onClickFilter:[{columnIndex:0,expression:""}]},type:"bar",sql:"",data:[],mode:"explorer"};h(N,f)}function y(N,f){return N.cards.length===1&&(f.displayTab===!0||f.displayTab===void 0)||N.activeCardId!==f.id&&(f.displayTab===!0||f.displayTab===void 0)?null:e.jsx("div",{onClick:()=>{const E=f.displayTab===void 0?!1:!f.displayTab;o({...f,displayTab:E}),i({...f,displayTab:E})},children:f.displayTab===!0||f.displayTab===void 0?e.jsx(t.Eye,{className:"mr-2 size-3.5 text-muted-foreground hover:text-foreground"}):e.jsx(Hs,{className:"mr-2 size-3.5 text-muted-foreground hover:text-foreground"})})}return e.jsx(t.TabsList,{className:"group mx-4 justify-between overflow-x-auto",children:e.jsxs("div",{className:"flex items-center",children:[s.cards.map((N,f)=>e.jsxs(t.TabsTrigger,{draggable:!0,onDragStart:E=>c(E,f),onDragOver:d,onDrop:E=>l(E,f),className:"",value:N.id,children:[y(s,N),e.jsx(t.Editable,{enabled:s.activeCardId===N.id,text:N.tabTitle||N.title,onSave:E=>{o({...a,tabTitle:E}),i({...a,tabTitle:E})},children:N.tabTitle||N.title},N.id),s.activeCardId===N.id&&s.cards.length>1&&e.jsx(t.X,{className:"ml-2 size-3.5 text-muted-foreground hover:text-foreground",onClick:()=>x(N.id)})]},N.id)),e.jsx(t.Button,{className:"ml-1 h-8 px-2 hover:bg-muted-foreground/50",variant:"outline",onClick:()=>j(a),children:e.jsx(t.Plus,{className:"h-4 w-4"})}),e.jsx(t.Button,{className:"invisible ml-1 h-8 px-2 hover:bg-muted-foreground/50 group-hover:visible",variant:"outline",onClick:u,children:e.jsx($s,{className:"h-4 w-4"})})]})})}function ns(){const s=t.useEditorStore(f=>f.frame),a=t.useEditorStore(f=>f.card),n=t.useEditorStore(f=>f.isSqlRunning),r=t.useEditorStore(f=>f.isDevMode),{setFrame:o,setActiveTabCardId:i,setCard:c,setIsDevMode:d,setRunSql:l}=t.useEditorActions(),{data:x,isLoading:h,isFetching:u}=t.useDashboardCardQuery(a);function j(f){const E=s.cards.find(p=>p.id===f);if(E!=null&&E.sql){r||d(!0),i(f);return}if(E!=null&&E.queryConfig){r&&d(!1),y(f),i(f);return}r||y(f),i(f)}function y(f){const E={...s,cards:s.cards.map(g=>g.id===a.id?{...a,mode:a.mode||g.mode}:g),activeCardId:f};o(E);const p=E.cards.find(g=>g.id===f);p.sql&&l(!0),c(p)}function N(){return a.type==="kpi"?e.jsx("div",{className:"flex h-full items-center justify-center",children:e.jsx("div",{className:"w-1/2 rounded-md border",children:e.jsx(t.KPICard,{card:a,data:x==null?void 0:x.records,isPending:h})})}):a.type==="text"?e.jsx("div",{className:"flex h-full items-center justify-center",children:e.jsx("div",{className:"w-1/2 rounded-md border",children:e.jsx(t.ScrollArea,{className:"mx-3 my-6 h-[300px] overflow-y-auto break-words px-3",children:e.jsx(t.TextCard,{isLoading:n,card:a,data:x==null?void 0:x.records})})})}):e.jsx(t.ErrorBoundary,{FallbackComponent:t.FallbackEditorCard,children:e.jsx(Zt,{className:"grow border-none shadow-none"})})}return e.jsxs(t.Tabs,{onValueChange:j,value:s.activeCardId,className:"flex grow flex-col",children:[s.cards.map(f=>e.jsx(t.TabsContent,{className:"mt-0 grow",value:f.id,children:N()},f.id)),e.jsx(aa,{})]})}function De({children:s}){t.useEditorStore(g=>g.frame);const a=t.useEditorStore(g=>g.card),n=t.useEditorStore(g=>g.isDevMode),r=t.useEditorStore(g=>g.isShowingVisual),o=t.useDashboardStore(g=>g.isVisualEditing),i=t.useEditorStore(g=>g.pythonStdOut);t.useEditorStore(g=>g.actions.setRunSql);const{setFrame:c,setCard:d,setActiveTabCardId:l,runAssistant:x,setIsDevMode:h}=t.useEditorActions(),{data:u,isLoading:j,isFetching:y,errorMessage:N}=t.useDashboardCardQuery(a);function f(){const g=JSON.stringify(u==null?void 0:u.records,null,2),O=new Blob([g],{type:"application/json"}),I=URL.createObjectURL(O),k=document.createElement("a");k.href=I,k.download=`${a.title}.json`,k.click()}function E(){const O=[Object.keys(u==null?void 0:u.records.reduce((C,S)=>({...C,...S}),{})).join(","),...((u==null?void 0:u.records)||[]).map(C=>Object.values(C).join(","))].join(`
369
- `),I=new Blob([O],{type:"text/csv"}),k=URL.createObjectURL(I),v=document.createElement("a");v.href=k,v.download=`${a.title}.csv`,v.click()}function p(){const g=`Can you get the documentation for ${a.type} chart?`;x(g)}return a?e.jsxs("div",{className:"relative isolate flex h-full flex-col py-2 pb-3",children:[(j||y)&&e.jsx("div",{className:"absolute bottom-0 left-0 right-0 top-0 z-50 m-auto flex h-10 w-10 items-center justify-center rounded-md bg-muted",children:e.jsx(t.LoaderCircle,{className:"h-8 w-8 animate-spin text-muted-foreground"})}),e.jsxs("div",{className:"z-10 mb-0 flex min-h-10 items-center justify-end gap-2 px-6",children:[r&&e.jsxs("div",{className:"flex grow items-center",children:[e.jsx(ts,{}),o&&e.jsx(t.IconButton,{tooltip:"Visual Docs",onClick:p,children:e.jsx(Bs,{className:"size-4"})}),!["table","custom"].includes(a.type)&&o&&e.jsx(Qn,{})]}),!r&&e.jsxs("div",{className:"flex grow items-center gap-1",children:[e.jsx(t.Button,{className:"h-7 w-fit px-1 font-mono text-xs text-muted-foreground/70",variant:"ghost",size:"icon",onClick:E,children:e.jsx(Zn,{className:"size-4"})}),e.jsx(t.Button,{className:"h-7 w-fit px-1 font-mono text-xs text-muted-foreground/70",variant:"ghost",size:"icon",onClick:f,children:e.jsx(Ys,{strokeWidth:1.5,className:"size-4"})}),e.jsx(t.CopyButton,{text:JSON.stringify(u==null?void 0:u.records,null,2),className:"h-7 w-fit px-1 font-mono text-xs text-muted-foreground/70"})]}),e.jsxs("div",{className:"flex items-center gap-2",children:[s,e.jsx(ss,{})]}),n&&e.jsx(oa,{})]}),r?e.jsx(ns,{}):e.jsxs(t.ResizablePanelGroup,{className:"px-6",direction:"horizontal",children:[i&&e.jsxs(e.Fragment,{children:[e.jsx(t.ResizablePanel,{id:"1",order:1,defaultSize:30,minSize:10,className:"relative flex h-full min-h-0 w-full flex-1 basis-0",children:i&&e.jsx(ra,{})}),e.jsx(t.ResizableHandle,{})]}),e.jsxs(t.ResizablePanel,{id:"2",order:2,minSize:10,className:"relative flex h-full min-h-0 w-full flex-1 basis-0",children:[(u==null?void 0:u.records)&&(u==null?void 0:u.records.length)>0&&e.jsx(Jn,{data:(u==null?void 0:u.records)||[]}),N&&e.jsx(Ut,{error:N})]})]})]}):e.jsx(e.Fragment,{children:"No Active Card"})}function ra(){const s=t.useEditorStore(n=>n.pythonStdOut);if(!s)return null;const a=s.replace(/\n/g,"<br>");return e.jsxs("div",{className:"relative flex w-full flex-col border-r",children:[e.jsx("div",{className:"sticky top-0 flex max-h-11 min-h-11 grow items-center border-b bg-muted px-3 font-mono text-xs font-semibold text-foreground/70",children:"Python Output"}),e.jsxs(t.ScrollArea,{className:"overflow-y-auto px-2 pt-1 font-mono text-xs text-foreground/90",children:[e.jsx("div",{dangerouslySetInnerHTML:{__html:a}}),e.jsx(t.ScrollBar,{orientation:"horizontal"})]})]})}function oa(){const s=t.useEditorStore(n=>n.isShowingVisual),a=t.useEditorStore(n=>n.actions.setIsShowingVisual);return e.jsxs("div",{className:"flex items-center space-x-2",children:[e.jsx(t.Label,{htmlFor:"visualize",children:"Chart"}),e.jsx(t.SmallSwitch,{checked:s,onCheckedChange:()=>a(!s),id:"visualize",className:"data-[state=checked]:bg-foreground/50"})]})}function ia(){var f,E;const s=t.useEditorStore(p=>p.card.customCardPreferences),{data:a}=dt(),n=(a==null?void 0:a.plugins)||[],r=t.useEditorStore(p=>p.card),o=t.useEditorStore(p=>p.frame),i=(s==null?void 0:s.visualType)||"single",{setCustomCardPreferences:c}=t.useEditorActions(),{components:d,manifest:l}=t.useCustomVisual((s==null?void 0:s.url)||""),x=(f=l==null?void 0:l.visuals)==null?void 0:f.find(p=>p.name===(s==null?void 0:s.componentName));function h(p,g){if(!s)return;const I={...(s==null?void 0:s.dataInputCardIds)||{},[p]:{cardId:g,hookRef:null}};c({...s,dataInputCardIds:I})}function u(p){var O,I;const g=(O=o==null?void 0:o.cards)==null?void 0:O.filter(k=>{var v;return((v=k==null?void 0:k.customCardPreferences)==null?void 0:v.visualType)!=="multiple"}).map(k=>({value:k.id,label:k.tabTitle||k.title}));return e.jsx("div",{className:"space-y-2",children:(I=p==null?void 0:p.dataInputs)==null?void 0:I.map((k,v)=>{var C,S;return e.jsxs("div",{className:"grid grid-cols-10 gap-2",children:[e.jsx("div",{className:"col-span-4 flex items-center",children:k}),e.jsx(ae,{className:"col-span-6 h-8 w-full justify-between",label:"",options:g||[],value:((S=(C=s==null?void 0:s.dataInputCardIds)==null?void 0:C[v])==null?void 0:S.cardId)||"",onValueChange:D=>h(v,D)})]},v+Math.random())})})}function j(p,g,O=[],I=""){var k,v;return s?p==="input"?e.jsx(t.Input,{className:`h-8 w-full ${t.removeRing}`,value:((k=s==null?void 0:s.settings)==null?void 0:k[g])||I,onChange:C=>{c({...s,settings:{...s==null?void 0:s.settings,[g]:C.target.value}})}},g):p==="select"?e.jsx(ae,{className:"h-8 w-full",label:"",options:O,value:((v=s==null?void 0:s.settings)==null?void 0:v[g])||I,onValueChange:C=>{c({...s,settings:{...s==null?void 0:s.settings,[g]:C}})}}):null:null}function y(p){const g=Object.entries((p==null?void 0:p.settings)||{});return e.jsx("div",{className:"space-y-3",children:g.map(([O,I])=>e.jsxs("div",{className:"space-y-1",children:[e.jsx(t.Label,{children:I.title}),j(I.ui,O,I.options,I.defaultValue)]},O))})}function N(p){s&&c({...s,visualType:p,componentName:""})}return e.jsxs(t.Accordion,{type:"multiple",defaultValue:["component-settings"],className:"px-6 py-2",children:[e.jsxs(t.AccordionItem,{value:"plugin-settings",children:[e.jsx(t.AccordionTrigger,{children:"Plugin"}),e.jsx(t.AccordionContent,{children:e.jsxs("div",{className:"space-y-4 text-sm",children:[e.jsx("div",{className:"space-y-2",children:e.jsxs("div",{className:"space-y-4",children:[e.jsx(ae,{icon:e.jsx(Os,{className:"h-3.5 w-3.5"}),className:"h-9 w-full",label:"Select Plugin",options:n,value:(s==null?void 0:s.url)||"",onValueChange:p=>c({...s||{url:"",componentName:""},url:p})}),((s==null?void 0:s.type)==="component"||(s==null?void 0:s.type)===void 0)&&e.jsx(t.Tabs,{value:i,onValueChange:N,children:e.jsxs(t.TabsList,{className:"h-9 w-full",children:[e.jsx(t.TabsTrigger,{className:"h-7 w-full",value:"single",children:"Single Visual"}),e.jsx(t.TabsTrigger,{className:"h-7 w-full",value:"multiple",children:"Multi-Visual"})]})})]})}),((s==null?void 0:s.type)==="component"||(s==null?void 0:s.type)===void 0)&&s&&e.jsx(e.Fragment,{children:d&&e.jsx(ae,{icon:e.jsx(Gs,{className:"h-3.5 w-3.5"}),className:"h-9 w-full",label:"Select Component",options:(d==null?void 0:d.filter(p=>p.type===i).map(p=>({value:p.name,label:p.name})))||[],value:s.componentName,onValueChange:p=>{console.log("changing value",p),c({...s,componentName:p})}})})]})})]}),((E=r==null?void 0:r.customCardPreferences)==null?void 0:E.componentName)&&e.jsxs(t.AccordionItem,{className:"border-none",value:"component-settings",children:[e.jsx(t.AccordionTrigger,{children:"Settings"}),e.jsxs(t.AccordionContent,{children:[x&&x.dataInputs&&e.jsxs("div",{className:"space-y-3",children:[e.jsx(t.Label,{children:"Input Mapping"}),e.jsx("div",{className:"px-2",children:u(x)})]}),x&&x.settings&&e.jsx("div",{className:"space-y-3",children:e.jsx("div",{className:"px-2",children:y(x)})})]})]})]})}function je(){const[s,a]=L.useState([]),n=t.useEditorStore(x=>x.card.preferences),{setFilterOnClickColumnIndex:r,setCardPreferences:o}=t.useEditorStore(x=>x.actions),i=t.useEditorStore(x=>x.queryResultColumns);t.useEditorStore(x=>{var h;return(h=x.card.preferences)==null?void 0:h.filterOnClickColumnIndex}),L.useEffect(()=>{i&&a(new Array(i.length).fill(!1))},[i]);function c(x,h){var u,j;h?n!=null&&n.onClickFilter&&((u=n==null?void 0:n.onClickFilter)==null?void 0:u.length)>0?o({...n,onClickFilter:[...n.onClickFilter,{columnIndex:x,expression:""}]}):o({...n,onClickFilter:[{columnIndex:x,expression:""}]}):(o({...n,onClickFilter:(j=n==null?void 0:n.onClickFilter)==null?void 0:j.filter(y=>y.columnIndex!==x)}),a(y=>{const N=[...y];return N[x]=!1,N}))}function d(x,h){var j;const u=(j=n==null?void 0:n.onClickFilter)==null?void 0:j.map(y=>y.columnIndex===x?{...y,expression:h.target.value}:y);o({...n,onClickFilter:u})}function l(x){var h,u,j,y;if(s!=null&&s[x]||(u=(h=n==null?void 0:n.onClickFilter)==null?void 0:h.find(N=>N.columnIndex===x))!=null&&u.expression)return e.jsx(t.Input,{value:(y=(j=n==null?void 0:n.onClickFilter)==null?void 0:j.find(N=>N.columnIndex===x))==null?void 0:y.expression,onChange:N=>d(x,N),type:"text",className:"h-9 w-full font-mono text-xs focus-visible:ring-0 focus-visible:ring-ring focus-visible:ring-offset-0",placeholder:"Expression"})}return e.jsxs("div",{className:"max-h-[150px] space-y-2 overflow-y-auto",children:[e.jsx(t.Label,{children:"On Click"}),i==null?void 0:i.map((x,h)=>{var u,j;return e.jsx("div",{className:"group flex items-center justify-between space-y-2",children:e.jsxs("div",{className:"grow",children:[e.jsxs("div",{className:"flex items-center space-x-2 py-2",children:[e.jsx(t.Checkbox,{checked:!!((u=n==null?void 0:n.onClickFilter)!=null&&u.find(y=>y.columnIndex===h)),onCheckedChange:y=>c(h,y)}),e.jsx("label",{className:"text-sm font-medium leading-none peer-disabled:cursor-not-allowed peer-disabled:opacity-70",children:x}),e.jsx("div",{className:"flex items-center gap-2",children:((j=n==null?void 0:n.onClickFilter)==null?void 0:j.find(y=>y.columnIndex===h))&&e.jsx(t.Pencil,{onClick:()=>{a(y=>{const N=[...y];return N[h]=!y[h],N})},className:"invisible size-3 cursor-pointer text-gray-400 group-hover:visible"})})]}),l(h)]})},x)})]})}function la({idx:s}){var d;const a=t.useEditorStore(l=>{var x;return(x=l.card)==null?void 0:x.preferences}),n=t.useEditorStore(l=>{var x;return(x=l.card.preferences)==null?void 0:x.datasetOptions}),r=t.useEditorStore(l=>l.actions.setCardPreferences),o=(d=a==null?void 0:a.chartOptions)==null?void 0:d.indexAxis,i=n==null?void 0:n.find(l=>l.idx===s);function c(l,x){(l==="end"||l==="start")&&t.getContrastColor(t.getCanvasBackgroundColor());const h={display:l!=="none",align:l,anchor:l,clamp:!0};if(!i)r({...a,datasetOptions:[...n||[],{idx:x,datalabels:h}]});else{const u={...i};u.datalabels=h;const j=n==null?void 0:n.map(y=>y.idx===x?u:y);r({...a,datasetOptions:j})}}return e.jsxs(t.Popover,{children:[e.jsx(t.PopoverTrigger,{children:e.jsx(Pt,{className:"size-4 rotate-[135deg] cursor-pointer text-muted-foreground hover:text-foreground"})}),e.jsx(t.PopoverContent,{className:"w-fit px-2 py-1",children:e.jsxs("div",{className:"flex gap-1",children:[e.jsx("button",{onClick:()=>c("none",s),className:"h-7 p-1 text-xs font-normal",children:e.jsx(t.X,{className:"size-3.5"})}),e.jsx("button",{onClick:()=>c("start",s),className:"h-7 p-1 text-xs font-normal",children:e.jsx(tn,{className:t.cn("h-4 w-4",{"rotate-90":o==="y"})})}),e.jsx("button",{onClick:()=>c("center",s),className:"h-7 p-1 text-xs font-normal",children:e.jsx(nn,{className:t.cn("h-4 w-4",{"rotate-90":o==="y"})})}),e.jsx("button",{onClick:()=>c("end",s),className:"h-7 p-1 text-xs font-normal",children:e.jsx(sn,{className:t.cn("h-4 w-4",{"rotate-90":o==="y"})})})]})})]})}function ca(){const s=t.useEditorStore(i=>i.card),{data:a}=t.useDashboardCardQuery(s),{keys:n}=t.getKeys((a==null?void 0:a.records)||[]),r=n.slice(1).filter(i=>!t.METADATA_KEYS.includes(i));let o=r;if(["stackedBar","stackedLine"].includes(s.type)){const i=t.pivotData({dataArray:(a==null?void 0:a.records)||[],groupKey:n[0],pivotKey:n[1],valueKey:n[2]}),{keys:c}=t.getKeys(i);o=c.slice(1)}return{transformedMetricKeys:o,dimensionKeys:n.slice(0,1),keys:n,defaultMetricKeys:r}}function ft({children:s,className:a,delayDuration:n}){return e.jsx(t.TooltipProvider$1,{children:e.jsxs(t.Tooltip,{delayDuration:n,children:[e.jsx(t.TooltipTrigger,{asChild:!0,children:e.jsx("span",{className:t.cn("overflow-hidden text-ellipsis whitespace-nowrap",a),children:s})}),e.jsx(t.TooltipContent,{children:s})]})})}function as(){const s=t.useEditorStore(l=>l.card),a=t.useEditorStore(l=>{var x,h,u;return(u=(h=(x=l==null?void 0:l.card)==null?void 0:x.preferences)==null?void 0:h.chartOptions)==null?void 0:u.indexAxis}),{data:n}=t.useDashboardCardQuery(s),r=a==="y"?"Metric":"Dimension",o=a==="y"?"Dimension":"Metric",{dimensionKeys:i,transformedMetricKeys:c,keys:d}=ca();return d.length===0?null:e.jsxs("div",{className:"space-y-4",children:[e.jsxs("div",{className:"space-y-2",children:[e.jsx(t.Label,{children:r}),e.jsx("div",{className:"max-h-[125px] space-y-1 overflow-y-auto",children:i.map(l=>e.jsx("p",{className:"flex h-8 items-center rounded-md bg-muted/70 px-3 hover:bg-muted",title:l,children:rs(l)},l))})]}),e.jsxs("div",{className:"space-y-2",children:[e.jsx(t.Label,{children:o}),e.jsx("div",{className:"my-1 max-h-[125px] space-y-1 overflow-y-auto",children:c.map((l,x)=>e.jsx(os,{className:"flex h-8 items-center bg-muted/70 px-3 hover:bg-muted",iconClassName:"invisible group-hover:visible",col:l,idx:x},l))})]})]})}function rs(s,a=30){return s.length>a?s.slice(0,a)+"...":s}function os({col:s,idx:a,className:n,iconClassName:r,children:o}){const i=t.useEditorStore(h=>{var u;return(u=h.card)==null?void 0:u.preferences}),c=t.useEditorStore(h=>{var u,j;return(j=(u=h.card)==null?void 0:u.preferences)==null?void 0:j.datasetOptions}),d=c==null?void 0:c.find(h=>h.idx===a),{setCardPreferences:l}=t.useEditorStore(h=>h.actions);function x(h){if(!d)l({...i,datasetOptions:[...c||[],{idx:a,type:h==="area"?"line":h,fill:h==="area"?"origin":""}]});else{const u={...d};u.type=h==="area"?"line":h,u.fill=h==="area"?"origin":"";const j=c==null?void 0:c.map(y=>y.idx===a?u:y);l({...i,datasetOptions:j})}}return e.jsxs("div",{className:t.cn("group flex items-center justify-between gap-2 rounded-md",n),children:[o||e.jsx(ft,{className:"max-w-[100px]",title:s,children:rs(s)}),e.jsxs("div",{className:"flex gap-2",children:[e.jsx(Be,{onClick:()=>x("bar"),className:t.cn("size-4 cursor-pointer text-muted-foreground hover:text-foreground",r)}),e.jsx(Fe,{onClick:()=>x("line"),className:t.cn("size-4 cursor-pointer text-muted-foreground hover:text-foreground",r)}),e.jsx(Vs,{onClick:()=>x("area"),className:t.cn("size-4 cursor-pointer text-muted-foreground hover:text-foreground",r)}),e.jsx(la,{idx:a})]})]})}function is(){const s=t.useEditorStore(y=>y.selectedConnectionId),a=t.useEditorStore(y=>y.selectedDatamodelId),n=t.useEditorStore(y=>y.selectedDatabaseName),r=t.useEditorStore(y=>y.selectedSchemaName),o=t.useEditorStore(y=>y.selectedTableName),i=t.useDashboardStore(y=>y.dashboard.filters)||[],c=t.useDashboardStore(y=>y.actions.addFilter),d=t.useDashboardStore(y=>y.actions.removeFilter),{removeFilterValues:l}=t.useDashboardActions(),{modelItems:x,tableName:h,connectionType:u}=t.useEditorAside();function j(y,N="dashboard"){var C;const f=t.fmt(y.column_name),E=t.fmt(n||""),p=t.fmt(r||""),g=t.fmt(h);let O=t.getQualifiedTableName({schemaName:p,tableName:g,connectionType:u,databaseName:E}),I=`${O}.${f}`;const k=(C=x==null?void 0:x.find(S=>S.id===a))==null?void 0:C.name;a&&a!=="none"&&(I=`${t.DATAMODEL_NAMESPCACE}.${k}.${f}`,O=`${t.DATAMODEL_NAMESPCACE}.${k}`);const v=i==null?void 0:i.find(S=>S.column===I&&S.table===g&&(S.database===E||S.database===n));if(v)l(v.id),d(v.id);else{const S=t.v4();return h==="api"&&s?(c({location:N,id:S,column:I,title:y.column_name,dataType:y.data_type,table:"api",database:"",connectionId:s,operation:"in",sql:t.getDefaultFilterSql(y.data_type,O,f)}),S):(c({id:S,location:N,column:I,title:y.column_name,dataType:y.data_type,table:o||"",database:n||"",connectionId:s||"",operation:"in",sql:t.getDefaultFilterSql(y.data_type,O,f)}),S)}}return{assignFilter:j}}function Ne(){const s=t.useDashboardStore(d=>d.dashboard.filters),a=t.useEditorStore(d=>d.frame),{setFrame:n}=t.useEditorActions(),{columns:r}=t.useEditorAside(),{assignFilter:o}=is();function i(d){const l=o(d,"frame");n({...a,filterId:l})}const c=s==null?void 0:s.find(d=>d.id===a.filterId);return e.jsxs("div",{className:"space-y-3",children:[e.jsx(t.Label,{children:"Card Filter"}),e.jsx(da,{onSelect:i,columns:r}),c&&e.jsx(t.FilterHeader,{filter:c})]})}function da({columns:s,onSelect:a}){var c;const[n,r]=he.useState(!1),[o,i]=he.useState("");return e.jsxs(t.Popover,{open:n,onOpenChange:r,children:[e.jsx(t.PopoverTrigger,{asChild:!0,children:e.jsxs(t.Button,{size:"sm",variant:"outline",role:"combobox","aria-expanded":n,className:"w-full justify-between font-normal",children:[o?(c=s.find(d=>d.column_name===o))==null?void 0:c.column_name:"Select Column...",e.jsx(t.CaretSortIcon,{className:"ml-2 h-4 w-4 shrink-0 opacity-50"})]})}),e.jsx(t.PopoverContent,{className:"w-[200px] p-0",children:e.jsxs(t.Command,{children:[e.jsx(t.CommandInput,{placeholder:"Search column",className:"h-9"}),e.jsxs(t.CommandList,{children:[e.jsx(t.CommandEmpty,{children:"No framework found."}),e.jsx(t.CommandGroup,{children:s==null?void 0:s.map(d=>e.jsxs(t.CommandItem,{value:d.column_name,onSelect:l=>{const x=l===o?"":l;i(x),r(!1),x&&a(d)},children:[d.column_name,e.jsx(t.CheckIcon,{className:t.cn("ml-auto h-4 w-4",o===d.column_name?"opacity-100":"opacity-0")})]},d.column_name))})]})]})})]})}function ua({cardType:s}){return e.jsx("div",{className:"space-y-6 px-6 py-2",children:e.jsxs(t.Accordion,{defaultValue:["item-2"],type:"multiple",children:[e.jsxs(t.AccordionItem,{value:"item-1",children:[e.jsx(t.AccordionTrigger,{children:`${t.titleCase(s)} Chart`}),e.jsxs(t.AccordionContent,{className:"space-y-4 font-mono text-xs",children:[e.jsx("div",{className:"rounded bg-muted px-2 py-1 text-xs",children:"SELECT x-axis, y-axis-1, y-axis-2,... FROM table"}),e.jsxs("ul",{className:"ml-6 list-disc text-xs [&>li]:mt-2",children:[e.jsx("li",{children:"x-axis - category"}),e.jsx("li",{children:"y-axis1 - number"}),e.jsx("li",{children:"y-axis2 - number"})]}),e.jsxs("div",{children:["See ",e.jsx("a",{target:"_blank",onClick:a=>a.stopPropagation(),className:"text-blue-700",href:"https://docs.semaphor.cloud/docs/charts/bar-line-area",children:"example"})," in the docs."]})]})]}),e.jsxs(t.AccordionItem,{value:"item-2",children:[e.jsx(t.AccordionTrigger,{children:"Settings"}),e.jsx(t.AccordionContent,{className:"space-y-4 px-2",children:e.jsx(as,{})})]}),e.jsxs(t.AccordionItem,{value:"item-3",children:[e.jsx(t.AccordionTrigger,{children:"Filters"}),e.jsxs(t.AccordionContent,{className:"space-y-4 px-2",children:[e.jsx(je,{}),e.jsx(Ne,{})]})]})]})})}function Ve(){const s=t.useEditorStore(d=>d.card.type),a=t.useEditorStore(d=>d.isDevMode),n=t.useEditorStore(d=>d.card.preferences),{setCardPreferences:r}=t.useEditorStore(d=>d.actions);function o(d){var h;const l={datalabels:{display:d!=="none",align:d,anchor:d,clamp:!0}},x={...n,chartOptions:{...n==null?void 0:n.chartOptions,plugins:{...(h=n==null?void 0:n.chartOptions)==null?void 0:h.plugins,...l}}};r(x)}function i(){var d,l,x;return e.jsxs("div",{className:"space-y-2",children:[e.jsx("label",{className:"font-medium",children:"Data Labels"}),e.jsxs(t.Select,{value:((x=(l=(d=n==null?void 0:n.chartOptions)==null?void 0:d.plugins)==null?void 0:l.datalabels)==null?void 0:x.anchor)||"none",onValueChange:o,defaultValue:"none",children:[e.jsx(t.SelectTrigger,{className:"h-8 w-full focus:ring-1 focus:ring-offset-0",children:e.jsx(t.SelectValue,{placeholder:"Select position"})}),e.jsx(t.SelectContent,{children:e.jsxs(t.SelectGroup,{children:[e.jsx(t.SelectLabel,{children:"Data Labels"}),e.jsx(t.SelectItem,{value:"none",children:"None"}),!["pyramid","funnel"].includes(s)&&e.jsx(t.SelectItem,{value:"start",children:"Start"}),e.jsx(t.SelectItem,{value:"center",children:"Center"}),!["pyramid","funnel"].includes(s)&&e.jsx(t.SelectItem,{value:"end",children:"End"})]})})]})]})}function c(){var d,l,x;return e.jsx("div",{children:e.jsxs(t.Select,{value:((x=(l=(d=n==null?void 0:n.chartOptions)==null?void 0:d.plugins)==null?void 0:l.datalabels)==null?void 0:x.anchor)||"none",onValueChange:o,defaultValue:"none",children:[e.jsx(t.SelectTrigger,{className:"h-8 w-full text-xs",children:e.jsx(t.SelectValue,{placeholder:"Select position"})}),e.jsx(t.SelectContent,{children:e.jsxs(t.SelectGroup,{children:[e.jsx(t.SelectItem,{className:"text-xs",value:"none",children:"None"}),!["pyramid","funnel"].includes(s)&&e.jsx(t.SelectItem,{className:"text-xs",value:"start",children:"Start"}),e.jsx(t.SelectItem,{className:"text-xs",value:"center",children:"Center"}),!["pyramid","funnel"].includes(s)&&e.jsx(t.SelectItem,{className:"text-xs",value:"end",children:"End"})]})})]})})}return e.jsx(e.Fragment,{children:a?i():c()})}function ma({cardType:s}){function a(n){return e.jsxs(e.Fragment,{children:[e.jsx("div",{className:"rounded bg-muted px-2 py-1 text-xs",children:n==="bubble"?"SELECT label, [group], x-axis, y-axis, radius FROM table":"SELECT label, [group], x-axis, y-axis FROM table"}),e.jsxs("ul",{className:"ml-6 list-disc text-xs [&>li]:mt-2",children:[e.jsx("li",{children:"label - category"}),e.jsx("li",{children:"group (optional) - category"}),e.jsx("li",{children:"x-axis - number"}),e.jsx("li",{children:"y-axis - number"}),n==="bubble"&&e.jsx("li",{children:"radius - number"})]}),e.jsxs("div",{children:["See ",e.jsx("a",{target:"_blank",onClick:i=>i.stopPropagation(),className:"text-blue-700",href:"https://docs.semaphor.cloud/docs/charts/bubble",children:"example"})," in the docs."]})]})}return e.jsx("div",{className:"space-y-6 px-6 py-2",children:e.jsxs(t.Accordion,{defaultValue:["item-2"],type:"multiple",children:[e.jsxs(t.AccordionItem,{value:"item-1",children:[e.jsx(t.AccordionTrigger,{children:`${t.titleCase(s)} Chart`}),e.jsx(t.AccordionContent,{className:"space-y-4 font-mono text-xs",children:a(s)})]}),e.jsxs(t.AccordionItem,{value:"item-2",children:[e.jsx(t.AccordionTrigger,{children:"Settings"}),e.jsx(t.AccordionContent,{className:"px-2",children:e.jsx(Ve,{})})]}),e.jsxs(t.AccordionItem,{value:"item-3",children:[e.jsx(t.AccordionTrigger,{children:"Filters"}),e.jsxs(t.AccordionContent,{className:"space-y-4 px-2",children:[e.jsx(je,{}),e.jsx(Ne,{})]})]})]})})}const ha={datasets:[{type:"line",label:"Sum_sales",data:[]},{type:"bar",label:"Sum_profit",data:[]}]},xa={datasets:[{fill:"origin",type:"line",label:"Sum_sales",data:[]}]};function pa(){const s=t.useEditorStore(a=>a.card.type);return e.jsxs("div",{className:"space-y-6 p-6",children:[e.jsx(t.Accordion,{className:" ",type:"single",collapsible:!0,children:fa(s)}),!["kpi"].includes(s)&&e.jsxs("div",{className:"space-y-4",children:[e.jsx(Ve,{}),e.jsx(je,{}),e.jsx(Ne,{})]})]})}function fa(s){if(["line","bar"].includes(s))return e.jsxs(e.Fragment,{children:[e.jsxs(t.AccordionItem,{value:"item-1",children:[e.jsx(t.AccordionTrigger,{className:"font-normal",children:e.jsx("p",{children:"Chart Query"})}),e.jsxs(t.AccordionContent,{className:" ",children:[e.jsx("div",{className:"rounded bg-muted px-2 py-1 font-mono text-xs font-semibold",children:"SELECT x-axis, y-axis-1, y-axis-2, y-axis-3,... FROM table"}),e.jsxs("ul",{className:"my-6 ml-6 list-disc text-xs font-normal [&>li]:mt-2",children:[e.jsx("li",{children:"X-axis - Category (ex. city)"}),e.jsx("li",{children:"Y-axis - Number (ex. population)"})]})]})]}),e.jsxs(t.AccordionItem,{value:"item-2",children:[e.jsx(t.AccordionTrigger,{className:"font-normal",children:"Mixed Chart"}),e.jsxs(t.AccordionContent,{className:"space-y-2 text-xs",children:[e.jsxs("p",{children:["Click ",e.jsx("b",{children:"Customize"})," and change the `type` property in the dataset."]}),e.jsx("pre",{children:JSON.stringify(ha,null,2)})]})]}),e.jsxs(t.AccordionItem,{value:"item-3",children:[e.jsx(t.AccordionTrigger,{className:"font-normal",children:"Area Chart"}),e.jsxs(t.AccordionContent,{className:"space-y-2 text-xs",children:[e.jsxs("p",{children:["Click ",e.jsx("b",{children:"Customize"})," and add `fill` property to the dataset. See",e.jsx("a",{className:"mx-1 text-blue-500 hover:underline",href:"https://www.chartjs.org/docs/latest/samples/area/line-boundaries.html",target:"_blank",children:"docs"}),"for more options."]}),e.jsx("pre",{children:JSON.stringify(xa,null,2)})]})]})]});if(s==="bubble")return e.jsx(e.Fragment,{children:e.jsxs(t.AccordionItem,{value:"item-1",children:[e.jsx(t.AccordionTrigger,{className:"font-normal",children:e.jsxs("p",{children:["How to create a ",e.jsx("span",{children:s})," chart query?"]})}),e.jsxs(t.AccordionContent,{className:" ",children:[e.jsx("div",{className:"rounded bg-muted px-2 py-1 font-mono text-xs font-semibold",children:"SELECT label, x-axis, y-axis, radius FROM table"}),e.jsxs("ul",{className:"my-6 ml-6 list-disc text-xs font-normal [&>li]:mt-2",children:[e.jsx("li",{children:"Label - Category (ex. city)"}),e.jsx("li",{children:"Bubble Group (opt) - Category (ex. state)"}),e.jsx("li",{children:"X-axis - Number (ex. avg. age)"}),e.jsx("li",{children:"Y-axis - Number (ex. avg. weight)"}),e.jsx("li",{children:"Radius - Number (ex. population)"})]})]})]})});if(s==="scatter")return e.jsx(e.Fragment,{children:e.jsxs(t.AccordionItem,{value:"item-1",children:[e.jsx(t.AccordionTrigger,{className:"font-normal",children:e.jsxs("p",{children:["How to create a ",e.jsx("span",{children:s})," chart query?"]})}),e.jsxs(t.AccordionContent,{className:" ",children:[e.jsx("div",{className:"rounded bg-muted px-2 py-1 font-mono text-xs font-semibold",children:"SELECT label, x-axis, y-axis FROM table"}),e.jsxs("ul",{className:"my-6 ml-6 list-disc text-xs font-normal [&>li]:mt-2",children:[e.jsx("li",{children:"Label - Category (ex. city)"}),e.jsx("li",{children:"Group (opt) - Category (ex. state)"}),e.jsx("li",{children:"X-axis - Number (ex. avg. age)"}),e.jsx("li",{children:"Y-axis - Number (ex. avg. weight)"})]})]})]})});if(["pie","doughnut","polarArea","funnel"].includes(s))return e.jsx(e.Fragment,{children:e.jsxs(t.AccordionItem,{value:"item-1",children:[e.jsx(t.AccordionTrigger,{className:"font-normal",children:e.jsxs("p",{children:[e.jsx("span",{children:s==="polarArea"?"Polar":s.charAt(0).toUpperCase()+s.slice(1)})," ","chart query"]})}),e.jsxs(t.AccordionContent,{className:" ",children:[e.jsx("div",{className:"rounded bg-muted px-2 py-1 font-mono text-xs font-semibold",children:"SELECT label, measure FROM table"}),e.jsxs("ul",{className:"my-6 ml-6 list-disc text-xs font-normal [&>li]:mt-2",children:[e.jsx("li",{children:"Label - Category (ex. city)"}),e.jsx("li",{children:"Measure - Number (ex. population)"})]})]})]})})}function ga(){return e.jsxs("div",{className:"space-y-6 px-6 py-2",children:[e.jsx(t.Accordion,{type:"single",collapsible:!0,children:e.jsxs(t.AccordionItem,{value:"item-1",children:[e.jsx(t.AccordionTrigger,{className:"",children:"KPI Query"}),e.jsxs(t.AccordionContent,{className:"font-mono",children:[e.jsx("div",{className:"rounded bg-muted px-2 py-1 font-mono text-xs",children:"SELECT current, previous FROM table"}),e.jsxs("ul",{className:"my-6 ml-6 list-disc text-xs [&>li]:mt-2",children:[e.jsx("li",{children:"current - number"}),e.jsx("li",{children:"previous - number"})]}),e.jsxs("div",{children:["See ",e.jsx("a",{target:"_blank",onClick:s=>s.stopPropagation(),className:"text-blue-700",href:"https://docs.semaphor.cloud/docs/charts/kpi",children:"example"})," in the docs."]})]})]})}),e.jsx("section",{className:"",children:e.jsx(t.FormatNumberSetting,{})}),e.jsx("div",{}),e.jsx("div",{})]})}function He({children:s,summary:a,open:n,className:r}){return e.jsxs("details",{open:n,className:t.cn("space-y-4 [&_summary>svg]:open:-rotate-180",r),children:[e.jsxs("summary",{className:"flex cursor-pointer list-none items-center justify-between gap-4",children:[e.jsx(t.Label,{children:a}),e.jsx(t.ChevronUp,{className:"h-4 w-4"})]}),e.jsx("div",{className:"transition-all ease-in-out",children:s})]})}const ja=[{label:"Mercator",value:"mercator"},{label:"Azimuthal Equidistant",value:"azimuthalEquidistant"},{label:"Gnomonic",value:"gnomonic"},{label:"Orthographic",value:"orthographic"},{label:"Stereographic",value:"stereographic"},{label:"Equal Earth",value:"equalEarth"},{label:"Albers",value:"albers"},{label:"Albers USA",value:"albersUsa"},{label:"Conic Conformal",value:"conicConformal"},{label:"Conic Equal Area",value:"conicEqualArea"},{label:"Conic Equidistant",value:"conicEquidistant"},{label:"Equirectangular",value:"equirectangular"},{label:"Transverse Mercator",value:"transverseMercator"},{label:"Natural Earth 1",value:"naturalEarth1"}],ya=["blues","brBG","buGn","buPu","cividis","cool","cubehelixDefault","gnBu","greens","greys","inferno","magma","orRd","oranges","pRGn","piYG","plasma","puBu","puBuGn","puOr","puRd","purples","rainbow","rdBu","rdGy","rdPu","rdYlBu","rdYlGn","reds","sinebow","spectral","turbo","viridis","warm","ylGn","ylGnBu","ylOrBr","ylOrRd"],ba=ya.map(s=>({label:s,value:s}));function va(){var l,x,h,u,j,y,N,f,E,p,g,O,I,k,v,C,S,D;const s=t.useEditorStore(w=>w.card),a=(x=(l=s==null?void 0:s.preferences)==null?void 0:l.mapVisualOptions)==null?void 0:x.topoJsonUrl,[n,r]=L.useState(((u=(h=s==null?void 0:s.preferences)==null?void 0:h.mapVisualOptions)==null?void 0:u.customTopoJsonUrl)||""),{setCardPreferences:o}=t.useEditorActions(),{data:i}=t.useTopoJson(s),c=Object.keys((i==null?void 0:i.objects)||{}).map(w=>({label:w,value:w}))||[],d=[{label:"US States 10m",value:"https://unpkg.com/us-atlas/states-10m.json"},{label:"Countries 50m",value:"https://unpkg.com/world-atlas/countries-50m.json"},{label:"Custom",value:"custom"}];return e.jsxs("div",{className:"p-6",children:[e.jsx(He,{summary:"Map Chart",children:e.jsx("p",{className:"rounded-md bg-muted p-2 font-mono text-xs",children:"SELECT country, value FROM table"})}),e.jsx(t.Separator,{className:"my-4"}),e.jsx(He,{open:!0,summary:"Settings",children:e.jsxs("div",{className:"space-y-3 px-2",children:[e.jsx(ae,{className:"h-9",options:d,onValueChange:w=>{console.log("value",w),o({...s.preferences,mapVisualOptions:{topoJsonUrl:w}})},value:a||"",label:"Select Map"}),a==="custom"&&e.jsx(t.Input,{onChange:w=>{r(w.target.value)},onBlur:()=>{var w;console.log("onBlur",n),o({...s.preferences,mapVisualOptions:{...(w=s.preferences)==null?void 0:w.mapVisualOptions,customTopoJsonUrl:n}})},value:n,className:`h-9 w-full ${t.removeRing}`,placeholder:"Custom URL"}),i&&e.jsxs(e.Fragment,{children:[e.jsxs("div",{className:"space-y-1",children:[e.jsx(t.Label,{children:"Map Object"}),e.jsx(ae,{className:"h-9",options:c,value:((y=(j=s.preferences)==null?void 0:j.mapVisualOptions)==null?void 0:y.objectKey)||"",label:"Map Object",onValueChange:w=>{var m;o({...s.preferences,mapVisualOptions:{...(m=s.preferences)==null?void 0:m.mapVisualOptions,objectKey:w}})}})]}),e.jsxs("div",{className:"space-y-1",children:[e.jsx(t.Label,{children:"Projection"}),e.jsx(ae,{className:"h-9",options:ja,value:((f=(N=s.preferences)==null?void 0:N.mapVisualOptions)==null?void 0:f.projection)||"",label:"Projection",onValueChange:w=>{var m;o({...s.preferences,mapVisualOptions:{...(m=s.preferences)==null?void 0:m.mapVisualOptions,projection:w}})}})]}),e.jsxs("div",{className:"space-y-1",children:[e.jsx(t.Label,{children:"Colors"}),e.jsx(ae,{className:"h-9",options:ba,value:((p=(E=s.preferences)==null?void 0:E.mapVisualOptions)==null?void 0:p.colorScale)||"",label:"Select Color Scale",onValueChange:w=>{var m;o({...s.preferences,mapVisualOptions:{...(m=s.preferences)==null?void 0:m.mapVisualOptions,colorScale:w}})}})]})]})]})}),e.jsx(t.Separator,{className:"my-4"}),e.jsx(He,{className:"",summary:"Scale Options",children:e.jsxs("div",{className:"flex items-center gap-3",children:[e.jsx(t.Input,{className:`h-9 w-full ${t.removeRing}`,type:"number",step:.1,value:((O=(g=s.preferences)==null?void 0:g.mapVisualOptions)==null?void 0:O.projectionScale)||1,onChange:w=>{var m;o({...s.preferences,mapVisualOptions:{...(m=s.preferences)==null?void 0:m.mapVisualOptions,projectionScale:Number(w.target.value)}})}}),e.jsx(t.Label,{children:"X"}),e.jsx(t.Input,{className:`h-9 w-full ${t.removeRing}`,type:"number",step:10,value:((v=(k=(I=s.preferences)==null?void 0:I.mapVisualOptions)==null?void 0:k.projectionOffset)==null?void 0:v[0])||0,onChange:w=>{var m,B,M,T;o({...s.preferences,mapVisualOptions:{...(m=s.preferences)==null?void 0:m.mapVisualOptions,projectionOffset:[Number(w.target.value),((T=(M=(B=s.preferences)==null?void 0:B.mapVisualOptions)==null?void 0:M.projectionOffset)==null?void 0:T[1])||0]}})}}),e.jsx(t.Label,{children:"Y"}),e.jsx(t.Input,{className:`h-9 w-full ${t.removeRing}`,type:"number",step:10,value:((D=(S=(C=s.preferences)==null?void 0:C.mapVisualOptions)==null?void 0:S.projectionOffset)==null?void 0:D[1])||0,onChange:w=>{var m,B,M,T;o({...s.preferences,mapVisualOptions:{...(m=s.preferences)==null?void 0:m.mapVisualOptions,projectionOffset:[((T=(M=(B=s.preferences)==null?void 0:B.mapVisualOptions)==null?void 0:M.projectionOffset)==null?void 0:T[0])||0,Number(w.target.value)]}})}})]})}),e.jsx(t.Separator,{className:"my-4"}),e.jsx(je,{})]})}function Na(){var r;const s=t.useEditorStore(o=>o.card.preferences),{setCardPreferences:a}=t.useEditorStore(o=>o.actions);function n(o){a({...s,textVisualOptions:{...s==null?void 0:s.textVisualOptions,isDynamicText:o==="dynamic"}})}return e.jsxs(t.RadioGroup,{value:(r=s==null?void 0:s.textVisualOptions)!=null&&r.isDynamicText?"dynamic":"static",onValueChange:n,className:"flex gap-3",defaultValue:"x",children:[e.jsxs("div",{className:"flex items-center space-x-2",children:[e.jsx(t.RadioGroupItem,{value:"static",id:"r1"}),e.jsx("label",{className:"text-sm",htmlFor:"r1",children:"Static"})]}),e.jsxs("div",{className:"flex items-center space-x-2",children:[e.jsx(t.RadioGroupItem,{value:"dynamic",id:"r2"}),e.jsx("label",{className:"text-sm",htmlFor:"r2",children:"Dynamic"})]})]})}function Ie({cardType:s,docContent:a,suffix:n="Chart"}){let r="pie-donut-polar";return s==="funnel"&&(r="funnel"),e.jsx("div",{className:"space-y-6 px-6 py-2",children:e.jsxs(t.Accordion,{defaultValue:["item-2"],type:"multiple",children:[e.jsxs(t.AccordionItem,{value:"item-1",children:[e.jsx(t.AccordionTrigger,{children:`${t.titleCase(s)} ${n}`}),e.jsx(t.AccordionContent,{children:a||e.jsxs("div",{className:"space-y-4 font-mono text-xs",children:[e.jsx("div",{className:"rounded bg-muted px-2 py-1 text-xs",children:"SELECT label, measure FROM table"}),e.jsxs("ul",{className:"ml-6 list-disc text-xs [&>li]:mt-2",children:[e.jsx("li",{children:"label - category"}),e.jsx("li",{children:"measure - number"})]}),e.jsxs("div",{children:["See ",e.jsx("a",{target:"_blank",onClick:o=>o.stopPropagation(),className:"text-blue-700",href:`https://docs.semaphor.cloud/docs/charts/${r}`,children:"example"})," in the docs."]})]})})]}),e.jsxs(t.AccordionItem,{value:"item-2",children:[e.jsx(t.AccordionTrigger,{children:"Settings"}),e.jsxs(t.AccordionContent,{className:"space-y-4 px-2",children:[s!=="text"&&e.jsx(Ve,{}),s==="text"&&e.jsx(Na,{})]})]}),!["range","text"].includes(s)&&e.jsxs(t.AccordionItem,{value:"item-3",children:[e.jsx(t.AccordionTrigger,{children:"Filters"}),e.jsxs(t.AccordionContent,{className:"space-y-4 px-2",children:[e.jsx(je,{}),e.jsx(Ne,{})]})]})]})})}function Ca(){const s=t.useEditorStore(r=>{var o,i;return(i=(o=r==null?void 0:r.card)==null?void 0:o.preferences)==null?void 0:i.sortChart}),{setSortChart:a}=t.useEditorActions();function n(){return e.jsxs("div",{className:"space-y-2",children:[e.jsx(t.Label,{children:"Sort"}),e.jsx(ae,{className:"h-8",label:"Sort Chart",options:[{label:"None",value:"none"},{label:"ASC",value:"asc"},{label:"DESC",value:"desc"}],value:s||"none",onValueChange:r=>{a(r)}})]})}return e.jsx("div",{className:"space-y-6 px-6 py-2",children:e.jsxs(t.Accordion,{defaultValue:["item-2"],type:"multiple",children:[e.jsxs(t.AccordionItem,{value:"item-1",children:[e.jsx(t.AccordionTrigger,{children:"Stacked Chart"}),e.jsxs(t.AccordionContent,{className:"space-y-4 font-mono text-xs",children:[e.jsx("div",{className:"rounded bg-muted px-2 py-1 text-xs",children:"SELECT x-axis, stack-by, y-axis FROM table"}),e.jsxs("ul",{className:"ml-6 list-disc text-xs [&>li]:mt-2",children:[e.jsx("li",{children:"x-axis - category"}),e.jsx("li",{children:"stack by - category"}),e.jsx("li",{children:"y-axis - number"})]}),e.jsxs("div",{children:["See ",e.jsx("a",{target:"_blank",onClick:r=>r.stopPropagation(),className:"text-blue-700",href:"https://docs.semaphor.cloud/docs/charts/stacked",children:"example"})," in the docs."]})]})]}),e.jsxs(t.AccordionItem,{value:"item-2",children:[e.jsx(t.AccordionTrigger,{children:"Settings"}),e.jsxs(t.AccordionContent,{className:"space-y-4 px-2",children:[n(),e.jsx(as,{})]})]}),e.jsxs(t.AccordionItem,{value:"item-3",children:[e.jsx(t.AccordionTrigger,{children:"Filters"}),e.jsxs(t.AccordionContent,{className:"space-y-4 px-2",children:[e.jsx(je,{}),e.jsx(Ne,{})]})]})]})})}function Sa({cardType:s="table"}){console.log("cardType",s);const a=t.useEditorStore(o=>{var i;return(i=o.card)==null?void 0:i.preferences}),n=t.useEditorStore(o=>o.actions.setCardPreferences),r=o=>{n({...a,allowDownload:o})};return e.jsxs("div",{className:"space-y-6 px-6 py-2",children:[e.jsx(t.Accordion,{defaultValue:["item-3"],type:"multiple",children:e.jsxs(t.AccordionItem,{value:"item-3",children:[e.jsx(t.AccordionTrigger,{children:"Filters"}),e.jsxs(t.AccordionContent,{className:"space-y-4 px-2",children:[e.jsx(je,{}),e.jsx(Ne,{})]})]})}),e.jsxs("div",{className:"flex items-center space-x-2",children:[e.jsx(t.Checkbox,{onCheckedChange:r,id:"allow-download"}),e.jsx("label",{htmlFor:"allow-download",className:"text-sm font-medium leading-none peer-disabled:cursor-not-allowed peer-disabled:opacity-70",children:"Allow Download"})]})]})}const wa=e.jsxs("div",{className:"space-y-4 font-mono text-xs",children:[e.jsx("div",{className:"rounded bg-muted px-2 py-1 text-xs",children:"SELECT dimension, cohort, metric FROM table"}),e.jsxs("div",{children:["See ",e.jsx("a",{target:"_blank",onClick:s=>s.stopPropagation(),className:"text-blue-700",href:"https://docs.semaphor.cloud/docs/charts/tornado",children:"example"})," in the docs."]})]}),ka=e.jsxs("div",{className:"space-y-4 font-mono text-xs",children:[e.jsx("div",{className:"rounded bg-muted px-2 py-1 text-xs",children:"SELECT y-axis, label, range-from, range-to, range-value FROM table"}),e.jsxs("div",{children:["See ",e.jsx("a",{target:"_blank",onClick:s=>s.stopPropagation(),className:"text-blue-700",href:"https://docs.semaphor.cloud/docs/charts/range",children:"example"})," in the docs."]})]}),Ea=e.jsxs("div",{className:"space-y-4 font-mono text-xs",children:[e.jsx("div",{className:"rounded bg-muted px-2 py-1 text-xs",children:"SELECT text FROM table limit 1"}),e.jsxs("div",{children:["See ",e.jsx("a",{target:"_blank",onClick:s=>s.stopPropagation(),className:"text-blue-700",href:"https://docs.semaphor.cloud/docs/charts/text",children:"example"})," in the docs."]})]});function Da(){const s=t.useEditorStore(n=>n.card.type);function a(n){switch(n){case"stackedBar":case"stackedLine":return e.jsx(Ca,{});case"tornado":case"pyramid":return e.jsx(Ie,{docContent:wa,cardType:n});case"kpi":return e.jsx(ga,{});case"line":case"bar":return e.jsx(ua,{cardType:n});case"range":return e.jsx(Ie,{docContent:ka,cardType:n});case"pie":case"doughnut":case"polarArea":case"radar":case"funnel":return e.jsx(Ie,{cardType:n});case"bubble":case"scatter":return e.jsx(ma,{cardType:n});case"table":return e.jsx(Sa,{cardType:n});case"text":return e.jsx(Ie,{docContent:Ea,cardType:n,suffix:"Visual"});case"map":return e.jsx(va,{});case"custom":return e.jsx(ia,{});default:return e.jsx(pa,{})}}return e.jsxs(t.ScrollArea,{className:"h-full w-full text-sm",children:[a(s),e.jsx(t.ScrollBar,{orientation:"horizontal"})]})}function ls({label:s,column:a,functions:n,onFunctionChange:r}){let o=n[0];"aggregate"in a?o=n.find(c=>c.value===a.aggregate)||n[0]:"granularity"in a&&(o=n.find(c=>c.value===a.granularity)||n[0]);function i(c){r(c)}return e.jsx(ae,{className:"flex h-8 w-8 justify-center overflow-clip rounded-none border-none bg-muted px-0 [&>svg]:hidden",icon:o.logo,options:n,value:o.value,onValueChange:c=>i(c),label:s,showPlaceholderLabel:!1})}const Ia=[{label:"Sum",value:"SUM",logo:e.jsx(zt,{className:"size-3.5"})},{label:"Count",value:"COUNT",logo:e.jsx(nt,{className:"size-3.5"})},{label:"Unique",value:"DISTINCT",logo:e.jsx(Qs,{className:"size-3.5"})},{label:"Average",value:"AVG",logo:e.jsx(Is,{className:"size-3.5"})},{label:"Min",value:"MIN",logo:e.jsx(t.ArrowDown,{className:"size-3.5"})},{label:"Max",value:"MAX",logo:e.jsx(t.ArrowUp,{className:"size-3.5"})}];function Ta({column:s}){const{updateMetricColumnOld:a}=t.useEditorActions();let n=Ia;t.isTextDataType(s.type)&&(n=n.filter(o=>["COUNT","DISTINCT"].includes(o.value))),t.isNumberDataType(s.type)&&(n=n.filter(o=>!["DISTINCT"].includes(o.value)));function r(o){const i={...s,aggregate:o,label:ke(s.name,o)};a(s.id,i)}return e.jsx(ls,{column:s,functions:n,onFunctionChange:o=>r(o),label:"Aggregation"})}const Ma=[{label:"Day (D)",value:"day",logo:e.jsx(t.Label,{className:"cursor-pointer text-xs",children:"D"})},{label:"Week (W)",value:"week",logo:e.jsx(t.Label,{className:"cursor-pointer text-xs",children:"W"})},{label:"Month (M)",value:"month",logo:e.jsx(t.Label,{className:"cursor-pointer text-xs",children:"M"})},{label:"Year (Y)",value:"year",logo:e.jsx(t.Label,{className:"cursor-pointer text-xs",children:"Y"})}];function Aa({column:s}){const{updateGroupByColumnOld:a}=t.useEditorActions();function n(r){const o={...s,granularity:r,label:ve(s.name,r)};a(s.id,o)}return e.jsx(ls,{column:s,functions:Ma,onFunctionChange:r=>n(r),label:"Granularity"})}function La({col:s,onChange:a,droppableId:n}){const{columns:r}=t.useDataColumns(),o=L.useMemo(()=>{let d=[];(n===xe||n===pe||n===fe)&&(d=r);const l=d==null?void 0:d.filter(x=>x.column_name!==s.name);return l==null?void 0:l.map(x=>({id:x.column_name,value:x.column_name}))},[r,n,s.name]),i=[{id:s.name,value:s.name}];function c(d){const l=r==null?void 0:r.find(x=>{var h;return x.column_name===((h=d[0])==null?void 0:h.id)});l&&a(l)}return o!=null&&o.length?e.jsx(t.ComboBox2,{multiple:!1,options:o,selectedOptions:i,onChange:c,selectAllChecked:!1,onSelectAllCheckedChange:()=>{},inputClassName:"border-none bg-muted pl-0 pr-8"}):e.jsx("input",{disabled:!0,type:"text",className:"overflow-hidden truncate text-ellipsis whitespace-nowrap bg-muted text-sm",value:s.name})}function cs({column:s}){const a=t.useEditorStore(l=>l.card.type),n=t.useEditorStore(l=>{var x,h;return(h=(x=l.card)==null?void 0:x.config)==null?void 0:h.metricColumns}),r=(n==null?void 0:n.map(l=>l.label))||[],o=r==null?void 0:r.find(l=>l===s.label||l===s.name),i=o?r.indexOf(o):-1;function c(){return e.jsx("div",{className:"pr-1",children:o&&e.jsx(os,{idx:i,col:o,children:e.jsx("div",{className:"w-[130px] text-xs text-muted-foreground",children:"Display Series As"})})})}function d(){return e.jsxs("div",{className:"space-y-1",children:[e.jsx(t.Label,{className:"text-xs font-medium text-muted-foreground",children:"Data Labels"}),e.jsx(Ve,{})]})}return e.jsxs("div",{className:"space-y-1",children:[["stackedBar","stackedLine","bar","line"].includes(a)&&c(),["pie","doughnut"].includes(a)&&d()]})}function Oa({column:s,type:a,onRemoveColumn:n,droppableId:r}){const[o,i]=L.useState(!1),{updateGroupByColumnOld:c,updateMetricColumnOld:d,updatePivotByColumnOld:l}=t.useEditorActions(),{attributes:x,listeners:h,setNodeRef:u,transform:j,transition:y,isDragging:N}=t.useSortable({id:s.id,data:{type:a}}),f=j?{opacity:N?.5:void 0,transform:t.CSS.Translate.toString(j),transition:y}:void 0,E=t.isTextDataType(s.type);function p(v){const C=t.isNumberDataType(v.data_type),S=t.isTextDataType(v.data_type),D=t.isDateDataType(v.data_type),w=C?"number":S?"string":D?"date":"string";if(r===xe){if(S){const m={id:s.id,name:v.column_name,type:w,role:"groupby"};c(s.id,m)}if(D){const m={id:s.id,name:v.column_name,type:w,role:"groupby",label:ve(v.column_name,"month"),granularity:"month"};c(s.id,m)}}if(r===fe){if(S){const m={id:s.id,name:v.column_name,type:w,role:"groupby"};l(s.id,m)}if(D){const m={id:s.id,name:v.column_name,type:w,label:ve(v.column_name,"month"),granularity:"month",role:"groupby"};l(s.id,m)}}if(r===pe){const m={id:s.id,name:v.column_name,type:w,role:"metric",label:ke(v.column_name,"SUM"),aggregate:C?"SUM":"COUNT"};d(s.id,m)}}function g(){if(r===pe)return e.jsx("div",{"data-setting-container":"",className:"mt-1.5 max-h-32 overflow-y-auto rounded-md border border-border p-3 text-sm",children:e.jsx(cs,{column:s})})}function O(){const v=t.isDateDataType(s.type);if(r===pe)return e.jsx(Ta,{column:s});if((r===xe||r===fe)&&v)return e.jsx(Aa,{column:s})}function I(){return e.jsx("div",{className:t.cn("grow",{"pl-3":(r===xe||r===fe)&&E}),children:e.jsx(La,{col:s,onChange:p,droppableId:r})})}function k(){return e.jsx("div",{"data-setting-actions":"",className:"flex h-full items-center gap-2",children:e.jsx("button",{className:"h-full pl-2",onClick:()=>i(!o),children:o?e.jsx(pn,{className:t.cn("size-3 cursor-pointer items-center justify-center rounded-r-sm text-muted-foreground")}):e.jsx(Bt,{className:t.cn("size-3 cursor-pointer items-center justify-center rounded-r-sm text-muted-foreground")})})})}return e.jsx("div",{...h,...x,ref:u,style:f,children:e.jsxs("div",{className:"group flex items-center justify-between gap-2",children:[e.jsxs("div",{className:"grow",children:[e.jsxs("div",{className:"flex h-8 grow items-center justify-between rounded-md bg-muted",children:[k(),O(),I()]}),o&&g()]}),e.jsx("div",{className:t.cn("opacity-0 transition-opacity duration-200 group-hover:opacity-100",{hidden:o}),children:e.jsx("button",{onClick:()=>n(s.id),children:e.jsx(t.X,{className:"size-3 cursor-pointer text-muted-foreground"})})})]})})}function Ue({id:s,label:a,columns:n,previewColumns:r,sortableType:o,onRemoveColumn:i}){var f,E;const{setNodeRef:c,isOver:d,over:l}=t.useDroppable({id:s}),x=t.useDndStore(p=>p.activeId),h=t.useEditorStore(p=>{var g;return(g=p.card)==null?void 0:g.type}),u=d||((E=(f=l==null?void 0:l.data)==null?void 0:f.current)==null?void 0:E.type)===o,j=x?r:n,y=o===Me?"Rows":o===Ae?"Pivot Columns":"Columns";function N(){if(!j||j.length===0)return e.jsx("div",{className:"mr-5 flex h-8 grow items-center space-x-2 rounded-md border border-dashed border-muted-foreground/80 bg-background px-2 py-1 text-sm text-muted-foreground",children:e.jsx("span",{className:"invisible text-muted-foreground/70 group-hover:visible",children:"Drag here"})})}return e.jsx(t.SortableContext,{items:n==null?void 0:n.map(p=>p.id),children:e.jsxs("div",{className:t.cn("group space-y-2 rounded-md p-4",u&&"border border-muted-foreground/20"),ref:c,children:[e.jsxs("div",{className:"flex items-center justify-between pr-5",children:[e.jsx(t.Label,{className:"text-sm",children:a}),h!=="table"&&e.jsx("span",{className:"text-xs text-muted-foreground/50",children:y})]}),N(),e.jsx("div",{className:"space-y-2",children:j==null?void 0:j.map(p=>p.id===Jt.id?e.jsx(Ba,{},p.id):e.jsx(Oa,{droppableId:s,type:o,column:p,onRemoveColumn:i},p.id))})]})})}function Ba(){return e.jsx("div",{className:"mr-5 flex h-8 grow items-center space-x-2 rounded-md border border-dashed border-muted-foreground bg-background px-2 py-1 text-sm",children:e.jsx("span",{className:"text-muted-foreground/70",children:"Drop here"})})}function ds({children:s,id:a,type:n}){const{attributes:r,listeners:o,setNodeRef:i,transform:c,transition:d,isDragging:l}=t.useSortable({id:a,data:{type:n}}),x=c?{opacity:l?.5:void 0,transform:t.CSS.Translate.toString(c),transition:d}:void 0;return e.jsx("div",{...o,...r,ref:i,style:x,children:s})}function Fa(){const s=t.useEditorStore(p=>{var g;return(g=p.card.queryConfig)==null?void 0:g.orderBy})||[],a=t.useEditorStore(p=>{var g;return(g=p.card.queryConfig)==null?void 0:g.groupByColumns})||[],n=t.useEditorStore(p=>{var g;return(g=p.card.queryConfig)==null?void 0:g.metricColumns})||[],{addOrderByColumn:r,removeOrderByColumn:o,updateOrderByColumn:i}=t.useEditorActions(),c=[...a,...n];if(c.length===0)return e.jsx(e.Fragment,{});const d=e.jsx(Ls,{className:"size-3.5 text-muted-foreground hover:text-foreground"}),l=e.jsx(Ds,{className:"size-3.5 text-muted-foreground hover:text-foreground"}),x=e.jsx(As,{className:"size-3.5 text-muted-foreground hover:text-foreground"}),h=e.jsx(Es,{className:"size-3.5 text-muted-foreground hover:text-foreground"}),u=c==null?void 0:c.filter(p=>!s.some(g=>g.columnId===p.id)).map(p=>({id:p.id,value:p.label||p.name}));function j(p,g){const O=y(p);return O?O.role==="metric"?g==="asc"?x:h:g==="asc"?d:l:null}function y(p){return c.find(g=>g.id===p)}function N(p){const g=s.find(O=>O.columnId===p);if(g){const O={...g,direction:g.direction==="asc"?"desc":"asc"};i(O)}}const f=p=>{r({columnId:p.id,direction:"asc"})};function E(p){const g=s.find(O=>O.columnId===p);g&&o(g)}return e.jsx(t.SortableContext,{items:s.map(p=>Ce(p.columnId)),children:e.jsxs("div",{className:"space-y-2 rounded-md p-4 text-sm",children:[e.jsx(t.Label,{className:"text-sm",children:"Sort By"}),u.length>0&&e.jsx("div",{className:"mr-5",children:e.jsx(t.ComboBox2,{multiple:!1,options:u,selectedOptions:[],onChange:p=>f(p[0]),selectAllChecked:!1,onSelectAllCheckedChange:()=>{},inputClassName:"h-8 bg-muted border-none"})}),s.map(p=>{var g,O;return e.jsx(ds,{id:Ce(p.columnId),type:ct,children:e.jsx("div",{className:"group flex h-8 items-center gap-2 rounded-sm p-0",children:e.jsxs("div",{className:"flex h-full grow items-center justify-between gap-2",children:[e.jsxs("div",{className:"flex h-full grow items-center justify-between gap-2 rounded-sm bg-muted px-2",children:[e.jsxs("div",{className:"flex items-center gap-3",children:[e.jsx(Bt,{className:"size-3 cursor-move text-muted-foreground hover:text-foreground"}),e.jsx(ft,{className:"w-[175px] text-sm",children:((g=y(p.columnId))==null?void 0:g.label)||((O=y(p.columnId))==null?void 0:O.name)})]}),e.jsx("button",{title:p.direction==="asc"?"Ascending":"Descending",onClick:()=>N(p.columnId),className:"rounded-sm p-0",children:j(p.columnId,p.direction)})]}),e.jsx("div",{children:e.jsx("button",{onClick:()=>E(p.columnId),className:"rounded-sm p-0",children:e.jsx(t.X,{className:"size-3 text-muted-foreground opacity-0 transition-opacity duration-200 hover:text-foreground group-hover:opacity-100"})})})]})},p.columnId)},Ce(p.columnId))})]})})}function za(){const s=t.useEditorStore(E=>{var p;return((p=E.card.queryConfig)==null?void 0:p.groupByColumns)||[]}),a=t.useEditorStore(E=>E.card.type),n=t.useDndStore(E=>E.previewGroupByColumns),r=t.useEditorStore(E=>{var p;return((p=E.card.queryConfig)==null?void 0:p.metricColumns)||[]}),o=t.useDndStore(E=>E.previewMetricColumns),i=t.useEditorStore(E=>{var p;return((p=E.card.queryConfig)==null?void 0:p.pivotColumns)||[]}),c=t.useDndStore(E=>E.previewPivotColumns),{removeColumnFromGroupBy:d,removeColumnFromMetricColumns:l,removeColumnFromPivotBy:x}=t.useEditorActions();function h(E){d(E)}function u(E){l(E)}function j(E){x(E)}let y="Group By",N="Metrics",f="Stack By";return a==="table"&&(y="Rows",N="Metrics",f="Columns"),e.jsxs("div",{className:"flex h-full w-full flex-col gap-3 py-4",children:[e.jsx(es,{iconClassName:"size-[19px]"}),e.jsxs(t.CustomScrollArea,{className:"flex min-h-0 grow basis-0 flex-col gap-4 overflow-y-auto",children:[e.jsxs("div",{className:"flex flex-col gap-4 p-4",children:[e.jsx(Ue,{onRemoveColumn:h,sortableType:Me,id:xe,label:y,columns:s,previewColumns:n}),e.jsx(Ue,{onRemoveColumn:j,sortableType:Ae,id:fe,label:f,columns:i,previewColumns:c}),e.jsx(Ue,{onRemoveColumn:u,sortableType:Ke,id:pe,label:N,columns:r,previewColumns:o}),e.jsx(Fa,{})]}),e.jsx(t.ScrollBar,{orientation:"horizontal"})]})]})}function gt({children:s,column:a,id:n,sortableType:r,className:o}){const[i,c]=L.useState(!1),{removeEditorFilter:d,clearEditorFilter:l}=t.useEditorActions(),x=t.useEditorStore(u=>{var j,y;return(y=(j=u.card.queryConfig)==null?void 0:j.filters)==null?void 0:y.some(N=>N.filterColumnName===a.name)});function h(u){d(u)}return e.jsx(ds,{id:n,type:r,children:e.jsxs("div",{className:t.cn("group space-y-1 rounded-md bg-muted px-3 py-2",{"border-border":i}),children:[e.jsxs("div",{className:"flex items-center justify-between",children:[e.jsxs("div",{className:"flex items-center gap-2",children:[e.jsx(t.Label,{className:"text-sm",children:a.name}),x&&e.jsx("button",{onClick:()=>l(a),children:e.jsx(t.FilterX,{className:"size-3 cursor-pointer items-center justify-center text-muted-foreground hover:text-foreground"})})]}),e.jsx("div",{"data-setting-actions":"",className:"invisible flex h-full items-center gap-2 group-hover:visible",children:e.jsx("button",{onClick:()=>h(a),children:e.jsx(t.X,{className:"size-3.5 cursor-pointer items-center justify-center rounded-r-sm text-muted-foreground"})})})]}),e.jsxs("div",{className:t.cn("group flex items-center rounded-t-md text-sm",!i&&"rounded-b-md",i&&"border border-border"),children:[e.jsx("div",{children:e.jsx(t.GripVertical,{className:"mr-2 size-3.5 cursor-move items-center justify-center p-0 text-muted-foreground/60 hover:text-foreground"})}),e.jsx("div",{className:t.cn("grow cursor-pointer overflow-hidden truncate text-ellipsis whitespace-nowrap",o),children:s})]})]})})}function Pa({column:s,sortableType:a}){const n=t.useDashboardStore(O=>O.themeStyle),r=t.useEditorStore(O=>{var I,k;return(k=(I=O.card)==null?void 0:I.queryConfig)==null?void 0:k.filters}),o=t.useEditorStore(O=>{var I,k;return(k=(I=O.card.queryConfig)==null?void 0:I.filterColumns)==null?void 0:k.find(v=>v.name===s.name)}),{selectedConnectionId:i,selectedDatabaseName:c,selectedTableName:d}=t.useEditorAside(),l=L.useMemo(()=>{var O;return(O=r==null?void 0:r.find(I=>I.filterColumnName===s.name))==null?void 0:O.filterValue},[r,s.name]),x=L.useMemo(()=>Array.isArray(l)?l.map(O=>({id:O,value:O})):[],[l]),{updateEditorFilterValue:h}=t.useEditorActions(),u={column:s.name,sql:s.sql,id:s.name,connectionId:i,dataType:s.type},{data:j,isLoading:y,isFetching:N,isError:f}=t.useFilterQuery(u),E=L.useMemo(()=>{var I;return u.column?(I=j==null?void 0:j.records)==null?void 0:I.map(k=>{let v=u.column.split(".").slice(-1)[0].replace(/"/g,"");return k[v]===void 0&&(v=v.toLowerCase()),{id:k[v],value:k[v]}}):[]},[j,u.column]);function p(O){const I=O.map(k=>k.id);h(s.name,I)}function g(){return y||N?e.jsx(t.Skeleton,{style:{borderRadius:n==null?void 0:n.controlInputRadius},className:"h-8 min-w-60 bg-foreground/10"}):f?e.jsx("div",{className:"flex h-8 min-w-60 items-center bg-muted px-2 text-sm",children:"Error"}):e.jsx(t.ComboBox2,{renderFilterModeButton:()=>e.jsx(Va,{columnName:s.name}),showNegativeIndicator:(o==null?void 0:o.mode)==="exclude",options:E,onChange:p,selectedOptions:x,selectAllChecked:!1,onSelectAllCheckedChange:()=>{}})}return e.jsx(gt,{className:"w-60",id:s.id,sortableType:a,column:s,children:g()})}function Va({columnName:s}){const{setEditorFilterMode:a}=t.useEditorActions(),n=t.useEditorStore(o=>{var i,c;return(c=(i=o.card.queryConfig)==null?void 0:i.filterColumns)==null?void 0:c.find(d=>d.name===s)});function r(){(n==null?void 0:n.mode)==="exclude"?a(s,"include"):a(s,"exclude")}return e.jsx(t.Button,{onClick:r,variant:"secondary",size:"sm",className:t.cn("h-5 text-xs hover:underline",{}),children:t.titleCase((n==null?void 0:n.mode)==="exclude"?"exclude":"include")})}function Ra({column:s,sortableType:a}){const[n,r]=L.useState(!1),{selectedConnectionId:o,selectedDatabaseName:i,selectedTableName:c}=t.useEditorAside(),d={column:s.name,sql:s.sql,id:s.name,connectionId:o,title:"",dataType:s.type},{isLoading:l,isFetching:x,isError:h,data:u}=t.useFilterQuery(d),j=u==null?void 0:u.records,{dateRange:y,setDateRange:N,initialDateRange:f}=t.useDateRangeFromRecords(j),{updateEditorFilterValue:E}=t.useEditorActions();function p(I){var v,C;const k={gte:(v=I==null?void 0:I.from)==null?void 0:v.toISOString(),lte:(C=I==null?void 0:I.to)==null?void 0:C.toISOString()};E(s.name,k)}function g(){E(s.name,null,!0),N(f)}function O(){return l||x?e.jsx("div",{children:e.jsx(t.Skeleton,{className:"h-8 w-72 bg-foreground/10"})}):h?e.jsx("div",{className:"h-8 w-72 bg-muted px-2",children:"Error"}):j?e.jsx(t.DateRangePopover,{title:d.title,open:n,inputClassName:"h-8",setOpen:r,dateRange:y,setDateRange:N,onApply:p,onClear:g}):e.jsx(t.Label,{className:"flex h-8 w-72 items-center bg-muted px-2",children:"No Data"})}return e.jsx(gt,{className:"w-72",id:s.id,sortableType:a,column:s,children:O()})}function qa({id:s,label:a,columns:n,previewColumns:r,sortableType:o}){var N,f;const{setNodeRef:i,isOver:c,over:d}=t.useDroppable({id:s}),l=t.useDndStore(E=>E.activeId),x={},h=c||((f=(N=d==null?void 0:d.data)==null?void 0:N.current)==null?void 0:f.type)===o;function u(){if(!y||y.length===0)return e.jsx("div",{className:"flex h-8 grow items-center space-x-2 rounded-md border border-dashed border-muted-foreground/80 bg-background px-2 py-1 text-sm text-muted-foreground",children:e.jsx("span",{className:"invisible text-muted-foreground/70 group-hover:visible",children:"Drag here"})})}function j(E){const p=t.isDateDataType(E.type);return E.id===Jt.id?e.jsx(gt,{id:E.id,sortableType:o,column:E,children:e.jsx(_a,{})},E.id):p?e.jsx(Ra,{droppableId:s,sortableType:o,column:E},E.id):e.jsx(Pa,{droppableId:s,sortableType:o,column:E},E.id)}const y=l?r:n;return e.jsx(t.SortableContext,{items:n==null?void 0:n.map(E=>E.id),children:e.jsxs("div",{className:t.cn("group space-y-2 rounded-md border-muted-foreground/50 p-4",h&&"border border-muted-foreground/20"),ref:i,style:x,children:[e.jsx(t.Label,{className:"text-sm",children:a}),u(),e.jsx("div",{className:"flex flex-wrap items-center gap-4",children:y==null?void 0:y.map(E=>j(E))})]})})}function _a(){return e.jsx("div",{className:"flex h-8 w-60 items-center space-x-2 rounded-md border border-dashed border-muted-foreground bg-background px-2 py-1 text-sm text-muted-foreground",children:"Drop here"})}function Ga(){const s=t.useEditorStore(o=>{var i;return((i=o.card.queryConfig)==null?void 0:i.filterColumns)||[]}),a=t.useDndStore(o=>o.previewFilterColumns),{removeColumnFromFilterColumns:n}=t.useEditorActions();function r(o){n(o)}return e.jsx("section",{className:"size-full px-4 pb-4",children:e.jsx(qa,{onRemoveColumn:r,sortableType:We,id:Qe,label:"Filters",columns:s,previewColumns:a})})}function $a(){const s=t.useEditorStore(i=>i.card),a=t.useEditorStore(i=>i.showAIDialog),{setShowAIDialog:n}=t.useEditorActions(),{data:r,errorMessage:o}=t.useDashboardCardQuery(s);return e.jsxs("section",{className:"flex justify-between gap-2 p-4",children:[e.jsxs("div",{className:"flex items-center gap-3",children:[e.jsx(t.EditorClearButton,{}),!a&&e.jsxs(t.Button,{onClick:()=>n(!0),variant:"secondary",size:"sm",children:[e.jsx(cn,{className:"mr-2 h-4 w-4"}),"Assistant"]}),e.jsx(Kt,{sql:r==null?void 0:r.sql,error:o})]}),e.jsxs("div",{className:"flex items-center gap-3",children:[e.jsx("div",{className:"rounded-full bg-green-300 px-3 py-1 text-xs font-medium text-black",children:"Preview"}),e.jsx(t.EditorCancelButton,{}),e.jsx(t.EditorAcceptButton,{variant:"default"})]})]})}function Ja(){const s=L.useRef(null),a=L.useRef(null),n=t.useEditorStore(d=>d.isShowingVisual),r=t.useEditorStore(d=>d.showAIDialog),o=t.useEditorStore(d=>d.isDevMode);L.useEffect(()=>{var d,l,x,h;r?((d=s.current)==null||d.resize(0),(l=a.current)==null||l.resize(0)):((x=s.current)==null||x.resize(25),(h=a.current)==null||h.resize(25))},[r]);function i(){return e.jsxs(e.Fragment,{children:[e.jsx(t.ResizablePanel,{role:"query-section",className:"flex",minSize:20,defaultSize:40,children:e.jsx($n,{})}),e.jsx(t.ResizableHandle,{withHandle:!0}),e.jsx(t.ResizablePanel,{className:"pb-1",role:"visual-section",minSize:0,defaultSize:60,children:n&&!r?e.jsxs(t.ResizablePanelGroup,{direction:"horizontal",children:[e.jsx(e.Fragment,{children:e.jsx(t.ResizablePanel,{ref:s,className:"flex",defaultSize:25,maxSize:30,children:e.jsx(Da,{})})}),!r&&e.jsx(t.ResizableHandle,{}),e.jsx(t.ResizablePanel,{minSize:40,defaultSize:75,maxSize:100,children:e.jsx(De,{})})]}):e.jsx(De,{})})]})}function c(){return e.jsx(e.Fragment,{children:e.jsx("div",{className:"grow","data-biz-mode-container":"",children:n?e.jsxs(t.ResizablePanelGroup,{direction:"horizontal",children:[e.jsx(e.Fragment,{children:e.jsx(t.ResizablePanel,{ref:a,defaultSize:25,maxSize:30,children:e.jsx(za,{})})}),e.jsx(t.ResizableHandle,{}),e.jsx(t.ResizablePanel,{defaultSize:75,maxSize:100,children:e.jsxs(t.ResizablePanelGroup,{direction:"vertical",children:[e.jsxs(t.ResizablePanel,{className:"flex min-h-fit flex-col",minSize:10,defaultSize:20,children:[e.jsx($a,{}),e.jsx(Ga,{})]}),e.jsx(t.ResizableHandle,{}),e.jsx(t.ResizablePanel,{minSize:60,defaultSize:80,children:e.jsx(De,{})})]})})]}):e.jsx(De,{})})})}return e.jsx(t.ResizablePanelGroup,{direction:"vertical",className:"min-h-[250px] min-w-full max-w-lg",children:o?i():c()})}function Ha(s){const a=t.useAIInteractionStore(_=>_.currentAIContext),[n,r]=L.useState(""),[o,i]=L.useState(null),{authToken:c}=t.useSemaphorContext(),d=t.useEditorStore(_=>{var Q;return(Q=_==null?void 0:_.card)==null?void 0:Q.sql}),l=t.useEditorStore(_=>_.isDevMode),x=t.useEditorStore(_=>{var Q;return(Q=_==null?void 0:_.card)==null?void 0:Q.python}),{setCardPython:h,setCardSql:u,setRunSql:j,switchCardType:y,setQueryConfig:N}=t.useEditorActions(),f=t.useEditorStore(_=>_.currentAssitantScope)||[],E=t.useEditorStore(_=>_.userInputForAI),p=t.useEditorStore(_=>_.triggerAIRun),g=t.useEditorStore(_=>_.card),O=t.useEditorStore(_=>_.selectedDatabaseName),I=t.useEditorStore(_=>_.selectedTableName),k=t.useEditorStore(_=>_.selectedConnectionId),v=t.useEditorStore(_=>_.selectedSchemaName),C=t.useDashboardStore(_=>_.dashboard.aiScopeTables),{errorMessage:S,refetch:D,data:w}=t.useDashboardCardQuery(g),{setTriggerAIRun:m,setCurrentAssitantScope:B,setCardConfig:M}=t.useEditorActions(),{selectedDatamodelName:T,connectionType:b,selectedDatamodelId:A}=t.useEditorAside(),{messages:F,setMessages:P,reload:R,error:z,append:Y,input:V,setInput:q,status:H,handleInputChange:K,handleSubmit:G,stop:$}=t.useChat({api:"https://semaphor.cloud/api/v1/assistant",headers:{Authorization:`Bearer ${c==null?void 0:c.accessToken}`},body:{random:Math.random(),assistantId:"editor-assistant",isDevMode:l,aiContext:a},maxSteps:10,onError:_=>{console.log("on error",_)},onToolCall:J,onFinish(_,Q){X(Q.usage),r(""),Q.finishReason==="stop"&&r("")}});L.useEffect(()=>{p&&E&&(Y({role:"user",content:E}),m(!1))},[p,E,Y,m]);async function J({toolCall:_}){var Q,oe,de,me;if(["createChartFromSql","createForecast"].includes(_.toolName)){const W=_.args.sql,Z=_.args.python,ee=_.args.chartType;return y(ee),u(W),h(Z),j(!0),{status:"success",message:"Let the user know that chart is created"}}else if(_.toolName==="getTableColumns")r("Getting table columns...");else{if(_.toolName==="getUserSql")return d?{status:"success",sql:d,python:x||""}:{status:"error",message:"No SQL found"};if(_.toolName==="getCurrentTableScope")return r("Getting table scope..."),ne(),{status:"success",tables:f};if(_.toolName==="generateQueryConfig"){r("Generating query config...");const W=_.args.chartType,Z=_.args.queryConfig;_.args.cardConfig,y(W),M(Z),u(void 0),h(void 0);const ee=await D();return(Q=ee==null?void 0:ee.data)!=null&&Q.error?{status:"error",queryConfig:Z,message:(oe=ee==null?void 0:ee.data)==null?void 0:oe.error.message}:(de=ee==null?void 0:ee.data)!=null&&de.records?{status:"success",queryConfig:Z,message:"The data has been visualized"}:{status:"success",queryConfig:Z,message:"The data has been visualized",records:(me=ee==null?void 0:ee.data)==null?void 0:me.records}}else r("Analyzing...")}}function X(_){i(Q=>Q?{promptTokens:Q.promptTokens+_.promptTokens,completionTokens:Q.completionTokens+_.completionTokens,totalTokens:Q.totalTokens+_.totalTokens}:_)}function se(_){const Q=t.removeFromScopeArray(f,_);re(Q)}function re(_){const Q=t.sanitizeAIScope(_);B(Q),P(oe=>[...oe,{id:crypto.randomUUID(),role:"system",content:`Current scope of tables. Always use the table reference format when generating SQL | ${JSON.stringify(Q)}`}])}function le(){const _={databaseName:O||"",schemaName:v||"",tableName:I||"",datamodelId:A||"",datamodelName:t.resolveDatamodelName(T),connectionId:k||"",connectionType:b||""},Q=t.dedup([...f,_]);re(Q)}function ne(){const _={databaseName:O||"",schemaName:v||"",tableName:I||"",datamodelName:t.resolveDatamodelName(T),connectionId:k||"",connectionType:b||"",datamodelId:A||""};if(!t.isInAiScopeArray([...C||[],...f],_)||f.length===0){const oe=t.dedup([...C||[],...f,_]).filter(de=>de.connectionId===_.connectionId);re(oe)}}const te=!["ready","error"].includes(H),ce=t.getErrorMessage(z);return{messages:F,setMessages:P,reload:R,append:Y,input:V,setInput:q,isLoading:te,handleSetAIScope:ne,handleAddCurrentTableToScope:le,removeFromCurrentSelections:se,currentAssitantScope:f,setCurrentAssitantScope:B,handleInputChange:K,handleSubmit:G,stop:$,chatStatus:H,toolStatus:n,llmUsage:o,onFinish:s,errorMessage:ce}}const Ua=[{title:"Help me write a query for",subtitle:"orders by month"},{title:"Create a bar chart for",subtitle:"sales by category"}];function Tt(){const s=L.useRef(null),a=L.useRef(null),[n,r]=L.useState(!1),[o,i]=L.useState(t.isDevEnv),[c,d]=L.useState(!1),[l,x]=L.useState(!1),h=t.useCurrentAIContext(),{setCurrentAIContext:u}=t.useAIActions(),j=t.useDashboardStore($=>$.dashboard.aiContext),y=t.useEditorStore($=>$.card.dataSource),N=t.useEditorStore($=>$.actions.setCardSql),f=t.useEditorStore($=>$.actions.setRunSql),E=t.useEditorStore($=>$.showAIDialog),p=t.useDashboardStore($=>$.handleOpenAssistantProfile),{setShowAIDialog:g,setCardPython:O}=t.useEditorActions(),{setDataSource:I}=t.useEditorActions(),{assistantProfile:k}=t.useAssistantProfile(),{messages:v,setMessages:C,reload:S,append:D,input:w,setInput:m,isLoading:B,handleInputChange:M,handleSubmit:T,stop:b,chatStatus:A,llmUsage:F,errorMessage:P}=Ha();t.useAssistantScroll({scrollContainerRef:s,inputRef:a,messages:v}),L.useEffect(()=>{var $;E&&(($=a.current)==null||$.focus(),u({selectedEntities:(y==null?void 0:y.selectedEntities)||[]}))},[E,y,u]);function R($,J){J==="sql"?(N($),f(!0)):J==="python"&&(O($),f(!0))}function z(){var $;($=j==null?void 0:j.selectedEntities)==null||$[0],x(!0)}function Y(){h.selectedEntities.length===0&&u({selectedEntities:(j==null?void 0:j.selectedEntities)||[]})}function V($){Y();const J={role:"user",content:$.title+" "+$.subtitle};D(J)}function q($){Y(),D({role:"user",content:$})}function H(){return e.jsxs(t.DropdownMenu,{children:[e.jsx(t.DropdownMenuTrigger,{asChild:!0,children:e.jsx(t.Button,{className:"h-7 p-2",size:"sm",variant:"ghost",children:e.jsx(t.EllipsisVertical,{className:"size-3.5"})})}),e.jsxs(t.DropdownMenuContent,{align:"end",children:[e.jsx(t.DropdownMenuLabel,{children:"Options"}),e.jsx(t.DropdownMenuSeparator,{}),e.jsx(t.DropdownMenuCheckboxItem,{checked:n,onCheckedChange:r,children:"Token Usage"}),e.jsx(t.DropdownMenuCheckboxItem,{checked:o,onCheckedChange:i,children:"Tool Invocations"}),e.jsx(t.DropdownMenuCheckboxItem,{checked:c,onCheckedChange:d,children:"System Message"})]})]})}function K(){return e.jsx("div",{"data-role":"header",children:e.jsx("div",{className:"text-lg font-semibold",children:"Assistant"})})}const G=(w==null?void 0:w.length)===0&&(v==null?void 0:v.filter($=>$.role==="user").length)===0;return e.jsxs("div",{"data-role":"editor-assistant",className:"flex h-full w-full flex-col justify-between px-6 py-4",children:[e.jsxs("div",{"data-role":"header-section",className:"flex items-start justify-between gap-2",children:[K(),p&&e.jsx(t.Button,{variant:"outline",size:"sm",className:"h-7 p-2",onClick:p,children:(k==null?void 0:k.name)||"Default Profile"}),e.jsxs("div",{"data-role":"header-actions",className:"flex items-center gap-2",children:[H(),e.jsx(t.IconButton,{tooltip:"Add Context",className:"h-7 p-2",onClick:z,children:e.jsx(t.Settings,{className:"size-4"})}),e.jsx(t.IconButton,{className:"h-7 p-2",tooltip:"New Chat",onClick:()=>{C([]),S()},children:e.jsx(t.SquarePen,{className:"size-4"})}),e.jsx(t.Button,{variant:"ghost",className:"h-8",size:"sm",onClick:()=>{g(!1)},children:e.jsx(t.PanelRight,{className:"size-4"})})]})]}),e.jsx(t.CustomScrollArea,{ref:s,className:"mt-2 flex w-full grow basis-0",children:e.jsxs("div",{className:"space-y-4 py-2 pr-3","data-role":"messages",children:[e.jsx(t.PrintMessages,{messages:v,showTools:o,handleRun:R,showSystemMessage:c}),e.jsx(t.ChatStatus,{messages:v,chatStatus:A,errorMessage:P})]})}),e.jsxs("div",{className:"mb-3",children:[G&&!k&&e.jsx(t.Placeholders,{onClick:V,placeholders:Ua}),e.jsx("div",{children:G&&k&&e.jsx(t.SeedQuestions,{seedQuestions:k.seedQuestions||[],handleSeedQuestionClick:q})})]}),e.jsx(t.ChatInputWithContext,{ref:a,setInput:m,stop:b,input:w,handleInputChange:M,handleSubmit:$=>{Y(),T($)},isLoading:B,onFocus:()=>{}}),F&&n&&e.jsx("div",{className:"flex h-8 items-center justify-between",children:e.jsxs("div",{className:"text-xs text-muted-foreground",children:["Usage: ",F.promptTokens," prompt tokens,"," ",F.completionTokens," completion tokens,"," ",F.totalTokens," total tokens"]})}),e.jsx(t.DataSourceDialog,{incomingSelectedEntities:(y==null?void 0:y.selectedEntities)||[],open:l,onOpenChange:x,dataSource:y||t.EMPTY_DATA_SOURCE,fallbackDataSource:t.EMPTY_DATA_SOURCE,dialogMode:"aiContext"})]})}function Ya({field:s}){const{attributes:a,listeners:n,setNodeRef:r,transform:o,transition:i,isDragging:c}=t.useSortable({id:s.id}),[d,l]=L.useState(!1),x={transform:t.CSS.Transform.toString(o),transition:i},h=t.getDataType(s.dataType),j=(y=>{const N=(y||"").toLowerCase();switch(t.getDataType(N)){case"number":return nt;case"date":return t.Calendar;case"boolean":return Vt;case"json":return qs;case"geo":return on;default:return Rt}})(s.dataType);return e.jsxs("div",{ref:r,style:x,...a,...n,className:`group/container overflow-hidden rounded-lg transition-all ${c?"scale-95 opacity-50":"border border-transparent hover:border-blue-200 hover:bg-blue-50 dark:hover:border-blue-800 dark:hover:bg-blue-950"}`,children:[e.jsxs("div",{className:"flex min-w-0 items-center gap-1 p-2",onClick:()=>l(!d),children:[e.jsx("div",{className:"flex-shrink-0 hover:cursor-grab active:cursor-grabbing",children:e.jsx(t.GripVertical,{className:"invisible size-3.5 text-gray-400 group-hover/container:visible"})}),e.jsx(j,{className:t.cn("size-3.5 flex-shrink-0 text-gray-500",h==="string"?"text-blue-500":"",h==="number"?"text-green-500":"",h==="date"?"text-purple-500":"",h==="boolean"?"text-orange-500":"")}),e.jsx(t.TooltipProvider$1,{children:e.jsxs(t.Tooltip,{children:[e.jsx(t.TooltipTrigger,{asChild:!0,children:e.jsx("div",{className:"min-w-0 flex-1 overflow-hidden",children:e.jsx("span",{className:`block text-sm text-foreground/90 hover:text-foreground dark:text-muted-foreground ${d?"whitespace-normal break-words":"truncate"}`,children:s.name})})}),e.jsx(t.TooltipContent,{side:"bottom",align:"start",className:"max-w-fit",children:e.jsxs("div",{className:"overflow-x-auto",children:[e.jsx("p",{className:t.cn("font-medium",{"text-blue-500":h==="string","text-green-500":h==="number","text-purple-500":h==="date","text-orange-500":h==="boolean"}),children:s.label||s.name}),s.description&&e.jsx("div",{className:"mt-1 text-sm text-muted-foreground",children:s.description}),e.jsxs("div",{className:"mt-2 flex items-center gap-2 text-xs text-muted-foreground",children:[e.jsx(mn,{className:"size-3.5"}),e.jsx("p",{className:"",children:s.qualifiedEntityName?`${s.qualifiedEntityName}.${s.name}`:s.name})]}),e.jsxs("div",{className:"flex items-center gap-2.5",children:[e.jsx(j,{className:t.cn("size-3 flex-shrink-0 text-gray-500",h==="string"?"text-blue-500":"",h==="number"?"text-green-500":"",h==="date"?"text-purple-500":"",h==="boolean"?"text-orange-500":"")}),e.jsx("p",{className:t.cn("text-xs font-normal text-gray-500"),children:s.dataType})]})]})})]})}),e.jsx("button",{onClick:y=>{y.stopPropagation(),l(!d)},className:"invisible flex-shrink-0 text-gray-400 hover:text-gray-600 group-hover/container:visible",children:d?e.jsx(t.ChevronDown,{className:"h-4 w-4"}):e.jsx(t.ChevronRight,{className:"h-4 w-4"})})]}),d&&e.jsx("div",{className:"text-muted-foreground-700 px-2 pb-3 text-sm",children:e.jsx(t.Card,{className:"",children:e.jsxs(t.CardContent,{className:"space-y-2 p-3",children:[e.jsxs("div",{className:"flex items-center gap-2",children:[e.jsx(Pt,{className:"h-4 w-4 text-muted-foreground"}),e.jsx("span",{className:"break-all",children:s.label||s.name})]}),e.jsxs("div",{className:"flex items-center gap-2",children:[e.jsx(jn,{className:"h-4 w-4 text-muted-foreground"}),e.jsx("span",{className:"break-all",children:s.name})]}),e.jsx(t.Badge,{variant:"outline",className:"mt-2 text-xs",children:s.dataType})]})})})]})}function Ka({entityGroup:s,fields:a,isOpen:n,onToggle:r}){return e.jsxs(t.Collapsible,{open:n,onOpenChange:r,children:[e.jsxs(t.CollapsibleTrigger,{className:"flex w-full items-center gap-2 rounded-md px-3 py-2 hover:bg-muted",children:[e.jsx("span",{className:"flex-1 text-left text-sm font-medium",children:s.label||s.entityName}),e.jsxs("span",{className:"text-xs text-gray-500",children:["(",a.length,")"]}),n?e.jsx(t.ChevronDown,{className:"h-4 w-4"}):e.jsx(t.ChevronRight,{className:"h-4 w-4"})]}),e.jsx(t.CollapsibleContent,{className:"mt-1 space-y-1",children:e.jsx(t.SortableContext,{items:a.map(o=>o.id),strategy:t.verticalListSortingStrategy,children:a.map(o=>e.jsx(Ya,{field:o},o.id))})})]})}function Qa(){const[s,a]=L.useState(""),[n,r]=L.useState(new Set),[o,i]=L.useState("all");Wa();const c=t.useEditorStore(I=>I.card.dataSource),{columns:d=[],columnGroups:l=[],isLoading:x,error:h}=t.useColumns(),u=d.filter(I=>I.name.toLowerCase().includes(s.toLowerCase())||I.dataType.toLowerCase().includes(s.toLowerCase())||I.qualifiedEntityName&&I.qualifiedEntityName.toLowerCase().includes(s.toLowerCase())),j=I=>I.dataType==="number"||I.dataType==="integer"||I.dataType==="float"||I.dataType==="decimal"||I.dataType==="currency"?"metrics":"dimensions",N=(o==="all"?u:u.filter(I=>j(I)===o)).reduce((I,k)=>{const v=k.qualifiedEntityName||"Other Fields";return I[v]||(I[v]={label:t.toLabel(k.entityName),fields:[]}),I[v].fields.push(k),I},{});L.useEffect(()=>{const I=Object.keys(N);r(new Set(I))},[Object.keys(N).join(",")]);const f=I=>{const k=new Set(n);k.has(I)?k.delete(I):k.add(I),r(k)},E=u.filter(I=>j(I)==="dimensions").length,p=u.filter(I=>j(I)==="metrics").length,g=u.filter(I=>j(I)==="calculated").length,O=u.length>0;return x?e.jsxs("div",{className:"flex h-[calc(100vh-200px)] w-[290px] flex-col items-center justify-center",children:[e.jsx(t.LoaderCircle,{className:"h-8 w-8 animate-spin text-gray-400"}),e.jsx("span",{className:"mt-2 text-sm text-gray-500",children:"Loading fields..."})]}):h?e.jsxs("div",{className:"flex h-[calc(100vh-200px)] w-[290px] flex-col items-center justify-center",children:[e.jsx(t.Database,{className:"mb-4 h-12 w-12 text-red-300"}),e.jsx("p",{className:"mb-2 text-sm text-red-500",children:"Error loading fields"}),e.jsx("p",{className:"px-4 text-center text-xs text-red-400",children:h.message||"Failed to load column data"})]}):!c||!c.selectedEntities||c.selectedEntities.length===0?e.jsx(t.ScrollArea,{className:"h-[calc(100vh-200px)] w-[290px]",children:e.jsxs("div",{className:"flex flex-col items-center justify-center py-8 text-center",children:[e.jsx(t.Database,{className:"mb-4 h-12 w-12 text-gray-300"}),e.jsx("p",{className:"mb-2 text-sm text-gray-500",children:"No data source selected"}),e.jsx("p",{className:"px-4 text-xs text-gray-400",children:"Select a table, view, or dataset from the data source panel to see available fields"})]})}):e.jsxs("div",{className:"mt-2 flex h-[calc(100vh-200px)] w-full grow flex-col gap-2 px-6 pb-6",children:[e.jsxs("div",{className:"mt-1 flex-shrink-0 space-y-2",children:[d.length>0&&e.jsx("div",{className:"mb-4",children:e.jsx(t.Input$1,{type:"text",placeholder:"Search fields...",value:s,onChange:I=>a(I.target.value)})}),O&&e.jsx(t.Tabs,{defaultValue:"all",value:o,onValueChange:I=>i(I),className:"mb-4",children:e.jsxs(t.TabsList,{className:"grid h-9 w-full grid-cols-4",children:[e.jsxs(t.TabsTrigger,{value:"all",className:"text-xs",children:["All",e.jsx("span",{className:"ml-2 text-xs font-semibold",children:u.length})]}),e.jsxs(t.TabsTrigger,{value:"dimensions",className:"text-xs",children:[e.jsx(t.Layers,{className:"size-4 shrink-0"}),e.jsx("span",{className:"ml-2 text-xs font-semibold",children:E})]}),e.jsxs(t.TabsTrigger,{value:"metrics",className:"text-xs",children:[e.jsx(t.ChartColumn,{className:"size-4 shrink-0"}),e.jsx("span",{className:"ml-2 text-xs font-semibold",children:p})]}),e.jsxs(t.TabsTrigger,{value:"calculated",className:"text-xs",children:[e.jsx(Ps,{className:"size-4 shrink-0"}),e.jsx("span",{className:"ml-2 text-xs font-semibold",children:g})]})]})})]}),e.jsxs(t.CustomScrollArea,{className:"py-2",children:[e.jsxs("div",{className:"space-y-2",children:[Object.entries(N).map(([I,k])=>{const v=l.find(C=>C.entityName===I)||{entityName:I,label:k.label};return e.jsx(Ka,{entityGroup:v,fields:k.fields,isOpen:n.has(I),onToggle:()=>f(I)},I)}),Object.keys(N).length===0&&d.length===0&&e.jsxs("div",{className:"py-8 text-center text-sm text-gray-500",children:[e.jsx("p",{children:"No fields found for selected data source"}),e.jsx("p",{className:"mt-1 text-xs text-gray-400",children:"Try selecting different data sources"})]}),Object.keys(N).length===0&&d.length>0&&e.jsx("div",{className:"py-4 text-center text-sm text-gray-500",children:"No fields found for this category"})]}),e.jsx(t.ScrollBar,{orientation:"horizontal"}),e.jsx(t.ScrollBar,{orientation:"vertical"})]})]})}function Wa(){const[s,a]=L.useState(!1);return t.useDndMonitor({onDragStart(){a(!0)},onDragEnd(){a(!1)},onDragCancel(){a(!1)}}),s}function Xa(){return e.jsxs("div",{className:" h-full flex flex-col items-center",children:[" ",e.jsx(Qa,{})," "]})}function Za({initialJoinPlan:s,availableDataSources:a}){const[n,r]=L.useState(s),[o,i]=L.useState(new Set),c=()=>{const v=n.joins.length>0?Math.max(...n.joins.map(S=>S.sequence))+1:1,C={id:`join-${Date.now()}`,source:{type:"table",name:"",database:"",schema:""},target:{type:"table",name:"",database:"",schema:""},joinType:"INNER",sequence:v,joinKeyGroups:[{id:"group-"+Date.now()+"-"+Math.random().toString(36).substr(2,9),operator:"AND",keys:[]}]};r({...n,joins:[...n.joins,C]}),i(new Set([...o,C.id]))},d=v=>{r({...n,joins:n.joins.filter(C=>C.id!==v)}),i(new Set([...o].filter(C=>C!==v)))},l=(v,C)=>{var m,B;const S=n.joins.find(M=>M.id===v);if(!S)return;const D={...S,...C},w=n.joins.map(M=>M.id===v?D:M);if((m=D.source)!=null&&m.name&&((B=D.target)!=null&&B.name)&&D.joinKeyGroups[0].keys.length===0){const M=a.find(F=>{var P;return F.name===((P=D.source)==null?void 0:P.name)}),T=a.find(F=>{var P;return F.name===((P=D.target)==null?void 0:P.name)}),b={id:`key-${Date.now()}`,source:{id:`source-${Date.now()}`,name:"",dataType:"",label:"",entityId:(M==null?void 0:M.name)||"",entityName:(M==null?void 0:M.name)||"",entityType:(M==null?void 0:M.type)||"table"},target:{id:`target-${Date.now()}`,name:"",dataType:"",label:"",entityId:(T==null?void 0:T.name)||"",entityName:(T==null?void 0:T.name)||"",entityType:(T==null?void 0:T.type)||"table"},operator:"="},A=[...D.joinKeyGroups];A[0]={...A[0],keys:[b]},D.joinKeyGroups=A,w[w.findIndex(F=>F.id===v)]=D}r({...n,joins:w})};return{joinPlan:n,expandedJoins:o,setJoinPlan:r,addJoin:c,removeJoin:d,updateJoin:l,moveJoinUp:v=>{const C=n.joins.findIndex(S=>S.id===v);if(C>0){const S=[...n.joins],D={...S[C]},w={...S[C-1]};S[C]=w,S[C-1]=D,S.forEach((B,M)=>{B.sequence=M+1});const m={...n,joins:S};r(m)}},moveJoinDown:v=>{const C=n.joins.findIndex(S=>S.id===v);if(C<n.joins.length-1){const S=[...n.joins],D={...S[C]},w={...S[C+1]};S[C]=w,S[C+1]=D,S.forEach((B,M)=>{B.sequence=M+1});const m={...n,joins:S};r(m)}},toggleJoinExpansion:v=>{const C=new Set(o);C.has(v)?C.delete(v):C.add(v),i(C)},getAvailableSourceEntities:v=>{if(n.joins.length===0)return a;const C=n.joins.findIndex(D=>D.id===v);if(C===0)return a;const S=new Set;return n.baseEntity.name&&S.add(n.baseEntity.name),n.joins.slice(0,C).forEach(D=>{S.add(D.source.name),S.add(D.target.name)}),a.filter(D=>S.has(D.name))},getAvailableTargetEntities:v=>a.filter(C=>C.name!==v),addJoinKeyGroup:v=>{const C=n.joins.find(D=>D.id===v);if(!C)return;const S=[...C.joinKeyGroups,{id:"group-"+Date.now()+"-"+Math.random().toString(36).substr(2,9),operator:"AND",keys:[]}];l(v,{joinKeyGroups:S})},updateGroupOperator:(v,C,S)=>{const D=n.joins.find(m=>m.id===v);if(!D)return;const w=[...D.joinKeyGroups];w[C]={...w[C],operator:S},l(v,{joinKeyGroups:w})},removeJoinKeyGroup:(v,C)=>{const S=n.joins.find(w=>w.id===v);if(!S)return;const D=[...S.joinKeyGroups];D.splice(C,1),l(v,{joinKeyGroups:D})},addJoinKey:(v,C)=>{const S=n.joins.find(M=>M.id===v);if(!S)return;const D=a.find(M=>M.name===S.source.name),w=a.find(M=>M.name===S.target.name),m=[...S.joinKeyGroups],B={id:`key-${Date.now()}`,source:{id:`source-${Date.now()}`,name:"",dataType:"",label:"",entityId:(D==null?void 0:D.name)||"",entityName:(D==null?void 0:D.name)||"",entityType:(D==null?void 0:D.type)||"table"},target:{id:`target-${Date.now()}`,name:"",dataType:"",label:"",entityId:(w==null?void 0:w.name)||"",entityName:(w==null?void 0:w.name)||"",entityType:(w==null?void 0:w.type)||"table"},operator:"="};m[C]={...m[C],keys:[...m[C].keys,B]},l(v,{joinKeyGroups:m})},updateJoinKey:(v,C,S,D,w)=>{const m=n.joins.find(A=>A.id===v);if(!m)return;const B=a.find(A=>A.name===m.source.name),M=a.find(A=>A.name===m.target.name),T=[...m.joinKeyGroups],b=T[C].keys[S];D==="sourceColumnName"&&B?T[C].keys[S]={...b,source:{...b.source,name:w}}:D==="targetColumnName"&&M?T[C].keys[S]={...b,target:{...b.target,name:w}}:D==="operator"&&(T[C].keys[S]={...b,operator:w}),l(v,{joinKeyGroups:T})},removeJoinKey:(v,C,S)=>{const D=n.joins.find(m=>m.id===v);if(!D)return;const w=[...D.joinKeyGroups];w[C].keys.splice(S,1),l(v,{joinKeyGroups:w})},generateSQLPreview:()=>{const v=[...n.joins].sort((D,w)=>D.sequence-w.sequence),C=n.baseEntity;if(!C.name)return"SELECT * FROM table -- Please select a base entity";let S=`SELECT *
369
+ `),I=new Blob([O],{type:"text/csv"}),k=URL.createObjectURL(I),v=document.createElement("a");v.href=k,v.download=`${a.title}.csv`,v.click()}function p(){const g=`Can you get the documentation for ${a.type} chart?`;x(g)}return a?e.jsxs("div",{className:"relative isolate flex h-full flex-col py-2 pb-3",children:[(j||y)&&e.jsx("div",{className:"absolute bottom-0 left-0 right-0 top-0 z-50 m-auto flex h-10 w-10 items-center justify-center rounded-md bg-muted",children:e.jsx(t.LoaderCircle,{className:"h-8 w-8 animate-spin text-muted-foreground"})}),e.jsxs("div",{className:"z-10 mb-0 flex min-h-10 items-center justify-end gap-2 px-6",children:[r&&e.jsxs("div",{className:"flex grow items-center",children:[e.jsx(ts,{}),o&&e.jsx(t.IconButton,{tooltip:"Visual Docs",onClick:p,children:e.jsx(Bs,{className:"size-4"})}),!["table","custom"].includes(a.type)&&o&&e.jsx(Qn,{})]}),!r&&e.jsxs("div",{className:"flex grow items-center gap-1",children:[e.jsx(t.Button,{className:"h-7 w-fit px-1 font-mono text-xs text-muted-foreground/70",variant:"ghost",size:"icon",onClick:E,children:e.jsx(Zn,{className:"size-4"})}),e.jsx(t.Button,{className:"h-7 w-fit px-1 font-mono text-xs text-muted-foreground/70",variant:"ghost",size:"icon",onClick:f,children:e.jsx(Ys,{strokeWidth:1.5,className:"size-4"})}),e.jsx(t.CopyButton,{text:JSON.stringify(u==null?void 0:u.records,null,2),className:"h-7 w-fit px-1 font-mono text-xs text-muted-foreground/70"})]}),e.jsxs("div",{className:"flex items-center gap-2",children:[s,e.jsx(ss,{})]}),n&&e.jsx(oa,{})]}),r?e.jsx(ns,{}):e.jsxs(t.ResizablePanelGroup,{className:"px-6",direction:"horizontal",children:[i&&e.jsxs(e.Fragment,{children:[e.jsx(t.ResizablePanel,{id:"1",order:1,defaultSize:30,minSize:10,className:"relative flex h-full min-h-0 w-full flex-1 basis-0",children:i&&e.jsx(ra,{})}),e.jsx(t.ResizableHandle,{})]}),e.jsxs(t.ResizablePanel,{id:"2",order:2,minSize:10,className:"relative flex h-full min-h-0 w-full flex-1 basis-0",children:[(u==null?void 0:u.records)&&(u==null?void 0:u.records.length)>0&&e.jsx(Jn,{data:(u==null?void 0:u.records)||[]}),N&&e.jsx(Ut,{error:N})]})]})]}):e.jsx(e.Fragment,{children:"No Active Card"})}function ra(){const s=t.useEditorStore(n=>n.pythonStdOut);if(!s)return null;const a=s.replace(/\n/g,"<br>");return e.jsxs("div",{className:"relative flex w-full flex-col border-r",children:[e.jsx("div",{className:"sticky top-0 flex max-h-11 min-h-11 grow items-center border-b bg-muted px-3 font-mono text-xs font-semibold text-foreground/70",children:"Python Output"}),e.jsxs(t.ScrollArea,{className:"overflow-y-auto px-2 pt-1 font-mono text-xs text-foreground/90",children:[e.jsx("div",{dangerouslySetInnerHTML:{__html:a}}),e.jsx(t.ScrollBar,{orientation:"horizontal"})]})]})}function oa(){const s=t.useEditorStore(n=>n.isShowingVisual),a=t.useEditorStore(n=>n.actions.setIsShowingVisual);return e.jsxs("div",{className:"flex items-center space-x-2",children:[e.jsx(t.Label,{htmlFor:"visualize",children:"Chart"}),e.jsx(t.SmallSwitch,{checked:s,onCheckedChange:()=>a(!s),id:"visualize",className:"data-[state=checked]:bg-foreground/50"})]})}function ia(){var f,E;const s=t.useEditorStore(p=>p.card.customCardPreferences),{data:a}=dt(),n=(a==null?void 0:a.plugins)||[],r=t.useEditorStore(p=>p.card),o=t.useEditorStore(p=>p.frame),i=(s==null?void 0:s.visualType)||"single",{setCustomCardPreferences:c}=t.useEditorActions(),{components:d,manifest:l}=t.useCustomVisual((s==null?void 0:s.url)||""),x=(f=l==null?void 0:l.visuals)==null?void 0:f.find(p=>p.name===(s==null?void 0:s.componentName));function h(p,g){if(!s)return;const I={...(s==null?void 0:s.dataInputCardIds)||{},[p]:{cardId:g,hookRef:null}};c({...s,dataInputCardIds:I})}function u(p){var O,I;const g=(O=o==null?void 0:o.cards)==null?void 0:O.filter(k=>{var v;return((v=k==null?void 0:k.customCardPreferences)==null?void 0:v.visualType)!=="multiple"}).map(k=>({value:k.id,label:k.tabTitle||k.title}));return e.jsx("div",{className:"space-y-2",children:(I=p==null?void 0:p.dataInputs)==null?void 0:I.map((k,v)=>{var C,S;return e.jsxs("div",{className:"grid grid-cols-10 gap-2",children:[e.jsx("div",{className:"col-span-4 flex items-center",children:k}),e.jsx(ae,{className:"col-span-6 h-8 w-full justify-between",label:"",options:g||[],value:((S=(C=s==null?void 0:s.dataInputCardIds)==null?void 0:C[v])==null?void 0:S.cardId)||"",onValueChange:D=>h(v,D)})]},v+Math.random())})})}function j(p,g,O=[],I=""){var k,v;return s?p==="input"?e.jsx(t.Input,{className:`h-8 w-full ${t.removeRing}`,value:((k=s==null?void 0:s.settings)==null?void 0:k[g])||I,onChange:C=>{c({...s,settings:{...s==null?void 0:s.settings,[g]:C.target.value}})}},g):p==="select"?e.jsx(ae,{className:"h-8 w-full",label:"",options:O,value:((v=s==null?void 0:s.settings)==null?void 0:v[g])||I,onValueChange:C=>{c({...s,settings:{...s==null?void 0:s.settings,[g]:C}})}}):null:null}function y(p){const g=Object.entries((p==null?void 0:p.settings)||{});return e.jsx("div",{className:"space-y-3",children:g.map(([O,I])=>e.jsxs("div",{className:"space-y-1",children:[e.jsx(t.Label,{children:I.title}),j(I.ui,O,I.options,I.defaultValue)]},O))})}function N(p){s&&c({...s,visualType:p,componentName:""})}return e.jsxs(t.Accordion,{type:"multiple",defaultValue:["component-settings"],className:"px-6 py-2",children:[e.jsxs(t.AccordionItem,{value:"plugin-settings",children:[e.jsx(t.AccordionTrigger,{children:"Plugin"}),e.jsx(t.AccordionContent,{children:e.jsxs("div",{className:"space-y-4 text-sm",children:[e.jsx("div",{className:"space-y-2",children:e.jsxs("div",{className:"space-y-4",children:[e.jsx(ae,{icon:e.jsx(Os,{className:"h-3.5 w-3.5"}),className:"h-9 w-full",label:"Select Plugin",options:n,value:(s==null?void 0:s.url)||"",onValueChange:p=>c({...s||{url:"",componentName:""},url:p})}),((s==null?void 0:s.type)==="component"||(s==null?void 0:s.type)===void 0)&&e.jsx(t.Tabs,{value:i,onValueChange:N,children:e.jsxs(t.TabsList,{className:"h-9 w-full",children:[e.jsx(t.TabsTrigger,{className:"h-7 w-full",value:"single",children:"Single Visual"}),e.jsx(t.TabsTrigger,{className:"h-7 w-full",value:"multiple",children:"Multi-Visual"})]})})]})}),((s==null?void 0:s.type)==="component"||(s==null?void 0:s.type)===void 0)&&s&&e.jsx(e.Fragment,{children:d&&e.jsx(ae,{icon:e.jsx(Gs,{className:"h-3.5 w-3.5"}),className:"h-9 w-full",label:"Select Component",options:(d==null?void 0:d.filter(p=>p.type===i).map(p=>({value:p.name,label:p.name})))||[],value:s.componentName,onValueChange:p=>{console.log("changing value",p),c({...s,componentName:p})}})})]})})]}),((E=r==null?void 0:r.customCardPreferences)==null?void 0:E.componentName)&&e.jsxs(t.AccordionItem,{className:"border-none",value:"component-settings",children:[e.jsx(t.AccordionTrigger,{children:"Settings"}),e.jsxs(t.AccordionContent,{children:[x&&x.dataInputs&&e.jsxs("div",{className:"space-y-3",children:[e.jsx(t.Label,{children:"Input Mapping"}),e.jsx("div",{className:"px-2",children:u(x)})]}),x&&x.settings&&e.jsx("div",{className:"space-y-3",children:e.jsx("div",{className:"px-2",children:y(x)})})]})]})]})}function je(){const[s,a]=L.useState([]),n=t.useEditorStore(x=>x.card.preferences),{setFilterOnClickColumnIndex:r,setCardPreferences:o}=t.useEditorStore(x=>x.actions),i=t.useEditorStore(x=>x.queryResultColumns);t.useEditorStore(x=>{var h;return(h=x.card.preferences)==null?void 0:h.filterOnClickColumnIndex}),L.useEffect(()=>{i&&a(new Array(i.length).fill(!1))},[i]);function c(x,h){var u,j;h?n!=null&&n.onClickFilter&&((u=n==null?void 0:n.onClickFilter)==null?void 0:u.length)>0?o({...n,onClickFilter:[...n.onClickFilter,{columnIndex:x,expression:""}]}):o({...n,onClickFilter:[{columnIndex:x,expression:""}]}):(o({...n,onClickFilter:(j=n==null?void 0:n.onClickFilter)==null?void 0:j.filter(y=>y.columnIndex!==x)}),a(y=>{const N=[...y];return N[x]=!1,N}))}function d(x,h){var j;const u=(j=n==null?void 0:n.onClickFilter)==null?void 0:j.map(y=>y.columnIndex===x?{...y,expression:h.target.value}:y);o({...n,onClickFilter:u})}function l(x){var h,u,j,y;if(s!=null&&s[x]||(u=(h=n==null?void 0:n.onClickFilter)==null?void 0:h.find(N=>N.columnIndex===x))!=null&&u.expression)return e.jsx(t.Input,{value:(y=(j=n==null?void 0:n.onClickFilter)==null?void 0:j.find(N=>N.columnIndex===x))==null?void 0:y.expression,onChange:N=>d(x,N),type:"text",className:"h-9 w-full font-mono text-xs focus-visible:ring-0 focus-visible:ring-ring focus-visible:ring-offset-0",placeholder:"Expression"})}return e.jsxs("div",{className:"max-h-[150px] space-y-2 overflow-y-auto",children:[e.jsx(t.Label,{children:"On Click"}),i==null?void 0:i.map((x,h)=>{var u,j;return e.jsx("div",{className:"group flex items-center justify-between space-y-2",children:e.jsxs("div",{className:"grow",children:[e.jsxs("div",{className:"flex items-center space-x-2 py-2",children:[e.jsx(t.Checkbox,{checked:!!((u=n==null?void 0:n.onClickFilter)!=null&&u.find(y=>y.columnIndex===h)),onCheckedChange:y=>c(h,y)}),e.jsx("label",{className:"text-sm font-medium leading-none peer-disabled:cursor-not-allowed peer-disabled:opacity-70",children:x}),e.jsx("div",{className:"flex items-center gap-2",children:((j=n==null?void 0:n.onClickFilter)==null?void 0:j.find(y=>y.columnIndex===h))&&e.jsx(t.Pencil,{onClick:()=>{a(y=>{const N=[...y];return N[h]=!y[h],N})},className:"invisible size-3 cursor-pointer text-gray-400 group-hover:visible"})})]}),l(h)]})},x)})]})}function la({idx:s}){var d;const a=t.useEditorStore(l=>{var x;return(x=l.card)==null?void 0:x.preferences}),n=t.useEditorStore(l=>{var x;return(x=l.card.preferences)==null?void 0:x.datasetOptions}),r=t.useEditorStore(l=>l.actions.setCardPreferences),o=(d=a==null?void 0:a.chartOptions)==null?void 0:d.indexAxis,i=n==null?void 0:n.find(l=>l.idx===s);function c(l,x){(l==="end"||l==="start")&&t.getContrastColor(t.getCanvasBackgroundColor());const h={display:l!=="none",align:l,anchor:l,clamp:!0};if(!i)r({...a,datasetOptions:[...n||[],{idx:x,datalabels:h}]});else{const u={...i};u.datalabels=h;const j=n==null?void 0:n.map(y=>y.idx===x?u:y);r({...a,datasetOptions:j})}}return e.jsxs(t.Popover,{children:[e.jsx(t.PopoverTrigger,{children:e.jsx(Pt,{className:"size-4 rotate-[135deg] cursor-pointer text-muted-foreground hover:text-foreground"})}),e.jsx(t.PopoverContent,{className:"w-fit px-2 py-1",children:e.jsxs("div",{className:"flex gap-1",children:[e.jsx("button",{onClick:()=>c("none",s),className:"h-7 p-1 text-xs font-normal",children:e.jsx(t.X,{className:"size-3.5"})}),e.jsx("button",{onClick:()=>c("start",s),className:"h-7 p-1 text-xs font-normal",children:e.jsx(tn,{className:t.cn("h-4 w-4",{"rotate-90":o==="y"})})}),e.jsx("button",{onClick:()=>c("center",s),className:"h-7 p-1 text-xs font-normal",children:e.jsx(nn,{className:t.cn("h-4 w-4",{"rotate-90":o==="y"})})}),e.jsx("button",{onClick:()=>c("end",s),className:"h-7 p-1 text-xs font-normal",children:e.jsx(sn,{className:t.cn("h-4 w-4",{"rotate-90":o==="y"})})})]})})]})}function ca(){const s=t.useEditorStore(i=>i.card),{data:a}=t.useDashboardCardQuery(s),{keys:n}=t.getKeys((a==null?void 0:a.records)||[]),r=n.slice(1).filter(i=>!t.METADATA_KEYS.includes(i));let o=r;if(["stackedBar","stackedLine"].includes(s.type)){const i=t.pivotData({dataArray:(a==null?void 0:a.records)||[],groupKey:n[0],pivotKey:n[1],valueKey:n[2]}),{keys:c}=t.getKeys(i);o=c.slice(1)}return{transformedMetricKeys:o,dimensionKeys:n.slice(0,1),keys:n,defaultMetricKeys:r}}function ft({children:s,className:a,delayDuration:n}){return e.jsx(t.TooltipProvider$1,{children:e.jsxs(t.Tooltip,{delayDuration:n,children:[e.jsx(t.TooltipTrigger,{asChild:!0,children:e.jsx("span",{className:t.cn("overflow-hidden text-ellipsis whitespace-nowrap",a),children:s})}),e.jsx(t.TooltipContent,{children:s})]})})}function as(){const s=t.useEditorStore(l=>l.card),a=t.useEditorStore(l=>{var x,h,u;return(u=(h=(x=l==null?void 0:l.card)==null?void 0:x.preferences)==null?void 0:h.chartOptions)==null?void 0:u.indexAxis}),{data:n}=t.useDashboardCardQuery(s),r=a==="y"?"Metric":"Dimension",o=a==="y"?"Dimension":"Metric",{dimensionKeys:i,transformedMetricKeys:c,keys:d}=ca();return d.length===0?null:e.jsxs("div",{className:"space-y-4",children:[e.jsxs("div",{className:"space-y-2",children:[e.jsx(t.Label,{children:r}),e.jsx("div",{className:"max-h-[125px] space-y-1 overflow-y-auto",children:i.map(l=>e.jsx("p",{className:"flex h-8 items-center rounded-md bg-muted/70 px-3 hover:bg-muted",title:l,children:rs(l)},l))})]}),e.jsxs("div",{className:"space-y-2",children:[e.jsx(t.Label,{children:o}),e.jsx("div",{className:"my-1 max-h-[125px] space-y-1 overflow-y-auto",children:c.map((l,x)=>e.jsx(os,{className:"flex h-8 items-center bg-muted/70 px-3 hover:bg-muted",iconClassName:"invisible group-hover:visible",col:l,idx:x},l))})]})]})}function rs(s,a=30){return s.length>a?s.slice(0,a)+"...":s}function os({col:s,idx:a,className:n,iconClassName:r,children:o}){const i=t.useEditorStore(h=>{var u;return(u=h.card)==null?void 0:u.preferences}),c=t.useEditorStore(h=>{var u,j;return(j=(u=h.card)==null?void 0:u.preferences)==null?void 0:j.datasetOptions}),d=c==null?void 0:c.find(h=>h.idx===a),{setCardPreferences:l}=t.useEditorStore(h=>h.actions);function x(h){if(!d)l({...i,datasetOptions:[...c||[],{idx:a,type:h==="area"?"line":h,fill:h==="area"?"origin":""}]});else{const u={...d};u.type=h==="area"?"line":h,u.fill=h==="area"?"origin":"";const j=c==null?void 0:c.map(y=>y.idx===a?u:y);l({...i,datasetOptions:j})}}return e.jsxs("div",{className:t.cn("group flex items-center justify-between gap-2 rounded-md",n),children:[o||e.jsx(ft,{className:"max-w-[100px]",title:s,children:rs(s)}),e.jsxs("div",{className:"flex gap-2",children:[e.jsx(Be,{onClick:()=>x("bar"),className:t.cn("size-4 cursor-pointer text-muted-foreground hover:text-foreground",r)}),e.jsx(Fe,{onClick:()=>x("line"),className:t.cn("size-4 cursor-pointer text-muted-foreground hover:text-foreground",r)}),e.jsx(Vs,{onClick:()=>x("area"),className:t.cn("size-4 cursor-pointer text-muted-foreground hover:text-foreground",r)}),e.jsx(la,{idx:a})]})]})}function is(){const s=t.useEditorStore(y=>y.selectedConnectionId),a=t.useEditorStore(y=>y.selectedDatamodelId),n=t.useEditorStore(y=>y.selectedDatabaseName),r=t.useEditorStore(y=>y.selectedSchemaName),o=t.useEditorStore(y=>y.selectedTableName),i=t.useDashboardStore(y=>y.dashboard.filters)||[],c=t.useDashboardStore(y=>y.actions.addFilter),d=t.useDashboardStore(y=>y.actions.removeFilter),{removeFilterValues:l}=t.useDashboardActions(),{modelItems:x,tableName:h,connectionType:u}=t.useEditorAside();function j(y,N="dashboard"){var C;const f=t.fmt(y.column_name),E=t.fmt(n||""),p=t.fmt(r||""),g=t.fmt(h);let O=t.getQualifiedTableName({schemaName:p,tableName:g,connectionType:u,databaseName:E}),I=`${O}.${f}`;const k=(C=x==null?void 0:x.find(S=>S.id===a))==null?void 0:C.name;a&&a!=="none"&&(I=`${t.DATAMODEL_NAMESPCACE}.${k}.${f}`,O=`${t.DATAMODEL_NAMESPCACE}.${k}`);const v=i==null?void 0:i.find(S=>S.column===I&&S.table===g&&(S.database===E||S.database===n));if(v)l(v.id),d(v.id);else{const S=t.v4();return h==="api"&&s?(c({location:N,id:S,column:I,title:y.column_name,dataType:y.data_type,table:"api",database:"",connectionId:s,operation:"in",sql:t.getDefaultFilterSql(y.data_type,O,f)}),S):(c({id:S,location:N,column:I,title:y.column_name,dataType:y.data_type,table:o||"",database:n||"",connectionId:s||"",operation:"in",sql:t.getDefaultFilterSql(y.data_type,O,f)}),S)}}return{assignFilter:j}}function Ne(){const s=t.useDashboardStore(d=>d.dashboard.filters),a=t.useEditorStore(d=>d.frame),{setFrame:n}=t.useEditorActions(),{columns:r}=t.useEditorAside(),{assignFilter:o}=is();function i(d){const l=o(d,"frame");n({...a,filterId:l})}const c=s==null?void 0:s.find(d=>d.id===a.filterId);return e.jsxs("div",{className:"space-y-3",children:[e.jsx(t.Label,{children:"Card Filter"}),e.jsx(da,{onSelect:i,columns:r}),c&&e.jsx(t.FilterHeader,{filter:c})]})}function da({columns:s,onSelect:a}){var c;const[n,r]=he.useState(!1),[o,i]=he.useState("");return e.jsxs(t.Popover,{open:n,onOpenChange:r,children:[e.jsx(t.PopoverTrigger,{asChild:!0,children:e.jsxs(t.Button,{size:"sm",variant:"outline",role:"combobox","aria-expanded":n,className:"w-full justify-between font-normal",children:[o?(c=s.find(d=>d.column_name===o))==null?void 0:c.column_name:"Select Column...",e.jsx(t.CaretSortIcon,{className:"ml-2 h-4 w-4 shrink-0 opacity-50"})]})}),e.jsx(t.PopoverContent,{className:"w-[200px] p-0",children:e.jsxs(t.Command,{children:[e.jsx(t.CommandInput,{placeholder:"Search column",className:"h-9"}),e.jsxs(t.CommandList,{children:[e.jsx(t.CommandEmpty,{children:"No framework found."}),e.jsx(t.CommandGroup,{children:s==null?void 0:s.map(d=>e.jsxs(t.CommandItem,{value:d.column_name,onSelect:l=>{const x=l===o?"":l;i(x),r(!1),x&&a(d)},children:[d.column_name,e.jsx(t.CheckIcon,{className:t.cn("ml-auto h-4 w-4",o===d.column_name?"opacity-100":"opacity-0")})]},d.column_name))})]})]})})]})}function ua({cardType:s}){return e.jsx("div",{className:"space-y-6 px-6 py-2",children:e.jsxs(t.Accordion,{defaultValue:["item-2"],type:"multiple",children:[e.jsxs(t.AccordionItem,{value:"item-1",children:[e.jsx(t.AccordionTrigger,{children:`${t.titleCase(s)} Chart`}),e.jsxs(t.AccordionContent,{className:"space-y-4 font-mono text-xs",children:[e.jsx("div",{className:"rounded bg-muted px-2 py-1 text-xs",children:"SELECT x-axis, y-axis-1, y-axis-2,... FROM table"}),e.jsxs("ul",{className:"ml-6 list-disc text-xs [&>li]:mt-2",children:[e.jsx("li",{children:"x-axis - category"}),e.jsx("li",{children:"y-axis1 - number"}),e.jsx("li",{children:"y-axis2 - number"})]}),e.jsxs("div",{children:["See ",e.jsx("a",{target:"_blank",onClick:a=>a.stopPropagation(),className:"text-blue-700",href:"https://docs.semaphor.cloud/docs/charts/bar-line-area",children:"example"})," in the docs."]})]})]}),e.jsxs(t.AccordionItem,{value:"item-2",children:[e.jsx(t.AccordionTrigger,{children:"Settings"}),e.jsx(t.AccordionContent,{className:"space-y-4 px-2",children:e.jsx(as,{})})]}),e.jsxs(t.AccordionItem,{value:"item-3",children:[e.jsx(t.AccordionTrigger,{children:"Filters"}),e.jsxs(t.AccordionContent,{className:"space-y-4 px-2",children:[e.jsx(je,{}),e.jsx(Ne,{})]})]})]})})}function Ve(){const s=t.useEditorStore(d=>d.card.type),a=t.useEditorStore(d=>d.isDevMode),n=t.useEditorStore(d=>d.card.preferences),{setCardPreferences:r}=t.useEditorStore(d=>d.actions);function o(d){var h;const l={datalabels:{display:d!=="none",align:d,anchor:d,clamp:!0}},x={...n,chartOptions:{...n==null?void 0:n.chartOptions,plugins:{...(h=n==null?void 0:n.chartOptions)==null?void 0:h.plugins,...l}}};r(x)}function i(){var d,l,x;return e.jsxs("div",{className:"space-y-2",children:[e.jsx("label",{className:"font-medium",children:"Data Labels"}),e.jsxs(t.Select,{value:((x=(l=(d=n==null?void 0:n.chartOptions)==null?void 0:d.plugins)==null?void 0:l.datalabels)==null?void 0:x.anchor)||"none",onValueChange:o,defaultValue:"none",children:[e.jsx(t.SelectTrigger,{className:"h-8 w-full focus:ring-1 focus:ring-offset-0",children:e.jsx(t.SelectValue,{placeholder:"Select position"})}),e.jsx(t.SelectContent,{children:e.jsxs(t.SelectGroup,{children:[e.jsx(t.SelectLabel,{children:"Data Labels"}),e.jsx(t.SelectItem,{value:"none",children:"None"}),!["pyramid","funnel"].includes(s)&&e.jsx(t.SelectItem,{value:"start",children:"Start"}),e.jsx(t.SelectItem,{value:"center",children:"Center"}),!["pyramid","funnel"].includes(s)&&e.jsx(t.SelectItem,{value:"end",children:"End"})]})})]})]})}function c(){var d,l,x;return e.jsx("div",{children:e.jsxs(t.Select,{value:((x=(l=(d=n==null?void 0:n.chartOptions)==null?void 0:d.plugins)==null?void 0:l.datalabels)==null?void 0:x.anchor)||"none",onValueChange:o,defaultValue:"none",children:[e.jsx(t.SelectTrigger,{className:"h-8 w-full text-xs",children:e.jsx(t.SelectValue,{placeholder:"Select position"})}),e.jsx(t.SelectContent,{children:e.jsxs(t.SelectGroup,{children:[e.jsx(t.SelectItem,{className:"text-xs",value:"none",children:"None"}),!["pyramid","funnel"].includes(s)&&e.jsx(t.SelectItem,{className:"text-xs",value:"start",children:"Start"}),e.jsx(t.SelectItem,{className:"text-xs",value:"center",children:"Center"}),!["pyramid","funnel"].includes(s)&&e.jsx(t.SelectItem,{className:"text-xs",value:"end",children:"End"})]})})]})})}return e.jsx(e.Fragment,{children:a?i():c()})}function ma({cardType:s}){function a(n){return e.jsxs(e.Fragment,{children:[e.jsx("div",{className:"rounded bg-muted px-2 py-1 text-xs",children:n==="bubble"?"SELECT label, [group], x-axis, y-axis, radius FROM table":"SELECT label, [group], x-axis, y-axis FROM table"}),e.jsxs("ul",{className:"ml-6 list-disc text-xs [&>li]:mt-2",children:[e.jsx("li",{children:"label - category"}),e.jsx("li",{children:"group (optional) - category"}),e.jsx("li",{children:"x-axis - number"}),e.jsx("li",{children:"y-axis - number"}),n==="bubble"&&e.jsx("li",{children:"radius - number"})]}),e.jsxs("div",{children:["See ",e.jsx("a",{target:"_blank",onClick:i=>i.stopPropagation(),className:"text-blue-700",href:"https://docs.semaphor.cloud/docs/charts/bubble",children:"example"})," in the docs."]})]})}return e.jsx("div",{className:"space-y-6 px-6 py-2",children:e.jsxs(t.Accordion,{defaultValue:["item-2"],type:"multiple",children:[e.jsxs(t.AccordionItem,{value:"item-1",children:[e.jsx(t.AccordionTrigger,{children:`${t.titleCase(s)} Chart`}),e.jsx(t.AccordionContent,{className:"space-y-4 font-mono text-xs",children:a(s)})]}),e.jsxs(t.AccordionItem,{value:"item-2",children:[e.jsx(t.AccordionTrigger,{children:"Settings"}),e.jsx(t.AccordionContent,{className:"px-2",children:e.jsx(Ve,{})})]}),e.jsxs(t.AccordionItem,{value:"item-3",children:[e.jsx(t.AccordionTrigger,{children:"Filters"}),e.jsxs(t.AccordionContent,{className:"space-y-4 px-2",children:[e.jsx(je,{}),e.jsx(Ne,{})]})]})]})})}const ha={datasets:[{type:"line",label:"Sum_sales",data:[]},{type:"bar",label:"Sum_profit",data:[]}]},xa={datasets:[{fill:"origin",type:"line",label:"Sum_sales",data:[]}]};function pa(){const s=t.useEditorStore(a=>a.card.type);return e.jsxs("div",{className:"space-y-6 p-6",children:[e.jsx(t.Accordion,{className:" ",type:"single",collapsible:!0,children:fa(s)}),!["kpi"].includes(s)&&e.jsxs("div",{className:"space-y-4",children:[e.jsx(Ve,{}),e.jsx(je,{}),e.jsx(Ne,{})]})]})}function fa(s){if(["line","bar"].includes(s))return e.jsxs(e.Fragment,{children:[e.jsxs(t.AccordionItem,{value:"item-1",children:[e.jsx(t.AccordionTrigger,{className:"font-normal",children:e.jsx("p",{children:"Chart Query"})}),e.jsxs(t.AccordionContent,{className:" ",children:[e.jsx("div",{className:"rounded bg-muted px-2 py-1 font-mono text-xs font-semibold",children:"SELECT x-axis, y-axis-1, y-axis-2, y-axis-3,... FROM table"}),e.jsxs("ul",{className:"my-6 ml-6 list-disc text-xs font-normal [&>li]:mt-2",children:[e.jsx("li",{children:"X-axis - Category (ex. city)"}),e.jsx("li",{children:"Y-axis - Number (ex. population)"})]})]})]}),e.jsxs(t.AccordionItem,{value:"item-2",children:[e.jsx(t.AccordionTrigger,{className:"font-normal",children:"Mixed Chart"}),e.jsxs(t.AccordionContent,{className:"space-y-2 text-xs",children:[e.jsxs("p",{children:["Click ",e.jsx("b",{children:"Customize"})," and change the `type` property in the dataset."]}),e.jsx("pre",{children:JSON.stringify(ha,null,2)})]})]}),e.jsxs(t.AccordionItem,{value:"item-3",children:[e.jsx(t.AccordionTrigger,{className:"font-normal",children:"Area Chart"}),e.jsxs(t.AccordionContent,{className:"space-y-2 text-xs",children:[e.jsxs("p",{children:["Click ",e.jsx("b",{children:"Customize"})," and add `fill` property to the dataset. See",e.jsx("a",{className:"mx-1 text-blue-500 hover:underline",href:"https://www.chartjs.org/docs/latest/samples/area/line-boundaries.html",target:"_blank",children:"docs"}),"for more options."]}),e.jsx("pre",{children:JSON.stringify(xa,null,2)})]})]})]});if(s==="bubble")return e.jsx(e.Fragment,{children:e.jsxs(t.AccordionItem,{value:"item-1",children:[e.jsx(t.AccordionTrigger,{className:"font-normal",children:e.jsxs("p",{children:["How to create a ",e.jsx("span",{children:s})," chart query?"]})}),e.jsxs(t.AccordionContent,{className:" ",children:[e.jsx("div",{className:"rounded bg-muted px-2 py-1 font-mono text-xs font-semibold",children:"SELECT label, x-axis, y-axis, radius FROM table"}),e.jsxs("ul",{className:"my-6 ml-6 list-disc text-xs font-normal [&>li]:mt-2",children:[e.jsx("li",{children:"Label - Category (ex. city)"}),e.jsx("li",{children:"Bubble Group (opt) - Category (ex. state)"}),e.jsx("li",{children:"X-axis - Number (ex. avg. age)"}),e.jsx("li",{children:"Y-axis - Number (ex. avg. weight)"}),e.jsx("li",{children:"Radius - Number (ex. population)"})]})]})]})});if(s==="scatter")return e.jsx(e.Fragment,{children:e.jsxs(t.AccordionItem,{value:"item-1",children:[e.jsx(t.AccordionTrigger,{className:"font-normal",children:e.jsxs("p",{children:["How to create a ",e.jsx("span",{children:s})," chart query?"]})}),e.jsxs(t.AccordionContent,{className:" ",children:[e.jsx("div",{className:"rounded bg-muted px-2 py-1 font-mono text-xs font-semibold",children:"SELECT label, x-axis, y-axis FROM table"}),e.jsxs("ul",{className:"my-6 ml-6 list-disc text-xs font-normal [&>li]:mt-2",children:[e.jsx("li",{children:"Label - Category (ex. city)"}),e.jsx("li",{children:"Group (opt) - Category (ex. state)"}),e.jsx("li",{children:"X-axis - Number (ex. avg. age)"}),e.jsx("li",{children:"Y-axis - Number (ex. avg. weight)"})]})]})]})});if(["pie","doughnut","polarArea","funnel"].includes(s))return e.jsx(e.Fragment,{children:e.jsxs(t.AccordionItem,{value:"item-1",children:[e.jsx(t.AccordionTrigger,{className:"font-normal",children:e.jsxs("p",{children:[e.jsx("span",{children:s==="polarArea"?"Polar":s.charAt(0).toUpperCase()+s.slice(1)})," ","chart query"]})}),e.jsxs(t.AccordionContent,{className:" ",children:[e.jsx("div",{className:"rounded bg-muted px-2 py-1 font-mono text-xs font-semibold",children:"SELECT label, measure FROM table"}),e.jsxs("ul",{className:"my-6 ml-6 list-disc text-xs font-normal [&>li]:mt-2",children:[e.jsx("li",{children:"Label - Category (ex. city)"}),e.jsx("li",{children:"Measure - Number (ex. population)"})]})]})]})})}function ga(){return e.jsxs("div",{className:"space-y-6 px-6 py-2",children:[e.jsx(t.Accordion,{type:"single",collapsible:!0,children:e.jsxs(t.AccordionItem,{value:"item-1",children:[e.jsx(t.AccordionTrigger,{className:"",children:"KPI Query"}),e.jsxs(t.AccordionContent,{className:"font-mono",children:[e.jsx("div",{className:"rounded bg-muted px-2 py-1 font-mono text-xs",children:"SELECT current, previous FROM table"}),e.jsxs("ul",{className:"my-6 ml-6 list-disc text-xs [&>li]:mt-2",children:[e.jsx("li",{children:"current - number"}),e.jsx("li",{children:"previous - number"})]}),e.jsxs("div",{children:["See ",e.jsx("a",{target:"_blank",onClick:s=>s.stopPropagation(),className:"text-blue-700",href:"https://docs.semaphor.cloud/docs/charts/kpi",children:"example"})," in the docs."]})]})]})}),e.jsx("section",{className:"",children:e.jsx(t.FormatNumberSetting,{})}),e.jsx("div",{}),e.jsx("div",{})]})}function He({children:s,summary:a,open:n,className:r}){return e.jsxs("details",{open:n,className:t.cn("space-y-4 [&_summary>svg]:open:-rotate-180",r),children:[e.jsxs("summary",{className:"flex cursor-pointer list-none items-center justify-between gap-4",children:[e.jsx(t.Label,{children:a}),e.jsx(t.ChevronUp,{className:"h-4 w-4"})]}),e.jsx("div",{className:"transition-all ease-in-out",children:s})]})}const ja=[{label:"Mercator",value:"mercator"},{label:"Azimuthal Equidistant",value:"azimuthalEquidistant"},{label:"Gnomonic",value:"gnomonic"},{label:"Orthographic",value:"orthographic"},{label:"Stereographic",value:"stereographic"},{label:"Equal Earth",value:"equalEarth"},{label:"Albers",value:"albers"},{label:"Albers USA",value:"albersUsa"},{label:"Conic Conformal",value:"conicConformal"},{label:"Conic Equal Area",value:"conicEqualArea"},{label:"Conic Equidistant",value:"conicEquidistant"},{label:"Equirectangular",value:"equirectangular"},{label:"Transverse Mercator",value:"transverseMercator"},{label:"Natural Earth 1",value:"naturalEarth1"}],ya=["blues","brBG","buGn","buPu","cividis","cool","cubehelixDefault","gnBu","greens","greys","inferno","magma","orRd","oranges","pRGn","piYG","plasma","puBu","puBuGn","puOr","puRd","purples","rainbow","rdBu","rdGy","rdPu","rdYlBu","rdYlGn","reds","sinebow","spectral","turbo","viridis","warm","ylGn","ylGnBu","ylOrBr","ylOrRd"],ba=ya.map(s=>({label:s,value:s}));function va(){var l,x,h,u,j,y,N,f,E,p,g,O,I,k,v,C,S,D;const s=t.useEditorStore(w=>w.card),a=(x=(l=s==null?void 0:s.preferences)==null?void 0:l.mapVisualOptions)==null?void 0:x.topoJsonUrl,[n,r]=L.useState(((u=(h=s==null?void 0:s.preferences)==null?void 0:h.mapVisualOptions)==null?void 0:u.customTopoJsonUrl)||""),{setCardPreferences:o}=t.useEditorActions(),{data:i}=t.useTopoJson(s),c=Object.keys((i==null?void 0:i.objects)||{}).map(w=>({label:w,value:w}))||[],d=[{label:"US States 10m",value:"https://unpkg.com/us-atlas/states-10m.json"},{label:"Countries 50m",value:"https://unpkg.com/world-atlas/countries-50m.json"},{label:"Custom",value:"custom"}];return e.jsxs("div",{className:"p-6",children:[e.jsx(He,{summary:"Map Chart",children:e.jsx("p",{className:"rounded-md bg-muted p-2 font-mono text-xs",children:"SELECT country, value FROM table"})}),e.jsx(t.Separator,{className:"my-4"}),e.jsx(He,{open:!0,summary:"Settings",children:e.jsxs("div",{className:"space-y-3 px-2",children:[e.jsx(ae,{className:"h-9",options:d,onValueChange:w=>{console.log("value",w),o({...s.preferences,mapVisualOptions:{topoJsonUrl:w}})},value:a||"",label:"Select Map"}),a==="custom"&&e.jsx(t.Input,{onChange:w=>{r(w.target.value)},onBlur:()=>{var w;console.log("onBlur",n),o({...s.preferences,mapVisualOptions:{...(w=s.preferences)==null?void 0:w.mapVisualOptions,customTopoJsonUrl:n}})},value:n,className:`h-9 w-full ${t.removeRing}`,placeholder:"Custom URL"}),i&&e.jsxs(e.Fragment,{children:[e.jsxs("div",{className:"space-y-1",children:[e.jsx(t.Label,{children:"Map Object"}),e.jsx(ae,{className:"h-9",options:c,value:((y=(j=s.preferences)==null?void 0:j.mapVisualOptions)==null?void 0:y.objectKey)||"",label:"Map Object",onValueChange:w=>{var m;o({...s.preferences,mapVisualOptions:{...(m=s.preferences)==null?void 0:m.mapVisualOptions,objectKey:w}})}})]}),e.jsxs("div",{className:"space-y-1",children:[e.jsx(t.Label,{children:"Projection"}),e.jsx(ae,{className:"h-9",options:ja,value:((f=(N=s.preferences)==null?void 0:N.mapVisualOptions)==null?void 0:f.projection)||"",label:"Projection",onValueChange:w=>{var m;o({...s.preferences,mapVisualOptions:{...(m=s.preferences)==null?void 0:m.mapVisualOptions,projection:w}})}})]}),e.jsxs("div",{className:"space-y-1",children:[e.jsx(t.Label,{children:"Colors"}),e.jsx(ae,{className:"h-9",options:ba,value:((p=(E=s.preferences)==null?void 0:E.mapVisualOptions)==null?void 0:p.colorScale)||"",label:"Select Color Scale",onValueChange:w=>{var m;o({...s.preferences,mapVisualOptions:{...(m=s.preferences)==null?void 0:m.mapVisualOptions,colorScale:w}})}})]})]})]})}),e.jsx(t.Separator,{className:"my-4"}),e.jsx(He,{className:"",summary:"Scale Options",children:e.jsxs("div",{className:"flex items-center gap-3",children:[e.jsx(t.Input,{className:`h-9 w-full ${t.removeRing}`,type:"number",step:.1,value:((O=(g=s.preferences)==null?void 0:g.mapVisualOptions)==null?void 0:O.projectionScale)||1,onChange:w=>{var m;o({...s.preferences,mapVisualOptions:{...(m=s.preferences)==null?void 0:m.mapVisualOptions,projectionScale:Number(w.target.value)}})}}),e.jsx(t.Label,{children:"X"}),e.jsx(t.Input,{className:`h-9 w-full ${t.removeRing}`,type:"number",step:10,value:((v=(k=(I=s.preferences)==null?void 0:I.mapVisualOptions)==null?void 0:k.projectionOffset)==null?void 0:v[0])||0,onChange:w=>{var m,B,M,T;o({...s.preferences,mapVisualOptions:{...(m=s.preferences)==null?void 0:m.mapVisualOptions,projectionOffset:[Number(w.target.value),((T=(M=(B=s.preferences)==null?void 0:B.mapVisualOptions)==null?void 0:M.projectionOffset)==null?void 0:T[1])||0]}})}}),e.jsx(t.Label,{children:"Y"}),e.jsx(t.Input,{className:`h-9 w-full ${t.removeRing}`,type:"number",step:10,value:((D=(S=(C=s.preferences)==null?void 0:C.mapVisualOptions)==null?void 0:S.projectionOffset)==null?void 0:D[1])||0,onChange:w=>{var m,B,M,T;o({...s.preferences,mapVisualOptions:{...(m=s.preferences)==null?void 0:m.mapVisualOptions,projectionOffset:[((T=(M=(B=s.preferences)==null?void 0:B.mapVisualOptions)==null?void 0:M.projectionOffset)==null?void 0:T[0])||0,Number(w.target.value)]}})}})]})}),e.jsx(t.Separator,{className:"my-4"}),e.jsx(je,{})]})}function Na(){var r;const s=t.useEditorStore(o=>o.card.preferences),{setCardPreferences:a}=t.useEditorStore(o=>o.actions);function n(o){a({...s,textVisualOptions:{...s==null?void 0:s.textVisualOptions,isDynamicText:o==="dynamic"}})}return e.jsxs(t.RadioGroup,{value:(r=s==null?void 0:s.textVisualOptions)!=null&&r.isDynamicText?"dynamic":"static",onValueChange:n,className:"flex gap-3",defaultValue:"x",children:[e.jsxs("div",{className:"flex items-center space-x-2",children:[e.jsx(t.RadioGroupItem,{value:"static",id:"r1"}),e.jsx("label",{className:"text-sm",htmlFor:"r1",children:"Static"})]}),e.jsxs("div",{className:"flex items-center space-x-2",children:[e.jsx(t.RadioGroupItem,{value:"dynamic",id:"r2"}),e.jsx("label",{className:"text-sm",htmlFor:"r2",children:"Dynamic"})]})]})}function Ie({cardType:s,docContent:a,suffix:n="Chart"}){let r="pie-donut-polar";return s==="funnel"&&(r="funnel"),e.jsx("div",{className:"space-y-6 px-6 py-2",children:e.jsxs(t.Accordion,{defaultValue:["item-2"],type:"multiple",children:[e.jsxs(t.AccordionItem,{value:"item-1",children:[e.jsx(t.AccordionTrigger,{children:`${t.titleCase(s)} ${n}`}),e.jsx(t.AccordionContent,{children:a||e.jsxs("div",{className:"space-y-4 font-mono text-xs",children:[e.jsx("div",{className:"rounded bg-muted px-2 py-1 text-xs",children:"SELECT label, measure FROM table"}),e.jsxs("ul",{className:"ml-6 list-disc text-xs [&>li]:mt-2",children:[e.jsx("li",{children:"label - category"}),e.jsx("li",{children:"measure - number"})]}),e.jsxs("div",{children:["See ",e.jsx("a",{target:"_blank",onClick:o=>o.stopPropagation(),className:"text-blue-700",href:`https://docs.semaphor.cloud/docs/charts/${r}`,children:"example"})," in the docs."]})]})})]}),e.jsxs(t.AccordionItem,{value:"item-2",children:[e.jsx(t.AccordionTrigger,{children:"Settings"}),e.jsxs(t.AccordionContent,{className:"space-y-4 px-2",children:[s!=="text"&&e.jsx(Ve,{}),s==="text"&&e.jsx(Na,{})]})]}),!["range","text"].includes(s)&&e.jsxs(t.AccordionItem,{value:"item-3",children:[e.jsx(t.AccordionTrigger,{children:"Filters"}),e.jsxs(t.AccordionContent,{className:"space-y-4 px-2",children:[e.jsx(je,{}),e.jsx(Ne,{})]})]})]})})}function Ca(){const s=t.useEditorStore(r=>{var o,i;return(i=(o=r==null?void 0:r.card)==null?void 0:o.preferences)==null?void 0:i.sortChart}),{setSortChart:a}=t.useEditorActions();function n(){return e.jsxs("div",{className:"space-y-2",children:[e.jsx(t.Label,{children:"Sort"}),e.jsx(ae,{className:"h-8",label:"Sort Chart",options:[{label:"None",value:"none"},{label:"ASC",value:"asc"},{label:"DESC",value:"desc"}],value:s||"none",onValueChange:r=>{a(r)}})]})}return e.jsx("div",{className:"space-y-6 px-6 py-2",children:e.jsxs(t.Accordion,{defaultValue:["item-2"],type:"multiple",children:[e.jsxs(t.AccordionItem,{value:"item-1",children:[e.jsx(t.AccordionTrigger,{children:"Stacked Chart"}),e.jsxs(t.AccordionContent,{className:"space-y-4 font-mono text-xs",children:[e.jsx("div",{className:"rounded bg-muted px-2 py-1 text-xs",children:"SELECT x-axis, stack-by, y-axis FROM table"}),e.jsxs("ul",{className:"ml-6 list-disc text-xs [&>li]:mt-2",children:[e.jsx("li",{children:"x-axis - category"}),e.jsx("li",{children:"stack by - category"}),e.jsx("li",{children:"y-axis - number"})]}),e.jsxs("div",{children:["See ",e.jsx("a",{target:"_blank",onClick:r=>r.stopPropagation(),className:"text-blue-700",href:"https://docs.semaphor.cloud/docs/charts/stacked",children:"example"})," in the docs."]})]})]}),e.jsxs(t.AccordionItem,{value:"item-2",children:[e.jsx(t.AccordionTrigger,{children:"Settings"}),e.jsxs(t.AccordionContent,{className:"space-y-4 px-2",children:[n(),e.jsx(as,{})]})]}),e.jsxs(t.AccordionItem,{value:"item-3",children:[e.jsx(t.AccordionTrigger,{children:"Filters"}),e.jsxs(t.AccordionContent,{className:"space-y-4 px-2",children:[e.jsx(je,{}),e.jsx(Ne,{})]})]})]})})}function Sa({cardType:s="table"}){console.log("cardType",s);const a=t.useEditorStore(o=>{var i;return(i=o.card)==null?void 0:i.preferences}),n=t.useEditorStore(o=>o.actions.setCardPreferences),r=o=>{n({...a,allowDownload:o})};return e.jsxs("div",{className:"space-y-6 px-6 py-2",children:[e.jsx(t.Accordion,{defaultValue:["item-3"],type:"multiple",children:e.jsxs(t.AccordionItem,{value:"item-3",children:[e.jsx(t.AccordionTrigger,{children:"Filters"}),e.jsxs(t.AccordionContent,{className:"space-y-4 px-2",children:[e.jsx(je,{}),e.jsx(Ne,{})]})]})}),e.jsxs("div",{className:"flex items-center space-x-2",children:[e.jsx(t.Checkbox,{onCheckedChange:r,id:"allow-download"}),e.jsx("label",{htmlFor:"allow-download",className:"text-sm font-medium leading-none peer-disabled:cursor-not-allowed peer-disabled:opacity-70",children:"Allow Download"})]})]})}const wa=e.jsxs("div",{className:"space-y-4 font-mono text-xs",children:[e.jsx("div",{className:"rounded bg-muted px-2 py-1 text-xs",children:"SELECT dimension, cohort, metric FROM table"}),e.jsxs("div",{children:["See ",e.jsx("a",{target:"_blank",onClick:s=>s.stopPropagation(),className:"text-blue-700",href:"https://docs.semaphor.cloud/docs/charts/tornado",children:"example"})," in the docs."]})]}),ka=e.jsxs("div",{className:"space-y-4 font-mono text-xs",children:[e.jsx("div",{className:"rounded bg-muted px-2 py-1 text-xs",children:"SELECT y-axis, label, range-from, range-to, range-value FROM table"}),e.jsxs("div",{children:["See ",e.jsx("a",{target:"_blank",onClick:s=>s.stopPropagation(),className:"text-blue-700",href:"https://docs.semaphor.cloud/docs/charts/range",children:"example"})," in the docs."]})]}),Ea=e.jsxs("div",{className:"space-y-4 font-mono text-xs",children:[e.jsx("div",{className:"rounded bg-muted px-2 py-1 text-xs",children:"SELECT text FROM table limit 1"}),e.jsxs("div",{children:["See ",e.jsx("a",{target:"_blank",onClick:s=>s.stopPropagation(),className:"text-blue-700",href:"https://docs.semaphor.cloud/docs/charts/text",children:"example"})," in the docs."]})]});function Da(){const s=t.useEditorStore(n=>n.card.type);function a(n){switch(n){case"stackedBar":case"stackedLine":return e.jsx(Ca,{});case"tornado":case"pyramid":return e.jsx(Ie,{docContent:wa,cardType:n});case"kpi":return e.jsx(ga,{});case"line":case"bar":return e.jsx(ua,{cardType:n});case"range":return e.jsx(Ie,{docContent:ka,cardType:n});case"pie":case"doughnut":case"polarArea":case"radar":case"funnel":return e.jsx(Ie,{cardType:n});case"bubble":case"scatter":return e.jsx(ma,{cardType:n});case"table":return e.jsx(Sa,{cardType:n});case"text":return e.jsx(Ie,{docContent:Ea,cardType:n,suffix:"Visual"});case"map":return e.jsx(va,{});case"custom":return e.jsx(ia,{});default:return e.jsx(pa,{})}}return e.jsxs(t.ScrollArea,{className:"h-full w-full text-sm",children:[a(s),e.jsx(t.ScrollBar,{orientation:"horizontal"})]})}function ls({label:s,column:a,functions:n,onFunctionChange:r}){let o=n[0];"aggregate"in a?o=n.find(c=>c.value===a.aggregate)||n[0]:"granularity"in a&&(o=n.find(c=>c.value===a.granularity)||n[0]);function i(c){r(c)}return e.jsx(ae,{className:"flex h-8 w-8 justify-center overflow-clip rounded-none border-none bg-muted px-0 [&>svg]:hidden",icon:o.logo,options:n,value:o.value,onValueChange:c=>i(c),label:s,showPlaceholderLabel:!1})}const Ia=[{label:"Sum",value:"SUM",logo:e.jsx(zt,{className:"size-3.5"})},{label:"Count",value:"COUNT",logo:e.jsx(nt,{className:"size-3.5"})},{label:"Unique",value:"DISTINCT",logo:e.jsx(Qs,{className:"size-3.5"})},{label:"Average",value:"AVG",logo:e.jsx(Is,{className:"size-3.5"})},{label:"Min",value:"MIN",logo:e.jsx(t.ArrowDown,{className:"size-3.5"})},{label:"Max",value:"MAX",logo:e.jsx(t.ArrowUp,{className:"size-3.5"})}];function Ta({column:s}){const{updateMetricColumnOld:a}=t.useEditorActions();let n=Ia;t.isTextDataType(s.type)&&(n=n.filter(o=>["COUNT","DISTINCT"].includes(o.value))),t.isNumberDataType(s.type)&&(n=n.filter(o=>!["DISTINCT"].includes(o.value)));function r(o){const i={...s,aggregate:o,label:ke(s.name,o)};a(s.id,i)}return e.jsx(ls,{column:s,functions:n,onFunctionChange:o=>r(o),label:"Aggregation"})}const Ma=[{label:"Day (D)",value:"day",logo:e.jsx(t.Label,{className:"cursor-pointer text-xs",children:"D"})},{label:"Week (W)",value:"week",logo:e.jsx(t.Label,{className:"cursor-pointer text-xs",children:"W"})},{label:"Month (M)",value:"month",logo:e.jsx(t.Label,{className:"cursor-pointer text-xs",children:"M"})},{label:"Year (Y)",value:"year",logo:e.jsx(t.Label,{className:"cursor-pointer text-xs",children:"Y"})}];function Aa({column:s}){const{updateGroupByColumnOld:a}=t.useEditorActions();function n(r){const o={...s,granularity:r,label:ve(s.name,r)};a(s.id,o)}return e.jsx(ls,{column:s,functions:Ma,onFunctionChange:r=>n(r),label:"Granularity"})}function La({col:s,onChange:a,droppableId:n}){const{columns:r}=t.useDataColumns(),o=L.useMemo(()=>{let d=[];(n===xe||n===pe||n===fe)&&(d=r);const l=d==null?void 0:d.filter(x=>x.column_name!==s.name);return l==null?void 0:l.map(x=>({id:x.column_name,value:x.column_name}))},[r,n,s.name]),i=[{id:s.name,value:s.name}];function c(d){const l=r==null?void 0:r.find(x=>{var h;return x.column_name===((h=d[0])==null?void 0:h.id)});l&&a(l)}return o!=null&&o.length?e.jsx(t.ComboBox2,{multiple:!1,options:o,selectedOptions:i,onChange:c,selectAllChecked:!1,onSelectAllCheckedChange:()=>{},inputClassName:"border-none bg-muted pl-0 pr-8"}):e.jsx("input",{disabled:!0,type:"text",className:"overflow-hidden truncate text-ellipsis whitespace-nowrap bg-muted text-sm",value:s.name})}function cs({column:s}){const a=t.useEditorStore(l=>l.card.type),n=t.useEditorStore(l=>{var x,h;return(h=(x=l.card)==null?void 0:x.config)==null?void 0:h.metricColumns}),r=(n==null?void 0:n.map(l=>l.label))||[],o=r==null?void 0:r.find(l=>l===s.label||l===s.name),i=o?r.indexOf(o):-1;function c(){return e.jsx("div",{className:"pr-1",children:o&&e.jsx(os,{idx:i,col:o,children:e.jsx("div",{className:"w-[130px] text-xs text-muted-foreground",children:"Display Series As"})})})}function d(){return e.jsxs("div",{className:"space-y-1",children:[e.jsx(t.Label,{className:"text-xs font-medium text-muted-foreground",children:"Data Labels"}),e.jsx(Ve,{})]})}return e.jsxs("div",{className:"space-y-1",children:[["stackedBar","stackedLine","bar","line"].includes(a)&&c(),["pie","doughnut"].includes(a)&&d()]})}function Oa({column:s,type:a,onRemoveColumn:n,droppableId:r}){const[o,i]=L.useState(!1),{updateGroupByColumnOld:c,updateMetricColumnOld:d,updatePivotByColumnOld:l}=t.useEditorActions(),{attributes:x,listeners:h,setNodeRef:u,transform:j,transition:y,isDragging:N}=t.useSortable({id:s.id,data:{type:a}}),f=j?{opacity:N?.5:void 0,transform:t.CSS.Translate.toString(j),transition:y}:void 0,E=t.isTextDataType(s.type);function p(v){const C=t.isNumberDataType(v.data_type),S=t.isTextDataType(v.data_type),D=t.isDateDataType(v.data_type),w=C?"number":S?"string":D?"date":"string";if(r===xe){if(S){const m={id:s.id,name:v.column_name,type:w,role:"groupby"};c(s.id,m)}if(D){const m={id:s.id,name:v.column_name,type:w,role:"groupby",label:ve(v.column_name,"month"),granularity:"month"};c(s.id,m)}}if(r===fe){if(S){const m={id:s.id,name:v.column_name,type:w,role:"groupby"};l(s.id,m)}if(D){const m={id:s.id,name:v.column_name,type:w,label:ve(v.column_name,"month"),granularity:"month",role:"groupby"};l(s.id,m)}}if(r===pe){const m={id:s.id,name:v.column_name,type:w,role:"metric",label:ke(v.column_name,"SUM"),aggregate:C?"SUM":"COUNT"};d(s.id,m)}}function g(){if(r===pe)return e.jsx("div",{"data-setting-container":"",className:"mt-1.5 max-h-32 overflow-y-auto rounded-md border border-border p-3 text-sm",children:e.jsx(cs,{column:s})})}function O(){const v=t.isDateDataType(s.type);if(r===pe)return e.jsx(Ta,{column:s});if((r===xe||r===fe)&&v)return e.jsx(Aa,{column:s})}function I(){return e.jsx("div",{className:t.cn("grow",{"pl-3":(r===xe||r===fe)&&E}),children:e.jsx(La,{col:s,onChange:p,droppableId:r})})}function k(){return e.jsx("div",{"data-setting-actions":"",className:"flex h-full items-center gap-2",children:e.jsx("button",{className:"h-full pl-2",onClick:()=>i(!o),children:o?e.jsx(pn,{className:t.cn("size-3 cursor-pointer items-center justify-center rounded-r-sm text-muted-foreground")}):e.jsx(Bt,{className:t.cn("size-3 cursor-pointer items-center justify-center rounded-r-sm text-muted-foreground")})})})}return e.jsx("div",{...h,...x,ref:u,style:f,children:e.jsxs("div",{className:"group flex items-center justify-between gap-2",children:[e.jsxs("div",{className:"grow",children:[e.jsxs("div",{className:"flex h-8 grow items-center justify-between rounded-md bg-muted",children:[k(),O(),I()]}),o&&g()]}),e.jsx("div",{className:t.cn("opacity-0 transition-opacity duration-200 group-hover:opacity-100",{hidden:o}),children:e.jsx("button",{onClick:()=>n(s.id),children:e.jsx(t.X,{className:"size-3 cursor-pointer text-muted-foreground"})})})]})})}function Ue({id:s,label:a,columns:n,previewColumns:r,sortableType:o,onRemoveColumn:i}){var f,E;const{setNodeRef:c,isOver:d,over:l}=t.useDroppable({id:s}),x=t.useDndStore(p=>p.activeId),h=t.useEditorStore(p=>{var g;return(g=p.card)==null?void 0:g.type}),u=d||((E=(f=l==null?void 0:l.data)==null?void 0:f.current)==null?void 0:E.type)===o,j=x?r:n,y=o===Me?"Rows":o===Ae?"Pivot Columns":"Columns";function N(){if(!j||j.length===0)return e.jsx("div",{className:"mr-5 flex h-8 grow items-center space-x-2 rounded-md border border-dashed border-muted-foreground/80 bg-background px-2 py-1 text-sm text-muted-foreground",children:e.jsx("span",{className:"invisible text-muted-foreground/70 group-hover:visible",children:"Drag here"})})}return e.jsx(t.SortableContext,{items:n==null?void 0:n.map(p=>p.id),children:e.jsxs("div",{className:t.cn("group space-y-2 rounded-md p-4",u&&"border border-muted-foreground/20"),ref:c,children:[e.jsxs("div",{className:"flex items-center justify-between pr-5",children:[e.jsx(t.Label,{className:"text-sm",children:a}),h!=="table"&&e.jsx("span",{className:"text-xs text-muted-foreground/50",children:y})]}),N(),e.jsx("div",{className:"space-y-2",children:j==null?void 0:j.map(p=>p.id===Jt.id?e.jsx(Ba,{},p.id):e.jsx(Oa,{droppableId:s,type:o,column:p,onRemoveColumn:i},p.id))})]})})}function Ba(){return e.jsx("div",{className:"mr-5 flex h-8 grow items-center space-x-2 rounded-md border border-dashed border-muted-foreground bg-background px-2 py-1 text-sm",children:e.jsx("span",{className:"text-muted-foreground/70",children:"Drop here"})})}function ds({children:s,id:a,type:n}){const{attributes:r,listeners:o,setNodeRef:i,transform:c,transition:d,isDragging:l}=t.useSortable({id:a,data:{type:n}}),x=c?{opacity:l?.5:void 0,transform:t.CSS.Translate.toString(c),transition:d}:void 0;return e.jsx("div",{...o,...r,ref:i,style:x,children:s})}function Fa(){const s=t.useEditorStore(p=>{var g;return(g=p.card.queryConfig)==null?void 0:g.orderBy})||[],a=t.useEditorStore(p=>{var g;return(g=p.card.queryConfig)==null?void 0:g.groupByColumns})||[],n=t.useEditorStore(p=>{var g;return(g=p.card.queryConfig)==null?void 0:g.metricColumns})||[],{addOrderByColumn:r,removeOrderByColumn:o,updateOrderByColumn:i}=t.useEditorActions(),c=[...a,...n];if(c.length===0)return e.jsx(e.Fragment,{});const d=e.jsx(Ls,{className:"size-3.5 text-muted-foreground hover:text-foreground"}),l=e.jsx(Ds,{className:"size-3.5 text-muted-foreground hover:text-foreground"}),x=e.jsx(As,{className:"size-3.5 text-muted-foreground hover:text-foreground"}),h=e.jsx(Es,{className:"size-3.5 text-muted-foreground hover:text-foreground"}),u=c==null?void 0:c.filter(p=>!s.some(g=>g.columnId===p.id)).map(p=>({id:p.id,value:p.label||p.name}));function j(p,g){const O=y(p);return O?O.role==="metric"?g==="asc"?x:h:g==="asc"?d:l:null}function y(p){return c.find(g=>g.id===p)}function N(p){const g=s.find(O=>O.columnId===p);if(g){const O={...g,direction:g.direction==="asc"?"desc":"asc"};i(O)}}const f=p=>{r({columnId:p.id,direction:"asc"})};function E(p){const g=s.find(O=>O.columnId===p);g&&o(g)}return e.jsx(t.SortableContext,{items:s.map(p=>Ce(p.columnId)),children:e.jsxs("div",{className:"space-y-2 rounded-md p-4 text-sm",children:[e.jsx(t.Label,{className:"text-sm",children:"Sort By"}),u.length>0&&e.jsx("div",{className:"mr-5",children:e.jsx(t.ComboBox2,{multiple:!1,options:u,selectedOptions:[],onChange:p=>f(p[0]),selectAllChecked:!1,onSelectAllCheckedChange:()=>{},inputClassName:"h-8 bg-muted border-none"})}),s.map(p=>{var g,O;return e.jsx(ds,{id:Ce(p.columnId),type:ct,children:e.jsx("div",{className:"group flex h-8 items-center gap-2 rounded-sm p-0",children:e.jsxs("div",{className:"flex h-full grow items-center justify-between gap-2",children:[e.jsxs("div",{className:"flex h-full grow items-center justify-between gap-2 rounded-sm bg-muted px-2",children:[e.jsxs("div",{className:"flex items-center gap-3",children:[e.jsx(Bt,{className:"size-3 cursor-move text-muted-foreground hover:text-foreground"}),e.jsx(ft,{className:"w-[175px] text-sm",children:((g=y(p.columnId))==null?void 0:g.label)||((O=y(p.columnId))==null?void 0:O.name)})]}),e.jsx("button",{title:p.direction==="asc"?"Ascending":"Descending",onClick:()=>N(p.columnId),className:"rounded-sm p-0",children:j(p.columnId,p.direction)})]}),e.jsx("div",{children:e.jsx("button",{onClick:()=>E(p.columnId),className:"rounded-sm p-0",children:e.jsx(t.X,{className:"size-3 text-muted-foreground opacity-0 transition-opacity duration-200 hover:text-foreground group-hover:opacity-100"})})})]})},p.columnId)},Ce(p.columnId))})]})})}function za(){const s=t.useEditorStore(E=>{var p;return((p=E.card.queryConfig)==null?void 0:p.groupByColumns)||[]}),a=t.useEditorStore(E=>E.card.type),n=t.useDndStore(E=>E.previewGroupByColumns),r=t.useEditorStore(E=>{var p;return((p=E.card.queryConfig)==null?void 0:p.metricColumns)||[]}),o=t.useDndStore(E=>E.previewMetricColumns),i=t.useEditorStore(E=>{var p;return((p=E.card.queryConfig)==null?void 0:p.pivotColumns)||[]}),c=t.useDndStore(E=>E.previewPivotColumns),{removeColumnFromGroupBy:d,removeColumnFromMetricColumns:l,removeColumnFromPivotBy:x}=t.useEditorActions();function h(E){d(E)}function u(E){l(E)}function j(E){x(E)}let y="Group By",N="Metrics",f="Stack By";return a==="table"&&(y="Rows",N="Metrics",f="Columns"),e.jsxs("div",{className:"flex h-full w-full flex-col gap-3 py-4",children:[e.jsx(es,{iconClassName:"size-[19px]"}),e.jsxs(t.CustomScrollArea,{className:"flex min-h-0 grow basis-0 flex-col gap-4 overflow-y-auto",children:[e.jsxs("div",{className:"flex flex-col gap-4 p-4",children:[e.jsx(Ue,{onRemoveColumn:h,sortableType:Me,id:xe,label:y,columns:s,previewColumns:n}),e.jsx(Ue,{onRemoveColumn:j,sortableType:Ae,id:fe,label:f,columns:i,previewColumns:c}),e.jsx(Ue,{onRemoveColumn:u,sortableType:Ke,id:pe,label:N,columns:r,previewColumns:o}),e.jsx(Fa,{})]}),e.jsx(t.ScrollBar,{orientation:"horizontal"})]})]})}function gt({children:s,column:a,id:n,sortableType:r,className:o}){const[i,c]=L.useState(!1),{removeEditorFilter:d,clearEditorFilter:l}=t.useEditorActions(),x=t.useEditorStore(u=>{var j,y;return(y=(j=u.card.queryConfig)==null?void 0:j.filters)==null?void 0:y.some(N=>N.filterColumnName===a.name)});function h(u){d(u)}return e.jsx(ds,{id:n,type:r,children:e.jsxs("div",{className:t.cn("group space-y-1 rounded-md bg-muted px-3 py-2",{"border-border":i}),children:[e.jsxs("div",{className:"flex items-center justify-between",children:[e.jsxs("div",{className:"flex items-center gap-2",children:[e.jsx(t.Label,{className:"text-sm",children:a.name}),x&&e.jsx("button",{onClick:()=>l(a),children:e.jsx(t.FilterX,{className:"size-3 cursor-pointer items-center justify-center text-muted-foreground hover:text-foreground"})})]}),e.jsx("div",{"data-setting-actions":"",className:"invisible flex h-full items-center gap-2 group-hover:visible",children:e.jsx("button",{onClick:()=>h(a),children:e.jsx(t.X,{className:"size-3.5 cursor-pointer items-center justify-center rounded-r-sm text-muted-foreground"})})})]}),e.jsxs("div",{className:t.cn("group flex items-center rounded-t-md text-sm",!i&&"rounded-b-md",i&&"border border-border"),children:[e.jsx("div",{children:e.jsx(t.GripVertical,{className:"mr-2 size-3.5 cursor-move items-center justify-center p-0 text-muted-foreground/60 hover:text-foreground"})}),e.jsx("div",{className:t.cn("grow cursor-pointer overflow-hidden truncate text-ellipsis whitespace-nowrap",o),children:s})]})]})})}function Pa({column:s,sortableType:a}){const n=t.useDashboardStore(O=>O.themeStyle),r=t.useEditorStore(O=>{var I,k;return(k=(I=O.card)==null?void 0:I.queryConfig)==null?void 0:k.filters}),o=t.useEditorStore(O=>{var I,k;return(k=(I=O.card.queryConfig)==null?void 0:I.filterColumns)==null?void 0:k.find(v=>v.name===s.name)}),{selectedConnectionId:i,selectedDatabaseName:c,selectedTableName:d}=t.useEditorAside(),l=L.useMemo(()=>{var O;return(O=r==null?void 0:r.find(I=>I.filterColumnName===s.name))==null?void 0:O.filterValue},[r,s.name]),x=L.useMemo(()=>Array.isArray(l)?l.map(O=>({id:O,value:O})):[],[l]),{updateEditorFilterValue:h}=t.useEditorActions(),u={column:s.name,sql:s.sql,id:s.name,connectionId:i,dataType:s.type},{data:j,isLoading:y,isFetching:N,isError:f}=t.useFilterQuery(u),E=L.useMemo(()=>{var I;return u.column?(I=j==null?void 0:j.records)==null?void 0:I.map(k=>{let v=u.column.split(".").slice(-1)[0].replace(/"/g,"");return k[v]===void 0&&(v=v.toLowerCase()),{id:k[v],value:k[v]}}):[]},[j,u.column]);function p(O){const I=O.map(k=>k.id);h(s.name,I)}function g(){return y||N?e.jsx(t.Skeleton,{style:{borderRadius:n==null?void 0:n.controlInputRadius},className:"h-8 min-w-60 bg-foreground/10"}):f?e.jsx("div",{className:"flex h-8 min-w-60 items-center bg-muted px-2 text-sm",children:"Error"}):e.jsx(t.ComboBox2,{renderFilterModeButton:()=>e.jsx(Va,{columnName:s.name}),showNegativeIndicator:(o==null?void 0:o.mode)==="exclude",options:E,onChange:p,selectedOptions:x,selectAllChecked:!1,onSelectAllCheckedChange:()=>{}})}return e.jsx(gt,{className:"w-60",id:s.id,sortableType:a,column:s,children:g()})}function Va({columnName:s}){const{setEditorFilterMode:a}=t.useEditorActions(),n=t.useEditorStore(o=>{var i,c;return(c=(i=o.card.queryConfig)==null?void 0:i.filterColumns)==null?void 0:c.find(d=>d.name===s)});function r(){(n==null?void 0:n.mode)==="exclude"?a(s,"include"):a(s,"exclude")}return e.jsx(t.Button,{onClick:r,variant:"secondary",size:"sm",className:t.cn("h-5 text-xs hover:underline",{}),children:t.titleCase((n==null?void 0:n.mode)==="exclude"?"exclude":"include")})}function Ra({column:s,sortableType:a}){const[n,r]=L.useState(!1),{selectedConnectionId:o,selectedDatabaseName:i,selectedTableName:c}=t.useEditorAside(),d={column:s.name,sql:s.sql,id:s.name,connectionId:o,title:"",dataType:s.type},{isLoading:l,isFetching:x,isError:h,data:u}=t.useFilterQuery(d),j=u==null?void 0:u.records,{dateRange:y,setDateRange:N,initialDateRange:f}=t.useDateRangeFromRecords(j),{updateEditorFilterValue:E}=t.useEditorActions();function p(I){var v,C;const k={gte:(v=I==null?void 0:I.from)==null?void 0:v.toISOString(),lte:(C=I==null?void 0:I.to)==null?void 0:C.toISOString()};E(s.name,k)}function g(){E(s.name,null,!0),N(f)}function O(){return l||x?e.jsx("div",{children:e.jsx(t.Skeleton,{className:"h-8 w-72 bg-foreground/10"})}):h?e.jsx("div",{className:"h-8 w-72 bg-muted px-2",children:"Error"}):j?e.jsx(t.DateRangePopover,{title:d.title,open:n,inputClassName:"h-8",setOpen:r,dateRange:y,setDateRange:N,onApply:p,onClear:g}):e.jsx(t.Label,{className:"flex h-8 w-72 items-center bg-muted px-2",children:"No Data"})}return e.jsx(gt,{className:"w-72",id:s.id,sortableType:a,column:s,children:O()})}function qa({id:s,label:a,columns:n,previewColumns:r,sortableType:o}){var N,f;const{setNodeRef:i,isOver:c,over:d}=t.useDroppable({id:s}),l=t.useDndStore(E=>E.activeId),x={},h=c||((f=(N=d==null?void 0:d.data)==null?void 0:N.current)==null?void 0:f.type)===o;function u(){if(!y||y.length===0)return e.jsx("div",{className:"flex h-8 grow items-center space-x-2 rounded-md border border-dashed border-muted-foreground/80 bg-background px-2 py-1 text-sm text-muted-foreground",children:e.jsx("span",{className:"invisible text-muted-foreground/70 group-hover:visible",children:"Drag here"})})}function j(E){const p=t.isDateDataType(E.type);return E.id===Jt.id?e.jsx(gt,{id:E.id,sortableType:o,column:E,children:e.jsx(_a,{})},E.id):p?e.jsx(Ra,{droppableId:s,sortableType:o,column:E},E.id):e.jsx(Pa,{droppableId:s,sortableType:o,column:E},E.id)}const y=l?r:n;return e.jsx(t.SortableContext,{items:n==null?void 0:n.map(E=>E.id),children:e.jsxs("div",{className:t.cn("group space-y-2 rounded-md border-muted-foreground/50 p-4",h&&"border border-muted-foreground/20"),ref:i,style:x,children:[e.jsx(t.Label,{className:"text-sm",children:a}),u(),e.jsx("div",{className:"flex flex-wrap items-center gap-4",children:y==null?void 0:y.map(E=>j(E))})]})})}function _a(){return e.jsx("div",{className:"flex h-8 w-60 items-center space-x-2 rounded-md border border-dashed border-muted-foreground bg-background px-2 py-1 text-sm text-muted-foreground",children:"Drop here"})}function Ga(){const s=t.useEditorStore(o=>{var i;return((i=o.card.queryConfig)==null?void 0:i.filterColumns)||[]}),a=t.useDndStore(o=>o.previewFilterColumns),{removeColumnFromFilterColumns:n}=t.useEditorActions();function r(o){n(o)}return e.jsx("section",{className:"size-full px-4 pb-4",children:e.jsx(qa,{onRemoveColumn:r,sortableType:We,id:Qe,label:"Filters",columns:s,previewColumns:a})})}function $a(){const s=t.useEditorStore(i=>i.card),a=t.useEditorStore(i=>i.showAIDialog),{setShowAIDialog:n}=t.useEditorActions(),{data:r,errorMessage:o}=t.useDashboardCardQuery(s);return e.jsxs("section",{className:"flex justify-between gap-2 p-4",children:[e.jsxs("div",{className:"flex items-center gap-3",children:[e.jsx(t.EditorClearButton,{}),!a&&e.jsxs(t.Button,{onClick:()=>n(!0),variant:"secondary",size:"sm",children:[e.jsx(cn,{className:"mr-2 h-4 w-4"}),"Assistant"]}),e.jsx(Kt,{sql:r==null?void 0:r.sql,error:o})]}),e.jsxs("div",{className:"flex items-center gap-3",children:[e.jsx("div",{className:"rounded-full bg-green-300 px-3 py-1 text-xs font-medium text-black",children:"Preview"}),e.jsx(t.EditorCancelButton,{}),e.jsx(t.EditorAcceptButton,{variant:"default"})]})]})}function Ja(){const s=L.useRef(null),a=L.useRef(null),n=t.useEditorStore(d=>d.isShowingVisual),r=t.useEditorStore(d=>d.showAIDialog),o=t.useEditorStore(d=>d.isDevMode);L.useEffect(()=>{var d,l,x,h;r?((d=s.current)==null||d.resize(0),(l=a.current)==null||l.resize(0)):((x=s.current)==null||x.resize(25),(h=a.current)==null||h.resize(25))},[r]);function i(){return e.jsxs(e.Fragment,{children:[e.jsx(t.ResizablePanel,{role:"query-section",className:"flex",minSize:20,defaultSize:40,children:e.jsx($n,{})}),e.jsx(t.ResizableHandle,{withHandle:!0}),e.jsx(t.ResizablePanel,{className:"pb-1",role:"visual-section",minSize:0,defaultSize:60,children:n&&!r?e.jsxs(t.ResizablePanelGroup,{direction:"horizontal",children:[e.jsx(e.Fragment,{children:e.jsx(t.ResizablePanel,{ref:s,className:"flex",defaultSize:25,maxSize:30,children:e.jsx(Da,{})})}),!r&&e.jsx(t.ResizableHandle,{}),e.jsx(t.ResizablePanel,{minSize:40,defaultSize:75,maxSize:100,children:e.jsx(De,{})})]}):e.jsx(De,{})})]})}function c(){return e.jsx(e.Fragment,{children:e.jsx("div",{className:"grow","data-biz-mode-container":"",children:n?e.jsxs(t.ResizablePanelGroup,{direction:"horizontal",children:[e.jsx(e.Fragment,{children:e.jsx(t.ResizablePanel,{ref:a,defaultSize:25,maxSize:30,children:e.jsx(za,{})})}),e.jsx(t.ResizableHandle,{}),e.jsx(t.ResizablePanel,{defaultSize:75,maxSize:100,children:e.jsxs(t.ResizablePanelGroup,{direction:"vertical",children:[e.jsxs(t.ResizablePanel,{className:"flex min-h-fit flex-col",minSize:10,defaultSize:20,children:[e.jsx($a,{}),e.jsx(Ga,{})]}),e.jsx(t.ResizableHandle,{}),e.jsx(t.ResizablePanel,{minSize:60,defaultSize:80,children:e.jsx(De,{})})]})})]}):e.jsx(De,{})})})}return e.jsx(t.ResizablePanelGroup,{direction:"vertical",className:"min-h-[250px] min-w-full max-w-lg",children:o?i():c()})}function Ha(s){const a=t.useAIInteractionStore(_=>_.currentAIContext),[n,r]=L.useState(""),[o,i]=L.useState(null),{authToken:c}=t.useSemaphorContext(),d=t.useEditorStore(_=>{var Q;return(Q=_==null?void 0:_.card)==null?void 0:Q.sql}),l=t.useEditorStore(_=>_.isDevMode),x=t.useEditorStore(_=>{var Q;return(Q=_==null?void 0:_.card)==null?void 0:Q.python}),{setCardPython:h,setCardSql:u,setRunSql:j,switchCardType:y,setQueryConfig:N}=t.useEditorActions(),f=t.useEditorStore(_=>_.currentAssitantScope)||[],E=t.useEditorStore(_=>_.userInputForAI),p=t.useEditorStore(_=>_.triggerAIRun),g=t.useEditorStore(_=>_.card),O=t.useEditorStore(_=>_.selectedDatabaseName),I=t.useEditorStore(_=>_.selectedTableName),k=t.useEditorStore(_=>_.selectedConnectionId),v=t.useEditorStore(_=>_.selectedSchemaName),C=t.useDashboardStore(_=>_.dashboard.aiScopeTables),{errorMessage:S,refetch:D,data:w}=t.useDashboardCardQuery(g),{setTriggerAIRun:m,setCurrentAssitantScope:B,setCardConfig:M}=t.useEditorActions(),{selectedDatamodelName:T,connectionType:b,selectedDatamodelId:A}=t.useEditorAside(),{messages:F,setMessages:P,reload:R,error:z,append:Y,input:V,setInput:q,status:H,handleInputChange:K,handleSubmit:G,stop:$}=t.useChat({api:"https://semaphor.cloud/api/v1/assistant",headers:{Authorization:`Bearer ${c==null?void 0:c.accessToken}`},body:{random:Math.random(),assistantId:"editor-assistant",isDevMode:l,aiContext:a},maxSteps:10,onError:_=>{console.log("on error",_)},onToolCall:J,onFinish(_,Q){X(Q.usage),r(""),Q.finishReason==="stop"&&r("")}});L.useEffect(()=>{p&&E&&(Y({role:"user",content:E}),m(!1))},[p,E,Y,m]);async function J({toolCall:_}){var Q,oe,de,me;if(["createChartFromSql","createForecast"].includes(_.toolName)){const W=_.args.sql,Z=_.args.python,ee=_.args.chartType;return y(ee),u(W),h(Z),j(!0),{status:"success",message:"Let the user know that chart is created"}}else if(_.toolName==="getTableColumns")r("Getting table columns...");else{if(_.toolName==="getUserSql")return d?{status:"success",sql:d,python:x||""}:{status:"error",message:"No SQL found"};if(_.toolName==="getCurrentTableScope")return r("Getting table scope..."),ne(),{status:"success",tables:f};if(_.toolName==="generateQueryConfig"){r("Generating query config...");const W=_.args.chartType,Z=_.args.queryConfig;_.args.cardConfig,y(W),M(Z),u(void 0),h(void 0);const ee=await D();return(Q=ee==null?void 0:ee.data)!=null&&Q.error?{status:"error",queryConfig:Z,message:(oe=ee==null?void 0:ee.data)==null?void 0:oe.error.message}:(de=ee==null?void 0:ee.data)!=null&&de.records?{status:"success",queryConfig:Z,message:"The data has been visualized"}:{status:"success",queryConfig:Z,message:"The data has been visualized",records:(me=ee==null?void 0:ee.data)==null?void 0:me.records}}else r("Analyzing...")}}function X(_){i(Q=>Q?{promptTokens:Q.promptTokens+_.promptTokens,completionTokens:Q.completionTokens+_.completionTokens,totalTokens:Q.totalTokens+_.totalTokens}:_)}function se(_){const Q=t.removeFromScopeArray(f,_);re(Q)}function re(_){const Q=t.sanitizeAIScope(_);B(Q),P(oe=>[...oe,{id:crypto.randomUUID(),role:"system",content:`Current scope of tables. Always use the table reference format when generating SQL | ${JSON.stringify(Q)}`}])}function le(){const _={databaseName:O||"",schemaName:v||"",tableName:I||"",datamodelId:A||"",datamodelName:t.resolveDatamodelName(T),connectionId:k||"",connectionType:b||""},Q=t.dedup([...f,_]);re(Q)}function ne(){const _={databaseName:O||"",schemaName:v||"",tableName:I||"",datamodelName:t.resolveDatamodelName(T),connectionId:k||"",connectionType:b||"",datamodelId:A||""};if(!t.isInAiScopeArray([...C||[],...f],_)||f.length===0){const oe=t.dedup([...C||[],...f,_]).filter(de=>de.connectionId===_.connectionId);re(oe)}}const te=!["ready","error"].includes(H),ce=t.getErrorMessage(z);return{messages:F,setMessages:P,reload:R,append:Y,input:V,setInput:q,isLoading:te,handleSetAIScope:ne,handleAddCurrentTableToScope:le,removeFromCurrentSelections:se,currentAssitantScope:f,setCurrentAssitantScope:B,handleInputChange:K,handleSubmit:G,stop:$,chatStatus:H,toolStatus:n,llmUsage:o,onFinish:s,errorMessage:ce}}const Ua=[{title:"Help me write a query for",subtitle:"orders by month"},{title:"Create a bar chart for",subtitle:"sales by category"}];function Tt(){const s=L.useRef(null),a=L.useRef(null),[n,r]=L.useState(!1),[o,i]=L.useState(t.isDevEnv),[c,d]=L.useState(!1),[l,x]=L.useState(!1),h=t.useCurrentAIContext(),{setCurrentAIContext:u}=t.useAIActions(),j=t.useDashboardStore($=>$.dashboard.aiContext),y=t.useEditorStore($=>$.card.dataSource),N=t.useEditorStore($=>$.actions.setCardSql),f=t.useEditorStore($=>$.actions.setRunSql),E=t.useEditorStore($=>$.showAIDialog),p=t.useDashboardStore($=>$.handleOpenAssistantProfile),{setShowAIDialog:g,setCardPython:O}=t.useEditorActions(),{setDataSource:I}=t.useEditorActions(),{assistantProfile:k}=t.useAssistantProfile(),{messages:v,setMessages:C,reload:S,append:D,input:w,setInput:m,isLoading:B,handleInputChange:M,handleSubmit:T,stop:b,chatStatus:A,llmUsage:F,errorMessage:P}=Ha();t.useAssistantScroll({scrollContainerRef:s,inputRef:a,messages:v}),L.useEffect(()=>{var $;E&&(($=a.current)==null||$.focus(),u({selectedEntities:(y==null?void 0:y.selectedEntities)||[]}))},[E,y,u]);function R($,J){J==="sql"?(N($),f(!0)):J==="python"&&(O($),f(!0))}function z(){var $;($=j==null?void 0:j.selectedEntities)==null||$[0],x(!0)}function Y(){h.selectedEntities.length===0&&u({selectedEntities:(j==null?void 0:j.selectedEntities)||[]})}function V($){Y();const J={role:"user",content:$.title+" "+$.subtitle};D(J)}function q($){Y(),D({role:"user",content:$})}function H(){return e.jsxs(t.DropdownMenu,{children:[e.jsx(t.DropdownMenuTrigger,{asChild:!0,children:e.jsx(t.Button,{className:"h-7 p-2",size:"sm",variant:"ghost",children:e.jsx(t.EllipsisVertical,{className:"size-3.5"})})}),e.jsxs(t.DropdownMenuContent,{align:"end",children:[e.jsx(t.DropdownMenuLabel,{children:"Options"}),e.jsx(t.DropdownMenuSeparator,{}),e.jsx(t.DropdownMenuCheckboxItem,{checked:n,onCheckedChange:r,children:"Token Usage"}),e.jsx(t.DropdownMenuCheckboxItem,{checked:o,onCheckedChange:i,children:"Tool Invocations"}),e.jsx(t.DropdownMenuCheckboxItem,{checked:c,onCheckedChange:d,children:"System Message"})]})]})}function K(){return e.jsx("div",{"data-role":"header",children:e.jsx("div",{className:"text-lg font-semibold",children:"Assistant"})})}const G=(w==null?void 0:w.length)===0&&(v==null?void 0:v.filter($=>$.role==="user").length)===0;return e.jsxs("div",{"data-role":"editor-assistant",className:"flex h-full w-full flex-col justify-between px-6 py-4",children:[e.jsxs("div",{"data-role":"header-section",className:"flex items-start justify-between gap-2",children:[K(),p&&e.jsx(t.Button,{variant:"outline",size:"sm",className:"h-7 p-2",onClick:p,children:(k==null?void 0:k.name)||"Default Profile"}),e.jsxs("div",{"data-role":"header-actions",className:"flex items-center gap-2",children:[H(),e.jsx(t.IconButton,{tooltip:"Add Context",className:"h-7 p-2",onClick:z,children:e.jsx(t.Settings,{className:"size-4"})}),e.jsx(t.IconButton,{className:"h-7 p-2",tooltip:"New Chat",onClick:()=>{C([]),S()},children:e.jsx(t.SquarePen,{className:"size-4"})}),e.jsx(t.Button,{variant:"ghost",className:"h-8",size:"sm",onClick:()=>{g(!1)},children:e.jsx(t.PanelRight,{className:"size-4"})})]})]}),e.jsx(t.CustomScrollArea,{ref:s,className:"mt-2 flex w-full grow basis-0",children:e.jsxs("div",{className:"space-y-4 py-2 pr-3","data-role":"messages",children:[e.jsx(t.PrintMessages,{messages:v,showTools:o,handleRun:R,showSystemMessage:c}),e.jsx(t.ChatStatus,{messages:v,chatStatus:A,errorMessage:P})]})}),e.jsxs("div",{className:"mb-3",children:[G&&!k&&e.jsx(t.Placeholders,{onClick:V,placeholders:Ua}),e.jsx("div",{children:G&&k&&e.jsx(t.SeedQuestions,{seedQuestions:k.seedQuestions||[],handleSeedQuestionClick:q})})]}),e.jsx(t.ChatInputWithContext,{ref:a,setInput:m,stop:b,input:w,handleInputChange:M,handleSubmit:$=>{Y(),T($)},isLoading:B,onFocus:()=>{}}),F&&n&&e.jsx("div",{className:"flex h-8 items-center justify-between",children:e.jsxs("div",{className:"text-xs text-muted-foreground",children:["Usage: ",F.promptTokens," prompt tokens,"," ",F.completionTokens," completion tokens,"," ",F.totalTokens," total tokens"]})}),e.jsx(t.DataSourceDialog,{incomingSelectedEntities:(y==null?void 0:y.selectedEntities)||[],open:l,onOpenChange:x,dataSource:y||t.EMPTY_DATA_SOURCE,fallbackDataSource:t.EMPTY_DATA_SOURCE,dialogMode:"aiContext"})]})}function Ya({field:s}){const{attributes:a,listeners:n,setNodeRef:r,transform:o,transition:i,isDragging:c}=t.useSortable({id:s.id}),[d,l]=L.useState(!1),x={transform:t.CSS.Transform.toString(o),transition:i},h=t.getDataType(s.dataType),j=(y=>{const N=(y||"").toLowerCase();switch(t.getDataType(N)){case"number":return nt;case"date":return t.Calendar;case"boolean":return Vt;case"json":return qs;case"geo":return on;default:return Rt}})(s.dataType);return e.jsxs("div",{ref:r,style:x,...a,...n,className:`group/container overflow-hidden rounded-lg transition-all ${c?"scale-95 opacity-50":"border border-transparent hover:border-blue-200 hover:bg-blue-50 dark:hover:border-blue-800 dark:hover:bg-blue-950"}`,children:[e.jsxs("div",{className:"flex min-w-0 items-center gap-1 p-2",children:[e.jsx("div",{className:"flex-shrink-0 hover:cursor-grab active:cursor-grabbing",children:e.jsx(t.GripVertical,{className:"invisible size-3.5 text-gray-400 group-hover/container:visible"})}),e.jsx(j,{className:t.cn("size-3.5 flex-shrink-0 text-gray-500",h==="string"?"text-blue-500":"",h==="number"?"text-green-500":"",h==="date"?"text-purple-500":"",h==="boolean"?"text-orange-500":"")}),e.jsx(t.TooltipProvider$1,{children:e.jsxs(t.Tooltip,{children:[e.jsx(t.TooltipTrigger,{asChild:!0,children:e.jsx("div",{className:"min-w-0 flex-1 overflow-hidden",children:e.jsx("span",{className:`block text-sm text-foreground/90 hover:text-foreground dark:text-muted-foreground ${d?"whitespace-normal break-words":"truncate"}`,children:s.name})})}),e.jsx(t.TooltipContent,{side:"bottom",align:"start",className:"max-w-fit",children:e.jsxs("div",{className:"overflow-x-auto",children:[e.jsx("p",{className:t.cn("font-medium",{"text-blue-500":h==="string","text-green-500":h==="number","text-purple-500":h==="date","text-orange-500":h==="boolean"}),children:s.label||s.name}),s.description&&e.jsx("div",{className:"mt-1 text-sm text-muted-foreground",children:s.description}),e.jsxs("div",{className:"mt-2 flex items-center gap-2 text-xs text-muted-foreground",children:[e.jsx(mn,{className:"size-3.5"}),e.jsx("p",{className:"",children:s.qualifiedEntityName?`${s.qualifiedEntityName}.${s.name}`:s.name})]}),e.jsxs("div",{className:"flex items-center gap-2.5",children:[e.jsx(j,{className:t.cn("size-3 flex-shrink-0 text-gray-500",h==="string"?"text-blue-500":"",h==="number"?"text-green-500":"",h==="date"?"text-purple-500":"",h==="boolean"?"text-orange-500":"")}),e.jsx("p",{className:t.cn("text-xs font-normal text-gray-500"),children:s.dataType})]})]})})]})}),e.jsx("button",{onClick:y=>{y.stopPropagation(),l(!d)},className:"invisible flex-shrink-0 text-gray-400 hover:text-gray-600 group-hover/container:visible",children:d?e.jsx(t.ChevronDown,{className:"h-4 w-4"}):e.jsx(t.ChevronRight,{className:"h-4 w-4"})})]}),d&&e.jsx("div",{className:"text-muted-foreground-700 px-2 pb-3 text-sm",children:e.jsx(t.Card,{className:"",children:e.jsxs(t.CardContent,{className:"space-y-2 p-3",children:[e.jsxs("div",{className:"flex items-center gap-2",children:[e.jsx(Pt,{className:"h-4 w-4 text-muted-foreground"}),e.jsx("span",{className:"break-all",children:s.label||s.name})]}),e.jsxs("div",{className:"flex items-center gap-2",children:[e.jsx(jn,{className:"h-4 w-4 text-muted-foreground"}),e.jsx("span",{className:"break-all",children:s.name})]}),e.jsx(t.Badge,{variant:"outline",className:"mt-2 text-xs",children:s.dataType})]})})})]})}function Ka({entityGroup:s,fields:a,isOpen:n,onToggle:r}){return e.jsxs(t.Collapsible,{open:n,onOpenChange:r,children:[e.jsxs(t.CollapsibleTrigger,{className:"flex w-full items-center gap-2 rounded-md px-3 py-2 hover:bg-muted",children:[e.jsx("span",{className:"flex-1 text-left text-sm font-medium",children:s.label||s.entityName}),e.jsxs("span",{className:"text-xs text-gray-500",children:["(",a.length,")"]}),n?e.jsx(t.ChevronDown,{className:"h-4 w-4"}):e.jsx(t.ChevronRight,{className:"h-4 w-4"})]}),e.jsx(t.CollapsibleContent,{className:"mt-1 space-y-1",children:e.jsx(t.SortableContext,{items:a.map(o=>o.id),strategy:t.verticalListSortingStrategy,children:a.map(o=>e.jsx(Ya,{field:o},o.id))})})]})}function Qa(){const[s,a]=L.useState(""),[n,r]=L.useState(new Set),[o,i]=L.useState("all");Wa();const c=t.useEditorStore(I=>I.card.dataSource),{columns:d=[],columnGroups:l=[],isLoading:x,error:h}=t.useColumns(),u=d.filter(I=>I.name.toLowerCase().includes(s.toLowerCase())||I.dataType.toLowerCase().includes(s.toLowerCase())||I.qualifiedEntityName&&I.qualifiedEntityName.toLowerCase().includes(s.toLowerCase())),j=I=>I.dataType==="number"||I.dataType==="integer"||I.dataType==="float"||I.dataType==="decimal"||I.dataType==="currency"?"metrics":"dimensions",N=(o==="all"?u:u.filter(I=>j(I)===o)).reduce((I,k)=>{const v=k.qualifiedEntityName||"Other Fields";return I[v]||(I[v]={label:t.toLabel(k.entityName),fields:[]}),I[v].fields.push(k),I},{});L.useEffect(()=>{const I=Object.keys(N);r(new Set(I))},[Object.keys(N).join(",")]);const f=I=>{const k=new Set(n);k.has(I)?k.delete(I):k.add(I),r(k)},E=u.filter(I=>j(I)==="dimensions").length,p=u.filter(I=>j(I)==="metrics").length,g=u.filter(I=>j(I)==="calculated").length,O=u.length>0;return x?e.jsxs("div",{className:"flex h-[calc(100vh-200px)] w-[290px] flex-col items-center justify-center",children:[e.jsx(t.LoaderCircle,{className:"h-8 w-8 animate-spin text-gray-400"}),e.jsx("span",{className:"mt-2 text-sm text-gray-500",children:"Loading fields..."})]}):h?e.jsxs("div",{className:"flex h-[calc(100vh-200px)] w-[290px] flex-col items-center justify-center",children:[e.jsx(t.Database,{className:"mb-4 h-12 w-12 text-red-300"}),e.jsx("p",{className:"mb-2 text-sm text-red-500",children:"Error loading fields"}),e.jsx("p",{className:"px-4 text-center text-xs text-red-400",children:h.message||"Failed to load column data"})]}):!c||!c.selectedEntities||c.selectedEntities.length===0?e.jsx(t.ScrollArea,{className:"h-[calc(100vh-200px)] w-[290px]",children:e.jsxs("div",{className:"flex flex-col items-center justify-center py-8 text-center",children:[e.jsx(t.Database,{className:"mb-4 h-12 w-12 text-gray-300"}),e.jsx("p",{className:"mb-2 text-sm text-gray-500",children:"No data source selected"}),e.jsx("p",{className:"px-4 text-xs text-gray-400",children:"Select a table, view, or dataset from the data source panel to see available fields"})]})}):e.jsxs("div",{className:"mt-2 flex h-[calc(100vh-200px)] w-full grow flex-col gap-2 px-6 pb-6",children:[e.jsxs("div",{className:"mt-1 flex-shrink-0 space-y-2",children:[d.length>0&&e.jsx("div",{className:"mb-4",children:e.jsx(t.Input$1,{type:"text",placeholder:"Search fields...",value:s,onChange:I=>a(I.target.value)})}),O&&e.jsx(t.Tabs,{defaultValue:"all",value:o,onValueChange:I=>i(I),className:"mb-4",children:e.jsxs(t.TabsList,{className:"grid h-9 w-full grid-cols-4",children:[e.jsxs(t.TabsTrigger,{value:"all",className:"text-xs",children:["All",e.jsx("span",{className:"ml-2 text-xs font-semibold",children:u.length})]}),e.jsxs(t.TabsTrigger,{value:"dimensions",className:"text-xs",children:[e.jsx(t.Layers,{className:"size-4 shrink-0"}),e.jsx("span",{className:"ml-2 text-xs font-semibold",children:E})]}),e.jsxs(t.TabsTrigger,{value:"metrics",className:"text-xs",children:[e.jsx(t.ChartColumn,{className:"size-4 shrink-0"}),e.jsx("span",{className:"ml-2 text-xs font-semibold",children:p})]}),e.jsxs(t.TabsTrigger,{value:"calculated",className:"text-xs",children:[e.jsx(Ps,{className:"size-4 shrink-0"}),e.jsx("span",{className:"ml-2 text-xs font-semibold",children:g})]})]})})]}),e.jsxs(t.CustomScrollArea,{className:"py-2",children:[e.jsxs("div",{className:"space-y-2",children:[Object.entries(N).map(([I,k])=>{const v=l.find(C=>C.entityName===I)||{entityName:I,label:k.label};return e.jsx(Ka,{entityGroup:v,fields:k.fields,isOpen:n.has(I),onToggle:()=>f(I)},I)}),Object.keys(N).length===0&&d.length===0&&e.jsxs("div",{className:"py-8 text-center text-sm text-gray-500",children:[e.jsx("p",{children:"No fields found for selected data source"}),e.jsx("p",{className:"mt-1 text-xs text-gray-400",children:"Try selecting different data sources"})]}),Object.keys(N).length===0&&d.length>0&&e.jsx("div",{className:"py-4 text-center text-sm text-gray-500",children:"No fields found for this category"})]}),e.jsx(t.ScrollBar,{orientation:"horizontal"}),e.jsx(t.ScrollBar,{orientation:"vertical"})]})]})}function Wa(){const[s,a]=L.useState(!1);return t.useDndMonitor({onDragStart(){a(!0)},onDragEnd(){a(!1)},onDragCancel(){a(!1)}}),s}function Xa(){return e.jsxs("div",{className:" h-full flex flex-col items-center",children:[" ",e.jsx(Qa,{})," "]})}function Za({initialJoinPlan:s,availableDataSources:a}){const[n,r]=L.useState(s),[o,i]=L.useState(new Set),c=()=>{const v=n.joins.length>0?Math.max(...n.joins.map(S=>S.sequence))+1:1,C={id:`join-${Date.now()}`,source:{type:"table",name:"",database:"",schema:""},target:{type:"table",name:"",database:"",schema:""},joinType:"INNER",sequence:v,joinKeyGroups:[{id:"group-"+Date.now()+"-"+Math.random().toString(36).substr(2,9),operator:"AND",keys:[]}]};r({...n,joins:[...n.joins,C]}),i(new Set([...o,C.id]))},d=v=>{r({...n,joins:n.joins.filter(C=>C.id!==v)}),i(new Set([...o].filter(C=>C!==v)))},l=(v,C)=>{var m,B;const S=n.joins.find(M=>M.id===v);if(!S)return;const D={...S,...C},w=n.joins.map(M=>M.id===v?D:M);if((m=D.source)!=null&&m.name&&((B=D.target)!=null&&B.name)&&D.joinKeyGroups[0].keys.length===0){const M=a.find(F=>{var P;return F.name===((P=D.source)==null?void 0:P.name)}),T=a.find(F=>{var P;return F.name===((P=D.target)==null?void 0:P.name)}),b={id:`key-${Date.now()}`,source:{id:`source-${Date.now()}`,name:"",dataType:"",label:"",entityId:(M==null?void 0:M.name)||"",entityName:(M==null?void 0:M.name)||"",entityType:(M==null?void 0:M.type)||"table"},target:{id:`target-${Date.now()}`,name:"",dataType:"",label:"",entityId:(T==null?void 0:T.name)||"",entityName:(T==null?void 0:T.name)||"",entityType:(T==null?void 0:T.type)||"table"},operator:"="},A=[...D.joinKeyGroups];A[0]={...A[0],keys:[b]},D.joinKeyGroups=A,w[w.findIndex(F=>F.id===v)]=D}r({...n,joins:w})};return{joinPlan:n,expandedJoins:o,setJoinPlan:r,addJoin:c,removeJoin:d,updateJoin:l,moveJoinUp:v=>{const C=n.joins.findIndex(S=>S.id===v);if(C>0){const S=[...n.joins],D={...S[C]},w={...S[C-1]};S[C]=w,S[C-1]=D,S.forEach((B,M)=>{B.sequence=M+1});const m={...n,joins:S};r(m)}},moveJoinDown:v=>{const C=n.joins.findIndex(S=>S.id===v);if(C<n.joins.length-1){const S=[...n.joins],D={...S[C]},w={...S[C+1]};S[C]=w,S[C+1]=D,S.forEach((B,M)=>{B.sequence=M+1});const m={...n,joins:S};r(m)}},toggleJoinExpansion:v=>{const C=new Set(o);C.has(v)?C.delete(v):C.add(v),i(C)},getAvailableSourceEntities:v=>{if(n.joins.length===0)return a;const C=n.joins.findIndex(D=>D.id===v);if(C===0)return a;const S=new Set;return n.baseEntity.name&&S.add(n.baseEntity.name),n.joins.slice(0,C).forEach(D=>{S.add(D.source.name),S.add(D.target.name)}),a.filter(D=>S.has(D.name))},getAvailableTargetEntities:v=>a.filter(C=>C.name!==v),addJoinKeyGroup:v=>{const C=n.joins.find(D=>D.id===v);if(!C)return;const S=[...C.joinKeyGroups,{id:"group-"+Date.now()+"-"+Math.random().toString(36).substr(2,9),operator:"AND",keys:[]}];l(v,{joinKeyGroups:S})},updateGroupOperator:(v,C,S)=>{const D=n.joins.find(m=>m.id===v);if(!D)return;const w=[...D.joinKeyGroups];w[C]={...w[C],operator:S},l(v,{joinKeyGroups:w})},removeJoinKeyGroup:(v,C)=>{const S=n.joins.find(w=>w.id===v);if(!S)return;const D=[...S.joinKeyGroups];D.splice(C,1),l(v,{joinKeyGroups:D})},addJoinKey:(v,C)=>{const S=n.joins.find(M=>M.id===v);if(!S)return;const D=a.find(M=>M.name===S.source.name),w=a.find(M=>M.name===S.target.name),m=[...S.joinKeyGroups],B={id:`key-${Date.now()}`,source:{id:`source-${Date.now()}`,name:"",dataType:"",label:"",entityId:(D==null?void 0:D.name)||"",entityName:(D==null?void 0:D.name)||"",entityType:(D==null?void 0:D.type)||"table"},target:{id:`target-${Date.now()}`,name:"",dataType:"",label:"",entityId:(w==null?void 0:w.name)||"",entityName:(w==null?void 0:w.name)||"",entityType:(w==null?void 0:w.type)||"table"},operator:"="};m[C]={...m[C],keys:[...m[C].keys,B]},l(v,{joinKeyGroups:m})},updateJoinKey:(v,C,S,D,w)=>{const m=n.joins.find(A=>A.id===v);if(!m)return;const B=a.find(A=>A.name===m.source.name),M=a.find(A=>A.name===m.target.name),T=[...m.joinKeyGroups],b=T[C].keys[S];D==="sourceColumnName"&&B?T[C].keys[S]={...b,source:{...b.source,name:w}}:D==="targetColumnName"&&M?T[C].keys[S]={...b,target:{...b.target,name:w}}:D==="operator"&&(T[C].keys[S]={...b,operator:w}),l(v,{joinKeyGroups:T})},removeJoinKey:(v,C,S)=>{const D=n.joins.find(m=>m.id===v);if(!D)return;const w=[...D.joinKeyGroups];w[C].keys.splice(S,1),l(v,{joinKeyGroups:w})},generateSQLPreview:()=>{const v=[...n.joins].sort((D,w)=>D.sequence-w.sequence),C=n.baseEntity;if(!C.name)return"SELECT * FROM table -- Please select a base entity";let S=`SELECT *
370
370
  FROM ${C.name}`;return v.forEach(D=>{const w=a.find(M=>M.name===D.target.name);if(!w)return;const m=D.joinKeyGroups.filter(M=>M.keys&&M.keys.length>0).map(M=>{const T=M.keys.filter(b=>{var A,F,P,R;return((A=b.source)==null?void 0:A.name)&&((F=b.target)==null?void 0:F.name)&&((P=b.source)==null?void 0:P.entityName)&&((R=b.target)==null?void 0:R.entityName)}).map(b=>`${b.source.entityName}.${b.source.name} ${b.operator} ${b.target.entityName}.${b.target.name}`);return T.length>1?`(${T.join(` ${M.operator} `)})`:T[0]}).filter(Boolean),B=m.length>1?m.join(" OR "):m[0]||"condition_here";S+=`
371
371
  ${D.joinType} JOIN ${w.name}
372
372
  ON ${B}`}),S},isValidConfiguration:()=>!(!n.baseEntity.name||n.joins.some(D=>!D.source.name||!D.target.name)||n.joins.some(D=>D.joinKeyGroups.some(w=>w.keys.length===0))||n.joins.some(D=>D.joinKeyGroups.some(w=>w.keys.some(m=>!m.source.name||!m.target.name||!m.operator))))}}function er({joinPlan:s,availableDataSources:a,onSave:n,onRemove:r,onCancel:o}){const{setCardConfig:i}=t.useEditorActions();t.useEditorStore(m=>m.card.config);const{columnGroups:c}=t.useColumns(),{joinPlan:d,expandedJoins:l,setJoinPlan:x,addJoin:h,removeJoin:u,updateJoin:j,moveJoinUp:y,moveJoinDown:N,toggleJoinExpansion:f,getAvailableSourceEntities:E,getAvailableTargetEntities:p,addJoinKeyGroup:g,updateGroupOperator:O,removeJoinKeyGroup:I,addJoinKey:k,updateJoinKey:v,removeJoinKey:C,generateSQLPreview:S,isValidConfiguration:D}=Za({initialJoinPlan:s,availableDataSources:a}),w=m=>{const B=c.find(M=>M.entityName===m);return(B==null?void 0:B.columns)||[]};return e.jsxs("div",{className:"space-y-6",children:[e.jsxs("div",{className:"space-y-2",children:[e.jsx(t.Label,{children:"Base Entity (FROM clause)"}),e.jsxs(t.Select,{value:d.baseEntity.name,onValueChange:m=>{const B=a.find(M=>M.name===m);x({...d,baseEntity:{connectionId:(B==null?void 0:B.connectionId)||"",connectionType:(B==null?void 0:B.connectionType)||"none",type:(B==null?void 0:B.type)||"table",name:m,database:B==null?void 0:B.database,schema:B==null?void 0:B.schema}})},children:[e.jsx(t.SelectTrigger,{children:e.jsx(t.SelectValue,{placeholder:"Select base entity..."})}),e.jsx(t.SelectContent,{children:a.map(m=>e.jsx(t.SelectItem,{className:"hover:bg-muted",value:m.name,children:e.jsxs("div",{className:"flex items-center gap-2",children:[e.jsx(t.Badge,{variant:"outline",className:"text-xs",children:m.type}),m.name,e.jsx(t.Badge,{variant:"outline",className:"text-xs text-green-600",children:"BASE"})]})},m.name))})]}),e.jsx("p",{className:"text-xs text-muted-foreground",children:"This entity will be used as the base table in the FROM clause of the SQL query."})]}),e.jsxs("div",{className:"rounded-md border p-3",children:[e.jsx("div",{className:"mb-2 text-xs font-medium text-muted-foreground",children:"Join SQL Preview"}),e.jsx("code",{className:"block whitespace-pre-wrap break-all text-xs",children:S()})]}),e.jsxs("div",{className:"space-y-4",children:[e.jsxs("div",{className:"flex items-center justify-between",children:[e.jsxs(t.Label,{children:["Joins Configuration (",d.joins.length,")"]}),e.jsx("div",{className:"flex items-center gap-2",children:e.jsxs(t.Button,{variant:"outline",size:"sm",onClick:h,children:[e.jsx(t.Plus,{className:"mr-1 h-4 w-4"}),"Add Join"]})})]}),d.joins.length===0?e.jsx("div",{className:"rounded-lg border border-dashed py-8 text-center text-muted-foreground",children:e.jsx("p",{children:"No joins configured. Add a join to connect multiple data sources."})}):e.jsx("div",{className:"max-h-[300px] space-y-4 overflow-y-auto",children:d.joins.map(m=>{const B=a.find(b=>b.name===m.source.name),M=a.find(b=>b.name===m.target.name),T=l.has(m.id);return e.jsxs(t.Card,{className:"border",children:[e.jsx(t.CardHeader,{className:"pb-3",children:e.jsxs("div",{className:"flex items-center justify-between",children:[e.jsxs("div",{className:"flex items-center gap-2",children:[e.jsx(t.Badge,{children:m.sequence}),e.jsxs(t.CardTitle,{className:"text-sm",children:["Join ",m.sequence,B&&M&&e.jsxs("span",{className:"ml-2 font-normal text-gray-600",children:["(",B.name," → ",M.name,")"]})]})]}),e.jsxs("div",{className:"flex items-center gap-2",children:[e.jsx(t.Button,{variant:"ghost",size:"sm",onClick:()=>y(m.id),disabled:m.sequence===1,children:e.jsx(t.ArrowUp,{className:"h-4 w-4"})}),e.jsx(t.Button,{variant:"ghost",size:"sm",onClick:()=>N(m.id),disabled:m.sequence===d.joins.length,children:e.jsx(t.ArrowDown,{className:"h-4 w-4"})}),e.jsx(t.Button,{variant:"ghost",size:"sm",onClick:()=>f(m.id),children:T?e.jsx(t.ChevronUp,{className:"h-4 w-4"}):e.jsx(t.ChevronDown,{className:"h-4 w-4"})}),e.jsx(t.Button,{variant:"ghost",size:"sm",onClick:()=>u(m.id),children:e.jsx(t.X,{className:"h-4 w-4"})})]})]})}),T&&e.jsxs(t.CardContent,{className:"space-y-4 pb-6",children:[e.jsxs("div",{className:"grid grid-cols-1 gap-4 md:grid-cols-3",children:[e.jsxs("div",{className:"space-y-2",children:[e.jsx(t.Label,{children:"Source"}),e.jsxs(t.Select,{value:m.source.name,onValueChange:b=>{const A=a.find(F=>F.name===b);j(m.id,{source:{connectionId:(A==null?void 0:A.connectionId)||"",connectionType:(A==null?void 0:A.connectionType)||"none",type:(A==null?void 0:A.type)||"table",name:b,database:A==null?void 0:A.database,schema:A==null?void 0:A.schema}})},children:[e.jsx(t.SelectTrigger,{children:e.jsx(t.SelectValue,{placeholder:"Select source..."})}),e.jsx(t.SelectContent,{children:E(m.id).map(b=>e.jsx(t.SelectItem,{className:"hover:bg-muted",value:b.name,children:e.jsxs("div",{className:"flex items-center gap-2",children:[e.jsx(t.Badge,{variant:"outline",className:"text-xs",children:b.type}),b.name]})},b.name))})]})]}),e.jsxs("div",{className:"space-y-2",children:[e.jsx(t.Label,{children:"Join Type"}),e.jsxs(t.Select,{value:m.joinType,onValueChange:b=>j(m.id,{joinType:b}),children:[e.jsx(t.SelectTrigger,{children:e.jsx(t.SelectValue,{})}),e.jsxs(t.SelectContent,{children:[e.jsx(t.SelectItem,{className:"hover:bg-muted",value:"INNER",children:"INNER JOIN"}),e.jsx(t.SelectItem,{className:"hover:bg-muted",value:"LEFT",children:"LEFT JOIN"}),e.jsx(t.SelectItem,{className:"hover:bg-muted",value:"RIGHT",children:"RIGHT JOIN"}),e.jsx(t.SelectItem,{className:"hover:bg-muted",value:"FULL",children:"FULL JOIN"})]})]})]}),e.jsxs("div",{className:"space-y-2",children:[e.jsx(t.Label,{children:"Target"}),e.jsxs(t.Select,{value:m.target.name,onValueChange:b=>{const A=a.find(F=>F.name===b);j(m.id,{target:{connectionId:(A==null?void 0:A.connectionId)||"",connectionType:(A==null?void 0:A.connectionType)||"none",type:(A==null?void 0:A.type)||"table",name:b,database:A==null?void 0:A.database,schema:A==null?void 0:A.schema}})},disabled:!m.source.name,children:[e.jsx(t.SelectTrigger,{children:e.jsx(t.SelectValue,{placeholder:"Select target..."})}),e.jsx(t.SelectContent,{children:m.source.name?p(m.source.name).map(b=>e.jsx(t.SelectItem,{className:"hover:bg-muted",value:b.name,children:e.jsxs("div",{className:"flex items-center gap-2",children:[e.jsx(t.Badge,{variant:"outline",className:"text-xs",children:b.type}),b.name,b.name===m.source.name&&e.jsx(t.Badge,{variant:"outline",className:"text-xs text-yellow-600",children:"(Self-join)"})]})},b.name)):[]})]})]})]}),m.source.name&&m.target.name&&B&&M&&e.jsxs("div",{className:"space-y-4",children:[e.jsxs("div",{className:"flex items-center justify-between",children:[e.jsx(t.Label,{children:"Join Conditions"}),e.jsxs(t.Button,{type:"button",variant:"outline",size:"sm",onClick:()=>g(m.id),children:[e.jsx(t.Plus,{className:"mr-1 h-3 w-3"})," Add Condition Group"]})]}),m.joinKeyGroups.length===0?e.jsx("div",{className:"rounded-md border p-3 text-center text-sm text-gray-500",children:"No join conditions defined. Add condition groups to specify how data sources should be joined."}):e.jsx("div",{className:"space-y-4",children:m.joinKeyGroups.map((b,A)=>e.jsxs("div",{className:"space-y-3 rounded-md border p-3",children:[e.jsxs("div",{className:"flex items-center justify-between",children:[e.jsxs("div",{className:"flex items-center gap-2",children:[e.jsxs(t.Label,{children:["Group ",A+1]}),A>0&&e.jsxs("div",{className:"flex items-center gap-2 rounded-md bg-gray-100 px-2 py-1",children:[e.jsx(t.Label,{className:"text-xs font-normal",children:"Join with:"}),e.jsx("span",{className:"text-sm font-medium",children:"OR"})]})]}),e.jsxs("div",{className:"flex items-center gap-2",children:[e.jsxs(t.Select,{value:b.operator,onValueChange:F=>O(m.id,A,F),children:[e.jsx(t.SelectTrigger,{className:"w-[100px]",children:e.jsx(t.SelectValue,{})}),e.jsxs(t.SelectContent,{children:[e.jsx(t.SelectItem,{className:"hover:bg-muted",value:"AND",children:"AND"}),e.jsx(t.SelectItem,{value:"OR",children:"OR"})]})]}),e.jsx(t.Button,{type:"button",variant:"ghost",size:"sm",onClick:()=>I(m.id,A),children:e.jsx(t.Trash2,{className:"h-4 w-4"})})]})]}),e.jsxs("div",{className:"space-y-2",children:[b.keys.length===0?e.jsx("div",{className:"rounded-md border border-dashed p-3 text-center text-sm text-gray-500",children:"No conditions in this group. Add conditions to specify join criteria."}):e.jsx("div",{className:"space-y-2",children:b.keys.map((F,P)=>e.jsxs("div",{className:"flex flex-col items-start gap-2 rounded-md border p-2 sm:flex-row sm:items-center",children:[P>0&&e.jsx("div",{className:"self-center rounded-md bg-gray-100 px-2 py-1 text-xs font-medium",children:b.operator}),e.jsx("div",{className:"mb-2 w-full sm:mb-0 sm:flex-1",children:e.jsxs(t.Select,{value:F.source.name,onValueChange:R=>v(m.id,A,P,"sourceColumnName",R),children:[e.jsx(t.SelectTrigger,{children:e.jsx(t.SelectValue,{placeholder:"Source column"})}),e.jsx(t.SelectContent,{children:w(m.source.name).map(R=>e.jsx(t.SelectItem,{className:"hover:bg-muted",value:R.name,children:e.jsxs("div",{className:"flex w-full items-center justify-between",children:[e.jsx("span",{children:R.name}),e.jsx(t.Badge,{variant:"outline",className:"ml-2 text-xs",children:R.dataType})]})},R.name))})]})}),e.jsx("div",{className:"mb-2 w-full sm:mb-0 sm:w-20",children:e.jsxs(t.Select,{value:F.operator,onValueChange:R=>v(m.id,A,P,"operator",R),children:[e.jsx(t.SelectTrigger,{children:e.jsx(t.SelectValue,{})}),e.jsxs(t.SelectContent,{children:[e.jsx(t.SelectItem,{className:"hover:bg-muted",value:"=",children:"="}),e.jsx(t.SelectItem,{className:"hover:bg-muted",value:"<",children:"<"}),e.jsx(t.SelectItem,{className:"hover:bg-muted",value:">",children:">"}),e.jsx(t.SelectItem,{className:"hover:bg-muted",value:"<=",children:"<="}),e.jsx(t.SelectItem,{className:"hover:bg-muted",value:">=",children:">="})]})]})}),e.jsx("div",{className:"mb-2 w-full sm:mb-0 sm:flex-1",children:e.jsxs(t.Select,{value:F.target.name,onValueChange:R=>v(m.id,A,P,"targetColumnName",R),children:[e.jsx(t.SelectTrigger,{children:e.jsx(t.SelectValue,{placeholder:"Target column"})}),e.jsx(t.SelectContent,{children:w(m.target.name).map(R=>e.jsx(t.SelectItem,{className:"hover:bg-muted",value:R.name,children:e.jsxs("div",{className:"flex w-full items-center justify-between hover:bg-muted",children:[e.jsx("span",{children:R.name}),e.jsx(t.Badge,{variant:"outline",className:"ml-2 text-xs",children:R.dataType})]})},R.name))})]})}),e.jsx(t.Button,{type:"button",variant:"ghost",size:"sm",className:"self-center",onClick:()=>C(m.id,A,P),children:e.jsx(t.X,{className:"size-3.5"})})]},F.id||P))}),e.jsxs(t.Button,{type:"button",variant:"outline",size:"sm",className:"mt-2",onClick:()=>k(m.id,A),children:[e.jsx(t.Plus,{className:"mr-1 h-3 w-3"})," Add Condition"]})]})]},b.id))})]})]})]},m.id)})})]}),e.jsxs("div",{className:"flex justify-end gap-2 border-t pt-4",children:[e.jsx(t.Button,{variant:"outline",onClick:()=>{r(),o()},children:"Remove All"}),e.jsx(t.Button,{variant:"outline",onClick:o,children:"Cancel"}),e.jsx(t.Button,{onClick:()=>n(d),disabled:!D(),children:"Save"})]})]})}function Mt({children:s,open:a,onOpenChange:n,joinPlan:r,availableDataSources:o,onRemove:i,onSave:c,onCancel:d}){return e.jsxs(t.Dialog,{open:a,onOpenChange:n,children:[e.jsxs(t.DialogContent,{className:"max-w-4xl",children:[e.jsxs(t.DialogHeader,{children:[e.jsx(t.DialogTitle,{children:"Join Configuration"}),e.jsx(t.DialogDescription,{children:"Configure the join between the two entities to combine the fields."})]}),e.jsx(er,{joinPlan:r,availableDataSources:o,onSave:c,onCancel:d,onRemove:i})]}),s]})}function tr({joins:s,baseEntityId:a,availableDataSources:n,generateSQLPreview:r}){return e.jsxs("div",{className:"divide-y divide-border",children:[s.length>0&&e.jsxs("div",{className:"p-4",children:[e.jsx("h3",{className:"mb-3 text-left font-semibold",children:"Join Chain"}),e.jsx("div",{className:"flex flex-wrap items-center gap-2",children:(()=>{const o=[...s].sort((c,d)=>c.sequence-d.sequence),i=n.find(c=>c.name===a);return e.jsxs(e.Fragment,{children:[e.jsxs("div",{className:"flex items-center gap-1 rounded-md border bg-muted px-2 py-1",children:[e.jsx(t.Badge,{variant:"secondary",className:"text-xs",children:i==null?void 0:i.type}),e.jsx("span",{className:"text-xs font-medium",children:i==null?void 0:i.name}),e.jsx(t.Badge,{variant:"outline",className:"text-xs text-green-600",children:"BASE"})]}),o.map(c=>{const d=n.find(l=>l.name===c.target.name);return e.jsxs("div",{className:"flex items-center",children:[e.jsxs("div",{className:"mx-1 flex items-center gap-1",children:[e.jsx(t.Badge,{variant:"outline",className:"text-xs",children:c.joinType}),e.jsx("span",{className:"text-muted-foreground",children:"→"})]}),e.jsxs("div",{className:"flex items-center gap-1 rounded-md border bg-muted px-2 py-1",children:[e.jsx(t.Badge,{variant:"secondary",className:"text-xs",children:d==null?void 0:d.type}),e.jsx("span",{className:"text-xs font-medium",children:d==null?void 0:d.name})]})]},c.id)})]})})()})]}),e.jsxs("div",{className:"p-4",children:[e.jsxs("h3",{className:"mb-3 text-left text-sm font-medium",children:["Configured Joins (",s.length,")"]}),e.jsx("div",{className:"space-y-2",children:[...s].sort((o,i)=>o.sequence-i.sequence).map((o,i)=>{const c=n.find(l=>l.name===o.source.name),d=n.find(l=>l.name===o.target.name);return e.jsxs("div",{className:"flex items-center gap-2 rounded-md bg-muted p-2 text-left",children:[e.jsx(t.Badge,{variant:"secondary",className:"shrink-0 text-xs",children:i+1}),e.jsx(t.Badge,{variant:"outline",className:"shrink-0 text-xs",children:o.joinType}),e.jsxs("span",{className:"text-xs font-medium",children:[c==null?void 0:c.name," → ",d==null?void 0:d.name]}),e.jsxs(t.Badge,{variant:"outline",className:"ml-auto text-xs",children:[o.joinKeyGroups.reduce((l,x)=>l+x.keys.length,0)," ","condition",o.joinKeyGroups.reduce((l,x)=>l+x.keys.length,0)>1?"s":""]})]},o.id)})})]}),e.jsxs("div",{className:"p-4",children:[e.jsx("h3",{className:"mb-3 text-left text-sm font-medium",children:"SQL Query"}),e.jsx("div",{className:"overflow-x-auto rounded-md border bg-muted p-3",children:e.jsx("pre",{className:"whitespace-pre-wrap break-all text-left font-mono text-xs text-muted-foreground",children:r()})})]})]})}function sr(){var h,u;const s=t.useEditorStore(j=>j.card),a=t.useEditorStore(j=>j.actions.updateCardConfig),n=((h=s==null?void 0:s.config)==null?void 0:h.joinPlan)||{baseEntity:{type:"table",name:"",database:"",schema:"",connectionId:"",connectionType:"none",dialect:"none"},joins:[]},[r,o]=L.useState(!1),i=((u=s==null?void 0:s.dataSource)==null?void 0:u.selectedEntities)||[],c=j=>{a(s.id,{...s==null?void 0:s.config,joinPlan:j}),o(!1)},d=()=>{a(s.id,{...s==null?void 0:s.config,joinPlan:void 0})},l=()=>{o(!1)},x=()=>{const j=[...n.joins].sort((f,E)=>f.sequence-E.sequence),y=n.baseEntity;if(!y.name)return"SELECT * FROM table -- Please select a base entity";let N=`SELECT *
@@ -8241,7 +8241,6 @@ function _c({ field: t }) {
8241
8241
  "div",
8242
8242
  {
8243
8243
  className: "flex min-w-0 items-center gap-1 p-2",
8244
- onClick: () => o(!u),
8245
8244
  children: [
8246
8245
  /* @__PURE__ */ e("div", { className: "flex-shrink-0 hover:cursor-grab active:cursor-grabbing", children: /* @__PURE__ */ e(Ft, { className: "invisible size-3.5 text-gray-400 group-hover/container:visible" }) }),
8247
8246
  /* @__PURE__ */ e(
package/dist/index.cjs CHANGED
@@ -1 +1 @@
1
- "use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const e=require("./chunks/index-DdUA7rY3.js"),t=require("./types/index.cjs"),a=require("./chunks/dashboard-plus-Dw0bhQVI.js");require("react/jsx-runtime");require("react");require("react-dom");const r=["MM-DD-YYYY","YYYY-MM-DD","MM/DD/YYYY","DD/MM/YYYY","MMMM DD, YYYY","MMM DD, YYYY","DD MMM YYYY","YYYY-MM","MMMM YYYY","custom"];exports.Dashboard=e.Dashboard;exports.DashboardWC=e.DashboardWC;exports.SemaphorDataProvider=e.SemaphorQueryClient;exports.SemaphorQueryClient=e.SemaphorQueryClient;exports.createSqlGenConfig=e.createSqlGenConfig;exports.fmt=e.fmt;exports.getColumnDataType=e.getColumnDataType;exports.getFilterValueType=e.getFilterValueType;exports.getFormattedTableNameForQuery=e.getFormattedTableNameForQuery;exports.getQualifiedTableName=e.getQualifiedTableName;exports.getSql=e.getSql;exports.invalidateToken=e.invalidateToken;exports.isBooleanDataType=e.isBooleanDataType;exports.isColumnInSqlGen=e.isColumnInSqlGen;exports.isDateDataType=e.isDateDataType;exports.isNumberDataType=e.isNumberDataType;exports.isTextDataType=e.isTextDataType;exports.resolveDataType=e.resolveDataType;exports.resolveDatamodelName=e.resolveDatamodelName;exports.useCard=e.useCard;exports.useCurrentActiveCard=e.useCurrentActiveCard;exports.useCurrentCardConfig=e.useCurrentCardConfig;exports.useCurrentSheetActiveCards=e.useCurrentSheetActiveCards;exports.useDashboardActions=e.useDashboardActions;exports.useDashboardStore=e.useDashboardStore;exports.useDataColumns=e.useDataColumns;exports.useDateFilterHook=e.useDateFilterHook;exports.useEditorActions=e.useEditorActions;exports.useEditorAside=e.useEditorAside;exports.useEditorStore=e.useEditorStore;exports.useTextFilterHook=e.useTextFilterHook;exports.EMPTY_SELECTION=t.EMPTY_SELECTION;exports.ScheduleDashboard=a.ScheduleDashboard;exports.SelectComponent=a.SelectComponent;exports.Surfboard=a.DashboardPlus;exports.cleanCard=a.cleanCard;exports.downloadPdf=a.downloadPdf;exports.getDashbaordStateWithoutData=a.getDashbaordStateWithoutData;exports.DATE_FORMAT_VALUES=r;
1
+ "use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const e=require("./chunks/index-DdUA7rY3.js"),t=require("./types/index.cjs"),a=require("./chunks/dashboard-plus-D4i7WErk.js");require("react/jsx-runtime");require("react");require("react-dom");const r=["MM-DD-YYYY","YYYY-MM-DD","MM/DD/YYYY","DD/MM/YYYY","MMMM DD, YYYY","MMM DD, YYYY","DD MMM YYYY","YYYY-MM","MMMM YYYY","custom"];exports.Dashboard=e.Dashboard;exports.DashboardWC=e.DashboardWC;exports.SemaphorDataProvider=e.SemaphorQueryClient;exports.SemaphorQueryClient=e.SemaphorQueryClient;exports.createSqlGenConfig=e.createSqlGenConfig;exports.fmt=e.fmt;exports.getColumnDataType=e.getColumnDataType;exports.getFilterValueType=e.getFilterValueType;exports.getFormattedTableNameForQuery=e.getFormattedTableNameForQuery;exports.getQualifiedTableName=e.getQualifiedTableName;exports.getSql=e.getSql;exports.invalidateToken=e.invalidateToken;exports.isBooleanDataType=e.isBooleanDataType;exports.isColumnInSqlGen=e.isColumnInSqlGen;exports.isDateDataType=e.isDateDataType;exports.isNumberDataType=e.isNumberDataType;exports.isTextDataType=e.isTextDataType;exports.resolveDataType=e.resolveDataType;exports.resolveDatamodelName=e.resolveDatamodelName;exports.useCard=e.useCard;exports.useCurrentActiveCard=e.useCurrentActiveCard;exports.useCurrentCardConfig=e.useCurrentCardConfig;exports.useCurrentSheetActiveCards=e.useCurrentSheetActiveCards;exports.useDashboardActions=e.useDashboardActions;exports.useDashboardStore=e.useDashboardStore;exports.useDataColumns=e.useDataColumns;exports.useDateFilterHook=e.useDateFilterHook;exports.useEditorActions=e.useEditorActions;exports.useEditorAside=e.useEditorAside;exports.useEditorStore=e.useEditorStore;exports.useTextFilterHook=e.useTextFilterHook;exports.EMPTY_SELECTION=t.EMPTY_SELECTION;exports.ScheduleDashboard=a.ScheduleDashboard;exports.SelectComponent=a.SelectComponent;exports.Surfboard=a.DashboardPlus;exports.cleanCard=a.cleanCard;exports.downloadPdf=a.downloadPdf;exports.getDashbaordStateWithoutData=a.getDashbaordStateWithoutData;exports.DATE_FORMAT_VALUES=r;
package/dist/index.js CHANGED
@@ -1,6 +1,6 @@
1
1
  import { D as Y, c as D, S as i, S as u, l as d, f as M, n as l, m as n, p as m, q as p, k as C, i as S, j as T, o as c, h, g as b, e as f, s as g, r as y, b as A, w as E, y as v, x, z as F, v as N, d as k, u as q, B as P, t as Q, A as _, a as w } from "./chunks/index-CxuQLwIa.js";
2
2
  import { EMPTY_SELECTION as G } from "./types/index.js";
3
- import { S as I, a as L, D as O, c as V, d as W, g as j } from "./chunks/dashboard-plus-BTzz4Vxx.js";
3
+ import { S as I, a as L, D as O, c as V, d as W, g as j } from "./chunks/dashboard-plus-DV5VATMC.js";
4
4
  import "react/jsx-runtime";
5
5
  import "react";
6
6
  import "react-dom";
@@ -1 +1 @@
1
- "use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const e=require("../chunks/dashboard-plus-Dw0bhQVI.js"),r=require("../types/index.cjs");exports.Surfboard=e.DashboardPlus;exports.EMPTY_SELECTION=r.EMPTY_SELECTION;
1
+ "use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const e=require("../chunks/dashboard-plus-D4i7WErk.js"),r=require("../types/index.cjs");exports.Surfboard=e.DashboardPlus;exports.EMPTY_SELECTION=r.EMPTY_SELECTION;
@@ -1,4 +1,4 @@
1
- import { D as f } from "../chunks/dashboard-plus-BTzz4Vxx.js";
1
+ import { D as f } from "../chunks/dashboard-plus-DV5VATMC.js";
2
2
  import { EMPTY_SELECTION as a } from "../types/index.js";
3
3
  export {
4
4
  a as EMPTY_SELECTION,
package/package.json CHANGED
@@ -5,7 +5,7 @@
5
5
  "email": "support@semaphor.cloud"
6
6
  },
7
7
  "license": "MIT",
8
- "version": "0.0.524",
8
+ "version": "0.0.525",
9
9
  "description": "Fully interactive and customizable dashboards for your apps.",
10
10
  "keywords": [
11
11
  "react",
@@ -64,6 +64,7 @@
64
64
  "@radix-ui/react-icons": "^1.3.2",
65
65
  "@radix-ui/react-label": "^2.1.1",
66
66
  "@radix-ui/react-popover": "^1.1.4",
67
+ "@radix-ui/react-progress": "^1.1.7",
67
68
  "@radix-ui/react-radio-group": "^1.2.2",
68
69
  "@radix-ui/react-scroll-area": "^1.2.2",
69
70
  "@radix-ui/react-select": "^2.1.4",