react-semaphor 0.0.509 → 0.0.511

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.
@@ -1,4 +1,4 @@
1
- "use strict";var Vt=s=>{throw TypeError(s)};var Xe=(s,a,n)=>a.has(s)||Vt("Cannot "+n);var X=(s,a,n)=>(Xe(s,a,"read from private field"),n?n.call(s):a.get(s)),le=(s,a,n)=>a.has(s)?Vt("Cannot add the same private member more than once"):a instanceof WeakSet?a.add(s):a.set(s,n),te=(s,a,n,r)=>(Xe(s,a,"write to private field"),r?r.call(s,n):a.set(s,n),n),ce=(s,a,n)=>(Xe(s,a,"access private method"),n);const e=require("react/jsx-runtime"),t=require("./index-Cr3ClsCY.js"),L=require("react");require("react-dom");function Bs(s){const a=Object.create(null,{[Symbol.toStringTag]:{value:"Module"}});if(s){for(const n in s)if(n!=="default"){const r=Object.getOwnPropertyDescriptor(s,n);Object.defineProperty(a,n,r.get?r:{enumerable:!0,get:()=>s[n]})}}return a.default=s,Object.freeze(a)}const ie=Bs(L);function qt(s,a){return s.filter(n=>!a.includes(n))}function zs(s,a,n){const r=s.slice(0);return r[a]=n,r}var fe,re,Ee,Ie,oe,xe,Oe,Fe,Be,ee,it,lt,ct,dt,ut,Wt,Rs=(Wt=class extends t.Subscribable{constructor(a,n,r){super();le(this,ee);le(this,fe);le(this,re);le(this,Ee);le(this,Ie);le(this,oe);le(this,xe);le(this,Oe);le(this,Fe);le(this,Be,[]);te(this,fe,a),te(this,Ie,r),te(this,Ee,[]),te(this,oe,[]),te(this,re,[]),this.setQueries(n)}onSubscribe(){this.listeners.size===1&&X(this,oe).forEach(a=>{a.subscribe(n=>{ce(this,ee,dt).call(this,a,n)})})}onUnsubscribe(){this.listeners.size||this.destroy()}destroy(){this.listeners=new Set,X(this,oe).forEach(a=>{a.destroy()})}setQueries(a,n,r){if(te(this,Ee,a),te(this,Ie,n),process.env.NODE_ENV!=="production"){const o=a.map(i=>X(this,fe).defaultQueryOptions(i).queryHash);new Set(o).size!==o.length&&console.warn("[QueriesObserver]: Duplicate Queries found. This might result in unexpected behavior.")}t.notifyManager.batch(()=>{const o=X(this,oe),i=ce(this,ee,ct).call(this,X(this,Ee));te(this,Be,i),i.forEach(m=>m.observer.setOptions(m.defaultedQueryOptions,r));const l=i.map(m=>m.observer),u=l.map(m=>m.getCurrentResult()),c=l.some((m,d)=>m!==o[d]);o.length===l.length&&!c||(te(this,oe,l),te(this,re,u),this.hasListeners()&&(qt(o,l).forEach(m=>{m.destroy()}),qt(l,o).forEach(m=>{m.subscribe(d=>{ce(this,ee,dt).call(this,m,d)})}),ce(this,ee,ut).call(this)))})}getCurrentResult(){return X(this,re)}getQueries(){return X(this,oe).map(a=>a.getCurrentQuery())}getObservers(){return X(this,oe)}getOptimisticResult(a,n){const r=ce(this,ee,ct).call(this,a),o=r.map(i=>i.observer.getOptimisticResult(i.defaultedQueryOptions));return[o,i=>ce(this,ee,lt).call(this,i??o,n),()=>ce(this,ee,it).call(this,o,r)]}},fe=new WeakMap,re=new WeakMap,Ee=new WeakMap,Ie=new WeakMap,oe=new WeakMap,xe=new WeakMap,Oe=new WeakMap,Fe=new WeakMap,Be=new WeakMap,ee=new WeakSet,it=function(a,n){return n.map((r,o)=>{const i=a[o];return r.defaultedQueryOptions.notifyOnChangeProps?i:r.observer.trackResult(i,l=>{n.forEach(u=>{u.observer.trackProp(l)})})})},lt=function(a,n){return n?((!X(this,xe)||X(this,re)!==X(this,Fe)||n!==X(this,Oe))&&(te(this,Oe,n),te(this,Fe,X(this,re)),te(this,xe,t.replaceEqualDeep(X(this,xe),n(a)))),X(this,xe)):a},ct=function(a){const n=new Map(X(this,oe).map(o=>[o.options.queryHash,o])),r=[];return a.forEach(o=>{const i=X(this,fe).defaultQueryOptions(o),l=n.get(i.queryHash);l?r.push({defaultedQueryOptions:i,observer:l}):r.push({defaultedQueryOptions:i,observer:new t.QueryObserver(X(this,fe),i)})}),r},dt=function(a,n){const r=X(this,oe).indexOf(a);r!==-1&&(te(this,re,zs(X(this,re),r,n)),ce(this,ee,ut).call(this))},ut=function(){var a;if(this.hasListeners()){const n=X(this,xe),r=ce(this,ee,it).call(this,X(this,re),X(this,Be)),o=ce(this,ee,lt).call(this,r,(a=X(this,Ie))==null?void 0:a.combine);n!==o&&t.notifyManager.batch(()=>{this.listeners.forEach(i=>{i(X(this,re))})})}},Wt);function Ps({queries:s,...a},n){const r=t.useQueryClient(),o=t.useIsRestoring(),i=t.useQueryErrorResetBoundary(),l=ie.useMemo(()=>s.map(x=>{const g=r.defaultQueryOptions(x);return g._optimisticResults=o?"isRestoring":"optimistic",g}),[s,r,o]);l.forEach(x=>{t.ensureSuspenseTimers(x),t.ensurePreventErrorBoundaryRetry(x,i)}),t.useClearResetErrorBoundary(i);const[u]=ie.useState(()=>new Rs(r,l,a)),[c,m,d]=u.getOptimisticResult(l,a.combine),h=!o&&a.subscribed!==!1;ie.useSyncExternalStore(ie.useCallback(x=>h?u.subscribe(t.notifyManager.batchCalls(x)):t.noop,[u,h]),()=>u.getCurrentResult(),()=>u.getCurrentResult()),ie.useEffect(()=>{u.setQueries(l,a,{listeners:!1})},[l,a,u]);const f=c.some((x,g)=>t.shouldSuspend(l[g],x))?c.flatMap((x,g)=>{const p=l[g];if(p){const C=new t.QueryObserver(r,p);if(t.shouldSuspend(p,x))return t.fetchOptimistic(p,C,i);t.willFetch(x,o)&&t.fetchOptimistic(p,C,i)}return[]}):[];if(f.length>0)throw Promise.all(f);const y=c.find((x,g)=>{const p=l[g];return p&&t.getHasError({result:x,errorResetBoundary:i,throwOnError:p.throwOnError,query:r.getQueryCache().get(p.queryHash),suspense:p.suspense})});if(y!=null&&y.error)throw y.error;return m(d())}/**
1
+ "use strict";var Vt=s=>{throw TypeError(s)};var Xe=(s,a,n)=>a.has(s)||Vt("Cannot "+n);var X=(s,a,n)=>(Xe(s,a,"read from private field"),n?n.call(s):a.get(s)),le=(s,a,n)=>a.has(s)?Vt("Cannot add the same private member more than once"):a instanceof WeakSet?a.add(s):a.set(s,n),te=(s,a,n,r)=>(Xe(s,a,"write to private field"),r?r.call(s,n):a.set(s,n),n),ce=(s,a,n)=>(Xe(s,a,"access private method"),n);const e=require("react/jsx-runtime"),t=require("./index-Cd-WqnTH.js"),L=require("react");require("react-dom");function Bs(s){const a=Object.create(null,{[Symbol.toStringTag]:{value:"Module"}});if(s){for(const n in s)if(n!=="default"){const r=Object.getOwnPropertyDescriptor(s,n);Object.defineProperty(a,n,r.get?r:{enumerable:!0,get:()=>s[n]})}}return a.default=s,Object.freeze(a)}const ie=Bs(L);function qt(s,a){return s.filter(n=>!a.includes(n))}function zs(s,a,n){const r=s.slice(0);return r[a]=n,r}var fe,re,Ee,Ie,oe,xe,Oe,Fe,Be,ee,it,lt,ct,dt,ut,Wt,Rs=(Wt=class extends t.Subscribable{constructor(a,n,r){super();le(this,ee);le(this,fe);le(this,re);le(this,Ee);le(this,Ie);le(this,oe);le(this,xe);le(this,Oe);le(this,Fe);le(this,Be,[]);te(this,fe,a),te(this,Ie,r),te(this,Ee,[]),te(this,oe,[]),te(this,re,[]),this.setQueries(n)}onSubscribe(){this.listeners.size===1&&X(this,oe).forEach(a=>{a.subscribe(n=>{ce(this,ee,dt).call(this,a,n)})})}onUnsubscribe(){this.listeners.size||this.destroy()}destroy(){this.listeners=new Set,X(this,oe).forEach(a=>{a.destroy()})}setQueries(a,n,r){if(te(this,Ee,a),te(this,Ie,n),process.env.NODE_ENV!=="production"){const o=a.map(i=>X(this,fe).defaultQueryOptions(i).queryHash);new Set(o).size!==o.length&&console.warn("[QueriesObserver]: Duplicate Queries found. This might result in unexpected behavior.")}t.notifyManager.batch(()=>{const o=X(this,oe),i=ce(this,ee,ct).call(this,X(this,Ee));te(this,Be,i),i.forEach(m=>m.observer.setOptions(m.defaultedQueryOptions,r));const l=i.map(m=>m.observer),u=l.map(m=>m.getCurrentResult()),c=l.some((m,d)=>m!==o[d]);o.length===l.length&&!c||(te(this,oe,l),te(this,re,u),this.hasListeners()&&(qt(o,l).forEach(m=>{m.destroy()}),qt(l,o).forEach(m=>{m.subscribe(d=>{ce(this,ee,dt).call(this,m,d)})}),ce(this,ee,ut).call(this)))})}getCurrentResult(){return X(this,re)}getQueries(){return X(this,oe).map(a=>a.getCurrentQuery())}getObservers(){return X(this,oe)}getOptimisticResult(a,n){const r=ce(this,ee,ct).call(this,a),o=r.map(i=>i.observer.getOptimisticResult(i.defaultedQueryOptions));return[o,i=>ce(this,ee,lt).call(this,i??o,n),()=>ce(this,ee,it).call(this,o,r)]}},fe=new WeakMap,re=new WeakMap,Ee=new WeakMap,Ie=new WeakMap,oe=new WeakMap,xe=new WeakMap,Oe=new WeakMap,Fe=new WeakMap,Be=new WeakMap,ee=new WeakSet,it=function(a,n){return n.map((r,o)=>{const i=a[o];return r.defaultedQueryOptions.notifyOnChangeProps?i:r.observer.trackResult(i,l=>{n.forEach(u=>{u.observer.trackProp(l)})})})},lt=function(a,n){return n?((!X(this,xe)||X(this,re)!==X(this,Fe)||n!==X(this,Oe))&&(te(this,Oe,n),te(this,Fe,X(this,re)),te(this,xe,t.replaceEqualDeep(X(this,xe),n(a)))),X(this,xe)):a},ct=function(a){const n=new Map(X(this,oe).map(o=>[o.options.queryHash,o])),r=[];return a.forEach(o=>{const i=X(this,fe).defaultQueryOptions(o),l=n.get(i.queryHash);l?r.push({defaultedQueryOptions:i,observer:l}):r.push({defaultedQueryOptions:i,observer:new t.QueryObserver(X(this,fe),i)})}),r},dt=function(a,n){const r=X(this,oe).indexOf(a);r!==-1&&(te(this,re,zs(X(this,re),r,n)),ce(this,ee,ut).call(this))},ut=function(){var a;if(this.hasListeners()){const n=X(this,xe),r=ce(this,ee,it).call(this,X(this,re),X(this,Be)),o=ce(this,ee,lt).call(this,r,(a=X(this,Ie))==null?void 0:a.combine);n!==o&&t.notifyManager.batch(()=>{this.listeners.forEach(i=>{i(X(this,re))})})}},Wt);function Ps({queries:s,...a},n){const r=t.useQueryClient(),o=t.useIsRestoring(),i=t.useQueryErrorResetBoundary(),l=ie.useMemo(()=>s.map(x=>{const g=r.defaultQueryOptions(x);return g._optimisticResults=o?"isRestoring":"optimistic",g}),[s,r,o]);l.forEach(x=>{t.ensureSuspenseTimers(x),t.ensurePreventErrorBoundaryRetry(x,i)}),t.useClearResetErrorBoundary(i);const[u]=ie.useState(()=>new Rs(r,l,a)),[c,m,d]=u.getOptimisticResult(l,a.combine),h=!o&&a.subscribed!==!1;ie.useSyncExternalStore(ie.useCallback(x=>h?u.subscribe(t.notifyManager.batchCalls(x)):t.noop,[u,h]),()=>u.getCurrentResult(),()=>u.getCurrentResult()),ie.useEffect(()=>{u.setQueries(l,a,{listeners:!1})},[l,a,u]);const f=c.some((x,g)=>t.shouldSuspend(l[g],x))?c.flatMap((x,g)=>{const p=l[g];if(p){const C=new t.QueryObserver(r,p);if(t.shouldSuspend(p,x))return t.fetchOptimistic(p,C,i);t.willFetch(x,o)&&t.fetchOptimistic(p,C,i)}return[]}):[];if(f.length>0)throw Promise.all(f);const y=c.find((x,g)=>{const p=l[g];return p&&t.getHasError({result:x,errorResetBoundary:i,throwOnError:p.throwOnError,query:r.getQueryCache().get(p.queryHash),suspense:p.suspense})});if(y!=null&&y.error)throw y.error;return m(d())}/**
2
2
  * @license lucide-react v0.453.0 - ISC
3
3
  *
4
4
  * This source code is licensed under the ISC license.
@@ -396,7 +396,7 @@
396
396
  ${c?`Python:
397
397
  ${c}`:""}
398
398
  `;C(R)}function B(){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(oa,{jsonString:JSON.stringify(m,null,2)})})}),m&&m.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(Ct,{className:"size-3.5 text-muted-foreground"})})]})}function z(){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(aa,{})}),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(ra,{})}),e.jsx("code",{className:"absolute right-6 top-3 text-xs text-muted-foreground/70",children:"python"})]})]})]})}function P(){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:w||I,onClick:()=>{A()},className:"h-8 shrink-0",size:"sm",children:[w||I?e.jsx(ue,{className:"mr-2 h-4 w-4 animate-spin"}):e.jsx(t.Play,{className:"mr-2 h-4 w-4"}),"Run"]}),e.jsx(hs,{sql:v==null?void 0:v.sql,error:k,onClick:M}),e.jsx(t.EditorClearButton,{}),e.jsx(t.Toggle,{pressed:a,onPressedChange:R=>n(R),className:"",size:"sm",children:e.jsx(na,{className:"size-4 text-foreground/70"})}),e.jsx("button",{disabled:l,onClick:()=>{T(!0)},className:"h-9 w-full cursor-text px-3 text-left text-sm text-muted-foreground",children:l?"":"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:[z(),B()]}),P()]})}function la({data:s}){var l;const[a,n]=L.useState([]),o=Object.keys(s[0]).map(u=>({accessorKey:u,header:({column:c})=>{const m=c.getIsSorted();return e.jsx("div",{className:"flex gap-2",children:e.jsxs("div",{className:"flex cursor-pointer items-center",onClick:()=>c.toggleSorting(c.getIsSorted()==="asc"),children:[u,m==="asc"?e.jsx(t.TriangleUpIcon,{className:"ml-2 h-5 w-5"}):m==="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(u=>e.jsx(t.TableRow,{className:"",children:u.headers.map(c=>e.jsx(t.TableHead,{className:"h-11 font-semibold text-foreground",children:c.isPlaceholder?null:t.flexRender(c.column.columnDef.header,c.getContext())},c.id))},u.id))}),e.jsx(t.TableBody,{children:(l=i.getRowModel().rows)!=null&&l.length?i.getRowModel().rows.map(u=>e.jsx(t.TableRow,{className:"h-11 whitespace-nowrap py-2","data-state":u.getIsSelected()&&"selected",children:u.getVisibleCells().map(c=>e.jsx(t.TableCell,{className:"py-2",children:t.flexRender(c.column.columnDef.cell,c.getContext())},c.id))},u.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 ca({card:s}){var C,T,E,j,b,v,w,I,D,N,F;const[a,n]=L.useState(!1),[r,o]=L.useState([]),{authToken:i}=t.useSemaphorContext(),l=t.getTokenParams(i==null?void 0:i.accessToken),u=t.useDashboardStore(O=>O.themeStyle),c={colors:((T=(C=u==null?void 0:u.chart)==null?void 0:C.dataset)==null?void 0:T.backgroundColor)||[]};(E=s.customCardPreferences)!=null&&E.inputData;const{getCard:m}=t.useCustomVisual(((j=s.customCardPreferences)==null?void 0:j.url)||""),d=((b=s.customCardPreferences)==null?void 0:b.visualType)||"single",h=t.useEditorStore(O=>O.frame),{setCustomCardPreferences:S}=t.useEditorActions(),{data:f}=t.useDashboardCardQuery(s),y=L.useCallback((O,A)=>{o(k=>({...k,[O]:A}))},[]);if(!((v=s.customCardPreferences)!=null&&v.componentName))return null;const x=m((w=s.customCardPreferences)==null?void 0:w.componentName);function g(O){n(O)}const p=Object.keys(((I=s.customCardPreferences)==null?void 0:I.dataInputCardIds)||{}).map(O=>{var M,B,z;const A=(B=(M=s.customCardPreferences)==null?void 0:M.dataInputCardIds)==null?void 0:B[O].cardId,k=(z=h==null?void 0:h.cards)==null?void 0:z.find(P=>P.id===A);return k||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:[x&&d==="single"&&e.jsx(x,{params:l,theme:c,settings:(D=s.customCardPreferences)==null?void 0:D.settings,onDataChange:y,data:(f==null?void 0:f.records)||[]}),x&&d==="multiple"&&e.jsxs(e.Fragment,{children:[Object.keys(((N=s.customCardPreferences)==null?void 0:N.dataInputCardIds)||{}).map(O=>{var M,B,z;const A=(B=(M=s.customCardPreferences)==null?void 0:M.dataInputCardIds)==null?void 0:B[O].cardId,k=(z=h==null?void 0:h.cards)==null?void 0:z.find(P=>P.id===A);if(k)return e.jsx(t.MultiInputEmptyRenderer,{onLoadingStatus:g,onDataChange:y,dataInputIndex:O,card:k},k.id+O)}),e.jsx("div",{className:"flex flex-col gap-2",children:e.jsx(x,{theme:c,onDataChange:y,settings:p.map(O=>{var A;return(A=O==null?void 0:O.customCardPreferences)==null?void 0:A.settings}),data:p.map(O=>O!=null&&O.id?r==null?void 0:r[O.id]:[])})})]})]},(F=s.customCardPreferences)==null?void 0:F.componentName)})}function gs({className:s,...a}){var g;const n=t.useEditorStore(p=>p.card),r=((g=n.customCardPreferences)==null?void 0:g.showCardHeader)??!0,o=t.useEditorStore(p=>p.frame),i=t.useDashboardStore(p=>p.dashboard.filters);t.useEditorStore(p=>p.actions.setRunSql);const{updateFilter:l}=t.useDashboardActions(),u=i==null?void 0:i.find(p=>p.id===o.filterId),{data:c,isLoading:m,isFetching:d}=t.useDashboardCardQuery(n),{setCard:h}=t.useEditorActions(),{data:S}=t.useTopoJson(n),f=L.useMemo(()=>!n.id||!(c!=null&&c.records)?null:t.createChartConfig({card:n,data:c==null?void 0:c.records,cardType:n.type,queryConfig:n.queryConfig,customCfg:n.customCfg,preferences:n.preferences,topoJson:S}),[n.id,c==null?void 0:c.records,n.type,n.queryConfig,n.customCfg,n.preferences,S]);function y(p){return e.jsx(ca,{card:p})}function x(){if(c!=null&&c.records&&(c==null?void 0:c.records.length)===0&&!m&&!d)return 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 y(n);if(!["table","custom"].includes(n.type)&&f)return e.jsx(e.Fragment,{children:m||d?e.jsx(e.Fragment,{}):e.jsx(t.ChartJsVisual,{cfg:f})});if(n.type==="table"&&(c!=null&&c.records)&&(c==null?void 0:c.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:c==null?void 0:c.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:p=>h({...n,title:p}),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:p=>h({...n,description:p}),children:e.jsx(t.CardDescription,{children:n.description||"Add description"})},n.description)]}),u&&e.jsxs("div",{className:"flex items-center gap-3",children:[e.jsx(t.Editable,{enabled:!0,className:"my-1",text:u.title||u.column,onSave:p=>l({...u,title:p}),children:e.jsx(t.Label,{children:u.title})}),e.jsx(t.FilterComponent,{filter:u})]})]}),e.jsx(t.CardContent,{className:"flex grow flex-col",children:x()})]})}const at=({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}),da=()=>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."})]})]}),ua=({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(at,{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(at,{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(at,{language:"javascript",value:s,onChange:o})})]}),ma=({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 ha(){const[s,a]=L.useState(!1),[n,r]=L.useState(""),[o,i]=L.useState(""),[l,u]=L.useState(""),[c,m]=L.useState(""),d=t.useEditorStore(j=>j.card),h=t.useEditorStore(j=>j.card.customCfg),S=h?JSON.stringify(h,null,2):"",{data:f}=t.useDashboardCardQuery(d),{data:y}=t.useTopoJson(d),{setCardCustomCfg:x,setCustomVisualCode:g}=t.useEditorActions(),p=j=>{var b,v;return JSON.stringify({...j,data:{...j.data,datasets:(v=(b=j.data)==null?void 0:b.datasets)==null?void 0:v.map(w=>({...w,data:[]}))}},null,2)},C=()=>{var b,v;if(!((b=f==null?void 0:f.records)!=null&&b.length))return;const j=t.createChartConfig({card:d,data:f.records,cardType:d.type,queryConfig:d.queryConfig,preferences:d.preferences,topoJson:y});if(j){r(p(j)),u(((v=d.preferences)==null?void 0:v.customVisualCode)||"");const w=t.merge(j,h);i(p(w))}},T=()=>{try{if(l&&g(l),o){const j=JSON.parse(o),b=t.getObjectDiff(JSON.parse(n),j);x(b),m("")}}catch{m("Invalid JSON configuration")}},E=Object.keys(h||{}).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:C,className:E?"":"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(da,{}),e.jsxs("div",{className:"flex grow gap-2",children:[e.jsx(t.ErrorBoundary,{FallbackComponent:t.FallbackEditorCard,children:e.jsx(gs,{className:"w-1/2 rounded shadow-none"})}),e.jsx(ua,{customCode:l,cardCustomCfgString:S,mergedConfig:o,onConfigChange:j=>i(j??""),onCodeChange:j=>u(j??"")})]}),e.jsx(ma,{error:c,hasCardCustomConfig:!!h,onReset:()=>{i(n),x(null)},onApply:T,onClose:()=>a(!1)})]})]})}function js(s){const[a,n]=L.useState(null);return a}function ys(){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 xa({onChartTypeChange:s}){const[a,n]=L.useState([]),{setCardCustomCfg:r,setCardPreferences:o,setCardType:i,setCustomCardPreferences:l}=t.useEditorActions(),{data:u}=ys();function c(m,d){r(null),o({}),i(m),d&&l({type:"component",visualType:"single",url:d.url,componentName:d.name,icon:d.icon}),s==null||s()}return L.useEffect(()=>{(async()=>{var d;if(u){const S=(await Promise.all((d=u==null?void 0:u.plugins)==null?void 0:d.map(async f=>(await t.loadManifest(f.value)).visuals.map(g=>({name:g.name,icon:g.icon,url:f.value}))))).flat();n(S)}})()},[u]),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((m,d)=>e.jsx(pa,{text:m.name,onClick:()=>c("custom",m),icon:m.icon},m.url+m.name+d))})]})}const pa=({text:s,icon:a,onClick:n})=>{const r=js(),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 At(s){return be({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 fa(s){return be({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 Lt(s){return be({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 Ot(s){return be({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 Ft(s){return be({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 Bt(s){return be({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 bs({onChartTypeChange:s,iconClassName:a}){const{setCardType:n,setCardPreferences:r,setIsDevMode:o}=t.useEditorStore(d=>d.actions),{setCardCustomCfg:i,setCustomCardPreferences:l,setQueryConfig:u}=t.useEditorActions();function c(d,h){i(null),r({}),n(d),["kpi","custom","text","map"].includes(d)&&(o(!0),u(void 0)),s==null||s()}const m=1e3;return e.jsxs("div",{className:"grid grid-cols-5 place-items-center",children:[e.jsx(t.IconButton,{openDelay:m,tooltip:"Table",onClick:()=>c("table"),className:"h-10 p-4",children:e.jsx(We,{className:t.cn("size-5",a)})}),e.jsx(t.IconButton,{openDelay:m,tooltip:"Bar Chart",onClick:()=>c("bar"),className:"h-10 p-4",children:e.jsx(Ke,{className:t.cn("size-5",a)})}),e.jsx(t.IconButton,{openDelay:m,tooltip:"Line Chart",onClick:()=>c("line"),className:"h-10 p-4",children:e.jsx(Qe,{className:t.cn("size-5",a)})}),e.jsx(t.IconButton,{openDelay:m,tooltip:"Stacked Bar Chart",onClick:()=>c("stackedBar"),className:"h-10 p-4",children:e.jsx(gt,{className:t.cn("size-5",a)})}),e.jsx(t.IconButton,{openDelay:m,tooltip:"Stacked Line Chart",onClick:()=>c("stackedLine"),className:"h-10 p-4",children:e.jsx(Ft,{className:t.cn("size-5",a),strokeWidth:0})}),e.jsx(t.IconButton,{openDelay:m,tooltip:"Scatter Chart",onClick:()=>c("scatter"),className:"h-10 p-4",children:e.jsx(vt,{className:t.cn("size-5",a)})}),e.jsx(t.IconButton,{openDelay:m,tooltip:"Bubble Chart",onClick:()=>c("bubble"),className:"h-10 p-4",children:e.jsx(Lt,{className:t.cn("size-5",a)})}),e.jsx(t.IconButton,{openDelay:m,tooltip:"Pie Chart",onClick:()=>c("pie"),className:"h-10 p-4",children:e.jsx(bt,{className:t.cn("size-5",a)})}),e.jsx(t.IconButton,{openDelay:m,tooltip:"Doughnut Chart",onClick:()=>c("doughnut"),className:"h-10 p-4",children:e.jsx(Nt,{className:t.cn("size-5",a)})}),e.jsx(t.IconButton,{openDelay:m,tooltip:"Funnel Chart",onClick:()=>c("funnel"),className:"h-10 p-4",children:e.jsx(Ot,{className:t.cn("size-5",a)})}),e.jsx(t.IconButton,{openDelay:m,tooltip:"Radar Chart",onClick:()=>c("radar"),className:"h-10 p-4",children:e.jsx(kt,{className:t.cn("size-5",a)})}),e.jsx(t.IconButton,{openDelay:m,tooltip:"Polar Area Chart",onClick:()=>c("polarArea"),className:"h-10 p-4",children:e.jsx(At,{className:t.cn("size-5",a)})}),e.jsx(t.IconButton,{openDelay:m,tooltip:"Tornado Chart",onClick:()=>c("tornado"),className:"h-10 p-4",children:e.jsx(It,{className:t.cn("size-5",a)})}),e.jsx(t.IconButton,{tooltip:"Range Chart",onClick:()=>c("range"),className:"h-10 p-4",children:e.jsx(yt,{className:t.cn("size-5",a)})}),e.jsx(t.IconButton,{openDelay:m,tooltip:"KPI",onClick:()=>c("kpi"),className:"h-10 p-4",children:e.jsx(Bt,{className:t.cn("size-5",a)})}),e.jsx(t.IconButton,{openDelay:m,tooltip:"Text",onClick:()=>c("text"),className:"h-10 p-4",children:e.jsx(Xt,{className:t.cn("size-5",a)})}),e.jsx(t.IconButton,{tooltip:"Map",onClick:()=>c("map"),className:"h-10 p-4",children:e.jsx(wt,{className:t.cn("size-5",a)})}),e.jsx(t.IconButton,{openDelay:m,tooltip:"Custom",onClick:()=>c("custom"),className:"h-10 p-4",children:e.jsx(Et,{className:t.cn("size-5",a)})})]})}function ga({chartType:s,className:a,customIcon:n,componentName:r}){const o=js();switch(s){case"bar":return e.jsx(Ke,{className:a});case"line":return e.jsx(Qe,{className:a});case"pie":return e.jsx(bt,{className:a});case"radar":return e.jsx(kt,{className:a});case"scatter":return e.jsx(vt,{className:a});case"bubble":return e.jsx(Lt,{className:a});case"doughnut":return e.jsx(Nt,{className:a});case"stackedBar":return e.jsx(gt,{className:a});case"stackedLine":return e.jsx(Ft,{className:a});case"polarArea":return e.jsx(At,{className:a});case"funnel":return e.jsx(Ot,{className:a});case"tornado":case"pyramid":return e.jsx(It,{className:a});case"range":return e.jsx(yt,{className:a});case"kpi":return e.jsx(Bt,{className:a});case"text":return e.jsx(rs,{className:a});case"map":return e.jsx(wt,{className:a});case"custom":return n&&o?e.jsx(o,{className:a}):r?r==null?void 0:r.charAt(0).toUpperCase():e.jsx(Et,{className:a});default:return e.jsx(We,{className:a})}}function vs({variant:s="ghost"}){var i,l;const[a,n]=L.useState(!1),r=t.useEditorStore(u=>u.card),o=r.type;return t.useDashboardStore(u=>u.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(ga,{className:"size-4",chartType:o,customIcon:(i=r.customCardPreferences)==null?void 0:i.icon,componentName:(l=r.customCardPreferences)==null?void 0:l.componentName})})}),e.jsxs(t.PopoverContentCustom,{onOpenAutoFocus:u=>u.preventDefault(),className:"w-72 p-1",children:[e.jsx(bs,{onChartTypeChange:()=>n(!1)}),e.jsx(xa,{onChartTypeChange:()=>n(!1)})]})]})}const Re="focus-visible:ring-0 focus-visible:ring-ring focus-visible:ring-offset-0";function Yt(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 ja(){var M,B,z,P,R,K;const[s,a]=L.useState(!1),n=t.useEditorStore(J=>{var _;return(_=J.card)==null?void 0:_.preferences}),r=t.useEditorStore(J=>{var _;return(_=J.card)==null?void 0:_.type}),o=t.getNumberAxis(n,{}),[i,l]=L.useState(Yt(n,r)),[u,c]=L.useState(((z=(B=(M=n==null?void 0:n.chartOptions)==null?void 0:M.scales)==null?void 0:B[o])==null?void 0:z.min)||""),[m,d]=L.useState(((K=(R=(P=n==null?void 0:n.chartOptions)==null?void 0:P.scales)==null?void 0:R[o])==null?void 0:K.max)||""),[h,S]=L.useState(u||m?"custom":"auto"),[f,y]=L.useState(""),[x,g]=L.useState(0),[p,C]=L.useState(""),[T,E]=L.useState(""),[j,b]=L.useState(""),v=t.useEditorStore(J=>J.actions.setCardPreferences),{updateCardInFrame:w}=t.useEditorActions(),I=t.useEditorStore(J=>J.card),D=["pie","doughnut","polarArea","funnel"].includes(r);L.useEffect(()=>{var J,_,U,q,V,G,H,Y,Z,ae,Ne,pe,Ce,Se;l(Yt(n,r)),c(((U=(_=(J=n==null?void 0:n.chartOptions)==null?void 0:J.scales)==null?void 0:_[o])==null?void 0:U.min)===0?0:""),d(((G=(V=(q=n==null?void 0:n.chartOptions)==null?void 0:q.scales)==null?void 0:V[o])==null?void 0:G.max)||""),y(((ae=(Z=(Y=(H=n==null?void 0:n.chartOptions)==null?void 0:H.scales)==null?void 0:Y[o])==null?void 0:Z.ticks)==null?void 0:ae.stepSize)||""),g(((Ne=n==null?void 0:n.numberAxisFormat)==null?void 0:Ne.decimalPlaces)||0),C(((pe=n==null?void 0:n.numberAxisFormat)==null?void 0:pe.suffix)||""),E(((Ce=n==null?void 0:n.numberAxisFormat)==null?void 0:Ce.currency)||""),b(((Se=n==null?void 0:n.numberAxisFormat)==null?void 0:Se.locale)||"")},[s,n,o,r]);function N(J,_){return _===""||/^[0-9\b]+$/.test(_)?Number(_):Number(J)}function F(){const J=[...new Set(t.LOCALE_CURRENCY_PAIRS.map(_=>_.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:T||"none",onValueChange:_=>E(_==="none"?"":_),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"}),J.map(_=>e.jsx(t.SelectItem,{value:_,children:_},_))]})})]}),e.jsxs(t.Select,{value:j,onValueChange:_=>b(_),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(_=>e.jsx(t.SelectItem,{value:_.locale,children:_.locale},_.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:x,onChange:_=>g(Number(_.target.value)),id:"format",className:`col-span-6 h-8 w-full tracking-wide ${Re}`})]})]})}function O(){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:D,value:i,onValueChange:J=>l(J),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:D,id:"scale-option",value:h,onValueChange:J=>S(J),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"})]})]})]}),h==="custom"&&i=="linear"&&A()]})}function A(){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:u,onChange:J=>c(_=>N(_,J.target.value)),className:`col-span-1 h-8 w-full ${Re}`}),e.jsx(t.Input,{value:m,onChange:J=>d(_=>N(_,J.target.value)),id:"max",className:`col-span-1 h-8 w-full ${Re}`})]}),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:f,onChange:J=>y(_=>N(_,J.target.value)),id:"step-size",className:`col-span-1 h-8 w-full ${Re}`})]})]})}function k(){var q;let J={};h==="custom"&&(J={min:u,max:m,ticks:{stepSize:f}});const _={...n||{},chartOptions:{...n==null?void 0:n.chartOptions,scales:{...(q=n==null?void 0:n.chartOptions)==null?void 0:q.scales,[o]:{type:i,...i==="linear"?J:{}}}},numberAxisFormat:{decimalPlaces:x,suffix:p,currency:T,locale:j}};console.log(_),v(_);const U={...I,preferences:_};w(U)}return e.jsxs(t.Popover,{onOpenChange:J=>a(J),children:[e.jsx(t.PopoverTrigger,{asChild:!0,children:e.jsx(t.IconButton,{tooltip:"Format Number",children:e.jsx(dn,{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:[F(),O(),e.jsx(t.SelectSeparator,{}),e.jsx("div",{className:"grid grid-cols-3",children:e.jsx(t.Button,{onClick:k,variant:"secondary",className:"col-span-1 col-start-3 h-8 w-full",children:"Apply"})})]})]})})]})}function ya(){const s=t.useEditorStore(u=>{var c,m,d,h;return(h=(d=(m=(c=u.card.preferences)==null?void 0:c.chartOptions)==null?void 0:m.plugins)==null?void 0:d.legend)==null?void 0:h.position}),a=t.useEditorStore(u=>{var c,m,d,h;return(h=(d=(m=(c=u.card.preferences)==null?void 0:c.chartOptions)==null?void 0:m.plugins)==null?void 0:d.legend)==null?void 0:h.align}),n=t.useEditorStore(u=>{var c,m,d,h;return(h=(d=(m=(c=u.card.preferences)==null?void 0:c.chartOptions)==null?void 0:m.plugins)==null?void 0:d.legend)==null?void 0:h.display}),{setLegendOptions:r}=t.useEditorActions(),o=u=>{r({display:u,position:s,align:a})},i=u=>{r({display:n,position:u,align:a})},l=u=>{r({display:n,position:s,align:u})};return e.jsxs(t.Popover,{children:[e.jsx(t.PopoverTrigger,{asChild:!0,children:e.jsx(t.IconButton,{tooltip:"Legend Settings",children:e.jsx(bn,{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(Ye,{className:"size-4"})}),e.jsx(t.IconButton,{tooltip:"Left",onClick:()=>i("left"),children:e.jsx(Js,{className:"size-4"})}),e.jsx(t.IconButton,{tooltip:"Bottom",onClick:()=>i("bottom"),children:e.jsx(Ue,{className:"size-4"})}),e.jsx(t.IconButton,{tooltip:"Right",onClick:()=>i("right"),children:e.jsx(Us,{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:()=>l("start"),children:e.jsx(qs,{className:"size-4"})}),e.jsx(t.IconButton,{tooltip:"Center",onClick:()=>l("center"),children:e.jsx(Vs,{className:"size-4"})}),e.jsx(t.IconButton,{tooltip:"End",onClick:()=>l("end"),children:e.jsx(_s,{className:"size-4"})})]})]})]})]})]})})]})}function ba(){const s=t.useEditorStore(i=>{var l,u;return(u=(l=i.card.preferences)==null?void 0:l.chartOptions)==null?void 0:u.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($t,{className:"size-4"}):e.jsx(_t,{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($t,{className:"size-4"}):e.jsx(_t,{className:"size-4"})})}return e.jsx(e.Fragment,{children:a==="funnel"?o():r()})}function Ns(){const s=t.useEditorStore(l=>l.card),a=t.useEditorStore(l=>l.isShowingVisual),n=t.useEditorStore(l=>{var u,c;return(c=(u=l.card)==null?void 0:u.preferences)==null?void 0:c.chartOptions}),r=t.getChartGridStyle(n),{setChartGrid:o}=t.useEditorActions();function i(){const l=["xy","none","x","y"],c=(l.indexOf(r)+1)%l.length;o(l[c])}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(ba,{}),!["kpi","text","custom","table"].includes(s.type)&&e.jsxs(e.Fragment,{children:[e.jsx(ja,{}),e.jsx(ya,{})]}),!["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(gn,{className:"size-4"}),r==="x"&&e.jsx(on,{className:"size-4"}),r==="y"&&e.jsx(Mn,{className:"size-4"}),r==="none"&&e.jsx(On,{className:"size-4"})]})]}):null}function va(){const s=t.useEditorStore(y=>y.frame),a=t.useEditorStore(y=>y.card),{setFrame:n,setActiveTabCardId:r,setCard:o,updateCardInFrame:i}=t.useEditorActions(),l=(y,x)=>{y.dataTransfer.setData("tabIndex",x.toString())},u=y=>{y.preventDefault()},c=(y,x)=>{const g=y.dataTransfer.getData("tabIndex");if(g===x.toString())return;const p=Array.from(s.cards),[C]=p.splice(parseInt(g),1);p.splice(x,0,C),n({...s,cards:p})};function m(y){const x=s.cards.filter(C=>C.id!==y),g=x[0],p={...s,cards:x,activeCardId:g.id};n(p),r(g.id),o(g)}function d(y,x){const g={...s,cards:[...s.cards,x],activeCardId:y.id};n(g),r(x.id)}function h(){const y={...a,id:t.v4(),title:`${a.title} Copy`,tabTitle:`${a.tabTitle||a.title} Copy`};d(a,y)}function S(y){const x={connectionId:y.connectionId,lastSelectedDatabase:y.lastSelectedDatabase,lastSelectedSchema:y.lastSelectedSchema,lastSelectedTable:y.lastSelectedTable,lastSelectedDatamodelId:y.lastSelectedDatamodelId,id:t.v4(),title:"Title",description:"",preferences:{onClickFilter:[{columnIndex:0,expression:""}]},type:"bar",sql:"",data:[]};d(y,x)}function f(y,x){return y.cards.length===1&&(x.displayTab===!0||x.displayTab===void 0)||y.activeCardId!==x.id&&(x.displayTab===!0||x.displayTab===void 0)?null:e.jsx("div",{onClick:()=>{const g=x.displayTab===void 0?!1:!x.displayTab;o({...x,displayTab:g}),i({...x,displayTab:g})},children:x.displayTab===!0||x.displayTab===void 0?e.jsx(t.Eye,{className:"mr-2 size-3.5 text-muted-foreground hover:text-foreground"}):e.jsx(un,{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((y,x)=>e.jsxs(t.TabsTrigger,{draggable:!0,onDragStart:g=>l(g,x),onDragOver:u,onDrop:g=>c(g,x),className:"",value:y.id,children:[f(s,y),e.jsx(t.Editable,{enabled:s.activeCardId===y.id,text:y.tabTitle||y.title,onSave:g=>{o({...a,tabTitle:g}),i({...a,tabTitle:g})},children:y.tabTitle||y.title},y.id),s.activeCardId===y.id&&s.cards.length>1&&e.jsx(t.X,{className:"ml-2 size-3.5 text-muted-foreground hover:text-foreground",onClick:()=>m(y.id)})]},y.id)),e.jsx(t.Button,{className:"ml-1 h-8 px-2 hover:bg-muted-foreground/50",variant:"outline",onClick:()=>S(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:h,children:e.jsx(cn,{className:"h-4 w-4"})})]})})}function Cs(){const s=t.useEditorStore(x=>x.frame),a=t.useEditorStore(x=>x.card),n=t.useEditorStore(x=>x.isSqlRunning),r=t.useEditorStore(x=>x.isDevMode),{setFrame:o,setActiveTabCardId:i,setCard:l,setIsDevMode:u,setRunSql:c}=t.useEditorActions(),{data:m,isLoading:d,isFetching:h}=t.useDashboardCardQuery(a);function S(x){const g=s.cards.find(p=>p.id===x);if(g!=null&&g.sql){r||u(!0),i(x);return}if(g!=null&&g.queryConfig){r&&u(!1),f(x),i(x);return}r||f(x),i(x)}function f(x){const g={...s,cards:s.cards.map(C=>C.id===a.id?a:C),activeCardId:x};o(g);const p=g.cards.find(C=>C.id===x);p.sql&&c(!0),l(p)}function y(){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:m==null?void 0:m.records,isPending:d})})}):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:m==null?void 0:m.records})})})}):e.jsx(t.ErrorBoundary,{FallbackComponent:t.FallbackEditorCard,children:e.jsx(gs,{className:"grow border-none shadow-none"})})}return e.jsxs(t.Tabs,{onValueChange:S,value:s.activeCardId,className:"flex grow flex-col",children:[s.cards.map(x=>e.jsx(t.TabsContent,{className:"mt-0 grow",value:x.id,children:y()},x.id)),e.jsx(va,{})]})}function Pe({children:s}){var C;t.useEditorStore(T=>T.frame);const a=t.useEditorStore(T=>T.card),n=t.useEditorStore(T=>T.isDevMode),r=t.useEditorStore(T=>T.isShowingVisual),o=t.useDashboardStore(T=>T.isVisualEditing),i=t.useEditorStore(T=>T.pythonStdOut);t.useEditorStore(T=>T.actions.setRunSql);const{setFrame:l,setCard:u,setActiveTabCardId:c,runAssistant:m,setIsDevMode:d}=t.useEditorActions(),{data:h,isLoading:S,isFetching:f,error:y}=t.useDashboardCardQuery(a);function x(){const T=JSON.stringify(h==null?void 0:h.records,null,2),E=new Blob([T],{type:"application/json"}),j=URL.createObjectURL(E),b=document.createElement("a");b.href=j,b.download=`${a.title}.json`,b.click()}function g(){const E=[Object.keys(h==null?void 0:h.records.reduce((w,I)=>({...w,...I}),{})).join(","),...((h==null?void 0:h.records)||[]).map(w=>Object.values(w).join(","))].join(`
399
- `),j=new Blob([E],{type:"text/csv"}),b=URL.createObjectURL(j),v=document.createElement("a");v.href=b,v.download=`${a.title}.csv`,v.click()}function p(){const T=`Can you get the documentation for ${a.type} chart?`;m(T)}return a?e.jsxs("div",{className:"relative isolate flex h-full flex-col py-2 pb-3",children:[(S||f)&&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(ue,{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(vs,{}),o&&e.jsx(t.IconButton,{tooltip:"Visual Docs",onClick:p,children:e.jsx(Ws,{className:"size-4"})}),!["table","custom"].includes(a.type)&&o&&e.jsx(ha,{})]}),!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:g,children:e.jsx(fa,{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:x,children:e.jsx(hn,{strokeWidth:1.5,className:"size-4"})}),e.jsx(t.CopyButton,{text:JSON.stringify(h==null?void 0:h.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(Ns,{})]}),n&&e.jsx(Ca,{})]}),r?e.jsx(Cs,{}):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(Na,{})}),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:[(h==null?void 0:h.records)&&(h==null?void 0:h.records.length)>0&&e.jsx(la,{data:(h==null?void 0:h.records)||[]}),(y||(h==null?void 0:h.error))&&e.jsx("span",{className:"font-mono text-xs",children:(y==null?void 0:y.message)||((C=h==null?void 0:h.error)==null?void 0:C.message)})]})]})]}):e.jsx(e.Fragment,{children:"No Active Card"})}function Na(){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 Ca(){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 Sa(){var x,g;const s=t.useEditorStore(p=>p.card.customCardPreferences),{data:a}=ys(),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:l}=t.useEditorActions(),{components:u,manifest:c}=t.useCustomVisual((s==null?void 0:s.url)||""),m=(x=c==null?void 0:c.visuals)==null?void 0:x.find(p=>p.name===(s==null?void 0:s.componentName));function d(p,C){if(!s)return;const E={...(s==null?void 0:s.dataInputCardIds)||{},[p]:{cardId:C,hookRef:null}};l({...s,dataInputCardIds:E})}function h(p){var T,E;const C=(T=o==null?void 0:o.cards)==null?void 0:T.filter(j=>{var b;return((b=j==null?void 0:j.customCardPreferences)==null?void 0:b.visualType)!=="multiple"}).map(j=>({value:j.id,label:j.tabTitle||j.title}));return e.jsx("div",{className:"space-y-2",children:(E=p==null?void 0:p.dataInputs)==null?void 0:E.map((j,b)=>{var v,w;return e.jsxs("div",{className:"grid grid-cols-10 gap-2",children:[e.jsx("div",{className:"col-span-4 flex items-center",children:j}),e.jsx(de,{className:"col-span-6 h-8 w-full justify-between",label:"",options:C||[],value:((w=(v=s==null?void 0:s.dataInputCardIds)==null?void 0:v[b])==null?void 0:w.cardId)||"",onValueChange:I=>d(b,I)})]},b+Math.random())})})}function S(p,C,T=[],E=""){var j,b;return s?p==="input"?e.jsx(t.Input,{className:`h-8 w-full ${t.removeRing}`,value:((j=s==null?void 0:s.settings)==null?void 0:j[C])||E,onChange:v=>{l({...s,settings:{...s==null?void 0:s.settings,[C]:v.target.value}})}},C):p==="select"?e.jsx(de,{className:"h-8 w-full",label:"",options:T,value:((b=s==null?void 0:s.settings)==null?void 0:b[C])||E,onValueChange:v=>{l({...s,settings:{...s==null?void 0:s.settings,[C]:v}})}}):null:null}function f(p){const C=Object.entries((p==null?void 0:p.settings)||{});return e.jsx("div",{className:"space-y-3",children:C.map(([T,E])=>e.jsxs("div",{className:"space-y-1",children:[e.jsx(t.Label,{children:E.title}),S(E.ui,T,E.options,E.defaultValue)]},T))})}function y(p){s&&l({...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(de,{icon:e.jsx(Qs,{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=>l({...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:y,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:u&&e.jsx(de,{icon:e.jsx(ln,{className:"h-3.5 w-3.5"}),className:"h-9 w-full",label:"Select Component",options:(u==null?void 0:u.filter(p=>p.type===i).map(p=>({value:p.name,label:p.name})))||[],value:s.componentName,onValueChange:p=>{console.log("changing value",p),l({...s,componentName:p})}})})]})})]}),((g=r==null?void 0:r.customCardPreferences)==null?void 0:g.componentName)&&e.jsxs(t.AccordionItem,{className:"border-none",value:"component-settings",children:[e.jsx(t.AccordionTrigger,{children:"Settings"}),e.jsxs(t.AccordionContent,{children:[m&&m.dataInputs&&e.jsxs("div",{className:"space-y-3",children:[e.jsx(t.Label,{children:"Input Mapping"}),e.jsx("div",{className:"px-2",children:h(m)})]}),m&&m.settings&&e.jsx("div",{className:"space-y-3",children:e.jsx("div",{className:"px-2",children:f(m)})})]})]})]})}function ve(){const[s,a]=L.useState([]),n=t.useEditorStore(m=>m.card.preferences),{setFilterOnClickColumnIndex:r,setCardPreferences:o}=t.useEditorStore(m=>m.actions),i=t.useEditorStore(m=>m.queryResultColumns);t.useEditorStore(m=>{var d;return(d=m.card.preferences)==null?void 0:d.filterOnClickColumnIndex}),L.useEffect(()=>{i&&a(new Array(i.length).fill(!1))},[i]);function l(m,d){var h,S;d?n!=null&&n.onClickFilter&&((h=n==null?void 0:n.onClickFilter)==null?void 0:h.length)>0?o({...n,onClickFilter:[...n.onClickFilter,{columnIndex:m,expression:""}]}):o({...n,onClickFilter:[{columnIndex:m,expression:""}]}):(o({...n,onClickFilter:(S=n==null?void 0:n.onClickFilter)==null?void 0:S.filter(f=>f.columnIndex!==m)}),a(f=>{const y=[...f];return y[m]=!1,y}))}function u(m,d){var S;const h=(S=n==null?void 0:n.onClickFilter)==null?void 0:S.map(f=>f.columnIndex===m?{...f,expression:d.target.value}:f);o({...n,onClickFilter:h})}function c(m){var d,h,S,f;if(s!=null&&s[m]||(h=(d=n==null?void 0:n.onClickFilter)==null?void 0:d.find(y=>y.columnIndex===m))!=null&&h.expression)return e.jsx(t.Input,{value:(f=(S=n==null?void 0:n.onClickFilter)==null?void 0:S.find(y=>y.columnIndex===m))==null?void 0:f.expression,onChange:y=>u(m,y),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((m,d)=>{var h,S;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:!!((h=n==null?void 0:n.onClickFilter)!=null&&h.find(f=>f.columnIndex===d)),onCheckedChange:f=>l(d,f)}),e.jsx("label",{className:"text-sm font-medium leading-none peer-disabled:cursor-not-allowed peer-disabled:opacity-70",children:m}),e.jsx("div",{className:"flex items-center gap-2",children:((S=n==null?void 0:n.onClickFilter)==null?void 0:S.find(f=>f.columnIndex===d))&&e.jsx(t.Pencil,{onClick:()=>{a(f=>{const y=[...f];return y[d]=!f[d],y})},className:"invisible size-3 cursor-pointer text-gray-400 group-hover:visible"})})]}),c(d)]})},m)})]})}function wa({idx:s}){var u;const a=t.useEditorStore(c=>{var m;return(m=c.card)==null?void 0:m.preferences}),n=t.useEditorStore(c=>{var m;return(m=c.card.preferences)==null?void 0:m.datasetOptions}),r=t.useEditorStore(c=>c.actions.setCardPreferences),o=(u=a==null?void 0:a.chartOptions)==null?void 0:u.indexAxis,i=n==null?void 0:n.find(c=>c.idx===s);function l(c,m){(c==="end"||c==="start")&&t.getContrastColor(t.getCanvasBackgroundColor());const d={display:c!=="none",align:c,anchor:c,clamp:!0};if(!i)r({...a,datasetOptions:[...n||[],{idx:m,datalabels:d}]});else{const h={...i};h.datalabels=d;const S=n==null?void 0:n.map(f=>f.idx===m?h:f);r({...a,datasetOptions:S})}}return e.jsxs(t.Popover,{children:[e.jsx(t.PopoverTrigger,{children:e.jsx(ns,{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:()=>l("none",s),className:"h-7 p-1 text-xs font-normal",children:e.jsx(t.X,{className:"size-3.5"})}),e.jsx("button",{onClick:()=>l("start",s),className:"h-7 p-1 text-xs font-normal",children:e.jsx(vn,{className:t.cn("h-4 w-4",{"rotate-90":o==="y"})})}),e.jsx("button",{onClick:()=>l("center",s),className:"h-7 p-1 text-xs font-normal",children:e.jsx(Cn,{className:t.cn("h-4 w-4",{"rotate-90":o==="y"})})}),e.jsx("button",{onClick:()=>l("end",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"})})})]})})]})}function Ss(){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:l}=t.getKeys(i);o=l.slice(1)}return{transformedMetricKeys:o,dimensionKeys:n.slice(0,1),keys:n,defaultMetricKeys:r}}function Je({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 ws(){const s=t.useEditorStore(c=>c.card),a=t.useEditorStore(c=>{var m,d,h;return(h=(d=(m=c==null?void 0:c.card)==null?void 0:m.preferences)==null?void 0:d.chartOptions)==null?void 0:h.indexAxis}),{data:n}=t.useDashboardCardQuery(s),r=a==="y"?"Metric":"Dimension",o=a==="y"?"Dimension":"Metric",{dimensionKeys:i,transformedMetricKeys:l,keys:u}=Ss();return u.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(c=>e.jsx("p",{className:"flex h-8 items-center rounded-md bg-muted/70 px-3 hover:bg-muted",title:c,children:ks(c)},c))})]}),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:l.map((c,m)=>e.jsx(Es,{className:"flex h-8 items-center bg-muted/70 px-3 hover:bg-muted",iconClassName:"invisible group-hover:visible",col:c,idx:m},c))})]})]})}function ks(s,a=30){return s.length>a?s.slice(0,a)+"...":s}function Es({col:s,idx:a,className:n,iconClassName:r,children:o}){const i=t.useEditorStore(d=>{var h;return(h=d.card)==null?void 0:h.preferences}),l=t.useEditorStore(d=>{var h,S;return(S=(h=d.card)==null?void 0:h.preferences)==null?void 0:S.datasetOptions}),u=l==null?void 0:l.find(d=>d.idx===a),{setCardPreferences:c}=t.useEditorStore(d=>d.actions);function m(d){if(!u)c({...i,datasetOptions:[...l||[],{idx:a,type:d==="area"?"line":d,fill:d==="area"?"origin":""}]});else{const h={...u};h.type=d==="area"?"line":d,h.fill=d==="area"?"origin":"";const S=l==null?void 0:l.map(f=>f.idx===a?h:f);c({...i,datasetOptions:S})}}return e.jsxs("div",{className:t.cn("group flex items-center justify-between gap-2 rounded-md",n),children:[o||e.jsx(Je,{className:"max-w-[100px]",title:s,children:ks(s)}),e.jsxs("div",{className:"flex gap-2",children:[e.jsx(Ke,{onClick:()=>m("bar"),className:t.cn("size-4 cursor-pointer text-muted-foreground hover:text-foreground",r)}),e.jsx(Qe,{onClick:()=>m("line"),className:t.cn("size-4 cursor-pointer text-muted-foreground hover:text-foreground",r)}),e.jsx(tn,{onClick:()=>m("area"),className:t.cn("size-4 cursor-pointer text-muted-foreground hover:text-foreground",r)}),e.jsx(wa,{idx:a})]})]})}function Is(){const s=t.useEditorStore(f=>f.selectedConnectionId),a=t.useEditorStore(f=>f.selectedDatamodelId),n=t.useEditorStore(f=>f.selectedDatabaseName),r=t.useEditorStore(f=>f.selectedSchemaName),o=t.useEditorStore(f=>f.selectedTableName),i=t.useDashboardStore(f=>f.dashboard.filters)||[],l=t.useDashboardStore(f=>f.actions.addFilter),u=t.useDashboardStore(f=>f.actions.removeFilter),{removeFilterValues:c}=t.useDashboardActions(),{modelItems:m,tableName:d,connectionType:h}=t.useEditorAside();function S(f,y="dashboard"){var v;const x=t.fmt(f.column_name),g=t.fmt(n||""),p=t.fmt(r||""),C=t.fmt(d);let T=t.getQualifiedTableName({schemaName:p,tableName:C,connectionType:h,databaseName:g}),E=`${T}.${x}`;const j=(v=m==null?void 0:m.find(w=>w.id===a))==null?void 0:v.name;a&&a!=="none"&&(E=`${t.DATAMODEL_NAMESPCACE}.${j}.${x}`,T=`${t.DATAMODEL_NAMESPCACE}.${j}`);const b=i==null?void 0:i.find(w=>w.column===E&&w.table===C&&(w.database===g||w.database===n));if(b)c(b.id),u(b.id);else{const w=t.v4();return d==="api"&&s?(l({location:y,id:w,column:E,title:f.column_name,dataType:f.data_type,table:"api",database:"",connectionId:s,operation:"in",sql:t.getDefaultFilterSql(f.data_type,T,x)}),w):(l({id:w,location:y,column:E,title:f.column_name,dataType:f.data_type,table:o||"",database:n||"",connectionId:s||"",operation:"in",sql:t.getDefaultFilterSql(f.data_type,T,x)}),w)}}return{assignFilter:S}}function Te(){const s=t.useDashboardStore(u=>u.dashboard.filters),a=t.useEditorStore(u=>u.frame),{setFrame:n}=t.useEditorActions(),{columns:r}=t.useEditorAside(),{assignFilter:o}=Is();function i(u){const c=o(u,"frame");n({...a,filterId:c})}const l=s==null?void 0:s.find(u=>u.id===a.filterId);return e.jsxs("div",{className:"space-y-3",children:[e.jsx(t.Label,{children:"Card Filter"}),e.jsx(ka,{onSelect:i,columns:r}),l&&e.jsx(t.FilterHeader,{filter:l})]})}function ka({columns:s,onSelect:a}){var l;const[n,r]=ie.useState(!1),[o,i]=ie.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?(l=s.find(u=>u.column_name===o))==null?void 0:l.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(u=>e.jsxs(t.CommandItem,{value:u.column_name,onSelect:c=>{const m=c===o?"":c;i(m),r(!1),m&&a(u)},children:[u.column_name,e.jsx(t.CheckIcon,{className:t.cn("ml-auto h-4 w-4",o===u.column_name?"opacity-100":"opacity-0")})]},u.column_name))})]})]})})]})}function Ea({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(ws,{})})]}),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(ve,{}),e.jsx(Te,{})]})]})]})})}function zt(){var o,i,l;const s=t.useEditorStore(u=>u.card.type),a=t.useEditorStore(u=>u.card.preferences),{setCardPreferences:n}=t.useEditorStore(u=>u.actions);function r(u){var d;const c={datalabels:{display:u!=="none",align:u,anchor:u,clamp:!0}},m={...a,chartOptions:{...a==null?void 0:a.chartOptions,plugins:{...(d=a==null?void 0:a.chartOptions)==null?void 0:d.plugins,...c}}};n(m),console.log(u)}return e.jsxs("div",{className:"space-y-2",children:[e.jsx("label",{className:"font-medium",children:"Data Labels"}),e.jsxs(t.Select,{value:((l=(i=(o=a==null?void 0:a.chartOptions)==null?void 0:o.plugins)==null?void 0:i.datalabels)==null?void 0:l.anchor)||"none",onValueChange:r,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 Ia({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(zt,{})})]}),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(ve,{}),e.jsx(Te,{})]})]})]})})}const Da={datasets:[{type:"line",label:"Sum_sales",data:[]},{type:"bar",label:"Sum_profit",data:[]}]},Ta={datasets:[{fill:"origin",type:"line",label:"Sum_sales",data:[]}]};function Ma(){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:Aa(s)}),!["kpi"].includes(s)&&e.jsxs("div",{className:"space-y-4",children:[e.jsx(zt,{}),e.jsx(ve,{}),e.jsx(Te,{})]})]})}function Aa(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(Da,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(Ta,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 La(){var c,m,d,h,S;const s=t.useEditorStore(f=>f.card.preferences),a=t.useEditorStore(f=>f.actions.setCardPreferences),n=t.useEditorStore(f=>f.actions.setNumberFormat);t.useEditorStore(f=>{var y,x;return(x=(y=f.card.preferences)==null?void 0:y.formatNumber)==null?void 0:x.decimalPlaces});const r=t.useEditorStore(f=>{var y,x;return(x=(y=f.card.preferences)==null?void 0:y.formatNumber)==null?void 0:x.locale}),o=t.useEditorStore(f=>{var y,x;return(x=(y=f.card.preferences)==null?void 0:y.formatNumber)==null?void 0:x.currency});t.useEditorStore(f=>f.actions.setFilterOnClickField);const i=t.useEditorStore(f=>{var y,x;return(x=(y=f.card.preferences)==null?void 0:y.formatNumber)==null?void 0:x.colorRanges})||[],l=t.useEditorStore(f=>f.actions.setColorRanges),u=[...new Set(t.LOCALE_CURRENCY_PAIRS.map(f=>f.currency))];return e.jsxs("div",{children:[e.jsxs("div",{className:"mb-3 flex items-center gap-2",children:[e.jsx(t.Checkbox,{checked:!!((c=s==null?void 0:s.formatNumber)!=null&&c.enabled),onCheckedChange:f=>{a({...s,formatNumber:{...s==null?void 0:s.formatNumber,enabled:f}})}}),e.jsx(t.Label,{children:"Format Number"})]}),((m=s==null?void 0:s.formatNumber)==null?void 0:m.enabled)===!0&&e.jsxs("div",{className:"flex flex-col gap-2",children:[e.jsx("div",{children:e.jsxs("div",{className:"space-y-4 p-2",children:[e.jsxs("div",{className:"flex items-center gap-2",children:[e.jsxs("div",{className:"w-full space-y-1",children:[e.jsx(t.Label,{children:"Locale"}),e.jsxs(t.Select,{value:r||"none",onValueChange:f=>{var y,x,g;return n(((y=s==null?void 0:s.formatNumber)==null?void 0:y.decimalPlaces)||0,((x=s==null?void 0:s.formatNumber)==null?void 0:x.currency)||"",f,((g=s==null?void 0:s.formatNumber)==null?void 0:g.suffix)||"")},children:[e.jsx(t.SelectTrigger,{className:"col-span-6 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:"Format"}),e.jsx(t.SelectItem,{value:"none",children:"None"},"none"),t.LOCALE_CURRENCY_PAIRS.map(f=>e.jsx(t.SelectItem,{value:f.locale,children:f.locale},f.locale))]})})]})]}),e.jsxs("div",{className:"w-full space-y-1",children:[e.jsx(t.Label,{children:"Currency"}),e.jsxs(t.Select,{value:o||"none",onValueChange:f=>{var y,x,g;console.log("currency",f),n(((y=s==null?void 0:s.formatNumber)==null?void 0:y.decimalPlaces)||0,f==="none"?"":f,((x=s==null?void 0:s.formatNumber)==null?void 0:x.locale)||"",((g=s==null?void 0:s.formatNumber)==null?void 0:g.suffix)||"")},children:[e.jsx(t.SelectTrigger,{className:"col-span-6 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"},"none"),u.map(f=>e.jsx(t.SelectItem,{value:f,children:f},f))]})})]})]})]}),e.jsxs("div",{className:"flex gap-2",children:[e.jsxs("div",{className:"w-full space-y-1",children:[e.jsx(t.Label,{children:"Decimals"}),e.jsxs(t.Select,{value:((h=(d=s==null?void 0:s.formatNumber)==null?void 0:d.decimalPlaces)==null?void 0:h.toString())||"0",onValueChange:f=>{var y,x,g;return n(Number(f),((y=s==null?void 0:s.formatNumber)==null?void 0:y.currency)||"",((x=s==null?void 0:s.formatNumber)==null?void 0:x.locale)||"",((g=s==null?void 0:s.formatNumber)==null?void 0:g.suffix)||"")},children:[e.jsx(t.SelectTrigger,{className:"col-span-3 h-8 w-full focus:ring-1 focus:ring-offset-0",children:e.jsx(t.SelectValue,{})}),e.jsx(t.SelectContent,{children:["0","1","2","3","4"].map(f=>e.jsx(t.SelectItem,{value:f,children:f},f))})]})]}),e.jsxs("div",{className:"w-full space-y-1",children:[e.jsx(t.Label,{children:"Suffix"}),e.jsx(t.Input,{value:((S=s==null?void 0:s.formatNumber)==null?void 0:S.suffix)||"",className:"h-8 font-mono text-xs focus-visible:ring-0 focus-visible:ring-ring focus-visible:ring-offset-0",placeholder:"K, M, B, %",onChange:f=>{var y,x,g;return n(((y=s==null?void 0:s.formatNumber)==null?void 0:y.decimalPlaces)||0,((x=s==null?void 0:s.formatNumber)==null?void 0:x.currency)||"",((g=s==null?void 0:s.formatNumber)==null?void 0:g.locale)||"",f.target.value)}})]})]})]})}),e.jsx(t.Separator,{className:"my-3"}),e.jsx(t.ColorFormat,{colorRanges:i,setColorRanges:l})]})]})}function Oa(){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(La,{})}),e.jsx("div",{}),e.jsx("div",{})]})}function rt({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 Fa=[{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"}],Ba=["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"],za=Ba.map(s=>({label:s,value:s}));function Ra(){var c,m,d,h,S,f,y,x,g,p,C,T,E,j,b,v,w,I;const s=t.useEditorStore(D=>D.card),a=(m=(c=s==null?void 0:s.preferences)==null?void 0:c.mapVisualOptions)==null?void 0:m.topoJsonUrl,[n,r]=L.useState(((h=(d=s==null?void 0:s.preferences)==null?void 0:d.mapVisualOptions)==null?void 0:h.customTopoJsonUrl)||""),{setCardPreferences:o}=t.useEditorActions(),{data:i}=t.useTopoJson(s),l=Object.keys((i==null?void 0:i.objects)||{}).map(D=>({label:D,value:D}))||[],u=[{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(rt,{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(rt,{open:!0,summary:"Settings",children:e.jsxs("div",{className:"space-y-3 px-2",children:[e.jsx(de,{className:"h-9",options:u,onValueChange:D=>{console.log("value",D),o({...s.preferences,mapVisualOptions:{topoJsonUrl:D}})},value:a||"",label:"Select Map"}),a==="custom"&&e.jsx(t.Input,{onChange:D=>{r(D.target.value)},onBlur:()=>{var D;console.log("onBlur",n),o({...s.preferences,mapVisualOptions:{...(D=s.preferences)==null?void 0:D.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(de,{className:"h-9",options:l,value:((f=(S=s.preferences)==null?void 0:S.mapVisualOptions)==null?void 0:f.objectKey)||"",label:"Map Object",onValueChange:D=>{var N;o({...s.preferences,mapVisualOptions:{...(N=s.preferences)==null?void 0:N.mapVisualOptions,objectKey:D}})}})]}),e.jsxs("div",{className:"space-y-1",children:[e.jsx(t.Label,{children:"Projection"}),e.jsx(de,{className:"h-9",options:Fa,value:((x=(y=s.preferences)==null?void 0:y.mapVisualOptions)==null?void 0:x.projection)||"",label:"Projection",onValueChange:D=>{var N;o({...s.preferences,mapVisualOptions:{...(N=s.preferences)==null?void 0:N.mapVisualOptions,projection:D}})}})]}),e.jsxs("div",{className:"space-y-1",children:[e.jsx(t.Label,{children:"Colors"}),e.jsx(de,{className:"h-9",options:za,value:((p=(g=s.preferences)==null?void 0:g.mapVisualOptions)==null?void 0:p.colorScale)||"",label:"Select Color Scale",onValueChange:D=>{var N;o({...s.preferences,mapVisualOptions:{...(N=s.preferences)==null?void 0:N.mapVisualOptions,colorScale:D}})}})]})]})]})}),e.jsx(t.Separator,{className:"my-4"}),e.jsx(rt,{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:((T=(C=s.preferences)==null?void 0:C.mapVisualOptions)==null?void 0:T.projectionScale)||1,onChange:D=>{var N;o({...s.preferences,mapVisualOptions:{...(N=s.preferences)==null?void 0:N.mapVisualOptions,projectionScale:Number(D.target.value)}})}}),e.jsx(t.Label,{children:"X"}),e.jsx(t.Input,{className:`h-9 w-full ${t.removeRing}`,type:"number",step:10,value:((b=(j=(E=s.preferences)==null?void 0:E.mapVisualOptions)==null?void 0:j.projectionOffset)==null?void 0:b[0])||0,onChange:D=>{var N,F,O,A;o({...s.preferences,mapVisualOptions:{...(N=s.preferences)==null?void 0:N.mapVisualOptions,projectionOffset:[Number(D.target.value),((A=(O=(F=s.preferences)==null?void 0:F.mapVisualOptions)==null?void 0:O.projectionOffset)==null?void 0:A[1])||0]}})}}),e.jsx(t.Label,{children:"Y"}),e.jsx(t.Input,{className:`h-9 w-full ${t.removeRing}`,type:"number",step:10,value:((I=(w=(v=s.preferences)==null?void 0:v.mapVisualOptions)==null?void 0:w.projectionOffset)==null?void 0:I[1])||0,onChange:D=>{var N,F,O,A;o({...s.preferences,mapVisualOptions:{...(N=s.preferences)==null?void 0:N.mapVisualOptions,projectionOffset:[((A=(O=(F=s.preferences)==null?void 0:F.mapVisualOptions)==null?void 0:O.projectionOffset)==null?void 0:A[0])||0,Number(D.target.value)]}})}})]})}),e.jsx(t.Separator,{className:"my-4"}),e.jsx(ve,{})]})}function Pa(){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 Ve({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(zt,{}),s==="text"&&e.jsx(Pa,{})]})]}),!["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(ve,{}),e.jsx(Te,{})]})]})]})})}function Va(){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(de,{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(ws,{})]})]}),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(ve,{}),e.jsx(Te,{})]})]})]})})}function qa({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(ve,{}),e.jsx(Te,{})]})]})}),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 _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 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."]})]}),$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 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."]})]}),Ga=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 Ha(){const s=t.useEditorStore(n=>n.card.type);function a(n){switch(n){case"stackedBar":case"stackedLine":return e.jsx(Va,{});case"tornado":case"pyramid":return e.jsx(Ve,{docContent:_a,cardType:n});case"kpi":return e.jsx(Oa,{});case"line":case"bar":return e.jsx(Ea,{cardType:n});case"range":return e.jsx(Ve,{docContent:$a,cardType:n});case"pie":case"doughnut":case"polarArea":case"radar":case"funnel":return e.jsx(Ve,{cardType:n});case"bubble":case"scatter":return e.jsx(Ia,{cardType:n});case"table":return e.jsx(qa,{cardType:n});case"text":return e.jsx(Ve,{docContent:Ga,cardType:n,suffix:"Visual"});case"map":return e.jsx(Ra,{});case"custom":return e.jsx(Sa,{});default:return e.jsx(Ma,{})}}return e.jsxs(t.ScrollArea,{className:"h-full w-full text-sm",children:[a(s),e.jsx(t.ScrollBar,{orientation:"horizontal"})]})}function Ds({label:s,column:a,functions:n,onFunctionChange:r}){let o=n[0];"aggregate"in a?o=n.find(l=>l.value===a.aggregate)||n[0]:"granularity"in a&&(o=n.find(l=>l.value===a.granularity)||n[0]);function i(l){r(l)}return e.jsx(de,{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:l=>i(l),label:s,showPlaceholderLabel:!1})}const Ja=[{label:"Sum",value:"SUM",logo:e.jsx(ss,{className:"size-3.5"})},{label:"Count",value:"COUNT",logo:e.jsx(St,{className:"size-3.5"})},{label:"Unique",value:"DISTINCT",logo:e.jsx(pn,{className:"size-3.5"})},{label:"Average",value:"AVG",logo:e.jsx(Hs,{className:"size-3.5"})},{label:"Min",value:"MIN",logo:e.jsx(Ue,{className:"size-3.5"})},{label:"Max",value:"MAX",logo:e.jsx(Ye,{className:"size-3.5"})}];function Ua({column:s}){const{updateMetricColumnOld:a}=t.useEditorActions();let n=Ja;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:Le(s.name,o)};a(s.id,i)}return e.jsx(Ds,{column:s,functions:n,onFunctionChange:o=>r(o),label:"Aggregation"})}const Ya=[{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 Ka({column:s}){const{updateGroupByColumnOld:a}=t.useEditorActions();function n(r){const o={...s,granularity:r,label:De(s.name,r)};a(s.id,o)}return e.jsx(Ds,{column:s,functions:Ya,onFunctionChange:r=>n(r),label:"Granularity"})}function Qa({col:s,onChange:a,droppableId:n}){const{columns:r}=t.useDataColumns(),o=L.useMemo(()=>{let u=[];(n===ge||n===je||n===ye)&&(u=r);const c=u==null?void 0:u.filter(m=>m.column_name!==s.name);return c==null?void 0:c.map(m=>({id:m.column_name,value:m.column_name}))},[r,n,s.name]),i=[{id:s.name,value:s.name}];function l(u){const c=r==null?void 0:r.find(m=>{var d;return m.column_name===((d=u[0])==null?void 0:d.id)});c&&a(c)}return o!=null&&o.length?e.jsx(t.ComboBox2,{multiple:!1,options:o,selectedOptions:i,onChange:l,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 Wa({column:s}){const{updateMetricColumnOld:a}=t.useEditorActions(),{transformedMetricKeys:n,dimensionKeys:r}=Ss();console.log(n,r);const o=t.useEditorStore(c=>{var m;return(m=c.card.queryConfig)==null?void 0:m.pivotColumns}),i=!!(o&&o.length>0),l=n.find(c=>c===s.label||c===s.name),u=l?n.indexOf(l):-1;return e.jsxs("div",{className:"space-y-3",children:[l&&e.jsx(Es,{idx:u,col:l,children:e.jsx(t.Editable,{enabled:!0,className:"w-[130px]",text:s.label||"",placeholder:"Enter label",onSave:c=>{a(s.id,{...s,label:c||s.name})},children:e.jsx(Je,{className:"w-[130px]",children:s.label||s.name})})}),i&&e.jsxs("div",{className:"flex items-center justify-between gap-2",children:[e.jsx(t.Label,{children:"Pivot Header"}),e.jsx(t.Editable,{enabled:!0,text:s.aliasTemplate||"",placeholder:"{label} ({pivot})",onSave:c=>{a(s.id,{...s,aliasTemplate:c||""})},children:e.jsx(Je,{className:"font-mono text-xs text-muted-foreground",children:s.aliasTemplate||"{label} ({pivot})"})})]})]})}function Xa({column:s,type:a,onRemoveColumn:n,droppableId:r}){const[o,i]=L.useState(!1),{updateGroupByColumnOld:l,updateMetricColumnOld:u,updatePivotByColumnOld:c}=t.useEditorActions(),{attributes:m,listeners:d,setNodeRef:h,transform:S,transition:f,isDragging:y}=t.useSortable({id:s.id,data:{type:a}}),x=S?{opacity:y?.5:void 0,transform:t.CSS.Translate.toString(S),transition:f}:void 0,g=t.isTextDataType(s.type);function p(b){const v=t.isNumberDataType(b.data_type),w=t.isTextDataType(b.data_type),I=t.isDateDataType(b.data_type),D=v?"number":w?"string":I?"date":"string";if(r===ge){if(w){const N={id:s.id,name:b.column_name,type:D,role:"groupby"};l(s.id,N)}if(I){const N={id:s.id,name:b.column_name,type:D,role:"groupby",label:De(b.column_name,"month"),granularity:"month"};l(s.id,N)}}if(r===ye){if(w){const N={id:s.id,name:b.column_name,type:D,role:"groupby"};c(s.id,N)}if(I){const N={id:s.id,name:b.column_name,type:D,label:De(b.column_name,"month"),granularity:"month",role:"groupby"};c(s.id,N)}}if(r===je){const N={id:s.id,name:b.column_name,type:D,role:"metric",label:Le(b.column_name,"SUM"),aggregate:v?"SUM":"COUNT"};u(s.id,N)}}function C(){if(r===je)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(Wa,{column:s})})}function T(){const b=t.isDateDataType(s.type);if(r===je)return e.jsx(Ua,{column:s});if((r===ge||r===ye)&&b)return e.jsx(Ka,{column:s})}function E(){return e.jsx("div",{className:t.cn("grow",{"pl-3":(r===ge||r===ye)&&g}),children:e.jsx(Qa,{col:s,onChange:p,droppableId:r})})}function j(){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(Ln,{className:t.cn("size-3 cursor-pointer items-center justify-center rounded-r-sm text-muted-foreground")}):e.jsx(es,{className:t.cn("size-3 cursor-pointer items-center justify-center rounded-r-sm text-muted-foreground")})})})}return e.jsx("div",{...d,...m,ref:h,style:x,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:[j(),T(),E()]}),o&&C()]}),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 ot({id:s,label:a,columns:n,previewColumns:r,sortableType:o,onRemoveColumn:i}){var x,g;const{setNodeRef:l,isOver:u,over:c}=t.useDroppable({id:s}),m=t.useDndStore(p=>p.activeId),d=t.useEditorStore(p=>{var C;return(C=p.card)==null?void 0:C.type}),h=u||((g=(x=c==null?void 0:c.data)==null?void 0:x.current)==null?void 0:g.type)===o,S=m?r:n,f=o===_e?"Rows":o===$e?"Pivot Columns":"Columns";function y(){if(!S||S.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",h&&"border border-muted-foreground/20"),ref:l,children:[e.jsxs("div",{className:"flex items-center justify-between pr-5",children:[e.jsx(t.Label,{className:"text-sm",children:a}),d!=="table"&&e.jsx("span",{className:"text-xs text-muted-foreground/50",children:f})]}),y(),e.jsx("div",{className:"space-y-2",children:S==null?void 0:S.map(p=>p.id===ds.id?e.jsx(Za,{},p.id):e.jsx(Xa,{droppableId:s,type:o,column:p,onRemoveColumn:i},p.id))})]})})}function Za(){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 Ts({children:s,id:a,type:n}){const{attributes:r,listeners:o,setNodeRef:i,transform:l,transition:u,isDragging:c}=t.useSortable({id:a,data:{type:n}}),m=l?{opacity:c?.5:void 0,transform:t.CSS.Translate.toString(l),transition:u}:void 0;return e.jsx("div",{...o,...r,ref:i,style:m,children:s})}function er(){const s=t.useEditorStore(p=>{var C;return(C=p.card.queryConfig)==null?void 0:C.orderBy})||[],a=t.useEditorStore(p=>{var C;return(C=p.card.queryConfig)==null?void 0:C.groupByColumns})||[],n=t.useEditorStore(p=>{var C;return(C=p.card.queryConfig)==null?void 0:C.metricColumns})||[],{addOrderByColumn:r,removeOrderByColumn:o,updateOrderByColumn:i}=t.useEditorActions(),l=[...a,...n];if(l.length===0)return e.jsx(e.Fragment,{});const u=e.jsx(Ks,{className:"size-3.5 text-muted-foreground hover:text-foreground"}),c=e.jsx(Gs,{className:"size-3.5 text-muted-foreground hover:text-foreground"}),m=e.jsx(Ys,{className:"size-3.5 text-muted-foreground hover:text-foreground"}),d=e.jsx($s,{className:"size-3.5 text-muted-foreground hover:text-foreground"}),h=l==null?void 0:l.filter(p=>!s.some(C=>C.columnId===p.id)).map(p=>({id:p.id,value:p.label||p.name}));function S(p,C){const T=f(p);return T?T.role==="metric"?C==="asc"?m:d:C==="asc"?u:c:null}function f(p){return l.find(C=>C.id===p)}function y(p){const C=s.find(T=>T.columnId===p);if(C){const T={...C,direction:C.direction==="asc"?"desc":"asc"};i(T)}}const x=p=>{r({columnId:p.id,direction:"asc"})};function g(p){const C=s.find(T=>T.columnId===p);C&&o(C)}return e.jsx(t.SortableContext,{items:s.map(p=>Ae(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"}),h.length>0&&e.jsx("div",{className:"mr-5",children:e.jsx(t.ComboBox2,{multiple:!1,options:h,selectedOptions:[],onChange:p=>x(p[0]),selectAllChecked:!1,onSelectAllCheckedChange:()=>{},inputClassName:"h-8 bg-muted border-none"})}),s.map(p=>{var C,T;return e.jsx(Ts,{id:Ae(p.columnId),type:Mt,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(es,{className:"size-3 cursor-move text-muted-foreground hover:text-foreground"}),e.jsx(Je,{className:"w-[175px] text-sm",children:((C=f(p.columnId))==null?void 0:C.label)||((T=f(p.columnId))==null?void 0:T.name)})]}),e.jsx("button",{title:p.direction==="asc"?"Ascending":"Descending",onClick:()=>y(p.columnId),className:"rounded-sm p-0",children:S(p.columnId,p.direction)})]}),e.jsx("div",{children:e.jsx("button",{onClick:()=>g(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)},Ae(p.columnId))})]})})}function tr(){const s=t.useEditorStore(g=>{var p;return((p=g.card.queryConfig)==null?void 0:p.groupByColumns)||[]}),a=t.useEditorStore(g=>g.card.type),n=t.useDndStore(g=>g.previewGroupByColumns),r=t.useEditorStore(g=>{var p;return((p=g.card.queryConfig)==null?void 0:p.metricColumns)||[]}),o=t.useDndStore(g=>g.previewMetricColumns),i=t.useEditorStore(g=>{var p;return((p=g.card.queryConfig)==null?void 0:p.pivotColumns)||[]}),l=t.useDndStore(g=>g.previewPivotColumns),{removeColumnFromGroupBy:u,removeColumnFromMetricColumns:c,removeColumnFromPivotBy:m}=t.useEditorActions();function d(g){u(g)}function h(g){c(g)}function S(g){m(g)}let f="Group By",y="Metrics",x="Stack By";return a==="table"&&(f="Rows",y="Metrics",x="Columns"),e.jsxs("div",{className:"flex h-full w-full flex-col gap-3 py-4",children:[e.jsx(bs,{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(ot,{onRemoveColumn:d,sortableType:_e,id:ge,label:f,columns:s,previewColumns:n}),e.jsx(ot,{onRemoveColumn:S,sortableType:$e,id:ye,label:x,columns:i,previewColumns:l}),e.jsx(ot,{onRemoveColumn:h,sortableType:ht,id:je,label:y,columns:r,previewColumns:o}),e.jsx(er,{})]}),e.jsx(t.ScrollBar,{orientation:"horizontal"})]})]})}function Rt({children:s,column:a,id:n,sortableType:r,className:o}){const[i,l]=L.useState(!1),{removeEditorFilter:u,clearEditorFilter:c}=t.useEditorActions(),m=t.useEditorStore(h=>{var S,f;return(f=(S=h.card.queryConfig)==null?void 0:S.filters)==null?void 0:f.some(y=>y.filterColumnName===a.name)});function d(h){u(h)}return e.jsx(Ts,{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}),m&&e.jsx("button",{onClick:()=>c(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:()=>d(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 sr({column:s,sortableType:a}){const n=t.useDashboardStore(T=>T.themeStyle),r=t.useEditorStore(T=>{var E,j;return(j=(E=T.card)==null?void 0:E.queryConfig)==null?void 0:j.filters}),o=t.useEditorStore(T=>{var E,j;return(j=(E=T.card.queryConfig)==null?void 0:E.filterColumns)==null?void 0:j.find(b=>b.name===s.name)}),{selectedConnectionId:i,selectedDatabaseName:l,selectedTableName:u}=t.useEditorAside(),c=L.useMemo(()=>{var T;return(T=r==null?void 0:r.find(E=>E.filterColumnName===s.name))==null?void 0:T.filterValue},[r,s.name]),m=L.useMemo(()=>Array.isArray(c)?c.map(T=>({id:T,value:T})):[],[c]),{updateEditorFilterValue:d}=t.useEditorActions(),h={column:s.name,sql:s.sql,id:s.name,connectionId:i,dataType:s.type},{data:S,isLoading:f,isFetching:y,isError:x}=t.useFilterQuery(h),g=L.useMemo(()=>{var E;return h.column?(E=S==null?void 0:S.records)==null?void 0:E.map(j=>{let b=h.column.split(".").slice(-1)[0].replace(/"/g,"");return j[b]===void 0&&(b=b.toLowerCase()),{id:j[b],value:j[b]}}):[]},[S,h.column]);function p(T){const E=T.map(j=>j.id);d(s.name,E)}function C(){return f||y?e.jsx(t.Skeleton,{style:{borderRadius:n==null?void 0:n.controlInputRadius},className:"h-8 min-w-60 bg-foreground/10"}):x?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(nr,{columnName:s.name}),showNegativeIndicator:(o==null?void 0:o.mode)==="exclude",options:g,onChange:p,selectedOptions:m,selectAllChecked:!1,onSelectAllCheckedChange:()=>{}})}return e.jsx(Rt,{className:"w-60",id:s.id,sortableType:a,column:s,children:C()})}function nr({columnName:s}){const{setEditorFilterMode:a}=t.useEditorActions(),n=t.useEditorStore(o=>{var i,l;return(l=(i=o.card.queryConfig)==null?void 0:i.filterColumns)==null?void 0:l.find(u=>u.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 ar({column:s,sortableType:a}){const[n,r]=L.useState(!1),{selectedConnectionId:o,selectedDatabaseName:i,selectedTableName:l}=t.useEditorAside(),u={column:s.name,sql:s.sql,id:s.name,connectionId:o,title:"",dataType:s.type},{isLoading:c,isFetching:m,isError:d,data:h}=t.useFilterQuery(u),S=h==null?void 0:h.records,{dateRange:f,setDateRange:y,initialDateRange:x}=t.useDateRangeFromRecords(S),{updateEditorFilterValue:g}=t.useEditorActions();function p(E){var b,v;const j={gte:(b=E==null?void 0:E.from)==null?void 0:b.toISOString(),lte:(v=E==null?void 0:E.to)==null?void 0:v.toISOString()};g(s.name,j)}function C(){g(s.name,null,!0),y(x)}function T(){return c||m?e.jsx("div",{children:e.jsx(t.Skeleton,{className:"h-8 w-72 bg-foreground/10"})}):d?e.jsx("div",{className:"h-8 w-72 bg-muted px-2",children:"Error"}):S?e.jsx(t.DateRangePopover,{title:u.title,open:n,inputClassName:"h-8",setOpen:r,dateRange:f,setDateRange:y,onApply:p,onClear:C}):e.jsx(t.Label,{className:"flex h-8 w-72 items-center bg-muted px-2",children:"No Data"})}return e.jsx(Rt,{className:"w-72",id:s.id,sortableType:a,column:s,children:T()})}function rr({id:s,label:a,columns:n,previewColumns:r,sortableType:o}){var y,x;const{setNodeRef:i,isOver:l,over:u}=t.useDroppable({id:s}),c=t.useDndStore(g=>g.activeId),m={},d=l||((x=(y=u==null?void 0:u.data)==null?void 0:y.current)==null?void 0:x.type)===o;function h(){if(!f||f.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 S(g){const p=t.isDateDataType(g.type);return g.id===ds.id?e.jsx(Rt,{id:g.id,sortableType:o,column:g,children:e.jsx(or,{})},g.id):p?e.jsx(ar,{droppableId:s,sortableType:o,column:g},g.id):e.jsx(sr,{droppableId:s,sortableType:o,column:g},g.id)}const f=c?r:n;return e.jsx(t.SortableContext,{items:n==null?void 0:n.map(g=>g.id),children:e.jsxs("div",{className:t.cn("group space-y-2 rounded-md border-muted-foreground/50 p-4",d&&"border border-muted-foreground/20"),ref:i,style:m,children:[e.jsx(t.Label,{className:"text-sm",children:a}),h(),e.jsx("div",{className:"flex flex-wrap items-center gap-4",children:f==null?void 0:f.map(g=>S(g))})]})})}function or(){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 ir(){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(rr,{onRemoveColumn:r,sortableType:pt,id:xt,label:"Filters",columns:s,previewColumns:a})})}function lr(){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(In,{className:"mr-2 h-4 w-4"}),"Assistant"]}),e.jsx(hs,{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 cr(){const s=L.useRef(null),a=L.useRef(null),n=t.useEditorStore(u=>u.isShowingVisual),r=t.useEditorStore(u=>u.showAIDialog),o=t.useEditorStore(u=>u.isDevMode);L.useEffect(()=>{var u,c,m,d;r?((u=s.current)==null||u.resize(0),(c=a.current)==null||c.resize(0)):((m=s.current)==null||m.resize(25),(d=a.current)==null||d.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(ia,{})}),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(Ha,{})})}),!r&&e.jsx(t.ResizableHandle,{}),e.jsx(t.ResizablePanel,{minSize:40,defaultSize:75,maxSize:100,children:e.jsx(Pe,{})})]}):e.jsx(Pe,{})})]})}function l(){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(tr,{})})}),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(lr,{}),e.jsx(ir,{})]}),e.jsx(t.ResizableHandle,{}),e.jsx(t.ResizablePanel,{minSize:60,defaultSize:80,children:e.jsx(Pe,{})})]})})]}):e.jsx(Pe,{})})})}return e.jsx(t.ResizablePanelGroup,{direction:"vertical",className:"min-h-[250px] min-w-full max-w-lg",children:o?i():l()})}function dr(s,a){const[n,r]=L.useState(""),[o,i]=L.useState(null),{authToken:l}=t.useSemaphorContext(),u=t.useEditorStore($=>{var Q;return(Q=$==null?void 0:$.card)==null?void 0:Q.sql}),c=t.useEditorStore($=>$.isDevMode),m=t.useEditorStore($=>{var Q;return(Q=$==null?void 0:$.card)==null?void 0:Q.python}),{setCardPython:d,setCardSql:h,setRunSql:S,switchCardType:f,setQueryConfig:y}=t.useEditorActions(),x=t.useEditorStore($=>$.currentAssitantScope)||[],g=t.useEditorStore($=>$.userInputForAI),p=t.useEditorStore($=>$.triggerAIRun),C=t.useEditorStore($=>$.card),T=t.useEditorStore($=>$.selectedDatabaseName),E=t.useEditorStore($=>$.selectedTableName),j=t.useEditorStore($=>$.selectedConnectionId),b=t.useEditorStore($=>$.selectedSchemaName),v=t.useDashboardStore($=>$.dashboard.aiScopeTables),{errorMessage:w,refetch:I,data:D}=t.useDashboardCardQuery(C),{setTriggerAIRun:N,setCurrentAssitantScope:F,setCardConfig:O}=t.useEditorActions(),{selectedDatamodelName:A,connectionType:k,selectedDatamodelId:M}=t.useEditorAside(),{messages:B,setMessages:z,reload:P,error:R,append:K,input:J,setInput:_,status:U,handleInputChange:q,handleSubmit:V,stop:G}=t.useChat({api:"https://semaphor.cloud/api/v1/assistant",headers:{Authorization:`Bearer ${l==null?void 0:l.accessToken}`},body:{random:Math.random(),assistantId:"editor-assistant",isDevMode:c,aiContext:s},maxSteps:10,onError:$=>{console.log("on error",$)},onToolCall:H,onFinish($,Q){Y(Q.usage),r(""),Q.finishReason==="stop"&&r("")}});L.useEffect(()=>{p&&g&&(q({target:{value:g}}),setTimeout(()=>{V(),N(!1)},100))},[p,V,g,N,q]);async function H({toolCall:$}){var Q,he,we,Me;if(["createChartFromSql","createForecast"].includes($.toolName)){const W=$.args.sql,se=$.args.python,ne=$.args.chartType;return f(ne),h(W),d(se),S(!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 u?{status:"success",sql:u,python:m||""}:{status:"error",message:"No SQL found"};if($.toolName==="getCurrentTableScope")return r("Getting table scope..."),pe(),{status:"success",tables:x};if($.toolName==="generateQueryConfig"){r("Generating query config...");const W=$.args.chartType,se=$.args.queryConfig;$.args.cardConfig,f(W),O(se),h(void 0),d(void 0);const ne=await I();return(Q=ne==null?void 0:ne.data)!=null&&Q.error?{status:"error",queryConfig:se,message:(he=ne==null?void 0:ne.data)==null?void 0:he.error.message}:(we=ne==null?void 0:ne.data)!=null&&we.records?{status:"success",queryConfig:se,message:"The data has been visualized"}:{status:"success",queryConfig:se,message:"No records found",records:(Me=ne==null?void 0:ne.data)==null?void 0:Me.records}}else r("Analyzing...")}}function Y($){i(Q=>Q?{promptTokens:Q.promptTokens+$.promptTokens,completionTokens:Q.completionTokens+$.completionTokens,totalTokens:Q.totalTokens+$.totalTokens}:$)}function Z($){const Q=t.removeFromScopeArray(x,$);ae(Q)}function ae($){const Q=t.sanitizeAIScope($);F(Q),z(he=>[...he,{id:crypto.randomUUID(),role:"system",content:`Current scope of tables. Always use the table reference format when generating SQL | ${JSON.stringify(Q)}`}])}function Ne(){const $={databaseName:T||"",schemaName:b||"",tableName:E||"",datamodelId:M||"",datamodelName:t.resolveDatamodelName(A),connectionId:j||"",connectionType:k||""},Q=t.dedup([...x,$]);ae(Q)}function pe(){const $={databaseName:T||"",schemaName:b||"",tableName:E||"",datamodelName:t.resolveDatamodelName(A),connectionId:j||"",connectionType:k||"",datamodelId:M||""};if(!t.isInAiScopeArray([...v||[],...x],$)||x.length===0){const he=t.dedup([...v||[],...x,$]).filter(we=>we.connectionId===$.connectionId);ae(he)}}const Ce=!["ready","error"].includes(U),Se=t.getErrorMessage(R);return{messages:B,setMessages:z,reload:P,append:K,input:J,setInput:_,isLoading:Ce,handleSetAIScope:pe,handleAddCurrentTableToScope:Ne,removeFromCurrentSelections:Z,currentAssitantScope:x,setCurrentAssitantScope:F,handleInputChange:q,handleSubmit:V,stop:G,chatStatus:U,toolStatus:n,llmUsage:o,onFinish:a,errorMessage:Se}}const ur=[{title:"Help me write a query for",subtitle:"orders by month"},{title:"Create a bar chart for",subtitle:"sales by category"}];function Kt(){const s=L.useRef(null),a=L.useRef(null),[n,r]=L.useState(!1),[o,i]=L.useState(t.isDevEnv),[l,u]=L.useState(!1),[c,m]=L.useState(!1),[d,h]=L.useState({selectedEntities:[]}),S=t.useDashboardStore(G=>G.dashboard.aiContext),f=t.useEditorStore(G=>G.card.dataSource),y=t.useEditorStore(G=>G.actions.setCardSql),x=t.useEditorStore(G=>G.actions.setRunSql),g=t.useEditorStore(G=>G.showAIDialog),p=t.useDashboardStore(G=>G.handleOpenAssistantProfile),{setShowAIDialog:C,setCardPython:T}=t.useEditorActions(),{setDataSource:E}=t.useEditorActions(),{assistantProfile:j}=t.useAssistantProfile(),{messages:b,setMessages:v,reload:w,append:I,input:D,setInput:N,isLoading:F,handleInputChange:O,handleSubmit:A,stop:k,chatStatus:M,llmUsage:B,errorMessage:z}=dr(d);t.useAssistantScroll({scrollContainerRef:s,inputRef:a,messages:b}),L.useEffect(()=>{var G;g&&((G=a.current)==null||G.focus(),h({selectedEntities:(f==null?void 0:f.selectedEntities)||[]}))},[g,f]);function P(G,H){H==="sql"?(y(G),x(!0)):H==="python"&&(T(G),x(!0))}function R(){var G;(G=S==null?void 0:S.selectedEntities)==null||G[0],m(!0)}function K(){d.selectedEntities.length===0&&h({selectedEntities:(S==null?void 0:S.selectedEntities)||[]})}function J(G){K();const H={role:"user",content:G.title+" "+G.subtitle};I(H)}function _(G){K(),I({role:"user",content:G})}function U(){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:l,onCheckedChange:u,children:"System Message"})]})]})}function q(){return e.jsx("div",{"data-role":"header",children:e.jsx("div",{className:"text-lg font-semibold",children:"Assistant"})})}const V=(D==null?void 0:D.length)===0&&(b==null?void 0:b.filter(G=>G.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:[q(),p&&e.jsx(t.Button,{variant:"outline",size:"sm",className:"h-7 p-2",onClick:p,children:(j==null?void 0:j.name)||"Default Profile"}),e.jsxs("div",{"data-role":"header-actions",className:"flex items-center gap-2",children:[U(),e.jsx(t.IconButton,{tooltip:"Add Context",className:"h-7 p-2",onClick:R,children:e.jsx(t.Settings,{className:"size-4"})}),e.jsx(t.IconButton,{className:"h-7 p-2",tooltip:"New Chat",onClick:()=>{v([]),w()},children:e.jsx(t.SquarePen,{className:"size-4"})}),e.jsx(t.Button,{variant:"ghost",className:"h-8",size:"sm",onClick:()=>{C(!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:b,showTools:o,handleRun:P,showSystemMessage:l}),e.jsx(t.ChatStatus,{messages:b,chatStatus:M,errorMessage:z})]})}),e.jsxs("div",{className:"mb-3",children:[V&&!j&&e.jsx(t.Placeholders,{onClick:J,placeholders:ur}),e.jsx("div",{children:V&&j&&e.jsx(t.SeedQuestions,{seedQuestions:j.seedQuestions||[],handleSeedQuestionClick:_})})]}),e.jsx(t.ChatInputWithContext,{ref:a,setInput:N,stop:k,input:D,localAiContext:d,setLocalAiContext:h,handleInputChange:O,handleSubmit:G=>{K(),A(G)},isLoading:F,onFocus:()=>{}}),B&&n&&e.jsx("div",{className:"flex h-8 items-center justify-between",children:e.jsxs("div",{className:"text-xs text-muted-foreground",children:["Usage: ",B.promptTokens," prompt tokens,"," ",B.completionTokens," completion tokens,"," ",B.totalTokens," total tokens"]})}),e.jsx(t.DataSourceDialog,{incomingSelectedEntities:(f==null?void 0:f.selectedEntities)||[],open:c,onOpenChange:m,dataSource:f||t.EMPTY_DATA_SOURCE,fallbackDataSource:t.EMPTY_DATA_SOURCE,dialogMode:"aiContext"})]})}function mr(s){return s.flatMap(a=>a.columns.map(n=>({id:`${a.entityId}-${n.name}`,name:n.name,dataType:n.dataType,qualifiedEntityName:a.qualifiedEntityName,label:n.label||t.toTitleCase(n.name),description:n.description,entityId:a.entityId,entityName:a.entityName,entityType:a.entityType})))}function ft(s){if(s.type==="table"||s.type==="view"){if(s.database&&s.schema)return`${s.database}.${s.schema}.${s.name}`;if(s.database)return`${s.database}.${s.name}`}return s.name}function ze(s){var x;const a=t.useDashboardStore(g=>g.authToken)||s,{hasSchemaSupport:n}=t.useSelectedConnection(s),r=t.useEditorStore(g=>{var p;return(p=g.card.dataSource)==null?void 0:p.connectionId}),o=t.useEditorStore(g=>{var p,C;return(C=(p=g.card.dataSource)==null?void 0:p.selectedEntities)==null?void 0:C.filter(T=>T.type==="model")})||[],i=t.useEditorStore(g=>{var p,C;return(C=(p=g.card.dataSource)==null?void 0:p.selectedEntities)==null?void 0:C.filter(T=>T.type==="table"||T.type==="view")})||[],l=t.useEditorStore(g=>{var p,C;return(C=(p=g.card.dataSource)==null?void 0:p.selectedEntities)==null?void 0:C.filter(T=>T.type==="dataset")})||[];function u(g){return g.type==="dataset"?!!r&&!!g.domainId&&!!g.name:g.type==="model"?!!r&&!!g.id:g.type==="table"||g.type==="view"?n?!!r&&!!g.name&&!!g.database&&!!g.schema:!!r&&!!g.name&&!!g.database:!1}const c=[...o,...i,...l],m=Ps({queries:c.map(g=>{let p={};return g.type==="model"?p={connection_id:r,datamodel_id:g.id,database_name:"",schema_name:"",table_name:"",domain_id:g.domainId,dataset_name:g.name}:g.type==="dataset"?p={connection_id:g.connectionId,domain_id:g.domainId,dataset_name:g.name}:p={connection_id:r,datamodel_id:"",database_name:g.database,schema_name:g.schema,table_name:g.name},{queryKey:["columns",r,g],queryFn:()=>t.getRequest("https://semaphor.cloud/api/v1/columns",(a==null?void 0:a.accessToken)||"",p),enabled:!!r&&u(g)}})}),d=m.some(g=>g.isPending),h=m.some(g=>g.isError),S=(x=m.find(g=>g.isError))==null?void 0:x.error,f=m.map((g,p)=>{var E;const C=c[p],T=ft(C);return{entityId:C.id||C.name,entityType:C.type,entityName:C.name,label:C.label,description:C.description,qualifiedEntityName:T,columns:(E=g.data)==null?void 0:E.columns.map(j=>({id:`${C.name}-${j.column_name}`,name:j.column_name,dataType:j.data_type,label:j.label||t.toLabel(j.column_name),description:j.description||"",qualifiedEntityName:T,entityId:C.id||C.id||C.name,entityName:C.name,entityType:C.type}))}}).filter(g=>{var p;return((p=g==null?void 0:g.columns)==null?void 0:p.length)>0})||[],y=mr(f);return{columnGroups:f,columns:y,isLoading:d,hasError:h,error:S,refetch:()=>{m.forEach(g=>g.refetch())}}}function hr({field:s}){const{attributes:a,listeners:n,setNodeRef:r,transform:o,transition:i,isDragging:l}=t.useSortable({id:s.id}),[u,c]=L.useState(!1),m={transform:t.CSS.Transform.toString(o),transition:i},d=t.getDataType(s.dataType),S=(f=>{const y=(f||"").toLowerCase();switch(t.getDataType(y)){case"number":return St;case"date":return t.Calendar;case"boolean":return as;case"json":return rn;case"geo":return kn;default:return rs}})(s.dataType);return e.jsxs("div",{ref:r,style:m,...a,...n,className:`group/container overflow-hidden rounded-lg transition-all ${l?"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:()=>c(!u),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(S,{className:t.cn("size-3.5 flex-shrink-0 text-gray-500",d==="string"?"text-blue-500":"",d==="number"?"text-green-500":"",d==="date"?"text-purple-500":"",d==="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 dark:text-muted-foreground ${u?"whitespace-normal break-words":"truncate"}`,children:s.name})})}),e.jsx(t.TooltipContent,{side:"right",className:"max-w-xs",children:e.jsxs("div",{className:"overflow-x-auto",children:[e.jsxs("div",{className:"flex items-center justify-between gap-2",children:[e.jsx("p",{className:t.cn("font-medium",{"text-blue-500":d==="string","text-green-500":d==="number","text-purple-500":d==="date","text-orange-500":d==="boolean"}),children:s.label||s.name}),e.jsx("p",{className:t.cn("pr-0.5 text-xs font-normal italic text-gray-500"),children:s.dataType})]}),s.description&&e.jsx("div",{className:"mt-1 text-sm text-muted-foreground",children:s.description}),e.jsx("div",{className:"mt-2 text-xs italic text-muted-foreground",children:s.qualifiedEntityName?`${s.qualifiedEntityName}.${s.name}`:s.name})]})})]})}),e.jsx("button",{onClick:f=>{f.stopPropagation(),c(!u)},className:"invisible flex-shrink-0 text-gray-400 hover:text-gray-600 group-hover/container:visible",children:u?e.jsx(t.ChevronDown,{className:"h-4 w-4"}):e.jsx(t.ChevronRight,{className:"h-4 w-4"})})]}),u&&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(ns,{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(Fn,{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 xr({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(hr,{field:o},o.id))})})]})}function pr(){const[s,a]=L.useState(""),[n,r]=L.useState(new Set),[o,i]=L.useState("all"),l=t.useEditorStore(E=>E.card.dataSource),{columns:u=[],columnGroups:c=[],isLoading:m,error:d}=ze(),h=u.filter(E=>E.name.toLowerCase().includes(s.toLowerCase())||E.dataType.toLowerCase().includes(s.toLowerCase())||E.qualifiedEntityName&&E.qualifiedEntityName.toLowerCase().includes(s.toLowerCase())),S=E=>E.dataType==="number"||E.dataType==="integer"||E.dataType==="float"||E.dataType==="decimal"||E.dataType==="currency"?"metrics":"dimensions",y=(o==="all"?h:h.filter(E=>S(E)===o)).reduce((E,j)=>{const b=j.qualifiedEntityName||"Other Fields";return E[b]||(E[b]={label:t.toLabel(j.entityName),fields:[]}),E[b].fields.push(j),E},{});L.useEffect(()=>{const E=Object.keys(y);r(new Set(E))},[Object.keys(y).join(",")]);const x=E=>{const j=new Set(n);j.has(E)?j.delete(E):j.add(E),r(j)},g=h.filter(E=>S(E)==="dimensions").length,p=h.filter(E=>S(E)==="metrics").length,C=h.filter(E=>S(E)==="calculated").length,T=h.length>0;return m?e.jsxs("div",{className:"flex h-[calc(100vh-200px)] w-[290px] flex-col items-center justify-center",children:[e.jsx(ue,{className:"h-8 w-8 animate-spin text-gray-400"}),e.jsx("span",{className:"mt-2 text-sm text-gray-500",children:"Loading fields..."})]}):d?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:d.message||"Failed to load column data"})]}):!l||!l.selectedEntities||l.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:[u.length>0&&e.jsx("div",{className:"mb-4",children:e.jsx(t.Input$1,{type:"text",placeholder:"Search fields...",value:s,onChange:E=>a(E.target.value)})}),T&&e.jsx(t.Tabs,{defaultValue:"all",value:o,onValueChange:E=>i(E),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:h.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:g})]}),e.jsxs(t.TabsTrigger,{value:"metrics",className:"text-xs",children:[e.jsx(jt,{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(en,{className:"size-4 shrink-0"}),e.jsx("span",{className:"ml-2 text-xs font-semibold",children:C})]})]})})]}),e.jsxs(t.CustomScrollArea,{className:"py-2",children:[e.jsxs("div",{className:"space-y-2",children:[Object.entries(y).map(([E,j])=>{const b=c.find(v=>v.entityName===E)||{entityName:E,label:j.label};return e.jsx(xr,{entityGroup:b,fields:j.fields,isOpen:n.has(E),onToggle:()=>x(E)},E)}),Object.keys(y).length===0&&u.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(y).length===0&&u.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 fr(){return e.jsxs("div",{className:" h-full flex flex-col items-center",children:[" ",e.jsx(pr,{})," "]})}function gr({initialJoinPlan:s,availableDataSources:a}){const[n,r]=L.useState(s),[o,i]=L.useState(new Set),l=()=>{const b=n.joins.length>0?Math.max(...n.joins.map(w=>w.sequence))+1:1,v={id:`join-${Date.now()}`,source:{type:"table",name:"",database:"",schema:""},target:{type:"table",name:"",database:"",schema:""},joinType:"INNER",sequence:b,joinKeyGroups:[{id:"group-"+Date.now()+"-"+Math.random().toString(36).substr(2,9),operator:"AND",keys:[]}]};r({...n,joins:[...n.joins,v]}),i(new Set([...o,v.id]))},u=b=>{r({...n,joins:n.joins.filter(v=>v.id!==b)}),i(new Set([...o].filter(v=>v!==b)))},c=(b,v)=>{var N,F;const w=n.joins.find(O=>O.id===b);if(!w)return;const I={...w,...v},D=n.joins.map(O=>O.id===b?I:O);if((N=I.source)!=null&&N.name&&((F=I.target)!=null&&F.name)&&I.joinKeyGroups[0].keys.length===0){const O=a.find(B=>{var z;return B.name===((z=I.source)==null?void 0:z.name)}),A=a.find(B=>{var z;return B.name===((z=I.target)==null?void 0:z.name)}),k={id:`key-${Date.now()}`,source:{id:`source-${Date.now()}`,name:"",dataType:"",label:"",entityId:(O==null?void 0:O.name)||"",entityName:(O==null?void 0:O.name)||"",entityType:(O==null?void 0:O.type)||"table"},target:{id:`target-${Date.now()}`,name:"",dataType:"",label:"",entityId:(A==null?void 0:A.name)||"",entityName:(A==null?void 0:A.name)||"",entityType:(A==null?void 0:A.type)||"table"},operator:"="},M=[...I.joinKeyGroups];M[0]={...M[0],keys:[k]},I.joinKeyGroups=M,D[D.findIndex(B=>B.id===b)]=I}r({...n,joins:D})};return{joinPlan:n,expandedJoins:o,setJoinPlan:r,addJoin:l,removeJoin:u,updateJoin:c,moveJoinUp:b=>{const v=n.joins.findIndex(w=>w.id===b);if(v>0){const w=[...n.joins],I={...w[v]},D={...w[v-1]};w[v]=D,w[v-1]=I,w.forEach((F,O)=>{F.sequence=O+1});const N={...n,joins:w};r(N)}},moveJoinDown:b=>{const v=n.joins.findIndex(w=>w.id===b);if(v<n.joins.length-1){const w=[...n.joins],I={...w[v]},D={...w[v+1]};w[v]=D,w[v+1]=I,w.forEach((F,O)=>{F.sequence=O+1});const N={...n,joins:w};r(N)}},toggleJoinExpansion:b=>{const v=new Set(o);v.has(b)?v.delete(b):v.add(b),i(v)},getAvailableSourceEntities:b=>{if(n.joins.length===0)return a;const v=n.joins.findIndex(I=>I.id===b);if(v===0)return a;const w=new Set;return n.baseEntity.name&&w.add(n.baseEntity.name),n.joins.slice(0,v).forEach(I=>{w.add(I.source.name),w.add(I.target.name)}),a.filter(I=>w.has(I.name))},getAvailableTargetEntities:b=>a.filter(v=>v.name!==b),addJoinKeyGroup:b=>{const v=n.joins.find(I=>I.id===b);if(!v)return;const w=[...v.joinKeyGroups,{id:"group-"+Date.now()+"-"+Math.random().toString(36).substr(2,9),operator:"AND",keys:[]}];c(b,{joinKeyGroups:w})},updateGroupOperator:(b,v,w)=>{const I=n.joins.find(N=>N.id===b);if(!I)return;const D=[...I.joinKeyGroups];D[v]={...D[v],operator:w},c(b,{joinKeyGroups:D})},removeJoinKeyGroup:(b,v)=>{const w=n.joins.find(D=>D.id===b);if(!w)return;const I=[...w.joinKeyGroups];I.splice(v,1),c(b,{joinKeyGroups:I})},addJoinKey:(b,v)=>{const w=n.joins.find(O=>O.id===b);if(!w)return;const I=a.find(O=>O.name===w.source.name),D=a.find(O=>O.name===w.target.name),N=[...w.joinKeyGroups],F={id:`key-${Date.now()}`,source:{id:`source-${Date.now()}`,name:"",dataType:"",label:"",entityId:(I==null?void 0:I.name)||"",entityName:(I==null?void 0:I.name)||"",entityType:(I==null?void 0:I.type)||"table"},target:{id:`target-${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"},operator:"="};N[v]={...N[v],keys:[...N[v].keys,F]},c(b,{joinKeyGroups:N})},updateJoinKey:(b,v,w,I,D)=>{const N=n.joins.find(M=>M.id===b);if(!N)return;const F=a.find(M=>M.name===N.source.name),O=a.find(M=>M.name===N.target.name),A=[...N.joinKeyGroups],k=A[v].keys[w];I==="sourceColumnName"&&F?A[v].keys[w]={...k,source:{...k.source,name:D}}:I==="targetColumnName"&&O?A[v].keys[w]={...k,target:{...k.target,name:D}}:I==="operator"&&(A[v].keys[w]={...k,operator:D}),c(b,{joinKeyGroups:A})},removeJoinKey:(b,v,w)=>{const I=n.joins.find(N=>N.id===b);if(!I)return;const D=[...I.joinKeyGroups];D[v].keys.splice(w,1),c(b,{joinKeyGroups:D})},generateSQLPreview:()=>{const b=[...n.joins].sort((I,D)=>I.sequence-D.sequence),v=n.baseEntity;if(!v.name)return"SELECT * FROM table -- Please select a base entity";let w=`SELECT *
399
+ `),j=new Blob([E],{type:"text/csv"}),b=URL.createObjectURL(j),v=document.createElement("a");v.href=b,v.download=`${a.title}.csv`,v.click()}function p(){const T=`Can you get the documentation for ${a.type} chart?`;m(T)}return a?e.jsxs("div",{className:"relative isolate flex h-full flex-col py-2 pb-3",children:[(S||f)&&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(ue,{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(vs,{}),o&&e.jsx(t.IconButton,{tooltip:"Visual Docs",onClick:p,children:e.jsx(Ws,{className:"size-4"})}),!["table","custom"].includes(a.type)&&o&&e.jsx(ha,{})]}),!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:g,children:e.jsx(fa,{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:x,children:e.jsx(hn,{strokeWidth:1.5,className:"size-4"})}),e.jsx(t.CopyButton,{text:JSON.stringify(h==null?void 0:h.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(Ns,{})]}),n&&e.jsx(Ca,{})]}),r?e.jsx(Cs,{}):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(Na,{})}),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:[(h==null?void 0:h.records)&&(h==null?void 0:h.records.length)>0&&e.jsx(la,{data:(h==null?void 0:h.records)||[]}),(y||(h==null?void 0:h.error))&&e.jsx("span",{className:"font-mono text-xs",children:(y==null?void 0:y.message)||((C=h==null?void 0:h.error)==null?void 0:C.message)})]})]})]}):e.jsx(e.Fragment,{children:"No Active Card"})}function Na(){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 Ca(){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 Sa(){var x,g;const s=t.useEditorStore(p=>p.card.customCardPreferences),{data:a}=ys(),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:l}=t.useEditorActions(),{components:u,manifest:c}=t.useCustomVisual((s==null?void 0:s.url)||""),m=(x=c==null?void 0:c.visuals)==null?void 0:x.find(p=>p.name===(s==null?void 0:s.componentName));function d(p,C){if(!s)return;const E={...(s==null?void 0:s.dataInputCardIds)||{},[p]:{cardId:C,hookRef:null}};l({...s,dataInputCardIds:E})}function h(p){var T,E;const C=(T=o==null?void 0:o.cards)==null?void 0:T.filter(j=>{var b;return((b=j==null?void 0:j.customCardPreferences)==null?void 0:b.visualType)!=="multiple"}).map(j=>({value:j.id,label:j.tabTitle||j.title}));return e.jsx("div",{className:"space-y-2",children:(E=p==null?void 0:p.dataInputs)==null?void 0:E.map((j,b)=>{var v,w;return e.jsxs("div",{className:"grid grid-cols-10 gap-2",children:[e.jsx("div",{className:"col-span-4 flex items-center",children:j}),e.jsx(de,{className:"col-span-6 h-8 w-full justify-between",label:"",options:C||[],value:((w=(v=s==null?void 0:s.dataInputCardIds)==null?void 0:v[b])==null?void 0:w.cardId)||"",onValueChange:I=>d(b,I)})]},b+Math.random())})})}function S(p,C,T=[],E=""){var j,b;return s?p==="input"?e.jsx(t.Input,{className:`h-8 w-full ${t.removeRing}`,value:((j=s==null?void 0:s.settings)==null?void 0:j[C])||E,onChange:v=>{l({...s,settings:{...s==null?void 0:s.settings,[C]:v.target.value}})}},C):p==="select"?e.jsx(de,{className:"h-8 w-full",label:"",options:T,value:((b=s==null?void 0:s.settings)==null?void 0:b[C])||E,onValueChange:v=>{l({...s,settings:{...s==null?void 0:s.settings,[C]:v}})}}):null:null}function f(p){const C=Object.entries((p==null?void 0:p.settings)||{});return e.jsx("div",{className:"space-y-3",children:C.map(([T,E])=>e.jsxs("div",{className:"space-y-1",children:[e.jsx(t.Label,{children:E.title}),S(E.ui,T,E.options,E.defaultValue)]},T))})}function y(p){s&&l({...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(de,{icon:e.jsx(Qs,{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=>l({...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:y,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:u&&e.jsx(de,{icon:e.jsx(ln,{className:"h-3.5 w-3.5"}),className:"h-9 w-full",label:"Select Component",options:(u==null?void 0:u.filter(p=>p.type===i).map(p=>({value:p.name,label:p.name})))||[],value:s.componentName,onValueChange:p=>{console.log("changing value",p),l({...s,componentName:p})}})})]})})]}),((g=r==null?void 0:r.customCardPreferences)==null?void 0:g.componentName)&&e.jsxs(t.AccordionItem,{className:"border-none",value:"component-settings",children:[e.jsx(t.AccordionTrigger,{children:"Settings"}),e.jsxs(t.AccordionContent,{children:[m&&m.dataInputs&&e.jsxs("div",{className:"space-y-3",children:[e.jsx(t.Label,{children:"Input Mapping"}),e.jsx("div",{className:"px-2",children:h(m)})]}),m&&m.settings&&e.jsx("div",{className:"space-y-3",children:e.jsx("div",{className:"px-2",children:f(m)})})]})]})]})}function ve(){const[s,a]=L.useState([]),n=t.useEditorStore(m=>m.card.preferences),{setFilterOnClickColumnIndex:r,setCardPreferences:o}=t.useEditorStore(m=>m.actions),i=t.useEditorStore(m=>m.queryResultColumns);t.useEditorStore(m=>{var d;return(d=m.card.preferences)==null?void 0:d.filterOnClickColumnIndex}),L.useEffect(()=>{i&&a(new Array(i.length).fill(!1))},[i]);function l(m,d){var h,S;d?n!=null&&n.onClickFilter&&((h=n==null?void 0:n.onClickFilter)==null?void 0:h.length)>0?o({...n,onClickFilter:[...n.onClickFilter,{columnIndex:m,expression:""}]}):o({...n,onClickFilter:[{columnIndex:m,expression:""}]}):(o({...n,onClickFilter:(S=n==null?void 0:n.onClickFilter)==null?void 0:S.filter(f=>f.columnIndex!==m)}),a(f=>{const y=[...f];return y[m]=!1,y}))}function u(m,d){var S;const h=(S=n==null?void 0:n.onClickFilter)==null?void 0:S.map(f=>f.columnIndex===m?{...f,expression:d.target.value}:f);o({...n,onClickFilter:h})}function c(m){var d,h,S,f;if(s!=null&&s[m]||(h=(d=n==null?void 0:n.onClickFilter)==null?void 0:d.find(y=>y.columnIndex===m))!=null&&h.expression)return e.jsx(t.Input,{value:(f=(S=n==null?void 0:n.onClickFilter)==null?void 0:S.find(y=>y.columnIndex===m))==null?void 0:f.expression,onChange:y=>u(m,y),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((m,d)=>{var h,S;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:!!((h=n==null?void 0:n.onClickFilter)!=null&&h.find(f=>f.columnIndex===d)),onCheckedChange:f=>l(d,f)}),e.jsx("label",{className:"text-sm font-medium leading-none peer-disabled:cursor-not-allowed peer-disabled:opacity-70",children:m}),e.jsx("div",{className:"flex items-center gap-2",children:((S=n==null?void 0:n.onClickFilter)==null?void 0:S.find(f=>f.columnIndex===d))&&e.jsx(t.Pencil,{onClick:()=>{a(f=>{const y=[...f];return y[d]=!f[d],y})},className:"invisible size-3 cursor-pointer text-gray-400 group-hover:visible"})})]}),c(d)]})},m)})]})}function wa({idx:s}){var u;const a=t.useEditorStore(c=>{var m;return(m=c.card)==null?void 0:m.preferences}),n=t.useEditorStore(c=>{var m;return(m=c.card.preferences)==null?void 0:m.datasetOptions}),r=t.useEditorStore(c=>c.actions.setCardPreferences),o=(u=a==null?void 0:a.chartOptions)==null?void 0:u.indexAxis,i=n==null?void 0:n.find(c=>c.idx===s);function l(c,m){(c==="end"||c==="start")&&t.getContrastColor(t.getCanvasBackgroundColor());const d={display:c!=="none",align:c,anchor:c,clamp:!0};if(!i)r({...a,datasetOptions:[...n||[],{idx:m,datalabels:d}]});else{const h={...i};h.datalabels=d;const S=n==null?void 0:n.map(f=>f.idx===m?h:f);r({...a,datasetOptions:S})}}return e.jsxs(t.Popover,{children:[e.jsx(t.PopoverTrigger,{children:e.jsx(ns,{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:()=>l("none",s),className:"h-7 p-1 text-xs font-normal",children:e.jsx(t.X,{className:"size-3.5"})}),e.jsx("button",{onClick:()=>l("start",s),className:"h-7 p-1 text-xs font-normal",children:e.jsx(vn,{className:t.cn("h-4 w-4",{"rotate-90":o==="y"})})}),e.jsx("button",{onClick:()=>l("center",s),className:"h-7 p-1 text-xs font-normal",children:e.jsx(Cn,{className:t.cn("h-4 w-4",{"rotate-90":o==="y"})})}),e.jsx("button",{onClick:()=>l("end",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"})})})]})})]})}function Ss(){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:l}=t.getKeys(i);o=l.slice(1)}return{transformedMetricKeys:o,dimensionKeys:n.slice(0,1),keys:n,defaultMetricKeys:r}}function Je({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 ws(){const s=t.useEditorStore(c=>c.card),a=t.useEditorStore(c=>{var m,d,h;return(h=(d=(m=c==null?void 0:c.card)==null?void 0:m.preferences)==null?void 0:d.chartOptions)==null?void 0:h.indexAxis}),{data:n}=t.useDashboardCardQuery(s),r=a==="y"?"Metric":"Dimension",o=a==="y"?"Dimension":"Metric",{dimensionKeys:i,transformedMetricKeys:l,keys:u}=Ss();return u.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(c=>e.jsx("p",{className:"flex h-8 items-center rounded-md bg-muted/70 px-3 hover:bg-muted",title:c,children:ks(c)},c))})]}),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:l.map((c,m)=>e.jsx(Es,{className:"flex h-8 items-center bg-muted/70 px-3 hover:bg-muted",iconClassName:"invisible group-hover:visible",col:c,idx:m},c))})]})]})}function ks(s,a=30){return s.length>a?s.slice(0,a)+"...":s}function Es({col:s,idx:a,className:n,iconClassName:r,children:o}){const i=t.useEditorStore(d=>{var h;return(h=d.card)==null?void 0:h.preferences}),l=t.useEditorStore(d=>{var h,S;return(S=(h=d.card)==null?void 0:h.preferences)==null?void 0:S.datasetOptions}),u=l==null?void 0:l.find(d=>d.idx===a),{setCardPreferences:c}=t.useEditorStore(d=>d.actions);function m(d){if(!u)c({...i,datasetOptions:[...l||[],{idx:a,type:d==="area"?"line":d,fill:d==="area"?"origin":""}]});else{const h={...u};h.type=d==="area"?"line":d,h.fill=d==="area"?"origin":"";const S=l==null?void 0:l.map(f=>f.idx===a?h:f);c({...i,datasetOptions:S})}}return e.jsxs("div",{className:t.cn("group flex items-center justify-between gap-2 rounded-md",n),children:[o||e.jsx(Je,{className:"max-w-[100px]",title:s,children:ks(s)}),e.jsxs("div",{className:"flex gap-2",children:[e.jsx(Ke,{onClick:()=>m("bar"),className:t.cn("size-4 cursor-pointer text-muted-foreground hover:text-foreground",r)}),e.jsx(Qe,{onClick:()=>m("line"),className:t.cn("size-4 cursor-pointer text-muted-foreground hover:text-foreground",r)}),e.jsx(tn,{onClick:()=>m("area"),className:t.cn("size-4 cursor-pointer text-muted-foreground hover:text-foreground",r)}),e.jsx(wa,{idx:a})]})]})}function Is(){const s=t.useEditorStore(f=>f.selectedConnectionId),a=t.useEditorStore(f=>f.selectedDatamodelId),n=t.useEditorStore(f=>f.selectedDatabaseName),r=t.useEditorStore(f=>f.selectedSchemaName),o=t.useEditorStore(f=>f.selectedTableName),i=t.useDashboardStore(f=>f.dashboard.filters)||[],l=t.useDashboardStore(f=>f.actions.addFilter),u=t.useDashboardStore(f=>f.actions.removeFilter),{removeFilterValues:c}=t.useDashboardActions(),{modelItems:m,tableName:d,connectionType:h}=t.useEditorAside();function S(f,y="dashboard"){var v;const x=t.fmt(f.column_name),g=t.fmt(n||""),p=t.fmt(r||""),C=t.fmt(d);let T=t.getQualifiedTableName({schemaName:p,tableName:C,connectionType:h,databaseName:g}),E=`${T}.${x}`;const j=(v=m==null?void 0:m.find(w=>w.id===a))==null?void 0:v.name;a&&a!=="none"&&(E=`${t.DATAMODEL_NAMESPCACE}.${j}.${x}`,T=`${t.DATAMODEL_NAMESPCACE}.${j}`);const b=i==null?void 0:i.find(w=>w.column===E&&w.table===C&&(w.database===g||w.database===n));if(b)c(b.id),u(b.id);else{const w=t.v4();return d==="api"&&s?(l({location:y,id:w,column:E,title:f.column_name,dataType:f.data_type,table:"api",database:"",connectionId:s,operation:"in",sql:t.getDefaultFilterSql(f.data_type,T,x)}),w):(l({id:w,location:y,column:E,title:f.column_name,dataType:f.data_type,table:o||"",database:n||"",connectionId:s||"",operation:"in",sql:t.getDefaultFilterSql(f.data_type,T,x)}),w)}}return{assignFilter:S}}function Te(){const s=t.useDashboardStore(u=>u.dashboard.filters),a=t.useEditorStore(u=>u.frame),{setFrame:n}=t.useEditorActions(),{columns:r}=t.useEditorAside(),{assignFilter:o}=Is();function i(u){const c=o(u,"frame");n({...a,filterId:c})}const l=s==null?void 0:s.find(u=>u.id===a.filterId);return e.jsxs("div",{className:"space-y-3",children:[e.jsx(t.Label,{children:"Card Filter"}),e.jsx(ka,{onSelect:i,columns:r}),l&&e.jsx(t.FilterHeader,{filter:l})]})}function ka({columns:s,onSelect:a}){var l;const[n,r]=ie.useState(!1),[o,i]=ie.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?(l=s.find(u=>u.column_name===o))==null?void 0:l.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(u=>e.jsxs(t.CommandItem,{value:u.column_name,onSelect:c=>{const m=c===o?"":c;i(m),r(!1),m&&a(u)},children:[u.column_name,e.jsx(t.CheckIcon,{className:t.cn("ml-auto h-4 w-4",o===u.column_name?"opacity-100":"opacity-0")})]},u.column_name))})]})]})})]})}function Ea({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(ws,{})})]}),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(ve,{}),e.jsx(Te,{})]})]})]})})}function zt(){var o,i,l;const s=t.useEditorStore(u=>u.card.type),a=t.useEditorStore(u=>u.card.preferences),{setCardPreferences:n}=t.useEditorStore(u=>u.actions);function r(u){var d;const c={datalabels:{display:u!=="none",align:u,anchor:u,clamp:!0}},m={...a,chartOptions:{...a==null?void 0:a.chartOptions,plugins:{...(d=a==null?void 0:a.chartOptions)==null?void 0:d.plugins,...c}}};n(m),console.log(u)}return e.jsxs("div",{className:"space-y-2",children:[e.jsx("label",{className:"font-medium",children:"Data Labels"}),e.jsxs(t.Select,{value:((l=(i=(o=a==null?void 0:a.chartOptions)==null?void 0:o.plugins)==null?void 0:i.datalabels)==null?void 0:l.anchor)||"none",onValueChange:r,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 Ia({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(zt,{})})]}),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(ve,{}),e.jsx(Te,{})]})]})]})})}const Da={datasets:[{type:"line",label:"Sum_sales",data:[]},{type:"bar",label:"Sum_profit",data:[]}]},Ta={datasets:[{fill:"origin",type:"line",label:"Sum_sales",data:[]}]};function Ma(){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:Aa(s)}),!["kpi"].includes(s)&&e.jsxs("div",{className:"space-y-4",children:[e.jsx(zt,{}),e.jsx(ve,{}),e.jsx(Te,{})]})]})}function Aa(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(Da,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(Ta,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 La(){var c,m,d,h,S;const s=t.useEditorStore(f=>f.card.preferences),a=t.useEditorStore(f=>f.actions.setCardPreferences),n=t.useEditorStore(f=>f.actions.setNumberFormat);t.useEditorStore(f=>{var y,x;return(x=(y=f.card.preferences)==null?void 0:y.formatNumber)==null?void 0:x.decimalPlaces});const r=t.useEditorStore(f=>{var y,x;return(x=(y=f.card.preferences)==null?void 0:y.formatNumber)==null?void 0:x.locale}),o=t.useEditorStore(f=>{var y,x;return(x=(y=f.card.preferences)==null?void 0:y.formatNumber)==null?void 0:x.currency});t.useEditorStore(f=>f.actions.setFilterOnClickField);const i=t.useEditorStore(f=>{var y,x;return(x=(y=f.card.preferences)==null?void 0:y.formatNumber)==null?void 0:x.colorRanges})||[],l=t.useEditorStore(f=>f.actions.setColorRanges),u=[...new Set(t.LOCALE_CURRENCY_PAIRS.map(f=>f.currency))];return e.jsxs("div",{children:[e.jsxs("div",{className:"mb-3 flex items-center gap-2",children:[e.jsx(t.Checkbox,{checked:!!((c=s==null?void 0:s.formatNumber)!=null&&c.enabled),onCheckedChange:f=>{a({...s,formatNumber:{...s==null?void 0:s.formatNumber,enabled:f}})}}),e.jsx(t.Label,{children:"Format Number"})]}),((m=s==null?void 0:s.formatNumber)==null?void 0:m.enabled)===!0&&e.jsxs("div",{className:"flex flex-col gap-2",children:[e.jsx("div",{children:e.jsxs("div",{className:"space-y-4 p-2",children:[e.jsxs("div",{className:"flex items-center gap-2",children:[e.jsxs("div",{className:"w-full space-y-1",children:[e.jsx(t.Label,{children:"Locale"}),e.jsxs(t.Select,{value:r||"none",onValueChange:f=>{var y,x,g;return n(((y=s==null?void 0:s.formatNumber)==null?void 0:y.decimalPlaces)||0,((x=s==null?void 0:s.formatNumber)==null?void 0:x.currency)||"",f,((g=s==null?void 0:s.formatNumber)==null?void 0:g.suffix)||"")},children:[e.jsx(t.SelectTrigger,{className:"col-span-6 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:"Format"}),e.jsx(t.SelectItem,{value:"none",children:"None"},"none"),t.LOCALE_CURRENCY_PAIRS.map(f=>e.jsx(t.SelectItem,{value:f.locale,children:f.locale},f.locale))]})})]})]}),e.jsxs("div",{className:"w-full space-y-1",children:[e.jsx(t.Label,{children:"Currency"}),e.jsxs(t.Select,{value:o||"none",onValueChange:f=>{var y,x,g;console.log("currency",f),n(((y=s==null?void 0:s.formatNumber)==null?void 0:y.decimalPlaces)||0,f==="none"?"":f,((x=s==null?void 0:s.formatNumber)==null?void 0:x.locale)||"",((g=s==null?void 0:s.formatNumber)==null?void 0:g.suffix)||"")},children:[e.jsx(t.SelectTrigger,{className:"col-span-6 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"},"none"),u.map(f=>e.jsx(t.SelectItem,{value:f,children:f},f))]})})]})]})]}),e.jsxs("div",{className:"flex gap-2",children:[e.jsxs("div",{className:"w-full space-y-1",children:[e.jsx(t.Label,{children:"Decimals"}),e.jsxs(t.Select,{value:((h=(d=s==null?void 0:s.formatNumber)==null?void 0:d.decimalPlaces)==null?void 0:h.toString())||"0",onValueChange:f=>{var y,x,g;return n(Number(f),((y=s==null?void 0:s.formatNumber)==null?void 0:y.currency)||"",((x=s==null?void 0:s.formatNumber)==null?void 0:x.locale)||"",((g=s==null?void 0:s.formatNumber)==null?void 0:g.suffix)||"")},children:[e.jsx(t.SelectTrigger,{className:"col-span-3 h-8 w-full focus:ring-1 focus:ring-offset-0",children:e.jsx(t.SelectValue,{})}),e.jsx(t.SelectContent,{children:["0","1","2","3","4"].map(f=>e.jsx(t.SelectItem,{value:f,children:f},f))})]})]}),e.jsxs("div",{className:"w-full space-y-1",children:[e.jsx(t.Label,{children:"Suffix"}),e.jsx(t.Input,{value:((S=s==null?void 0:s.formatNumber)==null?void 0:S.suffix)||"",className:"h-8 font-mono text-xs focus-visible:ring-0 focus-visible:ring-ring focus-visible:ring-offset-0",placeholder:"K, M, B, %",onChange:f=>{var y,x,g;return n(((y=s==null?void 0:s.formatNumber)==null?void 0:y.decimalPlaces)||0,((x=s==null?void 0:s.formatNumber)==null?void 0:x.currency)||"",((g=s==null?void 0:s.formatNumber)==null?void 0:g.locale)||"",f.target.value)}})]})]})]})}),e.jsx(t.Separator,{className:"my-3"}),e.jsx(t.ColorFormat,{colorRanges:i,setColorRanges:l})]})]})}function Oa(){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(La,{})}),e.jsx("div",{}),e.jsx("div",{})]})}function rt({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 Fa=[{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"}],Ba=["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"],za=Ba.map(s=>({label:s,value:s}));function Ra(){var c,m,d,h,S,f,y,x,g,p,C,T,E,j,b,v,w,I;const s=t.useEditorStore(D=>D.card),a=(m=(c=s==null?void 0:s.preferences)==null?void 0:c.mapVisualOptions)==null?void 0:m.topoJsonUrl,[n,r]=L.useState(((h=(d=s==null?void 0:s.preferences)==null?void 0:d.mapVisualOptions)==null?void 0:h.customTopoJsonUrl)||""),{setCardPreferences:o}=t.useEditorActions(),{data:i}=t.useTopoJson(s),l=Object.keys((i==null?void 0:i.objects)||{}).map(D=>({label:D,value:D}))||[],u=[{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(rt,{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(rt,{open:!0,summary:"Settings",children:e.jsxs("div",{className:"space-y-3 px-2",children:[e.jsx(de,{className:"h-9",options:u,onValueChange:D=>{console.log("value",D),o({...s.preferences,mapVisualOptions:{topoJsonUrl:D}})},value:a||"",label:"Select Map"}),a==="custom"&&e.jsx(t.Input,{onChange:D=>{r(D.target.value)},onBlur:()=>{var D;console.log("onBlur",n),o({...s.preferences,mapVisualOptions:{...(D=s.preferences)==null?void 0:D.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(de,{className:"h-9",options:l,value:((f=(S=s.preferences)==null?void 0:S.mapVisualOptions)==null?void 0:f.objectKey)||"",label:"Map Object",onValueChange:D=>{var N;o({...s.preferences,mapVisualOptions:{...(N=s.preferences)==null?void 0:N.mapVisualOptions,objectKey:D}})}})]}),e.jsxs("div",{className:"space-y-1",children:[e.jsx(t.Label,{children:"Projection"}),e.jsx(de,{className:"h-9",options:Fa,value:((x=(y=s.preferences)==null?void 0:y.mapVisualOptions)==null?void 0:x.projection)||"",label:"Projection",onValueChange:D=>{var N;o({...s.preferences,mapVisualOptions:{...(N=s.preferences)==null?void 0:N.mapVisualOptions,projection:D}})}})]}),e.jsxs("div",{className:"space-y-1",children:[e.jsx(t.Label,{children:"Colors"}),e.jsx(de,{className:"h-9",options:za,value:((p=(g=s.preferences)==null?void 0:g.mapVisualOptions)==null?void 0:p.colorScale)||"",label:"Select Color Scale",onValueChange:D=>{var N;o({...s.preferences,mapVisualOptions:{...(N=s.preferences)==null?void 0:N.mapVisualOptions,colorScale:D}})}})]})]})]})}),e.jsx(t.Separator,{className:"my-4"}),e.jsx(rt,{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:((T=(C=s.preferences)==null?void 0:C.mapVisualOptions)==null?void 0:T.projectionScale)||1,onChange:D=>{var N;o({...s.preferences,mapVisualOptions:{...(N=s.preferences)==null?void 0:N.mapVisualOptions,projectionScale:Number(D.target.value)}})}}),e.jsx(t.Label,{children:"X"}),e.jsx(t.Input,{className:`h-9 w-full ${t.removeRing}`,type:"number",step:10,value:((b=(j=(E=s.preferences)==null?void 0:E.mapVisualOptions)==null?void 0:j.projectionOffset)==null?void 0:b[0])||0,onChange:D=>{var N,F,O,A;o({...s.preferences,mapVisualOptions:{...(N=s.preferences)==null?void 0:N.mapVisualOptions,projectionOffset:[Number(D.target.value),((A=(O=(F=s.preferences)==null?void 0:F.mapVisualOptions)==null?void 0:O.projectionOffset)==null?void 0:A[1])||0]}})}}),e.jsx(t.Label,{children:"Y"}),e.jsx(t.Input,{className:`h-9 w-full ${t.removeRing}`,type:"number",step:10,value:((I=(w=(v=s.preferences)==null?void 0:v.mapVisualOptions)==null?void 0:w.projectionOffset)==null?void 0:I[1])||0,onChange:D=>{var N,F,O,A;o({...s.preferences,mapVisualOptions:{...(N=s.preferences)==null?void 0:N.mapVisualOptions,projectionOffset:[((A=(O=(F=s.preferences)==null?void 0:F.mapVisualOptions)==null?void 0:O.projectionOffset)==null?void 0:A[0])||0,Number(D.target.value)]}})}})]})}),e.jsx(t.Separator,{className:"my-4"}),e.jsx(ve,{})]})}function Pa(){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 Ve({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(zt,{}),s==="text"&&e.jsx(Pa,{})]})]}),!["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(ve,{}),e.jsx(Te,{})]})]})]})})}function Va(){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(de,{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(ws,{})]})]}),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(ve,{}),e.jsx(Te,{})]})]})]})})}function qa({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(ve,{}),e.jsx(Te,{})]})]})}),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 _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 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."]})]}),$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 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."]})]}),Ga=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 Ha(){const s=t.useEditorStore(n=>n.card.type);function a(n){switch(n){case"stackedBar":case"stackedLine":return e.jsx(Va,{});case"tornado":case"pyramid":return e.jsx(Ve,{docContent:_a,cardType:n});case"kpi":return e.jsx(Oa,{});case"line":case"bar":return e.jsx(Ea,{cardType:n});case"range":return e.jsx(Ve,{docContent:$a,cardType:n});case"pie":case"doughnut":case"polarArea":case"radar":case"funnel":return e.jsx(Ve,{cardType:n});case"bubble":case"scatter":return e.jsx(Ia,{cardType:n});case"table":return e.jsx(qa,{cardType:n});case"text":return e.jsx(Ve,{docContent:Ga,cardType:n,suffix:"Visual"});case"map":return e.jsx(Ra,{});case"custom":return e.jsx(Sa,{});default:return e.jsx(Ma,{})}}return e.jsxs(t.ScrollArea,{className:"h-full w-full text-sm",children:[a(s),e.jsx(t.ScrollBar,{orientation:"horizontal"})]})}function Ds({label:s,column:a,functions:n,onFunctionChange:r}){let o=n[0];"aggregate"in a?o=n.find(l=>l.value===a.aggregate)||n[0]:"granularity"in a&&(o=n.find(l=>l.value===a.granularity)||n[0]);function i(l){r(l)}return e.jsx(de,{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:l=>i(l),label:s,showPlaceholderLabel:!1})}const Ja=[{label:"Sum",value:"SUM",logo:e.jsx(ss,{className:"size-3.5"})},{label:"Count",value:"COUNT",logo:e.jsx(St,{className:"size-3.5"})},{label:"Unique",value:"DISTINCT",logo:e.jsx(pn,{className:"size-3.5"})},{label:"Average",value:"AVG",logo:e.jsx(Hs,{className:"size-3.5"})},{label:"Min",value:"MIN",logo:e.jsx(Ue,{className:"size-3.5"})},{label:"Max",value:"MAX",logo:e.jsx(Ye,{className:"size-3.5"})}];function Ua({column:s}){const{updateMetricColumnOld:a}=t.useEditorActions();let n=Ja;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:Le(s.name,o)};a(s.id,i)}return e.jsx(Ds,{column:s,functions:n,onFunctionChange:o=>r(o),label:"Aggregation"})}const Ya=[{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 Ka({column:s}){const{updateGroupByColumnOld:a}=t.useEditorActions();function n(r){const o={...s,granularity:r,label:De(s.name,r)};a(s.id,o)}return e.jsx(Ds,{column:s,functions:Ya,onFunctionChange:r=>n(r),label:"Granularity"})}function Qa({col:s,onChange:a,droppableId:n}){const{columns:r}=t.useDataColumns(),o=L.useMemo(()=>{let u=[];(n===ge||n===je||n===ye)&&(u=r);const c=u==null?void 0:u.filter(m=>m.column_name!==s.name);return c==null?void 0:c.map(m=>({id:m.column_name,value:m.column_name}))},[r,n,s.name]),i=[{id:s.name,value:s.name}];function l(u){const c=r==null?void 0:r.find(m=>{var d;return m.column_name===((d=u[0])==null?void 0:d.id)});c&&a(c)}return o!=null&&o.length?e.jsx(t.ComboBox2,{multiple:!1,options:o,selectedOptions:i,onChange:l,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 Wa({column:s}){const{updateMetricColumnOld:a}=t.useEditorActions(),{transformedMetricKeys:n,dimensionKeys:r}=Ss();console.log(n,r);const o=t.useEditorStore(c=>{var m;return(m=c.card.queryConfig)==null?void 0:m.pivotColumns}),i=!!(o&&o.length>0),l=n.find(c=>c===s.label||c===s.name),u=l?n.indexOf(l):-1;return e.jsxs("div",{className:"space-y-3",children:[l&&e.jsx(Es,{idx:u,col:l,children:e.jsx(t.Editable,{enabled:!0,className:"w-[130px]",text:s.label||"",placeholder:"Enter label",onSave:c=>{a(s.id,{...s,label:c||s.name})},children:e.jsx(Je,{className:"w-[130px]",children:s.label||s.name})})}),i&&e.jsxs("div",{className:"flex items-center justify-between gap-2",children:[e.jsx(t.Label,{children:"Pivot Header"}),e.jsx(t.Editable,{enabled:!0,text:s.aliasTemplate||"",placeholder:"{label} ({pivot})",onSave:c=>{a(s.id,{...s,aliasTemplate:c||""})},children:e.jsx(Je,{className:"font-mono text-xs text-muted-foreground",children:s.aliasTemplate||"{label} ({pivot})"})})]})]})}function Xa({column:s,type:a,onRemoveColumn:n,droppableId:r}){const[o,i]=L.useState(!1),{updateGroupByColumnOld:l,updateMetricColumnOld:u,updatePivotByColumnOld:c}=t.useEditorActions(),{attributes:m,listeners:d,setNodeRef:h,transform:S,transition:f,isDragging:y}=t.useSortable({id:s.id,data:{type:a}}),x=S?{opacity:y?.5:void 0,transform:t.CSS.Translate.toString(S),transition:f}:void 0,g=t.isTextDataType(s.type);function p(b){const v=t.isNumberDataType(b.data_type),w=t.isTextDataType(b.data_type),I=t.isDateDataType(b.data_type),D=v?"number":w?"string":I?"date":"string";if(r===ge){if(w){const N={id:s.id,name:b.column_name,type:D,role:"groupby"};l(s.id,N)}if(I){const N={id:s.id,name:b.column_name,type:D,role:"groupby",label:De(b.column_name,"month"),granularity:"month"};l(s.id,N)}}if(r===ye){if(w){const N={id:s.id,name:b.column_name,type:D,role:"groupby"};c(s.id,N)}if(I){const N={id:s.id,name:b.column_name,type:D,label:De(b.column_name,"month"),granularity:"month",role:"groupby"};c(s.id,N)}}if(r===je){const N={id:s.id,name:b.column_name,type:D,role:"metric",label:Le(b.column_name,"SUM"),aggregate:v?"SUM":"COUNT"};u(s.id,N)}}function C(){if(r===je)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(Wa,{column:s})})}function T(){const b=t.isDateDataType(s.type);if(r===je)return e.jsx(Ua,{column:s});if((r===ge||r===ye)&&b)return e.jsx(Ka,{column:s})}function E(){return e.jsx("div",{className:t.cn("grow",{"pl-3":(r===ge||r===ye)&&g}),children:e.jsx(Qa,{col:s,onChange:p,droppableId:r})})}function j(){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(Ln,{className:t.cn("size-3 cursor-pointer items-center justify-center rounded-r-sm text-muted-foreground")}):e.jsx(es,{className:t.cn("size-3 cursor-pointer items-center justify-center rounded-r-sm text-muted-foreground")})})})}return e.jsx("div",{...d,...m,ref:h,style:x,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:[j(),T(),E()]}),o&&C()]}),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 ot({id:s,label:a,columns:n,previewColumns:r,sortableType:o,onRemoveColumn:i}){var x,g;const{setNodeRef:l,isOver:u,over:c}=t.useDroppable({id:s}),m=t.useDndStore(p=>p.activeId),d=t.useEditorStore(p=>{var C;return(C=p.card)==null?void 0:C.type}),h=u||((g=(x=c==null?void 0:c.data)==null?void 0:x.current)==null?void 0:g.type)===o,S=m?r:n,f=o===_e?"Rows":o===$e?"Pivot Columns":"Columns";function y(){if(!S||S.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",h&&"border border-muted-foreground/20"),ref:l,children:[e.jsxs("div",{className:"flex items-center justify-between pr-5",children:[e.jsx(t.Label,{className:"text-sm",children:a}),d!=="table"&&e.jsx("span",{className:"text-xs text-muted-foreground/50",children:f})]}),y(),e.jsx("div",{className:"space-y-2",children:S==null?void 0:S.map(p=>p.id===ds.id?e.jsx(Za,{},p.id):e.jsx(Xa,{droppableId:s,type:o,column:p,onRemoveColumn:i},p.id))})]})})}function Za(){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 Ts({children:s,id:a,type:n}){const{attributes:r,listeners:o,setNodeRef:i,transform:l,transition:u,isDragging:c}=t.useSortable({id:a,data:{type:n}}),m=l?{opacity:c?.5:void 0,transform:t.CSS.Translate.toString(l),transition:u}:void 0;return e.jsx("div",{...o,...r,ref:i,style:m,children:s})}function er(){const s=t.useEditorStore(p=>{var C;return(C=p.card.queryConfig)==null?void 0:C.orderBy})||[],a=t.useEditorStore(p=>{var C;return(C=p.card.queryConfig)==null?void 0:C.groupByColumns})||[],n=t.useEditorStore(p=>{var C;return(C=p.card.queryConfig)==null?void 0:C.metricColumns})||[],{addOrderByColumn:r,removeOrderByColumn:o,updateOrderByColumn:i}=t.useEditorActions(),l=[...a,...n];if(l.length===0)return e.jsx(e.Fragment,{});const u=e.jsx(Ks,{className:"size-3.5 text-muted-foreground hover:text-foreground"}),c=e.jsx(Gs,{className:"size-3.5 text-muted-foreground hover:text-foreground"}),m=e.jsx(Ys,{className:"size-3.5 text-muted-foreground hover:text-foreground"}),d=e.jsx($s,{className:"size-3.5 text-muted-foreground hover:text-foreground"}),h=l==null?void 0:l.filter(p=>!s.some(C=>C.columnId===p.id)).map(p=>({id:p.id,value:p.label||p.name}));function S(p,C){const T=f(p);return T?T.role==="metric"?C==="asc"?m:d:C==="asc"?u:c:null}function f(p){return l.find(C=>C.id===p)}function y(p){const C=s.find(T=>T.columnId===p);if(C){const T={...C,direction:C.direction==="asc"?"desc":"asc"};i(T)}}const x=p=>{r({columnId:p.id,direction:"asc"})};function g(p){const C=s.find(T=>T.columnId===p);C&&o(C)}return e.jsx(t.SortableContext,{items:s.map(p=>Ae(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"}),h.length>0&&e.jsx("div",{className:"mr-5",children:e.jsx(t.ComboBox2,{multiple:!1,options:h,selectedOptions:[],onChange:p=>x(p[0]),selectAllChecked:!1,onSelectAllCheckedChange:()=>{},inputClassName:"h-8 bg-muted border-none"})}),s.map(p=>{var C,T;return e.jsx(Ts,{id:Ae(p.columnId),type:Mt,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(es,{className:"size-3 cursor-move text-muted-foreground hover:text-foreground"}),e.jsx(Je,{className:"w-[175px] text-sm",children:((C=f(p.columnId))==null?void 0:C.label)||((T=f(p.columnId))==null?void 0:T.name)})]}),e.jsx("button",{title:p.direction==="asc"?"Ascending":"Descending",onClick:()=>y(p.columnId),className:"rounded-sm p-0",children:S(p.columnId,p.direction)})]}),e.jsx("div",{children:e.jsx("button",{onClick:()=>g(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)},Ae(p.columnId))})]})})}function tr(){const s=t.useEditorStore(g=>{var p;return((p=g.card.queryConfig)==null?void 0:p.groupByColumns)||[]}),a=t.useEditorStore(g=>g.card.type),n=t.useDndStore(g=>g.previewGroupByColumns),r=t.useEditorStore(g=>{var p;return((p=g.card.queryConfig)==null?void 0:p.metricColumns)||[]}),o=t.useDndStore(g=>g.previewMetricColumns),i=t.useEditorStore(g=>{var p;return((p=g.card.queryConfig)==null?void 0:p.pivotColumns)||[]}),l=t.useDndStore(g=>g.previewPivotColumns),{removeColumnFromGroupBy:u,removeColumnFromMetricColumns:c,removeColumnFromPivotBy:m}=t.useEditorActions();function d(g){u(g)}function h(g){c(g)}function S(g){m(g)}let f="Group By",y="Metrics",x="Stack By";return a==="table"&&(f="Rows",y="Metrics",x="Columns"),e.jsxs("div",{className:"flex h-full w-full flex-col gap-3 py-4",children:[e.jsx(bs,{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(ot,{onRemoveColumn:d,sortableType:_e,id:ge,label:f,columns:s,previewColumns:n}),e.jsx(ot,{onRemoveColumn:S,sortableType:$e,id:ye,label:x,columns:i,previewColumns:l}),e.jsx(ot,{onRemoveColumn:h,sortableType:ht,id:je,label:y,columns:r,previewColumns:o}),e.jsx(er,{})]}),e.jsx(t.ScrollBar,{orientation:"horizontal"})]})]})}function Rt({children:s,column:a,id:n,sortableType:r,className:o}){const[i,l]=L.useState(!1),{removeEditorFilter:u,clearEditorFilter:c}=t.useEditorActions(),m=t.useEditorStore(h=>{var S,f;return(f=(S=h.card.queryConfig)==null?void 0:S.filters)==null?void 0:f.some(y=>y.filterColumnName===a.name)});function d(h){u(h)}return e.jsx(Ts,{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}),m&&e.jsx("button",{onClick:()=>c(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:()=>d(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 sr({column:s,sortableType:a}){const n=t.useDashboardStore(T=>T.themeStyle),r=t.useEditorStore(T=>{var E,j;return(j=(E=T.card)==null?void 0:E.queryConfig)==null?void 0:j.filters}),o=t.useEditorStore(T=>{var E,j;return(j=(E=T.card.queryConfig)==null?void 0:E.filterColumns)==null?void 0:j.find(b=>b.name===s.name)}),{selectedConnectionId:i,selectedDatabaseName:l,selectedTableName:u}=t.useEditorAside(),c=L.useMemo(()=>{var T;return(T=r==null?void 0:r.find(E=>E.filterColumnName===s.name))==null?void 0:T.filterValue},[r,s.name]),m=L.useMemo(()=>Array.isArray(c)?c.map(T=>({id:T,value:T})):[],[c]),{updateEditorFilterValue:d}=t.useEditorActions(),h={column:s.name,sql:s.sql,id:s.name,connectionId:i,dataType:s.type},{data:S,isLoading:f,isFetching:y,isError:x}=t.useFilterQuery(h),g=L.useMemo(()=>{var E;return h.column?(E=S==null?void 0:S.records)==null?void 0:E.map(j=>{let b=h.column.split(".").slice(-1)[0].replace(/"/g,"");return j[b]===void 0&&(b=b.toLowerCase()),{id:j[b],value:j[b]}}):[]},[S,h.column]);function p(T){const E=T.map(j=>j.id);d(s.name,E)}function C(){return f||y?e.jsx(t.Skeleton,{style:{borderRadius:n==null?void 0:n.controlInputRadius},className:"h-8 min-w-60 bg-foreground/10"}):x?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(nr,{columnName:s.name}),showNegativeIndicator:(o==null?void 0:o.mode)==="exclude",options:g,onChange:p,selectedOptions:m,selectAllChecked:!1,onSelectAllCheckedChange:()=>{}})}return e.jsx(Rt,{className:"w-60",id:s.id,sortableType:a,column:s,children:C()})}function nr({columnName:s}){const{setEditorFilterMode:a}=t.useEditorActions(),n=t.useEditorStore(o=>{var i,l;return(l=(i=o.card.queryConfig)==null?void 0:i.filterColumns)==null?void 0:l.find(u=>u.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 ar({column:s,sortableType:a}){const[n,r]=L.useState(!1),{selectedConnectionId:o,selectedDatabaseName:i,selectedTableName:l}=t.useEditorAside(),u={column:s.name,sql:s.sql,id:s.name,connectionId:o,title:"",dataType:s.type},{isLoading:c,isFetching:m,isError:d,data:h}=t.useFilterQuery(u),S=h==null?void 0:h.records,{dateRange:f,setDateRange:y,initialDateRange:x}=t.useDateRangeFromRecords(S),{updateEditorFilterValue:g}=t.useEditorActions();function p(E){var b,v;const j={gte:(b=E==null?void 0:E.from)==null?void 0:b.toISOString(),lte:(v=E==null?void 0:E.to)==null?void 0:v.toISOString()};g(s.name,j)}function C(){g(s.name,null,!0),y(x)}function T(){return c||m?e.jsx("div",{children:e.jsx(t.Skeleton,{className:"h-8 w-72 bg-foreground/10"})}):d?e.jsx("div",{className:"h-8 w-72 bg-muted px-2",children:"Error"}):S?e.jsx(t.DateRangePopover,{title:u.title,open:n,inputClassName:"h-8",setOpen:r,dateRange:f,setDateRange:y,onApply:p,onClear:C}):e.jsx(t.Label,{className:"flex h-8 w-72 items-center bg-muted px-2",children:"No Data"})}return e.jsx(Rt,{className:"w-72",id:s.id,sortableType:a,column:s,children:T()})}function rr({id:s,label:a,columns:n,previewColumns:r,sortableType:o}){var y,x;const{setNodeRef:i,isOver:l,over:u}=t.useDroppable({id:s}),c=t.useDndStore(g=>g.activeId),m={},d=l||((x=(y=u==null?void 0:u.data)==null?void 0:y.current)==null?void 0:x.type)===o;function h(){if(!f||f.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 S(g){const p=t.isDateDataType(g.type);return g.id===ds.id?e.jsx(Rt,{id:g.id,sortableType:o,column:g,children:e.jsx(or,{})},g.id):p?e.jsx(ar,{droppableId:s,sortableType:o,column:g},g.id):e.jsx(sr,{droppableId:s,sortableType:o,column:g},g.id)}const f=c?r:n;return e.jsx(t.SortableContext,{items:n==null?void 0:n.map(g=>g.id),children:e.jsxs("div",{className:t.cn("group space-y-2 rounded-md border-muted-foreground/50 p-4",d&&"border border-muted-foreground/20"),ref:i,style:m,children:[e.jsx(t.Label,{className:"text-sm",children:a}),h(),e.jsx("div",{className:"flex flex-wrap items-center gap-4",children:f==null?void 0:f.map(g=>S(g))})]})})}function or(){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 ir(){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(rr,{onRemoveColumn:r,sortableType:pt,id:xt,label:"Filters",columns:s,previewColumns:a})})}function lr(){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(In,{className:"mr-2 h-4 w-4"}),"Assistant"]}),e.jsx(hs,{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 cr(){const s=L.useRef(null),a=L.useRef(null),n=t.useEditorStore(u=>u.isShowingVisual),r=t.useEditorStore(u=>u.showAIDialog),o=t.useEditorStore(u=>u.isDevMode);L.useEffect(()=>{var u,c,m,d;r?((u=s.current)==null||u.resize(0),(c=a.current)==null||c.resize(0)):((m=s.current)==null||m.resize(25),(d=a.current)==null||d.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(ia,{})}),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(Ha,{})})}),!r&&e.jsx(t.ResizableHandle,{}),e.jsx(t.ResizablePanel,{minSize:40,defaultSize:75,maxSize:100,children:e.jsx(Pe,{})})]}):e.jsx(Pe,{})})]})}function l(){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(tr,{})})}),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(lr,{}),e.jsx(ir,{})]}),e.jsx(t.ResizableHandle,{}),e.jsx(t.ResizablePanel,{minSize:60,defaultSize:80,children:e.jsx(Pe,{})})]})})]}):e.jsx(Pe,{})})})}return e.jsx(t.ResizablePanelGroup,{direction:"vertical",className:"min-h-[250px] min-w-full max-w-lg",children:o?i():l()})}function dr(s,a){const[n,r]=L.useState(""),[o,i]=L.useState(null),{authToken:l}=t.useSemaphorContext(),u=t.useEditorStore($=>{var Q;return(Q=$==null?void 0:$.card)==null?void 0:Q.sql}),c=t.useEditorStore($=>$.isDevMode),m=t.useEditorStore($=>{var Q;return(Q=$==null?void 0:$.card)==null?void 0:Q.python}),{setCardPython:d,setCardSql:h,setRunSql:S,switchCardType:f,setQueryConfig:y}=t.useEditorActions(),x=t.useEditorStore($=>$.currentAssitantScope)||[],g=t.useEditorStore($=>$.userInputForAI),p=t.useEditorStore($=>$.triggerAIRun),C=t.useEditorStore($=>$.card),T=t.useEditorStore($=>$.selectedDatabaseName),E=t.useEditorStore($=>$.selectedTableName),j=t.useEditorStore($=>$.selectedConnectionId),b=t.useEditorStore($=>$.selectedSchemaName),v=t.useDashboardStore($=>$.dashboard.aiScopeTables),{errorMessage:w,refetch:I,data:D}=t.useDashboardCardQuery(C),{setTriggerAIRun:N,setCurrentAssitantScope:F,setCardConfig:O}=t.useEditorActions(),{selectedDatamodelName:A,connectionType:k,selectedDatamodelId:M}=t.useEditorAside(),{messages:B,setMessages:z,reload:P,error:R,append:K,input:J,setInput:_,status:U,handleInputChange:q,handleSubmit:V,stop:G}=t.useChat({api:"https://semaphor.cloud/api/v1/assistant",headers:{Authorization:`Bearer ${l==null?void 0:l.accessToken}`},body:{random:Math.random(),assistantId:"editor-assistant",isDevMode:c,aiContext:s},maxSteps:10,onError:$=>{console.log("on error",$)},onToolCall:H,onFinish($,Q){Y(Q.usage),r(""),Q.finishReason==="stop"&&r("")}});L.useEffect(()=>{p&&g&&(q({target:{value:g}}),setTimeout(()=>{V(),N(!1)},100))},[p,V,g,N,q]);async function H({toolCall:$}){var Q,he,we,Me;if(["createChartFromSql","createForecast"].includes($.toolName)){const W=$.args.sql,se=$.args.python,ne=$.args.chartType;return f(ne),h(W),d(se),S(!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 u?{status:"success",sql:u,python:m||""}:{status:"error",message:"No SQL found"};if($.toolName==="getCurrentTableScope")return r("Getting table scope..."),pe(),{status:"success",tables:x};if($.toolName==="generateQueryConfig"){r("Generating query config...");const W=$.args.chartType,se=$.args.queryConfig;$.args.cardConfig,f(W),O(se),h(void 0),d(void 0);const ne=await I();return(Q=ne==null?void 0:ne.data)!=null&&Q.error?{status:"error",queryConfig:se,message:(he=ne==null?void 0:ne.data)==null?void 0:he.error.message}:(we=ne==null?void 0:ne.data)!=null&&we.records?{status:"success",queryConfig:se,message:"The data has been visualized"}:{status:"success",queryConfig:se,message:"The data has been visualized",records:(Me=ne==null?void 0:ne.data)==null?void 0:Me.records}}else r("Analyzing...")}}function Y($){i(Q=>Q?{promptTokens:Q.promptTokens+$.promptTokens,completionTokens:Q.completionTokens+$.completionTokens,totalTokens:Q.totalTokens+$.totalTokens}:$)}function Z($){const Q=t.removeFromScopeArray(x,$);ae(Q)}function ae($){const Q=t.sanitizeAIScope($);F(Q),z(he=>[...he,{id:crypto.randomUUID(),role:"system",content:`Current scope of tables. Always use the table reference format when generating SQL | ${JSON.stringify(Q)}`}])}function Ne(){const $={databaseName:T||"",schemaName:b||"",tableName:E||"",datamodelId:M||"",datamodelName:t.resolveDatamodelName(A),connectionId:j||"",connectionType:k||""},Q=t.dedup([...x,$]);ae(Q)}function pe(){const $={databaseName:T||"",schemaName:b||"",tableName:E||"",datamodelName:t.resolveDatamodelName(A),connectionId:j||"",connectionType:k||"",datamodelId:M||""};if(!t.isInAiScopeArray([...v||[],...x],$)||x.length===0){const he=t.dedup([...v||[],...x,$]).filter(we=>we.connectionId===$.connectionId);ae(he)}}const Ce=!["ready","error"].includes(U),Se=t.getErrorMessage(R);return{messages:B,setMessages:z,reload:P,append:K,input:J,setInput:_,isLoading:Ce,handleSetAIScope:pe,handleAddCurrentTableToScope:Ne,removeFromCurrentSelections:Z,currentAssitantScope:x,setCurrentAssitantScope:F,handleInputChange:q,handleSubmit:V,stop:G,chatStatus:U,toolStatus:n,llmUsage:o,onFinish:a,errorMessage:Se}}const ur=[{title:"Help me write a query for",subtitle:"orders by month"},{title:"Create a bar chart for",subtitle:"sales by category"}];function Kt(){const s=L.useRef(null),a=L.useRef(null),[n,r]=L.useState(!1),[o,i]=L.useState(t.isDevEnv),[l,u]=L.useState(!1),[c,m]=L.useState(!1),[d,h]=L.useState({selectedEntities:[]}),S=t.useDashboardStore(G=>G.dashboard.aiContext),f=t.useEditorStore(G=>G.card.dataSource),y=t.useEditorStore(G=>G.actions.setCardSql),x=t.useEditorStore(G=>G.actions.setRunSql),g=t.useEditorStore(G=>G.showAIDialog),p=t.useDashboardStore(G=>G.handleOpenAssistantProfile),{setShowAIDialog:C,setCardPython:T}=t.useEditorActions(),{setDataSource:E}=t.useEditorActions(),{assistantProfile:j}=t.useAssistantProfile(),{messages:b,setMessages:v,reload:w,append:I,input:D,setInput:N,isLoading:F,handleInputChange:O,handleSubmit:A,stop:k,chatStatus:M,llmUsage:B,errorMessage:z}=dr(d);t.useAssistantScroll({scrollContainerRef:s,inputRef:a,messages:b}),L.useEffect(()=>{var G;g&&((G=a.current)==null||G.focus(),h({selectedEntities:(f==null?void 0:f.selectedEntities)||[]}))},[g,f]);function P(G,H){H==="sql"?(y(G),x(!0)):H==="python"&&(T(G),x(!0))}function R(){var G;(G=S==null?void 0:S.selectedEntities)==null||G[0],m(!0)}function K(){d.selectedEntities.length===0&&h({selectedEntities:(S==null?void 0:S.selectedEntities)||[]})}function J(G){K();const H={role:"user",content:G.title+" "+G.subtitle};I(H)}function _(G){K(),I({role:"user",content:G})}function U(){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:l,onCheckedChange:u,children:"System Message"})]})]})}function q(){return e.jsx("div",{"data-role":"header",children:e.jsx("div",{className:"text-lg font-semibold",children:"Assistant"})})}const V=(D==null?void 0:D.length)===0&&(b==null?void 0:b.filter(G=>G.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:[q(),p&&e.jsx(t.Button,{variant:"outline",size:"sm",className:"h-7 p-2",onClick:p,children:(j==null?void 0:j.name)||"Default Profile"}),e.jsxs("div",{"data-role":"header-actions",className:"flex items-center gap-2",children:[U(),e.jsx(t.IconButton,{tooltip:"Add Context",className:"h-7 p-2",onClick:R,children:e.jsx(t.Settings,{className:"size-4"})}),e.jsx(t.IconButton,{className:"h-7 p-2",tooltip:"New Chat",onClick:()=>{v([]),w()},children:e.jsx(t.SquarePen,{className:"size-4"})}),e.jsx(t.Button,{variant:"ghost",className:"h-8",size:"sm",onClick:()=>{C(!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:b,showTools:o,handleRun:P,showSystemMessage:l}),e.jsx(t.ChatStatus,{messages:b,chatStatus:M,errorMessage:z})]})}),e.jsxs("div",{className:"mb-3",children:[V&&!j&&e.jsx(t.Placeholders,{onClick:J,placeholders:ur}),e.jsx("div",{children:V&&j&&e.jsx(t.SeedQuestions,{seedQuestions:j.seedQuestions||[],handleSeedQuestionClick:_})})]}),e.jsx(t.ChatInputWithContext,{ref:a,setInput:N,stop:k,input:D,localAiContext:d,setLocalAiContext:h,handleInputChange:O,handleSubmit:G=>{K(),A(G)},isLoading:F,onFocus:()=>{}}),B&&n&&e.jsx("div",{className:"flex h-8 items-center justify-between",children:e.jsxs("div",{className:"text-xs text-muted-foreground",children:["Usage: ",B.promptTokens," prompt tokens,"," ",B.completionTokens," completion tokens,"," ",B.totalTokens," total tokens"]})}),e.jsx(t.DataSourceDialog,{incomingSelectedEntities:(f==null?void 0:f.selectedEntities)||[],open:c,onOpenChange:m,dataSource:f||t.EMPTY_DATA_SOURCE,fallbackDataSource:t.EMPTY_DATA_SOURCE,dialogMode:"aiContext"})]})}function mr(s){return s.flatMap(a=>a.columns.map(n=>({id:`${a.entityId}-${n.name}`,name:n.name,dataType:n.dataType,qualifiedEntityName:a.qualifiedEntityName,label:n.label||t.toTitleCase(n.name),description:n.description,entityId:a.entityId,entityName:a.entityName,entityType:a.entityType})))}function ft(s){if(s.type==="table"||s.type==="view"){if(s.database&&s.schema)return`${s.database}.${s.schema}.${s.name}`;if(s.database)return`${s.database}.${s.name}`}return s.name}function ze(s){var x;const a=t.useDashboardStore(g=>g.authToken)||s,{hasSchemaSupport:n}=t.useSelectedConnection(s),r=t.useEditorStore(g=>{var p;return(p=g.card.dataSource)==null?void 0:p.connectionId}),o=t.useEditorStore(g=>{var p,C;return(C=(p=g.card.dataSource)==null?void 0:p.selectedEntities)==null?void 0:C.filter(T=>T.type==="model")})||[],i=t.useEditorStore(g=>{var p,C;return(C=(p=g.card.dataSource)==null?void 0:p.selectedEntities)==null?void 0:C.filter(T=>T.type==="table"||T.type==="view")})||[],l=t.useEditorStore(g=>{var p,C;return(C=(p=g.card.dataSource)==null?void 0:p.selectedEntities)==null?void 0:C.filter(T=>T.type==="dataset")})||[];function u(g){return g.type==="dataset"?!!r&&!!g.domainId&&!!g.name:g.type==="model"?!!r&&!!g.id:g.type==="table"||g.type==="view"?n?!!r&&!!g.name&&!!g.database&&!!g.schema:!!r&&!!g.name&&!!g.database:!1}const c=[...o,...i,...l],m=Ps({queries:c.map(g=>{let p={};return g.type==="model"?p={connection_id:r,datamodel_id:g.id,database_name:"",schema_name:"",table_name:"",domain_id:g.domainId,dataset_name:g.name}:g.type==="dataset"?p={connection_id:g.connectionId,domain_id:g.domainId,dataset_name:g.name}:p={connection_id:r,datamodel_id:"",database_name:g.database,schema_name:g.schema,table_name:g.name},{queryKey:["columns",r,g],queryFn:()=>t.getRequest("https://semaphor.cloud/api/v1/columns",(a==null?void 0:a.accessToken)||"",p),enabled:!!r&&u(g)}})}),d=m.some(g=>g.isPending),h=m.some(g=>g.isError),S=(x=m.find(g=>g.isError))==null?void 0:x.error,f=m.map((g,p)=>{var E;const C=c[p],T=ft(C);return{entityId:C.id||C.name,entityType:C.type,entityName:C.name,label:C.label,description:C.description,qualifiedEntityName:T,columns:(E=g.data)==null?void 0:E.columns.map(j=>({id:`${C.name}-${j.column_name}`,name:j.column_name,dataType:j.data_type,label:j.label||t.toLabel(j.column_name),description:j.description||"",qualifiedEntityName:T,entityId:C.id||C.id||C.name,entityName:C.name,entityType:C.type}))}}).filter(g=>{var p;return((p=g==null?void 0:g.columns)==null?void 0:p.length)>0})||[],y=mr(f);return{columnGroups:f,columns:y,isLoading:d,hasError:h,error:S,refetch:()=>{m.forEach(g=>g.refetch())}}}function hr({field:s}){const{attributes:a,listeners:n,setNodeRef:r,transform:o,transition:i,isDragging:l}=t.useSortable({id:s.id}),[u,c]=L.useState(!1),m={transform:t.CSS.Transform.toString(o),transition:i},d=t.getDataType(s.dataType),S=(f=>{const y=(f||"").toLowerCase();switch(t.getDataType(y)){case"number":return St;case"date":return t.Calendar;case"boolean":return as;case"json":return rn;case"geo":return kn;default:return rs}})(s.dataType);return e.jsxs("div",{ref:r,style:m,...a,...n,className:`group/container overflow-hidden rounded-lg transition-all ${l?"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:()=>c(!u),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(S,{className:t.cn("size-3.5 flex-shrink-0 text-gray-500",d==="string"?"text-blue-500":"",d==="number"?"text-green-500":"",d==="date"?"text-purple-500":"",d==="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 dark:text-muted-foreground ${u?"whitespace-normal break-words":"truncate"}`,children:s.name})})}),e.jsx(t.TooltipContent,{side:"right",className:"max-w-xs",children:e.jsxs("div",{className:"overflow-x-auto",children:[e.jsxs("div",{className:"flex items-center justify-between gap-2",children:[e.jsx("p",{className:t.cn("font-medium",{"text-blue-500":d==="string","text-green-500":d==="number","text-purple-500":d==="date","text-orange-500":d==="boolean"}),children:s.label||s.name}),e.jsx("p",{className:t.cn("pr-0.5 text-xs font-normal italic text-gray-500"),children:s.dataType})]}),s.description&&e.jsx("div",{className:"mt-1 text-sm text-muted-foreground",children:s.description}),e.jsx("div",{className:"mt-2 text-xs italic text-muted-foreground",children:s.qualifiedEntityName?`${s.qualifiedEntityName}.${s.name}`:s.name})]})})]})}),e.jsx("button",{onClick:f=>{f.stopPropagation(),c(!u)},className:"invisible flex-shrink-0 text-gray-400 hover:text-gray-600 group-hover/container:visible",children:u?e.jsx(t.ChevronDown,{className:"h-4 w-4"}):e.jsx(t.ChevronRight,{className:"h-4 w-4"})})]}),u&&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(ns,{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(Fn,{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 xr({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(hr,{field:o},o.id))})})]})}function pr(){const[s,a]=L.useState(""),[n,r]=L.useState(new Set),[o,i]=L.useState("all"),l=t.useEditorStore(E=>E.card.dataSource),{columns:u=[],columnGroups:c=[],isLoading:m,error:d}=ze(),h=u.filter(E=>E.name.toLowerCase().includes(s.toLowerCase())||E.dataType.toLowerCase().includes(s.toLowerCase())||E.qualifiedEntityName&&E.qualifiedEntityName.toLowerCase().includes(s.toLowerCase())),S=E=>E.dataType==="number"||E.dataType==="integer"||E.dataType==="float"||E.dataType==="decimal"||E.dataType==="currency"?"metrics":"dimensions",y=(o==="all"?h:h.filter(E=>S(E)===o)).reduce((E,j)=>{const b=j.qualifiedEntityName||"Other Fields";return E[b]||(E[b]={label:t.toLabel(j.entityName),fields:[]}),E[b].fields.push(j),E},{});L.useEffect(()=>{const E=Object.keys(y);r(new Set(E))},[Object.keys(y).join(",")]);const x=E=>{const j=new Set(n);j.has(E)?j.delete(E):j.add(E),r(j)},g=h.filter(E=>S(E)==="dimensions").length,p=h.filter(E=>S(E)==="metrics").length,C=h.filter(E=>S(E)==="calculated").length,T=h.length>0;return m?e.jsxs("div",{className:"flex h-[calc(100vh-200px)] w-[290px] flex-col items-center justify-center",children:[e.jsx(ue,{className:"h-8 w-8 animate-spin text-gray-400"}),e.jsx("span",{className:"mt-2 text-sm text-gray-500",children:"Loading fields..."})]}):d?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:d.message||"Failed to load column data"})]}):!l||!l.selectedEntities||l.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:[u.length>0&&e.jsx("div",{className:"mb-4",children:e.jsx(t.Input$1,{type:"text",placeholder:"Search fields...",value:s,onChange:E=>a(E.target.value)})}),T&&e.jsx(t.Tabs,{defaultValue:"all",value:o,onValueChange:E=>i(E),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:h.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:g})]}),e.jsxs(t.TabsTrigger,{value:"metrics",className:"text-xs",children:[e.jsx(jt,{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(en,{className:"size-4 shrink-0"}),e.jsx("span",{className:"ml-2 text-xs font-semibold",children:C})]})]})})]}),e.jsxs(t.CustomScrollArea,{className:"py-2",children:[e.jsxs("div",{className:"space-y-2",children:[Object.entries(y).map(([E,j])=>{const b=c.find(v=>v.entityName===E)||{entityName:E,label:j.label};return e.jsx(xr,{entityGroup:b,fields:j.fields,isOpen:n.has(E),onToggle:()=>x(E)},E)}),Object.keys(y).length===0&&u.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(y).length===0&&u.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 fr(){return e.jsxs("div",{className:" h-full flex flex-col items-center",children:[" ",e.jsx(pr,{})," "]})}function gr({initialJoinPlan:s,availableDataSources:a}){const[n,r]=L.useState(s),[o,i]=L.useState(new Set),l=()=>{const b=n.joins.length>0?Math.max(...n.joins.map(w=>w.sequence))+1:1,v={id:`join-${Date.now()}`,source:{type:"table",name:"",database:"",schema:""},target:{type:"table",name:"",database:"",schema:""},joinType:"INNER",sequence:b,joinKeyGroups:[{id:"group-"+Date.now()+"-"+Math.random().toString(36).substr(2,9),operator:"AND",keys:[]}]};r({...n,joins:[...n.joins,v]}),i(new Set([...o,v.id]))},u=b=>{r({...n,joins:n.joins.filter(v=>v.id!==b)}),i(new Set([...o].filter(v=>v!==b)))},c=(b,v)=>{var N,F;const w=n.joins.find(O=>O.id===b);if(!w)return;const I={...w,...v},D=n.joins.map(O=>O.id===b?I:O);if((N=I.source)!=null&&N.name&&((F=I.target)!=null&&F.name)&&I.joinKeyGroups[0].keys.length===0){const O=a.find(B=>{var z;return B.name===((z=I.source)==null?void 0:z.name)}),A=a.find(B=>{var z;return B.name===((z=I.target)==null?void 0:z.name)}),k={id:`key-${Date.now()}`,source:{id:`source-${Date.now()}`,name:"",dataType:"",label:"",entityId:(O==null?void 0:O.name)||"",entityName:(O==null?void 0:O.name)||"",entityType:(O==null?void 0:O.type)||"table"},target:{id:`target-${Date.now()}`,name:"",dataType:"",label:"",entityId:(A==null?void 0:A.name)||"",entityName:(A==null?void 0:A.name)||"",entityType:(A==null?void 0:A.type)||"table"},operator:"="},M=[...I.joinKeyGroups];M[0]={...M[0],keys:[k]},I.joinKeyGroups=M,D[D.findIndex(B=>B.id===b)]=I}r({...n,joins:D})};return{joinPlan:n,expandedJoins:o,setJoinPlan:r,addJoin:l,removeJoin:u,updateJoin:c,moveJoinUp:b=>{const v=n.joins.findIndex(w=>w.id===b);if(v>0){const w=[...n.joins],I={...w[v]},D={...w[v-1]};w[v]=D,w[v-1]=I,w.forEach((F,O)=>{F.sequence=O+1});const N={...n,joins:w};r(N)}},moveJoinDown:b=>{const v=n.joins.findIndex(w=>w.id===b);if(v<n.joins.length-1){const w=[...n.joins],I={...w[v]},D={...w[v+1]};w[v]=D,w[v+1]=I,w.forEach((F,O)=>{F.sequence=O+1});const N={...n,joins:w};r(N)}},toggleJoinExpansion:b=>{const v=new Set(o);v.has(b)?v.delete(b):v.add(b),i(v)},getAvailableSourceEntities:b=>{if(n.joins.length===0)return a;const v=n.joins.findIndex(I=>I.id===b);if(v===0)return a;const w=new Set;return n.baseEntity.name&&w.add(n.baseEntity.name),n.joins.slice(0,v).forEach(I=>{w.add(I.source.name),w.add(I.target.name)}),a.filter(I=>w.has(I.name))},getAvailableTargetEntities:b=>a.filter(v=>v.name!==b),addJoinKeyGroup:b=>{const v=n.joins.find(I=>I.id===b);if(!v)return;const w=[...v.joinKeyGroups,{id:"group-"+Date.now()+"-"+Math.random().toString(36).substr(2,9),operator:"AND",keys:[]}];c(b,{joinKeyGroups:w})},updateGroupOperator:(b,v,w)=>{const I=n.joins.find(N=>N.id===b);if(!I)return;const D=[...I.joinKeyGroups];D[v]={...D[v],operator:w},c(b,{joinKeyGroups:D})},removeJoinKeyGroup:(b,v)=>{const w=n.joins.find(D=>D.id===b);if(!w)return;const I=[...w.joinKeyGroups];I.splice(v,1),c(b,{joinKeyGroups:I})},addJoinKey:(b,v)=>{const w=n.joins.find(O=>O.id===b);if(!w)return;const I=a.find(O=>O.name===w.source.name),D=a.find(O=>O.name===w.target.name),N=[...w.joinKeyGroups],F={id:`key-${Date.now()}`,source:{id:`source-${Date.now()}`,name:"",dataType:"",label:"",entityId:(I==null?void 0:I.name)||"",entityName:(I==null?void 0:I.name)||"",entityType:(I==null?void 0:I.type)||"table"},target:{id:`target-${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"},operator:"="};N[v]={...N[v],keys:[...N[v].keys,F]},c(b,{joinKeyGroups:N})},updateJoinKey:(b,v,w,I,D)=>{const N=n.joins.find(M=>M.id===b);if(!N)return;const F=a.find(M=>M.name===N.source.name),O=a.find(M=>M.name===N.target.name),A=[...N.joinKeyGroups],k=A[v].keys[w];I==="sourceColumnName"&&F?A[v].keys[w]={...k,source:{...k.source,name:D}}:I==="targetColumnName"&&O?A[v].keys[w]={...k,target:{...k.target,name:D}}:I==="operator"&&(A[v].keys[w]={...k,operator:D}),c(b,{joinKeyGroups:A})},removeJoinKey:(b,v,w)=>{const I=n.joins.find(N=>N.id===b);if(!I)return;const D=[...I.joinKeyGroups];D[v].keys.splice(w,1),c(b,{joinKeyGroups:D})},generateSQLPreview:()=>{const b=[...n.joins].sort((I,D)=>I.sequence-D.sequence),v=n.baseEntity;if(!v.name)return"SELECT * FROM table -- Please select a base entity";let w=`SELECT *
400
400
  FROM ${v.name}`;return b.forEach(I=>{const D=a.find(O=>O.name===I.target.name);if(!D)return;const N=I.joinKeyGroups.filter(O=>O.keys&&O.keys.length>0).map(O=>{const A=O.keys.filter(k=>{var M,B,z,P;return((M=k.source)==null?void 0:M.name)&&((B=k.target)==null?void 0:B.name)&&((z=k.source)==null?void 0:z.entityName)&&((P=k.target)==null?void 0:P.entityName)}).map(k=>`${k.source.entityName}.${k.source.name} ${k.operator} ${k.target.entityName}.${k.target.name}`);return A.length>1?`(${A.join(` ${O.operator} `)})`:A[0]}).filter(Boolean),F=N.length>1?N.join(" OR "):N[0]||"condition_here";w+=`
401
401
  ${I.joinType} JOIN ${D.name}
402
402
  ON ${F}`}),w},isValidConfiguration:()=>!(!n.baseEntity.name||n.joins.some(I=>!I.source.name||!I.target.name)||n.joins.some(I=>I.joinKeyGroups.some(D=>D.keys.length===0))||n.joins.some(I=>I.joinKeyGroups.some(D=>D.keys.some(N=>!N.source.name||!N.target.name||!N.operator))))}}function jr({joinPlan:s,availableDataSources:a,onSave:n,onRemove:r,onCancel:o}){const{setCardConfig:i}=t.useEditorActions();t.useEditorStore(N=>N.card.config);const{columnGroups:l}=ze(),{joinPlan:u,expandedJoins:c,setJoinPlan:m,addJoin:d,removeJoin:h,updateJoin:S,moveJoinUp:f,moveJoinDown:y,toggleJoinExpansion:x,getAvailableSourceEntities:g,getAvailableTargetEntities:p,addJoinKeyGroup:C,updateGroupOperator:T,removeJoinKeyGroup:E,addJoinKey:j,updateJoinKey:b,removeJoinKey:v,generateSQLPreview:w,isValidConfiguration:I}=gr({initialJoinPlan:s,availableDataSources:a}),D=N=>{const F=l.find(O=>O.entityName===N);return(F==null?void 0:F.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:u.baseEntity.name,onValueChange:N=>{const F=a.find(O=>O.name===N);m({...u,baseEntity:{connectionId:(F==null?void 0:F.connectionId)||"",connectionType:(F==null?void 0:F.connectionType)||"none",type:(F==null?void 0:F.type)||"table",name:N,database:F==null?void 0:F.database,schema:F==null?void 0:F.schema}})},children:[e.jsx(t.SelectTrigger,{children:e.jsx(t.SelectValue,{placeholder:"Select base entity..."})}),e.jsx(t.SelectContent,{children:a.map(N=>e.jsx(t.SelectItem,{value:N.name,children:e.jsxs("div",{className:"flex items-center gap-2",children:[e.jsx(t.Badge,{variant:"outline",className:"text-xs",children:N.type}),N.name,e.jsx(t.Badge,{variant:"outline",className:"text-xs text-green-600",children:"BASE"})]})},N.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:w()})]}),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 (",u.joins.length,")"]}),e.jsx("div",{className:"flex items-center gap-2",children:e.jsxs(t.Button,{variant:"outline",size:"sm",onClick:d,children:[e.jsx(t.Plus,{className:"mr-1 h-4 w-4"}),"Add Join"]})})]}),u.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:u.joins.map(N=>{const F=a.find(k=>k.name===N.source.name),O=a.find(k=>k.name===N.target.name),A=c.has(N.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:N.sequence}),e.jsxs(t.CardTitle,{className:"text-sm",children:["Join ",N.sequence,F&&O&&e.jsxs("span",{className:"ml-2 font-normal text-gray-600",children:["(",F.name," → ",O.name,")"]})]})]}),e.jsxs("div",{className:"flex items-center gap-2",children:[e.jsx(t.Button,{variant:"ghost",size:"sm",onClick:()=>f(N.id),disabled:N.sequence===1,children:e.jsx(Ye,{className:"h-4 w-4"})}),e.jsx(t.Button,{variant:"ghost",size:"sm",onClick:()=>y(N.id),disabled:N.sequence===u.joins.length,children:e.jsx(Ue,{className:"h-4 w-4"})}),e.jsx(t.Button,{variant:"ghost",size:"sm",onClick:()=>x(N.id),children:A?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:()=>h(N.id),children:e.jsx(t.X,{className:"h-4 w-4"})})]})]})}),A&&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:N.source.name,onValueChange:k=>{const M=a.find(B=>B.name===k);S(N.id,{source:{connectionId:(M==null?void 0:M.connectionId)||"",connectionType:(M==null?void 0:M.connectionType)||"none",type:(M==null?void 0:M.type)||"table",name:k,database:M==null?void 0:M.database,schema:M==null?void 0:M.schema}})},children:[e.jsx(t.SelectTrigger,{children:e.jsx(t.SelectValue,{placeholder:"Select source..."})}),e.jsx(t.SelectContent,{children:g(N.id).map(k=>e.jsx(t.SelectItem,{value:k.name,children:e.jsxs("div",{className:"flex items-center gap-2",children:[e.jsx(t.Badge,{variant:"outline",className:"text-xs",children:k.type}),k.name]})},k.name))})]})]}),e.jsxs("div",{className:"space-y-2",children:[e.jsx(t.Label,{children:"Join Type"}),e.jsxs(t.Select,{value:N.joinType,onValueChange:k=>S(N.id,{joinType:k}),children:[e.jsx(t.SelectTrigger,{children:e.jsx(t.SelectValue,{})}),e.jsxs(t.SelectContent,{children:[e.jsx(t.SelectItem,{value:"INNER",children:"INNER JOIN"}),e.jsx(t.SelectItem,{value:"LEFT",children:"LEFT JOIN"}),e.jsx(t.SelectItem,{value:"RIGHT",children:"RIGHT JOIN"}),e.jsx(t.SelectItem,{value:"FULL",children:"FULL JOIN"})]})]})]}),e.jsxs("div",{className:"space-y-2",children:[e.jsx(t.Label,{children:"Target"}),e.jsxs(t.Select,{value:N.target.name,onValueChange:k=>{const M=a.find(B=>B.name===k);S(N.id,{target:{connectionId:(M==null?void 0:M.connectionId)||"",connectionType:(M==null?void 0:M.connectionType)||"none",type:(M==null?void 0:M.type)||"table",name:k,database:M==null?void 0:M.database,schema:M==null?void 0:M.schema}})},disabled:!N.source.name,children:[e.jsx(t.SelectTrigger,{children:e.jsx(t.SelectValue,{placeholder:"Select target..."})}),e.jsx(t.SelectContent,{children:N.source.name?p(N.source.name).map(k=>e.jsx(t.SelectItem,{value:k.name,children:e.jsxs("div",{className:"flex items-center gap-2",children:[e.jsx(t.Badge,{variant:"outline",className:"text-xs",children:k.type}),k.name,k.name===N.source.name&&e.jsx(t.Badge,{variant:"outline",className:"text-xs text-yellow-600",children:"(Self-join)"})]})},k.name)):[]})]})]})]}),N.source.name&&N.target.name&&F&&O&&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:()=>C(N.id),children:[e.jsx(t.Plus,{className:"mr-1 h-3 w-3"})," Add Condition Group"]})]}),N.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:N.joinKeyGroups.map((k,M)=>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 ",M+1]}),M>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:k.operator,onValueChange:B=>T(N.id,M,B),children:[e.jsx(t.SelectTrigger,{className:"w-[100px]",children:e.jsx(t.SelectValue,{})}),e.jsxs(t.SelectContent,{children:[e.jsx(t.SelectItem,{value:"AND",children:"AND"}),e.jsx(t.SelectItem,{value:"OR",children:"OR"})]})]}),e.jsx(t.Button,{type:"button",variant:"ghost",size:"sm",onClick:()=>E(N.id,M),children:e.jsx(t.Trash2,{className:"h-4 w-4"})})]})]}),e.jsxs("div",{className:"space-y-2",children:[k.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:k.keys.map((B,z)=>e.jsxs("div",{className:"flex flex-col items-start gap-2 rounded-md border p-2 sm:flex-row sm:items-center",children:[z>0&&e.jsx("div",{className:"self-center rounded-md bg-gray-100 px-2 py-1 text-xs font-medium",children:k.operator}),e.jsx("div",{className:"mb-2 w-full sm:mb-0 sm:flex-1",children:e.jsxs(t.Select,{value:B.source.name,onValueChange:P=>b(N.id,M,z,"sourceColumnName",P),children:[e.jsx(t.SelectTrigger,{children:e.jsx(t.SelectValue,{placeholder:"Source column"})}),e.jsx(t.SelectContent,{children:D(N.source.name).map(P=>e.jsx(t.SelectItem,{value:P.name,children:e.jsxs("div",{className:"flex w-full items-center justify-between",children:[e.jsx("span",{children:P.name}),e.jsx(t.Badge,{variant:"outline",className:"ml-2 text-xs",children:P.dataType})]})},P.name))})]})}),e.jsx("div",{className:"mb-2 w-full sm:mb-0 sm:w-20",children:e.jsxs(t.Select,{value:B.operator,onValueChange:P=>b(N.id,M,z,"operator",P),children:[e.jsx(t.SelectTrigger,{children:e.jsx(t.SelectValue,{})}),e.jsxs(t.SelectContent,{children:[e.jsx(t.SelectItem,{value:"=",children:"="}),e.jsx(t.SelectItem,{value:"<",children:"<"}),e.jsx(t.SelectItem,{value:">",children:">"}),e.jsx(t.SelectItem,{value:"<=",children:"<="}),e.jsx(t.SelectItem,{value:">=",children:">="})]})]})}),e.jsx("div",{className:"mb-2 w-full sm:mb-0 sm:flex-1",children:e.jsxs(t.Select,{value:B.target.name,onValueChange:P=>b(N.id,M,z,"targetColumnName",P),children:[e.jsx(t.SelectTrigger,{children:e.jsx(t.SelectValue,{placeholder:"Target column"})}),e.jsx(t.SelectContent,{children:D(N.target.name).map(P=>e.jsx(t.SelectItem,{value:P.name,children:e.jsxs("div",{className:"flex w-full items-center justify-between",children:[e.jsx("span",{children:P.name}),e.jsx(t.Badge,{variant:"outline",className:"ml-2 text-xs",children:P.dataType})]})},P.name))})]})}),e.jsx(t.Button,{type:"button",variant:"ghost",size:"sm",className:"self-center",onClick:()=>v(N.id,M,z),children:e.jsx(t.X,{className:"size-3.5"})})]},B.id||z))}),e.jsxs(t.Button,{type:"button",variant:"outline",size:"sm",className:"mt-2",onClick:()=>j(N.id,M),children:[e.jsx(t.Plus,{className:"mr-1 h-3 w-3"})," Add Condition"]})]})]},k.id))})]})]})]},N.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(u),disabled:!I(),children:"Save"})]})]})}function Qt({children:s,open:a,onOpenChange:n,joinPlan:r,availableDataSources:o,onRemove:i,onSave:l,onCancel:u}){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(jr,{joinPlan:r,availableDataSources:o,onSave:l,onCancel:u,onRemove:i})]}),s]})}function yr({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((l,u)=>l.sequence-u.sequence),i=n.find(l=>l.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(l=>{const u=n.find(c=>c.name===l.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:l.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:u==null?void 0:u.type}),e.jsx("span",{className:"text-xs font-medium",children:u==null?void 0:u.name})]})]},l.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 l=n.find(c=>c.name===o.source.name),u=n.find(c=>c.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:[l==null?void 0:l.name," → ",u==null?void 0:u.name]}),e.jsxs(t.Badge,{variant:"outline",className:"ml-auto text-xs",children:[o.joinKeyGroups.reduce((c,m)=>c+m.keys.length,0)," ","condition",o.joinKeyGroups.reduce((c,m)=>c+m.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 br(){var h,S;ze(),t.useEditorStore(f=>f.card.dataSource);const s=t.useEditorStore(f=>f.frame),a=t.useEditorStore(f=>f.card),n=t.useEditorStore(f=>f.actions.updateCardConfig),r=((h=a==null?void 0:a.config)==null?void 0:h.joinPlan)||{baseEntity:{type:"table",name:"",database:"",schema:"",connectionId:"",connectionType:"none",dialect:"none"},joins:[]},[o,i]=L.useState(!1),l=((S=a==null?void 0:a.dataSource)==null?void 0:S.selectedEntities)||[],u=f=>{s.activeCardId&&(n(s.activeCardId,{...a==null?void 0:a.config,joinPlan:f}),i(!1))},c=()=>{n(s.activeCardId,{...a==null?void 0:a.config,joinPlan:void 0})},m=()=>{i(!1)},d=()=>{const f=[...r.joins].sort((g,p)=>g.sequence-p.sequence),y=r.baseEntity;if(!y.name)return"SELECT * FROM table -- Please select a base entity";let x=`SELECT *